From a05258f40f1523437dbb4a89796176dbabe3f918 Mon Sep 17 00:00:00 2001 From: Shane Riley Date: Tue, 30 Jun 2020 12:10:12 -0400 Subject: [PATCH] Updates BrowserFS --- browserfs.min.js | 22 ++++++++-------------- browserfs.min.js.map | 2 +- 2 files changed, 9 insertions(+), 15 deletions(-) diff --git a/browserfs.min.js b/browserfs.min.js index 17d22bea..209bc378 100644 --- a/browserfs.min.js +++ b/browserfs.min.js @@ -1,14 +1,8 @@ -!function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e():"function"==typeof define&&define.amd?define([],e):"object"==typeof exports?exports.BrowserFS=e():t.BrowserFS=e()}(this,function(){return function(t){function e(r){if(n[r])return n[r].exports;var i=n[r]={exports:{},id:r,loaded:!1};return t[r].call(i.exports,i,i.exports,e),i.loaded=!0,i.exports}var n={};return e.m=t,e.c=n,e.p="",e(0)}([function(t,e,n){(function(t,r,i,o){"use strict";function s(t){if(t)return t;throw new me(ge.EIO,"Initialize BrowserFS with a file system using BrowserFS.initialize(filesystem)")}function a(t,e){switch(typeof t){case"number":return t;case"string":var n=parseInt(t,8);return isNaN(n)?e:n;default:return e}}function c(t){if(t instanceof Date)return t;if("number"==typeof t)return new Date(1e3*t);throw new me(ge.EINVAL,"Invalid time.")}function u(t){if(t.indexOf("\0")>=0)throw new me(ge.EINVAL,"Path must be a string without null bytes.");if(""===t)throw new me(ge.EINVAL,"Path must not be empty.");return ye.resolve(t)}function f(t,e,n,r){switch(typeof t){case"object":return{encoding:"undefined"!=typeof t.encoding?t.encoding:e,flag:"undefined"!=typeof t.flag?t.flag:n,mode:a(t.mode,r)};case"string":return{encoding:t,flag:n,mode:r};default:return{encoding:e,flag:n,mode:r}}}function h(){}function p(){throw new Error("BFS has reached an impossible code path; please file a bug.")}function l(t,e,n){n.existsSync(t)||(l(ye.dirname(t),e,n),n.mkdirSync(t,e))}function d(t){var e=y(t),n=e.byteOffset,r=e.byteLength;return 0===n&&r===e.buffer.byteLength?e.buffer:e.buffer.slice(n,n+r)}function y(t){return t instanceof Uint8Array?t:new Uint8Array(t)}function g(t){return t instanceof r?t:t instanceof Uint8Array?_(t):new r(t)}function _(t){return t instanceof r?t:0===t.byteOffset&&t.byteLength===t.buffer.byteLength?v(t.buffer):new r(t)}function v(t){try{return new r(t)}catch(e){return new r(new Uint8Array(t))}}function w(t,e,n){if(void 0===e&&(e=0),void 0===n&&(n=t.length),e<0||n<0||n>t.length||e>n)throw new TypeError("Invalid slice bounds on buffer of length "+t.length+": ["+e+", "+n+"]");if(0===t.length)return new r(0);var i=y(t),o=t[0],s=(o+1)%255;return t[0]=s,i[0]===s?(i[0]=o,_(i.slice(e,n))):(t[0]=o,_(i.subarray(e,n)))}function m(t,e,n){switch(n.length){case 0:return t.call(e);case 1:return t.call(e,n[0]);case 2:return t.call(e,n[0],n[1]);case 3:return t.call(e,n[0],n[1],n[2])}return t.apply(e,n)}function E(t,e,n){return e=Ve(void 0===e?t.length-1:e,0),function(){for(var r=arguments,i=-1,o=Ve(r.length-e,0),s=Array(o);++i-1&&t%1==0&&t<=un}function T(t){return null!=t&&L(t.length)&&!N(t)}function x(){}function D(t){return function(){if(null!==t){var e=t;t=null,e.apply(this,arguments)}}}function A(t,e){for(var n=-1,r=Array(t);++n-1&&t%1==0&&t0?"/"+i.join("/"):e)}function _t(t,e){if(null!==e&&"object"==typeof e){var n=e,r=n.path;r&&(r="/"+ye.relative(t,r),n.message=n.message.replace(n.path,r),n.path=r)}return e}function vt(t,e){return"function"==typeof e?function(n){arguments.length>0&&(arguments[0]=_t(t,n)),e.apply(null,arguments)}:e}function wt(t,e,n){return"Sync"!==t.slice(t.length-4)?function(){return arguments.length>0&&(e&&(arguments[0]=ye.join(this._folder,arguments[0])),n&&(arguments[1]=ye.join(this._folder,arguments[1])),arguments[arguments.length-1]=vt(this._folder,arguments[arguments.length-1])),this._wrapped[t].apply(this._wrapped,arguments)}:function(){try{return e&&(arguments[0]=ye.join(this._folder,arguments[0])),n&&(arguments[1]=ye.join(this._folder,arguments[1])),this._wrapped[t].apply(this._wrapped,arguments)}catch(t){throw _t(this._folder,t)}}}function mt(t){return t.isDirectory}function Et(t,e,n,r){if("undefined"!=typeof navigator.webkitPersistentStorage)switch(t){case _e.PERSISTENT:navigator.webkitPersistentStorage.requestQuota(e,n,r);break;case _e.TEMPORARY:navigator.webkitTemporaryStorage.requestQuota(e,n,r);break;default:r(new TypeError("Invalid storage type: "+t))}else _e.webkitStorageInfo.requestQuota(t,e,n,r)}function St(t){return Array.prototype.slice.call(t||[],0)}function bt(t,e,n){switch(t.name){case"PathExistsError":return me.EEXIST(e);case"QuotaExceededError":return me.FileError(ge.ENOSPC,e);case"NotFoundError":return me.ENOENT(e);case"SecurityError":return me.FileError(ge.EACCES,e);case"InvalidModificationError":return me.FileError(ge.EPERM,e);case"TypeMismatchError":return me.FileError(n?ge.ENOTDIR:ge.EISDIR,e);case"EncodingError":case"InvalidStateError":case"NoModificationAllowedError":default:return me.FileError(ge.EINVAL,e)}}function kt(){return"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,function(t){var e=16*Math.random()|0,n="x"===t?e:3&e|8;return n.toString(16)})}function It(t,e){return!t||(e(t),!1)}function Ot(t,e,n){return!t||(e.abort(function(){n(t)}),!1)}function Ft(t,e){switch(void 0===e&&(e=t.toString()),t.name){case"NotFoundError":return new me(ge.ENOENT,e);case"QuotaExceededError":return new me(ge.ENOSPC,e);default:return new me(ge.EIO,e)}}function Rt(t,e,n){return void 0===e&&(e=ge.EIO),void 0===n&&(n=null),function(r){r.preventDefault(),t(new me(e,null!==n?n:void 0))}}function Nt(t,e,n){return e?function(){for(var e=[],n=arguments.length;n--;)e[n]=arguments[n];var r=e[0],i=this._getFs(r);e[0]=i.path;try{return i.fs[t].apply(i.fs,e)}catch(t){throw this.standardizeError(t,i.path,r),t}}:function(){for(var e=this,n=[],r=arguments.length;r--;)n[r]=arguments[r];var i=n[0],o=this._getFs(i);if(n[0]=o.path,"function"==typeof n[n.length-1]){var s=n[n.length-1];n[n.length-1]=function(){for(var t=[],n=arguments.length;n--;)t[n]=arguments[n];t.length>0&&t[0]instanceof me&&e.standardizeError(t[0],o.path,i),s.apply(null,t)}}return o.fs[t].apply(o.fs,n)}}function Lt(t){return 146|t}function Tt(t){return Se.getFileFlag(t)}function xt(t){return{type:mi.API_ERROR,errorData:jt(t.writeToBuffer())}}function Dt(t){return me.fromBuffer(zt(t.errorData))}function At(t){return{type:mi.ERROR,name:t.name,message:t.message,stack:t.stack}}function Pt(t){var e=_e[t.name];"function"!=typeof e&&(e=Error);var n=new e(t.message);return n.stack=t.stack,n}function Ct(t){return{type:mi.STATS,statsData:jt(t.toBuffer())}}function Ut(t){return ke.fromBuffer(zt(t.statsData))}function Mt(t){return{type:mi.FILEFLAG,flagStr:t.getFlagString()}}function Bt(t){return Se.getFileFlag(t.flagStr)}function jt(t){return d(t)}function zt(t){return v(t)}function qt(t){return{type:mi.BUFFER,data:jt(t)}}function Vt(t){return zt(t.data)}function Wt(t){return t&&"object"==typeof t&&t.hasOwnProperty("browserfsMessage")&&t.browserfsMessage}function Ht(t){return t&&"object"==typeof t&&t.hasOwnProperty("browserfsMessage")&&t.browserfsMessage}function Zt(t,e,n){var i=new XMLHttpRequest;i.open("GET",t,!0);var o=!0;switch(e){case"buffer":i.responseType="arraybuffer";break;case"json":try{i.responseType="json",o="json"===i.responseType}catch(t){o=!1}break;default:return n(new me(ge.EINVAL,"Invalid download type: "+e))}i.onreadystatechange=function(t){if(4===i.readyState){if(200!==i.status)return n(new me(i.status,"XHR error."));switch(e){case"buffer":return n(null,new r(i.response?i.response:0));case"json":return o?n(null,i.response):n(null,JSON.parse(i.responseText))}}},i.send()}function Yt(t,e){var n=new XMLHttpRequest;n.open("GET",t,!1);var i=null,o=null;if(n.overrideMimeType("text/plain; charset=x-user-defined"),n.onreadystatechange=function(t){if(4===n.readyState){if(200!==n.status)return void(o=new me(n.status,"XHR error."));switch(e){case"buffer":var s=n.responseText;i=new r(s.length);for(var a=0;a>5&15)-1,i=(e>>9)+1980,o=31&t,s=t>>5&63,a=t>>11;return new Date(i,r,n,a,s,o)}function ne(t,e,n,r){return 0===r?"":e?t.toString("utf8",n,n+r):Pi.byte2str(t.slice(n,n+r))}function re(t,e,n){return t.toString("ascii",e,e+n).trim()}function ie(t,e,n){if(1===n)return String.fromCharCode(t[e]);for(var r=Math.floor(n/2),i=new Array(r),o=0;othis._buffer.length){var e=new r(t-this._buffer.length);return e.fill(0),this.writeSync(e,0,e.length,this._buffer.length),void(this._flag.isSynchronous()&&Re.getRootFS().supportsSynch()&&this.syncSync())}this._stat.size=t;var n=new r(t);this._buffer.copy(n,0,0,t),this._buffer=n,this._flag.isSynchronous()&&Re.getRootFS().supportsSynch()&&this.syncSync()},e.prototype.write=function(t,e,n,r,i){try{i(null,this.writeSync(t,e,n,r),t)}catch(t){i(t)}},e.prototype.writeSync=function(t,e,n,i){if(this._dirty=!0,void 0!==i&&null!==i||(i=this.getPos()),!this._flag.isWriteable())throw new me(ge.EPERM,"File not opened with a writeable mode.");var o=i+n;if(o>this._stat.size&&(this._stat.size=o,o>this._buffer.length)){var s=new r(o);this._buffer.copy(s),this._buffer=s}var a=t.copy(this._buffer,i,e,e+n);return this._stat.mtime=new Date,this._flag.isSynchronous()?(this.syncSync(),a):(this.setPos(i+a),a)},e.prototype.read=function(t,e,n,r,i){try{i(null,this.readSync(t,e,n,r),t)}catch(t){i(t)}},e.prototype.readSync=function(t,e,n,r){if(!this._flag.isReadable())throw new me(ge.EPERM,"File not opened with a readable mode.");void 0!==r&&null!==r||(r=this.getPos());var i=r+n;i>this._stat.size&&(n=this._stat.size-r);var o=this._buffer.copy(t,e,r,r+n);return this._stat.atime=new Date,this._pos=r+n,o},e.prototype.chmod=function(t,e){try{this.chmodSync(t),e()}catch(t){e(t)}},e.prototype.chmodSync=function(t){if(!this._fs.supportsProps())throw new me(ge.ENOTSUP);this._dirty=!0,this._stat.chmod(t),this.syncSync()},e.prototype.isDirty=function(){return this._dirty},e.prototype.resetDirty=function(){this._dirty=!1},e}(Me),je=function(t){function e(e,n,r,i,o){t.call(this,e,n,r,i,o)}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e.prototype.sync=function(t){t()},e.prototype.syncSync=function(){},e.prototype.close=function(t){t()},e.prototype.closeSync=function(){},e}(Be),ze=function(t){function e(e,n,r,i,o){t.call(this,e,n,r,i,o)}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e.prototype.syncSync=function(){this.isDirty()&&(this._fs._syncSync(this),this.resetDirty())},e.prototype.closeSync=function(){this.syncSync()},e}(Be),qe=function(t){function e(e,n){if(t.call(this),this._queue=[],this._queueRunning=!1,this._isInitialized=!1,this._initializeCallbacks=[],this._sync=e,this._async=n,!e.supportsSynch())throw new Error("The first argument to AsyncMirror needs to be a synchronous file system.")}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e.isAvailable=function(){return!0},e.prototype.getName=function(){return"AsyncMirror"},e.prototype._syncSync=function(t){this._sync.writeFileSync(t.getPath(),t.getBuffer(),null,Se.getFileFlag("w"),t.getStats().mode),this.enqueueOp({apiMethod:"writeFile",arguments:[t.getPath(),t.getBuffer(),null,t.getFlag(),t.getStats().mode]})},e.prototype.initialize=function(t){var e=this,n=this._initializeCallbacks,r=function(t){e._isInitialized=!t,e._initializeCallbacks=[],n.forEach(function(e){return e(t)})};if(this._isInitialized)t();else if(1===n.push(t)){var i=function(t,n,r){"/"!==t&&e._sync.mkdirSync(t,n),e._async.readdir(t,function(e,n){function i(e){e?r(e):o0){var r=e._queue.shift(),i=r.arguments;i.push(n),e._async[r.apiMethod].apply(e._async,i)}else e._queueRunning=!1};n()}},e}(Ue),Ve=Math.max,We=function(t){return b(function(e){var n=e.pop();t.call(this,e,n)})},He="object"==typeof t&&t&&t.Object===Object&&t,Ze="object"==typeof self&&self&&self.Object===Object&&self,Ye=He||Ze||Function("return this")(),Xe=Ye.Symbol,Ke=Object.prototype,Ge=Ke.hasOwnProperty,Je=Ke.toString,Qe=Xe?Xe.toStringTag:void 0,$e=Object.prototype,tn=$e.toString,en="[object Null]",nn="[object Undefined]",rn=Xe?Xe.toStringTag:void 0,on="[object AsyncFunction]",sn="[object Function]",an="[object GeneratorFunction]",cn="[object Proxy]",un=9007199254740991,fn="function"==typeof Symbol&&Symbol.iterator,hn=function(t){return fn&&t[fn]&&t[fn]()},pn="[object Arguments]",ln=Object.prototype,dn=ln.hasOwnProperty,yn=ln.propertyIsEnumerable,gn=C(function(){return arguments}())?C:function(t){return P(t)&&dn.call(t,"callee")&&!yn.call(t,"callee")},_n=Array.isArray,vn="object"==typeof e&&e&&!e.nodeType&&e,wn=vn&&"object"==typeof i&&i&&!i.nodeType&&i,mn=wn&&wn.exports===vn,En=mn?Ye.Buffer:void 0,Sn=En?En.isBuffer:void 0,bn=Sn||U,kn=9007199254740991,In=/^(?:0|[1-9]\d*)$/,On="[object Arguments]",Fn="[object Array]",Rn="[object Boolean]",Nn="[object Date]",Ln="[object Error]",Tn="[object Function]",xn="[object Map]",Dn="[object Number]",An="[object Object]",Pn="[object RegExp]",Cn="[object Set]",Un="[object String]",Mn="[object WeakMap]",Bn="[object ArrayBuffer]",jn="[object DataView]",zn="[object Float32Array]",qn="[object Float64Array]",Vn="[object Int8Array]",Wn="[object Int16Array]",Hn="[object Int32Array]",Zn="[object Uint8Array]",Yn="[object Uint8ClampedArray]",Xn="[object Uint16Array]",Kn="[object Uint32Array]",Gn={};Gn[zn]=Gn[qn]=Gn[Vn]=Gn[Wn]=Gn[Hn]=Gn[Zn]=Gn[Yn]=Gn[Xn]=Gn[Kn]=!0,Gn[On]=Gn[Fn]=Gn[Bn]=Gn[Rn]=Gn[jn]=Gn[Nn]=Gn[Ln]=Gn[Tn]=Gn[xn]=Gn[Dn]=Gn[An]=Gn[Pn]=Gn[Cn]=Gn[Un]=Gn[Mn]=!1;var Jn="object"==typeof e&&e&&!e.nodeType&&e,Qn=Jn&&"object"==typeof i&&i&&!i.nodeType&&i,$n=Qn&&Qn.exports===Jn,tr=$n&&He.process,er=function(){try{return tr&&tr.binding&&tr.binding("util")}catch(t){}}(),nr=er&&er.isTypedArray,rr=nr?j(nr):B,ir=Object.prototype,or=ir.hasOwnProperty,sr=Object.prototype,ar=V(Object.keys,Object),cr=Object.prototype,ur=cr.hasOwnProperty,fr={},hr=$(Q,1/0),pr=function(t,e,n){var r=T(t)?tt:hr;r(t,e,n)},lr=et(nt);k(lr);var dr=rt(nt),yr=$(dr,1);k(yr),b(function(t,e){return b(function(n){return t.apply(null,e.concat(n))})});var gr,_r=(ot(),"\\ud800-\\udfff"),vr="\\u0300-\\u036f",wr="\\ufe20-\\ufe2f",mr="\\u20d0-\\u20ff",Er=vr+wr+mr,Sr="\\ufe0e\\ufe0f",br="["+_r+"]",kr="["+Er+"]",Ir="\\ud83c[\\udffb-\\udfff]",Or="(?:"+kr+"|"+Ir+")",Fr="[^"+_r+"]",Rr="(?:\\ud83c[\\udde6-\\uddff]){2}",Nr="[\\ud800-\\udbff][\\udc00-\\udfff]",Lr="\\u200d",Tr=Or+"?",xr="["+Sr+"]?",Dr=("(?:"+Lr+"(?:"+[Fr,Rr,Nr].join("|")+")"+xr+Tr+")*","(?:"+[Fr+kr+"?",kr,Rr,Nr,br].join("|")+")","function"==typeof setImmediate&&setImmediate),Ar="object"==typeof o&&"function"==typeof o.nextTick;gr=Dr?setImmediate:Ar?o.nextTick:st,at(gr);var Pr=$(Q,1),Cr=b(function(t){return b(function(e){var n=this,r=e[e.length-1];"function"==typeof r?e.pop():r=x,ct(t,e,function(t,e,r){e.apply(n,t.concat([b(function(t,e){r(t,e)})]))},function(t,e){r.apply(n,[t].concat(e))})})});b(function(t){return Cr.apply(null,t.reverse())}),b(function(t){var e=[null].concat(t);return We(function(t,n){return n.apply(this,e)})}),ut("dir"),ut("log");var Ur;Ur=Ar?o.nextTick:Dr?setImmediate:st,at(Ur);var Mr,Br=(Math.ceil,Math.max,function(t){this._cache={},this._client=t});Br.prototype.readdir=function(t,e){var n=this,r=this.getCachedDirInfo(t);this._wrap(function(e){null!==r&&r.contents?n._client.readdir(t,{contentHash:r.stat.contentHash},e):n._client.readdir(t,e)},function(i,o,s,a){i?i.status===Dropbox.ApiError.NO_CONTENT&&null!==r?e(null,r.contents.slice(0)):e(i):(n.updateCachedDirInfo(t,s,o.slice(0)),a.forEach(function(e){n.updateCachedInfo(ye.join(t,e.name),e)}),e(null,o))})},Br.prototype.remove=function(t,e){var n=this;this._wrap(function(e){n._client.remove(t,e)},function(r,i){r||n.updateCachedInfo(t,i),e(r)})},Br.prototype.move=function(t,e,n){var r=this;this._wrap(function(n){r._client.move(t,e,n)},function(i,o){i||(r.deleteCachedInfo(t),r.updateCachedInfo(e,o)),n(i)})},Br.prototype.stat=function(t,e){var n=this;this._wrap(function(e){n._client.stat(t,e)},function(r,i){r||n.updateCachedInfo(t,i),e(r,i)})},Br.prototype.readFile=function(t,e){var n=this,r=this.getCachedFileInfo(t);null!==r&&null!==r.contents?this.stat(t,function(i,o){i?e(i):o.contentHash===r.stat.contentHash?e(i,r.contents.slice(0),r.stat):n.readFile(t,e)}):this._wrap(function(e){n._client.readFile(t,{arrayBuffer:!0},e)},function(r,i,o){r||n.updateCachedInfo(t,o,i.slice(0)),e(r,i,o)})},Br.prototype.writeFile=function(t,e,n){var r=this;this._wrap(function(n){r._client.writeFile(t,e,n)},function(i,o){i||r.updateCachedInfo(t,o,e.slice(0)),n(i,o)})},Br.prototype.mkdir=function(t,e){var n=this;this._wrap(function(e){n._client.mkdir(t,e)},function(r,i){r||n.updateCachedInfo(t,i,[]),e(r)})},Br.prototype._wrap=function(t,e){var n=0,r=function(i){var o=2;if(i&&3>++n)switch(i.status){case Dropbox.ApiError.SERVER_ERROR:case Dropbox.ApiError.NETWORK_ERROR:case Dropbox.ApiError.RATE_LIMITED:setTimeout(function(){t(r)},1e3*o);break;default:e.apply(null,arguments)}else e.apply(null,arguments)};t(r)},Br.prototype.getCachedInfo=function(t){return this._cache[t.toLowerCase()]},Br.prototype.putCachedInfo=function(t,e){this._cache[t.toLowerCase()]=e},Br.prototype.deleteCachedInfo=function(t){delete this._cache[t.toLowerCase()]},Br.prototype.getCachedDirInfo=function(t){var e=this.getCachedInfo(t);return dt(e)?e:null},Br.prototype.getCachedFileInfo=function(t){var e=this.getCachedInfo(t);return lt(e)?e:null},Br.prototype.updateCachedDirInfo=function(t,e,n){void 0===n&&(n=null);var r=this.getCachedInfo(t);null===e.contentHash||void 0!==r&&r.stat.contentHash===e.contentHash||this.putCachedInfo(t,{stat:e,contents:n})},Br.prototype.updateCachedFileInfo=function(t,e,n){void 0===n&&(n=null);var r=this.getCachedInfo(t);null===e.versionTag||void 0!==r&&r.stat.versionTag===e.versionTag||this.putCachedInfo(t,{stat:e,contents:n})},Br.prototype.updateCachedInfo=function(t,e,n){void 0===n&&(n=null),e.isFile&&yt(n)?this.updateCachedFileInfo(t,e,n):e.isFolder&&Array.isArray(n)&&this.updateCachedDirInfo(t,e,n)};var jr=function(t){function e(e,n,r,i,o){t.call(this,e,n,r,i,o)}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e.prototype.sync=function(t){var e=this;if(this.isDirty()){var n=this.getBuffer(),r=d(n);this._fs._writeFileStrict(this.getPath(),r,function(n){n||e.resetDirty(),t(n)})}else t()},e.prototype.close=function(t){this.sync(t)},e}(Be),zr=function(t){function e(e){t.call(this),this._client=new Br(e),pt()}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e.isAvailable=function(){return"undefined"!=typeof Dropbox},e.prototype.getName=function(){return"Dropbox"},e.prototype.isReadOnly=function(){return!1},e.prototype.supportsSymlinks=function(){return!1},e.prototype.supportsProps=function(){return!1},e.prototype.supportsSynch=function(){return!1},e.prototype.empty=function(t){var e=this;this._client.readdir("/",function(n,r){if(n)t(e.convert(n,"/"));else{var i=function(t,n){var r=ye.join("/",t);e._client.remove(r,function(t){n(t?e.convert(t,r):null)})},o=function(e){e?t(e):t()};ht(r,i,o)}})},e.prototype.rename=function(t,e,n){var r=this;this._client.move(t,e,function(i){i?r._client.stat(e,function(o,s){if(o||s.isFolder){var a=i.response.error.indexOf(t)>-1?t:e;n(r.convert(i,a))}else r._client.remove(e,function(i){i?n(r.convert(i,e)):r.rename(t,e,n)})}):n()})},e.prototype.stat=function(t,e,n){var r=this;this._client.stat(t,function(e,i){if(e)n(r.convert(e,t));else{if(!i||!i.isRemoved){var o=new ke(r._statType(i),i.size);return n(null,o)}n(me.FileError(ge.ENOENT,t))}})},e.prototype.open=function(t,e,n,i){var o=this;this._client.readFile(t,function(n,s,a){if(!n){var c;c=null===s?new r(0):v(s);var u=o._makeFile(t,e,a,c);return i(null,u)}if(e.isReadable())i(o.convert(n,t));else switch(n.status){case Dropbox.ApiError.NOT_FOUND:var f=new ArrayBuffer(0);return o._writeFileStrict(t,f,function(n,r){if(n)i(n);else{var s=o._makeFile(t,e,r,v(f));i(null,s)}});default:return i(o.convert(n,t))}})},e.prototype._writeFileStrict=function(t,e,n){var r=this,i=ye.dirname(t);this.stat(i,!1,function(o,s){o?n(me.FileError(ge.ENOENT,i)):r._client.writeFile(t,e,function(e,i){e?n(r.convert(e,t)):n(null,i)})})},e.prototype._statType=function(t){return t.isFile?be.FILE:be.DIRECTORY},e.prototype._makeFile=function(t,e,n,r){var i=this._statType(n),o=new ke(i,n.size);return new jr(this,t,e,o,r)},e.prototype._remove=function(t,e,n){var r=this;this._client.stat(t,function(i,o){i?e(r.convert(i,t)):o.isFile&&!n?e(me.FileError(ge.ENOTDIR,t)):!o.isFile&&n?e(me.FileError(ge.EISDIR,t)):r._client.remove(t,function(n){e(n?r.convert(n,t):null)})})},e.prototype.unlink=function(t,e){this._remove(t,e,!0)},e.prototype.rmdir=function(t,e){this._remove(t,e,!1)},e.prototype.mkdir=function(t,e,n){var r=this,i=ye.dirname(t);this._client.stat(i,function(e,o){e?n(r.convert(e,i)):r._client.mkdir(t,function(e){n(e?me.FileError(ge.EEXIST,t):null)})})},e.prototype.readdir=function(t,e){var n=this;this._client.readdir(t,function(t,r){return t?e(n.convert(t)):e(null,r)})},e.prototype.convert=function(t,e){void 0===e&&(e=null);var n=Mr[t.status];return void 0===n&&(n=ge.EIO),e?me.FileError(n,e):new me(n)},e}(Ce),qr=function(t){function e(e,n,r,i){t.call(this),this._fs=e,this._FS=n,this._path=r,this._stream=i}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e.prototype.getPos=function(){},e.prototype.close=function(t){var e=null;try{this.closeSync()}catch(t){e=t}finally{t(e)}},e.prototype.closeSync=function(){try{this._FS.close(this._stream)}catch(t){throw gt(t,this._path)}},e.prototype.stat=function(t){try{t(null,this.statSync())}catch(e){t(e)}},e.prototype.statSync=function(){try{return this._fs.statSync(this._path,!1)}catch(t){throw gt(t,this._path)}},e.prototype.truncate=function(t,e){var n=null;try{this.truncateSync(t)}catch(t){n=t}finally{e(n)}},e.prototype.truncateSync=function(t){try{this._FS.ftruncate(this._stream.fd,t)}catch(t){throw gt(t,this._path)}},e.prototype.write=function(t,e,n,r,i){try{i(null,this.writeSync(t,e,n,r),t)}catch(t){i(t)}},e.prototype.writeSync=function(t,e,n,r){try{var i=y(t),o=null===r?void 0:r;return this._FS.write(this._stream,i,e,n,o)}catch(t){throw gt(t,this._path)}},e.prototype.read=function(t,e,n,r,i){try{i(null,this.readSync(t,e,n,r),t)}catch(t){i(t)}},e.prototype.readSync=function(t,e,n,r){try{var i=y(t),o=null===r?void 0:r;return this._FS.read(this._stream,i,e,n,o)}catch(t){throw gt(t,this._path)}},e.prototype.sync=function(t){t()},e.prototype.syncSync=function(){},e.prototype.chown=function(t,e,n){var r=null;try{this.chownSync(t,e)}catch(t){r=t}finally{n(r)}},e.prototype.chownSync=function(t,e){try{this._FS.fchown(this._stream.fd,t,e)}catch(t){throw gt(t,this._path)}},e.prototype.chmod=function(t,e){var n=null;try{this.chmodSync(t)}catch(t){n=t}finally{e(n)}},e.prototype.chmodSync=function(t){try{this._FS.fchmod(this._stream.fd,t)}catch(t){throw gt(t,this._path)}},e.prototype.utimes=function(t,e,n){var r=null;try{this.utimesSync(t,e)}catch(t){r=t}finally{n(r)}},e.prototype.utimesSync=function(t,e){ -this._fs.utimesSync(this._path,t,e)},e}(Me),Vr=function(t){function e(e){t.call(this),this._FS=e}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e.isAvailable=function(){return!0},e.prototype.getName=function(){return this._FS.DB_NAME()},e.prototype.isReadOnly=function(){return!1},e.prototype.supportsLinks=function(){return!0},e.prototype.supportsProps=function(){return!0},e.prototype.supportsSynch=function(){return!0},e.prototype.renameSync=function(t,e){try{this._FS.rename(t,e)}catch(n){throw n.errno===ge.ENOENT?gt(n,this.existsSync(t)?e:t):gt(n)}},e.prototype.statSync=function(t,e){try{var n=e?this._FS.lstat(t):this._FS.stat(t),r=this.modeToFileType(n.mode);return new ke(r,n.size,n.mode,n.atime,n.mtime,n.ctime)}catch(e){throw gt(e,t)}},e.prototype.openSync=function(t,e,n){try{var r=this._FS.open(t,e.getFlagString(),n);if(this._FS.isDir(r.node.mode))throw this._FS.close(r),me.EISDIR(t);return new qr(this,this._FS,t,r)}catch(e){throw gt(e,t)}},e.prototype.unlinkSync=function(t){try{this._FS.unlink(t)}catch(e){throw gt(e,t)}},e.prototype.rmdirSync=function(t){try{this._FS.rmdir(t)}catch(e){throw gt(e,t)}},e.prototype.mkdirSync=function(t,e){try{this._FS.mkdir(t,e)}catch(e){throw gt(e,t)}},e.prototype.readdirSync=function(t){try{return this._FS.readdir(t).filter(function(t){return"."!==t&&".."!==t})}catch(e){throw gt(e,t)}},e.prototype.truncateSync=function(t,e){try{this._FS.truncate(t,e)}catch(e){throw gt(e,t)}},e.prototype.readFileSync=function(t,e,n){try{var r=this._FS.readFile(t,{flags:n.getFlagString()}),i=_(r);return e?i.toString(e):i}catch(e){throw gt(e,t)}},e.prototype.writeFileSync=function(t,e,n,i,o){try{n&&(e=new r(e,n));var s=y(e);this._FS.writeFile(t,s,{flags:i.getFlagString(),encoding:"binary"}),this._FS.chmod(t,o)}catch(e){throw gt(e,t)}},e.prototype.chmodSync=function(t,e,n){try{e?this._FS.lchmod(t,n):this._FS.chmod(t,n)}catch(e){throw gt(e,t)}},e.prototype.chownSync=function(t,e,n,r){try{e?this._FS.lchown(t,n,r):this._FS.chown(t,n,r)}catch(e){throw gt(e,t)}},e.prototype.symlinkSync=function(t,e,n){try{this._FS.symlink(t,e)}catch(t){throw gt(t)}},e.prototype.readlinkSync=function(t){try{return this._FS.readlink(t)}catch(e){throw gt(e,t)}},e.prototype.utimesSync=function(t,e,n){try{this._FS.utime(t,e.getTime(),n.getTime())}catch(e){throw gt(e,t)}},e.prototype.modeToFileType=function(t){if(this._FS.isDir(t))return be.DIRECTORY;if(this._FS.isFile(t))return be.FILE;if(this._FS.isLink(t))return be.SYMLINK;throw me.EPERM("Invalid mode: "+t)},e}(Ue),Wr=function(t){function e(e,n){t.call(this),this._folder=e,this._wrapped=n}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e.isAvailable=function(){return!0},e.prototype.initialize=function(t){var e=this;this._wrapped.exists(this._folder,function(n){n?t():e._wrapped.isReadOnly()?t(me.ENOENT(e._folder)):e._wrapped.mkdir(e._folder,511,t)})},e.prototype.getName=function(){return this._wrapped.getName()},e.prototype.isReadOnly=function(){return this._wrapped.isReadOnly()},e.prototype.supportsProps=function(){return this._wrapped.supportsProps()},e.prototype.supportsSynch=function(){return this._wrapped.supportsSynch()},e.prototype.supportsLinks=function(){return!1},e}(Ce);["diskSpace","stat","statSync","open","openSync","unlink","unlinkSync","rmdir","rmdirSync","mkdir","mkdirSync","readdir","readdirSync","exists","existsSync","realpath","realpathSync","truncate","truncateSync","readFile","readFileSync","writeFile","writeFileSync","appendFile","appendFileSync","chmod","chmodSync","chown","chownSync","utimes","utimesSync","readlink","readlinkSync"].forEach(function(t){Wr.prototype[t]=wt(t,!0,!1)}),["rename","renameSync","link","linkSync","symlink","symlinkSync"].forEach(function(t){Wr.prototype[t]=wt(t,!0,!0)});var Hr=_e.webkitRequestFileSystem||_e.requestFileSystem||null,Zr=function(t){function e(e,n,r,i,o,s){t.call(this,e,r,i,o,s),this._entry=n}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e.prototype.sync=function(t){var e=this;return this.isDirty()?void this._entry.createWriter(function(n){var r=e.getBuffer(),i=new Blob([d(r)]),o=i.size;n.onwriteend=function(r){n.onwriteend=null,n.onerror=null,n.truncate(o),e.resetDirty(),t()},n.onerror=function(n){t(bt(n,e.getPath(),!1))},n.write(i)}):t()},e.prototype.close=function(t){this.sync(t)},e}(Be),Yr=function(t){function e(e,n){void 0===e&&(e=5),void 0===n&&(n=_e.PERSISTENT),t.call(this),this.size=1048576*e,this.type=n}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e.isAvailable=function(){return!!Hr},e.prototype.getName=function(){return"HTML5 FileSystem"},e.prototype.isReadOnly=function(){return!1},e.prototype.supportsSymlinks=function(){return!1},e.prototype.supportsProps=function(){return!1},e.prototype.supportsSynch=function(){return!1},e.prototype.allocate=function(t){var e=this;void 0===t&&(t=function(){});var n=function(n){e.fs=n,t()},r=function(e){t(bt(e,"/",!0))};this.type===_e.PERSISTENT?Et(this.type,this.size,function(t){Hr(e.type,t,n,r)},r):Hr(this.type,this.size,n,r)},e.prototype.empty=function(t){this._readdir("/",function(e,n){if(e)console.error("Failed to empty FS"),t(e);else{var r=function(n){e?(console.error("Failed to empty FS"),t(e)):t()},i=function(t,e){var n=function(){e()},r=function(n){e(bt(n,t.fullPath,!t.isDirectory))};mt(t)?t.removeRecursively(n,r):t.remove(n,r)};ht(n,i,r)}})},e.prototype.rename=function(t,e,n){var r=this,i=2,o=0,s=this.fs.root,a=t,c=function(t){--i<=0&&n(bt(t,a,!1))},u=function(i){return 2===++o?n(new me(ge.EINVAL,"Something was identified as both a file and a directory. This should never happen.")):t===e?n():(a=ye.dirname(e),void s.getDirectory(a,{},function(o){a=ye.basename(e),i.moveTo(o,a,function(t){n()},function(o){i.isDirectory?(a=e,r.unlink(e,function(i){i?c(o):r.rename(t,e,n)})):c(o)})},c))};s.getFile(t,{},u,c),s.getDirectory(t,{},u,c)},e.prototype.stat=function(t,e,n){var r=this,i={create:!1},o=function(t){var e=function(t){var e=new ke(be.FILE,t.size);n(null,e)};t.file(e,a)},s=function(t){var e=4096,r=new ke(be.DIRECTORY,e);n(null,r)},a=function(e){n(bt(e,t,!1))},c=function(){r.fs.root.getDirectory(t,i,s,a)};this.fs.root.getFile(t,i,o,c)},e.prototype.open=function(t,e,n,r){var i=this,o=function(n){r("InvalidModificationError"===n.name&&e.isExclusive()?me.EEXIST(t):bt(n,t,!1))};this.fs.root.getFile(t,{create:e.pathNotExistsAction()===we.CREATE_FILE,exclusive:e.isExclusive()},function(n){n.file(function(s){var a=new FileReader;a.onloadend=function(o){var c=i._makeFile(t,n,e,s,a.result);r(null,c)},a.onerror=function(t){o(a.error)},a.readAsArrayBuffer(s)},o)},o)},e.prototype.unlink=function(t,e){this._remove(t,e,!0)},e.prototype.rmdir=function(t,e){var n=this;this.readdir(t,function(r,i){r?e(r):i.length>0?e(me.ENOTEMPTY(t)):n._remove(t,e,!1)})},e.prototype.mkdir=function(t,e,n){var r={create:!0,exclusive:!0},i=function(t){n()},o=function(e){n(bt(e,t,!0))};this.fs.root.getDirectory(t,r,i,o)},e.prototype.readdir=function(t,e){this._readdir(t,function(t,n){if(t)return e(t);for(var r=[],i=0;i0)throw me.ENOTEMPTY(t);this.removeEntry(t,!0)},e.prototype.mkdirSync=function(t,e){var n=this.store.beginTransaction("readwrite"),i=new r("{}");this.commitNewFile(n,t,be.DIRECTORY,e,i)},e.prototype.readdirSync=function(t){var e=this.store.beginTransaction("readonly");return Object.keys(this.getDirListing(e,t,this.findINode(e,t)))},e.prototype._syncSync=function(t,e,n){var r=this.store.beginTransaction("readwrite"),i=this._findINode(r,ye.dirname(t),ye.basename(t)),o=this.getINode(r,t,i),s=o.update(n);try{r.put(o.id,e,!0),s&&r.put(i,o.toBuffer(),!0)}catch(t){throw r.abort(),t}r.commit()},e.prototype.makeRootDirectory=function(){var t=this.store.beginTransaction("readwrite");if(void 0===t.get(Kr)){var e=(new Date).getTime(),n=new Xr(kt(),4096,511|be.DIRECTORY,e,e,e);t.put(n.id,new r("{}"),!1),t.put(Kr,n.toBuffer(),!1),t.commit()}},e.prototype._findINode=function(t,e,n){var r=this,i=function(i){var o=r.getDirListing(t,e,i);if(o[n])return o[n];throw me.ENOENT(ye.resolve(e,n))};return"/"===e?""===n?Kr:i(this.getINode(t,e,Kr)):i(this.getINode(t,e+ye.sep+n,this._findINode(t,ye.dirname(e),ye.basename(e))))},e.prototype.findINode=function(t,e){return this.getINode(t,e,this._findINode(t,ye.dirname(e),ye.basename(e)))},e.prototype.getINode=function(t,e,n){var r=t.get(n);if(void 0===r)throw me.ENOENT(e);return Xr.fromBuffer(r)},e.prototype.getDirListing=function(t,e,n){if(!n.isDirectory())throw me.ENOTDIR(e);var r=t.get(n.id);if(void 0===r)throw me.ENOENT(e);return JSON.parse(r.toString())},e.prototype.addNewNode=function(t,e){for(var n,r=0;r<5;)try{return n=kt(),t.put(n,e,!1),n}catch(t){}throw new me(ge.EIO,"Unable to commit data to key-value store.")},e.prototype.commitNewFile=function(t,e,n,i,o){var s=ye.dirname(e),a=ye.basename(e),c=this.findINode(t,s),u=this.getDirListing(t,s,c),f=(new Date).getTime();if("/"===e)throw me.EEXIST(e);if(u[a])throw me.EEXIST(e);var h;try{var p=this.addNewNode(t,o);h=new Xr(p,o.length,i|n,f,f,f);var l=this.addNewNode(t,h.toBuffer());u[a]=l,t.put(c.id,new r(JSON.stringify(u)),!0)}catch(e){throw t.abort(),e}return t.commit(),h},e.prototype.removeEntry=function(t,e){var n=this.store.beginTransaction("readwrite"),i=ye.dirname(t),o=this.findINode(n,i),s=this.getDirListing(n,i,o),a=ye.basename(t);if(!s[a])throw me.ENOENT(t);var c=s[a];delete s[a];var u=this.getINode(n,t,c);if(!e&&u.isDirectory())throw me.EISDIR(t);if(e&&!u.isDirectory())throw me.ENOTDIR(t);try{n.del(u.id),n.del(c),n.put(o.id,new r(JSON.stringify(s)),!0)}catch(t){throw n.abort(),t}n.commit()},e}(Ue),$r=function(t){function e(e,n,r,i,o){t.call(this,e,n,r,i,o)}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e.prototype.sync=function(t){var e=this;this.isDirty()?this._fs._sync(this.getPath(),this.getBuffer(),this.getStats(),function(n){n||e.resetDirty(),t(n)}):t()},e.prototype.close=function(t){this.sync(t)},e}(Be),ti=function(t){function e(){t.apply(this,arguments)}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e.isAvailable=function(){return!0},e.prototype.init=function(t,e){this.store=t,this.makeRootDirectory(e)},e.prototype.getName=function(){return this.store.name()},e.prototype.isReadOnly=function(){return!1},e.prototype.supportsSymlinks=function(){return!1},e.prototype.supportsProps=function(){return!1},e.prototype.supportsSynch=function(){return!1},e.prototype.empty=function(t){var e=this;this.store.clear(function(n){It(n,t)&&e.makeRootDirectory(t)})},e.prototype.rename=function(t,e,n){var i=this,o=this.store.beginTransaction("readwrite"),s=ye.dirname(t),a=ye.basename(t),c=ye.dirname(e),u=ye.basename(e),f={},h={},p=!1;if(0===(c+"/").indexOf(t+"/"))return n(new me(ge.EBUSY,s));var l=function(){if(!p&&h.hasOwnProperty(s)&&h.hasOwnProperty(c)){var l=h[s],d=f[s],y=h[c],g=f[c];if(l[a]){var _=l[a];delete l[a];var v=function(){y[u]=_,o.put(d.id,new r(JSON.stringify(l)),!0,function(t){Ot(t,o,n)&&(s===c?o.commit(n):o.put(g.id,new r(JSON.stringify(y)),!0,function(t){Ot(t,o,n)&&o.commit(n)}))})};y[u]?i.getINode(o,e,y[u],function(t,r){Ot(t,o,n)&&(r.isFile()?o.del(r.id,function(t){Ot(t,o,n)&&o.del(y[u],function(t){Ot(t,o,n)&&v()})}):o.abort(function(t){n(me.EPERM(e))}))}):v()}else n(me.ENOENT(t))}},d=function(t){i.findINodeAndDirListing(o,t,function(e,r,i){e?p||(p=!0,o.abort(function(){n(e)})):(f[t]=r,h[t]=i,l())})};d(s),s!==c&&d(c)},e.prototype.stat=function(t,e,n){var r=this.store.beginTransaction("readonly");this.findINode(r,t,function(t,e){It(t,n)&&n(null,e.toStats())})},e.prototype.createFile=function(t,e,n,i){var o=this,s=this.store.beginTransaction("readwrite"),a=new r(0);this.commitNewFile(s,t,be.FILE,n,a,function(n,r){It(n,i)&&i(null,new $r(o,t,e,r.toStats(),a))})},e.prototype.openFile=function(t,e,n){var r=this,i=this.store.beginTransaction("readonly");this.findINode(i,t,function(o,s){It(o,n)&&i.get(s.id,function(i,o){It(i,n)&&(void 0===o?n(me.ENOENT(t)):n(null,new $r(r,t,e,s.toStats(),o)))})})},e.prototype.unlink=function(t,e){this.removeEntry(t,!1,e)},e.prototype.rmdir=function(t,e){var n=this;this.readdir(t,function(r,i){r?e(r):i.length>0?e(me.ENOTEMPTY(t)):n.removeEntry(t,!0,e)})},e.prototype.mkdir=function(t,e,n){var i=this.store.beginTransaction("readwrite"),o=new r("{}");this.commitNewFile(i,t,be.DIRECTORY,e,o,n)},e.prototype.readdir=function(t,e){var n=this,r=this.store.beginTransaction("readonly");this.findINode(r,t,function(i,o){It(i,e)&&n.getDirListing(r,t,o,function(t,n){It(t,e)&&e(null,Object.keys(n))})})},e.prototype._sync=function(t,e,n,r){var i=this,o=this.store.beginTransaction("readwrite");this._findINode(o,ye.dirname(t),ye.basename(t),function(s,a){Ot(s,o,r)&&i.getINode(o,t,a,function(t,i){if(Ot(t,o,r)){var s=i.update(n);o.put(i.id,e,!0,function(t){Ot(t,o,r)&&(s?o.put(a,i.toBuffer(),!0,function(t){Ot(t,o,r)&&o.commit(r)}):o.commit(r))})}})})},e.prototype.makeRootDirectory=function(t){var e=this.store.beginTransaction("readwrite");e.get(Kr,function(n,i){if(n||void 0===i){var o=(new Date).getTime(),s=new Xr(kt(),4096,511|be.DIRECTORY,o,o,o);e.put(s.id,new r("{}"),!1,function(n){Ot(n,e,t)&&e.put(Kr,s.toBuffer(),!1,function(n){n?e.abort(function(){t(n)}):e.commit(t)})})}else e.commit(t)})},e.prototype._findINode=function(t,e,n,r){var i=this,o=function(t,i,o){t?r(t):o[n]?r(null,o[n]):r(me.ENOENT(ye.resolve(e,n)))};"/"===e?""===n?r(null,Kr):this.getINode(t,e,Kr,function(n,s){It(n,r)&&i.getDirListing(t,e,s,function(t,e){o(t,s,e)})}):this.findINodeAndDirListing(t,e,o)},e.prototype.findINode=function(t,e,n){var r=this;this._findINode(t,ye.dirname(e),ye.basename(e),function(i,o){It(i,n)&&r.getINode(t,e,o,n)})},e.prototype.getINode=function(t,e,n,r){t.get(n,function(t,n){It(t,r)&&(void 0===n?r(me.ENOENT(e)):r(null,Xr.fromBuffer(n)))})},e.prototype.getDirListing=function(t,e,n,r){n.isDirectory()?t.get(n.id,function(t,n){if(It(t,r))try{r(null,JSON.parse(n.toString()))}catch(t){r(me.ENOENT(e))}}):r(me.ENOTDIR(e))},e.prototype.findINodeAndDirListing=function(t,e,n){var r=this;this.findINode(t,e,function(i,o){It(i,n)&&r.getDirListing(t,e,o,function(t,e){It(t,n)&&n(null,o,e)})})},e.prototype.addNewNode=function(t,e,n){var r,i=0,o=function(){5===++i?n(new me(ge.EIO,"Unable to commit data to key-value store.")):(r=kt(),t.put(r,e,!1,function(t,e){t||!e?o():n(null,r)}))};o()},e.prototype.commitNewFile=function(t,e,n,i,o,s){var a=this,c=ye.dirname(e),u=ye.basename(e),f=(new Date).getTime();return"/"===e?s(me.EEXIST(e)):void this.findINodeAndDirListing(t,c,function(c,h,p){Ot(c,t,s)&&(p[u]?t.abort(function(){s(me.EEXIST(e))}):a.addNewNode(t,o,function(e,c){if(Ot(e,t,s)){var l=new Xr(c,o.length,i|n,f,f,f);a.addNewNode(t,l.toBuffer(),function(e,n){Ot(e,t,s)&&(p[u]=n,t.put(h.id,new r(JSON.stringify(p)),!0,function(e){Ot(e,t,s)&&t.commit(function(e){Ot(e,t,s)&&s(null,l)})}))})}}))})},e.prototype.removeEntry=function(t,e,n){var i=this,o=this.store.beginTransaction("readwrite"),s=ye.dirname(t),a=ye.basename(t);this.findINodeAndDirListing(o,s,function(s,c,u){if(Ot(s,o,n))if(u[a]){var f=u[a];delete u[a],i.getINode(o,t,f,function(i,s){Ot(i,o,n)&&(!e&&s.isDirectory()?o.abort(function(){n(me.EISDIR(t))}):e&&!s.isDirectory()?o.abort(function(){n(me.ENOTDIR(t))}):o.del(s.id,function(t){Ot(t,o,n)&&o.del(f,function(t){Ot(t,o,n)&&o.put(c.id,new r(JSON.stringify(u)),!0,function(t){Ot(t,o,n)&&o.commit(n)})})}))})}else o.abort(function(){n(me.ENOENT(t))})})},e}(Ce),ei=function(){this.store={}};ei.prototype.name=function(){return"In-memory"},ei.prototype.clear=function(){this.store={}},ei.prototype.beginTransaction=function(t){return new Gr(this)},ei.prototype.get=function(t){return this.store[t]},ei.prototype.put=function(t,e,n){return!(!n&&this.store.hasOwnProperty(t))&&(this.store[t]=e,!0)},ei.prototype.del=function(t){delete this.store[t]};var ni=function(t){function e(){t.call(this,{store:new ei})}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e}(Qr),ri=_e.indexedDB||_e.mozIndexedDB||_e.webkitIndexedDB||_e.msIndexedDB,ii=function(t,e){this.tx=t,this.store=e};ii.prototype.get=function(t,e){try{var n=this.store.get(t);n.onerror=Rt(e),n.onsuccess=function(t){var n=t.target.result;void 0===n?e(null,n):e(null,v(n))}}catch(t){e(Ft(t))}};var oi=function(t){function e(e,n){t.call(this,e,n)}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e.prototype.put=function(t,e,n,r){try{var i,o=d(e);i=n?this.store.put(o,t):this.store.add(o,t),i.onerror=Rt(r),i.onsuccess=function(t){r(null,!0)}}catch(t){r(Ft(t))}},e.prototype.del=function(t,e){try{var n=this.store.delete(t);n.onerror=Rt(e),n.onsuccess=function(t){e()}}catch(t){e(Ft(t))}},e.prototype.commit=function(t){setTimeout(t,0)},e.prototype.abort=function(t){var e=null;try{this.tx.abort()}catch(t){e=Ft(t)}finally{t(e)}},e}(ii),si=function(t,e){var n=this;void 0===e&&(e="browserfs"),this.storeName=e;var r=ri.open(this.storeName,1);r.onupgradeneeded=function(t){var e=t.target.result;e.objectStoreNames.contains(n.storeName)&&e.deleteObjectStore(n.storeName),e.createObjectStore(n.storeName)},r.onsuccess=function(e){n.db=e.target.result,t(null,n)},r.onerror=Rt(t,ge.EACCES)};si.prototype.name=function(){return"IndexedDB - "+this.storeName},si.prototype.clear=function(t){try{var e=this.db.transaction(this.storeName,"readwrite"),n=e.objectStore(this.storeName),r=n.clear();r.onsuccess=function(e){setTimeout(t,0)},r.onerror=Rt(t)}catch(e){t(Ft(e))}},si.prototype.beginTransaction=function(t){void 0===t&&(t="readonly");var e=this.db.transaction(this.storeName,t),n=e.objectStore(this.storeName);if("readwrite"===t)return new oi(e,n);if("readonly"===t)return new ii(e,n);throw new me(ge.EINVAL,"Invalid transaction type.")};var ai,ci=function(t){function e(e,n){var r=this;t.call(this);var i=new si(function(t){t?e(t):r.init(i,function(t){e(t,r)})},n)}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e.isAvailable=function(){try{return"undefined"!=typeof ri&&null!==ri.open("__browserfs_test__")}catch(t){return!1}},e}(ti),ui=!1;try{_e.localStorage.setItem("__test__",String.fromCharCode(55296)),ui=_e.localStorage.getItem("__test__")===String.fromCharCode(55296)}catch(t){ui=!1}ai=ui?"binary_string":"binary_string_ie",r.isEncoding(ai)||(ai="base64");var fi=function(){};fi.prototype.name=function(){return"LocalStorage"},fi.prototype.clear=function(){_e.localStorage.clear()},fi.prototype.beginTransaction=function(t){return new Gr(this)},fi.prototype.get=function(t){try{var e=_e.localStorage.getItem(t);if(null!==e)return new r(e,ai)}catch(t){}},fi.prototype.put=function(t,e,n){try{return!(!n&&null!==_e.localStorage.getItem(t))&&(_e.localStorage.setItem(t,e.toString(ai)),!0)}catch(t){throw new me(ge.ENOSPC,"LocalStorage is full.")}},fi.prototype.del=function(t){try{_e.localStorage.removeItem(t)}catch(e){throw new me(ge.EIO,"Unable to delete key "+t+": "+e)}};for(var hi=function(t){function e(){t.call(this,{store:new fi})}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e.isAvailable=function(){return"undefined"!=typeof _e.localStorage},e}(Qr),pi=function(t){function e(){t.call(this),this.mountList=[],this.mntMap={},this.rootFs=new ni}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e.isAvailable=function(){return!0},e.prototype.mount=function(t,e){if("/"!==t[0]&&(t="/"+t),t=ye.resolve(t),this.mntMap[t])throw new me(ge.EINVAL,"Mount point "+t+" is already taken.");l(t,511,this.rootFs),this.mntMap[t]=e,this.mountList.push(t),this.mountList=this.mountList.sort(function(t,e){return e.length-t.length})},e.prototype.umount=function(t){var e=this;if("/"!==t[0]&&(t="/"+t),t=ye.resolve(t),!this.mntMap[t])throw new me(ge.EINVAL,"Mount point "+t+" is already unmounted.");for(delete this.mntMap[t],this.mountList.splice(this.mountList.indexOf(t),1);"/"!==t&&0===e.rootFs.readdirSync(t).length;)e.rootFs.rmdirSync(t),t=ye.dirname(t)},e.prototype._getFs=function(t){for(var e=this,n=this.mountList,r=n.length,i=0;i1?o.length:0),""===t&&(t="/"),{fs:e.mntMap[o],path:t}}return{fs:this.rootFs,path:t}},e.prototype.getName=function(){return"MountableFileSystem"},e.prototype.diskSpace=function(t,e){e(0,0)},e.prototype.isReadOnly=function(){return!1},e.prototype.supportsLinks=function(){return!1},e.prototype.supportsProps=function(){return!1},e.prototype.supportsSynch=function(){return!0},e.prototype.standardizeError=function(t,e,n){var r=t.message.indexOf(e);return r!==-1&&(t.message=t.message.substr(0,r)+n+t.message.substr(r+e.length),t.path=n),t},e.prototype.rename=function(t,e,n){var r=this,i=this._getFs(t),o=this._getFs(e);return i.fs===o.fs?i.fs.rename(i.path,o.path,function(s){s&&r.standardizeError(r.standardizeError(s,i.path,t),o.path,e),n(s)}):Re.readFile(t,function(r,i){return r?n(r):void Re.writeFile(e,i,function(e){return e?n(e):void Re.unlink(t,n)})})},e.prototype.renameSync=function(t,e){var n=this._getFs(t),r=this._getFs(e);if(n.fs===r.fs)try{return n.fs.renameSync(n.path,r.path)}catch(i){throw this.standardizeError(this.standardizeError(i,n.path,t),r.path,e),i}var i=Re.readFileSync(t);return Re.writeFileSync(e,i),Re.unlinkSync(t)},e.prototype.readdirSync=function(t){var e=this._getFs(t),n=null;if(e.fs!==this.rootFs)try{n=this.rootFs.readdirSync(t)}catch(t){}try{var r=e.fs.readdirSync(e.path);return null===n?r:r.concat(n.filter(function(t){return r.indexOf(t)===-1}))}catch(r){if(null===n)throw this.standardizeError(r,e.path,t);return n}},e.prototype.readdir=function(t,e){var n=this,r=this._getFs(t);r.fs.readdir(r.path,function(i,o){if(r.fs!==n.rootFs)try{var s=n.rootFs.readdirSync(t);o=o?o.concat(s.filter(function(t){return o.indexOf(t)===-1})):s}catch(o){if(i)return e(n.standardizeError(i,r.path,t))}else if(i)return e(n.standardizeError(i,r.path,t));e(null,o)})},e.prototype.rmdirSync=function(t){var e=this._getFs(t);if(this._containsMountPt(t))throw me.ENOTEMPTY(t);try{e.fs.rmdirSync(e.path)}catch(n){throw this.standardizeError(n,e.path,t)}},e.prototype.rmdir=function(t,e){var n=this,r=this._getFs(t);this._containsMountPt(t)?e(me.ENOTEMPTY(t)):r.fs.rmdir(r.path,function(i){e(i?n.standardizeError(i,r.path,t):null)})},e.prototype._containsMountPt=function(t){for(var e=this.mountList,n=e.length,r=0;r=t.length&&i.slice(0,t.length)===t)return!0}return!1},e}(Ce),li=[["exists","unlink","readlink"],["stat","mkdir","realpath","truncate"],["open","readFile","chmod","utimes"],["chown"],["writeFile","appendFile"]],di=0;di"},wi.prototype.getFSUnlocked=function(){return this._fs},wi.prototype.initialize=function(t){this._fs.initialize(t)},wi.prototype.diskSpace=function(t,e){this._fs.diskSpace(t,e)},wi.prototype.isReadOnly=function(){return this._fs.isReadOnly()},wi.prototype.supportsLinks=function(){return this._fs.supportsLinks()},wi.prototype.supportsProps=function(){return this._fs.supportsProps()},wi.prototype.supportsSynch=function(){return this._fs.supportsSynch()},wi.prototype.rename=function(t,e,n){var r=this;this._mu.lock(function(){r._fs.rename(t,e,function(t){r._mu.unlock(),n(t)})})},wi.prototype.renameSync=function(t,e){if(this._mu.isLocked())throw new Error("invalid sync call");return this._fs.renameSync(t,e)},wi.prototype.stat=function(t,e,n){var r=this;this._mu.lock(function(){r._fs.stat(t,e,function(t,e){r._mu.unlock(),n(t,e)})})},wi.prototype.statSync=function(t,e){if(this._mu.isLocked())throw new Error("invalid sync call");return this._fs.statSync(t,e)},wi.prototype.open=function(t,e,n,r){var i=this;this._mu.lock(function(){i._fs.open(t,e,n,function(t,e){i._mu.unlock(),r(t,e)})})},wi.prototype.openSync=function(t,e,n){if(this._mu.isLocked())throw new Error("invalid sync call");return this._fs.openSync(t,e,n)},wi.prototype.unlink=function(t,e){var n=this;this._mu.lock(function(){n._fs.unlink(t,function(t){n._mu.unlock(),e(t)})})},wi.prototype.unlinkSync=function(t){if(this._mu.isLocked())throw new Error("invalid sync call");return this._fs.unlinkSync(t)},wi.prototype.rmdir=function(t,e){var n=this;this._mu.lock(function(){n._fs.rmdir(t,function(t){n._mu.unlock(),e(t)})})},wi.prototype.rmdirSync=function(t){if(this._mu.isLocked())throw new Error("invalid sync call");return this._fs.rmdirSync(t)},wi.prototype.mkdir=function(t,e,n){var r=this;this._mu.lock(function(){r._fs.mkdir(t,e,function(t){r._mu.unlock(),n(t)})})},wi.prototype.mkdirSync=function(t,e){if(this._mu.isLocked())throw new Error("invalid sync call");return this._fs.mkdirSync(t,e)},wi.prototype.readdir=function(t,e){var n=this;this._mu.lock(function(){n._fs.readdir(t,function(t,r){n._mu.unlock(),e(t,r)})})},wi.prototype.readdirSync=function(t){if(this._mu.isLocked())throw new Error("invalid sync call");return this._fs.readdirSync(t)},wi.prototype.exists=function(t,e){var n=this;this._mu.lock(function(){n._fs.exists(t,function(t){n._mu.unlock(),e(t)})})},wi.prototype.existsSync=function(t){if(this._mu.isLocked())throw new Error("invalid sync call");return this._fs.existsSync(t)},wi.prototype.realpath=function(t,e,n){var r=this;this._mu.lock(function(){r._fs.realpath(t,e,function(t,e){r._mu.unlock(),n(t,e)})})},wi.prototype.realpathSync=function(t,e){if(this._mu.isLocked())throw new Error("invalid sync call");return this._fs.realpathSync(t,e)},wi.prototype.truncate=function(t,e,n){var r=this;this._mu.lock(function(){r._fs.truncate(t,e,function(t){r._mu.unlock(),n(t)})})},wi.prototype.truncateSync=function(t,e){if(this._mu.isLocked())throw new Error("invalid sync call");return this._fs.truncateSync(t,e)},wi.prototype.readFile=function(t,e,n,r){var i=this;this._mu.lock(function(){i._fs.readFile(t,e,n,function(t,e){i._mu.unlock(),r(t,e)})})},wi.prototype.readFileSync=function(t,e,n){if(this._mu.isLocked())throw new Error("invalid sync call");return this._fs.readFileSync(t,e,n)},wi.prototype.writeFile=function(t,e,n,r,i,o){var s=this;this._mu.lock(function(){s._fs.writeFile(t,e,n,r,i,function(t){s._mu.unlock(),o(t)})})},wi.prototype.writeFileSync=function(t,e,n,r,i){if(this._mu.isLocked())throw new Error("invalid sync call");return this._fs.writeFileSync(t,e,n,r,i)},wi.prototype.appendFile=function(t,e,n,r,i,o){var s=this; -this._mu.lock(function(){s._fs.appendFile(t,e,n,r,i,function(t){s._mu.unlock(),o(t)})})},wi.prototype.appendFileSync=function(t,e,n,r,i){if(this._mu.isLocked())throw new Error("invalid sync call");return this._fs.appendFileSync(t,e,n,r,i)},wi.prototype.chmod=function(t,e,n,r){var i=this;this._mu.lock(function(){i._fs.chmod(t,e,n,function(t){i._mu.unlock(),r(t)})})},wi.prototype.chmodSync=function(t,e,n){if(this._mu.isLocked())throw new Error("invalid sync call");return this._fs.chmodSync(t,e,n)},wi.prototype.chown=function(t,e,n,r,i){var o=this;this._mu.lock(function(){o._fs.chown(t,e,n,r,function(t){o._mu.unlock(),i(t)})})},wi.prototype.chownSync=function(t,e,n,r){if(this._mu.isLocked())throw new Error("invalid sync call");return this._fs.chownSync(t,e,n,r)},wi.prototype.utimes=function(t,e,n,r){var i=this;this._mu.lock(function(){i._fs.utimes(t,e,n,function(t){i._mu.unlock(),r(t)})})},wi.prototype.utimesSync=function(t,e,n){if(this._mu.isLocked())throw new Error("invalid sync call");return this._fs.utimesSync(t,e,n)},wi.prototype.link=function(t,e,n){var r=this;this._mu.lock(function(){r._fs.link(t,e,function(t){r._mu.unlock(),n(t)})})},wi.prototype.linkSync=function(t,e){if(this._mu.isLocked())throw new Error("invalid sync call");return this._fs.linkSync(t,e)},wi.prototype.symlink=function(t,e,n,r){var i=this;this._mu.lock(function(){i._fs.symlink(t,e,n,function(t){i._mu.unlock(),r(t)})})},wi.prototype.symlinkSync=function(t,e,n){if(this._mu.isLocked())throw new Error("invalid sync call");return this._fs.symlinkSync(t,e,n)},wi.prototype.readlink=function(t,e){var n=this;this._mu.lock(function(){n._fs.readlink(t,function(t,r){n._mu.unlock(),e(t,r)})})},wi.prototype.readlinkSync=function(t){if(this._mu.isLocked())throw new Error("invalid sync call");return this._fs.readlinkSync(t)};var mi,Ei="/.deletedFiles.log",Si=function(t){function e(e,n,r,i,o){t.call(this,e,n,r,i,o)}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e.prototype.sync=function(t){var e=this;return this.isDirty()?void this._fs._syncAsync(this,function(n){e.resetDirty(),t(n)}):void t(null)},e.prototype.syncSync=function(){this.isDirty()&&(this._fs._syncSync(this),this.resetDirty())},e.prototype.close=function(t){this.sync(t)},e.prototype.closeSync=function(){this.syncSync()},e}(Be),bi=function(t){function e(e,n){if(t.call(this),this._isInitialized=!1,this._initializeCallbacks=[],this._deletedFiles={},this._deleteLog="",this._deleteLogUpdatePending=!1,this._deleteLogUpdateNeeded=!1,this._deleteLogError=null,this._writable=e,this._readable=n,this._writable.isReadOnly())throw new me(ge.EINVAL,"Writable file system must be writable.")}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e.isAvailable=function(){return!0},e.prototype.getOverlayedFileSystems=function(){return{readable:this._readable,writable:this._writable}},e.prototype._syncAsync=function(t,e){var n=this;this.createParentDirectoriesAsync(t.getPath(),function(r){return r?e(r):void n._writable.writeFile(t.getPath(),t.getBuffer(),null,Tt("w"),t.getStats().mode,e)})},e.prototype._syncSync=function(t){this.createParentDirectories(t.getPath()),this._writable.writeFileSync(t.getPath(),t.getBuffer(),null,Tt("w"),t.getStats().mode)},e.prototype.getName=function(){return"OverlayFS"},e.prototype.initialize=function(t){var e=this,n=this._initializeCallbacks,r=function(t){e._isInitialized=!t,e._initializeCallbacks=[],n.forEach(function(e){return e(t)})};return this._isInitialized?t():(n.push(t),void(1===n.length&&this._writable.readFile(Ei,"utf8",Tt("r"),function(t,n){if(t){if(t.errno!==ge.ENOENT)return r(t)}else e._deleteLog=n;e._reparseDeletionLog(),r()})))},e.prototype.isReadOnly=function(){return!1},e.prototype.supportsSynch=function(){return this._readable.supportsSynch()&&this._writable.supportsSynch()},e.prototype.supportsLinks=function(){return!1},e.prototype.supportsProps=function(){return this._readable.supportsProps()&&this._writable.supportsProps()},e.prototype.getDeletionLog=function(){return this._deleteLog},e.prototype.restoreDeletionLog=function(t){this._deleteLog=t,this._reparseDeletionLog(),this.updateLog("")},e.prototype.rename=function(t,e,n){var r=this;if(this.checkInitAsync(n)&&!this.checkPathAsync(t,n)&&!this.checkPathAsync(e,n))return t===Ei||e===Ei?n(me.EPERM("Cannot rename deletion log.")):t===e?n():void this.stat(t,!1,function(i,o){return i?n(i):r.stat(e,!1,function(i,s){function a(r){var i=r.shift();if(!i)return n();var o=ye.resolve(t,i),s=ye.resolve(e,i);c.rename(o,s,function(t){return t?n(t):void a(r)})}var c=r,u=511;if(o.isDirectory()){if(i)return i.errno!==ge.ENOENT?n(i):r._writable.exists(t,function(i){return i?r._writable.rename(t,e,n):void r._writable.mkdir(e,u,function(e){return e?n(e):void r._readable.readdir(t,function(t,e){return t?n():void a(e)})})});if(u=s.mode,!s.isDirectory())return n(me.ENOTDIR(e));r.readdir(e,function(i,o){return o&&o.length?n(me.ENOTEMPTY(e)):void r._readable.readdir(t,function(t,e){return t?n():void a(e)})})}return s&&s.isDirectory()?n(me.EISDIR(e)):void r.readFile(t,null,Tt("r"),function(i,s){return i?n(i):r.writeFile(e,s,null,Tt("w"),o.mode,function(e){return e?n(e):r.unlink(t,n)})})})})},e.prototype.renameSync=function(t,e){var n=this;if(this.checkInitialized(),this.checkPath(t),this.checkPath(e),t===Ei||e===Ei)throw me.EPERM("Cannot rename deletion log.");var r=this.statSync(t,!1);if(r.isDirectory()){if(t===e)return;var i=511;if(this.existsSync(e)){var o=this.statSync(e,!1);if(i=o.mode,!o.isDirectory())throw me.ENOTDIR(e);if(this.readdirSync(e).length>0)throw me.ENOTEMPTY(e)}this._writable.existsSync(t)?this._writable.renameSync(t,e):this._writable.existsSync(e)||this._writable.mkdirSync(e,i),this._readable.existsSync(t)&&this._readable.readdirSync(t).forEach(function(r){n.renameSync(ye.resolve(t,r),ye.resolve(e,r))})}else{if(this.existsSync(e)&&this.statSync(e,!1).isDirectory())throw me.EISDIR(e);this.writeFileSync(e,this.readFileSync(t,null,Tt("r")),null,Tt("w"),r.mode)}t!==e&&this.existsSync(t)&&this.unlinkSync(t)},e.prototype.stat=function(t,e,n){var r=this;this.checkInitAsync(n)&&this._writable.stat(t,e,function(i,o){i&&i.errno===ge.ENOENT?(r._deletedFiles[t]&&n(me.ENOENT(t)),r._readable.stat(t,e,function(t,e){e&&(e=e.clone(),e.mode=Lt(e.mode)),n(t,e)})):n(i,o)})},e.prototype.statSync=function(t,e){this.checkInitialized();try{return this._writable.statSync(t,e)}catch(r){if(this._deletedFiles[t])throw me.ENOENT(t);var n=this._readable.statSync(t,e).clone();return n.mode=Lt(n.mode),n}},e.prototype.open=function(t,e,n,r){var i=this;this.checkInitAsync(r)&&!this.checkPathAsync(t,r)&&this.stat(t,!1,function(o,s){if(s)switch(e.pathExistsAction()){case we.TRUNCATE_FILE:return i.createParentDirectoriesAsync(t,function(o){return o?r(o):void i._writable.open(t,e,n,r)});case we.NOP:return i._writable.exists(t,function(o){o?i._writable.open(t,e,n,r):(s=s.clone(),s.mode=n,i._readable.readFile(t,null,Tt("r"),function(n,o){if(n)return r(n);s.size===-1&&(s.size=o.length);var a=new Si(i,t,e,s,o);r(null,a)}))});default:return r(me.EEXIST(t))}else switch(e.pathNotExistsAction()){case we.CREATE_FILE:return i.createParentDirectoriesAsync(t,function(o){return o?r(o):i._writable.open(t,e,n,r)});default:return r(me.ENOENT(t))}})},e.prototype.openSync=function(t,e,n){if(this.checkInitialized(),this.checkPath(t),t===Ei)throw me.EPERM("Cannot open deletion log.");if(this.existsSync(t))switch(e.pathExistsAction()){case we.TRUNCATE_FILE:return this.createParentDirectories(t),this._writable.openSync(t,e,n);case we.NOP:if(this._writable.existsSync(t))return this._writable.openSync(t,e,n);var r=this._readable.readFileSync(t,null,Tt("r")),i=this._readable.statSync(t,!1).clone();return i.mode=n,new Si(this,t,e,i,r);default:throw me.EEXIST(t)}else switch(e.pathNotExistsAction()){case we.CREATE_FILE:return this.createParentDirectories(t),this._writable.openSync(t,e,n);default:throw me.ENOENT(t)}},e.prototype.unlink=function(t,e){var n=this;this.checkInitAsync(e)&&!this.checkPathAsync(t,e)&&this.exists(t,function(r){return r?void n._writable.exists(t,function(r){return r?n._writable.unlink(t,function(r){return r?e(r):void n.exists(t,function(r){r&&n.deletePath(t),e(null)})}):(n.deletePath(t),void e(null))}):e(me.ENOENT(t))})},e.prototype.unlinkSync=function(t){if(this.checkInitialized(),this.checkPath(t),!this.existsSync(t))throw me.ENOENT(t);this._writable.existsSync(t)&&this._writable.unlinkSync(t),this.existsSync(t)&&this.deletePath(t)},e.prototype.rmdir=function(t,e){var n=this;if(this.checkInitAsync(e)){var r=function(){n.readdir(t,function(r,i){return r?e(r):i.length?e(me.ENOTEMPTY(t)):(n.deletePath(t),void e(null))})};this.exists(t,function(i){return i?void n._writable.exists(t,function(i){i?n._writable.rmdir(t,function(i){return i?e(i):void n._readable.exists(t,function(t){t?r():e()})}):r()}):e(me.ENOENT(t))})}},e.prototype.rmdirSync=function(t){if(this.checkInitialized(),!this.existsSync(t))throw me.ENOENT(t);if(this._writable.existsSync(t)&&this._writable.rmdirSync(t),this.existsSync(t)){if(this.readdirSync(t).length>0)throw me.ENOTEMPTY(t);this.deletePath(t)}},e.prototype.mkdir=function(t,e,n){var r=this;this.checkInitAsync(n)&&this.exists(t,function(i){return i?n(me.EEXIST(t)):void r.createParentDirectoriesAsync(t,function(i){return i?n(i):void r._writable.mkdir(t,e,n)})})},e.prototype.mkdirSync=function(t,e){if(this.checkInitialized(),this.existsSync(t))throw me.EEXIST(t);this.createParentDirectories(t),this._writable.mkdirSync(t,e)},e.prototype.readdir=function(t,e){var n=this;this.checkInitAsync(e)&&this.stat(t,!1,function(r,i){return r?e(r):i.isDirectory()?void n._writable.readdir(t,function(r,i){return r&&"ENOENT"!==r.code?e(r):(!r&&i||(i=[]),void n._readable.readdir(t,function(r,o){!r&&o||(o=[]);var s={},a=i.concat(o.filter(function(e){return!n._deletedFiles[t+"/"+e]})).filter(function(t){var e=!s[t];return s[t]=!0,e});e(null,a)}))}):e(me.ENOTDIR(t))})},e.prototype.readdirSync=function(t){var e=this;this.checkInitialized();var n=this.statSync(t,!1);if(!n.isDirectory())throw me.ENOTDIR(t);var r=[];try{r=r.concat(this._writable.readdirSync(t))}catch(t){}try{r=r.concat(this._readable.readdirSync(t).filter(function(n){return!e._deletedFiles[t+"/"+n]}))}catch(t){}var i={};return r.filter(function(t){var e=!i[t];return i[t]=!0,e})},e.prototype.exists=function(t,e){var n=this;this.checkInitialized(),this._writable.exists(t,function(r){return r?e(!0):void n._readable.exists(t,function(r){e(r&&n._deletedFiles[t]!==!0)})})},e.prototype.existsSync=function(t){return this.checkInitialized(),this._writable.existsSync(t)||this._readable.existsSync(t)&&this._deletedFiles[t]!==!0},e.prototype.chmod=function(t,e,n,r){var i=this;this.checkInitAsync(r)&&this.operateOnWritableAsync(t,function(o){return o?r(o):void i._writable.chmod(t,e,n,r)})},e.prototype.chmodSync=function(t,e,n){var r=this;this.checkInitialized(),this.operateOnWritable(t,function(){r._writable.chmodSync(t,e,n)})},e.prototype.chown=function(t,e,n,r,i){var o=this;this.checkInitAsync(i)&&this.operateOnWritableAsync(t,function(s){return s?i(s):void o._writable.chown(t,e,n,r,i)})},e.prototype.chownSync=function(t,e,n,r){var i=this;this.checkInitialized(),this.operateOnWritable(t,function(){i._writable.chownSync(t,e,n,r)})},e.prototype.utimes=function(t,e,n,r){var i=this;this.checkInitAsync(r)&&this.operateOnWritableAsync(t,function(o){return o?r(o):void i._writable.utimes(t,e,n,r)})},e.prototype.utimesSync=function(t,e,n){var r=this;this.checkInitialized(),this.operateOnWritable(t,function(){r._writable.utimesSync(t,e,n)})},e.prototype.deletePath=function(t){this._deletedFiles[t]=!0,this.updateLog("d"+t+"\n")},e.prototype.updateLog=function(t){var e=this;this._deleteLog+=t,this._deleteLogUpdatePending?this._deleteLogUpdateNeeded=!0:(this._deleteLogUpdatePending=!0,this._writable.writeFile(Ei,this._deleteLog,"utf8",Se.getFileFlag("w"),420,function(t){e._deleteLogUpdatePending=!1,t?e._deleteLogError=t:e._deleteLogUpdateNeeded&&(e._deleteLogUpdateNeeded=!1,e.updateLog(""))}))},e.prototype._reparseDeletionLog=function(){var t=this;this._deletedFiles={},this._deleteLog.split("\n").forEach(function(e){t._deletedFiles[e.slice(1)]="d"===e.slice(0,1)})},e.prototype.checkInitialized=function(){if(!this._isInitialized)throw new me(ge.EPERM,"OverlayFS is not initialized. Please initialize OverlayFS using its initialize() method before using it.");if(null!==this._deleteLogError){var t=this._deleteLogError;throw this._deleteLogError=null,t}},e.prototype.checkInitAsync=function(t){if(!this._isInitialized)return t(new me(ge.EPERM,"OverlayFS is not initialized. Please initialize OverlayFS using its initialize() method before using it.")),!1;if(null!==this._deleteLogError){var e=this._deleteLogError;return this._deleteLogError=null,t(e),!1}return!0},e.prototype.checkPath=function(t){if(t===Ei)throw me.EPERM(t)},e.prototype.checkPathAsync=function(t,e){return t===Ei&&(e(me.EPERM(t)),!0)},e.prototype.createParentDirectoriesAsync=function(t,e){function n(t,e){t?(o.push(i),i=ye.dirname(i),s._writable.stat(i,!1,n)):r()}function r(){if(!o.length)return e();var t=o.pop();s._readable.stat(t,!1,function(n,i){return i?void s._writable.mkdir(t,i.mode,function(t){return t?e(t):void r()}):e()})}var i=ye.dirname(t),o=[],s=this;this._writable.stat(i,!1,n)},e.prototype.createParentDirectories=function(t){for(var e=this,n=ye.dirname(t),r=[];!this._writable.existsSync(n);)r.push(n),n=ye.dirname(n);r=r.reverse(),r.forEach(function(t){e._writable.mkdirSync(t,e.statSync(t,!1).mode)})},e.prototype.operateOnWritable=function(t,e){if(!this.existsSync(t))throw me.ENOENT(t);this._writable.existsSync(t)||this.copyToWritable(t),e()},e.prototype.operateOnWritableAsync=function(t,e){var n=this;this.exists(t,function(r){return r?void n._writable.exists(t,function(r){return r?void e():n.copyToWritableAsync(t,e)}):e(me.ENOENT(t))})},e.prototype.copyToWritable=function(t){var e=this.statSync(t,!1);e.isDirectory()?this._writable.mkdirSync(t,e.mode):this.writeFileSync(t,this._readable.readFileSync(t,null,Tt("r")),null,Tt("w"),this.statSync(t,!1).mode)},e.prototype.copyToWritableAsync=function(t,e){var n=this;this.stat(t,!1,function(r,i){return r?e(r):i.isDirectory()?n._writable.mkdir(t,i.mode,e):void n._readable.readFile(t,null,Tt("r"),function(r,o){return r?e(r):void n.writeFile(t,o,null,Tt("w"),i.mode,e)})})},e}(Ce),ki=function(t){function e(e,n){t.call(this,new bi(e,n))}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e.isAvailable=function(){return bi.isAvailable()},e.prototype.initialize=function(e){t.prototype.initialize.call(this,e)},e.prototype.getOverlayedFileSystems=function(){return t.prototype.getFSUnlocked.call(this).getOverlayedFileSystems()},e.prototype.unwrap=function(){return t.prototype.getFSUnlocked.call(this)},e}(wi);!function(t){t[t.CB=0]="CB",t[t.FD=1]="FD",t[t.API_ERROR=2]="API_ERROR",t[t.STATS=3]="STATS",t[t.PROBE=4]="PROBE",t[t.FILEFLAG=5]="FILEFLAG",t[t.BUFFER=6]="BUFFER",t[t.ERROR=7]="ERROR"}(mi||(mi={}));var Ii=function(){this._callbacks={},this._nextId=0};Ii.prototype.toRemoteArg=function(t){var e=this._nextId++;return this._callbacks[e]=t,{type:mi.CB,id:e}},Ii.prototype.toLocalArg=function(t){var e=this._callbacks[t];return delete this._callbacks[t],e};var Oi=function(){this._fileDescriptors={},this._nextId=0};Oi.prototype.toRemoteArg=function(t,e,n,i){var o,s,a=this._nextId++;this._fileDescriptors[a]=t,t.stat(function(c,u){c?i(c):(s=jt(u.toBuffer()),n.isReadable()?t.read(new r(u.size),0,u.size,0,function(t,r,c){t?i(t):(o=jt(c),i(null,{type:mi.FD,id:a,data:o,stat:s,path:e,flag:n.getFlagString()}))}):i(null,{type:mi.FD,id:a,data:new ArrayBuffer(0),stat:s,path:e,flag:n.getFlagString()}))})},Oi.prototype.applyFdAPIRequest=function(t,e){var n=this,r=t.args[0];this._applyFdChanges(r,function(i,o){i?e(i):o[t.method](function(i){"close"===t.method&&delete n._fileDescriptors[r.id],e(i)})})},Oi.prototype._applyFdChanges=function(t,e){var n=this._fileDescriptors[t.id],r=zt(t.data),i=ke.fromBuffer(zt(t.stat)),o=Se.getFileFlag(t.flag);o.isWriteable()?n.write(r,0,r.length,o.isAppendable()?n.getPos():0,function(t){function s(){n.stat(function(t,r){t?e(t):r.mode!==i.mode?n.chmod(i.mode,function(t){e(t,n)}):e(t,n)})}t?e(t):o.isAppendable()?s():n.truncate(r.length,function(){s()})}):e(null,n)};var Fi=function(t){function e(e,n,r,i,o,s){t.call(this,e,n,r,i,s),this._remoteFdId=o}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e.prototype.getRemoteFdId=function(){return this._remoteFdId},e.prototype.toRemoteArg=function(){return{type:mi.FD,id:this._remoteFdId,data:jt(this.getBuffer()),stat:jt(this.getStats().toBuffer()),path:this.getPath(),flag:this.getFlag().getFlagString()}},e.prototype.sync=function(t){this._syncClose("sync",t)},e.prototype.close=function(t){this._syncClose("close",t)},e.prototype._syncClose=function(t,e){var n=this;this.isDirty()?this._fs.syncClose(t,this,function(t){t||n.resetDirty(),e(t)}):e()},e}(Be),Ri=function(t){function e(e){var n=this;t.call(this),this._callbackConverter=new Ii,this._isInitialized=!1,this._isReadOnly=!1,this._supportLinks=!1,this._supportProps=!1,this._worker=e,this._worker.addEventListener("message",function(t){var e=t.data;if(Ht(e)){var r,i=e.args,o=new Array(i.length);for(r=0;r0&&(u=-1,s={browserfsMessage:!0,cbId:o,args:[xt(e)]},t.postMessage(s))}var i,s,a=arguments,c=new Array(arguments.length),u=arguments.length;for(i=0;i0;){var i=void 0,o=r.pop(),s=o[0],a=o[1],c=o[2];for(var u in a)if(a.hasOwnProperty(u)){var f=a[u],h=s+"/"+u;f?(e._index[h]=i=new Di,r.push([h,f,i])):i=new xi(new ke(be.FILE,-1,365)),c&&(c._ls[u]=i)}}return e},Ti.prototype.fileIterator=function(t){var e=this;for(var n in e._index)if(e._index.hasOwnProperty(n))for(var r=e._index[n],i=r.getListing(),o=0;o0&&"/"!==n.charAt(n.length-1)&&(n+="/"),this.prefixUrl=n;var r=null;if("string"==typeof e){if(r=this._requestFileSync(e,"json"),!r)throw new Error("Unable to find listing at URL: ${listingUrlOrObj}")}else r=e;this._index=Ti.fromListing(r)}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e.isAvailable=function(){return"undefined"!=typeof XMLHttpRequest&&null!==XMLHttpRequest},e.prototype.empty=function(){this._index.fileIterator(function(t){t.fileData=null})},e.prototype._requestFileSizeAsync=function(t,e){Jt(this.getXhrPath(t),e)},e.prototype._requestFileSizeSync=function(t){return Gt(this.getXhrPath(t))},e.prototype.getName=function(){return"XmlHttpRequest"},e.prototype.diskSpace=function(t,e){e(0,0)},e.prototype.isReadOnly=function(){return!0},e.prototype.supportsLinks=function(){return!1},e.prototype.supportsProps=function(){return!1},e.prototype.supportsSynch=function(){return!0},e.prototype.preloadFile=function(t,e){var n=this._index.getInode(t);if(!Qt(n))throw me.EISDIR(t);if(null===n)throw me.ENOENT(t);var r=n.getData();r.size=e.length,r.fileData=e},e.prototype.stat=function(t,e,n){var r=this._index.getInode(t);if(null===r)return n(me.ENOENT(t));var i;Qt(r)?(i=r.getData(),i.size<0?this._requestFileSizeAsync(t,function(t,e){return t?n(t):(i.size=e,void n(null,i.clone()))}):n(null,i.clone())):$t(r)?(i=r.getStats(),n(null,i)):n(me.FileError(ge.EINVAL,t))},e.prototype.statSync=function(t,e){var n=this._index.getInode(t);if(null===n)throw me.ENOENT(t);var r;if(Qt(n))r=n.getData(),r.size<0&&(r.size=this._requestFileSizeSync(t));else{if(!$t(n))throw me.FileError(ge.EINVAL,t);r=n.getStats()}return r},e.prototype.open=function(t,e,n,r){if(e.isWriteable())return r(new me(ge.EPERM,t));var i=this,o=this._index.getInode(t);if(null===o)return r(me.ENOENT(t));if(!Qt(o))return r(me.EISDIR(t));var s=o.getData();switch(e.pathExistsAction()){case we.THROW_EXCEPTION:case we.TRUNCATE_FILE:return r(me.EEXIST(t));case we.NOP:if(s.fileData)return r(null,new je(i,t,e,s.clone(),s.fileData));this._requestFileAsync(t,"buffer",function(n,o){return n?r(n):(s.size=o.length,s.fileData=o,r(null,new je(i,t,e,s.clone(),o)))});break;default:return r(new me(ge.EINVAL,"Invalid FileMode object."))}},e.prototype.openSync=function(t,e,n){if(e.isWriteable())throw new me(ge.EPERM,t);var r=this._index.getInode(t);if(null===r)throw me.ENOENT(t);if(!Qt(r))throw me.EISDIR(t);var i=r.getData();switch(e.pathExistsAction()){case we.THROW_EXCEPTION:case we.TRUNCATE_FILE:throw me.EEXIST(t);case we.NOP:if(i.fileData)return new je(this,t,e,i.clone(),i.fileData);var o=this._requestFileSync(t,"buffer");return i.size=o.length,i.fileData=o,new je(this,t,e,i.clone(),o);default:throw new me(ge.EINVAL,"Invalid FileMode object.")}},e.prototype.readdir=function(t,e){try{e(null,this.readdirSync(t))}catch(t){e(t)}},e.prototype.readdirSync=function(t){var e=this._index.getInode(t);if(null===e)throw me.ENOENT(t);if($t(e))return e.getListing();throw me.ENOTDIR(t)},e.prototype.readFile=function(t,e,n,r){var i=r;this.open(t,n,420,function(t,n){if(t)return r(t);r=function(t,e){n.close(function(n){return t||(t=n),i(t,e)})};var o=n,s=o.getBuffer();null===e?r(t,w(s)):te(s,e,r)})},e.prototype.readFileSync=function(t,e,n){var r=this.openSync(t,n,420);try{var i=r,o=i.getBuffer();return null===e?w(o):o.toString(e)}finally{r.closeSync()}},e.prototype.getXhrPath=function(t){return"/"===t.charAt(0)&&(t=t.slice(1)),this.prefixUrl+t},e.prototype._requestFileAsync=function(t,e,n){Ni(this.getXhrPath(t),e,n)},e.prototype._requestFileSync=function(t,e){return Li(this.getXhrPath(t),e)},e}(Ce),Pi=function(){};Pi.str2byte=function(t,e){for(var n=t.length>e.length?e.length:t.length,r=0;r127){var o=Pi.extendedChars.indexOf(t.charAt(r));o>-1&&(i=o+128)}e[i]=r}return n},Pi.byte2str=function(t){for(var e=new Array(t.length),n=0;n127?e[n]=Pi.extendedChars[r-128]:e[n]=String.fromCharCode(r)}return e.join("")},Pi.byteLength=function(t){return t.length},Pi.extendedChars=["Ç","ü","é","â","ä","à","å","ç","ê","ë","è","ï","î","ì","Ä","Å","É","æ","Æ","ô","ö","ò","û","ù","ÿ","Ö","Ü","ø","£","Ø","×","ƒ","á","í","ó","ú","ñ","Ñ","ª","º","¿","®","¬","½","¼","¡","«","»","_","_","_","¦","¦","Á","Â","À","©","¦","¦","+","+","¢","¥","+","+","-","-","+","-","+","ã","Ã","+","+","-","-","¦","-","+","¤","ð","Ð","Ê","Ë","È","i","Í","Î","Ï","+","+","_","_","¦","Ì","_","Ó","ß","Ô","Ò","õ","Õ","µ","þ","Þ","Ú","Û","Ù","ý","Ý","¯","´","­","±","_","¾","¶","§","÷","¸","°","¨","·","¹","³","²","_"," "];var Ci,Ui=n(23).inflateRaw,Mi={};!function(t){t[t.MSDOS=0]="MSDOS",t[t.AMIGA=1]="AMIGA",t[t.OPENVMS=2]="OPENVMS",t[t.UNIX=3]="UNIX",t[t.VM_CMS=4]="VM_CMS",t[t.ATARI_ST=5]="ATARI_ST",t[t.OS2_HPFS=6]="OS2_HPFS",t[t.MAC=7]="MAC",t[t.Z_SYSTEM=8]="Z_SYSTEM",t[t.CP_M=9]="CP_M",t[t.NTFS=10]="NTFS",t[t.MVS=11]="MVS",t[t.VSE=12]="VSE",t[t.ACORN_RISC=13]="ACORN_RISC",t[t.VFAT=14]="VFAT",t[t.ALT_MVS=15]="ALT_MVS",t[t.BEOS=16]="BEOS",t[t.TANDEM=17]="TANDEM",t[t.OS_400=18]="OS_400",t[t.OSX=19]="OSX"}(Ci||(Ci={}));var Bi;!function(t){t[t.STORED=0]="STORED",t[t.SHRUNK=1]="SHRUNK",t[t.REDUCED_1=2]="REDUCED_1",t[t.REDUCED_2=3]="REDUCED_2",t[t.REDUCED_3=4]="REDUCED_3",t[t.REDUCED_4=5]="REDUCED_4",t[t.IMPLODE=6]="IMPLODE",t[t.DEFLATE=8]="DEFLATE",t[t.DEFLATE64=9]="DEFLATE64",t[t.TERSE_OLD=10]="TERSE_OLD",t[t.BZIP2=12]="BZIP2",t[t.LZMA=14]="LZMA",t[t.TERSE_NEW=18]="TERSE_NEW",t[t.LZ77=19]="LZ77",t[t.WAVPACK=97]="WAVPACK",t[t.PPMD=98]="PPMD"}(Bi||(Bi={}));var ji=function(t){if(this.data=t,67324752!==t.readUInt32LE(0))throw new me(ge.EINVAL,"Invalid Zip file: Local file header has invalid signature: "+this.data.readUInt32LE(0))};ji.prototype.versionNeeded=function(){return this.data.readUInt16LE(4)},ji.prototype.flags=function(){return this.data.readUInt16LE(6)},ji.prototype.compressionMethod=function(){return this.data.readUInt16LE(8)},ji.prototype.lastModFileTime=function(){return ee(this.data.readUInt16LE(10),this.data.readUInt16LE(12))},ji.prototype.rawLastModFileTime=function(){return this.data.readUInt32LE(10)},ji.prototype.crc32=function(){return this.data.readUInt32LE(14)},ji.prototype.fileNameLength=function(){return this.data.readUInt16LE(26)},ji.prototype.extraFieldLength=function(){return this.data.readUInt16LE(28)},ji.prototype.fileName=function(){return ne(this.data,this.useUTF8(),30,this.fileNameLength())},ji.prototype.extraField=function(){var t=30+this.fileNameLength();return this.data.slice(t,t+this.extraFieldLength())},ji.prototype.totalSize=function(){return 30+this.fileNameLength()+this.extraFieldLength()},ji.prototype.useUTF8=function(){return 2048===(2048&this.flags())};var zi=function(t,e,n){this.header=t,this.record=e,this.data=n};zi.prototype.decompress=function(){var t=this.header.compressionMethod(),e=Mi[t];if(e)return e(this.data,this.record.compressedSize(),this.record.uncompressedSize(),this.record.flag()); -var n=Bi[t];throw n||(n="Unknown: "+t),new me(ge.EINVAL,"Invalid compression method on file '"+this.header.fileName()+"': "+n)},zi.prototype.getHeader=function(){return this.header},zi.prototype.getRecord=function(){return this.record},zi.prototype.getRawData=function(){return this.data};var qi=function(t){this.data=t};qi.prototype.crc32=function(){return this.data.readUInt32LE(0)},qi.prototype.compressedSize=function(){return this.data.readUInt32LE(4)},qi.prototype.uncompressedSize=function(){return this.data.readUInt32LE(8)};var Vi=function(t){if(this.data=t,134630224!==this.data.readUInt32LE(0))throw new me(ge.EINVAL,"Invalid archive extra data record signature: "+this.data.readUInt32LE(0))};Vi.prototype.length=function(){return this.data.readUInt32LE(4)},Vi.prototype.extraFieldData=function(){return this.data.slice(8,8+this.length())};var Wi=function(t){if(this.data=t,84233040!==this.data.readUInt32LE(0))throw new me(ge.EINVAL,"Invalid digital signature signature: "+this.data.readUInt32LE(0))};Wi.prototype.size=function(){return this.data.readUInt16LE(4)},Wi.prototype.signatureData=function(){return this.data.slice(6,6+this.size())};var Hi=function(t,e){if(this.zipData=t,this.data=e,33639248!==this.data.readUInt32LE(0))throw new me(ge.EINVAL,"Invalid Zip file: Central directory record has invalid signature: "+this.data.readUInt32LE(0));this._filename=this.produceFilename()};Hi.prototype.versionMadeBy=function(){return this.data.readUInt16LE(4)},Hi.prototype.versionNeeded=function(){return this.data.readUInt16LE(6)},Hi.prototype.flag=function(){return this.data.readUInt16LE(8)},Hi.prototype.compressionMethod=function(){return this.data.readUInt16LE(10)},Hi.prototype.lastModFileTime=function(){return ee(this.data.readUInt16LE(12),this.data.readUInt16LE(14))},Hi.prototype.rawLastModFileTime=function(){return this.data.readUInt32LE(12)},Hi.prototype.crc32=function(){return this.data.readUInt32LE(16)},Hi.prototype.compressedSize=function(){return this.data.readUInt32LE(20)},Hi.prototype.uncompressedSize=function(){return this.data.readUInt32LE(24)},Hi.prototype.fileNameLength=function(){return this.data.readUInt16LE(28)},Hi.prototype.extraFieldLength=function(){return this.data.readUInt16LE(30)},Hi.prototype.fileCommentLength=function(){return this.data.readUInt16LE(32)},Hi.prototype.diskNumberStart=function(){return this.data.readUInt16LE(34)},Hi.prototype.internalAttributes=function(){return this.data.readUInt16LE(36)},Hi.prototype.externalAttributes=function(){return this.data.readUInt32LE(38)},Hi.prototype.headerRelativeOffset=function(){return this.data.readUInt32LE(42)},Hi.prototype.produceFilename=function(){var t=ne(this.data,this.useUTF8(),46,this.fileNameLength());return t.replace(/\\/g,"/")},Hi.prototype.fileName=function(){return this._filename},Hi.prototype.rawFileName=function(){return this.data.slice(46,46+this.fileNameLength())},Hi.prototype.extraField=function(){var t=44+this.fileNameLength();return this.data.slice(t,t+this.extraFieldLength())},Hi.prototype.fileComment=function(){var t=46+this.fileNameLength()+this.extraFieldLength();return ne(this.data,this.useUTF8(),t,this.fileCommentLength())},Hi.prototype.rawFileComment=function(){var t=46+this.fileNameLength()+this.extraFieldLength();return this.data.slice(t,t+this.fileCommentLength())},Hi.prototype.totalSize=function(){return 46+this.fileNameLength()+this.extraFieldLength()+this.fileCommentLength()},Hi.prototype.isDirectory=function(){var t=this.fileName();return!!(16&this.externalAttributes())||"/"===t.charAt(t.length-1)},Hi.prototype.isFile=function(){return!this.isDirectory()},Hi.prototype.useUTF8=function(){return 2048===(2048&this.flag())},Hi.prototype.isEncrypted=function(){return 1===(1&this.flag())},Hi.prototype.getFileData=function(){var t=this.headerRelativeOffset(),e=new ji(this.zipData.slice(t));return new zi(e,this,this.zipData.slice(t+e.totalSize()))},Hi.prototype.getData=function(){return this.getFileData().decompress()},Hi.prototype.getRawData=function(){return this.getFileData().getRawData()},Hi.prototype.getStats=function(){return new ke(be.FILE,this.uncompressedSize(),365,new Date,this.lastModFileTime())};var Zi=function(t){if(this.data=t,101010256!==this.data.readUInt32LE(0))throw new me(ge.EINVAL,"Invalid Zip file: End of central directory record has invalid signature: "+this.data.readUInt32LE(0))};Zi.prototype.diskNumber=function(){return this.data.readUInt16LE(4)},Zi.prototype.cdDiskNumber=function(){return this.data.readUInt16LE(6)},Zi.prototype.cdDiskEntryCount=function(){return this.data.readUInt16LE(8)},Zi.prototype.cdTotalEntryCount=function(){return this.data.readUInt16LE(10)},Zi.prototype.cdSize=function(){return this.data.readUInt32LE(12)},Zi.prototype.cdOffset=function(){return this.data.readUInt32LE(16)},Zi.prototype.cdZipCommentLength=function(){return this.data.readUInt16LE(20)},Zi.prototype.cdZipComment=function(){return ne(this.data,!0,22,this.cdZipCommentLength())},Zi.prototype.rawCdZipComment=function(){return this.data.slice(22,22+this.cdZipCommentLength())};var Yi=function(t,e,n,r){this.index=t,this.directoryEntries=e,this.eocd=n,this.data=r},Xi=function(t){function e(e,n){void 0===n&&(n=""),t.call(this),this.name=n,this._index=new Ti,this._directoryEntries=[],this._eocd=null,e instanceof Yi?(this._index=e.index,this._directoryEntries=e.directoryEntries,this._eocd=e.eocd,this.data=e.data):(this.data=e,this.populateIndex())}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e.isAvailable=function(){return!0},e.RegisterDecompressionMethod=function(t,e){Mi[t]=e},e.computeIndex=function(t,n){var r=new Ti,i=e.getEOCD(t);if(i.diskNumber()!==i.cdDiskNumber())throw new me(ge.EINVAL,"ZipFS does not support spanned zip files.");var o=i.cdOffset();if(4294967295===o)throw new me(ge.EINVAL,"ZipFS does not support Zip64.");var s=o+i.cdSize();e.computeIndexResponsive(t,r,o,s,n,[],i)},e.getEOCD=function(t){for(var e=22,n=Math.min(e+65535,t.length-1),r=e;r-1},to.prototype.getRockRidgeOffset=function(){return this._rockRidgeOffset},to.prototype.rootCheckForRockRidge=function(t){var e=this.getDirectory(t);this._rockRidgeOffset=e.getDotEntry(t)._getRockRidgeOffset(t),this._rockRidgeOffset>-1&&(this._fileOrDir=null)},to.prototype.length=function(){return this._data[0]},to.prototype.extendedAttributeRecordLength=function(){return this._data[1]},to.prototype.lba=function(){return 2048*this._data.readUInt32LE(2)},to.prototype.dataLength=function(){return this._data.readUInt32LE(10)},to.prototype.recordingDate=function(){return se(this._data,18)},to.prototype.fileFlags=function(){return this._data[25]},to.prototype.fileUnitSize=function(){return this._data[26]},to.prototype.interleaveGapSize=function(){return this._data[27]},to.prototype.volumeSequenceNumber=function(){return this._data.readUInt16LE(28)},to.prototype.identifier=function(){return this._getString(33,this._data[32])},to.prototype.fileName=function(t){if(this.hasRockRidge()){var e=this._rockRidgeFilename(t);if(null!==e)return e}var n=this.identifier();if(this.isDirectory(t))return n;var r=n.indexOf(";");return r===-1?n:"."===n[r-1]?n.slice(0,r-1):n.slice(0,r)},to.prototype.isDirectory=function(t){var e=!!(2&this.fileFlags());return!e&&this.hasRockRidge()&&(e=this.getSUEntries(t).filter(function(t){return t instanceof _o}).length>0),e},to.prototype.isSymlink=function(t){return this.hasRockRidge()&&this.getSUEntries(t).filter(function(t){return t instanceof lo}).length>0},to.prototype.getSymlinkPath=function(t){for(var e="",n=this.getSUEntries(t),r=this._getGetString(),i=0;i1&&"/"===e[e.length-1]?e.slice(0,e.length-1):e},to.prototype.getFile=function(t){if(this.isDirectory(t))throw new Error("Tried to get a File from a directory.");return null===this._fileOrDir&&(this._fileOrDir=t.slice(this.lba(),this.lba()+this.dataLength())),this._fileOrDir},to.prototype.getDirectory=function(t){if(!this.isDirectory(t))throw new Error("Tried to get a Directory from a file.");return null===this._fileOrDir&&(this._fileOrDir=this._constructDirectory(t)),this._fileOrDir},to.prototype.getSUEntries=function(t){return this._suEntries||this._constructSUEntries(t),this._suEntries},to.prototype._rockRidgeFilename=function(t){var e=this.getSUEntries(t).filter(function(t){return t instanceof go});if(0===e.length||6&e[0].flags())return null;for(var n="",r=this._getGetString(),i=0;i0){var n=e[0];if(n instanceof so&&n.checkBytesPass())for(var r=1;r0)){var e=Ro.shift();return e()}};Fo.addEventListener?Fo.addEventListener("message",To,!0):Fo.attachEvent("onmessage",To)}else if(Fo.MessageChannel){var xo=new Fo.MessageChannel;xo.port1.onmessage=function(t){if(Ro.length>0)return Ro.shift()()},Fo.setImmediate=function(t){Ro.push(t),xo.port2.postMessage("")}}else Fo.setImmediate=function(t){return setTimeout(t,0)}}"undefined"!=typeof ArrayBuffer&&"undefined"!=typeof Uint8Array&&(Uint8Array.prototype.slice||(Uint8Array.prototype.slice=function(t,e){void 0===t&&(t=0),void 0===e&&(e=this.length);var n=this;return t<0&&(t=this.length+t,t<0&&(t=0)),e<0&&(e=this.length+e,e<0&&(e=0)),e - * @license MIT - */ -"use strict";function r(){try{var t=new Uint8Array(1);return t.__proto__={__proto__:Uint8Array.prototype,foo:function(){return 42}},42===t.foo()}catch(t){return!1}}function i(e){if(e>K)throw new RangeError("Invalid typed array length");var n=new Uint8Array(e);return n.__proto__=t.prototype,n}function t(t,e,n){if("number"==typeof t){if("string"==typeof e)throw new Error("If encoding is specified then the first argument must be a string");return c(t)}return o(t,e,n)}function o(t,e,n){if("number"==typeof t)throw new TypeError('"value" argument must not be a number');return"undefined"!=typeof ArrayBuffer&&t instanceof ArrayBuffer?h(t,e,n):"string"==typeof t?u(t,e):p(t)}function s(t){if("number"!=typeof t)throw new TypeError('"size" argument must be a number');if(t<0)throw new RangeError('"size" argument must not be negative')}function a(t,e,n){return s(t),t<=0?i(t):void 0!==e?"string"==typeof n?i(t).fill(e,n):i(t).fill(e):i(t)}function c(t){return s(t),i(t<0?0:0|l(t))}function u(e,n){if("string"==typeof n&&""!==n||(n="utf8"),!t.isEncoding(n))throw new TypeError('"encoding" must be a valid string encoding');var r=0|y(e,n),o=i(r),s=o.write(e,n);return s!==r&&(o=o.slice(0,s)),o}function f(t){for(var e=t.length<0?0:0|l(t.length),n=i(e),r=0;r=K)throw new RangeError("Attempt to allocate Buffer larger than maximum size: 0x"+K.toString(16)+" bytes");return 0|t}function d(e){return+e!=e&&(e=0),t.alloc(+e)}function y(e,n){if(t.isBuffer(e))return e.length;if("undefined"!=typeof ArrayBuffer&&"function"==typeof ArrayBuffer.isView&&(ArrayBuffer.isView(e)||e instanceof ArrayBuffer))return e.byteLength;"string"!=typeof e&&(e=""+e);var r=e.length;if(0===r)return 0;for(var i=!1;;)switch(n){case"ascii":case"latin1":case"binary":return r;case"utf8":case"utf-8":case void 0:return z(e).length;case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return 2*r;case"hex":return r>>>1;case"base64":return W(e).length;default:if(i)return z(e).length;n=(""+n).toLowerCase(),i=!0}}function g(t,e,n){var r=!1;if((void 0===e||e<0)&&(e=0),e>this.length)return"";if((void 0===n||n>this.length)&&(n=this.length),n<=0)return"";if(n>>>=0,e>>>=0,n<=e)return"";for(t||(t="utf8");;)switch(t){case"hex":return T(this,e,n);case"utf8":case"utf-8":return F(this,e,n);case"ascii":return N(this,e,n);case"latin1":case"binary":return L(this,e,n);case"base64":return O(this,e,n);case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return x(this,e,n);default:if(r)throw new TypeError("Unknown encoding: "+t);t=(t+"").toLowerCase(),r=!0}}function _(t,e,n){var r=t[e];t[e]=t[n],t[n]=r}function v(e,n,r,i,o){if(0===e.length)return-1;if("string"==typeof r?(i=r,r=0):r>2147483647?r=2147483647:r<-2147483648&&(r=-2147483648),r=+r,isNaN(r)&&(r=o?0:e.length-1),r<0&&(r=e.length+r),r>=e.length){if(o)return-1;r=e.length-1}else if(r<0){if(!o)return-1;r=0}if("string"==typeof n&&(n=t.from(n,i)),t.isBuffer(n))return 0===n.length?-1:w(e,n,r,i,o);if("number"==typeof n)return n&=255,"function"==typeof Uint8Array.prototype.indexOf?o?Uint8Array.prototype.indexOf.call(e,n,r):Uint8Array.prototype.lastIndexOf.call(e,n,r):w(e,[n],r,i,o);throw new TypeError("val must be string, number or Buffer")}function w(t,e,n,r,i){function o(t,e){return 1===s?t[e]:t.readUInt16BE(e*s)}var s=1,a=t.length,c=e.length;if(void 0!==r&&(r=String(r).toLowerCase(),"ucs2"===r||"ucs-2"===r||"utf16le"===r||"utf-16le"===r)){if(t.length<2||e.length<2)return-1;s=2,a/=2,c/=2,n/=2}var u;if(i){var f=-1;for(u=n;ua&&(n=a-c),u=n;u>=0;u--){for(var h=!0,p=0;pi&&(r=i)):r=i;var o=e.length;if(o%2!==0)throw new TypeError("Invalid hex string");r>o/2&&(r=o/2);for(var s=0;s239?4:o>223?3:o>191?2:1;if(i+a<=n){var c,u,f,h;switch(a){case 1:o<128&&(s=o);break;case 2:c=t[i+1],128===(192&c)&&(h=(31&o)<<6|63&c,h>127&&(s=h));break;case 3:c=t[i+1],u=t[i+2],128===(192&c)&&128===(192&u)&&(h=(15&o)<<12|(63&c)<<6|63&u,h>2047&&(h<55296||h>57343)&&(s=h));break;case 4:c=t[i+1],u=t[i+2],f=t[i+3],128===(192&c)&&128===(192&u)&&128===(192&f)&&(h=(15&o)<<18|(63&c)<<12|(63&u)<<6|63&f,h>65535&&h<1114112&&(s=h))}}null===s?(s=65533,a=1):s>65535&&(s-=65536,r.push(s>>>10&1023|55296),s=56320|1023&s),r.push(s),i+=a}return R(r)}function R(t){var e=t.length;if(e<=G)return String.fromCharCode.apply(String,t);for(var n="",r=0;rr)&&(n=r);for(var i="",o=e;on)throw new RangeError("Trying to access beyond buffer length")}function A(e,n,r,i,o,s){if(!t.isBuffer(e))throw new TypeError('"buffer" argument must be a Buffer instance');if(n>o||ne.length)throw new RangeError("Index out of range")}function P(t,e,n,r,i,o){if(n+r>t.length)throw new RangeError("Index out of range");if(n<0)throw new RangeError("Index out of range")}function C(t,e,n,r,i){return e=+e,n>>>=0,i||P(t,e,n,4,3.4028234663852886e38,-3.4028234663852886e38),X.write(t,e,n,r,23,4),n+4}function U(t,e,n,r,i){return e=+e,n>>>=0,i||P(t,e,n,8,1.7976931348623157e308,-1.7976931348623157e308),X.write(t,e,n,r,52,8),n+8}function M(t){if(t=B(t).replace(J,""),t.length<2)return"";for(;t.length%4!==0;)t+="=";return t}function B(t){return t.trim?t.trim():t.replace(/^\s+|\s+$/g,"")}function j(t){return t<16?"0"+t.toString(16):t.toString(16)}function z(t,e){e=e||1/0;for(var n,r=t.length,i=null,o=[],s=0;s55295&&n<57344){if(!i){if(n>56319){(e-=3)>-1&&o.push(239,191,189);continue}if(s+1===r){(e-=3)>-1&&o.push(239,191,189);continue}i=n;continue}if(n<56320){(e-=3)>-1&&o.push(239,191,189),i=n;continue}n=(i-55296<<10|n-56320)+65536}else i&&(e-=3)>-1&&o.push(239,191,189);if(i=null,n<128){if((e-=1)<0)break;o.push(n)}else if(n<2048){if((e-=2)<0)break;o.push(n>>6|192,63&n|128)}else if(n<65536){if((e-=3)<0)break;o.push(n>>12|224,n>>6&63|128,63&n|128)}else{if(!(n<1114112))throw new Error("Invalid code point");if((e-=4)<0)break;o.push(n>>18|240,n>>12&63|128,n>>6&63|128,63&n|128)}}return o}function q(t){for(var e=[],n=0;n>8,i=n%256,o.push(i),o.push(r);return o}function W(t){return Y.toByteArray(M(t))}function H(t,e,n,r){for(var i=0;i=e.length||i>=t.length);++i)e[i+n]=t[i];return i}function Z(t){return t!==t}var Y=n(18),X=n(21);e.Buffer=t,e.SlowBuffer=d,e.INSPECT_MAX_BYTES=50;var K=2147483647;e.kMaxLength=K,t.TYPED_ARRAY_SUPPORT=r(),t.TYPED_ARRAY_SUPPORT||"undefined"==typeof console||"function"!=typeof console.error||console.error("This browser lacks typed array (Uint8Array) support which is required by `buffer` v5.x. Use `buffer` v4.x if you require old browser support."),"undefined"!=typeof Symbol&&Symbol.species&&t[Symbol.species]===t&&Object.defineProperty(t,Symbol.species,{value:null,configurable:!0,enumerable:!1,writable:!1}),t.poolSize=8192,t.from=function(t,e,n){return o(t,e,n)},t.prototype.__proto__=Uint8Array.prototype,t.__proto__=Uint8Array,t.alloc=function(t,e,n){return a(t,e,n)},t.allocUnsafe=function(t){return c(t)},t.allocUnsafeSlow=function(t){return c(t)},t.isBuffer=function(t){return!(null==t||!t._isBuffer)},t.compare=function(e,n){if(!t.isBuffer(e)||!t.isBuffer(n))throw new TypeError("Arguments must be Buffers");if(e===n)return 0;for(var r=e.length,i=n.length,o=0,s=Math.min(r,i);o0&&(t=this.toString("hex",0,n).match(/.{2}/g).join(" "),this.length>n&&(t+=" ... ")),""},t.prototype.compare=function(e,n,r,i,o){if(!t.isBuffer(e))throw new TypeError("Argument must be a Buffer");if(void 0===n&&(n=0),void 0===r&&(r=e?e.length:0),void 0===i&&(i=0),void 0===o&&(o=this.length),n<0||r>e.length||i<0||o>this.length)throw new RangeError("out of range index");if(i>=o&&n>=r)return 0;if(i>=o)return-1;if(n>=r)return 1;if(n>>>=0,r>>>=0,i>>>=0,o>>>=0,this===e)return 0;for(var s=o-i,a=r-n,c=Math.min(s,a),u=this.slice(i,o),f=e.slice(n,r),h=0;h>>=0,isFinite(n)?(n>>>=0,void 0===r&&(r="utf8")):(r=n,n=void 0)}var i=this.length-e;if((void 0===n||n>i)&&(n=i),t.length>0&&(n<0||e<0)||e>this.length)throw new RangeError("Attempt to write outside buffer bounds");r||(r="utf8");for(var o=!1;;)switch(r){case"hex":return m(this,t,e,n);case"utf8":case"utf-8":return E(this,t,e,n);case"ascii":return S(this,t,e,n);case"latin1":case"binary":return b(this,t,e,n);case"base64":return k(this,t,e,n);case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return I(this,t,e,n);default:if(o)throw new TypeError("Unknown encoding: "+r);r=(""+r).toLowerCase(),o=!0}},t.prototype.toJSON=function(){return{type:"Buffer",data:Array.prototype.slice.call(this._arr||this,0)}};var G=4096;t.prototype.slice=function(e,n){var r=this.length;e=~~e,n=void 0===n?r:~~n,e<0?(e+=r,e<0&&(e=0)):e>r&&(e=r),n<0?(n+=r,n<0&&(n=0)):n>r&&(n=r),n>>=0,e>>>=0,n||D(t,e,this.length);for(var r=this[t],i=1,o=0;++o>>=0,e>>>=0,n||D(t,e,this.length);for(var r=this[t+--e],i=1;e>0&&(i*=256);)r+=this[t+--e]*i;return r},t.prototype.readUInt8=function(t,e){return t>>>=0,e||D(t,1,this.length),this[t]},t.prototype.readUInt16LE=function(t,e){return t>>>=0,e||D(t,2,this.length),this[t]|this[t+1]<<8},t.prototype.readUInt16BE=function(t,e){return t>>>=0,e||D(t,2,this.length),this[t]<<8|this[t+1]},t.prototype.readUInt32LE=function(t,e){return t>>>=0,e||D(t,4,this.length),(this[t]|this[t+1]<<8|this[t+2]<<16)+16777216*this[t+3]},t.prototype.readUInt32BE=function(t,e){return t>>>=0,e||D(t,4,this.length),16777216*this[t]+(this[t+1]<<16|this[t+2]<<8|this[t+3])},t.prototype.readIntLE=function(t,e,n){t>>>=0,e>>>=0,n||D(t,e,this.length);for(var r=this[t],i=1,o=0;++o=i&&(r-=Math.pow(2,8*e)),r},t.prototype.readIntBE=function(t,e,n){t>>>=0,e>>>=0,n||D(t,e,this.length);for(var r=e,i=1,o=this[t+--r];r>0&&(i*=256);)o+=this[t+--r]*i;return i*=128,o>=i&&(o-=Math.pow(2,8*e)),o},t.prototype.readInt8=function(t,e){return t>>>=0,e||D(t,1,this.length),128&this[t]?(255-this[t]+1)*-1:this[t]},t.prototype.readInt16LE=function(t,e){t>>>=0,e||D(t,2,this.length);var n=this[t]|this[t+1]<<8;return 32768&n?4294901760|n:n},t.prototype.readInt16BE=function(t,e){t>>>=0,e||D(t,2,this.length);var n=this[t+1]|this[t]<<8;return 32768&n?4294901760|n:n},t.prototype.readInt32LE=function(t,e){return t>>>=0,e||D(t,4,this.length),this[t]|this[t+1]<<8|this[t+2]<<16|this[t+3]<<24},t.prototype.readInt32BE=function(t,e){return t>>>=0,e||D(t,4,this.length),this[t]<<24|this[t+1]<<16|this[t+2]<<8|this[t+3]},t.prototype.readFloatLE=function(t,e){return t>>>=0,e||D(t,4,this.length),X.read(this,t,!0,23,4)},t.prototype.readFloatBE=function(t,e){return t>>>=0,e||D(t,4,this.length),X.read(this,t,!1,23,4)},t.prototype.readDoubleLE=function(t,e){return t>>>=0,e||D(t,8,this.length),X.read(this,t,!0,52,8)},t.prototype.readDoubleBE=function(t,e){return t>>>=0,e||D(t,8,this.length),X.read(this,t,!1,52,8)},t.prototype.writeUIntLE=function(t,e,n,r){if(t=+t,e>>>=0,n>>>=0,!r){var i=Math.pow(2,8*n)-1;A(this,t,e,n,i,0)}var o=1,s=0;for(this[e]=255&t;++s>>=0,n>>>=0,!r){var i=Math.pow(2,8*n)-1;A(this,t,e,n,i,0)}var o=n-1,s=1;for(this[e+o]=255&t;--o>=0&&(s*=256);)this[e+o]=t/s&255;return e+n},t.prototype.writeUInt8=function(t,e,n){return t=+t,e>>>=0,n||A(this,t,e,1,255,0),this[e]=255&t,e+1},t.prototype.writeUInt16LE=function(t,e,n){return t=+t,e>>>=0,n||A(this,t,e,2,65535,0),this[e]=255&t,this[e+1]=t>>>8,e+2},t.prototype.writeUInt16BE=function(t,e,n){return t=+t,e>>>=0,n||A(this,t,e,2,65535,0),this[e]=t>>>8,this[e+1]=255&t,e+2},t.prototype.writeUInt32LE=function(t,e,n){return t=+t,e>>>=0,n||A(this,t,e,4,4294967295,0),this[e+3]=t>>>24,this[e+2]=t>>>16,this[e+1]=t>>>8,this[e]=255&t,e+4},t.prototype.writeUInt32BE=function(t,e,n){return t=+t,e>>>=0,n||A(this,t,e,4,4294967295,0),this[e]=t>>>24,this[e+1]=t>>>16,this[e+2]=t>>>8,this[e+3]=255&t,e+4},t.prototype.writeIntLE=function(t,e,n,r){if(t=+t,e>>>=0,!r){var i=Math.pow(2,8*n-1);A(this,t,e,n,i-1,-i)}var o=0,s=1,a=0;for(this[e]=255&t;++o>0)-a&255;return e+n},t.prototype.writeIntBE=function(t,e,n,r){if(t=+t,e>>>=0,!r){var i=Math.pow(2,8*n-1);A(this,t,e,n,i-1,-i)}var o=n-1,s=1,a=0;for(this[e+o]=255&t;--o>=0&&(s*=256);)t<0&&0===a&&0!==this[e+o+1]&&(a=1),this[e+o]=(t/s>>0)-a&255;return e+n},t.prototype.writeInt8=function(t,e,n){return t=+t,e>>>=0,n||A(this,t,e,1,127,-128),t<0&&(t=255+t+1),this[e]=255&t,e+1},t.prototype.writeInt16LE=function(t,e,n){return t=+t,e>>>=0,n||A(this,t,e,2,32767,-32768),this[e]=255&t,this[e+1]=t>>>8,e+2},t.prototype.writeInt16BE=function(t,e,n){return t=+t,e>>>=0,n||A(this,t,e,2,32767,-32768),this[e]=t>>>8,this[e+1]=255&t,e+2},t.prototype.writeInt32LE=function(t,e,n){return t=+t,e>>>=0,n||A(this,t,e,4,2147483647,-2147483648),this[e]=255&t,this[e+1]=t>>>8,this[e+2]=t>>>16,this[e+3]=t>>>24,e+4},t.prototype.writeInt32BE=function(t,e,n){return t=+t,e>>>=0,n||A(this,t,e,4,2147483647,-2147483648),t<0&&(t=4294967295+t+1),this[e]=t>>>24,this[e+1]=t>>>16,this[e+2]=t>>>8,this[e+3]=255&t,e+4},t.prototype.writeFloatLE=function(t,e,n){return C(this,t,e,!0,n)},t.prototype.writeFloatBE=function(t,e,n){return C(this,t,e,!1,n)},t.prototype.writeDoubleLE=function(t,e,n){return U(this,t,e,!0,n)},t.prototype.writeDoubleBE=function(t,e,n){return U(this,t,e,!1,n)},t.prototype.copy=function(t,e,n,r){if(n||(n=0),r||0===r||(r=this.length),e>=t.length&&(e=t.length),e||(e=0),r>0&&r=this.length)throw new RangeError("sourceStart out of bounds");if(r<0)throw new RangeError("sourceEnd out of bounds");r>this.length&&(r=this.length),t.length-e=0;--i)t[i+e]=this[i+n];else if(o<1e3)for(i=0;i>>=0,r=void 0===r?this.length:r>>>0,e||(e=0);var s;if("number"==typeof e)for(s=n;s0&&this._events[t].length>i&&(this._events[t].warned=!0,console.error("(node) warning: possible EventEmitter memory leak detected. %d listeners added. Use emitter.setMaxListeners() to increase limit.",this._events[t].length),"function"==typeof console.trace&&console.trace())),this},n.prototype.on=n.prototype.addListener,n.prototype.once=function(t,e){function n(){this.removeListener(t,n),i||(i=!0,e.apply(this,arguments))}if(!r(e))throw TypeError("listener must be a function");var i=!1;return n.listener=e,this.on(t,n),this},n.prototype.removeListener=function(t,e){var n,i,s,a;if(!r(e))throw TypeError("listener must be a function");if(!this._events||!this._events[t])return this;if(n=this._events[t],s=n.length,i=-1,n===e||r(n.listener)&&n.listener===e)delete this._events[t],this._events.removeListener&&this.emit("removeListener",t,e);else if(o(n)){for(a=s;a-- >0;)if(n[a]===e||n[a].listener&&n[a].listener===e){i=a;break}if(i<0)return this;1===n.length?(n.length=0,delete this._events[t]):n.splice(i,1),this._events.removeListener&&this.emit("removeListener",t,e)}return this},n.prototype.removeAllListeners=function(t){var e,n;if(!this._events)return this;if(!this._events.removeListener)return 0===arguments.length?this._events={}:this._events[t]&&delete this._events[t],this;if(0===arguments.length){for(e in this._events)"removeListener"!==e&&this.removeAllListeners(e);return this.removeAllListeners("removeListener"),this._events={},this}if(n=this._events[t],r(n))this.removeListener(t,n);else if(n)for(;n.length;)this.removeListener(t,n[n.length-1]);return delete this._events[t],this},n.prototype.listeners=function(t){var e;return e=this._events&&this._events[t]?r(this._events[t])?[this._events[t]]:this._events[t].slice():[]},n.prototype.listenerCount=function(t){if(this._events){var e=this._events[t];if(r(e))return 1;if(e)return e.length}return 0},n.listenerCount=function(t,e){return t.listenerCount(e)}},function(t,e,n){t.exports=n(1).Buffer},function(t,e){"use strict";var n="undefined"!=typeof Uint8Array&&"undefined"!=typeof Uint16Array&&"undefined"!=typeof Int32Array;e.assign=function(t){for(var e=Array.prototype.slice.call(arguments,1);e.length;){var n=e.shift();if(n){if("object"!=typeof n)throw new TypeError(n+"must be non-object");for(var r in n)n.hasOwnProperty(r)&&(t[r]=n[r])}}return t},e.shrinkBuf=function(t,e){return t.length===e?t:t.subarray?t.subarray(0,e):(t.length=e,t)};var r={arraySet:function(t,e,n,r,i){if(e.subarray&&t.subarray)return void t.set(e.subarray(n,n+r),i);for(var o=0;os)throw new RangeError("size is too large");var r=n,o=e;void 0===o&&(r=void 0,o=0);var a=new i(t);if("string"==typeof o)for(var c=new i(o,r),u=c.length,f=-1;++fs)throw new RangeError("size is too large");return new i(t)},e.from=function(e,n,r){if("function"==typeof i.from&&(!t.Uint8Array||Uint8Array.from!==i.from))return i.from(e,n,r);if("number"==typeof e)throw new TypeError('"value" argument must not be a number');if("string"==typeof e)return new i(e,n);if("undefined"!=typeof ArrayBuffer&&e instanceof ArrayBuffer){var o=n;if(1===arguments.length)return new i(e);"undefined"==typeof o&&(o=0);var s=r;if("undefined"==typeof s&&(s=e.byteLength-o),o>=e.byteLength)throw new RangeError("'offset' is out of bounds");if(s>e.byteLength-o)throw new RangeError("'length' is out of bounds");return new i(e.slice(o,o+s))}if(i.isBuffer(e)){var a=new i(e.length);return e.copy(a,0,0,e.length),a}if(e){if(Array.isArray(e)||"undefined"!=typeof ArrayBuffer&&e.buffer instanceof ArrayBuffer||"length"in e)return new i(e);if("Buffer"===e.type&&Array.isArray(e.data))return new i(e.data)}throw new TypeError("First argument must be a string, Buffer, ArrayBuffer, Array, or array-like object.")},e.allocUnsafeSlow=function(t){if("function"==typeof i.allocUnsafeSlow)return i.allocUnsafeSlow(t);if("number"!=typeof t)throw new TypeError("size must be a number");if(t>=s)throw new RangeError("size is too large");return new o(t)}}).call(e,function(){return this}())},function(t,e,n){(function(e){"use strict";function n(t,n,r,i){if("function"!=typeof t)throw new TypeError('"callback" argument must be a function');var o,s,a=arguments.length;switch(a){case 0:case 1:return e.nextTick(t);case 2:return e.nextTick(function(){t.call(null,n)});case 3:return e.nextTick(function(){t.call(null,n,r)});case 4:return e.nextTick(function(){t.call(null,n,r,i)});default:for(o=new Array(a-1),s=0;s-1?setImmediate:k;s.WritableState=o;var O=n(5);O.inherits=n(4);var F,R={deprecate:n(40)};!function(){try{F=n(9)}catch(t){}finally{F||(F=n(6).EventEmitter)}}();var N=n(1).Buffer,L=n(10);O.inherits(s,F),o.prototype.getBuffer=function(){for(var t=this.bufferedRequest,e=[];t;)e.push(t),t=t.next;return e},function(){try{Object.defineProperty(o.prototype,"buffer",{get:R.deprecate(function(){return this.getBuffer()},"_writableState.buffer is deprecated. Use _writableState.getBuffer instead.")})}catch(t){}}();var T;"function"==typeof Symbol&&Symbol.hasInstance&&"function"==typeof Function.prototype[Symbol.hasInstance]?(T=Function.prototype[Symbol.hasInstance],Object.defineProperty(s,Symbol.hasInstance,{value:function(t){return!!T.call(this,t)||t&&t._writableState instanceof o}})):T=function(t){return t instanceof this},s.prototype.pipe=function(){this.emit("error",new Error("Cannot pipe, not readable"))},s.prototype.write=function(t,e,n){var i=this._writableState,o=!1;return"function"==typeof e&&(n=e,e=null),N.isBuffer(t)?e="buffer":e||(e=i.defaultEncoding),"function"!=typeof n&&(n=r),i.ended?a(this,n):c(this,i,t,n)&&(i.pendingcb++,o=f(this,i,t,e,n)),o},s.prototype.cork=function(){var t=this._writableState;t.corked++},s.prototype.uncork=function(){var t=this._writableState;t.corked&&(t.corked--,t.writing||t.corked||t.finished||t.bufferProcessing||!t.bufferedRequest||_(this,t))},s.prototype.setDefaultEncoding=function(t){if("string"==typeof t&&(t=t.toLowerCase()),!(["hex","utf8","utf-8","ascii","binary","base64","ucs2","ucs-2","utf16le","utf-16le","raw"].indexOf((t+"").toLowerCase())>-1))throw new TypeError("Unknown encoding: "+t);return this._writableState.defaultEncoding=t,this},s.prototype._write=function(t,e,n){n(new Error("_write() is not implemented"))},s.prototype._writev=null,s.prototype.end=function(t,e,n){var r=this._writableState;"function"==typeof t?(n=t,t=null,e=null):"function"==typeof e&&(n=e,e=null),null!==t&&void 0!==t&&this.write(t,e),r.corked&&(r.corked=1,this.uncork()),r.ending||r.finished||E(this,r,n)}}).call(e,n(3))},function(t,e,n){(function(e){"use strict";function n(t){var e=r.exec(t);return e.shift(),e}var r=/^(\/?|)([\s\S]*?)((?:\.{1,2}|[^\/]+?|)(\.[^.\/]*|))(?:[\/]*)$/,i=function(){function t(){}return t.normalize=function(e){""===e&&(e=".");var n=e.charAt(0)===t.sep;e=t._removeDuplicateSeps(e);for(var r=e.split(t.sep),i=[],o=0;o0&&".."!==i[0])?i.pop():i.push(s))}if(!n&&i.length<2)switch(i.length){case 1:""===i[0]&&i.unshift(".");break;default:i.push(".")}return e=i.join(t.sep),n&&e.charAt(0)!==t.sep&&(e=t.sep+e),e},t.join=function(){for(var e=[],n=0;n1&&a.charAt(a.length-1)===t.sep)return a.substr(0,a.length-1);if(a.charAt(0)!==t.sep){"."!==a.charAt(0)||1!==a.length&&a.charAt(1)!==t.sep||(a=1===a.length?"":a.substr(2));var c=e.cwd();a=""!==a?this.normalize(c+("/"!==c?t.sep:"")+a):c}return a},t.relative=function(e,n){var r;e=t.resolve(e),n=t.resolve(n);var i=e.split(t.sep),o=n.split(t.sep);o.shift(),i.shift();var s=0,a=[];for(r=0;ri.length&&(s=i.length);var u="";for(r=0;r1&&u.charAt(u.length-1)===t.sep&&(u=u.substr(0,u.length-1)),u},t.dirname=function(e){e=t._removeDuplicateSeps(e);var n=e.charAt(0)===t.sep,r=e.split(t.sep);return""===r.pop()&&r.length>0&&r.pop(),r.length>1||1===r.length&&!n?r.join(t.sep):n?t.sep:"."},t.basename=function(e,n){if(void 0===n&&(n=""),""===e)return e;e=t.normalize(e);var r=e.split(t.sep),i=r[r.length-1];if(""===i&&r.length>1)return r[r.length-2];if(n.length>0){var o=i.substr(i.length-n.length);if(o===n)return i.substr(0,i.length-n.length)}return i},t.extname=function(e){e=t.normalize(e);var n=e.split(t.sep);if(e=n.pop(),""===e&&n.length>0&&(e=n.pop()),".."===e)return"";var r=e.lastIndexOf(".");return r===-1||0===r?"":e.substr(r)},t.isAbsolute=function(e){return e.length>0&&e.charAt(0)===t.sep},t._makeLong=function(t){return t},t.parse=function(t){var e=n(t);return{root:e[0],dir:e[0]+e[1].slice(0,-1),base:e[2],ext:e[3],name:e[2].slice(0,e[2].length-e[3].length)}},t.format=function(e){if(null===e||"object"!=typeof e)throw new TypeError("Parameter 'pathObject' must be an object, not "+typeof e);var n=e.root||"";if("string"!=typeof n)throw new TypeError("'pathObject.root' must be a string or undefined, not "+typeof e.root);var r=e.dir?e.dir+t.sep:"",i=e.base||"";return r+i},t._removeDuplicateSeps=function(t){return t=t.replace(this._replaceRegex,this.sep)},t.sep="/",t._replaceRegex=new RegExp("//+","g"),t.delimiter=":",t.posix=t,t.win32=t,t}();t.exports=i}).call(e,n(3))},function(t,e,n){"use strict";function r(t){return this instanceof r?void i.call(this,t):new r(t)}t.exports=r;var i=n(12),o=n(5);o.inherits=n(4),o.inherits(r,i),r.prototype._transform=function(t,e,n){n(null,t)}},function(t,e,n){(function(e){"use strict";function r(t,e,n){return"function"==typeof t.prependListener?t.prependListener(e,n):void(t._events&&t._events[e]?T(t._events[e])?t._events[e].unshift(n):t._events[e]=[n,t._events[e]]:t.on(e,n))}function i(t,e){N=N||n(2),t=t||{},this.objectMode=!!t.objectMode,e instanceof N&&(this.objectMode=this.objectMode||!!t.readableObjectMode);var r=t.highWaterMark,i=this.objectMode?16:16384;this.highWaterMark=r||0===r?r:i,this.highWaterMark=~~this.highWaterMark,this.buffer=new j,this.length=0,this.pipes=null,this.pipesCount=0,this.flowing=null,this.ended=!1,this.endEmitted=!1,this.reading=!1,this.sync=!0,this.needReadable=!1,this.emittedReadable=!1,this.readableListening=!1,this.resumeScheduled=!1,this.defaultEncoding=t.defaultEncoding||"utf8",this.ranOut=!1,this.awaitDrain=0,this.readingMore=!1,this.decoder=null,this.encoding=null,t.encoding&&(B||(B=n(17).StringDecoder),this.decoder=new B(t.encoding),this.encoding=t.encoding)}function o(t){return N=N||n(2),this instanceof o?(this._readableState=new i(t,this),this.readable=!0,t&&"function"==typeof t.read&&(this._read=t.read),void x.call(this)):new o(t)}function s(t,e,n,r,i){var o=f(e,n);if(o)t.emit("error",o);else if(null===n)e.reading=!1,h(t,e);else if(e.objectMode||n&&n.length>0)if(e.ended&&!i){var s=new Error("stream.push() after EOF");t.emit("error",s)}else if(e.endEmitted&&i){var c=new Error("stream.unshift() after end event");t.emit("error",c)}else{var u;!e.decoder||i||r||(n=e.decoder.write(n),u=!e.objectMode&&0===n.length),i||(e.reading=!1),u||(e.flowing&&0===e.length&&!e.sync?(t.emit("data",n),t.read(0)):(e.length+=e.objectMode?1:n.length,i?e.buffer.unshift(n):e.buffer.push(n),e.needReadable&&p(t))),d(t,e)}else i||(e.reading=!1);return a(e)}function a(t){return!t.ended&&(t.needReadable||t.length=z?t=z:(t--,t|=t>>>1,t|=t>>>2,t|=t>>>4,t|=t>>>8,t|=t>>>16,t++),t}function u(t,e){return t<=0||0===e.length&&e.ended?0:e.objectMode?1:t!==t?e.flowing&&e.length?e.buffer.head.data.length:e.length:(t>e.highWaterMark&&(e.highWaterMark=c(t)),t<=e.length?t:e.ended?e.length:(e.needReadable=!0,0))}function f(t,e){var n=null;return A.isBuffer(e)||"string"==typeof e||null===e||void 0===e||t.objectMode||(n=new TypeError("Invalid non-string/buffer chunk")),n}function h(t,e){if(!e.ended){if(e.decoder){var n=e.decoder.end();n&&n.length&&(e.buffer.push(n),e.length+=e.objectMode?1:n.length)}e.ended=!0,p(t)}}function p(t){var e=t._readableState;e.needReadable=!1,e.emittedReadable||(M("emitReadable",e.flowing),e.emittedReadable=!0,e.sync?L(l,t):l(t))}function l(t){M("emit readable"),t.emit("readable"),m(t)}function d(t,e){e.readingMore||(e.readingMore=!0,L(y,t,e))}function y(t,e){for(var n=e.length;!e.reading&&!e.flowing&&!e.ended&&e.length=e.length?(n=e.decoder?e.buffer.join(""):1===e.buffer.length?e.buffer.head.data:e.buffer.concat(e.length),e.buffer.clear()):n=S(t,e.buffer,e.decoder),n}function S(t,e,n){var r;return to.length?o.length:t;if(i+=s===o.length?o:o.slice(0,t),t-=s,0===t){s===o.length?(++r,n.next?e.head=n.next:e.head=e.tail=null):(e.head=n,n.data=o.slice(s));break}++r}return e.length-=r,i}function k(t,e){var n=P.allocUnsafe(t),r=e.head,i=1;for(r.data.copy(n),t-=r.data.length;r=r.next;){var o=r.data,s=t>o.length?o.length:t;if(o.copy(n,n.length-t,0,s),t-=s,0===t){s===o.length?(++i,r.next?e.head=r.next:e.head=e.tail=null):(e.head=r,r.data=o.slice(s));break}++i}return e.length-=i,n}function I(t){var e=t._readableState;if(e.length>0)throw new Error('"endReadable()" called on non-empty stream');e.endEmitted||(e.ended=!0,L(O,e,t))}function O(t,e){t.endEmitted||0!==t.length||(t.endEmitted=!0,e.readable=!1,e.emit("end"))}function F(t,e){for(var n=0,r=t.length;n=e.highWaterMark||e.ended))return M("read: emitReadable",e.length,e.ended),0===e.length&&e.ended?I(this):p(this),null;if(t=u(t,e),0===t&&e.ended)return 0===e.length&&I(this),null;var r=e.needReadable;M("need readable",r),(0===e.length||e.length-t0?E(t,e):null,null===i?(e.needReadable=!0,t=0):e.length-=t,0===e.length&&(e.ended||(e.needReadable=!0),n!==t&&e.ended&&I(this)),null!==i&&this.emit("data",i),i},o.prototype._read=function(t){this.emit("error",new Error("_read() is not implemented"))},o.prototype.pipe=function(t,n){function i(t){M("onunpipe"),t===p&&s()}function o(){M("onend"),t.end()}function s(){M("cleanup"),t.removeListener("close",u),t.removeListener("finish",f),t.removeListener("drain",_),t.removeListener("error",c),t.removeListener("unpipe",i),p.removeListener("end",o),p.removeListener("end",s),p.removeListener("data",a),v=!0,!l.awaitDrain||t._writableState&&!t._writableState.needDrain||_()}function a(e){M("ondata"),w=!1;var n=t.write(e);!1!==n||w||((1===l.pipesCount&&l.pipes===t||l.pipesCount>1&&R(l.pipes,t)!==-1)&&!v&&(M("false write response, pause",p._readableState.awaitDrain),p._readableState.awaitDrain++,w=!0),p.pause())}function c(e){M("onerror",e),h(),t.removeListener("error",c),0===D(t,"error")&&t.emit("error",e)}function u(){t.removeListener("finish",f),h()}function f(){M("onfinish"),t.removeListener("close",u),h()}function h(){M("unpipe"),p.unpipe(t)}var p=this,l=this._readableState;switch(l.pipesCount){case 0:l.pipes=t;break;case 1:l.pipes=[l.pipes,t];break;default:l.pipes.push(t)}l.pipesCount+=1,M("pipe count=%d opts=%j",l.pipesCount,n);var d=(!n||n.end!==!1)&&t!==e.stdout&&t!==e.stderr,y=d?o:s;l.endEmitted?L(y):p.once("end",y),t.on("unpipe",i);var _=g(p);t.on("drain",_);var v=!1,w=!1;return p.on("data",a),r(t,"error",c),t.once("close",u),t.once("finish",f),t.emit("pipe",p),l.flowing||(M("pipe resume"),p.resume()),t},o.prototype.unpipe=function(t){var e=this._readableState;if(0===e.pipesCount)return this;if(1===e.pipesCount)return t&&t!==e.pipes?this:(t||(t=e.pipes),e.pipes=null,e.pipesCount=0,e.flowing=!1,t&&t.emit("unpipe",this),this);if(!t){var n=e.pipes,r=e.pipesCount;e.pipes=null,e.pipesCount=0,e.flowing=!1;for(var i=0;i=this.charLength-this.charReceived?this.charLength-this.charReceived:t.length;if(t.copy(this.charBuffer,this.charReceived,0,n),this.charReceived+=n,this.charReceived=55296&&r<=56319)){if(this.charReceived=this.charLength=0,0===t.length)return e;break}this.charLength+=this.surrogateSize,e=""}this.detectIncompleteChar(t);var i=t.length;this.charLength&&(t.copy(this.charBuffer,0,t.length-this.charReceived,i),i-=this.charReceived),e+=t.toString(this.encoding,0,i);var i=e.length-1,r=e.charCodeAt(i);if(r>=55296&&r<=56319){var o=this.surrogateSize;return this.charLength+=o,this.charReceived+=o,this.charBuffer.copy(this.charBuffer,o,0,o),t.copy(this.charBuffer,0,0,o),e.substring(0,i)}return e},u.prototype.detectIncompleteChar=function(t){for(var e=t.length>=3?3:t.length;e>0;e--){var n=t[t.length-e];if(1==e&&n>>5==6){this.charLength=2;break}if(e<=2&&n>>4==14){this.charLength=3;break}if(e<=3&&n>>3==30){this.charLength=4;break}}this.charReceived=e},u.prototype.end=function(t){var e="";if(t&&t.length&&(e=this.write(t)),this.charReceived){var n=this.charReceived,r=this.charBuffer,i=this.encoding;e+=r.slice(0,n).toString(i)}return e}},function(t,e){"use strict";function n(t){var e=t.length;if(e%4>0)throw new Error("Invalid string. Length must be a multiple of 4");return"="===t[e-2]?2:"="===t[e-1]?1:0}function r(t){return 3*t.length/4-n(t)}function i(t){var e,r,i,o,s,a,c=t.length;s=n(t),a=new f(3*c/4-s),i=s>0?c-4:c;var h=0;for(e=0,r=0;e>16&255,a[h++]=o>>8&255,a[h++]=255&o;return 2===s?(o=u[t.charCodeAt(e)]<<2|u[t.charCodeAt(e+1)]>>4,a[h++]=255&o):1===s&&(o=u[t.charCodeAt(e)]<<10|u[t.charCodeAt(e+1)]<<4|u[t.charCodeAt(e+2)]>>2,a[h++]=o>>8&255,a[h++]=255&o),a}function o(t){return c[t>>18&63]+c[t>>12&63]+c[t>>6&63]+c[63&t]}function s(t,e,n){for(var r,i=[],s=e;sf?f:u+a));return 1===r?(e=t[n-1],i+=c[e>>2],i+=c[e<<4&63],i+="=="):2===r&&(e=(t[n-2]<<8)+t[n-1],i+=c[e>>10],i+=c[e>>4&63],i+=c[e<<2&63],i+="="),o.push(i),o.join("")}e.byteLength=r,e.toByteArray=i,e.fromByteArray=a;for(var c=[],u=[],f="undefined"!=typeof Uint8Array?Uint8Array:Array,h="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",p=0,l=h.length;p0&&(this._waitingForWrites=this.push(this._bufferedWrites.shift()),this._waitingForWrites););},n}(i.Duplex);t.exports=o}).call(e,n(7))},function(t,e){e.read=function(t,e,n,r,i){var o,s,a=8*i-r-1,c=(1<>1,f=-7,h=n?i-1:0,p=n?-1:1,l=t[e+h];for(h+=p,o=l&(1<<-f)-1,l>>=-f,f+=a;f>0;o=256*o+t[e+h],h+=p,f-=8);for(s=o&(1<<-f)-1,o>>=-f,f+=r;f>0;s=256*s+t[e+h],h+=p,f-=8);if(0===o)o=1-u;else{if(o===c)return s?NaN:(l?-1:1)*(1/0);s+=Math.pow(2,r),o-=u}return(l?-1:1)*s*Math.pow(2,o-r)},e.write=function(t,e,n,r,i,o){var s,a,c,u=8*o-i-1,f=(1<>1,p=23===i?Math.pow(2,-24)-Math.pow(2,-77):0,l=r?0:o-1,d=r?1:-1,y=e<0||0===e&&1/e<0?1:0;for(e=Math.abs(e),isNaN(e)||e===1/0?(a=isNaN(e)?1:0,s=f):(s=Math.floor(Math.log(e)/Math.LN2),e*(c=Math.pow(2,-s))<1&&(s--,c*=2),e+=s+h>=1?p/c:p*Math.pow(2,1-h),e*c>=2&&(s++,c/=2),s+h>=f?(a=0,s=f):s+h>=1?(a=(e*c-1)*Math.pow(2,i),s+=h):(a=e*Math.pow(2,h-1)*Math.pow(2,i),s=0));i>=8;t[n+l]=255&a,l+=d,a/=256,i-=8);for(s=s<0;t[n+l]=255&s,l+=d,s/=256,u-=8);t[n+l-d]|=128*y}},function(t,e){var n={}.toString;t.exports=Array.isArray||function(t){return"[object Array]"==n.call(t)}},function(t,e,n){"use strict";function r(t){if(!(this instanceof r))return new r(t);this.options=a.assign({chunkSize:16384,windowBits:0,to:""},t||{});var e=this.options;e.raw&&e.windowBits>=0&&e.windowBits<16&&(e.windowBits=-e.windowBits,0===e.windowBits&&(e.windowBits=-15)),!(e.windowBits>=0&&e.windowBits<16)||t&&t.windowBits||(e.windowBits+=32),e.windowBits>15&&e.windowBits<48&&0===(15&e.windowBits)&&(e.windowBits|=15),this.err=0,this.msg="",this.ended=!1,this.chunks=[],this.strm=new h,this.strm.avail_out=0;var n=s.inflateInit2(this.strm,e.windowBits);if(n!==u.Z_OK)throw new Error(f[n]);this.header=new p,s.inflateGetHeader(this.strm,this.header)}function i(t,e){var n=new r(e);if(n.push(t,!0),n.err)throw n.msg||f[n.err];return n.result}function o(t,e){return e=e||{},e.raw=!0,i(t,e)}var s=n(30),a=n(8),c=n(24),u=n(26),f=n(32),h=n(33),p=n(28),l=Object.prototype.toString;r.prototype.push=function(t,e){var n,r,i,o,f,h,p=this.strm,d=this.options.chunkSize,y=this.options.dictionary,g=!1;if(this.ended)return!1;r=e===~~e?e:e===!0?u.Z_FINISH:u.Z_NO_FLUSH,"string"==typeof t?p.input=c.binstring2buf(t):"[object ArrayBuffer]"===l.call(t)?p.input=new Uint8Array(t):p.input=t,p.next_in=0,p.avail_in=p.input.length;do{if(0===p.avail_out&&(p.output=new a.Buf8(d),p.next_out=0,p.avail_out=d),n=s.inflate(p,u.Z_NO_FLUSH),n===u.Z_NEED_DICT&&y&&(h="string"==typeof y?c.string2buf(y):"[object ArrayBuffer]"===l.call(y)?new Uint8Array(y):y,n=s.inflateSetDictionary(this.strm,h)),n===u.Z_BUF_ERROR&&g===!0&&(n=u.Z_OK,g=!1),n!==u.Z_STREAM_END&&n!==u.Z_OK)return this.onEnd(n),this.ended=!0,!1;p.next_out&&(0!==p.avail_out&&n!==u.Z_STREAM_END&&(0!==p.avail_in||r!==u.Z_FINISH&&r!==u.Z_SYNC_FLUSH)||("string"===this.options.to?(i=c.utf8border(p.output,p.next_out),o=p.next_out-i,f=c.buf2string(p.output,i),p.next_out=o,p.avail_out=d-o,o&&a.arraySet(p.output,p.output,i,o,0),this.onData(f)):this.onData(a.shrinkBuf(p.output,p.next_out)))),0===p.avail_in&&0===p.avail_out&&(g=!0)}while((p.avail_in>0||0===p.avail_out)&&n!==u.Z_STREAM_END);return n===u.Z_STREAM_END&&(r=u.Z_FINISH),r===u.Z_FINISH?(n=s.inflateEnd(this.strm),this.onEnd(n),this.ended=!0,n===u.Z_OK):r!==u.Z_SYNC_FLUSH||(this.onEnd(u.Z_OK),p.avail_out=0,!0)},r.prototype.onData=function(t){this.chunks.push(t)},r.prototype.onEnd=function(t){t===u.Z_OK&&("string"===this.options.to?this.result=this.chunks.join(""):this.result=a.flattenChunks(this.chunks)),this.chunks=[],this.err=t,this.msg=this.strm.msg},e.Inflate=r,e.inflate=i,e.inflateRaw=o,e.ungzip=i},function(t,e,n){"use strict";function r(t,e){if(e<65537&&(t.subarray&&s||!t.subarray&&o))return String.fromCharCode.apply(null,i.shrinkBuf(t,e));for(var n="",r=0;r=252?6:c>=248?5:c>=240?4:c>=224?3:c>=192?2:1;a[254]=a[254]=1,e.string2buf=function(t){var e,n,r,o,s,a=t.length,c=0;for(o=0;o>>6,e[s++]=128|63&n):n<65536?(e[s++]=224|n>>>12,e[s++]=128|n>>>6&63,e[s++]=128|63&n):(e[s++]=240|n>>>18,e[s++]=128|n>>>12&63,e[s++]=128|n>>>6&63,e[s++]=128|63&n);return e},e.buf2binstring=function(t){return r(t,t.length)},e.binstring2buf=function(t){for(var e=new i.Buf8(t.length),n=0,r=e.length;n4)u[i++]=65533,n+=s-1;else{for(o&=2===s?31:3===s?15:7;s>1&&n1?u[i++]=65533:o<65536?u[i++]=o:(o-=65536,u[i++]=55296|o>>10&1023, -u[i++]=56320|1023&o)}return r(u,i)},e.utf8border=function(t,e){var n;for(e=e||t.length,e>t.length&&(e=t.length),n=e-1;n>=0&&128===(192&t[n]);)n--;return n<0?e:0===n?e:n+a[t[n]]>e?n:e}},function(t,e){"use strict";function n(t,e,n,r){for(var i=65535&t|0,o=t>>>16&65535|0,s=0;0!==n;){s=n>2e3?2e3:n,n-=s;do i=i+e[r++]|0,o=o+i|0;while(--s);i%=65521,o%=65521}return i|o<<16|0}t.exports=n},function(t,e){"use strict";t.exports={Z_NO_FLUSH:0,Z_PARTIAL_FLUSH:1,Z_SYNC_FLUSH:2,Z_FULL_FLUSH:3,Z_FINISH:4,Z_BLOCK:5,Z_TREES:6,Z_OK:0,Z_STREAM_END:1,Z_NEED_DICT:2,Z_ERRNO:-1,Z_STREAM_ERROR:-2,Z_DATA_ERROR:-3,Z_BUF_ERROR:-5,Z_NO_COMPRESSION:0,Z_BEST_SPEED:1,Z_BEST_COMPRESSION:9,Z_DEFAULT_COMPRESSION:-1,Z_FILTERED:1,Z_HUFFMAN_ONLY:2,Z_RLE:3,Z_FIXED:4,Z_DEFAULT_STRATEGY:0,Z_BINARY:0,Z_TEXT:1,Z_UNKNOWN:2,Z_DEFLATED:8}},function(t,e){"use strict";function n(){for(var t,e=[],n=0;n<256;n++){t=n;for(var r=0;r<8;r++)t=1&t?3988292384^t>>>1:t>>>1;e[n]=t}return e}function r(t,e,n,r){var o=i,s=r+n;t^=-1;for(var a=r;a>>8^o[255&(t^e[a])];return t^-1}var i=n();t.exports=r},function(t,e){"use strict";function n(){this.text=0,this.time=0,this.xflags=0,this.os=0,this.extra=null,this.extra_len=0,this.name="",this.comment="",this.hcrc=0,this.done=!1}t.exports=n},function(t,e){"use strict";var n=30,r=12;t.exports=function(t,e){var i,o,s,a,c,u,f,h,p,l,d,y,g,_,v,w,m,E,S,b,k,I,O,F,R;i=t.state,o=t.next_in,F=t.input,s=o+(t.avail_in-5),a=t.next_out,R=t.output,c=a-(e-t.avail_out),u=a+(t.avail_out-257),f=i.dmax,h=i.wsize,p=i.whave,l=i.wnext,d=i.window,y=i.hold,g=i.bits,_=i.lencode,v=i.distcode,w=(1<>>24,y>>>=S,g-=S,S=E>>>16&255,0===S)R[a++]=65535&E;else{if(!(16&S)){if(0===(64&S)){E=_[(65535&E)+(y&(1<>>=S,g-=S),g<15&&(y+=F[o++]<>>24,y>>>=S,g-=S,S=E>>>16&255,!(16&S)){if(0===(64&S)){E=v[(65535&E)+(y&(1<f){t.msg="invalid distance too far back",i.mode=n;break t}if(y>>>=S,g-=S,S=a-c,k>S){if(S=k-S,S>p&&i.sane){t.msg="invalid distance too far back",i.mode=n;break t}if(I=0,O=d,0===l){if(I+=h-S,S2;)R[a++]=O[I++],R[a++]=O[I++],R[a++]=O[I++],b-=3;b&&(R[a++]=O[I++],b>1&&(R[a++]=O[I++]))}else{I=a-k;do R[a++]=R[I++],R[a++]=R[I++],R[a++]=R[I++],b-=3;while(b>2);b&&(R[a++]=R[I++],b>1&&(R[a++]=R[I++]))}break}}break}}while(o>3,o-=b,g-=b<<3,y&=(1<>>24&255)+(t>>>8&65280)+((65280&t)<<8)+((255&t)<<24)}function i(){this.mode=0,this.last=!1,this.wrap=0,this.havedict=!1,this.flags=0,this.dmax=0,this.check=0,this.total=0,this.head=null,this.wbits=0,this.wsize=0,this.whave=0,this.wnext=0,this.window=null,this.hold=0,this.bits=0,this.length=0,this.offset=0,this.extra=0,this.lencode=null,this.distcode=null,this.lenbits=0,this.distbits=0,this.ncode=0,this.nlen=0,this.ndist=0,this.have=0,this.next=null,this.lens=new v.Buf16(320),this.work=new v.Buf16(288),this.lendyn=null,this.distdyn=null,this.sane=0,this.back=0,this.was=0}function o(t){var e;return t&&t.state?(e=t.state,t.total_in=t.total_out=e.total=0,t.msg="",e.wrap&&(t.adler=1&e.wrap),e.mode=U,e.last=0,e.havedict=0,e.dmax=32768,e.head=null,e.hold=0,e.bits=0,e.lencode=e.lendyn=new v.Buf32(yt),e.distcode=e.distdyn=new v.Buf32(gt),e.sane=1,e.back=-1,N):x}function s(t){var e;return t&&t.state?(e=t.state,e.wsize=0,e.whave=0,e.wnext=0,o(t)):x}function a(t,e){var n,r;return t&&t.state?(r=t.state,e<0?(n=0,e=-e):(n=(e>>4)+1,e<48&&(e&=15)),e&&(e<8||e>15)?x:(null!==r.window&&r.wbits!==e&&(r.window=null),r.wrap=n,r.wbits=e,s(t))):x}function c(t,e){var n,r;return t?(r=new i,t.state=r,r.window=null,n=a(t,e),n!==N&&(t.state=null),n):x}function u(t){return c(t,vt)}function f(t){if(wt){var e;for(g=new v.Buf32(512),_=new v.Buf32(32),e=0;e<144;)t.lens[e++]=8;for(;e<256;)t.lens[e++]=9;for(;e<280;)t.lens[e++]=7;for(;e<288;)t.lens[e++]=8;for(S(k,t.lens,0,288,g,0,t.work,{bits:9}),e=0;e<32;)t.lens[e++]=5;S(I,t.lens,0,32,_,0,t.work,{bits:5}),wt=!1}t.lencode=g,t.lenbits=9,t.distcode=_,t.distbits=5}function h(t,e,n,r){var i,o=t.state;return null===o.window&&(o.wsize=1<=o.wsize?(v.arraySet(o.window,e,n-o.wsize,o.wsize,0),o.wnext=0,o.whave=o.wsize):(i=o.wsize-o.wnext,i>r&&(i=r),v.arraySet(o.window,e,n-r,i,o.wnext),r-=i,r?(v.arraySet(o.window,e,n-r,r,0),o.wnext=r,o.whave=o.wsize):(o.wnext+=i,o.wnext===o.wsize&&(o.wnext=0),o.whave>>8&255,n.check=m(n.check,Ft,2,0),p=0,l=0,n.mode=M;break}if(n.flags=0,n.head&&(n.head.done=!1),!(1&n.wrap)||(((255&p)<<8)+(p>>8))%31){t.msg="incorrect header check",n.mode=pt;break}if((15&p)!==C){t.msg="unknown compression method",n.mode=pt;break}if(p>>>=4,l-=4,St=(15&p)+8,0===n.wbits)n.wbits=St;else if(St>n.wbits){t.msg="invalid window size",n.mode=pt;break}n.dmax=1<>8&1),512&n.flags&&(Ft[0]=255&p,Ft[1]=p>>>8&255,n.check=m(n.check,Ft,2,0)),p=0,l=0,n.mode=B;case B:for(;l<32;){if(0===c)break t;c--,p+=i[s++]<>>8&255,Ft[2]=p>>>16&255,Ft[3]=p>>>24&255,n.check=m(n.check,Ft,4,0)),p=0,l=0,n.mode=j;case j:for(;l<16;){if(0===c)break t;c--,p+=i[s++]<>8),512&n.flags&&(Ft[0]=255&p,Ft[1]=p>>>8&255,n.check=m(n.check,Ft,2,0)),p=0,l=0,n.mode=z;case z:if(1024&n.flags){for(;l<16;){if(0===c)break t;c--,p+=i[s++]<>>8&255,n.check=m(n.check,Ft,2,0)),p=0,l=0}else n.head&&(n.head.extra=null);n.mode=q;case q:if(1024&n.flags&&(g=n.length,g>c&&(g=c),g&&(n.head&&(St=n.head.extra_len-n.length,n.head.extra||(n.head.extra=new Array(n.head.extra_len)),v.arraySet(n.head.extra,i,s,g,St)),512&n.flags&&(n.check=m(n.check,i,g,s)),c-=g,s+=g,n.length-=g),n.length))break t;n.length=0,n.mode=V;case V:if(2048&n.flags){if(0===c)break t;g=0;do St=i[s+g++],n.head&&St&&n.length<65536&&(n.head.name+=String.fromCharCode(St));while(St&&g>9&1,n.head.done=!0),t.adler=n.check=0,n.mode=X;break;case Z:for(;l<32;){if(0===c)break t;c--,p+=i[s++]<>>=7&l,l-=7&l,n.mode=ut;break}for(;l<3;){if(0===c)break t;c--,p+=i[s++]<>>=1,l-=1,3&p){case 0:n.mode=G;break;case 1:if(f(n),n.mode=nt,e===R){p>>>=2,l-=2;break t}break;case 2:n.mode=$;break;case 3:t.msg="invalid block type",n.mode=pt}p>>>=2,l-=2;break;case G:for(p>>>=7&l,l-=7&l;l<32;){if(0===c)break t;c--,p+=i[s++]<>>16^65535)){t.msg="invalid stored block lengths",n.mode=pt;break}if(n.length=65535&p,p=0,l=0,n.mode=J,e===R)break t;case J:n.mode=Q;case Q:if(g=n.length){if(g>c&&(g=c),g>u&&(g=u),0===g)break t;v.arraySet(o,i,s,g,a),c-=g,s+=g,u-=g,a+=g,n.length-=g;break}n.mode=X;break;case $:for(;l<14;){if(0===c)break t;c--,p+=i[s++]<>>=5,l-=5,n.ndist=(31&p)+1,p>>>=5,l-=5,n.ncode=(15&p)+4,p>>>=4,l-=4,n.nlen>286||n.ndist>30){t.msg="too many length or distance symbols",n.mode=pt;break}n.have=0,n.mode=tt;case tt:for(;n.have>>=3,l-=3}for(;n.have<19;)n.lens[Rt[n.have++]]=0;if(n.lencode=n.lendyn,n.lenbits=7,kt={bits:n.lenbits},bt=S(b,n.lens,0,19,n.lencode,0,n.work,kt),n.lenbits=kt.bits,bt){t.msg="invalid code lengths set",n.mode=pt;break}n.have=0,n.mode=et;case et:for(;n.have>>24,_t=Ot>>>16&255,vt=65535&Ot,!(gt<=l);){if(0===c)break t;c--,p+=i[s++]<>>=gt,l-=gt,n.lens[n.have++]=vt;else{if(16===vt){for(It=gt+2;l>>=gt,l-=gt,0===n.have){t.msg="invalid bit length repeat",n.mode=pt;break}St=n.lens[n.have-1],g=3+(3&p),p>>>=2,l-=2}else if(17===vt){for(It=gt+3;l>>=gt,l-=gt,St=0,g=3+(7&p),p>>>=3,l-=3}else{for(It=gt+7;l>>=gt,l-=gt,St=0,g=11+(127&p),p>>>=7,l-=7}if(n.have+g>n.nlen+n.ndist){t.msg="invalid bit length repeat",n.mode=pt;break}for(;g--;)n.lens[n.have++]=St}}if(n.mode===pt)break;if(0===n.lens[256]){t.msg="invalid code -- missing end-of-block",n.mode=pt;break}if(n.lenbits=9,kt={bits:n.lenbits},bt=S(k,n.lens,0,n.nlen,n.lencode,0,n.work,kt),n.lenbits=kt.bits,bt){t.msg="invalid literal/lengths set",n.mode=pt;break}if(n.distbits=6,n.distcode=n.distdyn,kt={bits:n.distbits},bt=S(I,n.lens,n.nlen,n.ndist,n.distcode,0,n.work,kt),n.distbits=kt.bits,bt){t.msg="invalid distances set",n.mode=pt;break}if(n.mode=nt,e===R)break t;case nt:n.mode=rt;case rt:if(c>=6&&u>=258){t.next_out=a,t.avail_out=u,t.next_in=s,t.avail_in=c,n.hold=p,n.bits=l,E(t,y),a=t.next_out,o=t.output,u=t.avail_out,s=t.next_in,i=t.input,c=t.avail_in,p=n.hold,l=n.bits,n.mode===X&&(n.back=-1);break}for(n.back=0;Ot=n.lencode[p&(1<>>24,_t=Ot>>>16&255,vt=65535&Ot,!(gt<=l);){if(0===c)break t;c--,p+=i[s++]<>wt)],gt=Ot>>>24,_t=Ot>>>16&255,vt=65535&Ot,!(wt+gt<=l);){if(0===c)break t;c--,p+=i[s++]<>>=wt,l-=wt,n.back+=wt}if(p>>>=gt,l-=gt,n.back+=gt,n.length=vt,0===_t){n.mode=ct;break}if(32&_t){n.back=-1,n.mode=X;break}if(64&_t){t.msg="invalid literal/length code",n.mode=pt;break}n.extra=15&_t,n.mode=it;case it:if(n.extra){for(It=n.extra;l>>=n.extra,l-=n.extra,n.back+=n.extra}n.was=n.length,n.mode=ot;case ot:for(;Ot=n.distcode[p&(1<>>24,_t=Ot>>>16&255,vt=65535&Ot,!(gt<=l);){if(0===c)break t;c--,p+=i[s++]<>wt)],gt=Ot>>>24,_t=Ot>>>16&255,vt=65535&Ot,!(wt+gt<=l);){if(0===c)break t;c--,p+=i[s++]<>>=wt,l-=wt,n.back+=wt}if(p>>>=gt,l-=gt,n.back+=gt,64&_t){t.msg="invalid distance code",n.mode=pt;break}n.offset=vt,n.extra=15&_t,n.mode=st;case st:if(n.extra){for(It=n.extra;l>>=n.extra,l-=n.extra,n.back+=n.extra}if(n.offset>n.dmax){t.msg="invalid distance too far back",n.mode=pt;break}n.mode=at;case at:if(0===u)break t;if(g=y-u,n.offset>g){if(g=n.offset-g,g>n.whave&&n.sane){t.msg="invalid distance too far back",n.mode=pt;break}g>n.wnext?(g-=n.wnext,_=n.wsize-g):_=n.wnext-g,g>n.length&&(g=n.length),yt=n.window}else yt=o,_=a-n.offset,g=n.length;g>u&&(g=u),u-=g,n.length-=g;do o[a++]=yt[_++];while(--g);0===n.length&&(n.mode=rt);break;case ct:if(0===u)break t;o[a++]=n.length,u--,n.mode=rt;break;case ut:if(n.wrap){for(;l<32;){if(0===c)break t;c--,p|=i[s++]<=1&&0===z[x];x--);if(D>x&&(D=x),0===x)return y[g++]=20971520,y[g++]=20971520,v.bits=1,0;for(T=1;T0&&(t===a||1!==x))return-1;for(q[1]=0,N=1;No||t===u&&U>s)return 1;for(;;){I=N-P,_[L]k?(O=V[W+_[L]],F=B[j+_[L]]):(O=96,F=0),w=1<>P)+m]=I<<24|O<<16|F|0;while(0!==m);for(w=1<>=1;if(0!==w?(M&=w-1,M+=w):M=0,L++,0===--z[N]){if(N===x)break;N=e[n+_[L]]}if(N>D&&(M&S)!==E){for(0===P&&(P=D),b+=T,A=N-P,C=1<o||t===u&&U>s)return 1;E=M&S,y[E]=D<<24|A<<16|b-g|0}}return 0!==M&&(y[b+M]=N-P<<24|64<<16|0),v.bits=D,0}},function(t,e){"use strict";t.exports={2:"need dictionary",1:"stream end",0:"","-1":"file error","-2":"stream error","-3":"data error","-4":"insufficient memory","-5":"buffer error","-6":"incompatible version"}},function(t,e){"use strict";function n(){this.input=null,this.next_in=0,this.avail_in=0,this.total_in=0,this.output=null,this.next_out=0,this.avail_out=0,this.total_out=0,this.msg="",this.state=null,this.data_type=2,this.adler=0}t.exports=n},function(t,e,n){t.exports=n(2)},function(t,e,n){"use strict";function r(){this.head=null,this.tail=null,this.length=0}var i=(n(1).Buffer,n(10));t.exports=r,r.prototype.push=function(t){var e={data:t,next:null};this.length>0?this.tail.next=e:this.head=e,this.tail=e,++this.length},r.prototype.unshift=function(t){var e={data:t,next:this.head};0===this.length&&(this.tail=e),this.head=e,++this.length},r.prototype.shift=function(){if(0!==this.length){var t=this.head.data;return 1===this.length?this.head=this.tail=null:this.head=this.head.next,--this.length,t}},r.prototype.clear=function(){this.head=this.tail=null,this.length=0},r.prototype.join=function(t){if(0===this.length)return"";for(var e=this.head,n=""+e.data;e=e.next;)n+=t+e.data;return n},r.prototype.concat=function(t){if(0===this.length)return i.alloc(0);if(1===this.length)return this.head.data;for(var e=i.allocUnsafe(t>>>0),n=this.head,r=0;n;)n.data.copy(e,r),r+=n.data.length,n=n.next;return e}},function(t,e,n){t.exports=n(15)},function(t,e,n){(function(r){var i=function(){try{return n(9)}catch(t){}}();e=t.exports=n(16),e.Stream=i||e,e.Readable=e,e.Writable=n(13),e.Duplex=n(2),e.Transform=n(12),e.PassThrough=n(15),!r.browser&&"disable"===r.env.READABLE_STREAM&&i&&(t.exports=i)}).call(e,n(3))},function(t,e,n){t.exports=n(12)},function(t,e,n){t.exports=n(13)},function(t,e){(function(e){function n(t,e){function n(){if(!i){if(r("throwDeprecation"))throw new Error(e);r("traceDeprecation")?console.trace(e):console.warn(e),i=!0}return t.apply(this,arguments)}if(r("noDeprecation"))return t;var i=!1;return n}function r(t){try{if(!e.localStorage)return!1}catch(t){return!1}var n=e.localStorage[t];return null!=n&&"true"===String(n).toLowerCase()}t.exports=n}).call(e,function(){return this}())},function(t,e){t.exports=function(t){return t.webpackPolyfill||(t.deprecate=function(){},t.paths=[],t.children=[],t.webpackPolyfill=1),t}},function(t,e){}])}); -//# sourceMappingURL=browserfs.min.js.map \ No newline at end of file +!function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e():"function"==typeof define&&define.amd?define([],e):"object"==typeof exports?exports.BrowserFS=e():t.BrowserFS=e()}(this,function(){return function(t){var e={};function n(r){if(e[r])return e[r].exports;var i=e[r]={i:r,l:!1,exports:{}};return t[r].call(i.exports,i,i.exports,n),i.l=!0,i.exports}return n.m=t,n.c=e,n.d=function(t,e,r){n.o(t,e)||Object.defineProperty(t,e,{enumerable:!0,get:r})},n.r=function(t){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})},n.t=function(t,e){if(1&e&&(t=n(t)),8&e)return t;if(4&e&&"object"==typeof t&&t&&t.__esModule)return t;var r=Object.create(null);if(n.r(r),Object.defineProperty(r,"default",{enumerable:!0,value:t}),2&e&&"string"!=typeof t)for(var i in t)n.d(r,i,function(e){return t[e]}.bind(null,i));return r},n.n=function(t){var e=t&&t.__esModule?function(){return t.default}:function(){return t};return n.d(e,"a",e),e},n.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},n.p="",n(n.s=19)}([function(t,e,n){"use strict";var r=n(6),i=Object.keys||function(t){var e=[];for(var n in t)e.push(n);return e};t.exports=h;var o=Object.create(n(3));o.inherits=n(1);var s=n(14),a=n(12);o.inherits(h,s);for(var c=i(a.prototype),u=0;u0&&s.length>i&&!s.warned){s.warned=!0;var a=new Error("Possible EventEmitter memory leak detected. "+s.length+" "+String(e)+" listeners added. Use emitter.setMaxListeners() to increase limit");a.name="MaxListenersExceededWarning",a.emitter=t,a.type=e,a.count=s.length,function(t){console&&console.warn&&console.warn(t)}(a)}return t}function l(t,e,n){var r={fired:!1,wrapFn:void 0,target:t,type:e,listener:n},i=function(){if(!this.fired)return this.target.removeListener(this.type,this.wrapFn),this.fired=!0,0===arguments.length?this.listener.call(this.target):this.listener.apply(this.target,arguments)}.bind(r);return i.listener=n,r.wrapFn=i,i}function p(t,e,n){var r=t._events;if(void 0===r)return[];var i=r[e];return void 0===i?[]:"function"==typeof i?n?[i.listener||i]:[i]:n?function(t){for(var e=new Array(t.length),n=0;n0&&(s=e[0]),s instanceof Error)throw s;var a=new Error("Unhandled error."+(s?" ("+s.message+")":""));throw a.context=s,a}var c=i[t];if(void 0===c)return!1;if("function"==typeof c)o(c,this,e);else{var u=c.length,f=y(c,u);for(n=0;n=0;o--)if(n[o]===e||n[o].listener===e){s=n[o].listener,i=o;break}if(i<0)return this;0===i?n.shift():function(t,e){for(;e+1=0;r--)this.removeListener(t,e[r]);return this},a.prototype.listeners=function(t){return p(this,t,!0)},a.prototype.rawListeners=function(t){return p(this,t,!1)},a.listenerCount=function(t,e){return"function"==typeof t.listenerCount?t.listenerCount(e):d.call(t,e)},a.prototype.listenerCount=d,a.prototype.eventNames=function(){return this._eventsCount>0?r(this._events):[]}},function(t,e,n){"use strict";(function(e){void 0===e||!e.version||0===e.version.indexOf("v0.")||0===e.version.indexOf("v1.")&&0!==e.version.indexOf("v1.8.")?t.exports={nextTick:function(t,n,r,i){if("function"!=typeof t)throw new TypeError('"callback" argument must be a function');var o,s,a=arguments.length;switch(a){case 0:case 1:return e.nextTick(t);case 2:return e.nextTick(function(){t.call(null,n)});case 3:return e.nextTick(function(){t.call(null,n,r)});case 4:return e.nextTick(function(){t.call(null,n,r,i)});default:for(o=new Array(a-1),s=0;s + * @license MIT + */var r=n(20),i=n(21);e.Buffer=a,e.SlowBuffer=function(t){+t!=t&&(t=0);return a.alloc(+t)},e.INSPECT_MAX_BYTES=50;var o=2147483647;function s(t){if(t>o)throw new RangeError("Invalid typed array length");var e=new Uint8Array(t);return e.__proto__=a.prototype,e}function a(t,e,n){if("number"==typeof t){if("string"==typeof e)throw new Error("If encoding is specified then the first argument must be a string");return f(t)}return c(t,e,n)}function c(t,e,n){if("number"==typeof t)throw new TypeError('"value" argument must not be a number');return B(t)||t&&B(t.buffer)?function(t,e,n){if(e<0||t.byteLength=o)throw new RangeError("Attempt to allocate Buffer larger than maximum size: 0x"+o.toString(16)+" bytes");return 0|t}function p(t,e){if(a.isBuffer(t))return t.length;if(ArrayBuffer.isView(t)||B(t))return t.byteLength;"string"!=typeof t&&(t=""+t);var n=t.length;if(0===n)return 0;for(var r=!1;;)switch(e){case"ascii":case"latin1":case"binary":return n;case"utf8":case"utf-8":case void 0:return M(t).length;case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return 2*n;case"hex":return n>>>1;case"base64":return U(t).length;default:if(r)return M(t).length;e=(""+e).toLowerCase(),r=!0}}function d(t,e,n){var r=t[e];t[e]=t[n],t[n]=r}function y(t,e,n,r,i){if(0===t.length)return-1;if("string"==typeof n?(r=n,n=0):n>2147483647?n=2147483647:n<-2147483648&&(n=-2147483648),z(n=+n)&&(n=i?0:t.length-1),n<0&&(n=t.length+n),n>=t.length){if(i)return-1;n=t.length-1}else if(n<0){if(!i)return-1;n=0}if("string"==typeof e&&(e=a.from(e,r)),a.isBuffer(e))return 0===e.length?-1:g(t,e,n,r,i);if("number"==typeof e)return e&=255,"function"==typeof Uint8Array.prototype.indexOf?i?Uint8Array.prototype.indexOf.call(t,e,n):Uint8Array.prototype.lastIndexOf.call(t,e,n):g(t,[e],n,r,i);throw new TypeError("val must be string, number or Buffer")}function g(t,e,n,r,i){var o,s=1,a=t.length,c=e.length;if(void 0!==r&&("ucs2"===(r=String(r).toLowerCase())||"ucs-2"===r||"utf16le"===r||"utf-16le"===r)){if(t.length<2||e.length<2)return-1;s=2,a/=2,c/=2,n/=2}function u(t,e){return 1===s?t[e]:t.readUInt16BE(e*s)}if(i){var f=-1;for(o=n;oa&&(n=a-c),o=n;o>=0;o--){for(var h=!0,l=0;li&&(r=i):r=i;var o=e.length;r>o/2&&(r=o/2);for(var s=0;s>8,i=n%256,o.push(i),o.push(r);return o}(e,t.length-n),t,n,r)}function E(t,e,n){return 0===e&&n===t.length?r.fromByteArray(t):r.fromByteArray(t.slice(e,n))}function k(t,e,n){n=Math.min(t.length,n);for(var r=[],i=e;i239?4:u>223?3:u>191?2:1;if(i+h<=n)switch(h){case 1:u<128&&(f=u);break;case 2:128==(192&(o=t[i+1]))&&(c=(31&u)<<6|63&o)>127&&(f=c);break;case 3:o=t[i+1],s=t[i+2],128==(192&o)&&128==(192&s)&&(c=(15&u)<<12|(63&o)<<6|63&s)>2047&&(c<55296||c>57343)&&(f=c);break;case 4:o=t[i+1],s=t[i+2],a=t[i+3],128==(192&o)&&128==(192&s)&&128==(192&a)&&(c=(15&u)<<18|(63&o)<<12|(63&s)<<6|63&a)>65535&&c<1114112&&(f=c)}null===f?(f=65533,h=1):f>65535&&(f-=65536,r.push(f>>>10&1023|55296),f=56320|1023&f),r.push(f),i+=h}return function(t){var e=t.length;if(e<=O)return String.fromCharCode.apply(String,t);var n="",r=0;for(;rthis.length)return"";if((void 0===n||n>this.length)&&(n=this.length),n<=0)return"";if((n>>>=0)<=(e>>>=0))return"";for(t||(t="utf8");;)switch(t){case"hex":return N(this,e,n);case"utf8":case"utf-8":return k(this,e,n);case"ascii":return I(this,e,n);case"latin1":case"binary":return F(this,e,n);case"base64":return E(this,e,n);case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return T(this,e,n);default:if(r)throw new TypeError("Unknown encoding: "+t);t=(t+"").toLowerCase(),r=!0}}.apply(this,arguments)},a.prototype.toLocaleString=a.prototype.toString,a.prototype.equals=function(t){if(!a.isBuffer(t))throw new TypeError("Argument must be a Buffer");return this===t||0===a.compare(this,t)},a.prototype.inspect=function(){var t="",n=e.INSPECT_MAX_BYTES;return this.length>0&&(t=this.toString("hex",0,n).match(/.{2}/g).join(" "),this.length>n&&(t+=" ... ")),""},a.prototype.compare=function(t,e,n,r,i){if(!a.isBuffer(t))throw new TypeError("Argument must be a Buffer");if(void 0===e&&(e=0),void 0===n&&(n=t?t.length:0),void 0===r&&(r=0),void 0===i&&(i=this.length),e<0||n>t.length||r<0||i>this.length)throw new RangeError("out of range index");if(r>=i&&e>=n)return 0;if(r>=i)return-1;if(e>=n)return 1;if(e>>>=0,n>>>=0,r>>>=0,i>>>=0,this===t)return 0;for(var o=i-r,s=n-e,c=Math.min(o,s),u=this.slice(r,i),f=t.slice(e,n),h=0;h>>=0,isFinite(n)?(n>>>=0,void 0===r&&(r="utf8")):(r=n,n=void 0)}var i=this.length-e;if((void 0===n||n>i)&&(n=i),t.length>0&&(n<0||e<0)||e>this.length)throw new RangeError("Attempt to write outside buffer bounds");r||(r="utf8");for(var o=!1;;)switch(r){case"hex":return _(this,t,e,n);case"utf8":case"utf-8":return m(this,t,e,n);case"ascii":return w(this,t,e,n);case"latin1":case"binary":return v(this,t,e,n);case"base64":return b(this,t,e,n);case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return S(this,t,e,n);default:if(o)throw new TypeError("Unknown encoding: "+r);r=(""+r).toLowerCase(),o=!0}},a.prototype.toJSON=function(){return{type:"Buffer",data:Array.prototype.slice.call(this._arr||this,0)}};var O=4096;function I(t,e,n){var r="";n=Math.min(t.length,n);for(var i=e;ir)&&(n=r);for(var i="",o=e;on)throw new RangeError("Trying to access beyond buffer length")}function L(t,e,n,r,i,o){if(!a.isBuffer(t))throw new TypeError('"buffer" argument must be a Buffer instance');if(e>i||et.length)throw new RangeError("Index out of range")}function x(t,e,n,r,i,o){if(n+r>t.length)throw new RangeError("Index out of range");if(n<0)throw new RangeError("Index out of range")}function D(t,e,n,r,o){return e=+e,n>>>=0,o||x(t,0,n,4),i.write(t,e,n,r,23,4),n+4}function A(t,e,n,r,o){return e=+e,n>>>=0,o||x(t,0,n,8),i.write(t,e,n,r,52,8),n+8}a.prototype.slice=function(t,e){var n=this.length;t=~~t,e=void 0===e?n:~~e,t<0?(t+=n)<0&&(t=0):t>n&&(t=n),e<0?(e+=n)<0&&(e=0):e>n&&(e=n),e>>=0,e>>>=0,n||R(t,e,this.length);for(var r=this[t],i=1,o=0;++o>>=0,e>>>=0,n||R(t,e,this.length);for(var r=this[t+--e],i=1;e>0&&(i*=256);)r+=this[t+--e]*i;return r},a.prototype.readUInt8=function(t,e){return t>>>=0,e||R(t,1,this.length),this[t]},a.prototype.readUInt16LE=function(t,e){return t>>>=0,e||R(t,2,this.length),this[t]|this[t+1]<<8},a.prototype.readUInt16BE=function(t,e){return t>>>=0,e||R(t,2,this.length),this[t]<<8|this[t+1]},a.prototype.readUInt32LE=function(t,e){return t>>>=0,e||R(t,4,this.length),(this[t]|this[t+1]<<8|this[t+2]<<16)+16777216*this[t+3]},a.prototype.readUInt32BE=function(t,e){return t>>>=0,e||R(t,4,this.length),16777216*this[t]+(this[t+1]<<16|this[t+2]<<8|this[t+3])},a.prototype.readIntLE=function(t,e,n){t>>>=0,e>>>=0,n||R(t,e,this.length);for(var r=this[t],i=1,o=0;++o=(i*=128)&&(r-=Math.pow(2,8*e)),r},a.prototype.readIntBE=function(t,e,n){t>>>=0,e>>>=0,n||R(t,e,this.length);for(var r=e,i=1,o=this[t+--r];r>0&&(i*=256);)o+=this[t+--r]*i;return o>=(i*=128)&&(o-=Math.pow(2,8*e)),o},a.prototype.readInt8=function(t,e){return t>>>=0,e||R(t,1,this.length),128&this[t]?-1*(255-this[t]+1):this[t]},a.prototype.readInt16LE=function(t,e){t>>>=0,e||R(t,2,this.length);var n=this[t]|this[t+1]<<8;return 32768&n?4294901760|n:n},a.prototype.readInt16BE=function(t,e){t>>>=0,e||R(t,2,this.length);var n=this[t+1]|this[t]<<8;return 32768&n?4294901760|n:n},a.prototype.readInt32LE=function(t,e){return t>>>=0,e||R(t,4,this.length),this[t]|this[t+1]<<8|this[t+2]<<16|this[t+3]<<24},a.prototype.readInt32BE=function(t,e){return t>>>=0,e||R(t,4,this.length),this[t]<<24|this[t+1]<<16|this[t+2]<<8|this[t+3]},a.prototype.readFloatLE=function(t,e){return t>>>=0,e||R(t,4,this.length),i.read(this,t,!0,23,4)},a.prototype.readFloatBE=function(t,e){return t>>>=0,e||R(t,4,this.length),i.read(this,t,!1,23,4)},a.prototype.readDoubleLE=function(t,e){return t>>>=0,e||R(t,8,this.length),i.read(this,t,!0,52,8)},a.prototype.readDoubleBE=function(t,e){return t>>>=0,e||R(t,8,this.length),i.read(this,t,!1,52,8)},a.prototype.writeUIntLE=function(t,e,n,r){(t=+t,e>>>=0,n>>>=0,r)||L(this,t,e,n,Math.pow(2,8*n)-1,0);var i=1,o=0;for(this[e]=255&t;++o>>=0,n>>>=0,r)||L(this,t,e,n,Math.pow(2,8*n)-1,0);var i=n-1,o=1;for(this[e+i]=255&t;--i>=0&&(o*=256);)this[e+i]=t/o&255;return e+n},a.prototype.writeUInt8=function(t,e,n){return t=+t,e>>>=0,n||L(this,t,e,1,255,0),this[e]=255&t,e+1},a.prototype.writeUInt16LE=function(t,e,n){return t=+t,e>>>=0,n||L(this,t,e,2,65535,0),this[e]=255&t,this[e+1]=t>>>8,e+2},a.prototype.writeUInt16BE=function(t,e,n){return t=+t,e>>>=0,n||L(this,t,e,2,65535,0),this[e]=t>>>8,this[e+1]=255&t,e+2},a.prototype.writeUInt32LE=function(t,e,n){return t=+t,e>>>=0,n||L(this,t,e,4,4294967295,0),this[e+3]=t>>>24,this[e+2]=t>>>16,this[e+1]=t>>>8,this[e]=255&t,e+4},a.prototype.writeUInt32BE=function(t,e,n){return t=+t,e>>>=0,n||L(this,t,e,4,4294967295,0),this[e]=t>>>24,this[e+1]=t>>>16,this[e+2]=t>>>8,this[e+3]=255&t,e+4},a.prototype.writeIntLE=function(t,e,n,r){if(t=+t,e>>>=0,!r){var i=Math.pow(2,8*n-1);L(this,t,e,n,i-1,-i)}var o=0,s=1,a=0;for(this[e]=255&t;++o>0)-a&255;return e+n},a.prototype.writeIntBE=function(t,e,n,r){if(t=+t,e>>>=0,!r){var i=Math.pow(2,8*n-1);L(this,t,e,n,i-1,-i)}var o=n-1,s=1,a=0;for(this[e+o]=255&t;--o>=0&&(s*=256);)t<0&&0===a&&0!==this[e+o+1]&&(a=1),this[e+o]=(t/s>>0)-a&255;return e+n},a.prototype.writeInt8=function(t,e,n){return t=+t,e>>>=0,n||L(this,t,e,1,127,-128),t<0&&(t=255+t+1),this[e]=255&t,e+1},a.prototype.writeInt16LE=function(t,e,n){return t=+t,e>>>=0,n||L(this,t,e,2,32767,-32768),this[e]=255&t,this[e+1]=t>>>8,e+2},a.prototype.writeInt16BE=function(t,e,n){return t=+t,e>>>=0,n||L(this,t,e,2,32767,-32768),this[e]=t>>>8,this[e+1]=255&t,e+2},a.prototype.writeInt32LE=function(t,e,n){return t=+t,e>>>=0,n||L(this,t,e,4,2147483647,-2147483648),this[e]=255&t,this[e+1]=t>>>8,this[e+2]=t>>>16,this[e+3]=t>>>24,e+4},a.prototype.writeInt32BE=function(t,e,n){return t=+t,e>>>=0,n||L(this,t,e,4,2147483647,-2147483648),t<0&&(t=4294967295+t+1),this[e]=t>>>24,this[e+1]=t>>>16,this[e+2]=t>>>8,this[e+3]=255&t,e+4},a.prototype.writeFloatLE=function(t,e,n){return D(this,t,e,!0,n)},a.prototype.writeFloatBE=function(t,e,n){return D(this,t,e,!1,n)},a.prototype.writeDoubleLE=function(t,e,n){return A(this,t,e,!0,n)},a.prototype.writeDoubleBE=function(t,e,n){return A(this,t,e,!1,n)},a.prototype.copy=function(t,e,n,r){if(!a.isBuffer(t))throw new TypeError("argument should be a Buffer");if(n||(n=0),r||0===r||(r=this.length),e>=t.length&&(e=t.length),e||(e=0),r>0&&r=this.length)throw new RangeError("Index out of range");if(r<0)throw new RangeError("sourceEnd out of bounds");r>this.length&&(r=this.length),t.length-e=0;--o)t[o+e]=this[o+n];else Uint8Array.prototype.set.call(t,this.subarray(n,r),e);return i},a.prototype.fill=function(t,e,n,r){if("string"==typeof t){if("string"==typeof e?(r=e,e=0,n=this.length):"string"==typeof n&&(r=n,n=this.length),void 0!==r&&"string"!=typeof r)throw new TypeError("encoding must be a string");if("string"==typeof r&&!a.isEncoding(r))throw new TypeError("Unknown encoding: "+r);if(1===t.length){var i=t.charCodeAt(0);("utf8"===r&&i<128||"latin1"===r)&&(t=i)}}else"number"==typeof t&&(t&=255);if(e<0||this.length>>=0,n=void 0===n?this.length:n>>>0,t||(t=0),"number"==typeof t)for(o=e;o55295&&n<57344){if(!i){if(n>56319){(e-=3)>-1&&o.push(239,191,189);continue}if(s+1===r){(e-=3)>-1&&o.push(239,191,189);continue}i=n;continue}if(n<56320){(e-=3)>-1&&o.push(239,191,189),i=n;continue}n=65536+(i-55296<<10|n-56320)}else i&&(e-=3)>-1&&o.push(239,191,189);if(i=null,n<128){if((e-=1)<0)break;o.push(n)}else if(n<2048){if((e-=2)<0)break;o.push(n>>6|192,63&n|128)}else if(n<65536){if((e-=3)<0)break;o.push(n>>12|224,n>>6&63|128,63&n|128)}else{if(!(n<1114112))throw new Error("Invalid code point");if((e-=4)<0)break;o.push(n>>18|240,n>>12&63|128,n>>6&63|128,63&n|128)}}return o}function U(t){return r.toByteArray(function(t){if((t=(t=t.split("=")[0]).trim().replace(P,"")).length<2)return"";for(;t.length%4!=0;)t+="=";return t}(t))}function j(t,e,n,r){for(var i=0;i=e.length||i>=t.length);++i)e[i+n]=t[i];return i}function B(t){return t instanceof ArrayBuffer||null!=t&&null!=t.constructor&&"ArrayBuffer"===t.constructor.name&&"number"==typeof t.byteLength}function z(t){return t!=t}},function(t,e,n){(e=t.exports=n(14)).Stream=e,e.Readable=e,e.Writable=n(12),e.Duplex=n(0),e.Transform=n(18),e.PassThrough=n(30)},function(t,e,n){"use strict";(function(e,r){var i=n(6);function o(t){var e=this;this.next=null,this.entry=null,this.finish=function(){!function(t,e,n){var r=t.entry;t.entry=null;for(;r;){var i=r.callback;e.pendingcb--,i(n),r=r.next}e.corkedRequestsFree?e.corkedRequestsFree.next=t:e.corkedRequestsFree=t}(e,t)}}t.exports=_;var s,a=!e.browser&&["v0.10","v0.9."].indexOf(e.version.slice(0,5))>-1?setImmediate:i.nextTick;_.WritableState=g;var c=Object.create(n(3));c.inherits=n(1);var u={deprecate:n(29)},f=n(15),h=n(7).Buffer,l=r.Uint8Array||function(){};var p,d=n(16);function y(){}function g(t,e){s=s||n(0),t=t||{};var r=e instanceof s;this.objectMode=!!t.objectMode,r&&(this.objectMode=this.objectMode||!!t.writableObjectMode);var c=t.highWaterMark,u=t.writableHighWaterMark,f=this.objectMode?16:16384;this.highWaterMark=c||0===c?c:r&&(u||0===u)?u:f,this.highWaterMark=Math.floor(this.highWaterMark),this.finalCalled=!1,this.needDrain=!1,this.ending=!1,this.ended=!1,this.finished=!1,this.destroyed=!1;var h=!1===t.decodeStrings;this.decodeStrings=!h,this.defaultEncoding=t.defaultEncoding||"utf8",this.length=0,this.writing=!1,this.corked=0,this.sync=!0,this.bufferProcessing=!1,this.onwrite=function(t){!function(t,e){var n=t._writableState,r=n.sync,o=n.writecb;if(function(t){t.writing=!1,t.writecb=null,t.length-=t.writelen,t.writelen=0}(n),e)!function(t,e,n,r,o){--e.pendingcb,n?(i.nextTick(o,r),i.nextTick(E,t,e),t._writableState.errorEmitted=!0,t.emit("error",r)):(o(r),t._writableState.errorEmitted=!0,t.emit("error",r),E(t,e))}(t,n,r,e,o);else{var s=b(n);s||n.corked||n.bufferProcessing||!n.bufferedRequest||v(t,n),r?a(w,t,n,s,o):w(t,n,s,o)}}(e,t)},this.writecb=null,this.writelen=0,this.bufferedRequest=null,this.lastBufferedRequest=null,this.pendingcb=0,this.prefinished=!1,this.errorEmitted=!1,this.bufferedRequestCount=0,this.corkedRequestsFree=new o(this)}function _(t){if(s=s||n(0),!(p.call(_,this)||this instanceof s))return new _(t);this._writableState=new g(t,this),this.writable=!0,t&&("function"==typeof t.write&&(this._write=t.write),"function"==typeof t.writev&&(this._writev=t.writev),"function"==typeof t.destroy&&(this._destroy=t.destroy),"function"==typeof t.final&&(this._final=t.final)),f.call(this)}function m(t,e,n,r,i,o,s){e.writelen=r,e.writecb=s,e.writing=!0,e.sync=!0,n?t._writev(i,e.onwrite):t._write(i,o,e.onwrite),e.sync=!1}function w(t,e,n,r){n||function(t,e){0===e.length&&e.needDrain&&(e.needDrain=!1,t.emit("drain"))}(t,e),e.pendingcb--,r(),E(t,e)}function v(t,e){e.bufferProcessing=!0;var n=e.bufferedRequest;if(t._writev&&n&&n.next){var r=e.bufferedRequestCount,i=new Array(r),s=e.corkedRequestsFree;s.entry=n;for(var a=0,c=!0;n;)i[a]=n,n.isBuf||(c=!1),n=n.next,a+=1;i.allBuffers=c,m(t,e,!0,e.length,i,"",s.finish),e.pendingcb++,e.lastBufferedRequest=null,s.next?(e.corkedRequestsFree=s.next,s.next=null):e.corkedRequestsFree=new o(e),e.bufferedRequestCount=0}else{for(;n;){var u=n.chunk,f=n.encoding,h=n.callback;if(m(t,e,!1,e.objectMode?1:u.length,u,f,h),n=n.next,e.bufferedRequestCount--,e.writing)break}null===n&&(e.lastBufferedRequest=null)}e.bufferedRequest=n,e.bufferProcessing=!1}function b(t){return t.ending&&0===t.length&&null===t.bufferedRequest&&!t.finished&&!t.writing}function S(t,e){t._final(function(n){e.pendingcb--,n&&t.emit("error",n),e.prefinished=!0,t.emit("prefinish"),E(t,e)})}function E(t,e){var n=b(e);return n&&(!function(t,e){e.prefinished||e.finalCalled||("function"==typeof t._final?(e.pendingcb++,e.finalCalled=!0,i.nextTick(S,t,e)):(e.prefinished=!0,t.emit("prefinish")))}(t,e),0===e.pendingcb&&(e.finished=!0,t.emit("finish"))),n}c.inherits(_,f),g.prototype.getBuffer=function(){for(var t=this.bufferedRequest,e=[];t;)e.push(t),t=t.next;return e},function(){try{Object.defineProperty(g.prototype,"buffer",{get:u.deprecate(function(){return this.getBuffer()},"_writableState.buffer is deprecated. Use _writableState.getBuffer instead.","DEP0003")})}catch(t){}}(),"function"==typeof Symbol&&Symbol.hasInstance&&"function"==typeof Function.prototype[Symbol.hasInstance]?(p=Function.prototype[Symbol.hasInstance],Object.defineProperty(_,Symbol.hasInstance,{value:function(t){return!!p.call(this,t)||this===_&&(t&&t._writableState instanceof g)}})):p=function(t){return t instanceof this},_.prototype.pipe=function(){this.emit("error",new Error("Cannot pipe, not readable"))},_.prototype.write=function(t,e,n){var r=this._writableState,o=!1,s=!r.objectMode&&function(t){return h.isBuffer(t)||t instanceof l}(t);return s&&!h.isBuffer(t)&&(t=function(t){return h.from(t)}(t)),"function"==typeof e&&(n=e,e=null),s?e="buffer":e||(e=r.defaultEncoding),"function"!=typeof n&&(n=y),r.ended?function(t,e){var n=new Error("write after end");t.emit("error",n),i.nextTick(e,n)}(this,n):(s||function(t,e,n,r){var o=!0,s=!1;return null===n?s=new TypeError("May not write null values to stream"):"string"==typeof n||void 0===n||e.objectMode||(s=new TypeError("Invalid non-string/buffer chunk")),s&&(t.emit("error",s),i.nextTick(r,s),o=!1),o}(this,r,t,n))&&(r.pendingcb++,o=function(t,e,n,r,i,o){if(!n){var s=function(t,e,n){t.objectMode||!1===t.decodeStrings||"string"!=typeof e||(e=h.from(e,n));return e}(e,r,i);r!==s&&(n=!0,i="buffer",r=s)}var a=e.objectMode?1:r.length;e.length+=a;var c=e.length-1))throw new TypeError("Unknown encoding: "+t);return this._writableState.defaultEncoding=t,this},Object.defineProperty(_.prototype,"writableHighWaterMark",{enumerable:!1,get:function(){return this._writableState.highWaterMark}}),_.prototype._write=function(t,e,n){n(new Error("_write() is not implemented"))},_.prototype._writev=null,_.prototype.end=function(t,e,n){var r=this._writableState;"function"==typeof t?(n=t,t=null,e=null):"function"==typeof e&&(n=e,e=null),null!==t&&void 0!==t&&this.write(t,e),r.corked&&(r.corked=1,this.uncork()),r.ending||r.finished||function(t,e,n){e.ending=!0,E(t,e),n&&(e.finished?i.nextTick(n):t.once("finish",n));e.ended=!0,t.writable=!1}(this,r,n)},Object.defineProperty(_.prototype,"destroyed",{get:function(){return void 0!==this._writableState&&this._writableState.destroyed},set:function(t){this._writableState&&(this._writableState.destroyed=t)}}),_.prototype.destroy=d.destroy,_.prototype._undestroy=d.undestroy,_.prototype._destroy=function(t,e){this.end(),e(t)}}).call(this,n(2),n(4))},function(t,e,n){"use strict";(function(e){var n=/^(\/?|)([\s\S]*?)((?:\.{1,2}|[^\/]+?|)(\.[^.\/]*|))(?:[\/]*)$/;var r=function(){function t(){}return t.normalize=function(e){""===e&&(e=".");for(var n=e.charAt(0)===t.sep,r=(e=t._removeDuplicateSeps(e)).split(t.sep),i=[],o=0;o0&&".."!==i[0])?i.pop():i.push(s))}if(!n&&i.length<2)switch(i.length){case 1:""===i[0]&&i.unshift(".");break;default:i.push(".")}return e=i.join(t.sep),n&&e.charAt(0)!==t.sep&&(e=t.sep+e),e},t.join=function(){for(var e=[],n=0;n1&&a.charAt(a.length-1)===t.sep)return a.substr(0,a.length-1);if(a.charAt(0)!==t.sep){"."!==a.charAt(0)||1!==a.length&&a.charAt(1)!==t.sep||(a=1===a.length?"":a.substr(2));var c=e.cwd();a=""!==a?this.normalize(c+("/"!==c?t.sep:"")+a):c}return a},t.relative=function(e,n){var r;e=t.resolve(e),n=t.resolve(n);var i=e.split(t.sep),o=n.split(t.sep);o.shift(),i.shift();var s=0,a=[];for(r=0;ri.length&&(s=i.length);var c="";for(r=0;r1&&c.charAt(c.length-1)===t.sep&&(c=c.substr(0,c.length-1)),c},t.dirname=function(e){var n=(e=t._removeDuplicateSeps(e)).charAt(0)===t.sep,r=e.split(t.sep);return""===r.pop()&&r.length>0&&r.pop(),r.length>1||1===r.length&&!n?r.join(t.sep):n?t.sep:"."},t.basename=function(e,n){if(void 0===n&&(n=""),""===e)return e;var r=(e=t.normalize(e)).split(t.sep),i=r[r.length-1];if(""===i&&r.length>1)return r[r.length-2];if(n.length>0&&i.substr(i.length-n.length)===n)return i.substr(0,i.length-n.length);return i},t.extname=function(e){var n=(e=t.normalize(e)).split(t.sep);if(""===(e=n.pop())&&n.length>0&&(e=n.pop()),".."===e)return"";var r=e.lastIndexOf(".");return-1===r||0===r?"":e.substr(r)},t.isAbsolute=function(e){return e.length>0&&e.charAt(0)===t.sep},t._makeLong=function(t){return t},t.parse=function(t){var e=function(t){var e=n.exec(t);return e.shift(),e}(t);return{root:e[0],dir:e[0]+e[1].slice(0,-1),base:e[2],ext:e[3],name:e[2].slice(0,e[2].length-e[3].length)}},t.format=function(e){if(null===e||"object"!=typeof e)throw new TypeError("Parameter 'pathObject' must be an object, not "+typeof e);if("string"!=typeof(e.root||""))throw new TypeError("'pathObject.root' must be a string or undefined, not "+typeof e.root);return(e.dir?e.dir+t.sep:"")+(e.base||"")},t._removeDuplicateSeps=function(t){return t=t.replace(this._replaceRegex,this.sep)},t.sep="/",t._replaceRegex=new RegExp("//+","g"),t.delimiter=":",t.posix=t,t.win32=t,t}();t.exports=r}).call(this,n(2))},function(t,e,n){"use strict";(function(e,r){var i=n(6);t.exports=w;var o,s=n(25);w.ReadableState=m;n(5).EventEmitter;var a=function(t,e){return t.listeners(e).length},c=n(15),u=n(7).Buffer,f=e.Uint8Array||function(){};var h=Object.create(n(3));h.inherits=n(1);var l=n(26),p=void 0;p=l&&l.debuglog?l.debuglog("stream"):function(){};var d,y=n(27),g=n(16);h.inherits(w,c);var _=["error","close","destroy","pause","resume"];function m(t,e){o=o||n(0),t=t||{};var r=e instanceof o;this.objectMode=!!t.objectMode,r&&(this.objectMode=this.objectMode||!!t.readableObjectMode);var i=t.highWaterMark,s=t.readableHighWaterMark,a=this.objectMode?16:16384;this.highWaterMark=i||0===i?i:r&&(s||0===s)?s:a,this.highWaterMark=Math.floor(this.highWaterMark),this.buffer=new y,this.length=0,this.pipes=null,this.pipesCount=0,this.flowing=null,this.ended=!1,this.endEmitted=!1,this.reading=!1,this.sync=!0,this.needReadable=!1,this.emittedReadable=!1,this.readableListening=!1,this.resumeScheduled=!1,this.destroyed=!1,this.defaultEncoding=t.defaultEncoding||"utf8",this.awaitDrain=0,this.readingMore=!1,this.decoder=null,this.encoding=null,t.encoding&&(d||(d=n(17).StringDecoder),this.decoder=new d(t.encoding),this.encoding=t.encoding)}function w(t){if(o=o||n(0),!(this instanceof w))return new w(t);this._readableState=new m(t,this),this.readable=!0,t&&("function"==typeof t.read&&(this._read=t.read),"function"==typeof t.destroy&&(this._destroy=t.destroy)),c.call(this)}function v(t,e,n,r,i){var o,s=t._readableState;null===e?(s.reading=!1,function(t,e){if(e.ended)return;if(e.decoder){var n=e.decoder.end();n&&n.length&&(e.buffer.push(n),e.length+=e.objectMode?1:n.length)}e.ended=!0,k(t)}(t,s)):(i||(o=function(t,e){var n;(function(t){return u.isBuffer(t)||t instanceof f})(e)||"string"==typeof e||void 0===e||t.objectMode||(n=new TypeError("Invalid non-string/buffer chunk"));return n}(s,e)),o?t.emit("error",o):s.objectMode||e&&e.length>0?("string"==typeof e||s.objectMode||Object.getPrototypeOf(e)===u.prototype||(e=function(t){return u.from(t)}(e)),r?s.endEmitted?t.emit("error",new Error("stream.unshift() after end event")):b(t,s,e,!0):s.ended?t.emit("error",new Error("stream.push() after EOF")):(s.reading=!1,s.decoder&&!n?(e=s.decoder.write(e),s.objectMode||0!==e.length?b(t,s,e,!1):I(t,s)):b(t,s,e,!1))):r||(s.reading=!1));return function(t){return!t.ended&&(t.needReadable||t.lengthe.highWaterMark&&(e.highWaterMark=function(t){return t>=S?t=S:(t--,t|=t>>>1,t|=t>>>2,t|=t>>>4,t|=t>>>8,t|=t>>>16,t++),t}(t)),t<=e.length?t:e.ended?e.length:(e.needReadable=!0,0))}function k(t){var e=t._readableState;e.needReadable=!1,e.emittedReadable||(p("emitReadable",e.flowing),e.emittedReadable=!0,e.sync?i.nextTick(O,t):O(t))}function O(t){p("emit readable"),t.emit("readable"),R(t)}function I(t,e){e.readingMore||(e.readingMore=!0,i.nextTick(F,t,e))}function F(t,e){for(var n=e.length;!e.reading&&!e.flowing&&!e.ended&&e.length=e.length?(n=e.decoder?e.buffer.join(""):1===e.buffer.length?e.buffer.head.data:e.buffer.concat(e.length),e.buffer.clear()):n=function(t,e,n){var r;to.length?o.length:t;if(s===o.length?i+=o:i+=o.slice(0,t),0===(t-=s)){s===o.length?(++r,n.next?e.head=n.next:e.head=e.tail=null):(e.head=n,n.data=o.slice(s));break}++r}return e.length-=r,i}(t,e):function(t,e){var n=u.allocUnsafe(t),r=e.head,i=1;r.data.copy(n),t-=r.data.length;for(;r=r.next;){var o=r.data,s=t>o.length?o.length:t;if(o.copy(n,n.length-t,0,s),0===(t-=s)){s===o.length?(++i,r.next?e.head=r.next:e.head=e.tail=null):(e.head=r,r.data=o.slice(s));break}++i}return e.length-=i,n}(t,e);return r}(t,e.buffer,e.decoder),n);var n}function x(t){var e=t._readableState;if(e.length>0)throw new Error('"endReadable()" called on non-empty stream');e.endEmitted||(e.ended=!0,i.nextTick(D,e,t))}function D(t,e){t.endEmitted||0!==t.length||(t.endEmitted=!0,e.readable=!1,e.emit("end"))}function A(t,e){for(var n=0,r=t.length;n=e.highWaterMark||e.ended))return p("read: emitReadable",e.length,e.ended),0===e.length&&e.ended?x(this):k(this),null;if(0===(t=E(t,e))&&e.ended)return 0===e.length&&x(this),null;var r,i=e.needReadable;return p("need readable",i),(0===e.length||e.length-t0?L(t,e):null)?(e.needReadable=!0,t=0):e.length-=t,0===e.length&&(e.ended||(e.needReadable=!0),n!==t&&e.ended&&x(this)),null!==r&&this.emit("data",r),r},w.prototype._read=function(t){this.emit("error",new Error("_read() is not implemented"))},w.prototype.pipe=function(t,e){var n=this,o=this._readableState;switch(o.pipesCount){case 0:o.pipes=t;break;case 1:o.pipes=[o.pipes,t];break;default:o.pipes.push(t)}o.pipesCount+=1,p("pipe count=%d opts=%j",o.pipesCount,e);var c=(!e||!1!==e.end)&&t!==r.stdout&&t!==r.stderr?f:w;function u(e,r){p("onunpipe"),e===n&&r&&!1===r.hasUnpiped&&(r.hasUnpiped=!0,p("cleanup"),t.removeListener("close",_),t.removeListener("finish",m),t.removeListener("drain",h),t.removeListener("error",g),t.removeListener("unpipe",u),n.removeListener("end",f),n.removeListener("end",w),n.removeListener("data",y),l=!0,!o.awaitDrain||t._writableState&&!t._writableState.needDrain||h())}function f(){p("onend"),t.end()}o.endEmitted?i.nextTick(c):n.once("end",c),t.on("unpipe",u);var h=function(t){return function(){var e=t._readableState;p("pipeOnDrain",e.awaitDrain),e.awaitDrain&&e.awaitDrain--,0===e.awaitDrain&&a(t,"data")&&(e.flowing=!0,R(t))}}(n);t.on("drain",h);var l=!1;var d=!1;function y(e){p("ondata"),d=!1,!1!==t.write(e)||d||((1===o.pipesCount&&o.pipes===t||o.pipesCount>1&&-1!==A(o.pipes,t))&&!l&&(p("false write response, pause",n._readableState.awaitDrain),n._readableState.awaitDrain++,d=!0),n.pause())}function g(e){p("onerror",e),w(),t.removeListener("error",g),0===a(t,"error")&&t.emit("error",e)}function _(){t.removeListener("finish",m),w()}function m(){p("onfinish"),t.removeListener("close",_),w()}function w(){p("unpipe"),n.unpipe(t)}return n.on("data",y),function(t,e,n){if("function"==typeof t.prependListener)return t.prependListener(e,n);t._events&&t._events[e]?s(t._events[e])?t._events[e].unshift(n):t._events[e]=[n,t._events[e]]:t.on(e,n)}(t,"error",g),t.once("close",_),t.once("finish",m),t.emit("pipe",n),o.flowing||(p("pipe resume"),n.resume()),t},w.prototype.unpipe=function(t){var e=this._readableState,n={hasUnpiped:!1};if(0===e.pipesCount)return this;if(1===e.pipesCount)return t&&t!==e.pipes?this:(t||(t=e.pipes),e.pipes=null,e.pipesCount=0,e.flowing=!1,t&&t.emit("unpipe",this,n),this);if(!t){var r=e.pipes,i=e.pipesCount;e.pipes=null,e.pipesCount=0,e.flowing=!1;for(var o=0;o>5==6?2:t>>4==14?3:t>>3==30?4:t>>6==2?-1:-2}function a(t){var e=this.lastTotal-this.lastNeed,n=function(t,e,n){if(128!=(192&e[0]))return t.lastNeed=0,"�";if(t.lastNeed>1&&e.length>1){if(128!=(192&e[1]))return t.lastNeed=1,"�";if(t.lastNeed>2&&e.length>2&&128!=(192&e[2]))return t.lastNeed=2,"�"}}(this,t);return void 0!==n?n:this.lastNeed<=t.length?(t.copy(this.lastChar,e,0,this.lastNeed),this.lastChar.toString(this.encoding,0,this.lastTotal)):(t.copy(this.lastChar,e,0,t.length),void(this.lastNeed-=t.length))}function c(t,e){if((t.length-e)%2==0){var n=t.toString("utf16le",e);if(n){var r=n.charCodeAt(n.length-1);if(r>=55296&&r<=56319)return this.lastNeed=2,this.lastTotal=4,this.lastChar[0]=t[t.length-2],this.lastChar[1]=t[t.length-1],n.slice(0,-1)}return n}return this.lastNeed=1,this.lastTotal=2,this.lastChar[0]=t[t.length-1],t.toString("utf16le",e,t.length-1)}function u(t){var e=t&&t.length?this.write(t):"";if(this.lastNeed){var n=this.lastTotal-this.lastNeed;return e+this.lastChar.toString("utf16le",0,n)}return e}function f(t,e){var n=(t.length-e)%3;return 0===n?t.toString("base64",e):(this.lastNeed=3-n,this.lastTotal=3,1===n?this.lastChar[0]=t[t.length-1]:(this.lastChar[0]=t[t.length-2],this.lastChar[1]=t[t.length-1]),t.toString("base64",e,t.length-n))}function h(t){var e=t&&t.length?this.write(t):"";return this.lastNeed?e+this.lastChar.toString("base64",0,3-this.lastNeed):e}function l(t){return t.toString(this.encoding)}function p(t){return t&&t.length?this.write(t):""}e.StringDecoder=o,o.prototype.write=function(t){if(0===t.length)return"";var e,n;if(this.lastNeed){if(void 0===(e=this.fillLast(t)))return"";n=this.lastNeed,this.lastNeed=0}else n=0;return n=0)return i>0&&(t.lastNeed=i-1),i;if(--r=0)return i>0&&(t.lastNeed=i-2),i;if(--r=0)return i>0&&(2===i?i=0:t.lastNeed=i-3),i;return 0}(this,t,e);if(!this.lastNeed)return t.toString("utf8",e);this.lastTotal=n;var r=t.length-(n-this.lastNeed);return t.copy(this.lastChar,0,r),t.toString("utf8",e,r)},o.prototype.fillLast=function(t){if(this.lastNeed<=t.length)return t.copy(this.lastChar,this.lastTotal-this.lastNeed,0,this.lastNeed),this.lastChar.toString(this.encoding,0,this.lastTotal);t.copy(this.lastChar,this.lastTotal-this.lastNeed,0,t.length),this.lastNeed-=t.length}},function(t,e,n){"use strict";t.exports=o;var r=n(0),i=Object.create(n(3));function o(t){if(!(this instanceof o))return new o(t);r.call(this,t),this._transformState={afterTransform:function(t,e){var n=this._transformState;n.transforming=!1;var r=n.writecb;if(!r)return this.emit("error",new Error("write callback called multiple times"));n.writechunk=null,n.writecb=null,null!=e&&this.push(e),r(t);var i=this._readableState;i.reading=!1,(i.needReadable||i.length0))return v.shift()()};w.addEventListener?w.addEventListener("message",b,!0):w.attachEvent("onmessage",b)}else if(w.MessageChannel){var S=new w.MessageChannel;S.port1.onmessage=function(t){if(v.length>0)return v.shift()()},_=function(t){v.push(t),S.port2.postMessage("")}}else _=function(t){return setTimeout(t,0)}}var E=_,k=function(t,e){return t};function O(t,e){if("function"!=typeof t)throw new Error("Callback must be a function.");var n=k(t,e);switch(e){case 1:return function(t){E(function(){return n(t)})};case 2:return function(t,e){E(function(){return n(t,e)})};case 3:return function(t,e,r){E(function(){return n(t,e,r)})};default:throw new Error("Invalid invocation of wrapCb.")}}function I(t){if(t)return t;throw new h(s.EIO,"Initialize BrowserFS with a file system using BrowserFS.initialize(filesystem)")}function F(t,e){switch(typeof t){case"number":return t;case"string":var n=parseInt(t,8);return isNaN(n)?e:n;default:return e}}function N(t){if(t instanceof Date)return t;if("number"==typeof t)return new Date(1e3*t);throw new h(s.EINVAL,"Invalid time.")}function T(t){if(t.indexOf("\0")>=0)throw new h(s.EINVAL,"Path must be a string without null bytes.");if(""===t)throw new h(s.EINVAL,"Path must not be empty.");return a.resolve(t)}function R(t,e,n,r){switch(null===t?"null":typeof t){case"object":return{encoding:void 0!==t.encoding?t.encoding:e,flag:void 0!==t.flag?t.flag:n,mode:F(t.mode,r)};case"string":return{encoding:t,flag:n,mode:r};case"null":case"undefined":case"function":return{encoding:e,flag:n,mode:r};default:throw new TypeError('"options" must be a string or an object, got '+typeof t+" instead.")}}function L(){}var x=function(){this.F_OK=0,this.R_OK=4,this.W_OK=2,this.X_OK=1,this.root=null,this.fdMap={},this.nextFd=100};x.prototype.initialize=function(t){if(!t.constructor.isAvailable())throw new h(s.EINVAL,"Tried to instantiate BrowserFS with an unavailable file system.");return this.root=t},x.prototype._toUnixTimestamp=function(t){if("number"==typeof t)return t;if(t instanceof Date)return t.getTime()/1e3;throw new Error("Cannot parse time: "+t)},x.prototype.getRootFS=function(){return this.root?this.root:null},x.prototype.rename=function(t,e,n){void 0===n&&(n=L);var r=O(n,1);try{I(this.root).rename(T(t),T(e),r)}catch(t){r(t)}},x.prototype.renameSync=function(t,e){I(this.root).renameSync(T(t),T(e))},x.prototype.exists=function(t,e){void 0===e&&(e=L);var n=O(e,1);try{return I(this.root).exists(T(t),n)}catch(t){return n(!1)}},x.prototype.existsSync=function(t){try{return I(this.root).existsSync(T(t))}catch(t){return!1}},x.prototype.stat=function(t,e){void 0===e&&(e=L);var n=O(e,2);try{return I(this.root).stat(T(t),!1,n)}catch(t){return n(t)}},x.prototype.statSync=function(t){return I(this.root).statSync(T(t),!1)},x.prototype.lstat=function(t,e){void 0===e&&(e=L);var n=O(e,2);try{return I(this.root).stat(T(t),!0,n)}catch(t){return n(t)}},x.prototype.lstatSync=function(t){return I(this.root).statSync(T(t),!0)},x.prototype.truncate=function(t,e,n){void 0===e&&(e=0),void 0===n&&(n=L);var r=0;"function"==typeof e?n=e:"number"==typeof e&&(r=e);var i=O(n,1);try{if(r<0)throw new h(s.EINVAL);return I(this.root).truncate(T(t),r,i)}catch(t){return i(t)}},x.prototype.truncateSync=function(t,e){if(void 0===e&&(e=0),e<0)throw new h(s.EINVAL);return I(this.root).truncateSync(T(t),e)},x.prototype.unlink=function(t,e){void 0===e&&(e=L);var n=O(e,1);try{return I(this.root).unlink(T(t),n)}catch(t){return n(t)}},x.prototype.unlinkSync=function(t){return I(this.root).unlinkSync(T(t))},x.prototype.open=function(t,e,n,r){var i=this;void 0===r&&(r=L);var o=F(n,420),s=O(r="function"==typeof n?n:r,2);try{I(this.root).open(T(t),d.getFileFlag(e),o,function(t,e){e?s(t,i.getFdForFile(e)):s(t)})}catch(t){s(t)}},x.prototype.openSync=function(t,e,n){return void 0===n&&(n=420),this.getFdForFile(I(this.root).openSync(T(t),d.getFileFlag(e),F(n,420)))},x.prototype.readFile=function(t,e,n){void 0===e&&(e={}),void 0===n&&(n=L);var r=R(e,null,"r",null),i=O(n="function"==typeof e?e:n,2);try{var o=d.getFileFlag(r.flag);return o.isReadable()?I(this.root).readFile(T(t),r.encoding,o,i):i(new h(s.EINVAL,"Flag passed to readFile must allow for reading."))}catch(t){return i(t)}},x.prototype.readFileSync=function(t,e){void 0===e&&(e={});var n=R(e,null,"r",null),r=d.getFileFlag(n.flag);if(!r.isReadable())throw new h(s.EINVAL,"Flag passed to readFile must allow for reading.");return I(this.root).readFileSync(T(t),n.encoding,r)},x.prototype.writeFile=function(t,e,n,r){void 0===n&&(n={}),void 0===r&&(r=L);var i=R(n,"utf8","w",420),o=O(r="function"==typeof n?n:r,1);try{var a=d.getFileFlag(i.flag);return a.isWriteable()?I(this.root).writeFile(T(t),e,i.encoding,a,i.mode,o):o(new h(s.EINVAL,"Flag passed to writeFile must allow for writing."))}catch(t){return o(t)}},x.prototype.writeFileSync=function(t,e,n){var r=R(n,"utf8","w",420),i=d.getFileFlag(r.flag);if(!i.isWriteable())throw new h(s.EINVAL,"Flag passed to writeFile must allow for writing.");return I(this.root).writeFileSync(T(t),e,r.encoding,i,r.mode)},x.prototype.appendFile=function(t,e,n,r){void 0===r&&(r=L);var i=R(n,"utf8","a",420),o=O(r="function"==typeof n?n:r,1);try{var a=d.getFileFlag(i.flag);if(!a.isAppendable())return o(new h(s.EINVAL,"Flag passed to appendFile must allow for appending."));I(this.root).appendFile(T(t),e,i.encoding,a,i.mode,o)}catch(t){o(t)}},x.prototype.appendFileSync=function(t,e,n){var r=R(n,"utf8","a",420),i=d.getFileFlag(r.flag);if(!i.isAppendable())throw new h(s.EINVAL,"Flag passed to appendFile must allow for appending.");return I(this.root).appendFileSync(T(t),e,r.encoding,i,r.mode)},x.prototype.fstat=function(t,e){void 0===e&&(e=L);var n=O(e,2);try{this.fd2file(t).stat(n)}catch(t){n(t)}},x.prototype.fstatSync=function(t){return this.fd2file(t).statSync()},x.prototype.close=function(t,e){var n=this;void 0===e&&(e=L);var r=O(e,1);try{this.fd2file(t).close(function(e){e||n.closeFd(t),r(e)})}catch(t){r(t)}},x.prototype.closeSync=function(t){this.fd2file(t).closeSync(),this.closeFd(t)},x.prototype.ftruncate=function(t,e,n){void 0===n&&(n=L);var r="number"==typeof e?e:0,i=O(n="function"==typeof e?e:n,1);try{var o=this.fd2file(t);if(r<0)throw new h(s.EINVAL);o.truncate(r,i)}catch(t){i(t)}},x.prototype.ftruncateSync=function(t,e){void 0===e&&(e=0);var n=this.fd2file(t);if(e<0)throw new h(s.EINVAL);n.truncateSync(e)},x.prototype.fsync=function(t,e){void 0===e&&(e=L);var n=O(e,1);try{this.fd2file(t).sync(n)}catch(t){n(t)}},x.prototype.fsyncSync=function(t){this.fd2file(t).syncSync()},x.prototype.fdatasync=function(t,e){void 0===e&&(e=L);var n=O(e,1);try{this.fd2file(t).datasync(n)}catch(t){n(t)}},x.prototype.fdatasyncSync=function(t){this.fd2file(t).datasyncSync()},x.prototype.write=function(e,n,r,i,o,a){void 0===a&&(a=L);var c,u,f,l=null;if("string"==typeof n){var p="utf8";switch(typeof r){case"function":a=r;break;case"number":l=r,p="string"==typeof i?i:"utf8",a="function"==typeof o?o:a;break;default:return(a="function"==typeof i?i:"function"==typeof o?o:a)(new h(s.EINVAL,"Invalid arguments."))}u=0,f=(c=t.from(n,p)).length}else c=n,u=r,f=i,l="number"==typeof o?o:null,a="function"==typeof o?o:a;var d=O(a,3);try{var y=this.fd2file(e);void 0!==l&&null!==l||(l=y.getPos()),y.write(c,u,f,l,d)}catch(t){d(t)}},x.prototype.writeSync=function(e,n,r,i,o){var s,a,c,u=0;if("string"==typeof n){c="number"==typeof r?r:null;var f="string"==typeof i?i:"utf8";u=0,a=(s=t.from(n,f)).length}else s=n,u=r,a=i,c="number"==typeof o?o:null;var h=this.fd2file(e);return void 0!==c&&null!==c||(c=h.getPos()),h.writeSync(s,u,a,c)},x.prototype.read=function(e,n,r,i,o,s){var a,c,u,f,h;if(void 0===s&&(s=L),"number"==typeof n){u=n,a=r;var l=i;s="function"==typeof o?o:s,c=0,f=t.alloc(u),h=O(function(t,e,n){if(t)return s(t);s(t,n.toString(l),e)},3)}else f=n,c=r,u=i,a=o,h=O(s,3);try{var p=this.fd2file(e);void 0!==a&&null!==a||(a=p.getPos()),p.read(f,c,u,a,h)}catch(t){h(t)}},x.prototype.readSync=function(e,n,r,i,o){var s,a,c,u,f=!1,h="utf8";"number"==typeof n?(c=n,u=r,h=i,a=0,s=t.alloc(c),f=!0):(s=n,a=r,c=i,u=o);var l=this.fd2file(e);void 0!==u&&null!==u||(u=l.getPos());var p=l.readSync(s,a,c,u);return f?[s.toString(h),p]:p},x.prototype.fchown=function(t,e,n,r){void 0===r&&(r=L);var i=O(r,1);try{this.fd2file(t).chown(e,n,i)}catch(t){i(t)}},x.prototype.fchownSync=function(t,e,n){this.fd2file(t).chownSync(e,n)},x.prototype.fchmod=function(t,e,n){var r=O(n,1);try{var i="string"==typeof e?parseInt(e,8):e;this.fd2file(t).chmod(i,r)}catch(t){r(t)}},x.prototype.fchmodSync=function(t,e){var n="string"==typeof e?parseInt(e,8):e;this.fd2file(t).chmodSync(n)},x.prototype.futimes=function(t,e,n,r){void 0===r&&(r=L);var i=O(r,1);try{var o=this.fd2file(t);"number"==typeof e&&(e=new Date(1e3*e)),"number"==typeof n&&(n=new Date(1e3*n)),o.utimes(e,n,i)}catch(t){i(t)}},x.prototype.futimesSync=function(t,e,n){this.fd2file(t).utimesSync(N(e),N(n))},x.prototype.rmdir=function(t,e){void 0===e&&(e=L);var n=O(e,1);try{t=T(t),I(this.root).rmdir(t,n)}catch(t){n(t)}},x.prototype.rmdirSync=function(t){return t=T(t),I(this.root).rmdirSync(t)},x.prototype.mkdir=function(t,e,n){void 0===n&&(n=L),"function"==typeof e&&(n=e,e=511);var r=O(n,1);try{t=T(t),I(this.root).mkdir(t,e,r)}catch(t){r(t)}},x.prototype.mkdirSync=function(t,e){I(this.root).mkdirSync(T(t),F(e,511))},x.prototype.readdir=function(t,e){void 0===e&&(e=L);var n=O(e,2);try{t=T(t),I(this.root).readdir(t,n)}catch(t){n(t)}},x.prototype.readdirSync=function(t){return t=T(t),I(this.root).readdirSync(t)},x.prototype.link=function(t,e,n){void 0===n&&(n=L);var r=O(n,1);try{t=T(t),e=T(e),I(this.root).link(t,e,r)}catch(t){r(t)}},x.prototype.linkSync=function(t,e){return t=T(t),e=T(e),I(this.root).linkSync(t,e)},x.prototype.symlink=function(t,e,n,r){void 0===r&&(r=L);var i="string"==typeof n?n:"file",o=O(r="function"==typeof n?n:r,1);try{if("file"!==i&&"dir"!==i)return o(new h(s.EINVAL,"Invalid type: "+i));t=T(t),e=T(e),I(this.root).symlink(t,e,i,o)}catch(t){o(t)}},x.prototype.symlinkSync=function(t,e,n){if(n){if("file"!==n&&"dir"!==n)throw new h(s.EINVAL,"Invalid type: "+n)}else n="file";return t=T(t),e=T(e),I(this.root).symlinkSync(t,e,n)},x.prototype.readlink=function(t,e){void 0===e&&(e=L);var n=O(e,2);try{t=T(t),I(this.root).readlink(t,n)}catch(t){n(t)}},x.prototype.readlinkSync=function(t){return t=T(t),I(this.root).readlinkSync(t)},x.prototype.chown=function(t,e,n,r){void 0===r&&(r=L);var i=O(r,1);try{t=T(t),I(this.root).chown(t,!1,e,n,i)}catch(t){i(t)}},x.prototype.chownSync=function(t,e,n){t=T(t),I(this.root).chownSync(t,!1,e,n)},x.prototype.lchown=function(t,e,n,r){void 0===r&&(r=L);var i=O(r,1);try{t=T(t),I(this.root).chown(t,!0,e,n,i)}catch(t){i(t)}},x.prototype.lchownSync=function(t,e,n){t=T(t),I(this.root).chownSync(t,!0,e,n)},x.prototype.chmod=function(t,e,n){void 0===n&&(n=L);var r=O(n,1);try{var i=F(e,-1);if(i<0)throw new h(s.EINVAL,"Invalid mode.");I(this.root).chmod(T(t),!1,i,r)}catch(t){r(t)}},x.prototype.chmodSync=function(t,e){var n=F(e,-1);if(n<0)throw new h(s.EINVAL,"Invalid mode.");t=T(t),I(this.root).chmodSync(t,!1,n)},x.prototype.lchmod=function(t,e,n){void 0===n&&(n=L);var r=O(n,1);try{var i=F(e,-1);if(i<0)throw new h(s.EINVAL,"Invalid mode.");I(this.root).chmod(T(t),!0,i,r)}catch(t){r(t)}},x.prototype.lchmodSync=function(t,e){var n=F(e,-1);if(n<1)throw new h(s.EINVAL,"Invalid mode.");I(this.root).chmodSync(T(t),!0,n)},x.prototype.utimes=function(t,e,n,r){void 0===r&&(r=L);var i=O(r,1);try{I(this.root).utimes(T(t),N(e),N(n),i)}catch(t){i(t)}},x.prototype.utimesSync=function(t,e,n){I(this.root).utimesSync(T(t),N(e),N(n))},x.prototype.realpath=function(t,e,n){void 0===n&&(n=L);var r="object"==typeof e?e:{},i=O(n="function"==typeof e?e:L,2);try{t=T(t),I(this.root).realpath(t,r,i)}catch(t){i(t)}},x.prototype.realpathSync=function(t,e){return void 0===e&&(e={}),t=T(t),I(this.root).realpathSync(t,e)},x.prototype.watchFile=function(t,e,n){throw void 0===n&&(n=L),new h(s.ENOTSUP)},x.prototype.unwatchFile=function(t,e){throw void 0===e&&(e=L),new h(s.ENOTSUP)},x.prototype.watch=function(t,e,n){throw void 0===n&&(n=L),new h(s.ENOTSUP)},x.prototype.access=function(t,e,n){throw void 0===n&&(n=L),new h(s.ENOTSUP)},x.prototype.accessSync=function(t,e){throw new h(s.ENOTSUP)},x.prototype.createReadStream=function(t,e){throw new h(s.ENOTSUP)},x.prototype.createWriteStream=function(t,e){throw new h(s.ENOTSUP)},x.prototype.wrapCallbacks=function(t){k=t},x.prototype.getFdForFile=function(t){var e=this.nextFd++;return this.fdMap[e]=t,e},x.prototype.fd2file=function(t){var e=this.fdMap[t];if(e)return e;throw new h(s.EBADF,"Invalid file descriptor.")},x.prototype.closeFd=function(t){delete this.fdMap[t]},x.Stats=y;var D=new x,A={},P=x.prototype;function C(t,e,n,r,i){return tn?n+1:t+1:r===i?e:e+1}Object.keys(P).forEach(function(t){"function"==typeof D[t]?A[t]=function(){return D[t].apply(D,arguments)}:A[t]=D[t]}),A.changeFSModule=function(t){D=t},A.getFSModule=function(){return D},A.FS=x,A.Stats=x.Stats;var M="undefined"!=typeof navigator&&!(!/(msie) ([\w.]+)/.exec(navigator.userAgent.toLowerCase())&&-1===navigator.userAgent.indexOf("Trident")),U="undefined"==typeof window;function j(){throw new Error("BFS has reached an impossible code path; please file a bug.")}function B(t,e,n){n.existsSync(t)||(B(a.dirname(t),e,n),n.mkdirSync(t,e))}function z(t){var e=q(t),n=e.byteOffset,r=e.byteLength;return 0===n&&r===e.buffer.byteLength?e.buffer:e.buffer.slice(n,n+r)}function q(t){return t instanceof Uint8Array?t:new Uint8Array(t)}function W(e){return e instanceof t?e:e instanceof Uint8Array?H(e):t.from(e)}function H(e){return e instanceof t?e:0===e.byteOffset&&e.byteLength===e.buffer.byteLength?V(e.buffer):t.from(e.buffer,e.byteOffset,e.byteLength)}function V(e){return t.from(e)}function Z(t,e,n){if(void 0===e&&(e=0),void 0===n&&(n=t.length),e<0||n<0||n>t.length||e>n)throw new TypeError("Invalid slice bounds on buffer of length "+t.length+": ["+e+", "+n+"]");if(0===t.length)return X();var r=q(t),i=t[0],o=(i+1)%255;return t[0]=o,r[0]===o?(r[0]=i,H(r.slice(e,n))):(t[0]=i,H(r.subarray(e,n)))}var Y=null;function X(){return Y||(Y=t.alloc(0))}function K(e,n){t.isBuffer(e)?n():n(new h(s.EINVAL,"option must be a Buffer."))}function J(t,e,n){var r=t.Options,i=t.Name,o=0,a=!1,c=!1;function u(t){a||(t&&(a=!0,n(t)),0===--o&&c&&n())}var f=function(t){if(r.hasOwnProperty(t)){var c=r[t],f=e[t];if(void 0===f||null===f){if(!c.optional){var l=Object.keys(e).filter(function(t){return!(t in r)}).map(function(e){return{str:e,distance:function(t,e){if(t===e)return 0;if(t.length>e.length){var n=t;t=e,e=n}for(var r=t.length,i=e.length;r>0&&t.charCodeAt(r-1)===e.charCodeAt(i-1);)r--,i--;for(var o=0;ob?b+1:k+1:S===h[r+E]?a:a+1,a=k}}return b}(t,e)}}).filter(function(t){return t.distance<5}).sort(function(t,e){return t.distance-e.distance});return a?{}:(a=!0,{v:n(new h(s.EINVAL,"["+i+"] Required option '"+t+"' not provided."+(l.length>0?" You provided unrecognized option '"+l[0].str+"'; perhaps you meant to type '"+t+"'.":"")+"\nOption description: "+c.description))})}}else{if(!(Array.isArray(c.type)?-1!==c.type.indexOf(typeof f):typeof f===c.type))return a?{}:(a=!0,{v:n(new h(s.EINVAL,"["+i+"] Value provided for option "+t+" is not the proper type. Expected "+(Array.isArray(c.type)?"one of {"+c.type.join(", ")+"}":c.type)+", but received "+typeof f+"\nOption description: "+c.description))});c.validator&&(o++,c.validator(f,u))}}};for(var l in r){var p=f(l);if(p)return p.v}c=!0,0!==o||a||n()}var G=Object.freeze({deprecationMessage:function(t,e,n){t&&console.warn("["+e+"] Direct file system constructor usage is deprecated for this file system, and will be removed in the next major version. Please use the '"+e+".Create("+JSON.stringify(n)+", callback)' method instead. See https://github.com/jvilk/BrowserFS/issues/176 for more details.")},isIE:M,isWebWorker:U,fail:j,mkdirpSync:B,buffer2ArrayBuffer:z,buffer2Uint8array:q,arrayish2Buffer:W,uint8Array2Buffer:H,arrayBuffer2Buffer:V,copyingSlice:Z,emptyBuffer:X,bufferValidator:K,checkOptions:J}),Q=function(t){this.fs=t,this.nodefs=t.getNodeFS(),this.FS=t.getFS(),this.PATH=t.getPATH(),this.ERRNO_CODES=t.getERRNO_CODES()};Q.prototype.open=function(t){var e=this.fs.realPath(t.node),n=this.FS;try{n.isFile(t.node.mode)&&(t.nfd=this.nodefs.openSync(e,this.fs.flagsToPermissionString(t.flags)))}catch(t){if(!t.code)throw t;throw new n.ErrnoError(this.ERRNO_CODES[t.code])}},Q.prototype.close=function(t){var e=this.FS;try{e.isFile(t.node.mode)&&t.nfd&&this.nodefs.closeSync(t.nfd)}catch(t){if(!t.code)throw t;throw new e.ErrnoError(this.ERRNO_CODES[t.code])}},Q.prototype.read=function(t,e,n,r,i){try{return this.nodefs.readSync(t.nfd,H(e),n,r,i)}catch(t){throw new this.FS.ErrnoError(this.ERRNO_CODES[t.code])}},Q.prototype.write=function(t,e,n,r,i){try{return this.nodefs.writeSync(t.nfd,H(e),n,r,i)}catch(t){throw new this.FS.ErrnoError(this.ERRNO_CODES[t.code])}},Q.prototype.llseek=function(t,e,n){var r=e;if(1===n)r+=t.position;else if(2===n&&this.FS.isFile(t.node.mode))try{r+=this.nodefs.fstatSync(t.nfd).size}catch(t){throw new this.FS.ErrnoError(this.ERRNO_CODES[t.code])}if(r<0)throw new this.FS.ErrnoError(this.ERRNO_CODES.EINVAL);return t.position=r,r};var $=function(t){this.fs=t,this.nodefs=t.getNodeFS(),this.FS=t.getFS(),this.PATH=t.getPATH(),this.ERRNO_CODES=t.getERRNO_CODES()};$.prototype.getattr=function(t){var e,n=this.fs.realPath(t);try{e=this.nodefs.lstatSync(n)}catch(t){if(!t.code)throw t;throw new this.FS.ErrnoError(this.ERRNO_CODES[t.code])}return{dev:e.dev,ino:e.ino,mode:e.mode,nlink:e.nlink,uid:e.uid,gid:e.gid,rdev:e.rdev,size:e.size,atime:e.atime,mtime:e.mtime,ctime:e.ctime,blksize:e.blksize,blocks:e.blocks}},$.prototype.setattr=function(t,e){var n=this.fs.realPath(t);try{if(void 0!==e.mode&&(this.nodefs.chmodSync(n,e.mode),t.mode=e.mode),void 0!==e.timestamp){var r=new Date(e.timestamp);this.nodefs.utimesSync(n,r,r)}}catch(t){if(!t.code)throw t;if("ENOTSUP"!==t.code)throw new this.FS.ErrnoError(this.ERRNO_CODES[t.code])}if(void 0!==e.size)try{this.nodefs.truncateSync(n,e.size)}catch(t){if(!t.code)throw t;throw new this.FS.ErrnoError(this.ERRNO_CODES[t.code])}},$.prototype.lookup=function(t,e){var n=this.PATH.join2(this.fs.realPath(t),e),r=this.fs.getMode(n);return this.fs.createNode(t,e,r)},$.prototype.mknod=function(t,e,n,r){var i=this.fs.createNode(t,e,n,r),o=this.fs.realPath(i);try{this.FS.isDir(i.mode)?this.nodefs.mkdirSync(o,i.mode):this.nodefs.writeFileSync(o,"",{mode:i.mode})}catch(t){if(!t.code)throw t;throw new this.FS.ErrnoError(this.ERRNO_CODES[t.code])}return i},$.prototype.rename=function(t,e,n){var r=this.fs.realPath(t),i=this.PATH.join2(this.fs.realPath(e),n);try{this.nodefs.renameSync(r,i),t.name=n,t.parent=e}catch(t){if(!t.code)throw t;throw new this.FS.ErrnoError(this.ERRNO_CODES[t.code])}},$.prototype.unlink=function(t,e){var n=this.PATH.join2(this.fs.realPath(t),e);try{this.nodefs.unlinkSync(n)}catch(t){if(!t.code)throw t;throw new this.FS.ErrnoError(this.ERRNO_CODES[t.code])}},$.prototype.rmdir=function(t,e){var n=this.PATH.join2(this.fs.realPath(t),e);try{this.nodefs.rmdirSync(n)}catch(t){if(!t.code)throw t;throw new this.FS.ErrnoError(this.ERRNO_CODES[t.code])}},$.prototype.readdir=function(t){var e=this.fs.realPath(t);try{var n=this.nodefs.readdirSync(e);return n.push(".",".."),n}catch(t){if(!t.code)throw t;throw new this.FS.ErrnoError(this.ERRNO_CODES[t.code])}},$.prototype.symlink=function(t,e,n){var r=this.PATH.join2(this.fs.realPath(t),e);try{this.nodefs.symlinkSync(n,r)}catch(t){if(!t.code)throw t;throw new this.FS.ErrnoError(this.ERRNO_CODES[t.code])}},$.prototype.readlink=function(t){var e=this.fs.realPath(t);try{return this.nodefs.readlinkSync(e)}catch(t){if(!t.code)throw t;throw new this.FS.ErrnoError(this.ERRNO_CODES[t.code])}};var tt=function(t,e,n,r){void 0===t&&(t=self.FS),void 0===e&&(e=self.PATH),void 0===n&&(n=self.ERRNO_CODES),void 0===r&&(r=A),this.flagsToPermissionStringMap={0:"r",1:"r+",2:"r+",64:"r",65:"r+",66:"r+",129:"rx+",193:"rx+",514:"w+",577:"w",578:"w+",705:"wx",706:"wx+",1024:"a",1025:"a",1026:"a+",1089:"a",1090:"a+",1153:"ax",1154:"ax+",1217:"ax",1218:"ax+",4096:"rs",4098:"rs+"},this.nodefs=r,this.FS=t,this.PATH=e,this.ERRNO_CODES=n,this.node_ops=new $(this),this.stream_ops=new Q(this)};tt.prototype.mount=function(t){return this.createNode(null,"/",this.getMode(t.opts.root),0)},tt.prototype.createNode=function(t,e,n,r){var i=this.FS;if(!i.isDir(n)&&!i.isFile(n)&&!i.isLink(n))throw new i.ErrnoError(this.ERRNO_CODES.EINVAL);var o=i.createNode(t,e,n);return o.node_ops=this.node_ops,o.stream_ops=this.stream_ops,o},tt.prototype.getMode=function(t){var e;try{e=this.nodefs.lstatSync(t)}catch(t){if(!t.code)throw t;throw new this.FS.ErrnoError(this.ERRNO_CODES[t.code])}return e.mode},tt.prototype.realPath=function(t){for(var e=[];t.parent!==t;)e.push(t.name),t=t.parent;return e.push(t.mount.opts.root),e.reverse(),this.PATH.join.apply(null,e)},tt.prototype.flagsToPermissionString=function(t){var e="string"==typeof t?parseInt(t,10):t;return(e&=8191)in this.flagsToPermissionStringMap?this.flagsToPermissionStringMap[e]:t},tt.prototype.getNodeFS=function(){return this.nodefs},tt.prototype.getFS=function(){return this.FS},tt.prototype.getPATH=function(){return this.PATH},tt.prototype.getERRNO_CODES=function(){return this.ERRNO_CODES};var et=function(){};et.prototype.supportsLinks=function(){return!1},et.prototype.diskSpace=function(t,e){e(0,0)},et.prototype.openFile=function(t,e,n){throw new h(s.ENOTSUP)},et.prototype.createFile=function(t,e,n,r){throw new h(s.ENOTSUP)},et.prototype.open=function(t,e,n,r){var i=this;this.stat(t,!1,function(o,c){if(o)switch(e.pathNotExistsAction()){case f.CREATE_FILE:return i.stat(a.dirname(t),!1,function(o,s){o?r(o):s&&!s.isDirectory()?r(h.ENOTDIR(a.dirname(t))):i.createFile(t,e,n,r)});case f.THROW_EXCEPTION:return r(h.ENOENT(t));default:return r(new h(s.EINVAL,"Invalid FileFlag object."))}else{if(c&&c.isDirectory())return r(h.EISDIR(t));switch(e.pathExistsAction()){case f.THROW_EXCEPTION:return r(h.EEXIST(t));case f.TRUNCATE_FILE:return i.openFile(t,e,function(t,e){t?r(t):e?e.truncate(0,function(){e.sync(function(){r(null,e)})}):j()});case f.NOP:return i.openFile(t,e,r);default:return r(new h(s.EINVAL,"Invalid FileFlag object."))}}})},et.prototype.rename=function(t,e,n){n(new h(s.ENOTSUP))},et.prototype.renameSync=function(t,e){throw new h(s.ENOTSUP)},et.prototype.stat=function(t,e,n){n(new h(s.ENOTSUP))},et.prototype.statSync=function(t,e){throw new h(s.ENOTSUP)},et.prototype.openFileSync=function(t,e,n){throw new h(s.ENOTSUP)},et.prototype.createFileSync=function(t,e,n){throw new h(s.ENOTSUP)},et.prototype.openSync=function(t,e,n){var r;try{r=this.statSync(t,!1)}catch(r){switch(e.pathNotExistsAction()){case f.CREATE_FILE:if(!this.statSync(a.dirname(t),!1).isDirectory())throw h.ENOTDIR(a.dirname(t));return this.createFileSync(t,e,n);case f.THROW_EXCEPTION:throw h.ENOENT(t);default:throw new h(s.EINVAL,"Invalid FileFlag object.")}}if(r.isDirectory())throw h.EISDIR(t);switch(e.pathExistsAction()){case f.THROW_EXCEPTION:throw h.EEXIST(t);case f.TRUNCATE_FILE:return this.unlinkSync(t),this.createFileSync(t,e,r.mode);case f.NOP:return this.openFileSync(t,e,n);default:throw new h(s.EINVAL,"Invalid FileFlag object.")}},et.prototype.unlink=function(t,e){e(new h(s.ENOTSUP))},et.prototype.unlinkSync=function(t){throw new h(s.ENOTSUP)},et.prototype.rmdir=function(t,e){e(new h(s.ENOTSUP))},et.prototype.rmdirSync=function(t){throw new h(s.ENOTSUP)},et.prototype.mkdir=function(t,e,n){n(new h(s.ENOTSUP))},et.prototype.mkdirSync=function(t,e){throw new h(s.ENOTSUP)},et.prototype.readdir=function(t,e){e(new h(s.ENOTSUP))},et.prototype.readdirSync=function(t){throw new h(s.ENOTSUP)},et.prototype.exists=function(t,e){this.stat(t,null,function(t){e(!t)})},et.prototype.existsSync=function(t){try{return this.statSync(t,!0),!0}catch(t){return!1}},et.prototype.realpath=function(t,e,n){if(this.supportsLinks())for(var r=t.split(a.sep),i=0;ithis._buffer.length){var n=t.alloc(e-this._buffer.length,0);return this.writeSync(n,0,n.length,this._buffer.length),void(this._flag.isSynchronous()&&A.getRootFS().supportsSynch()&&this.syncSync())}this._stat.size=e;var r=t.alloc(e);this._buffer.copy(r,0,0,e),this._buffer=r,this._flag.isSynchronous()&&A.getRootFS().supportsSynch()&&this.syncSync()},n.prototype.write=function(t,e,n,r,i){try{i(null,this.writeSync(t,e,n,r),t)}catch(t){i(t)}},n.prototype.writeSync=function(e,n,r,i){if(this._dirty=!0,void 0!==i&&null!==i||(i=this.getPos()),!this._flag.isWriteable())throw new h(s.EPERM,"File not opened with a writeable mode.");var o=i+r;if(o>this._stat.size&&(this._stat.size=o,o>this._buffer.length)){var a=t.alloc(o);this._buffer.copy(a),this._buffer=a}var c=e.copy(this._buffer,i,n,n+r);return this._stat.mtimeMs=Date.now(),this._flag.isSynchronous()?(this.syncSync(),c):(this.setPos(i+c),c)},n.prototype.read=function(t,e,n,r,i){try{i(null,this.readSync(t,e,n,r),t)}catch(t){i(t)}},n.prototype.readSync=function(t,e,n,r){if(!this._flag.isReadable())throw new h(s.EPERM,"File not opened with a readable mode.");void 0!==r&&null!==r||(r=this.getPos()),r+n>this._stat.size&&(n=this._stat.size-r);var i=this._buffer.copy(t,e,r,r+n);return this._stat.atimeMs=Date.now(),this._pos=r+n,i},n.prototype.chmod=function(t,e){try{this.chmodSync(t),e()}catch(t){e(t)}},n.prototype.chmodSync=function(t){if(!this._fs.supportsProps())throw new h(s.ENOTSUP);this._dirty=!0,this._stat.chmod(t),this.syncSync()},n.prototype.isDirty=function(){return this._dirty},n.prototype.resetDirty=function(){this._dirty=!1},n}(rt),ot=function(t){function e(e,n,r,i,o){t.call(this,e,n,r,i,o)}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e.prototype.sync=function(t){t()},e.prototype.syncSync=function(){},e.prototype.close=function(t){t()},e.prototype.closeSync=function(){},e}(it),st=function(t){function e(e,n,r,i,o){t.call(this,e,n,r,i,o)}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e.prototype.syncSync=function(){this.isDirty()&&(this._fs._syncSync(this),this.resetDirty())},e.prototype.closeSync=function(){this.syncSync()},e}(it),at=function(t){function e(e,n){t.call(this),this._queue=[],this._queueRunning=!1,this._isInitialized=!1,this._initializeCallbacks=[],this._sync=e,this._async=n}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e.Create=function(t,n){try{var r=new e(t.sync,t.async);r._initialize(function(t){t?n(t):n(null,r)})}catch(t){n(t)}},e.isAvailable=function(){return!0},e.prototype.getName=function(){return e.Name},e.prototype._syncSync=function(t){this._sync.writeFileSync(t.getPath(),t.getBuffer(),null,d.getFileFlag("w"),t.getStats().mode),this.enqueueOp({apiMethod:"writeFile",arguments:[t.getPath(),t.getBuffer(),null,t.getFlag(),t.getStats().mode]})},e.prototype.isReadOnly=function(){return!1},e.prototype.supportsSynch=function(){return!0},e.prototype.supportsLinks=function(){return!1},e.prototype.supportsProps=function(){return this._sync.supportsProps()&&this._async.supportsProps()},e.prototype.renameSync=function(t,e){this._sync.renameSync(t,e),this.enqueueOp({apiMethod:"rename",arguments:[t,e]})},e.prototype.statSync=function(t,e){return this._sync.statSync(t,e)},e.prototype.openSync=function(t,e,n){return this._sync.openSync(t,e,n).closeSync(),new st(this,t,e,this._sync.statSync(t,!1),this._sync.readFileSync(t,null,d.getFileFlag("r")))},e.prototype.unlinkSync=function(t){this._sync.unlinkSync(t),this.enqueueOp({apiMethod:"unlink",arguments:[t]})},e.prototype.rmdirSync=function(t){this._sync.rmdirSync(t),this.enqueueOp({apiMethod:"rmdir",arguments:[t]})},e.prototype.mkdirSync=function(t,e){this._sync.mkdirSync(t,e),this.enqueueOp({apiMethod:"mkdir",arguments:[t,e]})},e.prototype.readdirSync=function(t){return this._sync.readdirSync(t)},e.prototype.existsSync=function(t){return this._sync.existsSync(t)},e.prototype.chmodSync=function(t,e,n){this._sync.chmodSync(t,e,n),this.enqueueOp({apiMethod:"chmod",arguments:[t,e,n]})},e.prototype.chownSync=function(t,e,n,r){this._sync.chownSync(t,e,n,r),this.enqueueOp({apiMethod:"chown",arguments:[t,e,n,r]})},e.prototype.utimesSync=function(t,e,n){this._sync.utimesSync(t,e,n),this.enqueueOp({apiMethod:"utimes",arguments:[t,e,n]})},e.prototype._initialize=function(t){var e=this,n=this._initializeCallbacks;if(this._isInitialized)t();else if(1===n.push(t)){var r=function(t,n,r){"/"!==t&&e._sync.mkdirSync(t,n),e._async.readdir(t,function(e,n){var o=0;e?r(e):function e(s){s?r(s):o0){var r=e._queue.shift(),i=r.arguments;i.push(n),e._async[r.apiMethod].apply(e._async,i)}else e._queueRunning=!1};n()}},e}(nt);at.Name="AsyncMirror",at.Options={sync:{type:"object",description:"The synchronous file system to mirror the asynchronous file system to.",validator:function(t,e){t&&"function"==typeof t.supportsSynch&&t.supportsSynch()?e():e(new h(s.EINVAL,"'sync' option must be a file system that supports synchronous operations"))}},async:{type:"object",description:"The asynchronous file system to mirror."}};var ct=m.Dropbox?m.Dropbox.Dropbox:void 0;function ut(t){return"/"===t?"":t}function ft(t){var e=t.error;if(e[".tag"])return e;if(e.error){var n=e.error;return n[".tag"]?n:n.reason&&n.reason[".tag"]?n.reason:n}if("string"==typeof e)try{var r=JSON.parse(e);if(r.error&&r.error.reason&&r.error.reason[".tag"])return r.error.reason}catch(t){}return e}function ht(t){if(t.user_message)return t.user_message.text;if(t.error_summary)return t.error_summary;if("string"==typeof t.error)return t.error;if("object"==typeof t.error)return ht(t.error);throw new Error("Dropbox's servers gave us a garbage error message: "+JSON.stringify(t))}function lt(t,e,n){switch(t[".tag"]){case"malformed_path":return new h(s.EBADF,n,e);case"not_found":return h.ENOENT(e);case"not_file":return h.EISDIR(e);case"not_folder":return h.ENOTDIR(e);case"restricted_content":return h.EPERM(e);case"other":default:return new h(s.EIO,n,e)}}function pt(t,e,n){switch(t[".tag"]){case"malformed_path":case"disallowed_name":return new h(s.EBADF,n,e);case"conflict":case"no_write_permission":case"team_folder":return h.EPERM(e);case"insufficient_space":return new h(s.ENOSPC,n);case"other":default:return new h(s.EIO,n,e)}}function dt(t,e,n){var r={path:ut(e)};t.filesDeleteV2(r).then(function(){n()}).catch(function(r){var i=ft(r);switch(i[".tag"]){case"path_lookup":n(lt(i.path_lookup,e,ht(r)));break;case"path_write":n(pt(i.path_write,e,ht(r)));break;case"too_many_write_operations":setTimeout(function(){return dt(t,e,n)},500+300*Math.random());break;case"other":default:n(new h(s.EIO,ht(r),e))}})}var yt=function(t){function e(e,n,r,i,o){t.call(this,e,n,r,i,o)}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e.prototype.sync=function(t){this._fs._syncFile(this.getPath(),this.getBuffer(),t)},e.prototype.close=function(t){this.sync(t)},e}(it),gt=function(e){function n(t){e.call(this),this._client=t}return e&&(n.__proto__=e),n.prototype=Object.create(e&&e.prototype),n.prototype.constructor=n,n.Create=function(t,e){e(null,new n(t.client))},n.isAvailable=function(){return void 0!==ct},n.prototype.getName=function(){return n.Name},n.prototype.isReadOnly=function(){return!1},n.prototype.supportsSymlinks=function(){return!1},n.prototype.supportsProps=function(){return!1},n.prototype.supportsSynch=function(){return!1},n.prototype.empty=function(t){var e=this;this.readdir("/",function(n,r){if(r){var i=function(n){0===r.length?t():dt(e._client,r.shift(),i)};i()}else t(n)})},n.prototype.rename=function(t,e,n){var r=this;this.stat(e,!1,function(i,o){var a=function(){var i={from_path:ut(t),to_path:ut(e)};r._client.filesMoveV2(i).then(function(){return n()}).catch(function(r){var i=ft(r);switch(i[".tag"]){case"from_lookup":n(lt(i.from_lookup,t,ht(r)));break;case"from_write":n(pt(i.from_write,t,ht(r)));break;case"to":n(pt(i.to,e,ht(r)));break;case"cant_copy_shared_folder":case"cant_nest_shared_folder":n(new h(s.EPERM,ht(r),t));break;case"cant_move_folder_into_itself":case"duplicated_or_nested_paths":n(new h(s.EBADF,ht(r),t));break;case"too_many_files":n(new h(s.ENOSPC,ht(r),t));break;case"other":default:n(new h(s.EIO,ht(r),t))}})};i?a():t===e?i?n(h.ENOENT(e)):n():o&&o.isDirectory()?n(h.EISDIR(e)):r.unlink(e,function(t){t?n(t):a()})})},n.prototype.stat=function(t,e,n){if("/"!==t){var r={path:ut(t)};this._client.filesGetMetadata(r).then(function(e){switch(e[".tag"]){case"file":var r=e;n(null,new y(p.FILE,r.size));break;case"folder":n(null,new y(p.DIRECTORY,4096));break;case"deleted":n(h.ENOENT(t))}}).catch(function(e){var r=ft(e);switch(r[".tag"]){case"path":n(lt(r.path,t,ht(e)));break;default:n(new h(s.EIO,ht(e),t))}})}else E(function(){n(null,new y(p.DIRECTORY,4096))})},n.prototype.openFile=function(t,e,n){var r=this,i={path:ut(t)};this._client.filesDownload(i).then(function(i){var o=i.fileBlob,s=new FileReader;s.onload=function(){var i=s.result;n(null,new yt(r,t,e,new y(p.FILE,i.byteLength),V(i)))},s.readAsArrayBuffer(o)}).catch(function(e){var r=ft(e);switch(r[".tag"]){case"path":n(lt(r.path,t,ht(e)));break;case"other":default:n(new h(s.EIO,ht(e),t))}})},n.prototype.createFile=function(e,n,r,i){var o=this,a=t.alloc(0),c={contents:new Blob([z(a)],{type:"octet/stream"}),path:ut(e)};this._client.filesUpload(c).then(function(t){i(null,new yt(o,e,n,new y(p.FILE,0),a))}).catch(function(t){var a=ft(t);switch(a[".tag"]){case"path":i(pt(a.path.reason,e,ht(t)));break;case"too_many_write_operations":setTimeout(function(){return o.createFile(e,n,r,i)},500+300*Math.random());break;case"other":default:i(new h(s.EIO,ht(t),e))}})},n.prototype.unlink=function(t,e){var n=this;this.stat(t,!1,function(r,i){i?i.isDirectory()?e(h.EISDIR(t)):dt(n._client,t,e):e(r)})},n.prototype.rmdir=function(t,e){var n=this;this.readdir(t,function(r,i){i?i.length>0?e(h.ENOTEMPTY(t)):dt(n._client,t,e):e(r)})},n.prototype.mkdir=function(t,e,n){var r=this,i=a.dirname(t);this.stat(i,!1,function(o,s){if(o)n(o);else if(s&&!s.isDirectory())n(h.ENOTDIR(i));else{var a={path:ut(t)};r._client.filesCreateFolderV2(a).then(function(){return n()}).catch(function(i){"too_many_write_operations"===ft(i)[".tag"]?setTimeout(function(){return r.mkdir(t,e,n)},500+300*Math.random()):n(pt(ft(i).path,t,ht(i)))})}})},n.prototype.readdir=function(t,e){var n=this,r={path:ut(t)};this._client.filesListFolder(r).then(function(r){!function t(e,n,r,i,o){var s=r.entries.map(function(t){return t.path_display}).filter(function(t){return!!t});var a=i.concat(s);if(r.has_more){var c={cursor:r.cursor};e.filesListFolderContinue(c).then(function(r){t(e,n,r,a,o)}).catch(function(t){_t(t,n,o)})}else o(null,a)}(n._client,t,r,[],e)}).catch(function(n){_t(n,t,e)})},n.prototype._syncFile=function(t,e,n){var r=this,i={contents:new Blob([z(e)],{type:"octet/stream"}),path:ut(t),mode:{".tag":"overwrite"}};this._client.filesUpload(i).then(function(){n()}).catch(function(i){var o=ft(i);switch(o[".tag"]){case"path":n(pt(o.path.reason,t,ht(i)));break;case"too_many_write_operations":setTimeout(function(){return r._syncFile(t,e,n)},500+300*Math.random());break;case"other":default:n(new h(s.EIO,ht(i),t))}})},n}(et);function _t(t,e,n){var r=ft(t);switch(r[".tag"]){case"path":n(lt(r.path,e,ht(t)));break;case"other":default:n(new h(s.EIO,ht(t),e))}}function mt(t,e){void 0===e&&(e="");for(var n=t.errno,r=t.node,i=[];r&&(i.unshift(r.name),r!==r.parent);)r=r.parent;return new h(n,u[n],i.length>0?"/"+i.join("/"):e)}gt.Name="DropboxV2",gt.Options={client:{type:"object",description:"An *authenticated* Dropbox client. Must be from the 2.5.x JS SDK."}};var wt=function(t){function e(e,n,r,i){t.call(this),this._fs=e,this._FS=n,this._path=r,this._stream=i}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e.prototype.getPos=function(){},e.prototype.close=function(t){var e=null;try{this.closeSync()}catch(t){e=t}finally{t(e)}},e.prototype.closeSync=function(){try{this._FS.close(this._stream)}catch(t){throw mt(t,this._path)}},e.prototype.stat=function(t){try{t(null,this.statSync())}catch(e){t(e)}},e.prototype.statSync=function(){try{return this._fs.statSync(this._path,!1)}catch(t){throw mt(t,this._path)}},e.prototype.truncate=function(t,e){var n=null;try{this.truncateSync(t)}catch(t){n=t}finally{e(n)}},e.prototype.truncateSync=function(t){try{this._FS.ftruncate(this._stream.fd,t)}catch(t){throw mt(t,this._path)}},e.prototype.write=function(t,e,n,r,i){try{i(null,this.writeSync(t,e,n,r),t)}catch(t){i(t)}},e.prototype.writeSync=function(t,e,n,r){try{var i=q(t),o=null===r?void 0:r;return this._FS.write(this._stream,i,e,n,o)}catch(t){throw mt(t,this._path)}},e.prototype.read=function(t,e,n,r,i){try{i(null,this.readSync(t,e,n,r),t)}catch(t){i(t)}},e.prototype.readSync=function(t,e,n,r){try{var i=q(t),o=null===r?void 0:r;return this._FS.read(this._stream,i,e,n,o)}catch(t){throw mt(t,this._path)}},e.prototype.sync=function(t){t()},e.prototype.syncSync=function(){},e.prototype.chown=function(t,e,n){var r=null;try{this.chownSync(t,e)}catch(t){r=t}finally{n(r)}},e.prototype.chownSync=function(t,e){try{this._FS.fchown(this._stream.fd,t,e)}catch(t){throw mt(t,this._path)}},e.prototype.chmod=function(t,e){var n=null;try{this.chmodSync(t)}catch(t){n=t}finally{e(n)}},e.prototype.chmodSync=function(t){try{this._FS.fchmod(this._stream.fd,t)}catch(t){throw mt(t,this._path)}},e.prototype.utimes=function(t,e,n){var r=null;try{this.utimesSync(t,e)}catch(t){r=t}finally{n(r)}},e.prototype.utimesSync=function(t,e){this._fs.utimesSync(this._path,t,e)},e}(rt),vt=function(e){function n(t){e.call(this),this._FS=t}return e&&(n.__proto__=e),n.prototype=Object.create(e&&e.prototype),n.prototype.constructor=n,n.Create=function(t,e){e(null,new n(t.FS))},n.isAvailable=function(){return!0},n.prototype.getName=function(){return this._FS.DB_NAME()},n.prototype.isReadOnly=function(){return!1},n.prototype.supportsLinks=function(){return!0},n.prototype.supportsProps=function(){return!0},n.prototype.supportsSynch=function(){return!0},n.prototype.renameSync=function(t,e){try{this._FS.rename(t,e)}catch(n){throw n.errno===s.ENOENT?mt(n,this.existsSync(t)?e:t):mt(n)}},n.prototype.statSync=function(t,e){try{var n=e?this._FS.lstat(t):this._FS.stat(t),r=this.modeToFileType(n.mode);return new y(r,n.size,n.mode,n.atime.getTime(),n.mtime.getTime(),n.ctime.getTime())}catch(e){throw mt(e,t)}},n.prototype.openSync=function(t,e,n){try{var r=this._FS.open(t,e.getFlagString(),n);if(this._FS.isDir(r.node.mode))throw this._FS.close(r),h.EISDIR(t);return new wt(this,this._FS,t,r)}catch(e){throw mt(e,t)}},n.prototype.unlinkSync=function(t){try{this._FS.unlink(t)}catch(e){throw mt(e,t)}},n.prototype.rmdirSync=function(t){try{this._FS.rmdir(t)}catch(e){throw mt(e,t)}},n.prototype.mkdirSync=function(t,e){try{this._FS.mkdir(t,e)}catch(e){throw mt(e,t)}},n.prototype.readdirSync=function(t){try{return this._FS.readdir(t).filter(function(t){return"."!==t&&".."!==t})}catch(e){throw mt(e,t)}},n.prototype.truncateSync=function(t,e){try{this._FS.truncate(t,e)}catch(e){throw mt(e,t)}},n.prototype.readFileSync=function(t,e,n){try{var r=H(this._FS.readFile(t,{flags:n.getFlagString()}));return e?r.toString(e):r}catch(e){throw mt(e,t)}},n.prototype.writeFileSync=function(e,n,r,i,o){try{r&&(n=t.from(n,r));var s=q(n);this._FS.writeFile(e,s,{flags:i.getFlagString(),encoding:"binary"}),this._FS.chmod(e,o)}catch(t){throw mt(t,e)}},n.prototype.chmodSync=function(t,e,n){try{e?this._FS.lchmod(t,n):this._FS.chmod(t,n)}catch(e){throw mt(e,t)}},n.prototype.chownSync=function(t,e,n,r){try{e?this._FS.lchown(t,n,r):this._FS.chown(t,n,r)}catch(e){throw mt(e,t)}},n.prototype.symlinkSync=function(t,e,n){try{this._FS.symlink(t,e)}catch(t){throw mt(t)}},n.prototype.readlinkSync=function(t){try{return this._FS.readlink(t)}catch(e){throw mt(e,t)}},n.prototype.utimesSync=function(t,e,n){try{this._FS.utime(t,e.getTime(),n.getTime())}catch(e){throw mt(e,t)}},n.prototype.modeToFileType=function(t){if(this._FS.isDir(t))return p.DIRECTORY;if(this._FS.isFile(t))return p.FILE;if(this._FS.isLink(t))return p.SYMLINK;throw h.EPERM("Invalid mode: "+t)},n}(nt);vt.Name="EmscriptenFileSystem",vt.Options={FS:{type:"object",description:"The Emscripten file system to use (the `FS` variable)"}};var bt=function(t){function e(e,n){t.call(this),this._folder=e,this._wrapped=n}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e.Create=function(t,n){var r=new e(t.folder,t.wrapped);r._initialize(function(t){t?n(t):n(null,r)})},e.isAvailable=function(){return!0},e.prototype.getName=function(){return this._wrapped.getName()},e.prototype.isReadOnly=function(){return this._wrapped.isReadOnly()},e.prototype.supportsProps=function(){return this._wrapped.supportsProps()},e.prototype.supportsSynch=function(){return this._wrapped.supportsSynch()},e.prototype.supportsLinks=function(){return!1},e.prototype._initialize=function(t){var e=this;this._wrapped.exists(this._folder,function(n){n?t():e._wrapped.isReadOnly()?t(h.ENOENT(e._folder)):e._wrapped.mkdir(e._folder,511,t)})},e}(et);function St(t,e){if(null!==e&&"object"==typeof e){var n=e,r=n.path;r&&(r="/"+a.relative(t,r),n.message=n.message.replace(n.path,r),n.path=r)}return e}function Et(t,e,n){return"Sync"!==t.slice(t.length-4)?function(){return arguments.length>0&&(e&&(arguments[0]=a.join(this._folder,arguments[0])),n&&(arguments[1]=a.join(this._folder,arguments[1])),arguments[arguments.length-1]=function(t,e){return"function"==typeof e?function(n){arguments.length>0&&(arguments[0]=St(t,n)),e.apply(null,arguments)}:e}(this._folder,arguments[arguments.length-1])),this._wrapped[t].apply(this._wrapped,arguments)}:function(){try{return e&&(arguments[0]=a.join(this._folder,arguments[0])),n&&(arguments[1]=a.join(this._folder,arguments[1])),this._wrapped[t].apply(this._wrapped,arguments)}catch(t){throw St(this._folder,t)}}}function kt(t,e){e|=0;for(var n=Math.max(t.length-e,0),r=Array(n),i=0;i-1&&t%1==0&&t<=Qt}function te(t){return null!=t&&$t(t.length)&&!function(t){if(!Ot(t))return!1;var e=Yt(t);return e==Kt||e==Jt||e==Xt||e==Gt}(t)}var ee={};function ne(){}function re(t){return function(){if(null!==t){var e=t;t=null,e.apply(this,arguments)}}}var ie="function"==typeof Symbol&&Symbol.iterator;function oe(t){return null!=t&&"object"==typeof t}var se="[object Arguments]";function ae(t){return oe(t)&&Yt(t)==se}var ce=Object.prototype,ue=ce.hasOwnProperty,fe=ce.propertyIsEnumerable,he=ae(function(){return arguments}())?ae:function(t){return oe(t)&&ue.call(t,"callee")&&!fe.call(t,"callee")},le=Array.isArray;var pe="object"==typeof e&&e&&!e.nodeType&&e,de=pe&&"object"==typeof o&&o&&!o.nodeType&&o,ye=de&&de.exports===pe?Mt.Buffer:void 0,ge=(ye?ye.isBuffer:void 0)||function(){return!1},_e=9007199254740991,me=/^(?:0|[1-9]\d*)$/;function we(t,e){var n=typeof t;return!!(e=null==e?_e:e)&&("number"==n||"symbol"!=n&&me.test(t))&&t>-1&&t%1==0&&t0?e(h.ENOTEMPTY(t)):n._remove(t,e,!1)})},e.prototype.mkdir=function(t,e,n){this.fs.root.getDirectory(t,{create:!0,exclusive:!0},function(t){n()},function(e){n(ze(e,t,!0))})},e.prototype.readdir=function(t,e){this._readdir(t,function(t,n){if(!n)return e(t);for(var r=[],i=0,o=n;i=this.limit&&(delete this.map[this.tail.key],this.size--,this.tail=this.tail.prev,this.tail.next=null),this.setHead(n)},Ge.prototype.get=function(t){if(this.map[t]){var e=this.map[t].value,n=new Je(t,e);return this.remove(t),this.setHead(n),e}return null},Ge.prototype.remove=function(t){var e=this.map[t];e&&(null!==e.prev?e.prev.next=e.next:this.head=e.next,null!==e.next?e.next.prev=e.prev:this.tail=e.prev,delete this.map[t],this.size--)},Ge.prototype.removeAll=function(){this.size=0,this.map={},this.head=null,this.tail=null},Ge.prototype.setHead=function(t){t.next=this.head,t.prev=null,null!==this.head&&(this.head.prev=t),this.head=t,null===this.tail&&(this.tail=t),this.size++,this.map[t.key]=t};var Qe=function(t){this.store=t,this.originalData={},this.modifiedKeys=[]};Qe.prototype.get=function(t){var e=this.store.get(t);return this.stashOldValue(t,e),e},Qe.prototype.put=function(t,e,n){return this.markModified(t),this.store.put(t,e,n)},Qe.prototype.del=function(t){this.markModified(t),this.store.del(t)},Qe.prototype.commit=function(){},Qe.prototype.abort=function(){for(var t=0,e=this.modifiedKeys;t0)throw h.ENOTEMPTY(t);this.removeEntry(t,!0)},n.prototype.mkdirSync=function(e,n){var r=this.store.beginTransaction("readwrite"),i=t.from("{}");this.commitNewFile(r,e,p.DIRECTORY,n,i)},n.prototype.readdirSync=function(t){var e=this.store.beginTransaction("readonly");return Object.keys(this.getDirListing(e,t,this.findINode(e,t)))},n.prototype._syncSync=function(t,e,n){var r=this.store.beginTransaction("readwrite"),i=this._findINode(r,a.dirname(t),a.basename(t)),o=this.getINode(r,t,i),s=o.update(n);try{r.put(o.id,e,!0),s&&r.put(i,o.toBuffer(),!0)}catch(t){throw r.abort(),t}r.commit()},n.prototype.makeRootDirectory=function(){var t=this.store.beginTransaction("readwrite");if(void 0===t.get("/")){var e=(new Date).getTime(),n=new He(Ye(),4096,511|p.DIRECTORY,e,e,e);t.put(n.id,Ze(),!1),t.put("/",n.toBuffer(),!1),t.commit()}},n.prototype._findINode=function(t,e,n){var r=this,i=function(i){var o=r.getDirListing(t,e,i);if(o[n])return o[n];throw h.ENOENT(a.resolve(e,n))};return"/"===e?""===n?"/":i(this.getINode(t,e,"/")):i(this.getINode(t,e+a.sep+n,this._findINode(t,a.dirname(e),a.basename(e))))},n.prototype.findINode=function(t,e){return this.getINode(t,e,this._findINode(t,a.dirname(e),a.basename(e)))},n.prototype.getINode=function(t,e,n){var r=t.get(n);if(void 0===r)throw h.ENOENT(e);return He.fromBuffer(r)},n.prototype.getDirListing=function(t,e,n){if(!n.isDirectory())throw h.ENOTDIR(e);var r=t.get(n.id);if(void 0===r)throw h.ENOENT(e);return JSON.parse(r.toString())},n.prototype.addNewNode=function(t,e){for(var n;;)try{return n=Ye(),t.put(n,e,!1),n}catch(t){}throw new h(s.EIO,"Unable to commit data to key-value store.")},n.prototype.commitNewFile=function(e,n,r,i,o){var s,c=a.dirname(n),u=a.basename(n),f=this.findINode(e,c),l=this.getDirListing(e,c,f),p=(new Date).getTime();if("/"===n)throw h.EEXIST(n);if(l[u])throw h.EEXIST(n);try{var d=this.addNewNode(e,o);s=new He(d,o.length,i|r,p,p,p);var y=this.addNewNode(e,s.toBuffer());l[u]=y,e.put(f.id,t.from(JSON.stringify(l)),!0)}catch(t){throw e.abort(),t}return e.commit(),s},n.prototype.removeEntry=function(e,n){var r=this.store.beginTransaction("readwrite"),i=a.dirname(e),o=this.findINode(r,i),s=this.getDirListing(r,i,o),c=a.basename(e);if(!s[c])throw h.ENOENT(e);var u=s[c];delete s[c];var f=this.getINode(r,e,u);if(!n&&f.isDirectory())throw h.EISDIR(e);if(n&&!f.isDirectory())throw h.ENOTDIR(e);try{r.del(f.id),r.del(u),r.put(o.id,t.from(JSON.stringify(s)),!0)}catch(t){throw r.abort(),t}r.commit()},n}(nt),en=function(t){function e(e,n,r,i,o){t.call(this,e,n,r,i,o)}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e.prototype.sync=function(t){var e=this;this.isDirty()?this._fs._sync(this.getPath(),this.getBuffer(),this.getStats(),function(n){n||e.resetDirty(),t(n)}):t()},e.prototype.close=function(t){this.sync(t)},e}(it),nn=function(e){function n(t){e.call(this),this._cache=null,t>0&&(this._cache=new Ge(t))}return e&&(n.__proto__=e),n.prototype=Object.create(e&&e.prototype),n.prototype.constructor=n,n.isAvailable=function(){return!0},n.prototype.init=function(t,e){this.store=t,this.makeRootDirectory(e)},n.prototype.getName=function(){return this.store.name()},n.prototype.isReadOnly=function(){return!1},n.prototype.supportsSymlinks=function(){return!1},n.prototype.supportsProps=function(){return!1},n.prototype.supportsSynch=function(){return!1},n.prototype.empty=function(t){var e=this;this._cache&&this._cache.removeAll(),this.store.clear(function(n){Xe(n,t)&&e.makeRootDirectory(t)})},n.prototype.rename=function(e,n,r){var i=this;if(this._cache){var o=this._cache;this._cache=null,o.removeAll();var c=r;r=function(t){i._cache=o,c(t)}}var u=this.store.beginTransaction("readwrite"),f=a.dirname(e),l=a.basename(e),p=a.dirname(n),d=a.basename(n),y={},g={},_=!1;if(0===(p+"/").indexOf(e+"/"))return r(new h(s.EBUSY,f));var m=function(o){i.findINodeAndDirListing(u,o,function(s,a,c){s?_||(_=!0,u.abort(function(){r(s)})):(y[o]=a,g[o]=c,function(){if(!_&&g.hasOwnProperty(f)&&g.hasOwnProperty(p)){var o=g[f],s=y[f],a=g[p],c=y[p];if(o[l]){var m=o[l];delete o[l];var w=function(){a[d]=m,u.put(s.id,t.from(JSON.stringify(o)),!0,function(e){Ke(e,u,r)&&(f===p?u.commit(r):u.put(c.id,t.from(JSON.stringify(a)),!0,function(t){Ke(t,u,r)&&u.commit(r)}))})};a[d]?i.getINode(u,n,a[d],function(t,e){Ke(t,u,r)&&(e.isFile()?u.del(e.id,function(t){Ke(t,u,r)&&u.del(a[d],function(t){Ke(t,u,r)&&w()})}):u.abort(function(t){r(h.EPERM(n))}))}):w()}else r(h.ENOENT(e))}}())})};m(f),f!==p&&m(p)},n.prototype.stat=function(t,e,n){var r=this.store.beginTransaction("readonly");this.findINode(r,t,function(t,e){Xe(t,n)&&n(null,e.toStats())})},n.prototype.createFile=function(t,e,n,r){var i=this,o=this.store.beginTransaction("readwrite"),s=X();this.commitNewFile(o,t,p.FILE,n,s,function(n,o){Xe(n,r)&&r(null,new en(i,t,e,o.toStats(),s))})},n.prototype.openFile=function(t,e,n){var r=this,i=this.store.beginTransaction("readonly");this.findINode(i,t,function(o,s){Xe(o,n)&&i.get(s.id,function(i,o){Xe(i,n)&&(void 0===o?n(h.ENOENT(t)):n(null,new en(r,t,e,s.toStats(),o)))})})},n.prototype.unlink=function(t,e){this.removeEntry(t,!1,e)},n.prototype.rmdir=function(t,e){var n=this;this.readdir(t,function(r,i){r?e(r):i.length>0?e(h.ENOTEMPTY(t)):n.removeEntry(t,!0,e)})},n.prototype.mkdir=function(e,n,r){var i=this.store.beginTransaction("readwrite"),o=t.from("{}");this.commitNewFile(i,e,p.DIRECTORY,n,o,r)},n.prototype.readdir=function(t,e){var n=this,r=this.store.beginTransaction("readonly");this.findINode(r,t,function(i,o){Xe(i,e)&&n.getDirListing(r,t,o,function(t,n){Xe(t,e)&&e(null,Object.keys(n))})})},n.prototype._sync=function(t,e,n,r){var i=this,o=this.store.beginTransaction("readwrite");this._findINode(o,a.dirname(t),a.basename(t),function(s,a){Ke(s,o,r)&&i.getINode(o,t,a,function(t,i){if(Ke(t,o,r)){var s=i.update(n);o.put(i.id,e,!0,function(t){Ke(t,o,r)&&(s?o.put(a,i.toBuffer(),!0,function(t){Ke(t,o,r)&&o.commit(r)}):o.commit(r))})}})})},n.prototype.makeRootDirectory=function(t){var e=this.store.beginTransaction("readwrite");e.get("/",function(n,r){if(n||void 0===r){var i=(new Date).getTime(),o=new He(Ye(),4096,511|p.DIRECTORY,i,i,i);e.put(o.id,Ze(),!1,function(n){Ke(n,e,t)&&e.put("/",o.toBuffer(),!1,function(n){n?e.abort(function(){t(n)}):e.commit(t)})})}else e.commit(t)})},n.prototype._findINode=function(t,e,n,r){var i=this;if(this._cache){var o=this._cache.get(a.join(e,n));if(o)return r(null,o)}var s=function(t,o,s){if(t)r(t);else if(s[n]){var c=s[n];i._cache&&i._cache.set(a.join(e,n),c),r(null,c)}else r(h.ENOENT(a.resolve(e,n)))};"/"===e?""===n?(this._cache&&this._cache.set(a.join(e,n),"/"),r(null,"/")):this.getINode(t,e,"/",function(n,o){Xe(n,r)&&i.getDirListing(t,e,o,function(t,e){s(t,0,e)})}):this.findINodeAndDirListing(t,e,s)},n.prototype.findINode=function(t,e,n){var r=this;this._findINode(t,a.dirname(e),a.basename(e),function(i,o){Xe(i,n)&&r.getINode(t,e,o,n)})},n.prototype.getINode=function(t,e,n,r){t.get(n,function(t,n){Xe(t,r)&&(void 0===n?r(h.ENOENT(e)):r(null,He.fromBuffer(n)))})},n.prototype.getDirListing=function(t,e,n,r){n.isDirectory()?t.get(n.id,function(t,n){if(Xe(t,r))try{r(null,JSON.parse(n.toString()))}catch(t){r(h.ENOENT(e))}}):r(h.ENOTDIR(e))},n.prototype.findINodeAndDirListing=function(t,e,n){var r=this;this.findINode(t,e,function(i,o){Xe(i,n)&&r.getDirListing(t,e,o,function(t,e){Xe(t,n)&&n(null,o,e)})})},n.prototype.addNewNode=function(t,e,n){var r,i=0,o=function(){5==++i?n(new h(s.EIO,"Unable to commit data to key-value store.")):(r=Ye(),t.put(r,e,!1,function(t,e){t||!e?o():n(null,r)}))};o()},n.prototype.commitNewFile=function(e,n,r,i,o,s){var c=this,u=a.dirname(n),f=a.basename(n),l=(new Date).getTime();if("/"===n)return s(h.EEXIST(n));this.findINodeAndDirListing(e,u,function(a,u,p){Ke(a,e,s)&&(p[f]?e.abort(function(){s(h.EEXIST(n))}):c.addNewNode(e,o,function(n,a){if(Ke(n,e,s)){var h=new He(a,o.length,i|r,l,l,l);c.addNewNode(e,h.toBuffer(),function(n,r){Ke(n,e,s)&&(p[f]=r,e.put(u.id,t.from(JSON.stringify(p)),!0,function(t){Ke(t,e,s)&&e.commit(function(t){Ke(t,e,s)&&s(null,h)})}))})}}))})},n.prototype.removeEntry=function(e,n,r){var i=this;this._cache&&this._cache.remove(e);var o=this.store.beginTransaction("readwrite"),s=a.dirname(e),c=a.basename(e);this.findINodeAndDirListing(o,s,function(s,a,u){if(Ke(s,o,r))if(u[c]){var f=u[c];delete u[c],i.getINode(o,e,f,function(i,s){Ke(i,o,r)&&(!n&&s.isDirectory()?o.abort(function(){r(h.EISDIR(e))}):n&&!s.isDirectory()?o.abort(function(){r(h.ENOTDIR(e))}):o.del(s.id,function(e){Ke(e,o,r)&&o.del(f,function(e){Ke(e,o,r)&&o.put(a.id,t.from(JSON.stringify(u)),!0,function(t){Ke(t,o,r)&&o.commit(r)})})}))})}else o.abort(function(){r(h.ENOENT(e))})})},n}(et),rn=function(){this.store={}};rn.prototype.name=function(){return on.Name},rn.prototype.clear=function(){this.store={}},rn.prototype.beginTransaction=function(t){return new Qe(this)},rn.prototype.get=function(t){return this.store[t]},rn.prototype.put=function(t,e,n){return!(!n&&this.store.hasOwnProperty(t))&&(this.store[t]=e,!0)},rn.prototype.del=function(t){delete this.store[t]};var on=function(t){function e(){t.call(this,{store:new rn})}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e.Create=function(t,n){n(null,new e)},e}(tn);on.Name="InMemory",on.Options={};var sn=function(){try{return m.indexedDB||m.mozIndexedDB||m.webkitIndexedDB||m.msIndexedDB}catch(t){return null}}();function an(t,e){switch(void 0===e&&(e=t.toString()),t.name){case"NotFoundError":return new h(s.ENOENT,e);case"QuotaExceededError":return new h(s.ENOSPC,e);default:return new h(s.EIO,e)}}function cn(t,e,n){return void 0===e&&(e=s.EIO),void 0===n&&(n=null),function(r){r.preventDefault(),t(new h(e,null!==n?n:void 0))}}var un=function(t,e){this.tx=t,this.store=e};un.prototype.get=function(t,e){try{var n=this.store.get(t);n.onerror=cn(e),n.onsuccess=function(t){var n=t.target.result;e(null,void 0===n?n:V(n))}}catch(t){e(an(t))}};var fn=function(t){function e(e,n){t.call(this,e,n)}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e.prototype.put=function(t,e,n,r){try{var i,o=z(e);(i=n?this.store.put(o,t):this.store.add(o,t)).onerror=cn(r),i.onsuccess=function(t){r(null,!0)}}catch(t){r(an(t))}},e.prototype.del=function(t,e){try{var n=this.store.delete(t);n.onerror=cn(e),n.onsuccess=function(t){e()}}catch(t){e(an(t))}},e.prototype.commit=function(t){setTimeout(t,0)},e.prototype.abort=function(t){var e=null;try{this.tx.abort()}catch(t){e=an(t)}finally{t(e)}},e}(un),hn=function(t,e){this.db=t,this.storeName=e};hn.Create=function(t,e){var n=sn.open(t,1);n.onupgradeneeded=function(e){var n=e.target.result;n.objectStoreNames.contains(t)&&n.deleteObjectStore(t),n.createObjectStore(t)},n.onsuccess=function(n){e(null,new hn(n.target.result,t))},n.onerror=cn(e,s.EACCES)},hn.prototype.name=function(){return ln.Name+" - "+this.storeName},hn.prototype.clear=function(t){try{var e=this.db.transaction(this.storeName,"readwrite").objectStore(this.storeName).clear();e.onsuccess=function(e){setTimeout(t,0)},e.onerror=cn(t)}catch(e){t(an(e))}},hn.prototype.beginTransaction=function(t){void 0===t&&(t="readonly");var e=this.db.transaction(this.storeName,t),n=e.objectStore(this.storeName);if("readwrite"===t)return new fn(e,n);if("readonly"===t)return new un(e,n);throw new h(s.EINVAL,"Invalid transaction type.")};var ln=function(t){function e(e){t.call(this,e)}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e.Create=function(t,n){void 0===t&&(t={}),hn.Create(t.storeName?t.storeName:"browserfs",function(r,i){if(i){var o=new e("number"==typeof t.cacheSize?t.cacheSize:100);o.init(i,function(t){t?n(t):n(null,o)})}else n(r)})},e.isAvailable=function(){try{return void 0!==sn&&null!==sn.open("__browserfs_test__")}catch(t){return!1}},e}(nn);ln.Name="IndexedDB",ln.Options={storeName:{type:"string",optional:!0,description:"The name of this file system. You can have multiple IndexedDB file systems operating at once, but each must have a different name."},cacheSize:{type:"number",optional:!0,description:"The size of the inode cache. Defaults to 100. A size of 0 or below disables caching."}};var pn,dn=!1;try{m.localStorage.setItem("__test__",String.fromCharCode(55296)),dn=m.localStorage.getItem("__test__")===String.fromCharCode(55296)}catch(t){dn=!1}pn=dn?"binary_string":"binary_string_ie",t.isEncoding(pn)||(pn="base64");var yn=function(){};yn.prototype.name=function(){return gn.Name},yn.prototype.clear=function(){m.localStorage.clear()},yn.prototype.beginTransaction=function(t){return new Qe(this)},yn.prototype.get=function(e){try{var n=m.localStorage.getItem(e);if(null!==n)return t.from(n,pn)}catch(t){}},yn.prototype.put=function(t,e,n){try{return!(!n&&null!==m.localStorage.getItem(t))&&(m.localStorage.setItem(t,e.toString(pn)),!0)}catch(t){throw new h(s.ENOSPC,"LocalStorage is full.")}},yn.prototype.del=function(t){try{m.localStorage.removeItem(t)}catch(e){throw new h(s.EIO,"Unable to delete key "+t+": "+e)}};var gn=function(t){function e(){t.call(this,{store:new yn})}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e.Create=function(t,n){n(null,new e)},e.isAvailable=function(){return void 0!==m.localStorage},e}(tn);gn.Name="LocalStorage",gn.Options={};var _n=function(t){function e(e){t.call(this),this.mountList=[],this.mntMap={},this.rootFs=e}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e.Create=function(t,n){on.Create({},function(r,i){if(i){var o=new e(i);try{Object.keys(t).forEach(function(e){o.mount(e,t[e])})}catch(r){return n(r)}n(null,o)}else n(r)})},e.isAvailable=function(){return!0},e.prototype.mount=function(t,e){if("/"!==t[0]&&(t="/"+t),t=a.resolve(t),this.mntMap[t])throw new h(s.EINVAL,"Mount point "+t+" is already taken.");B(t,511,this.rootFs),this.mntMap[t]=e,this.mountList.push(t),this.mountList=this.mountList.sort(function(t,e){return e.length-t.length})},e.prototype.umount=function(t){if("/"!==t[0]&&(t="/"+t),t=a.resolve(t),!this.mntMap[t])throw new h(s.EINVAL,"Mount point "+t+" is already unmounted.");for(delete this.mntMap[t],this.mountList.splice(this.mountList.indexOf(t),1);"/"!==t&&0===this.rootFs.readdirSync(t).length;)this.rootFs.rmdirSync(t),t=a.dirname(t)},e.prototype._getFs=function(t){for(var e=this.mountList,n=e.length,r=0;r1?i.length:0))&&(t="/"),{fs:this.mntMap[i],path:t,mountPoint:i}}return{fs:this.rootFs,path:t,mountPoint:"/"}},e.prototype.getName=function(){return e.Name},e.prototype.diskSpace=function(t,e){e(0,0)},e.prototype.isReadOnly=function(){return!1},e.prototype.supportsLinks=function(){return!1},e.prototype.supportsProps=function(){return!1},e.prototype.supportsSynch=function(){return!0},e.prototype.standardizeError=function(t,e,n){var r=t.message.indexOf(e);return-1!==r&&(t.message=t.message.substr(0,r)+n+t.message.substr(r+e.length),t.path=n),t},e.prototype.rename=function(t,e,n){var r=this,i=this._getFs(t),o=this._getFs(e);return i.fs===o.fs?i.fs.rename(i.path,o.path,function(s){s&&r.standardizeError(r.standardizeError(s,i.path,t),o.path,e),n(s)}):A.readFile(t,function(r,i){if(r)return n(r);A.writeFile(e,i,function(e){if(e)return n(e);A.unlink(t,n)})})},e.prototype.renameSync=function(t,e){var n=this._getFs(t),r=this._getFs(e);if(n.fs===r.fs)try{return n.fs.renameSync(n.path,r.path)}catch(i){throw this.standardizeError(this.standardizeError(i,n.path,t),r.path,e),i}var i=A.readFileSync(t);return A.writeFileSync(e,i),A.unlinkSync(t)},e.prototype.readdirSync=function(t){var e=this._getFs(t),n=null;if(e.fs!==this.rootFs)try{n=this.rootFs.readdirSync(t)}catch(t){}try{var r=e.fs.readdirSync(e.path);return null===n?r:r.concat(n.filter(function(t){return-1===r.indexOf(t)}))}catch(r){if(null===n)throw this.standardizeError(r,e.path,t);return n}},e.prototype.readdir=function(t,e){var n=this,r=this._getFs(t);r.fs.readdir(r.path,function(i,o){if(r.fs!==n.rootFs)try{var s=n.rootFs.readdirSync(t);o=o?o.concat(s.filter(function(t){return-1===o.indexOf(t)})):s}catch(o){if(i)return e(n.standardizeError(i,r.path,t))}else if(i)return e(n.standardizeError(i,r.path,t));e(null,o)})},e.prototype.realpathSync=function(t,e){var n=this._getFs(t);try{var r=n.fs.realpathSync(n.path,{});return a.resolve(a.join(n.mountPoint,r))}catch(e){throw this.standardizeError(e,n.path,t)}},e.prototype.realpath=function(t,e,n){var r=this,i=this._getFs(t);i.fs.realpath(i.path,{},function(e,o){e?n(r.standardizeError(e,i.path,t)):n(null,a.resolve(a.join(i.mountPoint,o)))})},e.prototype.rmdirSync=function(t){var e=this._getFs(t);if(this._containsMountPt(t))throw h.ENOTEMPTY(t);try{e.fs.rmdirSync(e.path)}catch(n){throw this.standardizeError(n,e.path,t)}},e.prototype.rmdir=function(t,e){var n=this,r=this._getFs(t);this._containsMountPt(t)?e(h.ENOTEMPTY(t)):r.fs.rmdir(r.path,function(i){e(i?n.standardizeError(i,r.path,t):null)})},e.prototype._containsMountPt=function(t){for(var e=this.mountList,n=e.length,r=0;r=t.length&&i.slice(0,t.length)===t)return!0}return!1},e}(et);function mn(t,e,n){return e?function(){for(var e=[],n=arguments.length;n--;)e[n]=arguments[n];var r=e[0],i=this._getFs(r);e[0]=i.path;try{return i.fs[t].apply(i.fs,e)}catch(t){throw this.standardizeError(t,i.path,r),t}}:function(){for(var e=this,n=[],r=arguments.length;r--;)n[r]=arguments[r];var i=n[0],o=this._getFs(i);if(n[0]=o.path,"function"==typeof n[n.length-1]){var s=n[n.length-1];n[n.length-1]=function(){for(var t=[],n=arguments.length;n--;)t[n]=arguments[n];t.length>0&&t[0]instanceof h&&e.standardizeError(t[0],o.path,i),s.apply(null,t)}}return o.fs[t].apply(o.fs,n)}}_n.Name="MountableFileSystem",_n.Options={};for(var wn=[["exists","unlink","readlink"],["stat","mkdir","truncate"],["open","readFile","chmod","utimes"],["chown"],["writeFile","appendFile"]],vn=0;vn"},On.prototype.getFSUnlocked=function(){return this._fs},On.prototype.diskSpace=function(t,e){this._fs.diskSpace(t,e)},On.prototype.isReadOnly=function(){return this._fs.isReadOnly()},On.prototype.supportsLinks=function(){return this._fs.supportsLinks()},On.prototype.supportsProps=function(){return this._fs.supportsProps()},On.prototype.supportsSynch=function(){return this._fs.supportsSynch()},On.prototype.rename=function(t,e,n){var r=this;this._mu.lock(function(){r._fs.rename(t,e,function(t){r._mu.unlock(),n(t)})})},On.prototype.renameSync=function(t,e){if(this._mu.isLocked())throw new Error("invalid sync call");return this._fs.renameSync(t,e)},On.prototype.stat=function(t,e,n){var r=this;this._mu.lock(function(){r._fs.stat(t,e,function(t,e){r._mu.unlock(),n(t,e)})})},On.prototype.statSync=function(t,e){if(this._mu.isLocked())throw new Error("invalid sync call");return this._fs.statSync(t,e)},On.prototype.open=function(t,e,n,r){var i=this;this._mu.lock(function(){i._fs.open(t,e,n,function(t,e){i._mu.unlock(),r(t,e)})})},On.prototype.openSync=function(t,e,n){if(this._mu.isLocked())throw new Error("invalid sync call");return this._fs.openSync(t,e,n)},On.prototype.unlink=function(t,e){var n=this;this._mu.lock(function(){n._fs.unlink(t,function(t){n._mu.unlock(),e(t)})})},On.prototype.unlinkSync=function(t){if(this._mu.isLocked())throw new Error("invalid sync call");return this._fs.unlinkSync(t)},On.prototype.rmdir=function(t,e){var n=this;this._mu.lock(function(){n._fs.rmdir(t,function(t){n._mu.unlock(),e(t)})})},On.prototype.rmdirSync=function(t){if(this._mu.isLocked())throw new Error("invalid sync call");return this._fs.rmdirSync(t)},On.prototype.mkdir=function(t,e,n){var r=this;this._mu.lock(function(){r._fs.mkdir(t,e,function(t){r._mu.unlock(),n(t)})})},On.prototype.mkdirSync=function(t,e){if(this._mu.isLocked())throw new Error("invalid sync call");return this._fs.mkdirSync(t,e)},On.prototype.readdir=function(t,e){var n=this;this._mu.lock(function(){n._fs.readdir(t,function(t,r){n._mu.unlock(),e(t,r)})})},On.prototype.readdirSync=function(t){if(this._mu.isLocked())throw new Error("invalid sync call");return this._fs.readdirSync(t)},On.prototype.exists=function(t,e){var n=this;this._mu.lock(function(){n._fs.exists(t,function(t){n._mu.unlock(),e(t)})})},On.prototype.existsSync=function(t){if(this._mu.isLocked())throw new Error("invalid sync call");return this._fs.existsSync(t)},On.prototype.realpath=function(t,e,n){var r=this;this._mu.lock(function(){r._fs.realpath(t,e,function(t,e){r._mu.unlock(),n(t,e)})})},On.prototype.realpathSync=function(t,e){if(this._mu.isLocked())throw new Error("invalid sync call");return this._fs.realpathSync(t,e)},On.prototype.truncate=function(t,e,n){var r=this;this._mu.lock(function(){r._fs.truncate(t,e,function(t){r._mu.unlock(),n(t)})})},On.prototype.truncateSync=function(t,e){if(this._mu.isLocked())throw new Error("invalid sync call");return this._fs.truncateSync(t,e)},On.prototype.readFile=function(t,e,n,r){var i=this;this._mu.lock(function(){i._fs.readFile(t,e,n,function(t,e){i._mu.unlock(),r(t,e)})})},On.prototype.readFileSync=function(t,e,n){if(this._mu.isLocked())throw new Error("invalid sync call");return this._fs.readFileSync(t,e,n)},On.prototype.writeFile=function(t,e,n,r,i,o){var s=this;this._mu.lock(function(){s._fs.writeFile(t,e,n,r,i,function(t){s._mu.unlock(),o(t)})})},On.prototype.writeFileSync=function(t,e,n,r,i){if(this._mu.isLocked())throw new Error("invalid sync call");return this._fs.writeFileSync(t,e,n,r,i)},On.prototype.appendFile=function(t,e,n,r,i,o){var s=this;this._mu.lock(function(){s._fs.appendFile(t,e,n,r,i,function(t){s._mu.unlock(),o(t)})})},On.prototype.appendFileSync=function(t,e,n,r,i){if(this._mu.isLocked())throw new Error("invalid sync call");return this._fs.appendFileSync(t,e,n,r,i)},On.prototype.chmod=function(t,e,n,r){var i=this;this._mu.lock(function(){i._fs.chmod(t,e,n,function(t){i._mu.unlock(),r(t)})})},On.prototype.chmodSync=function(t,e,n){if(this._mu.isLocked())throw new Error("invalid sync call");return this._fs.chmodSync(t,e,n)},On.prototype.chown=function(t,e,n,r,i){var o=this;this._mu.lock(function(){o._fs.chown(t,e,n,r,function(t){o._mu.unlock(),i(t)})})},On.prototype.chownSync=function(t,e,n,r){if(this._mu.isLocked())throw new Error("invalid sync call");return this._fs.chownSync(t,e,n,r)},On.prototype.utimes=function(t,e,n,r){var i=this;this._mu.lock(function(){i._fs.utimes(t,e,n,function(t){i._mu.unlock(),r(t)})})},On.prototype.utimesSync=function(t,e,n){if(this._mu.isLocked())throw new Error("invalid sync call");return this._fs.utimesSync(t,e,n)},On.prototype.link=function(t,e,n){var r=this;this._mu.lock(function(){r._fs.link(t,e,function(t){r._mu.unlock(),n(t)})})},On.prototype.linkSync=function(t,e){if(this._mu.isLocked())throw new Error("invalid sync call");return this._fs.linkSync(t,e)},On.prototype.symlink=function(t,e,n,r){var i=this;this._mu.lock(function(){i._fs.symlink(t,e,n,function(t){i._mu.unlock(),r(t)})})},On.prototype.symlinkSync=function(t,e,n){if(this._mu.isLocked())throw new Error("invalid sync call");return this._fs.symlinkSync(t,e,n)},On.prototype.readlink=function(t,e){var n=this;this._mu.lock(function(){n._fs.readlink(t,function(t,r){n._mu.unlock(),e(t,r)})})},On.prototype.readlinkSync=function(t){if(this._mu.isLocked())throw new Error("invalid sync call");return this._fs.readlinkSync(t)};var In="/.deletedFiles.log";function Fn(t){return 146|t}function Nn(t){return d.getFileFlag(t)}var Tn,Rn=function(t){function e(e,n,r,i,o){t.call(this,e,n,r,i,o)}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e.prototype.sync=function(t){var e=this;this.isDirty()?this._fs._syncAsync(this,function(n){e.resetDirty(),t(n)}):t(null)},e.prototype.syncSync=function(){this.isDirty()&&(this._fs._syncSync(this),this.resetDirty())},e.prototype.close=function(t){this.sync(t)},e.prototype.closeSync=function(){this.syncSync()},e}(it),Ln=function(t){function e(e,n){if(t.call(this),this._isInitialized=!1,this._initializeCallbacks=[],this._deletedFiles={},this._deleteLog="",this._deleteLogUpdatePending=!1,this._deleteLogUpdateNeeded=!1,this._deleteLogError=null,this._writable=e,this._readable=n,this._writable.isReadOnly())throw new h(s.EINVAL,"Writable file system must be writable.")}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e.isAvailable=function(){return!0},e.prototype.getOverlayedFileSystems=function(){return{readable:this._readable,writable:this._writable}},e.prototype._syncAsync=function(t,e){var n=this;this.createParentDirectoriesAsync(t.getPath(),function(r){if(r)return e(r);n._writable.writeFile(t.getPath(),t.getBuffer(),null,Nn("w"),t.getStats().mode,e)})},e.prototype._syncSync=function(t){this.createParentDirectories(t.getPath()),this._writable.writeFileSync(t.getPath(),t.getBuffer(),null,Nn("w"),t.getStats().mode)},e.prototype.getName=function(){return xn.Name},e.prototype._initialize=function(t){var e=this,n=this._initializeCallbacks,r=function(t){e._isInitialized=!t,e._initializeCallbacks=[],n.forEach(function(e){return e(t)})};if(this._isInitialized)return t();n.push(t),1===n.length&&this._writable.readFile(In,"utf8",Nn("r"),function(t,n){if(t){if(t.errno!==s.ENOENT)return r(t)}else e._deleteLog=n;e._reparseDeletionLog(),r()})},e.prototype.isReadOnly=function(){return!1},e.prototype.supportsSynch=function(){return this._readable.supportsSynch()&&this._writable.supportsSynch()},e.prototype.supportsLinks=function(){return!1},e.prototype.supportsProps=function(){return this._readable.supportsProps()&&this._writable.supportsProps()},e.prototype.getDeletionLog=function(){return this._deleteLog},e.prototype.restoreDeletionLog=function(t){this._deleteLog=t,this._reparseDeletionLog(),this.updateLog("")},e.prototype.rename=function(t,e,n){var r=this;if(this.checkInitAsync(n)&&!this.checkPathAsync(t,n)&&!this.checkPathAsync(e,n))return t===In||e===In?n(h.EPERM("Cannot rename deletion log.")):t===e?n():void this.stat(t,!1,function(i,o){return i?n(i):r.stat(e,!1,function(i,c){var u=r;function f(r){var i=r.shift();if(!i)return n();var o=a.resolve(t,i),s=a.resolve(e,i);u.rename(o,s,function(t){if(t)return n(t);f(r)})}var l=511;if(o.isDirectory()){if(i)return i.errno!==s.ENOENT?n(i):r._writable.exists(t,function(i){if(i)return r._writable.rename(t,e,n);r._writable.mkdir(e,l,function(e){if(e)return n(e);r._readable.readdir(t,function(t,e){if(t)return n();f(e)})})});if(l=c.mode,!c.isDirectory())return n(h.ENOTDIR(e));r.readdir(e,function(i,o){if(o&&o.length)return n(h.ENOTEMPTY(e));r._readable.readdir(t,function(t,e){if(t)return n();f(e)})})}if(c&&c.isDirectory())return n(h.EISDIR(e));r.readFile(t,null,Nn("r"),function(i,s){return i?n(i):r.writeFile(e,s,null,Nn("w"),o.mode,function(e){return e?n(e):r.unlink(t,n)})})})})},e.prototype.renameSync=function(t,e){var n=this;if(this.checkInitialized(),this.checkPath(t),this.checkPath(e),t===In||e===In)throw h.EPERM("Cannot rename deletion log.");var r=this.statSync(t,!1);if(r.isDirectory()){if(t===e)return;var i=511;if(this.existsSync(e)){var o=this.statSync(e,!1);if(i=o.mode,!o.isDirectory())throw h.ENOTDIR(e);if(this.readdirSync(e).length>0)throw h.ENOTEMPTY(e)}this._writable.existsSync(t)?this._writable.renameSync(t,e):this._writable.existsSync(e)||this._writable.mkdirSync(e,i),this._readable.existsSync(t)&&this._readable.readdirSync(t).forEach(function(r){n.renameSync(a.resolve(t,r),a.resolve(e,r))})}else{if(this.existsSync(e)&&this.statSync(e,!1).isDirectory())throw h.EISDIR(e);this.writeFileSync(e,this.readFileSync(t,null,Nn("r")),null,Nn("w"),r.mode)}t!==e&&this.existsSync(t)&&this.unlinkSync(t)},e.prototype.stat=function(t,e,n){var r=this;this.checkInitAsync(n)&&this._writable.stat(t,e,function(i,o){i&&i.errno===s.ENOENT?(r._deletedFiles[t]&&n(h.ENOENT(t)),r._readable.stat(t,e,function(t,e){e&&((e=y.clone(e)).mode=Fn(e.mode)),n(t,e)})):n(i,o)})},e.prototype.statSync=function(t,e){this.checkInitialized();try{return this._writable.statSync(t,e)}catch(r){if(this._deletedFiles[t])throw h.ENOENT(t);var n=y.clone(this._readable.statSync(t,e));return n.mode=Fn(n.mode),n}},e.prototype.open=function(t,e,n,r){var i=this;this.checkInitAsync(r)&&!this.checkPathAsync(t,r)&&this.stat(t,!1,function(o,s){if(s)switch(e.pathExistsAction()){case f.TRUNCATE_FILE:return i.createParentDirectoriesAsync(t,function(o){if(o)return r(o);i._writable.open(t,e,n,r)});case f.NOP:return i._writable.exists(t,function(o){o?i._writable.open(t,e,n,r):((s=y.clone(s)).mode=n,i._readable.readFile(t,null,Nn("r"),function(n,o){if(n)return r(n);-1===s.size&&(s.size=o.length);var a=new Rn(i,t,e,s,o);r(null,a)}))});default:return r(h.EEXIST(t))}else switch(e.pathNotExistsAction()){case f.CREATE_FILE:return i.createParentDirectoriesAsync(t,function(o){return o?r(o):i._writable.open(t,e,n,r)});default:return r(h.ENOENT(t))}})},e.prototype.openSync=function(t,e,n){if(this.checkInitialized(),this.checkPath(t),t===In)throw h.EPERM("Cannot open deletion log.");if(this.existsSync(t))switch(e.pathExistsAction()){case f.TRUNCATE_FILE:return this.createParentDirectories(t),this._writable.openSync(t,e,n);case f.NOP:if(this._writable.existsSync(t))return this._writable.openSync(t,e,n);var r=this._readable.readFileSync(t,null,Nn("r")),i=y.clone(this._readable.statSync(t,!1));return i.mode=n,new Rn(this,t,e,i,r);default:throw h.EEXIST(t)}else switch(e.pathNotExistsAction()){case f.CREATE_FILE:return this.createParentDirectories(t),this._writable.openSync(t,e,n);default:throw h.ENOENT(t)}},e.prototype.unlink=function(t,e){var n=this;this.checkInitAsync(e)&&!this.checkPathAsync(t,e)&&this.exists(t,function(r){if(!r)return e(h.ENOENT(t));n._writable.exists(t,function(r){if(r)return n._writable.unlink(t,function(r){if(r)return e(r);n.exists(t,function(r){r&&n.deletePath(t),e(null)})});n.deletePath(t),e(null)})})},e.prototype.unlinkSync=function(t){if(this.checkInitialized(),this.checkPath(t),!this.existsSync(t))throw h.ENOENT(t);this._writable.existsSync(t)&&this._writable.unlinkSync(t),this.existsSync(t)&&this.deletePath(t)},e.prototype.rmdir=function(t,e){var n=this;if(this.checkInitAsync(e)){var r=function(){n.readdir(t,function(r,i){return r?e(r):i.length?e(h.ENOTEMPTY(t)):(n.deletePath(t),void e(null))})};this.exists(t,function(i){if(!i)return e(h.ENOENT(t));n._writable.exists(t,function(i){i?n._writable.rmdir(t,function(i){if(i)return e(i);n._readable.exists(t,function(t){t?r():e()})}):r()})})}},e.prototype.rmdirSync=function(t){if(this.checkInitialized(),!this.existsSync(t))throw h.ENOENT(t);if(this._writable.existsSync(t)&&this._writable.rmdirSync(t),this.existsSync(t)){if(this.readdirSync(t).length>0)throw h.ENOTEMPTY(t);this.deletePath(t)}},e.prototype.mkdir=function(t,e,n){var r=this;this.checkInitAsync(n)&&this.exists(t,function(i){if(i)return n(h.EEXIST(t));r.createParentDirectoriesAsync(t,function(i){if(i)return n(i);r._writable.mkdir(t,e,n)})})},e.prototype.mkdirSync=function(t,e){if(this.checkInitialized(),this.existsSync(t))throw h.EEXIST(t);this.createParentDirectories(t),this._writable.mkdirSync(t,e)},e.prototype.readdir=function(t,e){var n=this;this.checkInitAsync(e)&&this.stat(t,!1,function(r,i){return r?e(r):i.isDirectory()?void n._writable.readdir(t,function(r,i){if(r&&"ENOENT"!==r.code)return e(r);!r&&i||(i=[]),n._readable.readdir(t,function(r,o){!r&&o||(o=[]);var s={},a=i.concat(o.filter(function(e){return!n._deletedFiles[t+"/"+e]})).filter(function(t){var e=!s[t];return s[t]=!0,e});e(null,a)})}):e(h.ENOTDIR(t))})},e.prototype.readdirSync=function(t){var e=this;if(this.checkInitialized(),!this.statSync(t,!1).isDirectory())throw h.ENOTDIR(t);var n=[];try{n=n.concat(this._writable.readdirSync(t))}catch(t){}try{n=n.concat(this._readable.readdirSync(t).filter(function(n){return!e._deletedFiles[t+"/"+n]}))}catch(t){}var r={};return n.filter(function(t){var e=!r[t];return r[t]=!0,e})},e.prototype.exists=function(t,e){var n=this;this.checkInitialized(),this._writable.exists(t,function(r){if(r)return e(!0);n._readable.exists(t,function(r){e(r&&!0!==n._deletedFiles[t])})})},e.prototype.existsSync=function(t){return this.checkInitialized(),this._writable.existsSync(t)||this._readable.existsSync(t)&&!0!==this._deletedFiles[t]},e.prototype.chmod=function(t,e,n,r){var i=this;this.checkInitAsync(r)&&this.operateOnWritableAsync(t,function(o){if(o)return r(o);i._writable.chmod(t,e,n,r)})},e.prototype.chmodSync=function(t,e,n){var r=this;this.checkInitialized(),this.operateOnWritable(t,function(){r._writable.chmodSync(t,e,n)})},e.prototype.chown=function(t,e,n,r,i){var o=this;this.checkInitAsync(i)&&this.operateOnWritableAsync(t,function(s){if(s)return i(s);o._writable.chown(t,e,n,r,i)})},e.prototype.chownSync=function(t,e,n,r){var i=this;this.checkInitialized(),this.operateOnWritable(t,function(){i._writable.chownSync(t,e,n,r)})},e.prototype.utimes=function(t,e,n,r){var i=this;this.checkInitAsync(r)&&this.operateOnWritableAsync(t,function(o){if(o)return r(o);i._writable.utimes(t,e,n,r)})},e.prototype.utimesSync=function(t,e,n){var r=this;this.checkInitialized(),this.operateOnWritable(t,function(){r._writable.utimesSync(t,e,n)})},e.prototype.deletePath=function(t){this._deletedFiles[t]=!0,this.updateLog("d"+t+"\n")},e.prototype.updateLog=function(t){var e=this;this._deleteLog+=t,this._deleteLogUpdatePending?this._deleteLogUpdateNeeded=!0:(this._deleteLogUpdatePending=!0,this._writable.writeFile(In,this._deleteLog,"utf8",d.getFileFlag("w"),420,function(t){e._deleteLogUpdatePending=!1,t?e._deleteLogError=t:e._deleteLogUpdateNeeded&&(e._deleteLogUpdateNeeded=!1,e.updateLog(""))}))},e.prototype._reparseDeletionLog=function(){var t=this;this._deletedFiles={},this._deleteLog.split("\n").forEach(function(e){t._deletedFiles[e.slice(1)]="d"===e.slice(0,1)})},e.prototype.checkInitialized=function(){if(!this._isInitialized)throw new h(s.EPERM,"OverlayFS is not initialized. Please initialize OverlayFS using its initialize() method before using it.");if(null!==this._deleteLogError){var t=this._deleteLogError;throw this._deleteLogError=null,t}},e.prototype.checkInitAsync=function(t){if(!this._isInitialized)return t(new h(s.EPERM,"OverlayFS is not initialized. Please initialize OverlayFS using its initialize() method before using it.")),!1;if(null!==this._deleteLogError){var e=this._deleteLogError;return this._deleteLogError=null,t(e),!1}return!0},e.prototype.checkPath=function(t){if(t===In)throw h.EPERM(t)},e.prototype.checkPathAsync=function(t,e){return t===In&&(e(h.EPERM(t)),!0)},e.prototype.createParentDirectoriesAsync=function(t,e){var n=a.dirname(t),r=[],i=this;this._writable.stat(n,!1,function t(o,c){o?"/"===n?e(new h(s.EBUSY,"Invariant failed: root does not exist!")):(r.push(n),n=a.dirname(n),i._writable.stat(n,!1,t)):function t(){if(!r.length)return e();var n=r.pop();i._readable.stat(n,!1,function(r,o){if(!o)return e();i._writable.mkdir(n,o.mode,function(n){if(n)return e(n);t()})})}()})},e.prototype.createParentDirectories=function(t){for(var e=this,n=a.dirname(t),r=[];!this._writable.existsSync(n);)r.push(n),n=a.dirname(n);(r=r.reverse()).forEach(function(t){e._writable.mkdirSync(t,e.statSync(t,!1).mode)})},e.prototype.operateOnWritable=function(t,e){if(!this.existsSync(t))throw h.ENOENT(t);this._writable.existsSync(t)||this.copyToWritable(t),e()},e.prototype.operateOnWritableAsync=function(t,e){var n=this;this.exists(t,function(r){if(!r)return e(h.ENOENT(t));n._writable.exists(t,function(r){if(!r)return n.copyToWritableAsync(t,e);e()})})},e.prototype.copyToWritable=function(t){var e=this.statSync(t,!1);e.isDirectory()?this._writable.mkdirSync(t,e.mode):this.writeFileSync(t,this._readable.readFileSync(t,null,Nn("r")),null,Nn("w"),this.statSync(t,!1).mode)},e.prototype.copyToWritableAsync=function(t,e){var n=this;this.stat(t,!1,function(r,i){return r?e(r):i.isDirectory()?n._writable.mkdir(t,i.mode,e):void n._readable.readFile(t,null,Nn("r"),function(r,o){if(r)return e(r);n.writeFile(t,o,null,Nn("w"),i.mode,e)})})},e}(et),xn=function(t){function e(e,n){t.call(this,new Ln(e,n))}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e.Create=function(t,n){try{var r=new e(t.writable,t.readable);r._initialize(function(t){n(t,r)})}catch(t){n(t)}},e.isAvailable=function(){return Ln.isAvailable()},e.prototype.getOverlayedFileSystems=function(){return t.prototype.getFSUnlocked.call(this).getOverlayedFileSystems()},e.prototype.unwrap=function(){return t.prototype.getFSUnlocked.call(this)},e.prototype._initialize=function(e){t.prototype.getFSUnlocked.call(this)._initialize(e)},e}(On);xn.Name="OverlayFS",xn.Options={writable:{type:"object",description:"The file system to write modified files to."},readable:{type:"object",description:"The file system that initially populates this file system."}},function(t){t[t.CB=0]="CB",t[t.FD=1]="FD",t[t.API_ERROR=2]="API_ERROR",t[t.STATS=3]="STATS",t[t.PROBE=4]="PROBE",t[t.FILEFLAG=5]="FILEFLAG",t[t.BUFFER=6]="BUFFER",t[t.ERROR=7]="ERROR"}(Tn||(Tn={}));var Dn=function(){this._callbacks={},this._nextId=0};Dn.prototype.toRemoteArg=function(t){var e=this._nextId++;return this._callbacks[e]=t,{type:Tn.CB,id:e}},Dn.prototype.toLocalArg=function(t){var e=this._callbacks[t];return delete this._callbacks[t],e};var An=function(){this._fileDescriptors={},this._nextId=0};function Pn(t){return{type:Tn.API_ERROR,errorData:Wn(t.writeToBuffer())}}function Cn(t){return h.fromBuffer(Hn(t.errorData))}function Mn(t){return{type:Tn.ERROR,name:t.name,message:t.message,stack:t.stack}}function Un(t){var e=m[t.name];"function"!=typeof e&&(e=Error);var n=new e(t.message);return n.stack=t.stack,n}function jn(t){return{type:Tn.STATS,statsData:Wn(t.toBuffer())}}function Bn(t){return y.fromBuffer(Hn(t.statsData))}function zn(t){return{type:Tn.FILEFLAG,flagStr:t.getFlagString()}}function qn(t){return d.getFileFlag(t.flagStr)}function Wn(t){return z(t)}function Hn(t){return V(t)}function Vn(t){return{type:Tn.BUFFER,data:Wn(t)}}function Zn(t){return Hn(t.data)}An.prototype.toRemoteArg=function(e,n,r,i){var o,s,a=this._nextId++;this._fileDescriptors[a]=e,e.stat(function(c,u){c?i(c):(s=Wn(u.toBuffer()),r.isReadable()?e.read(t.alloc(u.size),0,u.size,0,function(t,e,c){t?i(t):(o=Wn(c),i(null,{type:Tn.FD,id:a,data:o,stat:s,path:n,flag:r.getFlagString()}))}):i(null,{type:Tn.FD,id:a,data:new ArrayBuffer(0),stat:s,path:n,flag:r.getFlagString()}))})},An.prototype.applyFdAPIRequest=function(t,e){var n=this,r=t.args[0];this._applyFdChanges(r,function(i,o){i?e(i):o[t.method](function(i){"close"===t.method&&delete n._fileDescriptors[r.id],e(i)})})},An.prototype._applyFdChanges=function(t,e){var n=this._fileDescriptors[t.id],r=Hn(t.data),i=y.fromBuffer(Hn(t.stat)),o=d.getFileFlag(t.flag);o.isWriteable()?n.write(r,0,r.length,o.isAppendable()?n.getPos():0,function(t){function s(){n.stat(function(t,r){t?e(t):r.mode!==i.mode?n.chmod(i.mode,function(t){e(t,n)}):e(t,n)})}t?e(t):o.isAppendable()?s():n.truncate(r.length,function(){s()})}):e(null,n)};var Yn=function(t){function e(e,n,r,i,o,s){t.call(this,e,n,r,i,s),this._remoteFdId=o}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e.prototype.getRemoteFdId=function(){return this._remoteFdId},e.prototype.toRemoteArg=function(){return{type:Tn.FD,id:this._remoteFdId,data:Wn(this.getBuffer()),stat:Wn(this.getStats().toBuffer()),path:this.getPath(),flag:this.getFlag().getFlagString()}},e.prototype.sync=function(t){this._syncClose("sync",t)},e.prototype.close=function(t){this._syncClose("close",t)},e.prototype._syncClose=function(t,e){var n=this;this.isDirty()?this._fs.syncClose(t,this,function(t){t||n.resetDirty(),e(t)}):e()},e}(it),Xn=function(e){function n(t){var n=this;e.call(this),this._callbackConverter=new Dn,this._isInitialized=!1,this._isReadOnly=!1,this._supportLinks=!1,this._supportProps=!1,this._worker=t,this._worker.addEventListener("message",function(t){var e=t.data;if(function(t){return t&&"object"==typeof t&&t.hasOwnProperty("browserfsMessage")&&t.browserfsMessage}(e)){var r,i=e.args,o=new Array(i.length);for(r=0;r0&&(c=-1,i={browserfsMessage:!0,cbId:o,args:[Pn(t)]},e.postMessage(i))}for(t=0;t0;){var i=void 0,o=r.pop(),s=o[0],a=o[1],c=o[2];for(var u in a)if(a.hasOwnProperty(u)){var f=a[u],h=s+"/"+u;f?(e._index[h]=i=new sr,r.push([h,f,i])):i=new or(new y(p.FILE,-1,365)),c&&(c._ls[u]=i)}}return e},ir.prototype.fileIterator=function(t){for(var e in this._index)if(this._index.hasOwnProperty(e))for(var n=this._index[e],r=0,i=n.getListing();r0&&"/"!==n.charAt(n.length-1)&&(n+="/"),this.prefixUrl=n,this._index=ir.fromListing(e),!er||r&&Kn?(this._requestFileAsyncInternal=Gn,this._requestFileSizeAsyncInternal=tr):(this._requestFileAsyncInternal=nr,this._requestFileSizeAsyncInternal=rr),Kn?(this._requestFileSyncInternal=Qn,this._requestFileSizeSyncInternal=$n):(this._requestFileSyncInternal=ur,this._requestFileSizeSyncInternal=ur)}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e.Create=function(t,n){void 0===t.index&&(t.index="index.json"),"string"==typeof t.index?Gn(t.index,"json",function(r,i){r?n(r):n(null,new e(i,t.baseUrl))}):n(null,new e(t.index,t.baseUrl))},e.isAvailable=function(){return Kn||er},e.prototype.empty=function(){this._index.fileIterator(function(t){t.fileData=null})},e.prototype.getName=function(){return e.Name},e.prototype.diskSpace=function(t,e){e(0,0)},e.prototype.isReadOnly=function(){return!0},e.prototype.supportsLinks=function(){return!1},e.prototype.supportsProps=function(){return!1},e.prototype.supportsSynch=function(){return Kn},e.prototype.preloadFile=function(t,e){var n=this._index.getInode(t);if(!ar(n))throw h.EISDIR(t);if(null===n)throw h.ENOENT(t);var r=n.getData();r.size=e.length,r.fileData=e},e.prototype.stat=function(t,e,n){var r,i=this._index.getInode(t);if(null===i)return n(h.ENOENT(t));ar(i)?(r=i.getData()).size<0?this._requestFileSizeAsync(t,function(t,e){if(t)return n(t);r.size=e,n(null,y.clone(r))}):n(null,y.clone(r)):cr(i)?(r=i.getStats(),n(null,r)):n(h.FileError(s.EINVAL,t))},e.prototype.statSync=function(t,e){var n,r=this._index.getInode(t);if(null===r)throw h.ENOENT(t);if(ar(r))(n=r.getData()).size<0&&(n.size=this._requestFileSizeSync(t));else{if(!cr(r))throw h.FileError(s.EINVAL,t);n=r.getStats()}return n},e.prototype.open=function(t,e,n,r){if(e.isWriteable())return r(new h(s.EPERM,t));var i=this,o=this._index.getInode(t);if(null===o)return r(h.ENOENT(t));if(!ar(o))return r(h.EISDIR(t));var a=o.getData();switch(e.pathExistsAction()){case f.THROW_EXCEPTION:case f.TRUNCATE_FILE:return r(h.EEXIST(t));case f.NOP:if(a.fileData)return r(null,new ot(i,t,e,y.clone(a),a.fileData));this._requestFileAsync(t,"buffer",function(n,o){return n?r(n):(a.size=o.length,a.fileData=o,r(null,new ot(i,t,e,y.clone(a),o)))});break;default:return r(new h(s.EINVAL,"Invalid FileMode object."))}},e.prototype.openSync=function(t,e,n){if(e.isWriteable())throw new h(s.EPERM,t);var r=this._index.getInode(t);if(null===r)throw h.ENOENT(t);if(!ar(r))throw h.EISDIR(t);var i=r.getData();switch(e.pathExistsAction()){case f.THROW_EXCEPTION:case f.TRUNCATE_FILE:throw h.EEXIST(t);case f.NOP:if(i.fileData)return new ot(this,t,e,y.clone(i),i.fileData);var o=this._requestFileSync(t,"buffer");return i.size=o.length,i.fileData=o,new ot(this,t,e,y.clone(i),o);default:throw new h(s.EINVAL,"Invalid FileMode object.")}},e.prototype.readdir=function(t,e){try{e(null,this.readdirSync(t))}catch(t){e(t)}},e.prototype.readdirSync=function(t){var e=this._index.getInode(t);if(null===e)throw h.ENOENT(t);if(cr(e))return e.getListing();throw h.ENOTDIR(t)},e.prototype.readFile=function(t,e,n,r){var i=r;this.open(t,n,420,function(t,n){if(t)return r(t);r=function(t,e){n.close(function(n){return t||(t=n),i(t,e)})};var o=n.getBuffer();null===e?r(t,Z(o)):function(t,e,n){try{n(null,t.toString(e))}catch(t){n(t)}}(o,e,r)})},e.prototype.readFileSync=function(t,e,n){var r=this.openSync(t,n,420);try{var i=r.getBuffer();return null===e?Z(i):i.toString(e)}finally{r.closeSync()}},e.prototype._getHTTPPath=function(t){return"/"===t.charAt(0)&&(t=t.slice(1)),this.prefixUrl+t},e.prototype._requestFileAsync=function(t,e,n){this._requestFileAsyncInternal(this._getHTTPPath(t),e,n)},e.prototype._requestFileSync=function(t,e){return this._requestFileSyncInternal(this._getHTTPPath(t),e)},e.prototype._requestFileSizeAsync=function(t,e){this._requestFileSizeAsyncInternal(this._getHTTPPath(t),e)},e.prototype._requestFileSizeSync=function(t){return this._requestFileSizeSyncInternal(this._getHTTPPath(t))},e}(et);fr.Name="HTTPRequest",fr.Options={index:{type:["string","object"],optional:!0,description:"URL to a file index as a JSON file or the file index object itself, generated with the make_http_index script. Defaults to `index.json`."},baseUrl:{type:"string",optional:!0,description:"Used as the URL prefix for fetched files. Default: Fetch files relative to the index."},preferXHR:{type:"boolean",optional:!0,description:"Whether to prefer XmlHttpRequest or fetch for async operations if both are available. Default: false"}};var hr=function(){};hr.str2byte=function(t,e){for(var n=t.length>e.length?e.length:t.length,r=0;r127){var o=hr.extendedChars.indexOf(t.charAt(r));o>-1&&(i=o+128)}e[i]=r}return n},hr.byte2str=function(t){for(var e=new Array(t.length),n=0;n127?hr.extendedChars[r-128]:String.fromCharCode(r)}return e.join("")},hr.byteLength=function(t){return t.length},hr.extendedChars=["Ç","ü","é","â","ä","à","å","ç","ê","ë","è","ï","î","ì","Ä","Å","É","æ","Æ","ô","ö","ò","û","ù","ÿ","Ö","Ü","ø","£","Ø","×","ƒ","á","í","ó","ú","ñ","Ñ","ª","º","¿","®","¬","½","¼","¡","«","»","_","_","_","¦","¦","Á","Â","À","©","¦","¦","+","+","¢","¥","+","+","-","-","+","-","+","ã","Ã","+","+","-","-","¦","-","+","¤","ð","Ð","Ê","Ë","È","i","Í","Î","Ï","+","+","_","_","¦","Ì","_","Ó","ß","Ô","Ò","õ","Õ","µ","þ","Þ","Ú","Û","Ù","ý","Ý","¯","´","­","±","_","¾","¶","§","÷","¸","°","¨","·","¹","³","²","_"," "];var lr,pr,dr=n(36).inflateRaw,yr={};function gr(t,e){return new Date(1980+(e>>9),(e>>5&15)-1,31&e,t>>11,t>>5&63,31&t)}function _r(t,e,n,r){return 0===r?"":e?t.toString("utf8",n,n+r):hr.byte2str(t.slice(n,n+r))}!function(t){t[t.MSDOS=0]="MSDOS",t[t.AMIGA=1]="AMIGA",t[t.OPENVMS=2]="OPENVMS",t[t.UNIX=3]="UNIX",t[t.VM_CMS=4]="VM_CMS",t[t.ATARI_ST=5]="ATARI_ST",t[t.OS2_HPFS=6]="OS2_HPFS",t[t.MAC=7]="MAC",t[t.Z_SYSTEM=8]="Z_SYSTEM",t[t.CP_M=9]="CP_M",t[t.NTFS=10]="NTFS",t[t.MVS=11]="MVS",t[t.VSE=12]="VSE",t[t.ACORN_RISC=13]="ACORN_RISC",t[t.VFAT=14]="VFAT",t[t.ALT_MVS=15]="ALT_MVS",t[t.BEOS=16]="BEOS",t[t.TANDEM=17]="TANDEM",t[t.OS_400=18]="OS_400",t[t.OSX=19]="OSX"}(lr||(lr={})),function(t){t[t.STORED=0]="STORED",t[t.SHRUNK=1]="SHRUNK",t[t.REDUCED_1=2]="REDUCED_1",t[t.REDUCED_2=3]="REDUCED_2",t[t.REDUCED_3=4]="REDUCED_3",t[t.REDUCED_4=5]="REDUCED_4",t[t.IMPLODE=6]="IMPLODE",t[t.DEFLATE=8]="DEFLATE",t[t.DEFLATE64=9]="DEFLATE64",t[t.TERSE_OLD=10]="TERSE_OLD",t[t.BZIP2=12]="BZIP2",t[t.LZMA=14]="LZMA",t[t.TERSE_NEW=18]="TERSE_NEW",t[t.LZ77=19]="LZ77",t[t.WAVPACK=97]="WAVPACK",t[t.PPMD=98]="PPMD"}(pr||(pr={}));var mr=function(t){if(this.data=t,67324752!==t.readUInt32LE(0))throw new h(s.EINVAL,"Invalid Zip file: Local file header has invalid signature: "+this.data.readUInt32LE(0))};mr.prototype.versionNeeded=function(){return this.data.readUInt16LE(4)},mr.prototype.flags=function(){return this.data.readUInt16LE(6)},mr.prototype.compressionMethod=function(){return this.data.readUInt16LE(8)},mr.prototype.lastModFileTime=function(){return gr(this.data.readUInt16LE(10),this.data.readUInt16LE(12))},mr.prototype.rawLastModFileTime=function(){return this.data.readUInt32LE(10)},mr.prototype.crc32=function(){return this.data.readUInt32LE(14)},mr.prototype.fileNameLength=function(){return this.data.readUInt16LE(26)},mr.prototype.extraFieldLength=function(){return this.data.readUInt16LE(28)},mr.prototype.fileName=function(){return _r(this.data,this.useUTF8(),30,this.fileNameLength())},mr.prototype.extraField=function(){var t=30+this.fileNameLength();return this.data.slice(t,t+this.extraFieldLength())},mr.prototype.totalSize=function(){return 30+this.fileNameLength()+this.extraFieldLength()},mr.prototype.useUTF8=function(){return 2048==(2048&this.flags())};var wr=function(t,e,n){this.header=t,this.record=e,this.data=n};wr.prototype.decompress=function(){var t=this.header.compressionMethod(),e=yr[t];if(e)return e(this.data,this.record.compressedSize(),this.record.uncompressedSize(),this.record.flag());var n=pr[t];throw n||(n="Unknown: "+t),new h(s.EINVAL,"Invalid compression method on file '"+this.header.fileName()+"': "+n)},wr.prototype.getHeader=function(){return this.header},wr.prototype.getRecord=function(){return this.record},wr.prototype.getRawData=function(){return this.data};var vr=function(t,e){if(this.zipData=t,this.data=e,33639248!==this.data.readUInt32LE(0))throw new h(s.EINVAL,"Invalid Zip file: Central directory record has invalid signature: "+this.data.readUInt32LE(0));this._filename=this.produceFilename()};vr.prototype.versionMadeBy=function(){return this.data.readUInt16LE(4)},vr.prototype.versionNeeded=function(){return this.data.readUInt16LE(6)},vr.prototype.flag=function(){return this.data.readUInt16LE(8)},vr.prototype.compressionMethod=function(){return this.data.readUInt16LE(10)},vr.prototype.lastModFileTime=function(){return gr(this.data.readUInt16LE(12),this.data.readUInt16LE(14))},vr.prototype.rawLastModFileTime=function(){return this.data.readUInt32LE(12)},vr.prototype.crc32=function(){return this.data.readUInt32LE(16)},vr.prototype.compressedSize=function(){return this.data.readUInt32LE(20)},vr.prototype.uncompressedSize=function(){return this.data.readUInt32LE(24)},vr.prototype.fileNameLength=function(){return this.data.readUInt16LE(28)},vr.prototype.extraFieldLength=function(){return this.data.readUInt16LE(30)},vr.prototype.fileCommentLength=function(){return this.data.readUInt16LE(32)},vr.prototype.diskNumberStart=function(){return this.data.readUInt16LE(34)},vr.prototype.internalAttributes=function(){return this.data.readUInt16LE(36)},vr.prototype.externalAttributes=function(){return this.data.readUInt32LE(38)},vr.prototype.headerRelativeOffset=function(){return this.data.readUInt32LE(42)},vr.prototype.produceFilename=function(){return _r(this.data,this.useUTF8(),46,this.fileNameLength()).replace(/\\/g,"/")},vr.prototype.fileName=function(){return this._filename},vr.prototype.rawFileName=function(){return this.data.slice(46,46+this.fileNameLength())},vr.prototype.extraField=function(){var t=44+this.fileNameLength();return this.data.slice(t,t+this.extraFieldLength())},vr.prototype.fileComment=function(){var t=46+this.fileNameLength()+this.extraFieldLength();return _r(this.data,this.useUTF8(),t,this.fileCommentLength())},vr.prototype.rawFileComment=function(){var t=46+this.fileNameLength()+this.extraFieldLength();return this.data.slice(t,t+this.fileCommentLength())},vr.prototype.totalSize=function(){return 46+this.fileNameLength()+this.extraFieldLength()+this.fileCommentLength()},vr.prototype.isDirectory=function(){var t=this.fileName();return!!(16&this.externalAttributes())||"/"===t.charAt(t.length-1)},vr.prototype.isFile=function(){return!this.isDirectory()},vr.prototype.useUTF8=function(){return 2048==(2048&this.flag())},vr.prototype.isEncrypted=function(){return 1==(1&this.flag())},vr.prototype.getFileData=function(){var t=this.headerRelativeOffset(),e=new mr(this.zipData.slice(t));return new wr(e,this,this.zipData.slice(t+e.totalSize()))},vr.prototype.getData=function(){return this.getFileData().decompress()},vr.prototype.getRawData=function(){return this.getFileData().getRawData()},vr.prototype.getStats=function(){return new y(p.FILE,this.uncompressedSize(),365,Date.now(),this.lastModFileTime().getTime())};var br=function(t){if(this.data=t,101010256!==this.data.readUInt32LE(0))throw new h(s.EINVAL,"Invalid Zip file: End of central directory record has invalid signature: "+this.data.readUInt32LE(0))};br.prototype.diskNumber=function(){return this.data.readUInt16LE(4)},br.prototype.cdDiskNumber=function(){return this.data.readUInt16LE(6)},br.prototype.cdDiskEntryCount=function(){return this.data.readUInt16LE(8)},br.prototype.cdTotalEntryCount=function(){return this.data.readUInt16LE(10)},br.prototype.cdSize=function(){return this.data.readUInt32LE(12)},br.prototype.cdOffset=function(){return this.data.readUInt32LE(16)},br.prototype.cdZipCommentLength=function(){return this.data.readUInt16LE(20)},br.prototype.cdZipComment=function(){return _r(this.data,!0,22,this.cdZipCommentLength())},br.prototype.rawCdZipComment=function(){return this.data.slice(22,22+this.cdZipCommentLength())};var Sr=function(t){function e(e,n){void 0===n&&(n=""),t.call(this),this.name=n,this._index=new ir,this._directoryEntries=[],this._eocd=null,this._index=e.index,this._directoryEntries=e.directoryEntries,this._eocd=e.eocd,this.data=e.data}return t&&(e.__proto__=t),e.prototype=Object.create(t&&t.prototype),e.prototype.constructor=e,e.Create=function(t,n){try{e._computeIndex(t.zipData,function(r,i){if(i){var o=new e(i,t.name);n(null,o)}else n(r)})}catch(t){n(t)}},e.isAvailable=function(){return!0},e.RegisterDecompressionMethod=function(t,e){yr[t]=e},e._getEOCD=function(t){for(var e=Math.min(65557,t.length-1),n=22;n-1},Dr.prototype.getRockRidgeOffset=function(){return this._rockRidgeOffset},Dr.prototype.rootCheckForRockRidge=function(t){var e=this.getDirectory(t);this._rockRidgeOffset=e.getDotEntry(t)._getRockRidgeOffset(t),this._rockRidgeOffset>-1&&(this._fileOrDir=null)},Dr.prototype.length=function(){return this._data[0]},Dr.prototype.extendedAttributeRecordLength=function(){return this._data[1]},Dr.prototype.lba=function(){return 2048*this._data.readUInt32LE(2)},Dr.prototype.dataLength=function(){return this._data.readUInt32LE(10)},Dr.prototype.recordingDate=function(){return Ir(this._data,18)},Dr.prototype.fileFlags=function(){return this._data[25]},Dr.prototype.fileUnitSize=function(){return this._data[26]},Dr.prototype.interleaveGapSize=function(){return this._data[27]},Dr.prototype.volumeSequenceNumber=function(){return this._data.readUInt16LE(28)},Dr.prototype.identifier=function(){return this._getString(33,this._data[32])},Dr.prototype.fileName=function(t){if(this.hasRockRidge()){var e=this._rockRidgeFilename(t);if(null!==e)return e}var n=this.identifier();if(this.isDirectory(t))return n;var r=n.indexOf(";");return-1===r?n:"."===n[r-1]?n.slice(0,r-1):n.slice(0,r)},Dr.prototype.isDirectory=function(t){var e=!!(2&this.fileFlags());return!e&&this.hasRockRidge()&&(e=this.getSUEntries(t).filter(function(t){return t instanceof Kr}).length>0),e},Dr.prototype.isSymlink=function(t){return this.hasRockRidge()&&this.getSUEntries(t).filter(function(t){return t instanceof Zr}).length>0},Dr.prototype.getSymlinkPath=function(t){for(var e="",n=this.getSUEntries(t),r=this._getGetString(),i=0,o=n;i1&&"/"===e[e.length-1]?e.slice(0,e.length-1):e},Dr.prototype.getFile=function(t){if(this.isDirectory(t))throw new Error("Tried to get a File from a directory.");return null===this._fileOrDir&&(this._fileOrDir=t.slice(this.lba(),this.lba()+this.dataLength())),this._fileOrDir},Dr.prototype.getDirectory=function(t){if(!this.isDirectory(t))throw new Error("Tried to get a Directory from a file.");return null===this._fileOrDir&&(this._fileOrDir=this._constructDirectory(t)),this._fileOrDir},Dr.prototype.getSUEntries=function(t){return this._suEntries||this._constructSUEntries(t),this._suEntries},Dr.prototype._rockRidgeFilename=function(t){var e=this.getSUEntries(t).filter(function(t){return t instanceof Xr});if(0===e.length||6&e[0].flags())return null;for(var n="",r=this._getGetString(),i=0,o=e;i0){var n=e[0];if(n instanceof jr&&n.checkBytesPass())for(var r=1;r0?s-4:s;for(n=0;n>16&255,c[f++]=e>>8&255,c[f++]=255&e;2===a&&(e=i[t.charCodeAt(n)]<<2|i[t.charCodeAt(n+1)]>>4,c[f++]=255&e);1===a&&(e=i[t.charCodeAt(n)]<<10|i[t.charCodeAt(n+1)]<<4|i[t.charCodeAt(n+2)]>>2,c[f++]=e>>8&255,c[f++]=255&e);return c},e.fromByteArray=function(t){for(var e,n=t.length,i=n%3,o=[],s=0,a=n-i;sa?a:s+16383));1===i?(e=t[n-1],o.push(r[e>>2]+r[e<<4&63]+"==")):2===i&&(e=(t[n-2]<<8)+t[n-1],o.push(r[e>>10]+r[e>>4&63]+r[e<<2&63]+"="));return o.join("")};for(var r=[],i=[],o="undefined"!=typeof Uint8Array?Uint8Array:Array,s="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",a=0,c=s.length;a0)throw new Error("Invalid string. Length must be a multiple of 4");var n=t.indexOf("=");return-1===n&&(n=e),[n,n===e?0:4-n%4]}function f(t){return r[t>>18&63]+r[t>>12&63]+r[t>>6&63]+r[63&t]}function h(t,e,n){for(var r,i=[],o=e;o>1,f=-7,h=n?i-1:0,l=n?-1:1,p=t[e+h];for(h+=l,o=p&(1<<-f)-1,p>>=-f,f+=a;f>0;o=256*o+t[e+h],h+=l,f-=8);for(s=o&(1<<-f)-1,o>>=-f,f+=r;f>0;s=256*s+t[e+h],h+=l,f-=8);if(0===o)o=1-u;else{if(o===c)return s?NaN:1/0*(p?-1:1);s+=Math.pow(2,r),o-=u}return(p?-1:1)*s*Math.pow(2,o-r)},e.write=function(t,e,n,r,i,o){var s,a,c,u=8*o-i-1,f=(1<>1,l=23===i?Math.pow(2,-24)-Math.pow(2,-77):0,p=r?0:o-1,d=r?1:-1,y=e<0||0===e&&1/e<0?1:0;for(e=Math.abs(e),isNaN(e)||e===1/0?(a=isNaN(e)?1:0,s=f):(s=Math.floor(Math.log(e)/Math.LN2),e*(c=Math.pow(2,-s))<1&&(s--,c*=2),(e+=s+h>=1?l/c:l*Math.pow(2,1-h))*c>=2&&(s++,c/=2),s+h>=f?(a=0,s=f):s+h>=1?(a=(e*c-1)*Math.pow(2,i),s+=h):(a=e*Math.pow(2,h-1)*Math.pow(2,i),s=0));i>=8;t[n+p]=255&a,p+=d,a/=256,i-=8);for(s=s<0;t[n+p]=255&s,p+=d,s/=256,u-=8);t[n+p-d]|=128*y}},function(t,e,n){"use strict";(function(e){var r=this&&this.__extends||function(t,e){for(var n in e)e.hasOwnProperty(n)&&(t[n]=e[n]);function r(){this.constructor=t}t.prototype=null===e?Object.create(e):(r.prototype=e.prototype,new r)},i=n(5),o=null,s=function(){function t(t,e){this.fun=t,this.array=e}return t.prototype.run=function(){this.fun.apply(null,this.array)},t}(),a=function(){function t(){this._queue=[],this._draining=!1,this._currentQueue=null,this._queueIndex=-1}return t.prototype.push=function(t){var e=this;1!==this._queue.push(t)||this._draining||setTimeout(function(){return e._drainQueue()},0)},t.prototype._cleanUpNextTick=function(){this._draining=!1,this._currentQueue&&this._currentQueue.length?this._queue=this._currentQueue.concat(this._queue):this._queueIndex=-1,this._queue.length&&this._drainQueue()},t.prototype._drainQueue=function(){var t=this;if(!this._draining){var e=setTimeout(function(){return t._cleanUpNextTick()});this._draining=!0;for(var n=this._queue.length;n;){for(this._currentQueue=this._queue,this._queue=[];++this._queueIndex0&&(this._waitingForWrites=this.push(this._bufferedWrites.shift()),this._waitingForWrites););},n}(n(24).Duplex);t.exports=i}).call(this,n(9))},function(t,e,n){t.exports=i;var r=n(5).EventEmitter;function i(){r.call(this)}n(1)(i,r),i.Readable=n(11),i.Writable=n(31),i.Duplex=n(32),i.Transform=n(33),i.PassThrough=n(34),i.Stream=i,i.prototype.pipe=function(t,e){var n=this;function i(e){t.writable&&!1===t.write(e)&&n.pause&&n.pause()}function o(){n.readable&&n.resume&&n.resume()}n.on("data",i),t.on("drain",o),t._isStdio||e&&!1===e.end||(n.on("end",a),n.on("close",c));var s=!1;function a(){s||(s=!0,t.end())}function c(){s||(s=!0,"function"==typeof t.destroy&&t.destroy())}function u(t){if(f(),0===r.listenerCount(this,"error"))throw t}function f(){n.removeListener("data",i),t.removeListener("drain",o),n.removeListener("end",a),n.removeListener("close",c),n.removeListener("error",u),t.removeListener("error",u),n.removeListener("end",f),n.removeListener("close",f),t.removeListener("close",f)}return n.on("error",u),t.on("error",u),n.on("end",f),n.on("close",f),t.on("close",f),t.emit("pipe",n),t}},function(t,e){var n={}.toString;t.exports=Array.isArray||function(t){return"[object Array]"==n.call(t)}},function(t,e){},function(t,e,n){"use strict";var r=n(7).Buffer,i=n(28);function o(t,e,n){t.copy(e,n)}t.exports=function(){function t(){!function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,t),this.head=null,this.tail=null,this.length=0}return t.prototype.push=function(t){var e={data:t,next:null};this.length>0?this.tail.next=e:this.head=e,this.tail=e,++this.length},t.prototype.unshift=function(t){var e={data:t,next:this.head};0===this.length&&(this.tail=e),this.head=e,++this.length},t.prototype.shift=function(){if(0!==this.length){var t=this.head.data;return 1===this.length?this.head=this.tail=null:this.head=this.head.next,--this.length,t}},t.prototype.clear=function(){this.head=this.tail=null,this.length=0},t.prototype.join=function(t){if(0===this.length)return"";for(var e=this.head,n=""+e.data;e=e.next;)n+=t+e.data;return n},t.prototype.concat=function(t){if(0===this.length)return r.alloc(0);if(1===this.length)return this.head.data;for(var e=r.allocUnsafe(t>>>0),n=this.head,i=0;n;)o(n.data,e,i),i+=n.data.length,n=n.next;return e},t}(),i&&i.inspect&&i.inspect.custom&&(t.exports.prototype[i.inspect.custom]=function(){var t=i.inspect({length:this.length});return this.constructor.name+" "+t})},function(t,e){},function(t,e,n){(function(e){function n(t){try{if(!e.localStorage)return!1}catch(t){return!1}var n=e.localStorage[t];return null!=n&&"true"===String(n).toLowerCase()}t.exports=function(t,e){if(n("noDeprecation"))return t;var r=!1;return function(){if(!r){if(n("throwDeprecation"))throw new Error(e);n("traceDeprecation")?console.trace(e):console.warn(e),r=!0}return t.apply(this,arguments)}}}).call(this,n(4))},function(t,e,n){"use strict";t.exports=o;var r=n(18),i=Object.create(n(3));function o(t){if(!(this instanceof o))return new o(t);r.call(this,t)}i.inherits=n(1),i.inherits(o,r),o.prototype._transform=function(t,e,n){n(null,t)}},function(t,e,n){t.exports=n(12)},function(t,e,n){t.exports=n(0)},function(t,e,n){t.exports=n(11).Transform},function(t,e,n){t.exports=n(11).PassThrough},function(t,e){t.exports=function(t){return t.webpackPolyfill||(t.deprecate=function(){},t.paths=[],t.children||(t.children=[]),Object.defineProperty(t,"loaded",{enumerable:!0,get:function(){return t.l}}),Object.defineProperty(t,"id",{enumerable:!0,get:function(){return t.i}}),t.webpackPolyfill=1),t}},function(t,e,n){"use strict";var r=n(37),i=n(8),o=n(42),s=n(43),a=n(44),c=n(45),u=n(46),f=Object.prototype.toString;function h(t){if(!(this instanceof h))return new h(t);this.options=i.assign({chunkSize:16384,windowBits:0,to:""},t||{});var e=this.options;e.raw&&e.windowBits>=0&&e.windowBits<16&&(e.windowBits=-e.windowBits,0===e.windowBits&&(e.windowBits=-15)),!(e.windowBits>=0&&e.windowBits<16)||t&&t.windowBits||(e.windowBits+=32),e.windowBits>15&&e.windowBits<48&&0==(15&e.windowBits)&&(e.windowBits|=15),this.err=0,this.msg="",this.ended=!1,this.chunks=[],this.strm=new c,this.strm.avail_out=0;var n=r.inflateInit2(this.strm,e.windowBits);if(n!==s.Z_OK)throw new Error(a[n]);if(this.header=new u,r.inflateGetHeader(this.strm,this.header),e.dictionary&&("string"==typeof e.dictionary?e.dictionary=o.string2buf(e.dictionary):"[object ArrayBuffer]"===f.call(e.dictionary)&&(e.dictionary=new Uint8Array(e.dictionary)),e.raw&&(n=r.inflateSetDictionary(this.strm,e.dictionary))!==s.Z_OK))throw new Error(a[n])}function l(t,e){var n=new h(e);if(n.push(t,!0),n.err)throw n.msg||a[n.err];return n.result}h.prototype.push=function(t,e){var n,a,c,u,h,l=this.strm,p=this.options.chunkSize,d=this.options.dictionary,y=!1;if(this.ended)return!1;a=e===~~e?e:!0===e?s.Z_FINISH:s.Z_NO_FLUSH,"string"==typeof t?l.input=o.binstring2buf(t):"[object ArrayBuffer]"===f.call(t)?l.input=new Uint8Array(t):l.input=t,l.next_in=0,l.avail_in=l.input.length;do{if(0===l.avail_out&&(l.output=new i.Buf8(p),l.next_out=0,l.avail_out=p),(n=r.inflate(l,s.Z_NO_FLUSH))===s.Z_NEED_DICT&&d&&(n=r.inflateSetDictionary(this.strm,d)),n===s.Z_BUF_ERROR&&!0===y&&(n=s.Z_OK,y=!1),n!==s.Z_STREAM_END&&n!==s.Z_OK)return this.onEnd(n),this.ended=!0,!1;l.next_out&&(0!==l.avail_out&&n!==s.Z_STREAM_END&&(0!==l.avail_in||a!==s.Z_FINISH&&a!==s.Z_SYNC_FLUSH)||("string"===this.options.to?(c=o.utf8border(l.output,l.next_out),u=l.next_out-c,h=o.buf2string(l.output,c),l.next_out=u,l.avail_out=p-u,u&&i.arraySet(l.output,l.output,c,u,0),this.onData(h)):this.onData(i.shrinkBuf(l.output,l.next_out)))),0===l.avail_in&&0===l.avail_out&&(y=!0)}while((l.avail_in>0||0===l.avail_out)&&n!==s.Z_STREAM_END);return n===s.Z_STREAM_END&&(a=s.Z_FINISH),a===s.Z_FINISH?(n=r.inflateEnd(this.strm),this.onEnd(n),this.ended=!0,n===s.Z_OK):a!==s.Z_SYNC_FLUSH||(this.onEnd(s.Z_OK),l.avail_out=0,!0)},h.prototype.onData=function(t){this.chunks.push(t)},h.prototype.onEnd=function(t){t===s.Z_OK&&("string"===this.options.to?this.result=this.chunks.join(""):this.result=i.flattenChunks(this.chunks)),this.chunks=[],this.err=t,this.msg=this.strm.msg},e.Inflate=h,e.inflate=l,e.inflateRaw=function(t,e){return(e=e||{}).raw=!0,l(t,e)},e.ungzip=l},function(t,e,n){"use strict";var r=n(8),i=n(38),o=n(39),s=n(40),a=n(41),c=0,u=1,f=2,h=4,l=5,p=6,d=0,y=1,g=2,_=-2,m=-3,w=-4,v=-5,b=8,S=1,E=2,k=3,O=4,I=5,F=6,N=7,T=8,R=9,L=10,x=11,D=12,A=13,P=14,C=15,M=16,U=17,j=18,B=19,z=20,q=21,W=22,H=23,V=24,Z=25,Y=26,X=27,K=28,J=29,G=30,Q=31,$=32,tt=852,et=592,nt=15;function rt(t){return(t>>>24&255)+(t>>>8&65280)+((65280&t)<<8)+((255&t)<<24)}function it(t){var e;return t&&t.state?(e=t.state,t.total_in=t.total_out=e.total=0,t.msg="",e.wrap&&(t.adler=1&e.wrap),e.mode=S,e.last=0,e.havedict=0,e.dmax=32768,e.head=null,e.hold=0,e.bits=0,e.lencode=e.lendyn=new r.Buf32(tt),e.distcode=e.distdyn=new r.Buf32(et),e.sane=1,e.back=-1,d):_}function ot(t){var e;return t&&t.state?((e=t.state).wsize=0,e.whave=0,e.wnext=0,it(t)):_}function st(t,e){var n,r;return t&&t.state?(r=t.state,e<0?(n=0,e=-e):(n=1+(e>>4),e<48&&(e&=15)),e&&(e<8||e>15)?_:(null!==r.window&&r.wbits!==e&&(r.window=null),r.wrap=n,r.wbits=e,ot(t))):_}function at(t,e){var n,i;return t?(i=new function(){this.mode=0,this.last=!1,this.wrap=0,this.havedict=!1,this.flags=0,this.dmax=0,this.check=0,this.total=0,this.head=null,this.wbits=0,this.wsize=0,this.whave=0,this.wnext=0,this.window=null,this.hold=0,this.bits=0,this.length=0,this.offset=0,this.extra=0,this.lencode=null,this.distcode=null,this.lenbits=0,this.distbits=0,this.ncode=0,this.nlen=0,this.ndist=0,this.have=0,this.next=null,this.lens=new r.Buf16(320),this.work=new r.Buf16(288),this.lendyn=null,this.distdyn=null,this.sane=0,this.back=0,this.was=0},t.state=i,i.window=null,(n=st(t,e))!==d&&(t.state=null),n):_}var ct,ut,ft=!0;function ht(t){if(ft){var e;for(ct=new r.Buf32(512),ut=new r.Buf32(32),e=0;e<144;)t.lens[e++]=8;for(;e<256;)t.lens[e++]=9;for(;e<280;)t.lens[e++]=7;for(;e<288;)t.lens[e++]=8;for(a(u,t.lens,0,288,ct,0,t.work,{bits:9}),e=0;e<32;)t.lens[e++]=5;a(f,t.lens,0,32,ut,0,t.work,{bits:5}),ft=!1}t.lencode=ct,t.lenbits=9,t.distcode=ut,t.distbits=5}function lt(t,e,n,i){var o,s=t.state;return null===s.window&&(s.wsize=1<=s.wsize?(r.arraySet(s.window,e,n-s.wsize,s.wsize,0),s.wnext=0,s.whave=s.wsize):((o=s.wsize-s.wnext)>i&&(o=i),r.arraySet(s.window,e,n-i,o,s.wnext),(i-=o)?(r.arraySet(s.window,e,n-i,i,0),s.wnext=i,s.whave=s.wsize):(s.wnext+=o,s.wnext===s.wsize&&(s.wnext=0),s.whave>>8&255,n.check=o(n.check,Ft,2,0),at=0,ct=0,n.mode=E;break}if(n.flags=0,n.head&&(n.head.done=!1),!(1&n.wrap)||(((255&at)<<8)+(at>>8))%31){t.msg="incorrect header check",n.mode=G;break}if((15&at)!==b){t.msg="unknown compression method",n.mode=G;break}if(ct-=4,St=8+(15&(at>>>=4)),0===n.wbits)n.wbits=St;else if(St>n.wbits){t.msg="invalid window size",n.mode=G;break}n.dmax=1<>8&1),512&n.flags&&(Ft[0]=255&at,Ft[1]=at>>>8&255,n.check=o(n.check,Ft,2,0)),at=0,ct=0,n.mode=k;case k:for(;ct<32;){if(0===ot)break t;ot--,at+=tt[nt++]<>>8&255,Ft[2]=at>>>16&255,Ft[3]=at>>>24&255,n.check=o(n.check,Ft,4,0)),at=0,ct=0,n.mode=O;case O:for(;ct<16;){if(0===ot)break t;ot--,at+=tt[nt++]<>8),512&n.flags&&(Ft[0]=255&at,Ft[1]=at>>>8&255,n.check=o(n.check,Ft,2,0)),at=0,ct=0,n.mode=I;case I:if(1024&n.flags){for(;ct<16;){if(0===ot)break t;ot--,at+=tt[nt++]<>>8&255,n.check=o(n.check,Ft,2,0)),at=0,ct=0}else n.head&&(n.head.extra=null);n.mode=F;case F:if(1024&n.flags&&((pt=n.length)>ot&&(pt=ot),pt&&(n.head&&(St=n.head.extra_len-n.length,n.head.extra||(n.head.extra=new Array(n.head.extra_len)),r.arraySet(n.head.extra,tt,nt,pt,St)),512&n.flags&&(n.check=o(n.check,tt,pt,nt)),ot-=pt,nt+=pt,n.length-=pt),n.length))break t;n.length=0,n.mode=N;case N:if(2048&n.flags){if(0===ot)break t;pt=0;do{St=tt[nt+pt++],n.head&&St&&n.length<65536&&(n.head.name+=String.fromCharCode(St))}while(St&&pt>9&1,n.head.done=!0),t.adler=n.check=0,n.mode=D;break;case L:for(;ct<32;){if(0===ot)break t;ot--,at+=tt[nt++]<>>=7&ct,ct-=7&ct,n.mode=X;break}for(;ct<3;){if(0===ot)break t;ot--,at+=tt[nt++]<>>=1)){case 0:n.mode=P;break;case 1:if(ht(n),n.mode=z,e===p){at>>>=2,ct-=2;break t}break;case 2:n.mode=U;break;case 3:t.msg="invalid block type",n.mode=G}at>>>=2,ct-=2;break;case P:for(at>>>=7&ct,ct-=7&ct;ct<32;){if(0===ot)break t;ot--,at+=tt[nt++]<>>16^65535)){t.msg="invalid stored block lengths",n.mode=G;break}if(n.length=65535&at,at=0,ct=0,n.mode=C,e===p)break t;case C:n.mode=M;case M:if(pt=n.length){if(pt>ot&&(pt=ot),pt>st&&(pt=st),0===pt)break t;r.arraySet(et,tt,nt,pt,it),ot-=pt,nt+=pt,st-=pt,it+=pt,n.length-=pt;break}n.mode=D;break;case U:for(;ct<14;){if(0===ot)break t;ot--,at+=tt[nt++]<>>=5,ct-=5,n.ndist=1+(31&at),at>>>=5,ct-=5,n.ncode=4+(15&at),at>>>=4,ct-=4,n.nlen>286||n.ndist>30){t.msg="too many length or distance symbols",n.mode=G;break}n.have=0,n.mode=j;case j:for(;n.have>>=3,ct-=3}for(;n.have<19;)n.lens[Nt[n.have++]]=0;if(n.lencode=n.lendyn,n.lenbits=7,kt={bits:n.lenbits},Et=a(c,n.lens,0,19,n.lencode,0,n.work,kt),n.lenbits=kt.bits,Et){t.msg="invalid code lengths set",n.mode=G;break}n.have=0,n.mode=B;case B:for(;n.have>>16&255,mt=65535&It,!((gt=It>>>24)<=ct);){if(0===ot)break t;ot--,at+=tt[nt++]<>>=gt,ct-=gt,n.lens[n.have++]=mt;else{if(16===mt){for(Ot=gt+2;ct>>=gt,ct-=gt,0===n.have){t.msg="invalid bit length repeat",n.mode=G;break}St=n.lens[n.have-1],pt=3+(3&at),at>>>=2,ct-=2}else if(17===mt){for(Ot=gt+3;ct>>=gt)),at>>>=3,ct-=3}else{for(Ot=gt+7;ct>>=gt)),at>>>=7,ct-=7}if(n.have+pt>n.nlen+n.ndist){t.msg="invalid bit length repeat",n.mode=G;break}for(;pt--;)n.lens[n.have++]=St}}if(n.mode===G)break;if(0===n.lens[256]){t.msg="invalid code -- missing end-of-block",n.mode=G;break}if(n.lenbits=9,kt={bits:n.lenbits},Et=a(u,n.lens,0,n.nlen,n.lencode,0,n.work,kt),n.lenbits=kt.bits,Et){t.msg="invalid literal/lengths set",n.mode=G;break}if(n.distbits=6,n.distcode=n.distdyn,kt={bits:n.distbits},Et=a(f,n.lens,n.nlen,n.ndist,n.distcode,0,n.work,kt),n.distbits=kt.bits,Et){t.msg="invalid distances set",n.mode=G;break}if(n.mode=z,e===p)break t;case z:n.mode=q;case q:if(ot>=6&&st>=258){t.next_out=it,t.avail_out=st,t.next_in=nt,t.avail_in=ot,n.hold=at,n.bits=ct,s(t,ft),it=t.next_out,et=t.output,st=t.avail_out,nt=t.next_in,tt=t.input,ot=t.avail_in,at=n.hold,ct=n.bits,n.mode===D&&(n.back=-1);break}for(n.back=0;_t=(It=n.lencode[at&(1<>>16&255,mt=65535&It,!((gt=It>>>24)<=ct);){if(0===ot)break t;ot--,at+=tt[nt++]<>wt)])>>>16&255,mt=65535&It,!(wt+(gt=It>>>24)<=ct);){if(0===ot)break t;ot--,at+=tt[nt++]<>>=wt,ct-=wt,n.back+=wt}if(at>>>=gt,ct-=gt,n.back+=gt,n.length=mt,0===_t){n.mode=Y;break}if(32&_t){n.back=-1,n.mode=D;break}if(64&_t){t.msg="invalid literal/length code",n.mode=G;break}n.extra=15&_t,n.mode=W;case W:if(n.extra){for(Ot=n.extra;ct>>=n.extra,ct-=n.extra,n.back+=n.extra}n.was=n.length,n.mode=H;case H:for(;_t=(It=n.distcode[at&(1<>>16&255,mt=65535&It,!((gt=It>>>24)<=ct);){if(0===ot)break t;ot--,at+=tt[nt++]<>wt)])>>>16&255,mt=65535&It,!(wt+(gt=It>>>24)<=ct);){if(0===ot)break t;ot--,at+=tt[nt++]<>>=wt,ct-=wt,n.back+=wt}if(at>>>=gt,ct-=gt,n.back+=gt,64&_t){t.msg="invalid distance code",n.mode=G;break}n.offset=mt,n.extra=15&_t,n.mode=V;case V:if(n.extra){for(Ot=n.extra;ct>>=n.extra,ct-=n.extra,n.back+=n.extra}if(n.offset>n.dmax){t.msg="invalid distance too far back",n.mode=G;break}n.mode=Z;case Z:if(0===st)break t;if(pt=ft-st,n.offset>pt){if((pt=n.offset-pt)>n.whave&&n.sane){t.msg="invalid distance too far back",n.mode=G;break}pt>n.wnext?(pt-=n.wnext,dt=n.wsize-pt):dt=n.wnext-pt,pt>n.length&&(pt=n.length),yt=n.window}else yt=et,dt=it-n.offset,pt=n.length;pt>st&&(pt=st),st-=pt,n.length-=pt;do{et[it++]=yt[dt++]}while(--pt);0===n.length&&(n.mode=q);break;case Y:if(0===st)break t;et[it++]=n.length,st--,n.mode=q;break;case X:if(n.wrap){for(;ct<32;){if(0===ot)break t;ot--,at|=tt[nt++]<>>16&65535|0,s=0;0!==n;){n-=s=n>2e3?2e3:n;do{o=o+(i=i+e[r++]|0)|0}while(--s);i%=65521,o%=65521}return i|o<<16|0}},function(t,e,n){"use strict";var r=function(){for(var t,e=[],n=0;n<256;n++){t=n;for(var r=0;r<8;r++)t=1&t?3988292384^t>>>1:t>>>1;e[n]=t}return e}();t.exports=function(t,e,n,i){var o=r,s=i+n;t^=-1;for(var a=i;a>>8^o[255&(t^e[a])];return-1^t}},function(t,e,n){"use strict";t.exports=function(t,e){var n,r,i,o,s,a,c,u,f,h,l,p,d,y,g,_,m,w,v,b,S,E,k,O,I;n=t.state,r=t.next_in,O=t.input,i=r+(t.avail_in-5),o=t.next_out,I=t.output,s=o-(e-t.avail_out),a=o+(t.avail_out-257),c=n.dmax,u=n.wsize,f=n.whave,h=n.wnext,l=n.window,p=n.hold,d=n.bits,y=n.lencode,g=n.distcode,_=(1<>>=v=w>>>24,d-=v,0===(v=w>>>16&255))I[o++]=65535&w;else{if(!(16&v)){if(0==(64&v)){w=y[(65535&w)+(p&(1<>>=v,d-=v),d<15&&(p+=O[r++]<>>=v=w>>>24,d-=v,!(16&(v=w>>>16&255))){if(0==(64&v)){w=g[(65535&w)+(p&(1<c){t.msg="invalid distance too far back",n.mode=30;break t}if(p>>>=v,d-=v,S>(v=o-s)){if((v=S-v)>f&&n.sane){t.msg="invalid distance too far back",n.mode=30;break t}if(E=0,k=l,0===h){if(E+=u-v,v2;)I[o++]=k[E++],I[o++]=k[E++],I[o++]=k[E++],b-=3;b&&(I[o++]=k[E++],b>1&&(I[o++]=k[E++]))}else{E=o-S;do{I[o++]=I[E++],I[o++]=I[E++],I[o++]=I[E++],b-=3}while(b>2);b&&(I[o++]=I[E++],b>1&&(I[o++]=I[E++]))}break}}break}}while(r>3,p&=(1<<(d-=b<<3))-1,t.next_in=r,t.next_out=o,t.avail_in=r=1&&0===P[I];I--);if(F>I&&(F=I),0===I)return u[f++]=20971520,u[f++]=20971520,l.bits=1,0;for(O=1;O0&&(0===t||1!==I))return-1;for(C[1]=0,E=1;E<15;E++)C[E+1]=C[E]+P[E];for(k=0;k852||2===t&&L>592)return 1;for(;;){w=E-T,h[k]m?(v=M[U+h[k]],b=D[A+h[k]]):(v=96,b=0),p=1<>T)+(d-=p)]=w<<24|v<<16|b|0}while(0!==d);for(p=1<>=1;if(0!==p?(x&=p-1,x+=p):x=0,k++,0==--P[E]){if(E===I)break;E=e[n+h[k]]}if(E>F&&(x&g)!==y){for(0===T&&(T=F),_+=O,R=1<<(N=E-T);N+T852||2===t&&L>592)return 1;u[y=x&g]=F<<24|N<<16|_-f|0}}return 0!==x&&(u[_+x]=E-T<<24|64<<16|0),l.bits=F,0}},function(t,e,n){"use strict";var r=n(8),i=!0,o=!0;try{String.fromCharCode.apply(null,[0])}catch(t){i=!1}try{String.fromCharCode.apply(null,new Uint8Array(1))}catch(t){o=!1}for(var s=new r.Buf8(256),a=0;a<256;a++)s[a]=a>=252?6:a>=248?5:a>=240?4:a>=224?3:a>=192?2:1;function c(t,e){if(e<65534&&(t.subarray&&o||!t.subarray&&i))return String.fromCharCode.apply(null,r.shrinkBuf(t,e));for(var n="",s=0;s>>6,e[s++]=128|63&n):n<65536?(e[s++]=224|n>>>12,e[s++]=128|n>>>6&63,e[s++]=128|63&n):(e[s++]=240|n>>>18,e[s++]=128|n>>>12&63,e[s++]=128|n>>>6&63,e[s++]=128|63&n);return e},e.buf2binstring=function(t){return c(t,t.length)},e.binstring2buf=function(t){for(var e=new r.Buf8(t.length),n=0,i=e.length;n4)u[r++]=65533,n+=o-1;else{for(i&=2===o?31:3===o?15:7;o>1&&n1?u[r++]=65533:i<65536?u[r++]=i:(i-=65536,u[r++]=55296|i>>10&1023,u[r++]=56320|1023&i)}return c(u,r)},e.utf8border=function(t,e){var n;for((e=e||t.length)>t.length&&(e=t.length),n=e-1;n>=0&&128==(192&t[n]);)n--;return n<0?e:0===n?e:n+s[t[n]]>e?n:e}},function(t,e,n){"use strict";t.exports={Z_NO_FLUSH:0,Z_PARTIAL_FLUSH:1,Z_SYNC_FLUSH:2,Z_FULL_FLUSH:3,Z_FINISH:4,Z_BLOCK:5,Z_TREES:6,Z_OK:0,Z_STREAM_END:1,Z_NEED_DICT:2,Z_ERRNO:-1,Z_STREAM_ERROR:-2,Z_DATA_ERROR:-3,Z_BUF_ERROR:-5,Z_NO_COMPRESSION:0,Z_BEST_SPEED:1,Z_BEST_COMPRESSION:9,Z_DEFAULT_COMPRESSION:-1,Z_FILTERED:1,Z_HUFFMAN_ONLY:2,Z_RLE:3,Z_FIXED:4,Z_DEFAULT_STRATEGY:0,Z_BINARY:0,Z_TEXT:1,Z_UNKNOWN:2,Z_DEFLATED:8}},function(t,e,n){"use strict";t.exports={2:"need dictionary",1:"stream end",0:"","-1":"file error","-2":"stream error","-3":"data error","-4":"insufficient memory","-5":"buffer error","-6":"incompatible version"}},function(t,e,n){"use strict";t.exports=function(){this.input=null,this.next_in=0,this.avail_in=0,this.total_in=0,this.output=null,this.next_out=0,this.avail_out=0,this.total_out=0,this.msg="",this.state=null,this.data_type=2,this.adler=0}},function(t,e,n){"use strict";t.exports=function(){this.text=0,this.time=0,this.xflags=0,this.os=0,this.extra=null,this.extra_len=0,this.name="",this.comment="",this.hcrc=0,this.done=!1}}])}); +//# sourceMappingURL=browserfs.min.js.map diff --git a/browserfs.min.js.map b/browserfs.min.js.map index 469ba0a6..321d9999 100644 --- a/browserfs.min.js.map +++ b/browserfs.min.js.map @@ -1 +1 @@ -{"version":3,"sources":["webpack:///webpack/universalModuleDefinition","webpack:///../build/browserfs.min.js","webpack:///webpack/bootstrap 971c321eaacbc0b5e6c1","webpack:///../../../../src/core/FS.ts","webpack:///../../../../src/core/util.ts","webpack:///../../../../~/lodash-es/_apply.js","webpack:///../../../../~/lodash-es/_overRest.js","webpack:///../../../../~/lodash-es/identity.js","webpack:///../../../../~/async-es/internal/rest.js","webpack:///../../../../~/async-es/internal/applyEach.js","webpack:///../../../../~/lodash-es/_getRawTag.js","webpack:///../../../../~/lodash-es/_objectToString.js","webpack:///../../../../~/lodash-es/_baseGetTag.js","webpack:///../../../../~/lodash-es/isObject.js","webpack:///../../../../~/lodash-es/isFunction.js","webpack:///../../../../~/lodash-es/isLength.js","webpack:///../../../../~/lodash-es/isArrayLike.js","webpack:///../../../../~/lodash-es/noop.js","webpack:///../../../../~/async-es/internal/once.js","webpack:///../../../../~/lodash-es/_baseTimes.js","webpack:///../../../../~/lodash-es/isObjectLike.js","webpack:///../../../../~/lodash-es/_baseIsArguments.js","webpack:///../../../../~/lodash-es/stubFalse.js","webpack:///../../../../~/lodash-es/_isIndex.js","webpack:///../../../../~/lodash-es/_baseIsTypedArray.js","webpack:///../../../../~/lodash-es/_baseUnary.js","webpack:///../../../../~/lodash-es/_arrayLikeKeys.js","webpack:///../../../../~/lodash-es/_isPrototype.js","webpack:///../../../../~/lodash-es/_overArg.js","webpack:///../../../../~/lodash-es/_baseKeys.js","webpack:///../../../../~/lodash-es/keys.js","webpack:///../../../../~/async-es/internal/iterator.js","webpack:///../../../../~/async-es/internal/onlyOnce.js","webpack:///../../../../~/async-es/internal/eachOfLimit.js","webpack:///../../../../~/async-es/eachOfLimit.js","webpack:///../../../../~/async-es/internal/doLimit.js","webpack:///../../../../~/async-es/eachOf.js","webpack:///../../../../~/async-es/internal/doParallel.js","webpack:///../../../../~/async-es/internal/map.js","webpack:///../../../../~/async-es/internal/doParallelLimit.js","webpack:///../../../../~/lodash-es/_arrayEach.js","webpack:///../../../../~/lodash-es/_createBaseFor.js","webpack:///../../../../~/async-es/internal/setImmediate.js","webpack:///../../../../~/async-es/reduce.js","webpack:///../../../../~/async-es/internal/consoleFunc.js","webpack:///../../../../~/async-es/internal/withoutIndex.js","webpack:///../../../../~/async-es/each.js","webpack:///../../../../src/backend/Dropbox.ts","webpack:///../../../../src/backend/Emscripten.ts","webpack:///../../../../src/backend/FolderAdapter.ts","webpack:///../../../../src/backend/HTML5FS.ts","webpack:///../../../../src/generic/key_value_filesystem.ts","webpack:///../../../../src/backend/IndexedDB.ts","webpack:///../../../../src/backend/MountableFileSystem.ts","webpack:///../../../../src/backend/OverlayFS.ts","webpack:///../../../../src/backend/WorkerFS.ts","webpack:///../../../../src/generic/xhr.ts","webpack:///../../../../src/generic/file_index.ts","webpack:///../../../../src/backend/XmlHttpRequest.ts","webpack:///../../../../src/backend/ZipFS.ts","webpack:///../../../../src/backend/IsoFS.ts","webpack:///../../../../src/core/browserfs.ts","webpack:///../../../../src/core/global.ts","webpack:///../../../../src/core/api_error.ts","webpack:///../../../../src/core/file_flag.ts","webpack:///../../../../src/core/node_fs_stats.ts","webpack:///../../../../src/core/node_fs.ts","webpack:///../../../../src/generic/emscripten_fs.ts","webpack:///../../../../src/core/file_system.ts","webpack:///../../../../src/core/file.ts","webpack:///../../../../src/generic/preload_file.ts","webpack:///../../../../src/backend/AsyncMirror.ts","webpack:///../../../../~/async-es/internal/initialParams.js","webpack:///../../../../~/lodash-es/_freeGlobal.js","webpack:///../../../../~/lodash-es/_root.js","webpack:///../../../../~/lodash-es/_Symbol.js","webpack:///../../../../~/async-es/internal/getIterator.js","webpack:///../../../../~/lodash-es/isArguments.js","webpack:///../../../../~/lodash-es/isArray.js","webpack:///../../../../~/lodash-es/isBuffer.js","webpack:///../../../../~/lodash-es/_nodeUtil.js","webpack:///../../../../~/lodash-es/isTypedArray.js","webpack:///../../../../~/lodash-es/_nativeKeys.js","webpack:///../../../../~/async-es/internal/breakLoop.js","webpack:///../../../../~/async-es/map.js","webpack:///../../../../~/async-es/applyEach.js","webpack:///../../../../~/async-es/mapLimit.js","webpack:///../../../../~/async-es/mapSeries.js","webpack:///../../../../~/async-es/applyEachSeries.js","webpack:///../../../../~/async-es/apply.js","webpack:///../../../../~/lodash-es/_baseFor.js","webpack:///../../../../~/lodash-es/_unicodeToArray.js","webpack:///../../../../~/async-es/eachOfSeries.js","webpack:///../../../../~/async-es/seq.js","webpack:///../../../../~/async-es/compose.js","webpack:///../../../../~/async-es/constant.js","webpack:///../../../../~/async-es/dir.js","webpack:///../../../../~/async-es/log.js","webpack:///../../../../~/async-es/nextTick.js","webpack:///../../../../~/lodash-es/_baseRange.js","webpack:///../../../../src/generic/inode.ts","webpack:///../../../../src/backend/InMemory.ts","webpack:///../../../../src/backend/LocalStorage.ts","webpack:///../../../../src/generic/mutex.ts","webpack:///../../../../src/generic/locked_fs.ts","webpack:///../../../../src/generic/extended_ascii.ts","webpack:///../../../../src/core/backends.ts","webpack:///../../../../src/index.ts","webpack:///./~/buffer/index.js","webpack:///./~/readable-stream/lib/_stream_duplex.js","webpack:///../ts/index.ts","webpack:///./~/inherits/inherits_browser.js","webpack:///./~/core-util-is/lib/util.js","webpack:///./~/events/events.js","webpack:///./build/temp/library/webpack/BFSBuffer.js","webpack:///./~/pako/lib/utils/common.js","webpack:///./~/stream-browserify/index.js","webpack:///./~/buffer-shims/index.js","webpack:///./~/process-nextick-args/index.js","webpack:///./~/readable-stream/lib/_stream_transform.js","webpack:///./~/readable-stream/lib/_stream_writable.js","webpack:///../ts/path.ts","webpack:///./~/readable-stream/lib/_stream_passthrough.js","webpack:///./~/readable-stream/lib/_stream_readable.js","webpack:///./~/string_decoder/index.js","webpack:///./~/base64-js/index.js","webpack:///../ts/process.ts","webpack:///../ts/tty.ts","webpack:///./~/ieee754/index.js","webpack:///./~/isarray/index.js","webpack:///./~/pako/lib/inflate.js","webpack:///./~/pako/lib/utils/strings.js","webpack:///./~/pako/lib/zlib/adler32.js","webpack:///./~/pako/lib/zlib/constants.js","webpack:///./~/pako/lib/zlib/crc32.js","webpack:///./~/pako/lib/zlib/gzheader.js","webpack:///./~/pako/lib/zlib/inffast.js","webpack:///./~/pako/lib/zlib/inflate.js","webpack:///./~/pako/lib/zlib/inftrees.js","webpack:///./~/pako/lib/zlib/messages.js","webpack:///./~/pako/lib/zlib/zstream.js","webpack:///./~/readable-stream/duplex.js","webpack:///./~/readable-stream/lib/internal/streams/BufferList.js","webpack:///./~/readable-stream/passthrough.js","webpack:///./~/readable-stream/readable.js","webpack:///./~/readable-stream/transform.js","webpack:///./~/readable-stream/writable.js","webpack:///./~/util-deprecate/browser.js","webpack:///(webpack)/buildin/module.js"],"names":["root","factory","exports","module","define","amd","this","modules","__webpack_require__","moduleId","installedModules","id","loaded","call","m","c","p","global","Buffer","process","assertRoot","fs","ApiError","ErrorCode","EIO","normalizeMode","mode","def","const","trueMode","parseInt","isNaN","normalizeTime","time","Date","EINVAL","normalizePath","indexOf","path.resolve","normalizeOptions","options","defEnc","defFlag","defMode","encoding","flag","nopCb","fail","Error","mkdirpSync","existsSync","path.dirname","mkdirSync","buffer2ArrayBuffer","buff","u8","buffer2Uint8array","u8offset","byteOffset","u8Len","byteLength","buffer","slice","Uint8Array","arrayish2Buffer","arr","uint8Array2Buffer","arrayBuffer2Buffer","ab","e","copyingSlice","start","end","length","TypeError","s0","newS0","subarray","apply","func","thisArg","args","overRest","transform","nativeMax","undefined","arguments","index","array","Array","otherArgs","identity","value","rest","_overRest","applyEach","eachfn","fns","go","initialParams","callback","that","fn","cb","concat","getRawTag","isOwn","hasOwnProperty","symToStringTag","tag","unmasked","result","nativeObjectToString","objectToString","baseGetTag","undefinedTag","nullTag","Object","isObject","type","isFunction","funcTag","genTag","asyncTag","proxyTag","isLength","MAX_SAFE_INTEGER","isArrayLike","noop","once","callFn","baseTimes","n","iteratee","isObjectLike","baseIsArguments","argsTag","stubFalse","isIndex","reIsUint","test","baseIsTypedArray","typedArrayTags","baseUnary","arrayLikeKeys","inherited","isArr","isArray","isArg","isArguments","isBuff","isBuffer","isType","isTypedArray","skipIndexes","String","key","push","isPrototype","Ctor","constructor","proto","prototype","objectProto","overArg","arg","baseKeys","object","nativeKeys","keys","createArrayIterator","coll","i","len","createES2015Iterator","iterator","item","next","done","createObjectIterator","obj","okeys","getIterator","onlyOnce","_eachOfLimit","limit","iterateeCallback","err","running","breakLoop","replenish","elem","nextElem","eachOfLimit","doLimit","iterable","eachOfArrayLike","iteratorCallback","completed","doParallel","eachOf","_asyncMap","results","counter","_","v","doParallelLimit","arrayEach","createBaseFor","fromRight","keysFunc","props","fallback","setTimeout","wrap","defer","reduce","memo","eachOfSeries","x","consoleFunc","name","console","error","_withoutIndex","eachLimit","withoutIndex","constructErrorCodeLookup","errorCodeLookup","Dropbox","NETWORK_ERROR","INVALID_PARAM","INVALID_TOKEN","EPERM","OAUTH_ERROR","NOT_FOUND","ENOENT","INVALID_METHOD","NOT_ACCEPTABLE","CONFLICT","RATE_LIMITED","EBUSY","SERVER_ERROR","OVER_QUOTA","ENOSPC","isFileInfo","cache","stat","isFile","isDirInfo","isFolder","isArrayBuffer","convertError","path","path$$1","errno","parent","node","paths","unshift","ErrorStrings","join","translateError","folder","path.relative","message","replace","wrapCallback","wrapFunction","wrapFirst","wrapSecond","path.join","_folder","_wrapped","isDirectoryEntry","entry","isDirectory","_requestQuota","size","success","errorCallback","navigator","PERSISTENT","webkitPersistentStorage","requestQuota","TEMPORARY","webkitTemporaryStorage","webkitStorageInfo","_toArray","list","convertError$1","expectedDir","EEXIST","FileError","EACCES","ENOTDIR","EISDIR","GenerateRandomID","r","Math","random","toString","noError","noErrorTx","tx","abort","convertError$2","onErrorHandler","code","preventDefault","defineFcn","isSync","numArgs","rv","_getFs","standardizeError","this$1","makeModeWritable","0o222","getFlag","f","FileFlag","getFileFlag","apiErrorLocal2Remote","SpecialArgType","API_ERROR","errorData","bufferToTransferrableObject","writeToBuffer","apiErrorRemote2Local","fromBuffer","transferrableObjectToBuffer","errorLocal2Remote","ERROR","stack","errorRemote2Local","let","cnstr","statsLocal2Remote","stats","STATS","statsData","toBuffer","statsRemote2Local","Stats","fileFlagLocal2Remote","FILEFLAG","flagStr","getFlagString","fileFlagRemote2Local","remoteFlag","bufferLocal2Remote","BUFFER","data","bufferRemote2Local","buffArg","isAPIRequest","isAPIResponse","asyncDownloadFileModern","req","XMLHttpRequest","open","jsonSupported","responseType","onreadystatechange","readyState","status","response","JSON","parse","responseText","send","syncDownloadFileModern","overrideMimeType","text","charCodeAt","syncDownloadFileIE10","getFileSize","async","getResponseHeader","getFileSizeSync","getFileSizeAsync","isFileInode","inode","isDirInode","isDir","tryToString","msdos2date","date","day","month","year","second","minute","hour","safeToString","useUTF8","ExtendedASCII","byte2str","getASCIIString","startIndex","trim","getJolietString","fromCharCode","pairs","floor","chars","pos","getDate","mon","min","sec","hundrethsSec","getShortFormDate","yearsSince1900","constructSystemUseEntry","bigData","sue","SystemUseEntry","signatureWord","CEEntry","PDEntry","SPEntry","STEntry","EREntry","ESEntry","PXEntry","PNEntry","SLEntry","NMEntry","CLEntry","PLEntry","REEntry","TFEntry","SFEntry","RREntry","constructSystemUseEntries","isoData","entries","getEntries","install","oldRequire","require","BFSRequire","registerFileSystem","Backends","BFSUtils","initialize","rootfs","defineProperty","toExport","window","self","global$1","EBADF","EFBIG","EROFS","ENOTEMPTY","ENOTSUP","ActionType","super","syscall","__proto__","create","fromJSON","json","readUInt32LE","toJSON","buffer$$1","bufferSize","bytesWritten","write","stringify","writeUInt32LE","api_error","freeze","validFlagStrs","flagCache","isReadable","isWriteable","isTruncating","isAppendable","isSynchronous","isExclusive","pathExistsAction","THROW_EXCEPTION","TRUNCATE_FILE","NOP","pathNotExistsAction","CREATE_FILE","FileType","itemType","atime","mtime","ctime","dev","ino","rdev","nlink","blksize","uid","gid","birthtime","fileData","FILE","DIRECTORY","blocks","ceil","readDoubleLE","writeDoubleLE","getTime","clone","isSymbolicLink","SYMLINK","chmod","isSocket","isBlockDevice","isCharacterDevice","isFIFO","wrapCb","FS","F_OK","R_OK","W_OK","X_OK","fdMap","nextFd","rootFS","isAvailable","_toUnixTimestamp","getRootFS","rename","oldPath","newPath","newCb","renameSync","exists","statSync","lstat","lstatSync","truncate","arg2","truncateSync","unlink","unlinkSync","file","getFdForFile","openSync","readFile","filename","readFileSync","writeFile","arg3","writeFileSync","appendFile","appendFileSync","fstat","fd","fd2file","fstatSync","close","closeFd","closeSync","ftruncate","ftruncateSync","fsync","sync","fsyncSync","syncSync","fdatasync","datasync","fdatasyncSync","datasyncSync","arg4","arg5","offset","position","getPos","writeSync","read","bytesRead","buf","readSync","shenanigans","fchown","chown","fchownSync","chownSync","fchmod","numMode","fchmodSync","chmodSync","futimes","utimes","futimesSync","utimesSync","rmdir","rmdirSync","mkdir","readdir","readdirSync","link","srcpath","dstpath","linkSync","symlink","symlinkSync","readlink","readlinkSync","lchown","lchownSync","lchmod","lchmodSync","realpath","realpathSync","watchFile","listener","unwatchFile","watch","access","accessSync","createReadStream","createWriteStream","wrapCallbacks","cbWrapper","_fsMock","fsProto","forEach","newFs","isIE","exec","userAgent","toLowerCase","isWebWorker","BFSEmscriptenStreamOps","nodefs","getNodeFS","getFS","PATH","getPATH","ERRNO_CODES","getERRNO_CODES","stream","realPath","nfd","flagsToPermissionString","flags","ErrnoError","llseek","whence","BFSEmscriptenNodeOps","getattr","setattr","attr","timestamp","lookup","join2","getMode","createNode","mknod","oldNode","newDir","newName","contents","BFSEmscriptenFS","_FS","_PATH","_ERRNO_CODES","flagsToPermissionStringMap","0","1","2","64","65","66","129","193","514","577","578","705","706","1024","1025","1026","1089","1090","1153","1154","1217","1218","4096","4098","node_ops","stream_ops","mount","opts","isLink","parts","reverse","parsedFlags","BaseFileSystem","supportsLinks","diskSpace","openFile","createFile","mustBeFile","parentStats","isLstat","openFileSync","createFileSync","splitPath","split","path.sep","addPaths","doesExist","er","er2","fname","oldCb","err2","isLchmod","isLchown","SynchronousFileSystem","supportsSynch","BaseFile","PreloadFile","BaseFile$$1","_fs","_path","_flag","_stat","_pos","_dirty","_buffer","getBuffer","getStats","getPath","advancePos","delta","setPos","newPos","fill","newBuff","copy","endFp","endRead","supportsProps","isDirty","resetDirty","NoSyncFile","MirrorFile","PreloadFile$$1","_syncSync","AsyncMirror","SynchronousFileSystem$$1","_queue","_queueRunning","_isInitialized","_initializeCallbacks","_sync","_async","getName","enqueueOp","apiMethod","userCb","callbacks","copyDirectory","files","copyNextFile","copyItem","copyFile","isReadOnly","checkInitialized","op","doNextOp","shift","max","pop","freeGlobal","freeSelf","Function","Symbol","toStringTag","iteratorSymbol","propertyIsEnumerable","freeExports","nodeType","freeModule","moduleExports","nativeIsBuffer","arrayTag","boolTag","dateTag","errorTag","mapTag","numberTag","objectTag","regexpTag","setTag","stringTag","weakMapTag","arrayBufferTag","dataViewTag","float32Tag","float64Tag","int8Tag","int16Tag","int32Tag","uint8Tag","uint8ClampedTag","uint16Tag","uint32Tag","freeProcess","nodeUtil","binding","nodeIsTypedArray","eachOfGeneric","Infinity","eachOfImplementation","map","mapLimit","mapSeries","callArgs","_defer","rsAstralRange","rsComboMarksRange","reComboHalfMarksRange","rsComboSymbolsRange","rsComboRange","rsVarRange","rsAstral","rsCombo","rsFitz","rsModifier","rsNonAstral","rsRegional","rsSurrPair","rsZWJ","reOptMod","rsOptVar","hasSetImmediate","setImmediate","hasNextTick","nextTick","seq","functions","newargs","nextargs","values","ignoredArgs","CachedDropboxClient","client","_cache","_client","cacheInfo","getCachedDirInfo","_wrap","interceptCb","contentHash","filenames","folderEntries","NO_CONTENT","updateCachedDirInfo","updateCachedInfo","remove","move","src","dest","deleteCachedInfo","getCachedFileInfo","arrayBuffer","performOp","numRun","timeoutDuration","getCachedInfo","putCachedInfo","info","cachedInfo","updateCachedFileInfo","versionTag","DropboxFile","_writeFileStrict","DropboxFileSystem","BaseFileSystem$$1","supportsSymlinks","empty","mainCb","convert","deleteFile","finished","asyncEach","error2","missingPath","isRemoved","_statType","content","dbStat","_makeFile","ArrayBuffer","_remove","errorCode","EmscriptenFile","_stream","emPosition","EmscriptenFileSystem","DB_NAME","modeToFileType","filter","utime","FolderAdapter","wrapped","_getFS","webkitRequestFileSystem","requestFileSystem","HTML5FSFile","_entry","createWriter","writer","blob","Blob","onwriteend","onerror","HTML5FS","allocate","granted","_readdir","deleteEntry","succ","fullPath","removeRecursively","semaphore","successCount","currentPath","getDirectory","parentDir","path.basename","moveTo","getFile","loadAsFile","fileFromEntry","failedToLoad","loadAsDir","dir","failedToLoadAsFile","exclusive","reader","FileReader","onloadend","event","bfsFile","ev","readAsArrayBuffer","dirEntry","createReader","readEntries","Inode","readUInt16LE","toStats","getSize","writeUInt16LE","update","hasChanged","atimeMs","mtimeMs","ctimeMs","ROOT_NODE_ID","SimpleSyncRWTransaction","store","originalData","modifiedKeys","get","val","stashOldValue","put","overwrite","markModified","del","commit","SyncKeyValueFile","SyncKeyValueFileSystem","makeRootDirectory","clear","beginTransaction","oldParent","oldName","newParent","oldDirNode","findINode","oldDirList","getDirListing","nodeId","newDirNode","newDirList","newNameNode","getINode","newFile","commitNewFile","removeEntry","fileInodeId","_findINode","fileInode","inodeChanged","currTime","dirInode","readDirectory","dirList","addNewNode","currId","retries","parentNode","dirListing","fileNode","dataId","fileNodeId","parentListing","fileName","AsyncKeyValueFile","AsyncKeyValueFileSystem","init","inodes","lists","errorOccurred","theOleSwitcharoo","oldParentList","oldParentINode","newParentList","newParentINode","fileId","completeRename","processInodeAndListings","findINodeAndDirListing","handleDirectoryListings","listing","reroll","committed","InMemoryStore","InMemoryFileSystem","SyncKeyValueFileSystem$$1","indexedDB","mozIndexedDB","webkitIndexedDB","msIndexedDB","IndexedDBROTransaction","onsuccess","target","IndexedDBRWTransaction","arraybuffer","add","_e","IndexedDBStore","storeName","openReq","onupgradeneeded","db","objectStoreNames","contains","deleteObjectStore","createObjectStore","transaction","objectStore","binaryEncoding","IndexedDBFileSystem","AsyncKeyValueFileSystem$$1","supportsBinaryString","localStorage","setItem","getItem","isEncoding","LocalStorageStore","removeItem","LocalStorageFileSystem","MountableFileSystem","mountList","mntMap","rootFs","mountPoint","sort","a","b","umount","splice","substr","fs1rv","fs2rv","fsInfo","rv2","_containsMountPt","mountPoints","pt","fsCmdMap","cmds","j","fnName","Mutex","_locked","_waiters","lock","unlock","tryLock","isLocked","LockedFS","_mu","getFSUnlocked","resolvedPath","linkString","deletionLogPath","OverlayFile","_syncAsync","UnlockedOverlayFS","writable","readable","_deletedFiles","_deleteLog","_deleteLogUpdatePending","_deleteLogUpdateNeeded","_deleteLogError","_writable","_readable","getOverlayedFileSystems","createParentDirectoriesAsync","createParentDirectories","callbackArray","_reparseDeletionLog","getDeletionLog","restoreDeletionLog","log","updateLog","checkInitAsync","checkPathAsync","oldErr","oldStats","newErr","newStats","copyDirContents","oldFile","0o777","mkdirErr","readdirErr","checkPath","oldStat","readFileErr","writableExists","readableExists","deletePath","rmdirLower","dirStats","wFiles","rFiles","seenMap","filtered","fPath","fileP","existsWritable","existsReadable","operateOnWritableAsync","operateOnWritable","addition","0o644","statDone","toCreate","createParents","copyToWritable","copyToWritableAsync","pStats","OverlayFS","LockedFS$$1","unwrap","CallbackArgumentConverter","_callbacks","_nextId","toRemoteArg","CB","toLocalArg","FileDescriptorArgumentConverter","_fileDescriptors","FD","applyFdAPIRequest","request","fdArg","_applyFdChanges","method","remoteFd","remoteStats","applyStatChanges","WorkerFile","remoteFdId","_remoteFdId","getRemoteFdId","_syncClose","syncClose","WorkerFS","worker","_callbackConverter","_isReadOnly","_supportLinks","_supportProps","_worker","addEventListener","resp","fixedArgs","_argRemote2Local","cbId","attachRemoteListener","argLocal2Remote","requestArgs","fdConverter","argRemote2Local","fixedRequestArgs","specialArg","abortAndSendError","countdown","browserfsMessage","postMessage","arguments$1","fixedArg","remoteCb","probeResponse","PROBE","_argLocal2Remote","_rpc","methodName","asyncDownloadFile","syncDownloadFile","FileIndex","_index","addPath","DirInode","fromListing","idx","rootInode","queue","pwd","tree","children","FileInode","_ls","fileIterator","getListing","getData","_split_path","dirpath","itemname","addItem","addPathFast","itemNameMark","lastIndexOf","parentPath","substring","itemName","removePath","remItem","ls","getInode","setData","XmlHttpRequest","listingUrlOrObj","prefixUrl","charAt","_requestFileSync","_requestFileSizeAsync","getXhrPath","_requestFileSizeSync","preloadFile","_requestFileAsync","fdCast","fdBuff","filePath","str2byte","str","charCode","charIdx","extendedChars","ExternalFileAttributeType","inflateRaw","decompressionMethods","CompressionMethod","FileHeader","versionNeeded","compressionMethod","lastModFileTime","rawLastModFileTime","crc32","fileNameLength","extraFieldLength","extraField","totalSize","FileData","header","record","decompress","fcn","compressedSize","uncompressedSize","getHeader","getRecord","getRawData","DataDescriptor","ArchiveExtraDataRecord","extraFieldData","DigitalSignature","signatureData","CentralDirectory","zipData","_filename","produceFilename","versionMadeBy","fileCommentLength","diskNumberStart","internalAttributes","externalAttributes","headerRelativeOffset","rawFileName","fileComment","rawFileComment","isEncrypted","getFileData","EndOfCentralDirectory","diskNumber","cdDiskNumber","cdDiskEntryCount","cdTotalEntryCount","cdSize","cdOffset","cdZipCommentLength","cdZipComment","rawCdZipComment","ZipTOC","directoryEntries","eocd","ZipFS","input","_directoryEntries","_eocd","populateIndex","RegisterDecompressionMethod","computeIndex","getEOCD","cdPtr","cdEnd","computeIndexResponsive","startOffset","endOffset","addToIndex","cd","cdEntries","count","getCentralDirectoryEntry","getCentralDirectoryEntryAt","RangeError","getNumberOfCentralDirectoryEntries","getEndOfCentralDirectory","cdRecord","DEFLATE","chunkSize","STORED","rockRidgeIdentifier","VolumeDescriptor","_data","standardIdentifier","version","PrimaryOrSupplementaryVolumeDescriptor","_root","systemIdentifier","_getString32","volumeIdentifier","volumeSpaceSize","volumeSetSize","volumeSequenceNumber","logicalBlockSize","pathTableSize","locationOfTypeLPathTable","locationOfOptionalTypeLPathTable","locationOfTypeMPathTable","readUInt32BE","locationOfOptionalTypeMPathTable","rootDirectoryEntry","_constructRootDirectoryRecord","rootCheckForRockRidge","volumeSetIdentifier","_getString","publisherIdentifier","dataPreparerIdentifier","applicationIdentifier","copyrightFileIdentifier","abstractFileIdentifier","bibliographicFileIdentifier","volumeCreationDate","volumeModificationDate","volumeExpirationDate","volumeEffectiveDate","fileStructureVersion","applicationUsed","reserved","PrimaryVolumeDescriptor","ISODirectoryRecord","SupplementaryVolumeDescriptor","escapeSequence","third","JolietDirectoryRecord","DirectoryRecord","rockRidgeOffset","_suEntries","_fileOrDir","_rockRidgeOffset","hasRockRidge","getRockRidgeOffset","getDotEntry","_getRockRidgeOffset","extendedAttributeRecordLength","lba","dataLength","recordingDate","fileFlags","fileUnitSize","interleaveGapSize","identifier","_rockRidgeFilename","ident","versionSeparator","getSUEntries","isSymlink","getSymlinkPath","getStr","_getGetString","components","componentRecords","component","continueFlag","_constructDirectory","_constructSUEntries","nmEntries","getString","suEntries","spEntry","checkBytesPass","extensionIdentifier","bytesSkipped","ISODirectory","JolietDirectory","readUInt16BE","signatureWordString","suVersion","_entries","continuationLba","continuationLbaOffset","continuationLength","identifierLength","descriptorLength","sourceLength","extensionVersion","extensionDescriptor","extensionSource","extensionSequence","fileLinks","devTHigh","devTLow","records","SLComponentRecord","componentLength","childDirectoryLba","parentDirectoryLba","creation","_longFormDates","modify","previousDates","backup","expiration","effective","virtualSizeHigh","virtualSizeLow","tableDepth","Directory","_fileList","_fileMap","_record","iLimit","cl","_constructDirectoryRecord","getFileList","IsoFS","vdTerminatorFound","candidateVDs","vd","_pvd","_name","_getDirectoryRecord","_getStats","newP","dirRec","Emscripten","InMemory","IndexedDB","LocalStorage","gScope","timeouts","messageName","canUsePostMessage","importScripts","postMessageIsAsync","oldOnMessage","onmessage","handleMessage","source","stopPropagation","cancelBubble","attachEvent","MessageChannel","channel","port1","port2","EmscriptenFS","FileSystem","Errors","typedArraySupport","foo","createBuffer","K_MAX_LENGTH","encodingOrOffset","allocUnsafe","from","fromArrayBuffer","fromString","fromObject","assertSize","alloc","checked","string","actual","fromArrayLike","isnan","SlowBuffer","isView","loweredCase","utf8ToBytes","base64ToBytes","slowToString","hexSlice","utf8Slice","asciiSlice","latin1Slice","base64Slice","utf16leSlice","swap","bidirectionalIndexOf","arrayIndexOf","indexSize","arrLength","valLength","foundIndex","found","hexWrite","Number","remaining","strLen","parsed","utf8Write","blitBuffer","asciiWrite","asciiToBytes","latin1Write","base64Write","ucs2Write","utf16leToBytes","base64","fromByteArray","res","firstByte","codePoint","bytesPerSequence","secondByte","thirdByte","fourthByte","tempCodePoint","decodeCodePointsArray","codePoints","MAX_ARGUMENTS_LENGTH","ret","out","toHex","bytes","checkOffset","ext","checkInt","checkIEEE754","writeFloat","littleEndian","noAssert","ieee754","writeDouble","base64clean","stringtrim","INVALID_BASE64_RE","units","leadSurrogate","byteArray","hi","lo","toByteArray","dst","INSPECT_MAX_BYTES","kMaxLength","TYPED_ARRAY_SUPPORT","species","configurable","enumerable","poolSize","allocUnsafeSlow","_isBuffer","compare","y","swap16","swap32","swap64","equals","inspect","match","thisStart","thisEnd","thisCopy","targetCopy","includes","isFinite","_arr","newBuf","readUIntLE","mul","readUIntBE","readUInt8","readIntLE","pow","readIntBE","readInt8","readInt16LE","readInt16BE","readInt32LE","readInt32BE","readFloatLE","readFloatBE","readDoubleBE","writeUIntLE","maxBytes","writeUIntBE","writeUInt8","writeUInt16BE","writeUInt32BE","writeIntLE","sub","writeIntBE","writeInt8","writeInt16LE","writeInt16BE","writeInt32LE","writeInt32BE","writeFloatLE","writeFloatBE","writeDoubleBE","targetStart","set","Duplex","Readable","Writable","allowHalfOpen","onend","_writableState","ended","processNextTick","onEndNT","objectKeys","util","inherits","defineKey","processProxy","Process","initializeTTYs","stdin","stdout","stderr","ctor","superCtor","super_","TempCtor","isBoolean","isNull","isNullOrUndefined","isNumber","isString","isSymbol","isUndefined","isRegExp","re","isDate","d","isError","isPrimitive","o","EventEmitter","_events","_maxListeners","defaultMaxListeners","setMaxListeners","emit","handler","listeners","context","addListener","newListener","warned","trace","on","g","removeListener","fired","removeAllListeners","listenerCount","evlistener","emitter","TYPED_OK","Uint16Array","Int32Array","assign","sources","shrinkBuf","fnTyped","arraySet","src_offs","dest_offs","flattenChunks","chunks","l","chunk","fnUntyped","setTyped","Buf8","Buf16","Buf32","Stream","EE","Transform","PassThrough","pipe","ondata","pause","ondrain","resume","didOnEnd","onclose","destroy","cleanup","_isStdio","MAX_LEN","enc","_fill","fillBuf","flen","arg1","TransformState","afterTransform","needTransform","transforming","writecb","writechunk","writeencoding","ts","_transformState","rs","_readableState","reading","needReadable","highWaterMark","_read","_transform","flush","_flush","ws","_write","nop","WriteReq","WritableState","objectMode","writableObjectMode","hwm","defaultHwm","needDrain","ending","noDecode","decodeStrings","defaultEncoding","writing","corked","bufferProcessing","onwrite","writelen","bufferedRequest","lastBufferedRequest","pendingcb","prefinished","errorEmitted","bufferedRequestCount","corkedRequestsFree","CorkedRequest","realHasInstance","writev","_writev","writeAfterEnd","validChunk","state","valid","decodeChunk","bufferShim","writeOrBuffer","last","doWrite","onwriteError","onwriteStateUpdate","needFinish","clearBuffer","asyncWrite","afterWrite","onwriteDrain","finishMaybe","holder","finish","prefinish","need","endWritable","_this","browser","internalUtil","deprecate","current","hasInstance","cork","uncork","setDefaultEncoding","posixSplitPath","splitPathRe","normalize","absolute","sep","_removeDuplicateSeps","goodComponents","_i","processed","segment","resolve","resolved","cwd","relative","to","fromSegs","toSegs","upCount","downSegs","seg","dirname","sections","basename","lastPart","lastPartExt","extname","isAbsolute","_makeLong","allParts","base","format","pathObject","_replaceRegex","RegExp","delimiter","posix","win32","prependListener","ReadableState","readableObjectMode","BufferList","pipes","pipesCount","flowing","endEmitted","emittedReadable","readableListening","resumeScheduled","ranOut","awaitDrain","readingMore","decoder","StringDecoder","readableAddChunk","addToFront","chunkInvalid","onEofChunk","skipAdd","emitReadable","maybeReadMore","needMoreData","computeNewHighWaterMark","MAX_HWM","howMuchToRead","head","debug","emitReadable_","flow","maybeReadMore_","pipeOnDrain","EElistenerCount","nReadingNextTick","resume_","fromList","fromListPartial","hasStrings","copyFromBufferString","copyFromBuffer","nb","tail","endReadable","endReadableNT","xs","debugUtil","debuglog","isPaused","setEncoding","nOrig","doRead","pipeOpts","onunpipe","onfinish","cleanedUp","increasedAwaitDrain","unpipe","doEnd","endFn","dests","paused","events","bind","_fromList","assertEncoding","isBufferEncoding","passThroughWrite","utf16DetectIncompleteChar","charReceived","charLength","base64DetectIncompleteChar","surrogateSize","detectIncompleteChar","charBuffer","charStr","available","cr","placeHoldersCount","b64","tmp","placeHolders","Arr","L","revLookup","tripletToBase64","num","encodeChunk","uint8","output","extraBytes","maxChunkLength","len2","__dirname","__extends","__","Item","fun","run","NextTickQueue","_draining","_currentQueue","_queueIndex","_drainQueue","_cleanUpNextTick","timeout","clearTimeout","_super","startTime","now","_cwd","platform","argv","execArgv","domain","execPath","env","exitCode","_gid","_uid","versions","http_parser","v8","uv","zlib","ares","icu","openssl","config","target_defaults","cflags","default_configuration","defines","include_dirs","libraries","variables","clang","host_arch","node_install_npm","node_install_waf","node_prefix","node_shared_cares","node_shared_http_parser","node_shared_libuv","node_shared_zlib","node_shared_v8","node_use_dtrace","node_use_etw","node_use_openssl","node_shared_openssl","strict_aliasing","target_arch","v8_use_snapshot","v8_no_strict_aliasing","visibility","pid","title","arch","_mask","connected","chdir","uptime","exit","getgid","setgid","getuid","setuid","kill","signal","memoryUsage","rss","heapTotal","heapUsed","umask","mask","oldMask","hrtime","timeinfo","performance","secs","TTY","disconnect","isRaw","columns","rows","isTTY","_bufferedWrites","_waitingForWrites","setRawMode","changeColumns","changeRows","isatty","isLE","mLen","nBytes","eLen","eMax","eBias","nBits","s","NaN","rt","abs","LN2","Inflate","utils","windowBits","opt","raw","msg","strm","ZStream","avail_out","zlib_inflate","inflateInit2","Z_OK","GZheader","inflateGetHeader","inflate","inflator","strings","_mode","next_out_utf8","utf8str","dict","dictionary","allowBufError","Z_FINISH","Z_NO_FLUSH","binstring2buf","next_in","avail_in","next_out","Z_NEED_DICT","string2buf","inflateSetDictionary","Z_BUF_ERROR","Z_STREAM_END","onEnd","Z_SYNC_FLUSH","utf8border","buf2string","onData","inflateEnd","ungzip","buf2binstring","STR_APPLY_UIA_OK","STR_APPLY_OK","_utf8len","q","c2","m_pos","str_len","buf_len","c_len","utf16buf","adler32","adler","s1","s2","Z_PARTIAL_FLUSH","Z_FULL_FLUSH","Z_BLOCK","Z_TREES","Z_ERRNO","Z_STREAM_ERROR","Z_DATA_ERROR","Z_NO_COMPRESSION","Z_BEST_SPEED","Z_BEST_COMPRESSION","Z_DEFAULT_COMPRESSION","Z_FILTERED","Z_HUFFMAN_ONLY","Z_RLE","Z_FIXED","Z_DEFAULT_STRATEGY","Z_BINARY","Z_TEXT","Z_UNKNOWN","Z_DEFLATED","makeTable","table","k","crc","t","crcTable","xflags","os","extra","extra_len","comment","hcrc","BAD","TYPE","_in","_out","beg","dmax","wsize","whave","wnext","s_window","hold","bits","lcode","dcode","lmask","dmask","here","dist","from_source","lencode","distcode","lenbits","distbits","top","dolen","dodist","sane","zswap32","InflateState","havedict","check","total","wbits","ncode","nlen","ndist","have","lens","work","lendyn","distdyn","back","was","inflateResetKeep","total_in","total_out","HEAD","ENOUGH_LENS","ENOUGH_DISTS","inflateReset","inflateReset2","inflateInit","DEF_WBITS","fixedtables","virgin","sym","lenfix","distfix","inflate_table","LENS","DISTS","updatewindow","left","here_bits","here_op","here_val","last_bits","last_op","last_val","hbuf","order","TYPEDO","inf_leave","FLAGS","DICTID","TIME","OS","EXLEN","EXTRA","NAME","COMMENT","HCRC","DICT","CHECK","LEN_","TABLE","COPY_","COPY","LENLENS","CODES","CODELENS","LEN","inflate_fast","LIT","LENEXT","DIST","DISTEXT","MATCH","LENGTH","DONE","MEM","Z_MEM_ERROR","SYNC","data_type","dictid","dictLength","MAX_WBITS","inflateInfo","MAXBITS","lbase","lext","dbase","dext","lens_index","codes","table_index","incr","low","curr","drop","used","huff","base_index","offs","extra_index","-1","-2","-3","-4","-5","-6","READABLE_STREAM","deprecated","warn","webpackPolyfill"],"mappings":"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,ElEwtDL,MkEttDG,IAAI/D,MAAKkgB,GAAG+H,WAAWjoB,KAAK0nB,YAAY3jB,EAAE+O,SlEytDrDsV,GAAqBxe,UkErtDb2b,QAAO,SAAC7V,EAA0BsZ,EAAiBlI,GlEstDvD,GkErtDKC,GAAU/gB,KAAKwnB,KAAKkB,MAAM1oB,KAAKe,GAAG8mB,SAASnY,GAASsZ,ElEstDzD,KACIhpB,KkErtDEqnB,OAAO7B,YAAY1E,EAASC,GlEutDlC,MkEttDQhd,GlEutDJ,IkEttDEA,EAAE+O,KlEutDA,KkEttDC/O,ElEwtDL,MkEttDG,IAAI/D,MAAKkgB,GAAG+H,WAAWjoB,KAAK0nB,YAAY3jB,EAAE+O,SlEytDrDsV,GAAqBxe,UkErtDb6b,SAAQ,SAAC9V,GlEstDb,GkErtDKJ,GAAOvP,KAAKe,GAAG8mB,SAASlY,ElEstD7B,KACI,MkErtDI3P,MAAKqnB,OAAO3B,aAAanW,GlEutDjC,MkEttDQxL,GlEutDJ,IkEttDEA,EAAE+O,KlEutDA,KkEttDC/O,ElEwtDL,MkEttDG,IAAI/D,MAAKkgB,GAAG+H,WAAWjoB,KAAK0nB,YAAY3jB,EAAE+O,QAKtD,IAAAoW,IAAA,SAsCcC,EAA0BC,EAA8BC,EAA4ChC,GlE+qDhG,SAAR8B,IAAiBA,EkE/qDArN,KAAU,IlEgrDjB,SAAVsN,IAAmBA,EkEhrD0BtN,KAAY,MlEirDxC,SAAjBuN,IAA0BA,EkEjrDwDvN,KAAmB,alEkrD1F,SAAXuL,IAAoBA,EkElrDiGtmB,IlEsrD1Hf,KAAKspB,4BACDC,EkEztDU,IlE0tDVC,EkEztDU,KlE0tDVC,EkEztDQ,KlE0tDRC,GkEztDU,IlE0tDVC,GkEztDmB,KlE0tDnBC,GkEztDiB,KlE0tDjBC,IkEztDmB,MlE0tDnBC,IkEztD2B,MlE0tD3BC,IkEztDkB,KlE0tDlBC,IkEztD4B,IlE0tD5BC,IkEztD0B,KlE0tD1BC,IkEztDmC,KlE0tDnCC,IkEztDiC,MlE0tDjCC,KkEztDa,IlE0tDbC,KkEztDsB,IlE0tDtBC,KkEztDoB,KlE0tDpBC,KkEztD8B,IlE0tD9BC,KkEztD4B,KlE0tD5BC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","file":"../build/browserfs.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"BrowserFS\"] = factory();\n\telse\n\t\troot[\"BrowserFS\"] = factory();\n})(this, function() {\nreturn \n\n\n// WEBPACK FOOTER //\n// webpack/universalModuleDefinition","(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"BrowserFS\"] = factory();\n\telse\n\t\troot[\"BrowserFS\"] = factory();\n})(this, function() {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId])\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\texports: {},\n/******/ \t\t\tid: moduleId,\n/******/ \t\t\tloaded: false\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.loaded = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(0);\n/******/ })\n/************************************************************************/\n/******/ ([\n/* 0 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t/* WEBPACK VAR INJECTION */(function(global, Buffer, module, process) {'use strict';\n\t\n\tObject.defineProperty(exports, '__esModule', { value: true });\n\t\n\tvar buffer = __webpack_require__(1);\n\tvar path = __webpack_require__(14);\n\t\n\tvar toExport;\n\tif (typeof (window) !== 'undefined') {\n\t toExport = window;\n\t}\n\telse if (typeof (self) !== 'undefined') {\n\t toExport = self;\n\t}\n\telse {\n\t toExport = global;\n\t}\n\tvar global$1 = toExport;\n\t\n\t/**\n\t * Standard libc error codes. Add more to this enum and ErrorStrings as they are\n\t * needed.\n\t * @url http://www.gnu.org/software/libc/manual/html_node/Error-Codes.html\n\t */\n\t/**\n\t * Standard libc error codes. Add more to this enum and ErrorStrings as they are\n\t * needed.\n\t * @url http://www.gnu.org/software/libc/manual/html_node/Error-Codes.html\n\t */ var ErrorCode;\n\t(function (ErrorCode) {\n\t ErrorCode[ErrorCode[\"EPERM\"] = 1] = \"EPERM\";\n\t ErrorCode[ErrorCode[\"ENOENT\"] = 2] = \"ENOENT\";\n\t ErrorCode[ErrorCode[\"EIO\"] = 5] = \"EIO\";\n\t ErrorCode[ErrorCode[\"EBADF\"] = 9] = \"EBADF\";\n\t ErrorCode[ErrorCode[\"EACCES\"] = 13] = \"EACCES\";\n\t ErrorCode[ErrorCode[\"EBUSY\"] = 16] = \"EBUSY\";\n\t ErrorCode[ErrorCode[\"EEXIST\"] = 17] = \"EEXIST\";\n\t ErrorCode[ErrorCode[\"ENOTDIR\"] = 20] = \"ENOTDIR\";\n\t ErrorCode[ErrorCode[\"EISDIR\"] = 21] = \"EISDIR\";\n\t ErrorCode[ErrorCode[\"EINVAL\"] = 22] = \"EINVAL\";\n\t ErrorCode[ErrorCode[\"EFBIG\"] = 27] = \"EFBIG\";\n\t ErrorCode[ErrorCode[\"ENOSPC\"] = 28] = \"ENOSPC\";\n\t ErrorCode[ErrorCode[\"EROFS\"] = 30] = \"EROFS\";\n\t ErrorCode[ErrorCode[\"ENOTEMPTY\"] = 39] = \"ENOTEMPTY\";\n\t ErrorCode[ErrorCode[\"ENOTSUP\"] = 95] = \"ENOTSUP\";\n\t})(ErrorCode || (ErrorCode = {}));\n\t/* tslint:disable:variable-name */\n\t/**\n\t * Strings associated with each error code.\n\t */\n\tvar ErrorStrings = {};\n\tErrorStrings[ErrorCode.EPERM] = 'Operation not permitted.';\n\tErrorStrings[ErrorCode.ENOENT] = 'No such file or directory.';\n\tErrorStrings[ErrorCode.EIO] = 'Input/output error.';\n\tErrorStrings[ErrorCode.EBADF] = 'Bad file descriptor.';\n\tErrorStrings[ErrorCode.EACCES] = 'Permission denied.';\n\tErrorStrings[ErrorCode.EBUSY] = 'Resource busy or locked.';\n\tErrorStrings[ErrorCode.EEXIST] = 'File exists.';\n\tErrorStrings[ErrorCode.ENOTDIR] = 'File is not a directory.';\n\tErrorStrings[ErrorCode.EISDIR] = 'File is a directory.';\n\tErrorStrings[ErrorCode.EINVAL] = 'Invalid argument.';\n\tErrorStrings[ErrorCode.EFBIG] = 'File is too big.';\n\tErrorStrings[ErrorCode.ENOSPC] = 'No space left on disk.';\n\tErrorStrings[ErrorCode.EROFS] = 'Cannot modify a read-only file system.';\n\tErrorStrings[ErrorCode.ENOTEMPTY] = 'Directory is not empty.';\n\tErrorStrings[ErrorCode.ENOTSUP] = 'Operation is not supported.';\n\t/* tslint:enable:variable-name */\n\t/**\n\t * Represents a BrowserFS error. Passed back to applications after a failed\n\t * call to the BrowserFS API.\n\t */\n\tvar ApiError = (function (Error) {\n\t function ApiError(type, message, path$$1) {\n\t if ( message === void 0 ) message = ErrorStrings[type];\n\t\n\t Error.call(this, message);\n\t // Unsupported.\n\t this.syscall = \"\";\n\t this.errno = type;\n\t this.code = ErrorCode[type];\n\t this.path = path$$1;\n\t this.stack = new Error().stack;\n\t this.message = \"Error: \" + (this.code) + \": \" + message + (this.path ? (\", '\" + (this.path) + \"'\") : '');\n\t }\n\t\n\t if ( Error ) ApiError.__proto__ = Error;\n\t ApiError.prototype = Object.create( Error && Error.prototype );\n\t ApiError.prototype.constructor = ApiError;\n\t ApiError.fromJSON = function fromJSON (json) {\n\t var err = new ApiError(0);\n\t err.errno = json.errno;\n\t err.code = json.code;\n\t err.path = json.path;\n\t err.stack = json.stack;\n\t err.message = json.message;\n\t return err;\n\t };\n\t /**\n\t * Creates an ApiError object from a buffer.\n\t */\n\t ApiError.fromBuffer = function fromBuffer (buffer$$1, i) {\n\t if ( i === void 0 ) i = 0;\n\t\n\t return ApiError.fromJSON(JSON.parse(buffer$$1.toString('utf8', i + 4, i + 4 + buffer$$1.readUInt32LE(i))));\n\t };\n\t ApiError.FileError = function FileError (code, p) {\n\t return new ApiError(code, ErrorStrings[code], p);\n\t };\n\t ApiError.ENOENT = function ENOENT (path$$1) {\n\t return this.FileError(ErrorCode.ENOENT, path$$1);\n\t };\n\t ApiError.EEXIST = function EEXIST (path$$1) {\n\t return this.FileError(ErrorCode.EEXIST, path$$1);\n\t };\n\t ApiError.EISDIR = function EISDIR (path$$1) {\n\t return this.FileError(ErrorCode.EISDIR, path$$1);\n\t };\n\t ApiError.ENOTDIR = function ENOTDIR (path$$1) {\n\t return this.FileError(ErrorCode.ENOTDIR, path$$1);\n\t };\n\t ApiError.EPERM = function EPERM (path$$1) {\n\t return this.FileError(ErrorCode.EPERM, path$$1);\n\t };\n\t ApiError.ENOTEMPTY = function ENOTEMPTY (path$$1) {\n\t return this.FileError(ErrorCode.ENOTEMPTY, path$$1);\n\t };\n\t /**\n\t * @return A friendly error message.\n\t */\n\t ApiError.prototype.toString = function toString () {\n\t return this.message;\n\t };\n\t ApiError.prototype.toJSON = function toJSON () {\n\t return {\n\t errno: this.errno,\n\t code: this.code,\n\t path: this.path,\n\t stack: this.stack,\n\t message: this.message\n\t };\n\t };\n\t /**\n\t * Writes the API error into a buffer.\n\t */\n\t ApiError.prototype.writeToBuffer = function writeToBuffer (buffer$$1, i) {\n\t if ( buffer$$1 === void 0 ) buffer$$1 = new Buffer(this.bufferSize());\n\t if ( i === void 0 ) i = 0;\n\t\n\t var bytesWritten = buffer$$1.write(JSON.stringify(this.toJSON()), i + 4);\n\t buffer$$1.writeUInt32LE(bytesWritten, i);\n\t return buffer$$1;\n\t };\n\t /**\n\t * The size of the API error in buffer-form in bytes.\n\t */\n\t ApiError.prototype.bufferSize = function bufferSize () {\n\t // 4 bytes for string length.\n\t return 4 + Buffer.byteLength(JSON.stringify(this.toJSON()));\n\t };\n\t\n\t return ApiError;\n\t }(Error));\n\t\n\t\n\tvar api_error = Object.freeze({\n\t\tget ErrorCode () { return ErrorCode; },\n\t\tErrorStrings: ErrorStrings,\n\t\tApiError: ApiError\n\t});\n\t\n\tvar ActionType;\n\t(function (ActionType) {\n\t // Indicates that the code should not do anything.\n\t ActionType[ActionType[\"NOP\"] = 0] = \"NOP\";\n\t // Indicates that the code should throw an exception.\n\t ActionType[ActionType[\"THROW_EXCEPTION\"] = 1] = \"THROW_EXCEPTION\";\n\t // Indicates that the code should truncate the file, but only if it is a file.\n\t ActionType[ActionType[\"TRUNCATE_FILE\"] = 2] = \"TRUNCATE_FILE\";\n\t // Indicates that the code should create the file.\n\t ActionType[ActionType[\"CREATE_FILE\"] = 3] = \"CREATE_FILE\";\n\t})(ActionType || (ActionType = {}));\n\t/**\n\t * Represents one of the following file flags. A convenience object.\n\t *\n\t * * `'r'` - Open file for reading. An exception occurs if the file does not exist.\n\t * * `'r+'` - Open file for reading and writing. An exception occurs if the file does not exist.\n\t * * `'rs'` - Open file for reading in synchronous mode. Instructs the filesystem to not cache writes.\n\t * * `'rs+'` - Open file for reading and writing, and opens the file in synchronous mode.\n\t * * `'w'` - Open file for writing. The file is created (if it does not exist) or truncated (if it exists).\n\t * * `'wx'` - Like 'w' but opens the file in exclusive mode.\n\t * * `'w+'` - Open file for reading and writing. The file is created (if it does not exist) or truncated (if it exists).\n\t * * `'wx+'` - Like 'w+' but opens the file in exclusive mode.\n\t * * `'a'` - Open file for appending. The file is created if it does not exist.\n\t * * `'ax'` - Like 'a' but opens the file in exclusive mode.\n\t * * `'a+'` - Open file for reading and appending. The file is created if it does not exist.\n\t * * `'ax+'` - Like 'a+' but opens the file in exclusive mode.\n\t *\n\t * Exclusive mode ensures that the file path is newly created.\n\t */\n\tvar FileFlag = function FileFlag(flagStr) {\n\t this.flagStr = flagStr;\n\t if (FileFlag.validFlagStrs.indexOf(flagStr) < 0) {\n\t throw new ApiError(ErrorCode.EINVAL, \"Invalid flag: \" + flagStr);\n\t }\n\t};\n\t/**\n\t * Get an object representing the given file flag.\n\t * @param modeStr The string representing the flag\n\t * @return The FileFlag object representing the flag\n\t * @throw when the flag string is invalid\n\t */\n\tFileFlag.getFileFlag = function getFileFlag (flagStr) {\n\t // Check cache first.\n\t if (FileFlag.flagCache.hasOwnProperty(flagStr)) {\n\t return FileFlag.flagCache[flagStr];\n\t }\n\t return FileFlag.flagCache[flagStr] = new FileFlag(flagStr);\n\t};\n\t/**\n\t * Get the underlying flag string for this flag.\n\t */\n\tFileFlag.prototype.getFlagString = function getFlagString () {\n\t return this.flagStr;\n\t};\n\t/**\n\t * Returns true if the file is readable.\n\t */\n\tFileFlag.prototype.isReadable = function isReadable () {\n\t return this.flagStr.indexOf('r') !== -1 || this.flagStr.indexOf('+') !== -1;\n\t};\n\t/**\n\t * Returns true if the file is writeable.\n\t */\n\tFileFlag.prototype.isWriteable = function isWriteable () {\n\t return this.flagStr.indexOf('w') !== -1 || this.flagStr.indexOf('a') !== -1 || this.flagStr.indexOf('+') !== -1;\n\t};\n\t/**\n\t * Returns true if the file mode should truncate.\n\t */\n\tFileFlag.prototype.isTruncating = function isTruncating () {\n\t return this.flagStr.indexOf('w') !== -1;\n\t};\n\t/**\n\t * Returns true if the file is appendable.\n\t */\n\tFileFlag.prototype.isAppendable = function isAppendable () {\n\t return this.flagStr.indexOf('a') !== -1;\n\t};\n\t/**\n\t * Returns true if the file is open in synchronous mode.\n\t */\n\tFileFlag.prototype.isSynchronous = function isSynchronous () {\n\t return this.flagStr.indexOf('s') !== -1;\n\t};\n\t/**\n\t * Returns true if the file is open in exclusive mode.\n\t */\n\tFileFlag.prototype.isExclusive = function isExclusive () {\n\t return this.flagStr.indexOf('x') !== -1;\n\t};\n\t/**\n\t * Returns one of the static fields on this object that indicates the\n\t * appropriate response to the path existing.\n\t */\n\tFileFlag.prototype.pathExistsAction = function pathExistsAction () {\n\t if (this.isExclusive()) {\n\t return ActionType.THROW_EXCEPTION;\n\t }\n\t else if (this.isTruncating()) {\n\t return ActionType.TRUNCATE_FILE;\n\t }\n\t else {\n\t return ActionType.NOP;\n\t }\n\t};\n\t/**\n\t * Returns one of the static fields on this object that indicates the\n\t * appropriate response to the path not existing.\n\t */\n\tFileFlag.prototype.pathNotExistsAction = function pathNotExistsAction () {\n\t if ((this.isWriteable() || this.isAppendable()) && this.flagStr !== 'r+') {\n\t return ActionType.CREATE_FILE;\n\t }\n\t else {\n\t return ActionType.THROW_EXCEPTION;\n\t }\n\t};\n\t// Contains cached FileMode instances.\n\tFileFlag.flagCache = {};\n\t// Array of valid mode strings.\n\tFileFlag.validFlagStrs = ['r', 'r+', 'rs', 'rs+', 'w', 'wx', 'w+', 'wx+', 'a', 'ax', 'a+', 'ax+'];\n\t\n\t/**\n\t * Indicates the type of the given file. Applied to 'mode'.\n\t */\n\tvar FileType;\n\t(function (FileType) {\n\t FileType[FileType[\"FILE\"] = 32768] = \"FILE\";\n\t FileType[FileType[\"DIRECTORY\"] = 16384] = \"DIRECTORY\";\n\t FileType[FileType[\"SYMLINK\"] = 40960] = \"SYMLINK\";\n\t})(FileType || (FileType = {}));\n\t/**\n\t * Emulation of Node's `fs.Stats` object.\n\t *\n\t * Attribute descriptions are from `man 2 stat'\n\t * @see http://nodejs.org/api/fs.html#fs_class_fs_stats\n\t * @see http://man7.org/linux/man-pages/man2/stat.2.html\n\t * @class\n\t */\n\tvar Stats = function Stats(itemType, size, mode, atime, mtime, ctime) {\n\t if ( atime === void 0 ) atime = new Date();\n\t if ( mtime === void 0 ) mtime = new Date();\n\t if ( ctime === void 0 ) ctime = new Date();\n\t\n\t this.size = size;\n\t this.atime = atime;\n\t this.mtime = mtime;\n\t this.ctime = ctime;\n\t /**\n\t * UNSUPPORTED ATTRIBUTES\n\t * I assume no one is going to need these details, although we could fake\n\t * appropriate values if need be.\n\t */\n\t // ID of device containing file\n\t this.dev = 0;\n\t // inode number\n\t this.ino = 0;\n\t // device ID (if special file)\n\t this.rdev = 0;\n\t // number of hard links\n\t this.nlink = 1;\n\t // blocksize for file system I/O\n\t this.blksize = 4096;\n\t // @todo Maybe support these? atm, it's a one-user filesystem.\n\t // user ID of owner\n\t this.uid = 0;\n\t // group ID of owner\n\t this.gid = 0;\n\t // time file was created (currently unsupported)\n\t this.birthtime = new Date(0);\n\t // XXX: Some file systems stash data on stats objects.\n\t this.fileData = null;\n\t if (!mode) {\n\t switch (itemType) {\n\t case FileType.FILE:\n\t this.mode = 0x1a4;\n\t break;\n\t case FileType.DIRECTORY:\n\t default:\n\t this.mode = 0x1ff;\n\t }\n\t }\n\t else {\n\t this.mode = mode;\n\t }\n\t // number of 512B blocks allocated\n\t this.blocks = Math.ceil(size / 512);\n\t // Check if mode also includes top-most bits, which indicate the file's\n\t // type.\n\t if (this.mode < 0x1000) {\n\t this.mode |= itemType;\n\t }\n\t};\n\tStats.fromBuffer = function fromBuffer (buffer$$1) {\n\t var size = buffer$$1.readUInt32LE(0), mode = buffer$$1.readUInt32LE(4), atime = buffer$$1.readDoubleLE(8), mtime = buffer$$1.readDoubleLE(16), ctime = buffer$$1.readDoubleLE(24);\n\t return new Stats(mode & 0xF000, size, mode & 0xFFF, new Date(atime), new Date(mtime), new Date(ctime));\n\t};\n\tStats.prototype.toBuffer = function toBuffer () {\n\t var buffer$$1 = new Buffer(32);\n\t buffer$$1.writeUInt32LE(this.size, 0);\n\t buffer$$1.writeUInt32LE(this.mode, 4);\n\t buffer$$1.writeDoubleLE(this.atime.getTime(), 8);\n\t buffer$$1.writeDoubleLE(this.mtime.getTime(), 16);\n\t buffer$$1.writeDoubleLE(this.ctime.getTime(), 24);\n\t return buffer$$1;\n\t};\n\t/**\n\t * **Nonstandard**: Clone the stats object.\n\t * @return [BrowserFS.node.fs.Stats]\n\t */\n\tStats.prototype.clone = function clone () {\n\t return new Stats(this.mode & 0xF000, this.size, this.mode & 0xFFF, this.atime, this.mtime, this.ctime);\n\t};\n\t/**\n\t * @return [Boolean] True if this item is a file.\n\t */\n\tStats.prototype.isFile = function isFile () {\n\t return (this.mode & 0xF000) === FileType.FILE;\n\t};\n\t/**\n\t * @return [Boolean] True if this item is a directory.\n\t */\n\tStats.prototype.isDirectory = function isDirectory () {\n\t return (this.mode & 0xF000) === FileType.DIRECTORY;\n\t};\n\t/**\n\t * @return [Boolean] True if this item is a symbolic link (only valid through lstat)\n\t */\n\tStats.prototype.isSymbolicLink = function isSymbolicLink () {\n\t return (this.mode & 0xF000) === FileType.SYMLINK;\n\t};\n\t/**\n\t * Change the mode of the file. We use this helper function to prevent messing\n\t * up the type of the file, which is encoded in mode.\n\t */\n\tStats.prototype.chmod = function chmod (mode) {\n\t this.mode = (this.mode & 0xF000) | mode;\n\t};\n\t// We don't support the following types of files.\n\tStats.prototype.isSocket = function isSocket () {\n\t return false;\n\t};\n\tStats.prototype.isBlockDevice = function isBlockDevice () {\n\t return false;\n\t};\n\tStats.prototype.isCharacterDevice = function isCharacterDevice () {\n\t return false;\n\t};\n\tStats.prototype.isFIFO = function isFIFO () {\n\t return false;\n\t};\n\t\n\t/**\n\t * Wraps a callback function. Used for unit testing. Defaults to a NOP.\n\t */\n\tvar wrapCb = function (cb, numArgs) {\n\t return cb;\n\t};\n\tfunction assertRoot(fs) {\n\t if (fs) {\n\t return fs;\n\t }\n\t throw new ApiError(ErrorCode.EIO, \"Initialize BrowserFS with a file system using BrowserFS.initialize(filesystem)\");\n\t}\n\tfunction normalizeMode(mode, def) {\n\t switch (typeof mode) {\n\t case 'number':\n\t // (path, flag, mode, cb?)\n\t return mode;\n\t case 'string':\n\t // (path, flag, modeString, cb?)\n\t var trueMode = parseInt(mode, 8);\n\t if (!isNaN(trueMode)) {\n\t return trueMode;\n\t }\n\t // Invalid string.\n\t return def;\n\t default:\n\t return def;\n\t }\n\t}\n\tfunction normalizeTime(time) {\n\t if (time instanceof Date) {\n\t return time;\n\t }\n\t else if (typeof time === 'number') {\n\t return new Date(time * 1000);\n\t }\n\t else {\n\t throw new ApiError(ErrorCode.EINVAL, \"Invalid time.\");\n\t }\n\t}\n\tfunction normalizePath(p) {\n\t // Node doesn't allow null characters in paths.\n\t if (p.indexOf('\\u0000') >= 0) {\n\t throw new ApiError(ErrorCode.EINVAL, 'Path must be a string without null bytes.');\n\t }\n\t else if (p === '') {\n\t throw new ApiError(ErrorCode.EINVAL, 'Path must not be empty.');\n\t }\n\t return path.resolve(p);\n\t}\n\tfunction normalizeOptions(options, defEnc, defFlag, defMode) {\n\t switch (typeof options) {\n\t case 'object':\n\t return {\n\t encoding: typeof options['encoding'] !== 'undefined' ? options['encoding'] : defEnc,\n\t flag: typeof options['flag'] !== 'undefined' ? options['flag'] : defFlag,\n\t mode: normalizeMode(options['mode'], defMode)\n\t };\n\t case 'string':\n\t return {\n\t encoding: options,\n\t flag: defFlag,\n\t mode: defMode\n\t };\n\t default:\n\t return {\n\t encoding: defEnc,\n\t flag: defFlag,\n\t mode: defMode\n\t };\n\t }\n\t}\n\t// The default callback is a NOP.\n\tfunction nopCb() {\n\t // NOP.\n\t}\n\t/**\n\t * The node frontend to all filesystems.\n\t * This layer handles:\n\t *\n\t * * Sanity checking inputs.\n\t * * Normalizing paths.\n\t * * Resetting stack depth for asynchronous operations which may not go through\n\t * the browser by wrapping all input callbacks using `setImmediate`.\n\t * * Performing the requested operation through the filesystem or the file\n\t * descriptor, as appropriate.\n\t * * Handling optional arguments and setting default arguments.\n\t * @see http://nodejs.org/api/fs.html\n\t * @class\n\t */\n\tvar FS = function FS() {\n\t /* tslint:enable:variable-name */\n\t this.F_OK = 0;\n\t this.R_OK = 4;\n\t this.W_OK = 2;\n\t this.X_OK = 1;\n\t this.root = null;\n\t this.fdMap = {};\n\t this.nextFd = 100;\n\t};\n\tFS.prototype.initialize = function initialize (rootFS) {\n\t if (!rootFS.constructor.isAvailable()) {\n\t throw new ApiError(ErrorCode.EINVAL, 'Tried to instantiate BrowserFS with an unavailable file system.');\n\t }\n\t return this.root = rootFS;\n\t};\n\t/**\n\t * converts Date or number to a fractional UNIX timestamp\n\t * Grabbed from NodeJS sources (lib/fs.js)\n\t */\n\tFS.prototype._toUnixTimestamp = function _toUnixTimestamp (time) {\n\t if (typeof time === 'number') {\n\t return time;\n\t }\n\t else if (time instanceof Date) {\n\t return time.getTime() / 1000;\n\t }\n\t throw new Error(\"Cannot parse time: \" + time);\n\t};\n\t/**\n\t * **NONSTANDARD**: Grab the FileSystem instance that backs this API.\n\t * @return [BrowserFS.FileSystem | null] Returns null if the file system has\n\t * not been initialized.\n\t */\n\tFS.prototype.getRootFS = function getRootFS () {\n\t if (this.root) {\n\t return this.root;\n\t }\n\t else {\n\t return null;\n\t }\n\t};\n\t// FILE OR DIRECTORY METHODS\n\t/**\n\t * Asynchronous rename. No arguments other than a possible exception are given\n\t * to the completion callback.\n\t * @param oldPath\n\t * @param newPath\n\t * @param callback\n\t */\n\tFS.prototype.rename = function rename (oldPath, newPath, cb) {\n\t if ( cb === void 0 ) cb = nopCb;\n\t\n\t var newCb = wrapCb(cb, 1);\n\t try {\n\t assertRoot(this.root).rename(normalizePath(oldPath), normalizePath(newPath), newCb);\n\t }\n\t catch (e) {\n\t newCb(e);\n\t }\n\t};\n\t/**\n\t * Synchronous rename.\n\t * @param oldPath\n\t * @param newPath\n\t */\n\tFS.prototype.renameSync = function renameSync (oldPath, newPath) {\n\t assertRoot(this.root).renameSync(normalizePath(oldPath), normalizePath(newPath));\n\t};\n\t/**\n\t * Test whether or not the given path exists by checking with the file system.\n\t * Then call the callback argument with either true or false.\n\t * @example Sample invocation\n\t * fs.exists('/etc/passwd', function (exists) {\n\t * util.debug(exists ? \"it's there\" : \"no passwd!\");\n\t * });\n\t * @param path\n\t * @param callback\n\t */\n\tFS.prototype.exists = function exists (path$$1, cb) {\n\t if ( cb === void 0 ) cb = nopCb;\n\t\n\t var newCb = wrapCb(cb, 1);\n\t try {\n\t return assertRoot(this.root).exists(normalizePath(path$$1), newCb);\n\t }\n\t catch (e) {\n\t // Doesn't return an error. If something bad happens, we assume it just\n\t // doesn't exist.\n\t return newCb(false);\n\t }\n\t};\n\t/**\n\t * Test whether or not the given path exists by checking with the file system.\n\t * @param path\n\t * @return [boolean]\n\t */\n\tFS.prototype.existsSync = function existsSync (path$$1) {\n\t try {\n\t return assertRoot(this.root).existsSync(normalizePath(path$$1));\n\t }\n\t catch (e) {\n\t // Doesn't return an error. If something bad happens, we assume it just\n\t // doesn't exist.\n\t return false;\n\t }\n\t};\n\t/**\n\t * Asynchronous `stat`.\n\t * @param path\n\t * @param callback\n\t */\n\tFS.prototype.stat = function stat (path$$1, cb) {\n\t if ( cb === void 0 ) cb = nopCb;\n\t\n\t var newCb = wrapCb(cb, 2);\n\t try {\n\t return assertRoot(this.root).stat(normalizePath(path$$1), false, newCb);\n\t }\n\t catch (e) {\n\t return newCb(e);\n\t }\n\t};\n\t/**\n\t * Synchronous `stat`.\n\t * @param path\n\t * @return [BrowserFS.node.fs.Stats]\n\t */\n\tFS.prototype.statSync = function statSync (path$$1) {\n\t return assertRoot(this.root).statSync(normalizePath(path$$1), false);\n\t};\n\t/**\n\t * Asynchronous `lstat`.\n\t * `lstat()` is identical to `stat()`, except that if path is a symbolic link,\n\t * then the link itself is stat-ed, not the file that it refers to.\n\t * @param path\n\t * @param callback\n\t */\n\tFS.prototype.lstat = function lstat (path$$1, cb) {\n\t if ( cb === void 0 ) cb = nopCb;\n\t\n\t var newCb = wrapCb(cb, 2);\n\t try {\n\t return assertRoot(this.root).stat(normalizePath(path$$1), true, newCb);\n\t }\n\t catch (e) {\n\t return newCb(e);\n\t }\n\t};\n\t/**\n\t * Synchronous `lstat`.\n\t * `lstat()` is identical to `stat()`, except that if path is a symbolic link,\n\t * then the link itself is stat-ed, not the file that it refers to.\n\t * @param path\n\t * @return [BrowserFS.node.fs.Stats]\n\t */\n\tFS.prototype.lstatSync = function lstatSync (path$$1) {\n\t return assertRoot(this.root).statSync(normalizePath(path$$1), true);\n\t};\n\tFS.prototype.truncate = function truncate (path$$1, arg2, cb) {\n\t if ( arg2 === void 0 ) arg2 = 0;\n\t if ( cb === void 0 ) cb = nopCb;\n\t\n\t var len = 0;\n\t if (typeof arg2 === 'function') {\n\t cb = arg2;\n\t }\n\t else if (typeof arg2 === 'number') {\n\t len = arg2;\n\t }\n\t var newCb = wrapCb(cb, 1);\n\t try {\n\t if (len < 0) {\n\t throw new ApiError(ErrorCode.EINVAL);\n\t }\n\t return assertRoot(this.root).truncate(normalizePath(path$$1), len, newCb);\n\t }\n\t catch (e) {\n\t return newCb(e);\n\t }\n\t};\n\t/**\n\t * Synchronous `truncate`.\n\t * @param path\n\t * @param len\n\t */\n\tFS.prototype.truncateSync = function truncateSync (path$$1, len) {\n\t if ( len === void 0 ) len = 0;\n\t\n\t if (len < 0) {\n\t throw new ApiError(ErrorCode.EINVAL);\n\t }\n\t return assertRoot(this.root).truncateSync(normalizePath(path$$1), len);\n\t};\n\t/**\n\t * Asynchronous `unlink`.\n\t * @param path\n\t * @param callback\n\t */\n\tFS.prototype.unlink = function unlink (path$$1, cb) {\n\t if ( cb === void 0 ) cb = nopCb;\n\t\n\t var newCb = wrapCb(cb, 1);\n\t try {\n\t return assertRoot(this.root).unlink(normalizePath(path$$1), newCb);\n\t }\n\t catch (e) {\n\t return newCb(e);\n\t }\n\t};\n\t/**\n\t * Synchronous `unlink`.\n\t * @param path\n\t */\n\tFS.prototype.unlinkSync = function unlinkSync (path$$1) {\n\t return assertRoot(this.root).unlinkSync(normalizePath(path$$1));\n\t};\n\tFS.prototype.open = function open (path$$1, flag, arg2, cb) {\n\t var this$1 = this;\n\t if ( cb === void 0 ) cb = nopCb;\n\t\n\t var mode = normalizeMode(arg2, 0x1a4);\n\t cb = typeof arg2 === 'function' ? arg2 : cb;\n\t var newCb = wrapCb(cb, 2);\n\t try {\n\t assertRoot(this.root).open(normalizePath(path$$1), FileFlag.getFileFlag(flag), mode, function (e, file) {\n\t if (file) {\n\t newCb(e, this$1.getFdForFile(file));\n\t }\n\t else {\n\t newCb(e);\n\t }\n\t });\n\t }\n\t catch (e) {\n\t newCb(e);\n\t }\n\t};\n\t/**\n\t * Synchronous file open.\n\t * @see http://www.manpagez.com/man/2/open/\n\t * @param path\n\t * @param flags\n\t * @param mode defaults to `0644`\n\t * @return [BrowserFS.File]\n\t */\n\tFS.prototype.openSync = function openSync (path$$1, flag, mode) {\n\t if ( mode === void 0 ) mode = 0x1a4;\n\t\n\t return this.getFdForFile(assertRoot(this.root).openSync(normalizePath(path$$1), FileFlag.getFileFlag(flag), normalizeMode(mode, 0x1a4)));\n\t};\n\tFS.prototype.readFile = function readFile (filename, arg2, cb) {\n\t if ( arg2 === void 0 ) arg2 = {};\n\t if ( cb === void 0 ) cb = nopCb;\n\t\n\t var options = normalizeOptions(arg2, null, 'r', null);\n\t cb = typeof arg2 === 'function' ? arg2 : cb;\n\t var newCb = wrapCb(cb, 2);\n\t try {\n\t var flag = FileFlag.getFileFlag(options['flag']);\n\t if (!flag.isReadable()) {\n\t return newCb(new ApiError(ErrorCode.EINVAL, 'Flag passed to readFile must allow for reading.'));\n\t }\n\t return assertRoot(this.root).readFile(normalizePath(filename), options.encoding, flag, newCb);\n\t }\n\t catch (e) {\n\t return newCb(e);\n\t }\n\t};\n\tFS.prototype.readFileSync = function readFileSync (filename, arg2) {\n\t if ( arg2 === void 0 ) arg2 = {};\n\t\n\t var options = normalizeOptions(arg2, null, 'r', null);\n\t var flag = FileFlag.getFileFlag(options.flag);\n\t if (!flag.isReadable()) {\n\t throw new ApiError(ErrorCode.EINVAL, 'Flag passed to readFile must allow for reading.');\n\t }\n\t return assertRoot(this.root).readFileSync(normalizePath(filename), options.encoding, flag);\n\t};\n\tFS.prototype.writeFile = function writeFile (filename, data, arg3, cb) {\n\t if ( arg3 === void 0 ) arg3 = {};\n\t if ( cb === void 0 ) cb = nopCb;\n\t\n\t var options = normalizeOptions(arg3, 'utf8', 'w', 0x1a4);\n\t cb = typeof arg3 === 'function' ? arg3 : cb;\n\t var newCb = wrapCb(cb, 1);\n\t try {\n\t var flag = FileFlag.getFileFlag(options.flag);\n\t if (!flag.isWriteable()) {\n\t return newCb(new ApiError(ErrorCode.EINVAL, 'Flag passed to writeFile must allow for writing.'));\n\t }\n\t return assertRoot(this.root).writeFile(normalizePath(filename), data, options.encoding, flag, options.mode, newCb);\n\t }\n\t catch (e) {\n\t return newCb(e);\n\t }\n\t};\n\tFS.prototype.writeFileSync = function writeFileSync (filename, data, arg3) {\n\t var options = normalizeOptions(arg3, 'utf8', 'w', 0x1a4);\n\t var flag = FileFlag.getFileFlag(options.flag);\n\t if (!flag.isWriteable()) {\n\t throw new ApiError(ErrorCode.EINVAL, 'Flag passed to writeFile must allow for writing.');\n\t }\n\t return assertRoot(this.root).writeFileSync(normalizePath(filename), data, options.encoding, flag, options.mode);\n\t};\n\tFS.prototype.appendFile = function appendFile (filename, data, arg3, cb) {\n\t if ( cb === void 0 ) cb = nopCb;\n\t\n\t var options = normalizeOptions(arg3, 'utf8', 'a', 0x1a4);\n\t cb = typeof arg3 === 'function' ? arg3 : cb;\n\t var newCb = wrapCb(cb, 1);\n\t try {\n\t var flag = FileFlag.getFileFlag(options.flag);\n\t if (!flag.isAppendable()) {\n\t return newCb(new ApiError(ErrorCode.EINVAL, 'Flag passed to appendFile must allow for appending.'));\n\t }\n\t assertRoot(this.root).appendFile(normalizePath(filename), data, options.encoding, flag, options.mode, newCb);\n\t }\n\t catch (e) {\n\t newCb(e);\n\t }\n\t};\n\tFS.prototype.appendFileSync = function appendFileSync (filename, data, arg3) {\n\t var options = normalizeOptions(arg3, 'utf8', 'a', 0x1a4);\n\t var flag = FileFlag.getFileFlag(options.flag);\n\t if (!flag.isAppendable()) {\n\t throw new ApiError(ErrorCode.EINVAL, 'Flag passed to appendFile must allow for appending.');\n\t }\n\t return assertRoot(this.root).appendFileSync(normalizePath(filename), data, options.encoding, flag, options.mode);\n\t};\n\t// FILE DESCRIPTOR METHODS\n\t/**\n\t * Asynchronous `fstat`.\n\t * `fstat()` is identical to `stat()`, except that the file to be stat-ed is\n\t * specified by the file descriptor `fd`.\n\t * @param fd\n\t * @param callback\n\t */\n\tFS.prototype.fstat = function fstat (fd, cb) {\n\t if ( cb === void 0 ) cb = nopCb;\n\t\n\t var newCb = wrapCb(cb, 2);\n\t try {\n\t var file = this.fd2file(fd);\n\t file.stat(newCb);\n\t }\n\t catch (e) {\n\t newCb(e);\n\t }\n\t};\n\t/**\n\t * Synchronous `fstat`.\n\t * `fstat()` is identical to `stat()`, except that the file to be stat-ed is\n\t * specified by the file descriptor `fd`.\n\t * @param fd\n\t * @return [BrowserFS.node.fs.Stats]\n\t */\n\tFS.prototype.fstatSync = function fstatSync (fd) {\n\t return this.fd2file(fd).statSync();\n\t};\n\t/**\n\t * Asynchronous close.\n\t * @param fd\n\t * @param callback\n\t */\n\tFS.prototype.close = function close (fd, cb) {\n\t var this$1 = this;\n\t if ( cb === void 0 ) cb = nopCb;\n\t\n\t var newCb = wrapCb(cb, 1);\n\t try {\n\t this.fd2file(fd).close(function (e) {\n\t if (!e) {\n\t this$1.closeFd(fd);\n\t }\n\t newCb(e);\n\t });\n\t }\n\t catch (e) {\n\t newCb(e);\n\t }\n\t};\n\t/**\n\t * Synchronous close.\n\t * @param fd\n\t */\n\tFS.prototype.closeSync = function closeSync (fd) {\n\t this.fd2file(fd).closeSync();\n\t this.closeFd(fd);\n\t};\n\tFS.prototype.ftruncate = function ftruncate (fd, arg2, cb) {\n\t if ( cb === void 0 ) cb = nopCb;\n\t\n\t var length = typeof arg2 === 'number' ? arg2 : 0;\n\t cb = typeof arg2 === 'function' ? arg2 : cb;\n\t var newCb = wrapCb(cb, 1);\n\t try {\n\t var file = this.fd2file(fd);\n\t if (length < 0) {\n\t throw new ApiError(ErrorCode.EINVAL);\n\t }\n\t file.truncate(length, newCb);\n\t }\n\t catch (e) {\n\t newCb(e);\n\t }\n\t};\n\t/**\n\t * Synchronous ftruncate.\n\t * @param fd\n\t * @param len\n\t */\n\tFS.prototype.ftruncateSync = function ftruncateSync (fd, len) {\n\t if ( len === void 0 ) len = 0;\n\t\n\t var file = this.fd2file(fd);\n\t if (len < 0) {\n\t throw new ApiError(ErrorCode.EINVAL);\n\t }\n\t file.truncateSync(len);\n\t};\n\t/**\n\t * Asynchronous fsync.\n\t * @param fd\n\t * @param callback\n\t */\n\tFS.prototype.fsync = function fsync (fd, cb) {\n\t if ( cb === void 0 ) cb = nopCb;\n\t\n\t var newCb = wrapCb(cb, 1);\n\t try {\n\t this.fd2file(fd).sync(newCb);\n\t }\n\t catch (e) {\n\t newCb(e);\n\t }\n\t};\n\t/**\n\t * Synchronous fsync.\n\t * @param fd\n\t */\n\tFS.prototype.fsyncSync = function fsyncSync (fd) {\n\t this.fd2file(fd).syncSync();\n\t};\n\t/**\n\t * Asynchronous fdatasync.\n\t * @param fd\n\t * @param callback\n\t */\n\tFS.prototype.fdatasync = function fdatasync (fd, cb) {\n\t if ( cb === void 0 ) cb = nopCb;\n\t\n\t var newCb = wrapCb(cb, 1);\n\t try {\n\t this.fd2file(fd).datasync(newCb);\n\t }\n\t catch (e) {\n\t newCb(e);\n\t }\n\t};\n\t/**\n\t * Synchronous fdatasync.\n\t * @param fd\n\t */\n\tFS.prototype.fdatasyncSync = function fdatasyncSync (fd) {\n\t this.fd2file(fd).datasyncSync();\n\t};\n\tFS.prototype.write = function write (fd, arg2, arg3, arg4, arg5, cb) {\n\t if ( cb === void 0 ) cb = nopCb;\n\t\n\t var buffer$$1, offset, length, position = null;\n\t if (typeof arg2 === 'string') {\n\t // Signature 1: (fd, string, [position?, [encoding?]], cb?)\n\t var encoding = 'utf8';\n\t switch (typeof arg3) {\n\t case 'function':\n\t // (fd, string, cb)\n\t cb = arg3;\n\t break;\n\t case 'number':\n\t // (fd, string, position, encoding?, cb?)\n\t position = arg3;\n\t encoding = typeof arg4 === 'string' ? arg4 : 'utf8';\n\t cb = typeof arg5 === 'function' ? arg5 : cb;\n\t break;\n\t default:\n\t // ...try to find the callback and get out of here!\n\t cb = typeof arg4 === 'function' ? arg4 : typeof arg5 === 'function' ? arg5 : cb;\n\t return cb(new ApiError(ErrorCode.EINVAL, 'Invalid arguments.'));\n\t }\n\t buffer$$1 = new Buffer(arg2, encoding);\n\t offset = 0;\n\t length = buffer$$1.length;\n\t }\n\t else {\n\t // Signature 2: (fd, buffer, offset, length, position?, cb?)\n\t buffer$$1 = arg2;\n\t offset = arg3;\n\t length = arg4;\n\t position = typeof arg5 === 'number' ? arg5 : null;\n\t cb = typeof arg5 === 'function' ? arg5 : cb;\n\t }\n\t var newCb = wrapCb(cb, 3);\n\t try {\n\t var file = this.fd2file(fd);\n\t if (position === undefined || position === null) {\n\t position = file.getPos();\n\t }\n\t file.write(buffer$$1, offset, length, position, newCb);\n\t }\n\t catch (e) {\n\t newCb(e);\n\t }\n\t};\n\tFS.prototype.writeSync = function writeSync (fd, arg2, arg3, arg4, arg5) {\n\t var buffer$$1, offset = 0, length, position;\n\t if (typeof arg2 === 'string') {\n\t // Signature 1: (fd, string, [position?, [encoding?]])\n\t position = typeof arg3 === 'number' ? arg3 : null;\n\t var encoding = typeof arg4 === 'string' ? arg4 : 'utf8';\n\t offset = 0;\n\t buffer$$1 = new Buffer(arg2, encoding);\n\t length = buffer$$1.length;\n\t }\n\t else {\n\t // Signature 2: (fd, buffer, offset, length, position?)\n\t buffer$$1 = arg2;\n\t offset = arg3;\n\t length = arg4;\n\t position = typeof arg5 === 'number' ? arg5 : null;\n\t }\n\t var file = this.fd2file(fd);\n\t if (position === undefined || position === null) {\n\t position = file.getPos();\n\t }\n\t return file.writeSync(buffer$$1, offset, length, position);\n\t};\n\tFS.prototype.read = function read (fd, arg2, arg3, arg4, arg5, cb) {\n\t if ( cb === void 0 ) cb = nopCb;\n\t\n\t var position, offset, length, buffer$$1, newCb;\n\t if (typeof arg2 === 'number') {\n\t // legacy interface\n\t // (fd, length, position, encoding, callback)\n\t length = arg2;\n\t position = arg3;\n\t var encoding = arg4;\n\t cb = typeof arg5 === 'function' ? arg5 : cb;\n\t offset = 0;\n\t buffer$$1 = new Buffer(length);\n\t // XXX: Inefficient.\n\t // Wrap the cb so we shelter upper layers of the API from these\n\t // shenanigans.\n\t newCb = wrapCb(function (err, bytesRead, buf) {\n\t if (err) {\n\t return cb(err);\n\t }\n\t cb(err, buf.toString(encoding), bytesRead);\n\t }, 3);\n\t }\n\t else {\n\t buffer$$1 = arg2;\n\t offset = arg3;\n\t length = arg4;\n\t position = arg5;\n\t newCb = wrapCb(cb, 3);\n\t }\n\t try {\n\t var file = this.fd2file(fd);\n\t if (position === undefined || position === null) {\n\t position = file.getPos();\n\t }\n\t file.read(buffer$$1, offset, length, position, newCb);\n\t }\n\t catch (e) {\n\t newCb(e);\n\t }\n\t};\n\tFS.prototype.readSync = function readSync (fd, arg2, arg3, arg4, arg5) {\n\t var shenanigans = false;\n\t var buffer$$1, offset, length, position, encoding = 'utf8';\n\t if (typeof arg2 === 'number') {\n\t length = arg2;\n\t position = arg3;\n\t encoding = arg4;\n\t offset = 0;\n\t buffer$$1 = new Buffer(length);\n\t shenanigans = true;\n\t }\n\t else {\n\t buffer$$1 = arg2;\n\t offset = arg3;\n\t length = arg4;\n\t position = arg5;\n\t }\n\t var file = this.fd2file(fd);\n\t if (position === undefined || position === null) {\n\t position = file.getPos();\n\t }\n\t var rv = file.readSync(buffer$$1, offset, length, position);\n\t if (!shenanigans) {\n\t return rv;\n\t }\n\t else {\n\t return [buffer$$1.toString(encoding), rv];\n\t }\n\t};\n\t/**\n\t * Asynchronous `fchown`.\n\t * @param fd\n\t * @param uid\n\t * @param gid\n\t * @param callback\n\t */\n\tFS.prototype.fchown = function fchown (fd, uid, gid, callback) {\n\t if ( callback === void 0 ) callback = nopCb;\n\t\n\t var newCb = wrapCb(callback, 1);\n\t try {\n\t this.fd2file(fd).chown(uid, gid, newCb);\n\t }\n\t catch (e) {\n\t newCb(e);\n\t }\n\t};\n\t/**\n\t * Synchronous `fchown`.\n\t * @param fd\n\t * @param uid\n\t * @param gid\n\t */\n\tFS.prototype.fchownSync = function fchownSync (fd, uid, gid) {\n\t this.fd2file(fd).chownSync(uid, gid);\n\t};\n\t/**\n\t * Asynchronous `fchmod`.\n\t * @param fd\n\t * @param mode\n\t * @param callback\n\t */\n\tFS.prototype.fchmod = function fchmod (fd, mode, cb) {\n\t var newCb = wrapCb(cb, 1);\n\t try {\n\t var numMode = typeof mode === 'string' ? parseInt(mode, 8) : mode;\n\t this.fd2file(fd).chmod(numMode, newCb);\n\t }\n\t catch (e) {\n\t newCb(e);\n\t }\n\t};\n\t/**\n\t * Synchronous `fchmod`.\n\t * @param fd\n\t * @param mode\n\t */\n\tFS.prototype.fchmodSync = function fchmodSync (fd, mode) {\n\t var numMode = typeof mode === 'string' ? parseInt(mode, 8) : mode;\n\t this.fd2file(fd).chmodSync(numMode);\n\t};\n\t/**\n\t * Change the file timestamps of a file referenced by the supplied file\n\t * descriptor.\n\t * @param fd\n\t * @param atime\n\t * @param mtime\n\t * @param callback\n\t */\n\tFS.prototype.futimes = function futimes (fd, atime, mtime, cb) {\n\t if ( cb === void 0 ) cb = nopCb;\n\t\n\t var newCb = wrapCb(cb, 1);\n\t try {\n\t var file = this.fd2file(fd);\n\t if (typeof atime === 'number') {\n\t atime = new Date(atime * 1000);\n\t }\n\t if (typeof mtime === 'number') {\n\t mtime = new Date(mtime * 1000);\n\t }\n\t file.utimes(atime, mtime, newCb);\n\t }\n\t catch (e) {\n\t newCb(e);\n\t }\n\t};\n\t/**\n\t * Change the file timestamps of a file referenced by the supplied file\n\t * descriptor.\n\t * @param fd\n\t * @param atime\n\t * @param mtime\n\t */\n\tFS.prototype.futimesSync = function futimesSync (fd, atime, mtime) {\n\t this.fd2file(fd).utimesSync(normalizeTime(atime), normalizeTime(mtime));\n\t};\n\t// DIRECTORY-ONLY METHODS\n\t/**\n\t * Asynchronous `rmdir`.\n\t * @param path\n\t * @param callback\n\t */\n\tFS.prototype.rmdir = function rmdir (path$$1, cb) {\n\t if ( cb === void 0 ) cb = nopCb;\n\t\n\t var newCb = wrapCb(cb, 1);\n\t try {\n\t path$$1 = normalizePath(path$$1);\n\t assertRoot(this.root).rmdir(path$$1, newCb);\n\t }\n\t catch (e) {\n\t newCb(e);\n\t }\n\t};\n\t/**\n\t * Synchronous `rmdir`.\n\t * @param path\n\t */\n\tFS.prototype.rmdirSync = function rmdirSync (path$$1) {\n\t path$$1 = normalizePath(path$$1);\n\t return assertRoot(this.root).rmdirSync(path$$1);\n\t};\n\t/**\n\t * Asynchronous `mkdir`.\n\t * @param path\n\t * @param mode defaults to `0777`\n\t * @param callback\n\t */\n\tFS.prototype.mkdir = function mkdir (path$$1, mode, cb) {\n\t if ( cb === void 0 ) cb = nopCb;\n\t\n\t if (typeof mode === 'function') {\n\t cb = mode;\n\t mode = 0x1ff;\n\t }\n\t var newCb = wrapCb(cb, 1);\n\t try {\n\t path$$1 = normalizePath(path$$1);\n\t assertRoot(this.root).mkdir(path$$1, mode, newCb);\n\t }\n\t catch (e) {\n\t newCb(e);\n\t }\n\t};\n\t/**\n\t * Synchronous `mkdir`.\n\t * @param path\n\t * @param mode defaults to `0777`\n\t */\n\tFS.prototype.mkdirSync = function mkdirSync (path$$1, mode) {\n\t assertRoot(this.root).mkdirSync(normalizePath(path$$1), normalizeMode(mode, 0x1ff));\n\t};\n\t/**\n\t * Asynchronous `readdir`. Reads the contents of a directory.\n\t * The callback gets two arguments `(err, files)` where `files` is an array of\n\t * the names of the files in the directory excluding `'.'` and `'..'`.\n\t * @param path\n\t * @param callback\n\t */\n\tFS.prototype.readdir = function readdir (path$$1, cb) {\n\t if ( cb === void 0 ) cb = nopCb;\n\t\n\t var newCb = wrapCb(cb, 2);\n\t try {\n\t path$$1 = normalizePath(path$$1);\n\t assertRoot(this.root).readdir(path$$1, newCb);\n\t }\n\t catch (e) {\n\t newCb(e);\n\t }\n\t};\n\t/**\n\t * Synchronous `readdir`. Reads the contents of a directory.\n\t * @param path\n\t * @return [String[]]\n\t */\n\tFS.prototype.readdirSync = function readdirSync (path$$1) {\n\t path$$1 = normalizePath(path$$1);\n\t return assertRoot(this.root).readdirSync(path$$1);\n\t};\n\t// SYMLINK METHODS\n\t/**\n\t * Asynchronous `link`.\n\t * @param srcpath\n\t * @param dstpath\n\t * @param callback\n\t */\n\tFS.prototype.link = function link (srcpath, dstpath, cb) {\n\t if ( cb === void 0 ) cb = nopCb;\n\t\n\t var newCb = wrapCb(cb, 1);\n\t try {\n\t srcpath = normalizePath(srcpath);\n\t dstpath = normalizePath(dstpath);\n\t assertRoot(this.root).link(srcpath, dstpath, newCb);\n\t }\n\t catch (e) {\n\t newCb(e);\n\t }\n\t};\n\t/**\n\t * Synchronous `link`.\n\t * @param srcpath\n\t * @param dstpath\n\t */\n\tFS.prototype.linkSync = function linkSync (srcpath, dstpath) {\n\t srcpath = normalizePath(srcpath);\n\t dstpath = normalizePath(dstpath);\n\t return assertRoot(this.root).linkSync(srcpath, dstpath);\n\t};\n\tFS.prototype.symlink = function symlink (srcpath, dstpath, arg3, cb) {\n\t if ( cb === void 0 ) cb = nopCb;\n\t\n\t var type = typeof arg3 === 'string' ? arg3 : 'file';\n\t cb = typeof arg3 === 'function' ? arg3 : cb;\n\t var newCb = wrapCb(cb, 1);\n\t try {\n\t if (type !== 'file' && type !== 'dir') {\n\t return newCb(new ApiError(ErrorCode.EINVAL, \"Invalid type: \" + type));\n\t }\n\t srcpath = normalizePath(srcpath);\n\t dstpath = normalizePath(dstpath);\n\t assertRoot(this.root).symlink(srcpath, dstpath, type, newCb);\n\t }\n\t catch (e) {\n\t newCb(e);\n\t }\n\t};\n\t/**\n\t * Synchronous `symlink`.\n\t * @param srcpath\n\t * @param dstpath\n\t * @param type can be either `'dir'` or `'file'` (default is `'file'`)\n\t */\n\tFS.prototype.symlinkSync = function symlinkSync (srcpath, dstpath, type) {\n\t if (!type) {\n\t type = 'file';\n\t }\n\t else if (type !== 'file' && type !== 'dir') {\n\t throw new ApiError(ErrorCode.EINVAL, \"Invalid type: \" + type);\n\t }\n\t srcpath = normalizePath(srcpath);\n\t dstpath = normalizePath(dstpath);\n\t return assertRoot(this.root).symlinkSync(srcpath, dstpath, type);\n\t};\n\t/**\n\t * Asynchronous readlink.\n\t * @param path\n\t * @param callback\n\t */\n\tFS.prototype.readlink = function readlink (path$$1, cb) {\n\t if ( cb === void 0 ) cb = nopCb;\n\t\n\t var newCb = wrapCb(cb, 2);\n\t try {\n\t path$$1 = normalizePath(path$$1);\n\t assertRoot(this.root).readlink(path$$1, newCb);\n\t }\n\t catch (e) {\n\t newCb(e);\n\t }\n\t};\n\t/**\n\t * Synchronous readlink.\n\t * @param path\n\t * @return [String]\n\t */\n\tFS.prototype.readlinkSync = function readlinkSync (path$$1) {\n\t path$$1 = normalizePath(path$$1);\n\t return assertRoot(this.root).readlinkSync(path$$1);\n\t};\n\t// PROPERTY OPERATIONS\n\t/**\n\t * Asynchronous `chown`.\n\t * @param path\n\t * @param uid\n\t * @param gid\n\t * @param callback\n\t */\n\tFS.prototype.chown = function chown (path$$1, uid, gid, cb) {\n\t if ( cb === void 0 ) cb = nopCb;\n\t\n\t var newCb = wrapCb(cb, 1);\n\t try {\n\t path$$1 = normalizePath(path$$1);\n\t assertRoot(this.root).chown(path$$1, false, uid, gid, newCb);\n\t }\n\t catch (e) {\n\t newCb(e);\n\t }\n\t};\n\t/**\n\t * Synchronous `chown`.\n\t * @param path\n\t * @param uid\n\t * @param gid\n\t */\n\tFS.prototype.chownSync = function chownSync (path$$1, uid, gid) {\n\t path$$1 = normalizePath(path$$1);\n\t assertRoot(this.root).chownSync(path$$1, false, uid, gid);\n\t};\n\t/**\n\t * Asynchronous `lchown`.\n\t * @param path\n\t * @param uid\n\t * @param gid\n\t * @param callback\n\t */\n\tFS.prototype.lchown = function lchown (path$$1, uid, gid, cb) {\n\t if ( cb === void 0 ) cb = nopCb;\n\t\n\t var newCb = wrapCb(cb, 1);\n\t try {\n\t path$$1 = normalizePath(path$$1);\n\t assertRoot(this.root).chown(path$$1, true, uid, gid, newCb);\n\t }\n\t catch (e) {\n\t newCb(e);\n\t }\n\t};\n\t/**\n\t * Synchronous `lchown`.\n\t * @param path\n\t * @param uid\n\t * @param gid\n\t */\n\tFS.prototype.lchownSync = function lchownSync (path$$1, uid, gid) {\n\t path$$1 = normalizePath(path$$1);\n\t assertRoot(this.root).chownSync(path$$1, true, uid, gid);\n\t};\n\t/**\n\t * Asynchronous `chmod`.\n\t * @param path\n\t * @param mode\n\t * @param callback\n\t */\n\tFS.prototype.chmod = function chmod (path$$1, mode, cb) {\n\t if ( cb === void 0 ) cb = nopCb;\n\t\n\t var newCb = wrapCb(cb, 1);\n\t try {\n\t var numMode = normalizeMode(mode, -1);\n\t if (numMode < 0) {\n\t throw new ApiError(ErrorCode.EINVAL, \"Invalid mode.\");\n\t }\n\t assertRoot(this.root).chmod(normalizePath(path$$1), false, numMode, newCb);\n\t }\n\t catch (e) {\n\t newCb(e);\n\t }\n\t};\n\t/**\n\t * Synchronous `chmod`.\n\t * @param path\n\t * @param mode\n\t */\n\tFS.prototype.chmodSync = function chmodSync (path$$1, mode) {\n\t var numMode = normalizeMode(mode, -1);\n\t if (numMode < 0) {\n\t throw new ApiError(ErrorCode.EINVAL, \"Invalid mode.\");\n\t }\n\t path$$1 = normalizePath(path$$1);\n\t assertRoot(this.root).chmodSync(path$$1, false, numMode);\n\t};\n\t/**\n\t * Asynchronous `lchmod`.\n\t * @param path\n\t * @param mode\n\t * @param callback\n\t */\n\tFS.prototype.lchmod = function lchmod (path$$1, mode, cb) {\n\t if ( cb === void 0 ) cb = nopCb;\n\t\n\t var newCb = wrapCb(cb, 1);\n\t try {\n\t var numMode = normalizeMode(mode, -1);\n\t if (numMode < 0) {\n\t throw new ApiError(ErrorCode.EINVAL, \"Invalid mode.\");\n\t }\n\t assertRoot(this.root).chmod(normalizePath(path$$1), true, numMode, newCb);\n\t }\n\t catch (e) {\n\t newCb(e);\n\t }\n\t};\n\t/**\n\t * Synchronous `lchmod`.\n\t * @param path\n\t * @param mode\n\t */\n\tFS.prototype.lchmodSync = function lchmodSync (path$$1, mode) {\n\t var numMode = normalizeMode(mode, -1);\n\t if (numMode < 1) {\n\t throw new ApiError(ErrorCode.EINVAL, \"Invalid mode.\");\n\t }\n\t assertRoot(this.root).chmodSync(normalizePath(path$$1), true, numMode);\n\t};\n\t/**\n\t * Change file timestamps of the file referenced by the supplied path.\n\t * @param path\n\t * @param atime\n\t * @param mtime\n\t * @param callback\n\t */\n\tFS.prototype.utimes = function utimes (path$$1, atime, mtime, cb) {\n\t if ( cb === void 0 ) cb = nopCb;\n\t\n\t var newCb = wrapCb(cb, 1);\n\t try {\n\t assertRoot(this.root).utimes(normalizePath(path$$1), normalizeTime(atime), normalizeTime(mtime), newCb);\n\t }\n\t catch (e) {\n\t newCb(e);\n\t }\n\t};\n\t/**\n\t * Change file timestamps of the file referenced by the supplied path.\n\t * @param path\n\t * @param atime\n\t * @param mtime\n\t */\n\tFS.prototype.utimesSync = function utimesSync (path$$1, atime, mtime) {\n\t assertRoot(this.root).utimesSync(normalizePath(path$$1), normalizeTime(atime), normalizeTime(mtime));\n\t};\n\tFS.prototype.realpath = function realpath (path$$1, arg2, cb) {\n\t if ( cb === void 0 ) cb = nopCb;\n\t\n\t var cache = typeof (arg2) === 'object' ? arg2 : {};\n\t cb = typeof (arg2) === 'function' ? arg2 : nopCb;\n\t var newCb = wrapCb(cb, 2);\n\t try {\n\t path$$1 = normalizePath(path$$1);\n\t assertRoot(this.root).realpath(path$$1, cache, newCb);\n\t }\n\t catch (e) {\n\t newCb(e);\n\t }\n\t};\n\t/**\n\t * Synchronous `realpath`.\n\t * @param path\n\t * @param cache An object literal of mapped paths that can be used to\n\t * force a specific path resolution or avoid additional `fs.stat` calls for\n\t * known real paths.\n\t * @return [String]\n\t */\n\tFS.prototype.realpathSync = function realpathSync (path$$1, cache) {\n\t if ( cache === void 0 ) cache = {};\n\t\n\t path$$1 = normalizePath(path$$1);\n\t return assertRoot(this.root).realpathSync(path$$1, cache);\n\t};\n\tFS.prototype.watchFile = function watchFile (filename, arg2, listener) {\n\t if ( listener === void 0 ) listener = nopCb;\n\t\n\t throw new ApiError(ErrorCode.ENOTSUP);\n\t};\n\tFS.prototype.unwatchFile = function unwatchFile (filename, listener) {\n\t if ( listener === void 0 ) listener = nopCb;\n\t\n\t throw new ApiError(ErrorCode.ENOTSUP);\n\t};\n\tFS.prototype.watch = function watch (filename, arg2, listener) {\n\t if ( listener === void 0 ) listener = nopCb;\n\t\n\t throw new ApiError(ErrorCode.ENOTSUP);\n\t};\n\tFS.prototype.access = function access (path$$1, arg2, cb) {\n\t if ( cb === void 0 ) cb = nopCb;\n\t\n\t throw new ApiError(ErrorCode.ENOTSUP);\n\t};\n\tFS.prototype.accessSync = function accessSync (path$$1, mode) {\n\t throw new ApiError(ErrorCode.ENOTSUP);\n\t};\n\tFS.prototype.createReadStream = function createReadStream (path$$1, options) {\n\t throw new ApiError(ErrorCode.ENOTSUP);\n\t};\n\tFS.prototype.createWriteStream = function createWriteStream (path$$1, options) {\n\t throw new ApiError(ErrorCode.ENOTSUP);\n\t};\n\t/**\n\t * For unit testing. Passes all incoming callbacks to cbWrapper for wrapping.\n\t */\n\tFS.prototype.wrapCallbacks = function wrapCallbacks (cbWrapper) {\n\t wrapCb = cbWrapper;\n\t};\n\tFS.prototype.getFdForFile = function getFdForFile (file) {\n\t var fd = this.nextFd++;\n\t this.fdMap[fd] = file;\n\t return fd;\n\t};\n\tFS.prototype.fd2file = function fd2file (fd) {\n\t var rv = this.fdMap[fd];\n\t if (rv) {\n\t return rv;\n\t }\n\t else {\n\t throw new ApiError(ErrorCode.EBADF, 'Invalid file descriptor.');\n\t }\n\t};\n\tFS.prototype.closeFd = function closeFd (fd) {\n\t delete this.fdMap[fd];\n\t};\n\t\n\t/* tslint:disable:variable-name */\n\t// Exported fs.Stats.\n\tFS.Stats = Stats;\n\t\n\t// Manually export the individual public functions of fs.\n\t// Required because some code will invoke functions off of the module.\n\t// e.g.:\n\t// let writeFile = fs.writeFile;\n\t// writeFile(...)\n\tvar fs = new FS();\n\tvar _fsMock = {};\n\tvar fsProto = FS.prototype;\n\tObject.keys(fsProto).forEach(function (key) {\n\t if (typeof fs[key] === 'function') {\n\t _fsMock[key] = function () {\n\t return fs[key].apply(fs, arguments);\n\t };\n\t }\n\t else {\n\t _fsMock[key] = fs[key];\n\t }\n\t});\n\t_fsMock['changeFSModule'] = function (newFs) {\n\t fs = newFs;\n\t};\n\t_fsMock['getFSModule'] = function () {\n\t return fs;\n\t};\n\t_fsMock['FS'] = FS;\n\t\n\t/**\n\t * Checks for any IE version, including IE11 which removed MSIE from the\n\t * userAgent string.\n\t */\n\tvar isIE = typeof navigator !== \"undefined\" && !!(/(msie) ([\\w.]+)/.exec(navigator.userAgent.toLowerCase()) || navigator.userAgent.indexOf('Trident') !== -1);\n\t/**å\n\t * Check if we're in a web worker.\n\t */\n\tvar isWebWorker = typeof window === \"undefined\";\n\t/**\n\t * Throws an exception. Called on code paths that should be impossible.\n\t */\n\tfunction fail() {\n\t throw new Error(\"BFS has reached an impossible code path; please file a bug.\");\n\t}\n\t/**\n\t * Synchronous recursive makedir.\n\t */\n\tfunction mkdirpSync(p, mode, fs) {\n\t if (!fs.existsSync(p)) {\n\t mkdirpSync(path.dirname(p), mode, fs);\n\t fs.mkdirSync(p, mode);\n\t }\n\t}\n\t/**\n\t * Converts a buffer into an array buffer. Attempts to do so in a\n\t * zero-copy manner, e.g. the array references the same memory.\n\t */\n\tfunction buffer2ArrayBuffer(buff) {\n\t var u8 = buffer2Uint8array(buff), u8offset = u8.byteOffset, u8Len = u8.byteLength;\n\t if (u8offset === 0 && u8Len === u8.buffer.byteLength) {\n\t return u8.buffer;\n\t }\n\t else {\n\t return u8.buffer.slice(u8offset, u8offset + u8Len);\n\t }\n\t}\n\t/**\n\t * Converts a buffer into a Uint8Array. Attempts to do so in a\n\t * zero-copy manner, e.g. the array references the same memory.\n\t */\n\tfunction buffer2Uint8array(buff) {\n\t if (buff instanceof Uint8Array) {\n\t // BFS & Node v4.0 buffers *are* Uint8Arrays.\n\t return buff;\n\t }\n\t else {\n\t // Uint8Arrays can be constructed from arrayish numbers.\n\t // At this point, we assume this isn't a BFS array.\n\t return new Uint8Array(buff);\n\t }\n\t}\n\t/**\n\t * Converts the given arrayish object into a Buffer. Attempts to\n\t * be zero-copy.\n\t */\n\tfunction arrayish2Buffer(arr) {\n\t if (arr instanceof Buffer) {\n\t return arr;\n\t }\n\t else if (arr instanceof Uint8Array) {\n\t return uint8Array2Buffer(arr);\n\t }\n\t else {\n\t return new Buffer(arr);\n\t }\n\t}\n\t/**\n\t * Converts the given Uint8Array into a Buffer. Attempts to be zero-copy.\n\t */\n\tfunction uint8Array2Buffer(u8) {\n\t if (u8 instanceof Buffer) {\n\t return u8;\n\t }\n\t else if (u8.byteOffset === 0 && u8.byteLength === u8.buffer.byteLength) {\n\t return arrayBuffer2Buffer(u8.buffer);\n\t }\n\t else {\n\t return new Buffer(u8);\n\t }\n\t}\n\t/**\n\t * Converts the given array buffer into a Buffer. Attempts to be\n\t * zero-copy.\n\t */\n\tfunction arrayBuffer2Buffer(ab) {\n\t try {\n\t // Works in BFS and Node v4.2.\n\t return new Buffer(ab);\n\t }\n\t catch (e) {\n\t // I believe this copies, but there's no avoiding it in Node < v4.2\n\t return new Buffer(new Uint8Array(ab));\n\t }\n\t}\n\t/**\n\t * Copies a slice of the given buffer\n\t */\n\tfunction copyingSlice(buff, start, end) {\n\t if ( start === void 0 ) start = 0;\n\t if ( end === void 0 ) end = buff.length;\n\t\n\t if (start < 0 || end < 0 || end > buff.length || start > end) {\n\t throw new TypeError((\"Invalid slice bounds on buffer of length \" + (buff.length) + \": [\" + start + \", \" + end + \"]\"));\n\t }\n\t if (buff.length === 0) {\n\t // Avoid s0 corner case in ArrayBuffer case.\n\t return new Buffer(0);\n\t }\n\t else {\n\t var u8 = buffer2Uint8array(buff), s0 = buff[0], newS0 = (s0 + 1) % 0xFF;\n\t buff[0] = newS0;\n\t if (u8[0] === newS0) {\n\t // Same memory. Revert & copy.\n\t u8[0] = s0;\n\t return uint8Array2Buffer(u8.slice(start, end));\n\t }\n\t else {\n\t // Revert.\n\t buff[0] = s0;\n\t return uint8Array2Buffer(u8.subarray(start, end));\n\t }\n\t }\n\t}\n\t\n\t\n\tvar BFSUtils = Object.freeze({\n\t\tisIE: isIE,\n\t\tisWebWorker: isWebWorker,\n\t\tfail: fail,\n\t\tmkdirpSync: mkdirpSync,\n\t\tbuffer2ArrayBuffer: buffer2ArrayBuffer,\n\t\tbuffer2Uint8array: buffer2Uint8array,\n\t\tarrayish2Buffer: arrayish2Buffer,\n\t\tuint8Array2Buffer: uint8Array2Buffer,\n\t\tarrayBuffer2Buffer: arrayBuffer2Buffer,\n\t\tcopyingSlice: copyingSlice\n\t});\n\t\n\tvar BFSEmscriptenStreamOps = function BFSEmscriptenStreamOps(fs) {\n\t this.fs = fs;\n\t this.nodefs = fs.getNodeFS();\n\t this.FS = fs.getFS();\n\t this.PATH = fs.getPATH();\n\t this.ERRNO_CODES = fs.getERRNO_CODES();\n\t};\n\tBFSEmscriptenStreamOps.prototype.open = function open (stream) {\n\t var path$$1 = this.fs.realPath(stream.node);\n\t var FS = this.FS;\n\t try {\n\t if (FS.isFile(stream.node.mode)) {\n\t stream.nfd = this.nodefs.openSync(path$$1, this.fs.flagsToPermissionString(stream.flags));\n\t }\n\t }\n\t catch (e) {\n\t if (!e.code) {\n\t throw e;\n\t }\n\t throw new FS.ErrnoError(this.ERRNO_CODES[e.code]);\n\t }\n\t};\n\tBFSEmscriptenStreamOps.prototype.close = function close (stream) {\n\t var FS = this.FS;\n\t try {\n\t if (FS.isFile(stream.node.mode) && stream.nfd) {\n\t this.nodefs.closeSync(stream.nfd);\n\t }\n\t }\n\t catch (e) {\n\t if (!e.code) {\n\t throw e;\n\t }\n\t throw new FS.ErrnoError(this.ERRNO_CODES[e.code]);\n\t }\n\t};\n\tBFSEmscriptenStreamOps.prototype.read = function read (stream, buffer$$1, offset, length, position) {\n\t // Avoid copying overhead by reading directly into buffer.\n\t try {\n\t return this.nodefs.readSync(stream.nfd, uint8Array2Buffer(buffer$$1), offset, length, position);\n\t }\n\t catch (e) {\n\t throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n\t }\n\t};\n\tBFSEmscriptenStreamOps.prototype.write = function write (stream, buffer$$1, offset, length, position) {\n\t // Avoid copying overhead.\n\t try {\n\t return this.nodefs.writeSync(stream.nfd, uint8Array2Buffer(buffer$$1), offset, length, position);\n\t }\n\t catch (e) {\n\t throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n\t }\n\t};\n\tBFSEmscriptenStreamOps.prototype.llseek = function llseek (stream, offset, whence) {\n\t var position = offset;\n\t if (whence === 1) {\n\t position += stream.position;\n\t }\n\t else if (whence === 2) {\n\t if (this.FS.isFile(stream.node.mode)) {\n\t try {\n\t var stat = this.nodefs.fstatSync(stream.nfd);\n\t position += stat.size;\n\t }\n\t catch (e) {\n\t throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n\t }\n\t }\n\t }\n\t if (position < 0) {\n\t throw new this.FS.ErrnoError(this.ERRNO_CODES.EINVAL);\n\t }\n\t stream.position = position;\n\t return position;\n\t};\n\tvar BFSEmscriptenNodeOps = function BFSEmscriptenNodeOps(fs) {\n\t this.fs = fs;\n\t this.nodefs = fs.getNodeFS();\n\t this.FS = fs.getFS();\n\t this.PATH = fs.getPATH();\n\t this.ERRNO_CODES = fs.getERRNO_CODES();\n\t};\n\tBFSEmscriptenNodeOps.prototype.getattr = function getattr (node) {\n\t var path$$1 = this.fs.realPath(node);\n\t var stat;\n\t try {\n\t stat = this.nodefs.lstatSync(path$$1);\n\t }\n\t catch (e) {\n\t if (!e.code) {\n\t throw e;\n\t }\n\t throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n\t }\n\t return {\n\t dev: stat.dev,\n\t ino: stat.ino,\n\t mode: stat.mode,\n\t nlink: stat.nlink,\n\t uid: stat.uid,\n\t gid: stat.gid,\n\t rdev: stat.rdev,\n\t size: stat.size,\n\t atime: stat.atime,\n\t mtime: stat.mtime,\n\t ctime: stat.ctime,\n\t blksize: stat.blksize,\n\t blocks: stat.blocks\n\t };\n\t};\n\tBFSEmscriptenNodeOps.prototype.setattr = function setattr (node, attr) {\n\t var path$$1 = this.fs.realPath(node);\n\t try {\n\t if (attr.mode !== undefined) {\n\t this.nodefs.chmodSync(path$$1, attr.mode);\n\t // update the common node structure mode as well\n\t node.mode = attr.mode;\n\t }\n\t if (attr.timestamp !== undefined) {\n\t var date = new Date(attr.timestamp);\n\t this.nodefs.utimesSync(path$$1, date, date);\n\t }\n\t }\n\t catch (e) {\n\t if (!e.code) {\n\t throw e;\n\t }\n\t // Ignore not supported errors. Emscripten does utimesSync when it\n\t // writes files, but never really requires the value to be set.\n\t if (e.code !== \"ENOTSUP\") {\n\t throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n\t }\n\t }\n\t if (attr.size !== undefined) {\n\t try {\n\t this.nodefs.truncateSync(path$$1, attr.size);\n\t }\n\t catch (e) {\n\t if (!e.code) {\n\t throw e;\n\t }\n\t throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n\t }\n\t }\n\t};\n\tBFSEmscriptenNodeOps.prototype.lookup = function lookup (parent, name) {\n\t var path$$1 = this.PATH.join2(this.fs.realPath(parent), name);\n\t var mode = this.fs.getMode(path$$1);\n\t return this.fs.createNode(parent, name, mode);\n\t};\n\tBFSEmscriptenNodeOps.prototype.mknod = function mknod (parent, name, mode, dev) {\n\t var node = this.fs.createNode(parent, name, mode, dev);\n\t // create the backing node for this in the fs root as well\n\t var path$$1 = this.fs.realPath(node);\n\t try {\n\t if (this.FS.isDir(node.mode)) {\n\t this.nodefs.mkdirSync(path$$1, node.mode);\n\t }\n\t else {\n\t this.nodefs.writeFileSync(path$$1, '', { mode: node.mode });\n\t }\n\t }\n\t catch (e) {\n\t if (!e.code) {\n\t throw e;\n\t }\n\t throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n\t }\n\t return node;\n\t};\n\tBFSEmscriptenNodeOps.prototype.rename = function rename (oldNode, newDir, newName) {\n\t var oldPath = this.fs.realPath(oldNode);\n\t var newPath = this.PATH.join2(this.fs.realPath(newDir), newName);\n\t try {\n\t this.nodefs.renameSync(oldPath, newPath);\n\t // This logic is missing from the original NodeFS,\n\t // causing Emscripten's filesystem to think that the old file still exists.\n\t oldNode.name = newName;\n\t oldNode.parent = newDir;\n\t }\n\t catch (e) {\n\t if (!e.code) {\n\t throw e;\n\t }\n\t throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n\t }\n\t};\n\tBFSEmscriptenNodeOps.prototype.unlink = function unlink (parent, name) {\n\t var path$$1 = this.PATH.join2(this.fs.realPath(parent), name);\n\t try {\n\t this.nodefs.unlinkSync(path$$1);\n\t }\n\t catch (e) {\n\t if (!e.code) {\n\t throw e;\n\t }\n\t throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n\t }\n\t};\n\tBFSEmscriptenNodeOps.prototype.rmdir = function rmdir (parent, name) {\n\t var path$$1 = this.PATH.join2(this.fs.realPath(parent), name);\n\t try {\n\t this.nodefs.rmdirSync(path$$1);\n\t }\n\t catch (e) {\n\t if (!e.code) {\n\t throw e;\n\t }\n\t throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n\t }\n\t};\n\tBFSEmscriptenNodeOps.prototype.readdir = function readdir (node) {\n\t var path$$1 = this.fs.realPath(node);\n\t try {\n\t // Node does not list . and .. in directory listings,\n\t // but Emscripten expects it.\n\t var contents = this.nodefs.readdirSync(path$$1);\n\t contents.push('.', '..');\n\t return contents;\n\t }\n\t catch (e) {\n\t if (!e.code) {\n\t throw e;\n\t }\n\t throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n\t }\n\t};\n\tBFSEmscriptenNodeOps.prototype.symlink = function symlink (parent, newName, oldPath) {\n\t var newPath = this.PATH.join2(this.fs.realPath(parent), newName);\n\t try {\n\t this.nodefs.symlinkSync(oldPath, newPath);\n\t }\n\t catch (e) {\n\t if (!e.code) {\n\t throw e;\n\t }\n\t throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n\t }\n\t};\n\tBFSEmscriptenNodeOps.prototype.readlink = function readlink (node) {\n\t var path$$1 = this.fs.realPath(node);\n\t try {\n\t return this.nodefs.readlinkSync(path$$1);\n\t }\n\t catch (e) {\n\t if (!e.code) {\n\t throw e;\n\t }\n\t throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n\t }\n\t};\n\tvar BFSEmscriptenFS = function BFSEmscriptenFS(_FS, _PATH, _ERRNO_CODES, nodefs) {\n\t if ( _FS === void 0 ) _FS = self['FS'];\n\t if ( _PATH === void 0 ) _PATH = self['PATH'];\n\t if ( _ERRNO_CODES === void 0 ) _ERRNO_CODES = self['ERRNO_CODES'];\n\t if ( nodefs === void 0 ) nodefs = _fsMock;\n\t\n\t // This maps the integer permission modes from http://linux.die.net/man/3/open\n\t // to node.js-specific file open permission strings at http://nodejs.org/api/fs.html#fs_fs_open_path_flags_mode_callback\n\t this.flagsToPermissionStringMap = {\n\t 0 /*O_RDONLY*/: 'r',\n\t 1 /*O_WRONLY*/: 'r+',\n\t 2 /*O_RDWR*/: 'r+',\n\t 64 /*O_CREAT*/: 'r',\n\t 65 /*O_WRONLY|O_CREAT*/: 'r+',\n\t 66 /*O_RDWR|O_CREAT*/: 'r+',\n\t 129 /*O_WRONLY|O_EXCL*/: 'rx+',\n\t 193 /*O_WRONLY|O_CREAT|O_EXCL*/: 'rx+',\n\t 514 /*O_RDWR|O_TRUNC*/: 'w+',\n\t 577 /*O_WRONLY|O_CREAT|O_TRUNC*/: 'w',\n\t 578 /*O_CREAT|O_RDWR|O_TRUNC*/: 'w+',\n\t 705 /*O_WRONLY|O_CREAT|O_EXCL|O_TRUNC*/: 'wx',\n\t 706 /*O_RDWR|O_CREAT|O_EXCL|O_TRUNC*/: 'wx+',\n\t 1024 /*O_APPEND*/: 'a',\n\t 1025 /*O_WRONLY|O_APPEND*/: 'a',\n\t 1026 /*O_RDWR|O_APPEND*/: 'a+',\n\t 1089 /*O_WRONLY|O_CREAT|O_APPEND*/: 'a',\n\t 1090 /*O_RDWR|O_CREAT|O_APPEND*/: 'a+',\n\t 1153 /*O_WRONLY|O_EXCL|O_APPEND*/: 'ax',\n\t 1154 /*O_RDWR|O_EXCL|O_APPEND*/: 'ax+',\n\t 1217 /*O_WRONLY|O_CREAT|O_EXCL|O_APPEND*/: 'ax',\n\t 1218 /*O_RDWR|O_CREAT|O_EXCL|O_APPEND*/: 'ax+',\n\t 4096 /*O_RDONLY|O_DSYNC*/: 'rs',\n\t 4098 /*O_RDWR|O_DSYNC*/: 'rs+'\n\t };\n\t this.nodefs = nodefs;\n\t this.FS = _FS;\n\t this.PATH = _PATH;\n\t this.ERRNO_CODES = _ERRNO_CODES;\n\t this.node_ops = new BFSEmscriptenNodeOps(this);\n\t this.stream_ops = new BFSEmscriptenStreamOps(this);\n\t};\n\tBFSEmscriptenFS.prototype.mount = function mount (m) {\n\t return this.createNode(null, '/', this.getMode(m.opts.root), 0);\n\t};\n\tBFSEmscriptenFS.prototype.createNode = function createNode (parent, name, mode, dev) {\n\t var FS = this.FS;\n\t if (!FS.isDir(mode) && !FS.isFile(mode) && !FS.isLink(mode)) {\n\t throw new FS.ErrnoError(this.ERRNO_CODES.EINVAL);\n\t }\n\t var node = FS.createNode(parent, name, mode);\n\t node.node_ops = this.node_ops;\n\t node.stream_ops = this.stream_ops;\n\t return node;\n\t};\n\tBFSEmscriptenFS.prototype.getMode = function getMode (path$$1) {\n\t var stat;\n\t try {\n\t stat = this.nodefs.lstatSync(path$$1);\n\t }\n\t catch (e) {\n\t if (!e.code) {\n\t throw e;\n\t }\n\t throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n\t }\n\t return stat.mode;\n\t};\n\tBFSEmscriptenFS.prototype.realPath = function realPath (node) {\n\t var parts = [];\n\t while (node.parent !== node) {\n\t parts.push(node.name);\n\t node = node.parent;\n\t }\n\t parts.push(node.mount.opts.root);\n\t parts.reverse();\n\t return this.PATH.join.apply(null, parts);\n\t};\n\tBFSEmscriptenFS.prototype.flagsToPermissionString = function flagsToPermissionString (flags) {\n\t var parsedFlags = (typeof flags === \"string\") ? parseInt(flags, 10) : flags;\n\t parsedFlags &= 0x1FFF;\n\t if (parsedFlags in this.flagsToPermissionStringMap) {\n\t return this.flagsToPermissionStringMap[parsedFlags];\n\t }\n\t else {\n\t return flags;\n\t }\n\t};\n\tBFSEmscriptenFS.prototype.getNodeFS = function getNodeFS () {\n\t return this.nodefs;\n\t};\n\tBFSEmscriptenFS.prototype.getFS = function getFS () {\n\t return this.FS;\n\t};\n\tBFSEmscriptenFS.prototype.getPATH = function getPATH () {\n\t return this.PATH;\n\t};\n\tBFSEmscriptenFS.prototype.getERRNO_CODES = function getERRNO_CODES () {\n\t return this.ERRNO_CODES;\n\t};\n\t\n\t/**\n\t * Basic filesystem class. Most filesystems should extend this class, as it\n\t * provides default implementations for a handful of methods.\n\t */\n\tvar BaseFileSystem = function BaseFileSystem () {};\n\t\n\tBaseFileSystem.prototype.supportsLinks = function supportsLinks () {\n\t return false;\n\t};\n\tBaseFileSystem.prototype.diskSpace = function diskSpace (p, cb) {\n\t cb(0, 0);\n\t};\n\t/**\n\t * Opens the file at path p with the given flag. The file must exist.\n\t * @param p The path to open.\n\t * @param flag The flag to use when opening the file.\n\t */\n\tBaseFileSystem.prototype.openFile = function openFile (p, flag, cb) {\n\t throw new ApiError(ErrorCode.ENOTSUP);\n\t};\n\t/**\n\t * Create the file at path p with the given mode. Then, open it with the given\n\t * flag.\n\t */\n\tBaseFileSystem.prototype.createFile = function createFile (p, flag, mode, cb) {\n\t throw new ApiError(ErrorCode.ENOTSUP);\n\t};\n\tBaseFileSystem.prototype.open = function open (p, flag, mode, cb) {\n\t var this$1 = this;\n\t\n\t var mustBeFile = function (e, stats) {\n\t if (e) {\n\t // File does not exist.\n\t switch (flag.pathNotExistsAction()) {\n\t case ActionType.CREATE_FILE:\n\t // Ensure parent exists.\n\t return this$1.stat(path.dirname(p), false, function (e, parentStats) {\n\t if (e) {\n\t cb(e);\n\t }\n\t else if (parentStats && !parentStats.isDirectory()) {\n\t cb(ApiError.ENOTDIR(path.dirname(p)));\n\t }\n\t else {\n\t this$1.createFile(p, flag, mode, cb);\n\t }\n\t });\n\t case ActionType.THROW_EXCEPTION:\n\t return cb(ApiError.ENOENT(p));\n\t default:\n\t return cb(new ApiError(ErrorCode.EINVAL, 'Invalid FileFlag object.'));\n\t }\n\t }\n\t else {\n\t // File exists.\n\t if (stats && stats.isDirectory()) {\n\t return cb(ApiError.EISDIR(p));\n\t }\n\t switch (flag.pathExistsAction()) {\n\t case ActionType.THROW_EXCEPTION:\n\t return cb(ApiError.EEXIST(p));\n\t case ActionType.TRUNCATE_FILE:\n\t // NOTE: In a previous implementation, we deleted the file and\n\t // re-created it. However, this created a race condition if another\n\t // asynchronous request was trying to read the file, as the file\n\t // would not exist for a small period of time.\n\t return this$1.openFile(p, flag, function (e, fd) {\n\t if (e) {\n\t cb(e);\n\t }\n\t else if (fd) {\n\t fd.truncate(0, function () {\n\t fd.sync(function () {\n\t cb(null, fd);\n\t });\n\t });\n\t }\n\t else {\n\t fail();\n\t }\n\t });\n\t case ActionType.NOP:\n\t return this$1.openFile(p, flag, cb);\n\t default:\n\t return cb(new ApiError(ErrorCode.EINVAL, 'Invalid FileFlag object.'));\n\t }\n\t }\n\t };\n\t this.stat(p, false, mustBeFile);\n\t};\n\tBaseFileSystem.prototype.rename = function rename (oldPath, newPath, cb) {\n\t cb(new ApiError(ErrorCode.ENOTSUP));\n\t};\n\tBaseFileSystem.prototype.renameSync = function renameSync (oldPath, newPath) {\n\t throw new ApiError(ErrorCode.ENOTSUP);\n\t};\n\tBaseFileSystem.prototype.stat = function stat (p, isLstat, cb) {\n\t cb(new ApiError(ErrorCode.ENOTSUP));\n\t};\n\tBaseFileSystem.prototype.statSync = function statSync (p, isLstat) {\n\t throw new ApiError(ErrorCode.ENOTSUP);\n\t};\n\t/**\n\t * Opens the file at path p with the given flag. The file must exist.\n\t * @param p The path to open.\n\t * @param flag The flag to use when opening the file.\n\t * @return A File object corresponding to the opened file.\n\t */\n\tBaseFileSystem.prototype.openFileSync = function openFileSync (p, flag, mode) {\n\t throw new ApiError(ErrorCode.ENOTSUP);\n\t};\n\t/**\n\t * Create the file at path p with the given mode. Then, open it with the given\n\t * flag.\n\t */\n\tBaseFileSystem.prototype.createFileSync = function createFileSync (p, flag, mode) {\n\t throw new ApiError(ErrorCode.ENOTSUP);\n\t};\n\tBaseFileSystem.prototype.openSync = function openSync (p, flag, mode) {\n\t // Check if the path exists, and is a file.\n\t var stats;\n\t try {\n\t stats = this.statSync(p, false);\n\t }\n\t catch (e) {\n\t // File does not exist.\n\t switch (flag.pathNotExistsAction()) {\n\t case ActionType.CREATE_FILE:\n\t // Ensure parent exists.\n\t var parentStats = this.statSync(path.dirname(p), false);\n\t if (!parentStats.isDirectory()) {\n\t throw ApiError.ENOTDIR(path.dirname(p));\n\t }\n\t return this.createFileSync(p, flag, mode);\n\t case ActionType.THROW_EXCEPTION:\n\t throw ApiError.ENOENT(p);\n\t default:\n\t throw new ApiError(ErrorCode.EINVAL, 'Invalid FileFlag object.');\n\t }\n\t }\n\t // File exists.\n\t if (stats.isDirectory()) {\n\t throw ApiError.EISDIR(p);\n\t }\n\t switch (flag.pathExistsAction()) {\n\t case ActionType.THROW_EXCEPTION:\n\t throw ApiError.EEXIST(p);\n\t case ActionType.TRUNCATE_FILE:\n\t // Delete file.\n\t this.unlinkSync(p);\n\t // Create file. Use the same mode as the old file.\n\t // Node itself modifies the ctime when this occurs, so this action\n\t // will preserve that behavior if the underlying file system\n\t // supports those properties.\n\t return this.createFileSync(p, flag, stats.mode);\n\t case ActionType.NOP:\n\t return this.openFileSync(p, flag, mode);\n\t default:\n\t throw new ApiError(ErrorCode.EINVAL, 'Invalid FileFlag object.');\n\t }\n\t};\n\tBaseFileSystem.prototype.unlink = function unlink (p, cb) {\n\t cb(new ApiError(ErrorCode.ENOTSUP));\n\t};\n\tBaseFileSystem.prototype.unlinkSync = function unlinkSync (p) {\n\t throw new ApiError(ErrorCode.ENOTSUP);\n\t};\n\tBaseFileSystem.prototype.rmdir = function rmdir (p, cb) {\n\t cb(new ApiError(ErrorCode.ENOTSUP));\n\t};\n\tBaseFileSystem.prototype.rmdirSync = function rmdirSync (p) {\n\t throw new ApiError(ErrorCode.ENOTSUP);\n\t};\n\tBaseFileSystem.prototype.mkdir = function mkdir (p, mode, cb) {\n\t cb(new ApiError(ErrorCode.ENOTSUP));\n\t};\n\tBaseFileSystem.prototype.mkdirSync = function mkdirSync (p, mode) {\n\t throw new ApiError(ErrorCode.ENOTSUP);\n\t};\n\tBaseFileSystem.prototype.readdir = function readdir (p, cb) {\n\t cb(new ApiError(ErrorCode.ENOTSUP));\n\t};\n\tBaseFileSystem.prototype.readdirSync = function readdirSync (p) {\n\t throw new ApiError(ErrorCode.ENOTSUP);\n\t};\n\tBaseFileSystem.prototype.exists = function exists (p, cb) {\n\t this.stat(p, null, function (err) {\n\t cb(!err);\n\t });\n\t};\n\tBaseFileSystem.prototype.existsSync = function existsSync (p) {\n\t try {\n\t this.statSync(p, true);\n\t return true;\n\t }\n\t catch (e) {\n\t return false;\n\t }\n\t};\n\tBaseFileSystem.prototype.realpath = function realpath (p, cache, cb) {\n\t if (this.supportsLinks()) {\n\t // The path could contain symlinks. Split up the path,\n\t // resolve any symlinks, return the resolved string.\n\t var splitPath = p.split(path.sep);\n\t // TODO: Simpler to just pass through file, find sep and such.\n\t for (var i = 0; i < splitPath.length; i++) {\n\t var addPaths = splitPath.slice(0, i + 1);\n\t splitPath[i] = path.join.apply(null, addPaths);\n\t }\n\t }\n\t else {\n\t // No symlinks. We just need to verify that it exists.\n\t this.exists(p, function (doesExist) {\n\t if (doesExist) {\n\t cb(null, p);\n\t }\n\t else {\n\t cb(ApiError.ENOENT(p));\n\t }\n\t });\n\t }\n\t};\n\tBaseFileSystem.prototype.realpathSync = function realpathSync (p, cache) {\n\t if (this.supportsLinks()) {\n\t // The path could contain symlinks. Split up the path,\n\t // resolve any symlinks, return the resolved string.\n\t var splitPath = p.split(path.sep);\n\t // TODO: Simpler to just pass through file, find sep and such.\n\t for (var i = 0; i < splitPath.length; i++) {\n\t var addPaths = splitPath.slice(0, i + 1);\n\t splitPath[i] = path.join.apply(path, addPaths);\n\t }\n\t return splitPath.join(path.sep);\n\t }\n\t else {\n\t // No symlinks. We just need to verify that it exists.\n\t if (this.existsSync(p)) {\n\t return p;\n\t }\n\t else {\n\t throw ApiError.ENOENT(p);\n\t }\n\t }\n\t};\n\tBaseFileSystem.prototype.truncate = function truncate (p, len, cb) {\n\t this.open(p, FileFlag.getFileFlag('r+'), 0x1a4, (function (er, fd) {\n\t if (er) {\n\t return cb(er);\n\t }\n\t fd.truncate(len, (function (er) {\n\t fd.close((function (er2) {\n\t cb(er || er2);\n\t }));\n\t }));\n\t }));\n\t};\n\tBaseFileSystem.prototype.truncateSync = function truncateSync (p, len) {\n\t var fd = this.openSync(p, FileFlag.getFileFlag('r+'), 0x1a4);\n\t // Need to safely close FD, regardless of whether or not truncate succeeds.\n\t try {\n\t fd.truncateSync(len);\n\t }\n\t catch (e) {\n\t throw e;\n\t }\n\t finally {\n\t fd.closeSync();\n\t }\n\t};\n\tBaseFileSystem.prototype.readFile = function readFile (fname, encoding, flag, cb) {\n\t // Wrap cb in file closing code.\n\t var oldCb = cb;\n\t // Get file.\n\t this.open(fname, flag, 0x1a4, function (err, fd) {\n\t if (err) {\n\t return cb(err);\n\t }\n\t cb = function (err, arg) {\n\t fd.close(function (err2) {\n\t if (!err) {\n\t err = err2;\n\t }\n\t return oldCb(err, arg);\n\t });\n\t };\n\t fd.stat(function (err, stat) {\n\t if (err) {\n\t return cb(err);\n\t }\n\t // Allocate buffer.\n\t var buf = new Buffer(stat.size);\n\t fd.read(buf, 0, stat.size, 0, function (err) {\n\t if (err) {\n\t return cb(err);\n\t }\n\t else if (encoding === null) {\n\t return cb(err, buf);\n\t }\n\t try {\n\t cb(null, buf.toString(encoding));\n\t }\n\t catch (e) {\n\t cb(e);\n\t }\n\t });\n\t });\n\t });\n\t};\n\tBaseFileSystem.prototype.readFileSync = function readFileSync (fname, encoding, flag) {\n\t // Get file.\n\t var fd = this.openSync(fname, flag, 0x1a4);\n\t try {\n\t var stat = fd.statSync();\n\t // Allocate buffer.\n\t var buf = new Buffer(stat.size);\n\t fd.readSync(buf, 0, stat.size, 0);\n\t fd.closeSync();\n\t if (encoding === null) {\n\t return buf;\n\t }\n\t return buf.toString(encoding);\n\t }\n\t finally {\n\t fd.closeSync();\n\t }\n\t};\n\tBaseFileSystem.prototype.writeFile = function writeFile (fname, data, encoding, flag, mode, cb) {\n\t // Wrap cb in file closing code.\n\t var oldCb = cb;\n\t // Get file.\n\t this.open(fname, flag, 0x1a4, function (err, fd) {\n\t if (err) {\n\t return cb(err);\n\t }\n\t cb = function (err) {\n\t fd.close(function (err2) {\n\t oldCb(err ? err : err2);\n\t });\n\t };\n\t try {\n\t if (typeof data === 'string') {\n\t data = new Buffer(data, encoding);\n\t }\n\t }\n\t catch (e) {\n\t return cb(e);\n\t }\n\t // Write into file.\n\t fd.write(data, 0, data.length, 0, cb);\n\t });\n\t};\n\tBaseFileSystem.prototype.writeFileSync = function writeFileSync (fname, data, encoding, flag, mode) {\n\t // Get file.\n\t var fd = this.openSync(fname, flag, mode);\n\t try {\n\t if (typeof data === 'string') {\n\t data = new Buffer(data, encoding);\n\t }\n\t // Write into file.\n\t fd.writeSync(data, 0, data.length, 0);\n\t }\n\t finally {\n\t fd.closeSync();\n\t }\n\t};\n\tBaseFileSystem.prototype.appendFile = function appendFile (fname, data, encoding, flag, mode, cb) {\n\t // Wrap cb in file closing code.\n\t var oldCb = cb;\n\t this.open(fname, flag, mode, function (err, fd) {\n\t if (err) {\n\t return cb(err);\n\t }\n\t cb = function (err) {\n\t fd.close(function (err2) {\n\t oldCb(err ? err : err2);\n\t });\n\t };\n\t if (typeof data === 'string') {\n\t data = new Buffer(data, encoding);\n\t }\n\t fd.write(data, 0, data.length, null, cb);\n\t });\n\t};\n\tBaseFileSystem.prototype.appendFileSync = function appendFileSync (fname, data, encoding, flag, mode) {\n\t var fd = this.openSync(fname, flag, mode);\n\t try {\n\t if (typeof data === 'string') {\n\t data = new Buffer(data, encoding);\n\t }\n\t fd.writeSync(data, 0, data.length, null);\n\t }\n\t finally {\n\t fd.closeSync();\n\t }\n\t};\n\tBaseFileSystem.prototype.chmod = function chmod (p, isLchmod, mode, cb) {\n\t cb(new ApiError(ErrorCode.ENOTSUP));\n\t};\n\tBaseFileSystem.prototype.chmodSync = function chmodSync (p, isLchmod, mode) {\n\t throw new ApiError(ErrorCode.ENOTSUP);\n\t};\n\tBaseFileSystem.prototype.chown = function chown (p, isLchown, uid, gid, cb) {\n\t cb(new ApiError(ErrorCode.ENOTSUP));\n\t};\n\tBaseFileSystem.prototype.chownSync = function chownSync (p, isLchown, uid, gid) {\n\t throw new ApiError(ErrorCode.ENOTSUP);\n\t};\n\tBaseFileSystem.prototype.utimes = function utimes (p, atime, mtime, cb) {\n\t cb(new ApiError(ErrorCode.ENOTSUP));\n\t};\n\tBaseFileSystem.prototype.utimesSync = function utimesSync (p, atime, mtime) {\n\t throw new ApiError(ErrorCode.ENOTSUP);\n\t};\n\tBaseFileSystem.prototype.link = function link (srcpath, dstpath, cb) {\n\t cb(new ApiError(ErrorCode.ENOTSUP));\n\t};\n\tBaseFileSystem.prototype.linkSync = function linkSync (srcpath, dstpath) {\n\t throw new ApiError(ErrorCode.ENOTSUP);\n\t};\n\tBaseFileSystem.prototype.symlink = function symlink (srcpath, dstpath, type, cb) {\n\t cb(new ApiError(ErrorCode.ENOTSUP));\n\t};\n\tBaseFileSystem.prototype.symlinkSync = function symlinkSync (srcpath, dstpath, type) {\n\t throw new ApiError(ErrorCode.ENOTSUP);\n\t};\n\tBaseFileSystem.prototype.readlink = function readlink (p, cb) {\n\t cb(new ApiError(ErrorCode.ENOTSUP));\n\t};\n\tBaseFileSystem.prototype.readlinkSync = function readlinkSync (p) {\n\t throw new ApiError(ErrorCode.ENOTSUP);\n\t};\n\t/**\n\t * Implements the asynchronous API in terms of the synchronous API.\n\t * @class SynchronousFileSystem\n\t */\n\tvar SynchronousFileSystem = (function (BaseFileSystem) {\n\t function SynchronousFileSystem () {\n\t BaseFileSystem.apply(this, arguments);\n\t }\n\t\n\t if ( BaseFileSystem ) SynchronousFileSystem.__proto__ = BaseFileSystem;\n\t SynchronousFileSystem.prototype = Object.create( BaseFileSystem && BaseFileSystem.prototype );\n\t SynchronousFileSystem.prototype.constructor = SynchronousFileSystem;\n\t\n\t SynchronousFileSystem.prototype.supportsSynch = function supportsSynch () {\n\t return true;\n\t };\n\t SynchronousFileSystem.prototype.rename = function rename (oldPath, newPath, cb) {\n\t try {\n\t this.renameSync(oldPath, newPath);\n\t cb();\n\t }\n\t catch (e) {\n\t cb(e);\n\t }\n\t };\n\t SynchronousFileSystem.prototype.stat = function stat (p, isLstat, cb) {\n\t try {\n\t cb(null, this.statSync(p, isLstat));\n\t }\n\t catch (e) {\n\t cb(e);\n\t }\n\t };\n\t SynchronousFileSystem.prototype.open = function open (p, flags, mode, cb) {\n\t try {\n\t cb(null, this.openSync(p, flags, mode));\n\t }\n\t catch (e) {\n\t cb(e);\n\t }\n\t };\n\t SynchronousFileSystem.prototype.unlink = function unlink (p, cb) {\n\t try {\n\t this.unlinkSync(p);\n\t cb();\n\t }\n\t catch (e) {\n\t cb(e);\n\t }\n\t };\n\t SynchronousFileSystem.prototype.rmdir = function rmdir (p, cb) {\n\t try {\n\t this.rmdirSync(p);\n\t cb();\n\t }\n\t catch (e) {\n\t cb(e);\n\t }\n\t };\n\t SynchronousFileSystem.prototype.mkdir = function mkdir (p, mode, cb) {\n\t try {\n\t this.mkdirSync(p, mode);\n\t cb();\n\t }\n\t catch (e) {\n\t cb(e);\n\t }\n\t };\n\t SynchronousFileSystem.prototype.readdir = function readdir (p, cb) {\n\t try {\n\t cb(null, this.readdirSync(p));\n\t }\n\t catch (e) {\n\t cb(e);\n\t }\n\t };\n\t SynchronousFileSystem.prototype.chmod = function chmod (p, isLchmod, mode, cb) {\n\t try {\n\t this.chmodSync(p, isLchmod, mode);\n\t cb();\n\t }\n\t catch (e) {\n\t cb(e);\n\t }\n\t };\n\t SynchronousFileSystem.prototype.chown = function chown (p, isLchown, uid, gid, cb) {\n\t try {\n\t this.chownSync(p, isLchown, uid, gid);\n\t cb();\n\t }\n\t catch (e) {\n\t cb(e);\n\t }\n\t };\n\t SynchronousFileSystem.prototype.utimes = function utimes (p, atime, mtime, cb) {\n\t try {\n\t this.utimesSync(p, atime, mtime);\n\t cb();\n\t }\n\t catch (e) {\n\t cb(e);\n\t }\n\t };\n\t SynchronousFileSystem.prototype.link = function link (srcpath, dstpath, cb) {\n\t try {\n\t this.linkSync(srcpath, dstpath);\n\t cb();\n\t }\n\t catch (e) {\n\t cb(e);\n\t }\n\t };\n\t SynchronousFileSystem.prototype.symlink = function symlink (srcpath, dstpath, type, cb) {\n\t try {\n\t this.symlinkSync(srcpath, dstpath, type);\n\t cb();\n\t }\n\t catch (e) {\n\t cb(e);\n\t }\n\t };\n\t SynchronousFileSystem.prototype.readlink = function readlink (p, cb) {\n\t try {\n\t cb(null, this.readlinkSync(p));\n\t }\n\t catch (e) {\n\t cb(e);\n\t }\n\t };\n\t\n\t return SynchronousFileSystem;\n\t}(BaseFileSystem));\n\t\n\t/**\n\t * Base class that contains shared implementations of functions for the file\n\t * object.\n\t */\n\tvar BaseFile = function BaseFile () {};\n\t\n\tBaseFile.prototype.sync = function sync (cb) {\n\t cb(new ApiError(ErrorCode.ENOTSUP));\n\t};\n\tBaseFile.prototype.syncSync = function syncSync () {\n\t throw new ApiError(ErrorCode.ENOTSUP);\n\t};\n\tBaseFile.prototype.datasync = function datasync (cb) {\n\t this.sync(cb);\n\t};\n\tBaseFile.prototype.datasyncSync = function datasyncSync () {\n\t return this.syncSync();\n\t};\n\tBaseFile.prototype.chown = function chown (uid, gid, cb) {\n\t cb(new ApiError(ErrorCode.ENOTSUP));\n\t};\n\tBaseFile.prototype.chownSync = function chownSync (uid, gid) {\n\t throw new ApiError(ErrorCode.ENOTSUP);\n\t};\n\tBaseFile.prototype.chmod = function chmod (mode, cb) {\n\t cb(new ApiError(ErrorCode.ENOTSUP));\n\t};\n\tBaseFile.prototype.chmodSync = function chmodSync (mode) {\n\t throw new ApiError(ErrorCode.ENOTSUP);\n\t};\n\tBaseFile.prototype.utimes = function utimes (atime, mtime, cb) {\n\t cb(new ApiError(ErrorCode.ENOTSUP));\n\t};\n\tBaseFile.prototype.utimesSync = function utimesSync (atime, mtime) {\n\t throw new ApiError(ErrorCode.ENOTSUP);\n\t};\n\t\n\t/**\n\t * An implementation of the File interface that operates on a file that is\n\t * completely in-memory. PreloadFiles are backed by a Buffer.\n\t *\n\t * This is also an abstract class, as it lacks an implementation of 'sync' and\n\t * 'close'. Each filesystem that wishes to use this file representation must\n\t * extend this class and implement those two methods.\n\t * @todo 'close' lever that disables functionality once closed.\n\t */\n\tvar PreloadFile = (function (BaseFile$$1) {\n\t function PreloadFile(_fs, _path, _flag, _stat, contents) {\n\t BaseFile$$1.call(this);\n\t this._pos = 0;\n\t this._dirty = false;\n\t this._fs = _fs;\n\t this._path = _path;\n\t this._flag = _flag;\n\t this._stat = _stat;\n\t if (contents) {\n\t this._buffer = contents;\n\t }\n\t else {\n\t // Empty buffer. It'll expand once we write stuff to it.\n\t this._buffer = new Buffer(0);\n\t }\n\t // Note: This invariant is *not* maintained once the file starts getting\n\t // modified.\n\t // Note: Only actually matters if file is readable, as writeable modes may\n\t // truncate/append to file.\n\t if (this._stat.size !== this._buffer.length && this._flag.isReadable()) {\n\t throw new Error((\"Invalid buffer: Buffer is \" + (this._buffer.length) + \" long, yet Stats object specifies that file is \" + (this._stat.size) + \" long.\"));\n\t }\n\t }\n\t\n\t if ( BaseFile$$1 ) PreloadFile.__proto__ = BaseFile$$1;\n\t PreloadFile.prototype = Object.create( BaseFile$$1 && BaseFile$$1.prototype );\n\t PreloadFile.prototype.constructor = PreloadFile;\n\t /**\n\t * NONSTANDARD: Get the underlying buffer for this file. !!DO NOT MUTATE!! Will mess up dirty tracking.\n\t */\n\t PreloadFile.prototype.getBuffer = function getBuffer () {\n\t return this._buffer;\n\t };\n\t /**\n\t * NONSTANDARD: Get underlying stats for this file. !!DO NOT MUTATE!!\n\t */\n\t PreloadFile.prototype.getStats = function getStats () {\n\t return this._stat;\n\t };\n\t PreloadFile.prototype.getFlag = function getFlag () {\n\t return this._flag;\n\t };\n\t /**\n\t * Get the path to this file.\n\t * @return [String] The path to the file.\n\t */\n\t PreloadFile.prototype.getPath = function getPath () {\n\t return this._path;\n\t };\n\t /**\n\t * Get the current file position.\n\t *\n\t * We emulate the following bug mentioned in the Node documentation:\n\t * > On Linux, positional writes don't work when the file is opened in append\n\t * mode. The kernel ignores the position argument and always appends the data\n\t * to the end of the file.\n\t * @return [Number] The current file position.\n\t */\n\t PreloadFile.prototype.getPos = function getPos () {\n\t if (this._flag.isAppendable()) {\n\t return this._stat.size;\n\t }\n\t return this._pos;\n\t };\n\t /**\n\t * Advance the current file position by the indicated number of positions.\n\t * @param [Number] delta\n\t */\n\t PreloadFile.prototype.advancePos = function advancePos (delta) {\n\t return this._pos += delta;\n\t };\n\t /**\n\t * Set the file position.\n\t * @param [Number] newPos\n\t */\n\t PreloadFile.prototype.setPos = function setPos (newPos) {\n\t return this._pos = newPos;\n\t };\n\t /**\n\t * **Core**: Asynchronous sync. Must be implemented by subclasses of this\n\t * class.\n\t * @param [Function(BrowserFS.ApiError)] cb\n\t */\n\t PreloadFile.prototype.sync = function sync (cb) {\n\t try {\n\t this.syncSync();\n\t cb();\n\t }\n\t catch (e) {\n\t cb(e);\n\t }\n\t };\n\t /**\n\t * **Core**: Synchronous sync.\n\t */\n\t PreloadFile.prototype.syncSync = function syncSync () {\n\t throw new ApiError(ErrorCode.ENOTSUP);\n\t };\n\t /**\n\t * **Core**: Asynchronous close. Must be implemented by subclasses of this\n\t * class.\n\t * @param [Function(BrowserFS.ApiError)] cb\n\t */\n\t PreloadFile.prototype.close = function close (cb) {\n\t try {\n\t this.closeSync();\n\t cb();\n\t }\n\t catch (e) {\n\t cb(e);\n\t }\n\t };\n\t /**\n\t * **Core**: Synchronous close.\n\t */\n\t PreloadFile.prototype.closeSync = function closeSync () {\n\t throw new ApiError(ErrorCode.ENOTSUP);\n\t };\n\t /**\n\t * Asynchronous `stat`.\n\t * @param [Function(BrowserFS.ApiError, BrowserFS.node.fs.Stats)] cb\n\t */\n\t PreloadFile.prototype.stat = function stat (cb) {\n\t try {\n\t cb(null, this._stat.clone());\n\t }\n\t catch (e) {\n\t cb(e);\n\t }\n\t };\n\t /**\n\t * Synchronous `stat`.\n\t */\n\t PreloadFile.prototype.statSync = function statSync () {\n\t return this._stat.clone();\n\t };\n\t /**\n\t * Asynchronous truncate.\n\t * @param [Number] len\n\t * @param [Function(BrowserFS.ApiError)] cb\n\t */\n\t PreloadFile.prototype.truncate = function truncate (len, cb) {\n\t try {\n\t this.truncateSync(len);\n\t if (this._flag.isSynchronous() && !_fsMock.getRootFS().supportsSynch()) {\n\t this.sync(cb);\n\t }\n\t cb();\n\t }\n\t catch (e) {\n\t return cb(e);\n\t }\n\t };\n\t /**\n\t * Synchronous truncate.\n\t * @param [Number] len\n\t */\n\t PreloadFile.prototype.truncateSync = function truncateSync (len) {\n\t this._dirty = true;\n\t if (!this._flag.isWriteable()) {\n\t throw new ApiError(ErrorCode.EPERM, 'File not opened with a writeable mode.');\n\t }\n\t this._stat.mtime = new Date();\n\t if (len > this._buffer.length) {\n\t var buf = new Buffer(len - this._buffer.length);\n\t buf.fill(0);\n\t // Write will set @_stat.size for us.\n\t this.writeSync(buf, 0, buf.length, this._buffer.length);\n\t if (this._flag.isSynchronous() && _fsMock.getRootFS().supportsSynch()) {\n\t this.syncSync();\n\t }\n\t return;\n\t }\n\t this._stat.size = len;\n\t // Truncate buffer to 'len'.\n\t var newBuff = new Buffer(len);\n\t this._buffer.copy(newBuff, 0, 0, len);\n\t this._buffer = newBuff;\n\t if (this._flag.isSynchronous() && _fsMock.getRootFS().supportsSynch()) {\n\t this.syncSync();\n\t }\n\t };\n\t /**\n\t * Write buffer to the file.\n\t * Note that it is unsafe to use fs.write multiple times on the same file\n\t * without waiting for the callback.\n\t * @param [BrowserFS.node.Buffer] buffer Buffer containing the data to write to\n\t * the file.\n\t * @param [Number] offset Offset in the buffer to start reading data from.\n\t * @param [Number] length The amount of bytes to write to the file.\n\t * @param [Number] position Offset from the beginning of the file where this\n\t * data should be written. If position is null, the data will be written at\n\t * the current position.\n\t * @param [Function(BrowserFS.ApiError, Number, BrowserFS.node.Buffer)]\n\t * cb The number specifies the number of bytes written into the file.\n\t */\n\t PreloadFile.prototype.write = function write (buffer$$1, offset, length, position, cb) {\n\t try {\n\t cb(null, this.writeSync(buffer$$1, offset, length, position), buffer$$1);\n\t }\n\t catch (e) {\n\t cb(e);\n\t }\n\t };\n\t /**\n\t * Write buffer to the file.\n\t * Note that it is unsafe to use fs.writeSync multiple times on the same file\n\t * without waiting for the callback.\n\t * @param [BrowserFS.node.Buffer] buffer Buffer containing the data to write to\n\t * the file.\n\t * @param [Number] offset Offset in the buffer to start reading data from.\n\t * @param [Number] length The amount of bytes to write to the file.\n\t * @param [Number] position Offset from the beginning of the file where this\n\t * data should be written. If position is null, the data will be written at\n\t * the current position.\n\t * @return [Number]\n\t */\n\t PreloadFile.prototype.writeSync = function writeSync (buffer$$1, offset, length, position) {\n\t this._dirty = true;\n\t if (position === undefined || position === null) {\n\t position = this.getPos();\n\t }\n\t if (!this._flag.isWriteable()) {\n\t throw new ApiError(ErrorCode.EPERM, 'File not opened with a writeable mode.');\n\t }\n\t var endFp = position + length;\n\t if (endFp > this._stat.size) {\n\t this._stat.size = endFp;\n\t if (endFp > this._buffer.length) {\n\t // Extend the buffer!\n\t var newBuff = new Buffer(endFp);\n\t this._buffer.copy(newBuff);\n\t this._buffer = newBuff;\n\t }\n\t }\n\t var len = buffer$$1.copy(this._buffer, position, offset, offset + length);\n\t this._stat.mtime = new Date();\n\t if (this._flag.isSynchronous()) {\n\t this.syncSync();\n\t return len;\n\t }\n\t this.setPos(position + len);\n\t return len;\n\t };\n\t /**\n\t * Read data from the file.\n\t * @param [BrowserFS.node.Buffer] buffer The buffer that the data will be\n\t * written to.\n\t * @param [Number] offset The offset within the buffer where writing will\n\t * start.\n\t * @param [Number] length An integer specifying the number of bytes to read.\n\t * @param [Number] position An integer specifying where to begin reading from\n\t * in the file. If position is null, data will be read from the current file\n\t * position.\n\t * @param [Function(BrowserFS.ApiError, Number, BrowserFS.node.Buffer)] cb The\n\t * number is the number of bytes read\n\t */\n\t PreloadFile.prototype.read = function read (buffer$$1, offset, length, position, cb) {\n\t try {\n\t cb(null, this.readSync(buffer$$1, offset, length, position), buffer$$1);\n\t }\n\t catch (e) {\n\t cb(e);\n\t }\n\t };\n\t /**\n\t * Read data from the file.\n\t * @param [BrowserFS.node.Buffer] buffer The buffer that the data will be\n\t * written to.\n\t * @param [Number] offset The offset within the buffer where writing will\n\t * start.\n\t * @param [Number] length An integer specifying the number of bytes to read.\n\t * @param [Number] position An integer specifying where to begin reading from\n\t * in the file. If position is null, data will be read from the current file\n\t * position.\n\t * @return [Number]\n\t */\n\t PreloadFile.prototype.readSync = function readSync (buffer$$1, offset, length, position) {\n\t if (!this._flag.isReadable()) {\n\t throw new ApiError(ErrorCode.EPERM, 'File not opened with a readable mode.');\n\t }\n\t if (position === undefined || position === null) {\n\t position = this.getPos();\n\t }\n\t var endRead = position + length;\n\t if (endRead > this._stat.size) {\n\t length = this._stat.size - position;\n\t }\n\t var rv = this._buffer.copy(buffer$$1, offset, position, position + length);\n\t this._stat.atime = new Date();\n\t this._pos = position + length;\n\t return rv;\n\t };\n\t /**\n\t * Asynchronous `fchmod`.\n\t * @param [Number|String] mode\n\t * @param [Function(BrowserFS.ApiError)] cb\n\t */\n\t PreloadFile.prototype.chmod = function chmod (mode, cb) {\n\t try {\n\t this.chmodSync(mode);\n\t cb();\n\t }\n\t catch (e) {\n\t cb(e);\n\t }\n\t };\n\t /**\n\t * Asynchronous `fchmod`.\n\t * @param [Number] mode\n\t */\n\t PreloadFile.prototype.chmodSync = function chmodSync (mode) {\n\t if (!this._fs.supportsProps()) {\n\t throw new ApiError(ErrorCode.ENOTSUP);\n\t }\n\t this._dirty = true;\n\t this._stat.chmod(mode);\n\t this.syncSync();\n\t };\n\t PreloadFile.prototype.isDirty = function isDirty () {\n\t return this._dirty;\n\t };\n\t /**\n\t * Resets the dirty bit. Should only be called after a sync has completed successfully.\n\t */\n\t PreloadFile.prototype.resetDirty = function resetDirty () {\n\t this._dirty = false;\n\t };\n\t\n\t return PreloadFile;\n\t}(BaseFile));\n\t\n\t/**\n\t * File class for the InMemory and XHR file systems.\n\t * Doesn't sync to anything, so it works nicely for memory-only files.\n\t */\n\tvar NoSyncFile = (function (PreloadFile) {\n\t function NoSyncFile(_fs, _path, _flag, _stat, contents) {\n\t PreloadFile.call(this, _fs, _path, _flag, _stat, contents);\n\t }\n\t\n\t if ( PreloadFile ) NoSyncFile.__proto__ = PreloadFile;\n\t NoSyncFile.prototype = Object.create( PreloadFile && PreloadFile.prototype );\n\t NoSyncFile.prototype.constructor = NoSyncFile;\n\t /**\n\t * Asynchronous sync. Doesn't do anything, simply calls the cb.\n\t * @param [Function(BrowserFS.ApiError)] cb\n\t */\n\t NoSyncFile.prototype.sync = function sync (cb) {\n\t cb();\n\t };\n\t /**\n\t * Synchronous sync. Doesn't do anything.\n\t */\n\t NoSyncFile.prototype.syncSync = function syncSync () {\n\t // NOP.\n\t };\n\t /**\n\t * Asynchronous close. Doesn't do anything, simply calls the cb.\n\t * @param [Function(BrowserFS.ApiError)] cb\n\t */\n\t NoSyncFile.prototype.close = function close (cb) {\n\t cb();\n\t };\n\t /**\n\t * Synchronous close. Doesn't do anything.\n\t */\n\t NoSyncFile.prototype.closeSync = function closeSync () {\n\t // NOP.\n\t };\n\t\n\t return NoSyncFile;\n\t}(PreloadFile));\n\t\n\t/**\n\t * We define our own file to interpose on syncSync() for mirroring purposes.\n\t */\n\tvar MirrorFile = (function (PreloadFile$$1) {\n\t function MirrorFile(fs, path$$1, flag, stat, data) {\n\t PreloadFile$$1.call(this, fs, path$$1, flag, stat, data);\n\t }\n\t\n\t if ( PreloadFile$$1 ) MirrorFile.__proto__ = PreloadFile$$1;\n\t MirrorFile.prototype = Object.create( PreloadFile$$1 && PreloadFile$$1.prototype );\n\t MirrorFile.prototype.constructor = MirrorFile;\n\t MirrorFile.prototype.syncSync = function syncSync () {\n\t if (this.isDirty()) {\n\t this._fs._syncSync(this);\n\t this.resetDirty();\n\t }\n\t };\n\t MirrorFile.prototype.closeSync = function closeSync () {\n\t this.syncSync();\n\t };\n\t\n\t return MirrorFile;\n\t}(PreloadFile));\n\t/**\n\t * AsyncMirrorFS mirrors a synchronous filesystem into an asynchronous filesystem\n\t * by:\n\t * * Performing operations over the in-memory copy, while asynchronously pipelining them\n\t * to the backing store.\n\t * * During application loading, the contents of the async file system can be reloaded into\n\t * the synchronous store, if desired.\n\t * The two stores will be kept in sync. The most common use-case is to pair a synchronous\n\t * in-memory filesystem with an asynchronous backing store.\n\t */\n\tvar AsyncMirror = (function (SynchronousFileSystem$$1) {\n\t function AsyncMirror(sync, async) {\n\t SynchronousFileSystem$$1.call(this);\n\t /**\n\t * Queue of pending asynchronous operations.\n\t */\n\t this._queue = [];\n\t this._queueRunning = false;\n\t this._isInitialized = false;\n\t this._initializeCallbacks = [];\n\t this._sync = sync;\n\t this._async = async;\n\t if (!sync.supportsSynch()) {\n\t throw new Error(\"The first argument to AsyncMirror needs to be a synchronous file system.\");\n\t }\n\t }\n\t\n\t if ( SynchronousFileSystem$$1 ) AsyncMirror.__proto__ = SynchronousFileSystem$$1;\n\t AsyncMirror.prototype = Object.create( SynchronousFileSystem$$1 && SynchronousFileSystem$$1.prototype );\n\t AsyncMirror.prototype.constructor = AsyncMirror;\n\t AsyncMirror.isAvailable = function isAvailable () {\n\t return true;\n\t };\n\t AsyncMirror.prototype.getName = function getName () {\n\t return \"AsyncMirror\";\n\t };\n\t AsyncMirror.prototype._syncSync = function _syncSync (fd) {\n\t this._sync.writeFileSync(fd.getPath(), fd.getBuffer(), null, FileFlag.getFileFlag('w'), fd.getStats().mode);\n\t this.enqueueOp({\n\t apiMethod: 'writeFile',\n\t arguments: [fd.getPath(), fd.getBuffer(), null, fd.getFlag(), fd.getStats().mode]\n\t });\n\t };\n\t /**\n\t * Called once to load up files from async storage into sync storage.\n\t */\n\t AsyncMirror.prototype.initialize = function initialize (userCb) {\n\t var this$1 = this;\n\t\n\t var callbacks = this._initializeCallbacks;\n\t var end = function (e) {\n\t this$1._isInitialized = !e;\n\t this$1._initializeCallbacks = [];\n\t callbacks.forEach(function (cb) { return cb(e); });\n\t };\n\t if (!this._isInitialized) {\n\t // First call triggers initialization, the rest wait.\n\t if (callbacks.push(userCb) === 1) {\n\t var copyDirectory = function (p, mode, cb) {\n\t if (p !== '/') {\n\t this$1._sync.mkdirSync(p, mode);\n\t }\n\t this$1._async.readdir(p, function (err, files) {\n\t var i = 0;\n\t // NOTE: This function must not be in a lexically nested statement,\n\t // such as an if or while statement. Safari refuses to run the\n\t // script since it is undefined behavior.\n\t function copyNextFile(err) {\n\t if (err) {\n\t cb(err);\n\t }\n\t else if (i < files.length) {\n\t copyItem(path.join(p, files[i]), copyNextFile);\n\t i++;\n\t }\n\t else {\n\t cb();\n\t }\n\t }\n\t if (err) {\n\t cb(err);\n\t }\n\t else {\n\t copyNextFile();\n\t }\n\t });\n\t }, copyFile = function (p, mode, cb) {\n\t this$1._async.readFile(p, null, FileFlag.getFileFlag('r'), function (err, data) {\n\t if (err) {\n\t cb(err);\n\t }\n\t else {\n\t try {\n\t this$1._sync.writeFileSync(p, data, null, FileFlag.getFileFlag('w'), mode);\n\t }\n\t catch (e) {\n\t err = e;\n\t }\n\t finally {\n\t cb(err);\n\t }\n\t }\n\t });\n\t }, copyItem = function (p, cb) {\n\t this$1._async.stat(p, false, function (err, stats) {\n\t if (err) {\n\t cb(err);\n\t }\n\t else if (stats.isDirectory()) {\n\t copyDirectory(p, stats.mode, cb);\n\t }\n\t else {\n\t copyFile(p, stats.mode, cb);\n\t }\n\t });\n\t };\n\t copyDirectory('/', 0, end);\n\t }\n\t }\n\t else {\n\t userCb();\n\t }\n\t };\n\t AsyncMirror.prototype.isReadOnly = function isReadOnly () { return false; };\n\t AsyncMirror.prototype.supportsSynch = function supportsSynch () { return true; };\n\t AsyncMirror.prototype.supportsLinks = function supportsLinks () { return false; };\n\t AsyncMirror.prototype.supportsProps = function supportsProps () { return this._sync.supportsProps() && this._async.supportsProps(); };\n\t AsyncMirror.prototype.renameSync = function renameSync (oldPath, newPath) {\n\t this.checkInitialized();\n\t this._sync.renameSync(oldPath, newPath);\n\t this.enqueueOp({\n\t apiMethod: 'rename',\n\t arguments: [oldPath, newPath]\n\t });\n\t };\n\t AsyncMirror.prototype.statSync = function statSync (p, isLstat) {\n\t this.checkInitialized();\n\t return this._sync.statSync(p, isLstat);\n\t };\n\t AsyncMirror.prototype.openSync = function openSync (p, flag, mode) {\n\t this.checkInitialized();\n\t // Sanity check: Is this open/close permitted?\n\t var fd = this._sync.openSync(p, flag, mode);\n\t fd.closeSync();\n\t return new MirrorFile(this, p, flag, this._sync.statSync(p, false), this._sync.readFileSync(p, null, FileFlag.getFileFlag('r')));\n\t };\n\t AsyncMirror.prototype.unlinkSync = function unlinkSync (p) {\n\t this.checkInitialized();\n\t this._sync.unlinkSync(p);\n\t this.enqueueOp({\n\t apiMethod: 'unlink',\n\t arguments: [p]\n\t });\n\t };\n\t AsyncMirror.prototype.rmdirSync = function rmdirSync (p) {\n\t this.checkInitialized();\n\t this._sync.rmdirSync(p);\n\t this.enqueueOp({\n\t apiMethod: 'rmdir',\n\t arguments: [p]\n\t });\n\t };\n\t AsyncMirror.prototype.mkdirSync = function mkdirSync (p, mode) {\n\t this.checkInitialized();\n\t this._sync.mkdirSync(p, mode);\n\t this.enqueueOp({\n\t apiMethod: 'mkdir',\n\t arguments: [p, mode]\n\t });\n\t };\n\t AsyncMirror.prototype.readdirSync = function readdirSync (p) {\n\t this.checkInitialized();\n\t return this._sync.readdirSync(p);\n\t };\n\t AsyncMirror.prototype.existsSync = function existsSync (p) {\n\t this.checkInitialized();\n\t return this._sync.existsSync(p);\n\t };\n\t AsyncMirror.prototype.chmodSync = function chmodSync (p, isLchmod, mode) {\n\t this.checkInitialized();\n\t this._sync.chmodSync(p, isLchmod, mode);\n\t this.enqueueOp({\n\t apiMethod: 'chmod',\n\t arguments: [p, isLchmod, mode]\n\t });\n\t };\n\t AsyncMirror.prototype.chownSync = function chownSync (p, isLchown, uid, gid) {\n\t this.checkInitialized();\n\t this._sync.chownSync(p, isLchown, uid, gid);\n\t this.enqueueOp({\n\t apiMethod: 'chown',\n\t arguments: [p, isLchown, uid, gid]\n\t });\n\t };\n\t AsyncMirror.prototype.utimesSync = function utimesSync (p, atime, mtime) {\n\t this.checkInitialized();\n\t this._sync.utimesSync(p, atime, mtime);\n\t this.enqueueOp({\n\t apiMethod: 'utimes',\n\t arguments: [p, atime, mtime]\n\t });\n\t };\n\t AsyncMirror.prototype.checkInitialized = function checkInitialized () {\n\t if (!this._isInitialized) {\n\t throw new ApiError(ErrorCode.EPERM, \"AsyncMirrorFS is not initialized. Please initialize AsyncMirrorFS using its initialize() method before using it.\");\n\t }\n\t };\n\t AsyncMirror.prototype.enqueueOp = function enqueueOp (op) {\n\t var this$1 = this;\n\t\n\t this._queue.push(op);\n\t if (!this._queueRunning) {\n\t this._queueRunning = true;\n\t var doNextOp = function (err) {\n\t if (err) {\n\t console.error((\"WARNING: File system has desynchronized. Received following error: \" + err + \"\\n$\"));\n\t }\n\t if (this$1._queue.length > 0) {\n\t var op = this$1._queue.shift(), args = op.arguments;\n\t args.push(doNextOp);\n\t this$1._async[op.apiMethod].apply(this$1._async, args);\n\t }\n\t else {\n\t this$1._queueRunning = false;\n\t }\n\t };\n\t doNextOp();\n\t }\n\t };\n\t\n\t return AsyncMirror;\n\t}(SynchronousFileSystem));\n\t\n\t/**\n\t * A faster alternative to `Function#apply`, this function invokes `func`\n\t * with the `this` binding of `thisArg` and the arguments of `args`.\n\t *\n\t * @private\n\t * @param {Function} func The function to invoke.\n\t * @param {*} thisArg The `this` binding of `func`.\n\t * @param {Array} args The arguments to invoke `func` with.\n\t * @returns {*} Returns the result of `func`.\n\t */\n\tfunction apply(func, thisArg, args) {\n\t switch (args.length) {\n\t case 0: return func.call(thisArg);\n\t case 1: return func.call(thisArg, args[0]);\n\t case 2: return func.call(thisArg, args[0], args[1]);\n\t case 3: return func.call(thisArg, args[0], args[1], args[2]);\n\t }\n\t return func.apply(thisArg, args);\n\t}\n\t\n\t/* Built-in method references for those with the same name as other `lodash` methods. */\n\tvar nativeMax = Math.max;\n\t\n\t/**\n\t * A specialized version of `baseRest` which transforms the rest array.\n\t *\n\t * @private\n\t * @param {Function} func The function to apply a rest parameter to.\n\t * @param {number} [start=func.length-1] The start position of the rest parameter.\n\t * @param {Function} transform The rest array transform.\n\t * @returns {Function} Returns the new function.\n\t */\n\tfunction overRest$1(func, start, transform) {\n\t start = nativeMax(start === undefined ? (func.length - 1) : start, 0);\n\t return function() {\n\t var args = arguments,\n\t index = -1,\n\t length = nativeMax(args.length - start, 0),\n\t array = Array(length);\n\t\n\t while (++index < length) {\n\t array[index] = args[start + index];\n\t }\n\t index = -1;\n\t var otherArgs = Array(start + 1);\n\t while (++index < start) {\n\t otherArgs[index] = args[index];\n\t }\n\t otherArgs[start] = transform(array);\n\t return apply(func, this, otherArgs);\n\t };\n\t}\n\t\n\t/**\n\t * This method returns the first argument it receives.\n\t *\n\t * @static\n\t * @since 0.1.0\n\t * @memberOf _\n\t * @category Util\n\t * @param {*} value Any value.\n\t * @returns {*} Returns `value`.\n\t * @example\n\t *\n\t * var object = { 'a': 1 };\n\t *\n\t * console.log(_.identity(object) === object);\n\t * // => true\n\t */\n\tfunction identity(value) {\n\t return value;\n\t}\n\t\n\t// Lodash rest function without function.toString()\n\t// remappings\n\tfunction rest(func, start) {\n\t return overRest$1(func, start, identity);\n\t}\n\t\n\tvar initialParams = function (fn) {\n\t return rest(function (args/*..., callback*/) {\n\t var callback = args.pop();\n\t fn.call(this, args, callback);\n\t });\n\t};\n\t\n\tfunction applyEach$1(eachfn) {\n\t return rest(function(fns, args) {\n\t var go = initialParams(function(args, callback) {\n\t var that = this;\n\t return eachfn(fns, function (fn, cb) {\n\t fn.apply(that, args.concat([cb]));\n\t }, callback);\n\t });\n\t if (args.length) {\n\t return go.apply(this, args);\n\t }\n\t else {\n\t return go;\n\t }\n\t });\n\t}\n\t\n\t/** Detect free variable `global` from Node.js. */\n\tvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\t\n\t/** Detect free variable `self`. */\n\tvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\t\n\t/** Used as a reference to the global object. */\n\tvar root = freeGlobal || freeSelf || Function('return this')();\n\t\n\t/** Built-in value references. */\n\tvar Symbol$1 = root.Symbol;\n\t\n\t/** Used for built-in method references. */\n\tvar objectProto = Object.prototype;\n\t\n\t/** Used to check objects for own properties. */\n\tvar hasOwnProperty = objectProto.hasOwnProperty;\n\t\n\t/**\n\t * Used to resolve the\n\t * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n\t * of values.\n\t */\n\tvar nativeObjectToString = objectProto.toString;\n\t\n\t/** Built-in value references. */\n\tvar symToStringTag$1 = Symbol$1 ? Symbol$1.toStringTag : undefined;\n\t\n\t/**\n\t * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values.\n\t *\n\t * @private\n\t * @param {*} value The value to query.\n\t * @returns {string} Returns the raw `toStringTag`.\n\t */\n\tfunction getRawTag(value) {\n\t var isOwn = hasOwnProperty.call(value, symToStringTag$1),\n\t tag = value[symToStringTag$1];\n\t\n\t try {\n\t value[symToStringTag$1] = undefined;\n\t var unmasked = true;\n\t } catch (e) {}\n\t\n\t var result = nativeObjectToString.call(value);\n\t if (unmasked) {\n\t if (isOwn) {\n\t value[symToStringTag$1] = tag;\n\t } else {\n\t delete value[symToStringTag$1];\n\t }\n\t }\n\t return result;\n\t}\n\t\n\t/** Used for built-in method references. */\n\tvar objectProto$1 = Object.prototype;\n\t\n\t/**\n\t * Used to resolve the\n\t * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n\t * of values.\n\t */\n\tvar nativeObjectToString$1 = objectProto$1.toString;\n\t\n\t/**\n\t * Converts `value` to a string using `Object.prototype.toString`.\n\t *\n\t * @private\n\t * @param {*} value The value to convert.\n\t * @returns {string} Returns the converted string.\n\t */\n\tfunction objectToString(value) {\n\t return nativeObjectToString$1.call(value);\n\t}\n\t\n\t/** `Object#toString` result references. */\n\tvar nullTag = '[object Null]';\n\tvar undefinedTag = '[object Undefined]';\n\t\n\t/** Built-in value references. */\n\tvar symToStringTag = Symbol$1 ? Symbol$1.toStringTag : undefined;\n\t\n\t/**\n\t * The base implementation of `getTag` without fallbacks for buggy environments.\n\t *\n\t * @private\n\t * @param {*} value The value to query.\n\t * @returns {string} Returns the `toStringTag`.\n\t */\n\tfunction baseGetTag(value) {\n\t if (value == null) {\n\t return value === undefined ? undefinedTag : nullTag;\n\t }\n\t return (symToStringTag && symToStringTag in Object(value))\n\t ? getRawTag(value)\n\t : objectToString(value);\n\t}\n\t\n\t/**\n\t * Checks if `value` is the\n\t * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n\t * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n\t *\n\t * @static\n\t * @memberOf _\n\t * @since 0.1.0\n\t * @category Lang\n\t * @param {*} value The value to check.\n\t * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n\t * @example\n\t *\n\t * _.isObject({});\n\t * // => true\n\t *\n\t * _.isObject([1, 2, 3]);\n\t * // => true\n\t *\n\t * _.isObject(_.noop);\n\t * // => true\n\t *\n\t * _.isObject(null);\n\t * // => false\n\t */\n\tfunction isObject(value) {\n\t var type = typeof value;\n\t return value != null && (type == 'object' || type == 'function');\n\t}\n\t\n\t/** `Object#toString` result references. */\n\tvar asyncTag = '[object AsyncFunction]';\n\tvar funcTag = '[object Function]';\n\tvar genTag = '[object GeneratorFunction]';\n\tvar proxyTag = '[object Proxy]';\n\t\n\t/**\n\t * Checks if `value` is classified as a `Function` object.\n\t *\n\t * @static\n\t * @memberOf _\n\t * @since 0.1.0\n\t * @category Lang\n\t * @param {*} value The value to check.\n\t * @returns {boolean} Returns `true` if `value` is a function, else `false`.\n\t * @example\n\t *\n\t * _.isFunction(_);\n\t * // => true\n\t *\n\t * _.isFunction(/abc/);\n\t * // => false\n\t */\n\tfunction isFunction(value) {\n\t if (!isObject(value)) {\n\t return false;\n\t }\n\t // The use of `Object#toString` avoids issues with the `typeof` operator\n\t // in Safari 9 which returns 'object' for typed arrays and other constructors.\n\t var tag = baseGetTag(value);\n\t return tag == funcTag || tag == genTag || tag == asyncTag || tag == proxyTag;\n\t}\n\t\n\t/** Used as references for various `Number` constants. */\n\tvar MAX_SAFE_INTEGER = 9007199254740991;\n\t\n\t/**\n\t * Checks if `value` is a valid array-like length.\n\t *\n\t * **Note:** This method is loosely based on\n\t * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\n\t *\n\t * @static\n\t * @memberOf _\n\t * @since 4.0.0\n\t * @category Lang\n\t * @param {*} value The value to check.\n\t * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.\n\t * @example\n\t *\n\t * _.isLength(3);\n\t * // => true\n\t *\n\t * _.isLength(Number.MIN_VALUE);\n\t * // => false\n\t *\n\t * _.isLength(Infinity);\n\t * // => false\n\t *\n\t * _.isLength('3');\n\t * // => false\n\t */\n\tfunction isLength(value) {\n\t return typeof value == 'number' &&\n\t value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;\n\t}\n\t\n\t/**\n\t * Checks if `value` is array-like. A value is considered array-like if it's\n\t * not a function and has a `value.length` that's an integer greater than or\n\t * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.\n\t *\n\t * @static\n\t * @memberOf _\n\t * @since 4.0.0\n\t * @category Lang\n\t * @param {*} value The value to check.\n\t * @returns {boolean} Returns `true` if `value` is array-like, else `false`.\n\t * @example\n\t *\n\t * _.isArrayLike([1, 2, 3]);\n\t * // => true\n\t *\n\t * _.isArrayLike(document.body.children);\n\t * // => true\n\t *\n\t * _.isArrayLike('abc');\n\t * // => true\n\t *\n\t * _.isArrayLike(_.noop);\n\t * // => false\n\t */\n\tfunction isArrayLike(value) {\n\t return value != null && isLength(value.length) && !isFunction(value);\n\t}\n\t\n\t/**\n\t * This method returns `undefined`.\n\t *\n\t * @static\n\t * @memberOf _\n\t * @since 2.3.0\n\t * @category Util\n\t * @example\n\t *\n\t * _.times(2, _.noop);\n\t * // => [undefined, undefined]\n\t */\n\tfunction noop() {\n\t // No operation performed.\n\t}\n\t\n\tfunction once(fn) {\n\t return function () {\n\t if (fn === null) { return; }\n\t var callFn = fn;\n\t fn = null;\n\t callFn.apply(this, arguments);\n\t };\n\t}\n\t\n\tvar iteratorSymbol = typeof Symbol === 'function' && Symbol.iterator;\n\t\n\tvar getIterator = function (coll) {\n\t return iteratorSymbol && coll[iteratorSymbol] && coll[iteratorSymbol]();\n\t};\n\t\n\t/**\n\t * The base implementation of `_.times` without support for iteratee shorthands\n\t * or max array length checks.\n\t *\n\t * @private\n\t * @param {number} n The number of times to invoke `iteratee`.\n\t * @param {Function} iteratee The function invoked per iteration.\n\t * @returns {Array} Returns the array of results.\n\t */\n\tfunction baseTimes(n, iteratee) {\n\t var index = -1,\n\t result = Array(n);\n\t\n\t while (++index < n) {\n\t result[index] = iteratee(index);\n\t }\n\t return result;\n\t}\n\t\n\t/**\n\t * Checks if `value` is object-like. A value is object-like if it's not `null`\n\t * and has a `typeof` result of \"object\".\n\t *\n\t * @static\n\t * @memberOf _\n\t * @since 4.0.0\n\t * @category Lang\n\t * @param {*} value The value to check.\n\t * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n\t * @example\n\t *\n\t * _.isObjectLike({});\n\t * // => true\n\t *\n\t * _.isObjectLike([1, 2, 3]);\n\t * // => true\n\t *\n\t * _.isObjectLike(_.noop);\n\t * // => false\n\t *\n\t * _.isObjectLike(null);\n\t * // => false\n\t */\n\tfunction isObjectLike(value) {\n\t return value != null && typeof value == 'object';\n\t}\n\t\n\t/** `Object#toString` result references. */\n\tvar argsTag = '[object Arguments]';\n\t\n\t/**\n\t * The base implementation of `_.isArguments`.\n\t *\n\t * @private\n\t * @param {*} value The value to check.\n\t * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n\t */\n\tfunction baseIsArguments(value) {\n\t return isObjectLike(value) && baseGetTag(value) == argsTag;\n\t}\n\t\n\t/** Used for built-in method references. */\n\tvar objectProto$3 = Object.prototype;\n\t\n\t/** Used to check objects for own properties. */\n\tvar hasOwnProperty$2 = objectProto$3.hasOwnProperty;\n\t\n\t/** Built-in value references. */\n\tvar propertyIsEnumerable = objectProto$3.propertyIsEnumerable;\n\t\n\t/**\n\t * Checks if `value` is likely an `arguments` object.\n\t *\n\t * @static\n\t * @memberOf _\n\t * @since 0.1.0\n\t * @category Lang\n\t * @param {*} value The value to check.\n\t * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n\t * else `false`.\n\t * @example\n\t *\n\t * _.isArguments(function() { return arguments; }());\n\t * // => true\n\t *\n\t * _.isArguments([1, 2, 3]);\n\t * // => false\n\t */\n\tvar isArguments = baseIsArguments(function() { return arguments; }()) ? baseIsArguments : function(value) {\n\t return isObjectLike(value) && hasOwnProperty$2.call(value, 'callee') &&\n\t !propertyIsEnumerable.call(value, 'callee');\n\t};\n\t\n\t/**\n\t * Checks if `value` is classified as an `Array` object.\n\t *\n\t * @static\n\t * @memberOf _\n\t * @since 0.1.0\n\t * @category Lang\n\t * @param {*} value The value to check.\n\t * @returns {boolean} Returns `true` if `value` is an array, else `false`.\n\t * @example\n\t *\n\t * _.isArray([1, 2, 3]);\n\t * // => true\n\t *\n\t * _.isArray(document.body.children);\n\t * // => false\n\t *\n\t * _.isArray('abc');\n\t * // => false\n\t *\n\t * _.isArray(_.noop);\n\t * // => false\n\t */\n\tvar isArray = Array.isArray;\n\t\n\t/**\n\t * This method returns `false`.\n\t *\n\t * @static\n\t * @memberOf _\n\t * @since 4.13.0\n\t * @category Util\n\t * @returns {boolean} Returns `false`.\n\t * @example\n\t *\n\t * _.times(2, _.stubFalse);\n\t * // => [false, false]\n\t */\n\tfunction stubFalse() {\n\t return false;\n\t}\n\t\n\t/** Detect free variable `exports`. */\n\tvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\t\n\t/** Detect free variable `module`. */\n\tvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\t\n\t/** Detect the popular CommonJS extension `module.exports`. */\n\tvar moduleExports = freeModule && freeModule.exports === freeExports;\n\t\n\t/** Built-in value references. */\n\tvar Buffer$1 = moduleExports ? root.Buffer : undefined;\n\t\n\t/* Built-in method references for those with the same name as other `lodash` methods. */\n\tvar nativeIsBuffer = Buffer$1 ? Buffer$1.isBuffer : undefined;\n\t\n\t/**\n\t * Checks if `value` is a buffer.\n\t *\n\t * @static\n\t * @memberOf _\n\t * @since 4.3.0\n\t * @category Lang\n\t * @param {*} value The value to check.\n\t * @returns {boolean} Returns `true` if `value` is a buffer, else `false`.\n\t * @example\n\t *\n\t * _.isBuffer(new Buffer(2));\n\t * // => true\n\t *\n\t * _.isBuffer(new Uint8Array(2));\n\t * // => false\n\t */\n\tvar isBuffer = nativeIsBuffer || stubFalse;\n\t\n\t/** Used as references for various `Number` constants. */\n\tvar MAX_SAFE_INTEGER$1 = 9007199254740991;\n\t\n\t/** Used to detect unsigned integer values. */\n\tvar reIsUint = /^(?:0|[1-9]\\d*)$/;\n\t\n\t/**\n\t * Checks if `value` is a valid array-like index.\n\t *\n\t * @private\n\t * @param {*} value The value to check.\n\t * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.\n\t * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.\n\t */\n\tfunction isIndex(value, length) {\n\t length = length == null ? MAX_SAFE_INTEGER$1 : length;\n\t return !!length &&\n\t (typeof value == 'number' || reIsUint.test(value)) &&\n\t (value > -1 && value % 1 == 0 && value < length);\n\t}\n\t\n\t/** `Object#toString` result references. */\n\tvar argsTag$1 = '[object Arguments]';\n\tvar arrayTag = '[object Array]';\n\tvar boolTag = '[object Boolean]';\n\tvar dateTag = '[object Date]';\n\tvar errorTag = '[object Error]';\n\tvar funcTag$1 = '[object Function]';\n\tvar mapTag = '[object Map]';\n\tvar numberTag = '[object Number]';\n\tvar objectTag = '[object Object]';\n\tvar regexpTag = '[object RegExp]';\n\tvar setTag = '[object Set]';\n\tvar stringTag = '[object String]';\n\tvar weakMapTag = '[object WeakMap]';\n\t\n\tvar arrayBufferTag = '[object ArrayBuffer]';\n\tvar dataViewTag = '[object DataView]';\n\tvar float32Tag = '[object Float32Array]';\n\tvar float64Tag = '[object Float64Array]';\n\tvar int8Tag = '[object Int8Array]';\n\tvar int16Tag = '[object Int16Array]';\n\tvar int32Tag = '[object Int32Array]';\n\tvar uint8Tag = '[object Uint8Array]';\n\tvar uint8ClampedTag = '[object Uint8ClampedArray]';\n\tvar uint16Tag = '[object Uint16Array]';\n\tvar uint32Tag = '[object Uint32Array]';\n\t\n\t/** Used to identify `toStringTag` values of typed arrays. */\n\tvar typedArrayTags = {};\n\ttypedArrayTags[float32Tag] = typedArrayTags[float64Tag] =\n\ttypedArrayTags[int8Tag] = typedArrayTags[int16Tag] =\n\ttypedArrayTags[int32Tag] = typedArrayTags[uint8Tag] =\n\ttypedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] =\n\ttypedArrayTags[uint32Tag] = true;\n\ttypedArrayTags[argsTag$1] = typedArrayTags[arrayTag] =\n\ttypedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] =\n\ttypedArrayTags[dataViewTag] = typedArrayTags[dateTag] =\n\ttypedArrayTags[errorTag] = typedArrayTags[funcTag$1] =\n\ttypedArrayTags[mapTag] = typedArrayTags[numberTag] =\n\ttypedArrayTags[objectTag] = typedArrayTags[regexpTag] =\n\ttypedArrayTags[setTag] = typedArrayTags[stringTag] =\n\ttypedArrayTags[weakMapTag] = false;\n\t\n\t/**\n\t * The base implementation of `_.isTypedArray` without Node.js optimizations.\n\t *\n\t * @private\n\t * @param {*} value The value to check.\n\t * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n\t */\n\tfunction baseIsTypedArray(value) {\n\t return isObjectLike(value) &&\n\t isLength(value.length) && !!typedArrayTags[baseGetTag(value)];\n\t}\n\t\n\t/**\n\t * The base implementation of `_.unary` without support for storing metadata.\n\t *\n\t * @private\n\t * @param {Function} func The function to cap arguments for.\n\t * @returns {Function} Returns the new capped function.\n\t */\n\tfunction baseUnary(func) {\n\t return function(value) {\n\t return func(value);\n\t };\n\t}\n\t\n\t/** Detect free variable `exports`. */\n\tvar freeExports$1 = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\t\n\t/** Detect free variable `module`. */\n\tvar freeModule$1 = freeExports$1 && typeof module == 'object' && module && !module.nodeType && module;\n\t\n\t/** Detect the popular CommonJS extension `module.exports`. */\n\tvar moduleExports$1 = freeModule$1 && freeModule$1.exports === freeExports$1;\n\t\n\t/** Detect free variable `process` from Node.js. */\n\tvar freeProcess = moduleExports$1 && freeGlobal.process;\n\t\n\t/** Used to access faster Node.js helpers. */\n\tvar nodeUtil = (function() {\n\t try {\n\t return freeProcess && freeProcess.binding && freeProcess.binding('util');\n\t } catch (e) {}\n\t}());\n\t\n\t/* Node.js helper references. */\n\tvar nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray;\n\t\n\t/**\n\t * Checks if `value` is classified as a typed array.\n\t *\n\t * @static\n\t * @memberOf _\n\t * @since 3.0.0\n\t * @category Lang\n\t * @param {*} value The value to check.\n\t * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n\t * @example\n\t *\n\t * _.isTypedArray(new Uint8Array);\n\t * // => true\n\t *\n\t * _.isTypedArray([]);\n\t * // => false\n\t */\n\tvar isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray;\n\t\n\t/** Used for built-in method references. */\n\tvar objectProto$2 = Object.prototype;\n\t\n\t/** Used to check objects for own properties. */\n\tvar hasOwnProperty$1 = objectProto$2.hasOwnProperty;\n\t\n\t/**\n\t * Creates an array of the enumerable property names of the array-like `value`.\n\t *\n\t * @private\n\t * @param {*} value The value to query.\n\t * @param {boolean} inherited Specify returning inherited property names.\n\t * @returns {Array} Returns the array of property names.\n\t */\n\tfunction arrayLikeKeys(value, inherited) {\n\t var isArr = isArray(value),\n\t isArg = !isArr && isArguments(value),\n\t isBuff = !isArr && !isArg && isBuffer(value),\n\t isType = !isArr && !isArg && !isBuff && isTypedArray(value),\n\t skipIndexes = isArr || isArg || isBuff || isType,\n\t result = skipIndexes ? baseTimes(value.length, String) : [],\n\t length = result.length;\n\t\n\t for (var key in value) {\n\t if ((inherited || hasOwnProperty$1.call(value, key)) &&\n\t !(skipIndexes && (\n\t // Safari 9 has enumerable `arguments.length` in strict mode.\n\t key == 'length' ||\n\t // Node.js 0.10 has enumerable non-index properties on buffers.\n\t (isBuff && (key == 'offset' || key == 'parent')) ||\n\t // PhantomJS 2 has enumerable non-index properties on typed arrays.\n\t (isType && (key == 'buffer' || key == 'byteLength' || key == 'byteOffset')) ||\n\t // Skip index properties.\n\t isIndex(key, length)\n\t ))) {\n\t result.push(key);\n\t }\n\t }\n\t return result;\n\t}\n\t\n\t/** Used for built-in method references. */\n\tvar objectProto$5 = Object.prototype;\n\t\n\t/**\n\t * Checks if `value` is likely a prototype object.\n\t *\n\t * @private\n\t * @param {*} value The value to check.\n\t * @returns {boolean} Returns `true` if `value` is a prototype, else `false`.\n\t */\n\tfunction isPrototype(value) {\n\t var Ctor = value && value.constructor,\n\t proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto$5;\n\t\n\t return value === proto;\n\t}\n\t\n\t/**\n\t * Creates a unary function that invokes `func` with its argument transformed.\n\t *\n\t * @private\n\t * @param {Function} func The function to wrap.\n\t * @param {Function} transform The argument transform.\n\t * @returns {Function} Returns the new function.\n\t */\n\tfunction overArg(func, transform) {\n\t return function(arg) {\n\t return func(transform(arg));\n\t };\n\t}\n\t\n\t/* Built-in method references for those with the same name as other `lodash` methods. */\n\tvar nativeKeys = overArg(Object.keys, Object);\n\t\n\t/** Used for built-in method references. */\n\tvar objectProto$4 = Object.prototype;\n\t\n\t/** Used to check objects for own properties. */\n\tvar hasOwnProperty$3 = objectProto$4.hasOwnProperty;\n\t\n\t/**\n\t * The base implementation of `_.keys` which doesn't treat sparse arrays as dense.\n\t *\n\t * @private\n\t * @param {Object} object The object to query.\n\t * @returns {Array} Returns the array of property names.\n\t */\n\tfunction baseKeys(object) {\n\t if (!isPrototype(object)) {\n\t return nativeKeys(object);\n\t }\n\t var result = [];\n\t for (var key in Object(object)) {\n\t if (hasOwnProperty$3.call(object, key) && key != 'constructor') {\n\t result.push(key);\n\t }\n\t }\n\t return result;\n\t}\n\t\n\t/**\n\t * Creates an array of the own enumerable property names of `object`.\n\t *\n\t * **Note:** Non-object values are coerced to objects. See the\n\t * [ES spec](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\n\t * for more details.\n\t *\n\t * @static\n\t * @since 0.1.0\n\t * @memberOf _\n\t * @category Object\n\t * @param {Object} object The object to query.\n\t * @returns {Array} Returns the array of property names.\n\t * @example\n\t *\n\t * function Foo() {\n\t * this.a = 1;\n\t * this.b = 2;\n\t * }\n\t *\n\t * Foo.prototype.c = 3;\n\t *\n\t * _.keys(new Foo);\n\t * // => ['a', 'b'] (iteration order is not guaranteed)\n\t *\n\t * _.keys('hi');\n\t * // => ['0', '1']\n\t */\n\tfunction keys(object) {\n\t return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object);\n\t}\n\t\n\tfunction createArrayIterator(coll) {\n\t var i = -1;\n\t var len = coll.length;\n\t return function next() {\n\t return ++i < len ? {value: coll[i], key: i} : null;\n\t }\n\t}\n\t\n\tfunction createES2015Iterator(iterator) {\n\t var i = -1;\n\t return function next() {\n\t var item = iterator.next();\n\t if (item.done)\n\t { return null; }\n\t i++;\n\t return {value: item.value, key: i};\n\t }\n\t}\n\t\n\tfunction createObjectIterator(obj) {\n\t var okeys = keys(obj);\n\t var i = -1;\n\t var len = okeys.length;\n\t return function next() {\n\t var key = okeys[++i];\n\t return i < len ? {value: obj[key], key: key} : null;\n\t };\n\t}\n\t\n\tfunction iterator(coll) {\n\t if (isArrayLike(coll)) {\n\t return createArrayIterator(coll);\n\t }\n\t\n\t var iterator = getIterator(coll);\n\t return iterator ? createES2015Iterator(iterator) : createObjectIterator(coll);\n\t}\n\t\n\tfunction onlyOnce(fn) {\n\t return function() {\n\t if (fn === null) { throw new Error(\"Callback was already called.\"); }\n\t var callFn = fn;\n\t fn = null;\n\t callFn.apply(this, arguments);\n\t };\n\t}\n\t\n\t// A temporary value used to identify if the loop should be broken.\n\t// See #1064, #1293\n\tvar breakLoop = {};\n\t\n\tfunction _eachOfLimit(limit) {\n\t return function (obj, iteratee, callback) {\n\t callback = once(callback || noop);\n\t if (limit <= 0 || !obj) {\n\t return callback(null);\n\t }\n\t var nextElem = iterator(obj);\n\t var done = false;\n\t var running = 0;\n\t\n\t function iterateeCallback(err, value) {\n\t running -= 1;\n\t if (err) {\n\t done = true;\n\t callback(err);\n\t }\n\t else if (value === breakLoop || (done && running <= 0)) {\n\t done = true;\n\t return callback(null);\n\t }\n\t else {\n\t replenish();\n\t }\n\t }\n\t\n\t function replenish () {\n\t while (running < limit && !done) {\n\t var elem = nextElem();\n\t if (elem === null) {\n\t done = true;\n\t if (running <= 0) {\n\t callback(null);\n\t }\n\t return;\n\t }\n\t running += 1;\n\t iteratee(elem.value, elem.key, onlyOnce(iterateeCallback));\n\t }\n\t }\n\t\n\t replenish();\n\t };\n\t}\n\t\n\t/**\n\t * The same as [`eachOf`]{@link module:Collections.eachOf} but runs a maximum of `limit` async operations at a\n\t * time.\n\t *\n\t * @name eachOfLimit\n\t * @static\n\t * @memberOf module:Collections\n\t * @method\n\t * @see [async.eachOf]{@link module:Collections.eachOf}\n\t * @alias forEachOfLimit\n\t * @category Collection\n\t * @param {Array|Iterable|Object} coll - A collection to iterate over.\n\t * @param {number} limit - The maximum number of async operations at a time.\n\t * @param {Function} iteratee - A function to apply to each\n\t * item in `coll`. The `key` is the item's key, or index in the case of an\n\t * array. The iteratee is passed a `callback(err)` which must be called once it\n\t * has completed. If no error has occurred, the callback should be run without\n\t * arguments or with an explicit `null` argument. Invoked with\n\t * (item, key, callback).\n\t * @param {Function} [callback] - A callback which is called when all\n\t * `iteratee` functions have finished, or an error occurs. Invoked with (err).\n\t */\n\tfunction eachOfLimit(coll, limit, iteratee, callback) {\n\t _eachOfLimit(limit)(coll, iteratee, callback);\n\t}\n\t\n\tfunction doLimit(fn, limit) {\n\t return function (iterable, iteratee, callback) {\n\t return fn(iterable, limit, iteratee, callback);\n\t };\n\t}\n\t\n\t// eachOf implementation optimized for array-likes\n\tfunction eachOfArrayLike(coll, iteratee, callback) {\n\t callback = once(callback || noop);\n\t var index = 0,\n\t completed = 0,\n\t length = coll.length;\n\t if (length === 0) {\n\t callback(null);\n\t }\n\t\n\t function iteratorCallback(err) {\n\t if (err) {\n\t callback(err);\n\t } else if (++completed === length) {\n\t callback(null);\n\t }\n\t }\n\t\n\t for (; index < length; index++) {\n\t iteratee(coll[index], index, onlyOnce(iteratorCallback));\n\t }\n\t}\n\t\n\t// a generic version of eachOf which can handle array, object, and iterator cases.\n\tvar eachOfGeneric = doLimit(eachOfLimit, Infinity);\n\t\n\t/**\n\t * Like [`each`]{@link module:Collections.each}, except that it passes the key (or index) as the second argument\n\t * to the iteratee.\n\t *\n\t * @name eachOf\n\t * @static\n\t * @memberOf module:Collections\n\t * @method\n\t * @alias forEachOf\n\t * @category Collection\n\t * @see [async.each]{@link module:Collections.each}\n\t * @param {Array|Iterable|Object} coll - A collection to iterate over.\n\t * @param {Function} iteratee - A function to apply to each\n\t * item in `coll`. The `key` is the item's key, or index in the case of an\n\t * array. The iteratee is passed a `callback(err)` which must be called once it\n\t * has completed. If no error has occurred, the callback should be run without\n\t * arguments or with an explicit `null` argument. Invoked with\n\t * (item, key, callback).\n\t * @param {Function} [callback] - A callback which is called when all\n\t * `iteratee` functions have finished, or an error occurs. Invoked with (err).\n\t * @example\n\t *\n\t * var obj = {dev: \"/dev.json\", test: \"/test.json\", prod: \"/prod.json\"};\n\t * var configs = {};\n\t *\n\t * async.forEachOf(obj, function (value, key, callback) {\n\t * fs.readFile(__dirname + value, \"utf8\", function (err, data) {\n\t * if (err) return callback(err);\n\t * try {\n\t * configs[key] = JSON.parse(data);\n\t * } catch (e) {\n\t * return callback(e);\n\t * }\n\t * callback();\n\t * });\n\t * }, function (err) {\n\t * if (err) console.error(err.message);\n\t * // configs is now a map of JSON data\n\t * doSomethingWith(configs);\n\t * });\n\t */\n\tvar eachOf = function(coll, iteratee, callback) {\n\t var eachOfImplementation = isArrayLike(coll) ? eachOfArrayLike : eachOfGeneric;\n\t eachOfImplementation(coll, iteratee, callback);\n\t};\n\t\n\tfunction doParallel(fn) {\n\t return function (obj, iteratee, callback) {\n\t return fn(eachOf, obj, iteratee, callback);\n\t };\n\t}\n\t\n\tfunction _asyncMap(eachfn, arr, iteratee, callback) {\n\t callback = callback || noop;\n\t arr = arr || [];\n\t var results = [];\n\t var counter = 0;\n\t\n\t eachfn(arr, function (value, _, callback) {\n\t var index = counter++;\n\t iteratee(value, function (err, v) {\n\t results[index] = v;\n\t callback(err);\n\t });\n\t }, function (err) {\n\t callback(err, results);\n\t });\n\t}\n\t\n\t/**\n\t * Produces a new collection of values by mapping each value in `coll` through\n\t * the `iteratee` function. The `iteratee` is called with an item from `coll`\n\t * and a callback for when it has finished processing. Each of these callback\n\t * takes 2 arguments: an `error`, and the transformed item from `coll`. If\n\t * `iteratee` passes an error to its callback, the main `callback` (for the\n\t * `map` function) is immediately called with the error.\n\t *\n\t * Note, that since this function applies the `iteratee` to each item in\n\t * parallel, there is no guarantee that the `iteratee` functions will complete\n\t * in order. However, the results array will be in the same order as the\n\t * original `coll`.\n\t *\n\t * If `map` is passed an Object, the results will be an Array. The results\n\t * will roughly be in the order of the original Objects' keys (but this can\n\t * vary across JavaScript engines)\n\t *\n\t * @name map\n\t * @static\n\t * @memberOf module:Collections\n\t * @method\n\t * @category Collection\n\t * @param {Array|Iterable|Object} coll - A collection to iterate over.\n\t * @param {Function} iteratee - A function to apply to each item in `coll`.\n\t * The iteratee is passed a `callback(err, transformed)` which must be called\n\t * once it has completed with an error (which can be `null`) and a\n\t * transformed item. Invoked with (item, callback).\n\t * @param {Function} [callback] - A callback which is called when all `iteratee`\n\t * functions have finished, or an error occurs. Results is an Array of the\n\t * transformed items from the `coll`. Invoked with (err, results).\n\t * @example\n\t *\n\t * async.map(['file1','file2','file3'], fs.stat, function(err, results) {\n\t * // results is now an array of stats for each file\n\t * });\n\t */\n\tvar map = doParallel(_asyncMap);\n\t\n\t/**\n\t * Applies the provided arguments to each function in the array, calling\n\t * `callback` after all functions have completed. If you only provide the first\n\t * argument, `fns`, then it will return a function which lets you pass in the\n\t * arguments as if it were a single function call. If more arguments are\n\t * provided, `callback` is required while `args` is still optional.\n\t *\n\t * @name applyEach\n\t * @static\n\t * @memberOf module:ControlFlow\n\t * @method\n\t * @category Control Flow\n\t * @param {Array|Iterable|Object} fns - A collection of asynchronous functions\n\t * to all call with the same arguments\n\t * @param {...*} [args] - any number of separate arguments to pass to the\n\t * function.\n\t * @param {Function} [callback] - the final argument should be the callback,\n\t * called when all functions have completed processing.\n\t * @returns {Function} - If only the first argument, `fns`, is provided, it will\n\t * return a function which lets you pass in the arguments as if it were a single\n\t * function call. The signature is `(..args, callback)`. If invoked with any\n\t * arguments, `callback` is required.\n\t * @example\n\t *\n\t * async.applyEach([enableSearch, updateSchema], 'bucket', callback);\n\t *\n\t * // partial application example:\n\t * async.each(\n\t * buckets,\n\t * async.applyEach([enableSearch, updateSchema]),\n\t * callback\n\t * );\n\t */\n\tapplyEach$1(map);\n\t\n\tfunction doParallelLimit(fn) {\n\t return function (obj, limit, iteratee, callback) {\n\t return fn(_eachOfLimit(limit), obj, iteratee, callback);\n\t };\n\t}\n\t\n\t/**\n\t * The same as [`map`]{@link module:Collections.map} but runs a maximum of `limit` async operations at a time.\n\t *\n\t * @name mapLimit\n\t * @static\n\t * @memberOf module:Collections\n\t * @method\n\t * @see [async.map]{@link module:Collections.map}\n\t * @category Collection\n\t * @param {Array|Iterable|Object} coll - A collection to iterate over.\n\t * @param {number} limit - The maximum number of async operations at a time.\n\t * @param {Function} iteratee - A function to apply to each item in `coll`.\n\t * The iteratee is passed a `callback(err, transformed)` which must be called\n\t * once it has completed with an error (which can be `null`) and a transformed\n\t * item. Invoked with (item, callback).\n\t * @param {Function} [callback] - A callback which is called when all `iteratee`\n\t * functions have finished, or an error occurs. Results is an array of the\n\t * transformed items from the `coll`. Invoked with (err, results).\n\t */\n\tvar mapLimit = doParallelLimit(_asyncMap);\n\t\n\t/**\n\t * The same as [`map`]{@link module:Collections.map} but runs only a single async operation at a time.\n\t *\n\t * @name mapSeries\n\t * @static\n\t * @memberOf module:Collections\n\t * @method\n\t * @see [async.map]{@link module:Collections.map}\n\t * @category Collection\n\t * @param {Array|Iterable|Object} coll - A collection to iterate over.\n\t * @param {Function} iteratee - A function to apply to each item in `coll`.\n\t * The iteratee is passed a `callback(err, transformed)` which must be called\n\t * once it has completed with an error (which can be `null`) and a\n\t * transformed item. Invoked with (item, callback).\n\t * @param {Function} [callback] - A callback which is called when all `iteratee`\n\t * functions have finished, or an error occurs. Results is an array of the\n\t * transformed items from the `coll`. Invoked with (err, results).\n\t */\n\tvar mapSeries = doLimit(mapLimit, 1);\n\t\n\t/**\n\t * The same as [`applyEach`]{@link module:ControlFlow.applyEach} but runs only a single async operation at a time.\n\t *\n\t * @name applyEachSeries\n\t * @static\n\t * @memberOf module:ControlFlow\n\t * @method\n\t * @see [async.applyEach]{@link module:ControlFlow.applyEach}\n\t * @category Control Flow\n\t * @param {Array|Iterable|Object} fns - A collection of asynchronous functions to all\n\t * call with the same arguments\n\t * @param {...*} [args] - any number of separate arguments to pass to the\n\t * function.\n\t * @param {Function} [callback] - the final argument should be the callback,\n\t * called when all functions have completed processing.\n\t * @returns {Function} - If only the first argument is provided, it will return\n\t * a function which lets you pass in the arguments as if it were a single\n\t * function call.\n\t */\n\tapplyEach$1(mapSeries);\n\t\n\t/**\n\t * Creates a continuation function with some arguments already applied.\n\t *\n\t * Useful as a shorthand when combined with other control flow functions. Any\n\t * arguments passed to the returned function are added to the arguments\n\t * originally passed to apply.\n\t *\n\t * @name apply\n\t * @static\n\t * @memberOf module:Utils\n\t * @method\n\t * @category Util\n\t * @param {Function} function - The function you want to eventually apply all\n\t * arguments to. Invokes with (arguments...).\n\t * @param {...*} arguments... - Any number of arguments to automatically apply\n\t * when the continuation is called.\n\t * @example\n\t *\n\t * // using apply\n\t * async.parallel([\n\t * async.apply(fs.writeFile, 'testfile1', 'test1'),\n\t * async.apply(fs.writeFile, 'testfile2', 'test2')\n\t * ]);\n\t *\n\t *\n\t * // the same process without using apply\n\t * async.parallel([\n\t * function(callback) {\n\t * fs.writeFile('testfile1', 'test1', callback);\n\t * },\n\t * function(callback) {\n\t * fs.writeFile('testfile2', 'test2', callback);\n\t * }\n\t * ]);\n\t *\n\t * // It's possible to pass any number of additional arguments when calling the\n\t * // continuation:\n\t *\n\t * node> var fn = async.apply(sys.puts, 'one');\n\t * node> fn('two', 'three');\n\t * one\n\t * two\n\t * three\n\t */\n\trest(function(fn, args) {\n\t return rest(function(callArgs) {\n\t return fn.apply(null, args.concat(callArgs));\n\t });\n\t});\n\t\n\t/**\n\t * A specialized version of `_.forEach` for arrays without support for\n\t * iteratee shorthands.\n\t *\n\t * @private\n\t * @param {Array} [array] The array to iterate over.\n\t * @param {Function} iteratee The function invoked per iteration.\n\t * @returns {Array} Returns `array`.\n\t */\n\tfunction arrayEach(array, iteratee) {\n\t var index = -1,\n\t length = array == null ? 0 : array.length;\n\t\n\t while (++index < length) {\n\t if (iteratee(array[index], index, array) === false) {\n\t break;\n\t }\n\t }\n\t return array;\n\t}\n\t\n\t/**\n\t * Creates a base function for methods like `_.forIn` and `_.forOwn`.\n\t *\n\t * @private\n\t * @param {boolean} [fromRight] Specify iterating from right to left.\n\t * @returns {Function} Returns the new base function.\n\t */\n\tfunction createBaseFor(fromRight) {\n\t return function(object, iteratee, keysFunc) {\n\t var index = -1,\n\t iterable = Object(object),\n\t props = keysFunc(object),\n\t length = props.length;\n\t\n\t while (length--) {\n\t var key = props[fromRight ? length : ++index];\n\t if (iteratee(iterable[key], key, iterable) === false) {\n\t break;\n\t }\n\t }\n\t return object;\n\t };\n\t}\n\t\n\t/**\n\t * The base implementation of `baseForOwn` which iterates over `object`\n\t * properties returned by `keysFunc` and invokes `iteratee` for each property.\n\t * Iteratee functions may exit iteration early by explicitly returning `false`.\n\t *\n\t * @private\n\t * @param {Object} object The object to iterate over.\n\t * @param {Function} iteratee The function invoked per iteration.\n\t * @param {Function} keysFunc The function to get the keys of `object`.\n\t * @returns {Object} Returns `object`.\n\t */\n\tvar baseFor = createBaseFor();\n\t\n\t/**\n\t * The base implementation of `_.forOwn` without support for iteratee shorthands.\n\t *\n\t * @private\n\t * @param {Object} object The object to iterate over.\n\t * @param {Function} iteratee The function invoked per iteration.\n\t * @returns {Object} Returns `object`.\n\t */\n\tfunction baseForOwn(object, iteratee) {\n\t return object && baseFor(object, iteratee, keys);\n\t}\n\t\n\t/**\n\t * The base implementation of `_.findIndex` and `_.findLastIndex` without\n\t * support for iteratee shorthands.\n\t *\n\t * @private\n\t * @param {Array} array The array to inspect.\n\t * @param {Function} predicate The function invoked per iteration.\n\t * @param {number} fromIndex The index to search from.\n\t * @param {boolean} [fromRight] Specify iterating from right to left.\n\t * @returns {number} Returns the index of the matched value, else `-1`.\n\t */\n\tfunction baseFindIndex(array, predicate, fromIndex, fromRight) {\n\t var length = array.length,\n\t index = fromIndex + (fromRight ? 1 : -1);\n\t\n\t while ((fromRight ? index-- : ++index < length)) {\n\t if (predicate(array[index], index, array)) {\n\t return index;\n\t }\n\t }\n\t return -1;\n\t}\n\t\n\t/**\n\t * The base implementation of `_.isNaN` without support for number objects.\n\t *\n\t * @private\n\t * @param {*} value The value to check.\n\t * @returns {boolean} Returns `true` if `value` is `NaN`, else `false`.\n\t */\n\tfunction baseIsNaN(value) {\n\t return value !== value;\n\t}\n\t\n\t/**\n\t * A specialized version of `_.indexOf` which performs strict equality\n\t * comparisons of values, i.e. `===`.\n\t *\n\t * @private\n\t * @param {Array} array The array to inspect.\n\t * @param {*} value The value to search for.\n\t * @param {number} fromIndex The index to search from.\n\t * @returns {number} Returns the index of the matched value, else `-1`.\n\t */\n\tfunction strictIndexOf(array, value, fromIndex) {\n\t var index = fromIndex - 1,\n\t length = array.length;\n\t\n\t while (++index < length) {\n\t if (array[index] === value) {\n\t return index;\n\t }\n\t }\n\t return -1;\n\t}\n\t\n\t/**\n\t * The base implementation of `_.indexOf` without `fromIndex` bounds checks.\n\t *\n\t * @private\n\t * @param {Array} array The array to inspect.\n\t * @param {*} value The value to search for.\n\t * @param {number} fromIndex The index to search from.\n\t * @returns {number} Returns the index of the matched value, else `-1`.\n\t */\n\tfunction baseIndexOf(array, value, fromIndex) {\n\t return value === value\n\t ? strictIndexOf(array, value, fromIndex)\n\t : baseFindIndex(array, baseIsNaN, fromIndex);\n\t}\n\t\n\t/**\n\t * Determines the best order for running the functions in `tasks`, based on\n\t * their requirements. Each function can optionally depend on other functions\n\t * being completed first, and each function is run as soon as its requirements\n\t * are satisfied.\n\t *\n\t * If any of the functions pass an error to their callback, the `auto` sequence\n\t * will stop. Further tasks will not execute (so any other functions depending\n\t * on it will not run), and the main `callback` is immediately called with the\n\t * error.\n\t *\n\t * Functions also receive an object containing the results of functions which\n\t * have completed so far as the first argument, if they have dependencies. If a\n\t * task function has no dependencies, it will only be passed a callback.\n\t *\n\t * @name auto\n\t * @static\n\t * @memberOf module:ControlFlow\n\t * @method\n\t * @category Control Flow\n\t * @param {Object} tasks - An object. Each of its properties is either a\n\t * function or an array of requirements, with the function itself the last item\n\t * in the array. The object's key of a property serves as the name of the task\n\t * defined by that property, i.e. can be used when specifying requirements for\n\t * other tasks. The function receives one or two arguments:\n\t * * a `results` object, containing the results of the previously executed\n\t * functions, only passed if the task has any dependencies,\n\t * * a `callback(err, result)` function, which must be called when finished,\n\t * passing an `error` (which can be `null`) and the result of the function's\n\t * execution.\n\t * @param {number} [concurrency=Infinity] - An optional `integer` for\n\t * determining the maximum number of tasks that can be run in parallel. By\n\t * default, as many as possible.\n\t * @param {Function} [callback] - An optional callback which is called when all\n\t * the tasks have been completed. It receives the `err` argument if any `tasks`\n\t * pass an error to their callback. Results are always returned; however, if an\n\t * error occurs, no further `tasks` will be performed, and the results object\n\t * will only contain partial results. Invoked with (err, results).\n\t * @returns undefined\n\t * @example\n\t *\n\t * async.auto({\n\t * // this function will just be passed a callback\n\t * readData: async.apply(fs.readFile, 'data.txt', 'utf-8'),\n\t * showData: ['readData', function(results, cb) {\n\t * // results.readData is the file's contents\n\t * // ...\n\t * }]\n\t * }, callback);\n\t *\n\t * async.auto({\n\t * get_data: function(callback) {\n\t * console.log('in get_data');\n\t * // async code to get some data\n\t * callback(null, 'data', 'converted to array');\n\t * },\n\t * make_folder: function(callback) {\n\t * console.log('in make_folder');\n\t * // async code to create a directory to store a file in\n\t * // this is run at the same time as getting the data\n\t * callback(null, 'folder');\n\t * },\n\t * write_file: ['get_data', 'make_folder', function(results, callback) {\n\t * console.log('in write_file', JSON.stringify(results));\n\t * // once there is some data and the directory exists,\n\t * // write the data to a file in the directory\n\t * callback(null, 'filename');\n\t * }],\n\t * email_link: ['write_file', function(results, callback) {\n\t * console.log('in email_link', JSON.stringify(results));\n\t * // once the file is written let's email a link to it...\n\t * // results.write_file contains the filename returned by write_file.\n\t * callback(null, {'file':results.write_file, 'email':'user@example.com'});\n\t * }]\n\t * }, function(err, results) {\n\t * console.log('err = ', err);\n\t * console.log('results = ', results);\n\t * });\n\t */\n\t\n\t/**\n\t * A specialized version of `_.map` for arrays without support for iteratee\n\t * shorthands.\n\t *\n\t * @private\n\t * @param {Array} [array] The array to iterate over.\n\t * @param {Function} iteratee The function invoked per iteration.\n\t * @returns {Array} Returns the new mapped array.\n\t */\n\t\n\t/**\n\t * The base implementation of `_.slice` without an iteratee call guard.\n\t *\n\t * @private\n\t * @param {Array} array The array to slice.\n\t * @param {number} [start=0] The start position.\n\t * @param {number} [end=array.length] The end position.\n\t * @returns {Array} Returns the slice of `array`.\n\t */\n\t\n\t/**\n\t * Converts an ASCII `string` to an array.\n\t *\n\t * @private\n\t * @param {string} string The string to convert.\n\t * @returns {Array} Returns the converted array.\n\t */\n\t\n\t/** Used to compose unicode character classes. */\n\t\n\t/** Used to compose unicode character classes. */\n\tvar rsAstralRange$1 = '\\\\ud800-\\\\udfff';\n\tvar rsComboMarksRange$1 = '\\\\u0300-\\\\u036f';\n\tvar reComboHalfMarksRange$1 = '\\\\ufe20-\\\\ufe2f';\n\tvar rsComboSymbolsRange$1 = '\\\\u20d0-\\\\u20ff';\n\tvar rsComboRange$1 = rsComboMarksRange$1 + reComboHalfMarksRange$1 + rsComboSymbolsRange$1;\n\tvar rsVarRange$1 = '\\\\ufe0e\\\\ufe0f';\n\t\n\t/** Used to compose unicode capture groups. */\n\tvar rsAstral = '[' + rsAstralRange$1 + ']';\n\tvar rsCombo = '[' + rsComboRange$1 + ']';\n\tvar rsFitz = '\\\\ud83c[\\\\udffb-\\\\udfff]';\n\tvar rsModifier = '(?:' + rsCombo + '|' + rsFitz + ')';\n\tvar rsNonAstral = '[^' + rsAstralRange$1 + ']';\n\tvar rsRegional = '(?:\\\\ud83c[\\\\udde6-\\\\uddff]){2}';\n\tvar rsSurrPair = '[\\\\ud800-\\\\udbff][\\\\udc00-\\\\udfff]';\n\tvar rsZWJ$1 = '\\\\u200d';\n\t\n\t/** Used to compose unicode regexes. */\n\tvar reOptMod = rsModifier + '?';\n\tvar rsOptVar = '[' + rsVarRange$1 + ']?';\n\tvar rsOptJoin = '(?:' + rsZWJ$1 + '(?:' + [rsNonAstral, rsRegional, rsSurrPair].join('|') + ')' + rsOptVar + reOptMod + ')*';\n\tvar rsSeq = rsOptVar + reOptMod + rsOptJoin;\n\tvar rsSymbol = '(?:' + [rsNonAstral + rsCombo + '?', rsCombo, rsRegional, rsSurrPair, rsAstral].join('|') + ')';\n\t\n\tvar hasSetImmediate = typeof setImmediate === 'function' && setImmediate;\n\tvar hasNextTick = typeof process === 'object' && typeof process.nextTick === 'function';\n\t\n\tfunction fallback(fn) {\n\t setTimeout(fn, 0);\n\t}\n\t\n\tfunction wrap(defer) {\n\t return rest(function (fn, args) {\n\t defer(function () {\n\t fn.apply(null, args);\n\t });\n\t });\n\t}\n\t\n\tvar _defer;\n\t\n\tif (hasSetImmediate) {\n\t _defer = setImmediate;\n\t} else if (hasNextTick) {\n\t _defer = process.nextTick;\n\t} else {\n\t _defer = fallback;\n\t}\n\t\n\twrap(_defer);\n\t\n\t// Simple doubly linked list (https://en.wikipedia.org/wiki/Doubly_linked_list) implementation\n\t// used for queues. This implementation assumes that the node provided by the user can be modified\n\t// to adjust the next and last properties. We implement only the minimal functionality\n\t// for queue support.\n\t\n\t/**\n\t * The same as [`eachOf`]{@link module:Collections.eachOf} but runs only a single async operation at a time.\n\t *\n\t * @name eachOfSeries\n\t * @static\n\t * @memberOf module:Collections\n\t * @method\n\t * @see [async.eachOf]{@link module:Collections.eachOf}\n\t * @alias forEachOfSeries\n\t * @category Collection\n\t * @param {Array|Iterable|Object} coll - A collection to iterate over.\n\t * @param {Function} iteratee - A function to apply to each item in `coll`. The\n\t * `key` is the item's key, or index in the case of an array. The iteratee is\n\t * passed a `callback(err)` which must be called once it has completed. If no\n\t * error has occurred, the callback should be run without arguments or with an\n\t * explicit `null` argument. Invoked with (item, key, callback).\n\t * @param {Function} [callback] - A callback which is called when all `iteratee`\n\t * functions have finished, or an error occurs. Invoked with (err).\n\t */\n\tvar eachOfSeries = doLimit(eachOfLimit, 1);\n\t\n\t/**\n\t * Reduces `coll` into a single value using an async `iteratee` to return each\n\t * successive step. `memo` is the initial state of the reduction. This function\n\t * only operates in series.\n\t *\n\t * For performance reasons, it may make sense to split a call to this function\n\t * into a parallel map, and then use the normal `Array.prototype.reduce` on the\n\t * results. This function is for situations where each step in the reduction\n\t * needs to be async; if you can get the data before reducing it, then it's\n\t * probably a good idea to do so.\n\t *\n\t * @name reduce\n\t * @static\n\t * @memberOf module:Collections\n\t * @method\n\t * @alias inject\n\t * @alias foldl\n\t * @category Collection\n\t * @param {Array|Iterable|Object} coll - A collection to iterate over.\n\t * @param {*} memo - The initial state of the reduction.\n\t * @param {Function} iteratee - A function applied to each item in the\n\t * array to produce the next step in the reduction. The `iteratee` is passed a\n\t * `callback(err, reduction)` which accepts an optional error as its first\n\t * argument, and the state of the reduction as the second. If an error is\n\t * passed to the callback, the reduction is stopped and the main `callback` is\n\t * immediately called with the error. Invoked with (memo, item, callback).\n\t * @param {Function} [callback] - A callback which is called after all the\n\t * `iteratee` functions have finished. Result is the reduced value. Invoked with\n\t * (err, result).\n\t * @example\n\t *\n\t * async.reduce([1,2,3], 0, function(memo, item, callback) {\n\t * // pointless async:\n\t * process.nextTick(function() {\n\t * callback(null, memo + item)\n\t * });\n\t * }, function(err, result) {\n\t * // result is now equal to the last value of memo, which is 6\n\t * });\n\t */\n\tfunction reduce(coll, memo, iteratee, callback) {\n\t callback = once(callback || noop);\n\t eachOfSeries(coll, function(x, i, callback) {\n\t iteratee(memo, x, function(err, v) {\n\t memo = v;\n\t callback(err);\n\t });\n\t }, function(err) {\n\t callback(err, memo);\n\t });\n\t}\n\t\n\t/**\n\t * Version of the compose function that is more natural to read. Each function\n\t * consumes the return value of the previous function. It is the equivalent of\n\t * [compose]{@link module:ControlFlow.compose} with the arguments reversed.\n\t *\n\t * Each function is executed with the `this` binding of the composed function.\n\t *\n\t * @name seq\n\t * @static\n\t * @memberOf module:ControlFlow\n\t * @method\n\t * @see [async.compose]{@link module:ControlFlow.compose}\n\t * @category Control Flow\n\t * @param {...Function} functions - the asynchronous functions to compose\n\t * @returns {Function} a function that composes the `functions` in order\n\t * @example\n\t *\n\t * // Requires lodash (or underscore), express3 and dresende's orm2.\n\t * // Part of an app, that fetches cats of the logged user.\n\t * // This example uses `seq` function to avoid overnesting and error\n\t * // handling clutter.\n\t * app.get('/cats', function(request, response) {\n\t * var User = request.models.User;\n\t * async.seq(\n\t * _.bind(User.get, User), // 'User.get' has signature (id, callback(err, data))\n\t * function(user, fn) {\n\t * user.getCats(fn); // 'getCats' has signature (callback(err, data))\n\t * }\n\t * )(req.session.user_id, function (err, cats) {\n\t * if (err) {\n\t * console.error(err);\n\t * response.json({ status: 'error', message: err.message });\n\t * } else {\n\t * response.json({ status: 'ok', message: 'Cats found', data: cats });\n\t * }\n\t * });\n\t * });\n\t */\n\tvar seq = rest(function seq(functions) {\n\t return rest(function(args) {\n\t var that = this;\n\t\n\t var cb = args[args.length - 1];\n\t if (typeof cb == 'function') {\n\t args.pop();\n\t } else {\n\t cb = noop;\n\t }\n\t\n\t reduce(functions, args, function(newargs, fn, cb) {\n\t fn.apply(that, newargs.concat([rest(function(err, nextargs) {\n\t cb(err, nextargs);\n\t })]));\n\t },\n\t function(err, results) {\n\t cb.apply(that, [err].concat(results));\n\t });\n\t });\n\t});\n\t\n\t/**\n\t * Creates a function which is a composition of the passed asynchronous\n\t * functions. Each function consumes the return value of the function that\n\t * follows. Composing functions `f()`, `g()`, and `h()` would produce the result\n\t * of `f(g(h()))`, only this version uses callbacks to obtain the return values.\n\t *\n\t * Each function is executed with the `this` binding of the composed function.\n\t *\n\t * @name compose\n\t * @static\n\t * @memberOf module:ControlFlow\n\t * @method\n\t * @category Control Flow\n\t * @param {...Function} functions - the asynchronous functions to compose\n\t * @returns {Function} an asynchronous function that is the composed\n\t * asynchronous `functions`\n\t * @example\n\t *\n\t * function add1(n, callback) {\n\t * setTimeout(function () {\n\t * callback(null, n + 1);\n\t * }, 10);\n\t * }\n\t *\n\t * function mul3(n, callback) {\n\t * setTimeout(function () {\n\t * callback(null, n * 3);\n\t * }, 10);\n\t * }\n\t *\n\t * var add1mul3 = async.compose(mul3, add1);\n\t * add1mul3(4, function (err, result) {\n\t * // result now equals 15\n\t * });\n\t */\n\trest(function(args) {\n\t return seq.apply(null, args.reverse());\n\t});\n\t\n\t/**\n\t * Applies `iteratee` to each item in `coll`, concatenating the results. Returns\n\t * the concatenated list. The `iteratee`s are called in parallel, and the\n\t * results are concatenated as they return. There is no guarantee that the\n\t * results array will be returned in the original order of `coll` passed to the\n\t * `iteratee` function.\n\t *\n\t * @name concat\n\t * @static\n\t * @memberOf module:Collections\n\t * @method\n\t * @category Collection\n\t * @param {Array|Iterable|Object} coll - A collection to iterate over.\n\t * @param {Function} iteratee - A function to apply to each item in `coll`.\n\t * The iteratee is passed a `callback(err, results)` which must be called once\n\t * it has completed with an error (which can be `null`) and an array of results.\n\t * Invoked with (item, callback).\n\t * @param {Function} [callback(err)] - A callback which is called after all the\n\t * `iteratee` functions have finished, or an error occurs. Results is an array\n\t * containing the concatenated results of the `iteratee` function. Invoked with\n\t * (err, results).\n\t * @example\n\t *\n\t * async.concat(['dir1','dir2','dir3'], fs.readdir, function(err, files) {\n\t * // files is now a list of filenames that exist in the 3 directories\n\t * });\n\t */\n\t\n\t/**\n\t * The same as [`concat`]{@link module:Collections.concat} but runs only a single async operation at a time.\n\t *\n\t * @name concatSeries\n\t * @static\n\t * @memberOf module:Collections\n\t * @method\n\t * @see [async.concat]{@link module:Collections.concat}\n\t * @category Collection\n\t * @param {Array|Iterable|Object} coll - A collection to iterate over.\n\t * @param {Function} iteratee - A function to apply to each item in `coll`.\n\t * The iteratee is passed a `callback(err, results)` which must be called once\n\t * it has completed with an error (which can be `null`) and an array of results.\n\t * Invoked with (item, callback).\n\t * @param {Function} [callback(err)] - A callback which is called after all the\n\t * `iteratee` functions have finished, or an error occurs. Results is an array\n\t * containing the concatenated results of the `iteratee` function. Invoked with\n\t * (err, results).\n\t */\n\t\n\t/**\n\t * Returns a function that when called, calls-back with the values provided.\n\t * Useful as the first function in a [`waterfall`]{@link module:ControlFlow.waterfall}, or for plugging values in to\n\t * [`auto`]{@link module:ControlFlow.auto}.\n\t *\n\t * @name constant\n\t * @static\n\t * @memberOf module:Utils\n\t * @method\n\t * @category Util\n\t * @param {...*} arguments... - Any number of arguments to automatically invoke\n\t * callback with.\n\t * @returns {Function} Returns a function that when invoked, automatically\n\t * invokes the callback with the previous given arguments.\n\t * @example\n\t *\n\t * async.waterfall([\n\t * async.constant(42),\n\t * function (value, next) {\n\t * // value === 42\n\t * },\n\t * //...\n\t * ], callback);\n\t *\n\t * async.waterfall([\n\t * async.constant(filename, \"utf8\"),\n\t * fs.readFile,\n\t * function (fileData, next) {\n\t * //...\n\t * }\n\t * //...\n\t * ], callback);\n\t *\n\t * async.auto({\n\t * hostname: async.constant(\"https://server.net/\"),\n\t * port: findFreePort,\n\t * launchServer: [\"hostname\", \"port\", function (options, cb) {\n\t * startServer(options, cb);\n\t * }],\n\t * //...\n\t * }, callback);\n\t */\n\trest(function(values) {\n\t var args = [null].concat(values);\n\t return initialParams(function (ignoredArgs, callback) {\n\t return callback.apply(this, args);\n\t });\n\t});\n\t\n\t/**\n\t * Returns the first value in `coll` that passes an async truth test. The\n\t * `iteratee` is applied in parallel, meaning the first iteratee to return\n\t * `true` will fire the detect `callback` with that result. That means the\n\t * result might not be the first item in the original `coll` (in terms of order)\n\t * that passes the test.\n\t\n\t * If order within the original `coll` is important, then look at\n\t * [`detectSeries`]{@link module:Collections.detectSeries}.\n\t *\n\t * @name detect\n\t * @static\n\t * @memberOf module:Collections\n\t * @method\n\t * @alias find\n\t * @category Collections\n\t * @param {Array|Iterable|Object} coll - A collection to iterate over.\n\t * @param {Function} iteratee - A truth test to apply to each item in `coll`.\n\t * The iteratee is passed a `callback(err, truthValue)` which must be called\n\t * with a boolean argument once it has completed. Invoked with (item, callback).\n\t * @param {Function} [callback] - A callback which is called as soon as any\n\t * iteratee returns `true`, or after all the `iteratee` functions have finished.\n\t * Result will be the first item in the array that passes the truth test\n\t * (iteratee) or the value `undefined` if none passed. Invoked with\n\t * (err, result).\n\t * @example\n\t *\n\t * async.detect(['file1','file2','file3'], function(filePath, callback) {\n\t * fs.access(filePath, function(err) {\n\t * callback(null, !err)\n\t * });\n\t * }, function(err, result) {\n\t * // result now equals the first file in the list that exists\n\t * });\n\t */\n\t\n\t/**\n\t * The same as [`detect`]{@link module:Collections.detect} but runs a maximum of `limit` async operations at a\n\t * time.\n\t *\n\t * @name detectLimit\n\t * @static\n\t * @memberOf module:Collections\n\t * @method\n\t * @see [async.detect]{@link module:Collections.detect}\n\t * @alias findLimit\n\t * @category Collections\n\t * @param {Array|Iterable|Object} coll - A collection to iterate over.\n\t * @param {number} limit - The maximum number of async operations at a time.\n\t * @param {Function} iteratee - A truth test to apply to each item in `coll`.\n\t * The iteratee is passed a `callback(err, truthValue)` which must be called\n\t * with a boolean argument once it has completed. Invoked with (item, callback).\n\t * @param {Function} [callback] - A callback which is called as soon as any\n\t * iteratee returns `true`, or after all the `iteratee` functions have finished.\n\t * Result will be the first item in the array that passes the truth test\n\t * (iteratee) or the value `undefined` if none passed. Invoked with\n\t * (err, result).\n\t */\n\t\n\t/**\n\t * The same as [`detect`]{@link module:Collections.detect} but runs only a single async operation at a time.\n\t *\n\t * @name detectSeries\n\t * @static\n\t * @memberOf module:Collections\n\t * @method\n\t * @see [async.detect]{@link module:Collections.detect}\n\t * @alias findSeries\n\t * @category Collections\n\t * @param {Array|Iterable|Object} coll - A collection to iterate over.\n\t * @param {Function} iteratee - A truth test to apply to each item in `coll`.\n\t * The iteratee is passed a `callback(err, truthValue)` which must be called\n\t * with a boolean argument once it has completed. Invoked with (item, callback).\n\t * @param {Function} [callback] - A callback which is called as soon as any\n\t * iteratee returns `true`, or after all the `iteratee` functions have finished.\n\t * Result will be the first item in the array that passes the truth test\n\t * (iteratee) or the value `undefined` if none passed. Invoked with\n\t * (err, result).\n\t */\n\t\n\tfunction consoleFunc(name) {\n\t return rest(function (fn, args) {\n\t fn.apply(null, args.concat([rest(function (err, args) {\n\t if (typeof console === 'object') {\n\t if (err) {\n\t if (console.error) {\n\t console.error(err);\n\t }\n\t }\n\t else if (console[name]) {\n\t arrayEach(args, function (x) {\n\t console[name](x);\n\t });\n\t }\n\t }\n\t })]));\n\t });\n\t}\n\t\n\t/**\n\t * Logs the result of an `async` function to the `console` using `console.dir`\n\t * to display the properties of the resulting object. Only works in Node.js or\n\t * in browsers that support `console.dir` and `console.error` (such as FF and\n\t * Chrome). If multiple arguments are returned from the async function,\n\t * `console.dir` is called on each argument in order.\n\t *\n\t * @name dir\n\t * @static\n\t * @memberOf module:Utils\n\t * @method\n\t * @category Util\n\t * @param {Function} function - The function you want to eventually apply all\n\t * arguments to.\n\t * @param {...*} arguments... - Any number of arguments to apply to the function.\n\t * @example\n\t *\n\t * // in a module\n\t * var hello = function(name, callback) {\n\t * setTimeout(function() {\n\t * callback(null, {hello: name});\n\t * }, 1000);\n\t * };\n\t *\n\t * // in the node repl\n\t * node> async.dir(hello, 'world');\n\t * {hello: 'world'}\n\t */\n\tconsoleFunc('dir');\n\t\n\tfunction _withoutIndex(iteratee) {\n\t return function (value, index, callback) {\n\t return iteratee(value, callback);\n\t };\n\t}\n\t\n\t/**\n\t * Applies the function `iteratee` to each item in `coll`, in parallel.\n\t * The `iteratee` is called with an item from the list, and a callback for when\n\t * it has finished. If the `iteratee` passes an error to its `callback`, the\n\t * main `callback` (for the `each` function) is immediately called with the\n\t * error.\n\t *\n\t * Note, that since this function applies `iteratee` to each item in parallel,\n\t * there is no guarantee that the iteratee functions will complete in order.\n\t *\n\t * @name each\n\t * @static\n\t * @memberOf module:Collections\n\t * @method\n\t * @alias forEach\n\t * @category Collection\n\t * @param {Array|Iterable|Object} coll - A collection to iterate over.\n\t * @param {Function} iteratee - A function to apply to each item\n\t * in `coll`. The iteratee is passed a `callback(err)` which must be called once\n\t * it has completed. If no error has occurred, the `callback` should be run\n\t * without arguments or with an explicit `null` argument. The array index is not\n\t * passed to the iteratee. Invoked with (item, callback). If you need the index,\n\t * use `eachOf`.\n\t * @param {Function} [callback] - A callback which is called when all\n\t * `iteratee` functions have finished, or an error occurs. Invoked with (err).\n\t * @example\n\t *\n\t * // assuming openFiles is an array of file names and saveFile is a function\n\t * // to save the modified contents of that file:\n\t *\n\t * async.each(openFiles, saveFile, function(err){\n\t * // if any of the saves produced an error, err would equal that error\n\t * });\n\t *\n\t * // assuming openFiles is an array of file names\n\t * async.each(openFiles, function(file, callback) {\n\t *\n\t * // Perform operation on file here.\n\t * console.log('Processing file ' + file);\n\t *\n\t * if( file.length > 32 ) {\n\t * console.log('This file name is too long');\n\t * callback('File name too long');\n\t * } else {\n\t * // Do work to process file here\n\t * console.log('File processed');\n\t * callback();\n\t * }\n\t * }, function(err) {\n\t * // if any of the file processing produced an error, err would equal that error\n\t * if( err ) {\n\t * // One of the iterations produced an error.\n\t * // All processing will now stop.\n\t * console.log('A file failed to process');\n\t * } else {\n\t * console.log('All files have been processed successfully');\n\t * }\n\t * });\n\t */\n\tfunction eachLimit(coll, iteratee, callback) {\n\t eachOf(coll, _withoutIndex(iteratee), callback);\n\t}\n\t\n\t/**\n\t * The same as [`each`]{@link module:Collections.each} but runs only a single async operation at a time.\n\t *\n\t * @name eachSeries\n\t * @static\n\t * @memberOf module:Collections\n\t * @method\n\t * @see [async.each]{@link module:Collections.each}\n\t * @alias forEachSeries\n\t * @category Collection\n\t * @param {Array|Iterable|Object} coll - A collection to iterate over.\n\t * @param {Function} iteratee - A function to apply to each\n\t * item in `coll`. The iteratee is passed a `callback(err)` which must be called\n\t * once it has completed. If no error has occurred, the `callback` should be run\n\t * without arguments or with an explicit `null` argument. The array index is\n\t * not passed to the iteratee. Invoked with (item, callback). If you need the\n\t * index, use `eachOfSeries`.\n\t * @param {Function} [callback] - A callback which is called when all\n\t * `iteratee` functions have finished, or an error occurs. Invoked with (err).\n\t */\n\t\n\t/**\n\t * Returns `true` if every element in `coll` satisfies an async test. If any\n\t * iteratee call returns `false`, the main `callback` is immediately called.\n\t *\n\t * @name every\n\t * @static\n\t * @memberOf module:Collections\n\t * @method\n\t * @alias all\n\t * @category Collection\n\t * @param {Array|Iterable|Object} coll - A collection to iterate over.\n\t * @param {Function} iteratee - A truth test to apply to each item in the\n\t * collection in parallel. The iteratee is passed a `callback(err, truthValue)`\n\t * which must be called with a boolean argument once it has completed. Invoked\n\t * with (item, callback).\n\t * @param {Function} [callback] - A callback which is called after all the\n\t * `iteratee` functions have finished. Result will be either `true` or `false`\n\t * depending on the values of the async tests. Invoked with (err, result).\n\t * @example\n\t *\n\t * async.every(['file1','file2','file3'], function(filePath, callback) {\n\t * fs.access(filePath, function(err) {\n\t * callback(null, !err)\n\t * });\n\t * }, function(err, result) {\n\t * // if result is true then every file exists\n\t * });\n\t */\n\t\n\t/**\n\t * The same as [`every`]{@link module:Collections.every} but runs a maximum of `limit` async operations at a time.\n\t *\n\t * @name everyLimit\n\t * @static\n\t * @memberOf module:Collections\n\t * @method\n\t * @see [async.every]{@link module:Collections.every}\n\t * @alias allLimit\n\t * @category Collection\n\t * @param {Array|Iterable|Object} coll - A collection to iterate over.\n\t * @param {number} limit - The maximum number of async operations at a time.\n\t * @param {Function} iteratee - A truth test to apply to each item in the\n\t * collection in parallel. The iteratee is passed a `callback(err, truthValue)`\n\t * which must be called with a boolean argument once it has completed. Invoked\n\t * with (item, callback).\n\t * @param {Function} [callback] - A callback which is called after all the\n\t * `iteratee` functions have finished. Result will be either `true` or `false`\n\t * depending on the values of the async tests. Invoked with (err, result).\n\t */\n\t\n\t/**\n\t * The same as [`every`]{@link module:Collections.every} but runs only a single async operation at a time.\n\t *\n\t * @name everySeries\n\t * @static\n\t * @memberOf module:Collections\n\t * @method\n\t * @see [async.every]{@link module:Collections.every}\n\t * @alias allSeries\n\t * @category Collection\n\t * @param {Array|Iterable|Object} coll - A collection to iterate over.\n\t * @param {Function} iteratee - A truth test to apply to each item in the\n\t * collection in parallel. The iteratee is passed a `callback(err, truthValue)`\n\t * which must be called with a boolean argument once it has completed. Invoked\n\t * with (item, callback).\n\t * @param {Function} [callback] - A callback which is called after all the\n\t * `iteratee` functions have finished. Result will be either `true` or `false`\n\t * depending on the values of the async tests. Invoked with (err, result).\n\t */\n\t\n\t/**\n\t * The base implementation of `_.property` without support for deep paths.\n\t *\n\t * @private\n\t * @param {string} key The key of the property to get.\n\t * @returns {Function} Returns the new accessor function.\n\t */\n\t\n\t/**\n\t * Returns a new array of all the values in `coll` which pass an async truth\n\t * test. This operation is performed in parallel, but the results array will be\n\t * in the same order as the original.\n\t *\n\t * @name filter\n\t * @static\n\t * @memberOf module:Collections\n\t * @method\n\t * @alias select\n\t * @category Collection\n\t * @param {Array|Iterable|Object} coll - A collection to iterate over.\n\t * @param {Function} iteratee - A truth test to apply to each item in `coll`.\n\t * The `iteratee` is passed a `callback(err, truthValue)`, which must be called\n\t * with a boolean argument once it has completed. Invoked with (item, callback).\n\t * @param {Function} [callback] - A callback which is called after all the\n\t * `iteratee` functions have finished. Invoked with (err, results).\n\t * @example\n\t *\n\t * async.filter(['file1','file2','file3'], function(filePath, callback) {\n\t * fs.access(filePath, function(err) {\n\t * callback(null, !err)\n\t * });\n\t * }, function(err, results) {\n\t * // results now equals an array of the existing files\n\t * });\n\t */\n\t\n\t/**\n\t * The same as [`filter`]{@link module:Collections.filter} but runs a maximum of `limit` async operations at a\n\t * time.\n\t *\n\t * @name filterLimit\n\t * @static\n\t * @memberOf module:Collections\n\t * @method\n\t * @see [async.filter]{@link module:Collections.filter}\n\t * @alias selectLimit\n\t * @category Collection\n\t * @param {Array|Iterable|Object} coll - A collection to iterate over.\n\t * @param {number} limit - The maximum number of async operations at a time.\n\t * @param {Function} iteratee - A truth test to apply to each item in `coll`.\n\t * The `iteratee` is passed a `callback(err, truthValue)`, which must be called\n\t * with a boolean argument once it has completed. Invoked with (item, callback).\n\t * @param {Function} [callback] - A callback which is called after all the\n\t * `iteratee` functions have finished. Invoked with (err, results).\n\t */\n\t\n\t/**\n\t * The same as [`filter`]{@link module:Collections.filter} but runs only a single async operation at a time.\n\t *\n\t * @name filterSeries\n\t * @static\n\t * @memberOf module:Collections\n\t * @method\n\t * @see [async.filter]{@link module:Collections.filter}\n\t * @alias selectSeries\n\t * @category Collection\n\t * @param {Array|Iterable|Object} coll - A collection to iterate over.\n\t * @param {Function} iteratee - A truth test to apply to each item in `coll`.\n\t * The `iteratee` is passed a `callback(err, truthValue)`, which must be called\n\t * with a boolean argument once it has completed. Invoked with (item, callback).\n\t * @param {Function} [callback] - A callback which is called after all the\n\t * `iteratee` functions have finished. Invoked with (err, results)\n\t */\n\t\n\t/**\n\t * Logs the result of an `async` function to the `console`. Only works in\n\t * Node.js or in browsers that support `console.log` and `console.error` (such\n\t * as FF and Chrome). If multiple arguments are returned from the async\n\t * function, `console.log` is called on each argument in order.\n\t *\n\t * @name log\n\t * @static\n\t * @memberOf module:Utils\n\t * @method\n\t * @category Util\n\t * @param {Function} function - The function you want to eventually apply all\n\t * arguments to.\n\t * @param {...*} arguments... - Any number of arguments to apply to the function.\n\t * @example\n\t *\n\t * // in a module\n\t * var hello = function(name, callback) {\n\t * setTimeout(function() {\n\t * callback(null, 'hello ' + name);\n\t * }, 1000);\n\t * };\n\t *\n\t * // in the node repl\n\t * node> async.log(hello, 'world');\n\t * 'hello world'\n\t */\n\tconsoleFunc('log');\n\t\n\t/**\n\t * A relative of [`map`]{@link module:Collections.map}, designed for use with objects.\n\t *\n\t * Produces a new Object by mapping each value of `obj` through the `iteratee`\n\t * function. The `iteratee` is called each `value` and `key` from `obj` and a\n\t * callback for when it has finished processing. Each of these callbacks takes\n\t * two arguments: an `error`, and the transformed item from `obj`. If `iteratee`\n\t * passes an error to its callback, the main `callback` (for the `mapValues`\n\t * function) is immediately called with the error.\n\t *\n\t * Note, the order of the keys in the result is not guaranteed. The keys will\n\t * be roughly in the order they complete, (but this is very engine-specific)\n\t *\n\t * @name mapValues\n\t * @static\n\t * @memberOf module:Collections\n\t * @method\n\t * @category Collection\n\t * @param {Object} obj - A collection to iterate over.\n\t * @param {Function} iteratee - A function to apply to each value and key in\n\t * `coll`. The iteratee is passed a `callback(err, transformed)` which must be\n\t * called once it has completed with an error (which can be `null`) and a\n\t * transformed value. Invoked with (value, key, callback).\n\t * @param {Function} [callback] - A callback which is called when all `iteratee`\n\t * functions have finished, or an error occurs. `result` is a new object consisting\n\t * of each key from `obj`, with each transformed value on the right-hand side.\n\t * Invoked with (err, result).\n\t * @example\n\t *\n\t * async.mapValues({\n\t * f1: 'file1',\n\t * f2: 'file2',\n\t * f3: 'file3'\n\t * }, function (file, key, callback) {\n\t * fs.stat(file, callback);\n\t * }, function(err, result) {\n\t * // result is now a map of stats for each file, e.g.\n\t * // {\n\t * // f1: [stats for file1],\n\t * // f2: [stats for file2],\n\t * // f3: [stats for file3]\n\t * // }\n\t * });\n\t */\n\t\n\t/**\n\t * The same as [`mapValues`]{@link module:Collections.mapValues} but runs only a single async operation at a time.\n\t *\n\t * @name mapValuesSeries\n\t * @static\n\t * @memberOf module:Collections\n\t * @method\n\t * @see [async.mapValues]{@link module:Collections.mapValues}\n\t * @category Collection\n\t * @param {Object} obj - A collection to iterate over.\n\t * @param {Function} iteratee - A function to apply to each value in `obj`.\n\t * The iteratee is passed a `callback(err, transformed)` which must be called\n\t * once it has completed with an error (which can be `null`) and a\n\t * transformed value. Invoked with (value, key, callback).\n\t * @param {Function} [callback] - A callback which is called when all `iteratee`\n\t * functions have finished, or an error occurs. `result` is a new object consisting\n\t * of each key from `obj`, with each transformed value on the right-hand side.\n\t * Invoked with (err, result).\n\t */\n\t\n\t/**\n\t * Calls `callback` on a later loop around the event loop. In Node.js this just\n\t * calls `setImmediate`. In the browser it will use `setImmediate` if\n\t * available, otherwise `setTimeout(callback, 0)`, which means other higher\n\t * priority events may precede the execution of `callback`.\n\t *\n\t * This is used internally for browser-compatibility purposes.\n\t *\n\t * @name nextTick\n\t * @static\n\t * @memberOf module:Utils\n\t * @method\n\t * @alias setImmediate\n\t * @category Util\n\t * @param {Function} callback - The function to call on a later loop around\n\t * the event loop. Invoked with (args...).\n\t * @param {...*} args... - any number of additional arguments to pass to the\n\t * callback on the next tick.\n\t * @example\n\t *\n\t * var call_order = [];\n\t * async.nextTick(function() {\n\t * call_order.push('two');\n\t * // call_order now equals ['one','two']\n\t * });\n\t * call_order.push('one');\n\t *\n\t * async.setImmediate(function (a, b, c) {\n\t * // a, b, and c equal 1, 2, and 3\n\t * }, 1, 2, 3);\n\t */\n\tvar _defer$1;\n\t\n\tif (hasNextTick) {\n\t _defer$1 = process.nextTick;\n\t} else if (hasSetImmediate) {\n\t _defer$1 = setImmediate;\n\t} else {\n\t _defer$1 = fallback;\n\t}\n\t\n\twrap(_defer$1);\n\t\n\t/**\n\t * Calls `callback` on a later loop around the event loop. In Node.js this just\n\t * calls `setImmediate`. In the browser it will use `setImmediate` if\n\t * available, otherwise `setTimeout(callback, 0)`, which means other higher\n\t * priority events may precede the execution of `callback`.\n\t *\n\t * This is used internally for browser-compatibility purposes.\n\t *\n\t * @name setImmediate\n\t * @static\n\t * @memberOf module:Utils\n\t * @method\n\t * @alias nextTick\n\t * @category Util\n\t * @param {Function} callback - The function to call on a later loop around\n\t * the event loop. Invoked with (args...).\n\t * @param {...*} args... - any number of additional arguments to pass to the\n\t * callback on the next tick.\n\t * @example\n\t *\n\t * var call_order = [];\n\t * async.nextTick(function() {\n\t * call_order.push('two');\n\t * // call_order now equals ['one','two']\n\t * });\n\t * call_order.push('one');\n\t *\n\t * async.setImmediate(function (a, b, c) {\n\t * // a, b, and c equal 1, 2, and 3\n\t * }, 1, 2, 3);\n\t */\n\t\n\t/**\n\t * A queue of tasks for the worker function to complete.\n\t * @typedef {Object} QueueObject\n\t * @memberOf module:ControlFlow\n\t * @property {Function} length - a function returning the number of items\n\t * waiting to be processed. Invoke with `queue.length()`.\n\t * @property {boolean} started - a boolean indicating whether or not any\n\t * items have been pushed and processed by the queue.\n\t * @property {Function} running - a function returning the number of items\n\t * currently being processed. Invoke with `queue.running()`.\n\t * @property {Function} workersList - a function returning the array of items\n\t * currently being processed. Invoke with `queue.workersList()`.\n\t * @property {Function} idle - a function returning false if there are items\n\t * waiting or being processed, or true if not. Invoke with `queue.idle()`.\n\t * @property {number} concurrency - an integer for determining how many `worker`\n\t * functions should be run in parallel. This property can be changed after a\n\t * `queue` is created to alter the concurrency on-the-fly.\n\t * @property {Function} push - add a new task to the `queue`. Calls `callback`\n\t * once the `worker` has finished processing the task. Instead of a single task,\n\t * a `tasks` array can be submitted. The respective callback is used for every\n\t * task in the list. Invoke with `queue.push(task, [callback])`,\n\t * @property {Function} unshift - add a new task to the front of the `queue`.\n\t * Invoke with `queue.unshift(task, [callback])`.\n\t * @property {Function} saturated - a callback that is called when the number of\n\t * running workers hits the `concurrency` limit, and further tasks will be\n\t * queued.\n\t * @property {Function} unsaturated - a callback that is called when the number\n\t * of running workers is less than the `concurrency` & `buffer` limits, and\n\t * further tasks will not be queued.\n\t * @property {number} buffer - A minimum threshold buffer in order to say that\n\t * the `queue` is `unsaturated`.\n\t * @property {Function} empty - a callback that is called when the last item\n\t * from the `queue` is given to a `worker`.\n\t * @property {Function} drain - a callback that is called when the last item\n\t * from the `queue` has returned from the `worker`.\n\t * @property {Function} error - a callback that is called when a task errors.\n\t * Has the signature `function(error, task)`.\n\t * @property {boolean} paused - a boolean for determining whether the queue is\n\t * in a paused state.\n\t * @property {Function} pause - a function that pauses the processing of tasks\n\t * until `resume()` is called. Invoke with `queue.pause()`.\n\t * @property {Function} resume - a function that resumes the processing of\n\t * queued tasks when the queue is paused. Invoke with `queue.resume()`.\n\t * @property {Function} kill - a function that removes the `drain` callback and\n\t * empties remaining tasks from the queue forcing it to go idle. Invoke with `queue.kill()`.\n\t */\n\t\n\t/**\n\t * Creates a `queue` object with the specified `concurrency`. Tasks added to the\n\t * `queue` are processed in parallel (up to the `concurrency` limit). If all\n\t * `worker`s are in progress, the task is queued until one becomes available.\n\t * Once a `worker` completes a `task`, that `task`'s callback is called.\n\t *\n\t * @name queue\n\t * @static\n\t * @memberOf module:ControlFlow\n\t * @method\n\t * @category Control Flow\n\t * @param {Function} worker - An asynchronous function for processing a queued\n\t * task, which must call its `callback(err)` argument when finished, with an\n\t * optional `error` as an argument. If you want to handle errors from an\n\t * individual task, pass a callback to `q.push()`. Invoked with\n\t * (task, callback).\n\t * @param {number} [concurrency=1] - An `integer` for determining how many\n\t * `worker` functions should be run in parallel. If omitted, the concurrency\n\t * defaults to `1`. If the concurrency is `0`, an error is thrown.\n\t * @returns {module:ControlFlow.QueueObject} A queue object to manage the tasks. Callbacks can\n\t * attached as certain properties to listen for specific events during the\n\t * lifecycle of the queue.\n\t * @example\n\t *\n\t * // create a queue object with concurrency 2\n\t * var q = async.queue(function(task, callback) {\n\t * console.log('hello ' + task.name);\n\t * callback();\n\t * }, 2);\n\t *\n\t * // assign a callback\n\t * q.drain = function() {\n\t * console.log('all items have been processed');\n\t * };\n\t *\n\t * // add some items to the queue\n\t * q.push({name: 'foo'}, function(err) {\n\t * console.log('finished processing foo');\n\t * });\n\t * q.push({name: 'bar'}, function (err) {\n\t * console.log('finished processing bar');\n\t * });\n\t *\n\t * // add some items to the queue (batch-wise)\n\t * q.push([{name: 'baz'},{name: 'bay'},{name: 'bax'}], function(err) {\n\t * console.log('finished processing item');\n\t * });\n\t *\n\t * // add some items to the front of the queue\n\t * q.unshift({name: 'bar'}, function (err) {\n\t * console.log('finished processing bar');\n\t * });\n\t */\n\t\n\t/**\n\t * The same as [async.queue]{@link module:ControlFlow.queue} only tasks are assigned a priority and\n\t * completed in ascending priority order.\n\t *\n\t * @name priorityQueue\n\t * @static\n\t * @memberOf module:ControlFlow\n\t * @method\n\t * @see [async.queue]{@link module:ControlFlow.queue}\n\t * @category Control Flow\n\t * @param {Function} worker - An asynchronous function for processing a queued\n\t * task, which must call its `callback(err)` argument when finished, with an\n\t * optional `error` as an argument. If you want to handle errors from an\n\t * individual task, pass a callback to `q.push()`. Invoked with\n\t * (task, callback).\n\t * @param {number} concurrency - An `integer` for determining how many `worker`\n\t * functions should be run in parallel. If omitted, the concurrency defaults to\n\t * `1`. If the concurrency is `0`, an error is thrown.\n\t * @returns {module:ControlFlow.QueueObject} A priorityQueue object to manage the tasks. There are two\n\t * differences between `queue` and `priorityQueue` objects:\n\t * * `push(task, priority, [callback])` - `priority` should be a number. If an\n\t * array of `tasks` is given, all tasks will be assigned the same priority.\n\t * * The `unshift` method was removed.\n\t */\n\t\n\t/**\n\t * The opposite of [`filter`]{@link module:Collections.filter}. Removes values that pass an `async` truth test.\n\t *\n\t * @name reject\n\t * @static\n\t * @memberOf module:Collections\n\t * @method\n\t * @see [async.filter]{@link module:Collections.filter}\n\t * @category Collection\n\t * @param {Array|Iterable|Object} coll - A collection to iterate over.\n\t * @param {Function} iteratee - A truth test to apply to each item in `coll`.\n\t * The `iteratee` is passed a `callback(err, truthValue)`, which must be called\n\t * with a boolean argument once it has completed. Invoked with (item, callback).\n\t * @param {Function} [callback] - A callback which is called after all the\n\t * `iteratee` functions have finished. Invoked with (err, results).\n\t * @example\n\t *\n\t * async.reject(['file1','file2','file3'], function(filePath, callback) {\n\t * fs.access(filePath, function(err) {\n\t * callback(null, !err)\n\t * });\n\t * }, function(err, results) {\n\t * // results now equals an array of missing files\n\t * createFiles(results);\n\t * });\n\t */\n\t\n\t/**\n\t * The same as [`reject`]{@link module:Collections.reject} but runs a maximum of `limit` async operations at a\n\t * time.\n\t *\n\t * @name rejectLimit\n\t * @static\n\t * @memberOf module:Collections\n\t * @method\n\t * @see [async.reject]{@link module:Collections.reject}\n\t * @category Collection\n\t * @param {Array|Iterable|Object} coll - A collection to iterate over.\n\t * @param {number} limit - The maximum number of async operations at a time.\n\t * @param {Function} iteratee - A truth test to apply to each item in `coll`.\n\t * The `iteratee` is passed a `callback(err, truthValue)`, which must be called\n\t * with a boolean argument once it has completed. Invoked with (item, callback).\n\t * @param {Function} [callback] - A callback which is called after all the\n\t * `iteratee` functions have finished. Invoked with (err, results).\n\t */\n\t\n\t/**\n\t * The same as [`reject`]{@link module:Collections.reject} but runs only a single async operation at a time.\n\t *\n\t * @name rejectSeries\n\t * @static\n\t * @memberOf module:Collections\n\t * @method\n\t * @see [async.reject]{@link module:Collections.reject}\n\t * @category Collection\n\t * @param {Array|Iterable|Object} coll - A collection to iterate over.\n\t * @param {Function} iteratee - A truth test to apply to each item in `coll`.\n\t * The `iteratee` is passed a `callback(err, truthValue)`, which must be called\n\t * with a boolean argument once it has completed. Invoked with (item, callback).\n\t * @param {Function} [callback] - A callback which is called after all the\n\t * `iteratee` functions have finished. Invoked with (err, results).\n\t */\n\t\n\t/**\n\t * Creates a function that returns `value`.\n\t *\n\t * @static\n\t * @memberOf _\n\t * @since 2.4.0\n\t * @category Util\n\t * @param {*} value The value to return from the new function.\n\t * @returns {Function} Returns the new constant function.\n\t * @example\n\t *\n\t * var objects = _.times(2, _.constant({ 'a': 1 }));\n\t *\n\t * console.log(objects);\n\t * // => [{ 'a': 1 }, { 'a': 1 }]\n\t *\n\t * console.log(objects[0] === objects[1]);\n\t * // => true\n\t */\n\t\n\t/**\n\t * A close relative of [`retry`]{@link module:ControlFlow.retry}. This method wraps a task and makes it\n\t * retryable, rather than immediately calling it with retries.\n\t *\n\t * @name retryable\n\t * @static\n\t * @memberOf module:ControlFlow\n\t * @method\n\t * @see [async.retry]{@link module:ControlFlow.retry}\n\t * @category Control Flow\n\t * @param {Object|number} [opts = {times: 5, interval: 0}| 5] - optional\n\t * options, exactly the same as from `retry`\n\t * @param {Function} task - the asynchronous function to wrap\n\t * @returns {Functions} The wrapped function, which when invoked, will retry on\n\t * an error, based on the parameters specified in `opts`.\n\t * @example\n\t *\n\t * async.auto({\n\t * dep1: async.retryable(3, getFromFlakyService),\n\t * process: [\"dep1\", async.retryable(3, function (results, cb) {\n\t * maybeProcessData(results.dep1, cb);\n\t * })]\n\t * }, callback);\n\t */\n\t\n\t/**\n\t * Returns `true` if at least one element in the `coll` satisfies an async test.\n\t * If any iteratee call returns `true`, the main `callback` is immediately\n\t * called.\n\t *\n\t * @name some\n\t * @static\n\t * @memberOf module:Collections\n\t * @method\n\t * @alias any\n\t * @category Collection\n\t * @param {Array|Iterable|Object} coll - A collection to iterate over.\n\t * @param {Function} iteratee - A truth test to apply to each item in the array\n\t * in parallel. The iteratee is passed a `callback(err, truthValue)` which must\n\t * be called with a boolean argument once it has completed. Invoked with\n\t * (item, callback).\n\t * @param {Function} [callback] - A callback which is called as soon as any\n\t * iteratee returns `true`, or after all the iteratee functions have finished.\n\t * Result will be either `true` or `false` depending on the values of the async\n\t * tests. Invoked with (err, result).\n\t * @example\n\t *\n\t * async.some(['file1','file2','file3'], function(filePath, callback) {\n\t * fs.access(filePath, function(err) {\n\t * callback(null, !err)\n\t * });\n\t * }, function(err, result) {\n\t * // if result is true then at least one of the files exists\n\t * });\n\t */\n\t\n\t/**\n\t * The same as [`some`]{@link module:Collections.some} but runs a maximum of `limit` async operations at a time.\n\t *\n\t * @name someLimit\n\t * @static\n\t * @memberOf module:Collections\n\t * @method\n\t * @see [async.some]{@link module:Collections.some}\n\t * @alias anyLimit\n\t * @category Collection\n\t * @param {Array|Iterable|Object} coll - A collection to iterate over.\n\t * @param {number} limit - The maximum number of async operations at a time.\n\t * @param {Function} iteratee - A truth test to apply to each item in the array\n\t * in parallel. The iteratee is passed a `callback(err, truthValue)` which must\n\t * be called with a boolean argument once it has completed. Invoked with\n\t * (item, callback).\n\t * @param {Function} [callback] - A callback which is called as soon as any\n\t * iteratee returns `true`, or after all the iteratee functions have finished.\n\t * Result will be either `true` or `false` depending on the values of the async\n\t * tests. Invoked with (err, result).\n\t */\n\t\n\t/**\n\t * The same as [`some`]{@link module:Collections.some} but runs only a single async operation at a time.\n\t *\n\t * @name someSeries\n\t * @static\n\t * @memberOf module:Collections\n\t * @method\n\t * @see [async.some]{@link module:Collections.some}\n\t * @alias anySeries\n\t * @category Collection\n\t * @param {Array|Iterable|Object} coll - A collection to iterate over.\n\t * @param {Function} iteratee - A truth test to apply to each item in the array\n\t * in parallel. The iteratee is passed a `callback(err, truthValue)` which must\n\t * be called with a boolean argument once it has completed. Invoked with\n\t * (item, callback).\n\t * @param {Function} [callback] - A callback which is called as soon as any\n\t * iteratee returns `true`, or after all the iteratee functions have finished.\n\t * Result will be either `true` or `false` depending on the values of the async\n\t * tests. Invoked with (err, result).\n\t */\n\t\n\t/* Built-in method references for those with the same name as other `lodash` methods. */\n\tvar nativeCeil = Math.ceil;\n\tvar nativeMax$1 = Math.max;\n\t\n\t/**\n\t * Calls the `iteratee` function `n` times, and accumulates results in the same\n\t * manner you would use with [map]{@link module:Collections.map}.\n\t *\n\t * @name times\n\t * @static\n\t * @memberOf module:ControlFlow\n\t * @method\n\t * @see [async.map]{@link module:Collections.map}\n\t * @category Control Flow\n\t * @param {number} n - The number of times to run the function.\n\t * @param {Function} iteratee - The function to call `n` times. Invoked with the\n\t * iteration index and a callback (n, next).\n\t * @param {Function} callback - see {@link module:Collections.map}.\n\t * @example\n\t *\n\t * // Pretend this is some complicated async factory\n\t * var createUser = function(id, callback) {\n\t * callback(null, {\n\t * id: 'user' + id\n\t * });\n\t * };\n\t *\n\t * // generate 5 users\n\t * async.times(5, function(n, next) {\n\t * createUser(n, function(err, user) {\n\t * next(err, user);\n\t * });\n\t * }, function(err, users) {\n\t * // we should now have 5 users\n\t * });\n\t */\n\t\n\t/**\n\t * The same as [times]{@link module:ControlFlow.times} but runs only a single async operation at a time.\n\t *\n\t * @name timesSeries\n\t * @static\n\t * @memberOf module:ControlFlow\n\t * @method\n\t * @see [async.times]{@link module:ControlFlow.times}\n\t * @category Control Flow\n\t * @param {number} n - The number of times to run the function.\n\t * @param {Function} iteratee - The function to call `n` times. Invoked with the\n\t * iteration index and a callback (n, next).\n\t * @param {Function} callback - see {@link module:Collections.map}.\n\t */\n\t\n\t/**\n\t * Undoes a [memoize]{@link module:Utils.memoize}d function, reverting it to the original,\n\t * unmemoized form. Handy for testing.\n\t *\n\t * @name unmemoize\n\t * @static\n\t * @memberOf module:Utils\n\t * @method\n\t * @see [async.memoize]{@link module:Utils.memoize}\n\t * @category Util\n\t * @param {Function} fn - the memoized function\n\t * @returns {Function} a function that calls the original unmemoized function\n\t */\n\t\n\t/**\n\t * Runs the `tasks` array of functions in series, each passing their results to\n\t * the next in the array. However, if any of the `tasks` pass an error to their\n\t * own callback, the next function is not executed, and the main `callback` is\n\t * immediately called with the error.\n\t *\n\t * @name waterfall\n\t * @static\n\t * @memberOf module:ControlFlow\n\t * @method\n\t * @category Control Flow\n\t * @param {Array} tasks - An array of functions to run, each function is passed\n\t * a `callback(err, result1, result2, ...)` it must call on completion. The\n\t * first argument is an error (which can be `null`) and any further arguments\n\t * will be passed as arguments in order to the next task.\n\t * @param {Function} [callback] - An optional callback to run once all the\n\t * functions have completed. This will be passed the results of the last task's\n\t * callback. Invoked with (err, [results]).\n\t * @returns undefined\n\t * @example\n\t *\n\t * async.waterfall([\n\t * function(callback) {\n\t * callback(null, 'one', 'two');\n\t * },\n\t * function(arg1, arg2, callback) {\n\t * // arg1 now equals 'one' and arg2 now equals 'two'\n\t * callback(null, 'three');\n\t * },\n\t * function(arg1, callback) {\n\t * // arg1 now equals 'three'\n\t * callback(null, 'done');\n\t * }\n\t * ], function (err, result) {\n\t * // result now equals 'done'\n\t * });\n\t *\n\t * // Or, with named functions:\n\t * async.waterfall([\n\t * myFirstFunction,\n\t * mySecondFunction,\n\t * myLastFunction,\n\t * ], function (err, result) {\n\t * // result now equals 'done'\n\t * });\n\t * function myFirstFunction(callback) {\n\t * callback(null, 'one', 'two');\n\t * }\n\t * function mySecondFunction(arg1, arg2, callback) {\n\t * // arg1 now equals 'one' and arg2 now equals 'two'\n\t * callback(null, 'three');\n\t * }\n\t * function myLastFunction(arg1, callback) {\n\t * // arg1 now equals 'three'\n\t * callback(null, 'done');\n\t * }\n\t */\n\t\n\t/**\n\t * Async is a utility module which provides straight-forward, powerful functions\n\t * for working with asynchronous JavaScript. Although originally designed for\n\t * use with [Node.js](http://nodejs.org) and installable via\n\t * `npm install --save async`, it can also be used directly in the browser.\n\t * @module async\n\t */\n\t\n\t/**\n\t * A collection of `async` functions for manipulating collections, such as\n\t * arrays and objects.\n\t * @module Collections\n\t */\n\t\n\t/**\n\t * A collection of `async` functions for controlling the flow through a script.\n\t * @module ControlFlow\n\t */\n\t\n\t /**\n\t * A collection of `async` utility functions.\n\t * @module Utils\n\t */\n\t\n\tvar errorCodeLookup;\n\t// Lazily construct error code lookup, since DropboxJS might be loaded *after* BrowserFS (or not at all!)\n\tfunction constructErrorCodeLookup() {\n\t if (errorCodeLookup) {\n\t return;\n\t }\n\t errorCodeLookup = {};\n\t // This indicates a network transmission error on modern browsers. Internet Explorer might cause this code to be reported on some API server errors.\n\t errorCodeLookup[Dropbox.ApiError.NETWORK_ERROR] = ErrorCode.EIO;\n\t // This happens when the contentHash parameter passed to a Dropbox.Client#readdir or Dropbox.Client#stat matches the most recent content, so the API call response is omitted, to save bandwidth.\n\t // errorCodeLookup[Dropbox.ApiError.NO_CONTENT];\n\t // The error property on {Dropbox.ApiError#response} should indicate which input parameter is invalid and why.\n\t errorCodeLookup[Dropbox.ApiError.INVALID_PARAM] = ErrorCode.EINVAL;\n\t // The OAuth token used for the request will never become valid again, so the user should be re-authenticated.\n\t errorCodeLookup[Dropbox.ApiError.INVALID_TOKEN] = ErrorCode.EPERM;\n\t // This indicates a bug in dropbox.js and should never occur under normal circumstances.\n\t // ^ Actually, that's false. This occurs when you try to move folders to themselves, or move a file over another file.\n\t errorCodeLookup[Dropbox.ApiError.OAUTH_ERROR] = ErrorCode.EPERM;\n\t // This happens when trying to read from a non-existing file, readdir a non-existing directory, write a file into a non-existing directory, etc.\n\t errorCodeLookup[Dropbox.ApiError.NOT_FOUND] = ErrorCode.ENOENT;\n\t // This indicates a bug in dropbox.js and should never occur under normal circumstances.\n\t errorCodeLookup[Dropbox.ApiError.INVALID_METHOD] = ErrorCode.EINVAL;\n\t // This happens when a Dropbox.Client#readdir or Dropbox.Client#stat call would return more than a maximum amount of directory entries.\n\t errorCodeLookup[Dropbox.ApiError.NOT_ACCEPTABLE] = ErrorCode.EINVAL;\n\t // This is used by some backend methods to indicate that the client needs to download server-side changes and perform conflict resolution. Under normal usage, errors with this code should never surface to the code using dropbox.js.\n\t errorCodeLookup[Dropbox.ApiError.CONFLICT] = ErrorCode.EINVAL;\n\t // Status value indicating that the application is making too many requests.\n\t errorCodeLookup[Dropbox.ApiError.RATE_LIMITED] = ErrorCode.EBUSY;\n\t // The request should be retried after some time.\n\t errorCodeLookup[Dropbox.ApiError.SERVER_ERROR] = ErrorCode.EBUSY;\n\t // Status value indicating that the user's Dropbox is over its storage quota.\n\t errorCodeLookup[Dropbox.ApiError.OVER_QUOTA] = ErrorCode.ENOSPC;\n\t}\n\tfunction isFileInfo(cache) {\n\t return cache && cache.stat.isFile;\n\t}\n\tfunction isDirInfo(cache) {\n\t return cache && cache.stat.isFolder;\n\t}\n\tfunction isArrayBuffer(ab) {\n\t // Accept null / undefined, too.\n\t return ab === null || ab === undefined || (typeof (ab) === 'object' && typeof (ab['byteLength']) === 'number');\n\t}\n\t/**\n\t * Wraps a Dropbox client and caches operations.\n\t */\n\tvar CachedDropboxClient = function CachedDropboxClient(client) {\n\t this._cache = {};\n\t this._client = client;\n\t};\n\tCachedDropboxClient.prototype.readdir = function readdir (p, cb) {\n\t var this$1 = this;\n\t\n\t var cacheInfo = this.getCachedDirInfo(p);\n\t this._wrap(function (interceptCb) {\n\t if (cacheInfo !== null && cacheInfo.contents) {\n\t this$1._client.readdir(p, {\n\t contentHash: cacheInfo.stat.contentHash\n\t }, interceptCb);\n\t }\n\t else {\n\t this$1._client.readdir(p, interceptCb);\n\t }\n\t }, function (err, filenames, stat, folderEntries) {\n\t if (err) {\n\t if (err.status === Dropbox.ApiError.NO_CONTENT && cacheInfo !== null) {\n\t cb(null, cacheInfo.contents.slice(0));\n\t }\n\t else {\n\t cb(err);\n\t }\n\t }\n\t else {\n\t this$1.updateCachedDirInfo(p, stat, filenames.slice(0));\n\t folderEntries.forEach(function (entry) {\n\t this$1.updateCachedInfo(path.join(p, entry.name), entry);\n\t });\n\t cb(null, filenames);\n\t }\n\t });\n\t};\n\tCachedDropboxClient.prototype.remove = function remove (p, cb) {\n\t var this$1 = this;\n\t\n\t this._wrap(function (interceptCb) {\n\t this$1._client.remove(p, interceptCb);\n\t }, function (err, stat) {\n\t if (!err) {\n\t this$1.updateCachedInfo(p, stat);\n\t }\n\t cb(err);\n\t });\n\t};\n\tCachedDropboxClient.prototype.move = function move (src, dest, cb) {\n\t var this$1 = this;\n\t\n\t this._wrap(function (interceptCb) {\n\t this$1._client.move(src, dest, interceptCb);\n\t }, function (err, stat) {\n\t if (!err) {\n\t this$1.deleteCachedInfo(src);\n\t this$1.updateCachedInfo(dest, stat);\n\t }\n\t cb(err);\n\t });\n\t};\n\tCachedDropboxClient.prototype.stat = function stat (p, cb) {\n\t var this$1 = this;\n\t\n\t this._wrap(function (interceptCb) {\n\t this$1._client.stat(p, interceptCb);\n\t }, function (err, stat) {\n\t if (!err) {\n\t this$1.updateCachedInfo(p, stat);\n\t }\n\t cb(err, stat);\n\t });\n\t};\n\tCachedDropboxClient.prototype.readFile = function readFile (p, cb) {\n\t var this$1 = this;\n\t\n\t var cacheInfo = this.getCachedFileInfo(p);\n\t if (cacheInfo !== null && cacheInfo.contents !== null) {\n\t // Try to use cached info; issue a stat to see if contents are up-to-date.\n\t this.stat(p, function (error, stat) {\n\t if (error) {\n\t cb(error);\n\t }\n\t else if (stat.contentHash === cacheInfo.stat.contentHash) {\n\t // No file changes.\n\t cb(error, cacheInfo.contents.slice(0), cacheInfo.stat);\n\t }\n\t else {\n\t // File changes; rerun to trigger actual readFile.\n\t this$1.readFile(p, cb);\n\t }\n\t });\n\t }\n\t else {\n\t this._wrap(function (interceptCb) {\n\t this$1._client.readFile(p, { arrayBuffer: true }, interceptCb);\n\t }, function (err, contents, stat) {\n\t if (!err) {\n\t this$1.updateCachedInfo(p, stat, contents.slice(0));\n\t }\n\t cb(err, contents, stat);\n\t });\n\t }\n\t};\n\tCachedDropboxClient.prototype.writeFile = function writeFile (p, contents, cb) {\n\t var this$1 = this;\n\t\n\t this._wrap(function (interceptCb) {\n\t this$1._client.writeFile(p, contents, interceptCb);\n\t }, function (err, stat) {\n\t if (!err) {\n\t this$1.updateCachedInfo(p, stat, contents.slice(0));\n\t }\n\t cb(err, stat);\n\t });\n\t};\n\tCachedDropboxClient.prototype.mkdir = function mkdir (p, cb) {\n\t var this$1 = this;\n\t\n\t this._wrap(function (interceptCb) {\n\t this$1._client.mkdir(p, interceptCb);\n\t }, function (err, stat) {\n\t if (!err) {\n\t this$1.updateCachedInfo(p, stat, []);\n\t }\n\t cb(err);\n\t });\n\t};\n\t/**\n\t * Wraps an operation such that we retry a failed operation 3 times.\n\t * Necessary to deal with Dropbox rate limiting.\n\t *\n\t * @param performOp Function that performs the operation. Will be called up to three times.\n\t * @param cb Called when the operation succeeds, fails in a non-temporary manner, or fails three times.\n\t */\n\tCachedDropboxClient.prototype._wrap = function _wrap (performOp, cb) {\n\t var numRun = 0;\n\t var interceptCb = function (error) {\n\t // Timeout duration, in seconds.\n\t var timeoutDuration = 2;\n\t if (error && 3 > (++numRun)) {\n\t switch (error.status) {\n\t case Dropbox.ApiError.SERVER_ERROR:\n\t case Dropbox.ApiError.NETWORK_ERROR:\n\t case Dropbox.ApiError.RATE_LIMITED:\n\t setTimeout(function () {\n\t performOp(interceptCb);\n\t }, timeoutDuration * 1000);\n\t break;\n\t default:\n\t cb.apply(null, arguments);\n\t break;\n\t }\n\t }\n\t else {\n\t cb.apply(null, arguments);\n\t }\n\t };\n\t performOp(interceptCb);\n\t};\n\tCachedDropboxClient.prototype.getCachedInfo = function getCachedInfo (p) {\n\t return this._cache[p.toLowerCase()];\n\t};\n\tCachedDropboxClient.prototype.putCachedInfo = function putCachedInfo (p, cache) {\n\t this._cache[p.toLowerCase()] = cache;\n\t};\n\tCachedDropboxClient.prototype.deleteCachedInfo = function deleteCachedInfo (p) {\n\t delete this._cache[p.toLowerCase()];\n\t};\n\tCachedDropboxClient.prototype.getCachedDirInfo = function getCachedDirInfo (p) {\n\t var info = this.getCachedInfo(p);\n\t if (isDirInfo(info)) {\n\t return info;\n\t }\n\t else {\n\t return null;\n\t }\n\t};\n\tCachedDropboxClient.prototype.getCachedFileInfo = function getCachedFileInfo (p) {\n\t var info = this.getCachedInfo(p);\n\t if (isFileInfo(info)) {\n\t return info;\n\t }\n\t else {\n\t return null;\n\t }\n\t};\n\tCachedDropboxClient.prototype.updateCachedDirInfo = function updateCachedDirInfo (p, stat, contents) {\n\t if ( contents === void 0 ) contents = null;\n\t\n\t var cachedInfo = this.getCachedInfo(p);\n\t // Dropbox uses the *contentHash* property for directories.\n\t // Ignore stat objects w/o a contentHash defined; those actually exist!!!\n\t // (Example: readdir returns an array of stat objs; stat objs for dirs in that context have no contentHash)\n\t if (stat.contentHash !== null && (cachedInfo === undefined || cachedInfo.stat.contentHash !== stat.contentHash)) {\n\t this.putCachedInfo(p, {\n\t stat: stat,\n\t contents: contents\n\t });\n\t }\n\t};\n\tCachedDropboxClient.prototype.updateCachedFileInfo = function updateCachedFileInfo (p, stat, contents) {\n\t if ( contents === void 0 ) contents = null;\n\t\n\t var cachedInfo = this.getCachedInfo(p);\n\t // Dropbox uses the *versionTag* property for files.\n\t // Ignore stat objects w/o a versionTag defined.\n\t if (stat.versionTag !== null && (cachedInfo === undefined || cachedInfo.stat.versionTag !== stat.versionTag)) {\n\t this.putCachedInfo(p, {\n\t stat: stat,\n\t contents: contents\n\t });\n\t }\n\t};\n\tCachedDropboxClient.prototype.updateCachedInfo = function updateCachedInfo (p, stat, contents) {\n\t if ( contents === void 0 ) contents = null;\n\t\n\t if (stat.isFile && isArrayBuffer(contents)) {\n\t this.updateCachedFileInfo(p, stat, contents);\n\t }\n\t else if (stat.isFolder && Array.isArray(contents)) {\n\t this.updateCachedDirInfo(p, stat, contents);\n\t }\n\t};\n\tvar DropboxFile = (function (PreloadFile$$1) {\n\t function DropboxFile(_fs, _path, _flag, _stat, contents) {\n\t PreloadFile$$1.call(this, _fs, _path, _flag, _stat, contents);\n\t }\n\t\n\t if ( PreloadFile$$1 ) DropboxFile.__proto__ = PreloadFile$$1;\n\t DropboxFile.prototype = Object.create( PreloadFile$$1 && PreloadFile$$1.prototype );\n\t DropboxFile.prototype.constructor = DropboxFile;\n\t DropboxFile.prototype.sync = function sync (cb) {\n\t var this$1 = this;\n\t\n\t if (this.isDirty()) {\n\t var buffer$$1 = this.getBuffer(), arrayBuffer = buffer2ArrayBuffer(buffer$$1);\n\t this._fs._writeFileStrict(this.getPath(), arrayBuffer, function (e) {\n\t if (!e) {\n\t this$1.resetDirty();\n\t }\n\t cb(e);\n\t });\n\t }\n\t else {\n\t cb();\n\t }\n\t };\n\t DropboxFile.prototype.close = function close (cb) {\n\t this.sync(cb);\n\t };\n\t\n\t return DropboxFile;\n\t}(PreloadFile));\n\tvar DropboxFileSystem = (function (BaseFileSystem$$1) {\n\t function DropboxFileSystem(client) {\n\t BaseFileSystem$$1.call(this);\n\t this._client = new CachedDropboxClient(client);\n\t constructErrorCodeLookup();\n\t }\n\t\n\t if ( BaseFileSystem$$1 ) DropboxFileSystem.__proto__ = BaseFileSystem$$1;\n\t DropboxFileSystem.prototype = Object.create( BaseFileSystem$$1 && BaseFileSystem$$1.prototype );\n\t DropboxFileSystem.prototype.constructor = DropboxFileSystem;\n\t DropboxFileSystem.isAvailable = function isAvailable () {\n\t // Checks if the Dropbox library is loaded.\n\t return typeof Dropbox !== 'undefined';\n\t };\n\t\n\t DropboxFileSystem.prototype.getName = function getName () {\n\t return 'Dropbox';\n\t };\n\t DropboxFileSystem.prototype.isReadOnly = function isReadOnly () {\n\t return false;\n\t };\n\t // Dropbox doesn't support symlinks, properties, or synchronous calls\n\t DropboxFileSystem.prototype.supportsSymlinks = function supportsSymlinks () {\n\t return false;\n\t };\n\t DropboxFileSystem.prototype.supportsProps = function supportsProps () {\n\t return false;\n\t };\n\t DropboxFileSystem.prototype.supportsSynch = function supportsSynch () {\n\t return false;\n\t };\n\t DropboxFileSystem.prototype.empty = function empty (mainCb) {\n\t var this$1 = this;\n\t\n\t this._client.readdir('/', function (error, files) {\n\t if (error) {\n\t mainCb(this$1.convert(error, '/'));\n\t }\n\t else {\n\t var deleteFile = function (file, cb) {\n\t var p = path.join('/', file);\n\t this$1._client.remove(p, function (err) {\n\t cb(err ? this$1.convert(err, p) : null);\n\t });\n\t };\n\t var finished = function (err) {\n\t if (err) {\n\t mainCb(err);\n\t }\n\t else {\n\t mainCb();\n\t }\n\t };\n\t // XXX: typing is to get around overly-restrictive ErrorCallback typing.\n\t eachLimit(files, deleteFile, finished);\n\t }\n\t });\n\t };\n\t DropboxFileSystem.prototype.rename = function rename (oldPath, newPath, cb) {\n\t var this$1 = this;\n\t\n\t this._client.move(oldPath, newPath, function (error) {\n\t if (error) {\n\t // the move is permitted if newPath is a file.\n\t // Check if this is the case, and remove if so.\n\t this$1._client.stat(newPath, function (error2, stat) {\n\t if (error2 || stat.isFolder) {\n\t var missingPath = error.response.error.indexOf(oldPath) > -1 ? oldPath : newPath;\n\t cb(this$1.convert(error, missingPath));\n\t }\n\t else {\n\t // Delete file, repeat rename.\n\t this$1._client.remove(newPath, function (error2) {\n\t if (error2) {\n\t cb(this$1.convert(error2, newPath));\n\t }\n\t else {\n\t this$1.rename(oldPath, newPath, cb);\n\t }\n\t });\n\t }\n\t });\n\t }\n\t else {\n\t cb();\n\t }\n\t });\n\t };\n\t DropboxFileSystem.prototype.stat = function stat (path$$1, isLstat, cb) {\n\t var this$1 = this;\n\t\n\t // Ignore lstat case -- Dropbox doesn't support symlinks\n\t // Stat the file\n\t this._client.stat(path$$1, function (error, stat) {\n\t if (error) {\n\t cb(this$1.convert(error, path$$1));\n\t }\n\t else if (stat && stat.isRemoved) {\n\t // Dropbox keeps track of deleted files, so if a file has existed in the\n\t // past but doesn't any longer, you wont get an error\n\t cb(ApiError.FileError(ErrorCode.ENOENT, path$$1));\n\t }\n\t else {\n\t var stats = new Stats(this$1._statType(stat), stat.size);\n\t return cb(null, stats);\n\t }\n\t });\n\t };\n\t DropboxFileSystem.prototype.open = function open (path$$1, flags, mode, cb) {\n\t var this$1 = this;\n\t\n\t // Try and get the file's contents\n\t this._client.readFile(path$$1, function (error, content, dbStat) {\n\t if (error) {\n\t // If the file's being opened for reading and doesn't exist, return an\n\t // error\n\t if (flags.isReadable()) {\n\t cb(this$1.convert(error, path$$1));\n\t }\n\t else {\n\t switch (error.status) {\n\t // If it's being opened for writing or appending, create it so that\n\t // it can be written to\n\t case Dropbox.ApiError.NOT_FOUND:\n\t var ab = new ArrayBuffer(0);\n\t return this$1._writeFileStrict(path$$1, ab, function (error2, stat) {\n\t if (error2) {\n\t cb(error2);\n\t }\n\t else {\n\t var file = this$1._makeFile(path$$1, flags, stat, arrayBuffer2Buffer(ab));\n\t cb(null, file);\n\t }\n\t });\n\t default:\n\t return cb(this$1.convert(error, path$$1));\n\t }\n\t }\n\t }\n\t else {\n\t // No error\n\t var buffer$$1;\n\t // Dropbox.js seems to set `content` to `null` rather than to an empty\n\t // buffer when reading an empty file. Not sure why this is.\n\t if (content === null) {\n\t buffer$$1 = new Buffer(0);\n\t }\n\t else {\n\t buffer$$1 = arrayBuffer2Buffer(content);\n\t }\n\t var file = this$1._makeFile(path$$1, flags, dbStat, buffer$$1);\n\t return cb(null, file);\n\t }\n\t });\n\t };\n\t DropboxFileSystem.prototype._writeFileStrict = function _writeFileStrict (p, data, cb) {\n\t var this$1 = this;\n\t\n\t var parent = path.dirname(p);\n\t this.stat(parent, false, function (error, stat) {\n\t if (error) {\n\t cb(ApiError.FileError(ErrorCode.ENOENT, parent));\n\t }\n\t else {\n\t this$1._client.writeFile(p, data, function (error2, stat) {\n\t if (error2) {\n\t cb(this$1.convert(error2, p));\n\t }\n\t else {\n\t cb(null, stat);\n\t }\n\t });\n\t }\n\t });\n\t };\n\t /**\n\t * Private\n\t * Returns a BrowserFS object representing the type of a Dropbox.js stat object\n\t */\n\t DropboxFileSystem.prototype._statType = function _statType (stat) {\n\t return stat.isFile ? FileType.FILE : FileType.DIRECTORY;\n\t };\n\t /**\n\t * Private\n\t * Returns a BrowserFS object representing a File, created from the data\n\t * returned by calls to the Dropbox API.\n\t */\n\t DropboxFileSystem.prototype._makeFile = function _makeFile (path$$1, flag, stat, buffer$$1) {\n\t var type = this._statType(stat);\n\t var stats = new Stats(type, stat.size);\n\t return new DropboxFile(this, path$$1, flag, stats, buffer$$1);\n\t };\n\t /**\n\t * Private\n\t * Delete a file or directory from Dropbox\n\t * isFile should reflect which call was made to remove the it (`unlink` or\n\t * `rmdir`). If this doesn't match what's actually at `path`, an error will be\n\t * returned\n\t */\n\t DropboxFileSystem.prototype._remove = function _remove (path$$1, cb, isFile) {\n\t var this$1 = this;\n\t\n\t this._client.stat(path$$1, function (error, stat) {\n\t if (error) {\n\t cb(this$1.convert(error, path$$1));\n\t }\n\t else {\n\t if (stat.isFile && !isFile) {\n\t cb(ApiError.FileError(ErrorCode.ENOTDIR, path$$1));\n\t }\n\t else if (!stat.isFile && isFile) {\n\t cb(ApiError.FileError(ErrorCode.EISDIR, path$$1));\n\t }\n\t else {\n\t this$1._client.remove(path$$1, function (error) {\n\t if (error) {\n\t cb(this$1.convert(error, path$$1));\n\t }\n\t else {\n\t cb(null);\n\t }\n\t });\n\t }\n\t }\n\t });\n\t };\n\t /**\n\t * Delete a file\n\t */\n\t DropboxFileSystem.prototype.unlink = function unlink (path$$1, cb) {\n\t this._remove(path$$1, cb, true);\n\t };\n\t /**\n\t * Delete a directory\n\t */\n\t DropboxFileSystem.prototype.rmdir = function rmdir (path$$1, cb) {\n\t this._remove(path$$1, cb, false);\n\t };\n\t /**\n\t * Create a directory\n\t */\n\t DropboxFileSystem.prototype.mkdir = function mkdir (p, mode, cb) {\n\t var this$1 = this;\n\t\n\t // Dropbox.js' client.mkdir() behaves like `mkdir -p`, i.e. it creates a\n\t // directory and all its ancestors if they don't exist.\n\t // Node's fs.mkdir() behaves like `mkdir`, i.e. it throws an error if an attempt\n\t // is made to create a directory without a parent.\n\t // To handle this inconsistency, a check for the existence of `path`'s parent\n\t // must be performed before it is created, and an error thrown if it does\n\t // not exist\n\t var parent = path.dirname(p);\n\t this._client.stat(parent, function (error, stat) {\n\t if (error) {\n\t cb(this$1.convert(error, parent));\n\t }\n\t else {\n\t this$1._client.mkdir(p, function (error) {\n\t if (error) {\n\t cb(ApiError.FileError(ErrorCode.EEXIST, p));\n\t }\n\t else {\n\t cb(null);\n\t }\n\t });\n\t }\n\t });\n\t };\n\t /**\n\t * Get the names of the files in a directory\n\t */\n\t DropboxFileSystem.prototype.readdir = function readdir (path$$1, cb) {\n\t var this$1 = this;\n\t\n\t this._client.readdir(path$$1, function (error, files) {\n\t if (error) {\n\t return cb(this$1.convert(error));\n\t }\n\t else {\n\t return cb(null, files);\n\t }\n\t });\n\t };\n\t /**\n\t * Converts a Dropbox-JS error into a BFS error.\n\t */\n\t DropboxFileSystem.prototype.convert = function convert (err, path$$1) {\n\t if ( path$$1 === void 0 ) path$$1 = null;\n\t\n\t var errorCode = errorCodeLookup[err.status];\n\t if (errorCode === undefined) {\n\t errorCode = ErrorCode.EIO;\n\t }\n\t if (!path$$1) {\n\t return new ApiError(errorCode);\n\t }\n\t else {\n\t return ApiError.FileError(errorCode, path$$1);\n\t }\n\t };\n\t\n\t return DropboxFileSystem;\n\t}(BaseFileSystem));\n\t\n\tfunction convertError(e, path$$1) {\n\t if ( path$$1 === void 0 ) path$$1 = '';\n\t\n\t var errno = e.errno;\n\t var parent = e.node;\n\t var paths = [];\n\t while (parent) {\n\t paths.unshift(parent.name);\n\t if (parent === parent.parent) {\n\t break;\n\t }\n\t parent = parent.parent;\n\t }\n\t return new ApiError(errno, ErrorStrings[errno], paths.length > 0 ? '/' + paths.join('/') : path$$1);\n\t}\n\tvar EmscriptenFile = (function (BaseFile$$1) {\n\t function EmscriptenFile(_fs, _FS, _path, _stream) {\n\t BaseFile$$1.call(this);\n\t this._fs = _fs;\n\t this._FS = _FS;\n\t this._path = _path;\n\t this._stream = _stream;\n\t }\n\t\n\t if ( BaseFile$$1 ) EmscriptenFile.__proto__ = BaseFile$$1;\n\t EmscriptenFile.prototype = Object.create( BaseFile$$1 && BaseFile$$1.prototype );\n\t EmscriptenFile.prototype.constructor = EmscriptenFile;\n\t EmscriptenFile.prototype.getPos = function getPos () {\n\t return undefined;\n\t };\n\t EmscriptenFile.prototype.close = function close (cb) {\n\t var err = null;\n\t try {\n\t this.closeSync();\n\t }\n\t catch (e) {\n\t err = e;\n\t }\n\t finally {\n\t cb(err);\n\t }\n\t };\n\t EmscriptenFile.prototype.closeSync = function closeSync () {\n\t try {\n\t this._FS.close(this._stream);\n\t }\n\t catch (e) {\n\t throw convertError(e, this._path);\n\t }\n\t };\n\t EmscriptenFile.prototype.stat = function stat (cb) {\n\t try {\n\t cb(null, this.statSync());\n\t }\n\t catch (e) {\n\t cb(e);\n\t }\n\t };\n\t EmscriptenFile.prototype.statSync = function statSync () {\n\t try {\n\t return this._fs.statSync(this._path, false);\n\t }\n\t catch (e) {\n\t throw convertError(e, this._path);\n\t }\n\t };\n\t EmscriptenFile.prototype.truncate = function truncate (len, cb) {\n\t var err = null;\n\t try {\n\t this.truncateSync(len);\n\t }\n\t catch (e) {\n\t err = e;\n\t }\n\t finally {\n\t cb(err);\n\t }\n\t };\n\t EmscriptenFile.prototype.truncateSync = function truncateSync (len) {\n\t try {\n\t this._FS.ftruncate(this._stream.fd, len);\n\t }\n\t catch (e) {\n\t throw convertError(e, this._path);\n\t }\n\t };\n\t EmscriptenFile.prototype.write = function write (buffer$$1, offset, length, position, cb) {\n\t try {\n\t cb(null, this.writeSync(buffer$$1, offset, length, position), buffer$$1);\n\t }\n\t catch (e) {\n\t cb(e);\n\t }\n\t };\n\t EmscriptenFile.prototype.writeSync = function writeSync (buffer$$1, offset, length, position) {\n\t try {\n\t var u8 = buffer2Uint8array(buffer$$1);\n\t // Emscripten is particular about what position is set to.\n\t var emPosition = position === null ? undefined : position;\n\t return this._FS.write(this._stream, u8, offset, length, emPosition);\n\t }\n\t catch (e) {\n\t throw convertError(e, this._path);\n\t }\n\t };\n\t EmscriptenFile.prototype.read = function read (buffer$$1, offset, length, position, cb) {\n\t try {\n\t cb(null, this.readSync(buffer$$1, offset, length, position), buffer$$1);\n\t }\n\t catch (e) {\n\t cb(e);\n\t }\n\t };\n\t EmscriptenFile.prototype.readSync = function readSync (buffer$$1, offset, length, position) {\n\t try {\n\t var u8 = buffer2Uint8array(buffer$$1);\n\t // Emscripten is particular about what position is set to.\n\t var emPosition = position === null ? undefined : position;\n\t return this._FS.read(this._stream, u8, offset, length, emPosition);\n\t }\n\t catch (e) {\n\t throw convertError(e, this._path);\n\t }\n\t };\n\t EmscriptenFile.prototype.sync = function sync (cb) {\n\t // NOP.\n\t cb();\n\t };\n\t EmscriptenFile.prototype.syncSync = function syncSync () {\n\t // NOP.\n\t };\n\t EmscriptenFile.prototype.chown = function chown (uid, gid, cb) {\n\t var err = null;\n\t try {\n\t this.chownSync(uid, gid);\n\t }\n\t catch (e) {\n\t err = e;\n\t }\n\t finally {\n\t cb(err);\n\t }\n\t };\n\t EmscriptenFile.prototype.chownSync = function chownSync (uid, gid) {\n\t try {\n\t this._FS.fchown(this._stream.fd, uid, gid);\n\t }\n\t catch (e) {\n\t throw convertError(e, this._path);\n\t }\n\t };\n\t EmscriptenFile.prototype.chmod = function chmod (mode, cb) {\n\t var err = null;\n\t try {\n\t this.chmodSync(mode);\n\t }\n\t catch (e) {\n\t err = e;\n\t }\n\t finally {\n\t cb(err);\n\t }\n\t };\n\t EmscriptenFile.prototype.chmodSync = function chmodSync (mode) {\n\t try {\n\t this._FS.fchmod(this._stream.fd, mode);\n\t }\n\t catch (e) {\n\t throw convertError(e, this._path);\n\t }\n\t };\n\t EmscriptenFile.prototype.utimes = function utimes (atime, mtime, cb) {\n\t var err = null;\n\t try {\n\t this.utimesSync(atime, mtime);\n\t }\n\t catch (e) {\n\t err = e;\n\t }\n\t finally {\n\t cb(err);\n\t }\n\t };\n\t EmscriptenFile.prototype.utimesSync = function utimesSync (atime, mtime) {\n\t this._fs.utimesSync(this._path, atime, mtime);\n\t };\n\t\n\t return EmscriptenFile;\n\t}(BaseFile));\n\t/**\n\t * A simple in-memory file system backed by an InMemoryStore.\n\t */\n\tvar EmscriptenFileSystem = (function (SynchronousFileSystem$$1) {\n\t function EmscriptenFileSystem(_FS) {\n\t SynchronousFileSystem$$1.call(this);\n\t this._FS = _FS;\n\t }\n\t\n\t if ( SynchronousFileSystem$$1 ) EmscriptenFileSystem.__proto__ = SynchronousFileSystem$$1;\n\t EmscriptenFileSystem.prototype = Object.create( SynchronousFileSystem$$1 && SynchronousFileSystem$$1.prototype );\n\t EmscriptenFileSystem.prototype.constructor = EmscriptenFileSystem;\n\t EmscriptenFileSystem.isAvailable = function isAvailable () { return true; };\n\t\n\t EmscriptenFileSystem.prototype.getName = function getName () { return this._FS.DB_NAME(); };\n\t EmscriptenFileSystem.prototype.isReadOnly = function isReadOnly () { return false; };\n\t EmscriptenFileSystem.prototype.supportsLinks = function supportsLinks () { return true; };\n\t EmscriptenFileSystem.prototype.supportsProps = function supportsProps () { return true; };\n\t EmscriptenFileSystem.prototype.supportsSynch = function supportsSynch () { return true; };\n\t EmscriptenFileSystem.prototype.renameSync = function renameSync (oldPath, newPath) {\n\t try {\n\t this._FS.rename(oldPath, newPath);\n\t }\n\t catch (e) {\n\t if (e.errno === ErrorCode.ENOENT) {\n\t throw convertError(e, this.existsSync(oldPath) ? newPath : oldPath);\n\t }\n\t else {\n\t throw convertError(e);\n\t }\n\t }\n\t };\n\t EmscriptenFileSystem.prototype.statSync = function statSync (p, isLstat) {\n\t try {\n\t var stats = isLstat ? this._FS.lstat(p) : this._FS.stat(p);\n\t var itemType = this.modeToFileType(stats.mode);\n\t return new Stats(itemType, stats.size, stats.mode, stats.atime, stats.mtime, stats.ctime);\n\t }\n\t catch (e) {\n\t throw convertError(e, p);\n\t }\n\t };\n\t EmscriptenFileSystem.prototype.openSync = function openSync (p, flag, mode) {\n\t try {\n\t var stream = this._FS.open(p, flag.getFlagString(), mode);\n\t if (this._FS.isDir(stream.node.mode)) {\n\t this._FS.close(stream);\n\t throw ApiError.EISDIR(p);\n\t }\n\t return new EmscriptenFile(this, this._FS, p, stream);\n\t }\n\t catch (e) {\n\t throw convertError(e, p);\n\t }\n\t };\n\t EmscriptenFileSystem.prototype.unlinkSync = function unlinkSync (p) {\n\t try {\n\t this._FS.unlink(p);\n\t }\n\t catch (e) {\n\t throw convertError(e, p);\n\t }\n\t };\n\t EmscriptenFileSystem.prototype.rmdirSync = function rmdirSync (p) {\n\t try {\n\t this._FS.rmdir(p);\n\t }\n\t catch (e) {\n\t throw convertError(e, p);\n\t }\n\t };\n\t EmscriptenFileSystem.prototype.mkdirSync = function mkdirSync (p, mode) {\n\t try {\n\t this._FS.mkdir(p, mode);\n\t }\n\t catch (e) {\n\t throw convertError(e, p);\n\t }\n\t };\n\t EmscriptenFileSystem.prototype.readdirSync = function readdirSync (p) {\n\t try {\n\t // Emscripten returns items for '.' and '..'. Node does not.\n\t return this._FS.readdir(p).filter(function (p) { return p !== '.' && p !== '..'; });\n\t }\n\t catch (e) {\n\t throw convertError(e, p);\n\t }\n\t };\n\t EmscriptenFileSystem.prototype.truncateSync = function truncateSync (p, len) {\n\t try {\n\t this._FS.truncate(p, len);\n\t }\n\t catch (e) {\n\t throw convertError(e, p);\n\t }\n\t };\n\t EmscriptenFileSystem.prototype.readFileSync = function readFileSync (p, encoding, flag) {\n\t try {\n\t var data = this._FS.readFile(p, { flags: flag.getFlagString() });\n\t var buff = uint8Array2Buffer(data);\n\t if (encoding) {\n\t return buff.toString(encoding);\n\t }\n\t else {\n\t return buff;\n\t }\n\t }\n\t catch (e) {\n\t throw convertError(e, p);\n\t }\n\t };\n\t EmscriptenFileSystem.prototype.writeFileSync = function writeFileSync (p, data, encoding, flag, mode) {\n\t try {\n\t if (encoding) {\n\t data = new Buffer(data, encoding);\n\t }\n\t var u8 = buffer2Uint8array(data);\n\t this._FS.writeFile(p, u8, { flags: flag.getFlagString(), encoding: 'binary' });\n\t this._FS.chmod(p, mode);\n\t }\n\t catch (e) {\n\t throw convertError(e, p);\n\t }\n\t };\n\t EmscriptenFileSystem.prototype.chmodSync = function chmodSync (p, isLchmod, mode) {\n\t try {\n\t isLchmod ? this._FS.lchmod(p, mode) : this._FS.chmod(p, mode);\n\t }\n\t catch (e) {\n\t throw convertError(e, p);\n\t }\n\t };\n\t EmscriptenFileSystem.prototype.chownSync = function chownSync (p, isLchown, uid, gid) {\n\t try {\n\t isLchown ? this._FS.lchown(p, uid, gid) : this._FS.chown(p, uid, gid);\n\t }\n\t catch (e) {\n\t throw convertError(e, p);\n\t }\n\t };\n\t EmscriptenFileSystem.prototype.symlinkSync = function symlinkSync (srcpath, dstpath, type) {\n\t try {\n\t this._FS.symlink(srcpath, dstpath);\n\t }\n\t catch (e) {\n\t throw convertError(e);\n\t }\n\t };\n\t EmscriptenFileSystem.prototype.readlinkSync = function readlinkSync (p) {\n\t try {\n\t return this._FS.readlink(p);\n\t }\n\t catch (e) {\n\t throw convertError(e, p);\n\t }\n\t };\n\t EmscriptenFileSystem.prototype.utimesSync = function utimesSync (p, atime, mtime) {\n\t try {\n\t this._FS.utime(p, atime.getTime(), mtime.getTime());\n\t }\n\t catch (e) {\n\t throw convertError(e, p);\n\t }\n\t };\n\t EmscriptenFileSystem.prototype.modeToFileType = function modeToFileType (mode) {\n\t if (this._FS.isDir(mode)) {\n\t return FileType.DIRECTORY;\n\t }\n\t else if (this._FS.isFile(mode)) {\n\t return FileType.FILE;\n\t }\n\t else if (this._FS.isLink(mode)) {\n\t return FileType.SYMLINK;\n\t }\n\t else {\n\t throw ApiError.EPERM((\"Invalid mode: \" + mode));\n\t }\n\t };\n\t\n\t return EmscriptenFileSystem;\n\t}(SynchronousFileSystem));\n\t\n\t/**\n\t * The FolderAdapter file system wraps a file system, and scopes all interactions to a subfolder of that file system.\n\t */\n\tvar FolderAdapter = (function (BaseFileSystem$$1) {\n\t function FolderAdapter(folder, wrapped) {\n\t BaseFileSystem$$1.call(this);\n\t this._folder = folder;\n\t this._wrapped = wrapped;\n\t }\n\t\n\t if ( BaseFileSystem$$1 ) FolderAdapter.__proto__ = BaseFileSystem$$1;\n\t FolderAdapter.prototype = Object.create( BaseFileSystem$$1 && BaseFileSystem$$1.prototype );\n\t FolderAdapter.prototype.constructor = FolderAdapter;\n\t /**\n\t * Initialize the file system. Ensures that the wrapped file system\n\t * has the given folder.\n\t */\n\t FolderAdapter.isAvailable = function isAvailable () {\n\t return true;\n\t };\n\t\n\t FolderAdapter.prototype.initialize = function initialize (cb) {\n\t var this$1 = this;\n\t\n\t this._wrapped.exists(this._folder, function (exists) {\n\t if (exists) {\n\t cb();\n\t }\n\t else if (this$1._wrapped.isReadOnly()) {\n\t cb(ApiError.ENOENT(this$1._folder));\n\t }\n\t else {\n\t this$1._wrapped.mkdir(this$1._folder, 0x1ff, cb);\n\t }\n\t });\n\t };\n\t FolderAdapter.prototype.getName = function getName () { return this._wrapped.getName(); };\n\t FolderAdapter.prototype.isReadOnly = function isReadOnly () { return this._wrapped.isReadOnly(); };\n\t FolderAdapter.prototype.supportsProps = function supportsProps () { return this._wrapped.supportsProps(); };\n\t FolderAdapter.prototype.supportsSynch = function supportsSynch () { return this._wrapped.supportsSynch(); };\n\t FolderAdapter.prototype.supportsLinks = function supportsLinks () { return false; };\n\t\n\t return FolderAdapter;\n\t}(BaseFileSystem));\n\t\n\tfunction translateError(folder, e) {\n\t if (e !== null && typeof e === 'object') {\n\t var err = e;\n\t var p = err.path;\n\t if (p) {\n\t p = '/' + path.relative(folder, p);\n\t err.message = err.message.replace(err.path, p);\n\t err.path = p;\n\t }\n\t }\n\t return e;\n\t}\n\tfunction wrapCallback(folder, cb) {\n\t if (typeof cb === 'function') {\n\t return function (err) {\n\t if (arguments.length > 0) {\n\t arguments[0] = translateError(folder, err);\n\t }\n\t cb.apply(null, arguments);\n\t };\n\t }\n\t else {\n\t return cb;\n\t }\n\t}\n\tfunction wrapFunction(name, wrapFirst, wrapSecond) {\n\t if (name.slice(name.length - 4) !== 'Sync') {\n\t // Async function. Translate error in callback.\n\t return function () {\n\t if (arguments.length > 0) {\n\t if (wrapFirst) {\n\t arguments[0] = path.join(this._folder, arguments[0]);\n\t }\n\t if (wrapSecond) {\n\t arguments[1] = path.join(this._folder, arguments[1]);\n\t }\n\t arguments[arguments.length - 1] = wrapCallback(this._folder, arguments[arguments.length - 1]);\n\t }\n\t return this._wrapped[name].apply(this._wrapped, arguments);\n\t };\n\t }\n\t else {\n\t // Sync function. Translate error in catch.\n\t return function () {\n\t try {\n\t if (wrapFirst) {\n\t arguments[0] = path.join(this._folder, arguments[0]);\n\t }\n\t if (wrapSecond) {\n\t arguments[1] = path.join(this._folder, arguments[1]);\n\t }\n\t return this._wrapped[name].apply(this._wrapped, arguments);\n\t }\n\t catch (e) {\n\t throw translateError(this._folder, e);\n\t }\n\t };\n\t }\n\t}\n\t// First argument is a path.\n\t['diskSpace', 'stat', 'statSync', 'open', 'openSync', 'unlink', 'unlinkSync',\n\t 'rmdir', 'rmdirSync', 'mkdir', 'mkdirSync', 'readdir', 'readdirSync', 'exists',\n\t 'existsSync', 'realpath', 'realpathSync', 'truncate', 'truncateSync', 'readFile',\n\t 'readFileSync', 'writeFile', 'writeFileSync', 'appendFile', 'appendFileSync',\n\t 'chmod', 'chmodSync', 'chown', 'chownSync', 'utimes', 'utimesSync', 'readlink',\n\t 'readlinkSync'].forEach(function (name) {\n\t FolderAdapter.prototype[name] = wrapFunction(name, true, false);\n\t});\n\t// First and second arguments are paths.\n\t['rename', 'renameSync', 'link', 'linkSync', 'symlink', 'symlinkSync'].forEach(function (name) {\n\t FolderAdapter.prototype[name] = wrapFunction(name, true, true);\n\t});\n\t\n\tfunction isDirectoryEntry(entry) {\n\t return entry.isDirectory;\n\t}\n\tvar _getFS = global$1.webkitRequestFileSystem || global$1.requestFileSystem || null;\n\tfunction _requestQuota(type, size, success, errorCallback) {\n\t // We cast navigator and window to '' because everything here is\n\t // nonstandard functionality, despite the fact that Chrome has the only\n\t // implementation of the HTML5FS and is likely driving the standardization\n\t // process. Thus, these objects defined off of navigator and window are not\n\t // present in the DefinitelyTyped TypeScript typings for FileSystem.\n\t if (typeof navigator['webkitPersistentStorage'] !== 'undefined') {\n\t switch (type) {\n\t case global$1.PERSISTENT:\n\t navigator.webkitPersistentStorage.requestQuota(size, success, errorCallback);\n\t break;\n\t case global$1.TEMPORARY:\n\t navigator.webkitTemporaryStorage.requestQuota(size, success, errorCallback);\n\t break;\n\t default:\n\t errorCallback(new TypeError((\"Invalid storage type: \" + type)));\n\t break;\n\t }\n\t }\n\t else {\n\t global$1.webkitStorageInfo.requestQuota(type, size, success, errorCallback);\n\t }\n\t}\n\tfunction _toArray(list) {\n\t return Array.prototype.slice.call(list || [], 0);\n\t}\n\t/**\n\t * Converts the given DOMError into an appropriate ApiError.\n\t * Full list of values here:\n\t * https://developer.mozilla.org/en-US/docs/Web/API/DOMError\n\t */\n\tfunction convertError$1(err, p, expectedDir) {\n\t switch (err.name) {\n\t /* The user agent failed to create a file or directory due to the existence of a file or\n\t directory with the same path. */\n\t case \"PathExistsError\":\n\t return ApiError.EEXIST(p);\n\t /* The operation failed because it would cause the application to exceed its storage quota. */\n\t case 'QuotaExceededError':\n\t return ApiError.FileError(ErrorCode.ENOSPC, p);\n\t /* A required file or directory could not be found at the time an operation was processed. */\n\t case 'NotFoundError':\n\t return ApiError.ENOENT(p);\n\t /* This is a security error code to be used in situations not covered by any other error codes.\n\t - A required file was unsafe for access within a Web application\n\t - Too many calls are being made on filesystem resources */\n\t case 'SecurityError':\n\t return ApiError.FileError(ErrorCode.EACCES, p);\n\t /* The modification requested was illegal. Examples of invalid modifications include moving a\n\t directory into its own child, moving a file into its parent directory without changing its name,\n\t or copying a directory to a path occupied by a file. */\n\t case 'InvalidModificationError':\n\t return ApiError.FileError(ErrorCode.EPERM, p);\n\t /* The user has attempted to look up a file or directory, but the Entry found is of the wrong type\n\t [e.g. is a DirectoryEntry when the user requested a FileEntry]. */\n\t case 'TypeMismatchError':\n\t return ApiError.FileError(expectedDir ? ErrorCode.ENOTDIR : ErrorCode.EISDIR, p);\n\t /* A path or URL supplied to the API was malformed. */\n\t case \"EncodingError\":\n\t /* An operation depended on state cached in an interface object, but that state that has changed\n\t since it was read from disk. */\n\t case \"InvalidStateError\":\n\t /* The user attempted to write to a file or directory which could not be modified due to the state\n\t of the underlying filesystem. */\n\t case \"NoModificationAllowedError\":\n\t default:\n\t return ApiError.FileError(ErrorCode.EINVAL, p);\n\t }\n\t}\n\t// A note about getFile and getDirectory options:\n\t// These methods are called at numerous places in this file, and are passed\n\t// some combination of these two options:\n\t// - create: If true, the entry will be created if it doesn't exist.\n\t// If false, an error will be thrown if it doesn't exist.\n\t// - exclusive: If true, only create the entry if it doesn't already exist,\n\t// and throw an error if it does.\n\tvar HTML5FSFile = (function (PreloadFile$$1) {\n\t function HTML5FSFile(fs, entry, path$$1, flag, stat, contents) {\n\t PreloadFile$$1.call(this, fs, path$$1, flag, stat, contents);\n\t this._entry = entry;\n\t }\n\t\n\t if ( PreloadFile$$1 ) HTML5FSFile.__proto__ = PreloadFile$$1;\n\t HTML5FSFile.prototype = Object.create( PreloadFile$$1 && PreloadFile$$1.prototype );\n\t HTML5FSFile.prototype.constructor = HTML5FSFile;\n\t HTML5FSFile.prototype.sync = function sync (cb) {\n\t var this$1 = this;\n\t\n\t if (!this.isDirty()) {\n\t return cb();\n\t }\n\t this._entry.createWriter(function (writer) {\n\t var buffer$$1 = this$1.getBuffer();\n\t var blob = new Blob([buffer2ArrayBuffer(buffer$$1)]);\n\t var length = blob.size;\n\t writer.onwriteend = function (err) {\n\t writer.onwriteend = null;\n\t writer.onerror = null;\n\t writer.truncate(length);\n\t this$1.resetDirty();\n\t cb();\n\t };\n\t writer.onerror = function (err) {\n\t cb(convertError$1(err, this$1.getPath(), false));\n\t };\n\t writer.write(blob);\n\t });\n\t };\n\t HTML5FSFile.prototype.close = function close (cb) {\n\t this.sync(cb);\n\t };\n\t\n\t return HTML5FSFile;\n\t}(PreloadFile));\n\tvar HTML5FS = (function (BaseFileSystem$$1) {\n\t function HTML5FS(size, type) {\n\t if ( size === void 0 ) size = 5;\n\t if ( type === void 0 ) type = global$1.PERSISTENT;\n\t\n\t BaseFileSystem$$1.call(this);\n\t // Convert MB to bytes.\n\t this.size = 1024 * 1024 * size;\n\t this.type = type;\n\t }\n\t\n\t if ( BaseFileSystem$$1 ) HTML5FS.__proto__ = BaseFileSystem$$1;\n\t HTML5FS.prototype = Object.create( BaseFileSystem$$1 && BaseFileSystem$$1.prototype );\n\t HTML5FS.prototype.constructor = HTML5FS;\n\t HTML5FS.isAvailable = function isAvailable () {\n\t return !!_getFS;\n\t };\n\t\n\t HTML5FS.prototype.getName = function getName () {\n\t return 'HTML5 FileSystem';\n\t };\n\t HTML5FS.prototype.isReadOnly = function isReadOnly () {\n\t return false;\n\t };\n\t HTML5FS.prototype.supportsSymlinks = function supportsSymlinks () {\n\t return false;\n\t };\n\t HTML5FS.prototype.supportsProps = function supportsProps () {\n\t return false;\n\t };\n\t HTML5FS.prototype.supportsSynch = function supportsSynch () {\n\t return false;\n\t };\n\t /**\n\t * Nonstandard\n\t * Requests a storage quota from the browser to back this FS.\n\t */\n\t HTML5FS.prototype.allocate = function allocate (cb) {\n\t var this$1 = this;\n\t if ( cb === void 0 ) cb = function () { };\n\t\n\t var success = function (fs) {\n\t this$1.fs = fs;\n\t cb();\n\t };\n\t var error = function (err) {\n\t cb(convertError$1(err, \"/\", true));\n\t };\n\t if (this.type === global$1.PERSISTENT) {\n\t _requestQuota(this.type, this.size, function (granted) {\n\t _getFS(this$1.type, granted, success, error);\n\t }, error);\n\t }\n\t else {\n\t _getFS(this.type, this.size, success, error);\n\t }\n\t };\n\t /**\n\t * Nonstandard\n\t * Deletes everything in the FS. Used for testing.\n\t * Karma clears the storage after you quit it but not between runs of the test\n\t * suite, and the tests expect an empty FS every time.\n\t */\n\t HTML5FS.prototype.empty = function empty (mainCb) {\n\t // Get a list of all entries in the root directory to delete them\n\t this._readdir('/', function (err, entries) {\n\t if (err) {\n\t console.error('Failed to empty FS');\n\t mainCb(err);\n\t }\n\t else {\n\t // Called when every entry has been operated on\n\t var finished = function (er) {\n\t if (err) {\n\t console.error(\"Failed to empty FS\");\n\t mainCb(err);\n\t }\n\t else {\n\t mainCb();\n\t }\n\t };\n\t // Removes files and recursively removes directories\n\t var deleteEntry = function (entry, cb) {\n\t var succ = function () {\n\t cb();\n\t };\n\t var error = function (err) {\n\t cb(convertError$1(err, entry.fullPath, !entry.isDirectory));\n\t };\n\t if (isDirectoryEntry(entry)) {\n\t entry.removeRecursively(succ, error);\n\t }\n\t else {\n\t entry.remove(succ, error);\n\t }\n\t };\n\t // Loop through the entries and remove them, then call the callback\n\t // when they're all finished.\n\t eachLimit(entries, deleteEntry, finished);\n\t }\n\t });\n\t };\n\t HTML5FS.prototype.rename = function rename (oldPath, newPath, cb) {\n\t var this$1 = this;\n\t\n\t var semaphore = 2;\n\t var successCount = 0;\n\t var root = this.fs.root;\n\t var currentPath = oldPath;\n\t var error = function (err) {\n\t if (--semaphore <= 0) {\n\t cb(convertError$1(err, currentPath, false));\n\t }\n\t };\n\t var success = function (file) {\n\t if (++successCount === 2) {\n\t return cb(new ApiError(ErrorCode.EINVAL, \"Something was identified as both a file and a directory. This should never happen.\"));\n\t }\n\t // SPECIAL CASE: If newPath === oldPath, and the path exists, then\n\t // this operation trivially succeeds.\n\t if (oldPath === newPath) {\n\t return cb();\n\t }\n\t // Get the new parent directory.\n\t currentPath = path.dirname(newPath);\n\t root.getDirectory(currentPath, {}, function (parentDir) {\n\t currentPath = path.basename(newPath);\n\t file.moveTo(parentDir, currentPath, function (entry) { cb(); }, function (err) {\n\t // SPECIAL CASE: If oldPath is a directory, and newPath is a\n\t // file, rename should delete the file and perform the move.\n\t if (file.isDirectory) {\n\t currentPath = newPath;\n\t // Unlink only works on files. Try to delete newPath.\n\t this$1.unlink(newPath, function (e) {\n\t if (e) {\n\t // newPath is probably a directory.\n\t error(err);\n\t }\n\t else {\n\t // Recur, now that newPath doesn't exist.\n\t this$1.rename(oldPath, newPath, cb);\n\t }\n\t });\n\t }\n\t else {\n\t error(err);\n\t }\n\t });\n\t }, error);\n\t };\n\t // We don't know if oldPath is a *file* or a *directory*, and there's no\n\t // way to stat items. So launch both requests, see which one succeeds.\n\t root.getFile(oldPath, {}, success, error);\n\t root.getDirectory(oldPath, {}, success, error);\n\t };\n\t HTML5FS.prototype.stat = function stat (path$$1, isLstat, cb) {\n\t var this$1 = this;\n\t\n\t // Throw an error if the entry doesn't exist, because then there's nothing\n\t // to stat.\n\t var opts = {\n\t create: false\n\t };\n\t // Called when the path has been successfully loaded as a file.\n\t var loadAsFile = function (entry) {\n\t var fileFromEntry = function (file) {\n\t var stat = new Stats(FileType.FILE, file.size);\n\t cb(null, stat);\n\t };\n\t entry.file(fileFromEntry, failedToLoad);\n\t };\n\t // Called when the path has been successfully loaded as a directory.\n\t var loadAsDir = function (dir$$1) {\n\t // Directory entry size can't be determined from the HTML5 FS API, and is\n\t // implementation-dependant anyway, so a dummy value is used.\n\t var size = 4096;\n\t var stat = new Stats(FileType.DIRECTORY, size);\n\t cb(null, stat);\n\t };\n\t // Called when the path couldn't be opened as a directory or a file.\n\t var failedToLoad = function (err) {\n\t cb(convertError$1(err, path$$1, false /* Unknown / irrelevant */));\n\t };\n\t // Called when the path couldn't be opened as a file, but might still be a\n\t // directory.\n\t var failedToLoadAsFile = function () {\n\t this$1.fs.root.getDirectory(path$$1, opts, loadAsDir, failedToLoad);\n\t };\n\t // No method currently exists to determine whether a path refers to a\n\t // directory or a file, so this implementation tries both and uses the first\n\t // one that succeeds.\n\t this.fs.root.getFile(path$$1, opts, loadAsFile, failedToLoadAsFile);\n\t };\n\t HTML5FS.prototype.open = function open (p, flags, mode, cb) {\n\t var this$1 = this;\n\t\n\t // XXX: err is a DOMError\n\t var error = function (err) {\n\t if (err.name === 'InvalidModificationError' && flags.isExclusive()) {\n\t cb(ApiError.EEXIST(p));\n\t }\n\t else {\n\t cb(convertError$1(err, p, false));\n\t }\n\t };\n\t this.fs.root.getFile(p, {\n\t create: flags.pathNotExistsAction() === ActionType.CREATE_FILE,\n\t exclusive: flags.isExclusive()\n\t }, function (entry) {\n\t // Try to fetch corresponding file.\n\t entry.file(function (file) {\n\t var reader = new FileReader();\n\t reader.onloadend = function (event) {\n\t var bfsFile = this$1._makeFile(p, entry, flags, file, reader.result);\n\t cb(null, bfsFile);\n\t };\n\t reader.onerror = function (ev) {\n\t error(reader.error);\n\t };\n\t reader.readAsArrayBuffer(file);\n\t }, error);\n\t }, error);\n\t };\n\t HTML5FS.prototype.unlink = function unlink (path$$1, cb) {\n\t this._remove(path$$1, cb, true);\n\t };\n\t HTML5FS.prototype.rmdir = function rmdir (path$$1, cb) {\n\t var this$1 = this;\n\t\n\t // Check if directory is non-empty, first.\n\t this.readdir(path$$1, function (e, files) {\n\t if (e) {\n\t cb(e);\n\t }\n\t else if (files.length > 0) {\n\t cb(ApiError.ENOTEMPTY(path$$1));\n\t }\n\t else {\n\t this$1._remove(path$$1, cb, false);\n\t }\n\t });\n\t };\n\t HTML5FS.prototype.mkdir = function mkdir (path$$1, mode, cb) {\n\t // Create the directory, but throw an error if it already exists, as per\n\t // mkdir(1)\n\t var opts = {\n\t create: true,\n\t exclusive: true\n\t };\n\t var success = function (dir$$1) {\n\t cb();\n\t };\n\t var error = function (err) {\n\t cb(convertError$1(err, path$$1, true));\n\t };\n\t this.fs.root.getDirectory(path$$1, opts, success, error);\n\t };\n\t /**\n\t * Map _readdir's list of `FileEntry`s to their names and return that.\n\t */\n\t HTML5FS.prototype.readdir = function readdir (path$$1, cb) {\n\t this._readdir(path$$1, function (e, entries) {\n\t if (e) {\n\t return cb(e);\n\t }\n\t var rv = [];\n\t for (var i = 0; i < entries.length; i++) {\n\t rv.push(entries[i].name);\n\t }\n\t cb(null, rv);\n\t });\n\t };\n\t /**\n\t * Returns a BrowserFS object representing a File.\n\t */\n\t HTML5FS.prototype._makeFile = function _makeFile (path$$1, entry, flag, stat, data) {\n\t if ( data === void 0 ) data = new ArrayBuffer(0);\n\t\n\t var stats = new Stats(FileType.FILE, stat.size);\n\t var buffer$$1 = arrayBuffer2Buffer(data);\n\t return new HTML5FSFile(this, entry, path$$1, flag, stats, buffer$$1);\n\t };\n\t /**\n\t * Returns an array of `FileEntry`s. Used internally by empty and readdir.\n\t */\n\t HTML5FS.prototype._readdir = function _readdir (path$$1, cb) {\n\t var error = function (err) {\n\t cb(convertError$1(err, path$$1, true));\n\t };\n\t // Grab the requested directory.\n\t this.fs.root.getDirectory(path$$1, { create: false }, function (dirEntry) {\n\t var reader = dirEntry.createReader();\n\t var entries = [];\n\t // Call the reader.readEntries() until no more results are returned.\n\t var readEntries = function () {\n\t reader.readEntries((function (results) {\n\t if (results.length) {\n\t entries = entries.concat(_toArray(results));\n\t readEntries();\n\t }\n\t else {\n\t cb(null, entries);\n\t }\n\t }), error);\n\t };\n\t readEntries();\n\t }, error);\n\t };\n\t /**\n\t * Delete a file or directory from the file system\n\t * isFile should reflect which call was made to remove the it (`unlink` or\n\t * `rmdir`). If this doesn't match what's actually at `path`, an error will be\n\t * returned\n\t */\n\t HTML5FS.prototype._remove = function _remove (path$$1, cb, isFile) {\n\t var success = function (entry) {\n\t var succ = function () {\n\t cb();\n\t };\n\t var err = function (err) {\n\t cb(convertError$1(err, path$$1, !isFile));\n\t };\n\t entry.remove(succ, err);\n\t };\n\t var error = function (err) {\n\t cb(convertError$1(err, path$$1, !isFile));\n\t };\n\t // Deleting the entry, so don't create it\n\t var opts = {\n\t create: false\n\t };\n\t if (isFile) {\n\t this.fs.root.getFile(path$$1, opts, success, error);\n\t }\n\t else {\n\t this.fs.root.getDirectory(path$$1, opts, success, error);\n\t }\n\t };\n\t\n\t return HTML5FS;\n\t}(BaseFileSystem));\n\t\n\t/**\n\t * Generic inode definition that can easily be serialized.\n\t */\n\tvar Inode = function Inode(id, size, mode, atime, mtime, ctime) {\n\t this.id = id;\n\t this.size = size;\n\t this.mode = mode;\n\t this.atime = atime;\n\t this.mtime = mtime;\n\t this.ctime = ctime;\n\t};\n\t/**\n\t * Converts the buffer into an Inode.\n\t */\n\tInode.fromBuffer = function fromBuffer (buffer$$1) {\n\t if (buffer$$1 === undefined) {\n\t throw new Error(\"NO\");\n\t }\n\t return new Inode(buffer$$1.toString('ascii', 30), buffer$$1.readUInt32LE(0), buffer$$1.readUInt16LE(4), buffer$$1.readDoubleLE(6), buffer$$1.readDoubleLE(14), buffer$$1.readDoubleLE(22));\n\t};\n\t/**\n\t * Handy function that converts the Inode to a Node Stats object.\n\t */\n\tInode.prototype.toStats = function toStats () {\n\t return new Stats((this.mode & 0xF000) === FileType.DIRECTORY ? FileType.DIRECTORY : FileType.FILE, this.size, this.mode, new Date(this.atime), new Date(this.mtime), new Date(this.ctime));\n\t};\n\t/**\n\t * Get the size of this Inode, in bytes.\n\t */\n\tInode.prototype.getSize = function getSize () {\n\t // ASSUMPTION: ID is ASCII (1 byte per char).\n\t return 30 + this.id.length;\n\t};\n\t/**\n\t * Writes the inode into the start of the buffer.\n\t */\n\tInode.prototype.toBuffer = function toBuffer (buff) {\n\t if ( buff === void 0 ) buff = new Buffer(this.getSize());\n\t\n\t buff.writeUInt32LE(this.size, 0);\n\t buff.writeUInt16LE(this.mode, 4);\n\t buff.writeDoubleLE(this.atime, 6);\n\t buff.writeDoubleLE(this.mtime, 14);\n\t buff.writeDoubleLE(this.ctime, 22);\n\t buff.write(this.id, 30, this.id.length, 'ascii');\n\t return buff;\n\t};\n\t/**\n\t * Updates the Inode using information from the stats object. Used by file\n\t * systems at sync time, e.g.:\n\t * - Program opens file and gets a File object.\n\t * - Program mutates file. File object is responsible for maintaining\n\t * metadata changes locally -- typically in a Stats object.\n\t * - Program closes file. File object's metadata changes are synced with the\n\t * file system.\n\t * @return True if any changes have occurred.\n\t */\n\tInode.prototype.update = function update (stats) {\n\t var hasChanged = false;\n\t if (this.size !== stats.size) {\n\t this.size = stats.size;\n\t hasChanged = true;\n\t }\n\t if (this.mode !== stats.mode) {\n\t this.mode = stats.mode;\n\t hasChanged = true;\n\t }\n\t var atimeMs = stats.atime.getTime();\n\t if (this.atime !== atimeMs) {\n\t this.atime = atimeMs;\n\t hasChanged = true;\n\t }\n\t var mtimeMs = stats.mtime.getTime();\n\t if (this.mtime !== mtimeMs) {\n\t this.mtime = mtimeMs;\n\t hasChanged = true;\n\t }\n\t var ctimeMs = stats.ctime.getTime();\n\t if (this.ctime !== ctimeMs) {\n\t this.ctime = ctimeMs;\n\t hasChanged = true;\n\t }\n\t return hasChanged;\n\t};\n\t// XXX: Copied from Stats. Should reconcile these two into something more\n\t// compact.\n\t/**\n\t * @return [Boolean] True if this item is a file.\n\t */\n\tInode.prototype.isFile = function isFile () {\n\t return (this.mode & 0xF000) === FileType.FILE;\n\t};\n\t/**\n\t * @return [Boolean] True if this item is a directory.\n\t */\n\tInode.prototype.isDirectory = function isDirectory () {\n\t return (this.mode & 0xF000) === FileType.DIRECTORY;\n\t};\n\t\n\tvar ROOT_NODE_ID = \"/\";\n\t/**\n\t * Generates a random ID.\n\t */\n\tfunction GenerateRandomID() {\n\t // From http://stackoverflow.com/questions/105034/how-to-create-a-guid-uuid-in-javascript\n\t return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function (c) {\n\t var r = Math.random() * 16 | 0;\n\t var v = c === 'x' ? r : (r & 0x3 | 0x8);\n\t return v.toString(16);\n\t });\n\t}\n\t/**\n\t * Helper function. Checks if 'e' is defined. If so, it triggers the callback\n\t * with 'e' and returns false. Otherwise, returns true.\n\t */\n\tfunction noError(e, cb) {\n\t if (e) {\n\t cb(e);\n\t return false;\n\t }\n\t return true;\n\t}\n\t/**\n\t * Helper function. Checks if 'e' is defined. If so, it aborts the transaction,\n\t * triggers the callback with 'e', and returns false. Otherwise, returns true.\n\t */\n\tfunction noErrorTx(e, tx, cb) {\n\t if (e) {\n\t tx.abort(function () {\n\t cb(e);\n\t });\n\t return false;\n\t }\n\t return true;\n\t}\n\t/**\n\t * A simple RW transaction for simple synchronous key-value stores.\n\t */\n\tvar SimpleSyncRWTransaction = function SimpleSyncRWTransaction(store) {\n\t this.store = store;\n\t /**\n\t * Stores data in the keys we modify prior to modifying them.\n\t * Allows us to roll back commits.\n\t */\n\t this.originalData = {};\n\t /**\n\t * List of keys modified in this transaction, if any.\n\t */\n\t this.modifiedKeys = [];\n\t};\n\tSimpleSyncRWTransaction.prototype.get = function get (key) {\n\t var val = this.store.get(key);\n\t this.stashOldValue(key, val);\n\t return val;\n\t};\n\tSimpleSyncRWTransaction.prototype.put = function put (key, data, overwrite) {\n\t this.markModified(key);\n\t return this.store.put(key, data, overwrite);\n\t};\n\tSimpleSyncRWTransaction.prototype.del = function del (key) {\n\t this.markModified(key);\n\t this.store.del(key);\n\t};\n\tSimpleSyncRWTransaction.prototype.commit = function commit () { };\n\tSimpleSyncRWTransaction.prototype.abort = function abort () {\n\t var this$1 = this;\n\t\n\t // Rollback old values.\n\t for (var i = 0; i < this.modifiedKeys.length; i++) {\n\t var key = this$1.modifiedKeys[i];\n\t var value = this$1.originalData[key];\n\t if (!value) {\n\t // Key didn't exist.\n\t this$1.store.del(key);\n\t }\n\t else {\n\t // Key existed. Store old value.\n\t this$1.store.put(key, value, true);\n\t }\n\t }\n\t};\n\t/**\n\t * Stashes given key value pair into `originalData` if it doesn't already\n\t * exist. Allows us to stash values the program is requesting anyway to\n\t * prevent needless `get` requests if the program modifies the data later\n\t * on during the transaction.\n\t */\n\tSimpleSyncRWTransaction.prototype.stashOldValue = function stashOldValue (key, value) {\n\t // Keep only the earliest value in the transaction.\n\t if (!this.originalData.hasOwnProperty(key)) {\n\t this.originalData[key] = value;\n\t }\n\t};\n\t/**\n\t * Marks the given key as modified, and stashes its value if it has not been\n\t * stashed already.\n\t */\n\tSimpleSyncRWTransaction.prototype.markModified = function markModified (key) {\n\t if (this.modifiedKeys.indexOf(key) === -1) {\n\t this.modifiedKeys.push(key);\n\t if (!this.originalData.hasOwnProperty(key)) {\n\t this.originalData[key] = this.store.get(key);\n\t }\n\t }\n\t};\n\tvar SyncKeyValueFile = (function (PreloadFile$$1) {\n\t function SyncKeyValueFile(_fs, _path, _flag, _stat, contents) {\n\t PreloadFile$$1.call(this, _fs, _path, _flag, _stat, contents);\n\t }\n\t\n\t if ( PreloadFile$$1 ) SyncKeyValueFile.__proto__ = PreloadFile$$1;\n\t SyncKeyValueFile.prototype = Object.create( PreloadFile$$1 && PreloadFile$$1.prototype );\n\t SyncKeyValueFile.prototype.constructor = SyncKeyValueFile;\n\t SyncKeyValueFile.prototype.syncSync = function syncSync () {\n\t if (this.isDirty()) {\n\t this._fs._syncSync(this.getPath(), this.getBuffer(), this.getStats());\n\t this.resetDirty();\n\t }\n\t };\n\t SyncKeyValueFile.prototype.closeSync = function closeSync () {\n\t this.syncSync();\n\t };\n\t\n\t return SyncKeyValueFile;\n\t}(PreloadFile));\n\t/**\n\t * A \"Synchronous key-value file system\". Stores data to/retrieves data from an\n\t * underlying key-value store.\n\t *\n\t * We use a unique ID for each node in the file system. The root node has a\n\t * fixed ID.\n\t * @todo Introduce Node ID caching.\n\t * @todo Check modes.\n\t */\n\tvar SyncKeyValueFileSystem = (function (SynchronousFileSystem$$1) {\n\t function SyncKeyValueFileSystem(options) {\n\t SynchronousFileSystem$$1.call(this);\n\t this.store = options.store;\n\t // INVARIANT: Ensure that the root exists.\n\t this.makeRootDirectory();\n\t }\n\t\n\t if ( SynchronousFileSystem$$1 ) SyncKeyValueFileSystem.__proto__ = SynchronousFileSystem$$1;\n\t SyncKeyValueFileSystem.prototype = Object.create( SynchronousFileSystem$$1 && SynchronousFileSystem$$1.prototype );\n\t SyncKeyValueFileSystem.prototype.constructor = SyncKeyValueFileSystem;\n\t SyncKeyValueFileSystem.isAvailable = function isAvailable () { return true; };\n\t\n\t SyncKeyValueFileSystem.prototype.getName = function getName () { return this.store.name(); };\n\t SyncKeyValueFileSystem.prototype.isReadOnly = function isReadOnly () { return false; };\n\t SyncKeyValueFileSystem.prototype.supportsSymlinks = function supportsSymlinks () { return false; };\n\t SyncKeyValueFileSystem.prototype.supportsProps = function supportsProps () { return false; };\n\t SyncKeyValueFileSystem.prototype.supportsSynch = function supportsSynch () { return true; };\n\t /**\n\t * Delete all contents stored in the file system.\n\t */\n\t SyncKeyValueFileSystem.prototype.empty = function empty () {\n\t this.store.clear();\n\t // INVARIANT: Root always exists.\n\t this.makeRootDirectory();\n\t };\n\t SyncKeyValueFileSystem.prototype.renameSync = function renameSync (oldPath, newPath) {\n\t var tx = this.store.beginTransaction('readwrite'), oldParent = path.dirname(oldPath), oldName = path.basename(oldPath), newParent = path.dirname(newPath), newName = path.basename(newPath), \n\t // Remove oldPath from parent's directory listing.\n\t oldDirNode = this.findINode(tx, oldParent), oldDirList = this.getDirListing(tx, oldParent, oldDirNode);\n\t if (!oldDirList[oldName]) {\n\t throw ApiError.ENOENT(oldPath);\n\t }\n\t var nodeId = oldDirList[oldName];\n\t delete oldDirList[oldName];\n\t // Invariant: Can't move a folder inside itself.\n\t // This funny little hack ensures that the check passes only if oldPath\n\t // is a subpath of newParent. We append '/' to avoid matching folders that\n\t // are a substring of the bottom-most folder in the path.\n\t if ((newParent + '/').indexOf(oldPath + '/') === 0) {\n\t throw new ApiError(ErrorCode.EBUSY, oldParent);\n\t }\n\t // Add newPath to parent's directory listing.\n\t var newDirNode, newDirList;\n\t if (newParent === oldParent) {\n\t // Prevent us from re-grabbing the same directory listing, which still\n\t // contains oldName.\n\t newDirNode = oldDirNode;\n\t newDirList = oldDirList;\n\t }\n\t else {\n\t newDirNode = this.findINode(tx, newParent);\n\t newDirList = this.getDirListing(tx, newParent, newDirNode);\n\t }\n\t if (newDirList[newName]) {\n\t // If it's a file, delete it.\n\t var newNameNode = this.getINode(tx, newPath, newDirList[newName]);\n\t if (newNameNode.isFile()) {\n\t try {\n\t tx.del(newNameNode.id);\n\t tx.del(newDirList[newName]);\n\t }\n\t catch (e) {\n\t tx.abort();\n\t throw e;\n\t }\n\t }\n\t else {\n\t // If it's a directory, throw a permissions error.\n\t throw ApiError.EPERM(newPath);\n\t }\n\t }\n\t newDirList[newName] = nodeId;\n\t // Commit the two changed directory listings.\n\t try {\n\t tx.put(oldDirNode.id, new Buffer(JSON.stringify(oldDirList)), true);\n\t tx.put(newDirNode.id, new Buffer(JSON.stringify(newDirList)), true);\n\t }\n\t catch (e) {\n\t tx.abort();\n\t throw e;\n\t }\n\t tx.commit();\n\t };\n\t SyncKeyValueFileSystem.prototype.statSync = function statSync (p, isLstat) {\n\t // Get the inode to the item, convert it into a Stats object.\n\t return this.findINode(this.store.beginTransaction('readonly'), p).toStats();\n\t };\n\t SyncKeyValueFileSystem.prototype.createFileSync = function createFileSync (p, flag, mode) {\n\t var tx = this.store.beginTransaction('readwrite'), data = new Buffer(0), newFile = this.commitNewFile(tx, p, FileType.FILE, mode, data);\n\t // Open the file.\n\t return new SyncKeyValueFile(this, p, flag, newFile.toStats(), data);\n\t };\n\t SyncKeyValueFileSystem.prototype.openFileSync = function openFileSync (p, flag) {\n\t var tx = this.store.beginTransaction('readonly'), node = this.findINode(tx, p), data = tx.get(node.id);\n\t if (data === undefined) {\n\t throw ApiError.ENOENT(p);\n\t }\n\t return new SyncKeyValueFile(this, p, flag, node.toStats(), data);\n\t };\n\t SyncKeyValueFileSystem.prototype.unlinkSync = function unlinkSync (p) {\n\t this.removeEntry(p, false);\n\t };\n\t SyncKeyValueFileSystem.prototype.rmdirSync = function rmdirSync (p) {\n\t // Check first if directory is empty.\n\t if (this.readdirSync(p).length > 0) {\n\t throw ApiError.ENOTEMPTY(p);\n\t }\n\t else {\n\t this.removeEntry(p, true);\n\t }\n\t };\n\t SyncKeyValueFileSystem.prototype.mkdirSync = function mkdirSync (p, mode) {\n\t var tx = this.store.beginTransaction('readwrite'), data = new Buffer('{}');\n\t this.commitNewFile(tx, p, FileType.DIRECTORY, mode, data);\n\t };\n\t SyncKeyValueFileSystem.prototype.readdirSync = function readdirSync (p) {\n\t var tx = this.store.beginTransaction('readonly');\n\t return Object.keys(this.getDirListing(tx, p, this.findINode(tx, p)));\n\t };\n\t SyncKeyValueFileSystem.prototype._syncSync = function _syncSync (p, data, stats) {\n\t // @todo Ensure mtime updates properly, and use that to determine if a data\n\t // update is required.\n\t var tx = this.store.beginTransaction('readwrite'), \n\t // We use the _findInode helper because we actually need the INode id.\n\t fileInodeId = this._findINode(tx, path.dirname(p), path.basename(p)), fileInode = this.getINode(tx, p, fileInodeId), inodeChanged = fileInode.update(stats);\n\t try {\n\t // Sync data.\n\t tx.put(fileInode.id, data, true);\n\t // Sync metadata.\n\t if (inodeChanged) {\n\t tx.put(fileInodeId, fileInode.toBuffer(), true);\n\t }\n\t }\n\t catch (e) {\n\t tx.abort();\n\t throw e;\n\t }\n\t tx.commit();\n\t };\n\t /**\n\t * Checks if the root directory exists. Creates it if it doesn't.\n\t */\n\t SyncKeyValueFileSystem.prototype.makeRootDirectory = function makeRootDirectory () {\n\t var tx = this.store.beginTransaction('readwrite');\n\t if (tx.get(ROOT_NODE_ID) === undefined) {\n\t // Create new inode.\n\t var currTime = (new Date()).getTime(), \n\t // Mode 0666\n\t dirInode = new Inode(GenerateRandomID(), 4096, 511 | FileType.DIRECTORY, currTime, currTime, currTime);\n\t // If the root doesn't exist, the first random ID shouldn't exist,\n\t // either.\n\t tx.put(dirInode.id, new Buffer(\"{}\"), false);\n\t tx.put(ROOT_NODE_ID, dirInode.toBuffer(), false);\n\t tx.commit();\n\t }\n\t };\n\t /**\n\t * Helper function for findINode.\n\t * @param parent The parent directory of the file we are attempting to find.\n\t * @param filename The filename of the inode we are attempting to find, minus\n\t * the parent.\n\t * @return string The ID of the file's inode in the file system.\n\t */\n\t SyncKeyValueFileSystem.prototype._findINode = function _findINode (tx, parent, filename) {\n\t var this$1 = this;\n\t\n\t var readDirectory = function (inode) {\n\t // Get the root's directory listing.\n\t var dirList = this$1.getDirListing(tx, parent, inode);\n\t // Get the file's ID.\n\t if (dirList[filename]) {\n\t return dirList[filename];\n\t }\n\t else {\n\t throw ApiError.ENOENT(path.resolve(parent, filename));\n\t }\n\t };\n\t if (parent === '/') {\n\t if (filename === '') {\n\t // BASE CASE #1: Return the root's ID.\n\t return ROOT_NODE_ID;\n\t }\n\t else {\n\t // BASE CASE #2: Find the item in the root ndoe.\n\t return readDirectory(this.getINode(tx, parent, ROOT_NODE_ID));\n\t }\n\t }\n\t else {\n\t return readDirectory(this.getINode(tx, parent + path.sep + filename, this._findINode(tx, path.dirname(parent), path.basename(parent))));\n\t }\n\t };\n\t /**\n\t * Finds the Inode of the given path.\n\t * @param p The path to look up.\n\t * @return The Inode of the path p.\n\t * @todo memoize/cache\n\t */\n\t SyncKeyValueFileSystem.prototype.findINode = function findINode (tx, p) {\n\t return this.getINode(tx, p, this._findINode(tx, path.dirname(p), path.basename(p)));\n\t };\n\t /**\n\t * Given the ID of a node, retrieves the corresponding Inode.\n\t * @param tx The transaction to use.\n\t * @param p The corresponding path to the file (used for error messages).\n\t * @param id The ID to look up.\n\t */\n\t SyncKeyValueFileSystem.prototype.getINode = function getINode (tx, p, id) {\n\t var inode = tx.get(id);\n\t if (inode === undefined) {\n\t throw ApiError.ENOENT(p);\n\t }\n\t return Inode.fromBuffer(inode);\n\t };\n\t /**\n\t * Given the Inode of a directory, retrieves the corresponding directory\n\t * listing.\n\t */\n\t SyncKeyValueFileSystem.prototype.getDirListing = function getDirListing (tx, p, inode) {\n\t if (!inode.isDirectory()) {\n\t throw ApiError.ENOTDIR(p);\n\t }\n\t var data = tx.get(inode.id);\n\t if (data === undefined) {\n\t throw ApiError.ENOENT(p);\n\t }\n\t return JSON.parse(data.toString());\n\t };\n\t /**\n\t * Creates a new node under a random ID. Retries 5 times before giving up in\n\t * the exceedingly unlikely chance that we try to reuse a random GUID.\n\t * @return The GUID that the data was stored under.\n\t */\n\t SyncKeyValueFileSystem.prototype.addNewNode = function addNewNode (tx, data) {\n\t var retries = 0;\n\t var currId;\n\t while (retries < 5) {\n\t try {\n\t currId = GenerateRandomID();\n\t tx.put(currId, data, false);\n\t return currId;\n\t }\n\t catch (e) {\n\t }\n\t }\n\t throw new ApiError(ErrorCode.EIO, 'Unable to commit data to key-value store.');\n\t };\n\t /**\n\t * Commits a new file (well, a FILE or a DIRECTORY) to the file system with\n\t * the given mode.\n\t * Note: This will commit the transaction.\n\t * @param p The path to the new file.\n\t * @param type The type of the new file.\n\t * @param mode The mode to create the new file with.\n\t * @param data The data to store at the file's data node.\n\t * @return The Inode for the new file.\n\t */\n\t SyncKeyValueFileSystem.prototype.commitNewFile = function commitNewFile (tx, p, type, mode, data) {\n\t var parentDir = path.dirname(p), fname = path.basename(p), parentNode = this.findINode(tx, parentDir), dirListing = this.getDirListing(tx, parentDir, parentNode), currTime = (new Date()).getTime();\n\t // Invariant: The root always exists.\n\t // If we don't check this prior to taking steps below, we will create a\n\t // file with name '' in root should p == '/'.\n\t if (p === '/') {\n\t throw ApiError.EEXIST(p);\n\t }\n\t // Check if file already exists.\n\t if (dirListing[fname]) {\n\t throw ApiError.EEXIST(p);\n\t }\n\t var fileNode;\n\t try {\n\t // Commit data.\n\t var dataId = this.addNewNode(tx, data);\n\t fileNode = new Inode(dataId, data.length, mode | type, currTime, currTime, currTime);\n\t // Commit file node.\n\t var fileNodeId = this.addNewNode(tx, fileNode.toBuffer());\n\t // Update and commit parent directory listing.\n\t dirListing[fname] = fileNodeId;\n\t tx.put(parentNode.id, new Buffer(JSON.stringify(dirListing)), true);\n\t }\n\t catch (e) {\n\t tx.abort();\n\t throw e;\n\t }\n\t tx.commit();\n\t return fileNode;\n\t };\n\t /**\n\t * Remove all traces of the given path from the file system.\n\t * @param p The path to remove from the file system.\n\t * @param isDir Does the path belong to a directory, or a file?\n\t * @todo Update mtime.\n\t */\n\t SyncKeyValueFileSystem.prototype.removeEntry = function removeEntry (p, isDir) {\n\t var tx = this.store.beginTransaction('readwrite'), parent = path.dirname(p), parentNode = this.findINode(tx, parent), parentListing = this.getDirListing(tx, parent, parentNode), fileName = path.basename(p);\n\t if (!parentListing[fileName]) {\n\t throw ApiError.ENOENT(p);\n\t }\n\t // Remove from directory listing of parent.\n\t var fileNodeId = parentListing[fileName];\n\t delete parentListing[fileName];\n\t // Get file inode.\n\t var fileNode = this.getINode(tx, p, fileNodeId);\n\t if (!isDir && fileNode.isDirectory()) {\n\t throw ApiError.EISDIR(p);\n\t }\n\t else if (isDir && !fileNode.isDirectory()) {\n\t throw ApiError.ENOTDIR(p);\n\t }\n\t try {\n\t // Delete data.\n\t tx.del(fileNode.id);\n\t // Delete node.\n\t tx.del(fileNodeId);\n\t // Update directory listing.\n\t tx.put(parentNode.id, new Buffer(JSON.stringify(parentListing)), true);\n\t }\n\t catch (e) {\n\t tx.abort();\n\t throw e;\n\t }\n\t // Success.\n\t tx.commit();\n\t };\n\t\n\t return SyncKeyValueFileSystem;\n\t}(SynchronousFileSystem));\n\tvar AsyncKeyValueFile = (function (PreloadFile$$1) {\n\t function AsyncKeyValueFile(_fs, _path, _flag, _stat, contents) {\n\t PreloadFile$$1.call(this, _fs, _path, _flag, _stat, contents);\n\t }\n\t\n\t if ( PreloadFile$$1 ) AsyncKeyValueFile.__proto__ = PreloadFile$$1;\n\t AsyncKeyValueFile.prototype = Object.create( PreloadFile$$1 && PreloadFile$$1.prototype );\n\t AsyncKeyValueFile.prototype.constructor = AsyncKeyValueFile;\n\t AsyncKeyValueFile.prototype.sync = function sync (cb) {\n\t var this$1 = this;\n\t\n\t if (this.isDirty()) {\n\t this._fs._sync(this.getPath(), this.getBuffer(), this.getStats(), function (e) {\n\t if (!e) {\n\t this$1.resetDirty();\n\t }\n\t cb(e);\n\t });\n\t }\n\t else {\n\t cb();\n\t }\n\t };\n\t AsyncKeyValueFile.prototype.close = function close (cb) {\n\t this.sync(cb);\n\t };\n\t\n\t return AsyncKeyValueFile;\n\t}(PreloadFile));\n\t/**\n\t * An \"Asynchronous key-value file system\". Stores data to/retrieves data from\n\t * an underlying asynchronous key-value store.\n\t */\n\tvar AsyncKeyValueFileSystem = (function (BaseFileSystem$$1) {\n\t function AsyncKeyValueFileSystem () {\n\t BaseFileSystem$$1.apply(this, arguments);\n\t }\n\t\n\t if ( BaseFileSystem$$1 ) AsyncKeyValueFileSystem.__proto__ = BaseFileSystem$$1;\n\t AsyncKeyValueFileSystem.prototype = Object.create( BaseFileSystem$$1 && BaseFileSystem$$1.prototype );\n\t AsyncKeyValueFileSystem.prototype.constructor = AsyncKeyValueFileSystem;\n\t\n\t AsyncKeyValueFileSystem.isAvailable = function isAvailable () { return true; };\n\t /**\n\t * Initializes the file system. Typically called by subclasses' async\n\t * constructors.\n\t */\n\t AsyncKeyValueFileSystem.prototype.init = function init (store, cb) {\n\t this.store = store;\n\t // INVARIANT: Ensure that the root exists.\n\t this.makeRootDirectory(cb);\n\t };\n\t AsyncKeyValueFileSystem.prototype.getName = function getName () { return this.store.name(); };\n\t AsyncKeyValueFileSystem.prototype.isReadOnly = function isReadOnly () { return false; };\n\t AsyncKeyValueFileSystem.prototype.supportsSymlinks = function supportsSymlinks () { return false; };\n\t AsyncKeyValueFileSystem.prototype.supportsProps = function supportsProps () { return false; };\n\t AsyncKeyValueFileSystem.prototype.supportsSynch = function supportsSynch () { return false; };\n\t /**\n\t * Delete all contents stored in the file system.\n\t */\n\t AsyncKeyValueFileSystem.prototype.empty = function empty (cb) {\n\t var this$1 = this;\n\t\n\t this.store.clear(function (e) {\n\t if (noError(e, cb)) {\n\t // INVARIANT: Root always exists.\n\t this$1.makeRootDirectory(cb);\n\t }\n\t });\n\t };\n\t AsyncKeyValueFileSystem.prototype.rename = function rename (oldPath, newPath, cb) {\n\t var this$1 = this;\n\t\n\t var tx = this.store.beginTransaction('readwrite');\n\t var oldParent = path.dirname(oldPath), oldName = path.basename(oldPath);\n\t var newParent = path.dirname(newPath), newName = path.basename(newPath);\n\t var inodes = {};\n\t var lists = {};\n\t var errorOccurred = false;\n\t // Invariant: Can't move a folder inside itself.\n\t // This funny little hack ensures that the check passes only if oldPath\n\t // is a subpath of newParent. We append '/' to avoid matching folders that\n\t // are a substring of the bottom-most folder in the path.\n\t if ((newParent + '/').indexOf(oldPath + '/') === 0) {\n\t return cb(new ApiError(ErrorCode.EBUSY, oldParent));\n\t }\n\t /**\n\t * Responsible for Phase 2 of the rename operation: Modifying and\n\t * committing the directory listings. Called once we have successfully\n\t * retrieved both the old and new parent's inodes and listings.\n\t */\n\t var theOleSwitcharoo = function () {\n\t // Sanity check: Ensure both paths are present, and no error has occurred.\n\t if (errorOccurred || !lists.hasOwnProperty(oldParent) || !lists.hasOwnProperty(newParent)) {\n\t return;\n\t }\n\t var oldParentList = lists[oldParent], oldParentINode = inodes[oldParent], newParentList = lists[newParent], newParentINode = inodes[newParent];\n\t // Delete file from old parent.\n\t if (!oldParentList[oldName]) {\n\t cb(ApiError.ENOENT(oldPath));\n\t }\n\t else {\n\t var fileId = oldParentList[oldName];\n\t delete oldParentList[oldName];\n\t // Finishes off the renaming process by adding the file to the new\n\t // parent.\n\t var completeRename = function () {\n\t newParentList[newName] = fileId;\n\t // Commit old parent's list.\n\t tx.put(oldParentINode.id, new Buffer(JSON.stringify(oldParentList)), true, function (e) {\n\t if (noErrorTx(e, tx, cb)) {\n\t if (oldParent === newParent) {\n\t // DONE!\n\t tx.commit(cb);\n\t }\n\t else {\n\t // Commit new parent's list.\n\t tx.put(newParentINode.id, new Buffer(JSON.stringify(newParentList)), true, function (e) {\n\t if (noErrorTx(e, tx, cb)) {\n\t tx.commit(cb);\n\t }\n\t });\n\t }\n\t }\n\t });\n\t };\n\t if (newParentList[newName]) {\n\t // 'newPath' already exists. Check if it's a file or a directory, and\n\t // act accordingly.\n\t this$1.getINode(tx, newPath, newParentList[newName], function (e, inode) {\n\t if (noErrorTx(e, tx, cb)) {\n\t if (inode.isFile()) {\n\t // Delete the file and continue.\n\t tx.del(inode.id, function (e) {\n\t if (noErrorTx(e, tx, cb)) {\n\t tx.del(newParentList[newName], function (e) {\n\t if (noErrorTx(e, tx, cb)) {\n\t completeRename();\n\t }\n\t });\n\t }\n\t });\n\t }\n\t else {\n\t // Can't overwrite a directory using rename.\n\t tx.abort(function (e) {\n\t cb(ApiError.EPERM(newPath));\n\t });\n\t }\n\t }\n\t });\n\t }\n\t else {\n\t completeRename();\n\t }\n\t }\n\t };\n\t /**\n\t * Grabs a path's inode and directory listing, and shoves it into the\n\t * inodes and lists hashes.\n\t */\n\t var processInodeAndListings = function (p) {\n\t this$1.findINodeAndDirListing(tx, p, function (e, node, dirList) {\n\t if (e) {\n\t if (!errorOccurred) {\n\t errorOccurred = true;\n\t tx.abort(function () {\n\t cb(e);\n\t });\n\t }\n\t }\n\t else {\n\t inodes[p] = node;\n\t lists[p] = dirList;\n\t theOleSwitcharoo();\n\t }\n\t });\n\t };\n\t processInodeAndListings(oldParent);\n\t if (oldParent !== newParent) {\n\t processInodeAndListings(newParent);\n\t }\n\t };\n\t AsyncKeyValueFileSystem.prototype.stat = function stat (p, isLstat, cb) {\n\t var tx = this.store.beginTransaction('readonly');\n\t this.findINode(tx, p, function (e, inode) {\n\t if (noError(e, cb)) {\n\t cb(null, inode.toStats());\n\t }\n\t });\n\t };\n\t AsyncKeyValueFileSystem.prototype.createFile = function createFile (p, flag, mode, cb) {\n\t var this$1 = this;\n\t\n\t var tx = this.store.beginTransaction('readwrite'), data = new Buffer(0);\n\t this.commitNewFile(tx, p, FileType.FILE, mode, data, function (e, newFile) {\n\t if (noError(e, cb)) {\n\t cb(null, new AsyncKeyValueFile(this$1, p, flag, newFile.toStats(), data));\n\t }\n\t });\n\t };\n\t AsyncKeyValueFileSystem.prototype.openFile = function openFile (p, flag, cb) {\n\t var this$1 = this;\n\t\n\t var tx = this.store.beginTransaction('readonly');\n\t // Step 1: Grab the file's inode.\n\t this.findINode(tx, p, function (e, inode) {\n\t if (noError(e, cb)) {\n\t // Step 2: Grab the file's data.\n\t tx.get(inode.id, function (e, data) {\n\t if (noError(e, cb)) {\n\t if (data === undefined) {\n\t cb(ApiError.ENOENT(p));\n\t }\n\t else {\n\t cb(null, new AsyncKeyValueFile(this$1, p, flag, inode.toStats(), data));\n\t }\n\t }\n\t });\n\t }\n\t });\n\t };\n\t AsyncKeyValueFileSystem.prototype.unlink = function unlink (p, cb) {\n\t this.removeEntry(p, false, cb);\n\t };\n\t AsyncKeyValueFileSystem.prototype.rmdir = function rmdir (p, cb) {\n\t var this$1 = this;\n\t\n\t // Check first if directory is empty.\n\t this.readdir(p, function (err, files) {\n\t if (err) {\n\t cb(err);\n\t }\n\t else if (files.length > 0) {\n\t cb(ApiError.ENOTEMPTY(p));\n\t }\n\t else {\n\t this$1.removeEntry(p, true, cb);\n\t }\n\t });\n\t };\n\t AsyncKeyValueFileSystem.prototype.mkdir = function mkdir (p, mode, cb) {\n\t var tx = this.store.beginTransaction('readwrite'), data = new Buffer('{}');\n\t this.commitNewFile(tx, p, FileType.DIRECTORY, mode, data, cb);\n\t };\n\t AsyncKeyValueFileSystem.prototype.readdir = function readdir (p, cb) {\n\t var this$1 = this;\n\t\n\t var tx = this.store.beginTransaction('readonly');\n\t this.findINode(tx, p, function (e, inode) {\n\t if (noError(e, cb)) {\n\t this$1.getDirListing(tx, p, inode, function (e, dirListing) {\n\t if (noError(e, cb)) {\n\t cb(null, Object.keys(dirListing));\n\t }\n\t });\n\t }\n\t });\n\t };\n\t AsyncKeyValueFileSystem.prototype._sync = function _sync (p, data, stats, cb) {\n\t var this$1 = this;\n\t\n\t // @todo Ensure mtime updates properly, and use that to determine if a data\n\t // update is required.\n\t var tx = this.store.beginTransaction('readwrite');\n\t // Step 1: Get the file node's ID.\n\t this._findINode(tx, path.dirname(p), path.basename(p), function (e, fileInodeId) {\n\t if (noErrorTx(e, tx, cb)) {\n\t // Step 2: Get the file inode.\n\t this$1.getINode(tx, p, fileInodeId, function (e, fileInode) {\n\t if (noErrorTx(e, tx, cb)) {\n\t var inodeChanged = fileInode.update(stats);\n\t // Step 3: Sync the data.\n\t tx.put(fileInode.id, data, true, function (e) {\n\t if (noErrorTx(e, tx, cb)) {\n\t // Step 4: Sync the metadata (if it changed)!\n\t if (inodeChanged) {\n\t tx.put(fileInodeId, fileInode.toBuffer(), true, function (e) {\n\t if (noErrorTx(e, tx, cb)) {\n\t tx.commit(cb);\n\t }\n\t });\n\t }\n\t else {\n\t // No need to sync metadata; return.\n\t tx.commit(cb);\n\t }\n\t }\n\t });\n\t }\n\t });\n\t }\n\t });\n\t };\n\t /**\n\t * Checks if the root directory exists. Creates it if it doesn't.\n\t */\n\t AsyncKeyValueFileSystem.prototype.makeRootDirectory = function makeRootDirectory (cb) {\n\t var tx = this.store.beginTransaction('readwrite');\n\t tx.get(ROOT_NODE_ID, function (e, data) {\n\t if (e || data === undefined) {\n\t // Create new inode.\n\t var currTime = (new Date()).getTime(), \n\t // Mode 0666\n\t dirInode = new Inode(GenerateRandomID(), 4096, 511 | FileType.DIRECTORY, currTime, currTime, currTime);\n\t // If the root doesn't exist, the first random ID shouldn't exist,\n\t // either.\n\t tx.put(dirInode.id, new Buffer(\"{}\"), false, function (e) {\n\t if (noErrorTx(e, tx, cb)) {\n\t tx.put(ROOT_NODE_ID, dirInode.toBuffer(), false, function (e) {\n\t if (e) {\n\t tx.abort(function () { cb(e); });\n\t }\n\t else {\n\t tx.commit(cb);\n\t }\n\t });\n\t }\n\t });\n\t }\n\t else {\n\t // We're good.\n\t tx.commit(cb);\n\t }\n\t });\n\t };\n\t /**\n\t * Helper function for findINode.\n\t * @param parent The parent directory of the file we are attempting to find.\n\t * @param filename The filename of the inode we are attempting to find, minus\n\t * the parent.\n\t * @param cb Passed an error or the ID of the file's inode in the file system.\n\t */\n\t AsyncKeyValueFileSystem.prototype._findINode = function _findINode (tx, parent, filename, cb) {\n\t var this$1 = this;\n\t\n\t var handleDirectoryListings = function (e, inode, dirList) {\n\t if (e) {\n\t cb(e);\n\t }\n\t else if (dirList[filename]) {\n\t cb(null, dirList[filename]);\n\t }\n\t else {\n\t cb(ApiError.ENOENT(path.resolve(parent, filename)));\n\t }\n\t };\n\t if (parent === '/') {\n\t if (filename === '') {\n\t // BASE CASE #1: Return the root's ID.\n\t cb(null, ROOT_NODE_ID);\n\t }\n\t else {\n\t // BASE CASE #2: Find the item in the root node.\n\t this.getINode(tx, parent, ROOT_NODE_ID, function (e, inode) {\n\t if (noError(e, cb)) {\n\t this$1.getDirListing(tx, parent, inode, function (e, dirList) {\n\t // handle_directory_listings will handle e for us.\n\t handleDirectoryListings(e, inode, dirList);\n\t });\n\t }\n\t });\n\t }\n\t }\n\t else {\n\t // Get the parent directory's INode, and find the file in its directory\n\t // listing.\n\t this.findINodeAndDirListing(tx, parent, handleDirectoryListings);\n\t }\n\t };\n\t /**\n\t * Finds the Inode of the given path.\n\t * @param p The path to look up.\n\t * @param cb Passed an error or the Inode of the path p.\n\t * @todo memoize/cache\n\t */\n\t AsyncKeyValueFileSystem.prototype.findINode = function findINode (tx, p, cb) {\n\t var this$1 = this;\n\t\n\t this._findINode(tx, path.dirname(p), path.basename(p), function (e, id) {\n\t if (noError(e, cb)) {\n\t this$1.getINode(tx, p, id, cb);\n\t }\n\t });\n\t };\n\t /**\n\t * Given the ID of a node, retrieves the corresponding Inode.\n\t * @param tx The transaction to use.\n\t * @param p The corresponding path to the file (used for error messages).\n\t * @param id The ID to look up.\n\t * @param cb Passed an error or the inode under the given id.\n\t */\n\t AsyncKeyValueFileSystem.prototype.getINode = function getINode (tx, p, id, cb) {\n\t tx.get(id, function (e, data) {\n\t if (noError(e, cb)) {\n\t if (data === undefined) {\n\t cb(ApiError.ENOENT(p));\n\t }\n\t else {\n\t cb(null, Inode.fromBuffer(data));\n\t }\n\t }\n\t });\n\t };\n\t /**\n\t * Given the Inode of a directory, retrieves the corresponding directory\n\t * listing.\n\t */\n\t AsyncKeyValueFileSystem.prototype.getDirListing = function getDirListing (tx, p, inode, cb) {\n\t if (!inode.isDirectory()) {\n\t cb(ApiError.ENOTDIR(p));\n\t }\n\t else {\n\t tx.get(inode.id, function (e, data) {\n\t if (noError(e, cb)) {\n\t try {\n\t cb(null, JSON.parse(data.toString()));\n\t }\n\t catch (e) {\n\t // Occurs when data is undefined, or corresponds to something other\n\t // than a directory listing. The latter should never occur unless\n\t // the file system is corrupted.\n\t cb(ApiError.ENOENT(p));\n\t }\n\t }\n\t });\n\t }\n\t };\n\t /**\n\t * Given a path to a directory, retrieves the corresponding INode and\n\t * directory listing.\n\t */\n\t AsyncKeyValueFileSystem.prototype.findINodeAndDirListing = function findINodeAndDirListing (tx, p, cb) {\n\t var this$1 = this;\n\t\n\t this.findINode(tx, p, function (e, inode) {\n\t if (noError(e, cb)) {\n\t this$1.getDirListing(tx, p, inode, function (e, listing) {\n\t if (noError(e, cb)) {\n\t cb(null, inode, listing);\n\t }\n\t });\n\t }\n\t });\n\t };\n\t /**\n\t * Adds a new node under a random ID. Retries 5 times before giving up in\n\t * the exceedingly unlikely chance that we try to reuse a random GUID.\n\t * @param cb Passed an error or the GUID that the data was stored under.\n\t */\n\t AsyncKeyValueFileSystem.prototype.addNewNode = function addNewNode (tx, data, cb) {\n\t var retries = 0, currId;\n\t var reroll = function () {\n\t if (++retries === 5) {\n\t // Max retries hit. Return with an error.\n\t cb(new ApiError(ErrorCode.EIO, 'Unable to commit data to key-value store.'));\n\t }\n\t else {\n\t // Try again.\n\t currId = GenerateRandomID();\n\t tx.put(currId, data, false, function (e, committed) {\n\t if (e || !committed) {\n\t reroll();\n\t }\n\t else {\n\t // Successfully stored under 'currId'.\n\t cb(null, currId);\n\t }\n\t });\n\t }\n\t };\n\t reroll();\n\t };\n\t /**\n\t * Commits a new file (well, a FILE or a DIRECTORY) to the file system with\n\t * the given mode.\n\t * Note: This will commit the transaction.\n\t * @param p The path to the new file.\n\t * @param type The type of the new file.\n\t * @param mode The mode to create the new file with.\n\t * @param data The data to store at the file's data node.\n\t * @param cb Passed an error or the Inode for the new file.\n\t */\n\t AsyncKeyValueFileSystem.prototype.commitNewFile = function commitNewFile (tx, p, type, mode, data, cb) {\n\t var this$1 = this;\n\t\n\t var parentDir = path.dirname(p), fname = path.basename(p), currTime = (new Date()).getTime();\n\t // Invariant: The root always exists.\n\t // If we don't check this prior to taking steps below, we will create a\n\t // file with name '' in root should p == '/'.\n\t if (p === '/') {\n\t return cb(ApiError.EEXIST(p));\n\t }\n\t // Let's build a pyramid of code!\n\t // Step 1: Get the parent directory's inode and directory listing\n\t this.findINodeAndDirListing(tx, parentDir, function (e, parentNode, dirListing) {\n\t if (noErrorTx(e, tx, cb)) {\n\t if (dirListing[fname]) {\n\t // File already exists.\n\t tx.abort(function () {\n\t cb(ApiError.EEXIST(p));\n\t });\n\t }\n\t else {\n\t // Step 2: Commit data to store.\n\t this$1.addNewNode(tx, data, function (e, dataId) {\n\t if (noErrorTx(e, tx, cb)) {\n\t // Step 3: Commit the file's inode to the store.\n\t var fileInode = new Inode(dataId, data.length, mode | type, currTime, currTime, currTime);\n\t this$1.addNewNode(tx, fileInode.toBuffer(), function (e, fileInodeId) {\n\t if (noErrorTx(e, tx, cb)) {\n\t // Step 4: Update parent directory's listing.\n\t dirListing[fname] = fileInodeId;\n\t tx.put(parentNode.id, new Buffer(JSON.stringify(dirListing)), true, function (e) {\n\t if (noErrorTx(e, tx, cb)) {\n\t // Step 5: Commit and return the new inode.\n\t tx.commit(function (e) {\n\t if (noErrorTx(e, tx, cb)) {\n\t cb(null, fileInode);\n\t }\n\t });\n\t }\n\t });\n\t }\n\t });\n\t }\n\t });\n\t }\n\t }\n\t });\n\t };\n\t /**\n\t * Remove all traces of the given path from the file system.\n\t * @param p The path to remove from the file system.\n\t * @param isDir Does the path belong to a directory, or a file?\n\t * @todo Update mtime.\n\t */\n\t AsyncKeyValueFileSystem.prototype.removeEntry = function removeEntry (p, isDir, cb) {\n\t var this$1 = this;\n\t\n\t var tx = this.store.beginTransaction('readwrite'), parent = path.dirname(p), fileName = path.basename(p);\n\t // Step 1: Get parent directory's node and directory listing.\n\t this.findINodeAndDirListing(tx, parent, function (e, parentNode, parentListing) {\n\t if (noErrorTx(e, tx, cb)) {\n\t if (!parentListing[fileName]) {\n\t tx.abort(function () {\n\t cb(ApiError.ENOENT(p));\n\t });\n\t }\n\t else {\n\t // Remove from directory listing of parent.\n\t var fileNodeId = parentListing[fileName];\n\t delete parentListing[fileName];\n\t // Step 2: Get file inode.\n\t this$1.getINode(tx, p, fileNodeId, function (e, fileNode) {\n\t if (noErrorTx(e, tx, cb)) {\n\t if (!isDir && fileNode.isDirectory()) {\n\t tx.abort(function () {\n\t cb(ApiError.EISDIR(p));\n\t });\n\t }\n\t else if (isDir && !fileNode.isDirectory()) {\n\t tx.abort(function () {\n\t cb(ApiError.ENOTDIR(p));\n\t });\n\t }\n\t else {\n\t // Step 3: Delete data.\n\t tx.del(fileNode.id, function (e) {\n\t if (noErrorTx(e, tx, cb)) {\n\t // Step 4: Delete node.\n\t tx.del(fileNodeId, function (e) {\n\t if (noErrorTx(e, tx, cb)) {\n\t // Step 5: Update directory listing.\n\t tx.put(parentNode.id, new Buffer(JSON.stringify(parentListing)), true, function (e) {\n\t if (noErrorTx(e, tx, cb)) {\n\t tx.commit(cb);\n\t }\n\t });\n\t }\n\t });\n\t }\n\t });\n\t }\n\t }\n\t });\n\t }\n\t }\n\t });\n\t };\n\t\n\t return AsyncKeyValueFileSystem;\n\t}(BaseFileSystem));\n\t\n\t/**\n\t * A simple in-memory key-value store backed by a JavaScript object.\n\t */\n\tvar InMemoryStore = function InMemoryStore() {\n\t this.store = {};\n\t};\n\tInMemoryStore.prototype.name = function name () { return 'In-memory'; };\n\tInMemoryStore.prototype.clear = function clear () { this.store = {}; };\n\tInMemoryStore.prototype.beginTransaction = function beginTransaction (type) {\n\t return new SimpleSyncRWTransaction(this);\n\t};\n\tInMemoryStore.prototype.get = function get (key) {\n\t return this.store[key];\n\t};\n\tInMemoryStore.prototype.put = function put (key, data, overwrite) {\n\t if (!overwrite && this.store.hasOwnProperty(key)) {\n\t return false;\n\t }\n\t this.store[key] = data;\n\t return true;\n\t};\n\tInMemoryStore.prototype.del = function del (key) {\n\t delete this.store[key];\n\t};\n\t/**\n\t * A simple in-memory file system backed by an InMemoryStore.\n\t */\n\tvar InMemoryFileSystem = (function (SyncKeyValueFileSystem$$1) {\n\t function InMemoryFileSystem() {\n\t SyncKeyValueFileSystem$$1.call(this, { store: new InMemoryStore() });\n\t }\n\t\n\t if ( SyncKeyValueFileSystem$$1 ) InMemoryFileSystem.__proto__ = SyncKeyValueFileSystem$$1;\n\t InMemoryFileSystem.prototype = Object.create( SyncKeyValueFileSystem$$1 && SyncKeyValueFileSystem$$1.prototype );\n\t InMemoryFileSystem.prototype.constructor = InMemoryFileSystem;\n\t\n\t return InMemoryFileSystem;\n\t}(SyncKeyValueFileSystem));\n\t\n\t/**\n\t * Get the indexedDB constructor for the current browser.\n\t */\n\tvar indexedDB = global$1.indexedDB ||\n\t global$1.mozIndexedDB ||\n\t global$1.webkitIndexedDB ||\n\t global$1.msIndexedDB;\n\t/**\n\t * Converts a DOMException or a DOMError from an IndexedDB event into a\n\t * standardized BrowserFS API error.\n\t */\n\tfunction convertError$2(e, message) {\n\t if ( message === void 0 ) message = e.toString();\n\t\n\t switch (e.name) {\n\t case \"NotFoundError\":\n\t return new ApiError(ErrorCode.ENOENT, message);\n\t case \"QuotaExceededError\":\n\t return new ApiError(ErrorCode.ENOSPC, message);\n\t default:\n\t // The rest do not seem to map cleanly to standard error codes.\n\t return new ApiError(ErrorCode.EIO, message);\n\t }\n\t}\n\t/**\n\t * Produces a new onerror handler for IDB. Our errors are always fatal, so we\n\t * handle them generically: Call the user-supplied callback with a translated\n\t * version of the error, and let the error bubble up.\n\t */\n\tfunction onErrorHandler(cb, code, message) {\n\t if ( code === void 0 ) code = ErrorCode.EIO;\n\t if ( message === void 0 ) message = null;\n\t\n\t return function (e) {\n\t // Prevent the error from canceling the transaction.\n\t e.preventDefault();\n\t cb(new ApiError(code, message !== null ? message : undefined));\n\t };\n\t}\n\tvar IndexedDBROTransaction = function IndexedDBROTransaction(tx, store) {\n\t this.tx = tx;\n\t this.store = store;\n\t};\n\tIndexedDBROTransaction.prototype.get = function get (key, cb) {\n\t try {\n\t var r = this.store.get(key);\n\t r.onerror = onErrorHandler(cb);\n\t r.onsuccess = function (event) {\n\t // IDB returns the value 'undefined' when you try to get keys that\n\t // don't exist. The caller expects this behavior.\n\t var result = event.target.result;\n\t if (result === undefined) {\n\t cb(null, result);\n\t }\n\t else {\n\t // IDB data is stored as an ArrayBuffer\n\t cb(null, arrayBuffer2Buffer(result));\n\t }\n\t };\n\t }\n\t catch (e) {\n\t cb(convertError$2(e));\n\t }\n\t};\n\tvar IndexedDBRWTransaction = (function (IndexedDBROTransaction) {\n\t function IndexedDBRWTransaction(tx, store) {\n\t IndexedDBROTransaction.call(this, tx, store);\n\t }\n\t\n\t if ( IndexedDBROTransaction ) IndexedDBRWTransaction.__proto__ = IndexedDBROTransaction;\n\t IndexedDBRWTransaction.prototype = Object.create( IndexedDBROTransaction && IndexedDBROTransaction.prototype );\n\t IndexedDBRWTransaction.prototype.constructor = IndexedDBRWTransaction;\n\t IndexedDBRWTransaction.prototype.put = function put (key, data, overwrite, cb) {\n\t try {\n\t var arraybuffer = buffer2ArrayBuffer(data);\n\t var r;\n\t if (overwrite) {\n\t r = this.store.put(arraybuffer, key);\n\t }\n\t else {\n\t // 'add' will never overwrite an existing key.\n\t r = this.store.add(arraybuffer, key);\n\t }\n\t // XXX: NEED TO RETURN FALSE WHEN ADD HAS A KEY CONFLICT. NO ERROR.\n\t r.onerror = onErrorHandler(cb);\n\t r.onsuccess = function (event) {\n\t cb(null, true);\n\t };\n\t }\n\t catch (e) {\n\t cb(convertError$2(e));\n\t }\n\t };\n\t IndexedDBRWTransaction.prototype.del = function del (key, cb) {\n\t try {\n\t // NOTE: IE8 has a bug with identifiers named 'delete' unless used as a string\n\t // like this.\n\t // http://stackoverflow.com/a/26479152\n\t var r = this.store['delete'](key);\n\t r.onerror = onErrorHandler(cb);\n\t r.onsuccess = function (event) {\n\t cb();\n\t };\n\t }\n\t catch (e) {\n\t cb(convertError$2(e));\n\t }\n\t };\n\t IndexedDBRWTransaction.prototype.commit = function commit (cb) {\n\t // Return to the event loop to commit the transaction.\n\t setTimeout(cb, 0);\n\t };\n\t IndexedDBRWTransaction.prototype.abort = function abort (cb) {\n\t var _e = null;\n\t try {\n\t this.tx.abort();\n\t }\n\t catch (e) {\n\t _e = convertError$2(e);\n\t }\n\t finally {\n\t cb(_e);\n\t }\n\t };\n\t\n\t return IndexedDBRWTransaction;\n\t}(IndexedDBROTransaction));\n\tvar IndexedDBStore = function IndexedDBStore(cb, storeName) {\n\t var this$1 = this;\n\t if ( storeName === void 0 ) storeName = 'browserfs';\n\t\n\t this.storeName = storeName;\n\t var openReq = indexedDB.open(this.storeName, 1);\n\t openReq.onupgradeneeded = function (event) {\n\t var db = event.target.result;\n\t // Huh. This should never happen; we're at version 1. Why does another\n\t // database exist?\n\t if (db.objectStoreNames.contains(this$1.storeName)) {\n\t db.deleteObjectStore(this$1.storeName);\n\t }\n\t db.createObjectStore(this$1.storeName);\n\t };\n\t openReq.onsuccess = function (event) {\n\t this$1.db = event.target.result;\n\t cb(null, this$1);\n\t };\n\t openReq.onerror = onErrorHandler(cb, ErrorCode.EACCES);\n\t};\n\tIndexedDBStore.prototype.name = function name () {\n\t return \"IndexedDB - \" + this.storeName;\n\t};\n\tIndexedDBStore.prototype.clear = function clear (cb) {\n\t try {\n\t var tx = this.db.transaction(this.storeName, 'readwrite'), objectStore = tx.objectStore(this.storeName), r = objectStore.clear();\n\t r.onsuccess = function (event) {\n\t // Use setTimeout to commit transaction.\n\t setTimeout(cb, 0);\n\t };\n\t r.onerror = onErrorHandler(cb);\n\t }\n\t catch (e) {\n\t cb(convertError$2(e));\n\t }\n\t};\n\tIndexedDBStore.prototype.beginTransaction = function beginTransaction (type) {\n\t if ( type === void 0 ) type = 'readonly';\n\t\n\t var tx = this.db.transaction(this.storeName, type), objectStore = tx.objectStore(this.storeName);\n\t if (type === 'readwrite') {\n\t return new IndexedDBRWTransaction(tx, objectStore);\n\t }\n\t else if (type === 'readonly') {\n\t return new IndexedDBROTransaction(tx, objectStore);\n\t }\n\t else {\n\t throw new ApiError(ErrorCode.EINVAL, 'Invalid transaction type.');\n\t }\n\t};\n\t/**\n\t * A file system that uses the IndexedDB key value file system.\n\t */\n\tvar IndexedDBFileSystem = (function (AsyncKeyValueFileSystem$$1) {\n\t function IndexedDBFileSystem(cb, storeName) {\n\t var this$1 = this;\n\t\n\t AsyncKeyValueFileSystem$$1.call(this);\n\t var store = new IndexedDBStore(function (e) {\n\t if (e) {\n\t cb(e);\n\t }\n\t else {\n\t this$1.init(store, function (e) {\n\t cb(e, this$1);\n\t });\n\t }\n\t }, storeName);\n\t }\n\t\n\t if ( AsyncKeyValueFileSystem$$1 ) IndexedDBFileSystem.__proto__ = AsyncKeyValueFileSystem$$1;\n\t IndexedDBFileSystem.prototype = Object.create( AsyncKeyValueFileSystem$$1 && AsyncKeyValueFileSystem$$1.prototype );\n\t IndexedDBFileSystem.prototype.constructor = IndexedDBFileSystem;\n\t\n\t IndexedDBFileSystem.isAvailable = function isAvailable () {\n\t // In Safari's private browsing mode, indexedDB.open returns NULL.\n\t // In Firefox, it throws an exception.\n\t // In Chrome, it \"just works\", and clears the database when you leave the page.\n\t // Untested: Opera, IE.\n\t try {\n\t return typeof indexedDB !== 'undefined' && null !== indexedDB.open(\"__browserfs_test__\");\n\t }\n\t catch (e) {\n\t return false;\n\t }\n\t };\n\t\n\t return IndexedDBFileSystem;\n\t}(AsyncKeyValueFileSystem));\n\t\n\t// Some versions of FF and all versions of IE do not support the full range of\n\t// 16-bit numbers encoded as characters, as they enforce UTF-16 restrictions.\n\t// http://stackoverflow.com/questions/11170716/are-there-any-characters-that-are-not-allowed-in-localstorage/11173673#11173673\n\tvar supportsBinaryString = false;\n\tvar binaryEncoding;\n\ttry {\n\t global$1.localStorage.setItem(\"__test__\", String.fromCharCode(0xD800));\n\t supportsBinaryString = global$1.localStorage.getItem(\"__test__\") === String.fromCharCode(0xD800);\n\t}\n\tcatch (e) {\n\t // IE throws an exception.\n\t supportsBinaryString = false;\n\t}\n\tbinaryEncoding = supportsBinaryString ? 'binary_string' : 'binary_string_ie';\n\tif (!Buffer.isEncoding(binaryEncoding)) {\n\t // Fallback for non BrowserFS implementations of buffer that lack a\n\t // binary_string format.\n\t binaryEncoding = \"base64\";\n\t}\n\t/**\n\t * A synchronous key-value store backed by localStorage.\n\t */\n\tvar LocalStorageStore = function LocalStorageStore () {};\n\t\n\tLocalStorageStore.prototype.name = function name () {\n\t return 'LocalStorage';\n\t};\n\tLocalStorageStore.prototype.clear = function clear () {\n\t global$1.localStorage.clear();\n\t};\n\tLocalStorageStore.prototype.beginTransaction = function beginTransaction (type) {\n\t // No need to differentiate.\n\t return new SimpleSyncRWTransaction(this);\n\t};\n\tLocalStorageStore.prototype.get = function get (key) {\n\t try {\n\t var data = global$1.localStorage.getItem(key);\n\t if (data !== null) {\n\t return new Buffer(data, binaryEncoding);\n\t }\n\t }\n\t catch (e) {\n\t }\n\t // Key doesn't exist, or a failure occurred.\n\t return undefined;\n\t};\n\tLocalStorageStore.prototype.put = function put (key, data, overwrite) {\n\t try {\n\t if (!overwrite && global$1.localStorage.getItem(key) !== null) {\n\t // Don't want to overwrite the key!\n\t return false;\n\t }\n\t global$1.localStorage.setItem(key, data.toString(binaryEncoding));\n\t return true;\n\t }\n\t catch (e) {\n\t throw new ApiError(ErrorCode.ENOSPC, \"LocalStorage is full.\");\n\t }\n\t};\n\tLocalStorageStore.prototype.del = function del (key) {\n\t try {\n\t global$1.localStorage.removeItem(key);\n\t }\n\t catch (e) {\n\t throw new ApiError(ErrorCode.EIO, \"Unable to delete key \" + key + \": \" + e);\n\t }\n\t};\n\t/**\n\t * A synchronous file system backed by localStorage. Connects our\n\t * LocalStorageStore to our SyncKeyValueFileSystem.\n\t */\n\tvar LocalStorageFileSystem = (function (SyncKeyValueFileSystem$$1) {\n\t function LocalStorageFileSystem() { SyncKeyValueFileSystem$$1.call(this, { store: new LocalStorageStore() }); }\n\t\n\t if ( SyncKeyValueFileSystem$$1 ) LocalStorageFileSystem.__proto__ = SyncKeyValueFileSystem$$1;\n\t LocalStorageFileSystem.prototype = Object.create( SyncKeyValueFileSystem$$1 && SyncKeyValueFileSystem$$1.prototype );\n\t LocalStorageFileSystem.prototype.constructor = LocalStorageFileSystem;\n\t\n\t LocalStorageFileSystem.isAvailable = function isAvailable () {\n\t return typeof global$1.localStorage !== 'undefined';\n\t };\n\t\n\t return LocalStorageFileSystem;\n\t}(SyncKeyValueFileSystem));\n\t\n\t/**\n\t * The MountableFileSystem allows you to mount multiple backend types or\n\t * multiple instantiations of the same backend into a single file system tree.\n\t * The file systems do not need to know about each other; all interactions are\n\t * automatically facilitated through this interface.\n\t *\n\t * For example, if a file system is mounted at /mnt/blah, and a request came in\n\t * for /mnt/blah/foo.txt, the file system would see a request for /foo.txt.\n\t */\n\tvar MountableFileSystem = (function (BaseFileSystem$$1) {\n\t function MountableFileSystem() {\n\t BaseFileSystem$$1.call(this);\n\t // Contains the list of mount points in mntMap, sorted by string length in decreasing order.\n\t // Ensures that we scan the most specific mount points for a match first, which lets us\n\t // nest mount points.\n\t this.mountList = [];\n\t this.mntMap = {};\n\t // The InMemory file system serves purely to provide directory listings for\n\t // mounted file systems.\n\t this.rootFs = new InMemoryFileSystem();\n\t }\n\t\n\t if ( BaseFileSystem$$1 ) MountableFileSystem.__proto__ = BaseFileSystem$$1;\n\t MountableFileSystem.prototype = Object.create( BaseFileSystem$$1 && BaseFileSystem$$1.prototype );\n\t MountableFileSystem.prototype.constructor = MountableFileSystem;\n\t MountableFileSystem.isAvailable = function isAvailable () {\n\t return true;\n\t };\n\t /**\n\t * Mounts the file system at the given mount point.\n\t */\n\t MountableFileSystem.prototype.mount = function mount (mountPoint, fs) {\n\t if (mountPoint[0] !== '/') {\n\t mountPoint = \"/\" + mountPoint;\n\t }\n\t mountPoint = path.resolve(mountPoint);\n\t if (this.mntMap[mountPoint]) {\n\t throw new ApiError(ErrorCode.EINVAL, \"Mount point \" + mountPoint + \" is already taken.\");\n\t }\n\t mkdirpSync(mountPoint, 0x1ff, this.rootFs);\n\t this.mntMap[mountPoint] = fs;\n\t this.mountList.push(mountPoint);\n\t this.mountList = this.mountList.sort(function (a, b) { return b.length - a.length; });\n\t };\n\t MountableFileSystem.prototype.umount = function umount (mountPoint) {\n\t var this$1 = this;\n\t\n\t if (mountPoint[0] !== '/') {\n\t mountPoint = \"/\" + mountPoint;\n\t }\n\t mountPoint = path.resolve(mountPoint);\n\t if (!this.mntMap[mountPoint]) {\n\t throw new ApiError(ErrorCode.EINVAL, \"Mount point \" + mountPoint + \" is already unmounted.\");\n\t }\n\t delete this.mntMap[mountPoint];\n\t this.mountList.splice(this.mountList.indexOf(mountPoint), 1);\n\t while (mountPoint !== '/') {\n\t if (this$1.rootFs.readdirSync(mountPoint).length === 0) {\n\t this$1.rootFs.rmdirSync(mountPoint);\n\t mountPoint = path.dirname(mountPoint);\n\t }\n\t else {\n\t break;\n\t }\n\t }\n\t };\n\t /**\n\t * Returns the file system that the path points to.\n\t */\n\t MountableFileSystem.prototype._getFs = function _getFs (path$$1) {\n\t var this$1 = this;\n\t\n\t var mountList = this.mountList, len = mountList.length;\n\t for (var i = 0; i < len; i++) {\n\t var mountPoint = mountList[i];\n\t // We know path is normalized, so it is a substring of the mount point.\n\t if (mountPoint.length <= path$$1.length && path$$1.indexOf(mountPoint) === 0) {\n\t path$$1 = path$$1.substr(mountPoint.length > 1 ? mountPoint.length : 0);\n\t if (path$$1 === '') {\n\t path$$1 = '/';\n\t }\n\t return { fs: this$1.mntMap[mountPoint], path: path$$1 };\n\t }\n\t }\n\t // Query our root file system.\n\t return { fs: this.rootFs, path: path$$1 };\n\t };\n\t // Global information methods\n\t MountableFileSystem.prototype.getName = function getName () {\n\t return 'MountableFileSystem';\n\t };\n\t MountableFileSystem.prototype.diskSpace = function diskSpace (path$$1, cb) {\n\t cb(0, 0);\n\t };\n\t MountableFileSystem.prototype.isReadOnly = function isReadOnly () {\n\t return false;\n\t };\n\t MountableFileSystem.prototype.supportsLinks = function supportsLinks () {\n\t // I'm not ready for cross-FS links yet.\n\t return false;\n\t };\n\t MountableFileSystem.prototype.supportsProps = function supportsProps () {\n\t return false;\n\t };\n\t MountableFileSystem.prototype.supportsSynch = function supportsSynch () {\n\t return true;\n\t };\n\t /**\n\t * Fixes up error messages so they mention the mounted file location relative\n\t * to the MFS root, not to the particular FS's root.\n\t * Mutates the input error, and returns it.\n\t */\n\t MountableFileSystem.prototype.standardizeError = function standardizeError (err, path$$1, realPath) {\n\t var index = err.message.indexOf(path$$1);\n\t if (index !== -1) {\n\t err.message = err.message.substr(0, index) + realPath + err.message.substr(index + path$$1.length);\n\t err.path = realPath;\n\t }\n\t return err;\n\t };\n\t // The following methods involve multiple file systems, and thus have custom\n\t // logic.\n\t // Note that we go through the Node API to use its robust default argument\n\t // processing.\n\t MountableFileSystem.prototype.rename = function rename (oldPath, newPath, cb) {\n\t var this$1 = this;\n\t\n\t // Scenario 1: old and new are on same FS.\n\t var fs1rv = this._getFs(oldPath);\n\t var fs2rv = this._getFs(newPath);\n\t if (fs1rv.fs === fs2rv.fs) {\n\t return fs1rv.fs.rename(fs1rv.path, fs2rv.path, function (e) {\n\t if (e) {\n\t this$1.standardizeError(this$1.standardizeError(e, fs1rv.path, oldPath), fs2rv.path, newPath);\n\t }\n\t cb(e);\n\t });\n\t }\n\t // Scenario 2: Different file systems.\n\t // Read old file, write new file, delete old file.\n\t return _fsMock.readFile(oldPath, function (err, data) {\n\t if (err) {\n\t return cb(err);\n\t }\n\t _fsMock.writeFile(newPath, data, function (err) {\n\t if (err) {\n\t return cb(err);\n\t }\n\t _fsMock.unlink(oldPath, cb);\n\t });\n\t });\n\t };\n\t MountableFileSystem.prototype.renameSync = function renameSync (oldPath, newPath) {\n\t // Scenario 1: old and new are on same FS.\n\t var fs1rv = this._getFs(oldPath);\n\t var fs2rv = this._getFs(newPath);\n\t if (fs1rv.fs === fs2rv.fs) {\n\t try {\n\t return fs1rv.fs.renameSync(fs1rv.path, fs2rv.path);\n\t }\n\t catch (e) {\n\t this.standardizeError(this.standardizeError(e, fs1rv.path, oldPath), fs2rv.path, newPath);\n\t throw e;\n\t }\n\t }\n\t // Scenario 2: Different file systems.\n\t var data = _fsMock.readFileSync(oldPath);\n\t _fsMock.writeFileSync(newPath, data);\n\t return _fsMock.unlinkSync(oldPath);\n\t };\n\t MountableFileSystem.prototype.readdirSync = function readdirSync (p) {\n\t var fsInfo = this._getFs(p);\n\t // If null, rootfs did not have the directory\n\t // (or the target FS is the root fs).\n\t var rv = null;\n\t // Mount points are all defined in the root FS.\n\t // Ensure that we list those, too.\n\t if (fsInfo.fs !== this.rootFs) {\n\t try {\n\t rv = this.rootFs.readdirSync(p);\n\t }\n\t catch (e) {\n\t }\n\t }\n\t try {\n\t var rv2 = fsInfo.fs.readdirSync(fsInfo.path);\n\t if (rv === null) {\n\t return rv2;\n\t }\n\t else {\n\t // Filter out duplicates.\n\t return rv2.concat(rv.filter(function (val) { return rv2.indexOf(val) === -1; }));\n\t }\n\t }\n\t catch (e) {\n\t if (rv === null) {\n\t throw this.standardizeError(e, fsInfo.path, p);\n\t }\n\t else {\n\t // The root FS had something.\n\t return rv;\n\t }\n\t }\n\t };\n\t MountableFileSystem.prototype.readdir = function readdir (p, cb) {\n\t var this$1 = this;\n\t\n\t var fsInfo = this._getFs(p);\n\t fsInfo.fs.readdir(fsInfo.path, function (err, files) {\n\t if (fsInfo.fs !== this$1.rootFs) {\n\t try {\n\t var rv = this$1.rootFs.readdirSync(p);\n\t if (files) {\n\t // Filter out duplicates.\n\t files = files.concat(rv.filter(function (val) { return files.indexOf(val) === -1; }));\n\t }\n\t else {\n\t files = rv;\n\t }\n\t }\n\t catch (e) {\n\t // Root FS and target FS did not have directory.\n\t if (err) {\n\t return cb(this$1.standardizeError(err, fsInfo.path, p));\n\t }\n\t }\n\t }\n\t else if (err) {\n\t // Root FS and target FS are the same, and did not have directory.\n\t return cb(this$1.standardizeError(err, fsInfo.path, p));\n\t }\n\t cb(null, files);\n\t });\n\t };\n\t MountableFileSystem.prototype.rmdirSync = function rmdirSync (p) {\n\t var fsInfo = this._getFs(p);\n\t if (this._containsMountPt(p)) {\n\t throw ApiError.ENOTEMPTY(p);\n\t }\n\t else {\n\t try {\n\t fsInfo.fs.rmdirSync(fsInfo.path);\n\t }\n\t catch (e) {\n\t throw this.standardizeError(e, fsInfo.path, p);\n\t }\n\t }\n\t };\n\t MountableFileSystem.prototype.rmdir = function rmdir (p, cb) {\n\t var this$1 = this;\n\t\n\t var fsInfo = this._getFs(p);\n\t if (this._containsMountPt(p)) {\n\t cb(ApiError.ENOTEMPTY(p));\n\t }\n\t else {\n\t fsInfo.fs.rmdir(fsInfo.path, function (err) {\n\t cb(err ? this$1.standardizeError(err, fsInfo.path, p) : null);\n\t });\n\t }\n\t };\n\t /**\n\t * Returns true if the given path contains a mount point.\n\t */\n\t MountableFileSystem.prototype._containsMountPt = function _containsMountPt (p) {\n\t var mountPoints = this.mountList, len = mountPoints.length;\n\t for (var i = 0; i < len; i++) {\n\t var pt = mountPoints[i];\n\t if (pt.length >= p.length && pt.slice(0, p.length) === p) {\n\t return true;\n\t }\n\t }\n\t return false;\n\t };\n\t\n\t return MountableFileSystem;\n\t}(BaseFileSystem));\n\t\n\t/**\n\t * Tricky: Define all of the functions that merely forward arguments to the\n\t * relevant file system, or return/throw an error.\n\t * Take advantage of the fact that the *first* argument is always the path, and\n\t * the *last* is the callback function (if async).\n\t * @todo Can use numArgs to make proxying more efficient.\n\t */\n\tfunction defineFcn(name, isSync, numArgs) {\n\t if (isSync) {\n\t return function () {\n\t var args = [], len = arguments.length;\n\t while ( len-- ) args[ len ] = arguments[ len ];\n\t\n\t var path$$1 = args[0];\n\t var rv = this._getFs(path$$1);\n\t args[0] = rv.path;\n\t try {\n\t return rv.fs[name].apply(rv.fs, args);\n\t }\n\t catch (e) {\n\t this.standardizeError(e, rv.path, path$$1);\n\t throw e;\n\t }\n\t };\n\t }\n\t else {\n\t return function () {\n\t var this$1 = this;\n\t var args = [], len = arguments.length;\n\t while ( len-- ) args[ len ] = arguments[ len ];\n\t\n\t var path$$1 = args[0];\n\t var rv = this._getFs(path$$1);\n\t args[0] = rv.path;\n\t if (typeof args[args.length - 1] === 'function') {\n\t var cb = args[args.length - 1];\n\t args[args.length - 1] = function () {\n\t var args = [], len = arguments.length;\n\t while ( len-- ) args[ len ] = arguments[ len ];\n\t\n\t if (args.length > 0 && args[0] instanceof ApiError) {\n\t this$1.standardizeError(args[0], rv.path, path$$1);\n\t }\n\t cb.apply(null, args);\n\t };\n\t }\n\t return rv.fs[name].apply(rv.fs, args);\n\t };\n\t }\n\t}\n\tvar fsCmdMap = [\n\t // 1 arg functions\n\t ['exists', 'unlink', 'readlink'],\n\t // 2 arg functions\n\t ['stat', 'mkdir', 'realpath', 'truncate'],\n\t // 3 arg functions\n\t ['open', 'readFile', 'chmod', 'utimes'],\n\t // 4 arg functions\n\t ['chown'],\n\t // 5 arg functions\n\t ['writeFile', 'appendFile']\n\t];\n\tfor (var i = 0; i < fsCmdMap.length; i++) {\n\t var cmds = fsCmdMap[i];\n\t for (var j = 0; j < cmds.length; j++) {\n\t var fnName = cmds[j];\n\t MountableFileSystem.prototype[fnName] = defineFcn(fnName, false, i + 1);\n\t MountableFileSystem.prototype[fnName + 'Sync'] = defineFcn(fnName + 'Sync', true, i + 1);\n\t }\n\t}\n\t\n\t/**\n\t * Non-recursive mutex\n\t */\n\tvar Mutex = function Mutex() {\n\t this._locked = false;\n\t this._waiters = [];\n\t};\n\tMutex.prototype.lock = function lock (cb) {\n\t if (this._locked) {\n\t this._waiters.push(cb);\n\t return;\n\t }\n\t this._locked = true;\n\t cb();\n\t};\n\tMutex.prototype.unlock = function unlock () {\n\t if (!this._locked) {\n\t throw new Error('unlock of a non-locked mutex');\n\t }\n\t var next = this._waiters.shift();\n\t // don't unlock - we want to queue up next for the\n\t // _end_ of the current task execution, but we don't\n\t // want it to be called inline with whatever the\n\t // current stack is. This way we still get the nice\n\t // behavior that an unlock immediately followed by a\n\t // lock won't cause starvation.\n\t if (next) {\n\t setImmediate(next);\n\t return;\n\t }\n\t this._locked = false;\n\t};\n\tMutex.prototype.tryLock = function tryLock () {\n\t if (this._locked) {\n\t return false;\n\t }\n\t this._locked = true;\n\t return true;\n\t};\n\tMutex.prototype.isLocked = function isLocked () {\n\t return this._locked;\n\t};\n\t\n\t/**\n\t * This class serializes access to an underlying async filesystem.\n\t * For example, on an OverlayFS instance with an async lower\n\t * directory operations like rename and rmdir may involve multiple\n\t * requests involving both the upper and lower filesystems -- they\n\t * are not executed in a single atomic step. OverlayFS uses this\n\t * LockedFS to avoid having to reason about the correctness of\n\t * multiple requests interleaving.\n\t */\n\tvar LockedFS = function LockedFS(fs) {\n\t this._fs = fs;\n\t this._mu = new Mutex();\n\t};\n\tLockedFS.prototype.getName = function getName () {\n\t return 'LockedFS<' + this._fs.getName() + '>';\n\t};\n\tLockedFS.prototype.getFSUnlocked = function getFSUnlocked () {\n\t return this._fs;\n\t};\n\tLockedFS.prototype.initialize = function initialize (cb) {\n\t // FIXME: check to see if FS supports initialization\n\t this._fs.initialize(cb);\n\t};\n\tLockedFS.prototype.diskSpace = function diskSpace (p, cb) {\n\t // FIXME: should this lock?\n\t this._fs.diskSpace(p, cb);\n\t};\n\tLockedFS.prototype.isReadOnly = function isReadOnly () {\n\t return this._fs.isReadOnly();\n\t};\n\tLockedFS.prototype.supportsLinks = function supportsLinks () {\n\t return this._fs.supportsLinks();\n\t};\n\tLockedFS.prototype.supportsProps = function supportsProps () {\n\t return this._fs.supportsProps();\n\t};\n\tLockedFS.prototype.supportsSynch = function supportsSynch () {\n\t return this._fs.supportsSynch();\n\t};\n\tLockedFS.prototype.rename = function rename (oldPath, newPath, cb) {\n\t var this$1 = this;\n\t\n\t this._mu.lock(function () {\n\t this$1._fs.rename(oldPath, newPath, function (err) {\n\t this$1._mu.unlock();\n\t cb(err);\n\t });\n\t });\n\t};\n\tLockedFS.prototype.renameSync = function renameSync (oldPath, newPath) {\n\t if (this._mu.isLocked()) {\n\t throw new Error('invalid sync call');\n\t }\n\t return this._fs.renameSync(oldPath, newPath);\n\t};\n\tLockedFS.prototype.stat = function stat (p, isLstat, cb) {\n\t var this$1 = this;\n\t\n\t this._mu.lock(function () {\n\t this$1._fs.stat(p, isLstat, function (err, stat) {\n\t this$1._mu.unlock();\n\t cb(err, stat);\n\t });\n\t });\n\t};\n\tLockedFS.prototype.statSync = function statSync (p, isLstat) {\n\t if (this._mu.isLocked()) {\n\t throw new Error('invalid sync call');\n\t }\n\t return this._fs.statSync(p, isLstat);\n\t};\n\tLockedFS.prototype.open = function open (p, flag, mode, cb) {\n\t var this$1 = this;\n\t\n\t this._mu.lock(function () {\n\t this$1._fs.open(p, flag, mode, function (err, fd) {\n\t this$1._mu.unlock();\n\t cb(err, fd);\n\t });\n\t });\n\t};\n\tLockedFS.prototype.openSync = function openSync (p, flag, mode) {\n\t if (this._mu.isLocked()) {\n\t throw new Error('invalid sync call');\n\t }\n\t return this._fs.openSync(p, flag, mode);\n\t};\n\tLockedFS.prototype.unlink = function unlink (p, cb) {\n\t var this$1 = this;\n\t\n\t this._mu.lock(function () {\n\t this$1._fs.unlink(p, function (err) {\n\t this$1._mu.unlock();\n\t cb(err);\n\t });\n\t });\n\t};\n\tLockedFS.prototype.unlinkSync = function unlinkSync (p) {\n\t if (this._mu.isLocked()) {\n\t throw new Error('invalid sync call');\n\t }\n\t return this._fs.unlinkSync(p);\n\t};\n\tLockedFS.prototype.rmdir = function rmdir (p, cb) {\n\t var this$1 = this;\n\t\n\t this._mu.lock(function () {\n\t this$1._fs.rmdir(p, function (err) {\n\t this$1._mu.unlock();\n\t cb(err);\n\t });\n\t });\n\t};\n\tLockedFS.prototype.rmdirSync = function rmdirSync (p) {\n\t if (this._mu.isLocked()) {\n\t throw new Error('invalid sync call');\n\t }\n\t return this._fs.rmdirSync(p);\n\t};\n\tLockedFS.prototype.mkdir = function mkdir (p, mode, cb) {\n\t var this$1 = this;\n\t\n\t this._mu.lock(function () {\n\t this$1._fs.mkdir(p, mode, function (err) {\n\t this$1._mu.unlock();\n\t cb(err);\n\t });\n\t });\n\t};\n\tLockedFS.prototype.mkdirSync = function mkdirSync (p, mode) {\n\t if (this._mu.isLocked()) {\n\t throw new Error('invalid sync call');\n\t }\n\t return this._fs.mkdirSync(p, mode);\n\t};\n\tLockedFS.prototype.readdir = function readdir (p, cb) {\n\t var this$1 = this;\n\t\n\t this._mu.lock(function () {\n\t this$1._fs.readdir(p, function (err, files) {\n\t this$1._mu.unlock();\n\t cb(err, files);\n\t });\n\t });\n\t};\n\tLockedFS.prototype.readdirSync = function readdirSync (p) {\n\t if (this._mu.isLocked()) {\n\t throw new Error('invalid sync call');\n\t }\n\t return this._fs.readdirSync(p);\n\t};\n\tLockedFS.prototype.exists = function exists (p, cb) {\n\t var this$1 = this;\n\t\n\t this._mu.lock(function () {\n\t this$1._fs.exists(p, function (exists) {\n\t this$1._mu.unlock();\n\t cb(exists);\n\t });\n\t });\n\t};\n\tLockedFS.prototype.existsSync = function existsSync (p) {\n\t if (this._mu.isLocked()) {\n\t throw new Error('invalid sync call');\n\t }\n\t return this._fs.existsSync(p);\n\t};\n\tLockedFS.prototype.realpath = function realpath (p, cache, cb) {\n\t var this$1 = this;\n\t\n\t this._mu.lock(function () {\n\t this$1._fs.realpath(p, cache, function (err, resolvedPath) {\n\t this$1._mu.unlock();\n\t cb(err, resolvedPath);\n\t });\n\t });\n\t};\n\tLockedFS.prototype.realpathSync = function realpathSync (p, cache) {\n\t if (this._mu.isLocked()) {\n\t throw new Error('invalid sync call');\n\t }\n\t return this._fs.realpathSync(p, cache);\n\t};\n\tLockedFS.prototype.truncate = function truncate (p, len, cb) {\n\t var this$1 = this;\n\t\n\t this._mu.lock(function () {\n\t this$1._fs.truncate(p, len, function (err) {\n\t this$1._mu.unlock();\n\t cb(err);\n\t });\n\t });\n\t};\n\tLockedFS.prototype.truncateSync = function truncateSync (p, len) {\n\t if (this._mu.isLocked()) {\n\t throw new Error('invalid sync call');\n\t }\n\t return this._fs.truncateSync(p, len);\n\t};\n\tLockedFS.prototype.readFile = function readFile (fname, encoding, flag, cb) {\n\t var this$1 = this;\n\t\n\t this._mu.lock(function () {\n\t this$1._fs.readFile(fname, encoding, flag, function (err, data) {\n\t this$1._mu.unlock();\n\t cb(err, data);\n\t });\n\t });\n\t};\n\tLockedFS.prototype.readFileSync = function readFileSync (fname, encoding, flag) {\n\t if (this._mu.isLocked()) {\n\t throw new Error('invalid sync call');\n\t }\n\t return this._fs.readFileSync(fname, encoding, flag);\n\t};\n\tLockedFS.prototype.writeFile = function writeFile (fname, data, encoding, flag, mode, cb) {\n\t var this$1 = this;\n\t\n\t this._mu.lock(function () {\n\t this$1._fs.writeFile(fname, data, encoding, flag, mode, function (err) {\n\t this$1._mu.unlock();\n\t cb(err);\n\t });\n\t });\n\t};\n\tLockedFS.prototype.writeFileSync = function writeFileSync (fname, data, encoding, flag, mode) {\n\t if (this._mu.isLocked()) {\n\t throw new Error('invalid sync call');\n\t }\n\t return this._fs.writeFileSync(fname, data, encoding, flag, mode);\n\t};\n\tLockedFS.prototype.appendFile = function appendFile (fname, data, encoding, flag, mode, cb) {\n\t var this$1 = this;\n\t\n\t this._mu.lock(function () {\n\t this$1._fs.appendFile(fname, data, encoding, flag, mode, function (err) {\n\t this$1._mu.unlock();\n\t cb(err);\n\t });\n\t });\n\t};\n\tLockedFS.prototype.appendFileSync = function appendFileSync (fname, data, encoding, flag, mode) {\n\t if (this._mu.isLocked()) {\n\t throw new Error('invalid sync call');\n\t }\n\t return this._fs.appendFileSync(fname, data, encoding, flag, mode);\n\t};\n\tLockedFS.prototype.chmod = function chmod (p, isLchmod, mode, cb) {\n\t var this$1 = this;\n\t\n\t this._mu.lock(function () {\n\t this$1._fs.chmod(p, isLchmod, mode, function (err) {\n\t this$1._mu.unlock();\n\t cb(err);\n\t });\n\t });\n\t};\n\tLockedFS.prototype.chmodSync = function chmodSync (p, isLchmod, mode) {\n\t if (this._mu.isLocked()) {\n\t throw new Error('invalid sync call');\n\t }\n\t return this._fs.chmodSync(p, isLchmod, mode);\n\t};\n\tLockedFS.prototype.chown = function chown (p, isLchown, uid, gid, cb) {\n\t var this$1 = this;\n\t\n\t this._mu.lock(function () {\n\t this$1._fs.chown(p, isLchown, uid, gid, function (err) {\n\t this$1._mu.unlock();\n\t cb(err);\n\t });\n\t });\n\t};\n\tLockedFS.prototype.chownSync = function chownSync (p, isLchown, uid, gid) {\n\t if (this._mu.isLocked()) {\n\t throw new Error('invalid sync call');\n\t }\n\t return this._fs.chownSync(p, isLchown, uid, gid);\n\t};\n\tLockedFS.prototype.utimes = function utimes (p, atime, mtime, cb) {\n\t var this$1 = this;\n\t\n\t this._mu.lock(function () {\n\t this$1._fs.utimes(p, atime, mtime, function (err) {\n\t this$1._mu.unlock();\n\t cb(err);\n\t });\n\t });\n\t};\n\tLockedFS.prototype.utimesSync = function utimesSync (p, atime, mtime) {\n\t if (this._mu.isLocked()) {\n\t throw new Error('invalid sync call');\n\t }\n\t return this._fs.utimesSync(p, atime, mtime);\n\t};\n\tLockedFS.prototype.link = function link (srcpath, dstpath, cb) {\n\t var this$1 = this;\n\t\n\t this._mu.lock(function () {\n\t this$1._fs.link(srcpath, dstpath, function (err) {\n\t this$1._mu.unlock();\n\t cb(err);\n\t });\n\t });\n\t};\n\tLockedFS.prototype.linkSync = function linkSync (srcpath, dstpath) {\n\t if (this._mu.isLocked()) {\n\t throw new Error('invalid sync call');\n\t }\n\t return this._fs.linkSync(srcpath, dstpath);\n\t};\n\tLockedFS.prototype.symlink = function symlink (srcpath, dstpath, type, cb) {\n\t var this$1 = this;\n\t\n\t this._mu.lock(function () {\n\t this$1._fs.symlink(srcpath, dstpath, type, function (err) {\n\t this$1._mu.unlock();\n\t cb(err);\n\t });\n\t });\n\t};\n\tLockedFS.prototype.symlinkSync = function symlinkSync (srcpath, dstpath, type) {\n\t if (this._mu.isLocked()) {\n\t throw new Error('invalid sync call');\n\t }\n\t return this._fs.symlinkSync(srcpath, dstpath, type);\n\t};\n\tLockedFS.prototype.readlink = function readlink (p, cb) {\n\t var this$1 = this;\n\t\n\t this._mu.lock(function () {\n\t this$1._fs.readlink(p, function (err, linkString) {\n\t this$1._mu.unlock();\n\t cb(err, linkString);\n\t });\n\t });\n\t};\n\tLockedFS.prototype.readlinkSync = function readlinkSync (p) {\n\t if (this._mu.isLocked()) {\n\t throw new Error('invalid sync call');\n\t }\n\t return this._fs.readlinkSync(p);\n\t};\n\t\n\tvar deletionLogPath = '/.deletedFiles.log';\n\t/**\n\t * Given a read-only mode, makes it writable.\n\t */\n\tfunction makeModeWritable(mode) {\n\t return 146 | mode;\n\t}\n\tfunction getFlag(f) {\n\t return FileFlag.getFileFlag(f);\n\t}\n\t/**\n\t * Overlays a RO file to make it writable.\n\t */\n\tvar OverlayFile = (function (PreloadFile$$1) {\n\t function OverlayFile(fs, path$$1, flag, stats, data) {\n\t PreloadFile$$1.call(this, fs, path$$1, flag, stats, data);\n\t }\n\t\n\t if ( PreloadFile$$1 ) OverlayFile.__proto__ = PreloadFile$$1;\n\t OverlayFile.prototype = Object.create( PreloadFile$$1 && PreloadFile$$1.prototype );\n\t OverlayFile.prototype.constructor = OverlayFile;\n\t OverlayFile.prototype.sync = function sync (cb) {\n\t var this$1 = this;\n\t\n\t if (!this.isDirty()) {\n\t cb(null);\n\t return;\n\t }\n\t this._fs._syncAsync(this, function (err) {\n\t this$1.resetDirty();\n\t cb(err);\n\t });\n\t };\n\t OverlayFile.prototype.syncSync = function syncSync () {\n\t if (this.isDirty()) {\n\t this._fs._syncSync(this);\n\t this.resetDirty();\n\t }\n\t };\n\t OverlayFile.prototype.close = function close (cb) {\n\t this.sync(cb);\n\t };\n\t OverlayFile.prototype.closeSync = function closeSync () {\n\t this.syncSync();\n\t };\n\t\n\t return OverlayFile;\n\t}(PreloadFile));\n\t/**\n\t * OverlayFS makes a read-only filesystem writable by storing writes on a second,\n\t * writable file system. Deletes are persisted via metadata stored on the writable\n\t * file system.\n\t */\n\tvar UnlockedOverlayFS = (function (BaseFileSystem$$1) {\n\t function UnlockedOverlayFS(writable, readable) {\n\t BaseFileSystem$$1.call(this);\n\t this._isInitialized = false;\n\t this._initializeCallbacks = [];\n\t this._deletedFiles = {};\n\t this._deleteLog = '';\n\t // If 'true', we have scheduled a delete log update.\n\t this._deleteLogUpdatePending = false;\n\t // If 'true', a delete log update is needed after the scheduled delete log\n\t // update finishes.\n\t this._deleteLogUpdateNeeded = false;\n\t // If there was an error updating the delete log...\n\t this._deleteLogError = null;\n\t this._writable = writable;\n\t this._readable = readable;\n\t if (this._writable.isReadOnly()) {\n\t throw new ApiError(ErrorCode.EINVAL, \"Writable file system must be writable.\");\n\t }\n\t }\n\t\n\t if ( BaseFileSystem$$1 ) UnlockedOverlayFS.__proto__ = BaseFileSystem$$1;\n\t UnlockedOverlayFS.prototype = Object.create( BaseFileSystem$$1 && BaseFileSystem$$1.prototype );\n\t UnlockedOverlayFS.prototype.constructor = UnlockedOverlayFS;\n\t UnlockedOverlayFS.isAvailable = function isAvailable () {\n\t return true;\n\t };\n\t UnlockedOverlayFS.prototype.getOverlayedFileSystems = function getOverlayedFileSystems () {\n\t return {\n\t readable: this._readable,\n\t writable: this._writable\n\t };\n\t };\n\t UnlockedOverlayFS.prototype._syncAsync = function _syncAsync (file, cb) {\n\t var this$1 = this;\n\t\n\t this.createParentDirectoriesAsync(file.getPath(), function (err) {\n\t if (err) {\n\t return cb(err);\n\t }\n\t this$1._writable.writeFile(file.getPath(), file.getBuffer(), null, getFlag('w'), file.getStats().mode, cb);\n\t });\n\t };\n\t UnlockedOverlayFS.prototype._syncSync = function _syncSync (file) {\n\t this.createParentDirectories(file.getPath());\n\t this._writable.writeFileSync(file.getPath(), file.getBuffer(), null, getFlag('w'), file.getStats().mode);\n\t };\n\t UnlockedOverlayFS.prototype.getName = function getName () {\n\t return \"OverlayFS\";\n\t };\n\t /**\n\t * Called once to load up metadata stored on the writable file system.\n\t */\n\t UnlockedOverlayFS.prototype.initialize = function initialize (cb) {\n\t var this$1 = this;\n\t\n\t var callbackArray = this._initializeCallbacks;\n\t var end = function (e) {\n\t this$1._isInitialized = !e;\n\t this$1._initializeCallbacks = [];\n\t callbackArray.forEach((function (cb) { return cb(e); }));\n\t };\n\t // if we're already initialized, immediately invoke the callback\n\t if (this._isInitialized) {\n\t return cb();\n\t }\n\t callbackArray.push(cb);\n\t // The first call to initialize initializes, the rest wait for it to complete.\n\t if (callbackArray.length !== 1) {\n\t return;\n\t }\n\t // Read deletion log, process into metadata.\n\t this._writable.readFile(deletionLogPath, 'utf8', getFlag('r'), function (err, data) {\n\t if (err) {\n\t // ENOENT === Newly-instantiated file system, and thus empty log.\n\t if (err.errno !== ErrorCode.ENOENT) {\n\t return end(err);\n\t }\n\t }\n\t else {\n\t this$1._deleteLog = data;\n\t }\n\t this$1._reparseDeletionLog();\n\t end();\n\t });\n\t };\n\t UnlockedOverlayFS.prototype.isReadOnly = function isReadOnly () { return false; };\n\t UnlockedOverlayFS.prototype.supportsSynch = function supportsSynch () { return this._readable.supportsSynch() && this._writable.supportsSynch(); };\n\t UnlockedOverlayFS.prototype.supportsLinks = function supportsLinks () { return false; };\n\t UnlockedOverlayFS.prototype.supportsProps = function supportsProps () { return this._readable.supportsProps() && this._writable.supportsProps(); };\n\t UnlockedOverlayFS.prototype.getDeletionLog = function getDeletionLog () {\n\t return this._deleteLog;\n\t };\n\t UnlockedOverlayFS.prototype.restoreDeletionLog = function restoreDeletionLog (log) {\n\t this._deleteLog = log;\n\t this._reparseDeletionLog();\n\t this.updateLog('');\n\t };\n\t UnlockedOverlayFS.prototype.rename = function rename (oldPath, newPath, cb) {\n\t var this$1 = this;\n\t\n\t if (!this.checkInitAsync(cb) || this.checkPathAsync(oldPath, cb) || this.checkPathAsync(newPath, cb)) {\n\t return;\n\t }\n\t if (oldPath === deletionLogPath || newPath === deletionLogPath) {\n\t return cb(ApiError.EPERM('Cannot rename deletion log.'));\n\t }\n\t // nothing to do if paths match\n\t if (oldPath === newPath) {\n\t return cb();\n\t }\n\t this.stat(oldPath, false, function (oldErr, oldStats) {\n\t if (oldErr) {\n\t return cb(oldErr);\n\t }\n\t return this$1.stat(newPath, false, function (newErr, newStats) {\n\t var self = this$1;\n\t // precondition: both oldPath and newPath exist and are dirs.\n\t // decreases: |files|\n\t // Need to move *every file/folder* currently stored on\n\t // readable to its new location on writable.\n\t function copyDirContents(files) {\n\t var file = files.shift();\n\t if (!file) {\n\t return cb();\n\t }\n\t var oldFile = path.resolve(oldPath, file);\n\t var newFile = path.resolve(newPath, file);\n\t // Recursion! Should work for any nested files / folders.\n\t self.rename(oldFile, newFile, function (err) {\n\t if (err) {\n\t return cb(err);\n\t }\n\t copyDirContents(files);\n\t });\n\t }\n\t var mode = 511;\n\t // from linux's rename(2) manpage: oldpath can specify a\n\t // directory. In this case, newpath must either not exist, or\n\t // it must specify an empty directory.\n\t if (oldStats.isDirectory()) {\n\t if (newErr) {\n\t if (newErr.errno !== ErrorCode.ENOENT) {\n\t return cb(newErr);\n\t }\n\t return this$1._writable.exists(oldPath, function (exists) {\n\t // simple case - both old and new are on the writable layer\n\t if (exists) {\n\t return this$1._writable.rename(oldPath, newPath, cb);\n\t }\n\t this$1._writable.mkdir(newPath, mode, function (mkdirErr) {\n\t if (mkdirErr) {\n\t return cb(mkdirErr);\n\t }\n\t this$1._readable.readdir(oldPath, function (err, files) {\n\t if (err) {\n\t return cb();\n\t }\n\t copyDirContents(files);\n\t });\n\t });\n\t });\n\t }\n\t mode = newStats.mode;\n\t if (!newStats.isDirectory()) {\n\t return cb(ApiError.ENOTDIR(newPath));\n\t }\n\t this$1.readdir(newPath, function (readdirErr, files) {\n\t if (files && files.length) {\n\t return cb(ApiError.ENOTEMPTY(newPath));\n\t }\n\t this$1._readable.readdir(oldPath, function (err, files) {\n\t if (err) {\n\t return cb();\n\t }\n\t copyDirContents(files);\n\t });\n\t });\n\t }\n\t if (newStats && newStats.isDirectory()) {\n\t return cb(ApiError.EISDIR(newPath));\n\t }\n\t this$1.readFile(oldPath, null, getFlag('r'), function (err, data) {\n\t if (err) {\n\t return cb(err);\n\t }\n\t return this$1.writeFile(newPath, data, null, getFlag('w'), oldStats.mode, function (err) {\n\t if (err) {\n\t return cb(err);\n\t }\n\t return this$1.unlink(oldPath, cb);\n\t });\n\t });\n\t });\n\t });\n\t };\n\t UnlockedOverlayFS.prototype.renameSync = function renameSync (oldPath, newPath) {\n\t var this$1 = this;\n\t\n\t this.checkInitialized();\n\t this.checkPath(oldPath);\n\t this.checkPath(newPath);\n\t if (oldPath === deletionLogPath || newPath === deletionLogPath) {\n\t throw ApiError.EPERM('Cannot rename deletion log.');\n\t }\n\t // Write newPath using oldPath's contents, delete oldPath.\n\t var oldStats = this.statSync(oldPath, false);\n\t if (oldStats.isDirectory()) {\n\t // Optimization: Don't bother moving if old === new.\n\t if (oldPath === newPath) {\n\t return;\n\t }\n\t var mode = 511;\n\t if (this.existsSync(newPath)) {\n\t var stats = this.statSync(newPath, false);\n\t mode = stats.mode;\n\t if (stats.isDirectory()) {\n\t if (this.readdirSync(newPath).length > 0) {\n\t throw ApiError.ENOTEMPTY(newPath);\n\t }\n\t }\n\t else {\n\t throw ApiError.ENOTDIR(newPath);\n\t }\n\t }\n\t // Take care of writable first. Move any files there, or create an empty directory\n\t // if it doesn't exist.\n\t if (this._writable.existsSync(oldPath)) {\n\t this._writable.renameSync(oldPath, newPath);\n\t }\n\t else if (!this._writable.existsSync(newPath)) {\n\t this._writable.mkdirSync(newPath, mode);\n\t }\n\t // Need to move *every file/folder* currently stored on readable to its new location\n\t // on writable.\n\t if (this._readable.existsSync(oldPath)) {\n\t this._readable.readdirSync(oldPath).forEach(function (name) {\n\t // Recursion! Should work for any nested files / folders.\n\t this$1.renameSync(path.resolve(oldPath, name), path.resolve(newPath, name));\n\t });\n\t }\n\t }\n\t else {\n\t if (this.existsSync(newPath) && this.statSync(newPath, false).isDirectory()) {\n\t throw ApiError.EISDIR(newPath);\n\t }\n\t this.writeFileSync(newPath, this.readFileSync(oldPath, null, getFlag('r')), null, getFlag('w'), oldStats.mode);\n\t }\n\t if (oldPath !== newPath && this.existsSync(oldPath)) {\n\t this.unlinkSync(oldPath);\n\t }\n\t };\n\t UnlockedOverlayFS.prototype.stat = function stat (p, isLstat, cb) {\n\t var this$1 = this;\n\t\n\t if (!this.checkInitAsync(cb)) {\n\t return;\n\t }\n\t this._writable.stat(p, isLstat, function (err, stat) {\n\t if (err && err.errno === ErrorCode.ENOENT) {\n\t if (this$1._deletedFiles[p]) {\n\t cb(ApiError.ENOENT(p));\n\t }\n\t this$1._readable.stat(p, isLstat, function (err, stat) {\n\t if (stat) {\n\t // Make the oldStat's mode writable. Preserve the topmost\n\t // part of the mode, which specifies if it is a file or a\n\t // directory.\n\t stat = stat.clone();\n\t stat.mode = makeModeWritable(stat.mode);\n\t }\n\t cb(err, stat);\n\t });\n\t }\n\t else {\n\t cb(err, stat);\n\t }\n\t });\n\t };\n\t UnlockedOverlayFS.prototype.statSync = function statSync (p, isLstat) {\n\t this.checkInitialized();\n\t try {\n\t return this._writable.statSync(p, isLstat);\n\t }\n\t catch (e) {\n\t if (this._deletedFiles[p]) {\n\t throw ApiError.ENOENT(p);\n\t }\n\t var oldStat = this._readable.statSync(p, isLstat).clone();\n\t // Make the oldStat's mode writable. Preserve the topmost part of the\n\t // mode, which specifies if it is a file or a directory.\n\t oldStat.mode = makeModeWritable(oldStat.mode);\n\t return oldStat;\n\t }\n\t };\n\t UnlockedOverlayFS.prototype.open = function open (p, flag, mode, cb) {\n\t var this$1 = this;\n\t\n\t if (!this.checkInitAsync(cb) || this.checkPathAsync(p, cb)) {\n\t return;\n\t }\n\t this.stat(p, false, function (err, stats) {\n\t if (stats) {\n\t switch (flag.pathExistsAction()) {\n\t case ActionType.TRUNCATE_FILE:\n\t return this$1.createParentDirectoriesAsync(p, function (err) {\n\t if (err) {\n\t return cb(err);\n\t }\n\t this$1._writable.open(p, flag, mode, cb);\n\t });\n\t case ActionType.NOP:\n\t return this$1._writable.exists(p, function (exists) {\n\t if (exists) {\n\t this$1._writable.open(p, flag, mode, cb);\n\t }\n\t else {\n\t // at this point we know the stats object we got is from\n\t // the readable FS.\n\t stats = stats.clone();\n\t stats.mode = mode;\n\t this$1._readable.readFile(p, null, getFlag('r'), function (readFileErr, data) {\n\t if (readFileErr) {\n\t return cb(readFileErr);\n\t }\n\t if (stats.size === -1) {\n\t stats.size = data.length;\n\t }\n\t var f = new OverlayFile(this$1, p, flag, stats, data);\n\t cb(null, f);\n\t });\n\t }\n\t });\n\t default:\n\t return cb(ApiError.EEXIST(p));\n\t }\n\t }\n\t else {\n\t switch (flag.pathNotExistsAction()) {\n\t case ActionType.CREATE_FILE:\n\t return this$1.createParentDirectoriesAsync(p, function (err) {\n\t if (err) {\n\t return cb(err);\n\t }\n\t return this$1._writable.open(p, flag, mode, cb);\n\t });\n\t default:\n\t return cb(ApiError.ENOENT(p));\n\t }\n\t }\n\t });\n\t };\n\t UnlockedOverlayFS.prototype.openSync = function openSync (p, flag, mode) {\n\t this.checkInitialized();\n\t this.checkPath(p);\n\t if (p === deletionLogPath) {\n\t throw ApiError.EPERM('Cannot open deletion log.');\n\t }\n\t if (this.existsSync(p)) {\n\t switch (flag.pathExistsAction()) {\n\t case ActionType.TRUNCATE_FILE:\n\t this.createParentDirectories(p);\n\t return this._writable.openSync(p, flag, mode);\n\t case ActionType.NOP:\n\t if (this._writable.existsSync(p)) {\n\t return this._writable.openSync(p, flag, mode);\n\t }\n\t else {\n\t // Create an OverlayFile.\n\t var buf = this._readable.readFileSync(p, null, getFlag('r'));\n\t var stats = this._readable.statSync(p, false).clone();\n\t stats.mode = mode;\n\t return new OverlayFile(this, p, flag, stats, buf);\n\t }\n\t default:\n\t throw ApiError.EEXIST(p);\n\t }\n\t }\n\t else {\n\t switch (flag.pathNotExistsAction()) {\n\t case ActionType.CREATE_FILE:\n\t this.createParentDirectories(p);\n\t return this._writable.openSync(p, flag, mode);\n\t default:\n\t throw ApiError.ENOENT(p);\n\t }\n\t }\n\t };\n\t UnlockedOverlayFS.prototype.unlink = function unlink (p, cb) {\n\t var this$1 = this;\n\t\n\t if (!this.checkInitAsync(cb) || this.checkPathAsync(p, cb)) {\n\t return;\n\t }\n\t this.exists(p, function (exists) {\n\t if (!exists) {\n\t return cb(ApiError.ENOENT(p));\n\t }\n\t this$1._writable.exists(p, function (writableExists) {\n\t if (writableExists) {\n\t return this$1._writable.unlink(p, function (err) {\n\t if (err) {\n\t return cb(err);\n\t }\n\t this$1.exists(p, function (readableExists) {\n\t if (readableExists) {\n\t this$1.deletePath(p);\n\t }\n\t cb(null);\n\t });\n\t });\n\t }\n\t else {\n\t // if this only exists on the readable FS, add it to the\n\t // delete map.\n\t this$1.deletePath(p);\n\t cb(null);\n\t }\n\t });\n\t });\n\t };\n\t UnlockedOverlayFS.prototype.unlinkSync = function unlinkSync (p) {\n\t this.checkInitialized();\n\t this.checkPath(p);\n\t if (this.existsSync(p)) {\n\t if (this._writable.existsSync(p)) {\n\t this._writable.unlinkSync(p);\n\t }\n\t // if it still exists add to the delete log\n\t if (this.existsSync(p)) {\n\t this.deletePath(p);\n\t }\n\t }\n\t else {\n\t throw ApiError.ENOENT(p);\n\t }\n\t };\n\t UnlockedOverlayFS.prototype.rmdir = function rmdir (p, cb) {\n\t var this$1 = this;\n\t\n\t if (!this.checkInitAsync(cb)) {\n\t return;\n\t }\n\t var rmdirLower = function () {\n\t this$1.readdir(p, function (err, files) {\n\t if (err) {\n\t return cb(err);\n\t }\n\t if (files.length) {\n\t return cb(ApiError.ENOTEMPTY(p));\n\t }\n\t this$1.deletePath(p);\n\t cb(null);\n\t });\n\t };\n\t this.exists(p, function (exists) {\n\t if (!exists) {\n\t return cb(ApiError.ENOENT(p));\n\t }\n\t this$1._writable.exists(p, function (writableExists) {\n\t if (writableExists) {\n\t this$1._writable.rmdir(p, function (err) {\n\t if (err) {\n\t return cb(err);\n\t }\n\t this$1._readable.exists(p, function (readableExists) {\n\t if (readableExists) {\n\t rmdirLower();\n\t }\n\t else {\n\t cb();\n\t }\n\t });\n\t });\n\t }\n\t else {\n\t rmdirLower();\n\t }\n\t });\n\t });\n\t };\n\t UnlockedOverlayFS.prototype.rmdirSync = function rmdirSync (p) {\n\t this.checkInitialized();\n\t if (this.existsSync(p)) {\n\t if (this._writable.existsSync(p)) {\n\t this._writable.rmdirSync(p);\n\t }\n\t if (this.existsSync(p)) {\n\t // Check if directory is empty.\n\t if (this.readdirSync(p).length > 0) {\n\t throw ApiError.ENOTEMPTY(p);\n\t }\n\t else {\n\t this.deletePath(p);\n\t }\n\t }\n\t }\n\t else {\n\t throw ApiError.ENOENT(p);\n\t }\n\t };\n\t UnlockedOverlayFS.prototype.mkdir = function mkdir (p, mode, cb) {\n\t var this$1 = this;\n\t\n\t if (!this.checkInitAsync(cb)) {\n\t return;\n\t }\n\t this.exists(p, function (exists) {\n\t if (exists) {\n\t return cb(ApiError.EEXIST(p));\n\t }\n\t // The below will throw should any of the parent directories\n\t // fail to exist on _writable.\n\t this$1.createParentDirectoriesAsync(p, function (err) {\n\t if (err) {\n\t return cb(err);\n\t }\n\t this$1._writable.mkdir(p, mode, cb);\n\t });\n\t });\n\t };\n\t UnlockedOverlayFS.prototype.mkdirSync = function mkdirSync (p, mode) {\n\t this.checkInitialized();\n\t if (this.existsSync(p)) {\n\t throw ApiError.EEXIST(p);\n\t }\n\t else {\n\t // The below will throw should any of the parent directories fail to exist\n\t // on _writable.\n\t this.createParentDirectories(p);\n\t this._writable.mkdirSync(p, mode);\n\t }\n\t };\n\t UnlockedOverlayFS.prototype.readdir = function readdir (p, cb) {\n\t var this$1 = this;\n\t\n\t if (!this.checkInitAsync(cb)) {\n\t return;\n\t }\n\t this.stat(p, false, function (err, dirStats) {\n\t if (err) {\n\t return cb(err);\n\t }\n\t if (!dirStats.isDirectory()) {\n\t return cb(ApiError.ENOTDIR(p));\n\t }\n\t this$1._writable.readdir(p, function (err, wFiles) {\n\t if (err && err.code !== 'ENOENT') {\n\t return cb(err);\n\t }\n\t else if (err || !wFiles) {\n\t wFiles = [];\n\t }\n\t this$1._readable.readdir(p, function (err, rFiles) {\n\t // if the directory doesn't exist on the lower FS set rFiles\n\t // here to simplify the following code.\n\t if (err || !rFiles) {\n\t rFiles = [];\n\t }\n\t // Readdir in both, check delete log on read-only file system's files, merge, return.\n\t var seenMap = {};\n\t var filtered = wFiles.concat(rFiles.filter(function (fPath) { return !this$1._deletedFiles[(p + \"/\" + fPath)]; })).filter(function (fPath) {\n\t // Remove duplicates.\n\t var result = !seenMap[fPath];\n\t seenMap[fPath] = true;\n\t return result;\n\t });\n\t cb(null, filtered);\n\t });\n\t });\n\t });\n\t };\n\t UnlockedOverlayFS.prototype.readdirSync = function readdirSync (p) {\n\t var this$1 = this;\n\t\n\t this.checkInitialized();\n\t var dirStats = this.statSync(p, false);\n\t if (!dirStats.isDirectory()) {\n\t throw ApiError.ENOTDIR(p);\n\t }\n\t // Readdir in both, check delete log on RO file system's listing, merge, return.\n\t var contents = [];\n\t try {\n\t contents = contents.concat(this._writable.readdirSync(p));\n\t }\n\t catch (e) {\n\t }\n\t try {\n\t contents = contents.concat(this._readable.readdirSync(p).filter(function (fPath) { return !this$1._deletedFiles[(p + \"/\" + fPath)]; }));\n\t }\n\t catch (e) {\n\t }\n\t var seenMap = {};\n\t return contents.filter(function (fileP) {\n\t var result = !seenMap[fileP];\n\t seenMap[fileP] = true;\n\t return result;\n\t });\n\t };\n\t UnlockedOverlayFS.prototype.exists = function exists (p, cb) {\n\t var this$1 = this;\n\t\n\t // Cannot pass an error back to callback, so throw an exception instead\n\t // if not initialized.\n\t this.checkInitialized();\n\t this._writable.exists(p, function (existsWritable) {\n\t if (existsWritable) {\n\t return cb(true);\n\t }\n\t this$1._readable.exists(p, function (existsReadable) {\n\t cb(existsReadable && this$1._deletedFiles[p] !== true);\n\t });\n\t });\n\t };\n\t UnlockedOverlayFS.prototype.existsSync = function existsSync (p) {\n\t this.checkInitialized();\n\t return this._writable.existsSync(p) || (this._readable.existsSync(p) && this._deletedFiles[p] !== true);\n\t };\n\t UnlockedOverlayFS.prototype.chmod = function chmod (p, isLchmod, mode, cb) {\n\t var this$1 = this;\n\t\n\t if (!this.checkInitAsync(cb)) {\n\t return;\n\t }\n\t this.operateOnWritableAsync(p, function (err) {\n\t if (err) {\n\t return cb(err);\n\t }\n\t else {\n\t this$1._writable.chmod(p, isLchmod, mode, cb);\n\t }\n\t });\n\t };\n\t UnlockedOverlayFS.prototype.chmodSync = function chmodSync (p, isLchmod, mode) {\n\t var this$1 = this;\n\t\n\t this.checkInitialized();\n\t this.operateOnWritable(p, function () {\n\t this$1._writable.chmodSync(p, isLchmod, mode);\n\t });\n\t };\n\t UnlockedOverlayFS.prototype.chown = function chown (p, isLchmod, uid, gid, cb) {\n\t var this$1 = this;\n\t\n\t if (!this.checkInitAsync(cb)) {\n\t return;\n\t }\n\t this.operateOnWritableAsync(p, function (err) {\n\t if (err) {\n\t return cb(err);\n\t }\n\t else {\n\t this$1._writable.chown(p, isLchmod, uid, gid, cb);\n\t }\n\t });\n\t };\n\t UnlockedOverlayFS.prototype.chownSync = function chownSync (p, isLchown, uid, gid) {\n\t var this$1 = this;\n\t\n\t this.checkInitialized();\n\t this.operateOnWritable(p, function () {\n\t this$1._writable.chownSync(p, isLchown, uid, gid);\n\t });\n\t };\n\t UnlockedOverlayFS.prototype.utimes = function utimes (p, atime, mtime, cb) {\n\t var this$1 = this;\n\t\n\t if (!this.checkInitAsync(cb)) {\n\t return;\n\t }\n\t this.operateOnWritableAsync(p, function (err) {\n\t if (err) {\n\t return cb(err);\n\t }\n\t else {\n\t this$1._writable.utimes(p, atime, mtime, cb);\n\t }\n\t });\n\t };\n\t UnlockedOverlayFS.prototype.utimesSync = function utimesSync (p, atime, mtime) {\n\t var this$1 = this;\n\t\n\t this.checkInitialized();\n\t this.operateOnWritable(p, function () {\n\t this$1._writable.utimesSync(p, atime, mtime);\n\t });\n\t };\n\t UnlockedOverlayFS.prototype.deletePath = function deletePath (p) {\n\t this._deletedFiles[p] = true;\n\t this.updateLog((\"d\" + p + \"\\n\"));\n\t };\n\t UnlockedOverlayFS.prototype.updateLog = function updateLog (addition) {\n\t var this$1 = this;\n\t\n\t this._deleteLog += addition;\n\t if (this._deleteLogUpdatePending) {\n\t this._deleteLogUpdateNeeded = true;\n\t }\n\t else {\n\t this._deleteLogUpdatePending = true;\n\t this._writable.writeFile(deletionLogPath, this._deleteLog, 'utf8', FileFlag.getFileFlag('w'), 420, function (e) {\n\t this$1._deleteLogUpdatePending = false;\n\t if (e) {\n\t this$1._deleteLogError = e;\n\t }\n\t else if (this$1._deleteLogUpdateNeeded) {\n\t this$1._deleteLogUpdateNeeded = false;\n\t this$1.updateLog('');\n\t }\n\t });\n\t }\n\t };\n\t UnlockedOverlayFS.prototype._reparseDeletionLog = function _reparseDeletionLog () {\n\t var this$1 = this;\n\t\n\t this._deletedFiles = {};\n\t this._deleteLog.split('\\n').forEach(function (path$$1) {\n\t // If the log entry begins w/ 'd', it's a deletion.\n\t this$1._deletedFiles[path$$1.slice(1)] = path$$1.slice(0, 1) === 'd';\n\t });\n\t };\n\t UnlockedOverlayFS.prototype.checkInitialized = function checkInitialized () {\n\t if (!this._isInitialized) {\n\t throw new ApiError(ErrorCode.EPERM, \"OverlayFS is not initialized. Please initialize OverlayFS using its initialize() method before using it.\");\n\t }\n\t else if (this._deleteLogError !== null) {\n\t var e = this._deleteLogError;\n\t this._deleteLogError = null;\n\t throw e;\n\t }\n\t };\n\t UnlockedOverlayFS.prototype.checkInitAsync = function checkInitAsync (cb) {\n\t if (!this._isInitialized) {\n\t cb(new ApiError(ErrorCode.EPERM, \"OverlayFS is not initialized. Please initialize OverlayFS using its initialize() method before using it.\"));\n\t return false;\n\t }\n\t else if (this._deleteLogError !== null) {\n\t var e = this._deleteLogError;\n\t this._deleteLogError = null;\n\t cb(e);\n\t return false;\n\t }\n\t return true;\n\t };\n\t UnlockedOverlayFS.prototype.checkPath = function checkPath (p) {\n\t if (p === deletionLogPath) {\n\t throw ApiError.EPERM(p);\n\t }\n\t };\n\t UnlockedOverlayFS.prototype.checkPathAsync = function checkPathAsync (p, cb) {\n\t if (p === deletionLogPath) {\n\t cb(ApiError.EPERM(p));\n\t return true;\n\t }\n\t return false;\n\t };\n\t UnlockedOverlayFS.prototype.createParentDirectoriesAsync = function createParentDirectoriesAsync (p, cb) {\n\t var parent = path.dirname(p);\n\t var toCreate = [];\n\t var self = this;\n\t this._writable.stat(parent, false, statDone);\n\t function statDone(err, stat) {\n\t if (err) {\n\t toCreate.push(parent);\n\t parent = path.dirname(parent);\n\t self._writable.stat(parent, false, statDone);\n\t }\n\t else {\n\t createParents();\n\t }\n\t }\n\t function createParents() {\n\t if (!toCreate.length) {\n\t return cb();\n\t }\n\t var dir = toCreate.pop();\n\t self._readable.stat(dir, false, function (err, stats) {\n\t // stop if we couldn't read the dir\n\t if (!stats) {\n\t return cb();\n\t }\n\t self._writable.mkdir(dir, stats.mode, function (err) {\n\t if (err) {\n\t return cb(err);\n\t }\n\t createParents();\n\t });\n\t });\n\t }\n\t };\n\t /**\n\t * With the given path, create the needed parent directories on the writable storage\n\t * should they not exist. Use modes from the read-only storage.\n\t */\n\t UnlockedOverlayFS.prototype.createParentDirectories = function createParentDirectories (p) {\n\t var this$1 = this;\n\t\n\t var parent = path.dirname(p), toCreate = [];\n\t while (!this._writable.existsSync(parent)) {\n\t toCreate.push(parent);\n\t parent = path.dirname(parent);\n\t }\n\t toCreate = toCreate.reverse();\n\t toCreate.forEach(function (p) {\n\t this$1._writable.mkdirSync(p, this$1.statSync(p, false).mode);\n\t });\n\t };\n\t /**\n\t * Helper function:\n\t * - Ensures p is on writable before proceeding. Throws an error if it doesn't exist.\n\t * - Calls f to perform operation on writable.\n\t */\n\t UnlockedOverlayFS.prototype.operateOnWritable = function operateOnWritable (p, f) {\n\t if (this.existsSync(p)) {\n\t if (!this._writable.existsSync(p)) {\n\t // File is on readable storage. Copy to writable storage before\n\t // changing its mode.\n\t this.copyToWritable(p);\n\t }\n\t f();\n\t }\n\t else {\n\t throw ApiError.ENOENT(p);\n\t }\n\t };\n\t UnlockedOverlayFS.prototype.operateOnWritableAsync = function operateOnWritableAsync (p, cb) {\n\t var this$1 = this;\n\t\n\t this.exists(p, function (exists) {\n\t if (!exists) {\n\t return cb(ApiError.ENOENT(p));\n\t }\n\t this$1._writable.exists(p, function (existsWritable) {\n\t if (existsWritable) {\n\t cb();\n\t }\n\t else {\n\t return this$1.copyToWritableAsync(p, cb);\n\t }\n\t });\n\t });\n\t };\n\t /**\n\t * Copy from readable to writable storage.\n\t * PRECONDITION: File does not exist on writable storage.\n\t */\n\t UnlockedOverlayFS.prototype.copyToWritable = function copyToWritable (p) {\n\t var pStats = this.statSync(p, false);\n\t if (pStats.isDirectory()) {\n\t this._writable.mkdirSync(p, pStats.mode);\n\t }\n\t else {\n\t this.writeFileSync(p, this._readable.readFileSync(p, null, getFlag('r')), null, getFlag('w'), this.statSync(p, false).mode);\n\t }\n\t };\n\t UnlockedOverlayFS.prototype.copyToWritableAsync = function copyToWritableAsync (p, cb) {\n\t var this$1 = this;\n\t\n\t this.stat(p, false, function (err, pStats) {\n\t if (err) {\n\t return cb(err);\n\t }\n\t if (pStats.isDirectory()) {\n\t return this$1._writable.mkdir(p, pStats.mode, cb);\n\t }\n\t // need to copy file.\n\t this$1._readable.readFile(p, null, getFlag('r'), function (err, data) {\n\t if (err) {\n\t return cb(err);\n\t }\n\t this$1.writeFile(p, data, null, getFlag('w'), pStats.mode, cb);\n\t });\n\t });\n\t };\n\t\n\t return UnlockedOverlayFS;\n\t}(BaseFileSystem));\n\tvar OverlayFS = (function (LockedFS$$1) {\n\t function OverlayFS(writable, readable) {\n\t LockedFS$$1.call(this, new UnlockedOverlayFS(writable, readable));\n\t }\n\t\n\t if ( LockedFS$$1 ) OverlayFS.__proto__ = LockedFS$$1;\n\t OverlayFS.prototype = Object.create( LockedFS$$1 && LockedFS$$1.prototype );\n\t OverlayFS.prototype.constructor = OverlayFS;\n\t OverlayFS.isAvailable = function isAvailable () {\n\t return UnlockedOverlayFS.isAvailable();\n\t };\n\t\n\t OverlayFS.prototype.initialize = function initialize (cb) {\n\t LockedFS$$1.prototype.initialize.call(this, cb);\n\t };\n\t OverlayFS.prototype.getOverlayedFileSystems = function getOverlayedFileSystems () {\n\t return LockedFS$$1.prototype.getFSUnlocked.call(this).getOverlayedFileSystems();\n\t };\n\t OverlayFS.prototype.unwrap = function unwrap () {\n\t return LockedFS$$1.prototype.getFSUnlocked.call(this);\n\t };\n\t\n\t return OverlayFS;\n\t}(LockedFS));\n\t\n\tvar SpecialArgType;\n\t(function (SpecialArgType) {\n\t // Callback\n\t SpecialArgType[SpecialArgType[\"CB\"] = 0] = \"CB\";\n\t // File descriptor\n\t SpecialArgType[SpecialArgType[\"FD\"] = 1] = \"FD\";\n\t // API error\n\t SpecialArgType[SpecialArgType[\"API_ERROR\"] = 2] = \"API_ERROR\";\n\t // Stats object\n\t SpecialArgType[SpecialArgType[\"STATS\"] = 3] = \"STATS\";\n\t // Initial probe for file system information.\n\t SpecialArgType[SpecialArgType[\"PROBE\"] = 4] = \"PROBE\";\n\t // FileFlag object.\n\t SpecialArgType[SpecialArgType[\"FILEFLAG\"] = 5] = \"FILEFLAG\";\n\t // Buffer object.\n\t SpecialArgType[SpecialArgType[\"BUFFER\"] = 6] = \"BUFFER\";\n\t // Generic Error object.\n\t SpecialArgType[SpecialArgType[\"ERROR\"] = 7] = \"ERROR\";\n\t})(SpecialArgType || (SpecialArgType = {}));\n\t/**\n\t * Converts callback arguments into ICallbackArgument objects, and back\n\t * again.\n\t */\n\tvar CallbackArgumentConverter = function CallbackArgumentConverter() {\n\t this._callbacks = {};\n\t this._nextId = 0;\n\t};\n\tCallbackArgumentConverter.prototype.toRemoteArg = function toRemoteArg (cb) {\n\t var id = this._nextId++;\n\t this._callbacks[id] = cb;\n\t return {\n\t type: SpecialArgType.CB,\n\t id: id\n\t };\n\t};\n\tCallbackArgumentConverter.prototype.toLocalArg = function toLocalArg (id) {\n\t var cb = this._callbacks[id];\n\t delete this._callbacks[id];\n\t return cb;\n\t};\n\tvar FileDescriptorArgumentConverter = function FileDescriptorArgumentConverter() {\n\t this._fileDescriptors = {};\n\t this._nextId = 0;\n\t};\n\tFileDescriptorArgumentConverter.prototype.toRemoteArg = function toRemoteArg (fd, p, flag, cb) {\n\t var id = this._nextId++;\n\t var data;\n\t var stat;\n\t this._fileDescriptors[id] = fd;\n\t // Extract needed information asynchronously.\n\t fd.stat(function (err, stats) {\n\t if (err) {\n\t cb(err);\n\t }\n\t else {\n\t stat = bufferToTransferrableObject(stats.toBuffer());\n\t // If it's a readable flag, we need to grab contents.\n\t if (flag.isReadable()) {\n\t fd.read(new Buffer(stats.size), 0, stats.size, 0, function (err, bytesRead, buff) {\n\t if (err) {\n\t cb(err);\n\t }\n\t else {\n\t data = bufferToTransferrableObject(buff);\n\t cb(null, {\n\t type: SpecialArgType.FD,\n\t id: id,\n\t data: data,\n\t stat: stat,\n\t path: p,\n\t flag: flag.getFlagString()\n\t });\n\t }\n\t });\n\t }\n\t else {\n\t // File is not readable, which means writing to it will append or\n\t // truncate/replace existing contents. Return an empty arraybuffer.\n\t cb(null, {\n\t type: SpecialArgType.FD,\n\t id: id,\n\t data: new ArrayBuffer(0),\n\t stat: stat,\n\t path: p,\n\t flag: flag.getFlagString()\n\t });\n\t }\n\t }\n\t });\n\t};\n\tFileDescriptorArgumentConverter.prototype.applyFdAPIRequest = function applyFdAPIRequest (request, cb) {\n\t var this$1 = this;\n\t\n\t var fdArg = request.args[0];\n\t this._applyFdChanges(fdArg, function (err, fd) {\n\t if (err) {\n\t cb(err);\n\t }\n\t else {\n\t // Apply method on now-changed file descriptor.\n\t fd[request.method](function (e) {\n\t if (request.method === 'close') {\n\t delete this$1._fileDescriptors[fdArg.id];\n\t }\n\t cb(e);\n\t });\n\t }\n\t });\n\t};\n\tFileDescriptorArgumentConverter.prototype._applyFdChanges = function _applyFdChanges (remoteFd, cb) {\n\t var fd = this._fileDescriptors[remoteFd.id], data = transferrableObjectToBuffer(remoteFd.data), remoteStats = Stats.fromBuffer(transferrableObjectToBuffer(remoteFd.stat));\n\t // Write data if the file is writable.\n\t var flag = FileFlag.getFileFlag(remoteFd.flag);\n\t if (flag.isWriteable()) {\n\t // Appendable: Write to end of file.\n\t // Writeable: Replace entire contents of file.\n\t fd.write(data, 0, data.length, flag.isAppendable() ? fd.getPos() : 0, function (e) {\n\t function applyStatChanges() {\n\t // Check if mode changed.\n\t fd.stat(function (e, stats) {\n\t if (e) {\n\t cb(e);\n\t }\n\t else {\n\t if (stats.mode !== remoteStats.mode) {\n\t fd.chmod(remoteStats.mode, function (e) {\n\t cb(e, fd);\n\t });\n\t }\n\t else {\n\t cb(e, fd);\n\t }\n\t }\n\t });\n\t }\n\t if (e) {\n\t cb(e);\n\t }\n\t else {\n\t // If writeable & not appendable, we need to ensure file contents are\n\t // identical to those from the remote FD. Thus, we truncate to the\n\t // length of the remote file.\n\t if (!flag.isAppendable()) {\n\t fd.truncate(data.length, function () {\n\t applyStatChanges();\n\t });\n\t }\n\t else {\n\t applyStatChanges();\n\t }\n\t }\n\t });\n\t }\n\t else {\n\t cb(null, fd);\n\t }\n\t};\n\tfunction apiErrorLocal2Remote(e) {\n\t return {\n\t type: SpecialArgType.API_ERROR,\n\t errorData: bufferToTransferrableObject(e.writeToBuffer())\n\t };\n\t}\n\tfunction apiErrorRemote2Local(e) {\n\t return ApiError.fromBuffer(transferrableObjectToBuffer(e.errorData));\n\t}\n\tfunction errorLocal2Remote(e) {\n\t return {\n\t type: SpecialArgType.ERROR,\n\t name: e.name,\n\t message: e.message,\n\t stack: e.stack\n\t };\n\t}\n\tfunction errorRemote2Local(e) {\n\t var cnstr = global$1[e.name];\n\t if (typeof (cnstr) !== 'function') {\n\t cnstr = Error;\n\t }\n\t var err = new cnstr(e.message);\n\t err.stack = e.stack;\n\t return err;\n\t}\n\tfunction statsLocal2Remote(stats) {\n\t return {\n\t type: SpecialArgType.STATS,\n\t statsData: bufferToTransferrableObject(stats.toBuffer())\n\t };\n\t}\n\tfunction statsRemote2Local(stats) {\n\t return Stats.fromBuffer(transferrableObjectToBuffer(stats.statsData));\n\t}\n\tfunction fileFlagLocal2Remote(flag) {\n\t return {\n\t type: SpecialArgType.FILEFLAG,\n\t flagStr: flag.getFlagString()\n\t };\n\t}\n\tfunction fileFlagRemote2Local(remoteFlag) {\n\t return FileFlag.getFileFlag(remoteFlag.flagStr);\n\t}\n\tfunction bufferToTransferrableObject(buff) {\n\t return buffer2ArrayBuffer(buff);\n\t}\n\tfunction transferrableObjectToBuffer(buff) {\n\t return arrayBuffer2Buffer(buff);\n\t}\n\tfunction bufferLocal2Remote(buff) {\n\t return {\n\t type: SpecialArgType.BUFFER,\n\t data: bufferToTransferrableObject(buff)\n\t };\n\t}\n\tfunction bufferRemote2Local(buffArg) {\n\t return transferrableObjectToBuffer(buffArg.data);\n\t}\n\tfunction isAPIRequest(data) {\n\t return data && typeof data === 'object' && data.hasOwnProperty('browserfsMessage') && data['browserfsMessage'];\n\t}\n\tfunction isAPIResponse(data) {\n\t return data && typeof data === 'object' && data.hasOwnProperty('browserfsMessage') && data['browserfsMessage'];\n\t}\n\t/**\n\t * Represents a remote file in a different worker/thread.\n\t */\n\tvar WorkerFile = (function (PreloadFile$$1) {\n\t function WorkerFile(_fs, _path, _flag, _stat, remoteFdId, contents) {\n\t PreloadFile$$1.call(this, _fs, _path, _flag, _stat, contents);\n\t this._remoteFdId = remoteFdId;\n\t }\n\t\n\t if ( PreloadFile$$1 ) WorkerFile.__proto__ = PreloadFile$$1;\n\t WorkerFile.prototype = Object.create( PreloadFile$$1 && PreloadFile$$1.prototype );\n\t WorkerFile.prototype.constructor = WorkerFile;\n\t WorkerFile.prototype.getRemoteFdId = function getRemoteFdId () {\n\t return this._remoteFdId;\n\t };\n\t WorkerFile.prototype.toRemoteArg = function toRemoteArg () {\n\t return {\n\t type: SpecialArgType.FD,\n\t id: this._remoteFdId,\n\t data: bufferToTransferrableObject(this.getBuffer()),\n\t stat: bufferToTransferrableObject(this.getStats().toBuffer()),\n\t path: this.getPath(),\n\t flag: this.getFlag().getFlagString()\n\t };\n\t };\n\t WorkerFile.prototype.sync = function sync (cb) {\n\t this._syncClose('sync', cb);\n\t };\n\t WorkerFile.prototype.close = function close (cb) {\n\t this._syncClose('close', cb);\n\t };\n\t WorkerFile.prototype._syncClose = function _syncClose (type, cb) {\n\t var this$1 = this;\n\t\n\t if (this.isDirty()) {\n\t this._fs.syncClose(type, this, function (e) {\n\t if (!e) {\n\t this$1.resetDirty();\n\t }\n\t cb(e);\n\t });\n\t }\n\t else {\n\t cb();\n\t }\n\t };\n\t\n\t return WorkerFile;\n\t}(PreloadFile));\n\t/**\n\t * WorkerFS lets you access a BrowserFS instance that is running in a different\n\t * JavaScript context (e.g. access BrowserFS in one of your WebWorkers, or\n\t * access BrowserFS running on the main page from a WebWorker).\n\t *\n\t * For example, to have a WebWorker access files in the main browser thread,\n\t * do the following:\n\t *\n\t * MAIN BROWSER THREAD:\n\t * ```\n\t * // Listen for remote file system requests.\n\t * BrowserFS.FileSystem.WorkerFS.attachRemoteListener(webWorkerObject);\n\t * ``\n\t *\n\t * WEBWORKER THREAD:\n\t * ```\n\t * // Set the remote file system as the root file system.\n\t * BrowserFS.initialize(new BrowserFS.FileSystem.WorkerFS(self));\n\t * ```\n\t *\n\t * Note that synchronous operations are not permitted on the WorkerFS, regardless\n\t * of the configuration option of the remote FS.\n\t */\n\tvar WorkerFS = (function (BaseFileSystem$$1) {\n\t function WorkerFS(worker) {\n\t var this$1 = this;\n\t\n\t BaseFileSystem$$1.call(this);\n\t this._callbackConverter = new CallbackArgumentConverter();\n\t this._isInitialized = false;\n\t this._isReadOnly = false;\n\t this._supportLinks = false;\n\t this._supportProps = false;\n\t this._worker = worker;\n\t this._worker.addEventListener('message', function (e) {\n\t var resp = e.data;\n\t if (isAPIResponse(resp)) {\n\t var i;\n\t var args = resp.args;\n\t var fixedArgs = new Array(args.length);\n\t // Dispatch event to correct id.\n\t for (i = 0; i < fixedArgs.length; i++) {\n\t fixedArgs[i] = this$1._argRemote2Local(args[i]);\n\t }\n\t this$1._callbackConverter.toLocalArg(resp.cbId).apply(null, fixedArgs);\n\t }\n\t });\n\t }\n\t\n\t if ( BaseFileSystem$$1 ) WorkerFS.__proto__ = BaseFileSystem$$1;\n\t WorkerFS.prototype = Object.create( BaseFileSystem$$1 && BaseFileSystem$$1.prototype );\n\t WorkerFS.prototype.constructor = WorkerFS;\n\t WorkerFS.isAvailable = function isAvailable () {\n\t return typeof (importScripts) !== 'undefined' || typeof (Worker) !== 'undefined';\n\t };\n\t /**\n\t * Attaches a listener to the remote worker for file system requests.\n\t */\n\t WorkerFS.attachRemoteListener = function attachRemoteListener (worker) {\n\t var fdConverter = new FileDescriptorArgumentConverter();\n\t function argLocal2Remote(arg, requestArgs, cb) {\n\t switch (typeof arg) {\n\t case 'object':\n\t if (arg instanceof Stats) {\n\t cb(null, statsLocal2Remote(arg));\n\t }\n\t else if (arg instanceof ApiError) {\n\t cb(null, apiErrorLocal2Remote(arg));\n\t }\n\t else if (arg instanceof BaseFile) {\n\t // Pass in p and flags from original request.\n\t cb(null, fdConverter.toRemoteArg(arg, requestArgs[0], requestArgs[1], cb));\n\t }\n\t else if (arg instanceof FileFlag) {\n\t cb(null, fileFlagLocal2Remote(arg));\n\t }\n\t else if (arg instanceof Buffer) {\n\t cb(null, bufferLocal2Remote(arg));\n\t }\n\t else if (arg instanceof Error) {\n\t cb(null, errorLocal2Remote(arg));\n\t }\n\t else {\n\t cb(null, arg);\n\t }\n\t break;\n\t default:\n\t cb(null, arg);\n\t break;\n\t }\n\t }\n\t function argRemote2Local(arg, fixedRequestArgs) {\n\t if (!arg) {\n\t return arg;\n\t }\n\t switch (typeof arg) {\n\t case 'object':\n\t if (typeof arg['type'] === 'number') {\n\t var specialArg = arg;\n\t switch (specialArg.type) {\n\t case SpecialArgType.CB:\n\t var cbId = arg.id;\n\t return function () {\n\t var arguments$1 = arguments;\n\t\n\t var i;\n\t var fixedArgs = new Array(arguments.length);\n\t var message, countdown = arguments.length;\n\t function abortAndSendError(err) {\n\t if (countdown > 0) {\n\t countdown = -1;\n\t message = {\n\t browserfsMessage: true,\n\t cbId: cbId,\n\t args: [apiErrorLocal2Remote(err)]\n\t };\n\t worker.postMessage(message);\n\t }\n\t }\n\t for (i = 0; i < arguments.length; i++) {\n\t // Capture i and argument.\n\t (function (i, arg) {\n\t argLocal2Remote(arg, fixedRequestArgs, function (err, fixedArg) {\n\t fixedArgs[i] = fixedArg;\n\t if (err) {\n\t abortAndSendError(err);\n\t }\n\t else if (--countdown === 0) {\n\t message = {\n\t browserfsMessage: true,\n\t cbId: cbId,\n\t args: fixedArgs\n\t };\n\t worker.postMessage(message);\n\t }\n\t });\n\t })(i, arguments$1[i]);\n\t }\n\t if (arguments.length === 0) {\n\t message = {\n\t browserfsMessage: true,\n\t cbId: cbId,\n\t args: fixedArgs\n\t };\n\t worker.postMessage(message);\n\t }\n\t };\n\t case SpecialArgType.API_ERROR:\n\t return apiErrorRemote2Local(specialArg);\n\t case SpecialArgType.STATS:\n\t return statsRemote2Local(specialArg);\n\t case SpecialArgType.FILEFLAG:\n\t return fileFlagRemote2Local(specialArg);\n\t case SpecialArgType.BUFFER:\n\t return bufferRemote2Local(specialArg);\n\t case SpecialArgType.ERROR:\n\t return errorRemote2Local(specialArg);\n\t default:\n\t // No idea what this is.\n\t return arg;\n\t }\n\t }\n\t else {\n\t return arg;\n\t }\n\t default:\n\t return arg;\n\t }\n\t }\n\t worker.addEventListener('message', function (e) {\n\t var request = e.data;\n\t if (isAPIRequest(request)) {\n\t var args = request.args, fixedArgs = new Array(args.length);\n\t switch (request.method) {\n\t case 'close':\n\t case 'sync':\n\t (function () {\n\t // File descriptor-relative methods.\n\t var remoteCb = args[1];\n\t fdConverter.applyFdAPIRequest(request, function (err) {\n\t // Send response.\n\t var response = {\n\t browserfsMessage: true,\n\t cbId: remoteCb.id,\n\t args: err ? [apiErrorLocal2Remote(err)] : []\n\t };\n\t worker.postMessage(response);\n\t });\n\t })();\n\t break;\n\t case 'probe':\n\t (function () {\n\t var rootFs = _fsMock.getRootFS(), remoteCb = args[1], probeResponse = {\n\t type: SpecialArgType.PROBE,\n\t isReadOnly: rootFs.isReadOnly(),\n\t supportsLinks: rootFs.supportsLinks(),\n\t supportsProps: rootFs.supportsProps()\n\t }, response = {\n\t browserfsMessage: true,\n\t cbId: remoteCb.id,\n\t args: [probeResponse]\n\t };\n\t worker.postMessage(response);\n\t })();\n\t break;\n\t default:\n\t // File system methods.\n\t for (var i = 0; i < args.length; i++) {\n\t fixedArgs[i] = argRemote2Local(args[i], fixedArgs);\n\t }\n\t var rootFS = _fsMock.getRootFS();\n\t rootFS[request.method].apply(rootFS, fixedArgs);\n\t break;\n\t }\n\t }\n\t });\n\t };\n\t WorkerFS.prototype.getName = function getName () {\n\t return 'WorkerFS';\n\t };\n\t /**\n\t * Converts a local argument into a remote argument. Public so WorkerFile objects can call it.\n\t */\n\t WorkerFS.prototype._argLocal2Remote = function _argLocal2Remote (arg) {\n\t if (!arg) {\n\t return arg;\n\t }\n\t switch (typeof arg) {\n\t case \"object\":\n\t if (arg instanceof Stats) {\n\t return statsLocal2Remote(arg);\n\t }\n\t else if (arg instanceof ApiError) {\n\t return apiErrorLocal2Remote(arg);\n\t }\n\t else if (arg instanceof WorkerFile) {\n\t return arg.toRemoteArg();\n\t }\n\t else if (arg instanceof FileFlag) {\n\t return fileFlagLocal2Remote(arg);\n\t }\n\t else if (arg instanceof Buffer) {\n\t return bufferLocal2Remote(arg);\n\t }\n\t else if (arg instanceof Error) {\n\t return errorLocal2Remote(arg);\n\t }\n\t else {\n\t return \"Unknown argument\";\n\t }\n\t case \"function\":\n\t return this._callbackConverter.toRemoteArg(arg);\n\t default:\n\t return arg;\n\t }\n\t };\n\t /**\n\t * Called once both local and remote sides are set up.\n\t */\n\t WorkerFS.prototype.initialize = function initialize (cb) {\n\t var this$1 = this;\n\t\n\t if (!this._isInitialized) {\n\t var message = {\n\t browserfsMessage: true,\n\t method: 'probe',\n\t args: [this._argLocal2Remote(new Buffer(0)), this._callbackConverter.toRemoteArg(function (probeResponse) {\n\t this$1._isInitialized = true;\n\t this$1._isReadOnly = probeResponse.isReadOnly;\n\t this$1._supportLinks = probeResponse.supportsLinks;\n\t this$1._supportProps = probeResponse.supportsProps;\n\t cb();\n\t })]\n\t };\n\t this._worker.postMessage(message);\n\t }\n\t else {\n\t cb();\n\t }\n\t };\n\t WorkerFS.prototype.isReadOnly = function isReadOnly () { return this._isReadOnly; };\n\t WorkerFS.prototype.supportsSynch = function supportsSynch () { return false; };\n\t WorkerFS.prototype.supportsLinks = function supportsLinks () { return this._supportLinks; };\n\t WorkerFS.prototype.supportsProps = function supportsProps () { return this._supportProps; };\n\t WorkerFS.prototype.rename = function rename (oldPath, newPath, cb) {\n\t this._rpc('rename', arguments);\n\t };\n\t WorkerFS.prototype.stat = function stat (p, isLstat, cb) {\n\t this._rpc('stat', arguments);\n\t };\n\t WorkerFS.prototype.open = function open (p, flag, mode, cb) {\n\t this._rpc('open', arguments);\n\t };\n\t WorkerFS.prototype.unlink = function unlink (p, cb) {\n\t this._rpc('unlink', arguments);\n\t };\n\t WorkerFS.prototype.rmdir = function rmdir (p, cb) {\n\t this._rpc('rmdir', arguments);\n\t };\n\t WorkerFS.prototype.mkdir = function mkdir (p, mode, cb) {\n\t this._rpc('mkdir', arguments);\n\t };\n\t WorkerFS.prototype.readdir = function readdir (p, cb) {\n\t this._rpc('readdir', arguments);\n\t };\n\t WorkerFS.prototype.exists = function exists (p, cb) {\n\t this._rpc('exists', arguments);\n\t };\n\t WorkerFS.prototype.realpath = function realpath (p, cache, cb) {\n\t this._rpc('realpath', arguments);\n\t };\n\t WorkerFS.prototype.truncate = function truncate (p, len, cb) {\n\t this._rpc('truncate', arguments);\n\t };\n\t WorkerFS.prototype.readFile = function readFile (fname, encoding, flag, cb) {\n\t this._rpc('readFile', arguments);\n\t };\n\t WorkerFS.prototype.writeFile = function writeFile (fname, data, encoding, flag, mode, cb) {\n\t this._rpc('writeFile', arguments);\n\t };\n\t WorkerFS.prototype.appendFile = function appendFile (fname, data, encoding, flag, mode, cb) {\n\t this._rpc('appendFile', arguments);\n\t };\n\t WorkerFS.prototype.chmod = function chmod (p, isLchmod, mode, cb) {\n\t this._rpc('chmod', arguments);\n\t };\n\t WorkerFS.prototype.chown = function chown (p, isLchown, uid, gid, cb) {\n\t this._rpc('chown', arguments);\n\t };\n\t WorkerFS.prototype.utimes = function utimes (p, atime, mtime, cb) {\n\t this._rpc('utimes', arguments);\n\t };\n\t WorkerFS.prototype.link = function link (srcpath, dstpath, cb) {\n\t this._rpc('link', arguments);\n\t };\n\t WorkerFS.prototype.symlink = function symlink (srcpath, dstpath, type, cb) {\n\t this._rpc('symlink', arguments);\n\t };\n\t WorkerFS.prototype.readlink = function readlink (p, cb) {\n\t this._rpc('readlink', arguments);\n\t };\n\t WorkerFS.prototype.syncClose = function syncClose (method, fd, cb) {\n\t this._worker.postMessage({\n\t browserfsMessage: true,\n\t method: method,\n\t args: [fd.toRemoteArg(), this._callbackConverter.toRemoteArg(cb)]\n\t });\n\t };\n\t WorkerFS.prototype._argRemote2Local = function _argRemote2Local (arg) {\n\t if (!arg) {\n\t return arg;\n\t }\n\t switch (typeof arg) {\n\t case 'object':\n\t if (typeof arg['type'] === 'number') {\n\t var specialArg = arg;\n\t switch (specialArg.type) {\n\t case SpecialArgType.API_ERROR:\n\t return apiErrorRemote2Local(specialArg);\n\t case SpecialArgType.FD:\n\t var fdArg = specialArg;\n\t return new WorkerFile(this, fdArg.path, FileFlag.getFileFlag(fdArg.flag), Stats.fromBuffer(transferrableObjectToBuffer(fdArg.stat)), fdArg.id, transferrableObjectToBuffer(fdArg.data));\n\t case SpecialArgType.STATS:\n\t return statsRemote2Local(specialArg);\n\t case SpecialArgType.FILEFLAG:\n\t return fileFlagRemote2Local(specialArg);\n\t case SpecialArgType.BUFFER:\n\t return bufferRemote2Local(specialArg);\n\t case SpecialArgType.ERROR:\n\t return errorRemote2Local(specialArg);\n\t default:\n\t return arg;\n\t }\n\t }\n\t else {\n\t return arg;\n\t }\n\t default:\n\t return arg;\n\t }\n\t };\n\t WorkerFS.prototype._rpc = function _rpc (methodName, args) {\n\t var this$1 = this;\n\t\n\t var fixedArgs = new Array(args.length);\n\t for (var i = 0; i < args.length; i++) {\n\t fixedArgs[i] = this$1._argLocal2Remote(args[i]);\n\t }\n\t var message = {\n\t browserfsMessage: true,\n\t method: methodName,\n\t args: fixedArgs\n\t };\n\t this._worker.postMessage(message);\n\t };\n\t\n\t return WorkerFS;\n\t}(BaseFileSystem));\n\t\n\t/**\n\t * Contains utility methods for performing a variety of tasks with\n\t * XmlHttpRequest across browsers.\n\t */\n\tfunction asyncDownloadFileModern(p, type, cb) {\n\t var req = new XMLHttpRequest();\n\t req.open('GET', p, true);\n\t var jsonSupported = true;\n\t switch (type) {\n\t case 'buffer':\n\t req.responseType = 'arraybuffer';\n\t break;\n\t case 'json':\n\t // Some browsers don't support the JSON response type.\n\t // They either reset responseType, or throw an exception.\n\t // @see https://github.com/Modernizr/Modernizr/blob/master/src/testXhrType.js\n\t try {\n\t req.responseType = 'json';\n\t jsonSupported = req.responseType === 'json';\n\t }\n\t catch (e) {\n\t jsonSupported = false;\n\t }\n\t break;\n\t default:\n\t return cb(new ApiError(ErrorCode.EINVAL, \"Invalid download type: \" + type));\n\t }\n\t req.onreadystatechange = function (e) {\n\t if (req.readyState === 4) {\n\t if (req.status === 200) {\n\t switch (type) {\n\t case 'buffer':\n\t // XXX: WebKit-based browsers return *null* when XHRing an empty file.\n\t return cb(null, new Buffer(req.response ? req.response : 0));\n\t case 'json':\n\t if (jsonSupported) {\n\t return cb(null, req.response);\n\t }\n\t else {\n\t return cb(null, JSON.parse(req.responseText));\n\t }\n\t }\n\t }\n\t else {\n\t return cb(new ApiError(req.status, \"XHR error.\"));\n\t }\n\t }\n\t };\n\t req.send();\n\t}\n\tfunction syncDownloadFileModern(p, type) {\n\t var req = new XMLHttpRequest();\n\t req.open('GET', p, false);\n\t // On most platforms, we cannot set the responseType of synchronous downloads.\n\t // @todo Test for this; IE10 allows this, as do older versions of Chrome/FF.\n\t var data = null;\n\t var err = null;\n\t // Classic hack to download binary data as a string.\n\t req.overrideMimeType('text/plain; charset=x-user-defined');\n\t req.onreadystatechange = function (e) {\n\t if (req.readyState === 4) {\n\t if (req.status === 200) {\n\t switch (type) {\n\t case 'buffer':\n\t // Convert the text into a buffer.\n\t var text = req.responseText;\n\t data = new Buffer(text.length);\n\t // Throw away the upper bits of each character.\n\t for (var i = 0; i < text.length; i++) {\n\t // This will automatically throw away the upper bit of each\n\t // character for us.\n\t data[i] = text.charCodeAt(i);\n\t }\n\t return;\n\t case 'json':\n\t data = JSON.parse(req.responseText);\n\t return;\n\t }\n\t }\n\t else {\n\t err = new ApiError(req.status, \"XHR error.\");\n\t return;\n\t }\n\t }\n\t };\n\t req.send();\n\t if (err) {\n\t throw err;\n\t }\n\t return data;\n\t}\n\tfunction syncDownloadFileIE10(p, type) {\n\t var req = new XMLHttpRequest();\n\t req.open('GET', p, false);\n\t switch (type) {\n\t case 'buffer':\n\t req.responseType = 'arraybuffer';\n\t break;\n\t case 'json':\n\t // IE10 does not support the JSON type.\n\t break;\n\t default:\n\t throw new ApiError(ErrorCode.EINVAL, \"Invalid download type: \" + type);\n\t }\n\t var data;\n\t var err;\n\t req.onreadystatechange = function (e) {\n\t if (req.readyState === 4) {\n\t if (req.status === 200) {\n\t switch (type) {\n\t case 'buffer':\n\t data = new Buffer(req.response);\n\t break;\n\t case 'json':\n\t data = JSON.parse(req.response);\n\t break;\n\t }\n\t }\n\t else {\n\t err = new ApiError(req.status, \"XHR error.\");\n\t }\n\t }\n\t };\n\t req.send();\n\t if (err) {\n\t throw err;\n\t }\n\t return data;\n\t}\n\tfunction getFileSize(async, p, cb) {\n\t var req = new XMLHttpRequest();\n\t req.open('HEAD', p, async);\n\t req.onreadystatechange = function (e) {\n\t if (req.readyState === 4) {\n\t if (req.status === 200) {\n\t try {\n\t return cb(null, parseInt(req.getResponseHeader('Content-Length') || '-1', 10));\n\t }\n\t catch (e) {\n\t // In the event that the header isn't present or there is an error...\n\t return cb(new ApiError(ErrorCode.EIO, \"XHR HEAD error: Could not read content-length.\"));\n\t }\n\t }\n\t else {\n\t return cb(new ApiError(req.status, \"XHR HEAD error.\"));\n\t }\n\t }\n\t };\n\t req.send();\n\t}\n\t/**\n\t * Asynchronously download a file as a buffer or a JSON object.\n\t * Note that the third function signature with a non-specialized type is\n\t * invalid, but TypeScript requires it when you specialize string arguments to\n\t * constants.\n\t */\n\tvar asyncDownloadFile = asyncDownloadFileModern;\n\t/**\n\t * Synchronously download a file as a buffer or a JSON object.\n\t * Note that the third function signature with a non-specialized type is\n\t * invalid, but TypeScript requires it when you specialize string arguments to\n\t * constants.\n\t */\n\tvar syncDownloadFile = (isIE && typeof Blob !== 'undefined') ? syncDownloadFileIE10 : syncDownloadFileModern;\n\t/**\n\t * Synchronously retrieves the size of the given file in bytes.\n\t */\n\tfunction getFileSizeSync(p) {\n\t var rv = -1;\n\t getFileSize(false, p, function (err, size) {\n\t if (err) {\n\t throw err;\n\t }\n\t rv = size;\n\t });\n\t return rv;\n\t}\n\t/**\n\t * Asynchronously retrieves the size of the given file in bytes.\n\t */\n\tfunction getFileSizeAsync(p, cb) {\n\t getFileSize(true, p, cb);\n\t}\n\t\n\t/**\n\t * A simple class for storing a filesystem index. Assumes that all paths passed\n\t * to it are *absolute* paths.\n\t *\n\t * Can be used as a partial or a full index, although care must be taken if used\n\t * for the former purpose, especially when directories are concerned.\n\t */\n\tvar FileIndex = function FileIndex() {\n\t // _index is a single-level key,value store that maps *directory* paths to\n\t // DirInodes. File information is only contained in DirInodes themselves.\n\t this._index = {};\n\t // Create the root directory.\n\t this.addPath('/', new DirInode());\n\t};\n\t/**\n\t * Static method for constructing indices from a JSON listing.\n\t * @param listing Directory listing generated by tools/XHRIndexer.coffee\n\t * @return A new FileIndex object.\n\t */\n\tFileIndex.fromListing = function fromListing (listing) {\n\t var idx = new FileIndex();\n\t // Add a root DirNode.\n\t var rootInode = new DirInode();\n\t idx._index['/'] = rootInode;\n\t var queue = [['', listing, rootInode]];\n\t while (queue.length > 0) {\n\t var inode = (void 0);\n\t var next = queue.pop();\n\t var pwd = next[0];\n\t var tree = next[1];\n\t var parent = next[2];\n\t for (var node in tree) {\n\t if (tree.hasOwnProperty(node)) {\n\t var children = tree[node];\n\t var name = pwd + \"/\" + node;\n\t if (children) {\n\t idx._index[name] = inode = new DirInode();\n\t queue.push([name, children, inode]);\n\t }\n\t else {\n\t // This inode doesn't have correct size information, noted with -1.\n\t inode = new FileInode(new Stats(FileType.FILE, -1, 0x16D));\n\t }\n\t if (parent) {\n\t parent._ls[node] = inode;\n\t }\n\t }\n\t }\n\t }\n\t return idx;\n\t};\n\t/**\n\t * Runs the given function over all files in the index.\n\t */\n\tFileIndex.prototype.fileIterator = function fileIterator (cb) {\n\t var this$1 = this;\n\t\n\t for (var path$$1 in this$1._index) {\n\t if (this$1._index.hasOwnProperty(path$$1)) {\n\t var dir = this$1._index[path$$1];\n\t var files = dir.getListing();\n\t for (var i = 0; i < files.length; i++) {\n\t var item = dir.getItem(files[i]);\n\t if (isFileInode(item)) {\n\t cb(item.getData());\n\t }\n\t }\n\t }\n\t }\n\t};\n\t/**\n\t * Adds the given absolute path to the index if it is not already in the index.\n\t * Creates any needed parent directories.\n\t * @param path The path to add to the index.\n\t * @param inode The inode for the\n\t * path to add.\n\t * @return 'True' if it was added or already exists, 'false' if there\n\t * was an issue adding it (e.g. item in path is a file, item exists but is\n\t * different).\n\t * @todo If adding fails and implicitly creates directories, we do not clean up\n\t * the new empty directories.\n\t */\n\tFileIndex.prototype.addPath = function addPath (path$$1, inode) {\n\t if (!inode) {\n\t throw new Error('Inode must be specified');\n\t }\n\t if (path$$1[0] !== '/') {\n\t throw new Error('Path must be absolute, got: ' + path$$1);\n\t }\n\t // Check if it already exists.\n\t if (this._index.hasOwnProperty(path$$1)) {\n\t return this._index[path$$1] === inode;\n\t }\n\t var splitPath = this._split_path(path$$1);\n\t var dirpath = splitPath[0];\n\t var itemname = splitPath[1];\n\t // Try to add to its parent directory first.\n\t var parent = this._index[dirpath];\n\t if (parent === undefined && path$$1 !== '/') {\n\t // Create parent.\n\t parent = new DirInode();\n\t if (!this.addPath(dirpath, parent)) {\n\t return false;\n\t }\n\t }\n\t // Add myself to my parent.\n\t if (path$$1 !== '/') {\n\t if (!parent.addItem(itemname, inode)) {\n\t return false;\n\t }\n\t }\n\t // If I'm a directory, add myself to the index.\n\t if (isDirInode(inode)) {\n\t this._index[path$$1] = inode;\n\t }\n\t return true;\n\t};\n\t/**\n\t * Adds the given absolute path to the index if it is not already in the index.\n\t * The path is added without special treatment (no joining of adjacent separators, etc).\n\t * Creates any needed parent directories.\n\t * @param path The path to add to the index.\n\t * @param inode The inode for the\n\t * path to add.\n\t * @return 'True' if it was added or already exists, 'false' if there\n\t * was an issue adding it (e.g. item in path is a file, item exists but is\n\t * different).\n\t * @todo If adding fails and implicitly creates directories, we do not clean up\n\t * the new empty directories.\n\t */\n\tFileIndex.prototype.addPathFast = function addPathFast (path$$1, inode) {\n\t var itemNameMark = path$$1.lastIndexOf('/');\n\t var parentPath = itemNameMark === 0 ? \"/\" : path$$1.substring(0, itemNameMark);\n\t var itemName = path$$1.substring(itemNameMark + 1);\n\t // Try to add to its parent directory first.\n\t var parent = this._index[parentPath];\n\t if (parent === undefined) {\n\t // Create parent.\n\t parent = new DirInode();\n\t this.addPathFast(parentPath, parent);\n\t }\n\t if (!parent.addItem(itemName, inode)) {\n\t return false;\n\t }\n\t // If adding a directory, add to the index as well.\n\t if (inode.isDir()) {\n\t this._index[path$$1] = inode;\n\t }\n\t return true;\n\t};\n\t/**\n\t * Removes the given path. Can be a file or a directory.\n\t * @return The removed item,\n\t * or null if it did not exist.\n\t */\n\tFileIndex.prototype.removePath = function removePath (path$$1) {\n\t var this$1 = this;\n\t\n\t var splitPath = this._split_path(path$$1);\n\t var dirpath = splitPath[0];\n\t var itemname = splitPath[1];\n\t // Try to remove it from its parent directory first.\n\t var parent = this._index[dirpath];\n\t if (parent === undefined) {\n\t return null;\n\t }\n\t // Remove myself from my parent.\n\t var inode = parent.remItem(itemname);\n\t if (inode === null) {\n\t return null;\n\t }\n\t // If I'm a directory, remove myself from the index, and remove my children.\n\t if (isDirInode(inode)) {\n\t var children = inode.getListing();\n\t for (var i = 0; i < children.length; i++) {\n\t this$1.removePath(path$$1 + '/' + children[i]);\n\t }\n\t // Remove the directory from the index, unless it's the root.\n\t if (path$$1 !== '/') {\n\t delete this._index[path$$1];\n\t }\n\t }\n\t return inode;\n\t};\n\t/**\n\t * Retrieves the directory listing of the given path.\n\t * @return An array of files in the given path, or 'null' if it does not exist.\n\t */\n\tFileIndex.prototype.ls = function ls (path$$1) {\n\t var item = this._index[path$$1];\n\t if (item === undefined) {\n\t return null;\n\t }\n\t return item.getListing();\n\t};\n\t/**\n\t * Returns the inode of the given item.\n\t * @return Returns null if the item does not exist.\n\t */\n\tFileIndex.prototype.getInode = function getInode (path$$1) {\n\t var splitPath = this._split_path(path$$1);\n\t var dirpath = splitPath[0];\n\t var itemname = splitPath[1];\n\t // Retrieve from its parent directory.\n\t var parent = this._index[dirpath];\n\t if (parent === undefined) {\n\t return null;\n\t }\n\t // Root case\n\t if (dirpath === path$$1) {\n\t return parent;\n\t }\n\t return parent.getItem(itemname);\n\t};\n\t/**\n\t * Split into a (directory path, item name) pair\n\t */\n\tFileIndex.prototype._split_path = function _split_path (p) {\n\t var dirpath = path.dirname(p);\n\t var itemname = p.substr(dirpath.length + (dirpath === \"/\" ? 0 : 1));\n\t return [dirpath, itemname];\n\t};\n\t/**\n\t * Inode for a file. Stores an arbitrary (filesystem-specific) data payload.\n\t */\n\tvar FileInode = function FileInode(data) {\n\t this.data = data;\n\t};\n\tFileInode.prototype.isFile = function isFile () { return true; };\n\tFileInode.prototype.isDir = function isDir () { return false; };\n\tFileInode.prototype.getData = function getData () { return this.data; };\n\tFileInode.prototype.setData = function setData (data) { this.data = data; };\n\t/**\n\t * Inode for a directory. Currently only contains the directory listing.\n\t */\n\tvar DirInode = function DirInode(data) {\n\t if ( data === void 0 ) data = null;\n\t\n\t this.data = data;\n\t this._ls = {};\n\t};\n\tDirInode.prototype.isFile = function isFile () {\n\t return false;\n\t};\n\tDirInode.prototype.isDir = function isDir () {\n\t return true;\n\t};\n\tDirInode.prototype.getData = function getData () { return this.data; };\n\t/**\n\t * Return a Stats object for this inode.\n\t * @todo Should probably remove this at some point. This isn't the\n\t * responsibility of the FileIndex.\n\t */\n\tDirInode.prototype.getStats = function getStats () {\n\t return new Stats(FileType.DIRECTORY, 4096, 0x16D);\n\t};\n\t/**\n\t * Returns the directory listing for this directory. Paths in the directory are\n\t * relative to the directory's path.\n\t * @return The directory listing for this directory.\n\t */\n\tDirInode.prototype.getListing = function getListing () {\n\t return Object.keys(this._ls);\n\t};\n\t/**\n\t * Returns the inode for the indicated item, or null if it does not exist.\n\t * @param p Name of item in this directory.\n\t */\n\tDirInode.prototype.getItem = function getItem (p) {\n\t var item = this._ls[p];\n\t return item ? item : null;\n\t};\n\t/**\n\t * Add the given item to the directory listing. Note that the given inode is\n\t * not copied, and will be mutated by the DirInode if it is a DirInode.\n\t * @param p Item name to add to the directory listing.\n\t * @param inode The inode for the\n\t * item to add to the directory inode.\n\t * @return True if it was added, false if it already existed.\n\t */\n\tDirInode.prototype.addItem = function addItem (p, inode) {\n\t if (p in this._ls) {\n\t return false;\n\t }\n\t this._ls[p] = inode;\n\t return true;\n\t};\n\t/**\n\t * Removes the given item from the directory listing.\n\t * @param p Name of item to remove from the directory listing.\n\t * @return Returns the item\n\t * removed, or null if the item did not exist.\n\t */\n\tDirInode.prototype.remItem = function remItem (p) {\n\t var item = this._ls[p];\n\t if (item === undefined) {\n\t return null;\n\t }\n\t delete this._ls[p];\n\t return item;\n\t};\n\tfunction isFileInode(inode) {\n\t return !!inode && inode.isFile();\n\t}\n\tfunction isDirInode(inode) {\n\t return !!inode && inode.isDir();\n\t}\n\t\n\t/**\n\t * Try to convert the given buffer into a string, and pass it to the callback.\n\t * Optimization that removes the needed try/catch into a helper function, as\n\t * this is an uncommon case.\n\t */\n\tfunction tryToString(buff, encoding, cb) {\n\t try {\n\t cb(null, buff.toString(encoding));\n\t }\n\t catch (e) {\n\t cb(e);\n\t }\n\t}\n\t/**\n\t * A simple filesystem backed by XmlHttpRequests.\n\t */\n\tvar XmlHttpRequest = (function (BaseFileSystem$$1) {\n\t function XmlHttpRequest(listingUrlOrObj, prefixUrl) {\n\t if ( prefixUrl === void 0 ) prefixUrl = '';\n\t\n\t BaseFileSystem$$1.call(this);\n\t if (!listingUrlOrObj) {\n\t listingUrlOrObj = 'index.json';\n\t }\n\t // prefix_url must end in a directory separator.\n\t if (prefixUrl.length > 0 && prefixUrl.charAt(prefixUrl.length - 1) !== '/') {\n\t prefixUrl = prefixUrl + '/';\n\t }\n\t this.prefixUrl = prefixUrl;\n\t var listing = null;\n\t if (typeof (listingUrlOrObj) === \"string\") {\n\t listing = this._requestFileSync(listingUrlOrObj, 'json');\n\t if (!listing) {\n\t throw new Error(\"Unable to find listing at URL: ${listingUrlOrObj}\");\n\t }\n\t }\n\t else {\n\t listing = listingUrlOrObj;\n\t }\n\t this._index = FileIndex.fromListing(listing);\n\t }\n\t\n\t if ( BaseFileSystem$$1 ) XmlHttpRequest.__proto__ = BaseFileSystem$$1;\n\t XmlHttpRequest.prototype = Object.create( BaseFileSystem$$1 && BaseFileSystem$$1.prototype );\n\t XmlHttpRequest.prototype.constructor = XmlHttpRequest;\n\t XmlHttpRequest.isAvailable = function isAvailable () {\n\t return typeof (XMLHttpRequest) !== \"undefined\" && XMLHttpRequest !== null;\n\t };\n\t\n\t XmlHttpRequest.prototype.empty = function empty () {\n\t this._index.fileIterator(function (file) {\n\t file.fileData = null;\n\t });\n\t };\n\t /**\n\t * Only requests the HEAD content, for the file size.\n\t */\n\t XmlHttpRequest.prototype._requestFileSizeAsync = function _requestFileSizeAsync (path$$1, cb) {\n\t getFileSizeAsync(this.getXhrPath(path$$1), cb);\n\t };\n\t XmlHttpRequest.prototype._requestFileSizeSync = function _requestFileSizeSync (path$$1) {\n\t return getFileSizeSync(this.getXhrPath(path$$1));\n\t };\n\t XmlHttpRequest.prototype.getName = function getName () {\n\t return 'XmlHttpRequest';\n\t };\n\t XmlHttpRequest.prototype.diskSpace = function diskSpace (path$$1, cb) {\n\t // Read-only file system. We could calculate the total space, but that's not\n\t // important right now.\n\t cb(0, 0);\n\t };\n\t XmlHttpRequest.prototype.isReadOnly = function isReadOnly () {\n\t return true;\n\t };\n\t XmlHttpRequest.prototype.supportsLinks = function supportsLinks () {\n\t return false;\n\t };\n\t XmlHttpRequest.prototype.supportsProps = function supportsProps () {\n\t return false;\n\t };\n\t XmlHttpRequest.prototype.supportsSynch = function supportsSynch () {\n\t return true;\n\t };\n\t /**\n\t * Special XHR function: Preload the given file into the index.\n\t * @param [String] path\n\t * @param [BrowserFS.Buffer] buffer\n\t */\n\t XmlHttpRequest.prototype.preloadFile = function preloadFile (path$$1, buffer$$1) {\n\t var inode = this._index.getInode(path$$1);\n\t if (isFileInode(inode)) {\n\t if (inode === null) {\n\t throw ApiError.ENOENT(path$$1);\n\t }\n\t var stats = inode.getData();\n\t stats.size = buffer$$1.length;\n\t stats.fileData = buffer$$1;\n\t }\n\t else {\n\t throw ApiError.EISDIR(path$$1);\n\t }\n\t };\n\t XmlHttpRequest.prototype.stat = function stat (path$$1, isLstat, cb) {\n\t var inode = this._index.getInode(path$$1);\n\t if (inode === null) {\n\t return cb(ApiError.ENOENT(path$$1));\n\t }\n\t var stats;\n\t if (isFileInode(inode)) {\n\t stats = inode.getData();\n\t // At this point, a non-opened file will still have default stats from the listing.\n\t if (stats.size < 0) {\n\t this._requestFileSizeAsync(path$$1, function (e, size) {\n\t if (e) {\n\t return cb(e);\n\t }\n\t stats.size = size;\n\t cb(null, stats.clone());\n\t });\n\t }\n\t else {\n\t cb(null, stats.clone());\n\t }\n\t }\n\t else if (isDirInode(inode)) {\n\t stats = inode.getStats();\n\t cb(null, stats);\n\t }\n\t else {\n\t cb(ApiError.FileError(ErrorCode.EINVAL, path$$1));\n\t }\n\t };\n\t XmlHttpRequest.prototype.statSync = function statSync (path$$1, isLstat) {\n\t var inode = this._index.getInode(path$$1);\n\t if (inode === null) {\n\t throw ApiError.ENOENT(path$$1);\n\t }\n\t var stats;\n\t if (isFileInode(inode)) {\n\t stats = inode.getData();\n\t // At this point, a non-opened file will still have default stats from the listing.\n\t if (stats.size < 0) {\n\t stats.size = this._requestFileSizeSync(path$$1);\n\t }\n\t }\n\t else if (isDirInode(inode)) {\n\t stats = inode.getStats();\n\t }\n\t else {\n\t throw ApiError.FileError(ErrorCode.EINVAL, path$$1);\n\t }\n\t return stats;\n\t };\n\t XmlHttpRequest.prototype.open = function open (path$$1, flags, mode, cb) {\n\t // INVARIANT: You can't write to files on this file system.\n\t if (flags.isWriteable()) {\n\t return cb(new ApiError(ErrorCode.EPERM, path$$1));\n\t }\n\t var self = this;\n\t // Check if the path exists, and is a file.\n\t var inode = this._index.getInode(path$$1);\n\t if (inode === null) {\n\t return cb(ApiError.ENOENT(path$$1));\n\t }\n\t if (isFileInode(inode)) {\n\t var stats = inode.getData();\n\t switch (flags.pathExistsAction()) {\n\t case ActionType.THROW_EXCEPTION:\n\t case ActionType.TRUNCATE_FILE:\n\t return cb(ApiError.EEXIST(path$$1));\n\t case ActionType.NOP:\n\t // Use existing file contents.\n\t // XXX: Uh, this maintains the previously-used flag.\n\t if (stats.fileData) {\n\t return cb(null, new NoSyncFile(self, path$$1, flags, stats.clone(), stats.fileData));\n\t }\n\t // @todo be lazier about actually requesting the file\n\t this._requestFileAsync(path$$1, 'buffer', function (err, buffer$$1) {\n\t if (err) {\n\t return cb(err);\n\t }\n\t // we don't initially have file sizes\n\t stats.size = buffer$$1.length;\n\t stats.fileData = buffer$$1;\n\t return cb(null, new NoSyncFile(self, path$$1, flags, stats.clone(), buffer$$1));\n\t });\n\t break;\n\t default:\n\t return cb(new ApiError(ErrorCode.EINVAL, 'Invalid FileMode object.'));\n\t }\n\t }\n\t else {\n\t return cb(ApiError.EISDIR(path$$1));\n\t }\n\t };\n\t XmlHttpRequest.prototype.openSync = function openSync (path$$1, flags, mode) {\n\t // INVARIANT: You can't write to files on this file system.\n\t if (flags.isWriteable()) {\n\t throw new ApiError(ErrorCode.EPERM, path$$1);\n\t }\n\t // Check if the path exists, and is a file.\n\t var inode = this._index.getInode(path$$1);\n\t if (inode === null) {\n\t throw ApiError.ENOENT(path$$1);\n\t }\n\t if (isFileInode(inode)) {\n\t var stats = inode.getData();\n\t switch (flags.pathExistsAction()) {\n\t case ActionType.THROW_EXCEPTION:\n\t case ActionType.TRUNCATE_FILE:\n\t throw ApiError.EEXIST(path$$1);\n\t case ActionType.NOP:\n\t // Use existing file contents.\n\t // XXX: Uh, this maintains the previously-used flag.\n\t if (stats.fileData) {\n\t return new NoSyncFile(this, path$$1, flags, stats.clone(), stats.fileData);\n\t }\n\t // @todo be lazier about actually requesting the file\n\t var buffer$$1 = this._requestFileSync(path$$1, 'buffer');\n\t // we don't initially have file sizes\n\t stats.size = buffer$$1.length;\n\t stats.fileData = buffer$$1;\n\t return new NoSyncFile(this, path$$1, flags, stats.clone(), buffer$$1);\n\t default:\n\t throw new ApiError(ErrorCode.EINVAL, 'Invalid FileMode object.');\n\t }\n\t }\n\t else {\n\t throw ApiError.EISDIR(path$$1);\n\t }\n\t };\n\t XmlHttpRequest.prototype.readdir = function readdir (path$$1, cb) {\n\t try {\n\t cb(null, this.readdirSync(path$$1));\n\t }\n\t catch (e) {\n\t cb(e);\n\t }\n\t };\n\t XmlHttpRequest.prototype.readdirSync = function readdirSync (path$$1) {\n\t // Check if it exists.\n\t var inode = this._index.getInode(path$$1);\n\t if (inode === null) {\n\t throw ApiError.ENOENT(path$$1);\n\t }\n\t else if (isDirInode(inode)) {\n\t return inode.getListing();\n\t }\n\t else {\n\t throw ApiError.ENOTDIR(path$$1);\n\t }\n\t };\n\t /**\n\t * We have the entire file as a buffer; optimize readFile.\n\t */\n\t XmlHttpRequest.prototype.readFile = function readFile (fname, encoding, flag, cb) {\n\t // Wrap cb in file closing code.\n\t var oldCb = cb;\n\t // Get file.\n\t this.open(fname, flag, 0x1a4, function (err, fd) {\n\t if (err) {\n\t return cb(err);\n\t }\n\t cb = function (err, arg) {\n\t fd.close(function (err2) {\n\t if (!err) {\n\t err = err2;\n\t }\n\t return oldCb(err, arg);\n\t });\n\t };\n\t var fdCast = fd;\n\t var fdBuff = fdCast.getBuffer();\n\t if (encoding === null) {\n\t cb(err, copyingSlice(fdBuff));\n\t }\n\t else {\n\t tryToString(fdBuff, encoding, cb);\n\t }\n\t });\n\t };\n\t /**\n\t * Specially-optimized readfile.\n\t */\n\t XmlHttpRequest.prototype.readFileSync = function readFileSync (fname, encoding, flag) {\n\t // Get file.\n\t var fd = this.openSync(fname, flag, 0x1a4);\n\t try {\n\t var fdCast = fd;\n\t var fdBuff = fdCast.getBuffer();\n\t if (encoding === null) {\n\t return copyingSlice(fdBuff);\n\t }\n\t return fdBuff.toString(encoding);\n\t }\n\t finally {\n\t fd.closeSync();\n\t }\n\t };\n\t XmlHttpRequest.prototype.getXhrPath = function getXhrPath (filePath) {\n\t if (filePath.charAt(0) === '/') {\n\t filePath = filePath.slice(1);\n\t }\n\t return this.prefixUrl + filePath;\n\t };\n\t XmlHttpRequest.prototype._requestFileAsync = function _requestFileAsync (p, type, cb) {\n\t asyncDownloadFile(this.getXhrPath(p), type, cb);\n\t };\n\t XmlHttpRequest.prototype._requestFileSync = function _requestFileSync (p, type) {\n\t return syncDownloadFile(this.getXhrPath(p), type);\n\t };\n\t\n\t return XmlHttpRequest;\n\t}(BaseFileSystem));\n\t\n\t/**\n\t * (Nonstandard) String utility function for 8-bit ASCII with the extended\n\t * character set. Unlike the ASCII above, we do not mask the high bits.\n\t *\n\t * Placed into a separate file so it can be used with other Buffer implementations.\n\t * @see http://en.wikipedia.org/wiki/Extended_ASCII\n\t */\n\t/**\n\t * (Nonstandard) String utility function for 8-bit ASCII with the extended\n\t * character set. Unlike the ASCII above, we do not mask the high bits.\n\t *\n\t * Placed into a separate file so it can be used with other Buffer implementations.\n\t * @see http://en.wikipedia.org/wiki/Extended_ASCII\n\t */ var ExtendedASCII = function ExtendedASCII () {};\n\t\n\t ExtendedASCII.str2byte = function str2byte (str, buf) {\n\t var length = str.length > buf.length ? buf.length : str.length;\n\t for (var i = 0; i < length; i++) {\n\t var charCode = str.charCodeAt(i);\n\t if (charCode > 0x7F) {\n\t // Check if extended ASCII.\n\t var charIdx = ExtendedASCII.extendedChars.indexOf(str.charAt(i));\n\t if (charIdx > -1) {\n\t charCode = charIdx + 0x80;\n\t }\n\t }\n\t buf[charCode] = i;\n\t }\n\t return length;\n\t};\n\tExtendedASCII.byte2str = function byte2str (buff) {\n\t var chars = new Array(buff.length);\n\t for (var i = 0; i < buff.length; i++) {\n\t var charCode = buff[i];\n\t if (charCode > 0x7F) {\n\t chars[i] = ExtendedASCII.extendedChars[charCode - 128];\n\t }\n\t else {\n\t chars[i] = String.fromCharCode(charCode);\n\t }\n\t }\n\t return chars.join('');\n\t};\n\tExtendedASCII.byteLength = function byteLength (str) { return str.length; };\n\t\n\t ExtendedASCII.extendedChars = ['\\u00C7', '\\u00FC', '\\u00E9', '\\u00E2', '\\u00E4',\n\t '\\u00E0', '\\u00E5', '\\u00E7', '\\u00EA', '\\u00EB', '\\u00E8', '\\u00EF',\n\t '\\u00EE', '\\u00EC', '\\u00C4', '\\u00C5', '\\u00C9', '\\u00E6', '\\u00C6',\n\t '\\u00F4', '\\u00F6', '\\u00F2', '\\u00FB', '\\u00F9', '\\u00FF', '\\u00D6',\n\t '\\u00DC', '\\u00F8', '\\u00A3', '\\u00D8', '\\u00D7', '\\u0192', '\\u00E1',\n\t '\\u00ED', '\\u00F3', '\\u00FA', '\\u00F1', '\\u00D1', '\\u00AA', '\\u00BA',\n\t '\\u00BF', '\\u00AE', '\\u00AC', '\\u00BD', '\\u00BC', '\\u00A1', '\\u00AB',\n\t '\\u00BB', '_', '_', '_', '\\u00A6', '\\u00A6', '\\u00C1', '\\u00C2', '\\u00C0',\n\t '\\u00A9', '\\u00A6', '\\u00A6', '+', '+', '\\u00A2', '\\u00A5', '+', '+', '-',\n\t '-', '+', '-', '+', '\\u00E3', '\\u00C3', '+', '+', '-', '-', '\\u00A6', '-',\n\t '+', '\\u00A4', '\\u00F0', '\\u00D0', '\\u00CA', '\\u00CB', '\\u00C8', 'i',\n\t '\\u00CD', '\\u00CE', '\\u00CF', '+', '+', '_', '_', '\\u00A6', '\\u00CC', '_',\n\t '\\u00D3', '\\u00DF', '\\u00D4', '\\u00D2', '\\u00F5', '\\u00D5', '\\u00B5',\n\t '\\u00FE', '\\u00DE', '\\u00DA', '\\u00DB', '\\u00D9', '\\u00FD', '\\u00DD',\n\t '\\u00AF', '\\u00B4', '\\u00AD', '\\u00B1', '_', '\\u00BE', '\\u00B6', '\\u00A7',\n\t '\\u00F7', '\\u00B8', '\\u00B0', '\\u00A8', '\\u00B7', '\\u00B9', '\\u00B3',\n\t '\\u00B2', '_', ' '];\n\t\n\t/**\n\t * Zip file-backed filesystem\n\t * Implemented according to the standard:\n\t * http://www.pkware.com/documents/casestudies/APPNOTE.TXT\n\t *\n\t * While there are a few zip libraries for JavaScript (e.g. JSZip and zip.js),\n\t * they are not a good match for BrowserFS. In particular, these libraries\n\t * perform a lot of unneeded data copying, and eagerly decompress every file\n\t * in the zip file upon loading to check the CRC32. They also eagerly decode\n\t * strings. Furthermore, these libraries duplicate functionality already present\n\t * in BrowserFS (e.g. UTF-8 decoding and binary data manipulation).\n\t *\n\t * This filesystem takes advantage of BrowserFS's Buffer implementation, which\n\t * efficiently represents the zip file in memory (in both ArrayBuffer-enabled\n\t * browsers *and* non-ArrayBuffer browsers), and which can neatly be 'sliced'\n\t * without copying data. Each struct defined in the standard is represented with\n\t * a buffer slice pointing to an offset in the zip file, and has getters for\n\t * each field. As we anticipate that this data will not be read often, we choose\n\t * not to store each struct field in the JavaScript object; instead, to reduce\n\t * memory consumption, we retrieve it directly from the binary data each time it\n\t * is requested.\n\t *\n\t * When the filesystem is instantiated, we determine the directory structure\n\t * of the zip file as quickly as possible. We lazily decompress and check the\n\t * CRC32 of files. We do not cache decompressed files; if this is a desired\n\t * feature, it is best implemented as a generic file system wrapper that can\n\t * cache data from arbitrary file systems.\n\t *\n\t * For inflation, we use `pako`'s implementation:\n\t * https://github.com/nodeca/pako\n\t *\n\t * Current limitations:\n\t * * No encryption.\n\t * * No ZIP64 support.\n\t * * Read-only.\n\t * Write support would require that we:\n\t * - Keep track of changed/new files.\n\t * - Compress changed files, and generate appropriate metadata for each.\n\t * - Update file offsets for other files in the zip file.\n\t * - Stream it out to a location.\n\t * This isn't that bad, so we might do this at a later date.\n\t */\n\tvar inflateRaw = __webpack_require__(23).inflateRaw;\n\t/**\n\t * Maps CompressionMethod => function that decompresses.\n\t */\n\tvar decompressionMethods = {};\n\t/**\n\t * 4.4.2.2: Indicates the compatibiltiy of a file's external attributes.\n\t */\n\tvar ExternalFileAttributeType;\n\t(function (ExternalFileAttributeType) {\n\t ExternalFileAttributeType[ExternalFileAttributeType[\"MSDOS\"] = 0] = \"MSDOS\";\n\t ExternalFileAttributeType[ExternalFileAttributeType[\"AMIGA\"] = 1] = \"AMIGA\";\n\t ExternalFileAttributeType[ExternalFileAttributeType[\"OPENVMS\"] = 2] = \"OPENVMS\";\n\t ExternalFileAttributeType[ExternalFileAttributeType[\"UNIX\"] = 3] = \"UNIX\";\n\t ExternalFileAttributeType[ExternalFileAttributeType[\"VM_CMS\"] = 4] = \"VM_CMS\";\n\t ExternalFileAttributeType[ExternalFileAttributeType[\"ATARI_ST\"] = 5] = \"ATARI_ST\";\n\t ExternalFileAttributeType[ExternalFileAttributeType[\"OS2_HPFS\"] = 6] = \"OS2_HPFS\";\n\t ExternalFileAttributeType[ExternalFileAttributeType[\"MAC\"] = 7] = \"MAC\";\n\t ExternalFileAttributeType[ExternalFileAttributeType[\"Z_SYSTEM\"] = 8] = \"Z_SYSTEM\";\n\t ExternalFileAttributeType[ExternalFileAttributeType[\"CP_M\"] = 9] = \"CP_M\";\n\t ExternalFileAttributeType[ExternalFileAttributeType[\"NTFS\"] = 10] = \"NTFS\";\n\t ExternalFileAttributeType[ExternalFileAttributeType[\"MVS\"] = 11] = \"MVS\";\n\t ExternalFileAttributeType[ExternalFileAttributeType[\"VSE\"] = 12] = \"VSE\";\n\t ExternalFileAttributeType[ExternalFileAttributeType[\"ACORN_RISC\"] = 13] = \"ACORN_RISC\";\n\t ExternalFileAttributeType[ExternalFileAttributeType[\"VFAT\"] = 14] = \"VFAT\";\n\t ExternalFileAttributeType[ExternalFileAttributeType[\"ALT_MVS\"] = 15] = \"ALT_MVS\";\n\t ExternalFileAttributeType[ExternalFileAttributeType[\"BEOS\"] = 16] = \"BEOS\";\n\t ExternalFileAttributeType[ExternalFileAttributeType[\"TANDEM\"] = 17] = \"TANDEM\";\n\t ExternalFileAttributeType[ExternalFileAttributeType[\"OS_400\"] = 18] = \"OS_400\";\n\t ExternalFileAttributeType[ExternalFileAttributeType[\"OSX\"] = 19] = \"OSX\";\n\t})(ExternalFileAttributeType || (ExternalFileAttributeType = {}));\n\t/**\n\t * 4.4.5\n\t */\n\tvar CompressionMethod;\n\t(function (CompressionMethod) {\n\t CompressionMethod[CompressionMethod[\"STORED\"] = 0] = \"STORED\";\n\t CompressionMethod[CompressionMethod[\"SHRUNK\"] = 1] = \"SHRUNK\";\n\t CompressionMethod[CompressionMethod[\"REDUCED_1\"] = 2] = \"REDUCED_1\";\n\t CompressionMethod[CompressionMethod[\"REDUCED_2\"] = 3] = \"REDUCED_2\";\n\t CompressionMethod[CompressionMethod[\"REDUCED_3\"] = 4] = \"REDUCED_3\";\n\t CompressionMethod[CompressionMethod[\"REDUCED_4\"] = 5] = \"REDUCED_4\";\n\t CompressionMethod[CompressionMethod[\"IMPLODE\"] = 6] = \"IMPLODE\";\n\t CompressionMethod[CompressionMethod[\"DEFLATE\"] = 8] = \"DEFLATE\";\n\t CompressionMethod[CompressionMethod[\"DEFLATE64\"] = 9] = \"DEFLATE64\";\n\t CompressionMethod[CompressionMethod[\"TERSE_OLD\"] = 10] = \"TERSE_OLD\";\n\t CompressionMethod[CompressionMethod[\"BZIP2\"] = 12] = \"BZIP2\";\n\t CompressionMethod[CompressionMethod[\"LZMA\"] = 14] = \"LZMA\";\n\t CompressionMethod[CompressionMethod[\"TERSE_NEW\"] = 18] = \"TERSE_NEW\";\n\t CompressionMethod[CompressionMethod[\"LZ77\"] = 19] = \"LZ77\";\n\t CompressionMethod[CompressionMethod[\"WAVPACK\"] = 97] = \"WAVPACK\";\n\t CompressionMethod[CompressionMethod[\"PPMD\"] = 98] = \"PPMD\"; // PPMd version I, Rev 1\n\t})(CompressionMethod || (CompressionMethod = {}));\n\t/**\n\t * Converts the input time and date in MS-DOS format into a JavaScript Date\n\t * object.\n\t */\n\tfunction msdos2date(time, date) {\n\t // MS-DOS Date\n\t // |0 0 0 0 0|0 0 0 0|0 0 0 0 0 0 0\n\t // D (1-31) M (1-23) Y (from 1980)\n\t var day = date & 0x1F;\n\t // JS date is 0-indexed, DOS is 1-indexed.\n\t var month = ((date >> 5) & 0xF) - 1;\n\t var year = (date >> 9) + 1980;\n\t // MS DOS Time\n\t // |0 0 0 0 0|0 0 0 0 0 0|0 0 0 0 0\n\t // Second Minute Hour\n\t var second = time & 0x1F;\n\t var minute = (time >> 5) & 0x3F;\n\t var hour = time >> 11;\n\t return new Date(year, month, day, hour, minute, second);\n\t}\n\t/**\n\t * Safely returns the string from the buffer, even if it is 0 bytes long.\n\t * (Normally, calling toString() on a buffer with start === end causes an\n\t * exception).\n\t */\n\tfunction safeToString(buff, useUTF8, start, length) {\n\t if (length === 0) {\n\t return \"\";\n\t }\n\t else if (useUTF8) {\n\t return buff.toString('utf8', start, start + length);\n\t }\n\t else {\n\t return ExtendedASCII.byte2str(buff.slice(start, start + length));\n\t }\n\t}\n\t/*\n\t 4.3.6 Overall .ZIP file format:\n\t\n\t [local file header 1]\n\t [encryption header 1]\n\t [file data 1]\n\t [data descriptor 1]\n\t .\n\t .\n\t .\n\t [local file header n]\n\t [encryption header n]\n\t [file data n]\n\t [data descriptor n]\n\t [archive decryption header]\n\t [archive extra data record]\n\t [central directory header 1]\n\t .\n\t .\n\t .\n\t [central directory header n]\n\t [zip64 end of central directory record]\n\t [zip64 end of central directory locator]\n\t [end of central directory record]\n\t*/\n\t/*\n\t 4.3.7 Local file header:\n\t\n\t local file header signature 4 bytes (0x04034b50)\n\t version needed to extract 2 bytes\n\t general purpose bit flag 2 bytes\n\t compression method 2 bytes\n\t last mod file time 2 bytes\n\t last mod file date 2 bytes\n\t crc-32 4 bytes\n\t compressed size 4 bytes\n\t uncompressed size 4 bytes\n\t file name length 2 bytes\n\t extra field length 2 bytes\n\t\n\t file name (variable size)\n\t extra field (variable size)\n\t */\n\tvar FileHeader = function FileHeader(data) {\n\t this.data = data;\n\t if (data.readUInt32LE(0) !== 0x04034b50) {\n\t throw new ApiError(ErrorCode.EINVAL, \"Invalid Zip file: Local file header has invalid signature: \" + this.data.readUInt32LE(0));\n\t }\n\t };\n\t FileHeader.prototype.versionNeeded = function versionNeeded () { return this.data.readUInt16LE(4); };\n\t FileHeader.prototype.flags = function flags () { return this.data.readUInt16LE(6); };\n\t FileHeader.prototype.compressionMethod = function compressionMethod () { return this.data.readUInt16LE(8); };\n\t FileHeader.prototype.lastModFileTime = function lastModFileTime () {\n\t // Time and date is in MS-DOS format.\n\t return msdos2date(this.data.readUInt16LE(10), this.data.readUInt16LE(12));\n\t };\n\t FileHeader.prototype.rawLastModFileTime = function rawLastModFileTime () {\n\t return this.data.readUInt32LE(10);\n\t };\n\t FileHeader.prototype.crc32 = function crc32 () { return this.data.readUInt32LE(14); };\n\t /**\n\t * These two values are COMPLETELY USELESS.\n\t *\n\t * Section 4.4.9:\n\t * If bit 3 of the general purpose bit flag is set,\n\t * these fields are set to zero in the local header and the\n\t * correct values are put in the data descriptor and\n\t * in the central directory.\n\t *\n\t * So we'll just use the central directory's values.\n\t */\n\t // public compressedSize(): number { return this.data.readUInt32LE(18); }\n\t // public uncompressedSize(): number { return this.data.readUInt32LE(22); }\n\t FileHeader.prototype.fileNameLength = function fileNameLength () { return this.data.readUInt16LE(26); };\n\t FileHeader.prototype.extraFieldLength = function extraFieldLength () { return this.data.readUInt16LE(28); };\n\t FileHeader.prototype.fileName = function fileName () {\n\t return safeToString(this.data, this.useUTF8(), 30, this.fileNameLength());\n\t };\n\t FileHeader.prototype.extraField = function extraField () {\n\t var start = 30 + this.fileNameLength();\n\t return this.data.slice(start, start + this.extraFieldLength());\n\t };\n\t FileHeader.prototype.totalSize = function totalSize () { return 30 + this.fileNameLength() + this.extraFieldLength(); };\n\t FileHeader.prototype.useUTF8 = function useUTF8 () { return (this.flags() & 0x800) === 0x800; };\n\t/**\n\t * 4.3.8 File data\n\t *\n\t * Immediately following the local header for a file\n\t * SHOULD be placed the compressed or stored data for the file.\n\t * If the file is encrypted, the encryption header for the file\n\t * SHOULD be placed after the local header and before the file\n\t * data. The series of [local file header][encryption header]\n\t * [file data][data descriptor] repeats for each file in the\n\t * .ZIP archive.\n\t *\n\t * Zero-byte files, directories, and other file types that\n\t * contain no content MUST not include file data.\n\t */\n\tvar FileData = function FileData(header, record, data) {\n\t this.header = header;\n\t this.record = record;\n\t this.data = data;\n\t };\n\t FileData.prototype.decompress = function decompress () {\n\t // Check the compression\n\t var compressionMethod = this.header.compressionMethod();\n\t var fcn = decompressionMethods[compressionMethod];\n\t if (fcn) {\n\t return fcn(this.data, this.record.compressedSize(), this.record.uncompressedSize(), this.record.flag());\n\t }\n\t else {\n\t var name = CompressionMethod[compressionMethod];\n\t if (!name) {\n\t name = \"Unknown: \" + compressionMethod;\n\t }\n\t throw new ApiError(ErrorCode.EINVAL, (\"Invalid compression method on file '\" + (this.header.fileName()) + \"': \" + name));\n\t }\n\t };\n\t FileData.prototype.getHeader = function getHeader () {\n\t return this.header;\n\t };\n\t FileData.prototype.getRecord = function getRecord () {\n\t return this.record;\n\t };\n\t FileData.prototype.getRawData = function getRawData () {\n\t return this.data;\n\t };\n\t/*\n\t 4.3.9 Data descriptor:\n\t\n\t crc-32 4 bytes\n\t compressed size 4 bytes\n\t uncompressed size 4 bytes\n\t */\n\tvar DataDescriptor = function DataDescriptor(data) {\n\t this.data = data;\n\t };\n\t DataDescriptor.prototype.crc32 = function crc32 () { return this.data.readUInt32LE(0); };\n\t DataDescriptor.prototype.compressedSize = function compressedSize () { return this.data.readUInt32LE(4); };\n\t DataDescriptor.prototype.uncompressedSize = function uncompressedSize () { return this.data.readUInt32LE(8); };\n\t/*\n\t` 4.3.10 Archive decryption header:\n\t\n\t 4.3.10.1 The Archive Decryption Header is introduced in version 6.2\n\t of the ZIP format specification. This record exists in support\n\t of the Central Directory Encryption Feature implemented as part of\n\t the Strong Encryption Specification as described in this document.\n\t When the Central Directory Structure is encrypted, this decryption\n\t header MUST precede the encrypted data segment.\n\t */\n\t/*\n\t 4.3.11 Archive extra data record:\n\t\n\t archive extra data signature 4 bytes (0x08064b50)\n\t extra field length 4 bytes\n\t extra field data (variable size)\n\t\n\t 4.3.11.1 The Archive Extra Data Record is introduced in version 6.2\n\t of the ZIP format specification. This record MAY be used in support\n\t of the Central Directory Encryption Feature implemented as part of\n\t the Strong Encryption Specification as described in this document.\n\t When present, this record MUST immediately precede the central\n\t directory data structure.\n\t*/\n\tvar ArchiveExtraDataRecord = function ArchiveExtraDataRecord(data) {\n\t this.data = data;\n\t if (this.data.readUInt32LE(0) !== 0x08064b50) {\n\t throw new ApiError(ErrorCode.EINVAL, \"Invalid archive extra data record signature: \" + this.data.readUInt32LE(0));\n\t }\n\t };\n\t ArchiveExtraDataRecord.prototype.length = function length () { return this.data.readUInt32LE(4); };\n\t ArchiveExtraDataRecord.prototype.extraFieldData = function extraFieldData () { return this.data.slice(8, 8 + this.length()); };\n\t/*\n\t 4.3.13 Digital signature:\n\t\n\t header signature 4 bytes (0x05054b50)\n\t size of data 2 bytes\n\t signature data (variable size)\n\t\n\t With the introduction of the Central Directory Encryption\n\t feature in version 6.2 of this specification, the Central\n\t Directory Structure MAY be stored both compressed and encrypted.\n\t Although not required, it is assumed when encrypting the\n\t Central Directory Structure, that it will be compressed\n\t for greater storage efficiency. Information on the\n\t Central Directory Encryption feature can be found in the section\n\t describing the Strong Encryption Specification. The Digital\n\t Signature record will be neither compressed nor encrypted.\n\t*/\n\tvar DigitalSignature = function DigitalSignature(data) {\n\t this.data = data;\n\t if (this.data.readUInt32LE(0) !== 0x05054b50) {\n\t throw new ApiError(ErrorCode.EINVAL, \"Invalid digital signature signature: \" + this.data.readUInt32LE(0));\n\t }\n\t };\n\t DigitalSignature.prototype.size = function size () { return this.data.readUInt16LE(4); };\n\t DigitalSignature.prototype.signatureData = function signatureData () { return this.data.slice(6, 6 + this.size()); };\n\t/*\n\t 4.3.12 Central directory structure:\n\t\n\t central file header signature 4 bytes (0x02014b50)\n\t version made by 2 bytes\n\t version needed to extract 2 bytes\n\t general purpose bit flag 2 bytes\n\t compression method 2 bytes\n\t last mod file time 2 bytes\n\t last mod file date 2 bytes\n\t crc-32 4 bytes\n\t compressed size 4 bytes\n\t uncompressed size 4 bytes\n\t file name length 2 bytes\n\t extra field length 2 bytes\n\t file comment length 2 bytes\n\t disk number start 2 bytes\n\t internal file attributes 2 bytes\n\t external file attributes 4 bytes\n\t relative offset of local header 4 bytes\n\t\n\t file name (variable size)\n\t extra field (variable size)\n\t file comment (variable size)\n\t */\n\tvar CentralDirectory = function CentralDirectory(zipData, data) {\n\t this.zipData = zipData;\n\t this.data = data;\n\t // Sanity check.\n\t if (this.data.readUInt32LE(0) !== 0x02014b50) {\n\t throw new ApiError(ErrorCode.EINVAL, (\"Invalid Zip file: Central directory record has invalid signature: \" + (this.data.readUInt32LE(0))));\n\t }\n\t this._filename = this.produceFilename();\n\t };\n\t CentralDirectory.prototype.versionMadeBy = function versionMadeBy () { return this.data.readUInt16LE(4); };\n\t CentralDirectory.prototype.versionNeeded = function versionNeeded () { return this.data.readUInt16LE(6); };\n\t CentralDirectory.prototype.flag = function flag () { return this.data.readUInt16LE(8); };\n\t CentralDirectory.prototype.compressionMethod = function compressionMethod () { return this.data.readUInt16LE(10); };\n\t CentralDirectory.prototype.lastModFileTime = function lastModFileTime () {\n\t // Time and date is in MS-DOS format.\n\t return msdos2date(this.data.readUInt16LE(12), this.data.readUInt16LE(14));\n\t };\n\t CentralDirectory.prototype.rawLastModFileTime = function rawLastModFileTime () {\n\t return this.data.readUInt32LE(12);\n\t };\n\t CentralDirectory.prototype.crc32 = function crc32 () { return this.data.readUInt32LE(16); };\n\t CentralDirectory.prototype.compressedSize = function compressedSize () { return this.data.readUInt32LE(20); };\n\t CentralDirectory.prototype.uncompressedSize = function uncompressedSize () { return this.data.readUInt32LE(24); };\n\t CentralDirectory.prototype.fileNameLength = function fileNameLength () { return this.data.readUInt16LE(28); };\n\t CentralDirectory.prototype.extraFieldLength = function extraFieldLength () { return this.data.readUInt16LE(30); };\n\t CentralDirectory.prototype.fileCommentLength = function fileCommentLength () { return this.data.readUInt16LE(32); };\n\t CentralDirectory.prototype.diskNumberStart = function diskNumberStart () { return this.data.readUInt16LE(34); };\n\t CentralDirectory.prototype.internalAttributes = function internalAttributes () { return this.data.readUInt16LE(36); };\n\t CentralDirectory.prototype.externalAttributes = function externalAttributes () { return this.data.readUInt32LE(38); };\n\t CentralDirectory.prototype.headerRelativeOffset = function headerRelativeOffset () { return this.data.readUInt32LE(42); };\n\t CentralDirectory.prototype.produceFilename = function produceFilename () {\n\t /*\n\t 4.4.17.1 claims:\n\t * All slashes are forward ('/') slashes.\n\t * Filename doesn't begin with a slash.\n\t * No drive letters or any nonsense like that.\n\t * If filename is missing, the input came from standard input.\n\t \n\t Unfortunately, this isn't true in practice. Some Windows zip utilities use\n\t a backslash here, but the correct Unix-style path in file headers.\n\t \n\t To avoid seeking all over the file to recover the known-good filenames\n\t from file headers, we simply convert '/' to '\\' here.\n\t */\n\t var fileName = safeToString(this.data, this.useUTF8(), 46, this.fileNameLength());\n\t return fileName.replace(/\\\\/g, \"/\");\n\t };\n\t CentralDirectory.prototype.fileName = function fileName () {\n\t return this._filename;\n\t };\n\t CentralDirectory.prototype.rawFileName = function rawFileName () {\n\t return this.data.slice(46, 46 + this.fileNameLength());\n\t };\n\t CentralDirectory.prototype.extraField = function extraField () {\n\t var start = 44 + this.fileNameLength();\n\t return this.data.slice(start, start + this.extraFieldLength());\n\t };\n\t CentralDirectory.prototype.fileComment = function fileComment () {\n\t var start = 46 + this.fileNameLength() + this.extraFieldLength();\n\t return safeToString(this.data, this.useUTF8(), start, this.fileCommentLength());\n\t };\n\t CentralDirectory.prototype.rawFileComment = function rawFileComment () {\n\t var start = 46 + this.fileNameLength() + this.extraFieldLength();\n\t return this.data.slice(start, start + this.fileCommentLength());\n\t };\n\t CentralDirectory.prototype.totalSize = function totalSize () {\n\t return 46 + this.fileNameLength() + this.extraFieldLength() + this.fileCommentLength();\n\t };\n\t CentralDirectory.prototype.isDirectory = function isDirectory () {\n\t // NOTE: This assumes that the zip file implementation uses the lower byte\n\t // of external attributes for DOS attributes for\n\t // backwards-compatibility. This is not mandated, but appears to be\n\t // commonplace.\n\t // According to the spec, the layout of external attributes is\n\t // platform-dependent.\n\t // If that fails, we also check if the name of the file ends in '/',\n\t // which is what Java's ZipFile implementation does.\n\t var fileName = this.fileName();\n\t return (this.externalAttributes() & 0x10 ? true : false) || (fileName.charAt(fileName.length - 1) === '/');\n\t };\n\t CentralDirectory.prototype.isFile = function isFile () { return !this.isDirectory(); };\n\t CentralDirectory.prototype.useUTF8 = function useUTF8 () { return (this.flag() & 0x800) === 0x800; };\n\t CentralDirectory.prototype.isEncrypted = function isEncrypted () { return (this.flag() & 0x1) === 0x1; };\n\t CentralDirectory.prototype.getFileData = function getFileData () {\n\t // Need to grab the header before we can figure out where the actual\n\t // compressed data starts.\n\t var start = this.headerRelativeOffset();\n\t var header = new FileHeader(this.zipData.slice(start));\n\t return new FileData(header, this, this.zipData.slice(start + header.totalSize()));\n\t };\n\t CentralDirectory.prototype.getData = function getData () {\n\t return this.getFileData().decompress();\n\t };\n\t CentralDirectory.prototype.getRawData = function getRawData () {\n\t return this.getFileData().getRawData();\n\t };\n\t CentralDirectory.prototype.getStats = function getStats () {\n\t return new Stats(FileType.FILE, this.uncompressedSize(), 0x16D, new Date(), this.lastModFileTime());\n\t };\n\t/*\n\t 4.3.16: end of central directory record\n\t end of central dir signature 4 bytes (0x06054b50)\n\t number of this disk 2 bytes\n\t number of the disk with the\n\t start of the central directory 2 bytes\n\t total number of entries in the\n\t central directory on this disk 2 bytes\n\t total number of entries in\n\t the central directory 2 bytes\n\t size of the central directory 4 bytes\n\t offset of start of central\n\t directory with respect to\n\t the starting disk number 4 bytes\n\t .ZIP file comment length 2 bytes\n\t .ZIP file comment (variable size)\n\t*/\n\tvar EndOfCentralDirectory = function EndOfCentralDirectory(data) {\n\t this.data = data;\n\t if (this.data.readUInt32LE(0) !== 0x06054b50) {\n\t throw new ApiError(ErrorCode.EINVAL, (\"Invalid Zip file: End of central directory record has invalid signature: \" + (this.data.readUInt32LE(0))));\n\t }\n\t };\n\t EndOfCentralDirectory.prototype.diskNumber = function diskNumber () { return this.data.readUInt16LE(4); };\n\t EndOfCentralDirectory.prototype.cdDiskNumber = function cdDiskNumber () { return this.data.readUInt16LE(6); };\n\t EndOfCentralDirectory.prototype.cdDiskEntryCount = function cdDiskEntryCount () { return this.data.readUInt16LE(8); };\n\t EndOfCentralDirectory.prototype.cdTotalEntryCount = function cdTotalEntryCount () { return this.data.readUInt16LE(10); };\n\t EndOfCentralDirectory.prototype.cdSize = function cdSize () { return this.data.readUInt32LE(12); };\n\t EndOfCentralDirectory.prototype.cdOffset = function cdOffset () { return this.data.readUInt32LE(16); };\n\t EndOfCentralDirectory.prototype.cdZipCommentLength = function cdZipCommentLength () { return this.data.readUInt16LE(20); };\n\t EndOfCentralDirectory.prototype.cdZipComment = function cdZipComment () {\n\t // Assuming UTF-8. The specification doesn't specify.\n\t return safeToString(this.data, true, 22, this.cdZipCommentLength());\n\t };\n\t EndOfCentralDirectory.prototype.rawCdZipComment = function rawCdZipComment () {\n\t return this.data.slice(22, 22 + this.cdZipCommentLength());\n\t };\n\tvar ZipTOC = function ZipTOC(index, directoryEntries, eocd, data) {\n\t this.index = index;\n\t this.directoryEntries = directoryEntries;\n\t this.eocd = eocd;\n\t this.data = data;\n\t };\n\tvar ZipFS = (function (SynchronousFileSystem$$1) {\n\t function ZipFS(input, name) {\n\t if ( name === void 0 ) name = '';\n\t\n\t SynchronousFileSystem$$1.call(this);\n\t this.name = name;\n\t this._index = new FileIndex();\n\t this._directoryEntries = [];\n\t this._eocd = null;\n\t if (input instanceof ZipTOC) {\n\t this._index = input.index;\n\t this._directoryEntries = input.directoryEntries;\n\t this._eocd = input.eocd;\n\t this.data = input.data;\n\t }\n\t else {\n\t this.data = input;\n\t this.populateIndex();\n\t }\n\t }\n\t\n\t if ( SynchronousFileSystem$$1 ) ZipFS.__proto__ = SynchronousFileSystem$$1;\n\t ZipFS.prototype = Object.create( SynchronousFileSystem$$1 && SynchronousFileSystem$$1.prototype );\n\t ZipFS.prototype.constructor = ZipFS;\n\t /* tslint:enable:variable-name */\n\t ZipFS.isAvailable = function isAvailable () { return true; };\n\t ZipFS.RegisterDecompressionMethod = function RegisterDecompressionMethod (m, fcn) {\n\t decompressionMethods[m] = fcn;\n\t };\n\t ZipFS.computeIndex = function computeIndex (data, cb) {\n\t var index = new FileIndex();\n\t var eocd = ZipFS.getEOCD(data);\n\t if (eocd.diskNumber() !== eocd.cdDiskNumber()) {\n\t throw new ApiError(ErrorCode.EINVAL, \"ZipFS does not support spanned zip files.\");\n\t }\n\t var cdPtr = eocd.cdOffset();\n\t if (cdPtr === 0xFFFFFFFF) {\n\t throw new ApiError(ErrorCode.EINVAL, \"ZipFS does not support Zip64.\");\n\t }\n\t var cdEnd = cdPtr + eocd.cdSize();\n\t ZipFS.computeIndexResponsive(data, index, cdPtr, cdEnd, cb, [], eocd);\n\t };\n\t /**\n\t * Locates the end of central directory record at the end of the file.\n\t * Throws an exception if it cannot be found.\n\t */\n\t ZipFS.getEOCD = function getEOCD (data) {\n\t // Unfortunately, the comment is variable size and up to 64K in size.\n\t // We assume that the magic signature does not appear in the comment, and\n\t // in the bytes between the comment and the signature. Other ZIP\n\t // implementations make this same assumption, since the alternative is to\n\t // read thread every entry in the file to get to it. :(\n\t // These are *negative* offsets from the end of the file.\n\t var startOffset = 22;\n\t var endOffset = Math.min(startOffset + 0xFFFF, data.length - 1);\n\t // There's not even a byte alignment guarantee on the comment so we need to\n\t // search byte by byte. *grumble grumble*\n\t for (var i = startOffset; i < endOffset; i++) {\n\t // Magic number: EOCD Signature\n\t if (data.readUInt32LE(data.length - i) === 0x06054b50) {\n\t return new EndOfCentralDirectory(data.slice(data.length - i));\n\t }\n\t }\n\t throw new ApiError(ErrorCode.EINVAL, \"Invalid ZIP file: Could not locate End of Central Directory signature.\");\n\t };\n\t ZipFS.addToIndex = function addToIndex (cd, index) {\n\t // Paths must be absolute, yet zip file paths are always relative to the\n\t // zip root. So we append '/' and call it a day.\n\t var filename = cd.fileName();\n\t if (filename.charAt(0) === '/') {\n\t throw new Error(\"WHY IS THIS ABSOLUTE\");\n\t }\n\t // XXX: For the file index, strip the trailing '/'.\n\t if (filename.charAt(filename.length - 1) === '/') {\n\t filename = filename.substr(0, filename.length - 1);\n\t }\n\t if (cd.isDirectory()) {\n\t index.addPathFast('/' + filename, new DirInode(cd));\n\t }\n\t else {\n\t index.addPathFast('/' + filename, new FileInode(cd));\n\t }\n\t };\n\t ZipFS.computeIndexResponsive = function computeIndexResponsive (data, index, cdPtr, cdEnd, cb, cdEntries, eocd) {\n\t if (cdPtr < cdEnd) {\n\t var count = 0;\n\t while (count++ < 200 && cdPtr < cdEnd) {\n\t var cd = new CentralDirectory(data, data.slice(cdPtr));\n\t ZipFS.addToIndex(cd, index);\n\t cdPtr += cd.totalSize();\n\t cdEntries.push(cd);\n\t }\n\t setImmediate(function () {\n\t ZipFS.computeIndexResponsive(data, index, cdPtr, cdEnd, cb, cdEntries, eocd);\n\t });\n\t }\n\t else {\n\t cb(new ZipTOC(index, cdEntries, eocd, data));\n\t }\n\t };\n\t ZipFS.prototype.getName = function getName () {\n\t return 'ZipFS' + (this.name !== '' ? ' ' + this.name : '');\n\t };\n\t /**\n\t * Get the CentralDirectory object for the given path.\n\t */\n\t ZipFS.prototype.getCentralDirectoryEntry = function getCentralDirectoryEntry (path$$1) {\n\t var inode = this._index.getInode(path$$1);\n\t if (inode === null) {\n\t throw ApiError.ENOENT(path$$1);\n\t }\n\t if (isFileInode(inode)) {\n\t return inode.getData();\n\t }\n\t else if (isDirInode(inode)) {\n\t return inode.getData();\n\t }\n\t else {\n\t // Should never occur.\n\t throw ApiError.EPERM((\"Invalid inode: \" + inode));\n\t }\n\t };\n\t ZipFS.prototype.getCentralDirectoryEntryAt = function getCentralDirectoryEntryAt (index) {\n\t var dirEntry = this._directoryEntries[index];\n\t if (!dirEntry) {\n\t throw new RangeError((\"Invalid directory index: \" + index + \".\"));\n\t }\n\t return dirEntry;\n\t };\n\t ZipFS.prototype.getNumberOfCentralDirectoryEntries = function getNumberOfCentralDirectoryEntries () {\n\t return this._directoryEntries.length;\n\t };\n\t ZipFS.prototype.getEndOfCentralDirectory = function getEndOfCentralDirectory () {\n\t return this._eocd;\n\t };\n\t ZipFS.prototype.diskSpace = function diskSpace (path$$1, cb) {\n\t // Read-only file system.\n\t cb(this.data.length, 0);\n\t };\n\t ZipFS.prototype.isReadOnly = function isReadOnly () {\n\t return true;\n\t };\n\t ZipFS.prototype.supportsLinks = function supportsLinks () {\n\t return false;\n\t };\n\t ZipFS.prototype.supportsProps = function supportsProps () {\n\t return false;\n\t };\n\t ZipFS.prototype.supportsSynch = function supportsSynch () {\n\t return true;\n\t };\n\t ZipFS.prototype.statSync = function statSync (path$$1, isLstat) {\n\t var inode = this._index.getInode(path$$1);\n\t if (inode === null) {\n\t throw ApiError.ENOENT(path$$1);\n\t }\n\t var stats;\n\t if (isFileInode(inode)) {\n\t stats = inode.getData().getStats();\n\t }\n\t else if (isDirInode(inode)) {\n\t stats = inode.getStats();\n\t }\n\t else {\n\t throw new ApiError(ErrorCode.EINVAL, \"Invalid inode.\");\n\t }\n\t return stats;\n\t };\n\t ZipFS.prototype.openSync = function openSync (path$$1, flags, mode) {\n\t // INVARIANT: Cannot write to RO file systems.\n\t if (flags.isWriteable()) {\n\t throw new ApiError(ErrorCode.EPERM, path$$1);\n\t }\n\t // Check if the path exists, and is a file.\n\t var inode = this._index.getInode(path$$1);\n\t if (!inode) {\n\t throw ApiError.ENOENT(path$$1);\n\t }\n\t else if (isFileInode(inode)) {\n\t var cdRecord = inode.getData();\n\t var stats = cdRecord.getStats();\n\t switch (flags.pathExistsAction()) {\n\t case ActionType.THROW_EXCEPTION:\n\t case ActionType.TRUNCATE_FILE:\n\t throw ApiError.EEXIST(path$$1);\n\t case ActionType.NOP:\n\t return new NoSyncFile(this, path$$1, flags, stats, cdRecord.getData());\n\t default:\n\t throw new ApiError(ErrorCode.EINVAL, 'Invalid FileMode object.');\n\t }\n\t }\n\t else {\n\t throw ApiError.EISDIR(path$$1);\n\t }\n\t };\n\t ZipFS.prototype.readdirSync = function readdirSync (path$$1) {\n\t // Check if it exists.\n\t var inode = this._index.getInode(path$$1);\n\t if (!inode) {\n\t throw ApiError.ENOENT(path$$1);\n\t }\n\t else if (isDirInode(inode)) {\n\t return inode.getListing();\n\t }\n\t else {\n\t throw ApiError.ENOTDIR(path$$1);\n\t }\n\t };\n\t /**\n\t * Specially-optimized readfile.\n\t */\n\t ZipFS.prototype.readFileSync = function readFileSync (fname, encoding, flag) {\n\t // Get file.\n\t var fd = this.openSync(fname, flag, 0x1a4);\n\t try {\n\t var fdCast = fd;\n\t var fdBuff = fdCast.getBuffer();\n\t if (encoding === null) {\n\t return copyingSlice(fdBuff);\n\t }\n\t return fdBuff.toString(encoding);\n\t }\n\t finally {\n\t fd.closeSync();\n\t }\n\t };\n\t ZipFS.prototype.populateIndex = function populateIndex () {\n\t var this$1 = this;\n\t\n\t var eocd = this._eocd = ZipFS.getEOCD(this.data);\n\t if (eocd.diskNumber() !== eocd.cdDiskNumber()) {\n\t throw new ApiError(ErrorCode.EINVAL, \"ZipFS does not support spanned zip files.\");\n\t }\n\t var cdPtr = eocd.cdOffset();\n\t if (cdPtr === 0xFFFFFFFF) {\n\t throw new ApiError(ErrorCode.EINVAL, \"ZipFS does not support Zip64.\");\n\t }\n\t var cdEnd = cdPtr + eocd.cdSize();\n\t while (cdPtr < cdEnd) {\n\t var cd = new CentralDirectory(this$1.data, this$1.data.slice(cdPtr));\n\t cdPtr += cd.totalSize();\n\t ZipFS.addToIndex(cd, this$1._index);\n\t this$1._directoryEntries.push(cd);\n\t }\n\t };\n\t\n\t return ZipFS;\n\t}(SynchronousFileSystem));\n\t\n\t/* tslint:disable:variable-name */\n\tZipFS.CompressionMethod = CompressionMethod;\n\tZipFS.RegisterDecompressionMethod(CompressionMethod.DEFLATE, function (data, compressedSize, uncompressedSize) {\n\t return arrayish2Buffer(inflateRaw(data.slice(0, compressedSize), { chunkSize: uncompressedSize }));\n\t});\n\tZipFS.RegisterDecompressionMethod(CompressionMethod.STORED, function (data, compressedSize, uncompressedSize) {\n\t return copyingSlice(data, 0, uncompressedSize);\n\t});\n\t\n\tvar rockRidgeIdentifier = \"IEEE_P1282\";\n\tfunction getASCIIString(data, startIndex, length) {\n\t return data.toString('ascii', startIndex, startIndex + length).trim();\n\t}\n\tfunction getJolietString(data, startIndex, length) {\n\t if (length === 1) {\n\t // Special: Root, parent, current directory are still a single byte.\n\t return String.fromCharCode(data[startIndex]);\n\t }\n\t // UTF16-BE, which isn't natively supported by NodeJS Buffers.\n\t // Length should be even, but pessimistically floor just in case.\n\t var pairs = Math.floor(length / 2);\n\t var chars = new Array(pairs);\n\t for (var i = 0; i < pairs; i++) {\n\t var pos = startIndex + (i << 1);\n\t chars[i] = String.fromCharCode(data[pos + 1] | (data[pos] << 8));\n\t }\n\t return chars.join('');\n\t}\n\tfunction getDate(data, startIndex) {\n\t var year = parseInt(getASCIIString(data, startIndex, 4), 10);\n\t var mon = parseInt(getASCIIString(data, startIndex + 4, 2), 10);\n\t var day = parseInt(getASCIIString(data, startIndex + 6, 2), 10);\n\t var hour = parseInt(getASCIIString(data, startIndex + 8, 2), 10);\n\t var min = parseInt(getASCIIString(data, startIndex + 10, 2), 10);\n\t var sec = parseInt(getASCIIString(data, startIndex + 12, 2), 10);\n\t var hundrethsSec = parseInt(getASCIIString(data, startIndex + 14, 2), 10);\n\t // Last is a time-zone offset, but JavaScript dates don't support time zones well.\n\t return new Date(year, mon, day, hour, min, sec, hundrethsSec * 100);\n\t}\n\tfunction getShortFormDate(data, startIndex) {\n\t var yearsSince1900 = data[startIndex];\n\t var month = data[startIndex + 1];\n\t var day = data[startIndex + 2];\n\t var hour = data[startIndex + 3];\n\t var minute = data[startIndex + 4];\n\t var second = data[startIndex + 5];\n\t // JavaScript's Date support isn't so great; ignore timezone.\n\t // const offsetFromGMT = this._data[24];\n\t return new Date(yearsSince1900, month - 1, day, hour, minute, second);\n\t}\n\tfunction constructSystemUseEntry(bigData, i) {\n\t var data = bigData.slice(i);\n\t var sue = new SystemUseEntry(data);\n\t switch (sue.signatureWord()) {\n\t case 17221 /* CE */:\n\t return new CEEntry(data);\n\t case 20548 /* PD */:\n\t return new PDEntry(data);\n\t case 21328 /* SP */:\n\t return new SPEntry(data);\n\t case 21332 /* ST */:\n\t return new STEntry(data);\n\t case 17746 /* ER */:\n\t return new EREntry(data);\n\t case 17747 /* ES */:\n\t return new ESEntry(data);\n\t case 20568 /* PX */:\n\t return new PXEntry(data);\n\t case 20558 /* PN */:\n\t return new PNEntry(data);\n\t case 21324 /* SL */:\n\t return new SLEntry(data);\n\t case 20045 /* NM */:\n\t return new NMEntry(data);\n\t case 17228 /* CL */:\n\t return new CLEntry(data);\n\t case 20556 /* PL */:\n\t return new PLEntry(data);\n\t case 21061 /* RE */:\n\t return new REEntry(data);\n\t case 21574 /* TF */:\n\t return new TFEntry(data);\n\t case 21318 /* SF */:\n\t return new SFEntry(data);\n\t case 21074 /* RR */:\n\t return new RREntry(data);\n\t default:\n\t return sue;\n\t }\n\t}\n\tfunction constructSystemUseEntries(data, i, len, isoData) {\n\t // If the remaining allocated space following the last recorded System Use Entry in a System\n\t // Use field or Continuation Area is less than four bytes long, it cannot contain a System\n\t // Use Entry and shall be ignored\n\t len = len - 4;\n\t var entries = new Array();\n\t while (i < len) {\n\t var entry = constructSystemUseEntry(data, i);\n\t var length = entry.length();\n\t if (length === 0) {\n\t // Invalid SU section; prevent infinite loop.\n\t return entries;\n\t }\n\t i += length;\n\t if (entry instanceof STEntry) {\n\t // ST indicates the end of entries.\n\t break;\n\t }\n\t if (entry instanceof CEEntry) {\n\t entries = entries.concat(entry.getEntries(isoData));\n\t }\n\t else {\n\t entries.push(entry);\n\t }\n\t }\n\t return entries;\n\t}\n\tvar VolumeDescriptor = function VolumeDescriptor(data) {\n\t this._data = data;\n\t};\n\tVolumeDescriptor.prototype.type = function type () {\n\t return this._data[0];\n\t};\n\tVolumeDescriptor.prototype.standardIdentifier = function standardIdentifier () {\n\t return getASCIIString(this._data, 1, 5);\n\t};\n\tVolumeDescriptor.prototype.version = function version () {\n\t return this._data[6];\n\t};\n\tVolumeDescriptor.prototype.data = function data () {\n\t return this._data.slice(7, 2048);\n\t};\n\tvar PrimaryOrSupplementaryVolumeDescriptor = (function (VolumeDescriptor) {\n\t function PrimaryOrSupplementaryVolumeDescriptor(data) {\n\t VolumeDescriptor.call(this, data);\n\t this._root = null;\n\t }\n\t\n\t if ( VolumeDescriptor ) PrimaryOrSupplementaryVolumeDescriptor.__proto__ = VolumeDescriptor;\n\t PrimaryOrSupplementaryVolumeDescriptor.prototype = Object.create( VolumeDescriptor && VolumeDescriptor.prototype );\n\t PrimaryOrSupplementaryVolumeDescriptor.prototype.constructor = PrimaryOrSupplementaryVolumeDescriptor;\n\t PrimaryOrSupplementaryVolumeDescriptor.prototype.systemIdentifier = function systemIdentifier () {\n\t return this._getString32(8);\n\t };\n\t PrimaryOrSupplementaryVolumeDescriptor.prototype.volumeIdentifier = function volumeIdentifier () {\n\t return this._getString32(40);\n\t };\n\t PrimaryOrSupplementaryVolumeDescriptor.prototype.volumeSpaceSize = function volumeSpaceSize () {\n\t return this._data.readUInt32LE(80);\n\t };\n\t PrimaryOrSupplementaryVolumeDescriptor.prototype.volumeSetSize = function volumeSetSize () {\n\t return this._data.readUInt16LE(120);\n\t };\n\t PrimaryOrSupplementaryVolumeDescriptor.prototype.volumeSequenceNumber = function volumeSequenceNumber () {\n\t return this._data.readUInt16LE(124);\n\t };\n\t PrimaryOrSupplementaryVolumeDescriptor.prototype.logicalBlockSize = function logicalBlockSize () {\n\t return this._data.readUInt16LE(128);\n\t };\n\t PrimaryOrSupplementaryVolumeDescriptor.prototype.pathTableSize = function pathTableSize () {\n\t return this._data.readUInt32LE(132);\n\t };\n\t PrimaryOrSupplementaryVolumeDescriptor.prototype.locationOfTypeLPathTable = function locationOfTypeLPathTable () {\n\t return this._data.readUInt32LE(140);\n\t };\n\t PrimaryOrSupplementaryVolumeDescriptor.prototype.locationOfOptionalTypeLPathTable = function locationOfOptionalTypeLPathTable () {\n\t return this._data.readUInt32LE(144);\n\t };\n\t PrimaryOrSupplementaryVolumeDescriptor.prototype.locationOfTypeMPathTable = function locationOfTypeMPathTable () {\n\t return this._data.readUInt32BE(148);\n\t };\n\t PrimaryOrSupplementaryVolumeDescriptor.prototype.locationOfOptionalTypeMPathTable = function locationOfOptionalTypeMPathTable () {\n\t return this._data.readUInt32BE(152);\n\t };\n\t PrimaryOrSupplementaryVolumeDescriptor.prototype.rootDirectoryEntry = function rootDirectoryEntry (isoData) {\n\t if (this._root === null) {\n\t this._root = this._constructRootDirectoryRecord(this._data.slice(156));\n\t this._root.rootCheckForRockRidge(isoData);\n\t }\n\t return this._root;\n\t };\n\t PrimaryOrSupplementaryVolumeDescriptor.prototype.volumeSetIdentifier = function volumeSetIdentifier () {\n\t return this._getString(190, 128);\n\t };\n\t PrimaryOrSupplementaryVolumeDescriptor.prototype.publisherIdentifier = function publisherIdentifier () {\n\t return this._getString(318, 128);\n\t };\n\t PrimaryOrSupplementaryVolumeDescriptor.prototype.dataPreparerIdentifier = function dataPreparerIdentifier () {\n\t return this._getString(446, 128);\n\t };\n\t PrimaryOrSupplementaryVolumeDescriptor.prototype.applicationIdentifier = function applicationIdentifier () {\n\t return this._getString(574, 128);\n\t };\n\t PrimaryOrSupplementaryVolumeDescriptor.prototype.copyrightFileIdentifier = function copyrightFileIdentifier () {\n\t return this._getString(702, 38);\n\t };\n\t PrimaryOrSupplementaryVolumeDescriptor.prototype.abstractFileIdentifier = function abstractFileIdentifier () {\n\t return this._getString(740, 36);\n\t };\n\t PrimaryOrSupplementaryVolumeDescriptor.prototype.bibliographicFileIdentifier = function bibliographicFileIdentifier () {\n\t return this._getString(776, 37);\n\t };\n\t PrimaryOrSupplementaryVolumeDescriptor.prototype.volumeCreationDate = function volumeCreationDate () {\n\t return getDate(this._data, 813);\n\t };\n\t PrimaryOrSupplementaryVolumeDescriptor.prototype.volumeModificationDate = function volumeModificationDate () {\n\t return getDate(this._data, 830);\n\t };\n\t PrimaryOrSupplementaryVolumeDescriptor.prototype.volumeExpirationDate = function volumeExpirationDate () {\n\t return getDate(this._data, 847);\n\t };\n\t PrimaryOrSupplementaryVolumeDescriptor.prototype.volumeEffectiveDate = function volumeEffectiveDate () {\n\t return getDate(this._data, 864);\n\t };\n\t PrimaryOrSupplementaryVolumeDescriptor.prototype.fileStructureVersion = function fileStructureVersion () {\n\t return this._data[881];\n\t };\n\t PrimaryOrSupplementaryVolumeDescriptor.prototype.applicationUsed = function applicationUsed () {\n\t return this._data.slice(883, 883 + 512);\n\t };\n\t PrimaryOrSupplementaryVolumeDescriptor.prototype.reserved = function reserved () {\n\t return this._data.slice(1395, 1395 + 653);\n\t };\n\t PrimaryOrSupplementaryVolumeDescriptor.prototype._getString32 = function _getString32 (idx) {\n\t return this._getString(idx, 32);\n\t };\n\t\n\t return PrimaryOrSupplementaryVolumeDescriptor;\n\t}(VolumeDescriptor));\n\tvar PrimaryVolumeDescriptor = (function (PrimaryOrSupplementaryVolumeDescriptor) {\n\t function PrimaryVolumeDescriptor(data) {\n\t PrimaryOrSupplementaryVolumeDescriptor.call(this, data);\n\t if (this.type() !== 1 /* PrimaryVolumeDescriptor */) {\n\t throw new ApiError(ErrorCode.EIO, \"Invalid primary volume descriptor.\");\n\t }\n\t }\n\t\n\t if ( PrimaryOrSupplementaryVolumeDescriptor ) PrimaryVolumeDescriptor.__proto__ = PrimaryOrSupplementaryVolumeDescriptor;\n\t PrimaryVolumeDescriptor.prototype = Object.create( PrimaryOrSupplementaryVolumeDescriptor && PrimaryOrSupplementaryVolumeDescriptor.prototype );\n\t PrimaryVolumeDescriptor.prototype.constructor = PrimaryVolumeDescriptor;\n\t PrimaryVolumeDescriptor.prototype.name = function name () {\n\t return \"ISO9660\";\n\t };\n\t PrimaryVolumeDescriptor.prototype._constructRootDirectoryRecord = function _constructRootDirectoryRecord (data) {\n\t return new ISODirectoryRecord(data, -1);\n\t };\n\t PrimaryVolumeDescriptor.prototype._getString = function _getString (idx, len) {\n\t return this._getString(idx, len);\n\t };\n\t\n\t return PrimaryVolumeDescriptor;\n\t}(PrimaryOrSupplementaryVolumeDescriptor));\n\tvar SupplementaryVolumeDescriptor = (function (PrimaryOrSupplementaryVolumeDescriptor) {\n\t function SupplementaryVolumeDescriptor(data) {\n\t PrimaryOrSupplementaryVolumeDescriptor.call(this, data);\n\t if (this.type() !== 2 /* SupplementaryVolumeDescriptor */) {\n\t throw new ApiError(ErrorCode.EIO, \"Invalid supplementary volume descriptor.\");\n\t }\n\t var escapeSequence = this.escapeSequence();\n\t var third = escapeSequence[2];\n\t // Third character identifies what 'level' of the UCS specification to follow.\n\t // We ignore it.\n\t if (escapeSequence[0] !== 0x25 || escapeSequence[1] !== 0x2F ||\n\t (third !== 0x40 && third !== 0x43 && third !== 0x45)) {\n\t throw new ApiError(ErrorCode.EIO, (\"Unrecognized escape sequence for SupplementaryVolumeDescriptor: \" + (escapeSequence.toString())));\n\t }\n\t }\n\t\n\t if ( PrimaryOrSupplementaryVolumeDescriptor ) SupplementaryVolumeDescriptor.__proto__ = PrimaryOrSupplementaryVolumeDescriptor;\n\t SupplementaryVolumeDescriptor.prototype = Object.create( PrimaryOrSupplementaryVolumeDescriptor && PrimaryOrSupplementaryVolumeDescriptor.prototype );\n\t SupplementaryVolumeDescriptor.prototype.constructor = SupplementaryVolumeDescriptor;\n\t SupplementaryVolumeDescriptor.prototype.name = function name () {\n\t return \"Joliet\";\n\t };\n\t SupplementaryVolumeDescriptor.prototype.escapeSequence = function escapeSequence () {\n\t return this._data.slice(88, 120);\n\t };\n\t SupplementaryVolumeDescriptor.prototype._constructRootDirectoryRecord = function _constructRootDirectoryRecord (data) {\n\t return new JolietDirectoryRecord(data, -1);\n\t };\n\t SupplementaryVolumeDescriptor.prototype._getString = function _getString (idx, len) {\n\t return getJolietString(this._data, idx, len);\n\t };\n\t\n\t return SupplementaryVolumeDescriptor;\n\t}(PrimaryOrSupplementaryVolumeDescriptor));\n\tvar DirectoryRecord = function DirectoryRecord(data, rockRidgeOffset) {\n\t this._suEntries = null;\n\t this._fileOrDir = null;\n\t this._data = data;\n\t this._rockRidgeOffset = rockRidgeOffset;\n\t};\n\tDirectoryRecord.prototype.hasRockRidge = function hasRockRidge () {\n\t return this._rockRidgeOffset > -1;\n\t};\n\tDirectoryRecord.prototype.getRockRidgeOffset = function getRockRidgeOffset () {\n\t return this._rockRidgeOffset;\n\t};\n\t/**\n\t * !!ONLY VALID ON ROOT NODE!!\n\t * Checks if Rock Ridge is enabled, and sets the offset.\n\t */\n\tDirectoryRecord.prototype.rootCheckForRockRidge = function rootCheckForRockRidge (isoData) {\n\t var dir = this.getDirectory(isoData);\n\t this._rockRidgeOffset = dir.getDotEntry(isoData)._getRockRidgeOffset(isoData);\n\t if (this._rockRidgeOffset > -1) {\n\t // Wipe out directory. Start over with RR knowledge.\n\t this._fileOrDir = null;\n\t }\n\t};\n\tDirectoryRecord.prototype.length = function length () {\n\t return this._data[0];\n\t};\n\tDirectoryRecord.prototype.extendedAttributeRecordLength = function extendedAttributeRecordLength () {\n\t return this._data[1];\n\t};\n\tDirectoryRecord.prototype.lba = function lba () {\n\t return this._data.readUInt32LE(2) * 2048;\n\t};\n\tDirectoryRecord.prototype.dataLength = function dataLength () {\n\t return this._data.readUInt32LE(10);\n\t};\n\tDirectoryRecord.prototype.recordingDate = function recordingDate () {\n\t return getShortFormDate(this._data, 18);\n\t};\n\tDirectoryRecord.prototype.fileFlags = function fileFlags () {\n\t return this._data[25];\n\t};\n\tDirectoryRecord.prototype.fileUnitSize = function fileUnitSize () {\n\t return this._data[26];\n\t};\n\tDirectoryRecord.prototype.interleaveGapSize = function interleaveGapSize () {\n\t return this._data[27];\n\t};\n\tDirectoryRecord.prototype.volumeSequenceNumber = function volumeSequenceNumber () {\n\t return this._data.readUInt16LE(28);\n\t};\n\tDirectoryRecord.prototype.identifier = function identifier () {\n\t return this._getString(33, this._data[32]);\n\t};\n\tDirectoryRecord.prototype.fileName = function fileName (isoData) {\n\t if (this.hasRockRidge()) {\n\t var fn = this._rockRidgeFilename(isoData);\n\t if (fn !== null) {\n\t return fn;\n\t }\n\t }\n\t var ident = this.identifier();\n\t if (this.isDirectory(isoData)) {\n\t return ident;\n\t }\n\t // Files:\n\t // - MUST have 0x2E (.) separating the name from the extension\n\t // - MUST have 0x3B (;) separating the file name and extension from the version\n\t // Gets expanded to two-byte char in Unicode directory records.\n\t var versionSeparator = ident.indexOf(';');\n\t if (versionSeparator === -1) {\n\t // Some Joliet filenames lack the version separator, despite the standard\n\t // specifying that it should be there.\n\t return ident;\n\t }\n\t else if (ident[versionSeparator - 1] === '.') {\n\t // Empty extension. Do not include '.' in the filename.\n\t return ident.slice(0, versionSeparator - 1);\n\t }\n\t else {\n\t // Include up to version separator.\n\t return ident.slice(0, versionSeparator);\n\t }\n\t};\n\tDirectoryRecord.prototype.isDirectory = function isDirectory (isoData) {\n\t var rv = !!(this.fileFlags() & 2 /* Directory */);\n\t // If it lacks the Directory flag, it may still be a directory if we've exceeded the directory\n\t // depth limit. Rock Ridge marks these as files and adds a special attribute.\n\t if (!rv && this.hasRockRidge()) {\n\t rv = this.getSUEntries(isoData).filter(function (e) { return e instanceof CLEntry; }).length > 0;\n\t }\n\t return rv;\n\t};\n\tDirectoryRecord.prototype.isSymlink = function isSymlink (isoData) {\n\t return this.hasRockRidge() && this.getSUEntries(isoData).filter(function (e) { return e instanceof SLEntry; }).length > 0;\n\t};\n\tDirectoryRecord.prototype.getSymlinkPath = function getSymlinkPath (isoData) {\n\t var p = \"\";\n\t var entries = this.getSUEntries(isoData);\n\t var getStr = this._getGetString();\n\t for (var i = 0; i < entries.length; i++) {\n\t var entry = entries[i];\n\t if (entry instanceof SLEntry) {\n\t var components = entry.componentRecords();\n\t for (var j = 0; j < components.length; j++) {\n\t var component = components[j];\n\t var flags = component.flags();\n\t if (flags & 2 /* CURRENT */) {\n\t p += \"./\";\n\t }\n\t else if (flags & 4 /* PARENT */) {\n\t p += \"../\";\n\t }\n\t else if (flags & 8 /* ROOT */) {\n\t p += \"/\";\n\t }\n\t else {\n\t p += component.content(getStr);\n\t if (!(flags & 1 /* CONTINUE */)) {\n\t p += '/';\n\t }\n\t }\n\t }\n\t if (!entry.continueFlag()) {\n\t // We are done with this link.\n\t break;\n\t }\n\t }\n\t }\n\t if (p.length > 1 && p[p.length - 1] === '/') {\n\t // Trim trailing '/'.\n\t return p.slice(0, p.length - 1);\n\t }\n\t else {\n\t return p;\n\t }\n\t};\n\tDirectoryRecord.prototype.getFile = function getFile (isoData) {\n\t if (this.isDirectory(isoData)) {\n\t throw new Error(\"Tried to get a File from a directory.\");\n\t }\n\t if (this._fileOrDir === null) {\n\t this._fileOrDir = isoData.slice(this.lba(), this.lba() + this.dataLength());\n\t }\n\t return this._fileOrDir;\n\t};\n\tDirectoryRecord.prototype.getDirectory = function getDirectory (isoData) {\n\t if (!this.isDirectory(isoData)) {\n\t throw new Error(\"Tried to get a Directory from a file.\");\n\t }\n\t if (this._fileOrDir === null) {\n\t this._fileOrDir = this._constructDirectory(isoData);\n\t }\n\t return this._fileOrDir;\n\t};\n\tDirectoryRecord.prototype.getSUEntries = function getSUEntries (isoData) {\n\t if (!this._suEntries) {\n\t this._constructSUEntries(isoData);\n\t }\n\t return this._suEntries;\n\t};\n\tDirectoryRecord.prototype._rockRidgeFilename = function _rockRidgeFilename (isoData) {\n\t var nmEntries = this.getSUEntries(isoData).filter(function (e) { return e instanceof NMEntry; });\n\t if (nmEntries.length === 0 || nmEntries[0].flags() & (2 /* CURRENT */ | 4 /* PARENT */)) {\n\t return null;\n\t }\n\t var str = '';\n\t var getString = this._getGetString();\n\t for (var i = 0; i < nmEntries.length; i++) {\n\t var e = nmEntries[i];\n\t str += e.name(getString);\n\t if (!(e.flags() & 1 /* CONTINUE */)) {\n\t break;\n\t }\n\t }\n\t return str;\n\t};\n\tDirectoryRecord.prototype._constructSUEntries = function _constructSUEntries (isoData) {\n\t var i = 33 + this._data[32];\n\t if (i % 2 === 1) {\n\t // Skip padding field.\n\t i++;\n\t }\n\t i += this._rockRidgeOffset;\n\t this._suEntries = constructSystemUseEntries(this._data, i, this.length(), isoData);\n\t};\n\t/**\n\t * !!ONLY VALID ON FIRST ENTRY OF ROOT DIRECTORY!!\n\t * Returns -1 if rock ridge is not enabled. Otherwise, returns the offset\n\t * at which system use fields begin.\n\t */\n\tDirectoryRecord.prototype._getRockRidgeOffset = function _getRockRidgeOffset (isoData) {\n\t // In the worst case, we get some garbage SU entries.\n\t // Fudge offset to 0 before proceeding.\n\t this._rockRidgeOffset = 0;\n\t var suEntries = this.getSUEntries(isoData);\n\t if (suEntries.length > 0) {\n\t var spEntry = suEntries[0];\n\t if (spEntry instanceof SPEntry && spEntry.checkBytesPass()) {\n\t // SUSP is in use.\n\t for (var i = 1; i < suEntries.length; i++) {\n\t var entry = suEntries[i];\n\t if (entry instanceof RREntry || (entry instanceof EREntry && entry.extensionIdentifier() === rockRidgeIdentifier)) {\n\t // Rock Ridge is in use!\n\t return spEntry.bytesSkipped();\n\t }\n\t }\n\t }\n\t }\n\t // Failed.\n\t this._rockRidgeOffset = -1;\n\t return -1;\n\t};\n\tvar ISODirectoryRecord = (function (DirectoryRecord) {\n\t function ISODirectoryRecord(data, rockRidgeOffset) {\n\t DirectoryRecord.call(this, data, rockRidgeOffset);\n\t }\n\t\n\t if ( DirectoryRecord ) ISODirectoryRecord.__proto__ = DirectoryRecord;\n\t ISODirectoryRecord.prototype = Object.create( DirectoryRecord && DirectoryRecord.prototype );\n\t ISODirectoryRecord.prototype.constructor = ISODirectoryRecord;\n\t ISODirectoryRecord.prototype._getString = function _getString (i, len) {\n\t return getASCIIString(this._data, i, len);\n\t };\n\t ISODirectoryRecord.prototype._constructDirectory = function _constructDirectory (isoData) {\n\t return new ISODirectory(this, isoData);\n\t };\n\t ISODirectoryRecord.prototype._getGetString = function _getGetString () {\n\t return getASCIIString;\n\t };\n\t\n\t return ISODirectoryRecord;\n\t}(DirectoryRecord));\n\tvar JolietDirectoryRecord = (function (DirectoryRecord) {\n\t function JolietDirectoryRecord(data, rockRidgeOffset) {\n\t DirectoryRecord.call(this, data, rockRidgeOffset);\n\t }\n\t\n\t if ( DirectoryRecord ) JolietDirectoryRecord.__proto__ = DirectoryRecord;\n\t JolietDirectoryRecord.prototype = Object.create( DirectoryRecord && DirectoryRecord.prototype );\n\t JolietDirectoryRecord.prototype.constructor = JolietDirectoryRecord;\n\t JolietDirectoryRecord.prototype._getString = function _getString (i, len) {\n\t return getJolietString(this._data, i, len);\n\t };\n\t JolietDirectoryRecord.prototype._constructDirectory = function _constructDirectory (isoData) {\n\t return new JolietDirectory(this, isoData);\n\t };\n\t JolietDirectoryRecord.prototype._getGetString = function _getGetString () {\n\t return getJolietString;\n\t };\n\t\n\t return JolietDirectoryRecord;\n\t}(DirectoryRecord));\n\tvar SystemUseEntry = function SystemUseEntry(data) {\n\t this._data = data;\n\t};\n\tSystemUseEntry.prototype.signatureWord = function signatureWord () {\n\t return this._data.readUInt16BE(0);\n\t};\n\tSystemUseEntry.prototype.signatureWordString = function signatureWordString () {\n\t return getASCIIString(this._data, 0, 2);\n\t};\n\tSystemUseEntry.prototype.length = function length () {\n\t return this._data[2];\n\t};\n\tSystemUseEntry.prototype.suVersion = function suVersion () {\n\t return this._data[3];\n\t};\n\t/**\n\t * Continuation entry.\n\t */\n\tvar CEEntry = (function (SystemUseEntry) {\n\t function CEEntry(data) {\n\t SystemUseEntry.call(this, data);\n\t this._entries = null;\n\t }\n\t\n\t if ( SystemUseEntry ) CEEntry.__proto__ = SystemUseEntry;\n\t CEEntry.prototype = Object.create( SystemUseEntry && SystemUseEntry.prototype );\n\t CEEntry.prototype.constructor = CEEntry;\n\t /**\n\t * Logical block address of the continuation area.\n\t */\n\t CEEntry.prototype.continuationLba = function continuationLba () {\n\t return this._data.readUInt32LE(4);\n\t };\n\t /**\n\t * Offset into the logical block.\n\t */\n\t CEEntry.prototype.continuationLbaOffset = function continuationLbaOffset () {\n\t return this._data.readUInt32LE(12);\n\t };\n\t /**\n\t * Length of the continuation area.\n\t */\n\t CEEntry.prototype.continuationLength = function continuationLength () {\n\t return this._data.readUInt32LE(20);\n\t };\n\t CEEntry.prototype.getEntries = function getEntries (isoData) {\n\t if (!this._entries) {\n\t var start = this.continuationLba() * 2048 + this.continuationLbaOffset();\n\t this._entries = constructSystemUseEntries(isoData, start, this.continuationLength(), isoData);\n\t }\n\t return this._entries;\n\t };\n\t\n\t return CEEntry;\n\t}(SystemUseEntry));\n\t/**\n\t * Padding entry.\n\t */\n\tvar PDEntry = (function (SystemUseEntry) {\n\t function PDEntry(data) {\n\t SystemUseEntry.call(this, data);\n\t }\n\t\n\t if ( SystemUseEntry ) PDEntry.__proto__ = SystemUseEntry;\n\t PDEntry.prototype = Object.create( SystemUseEntry && SystemUseEntry.prototype );\n\t PDEntry.prototype.constructor = PDEntry;\n\t\n\t return PDEntry;\n\t}(SystemUseEntry));\n\t/**\n\t * Identifies that SUSP is in-use.\n\t */\n\tvar SPEntry = (function (SystemUseEntry) {\n\t function SPEntry(data) {\n\t SystemUseEntry.call(this, data);\n\t }\n\t\n\t if ( SystemUseEntry ) SPEntry.__proto__ = SystemUseEntry;\n\t SPEntry.prototype = Object.create( SystemUseEntry && SystemUseEntry.prototype );\n\t SPEntry.prototype.constructor = SPEntry;\n\t SPEntry.prototype.checkBytesPass = function checkBytesPass () {\n\t return this._data[4] === 0xBE && this._data[5] === 0xEF;\n\t };\n\t SPEntry.prototype.bytesSkipped = function bytesSkipped () {\n\t return this._data[6];\n\t };\n\t\n\t return SPEntry;\n\t}(SystemUseEntry));\n\t/**\n\t * Identifies the end of the SUSP entries.\n\t */\n\tvar STEntry = (function (SystemUseEntry) {\n\t function STEntry(data) {\n\t SystemUseEntry.call(this, data);\n\t }\n\t\n\t if ( SystemUseEntry ) STEntry.__proto__ = SystemUseEntry;\n\t STEntry.prototype = Object.create( SystemUseEntry && SystemUseEntry.prototype );\n\t STEntry.prototype.constructor = STEntry;\n\t\n\t return STEntry;\n\t}(SystemUseEntry));\n\t/**\n\t * Specifies system-specific extensions to SUSP.\n\t */\n\tvar EREntry = (function (SystemUseEntry) {\n\t function EREntry(data) {\n\t SystemUseEntry.call(this, data);\n\t }\n\t\n\t if ( SystemUseEntry ) EREntry.__proto__ = SystemUseEntry;\n\t EREntry.prototype = Object.create( SystemUseEntry && SystemUseEntry.prototype );\n\t EREntry.prototype.constructor = EREntry;\n\t EREntry.prototype.identifierLength = function identifierLength () {\n\t return this._data[4];\n\t };\n\t EREntry.prototype.descriptorLength = function descriptorLength () {\n\t return this._data[5];\n\t };\n\t EREntry.prototype.sourceLength = function sourceLength () {\n\t return this._data[6];\n\t };\n\t EREntry.prototype.extensionVersion = function extensionVersion () {\n\t return this._data[7];\n\t };\n\t EREntry.prototype.extensionIdentifier = function extensionIdentifier () {\n\t return getASCIIString(this._data, 8, this.identifierLength());\n\t };\n\t EREntry.prototype.extensionDescriptor = function extensionDescriptor () {\n\t return getASCIIString(this._data, 8 + this.identifierLength(), this.descriptorLength());\n\t };\n\t EREntry.prototype.extensionSource = function extensionSource () {\n\t return getASCIIString(this._data, 8 + this.identifierLength() + this.descriptorLength(), this.sourceLength());\n\t };\n\t\n\t return EREntry;\n\t}(SystemUseEntry));\n\tvar ESEntry = (function (SystemUseEntry) {\n\t function ESEntry(data) {\n\t SystemUseEntry.call(this, data);\n\t }\n\t\n\t if ( SystemUseEntry ) ESEntry.__proto__ = SystemUseEntry;\n\t ESEntry.prototype = Object.create( SystemUseEntry && SystemUseEntry.prototype );\n\t ESEntry.prototype.constructor = ESEntry;\n\t ESEntry.prototype.extensionSequence = function extensionSequence () {\n\t return this._data[4];\n\t };\n\t\n\t return ESEntry;\n\t}(SystemUseEntry));\n\t/**\n\t * RockRidge: Marks that RockRidge is in use [deprecated]\n\t */\n\tvar RREntry = (function (SystemUseEntry) {\n\t function RREntry(data) {\n\t SystemUseEntry.call(this, data);\n\t }\n\t\n\t if ( SystemUseEntry ) RREntry.__proto__ = SystemUseEntry;\n\t RREntry.prototype = Object.create( SystemUseEntry && SystemUseEntry.prototype );\n\t RREntry.prototype.constructor = RREntry;\n\t\n\t return RREntry;\n\t}(SystemUseEntry));\n\t/**\n\t * RockRidge: Records POSIX file attributes.\n\t */\n\tvar PXEntry = (function (SystemUseEntry) {\n\t function PXEntry(data) {\n\t SystemUseEntry.call(this, data);\n\t }\n\t\n\t if ( SystemUseEntry ) PXEntry.__proto__ = SystemUseEntry;\n\t PXEntry.prototype = Object.create( SystemUseEntry && SystemUseEntry.prototype );\n\t PXEntry.prototype.constructor = PXEntry;\n\t PXEntry.prototype.mode = function mode () {\n\t return this._data.readUInt32LE(4);\n\t };\n\t PXEntry.prototype.fileLinks = function fileLinks () {\n\t return this._data.readUInt32LE(12);\n\t };\n\t PXEntry.prototype.uid = function uid () {\n\t return this._data.readUInt32LE(20);\n\t };\n\t PXEntry.prototype.gid = function gid () {\n\t return this._data.readUInt32LE(28);\n\t };\n\t PXEntry.prototype.inode = function inode () {\n\t return this._data.readUInt32LE(36);\n\t };\n\t\n\t return PXEntry;\n\t}(SystemUseEntry));\n\t/**\n\t * RockRidge: Records POSIX device number.\n\t */\n\tvar PNEntry = (function (SystemUseEntry) {\n\t function PNEntry(data) {\n\t SystemUseEntry.call(this, data);\n\t }\n\t\n\t if ( SystemUseEntry ) PNEntry.__proto__ = SystemUseEntry;\n\t PNEntry.prototype = Object.create( SystemUseEntry && SystemUseEntry.prototype );\n\t PNEntry.prototype.constructor = PNEntry;\n\t PNEntry.prototype.devTHigh = function devTHigh () {\n\t return this._data.readUInt32LE(4);\n\t };\n\t PNEntry.prototype.devTLow = function devTLow () {\n\t return this._data.readUInt32LE(12);\n\t };\n\t\n\t return PNEntry;\n\t}(SystemUseEntry));\n\t/**\n\t * RockRidge: Records symbolic link\n\t */\n\tvar SLEntry = (function (SystemUseEntry) {\n\t function SLEntry(data) {\n\t SystemUseEntry.call(this, data);\n\t }\n\t\n\t if ( SystemUseEntry ) SLEntry.__proto__ = SystemUseEntry;\n\t SLEntry.prototype = Object.create( SystemUseEntry && SystemUseEntry.prototype );\n\t SLEntry.prototype.constructor = SLEntry;\n\t SLEntry.prototype.flags = function flags () {\n\t return this._data[4];\n\t };\n\t SLEntry.prototype.continueFlag = function continueFlag () {\n\t return this.flags() & 0x1;\n\t };\n\t SLEntry.prototype.componentRecords = function componentRecords () {\n\t var this$1 = this;\n\t\n\t var records = new Array();\n\t var i = 5;\n\t while (i < this.length()) {\n\t var record = new SLComponentRecord(this$1._data.slice(i));\n\t records.push(record);\n\t i += record.length();\n\t }\n\t return records;\n\t };\n\t\n\t return SLEntry;\n\t}(SystemUseEntry));\n\tvar SLComponentRecord = function SLComponentRecord(data) {\n\t this._data = data;\n\t};\n\tSLComponentRecord.prototype.flags = function flags () {\n\t return this._data[0];\n\t};\n\tSLComponentRecord.prototype.length = function length () {\n\t return 2 + this.componentLength();\n\t};\n\tSLComponentRecord.prototype.componentLength = function componentLength () {\n\t return this._data[1];\n\t};\n\tSLComponentRecord.prototype.content = function content (getString) {\n\t return getString(this._data, 2, this.componentLength());\n\t};\n\t/**\n\t * RockRidge: Records alternate file name\n\t */\n\tvar NMEntry = (function (SystemUseEntry) {\n\t function NMEntry(data) {\n\t SystemUseEntry.call(this, data);\n\t }\n\t\n\t if ( SystemUseEntry ) NMEntry.__proto__ = SystemUseEntry;\n\t NMEntry.prototype = Object.create( SystemUseEntry && SystemUseEntry.prototype );\n\t NMEntry.prototype.constructor = NMEntry;\n\t NMEntry.prototype.flags = function flags () {\n\t return this._data[4];\n\t };\n\t NMEntry.prototype.name = function name (getString) {\n\t return getString(this._data, 5, this.length() - 5);\n\t };\n\t\n\t return NMEntry;\n\t}(SystemUseEntry));\n\t/**\n\t * RockRidge: Records child link\n\t */\n\tvar CLEntry = (function (SystemUseEntry) {\n\t function CLEntry(data) {\n\t SystemUseEntry.call(this, data);\n\t }\n\t\n\t if ( SystemUseEntry ) CLEntry.__proto__ = SystemUseEntry;\n\t CLEntry.prototype = Object.create( SystemUseEntry && SystemUseEntry.prototype );\n\t CLEntry.prototype.constructor = CLEntry;\n\t CLEntry.prototype.childDirectoryLba = function childDirectoryLba () {\n\t return this._data.readUInt32LE(4);\n\t };\n\t\n\t return CLEntry;\n\t}(SystemUseEntry));\n\t/**\n\t * RockRidge: Records parent link.\n\t */\n\tvar PLEntry = (function (SystemUseEntry) {\n\t function PLEntry(data) {\n\t SystemUseEntry.call(this, data);\n\t }\n\t\n\t if ( SystemUseEntry ) PLEntry.__proto__ = SystemUseEntry;\n\t PLEntry.prototype = Object.create( SystemUseEntry && SystemUseEntry.prototype );\n\t PLEntry.prototype.constructor = PLEntry;\n\t PLEntry.prototype.parentDirectoryLba = function parentDirectoryLba () {\n\t return this._data.readUInt32LE(4);\n\t };\n\t\n\t return PLEntry;\n\t}(SystemUseEntry));\n\t/**\n\t * RockRidge: Records relocated directory.\n\t */\n\tvar REEntry = (function (SystemUseEntry) {\n\t function REEntry(data) {\n\t SystemUseEntry.call(this, data);\n\t }\n\t\n\t if ( SystemUseEntry ) REEntry.__proto__ = SystemUseEntry;\n\t REEntry.prototype = Object.create( SystemUseEntry && SystemUseEntry.prototype );\n\t REEntry.prototype.constructor = REEntry;\n\t\n\t return REEntry;\n\t}(SystemUseEntry));\n\t/**\n\t * RockRidge: Records file timestamps\n\t */\n\tvar TFEntry = (function (SystemUseEntry) {\n\t function TFEntry(data) {\n\t SystemUseEntry.call(this, data);\n\t }\n\t\n\t if ( SystemUseEntry ) TFEntry.__proto__ = SystemUseEntry;\n\t TFEntry.prototype = Object.create( SystemUseEntry && SystemUseEntry.prototype );\n\t TFEntry.prototype.constructor = TFEntry;\n\t TFEntry.prototype.flags = function flags () {\n\t return this._data[4];\n\t };\n\t TFEntry.prototype.creation = function creation () {\n\t if (this.flags() & 1 /* CREATION */) {\n\t if (this._longFormDates()) {\n\t return getDate(this._data, 5);\n\t }\n\t else {\n\t return getShortFormDate(this._data, 5);\n\t }\n\t }\n\t else {\n\t return null;\n\t }\n\t };\n\t TFEntry.prototype.modify = function modify () {\n\t if (this.flags() & 2 /* MODIFY */) {\n\t var previousDates = (this.flags() & 1 /* CREATION */) ? 1 : 0;\n\t if (this._longFormDates) {\n\t return getDate(this._data, 5 + (previousDates * 17));\n\t }\n\t else {\n\t return getShortFormDate(this._data, 5 + (previousDates * 7));\n\t }\n\t }\n\t else {\n\t return null;\n\t }\n\t };\n\t TFEntry.prototype.access = function access () {\n\t if (this.flags() & 4 /* ACCESS */) {\n\t var previousDates = (this.flags() & 1 /* CREATION */) ? 1 : 0;\n\t previousDates += (this.flags() & 2 /* MODIFY */) ? 1 : 0;\n\t if (this._longFormDates) {\n\t return getDate(this._data, 5 + (previousDates * 17));\n\t }\n\t else {\n\t return getShortFormDate(this._data, 5 + (previousDates * 7));\n\t }\n\t }\n\t else {\n\t return null;\n\t }\n\t };\n\t TFEntry.prototype.backup = function backup () {\n\t if (this.flags() & 16 /* BACKUP */) {\n\t var previousDates = (this.flags() & 1 /* CREATION */) ? 1 : 0;\n\t previousDates += (this.flags() & 2 /* MODIFY */) ? 1 : 0;\n\t previousDates += (this.flags() & 4 /* ACCESS */) ? 1 : 0;\n\t if (this._longFormDates) {\n\t return getDate(this._data, 5 + (previousDates * 17));\n\t }\n\t else {\n\t return getShortFormDate(this._data, 5 + (previousDates * 7));\n\t }\n\t }\n\t else {\n\t return null;\n\t }\n\t };\n\t TFEntry.prototype.expiration = function expiration () {\n\t if (this.flags() & 32 /* EXPIRATION */) {\n\t var previousDates = (this.flags() & 1 /* CREATION */) ? 1 : 0;\n\t previousDates += (this.flags() & 2 /* MODIFY */) ? 1 : 0;\n\t previousDates += (this.flags() & 4 /* ACCESS */) ? 1 : 0;\n\t previousDates += (this.flags() & 16 /* BACKUP */) ? 1 : 0;\n\t if (this._longFormDates) {\n\t return getDate(this._data, 5 + (previousDates * 17));\n\t }\n\t else {\n\t return getShortFormDate(this._data, 5 + (previousDates * 7));\n\t }\n\t }\n\t else {\n\t return null;\n\t }\n\t };\n\t TFEntry.prototype.effective = function effective () {\n\t if (this.flags() & 64 /* EFFECTIVE */) {\n\t var previousDates = (this.flags() & 1 /* CREATION */) ? 1 : 0;\n\t previousDates += (this.flags() & 2 /* MODIFY */) ? 1 : 0;\n\t previousDates += (this.flags() & 4 /* ACCESS */) ? 1 : 0;\n\t previousDates += (this.flags() & 16 /* BACKUP */) ? 1 : 0;\n\t previousDates += (this.flags() & 32 /* EXPIRATION */) ? 1 : 0;\n\t if (this._longFormDates) {\n\t return getDate(this._data, 5 + (previousDates * 17));\n\t }\n\t else {\n\t return getShortFormDate(this._data, 5 + (previousDates * 7));\n\t }\n\t }\n\t else {\n\t return null;\n\t }\n\t };\n\t TFEntry.prototype._longFormDates = function _longFormDates () {\n\t return !!(this.flags() && 128 /* LONG_FORM */);\n\t };\n\t\n\t return TFEntry;\n\t}(SystemUseEntry));\n\t/**\n\t * RockRidge: File data in sparse format.\n\t */\n\tvar SFEntry = (function (SystemUseEntry) {\n\t function SFEntry(data) {\n\t SystemUseEntry.call(this, data);\n\t }\n\t\n\t if ( SystemUseEntry ) SFEntry.__proto__ = SystemUseEntry;\n\t SFEntry.prototype = Object.create( SystemUseEntry && SystemUseEntry.prototype );\n\t SFEntry.prototype.constructor = SFEntry;\n\t SFEntry.prototype.virtualSizeHigh = function virtualSizeHigh () {\n\t return this._data.readUInt32LE(4);\n\t };\n\t SFEntry.prototype.virtualSizeLow = function virtualSizeLow () {\n\t return this._data.readUInt32LE(12);\n\t };\n\t SFEntry.prototype.tableDepth = function tableDepth () {\n\t return this._data[20];\n\t };\n\t\n\t return SFEntry;\n\t}(SystemUseEntry));\n\tvar Directory = function Directory(record, isoData) {\n\t var this$1 = this;\n\t\n\t this._fileList = [];\n\t this._fileMap = {};\n\t this._record = record;\n\t var i = record.lba();\n\t var iLimit = i + record.dataLength();\n\t if (!(record.fileFlags() & 2 /* Directory */)) {\n\t // Must have a CL entry.\n\t var cl = record.getSUEntries(isoData).filter(function (e) { return e instanceof CLEntry; })[0];\n\t i = cl.childDirectoryLba() * 2048;\n\t iLimit = Infinity;\n\t }\n\t while (i < iLimit) {\n\t var len = isoData[i];\n\t // Zero-padding between sectors.\n\t // TODO: Could optimize this to seek to nearest-sector upon\n\t // seeing a 0.\n\t if (len === 0) {\n\t i++;\n\t continue;\n\t }\n\t var r = this$1._constructDirectoryRecord(isoData.slice(i));\n\t var fname = r.fileName(isoData);\n\t // Skip '.' and '..' entries.\n\t if (fname !== '\\u0000' && fname !== '\\u0001') {\n\t // Skip relocated entries.\n\t if (!r.hasRockRidge() || r.getSUEntries(isoData).filter(function (e) { return e instanceof REEntry; }).length === 0) {\n\t this$1._fileMap[fname] = r;\n\t this$1._fileList.push(fname);\n\t }\n\t }\n\t else if (iLimit === Infinity) {\n\t // First entry contains needed data.\n\t iLimit = i + r.dataLength();\n\t }\n\t i += r.length();\n\t }\n\t};\n\t/**\n\t * Get the record with the given name.\n\t * Returns undefined if not present.\n\t */\n\tDirectory.prototype.getRecord = function getRecord (name) {\n\t return this._fileMap[name];\n\t};\n\tDirectory.prototype.getFileList = function getFileList () {\n\t return this._fileList;\n\t};\n\tDirectory.prototype.getDotEntry = function getDotEntry (isoData) {\n\t return this._constructDirectoryRecord(isoData.slice(this._record.lba()));\n\t};\n\tvar ISODirectory = (function (Directory) {\n\t function ISODirectory(record, isoData) {\n\t Directory.call(this, record, isoData);\n\t }\n\t\n\t if ( Directory ) ISODirectory.__proto__ = Directory;\n\t ISODirectory.prototype = Object.create( Directory && Directory.prototype );\n\t ISODirectory.prototype.constructor = ISODirectory;\n\t ISODirectory.prototype._constructDirectoryRecord = function _constructDirectoryRecord (data) {\n\t return new ISODirectoryRecord(data, this._record.getRockRidgeOffset());\n\t };\n\t\n\t return ISODirectory;\n\t}(Directory));\n\tvar JolietDirectory = (function (Directory) {\n\t function JolietDirectory(record, isoData) {\n\t Directory.call(this, record, isoData);\n\t }\n\t\n\t if ( Directory ) JolietDirectory.__proto__ = Directory;\n\t JolietDirectory.prototype = Object.create( Directory && Directory.prototype );\n\t JolietDirectory.prototype.constructor = JolietDirectory;\n\t JolietDirectory.prototype._constructDirectoryRecord = function _constructDirectoryRecord (data) {\n\t return new JolietDirectoryRecord(data, this._record.getRockRidgeOffset());\n\t };\n\t\n\t return JolietDirectory;\n\t}(Directory));\n\tvar IsoFS = (function (SynchronousFileSystem$$1) {\n\t function IsoFS(data, name) {\n\t var this$1 = this;\n\t if ( name === void 0 ) name = \"\";\n\t\n\t SynchronousFileSystem$$1.call(this);\n\t this._data = data;\n\t // Skip first 16 sectors.\n\t var vdTerminatorFound = false;\n\t var i = 16 * 2048;\n\t var candidateVDs = new Array();\n\t while (!vdTerminatorFound) {\n\t var slice = data.slice(i);\n\t var vd = new VolumeDescriptor(slice);\n\t switch (vd.type()) {\n\t case 1 /* PrimaryVolumeDescriptor */:\n\t candidateVDs.push(new PrimaryVolumeDescriptor(slice));\n\t break;\n\t case 2 /* SupplementaryVolumeDescriptor */:\n\t candidateVDs.push(new SupplementaryVolumeDescriptor(slice));\n\t break;\n\t case 255 /* VolumeDescriptorSetTerminator */:\n\t vdTerminatorFound = true;\n\t break;\n\t }\n\t i += 2048;\n\t }\n\t if (candidateVDs.length === 0) {\n\t throw new ApiError(ErrorCode.EIO, \"Unable to find a suitable volume descriptor.\");\n\t }\n\t candidateVDs.forEach(function (v) {\n\t // Take an SVD over a PVD.\n\t if (!this$1._pvd || this$1._pvd.type() !== 2 /* SupplementaryVolumeDescriptor */) {\n\t this$1._pvd = v;\n\t }\n\t });\n\t this._root = this._pvd.rootDirectoryEntry(data);\n\t this._name = name;\n\t }\n\t\n\t if ( SynchronousFileSystem$$1 ) IsoFS.__proto__ = SynchronousFileSystem$$1;\n\t IsoFS.prototype = Object.create( SynchronousFileSystem$$1 && SynchronousFileSystem$$1.prototype );\n\t IsoFS.prototype.constructor = IsoFS;\n\t IsoFS.isAvailable = function isAvailable () {\n\t return true;\n\t };\n\t\n\t IsoFS.prototype.getName = function getName () {\n\t var name = \"IsoFS\" + (this._name) + \"-\" + (this._pvd.name());\n\t if (this._root.hasRockRidge()) {\n\t name += \"-RockRidge\";\n\t }\n\t return name;\n\t };\n\t IsoFS.prototype.diskSpace = function diskSpace (path$$1, cb) {\n\t // Read-only file system.\n\t cb(this._data.length, 0);\n\t };\n\t IsoFS.prototype.isReadOnly = function isReadOnly () {\n\t return true;\n\t };\n\t IsoFS.prototype.supportsLinks = function supportsLinks () {\n\t return false;\n\t };\n\t IsoFS.prototype.supportsProps = function supportsProps () {\n\t return false;\n\t };\n\t IsoFS.prototype.supportsSynch = function supportsSynch () {\n\t return true;\n\t };\n\t IsoFS.prototype.statSync = function statSync (p, isLstat) {\n\t var record = this._getDirectoryRecord(p);\n\t if (record === null) {\n\t throw ApiError.ENOENT(p);\n\t }\n\t return this._getStats(p, record);\n\t };\n\t IsoFS.prototype.openSync = function openSync (p, flags, mode) {\n\t // INVARIANT: Cannot write to RO file systems.\n\t if (flags.isWriteable()) {\n\t throw new ApiError(ErrorCode.EPERM, p);\n\t }\n\t // Check if the path exists, and is a file.\n\t var record = this._getDirectoryRecord(p);\n\t if (!record) {\n\t throw ApiError.ENOENT(p);\n\t }\n\t else if (record.isSymlink(this._data)) {\n\t return this.openSync(path.resolve(p, record.getSymlinkPath(this._data)), flags, mode);\n\t }\n\t else if (!record.isDirectory(this._data)) {\n\t var data = record.getFile(this._data);\n\t var stats = this._getStats(p, record);\n\t switch (flags.pathExistsAction()) {\n\t case ActionType.THROW_EXCEPTION:\n\t case ActionType.TRUNCATE_FILE:\n\t throw ApiError.EEXIST(p);\n\t case ActionType.NOP:\n\t return new NoSyncFile(this, p, flags, stats, data);\n\t default:\n\t throw new ApiError(ErrorCode.EINVAL, 'Invalid FileMode object.');\n\t }\n\t }\n\t else {\n\t throw ApiError.EISDIR(p);\n\t }\n\t };\n\t IsoFS.prototype.readdirSync = function readdirSync (path$$1) {\n\t // Check if it exists.\n\t var record = this._getDirectoryRecord(path$$1);\n\t if (!record) {\n\t throw ApiError.ENOENT(path$$1);\n\t }\n\t else if (record.isDirectory(this._data)) {\n\t return record.getDirectory(this._data).getFileList().slice(0);\n\t }\n\t else {\n\t throw ApiError.ENOTDIR(path$$1);\n\t }\n\t };\n\t /**\n\t * Specially-optimized readfile.\n\t */\n\t IsoFS.prototype.readFileSync = function readFileSync (fname, encoding, flag) {\n\t // Get file.\n\t var fd = this.openSync(fname, flag, 0x1a4);\n\t try {\n\t var fdCast = fd;\n\t var fdBuff = fdCast.getBuffer();\n\t if (encoding === null) {\n\t return copyingSlice(fdBuff);\n\t }\n\t return fdBuff.toString(encoding);\n\t }\n\t finally {\n\t fd.closeSync();\n\t }\n\t };\n\t IsoFS.prototype._getDirectoryRecord = function _getDirectoryRecord (path$$1) {\n\t var this$1 = this;\n\t\n\t // Special case.\n\t if (path$$1 === '/') {\n\t return this._root;\n\t }\n\t var components = path$$1.split('/').slice(1);\n\t var dir = this._root;\n\t for (var i = 0; i < components.length; i++) {\n\t if (dir.isDirectory(this$1._data)) {\n\t dir = dir.getDirectory(this$1._data).getRecord(components[i]);\n\t if (!dir) {\n\t return null;\n\t }\n\t }\n\t else {\n\t return null;\n\t }\n\t }\n\t return dir;\n\t };\n\t IsoFS.prototype._getStats = function _getStats (p, record) {\n\t if (record.isSymlink(this._data)) {\n\t var newP = path.resolve(p, record.getSymlinkPath(this._data));\n\t var dirRec = this._getDirectoryRecord(newP);\n\t if (!dirRec) {\n\t return null;\n\t }\n\t return this._getStats(newP, dirRec);\n\t }\n\t else {\n\t var len = record.dataLength();\n\t var mode = 0x16D;\n\t var date = record.recordingDate();\n\t var atime = date;\n\t var mtime = date;\n\t var ctime = date;\n\t if (record.hasRockRidge()) {\n\t var entries = record.getSUEntries(this._data);\n\t for (var i = 0; i < entries.length; i++) {\n\t var entry = entries[i];\n\t if (entry instanceof PXEntry) {\n\t mode = entry.mode();\n\t }\n\t else if (entry instanceof TFEntry) {\n\t var flags = entry.flags();\n\t if (flags & 4 /* ACCESS */) {\n\t atime = entry.access();\n\t }\n\t if (flags & 2 /* MODIFY */) {\n\t mtime = entry.modify();\n\t }\n\t if (flags & 1 /* CREATION */) {\n\t ctime = entry.creation();\n\t }\n\t }\n\t }\n\t }\n\t // Mask out writeable flags. This is a RO file system.\n\t mode = mode & 0x16D;\n\t return new Stats(record.isDirectory(this._data) ? FileType.DIRECTORY : FileType.FILE, len, mode, atime, mtime, ctime);\n\t }\n\t };\n\t\n\t return IsoFS;\n\t}(SynchronousFileSystem));\n\t\n\t/* tslint:disable:variable-name */\n\tvar Backends = { AsyncMirror: AsyncMirror, Dropbox: DropboxFileSystem, Emscripten: EmscriptenFileSystem, FolderAdapter: FolderAdapter, HTML5FS: HTML5FS, InMemory: InMemoryFileSystem, IndexedDB: IndexedDBFileSystem, IsoFS: IsoFS, LocalStorage: LocalStorageFileSystem, MountableFileSystem: MountableFileSystem, OverlayFS: OverlayFS, WorkerFS: WorkerFS, XmlHttpRequest: XmlHttpRequest, ZipFS: ZipFS };\n\t\n\t/* tslint:enable:variable-name */\n\t\n\t/**\n\t * BrowserFS's main module. This is exposed in the browser via the BrowserFS global.\n\t */\n\tif (process['initializeTTYs']) {\n\t process['initializeTTYs']();\n\t}\n\t/**\n\t * Installs BrowserFS onto the given object.\n\t * We recommend that you run install with the 'window' object to make things\n\t * global, as in Node.\n\t *\n\t * Properties installed:\n\t *\n\t * * Buffer\n\t * * process\n\t * * require (we monkey-patch it)\n\t *\n\t * This allows you to write code as if you were running inside Node.\n\t * @param {object} obj - The object to install things onto (e.g. window)\n\t */\n\tfunction install(obj) {\n\t obj.Buffer = Buffer;\n\t obj.process = process;\n\t var oldRequire = obj.require ? obj.require : null;\n\t // Monkey-patch require for Node-style code.\n\t obj.require = function (arg) {\n\t var rv = BFSRequire(arg);\n\t if (!rv) {\n\t return oldRequire.apply(null, Array.prototype.slice.call(arguments, 0));\n\t }\n\t else {\n\t return rv;\n\t }\n\t };\n\t}\n\tfunction registerFileSystem(name, fs) {\n\t Backends[name] = fs;\n\t}\n\tfunction BFSRequire(module) {\n\t switch (module) {\n\t case 'fs':\n\t return _fsMock;\n\t case 'path':\n\t return path;\n\t case 'buffer':\n\t // The 'buffer' module has 'Buffer' as a property.\n\t return buffer;\n\t case 'process':\n\t return process;\n\t case 'bfs_utils':\n\t return BFSUtils;\n\t default:\n\t return Backends[module];\n\t }\n\t}\n\t/**\n\t * You must call this function with a properly-instantiated root file system\n\t * before using any file system API method.\n\t * @param {BrowserFS.FileSystem} rootFS - The root filesystem to use for the\n\t * entire BrowserFS file system.\n\t */\n\tfunction initialize(rootfs) {\n\t return _fsMock.initialize(rootfs);\n\t}\n\t\n\t/**\n\t * BrowserFS's main entry point.\n\t * It installs all of the needed polyfills, and requires() the main module.\n\t */\n\t// IE substr does not support negative indices\n\tif ('ab'.substr(-1) !== 'b') {\n\t String.prototype.substr = function (substr) {\n\t return function (start, length) {\n\t // did we get a negative start, calculate how much it is from the\n\t // beginning of the string\n\t if (start < 0) {\n\t start = this.length + start;\n\t }\n\t // call the original function\n\t return substr.call(this, start, length);\n\t };\n\t }(String.prototype.substr);\n\t}\n\t// Only IE10 has setImmediate.\n\tif (typeof setImmediate === 'undefined') {\n\t var gScope = global$1;\n\t var timeouts = [];\n\t var messageName = \"zero-timeout-message\";\n\t var canUsePostMessage = function () {\n\t if (typeof gScope.importScripts !== 'undefined' || !gScope.postMessage) {\n\t return false;\n\t }\n\t var postMessageIsAsync = true;\n\t var oldOnMessage = gScope.onmessage;\n\t gScope.onmessage = function () {\n\t postMessageIsAsync = false;\n\t };\n\t gScope.postMessage('', '*');\n\t gScope.onmessage = oldOnMessage;\n\t return postMessageIsAsync;\n\t };\n\t if (canUsePostMessage()) {\n\t gScope.setImmediate = function (fn) {\n\t timeouts.push(fn);\n\t gScope.postMessage(messageName, \"*\");\n\t };\n\t var handleMessage = function (event) {\n\t if (event.source === self && event.data === messageName) {\n\t if (event.stopPropagation) {\n\t event.stopPropagation();\n\t }\n\t else {\n\t event.cancelBubble = true;\n\t }\n\t if (timeouts.length > 0) {\n\t var fn = timeouts.shift();\n\t return fn();\n\t }\n\t }\n\t };\n\t if (gScope.addEventListener) {\n\t gScope.addEventListener('message', handleMessage, true);\n\t }\n\t else {\n\t gScope.attachEvent('onmessage', handleMessage);\n\t }\n\t }\n\t else if (gScope.MessageChannel) {\n\t // WebWorker MessageChannel\n\t var channel = new gScope.MessageChannel();\n\t channel.port1.onmessage = function (event) {\n\t if (timeouts.length > 0) {\n\t return timeouts.shift()();\n\t }\n\t };\n\t gScope.setImmediate = function (fn) {\n\t timeouts.push(fn);\n\t channel.port2.postMessage('');\n\t };\n\t }\n\t else {\n\t gScope.setImmediate = function (fn) {\n\t return setTimeout(fn, 0);\n\t };\n\t }\n\t}\n\t// Polyfill for Uint8Array.prototype.slice.\n\t// Safari and some other browsers do not define it.\n\tif (typeof (ArrayBuffer) !== 'undefined' && typeof (Uint8Array) !== 'undefined') {\n\t if (!Uint8Array.prototype['slice']) {\n\t Uint8Array.prototype.slice = function (start, end) {\n\t if ( start === void 0 ) start = 0;\n\t if ( end === void 0 ) end = this.length;\n\t\n\t var self = this;\n\t if (start < 0) {\n\t start = this.length + start;\n\t if (start < 0) {\n\t start = 0;\n\t }\n\t }\n\t if (end < 0) {\n\t end = this.length + end;\n\t if (end < 0) {\n\t end = 0;\n\t }\n\t }\n\t if (end < start) {\n\t end = start;\n\t }\n\t return new Uint8Array(self.buffer, self.byteOffset + start, end - start);\n\t };\n\t }\n\t}\n\t\n\texports.install = install;\n\texports.registerFileSystem = registerFileSystem;\n\texports.BFSRequire = BFSRequire;\n\texports.initialize = initialize;\n\texports.EmscriptenFS = BFSEmscriptenFS;\n\texports.FileSystem = Backends;\n\texports.Errors = api_error;\n\t\n\t/* WEBPACK VAR INJECTION */}.call(exports, (function() { return this; }()), __webpack_require__(7), __webpack_require__(41)(module), __webpack_require__(3)))\n\n/***/ },\n/* 1 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t/* WEBPACK VAR INJECTION */(function(Buffer) {/*!\n\t * The buffer module from node.js, for the browser.\n\t *\n\t * @author Feross Aboukhadijeh \n\t * @license MIT\n\t */\n\t/* eslint-disable no-proto */\n\t\n\t'use strict'\n\t\n\tvar base64 = __webpack_require__(18)\n\tvar ieee754 = __webpack_require__(21)\n\t\n\texports.Buffer = Buffer\n\texports.SlowBuffer = SlowBuffer\n\texports.INSPECT_MAX_BYTES = 50\n\t\n\tvar K_MAX_LENGTH = 0x7fffffff\n\texports.kMaxLength = K_MAX_LENGTH\n\t\n\t/**\n\t * If `Buffer.TYPED_ARRAY_SUPPORT`:\n\t * === true Use Uint8Array implementation (fastest)\n\t * === false Print warning and recommend using `buffer` v4.x which has an Object\n\t * implementation (most compatible, even IE6)\n\t *\n\t * Browsers that support typed arrays are IE 10+, Firefox 4+, Chrome 7+, Safari 5.1+,\n\t * Opera 11.6+, iOS 4.2+.\n\t *\n\t * We report that the browser does not support typed arrays if the are not subclassable\n\t * using __proto__. Firefox 4-29 lacks support for adding new properties to `Uint8Array`\n\t * (See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438). IE 10 lacks support\n\t * for __proto__ and has a buggy typed array implementation.\n\t */\n\tBuffer.TYPED_ARRAY_SUPPORT = typedArraySupport()\n\t\n\tif (!Buffer.TYPED_ARRAY_SUPPORT && typeof console !== 'undefined' &&\n\t typeof console.error === 'function') {\n\t console.error(\n\t 'This browser lacks typed array (Uint8Array) support which is required by ' +\n\t '`buffer` v5.x. Use `buffer` v4.x if you require old browser support.'\n\t )\n\t}\n\t\n\tfunction typedArraySupport () {\n\t // Can typed array instances can be augmented?\n\t try {\n\t var arr = new Uint8Array(1)\n\t arr.__proto__ = {__proto__: Uint8Array.prototype, foo: function () { return 42 }}\n\t return arr.foo() === 42\n\t } catch (e) {\n\t return false\n\t }\n\t}\n\t\n\tfunction createBuffer (length) {\n\t if (length > K_MAX_LENGTH) {\n\t throw new RangeError('Invalid typed array length')\n\t }\n\t // Return an augmented `Uint8Array` instance\n\t var buf = new Uint8Array(length)\n\t buf.__proto__ = Buffer.prototype\n\t return buf\n\t}\n\t\n\t/**\n\t * The Buffer constructor returns instances of `Uint8Array` that have their\n\t * prototype changed to `Buffer.prototype`. Furthermore, `Buffer` is a subclass of\n\t * `Uint8Array`, so the returned instances will have all the node `Buffer` methods\n\t * and the `Uint8Array` methods. Square bracket notation works as expected -- it\n\t * returns a single octet.\n\t *\n\t * The `Uint8Array` prototype remains unmodified.\n\t */\n\t\n\tfunction Buffer (arg, encodingOrOffset, length) {\n\t // Common case.\n\t if (typeof arg === 'number') {\n\t if (typeof encodingOrOffset === 'string') {\n\t throw new Error(\n\t 'If encoding is specified then the first argument must be a string'\n\t )\n\t }\n\t return allocUnsafe(arg)\n\t }\n\t return from(arg, encodingOrOffset, length)\n\t}\n\t\n\t// Fix subarray() in ES2016. See: https://github.com/feross/buffer/pull/97\n\tif (typeof Symbol !== 'undefined' && Symbol.species &&\n\t Buffer[Symbol.species] === Buffer) {\n\t Object.defineProperty(Buffer, Symbol.species, {\n\t value: null,\n\t configurable: true,\n\t enumerable: false,\n\t writable: false\n\t })\n\t}\n\t\n\tBuffer.poolSize = 8192 // not used by this implementation\n\t\n\tfunction from (value, encodingOrOffset, length) {\n\t if (typeof value === 'number') {\n\t throw new TypeError('\"value\" argument must not be a number')\n\t }\n\t\n\t if (typeof ArrayBuffer !== 'undefined' && value instanceof ArrayBuffer) {\n\t return fromArrayBuffer(value, encodingOrOffset, length)\n\t }\n\t\n\t if (typeof value === 'string') {\n\t return fromString(value, encodingOrOffset)\n\t }\n\t\n\t return fromObject(value)\n\t}\n\t\n\t/**\n\t * Functionally equivalent to Buffer(arg, encoding) but throws a TypeError\n\t * if value is a number.\n\t * Buffer.from(str[, encoding])\n\t * Buffer.from(array)\n\t * Buffer.from(buffer)\n\t * Buffer.from(arrayBuffer[, byteOffset[, length]])\n\t **/\n\tBuffer.from = function (value, encodingOrOffset, length) {\n\t return from(value, encodingOrOffset, length)\n\t}\n\t\n\t// Note: Change prototype *after* Buffer.from is defined to workaround Chrome bug:\n\t// https://github.com/feross/buffer/pull/148\n\tBuffer.prototype.__proto__ = Uint8Array.prototype\n\tBuffer.__proto__ = Uint8Array\n\t\n\tfunction assertSize (size) {\n\t if (typeof size !== 'number') {\n\t throw new TypeError('\"size\" argument must be a number')\n\t } else if (size < 0) {\n\t throw new RangeError('\"size\" argument must not be negative')\n\t }\n\t}\n\t\n\tfunction alloc (size, fill, encoding) {\n\t assertSize(size)\n\t if (size <= 0) {\n\t return createBuffer(size)\n\t }\n\t if (fill !== undefined) {\n\t // Only pay attention to encoding if it's a string. This\n\t // prevents accidentally sending in a number that would\n\t // be interpretted as a start offset.\n\t return typeof encoding === 'string'\n\t ? createBuffer(size).fill(fill, encoding)\n\t : createBuffer(size).fill(fill)\n\t }\n\t return createBuffer(size)\n\t}\n\t\n\t/**\n\t * Creates a new filled Buffer instance.\n\t * alloc(size[, fill[, encoding]])\n\t **/\n\tBuffer.alloc = function (size, fill, encoding) {\n\t return alloc(size, fill, encoding)\n\t}\n\t\n\tfunction allocUnsafe (size) {\n\t assertSize(size)\n\t return createBuffer(size < 0 ? 0 : checked(size) | 0)\n\t}\n\t\n\t/**\n\t * Equivalent to Buffer(num), by default creates a non-zero-filled Buffer instance.\n\t * */\n\tBuffer.allocUnsafe = function (size) {\n\t return allocUnsafe(size)\n\t}\n\t/**\n\t * Equivalent to SlowBuffer(num), by default creates a non-zero-filled Buffer instance.\n\t */\n\tBuffer.allocUnsafeSlow = function (size) {\n\t return allocUnsafe(size)\n\t}\n\t\n\tfunction fromString (string, encoding) {\n\t if (typeof encoding !== 'string' || encoding === '') {\n\t encoding = 'utf8'\n\t }\n\t\n\t if (!Buffer.isEncoding(encoding)) {\n\t throw new TypeError('\"encoding\" must be a valid string encoding')\n\t }\n\t\n\t var length = byteLength(string, encoding) | 0\n\t var buf = createBuffer(length)\n\t\n\t var actual = buf.write(string, encoding)\n\t\n\t if (actual !== length) {\n\t // Writing a hex string, for example, that contains invalid characters will\n\t // cause everything after the first invalid character to be ignored. (e.g.\n\t // 'abxxcd' will be treated as 'ab')\n\t buf = buf.slice(0, actual)\n\t }\n\t\n\t return buf\n\t}\n\t\n\tfunction fromArrayLike (array) {\n\t var length = array.length < 0 ? 0 : checked(array.length) | 0\n\t var buf = createBuffer(length)\n\t for (var i = 0; i < length; i += 1) {\n\t buf[i] = array[i] & 255\n\t }\n\t return buf\n\t}\n\t\n\tfunction fromArrayBuffer (array, byteOffset, length) {\n\t array.byteLength // this throws if `array` is not a valid ArrayBuffer\n\t\n\t if (byteOffset < 0 || array.byteLength < byteOffset) {\n\t throw new RangeError('\\'offset\\' is out of bounds')\n\t }\n\t\n\t if (array.byteLength < byteOffset + (length || 0)) {\n\t throw new RangeError('\\'length\\' is out of bounds')\n\t }\n\t\n\t var buf\n\t if (byteOffset === undefined && length === undefined) {\n\t buf = new Uint8Array(array)\n\t } else if (length === undefined) {\n\t buf = new Uint8Array(array, byteOffset)\n\t } else {\n\t buf = new Uint8Array(array, byteOffset, length)\n\t }\n\t\n\t // Return an augmented `Uint8Array` instance\n\t buf.__proto__ = Buffer.prototype\n\t return buf\n\t}\n\t\n\tfunction fromObject (obj) {\n\t if (Buffer.isBuffer(obj)) {\n\t var len = checked(obj.length) | 0\n\t var buf = createBuffer(len)\n\t\n\t if (buf.length === 0) {\n\t return buf\n\t }\n\t\n\t obj.copy(buf, 0, 0, len)\n\t return buf\n\t }\n\t\n\t if (obj) {\n\t if ((typeof ArrayBuffer !== 'undefined' &&\n\t obj.buffer instanceof ArrayBuffer) || 'length' in obj) {\n\t if (typeof obj.length !== 'number' || isnan(obj.length)) {\n\t return createBuffer(0)\n\t }\n\t return fromArrayLike(obj)\n\t }\n\t\n\t if (obj.type === 'Buffer' && Array.isArray(obj.data)) {\n\t return fromArrayLike(obj.data)\n\t }\n\t }\n\t\n\t throw new TypeError('First argument must be a string, Buffer, ArrayBuffer, Array, or array-like object.')\n\t}\n\t\n\tfunction checked (length) {\n\t // Note: cannot use `length < K_MAX_LENGTH` here because that fails when\n\t // length is NaN (which is otherwise coerced to zero.)\n\t if (length >= K_MAX_LENGTH) {\n\t throw new RangeError('Attempt to allocate Buffer larger than maximum ' +\n\t 'size: 0x' + K_MAX_LENGTH.toString(16) + ' bytes')\n\t }\n\t return length | 0\n\t}\n\t\n\tfunction SlowBuffer (length) {\n\t if (+length != length) { // eslint-disable-line eqeqeq\n\t length = 0\n\t }\n\t return Buffer.alloc(+length)\n\t}\n\t\n\tBuffer.isBuffer = function isBuffer (b) {\n\t return !!(b != null && b._isBuffer)\n\t}\n\t\n\tBuffer.compare = function compare (a, b) {\n\t if (!Buffer.isBuffer(a) || !Buffer.isBuffer(b)) {\n\t throw new TypeError('Arguments must be Buffers')\n\t }\n\t\n\t if (a === b) return 0\n\t\n\t var x = a.length\n\t var y = b.length\n\t\n\t for (var i = 0, len = Math.min(x, y); i < len; ++i) {\n\t if (a[i] !== b[i]) {\n\t x = a[i]\n\t y = b[i]\n\t break\n\t }\n\t }\n\t\n\t if (x < y) return -1\n\t if (y < x) return 1\n\t return 0\n\t}\n\t\n\tBuffer.isEncoding = function isEncoding (encoding) {\n\t switch (String(encoding).toLowerCase()) {\n\t case 'hex':\n\t case 'utf8':\n\t case 'utf-8':\n\t case 'ascii':\n\t case 'latin1':\n\t case 'binary':\n\t case 'base64':\n\t case 'ucs2':\n\t case 'ucs-2':\n\t case 'utf16le':\n\t case 'utf-16le':\n\t return true\n\t default:\n\t return false\n\t }\n\t}\n\t\n\tBuffer.concat = function concat (list, length) {\n\t if (!Array.isArray(list)) {\n\t throw new TypeError('\"list\" argument must be an Array of Buffers')\n\t }\n\t\n\t if (list.length === 0) {\n\t return Buffer.alloc(0)\n\t }\n\t\n\t var i\n\t if (length === undefined) {\n\t length = 0\n\t for (i = 0; i < list.length; ++i) {\n\t length += list[i].length\n\t }\n\t }\n\t\n\t var buffer = Buffer.allocUnsafe(length)\n\t var pos = 0\n\t for (i = 0; i < list.length; ++i) {\n\t var buf = list[i]\n\t if (!Buffer.isBuffer(buf)) {\n\t throw new TypeError('\"list\" argument must be an Array of Buffers')\n\t }\n\t buf.copy(buffer, pos)\n\t pos += buf.length\n\t }\n\t return buffer\n\t}\n\t\n\tfunction byteLength (string, encoding) {\n\t if (Buffer.isBuffer(string)) {\n\t return string.length\n\t }\n\t if (typeof ArrayBuffer !== 'undefined' && typeof ArrayBuffer.isView === 'function' &&\n\t (ArrayBuffer.isView(string) || string instanceof ArrayBuffer)) {\n\t return string.byteLength\n\t }\n\t if (typeof string !== 'string') {\n\t string = '' + string\n\t }\n\t\n\t var len = string.length\n\t if (len === 0) return 0\n\t\n\t // Use a for loop to avoid recursion\n\t var loweredCase = false\n\t for (;;) {\n\t switch (encoding) {\n\t case 'ascii':\n\t case 'latin1':\n\t case 'binary':\n\t return len\n\t case 'utf8':\n\t case 'utf-8':\n\t case undefined:\n\t return utf8ToBytes(string).length\n\t case 'ucs2':\n\t case 'ucs-2':\n\t case 'utf16le':\n\t case 'utf-16le':\n\t return len * 2\n\t case 'hex':\n\t return len >>> 1\n\t case 'base64':\n\t return base64ToBytes(string).length\n\t default:\n\t if (loweredCase) return utf8ToBytes(string).length // assume utf8\n\t encoding = ('' + encoding).toLowerCase()\n\t loweredCase = true\n\t }\n\t }\n\t}\n\tBuffer.byteLength = byteLength\n\t\n\tfunction slowToString (encoding, start, end) {\n\t var loweredCase = false\n\t\n\t // No need to verify that \"this.length <= MAX_UINT32\" since it's a read-only\n\t // property of a typed array.\n\t\n\t // This behaves neither like String nor Uint8Array in that we set start/end\n\t // to their upper/lower bounds if the value passed is out of range.\n\t // undefined is handled specially as per ECMA-262 6th Edition,\n\t // Section 13.3.3.7 Runtime Semantics: KeyedBindingInitialization.\n\t if (start === undefined || start < 0) {\n\t start = 0\n\t }\n\t // Return early if start > this.length. Done here to prevent potential uint32\n\t // coercion fail below.\n\t if (start > this.length) {\n\t return ''\n\t }\n\t\n\t if (end === undefined || end > this.length) {\n\t end = this.length\n\t }\n\t\n\t if (end <= 0) {\n\t return ''\n\t }\n\t\n\t // Force coersion to uint32. This will also coerce falsey/NaN values to 0.\n\t end >>>= 0\n\t start >>>= 0\n\t\n\t if (end <= start) {\n\t return ''\n\t }\n\t\n\t if (!encoding) encoding = 'utf8'\n\t\n\t while (true) {\n\t switch (encoding) {\n\t case 'hex':\n\t return hexSlice(this, start, end)\n\t\n\t case 'utf8':\n\t case 'utf-8':\n\t return utf8Slice(this, start, end)\n\t\n\t case 'ascii':\n\t return asciiSlice(this, start, end)\n\t\n\t case 'latin1':\n\t case 'binary':\n\t return latin1Slice(this, start, end)\n\t\n\t case 'base64':\n\t return base64Slice(this, start, end)\n\t\n\t case 'ucs2':\n\t case 'ucs-2':\n\t case 'utf16le':\n\t case 'utf-16le':\n\t return utf16leSlice(this, start, end)\n\t\n\t default:\n\t if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n\t encoding = (encoding + '').toLowerCase()\n\t loweredCase = true\n\t }\n\t }\n\t}\n\t\n\t// The property is used by `Buffer.isBuffer` and `is-buffer` (in Safari 5-7) to detect\n\t// Buffer instances.\n\tBuffer.prototype._isBuffer = true\n\t\n\tfunction swap (b, n, m) {\n\t var i = b[n]\n\t b[n] = b[m]\n\t b[m] = i\n\t}\n\t\n\tBuffer.prototype.swap16 = function swap16 () {\n\t var len = this.length\n\t if (len % 2 !== 0) {\n\t throw new RangeError('Buffer size must be a multiple of 16-bits')\n\t }\n\t for (var i = 0; i < len; i += 2) {\n\t swap(this, i, i + 1)\n\t }\n\t return this\n\t}\n\t\n\tBuffer.prototype.swap32 = function swap32 () {\n\t var len = this.length\n\t if (len % 4 !== 0) {\n\t throw new RangeError('Buffer size must be a multiple of 32-bits')\n\t }\n\t for (var i = 0; i < len; i += 4) {\n\t swap(this, i, i + 3)\n\t swap(this, i + 1, i + 2)\n\t }\n\t return this\n\t}\n\t\n\tBuffer.prototype.swap64 = function swap64 () {\n\t var len = this.length\n\t if (len % 8 !== 0) {\n\t throw new RangeError('Buffer size must be a multiple of 64-bits')\n\t }\n\t for (var i = 0; i < len; i += 8) {\n\t swap(this, i, i + 7)\n\t swap(this, i + 1, i + 6)\n\t swap(this, i + 2, i + 5)\n\t swap(this, i + 3, i + 4)\n\t }\n\t return this\n\t}\n\t\n\tBuffer.prototype.toString = function toString () {\n\t var length = this.length\n\t if (length === 0) return ''\n\t if (arguments.length === 0) return utf8Slice(this, 0, length)\n\t return slowToString.apply(this, arguments)\n\t}\n\t\n\tBuffer.prototype.equals = function equals (b) {\n\t if (!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer')\n\t if (this === b) return true\n\t return Buffer.compare(this, b) === 0\n\t}\n\t\n\tBuffer.prototype.inspect = function inspect () {\n\t var str = ''\n\t var max = exports.INSPECT_MAX_BYTES\n\t if (this.length > 0) {\n\t str = this.toString('hex', 0, max).match(/.{2}/g).join(' ')\n\t if (this.length > max) str += ' ... '\n\t }\n\t return ''\n\t}\n\t\n\tBuffer.prototype.compare = function compare (target, start, end, thisStart, thisEnd) {\n\t if (!Buffer.isBuffer(target)) {\n\t throw new TypeError('Argument must be a Buffer')\n\t }\n\t\n\t if (start === undefined) {\n\t start = 0\n\t }\n\t if (end === undefined) {\n\t end = target ? target.length : 0\n\t }\n\t if (thisStart === undefined) {\n\t thisStart = 0\n\t }\n\t if (thisEnd === undefined) {\n\t thisEnd = this.length\n\t }\n\t\n\t if (start < 0 || end > target.length || thisStart < 0 || thisEnd > this.length) {\n\t throw new RangeError('out of range index')\n\t }\n\t\n\t if (thisStart >= thisEnd && start >= end) {\n\t return 0\n\t }\n\t if (thisStart >= thisEnd) {\n\t return -1\n\t }\n\t if (start >= end) {\n\t return 1\n\t }\n\t\n\t start >>>= 0\n\t end >>>= 0\n\t thisStart >>>= 0\n\t thisEnd >>>= 0\n\t\n\t if (this === target) return 0\n\t\n\t var x = thisEnd - thisStart\n\t var y = end - start\n\t var len = Math.min(x, y)\n\t\n\t var thisCopy = this.slice(thisStart, thisEnd)\n\t var targetCopy = target.slice(start, end)\n\t\n\t for (var i = 0; i < len; ++i) {\n\t if (thisCopy[i] !== targetCopy[i]) {\n\t x = thisCopy[i]\n\t y = targetCopy[i]\n\t break\n\t }\n\t }\n\t\n\t if (x < y) return -1\n\t if (y < x) return 1\n\t return 0\n\t}\n\t\n\t// Finds either the first index of `val` in `buffer` at offset >= `byteOffset`,\n\t// OR the last index of `val` in `buffer` at offset <= `byteOffset`.\n\t//\n\t// Arguments:\n\t// - buffer - a Buffer to search\n\t// - val - a string, Buffer, or number\n\t// - byteOffset - an index into `buffer`; will be clamped to an int32\n\t// - encoding - an optional encoding, relevant is val is a string\n\t// - dir - true for indexOf, false for lastIndexOf\n\tfunction bidirectionalIndexOf (buffer, val, byteOffset, encoding, dir) {\n\t // Empty buffer means no match\n\t if (buffer.length === 0) return -1\n\t\n\t // Normalize byteOffset\n\t if (typeof byteOffset === 'string') {\n\t encoding = byteOffset\n\t byteOffset = 0\n\t } else if (byteOffset > 0x7fffffff) {\n\t byteOffset = 0x7fffffff\n\t } else if (byteOffset < -0x80000000) {\n\t byteOffset = -0x80000000\n\t }\n\t byteOffset = +byteOffset // Coerce to Number.\n\t if (isNaN(byteOffset)) {\n\t // byteOffset: it it's undefined, null, NaN, \"foo\", etc, search whole buffer\n\t byteOffset = dir ? 0 : (buffer.length - 1)\n\t }\n\t\n\t // Normalize byteOffset: negative offsets start from the end of the buffer\n\t if (byteOffset < 0) byteOffset = buffer.length + byteOffset\n\t if (byteOffset >= buffer.length) {\n\t if (dir) return -1\n\t else byteOffset = buffer.length - 1\n\t } else if (byteOffset < 0) {\n\t if (dir) byteOffset = 0\n\t else return -1\n\t }\n\t\n\t // Normalize val\n\t if (typeof val === 'string') {\n\t val = Buffer.from(val, encoding)\n\t }\n\t\n\t // Finally, search either indexOf (if dir is true) or lastIndexOf\n\t if (Buffer.isBuffer(val)) {\n\t // Special case: looking for empty string/buffer always fails\n\t if (val.length === 0) {\n\t return -1\n\t }\n\t return arrayIndexOf(buffer, val, byteOffset, encoding, dir)\n\t } else if (typeof val === 'number') {\n\t val = val & 0xFF // Search for a byte value [0-255]\n\t if (typeof Uint8Array.prototype.indexOf === 'function') {\n\t if (dir) {\n\t return Uint8Array.prototype.indexOf.call(buffer, val, byteOffset)\n\t } else {\n\t return Uint8Array.prototype.lastIndexOf.call(buffer, val, byteOffset)\n\t }\n\t }\n\t return arrayIndexOf(buffer, [ val ], byteOffset, encoding, dir)\n\t }\n\t\n\t throw new TypeError('val must be string, number or Buffer')\n\t}\n\t\n\tfunction arrayIndexOf (arr, val, byteOffset, encoding, dir) {\n\t var indexSize = 1\n\t var arrLength = arr.length\n\t var valLength = val.length\n\t\n\t if (encoding !== undefined) {\n\t encoding = String(encoding).toLowerCase()\n\t if (encoding === 'ucs2' || encoding === 'ucs-2' ||\n\t encoding === 'utf16le' || encoding === 'utf-16le') {\n\t if (arr.length < 2 || val.length < 2) {\n\t return -1\n\t }\n\t indexSize = 2\n\t arrLength /= 2\n\t valLength /= 2\n\t byteOffset /= 2\n\t }\n\t }\n\t\n\t function read (buf, i) {\n\t if (indexSize === 1) {\n\t return buf[i]\n\t } else {\n\t return buf.readUInt16BE(i * indexSize)\n\t }\n\t }\n\t\n\t var i\n\t if (dir) {\n\t var foundIndex = -1\n\t for (i = byteOffset; i < arrLength; i++) {\n\t if (read(arr, i) === read(val, foundIndex === -1 ? 0 : i - foundIndex)) {\n\t if (foundIndex === -1) foundIndex = i\n\t if (i - foundIndex + 1 === valLength) return foundIndex * indexSize\n\t } else {\n\t if (foundIndex !== -1) i -= i - foundIndex\n\t foundIndex = -1\n\t }\n\t }\n\t } else {\n\t if (byteOffset + valLength > arrLength) byteOffset = arrLength - valLength\n\t for (i = byteOffset; i >= 0; i--) {\n\t var found = true\n\t for (var j = 0; j < valLength; j++) {\n\t if (read(arr, i + j) !== read(val, j)) {\n\t found = false\n\t break\n\t }\n\t }\n\t if (found) return i\n\t }\n\t }\n\t\n\t return -1\n\t}\n\t\n\tBuffer.prototype.includes = function includes (val, byteOffset, encoding) {\n\t return this.indexOf(val, byteOffset, encoding) !== -1\n\t}\n\t\n\tBuffer.prototype.indexOf = function indexOf (val, byteOffset, encoding) {\n\t return bidirectionalIndexOf(this, val, byteOffset, encoding, true)\n\t}\n\t\n\tBuffer.prototype.lastIndexOf = function lastIndexOf (val, byteOffset, encoding) {\n\t return bidirectionalIndexOf(this, val, byteOffset, encoding, false)\n\t}\n\t\n\tfunction hexWrite (buf, string, offset, length) {\n\t offset = Number(offset) || 0\n\t var remaining = buf.length - offset\n\t if (!length) {\n\t length = remaining\n\t } else {\n\t length = Number(length)\n\t if (length > remaining) {\n\t length = remaining\n\t }\n\t }\n\t\n\t // must be an even number of digits\n\t var strLen = string.length\n\t if (strLen % 2 !== 0) throw new TypeError('Invalid hex string')\n\t\n\t if (length > strLen / 2) {\n\t length = strLen / 2\n\t }\n\t for (var i = 0; i < length; ++i) {\n\t var parsed = parseInt(string.substr(i * 2, 2), 16)\n\t if (isNaN(parsed)) return i\n\t buf[offset + i] = parsed\n\t }\n\t return i\n\t}\n\t\n\tfunction utf8Write (buf, string, offset, length) {\n\t return blitBuffer(utf8ToBytes(string, buf.length - offset), buf, offset, length)\n\t}\n\t\n\tfunction asciiWrite (buf, string, offset, length) {\n\t return blitBuffer(asciiToBytes(string), buf, offset, length)\n\t}\n\t\n\tfunction latin1Write (buf, string, offset, length) {\n\t return asciiWrite(buf, string, offset, length)\n\t}\n\t\n\tfunction base64Write (buf, string, offset, length) {\n\t return blitBuffer(base64ToBytes(string), buf, offset, length)\n\t}\n\t\n\tfunction ucs2Write (buf, string, offset, length) {\n\t return blitBuffer(utf16leToBytes(string, buf.length - offset), buf, offset, length)\n\t}\n\t\n\tBuffer.prototype.write = function write (string, offset, length, encoding) {\n\t // Buffer#write(string)\n\t if (offset === undefined) {\n\t encoding = 'utf8'\n\t length = this.length\n\t offset = 0\n\t // Buffer#write(string, encoding)\n\t } else if (length === undefined && typeof offset === 'string') {\n\t encoding = offset\n\t length = this.length\n\t offset = 0\n\t // Buffer#write(string, offset[, length][, encoding])\n\t } else if (isFinite(offset)) {\n\t offset = offset >>> 0\n\t if (isFinite(length)) {\n\t length = length >>> 0\n\t if (encoding === undefined) encoding = 'utf8'\n\t } else {\n\t encoding = length\n\t length = undefined\n\t }\n\t } else {\n\t throw new Error(\n\t 'Buffer.write(string, encoding, offset[, length]) is no longer supported'\n\t )\n\t }\n\t\n\t var remaining = this.length - offset\n\t if (length === undefined || length > remaining) length = remaining\n\t\n\t if ((string.length > 0 && (length < 0 || offset < 0)) || offset > this.length) {\n\t throw new RangeError('Attempt to write outside buffer bounds')\n\t }\n\t\n\t if (!encoding) encoding = 'utf8'\n\t\n\t var loweredCase = false\n\t for (;;) {\n\t switch (encoding) {\n\t case 'hex':\n\t return hexWrite(this, string, offset, length)\n\t\n\t case 'utf8':\n\t case 'utf-8':\n\t return utf8Write(this, string, offset, length)\n\t\n\t case 'ascii':\n\t return asciiWrite(this, string, offset, length)\n\t\n\t case 'latin1':\n\t case 'binary':\n\t return latin1Write(this, string, offset, length)\n\t\n\t case 'base64':\n\t // Warning: maxLength not taken into account in base64Write\n\t return base64Write(this, string, offset, length)\n\t\n\t case 'ucs2':\n\t case 'ucs-2':\n\t case 'utf16le':\n\t case 'utf-16le':\n\t return ucs2Write(this, string, offset, length)\n\t\n\t default:\n\t if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n\t encoding = ('' + encoding).toLowerCase()\n\t loweredCase = true\n\t }\n\t }\n\t}\n\t\n\tBuffer.prototype.toJSON = function toJSON () {\n\t return {\n\t type: 'Buffer',\n\t data: Array.prototype.slice.call(this._arr || this, 0)\n\t }\n\t}\n\t\n\tfunction base64Slice (buf, start, end) {\n\t if (start === 0 && end === buf.length) {\n\t return base64.fromByteArray(buf)\n\t } else {\n\t return base64.fromByteArray(buf.slice(start, end))\n\t }\n\t}\n\t\n\tfunction utf8Slice (buf, start, end) {\n\t end = Math.min(buf.length, end)\n\t var res = []\n\t\n\t var i = start\n\t while (i < end) {\n\t var firstByte = buf[i]\n\t var codePoint = null\n\t var bytesPerSequence = (firstByte > 0xEF) ? 4\n\t : (firstByte > 0xDF) ? 3\n\t : (firstByte > 0xBF) ? 2\n\t : 1\n\t\n\t if (i + bytesPerSequence <= end) {\n\t var secondByte, thirdByte, fourthByte, tempCodePoint\n\t\n\t switch (bytesPerSequence) {\n\t case 1:\n\t if (firstByte < 0x80) {\n\t codePoint = firstByte\n\t }\n\t break\n\t case 2:\n\t secondByte = buf[i + 1]\n\t if ((secondByte & 0xC0) === 0x80) {\n\t tempCodePoint = (firstByte & 0x1F) << 0x6 | (secondByte & 0x3F)\n\t if (tempCodePoint > 0x7F) {\n\t codePoint = tempCodePoint\n\t }\n\t }\n\t break\n\t case 3:\n\t secondByte = buf[i + 1]\n\t thirdByte = buf[i + 2]\n\t if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80) {\n\t tempCodePoint = (firstByte & 0xF) << 0xC | (secondByte & 0x3F) << 0x6 | (thirdByte & 0x3F)\n\t if (tempCodePoint > 0x7FF && (tempCodePoint < 0xD800 || tempCodePoint > 0xDFFF)) {\n\t codePoint = tempCodePoint\n\t }\n\t }\n\t break\n\t case 4:\n\t secondByte = buf[i + 1]\n\t thirdByte = buf[i + 2]\n\t fourthByte = buf[i + 3]\n\t if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80 && (fourthByte & 0xC0) === 0x80) {\n\t tempCodePoint = (firstByte & 0xF) << 0x12 | (secondByte & 0x3F) << 0xC | (thirdByte & 0x3F) << 0x6 | (fourthByte & 0x3F)\n\t if (tempCodePoint > 0xFFFF && tempCodePoint < 0x110000) {\n\t codePoint = tempCodePoint\n\t }\n\t }\n\t }\n\t }\n\t\n\t if (codePoint === null) {\n\t // we did not generate a valid codePoint so insert a\n\t // replacement char (U+FFFD) and advance only 1 byte\n\t codePoint = 0xFFFD\n\t bytesPerSequence = 1\n\t } else if (codePoint > 0xFFFF) {\n\t // encode to utf16 (surrogate pair dance)\n\t codePoint -= 0x10000\n\t res.push(codePoint >>> 10 & 0x3FF | 0xD800)\n\t codePoint = 0xDC00 | codePoint & 0x3FF\n\t }\n\t\n\t res.push(codePoint)\n\t i += bytesPerSequence\n\t }\n\t\n\t return decodeCodePointsArray(res)\n\t}\n\t\n\t// Based on http://stackoverflow.com/a/22747272/680742, the browser with\n\t// the lowest limit is Chrome, with 0x10000 args.\n\t// We go 1 magnitude less, for safety\n\tvar MAX_ARGUMENTS_LENGTH = 0x1000\n\t\n\tfunction decodeCodePointsArray (codePoints) {\n\t var len = codePoints.length\n\t if (len <= MAX_ARGUMENTS_LENGTH) {\n\t return String.fromCharCode.apply(String, codePoints) // avoid extra slice()\n\t }\n\t\n\t // Decode in chunks to avoid \"call stack size exceeded\".\n\t var res = ''\n\t var i = 0\n\t while (i < len) {\n\t res += String.fromCharCode.apply(\n\t String,\n\t codePoints.slice(i, i += MAX_ARGUMENTS_LENGTH)\n\t )\n\t }\n\t return res\n\t}\n\t\n\tfunction asciiSlice (buf, start, end) {\n\t var ret = ''\n\t end = Math.min(buf.length, end)\n\t\n\t for (var i = start; i < end; ++i) {\n\t ret += String.fromCharCode(buf[i] & 0x7F)\n\t }\n\t return ret\n\t}\n\t\n\tfunction latin1Slice (buf, start, end) {\n\t var ret = ''\n\t end = Math.min(buf.length, end)\n\t\n\t for (var i = start; i < end; ++i) {\n\t ret += String.fromCharCode(buf[i])\n\t }\n\t return ret\n\t}\n\t\n\tfunction hexSlice (buf, start, end) {\n\t var len = buf.length\n\t\n\t if (!start || start < 0) start = 0\n\t if (!end || end < 0 || end > len) end = len\n\t\n\t var out = ''\n\t for (var i = start; i < end; ++i) {\n\t out += toHex(buf[i])\n\t }\n\t return out\n\t}\n\t\n\tfunction utf16leSlice (buf, start, end) {\n\t var bytes = buf.slice(start, end)\n\t var res = ''\n\t for (var i = 0; i < bytes.length; i += 2) {\n\t res += String.fromCharCode(bytes[i] + bytes[i + 1] * 256)\n\t }\n\t return res\n\t}\n\t\n\tBuffer.prototype.slice = function slice (start, end) {\n\t var len = this.length\n\t start = ~~start\n\t end = end === undefined ? len : ~~end\n\t\n\t if (start < 0) {\n\t start += len\n\t if (start < 0) start = 0\n\t } else if (start > len) {\n\t start = len\n\t }\n\t\n\t if (end < 0) {\n\t end += len\n\t if (end < 0) end = 0\n\t } else if (end > len) {\n\t end = len\n\t }\n\t\n\t if (end < start) end = start\n\t\n\t var newBuf = this.subarray(start, end)\n\t // Return an augmented `Uint8Array` instance\n\t newBuf.__proto__ = Buffer.prototype\n\t return newBuf\n\t}\n\t\n\t/*\n\t * Need to make sure that buffer isn't trying to write out of bounds.\n\t */\n\tfunction checkOffset (offset, ext, length) {\n\t if ((offset % 1) !== 0 || offset < 0) throw new RangeError('offset is not uint')\n\t if (offset + ext > length) throw new RangeError('Trying to access beyond buffer length')\n\t}\n\t\n\tBuffer.prototype.readUIntLE = function readUIntLE (offset, byteLength, noAssert) {\n\t offset = offset >>> 0\n\t byteLength = byteLength >>> 0\n\t if (!noAssert) checkOffset(offset, byteLength, this.length)\n\t\n\t var val = this[offset]\n\t var mul = 1\n\t var i = 0\n\t while (++i < byteLength && (mul *= 0x100)) {\n\t val += this[offset + i] * mul\n\t }\n\t\n\t return val\n\t}\n\t\n\tBuffer.prototype.readUIntBE = function readUIntBE (offset, byteLength, noAssert) {\n\t offset = offset >>> 0\n\t byteLength = byteLength >>> 0\n\t if (!noAssert) {\n\t checkOffset(offset, byteLength, this.length)\n\t }\n\t\n\t var val = this[offset + --byteLength]\n\t var mul = 1\n\t while (byteLength > 0 && (mul *= 0x100)) {\n\t val += this[offset + --byteLength] * mul\n\t }\n\t\n\t return val\n\t}\n\t\n\tBuffer.prototype.readUInt8 = function readUInt8 (offset, noAssert) {\n\t offset = offset >>> 0\n\t if (!noAssert) checkOffset(offset, 1, this.length)\n\t return this[offset]\n\t}\n\t\n\tBuffer.prototype.readUInt16LE = function readUInt16LE (offset, noAssert) {\n\t offset = offset >>> 0\n\t if (!noAssert) checkOffset(offset, 2, this.length)\n\t return this[offset] | (this[offset + 1] << 8)\n\t}\n\t\n\tBuffer.prototype.readUInt16BE = function readUInt16BE (offset, noAssert) {\n\t offset = offset >>> 0\n\t if (!noAssert) checkOffset(offset, 2, this.length)\n\t return (this[offset] << 8) | this[offset + 1]\n\t}\n\t\n\tBuffer.prototype.readUInt32LE = function readUInt32LE (offset, noAssert) {\n\t offset = offset >>> 0\n\t if (!noAssert) checkOffset(offset, 4, this.length)\n\t\n\t return ((this[offset]) |\n\t (this[offset + 1] << 8) |\n\t (this[offset + 2] << 16)) +\n\t (this[offset + 3] * 0x1000000)\n\t}\n\t\n\tBuffer.prototype.readUInt32BE = function readUInt32BE (offset, noAssert) {\n\t offset = offset >>> 0\n\t if (!noAssert) checkOffset(offset, 4, this.length)\n\t\n\t return (this[offset] * 0x1000000) +\n\t ((this[offset + 1] << 16) |\n\t (this[offset + 2] << 8) |\n\t this[offset + 3])\n\t}\n\t\n\tBuffer.prototype.readIntLE = function readIntLE (offset, byteLength, noAssert) {\n\t offset = offset >>> 0\n\t byteLength = byteLength >>> 0\n\t if (!noAssert) checkOffset(offset, byteLength, this.length)\n\t\n\t var val = this[offset]\n\t var mul = 1\n\t var i = 0\n\t while (++i < byteLength && (mul *= 0x100)) {\n\t val += this[offset + i] * mul\n\t }\n\t mul *= 0x80\n\t\n\t if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\t\n\t return val\n\t}\n\t\n\tBuffer.prototype.readIntBE = function readIntBE (offset, byteLength, noAssert) {\n\t offset = offset >>> 0\n\t byteLength = byteLength >>> 0\n\t if (!noAssert) checkOffset(offset, byteLength, this.length)\n\t\n\t var i = byteLength\n\t var mul = 1\n\t var val = this[offset + --i]\n\t while (i > 0 && (mul *= 0x100)) {\n\t val += this[offset + --i] * mul\n\t }\n\t mul *= 0x80\n\t\n\t if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\t\n\t return val\n\t}\n\t\n\tBuffer.prototype.readInt8 = function readInt8 (offset, noAssert) {\n\t offset = offset >>> 0\n\t if (!noAssert) checkOffset(offset, 1, this.length)\n\t if (!(this[offset] & 0x80)) return (this[offset])\n\t return ((0xff - this[offset] + 1) * -1)\n\t}\n\t\n\tBuffer.prototype.readInt16LE = function readInt16LE (offset, noAssert) {\n\t offset = offset >>> 0\n\t if (!noAssert) checkOffset(offset, 2, this.length)\n\t var val = this[offset] | (this[offset + 1] << 8)\n\t return (val & 0x8000) ? val | 0xFFFF0000 : val\n\t}\n\t\n\tBuffer.prototype.readInt16BE = function readInt16BE (offset, noAssert) {\n\t offset = offset >>> 0\n\t if (!noAssert) checkOffset(offset, 2, this.length)\n\t var val = this[offset + 1] | (this[offset] << 8)\n\t return (val & 0x8000) ? val | 0xFFFF0000 : val\n\t}\n\t\n\tBuffer.prototype.readInt32LE = function readInt32LE (offset, noAssert) {\n\t offset = offset >>> 0\n\t if (!noAssert) checkOffset(offset, 4, this.length)\n\t\n\t return (this[offset]) |\n\t (this[offset + 1] << 8) |\n\t (this[offset + 2] << 16) |\n\t (this[offset + 3] << 24)\n\t}\n\t\n\tBuffer.prototype.readInt32BE = function readInt32BE (offset, noAssert) {\n\t offset = offset >>> 0\n\t if (!noAssert) checkOffset(offset, 4, this.length)\n\t\n\t return (this[offset] << 24) |\n\t (this[offset + 1] << 16) |\n\t (this[offset + 2] << 8) |\n\t (this[offset + 3])\n\t}\n\t\n\tBuffer.prototype.readFloatLE = function readFloatLE (offset, noAssert) {\n\t offset = offset >>> 0\n\t if (!noAssert) checkOffset(offset, 4, this.length)\n\t return ieee754.read(this, offset, true, 23, 4)\n\t}\n\t\n\tBuffer.prototype.readFloatBE = function readFloatBE (offset, noAssert) {\n\t offset = offset >>> 0\n\t if (!noAssert) checkOffset(offset, 4, this.length)\n\t return ieee754.read(this, offset, false, 23, 4)\n\t}\n\t\n\tBuffer.prototype.readDoubleLE = function readDoubleLE (offset, noAssert) {\n\t offset = offset >>> 0\n\t if (!noAssert) checkOffset(offset, 8, this.length)\n\t return ieee754.read(this, offset, true, 52, 8)\n\t}\n\t\n\tBuffer.prototype.readDoubleBE = function readDoubleBE (offset, noAssert) {\n\t offset = offset >>> 0\n\t if (!noAssert) checkOffset(offset, 8, this.length)\n\t return ieee754.read(this, offset, false, 52, 8)\n\t}\n\t\n\tfunction checkInt (buf, value, offset, ext, max, min) {\n\t if (!Buffer.isBuffer(buf)) throw new TypeError('\"buffer\" argument must be a Buffer instance')\n\t if (value > max || value < min) throw new RangeError('\"value\" argument is out of bounds')\n\t if (offset + ext > buf.length) throw new RangeError('Index out of range')\n\t}\n\t\n\tBuffer.prototype.writeUIntLE = function writeUIntLE (value, offset, byteLength, noAssert) {\n\t value = +value\n\t offset = offset >>> 0\n\t byteLength = byteLength >>> 0\n\t if (!noAssert) {\n\t var maxBytes = Math.pow(2, 8 * byteLength) - 1\n\t checkInt(this, value, offset, byteLength, maxBytes, 0)\n\t }\n\t\n\t var mul = 1\n\t var i = 0\n\t this[offset] = value & 0xFF\n\t while (++i < byteLength && (mul *= 0x100)) {\n\t this[offset + i] = (value / mul) & 0xFF\n\t }\n\t\n\t return offset + byteLength\n\t}\n\t\n\tBuffer.prototype.writeUIntBE = function writeUIntBE (value, offset, byteLength, noAssert) {\n\t value = +value\n\t offset = offset >>> 0\n\t byteLength = byteLength >>> 0\n\t if (!noAssert) {\n\t var maxBytes = Math.pow(2, 8 * byteLength) - 1\n\t checkInt(this, value, offset, byteLength, maxBytes, 0)\n\t }\n\t\n\t var i = byteLength - 1\n\t var mul = 1\n\t this[offset + i] = value & 0xFF\n\t while (--i >= 0 && (mul *= 0x100)) {\n\t this[offset + i] = (value / mul) & 0xFF\n\t }\n\t\n\t return offset + byteLength\n\t}\n\t\n\tBuffer.prototype.writeUInt8 = function writeUInt8 (value, offset, noAssert) {\n\t value = +value\n\t offset = offset >>> 0\n\t if (!noAssert) checkInt(this, value, offset, 1, 0xff, 0)\n\t this[offset] = (value & 0xff)\n\t return offset + 1\n\t}\n\t\n\tBuffer.prototype.writeUInt16LE = function writeUInt16LE (value, offset, noAssert) {\n\t value = +value\n\t offset = offset >>> 0\n\t if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n\t this[offset] = (value & 0xff)\n\t this[offset + 1] = (value >>> 8)\n\t return offset + 2\n\t}\n\t\n\tBuffer.prototype.writeUInt16BE = function writeUInt16BE (value, offset, noAssert) {\n\t value = +value\n\t offset = offset >>> 0\n\t if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n\t this[offset] = (value >>> 8)\n\t this[offset + 1] = (value & 0xff)\n\t return offset + 2\n\t}\n\t\n\tBuffer.prototype.writeUInt32LE = function writeUInt32LE (value, offset, noAssert) {\n\t value = +value\n\t offset = offset >>> 0\n\t if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)\n\t this[offset + 3] = (value >>> 24)\n\t this[offset + 2] = (value >>> 16)\n\t this[offset + 1] = (value >>> 8)\n\t this[offset] = (value & 0xff)\n\t return offset + 4\n\t}\n\t\n\tBuffer.prototype.writeUInt32BE = function writeUInt32BE (value, offset, noAssert) {\n\t value = +value\n\t offset = offset >>> 0\n\t if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)\n\t this[offset] = (value >>> 24)\n\t this[offset + 1] = (value >>> 16)\n\t this[offset + 2] = (value >>> 8)\n\t this[offset + 3] = (value & 0xff)\n\t return offset + 4\n\t}\n\t\n\tBuffer.prototype.writeIntLE = function writeIntLE (value, offset, byteLength, noAssert) {\n\t value = +value\n\t offset = offset >>> 0\n\t if (!noAssert) {\n\t var limit = Math.pow(2, 8 * byteLength - 1)\n\t\n\t checkInt(this, value, offset, byteLength, limit - 1, -limit)\n\t }\n\t\n\t var i = 0\n\t var mul = 1\n\t var sub = 0\n\t this[offset] = value & 0xFF\n\t while (++i < byteLength && (mul *= 0x100)) {\n\t if (value < 0 && sub === 0 && this[offset + i - 1] !== 0) {\n\t sub = 1\n\t }\n\t this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n\t }\n\t\n\t return offset + byteLength\n\t}\n\t\n\tBuffer.prototype.writeIntBE = function writeIntBE (value, offset, byteLength, noAssert) {\n\t value = +value\n\t offset = offset >>> 0\n\t if (!noAssert) {\n\t var limit = Math.pow(2, 8 * byteLength - 1)\n\t\n\t checkInt(this, value, offset, byteLength, limit - 1, -limit)\n\t }\n\t\n\t var i = byteLength - 1\n\t var mul = 1\n\t var sub = 0\n\t this[offset + i] = value & 0xFF\n\t while (--i >= 0 && (mul *= 0x100)) {\n\t if (value < 0 && sub === 0 && this[offset + i + 1] !== 0) {\n\t sub = 1\n\t }\n\t this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n\t }\n\t\n\t return offset + byteLength\n\t}\n\t\n\tBuffer.prototype.writeInt8 = function writeInt8 (value, offset, noAssert) {\n\t value = +value\n\t offset = offset >>> 0\n\t if (!noAssert) checkInt(this, value, offset, 1, 0x7f, -0x80)\n\t if (value < 0) value = 0xff + value + 1\n\t this[offset] = (value & 0xff)\n\t return offset + 1\n\t}\n\t\n\tBuffer.prototype.writeInt16LE = function writeInt16LE (value, offset, noAssert) {\n\t value = +value\n\t offset = offset >>> 0\n\t if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n\t this[offset] = (value & 0xff)\n\t this[offset + 1] = (value >>> 8)\n\t return offset + 2\n\t}\n\t\n\tBuffer.prototype.writeInt16BE = function writeInt16BE (value, offset, noAssert) {\n\t value = +value\n\t offset = offset >>> 0\n\t if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n\t this[offset] = (value >>> 8)\n\t this[offset + 1] = (value & 0xff)\n\t return offset + 2\n\t}\n\t\n\tBuffer.prototype.writeInt32LE = function writeInt32LE (value, offset, noAssert) {\n\t value = +value\n\t offset = offset >>> 0\n\t if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n\t this[offset] = (value & 0xff)\n\t this[offset + 1] = (value >>> 8)\n\t this[offset + 2] = (value >>> 16)\n\t this[offset + 3] = (value >>> 24)\n\t return offset + 4\n\t}\n\t\n\tBuffer.prototype.writeInt32BE = function writeInt32BE (value, offset, noAssert) {\n\t value = +value\n\t offset = offset >>> 0\n\t if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n\t if (value < 0) value = 0xffffffff + value + 1\n\t this[offset] = (value >>> 24)\n\t this[offset + 1] = (value >>> 16)\n\t this[offset + 2] = (value >>> 8)\n\t this[offset + 3] = (value & 0xff)\n\t return offset + 4\n\t}\n\t\n\tfunction checkIEEE754 (buf, value, offset, ext, max, min) {\n\t if (offset + ext > buf.length) throw new RangeError('Index out of range')\n\t if (offset < 0) throw new RangeError('Index out of range')\n\t}\n\t\n\tfunction writeFloat (buf, value, offset, littleEndian, noAssert) {\n\t value = +value\n\t offset = offset >>> 0\n\t if (!noAssert) {\n\t checkIEEE754(buf, value, offset, 4, 3.4028234663852886e+38, -3.4028234663852886e+38)\n\t }\n\t ieee754.write(buf, value, offset, littleEndian, 23, 4)\n\t return offset + 4\n\t}\n\t\n\tBuffer.prototype.writeFloatLE = function writeFloatLE (value, offset, noAssert) {\n\t return writeFloat(this, value, offset, true, noAssert)\n\t}\n\t\n\tBuffer.prototype.writeFloatBE = function writeFloatBE (value, offset, noAssert) {\n\t return writeFloat(this, value, offset, false, noAssert)\n\t}\n\t\n\tfunction writeDouble (buf, value, offset, littleEndian, noAssert) {\n\t value = +value\n\t offset = offset >>> 0\n\t if (!noAssert) {\n\t checkIEEE754(buf, value, offset, 8, 1.7976931348623157E+308, -1.7976931348623157E+308)\n\t }\n\t ieee754.write(buf, value, offset, littleEndian, 52, 8)\n\t return offset + 8\n\t}\n\t\n\tBuffer.prototype.writeDoubleLE = function writeDoubleLE (value, offset, noAssert) {\n\t return writeDouble(this, value, offset, true, noAssert)\n\t}\n\t\n\tBuffer.prototype.writeDoubleBE = function writeDoubleBE (value, offset, noAssert) {\n\t return writeDouble(this, value, offset, false, noAssert)\n\t}\n\t\n\t// copy(targetBuffer, targetStart=0, sourceStart=0, sourceEnd=buffer.length)\n\tBuffer.prototype.copy = function copy (target, targetStart, start, end) {\n\t if (!start) start = 0\n\t if (!end && end !== 0) end = this.length\n\t if (targetStart >= target.length) targetStart = target.length\n\t if (!targetStart) targetStart = 0\n\t if (end > 0 && end < start) end = start\n\t\n\t // Copy 0 bytes; we're done\n\t if (end === start) return 0\n\t if (target.length === 0 || this.length === 0) return 0\n\t\n\t // Fatal error conditions\n\t if (targetStart < 0) {\n\t throw new RangeError('targetStart out of bounds')\n\t }\n\t if (start < 0 || start >= this.length) throw new RangeError('sourceStart out of bounds')\n\t if (end < 0) throw new RangeError('sourceEnd out of bounds')\n\t\n\t // Are we oob?\n\t if (end > this.length) end = this.length\n\t if (target.length - targetStart < end - start) {\n\t end = target.length - targetStart + start\n\t }\n\t\n\t var len = end - start\n\t var i\n\t\n\t if (this === target && start < targetStart && targetStart < end) {\n\t // descending copy from end\n\t for (i = len - 1; i >= 0; --i) {\n\t target[i + targetStart] = this[i + start]\n\t }\n\t } else if (len < 1000) {\n\t // ascending copy from start\n\t for (i = 0; i < len; ++i) {\n\t target[i + targetStart] = this[i + start]\n\t }\n\t } else {\n\t Uint8Array.prototype.set.call(\n\t target,\n\t this.subarray(start, start + len),\n\t targetStart\n\t )\n\t }\n\t\n\t return len\n\t}\n\t\n\t// Usage:\n\t// buffer.fill(number[, offset[, end]])\n\t// buffer.fill(buffer[, offset[, end]])\n\t// buffer.fill(string[, offset[, end]][, encoding])\n\tBuffer.prototype.fill = function fill (val, start, end, encoding) {\n\t // Handle string cases:\n\t if (typeof val === 'string') {\n\t if (typeof start === 'string') {\n\t encoding = start\n\t start = 0\n\t end = this.length\n\t } else if (typeof end === 'string') {\n\t encoding = end\n\t end = this.length\n\t }\n\t if (val.length === 1) {\n\t var code = val.charCodeAt(0)\n\t if (code < 256) {\n\t val = code\n\t }\n\t }\n\t if (encoding !== undefined && typeof encoding !== 'string') {\n\t throw new TypeError('encoding must be a string')\n\t }\n\t if (typeof encoding === 'string' && !Buffer.isEncoding(encoding)) {\n\t throw new TypeError('Unknown encoding: ' + encoding)\n\t }\n\t } else if (typeof val === 'number') {\n\t val = val & 255\n\t }\n\t\n\t // Invalid ranges are not set to a default, so can range check early.\n\t if (start < 0 || this.length < start || this.length < end) {\n\t throw new RangeError('Out of range index')\n\t }\n\t\n\t if (end <= start) {\n\t return this\n\t }\n\t\n\t start = start >>> 0\n\t end = end === undefined ? this.length : end >>> 0\n\t\n\t if (!val) val = 0\n\t\n\t var i\n\t if (typeof val === 'number') {\n\t for (i = start; i < end; ++i) {\n\t this[i] = val\n\t }\n\t } else {\n\t var bytes = Buffer.isBuffer(val)\n\t ? val\n\t : new Buffer(val, encoding)\n\t var len = bytes.length\n\t for (i = 0; i < end - start; ++i) {\n\t this[i + start] = bytes[i % len]\n\t }\n\t }\n\t\n\t return this\n\t}\n\t\n\t// HELPER FUNCTIONS\n\t// ================\n\t\n\tvar INVALID_BASE64_RE = /[^+/0-9A-Za-z-_]/g\n\t\n\tfunction base64clean (str) {\n\t // Node strips out invalid characters like \\n and \\t from the string, base64-js does not\n\t str = stringtrim(str).replace(INVALID_BASE64_RE, '')\n\t // Node converts strings with length < 2 to ''\n\t if (str.length < 2) return ''\n\t // Node allows for non-padded base64 strings (missing trailing ===), base64-js does not\n\t while (str.length % 4 !== 0) {\n\t str = str + '='\n\t }\n\t return str\n\t}\n\t\n\tfunction stringtrim (str) {\n\t if (str.trim) return str.trim()\n\t return str.replace(/^\\s+|\\s+$/g, '')\n\t}\n\t\n\tfunction toHex (n) {\n\t if (n < 16) return '0' + n.toString(16)\n\t return n.toString(16)\n\t}\n\t\n\tfunction utf8ToBytes (string, units) {\n\t units = units || Infinity\n\t var codePoint\n\t var length = string.length\n\t var leadSurrogate = null\n\t var bytes = []\n\t\n\t for (var i = 0; i < length; ++i) {\n\t codePoint = string.charCodeAt(i)\n\t\n\t // is surrogate component\n\t if (codePoint > 0xD7FF && codePoint < 0xE000) {\n\t // last char was a lead\n\t if (!leadSurrogate) {\n\t // no lead yet\n\t if (codePoint > 0xDBFF) {\n\t // unexpected trail\n\t if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n\t continue\n\t } else if (i + 1 === length) {\n\t // unpaired lead\n\t if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n\t continue\n\t }\n\t\n\t // valid lead\n\t leadSurrogate = codePoint\n\t\n\t continue\n\t }\n\t\n\t // 2 leads in a row\n\t if (codePoint < 0xDC00) {\n\t if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n\t leadSurrogate = codePoint\n\t continue\n\t }\n\t\n\t // valid surrogate pair\n\t codePoint = (leadSurrogate - 0xD800 << 10 | codePoint - 0xDC00) + 0x10000\n\t } else if (leadSurrogate) {\n\t // valid bmp char, but last char was a lead\n\t if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n\t }\n\t\n\t leadSurrogate = null\n\t\n\t // encode utf8\n\t if (codePoint < 0x80) {\n\t if ((units -= 1) < 0) break\n\t bytes.push(codePoint)\n\t } else if (codePoint < 0x800) {\n\t if ((units -= 2) < 0) break\n\t bytes.push(\n\t codePoint >> 0x6 | 0xC0,\n\t codePoint & 0x3F | 0x80\n\t )\n\t } else if (codePoint < 0x10000) {\n\t if ((units -= 3) < 0) break\n\t bytes.push(\n\t codePoint >> 0xC | 0xE0,\n\t codePoint >> 0x6 & 0x3F | 0x80,\n\t codePoint & 0x3F | 0x80\n\t )\n\t } else if (codePoint < 0x110000) {\n\t if ((units -= 4) < 0) break\n\t bytes.push(\n\t codePoint >> 0x12 | 0xF0,\n\t codePoint >> 0xC & 0x3F | 0x80,\n\t codePoint >> 0x6 & 0x3F | 0x80,\n\t codePoint & 0x3F | 0x80\n\t )\n\t } else {\n\t throw new Error('Invalid code point')\n\t }\n\t }\n\t\n\t return bytes\n\t}\n\t\n\tfunction asciiToBytes (str) {\n\t var byteArray = []\n\t for (var i = 0; i < str.length; ++i) {\n\t // Node's code seems to be doing this and not & 0x7F..\n\t byteArray.push(str.charCodeAt(i) & 0xFF)\n\t }\n\t return byteArray\n\t}\n\t\n\tfunction utf16leToBytes (str, units) {\n\t var c, hi, lo\n\t var byteArray = []\n\t for (var i = 0; i < str.length; ++i) {\n\t if ((units -= 2) < 0) break\n\t\n\t c = str.charCodeAt(i)\n\t hi = c >> 8\n\t lo = c % 256\n\t byteArray.push(lo)\n\t byteArray.push(hi)\n\t }\n\t\n\t return byteArray\n\t}\n\t\n\tfunction base64ToBytes (str) {\n\t return base64.toByteArray(base64clean(str))\n\t}\n\t\n\tfunction blitBuffer (src, dst, offset, length) {\n\t for (var i = 0; i < length; ++i) {\n\t if ((i + offset >= dst.length) || (i >= src.length)) break\n\t dst[i + offset] = src[i]\n\t }\n\t return i\n\t}\n\t\n\tfunction isnan (val) {\n\t return val !== val // eslint-disable-line no-self-compare\n\t}\n\t\n\t/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(7)))\n\n/***/ },\n/* 2 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t// a duplex stream is just a stream that is both readable and writable.\n\t// Since JS doesn't have multiple prototypal inheritance, this class\n\t// prototypally inherits from Readable, and then parasitically from\n\t// Writable.\n\t\n\t'use strict';\n\t\n\t/**/\n\t\n\tvar objectKeys = Object.keys || function (obj) {\n\t var keys = [];\n\t for (var key in obj) {\n\t keys.push(key);\n\t }return keys;\n\t};\n\t/**/\n\t\n\tmodule.exports = Duplex;\n\t\n\t/**/\n\tvar processNextTick = __webpack_require__(11);\n\t/**/\n\t\n\t/**/\n\tvar util = __webpack_require__(5);\n\tutil.inherits = __webpack_require__(4);\n\t/**/\n\t\n\tvar Readable = __webpack_require__(16);\n\tvar Writable = __webpack_require__(13);\n\t\n\tutil.inherits(Duplex, Readable);\n\t\n\tvar keys = objectKeys(Writable.prototype);\n\tfor (var v = 0; v < keys.length; v++) {\n\t var method = keys[v];\n\t if (!Duplex.prototype[method]) Duplex.prototype[method] = Writable.prototype[method];\n\t}\n\t\n\tfunction Duplex(options) {\n\t if (!(this instanceof Duplex)) return new Duplex(options);\n\t\n\t Readable.call(this, options);\n\t Writable.call(this, options);\n\t\n\t if (options && options.readable === false) this.readable = false;\n\t\n\t if (options && options.writable === false) this.writable = false;\n\t\n\t this.allowHalfOpen = true;\n\t if (options && options.allowHalfOpen === false) this.allowHalfOpen = false;\n\t\n\t this.once('end', onend);\n\t}\n\t\n\t// the no-half-open enforcer\n\tfunction onend() {\n\t // if we allow half-open state, or if the writable side ended,\n\t // then we're ok.\n\t if (this.allowHalfOpen || this._writableState.ended) return;\n\t\n\t // no more data can be written.\n\t // But allow more writes to happen in this tick.\n\t processNextTick(onEndNT, this);\n\t}\n\t\n\tfunction onEndNT(self) {\n\t self.end();\n\t}\n\t\n\tfunction forEach(xs, f) {\n\t for (var i = 0, l = xs.length; i < l; i++) {\n\t f(xs[i], i);\n\t }\n\t}\n\n/***/ },\n/* 3 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t\"use strict\";\n\tvar Process = __webpack_require__(19);\n\tvar process = new Process(), processProxy = {};\n\tfunction defineKey(key) {\n\t if (processProxy[key]) {\n\t // Probably a builtin Object property we don't care about.\n\t return;\n\t }\n\t if (typeof process[key] === 'function') {\n\t processProxy[key] = function () {\n\t return process[key].apply(process, arguments);\n\t };\n\t }\n\t else {\n\t processProxy[key] = process[key];\n\t }\n\t}\n\tfor (var key in process) {\n\t // Don't check if process.hasOwnProperty; we want to also expose objects\n\t // up the prototype hierarchy.\n\t defineKey(key);\n\t}\n\t// Special key: Ensure we update public-facing values of stdin/stdout/stderr.\n\tprocessProxy.initializeTTYs = function () {\n\t if (process.stdin === null) {\n\t process.initializeTTYs();\n\t processProxy.stdin = process.stdin;\n\t processProxy.stdout = process.stdout;\n\t processProxy.stderr = process.stderr;\n\t }\n\t};\n\tprocess.nextTick(function () {\n\t processProxy.initializeTTYs();\n\t});\n\tmodule.exports = processProxy;\n\n\n/***/ },\n/* 4 */\n/***/ function(module, exports) {\n\n\tif (typeof Object.create === 'function') {\n\t // implementation from standard node.js 'util' module\n\t module.exports = function inherits(ctor, superCtor) {\n\t ctor.super_ = superCtor\n\t ctor.prototype = Object.create(superCtor.prototype, {\n\t constructor: {\n\t value: ctor,\n\t enumerable: false,\n\t writable: true,\n\t configurable: true\n\t }\n\t });\n\t };\n\t} else {\n\t // old school shim for old browsers\n\t module.exports = function inherits(ctor, superCtor) {\n\t ctor.super_ = superCtor\n\t var TempCtor = function () {}\n\t TempCtor.prototype = superCtor.prototype\n\t ctor.prototype = new TempCtor()\n\t ctor.prototype.constructor = ctor\n\t }\n\t}\n\n\n/***/ },\n/* 5 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t/* WEBPACK VAR INJECTION */(function(Buffer) {// Copyright Joyent, Inc. and other Node contributors.\n\t//\n\t// Permission is hereby granted, free of charge, to any person obtaining a\n\t// copy of this software and associated documentation files (the\n\t// \"Software\"), to deal in the Software without restriction, including\n\t// without limitation the rights to use, copy, modify, merge, publish,\n\t// distribute, sublicense, and/or sell copies of the Software, and to permit\n\t// persons to whom the Software is furnished to do so, subject to the\n\t// following conditions:\n\t//\n\t// The above copyright notice and this permission notice shall be included\n\t// in all copies or substantial portions of the Software.\n\t//\n\t// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n\t// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n\t// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n\t// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n\t// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n\t// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n\t// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\t\n\t// NOTE: These type checking functions intentionally don't use `instanceof`\n\t// because it is fragile and can be easily faked with `Object.create()`.\n\t\n\tfunction isArray(arg) {\n\t if (Array.isArray) {\n\t return Array.isArray(arg);\n\t }\n\t return objectToString(arg) === '[object Array]';\n\t}\n\texports.isArray = isArray;\n\t\n\tfunction isBoolean(arg) {\n\t return typeof arg === 'boolean';\n\t}\n\texports.isBoolean = isBoolean;\n\t\n\tfunction isNull(arg) {\n\t return arg === null;\n\t}\n\texports.isNull = isNull;\n\t\n\tfunction isNullOrUndefined(arg) {\n\t return arg == null;\n\t}\n\texports.isNullOrUndefined = isNullOrUndefined;\n\t\n\tfunction isNumber(arg) {\n\t return typeof arg === 'number';\n\t}\n\texports.isNumber = isNumber;\n\t\n\tfunction isString(arg) {\n\t return typeof arg === 'string';\n\t}\n\texports.isString = isString;\n\t\n\tfunction isSymbol(arg) {\n\t return typeof arg === 'symbol';\n\t}\n\texports.isSymbol = isSymbol;\n\t\n\tfunction isUndefined(arg) {\n\t return arg === void 0;\n\t}\n\texports.isUndefined = isUndefined;\n\t\n\tfunction isRegExp(re) {\n\t return objectToString(re) === '[object RegExp]';\n\t}\n\texports.isRegExp = isRegExp;\n\t\n\tfunction isObject(arg) {\n\t return typeof arg === 'object' && arg !== null;\n\t}\n\texports.isObject = isObject;\n\t\n\tfunction isDate(d) {\n\t return objectToString(d) === '[object Date]';\n\t}\n\texports.isDate = isDate;\n\t\n\tfunction isError(e) {\n\t return (objectToString(e) === '[object Error]' || e instanceof Error);\n\t}\n\texports.isError = isError;\n\t\n\tfunction isFunction(arg) {\n\t return typeof arg === 'function';\n\t}\n\texports.isFunction = isFunction;\n\t\n\tfunction isPrimitive(arg) {\n\t return arg === null ||\n\t typeof arg === 'boolean' ||\n\t typeof arg === 'number' ||\n\t typeof arg === 'string' ||\n\t typeof arg === 'symbol' || // ES6 symbol\n\t typeof arg === 'undefined';\n\t}\n\texports.isPrimitive = isPrimitive;\n\t\n\texports.isBuffer = Buffer.isBuffer;\n\t\n\tfunction objectToString(o) {\n\t return Object.prototype.toString.call(o);\n\t}\n\t\n\t/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(7)))\n\n/***/ },\n/* 6 */\n/***/ function(module, exports) {\n\n\t// Copyright Joyent, Inc. and other Node contributors.\n\t//\n\t// Permission is hereby granted, free of charge, to any person obtaining a\n\t// copy of this software and associated documentation files (the\n\t// \"Software\"), to deal in the Software without restriction, including\n\t// without limitation the rights to use, copy, modify, merge, publish,\n\t// distribute, sublicense, and/or sell copies of the Software, and to permit\n\t// persons to whom the Software is furnished to do so, subject to the\n\t// following conditions:\n\t//\n\t// The above copyright notice and this permission notice shall be included\n\t// in all copies or substantial portions of the Software.\n\t//\n\t// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n\t// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n\t// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n\t// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n\t// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n\t// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n\t// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\t\n\tfunction EventEmitter() {\n\t this._events = this._events || {};\n\t this._maxListeners = this._maxListeners || undefined;\n\t}\n\tmodule.exports = EventEmitter;\n\t\n\t// Backwards-compat with node 0.10.x\n\tEventEmitter.EventEmitter = EventEmitter;\n\t\n\tEventEmitter.prototype._events = undefined;\n\tEventEmitter.prototype._maxListeners = undefined;\n\t\n\t// By default EventEmitters will print a warning if more than 10 listeners are\n\t// added to it. This is a useful default which helps finding memory leaks.\n\tEventEmitter.defaultMaxListeners = 10;\n\t\n\t// Obviously not all Emitters should be limited to 10. This function allows\n\t// that to be increased. Set to zero for unlimited.\n\tEventEmitter.prototype.setMaxListeners = function(n) {\n\t if (!isNumber(n) || n < 0 || isNaN(n))\n\t throw TypeError('n must be a positive number');\n\t this._maxListeners = n;\n\t return this;\n\t};\n\t\n\tEventEmitter.prototype.emit = function(type) {\n\t var er, handler, len, args, i, listeners;\n\t\n\t if (!this._events)\n\t this._events = {};\n\t\n\t // If there is no 'error' event listener then throw.\n\t if (type === 'error') {\n\t if (!this._events.error ||\n\t (isObject(this._events.error) && !this._events.error.length)) {\n\t er = arguments[1];\n\t if (er instanceof Error) {\n\t throw er; // Unhandled 'error' event\n\t } else {\n\t // At least give some kind of context to the user\n\t var err = new Error('Uncaught, unspecified \"error\" event. (' + er + ')');\n\t err.context = er;\n\t throw err;\n\t }\n\t }\n\t }\n\t\n\t handler = this._events[type];\n\t\n\t if (isUndefined(handler))\n\t return false;\n\t\n\t if (isFunction(handler)) {\n\t switch (arguments.length) {\n\t // fast cases\n\t case 1:\n\t handler.call(this);\n\t break;\n\t case 2:\n\t handler.call(this, arguments[1]);\n\t break;\n\t case 3:\n\t handler.call(this, arguments[1], arguments[2]);\n\t break;\n\t // slower\n\t default:\n\t args = Array.prototype.slice.call(arguments, 1);\n\t handler.apply(this, args);\n\t }\n\t } else if (isObject(handler)) {\n\t args = Array.prototype.slice.call(arguments, 1);\n\t listeners = handler.slice();\n\t len = listeners.length;\n\t for (i = 0; i < len; i++)\n\t listeners[i].apply(this, args);\n\t }\n\t\n\t return true;\n\t};\n\t\n\tEventEmitter.prototype.addListener = function(type, listener) {\n\t var m;\n\t\n\t if (!isFunction(listener))\n\t throw TypeError('listener must be a function');\n\t\n\t if (!this._events)\n\t this._events = {};\n\t\n\t // To avoid recursion in the case that type === \"newListener\"! Before\n\t // adding it to the listeners, first emit \"newListener\".\n\t if (this._events.newListener)\n\t this.emit('newListener', type,\n\t isFunction(listener.listener) ?\n\t listener.listener : listener);\n\t\n\t if (!this._events[type])\n\t // Optimize the case of one listener. Don't need the extra array object.\n\t this._events[type] = listener;\n\t else if (isObject(this._events[type]))\n\t // If we've already got an array, just append.\n\t this._events[type].push(listener);\n\t else\n\t // Adding the second element, need to change to array.\n\t this._events[type] = [this._events[type], listener];\n\t\n\t // Check for listener leak\n\t if (isObject(this._events[type]) && !this._events[type].warned) {\n\t if (!isUndefined(this._maxListeners)) {\n\t m = this._maxListeners;\n\t } else {\n\t m = EventEmitter.defaultMaxListeners;\n\t }\n\t\n\t if (m && m > 0 && this._events[type].length > m) {\n\t this._events[type].warned = true;\n\t console.error('(node) warning: possible EventEmitter memory ' +\n\t 'leak detected. %d listeners added. ' +\n\t 'Use emitter.setMaxListeners() to increase limit.',\n\t this._events[type].length);\n\t if (typeof console.trace === 'function') {\n\t // not supported in IE 10\n\t console.trace();\n\t }\n\t }\n\t }\n\t\n\t return this;\n\t};\n\t\n\tEventEmitter.prototype.on = EventEmitter.prototype.addListener;\n\t\n\tEventEmitter.prototype.once = function(type, listener) {\n\t if (!isFunction(listener))\n\t throw TypeError('listener must be a function');\n\t\n\t var fired = false;\n\t\n\t function g() {\n\t this.removeListener(type, g);\n\t\n\t if (!fired) {\n\t fired = true;\n\t listener.apply(this, arguments);\n\t }\n\t }\n\t\n\t g.listener = listener;\n\t this.on(type, g);\n\t\n\t return this;\n\t};\n\t\n\t// emits a 'removeListener' event iff the listener was removed\n\tEventEmitter.prototype.removeListener = function(type, listener) {\n\t var list, position, length, i;\n\t\n\t if (!isFunction(listener))\n\t throw TypeError('listener must be a function');\n\t\n\t if (!this._events || !this._events[type])\n\t return this;\n\t\n\t list = this._events[type];\n\t length = list.length;\n\t position = -1;\n\t\n\t if (list === listener ||\n\t (isFunction(list.listener) && list.listener === listener)) {\n\t delete this._events[type];\n\t if (this._events.removeListener)\n\t this.emit('removeListener', type, listener);\n\t\n\t } else if (isObject(list)) {\n\t for (i = length; i-- > 0;) {\n\t if (list[i] === listener ||\n\t (list[i].listener && list[i].listener === listener)) {\n\t position = i;\n\t break;\n\t }\n\t }\n\t\n\t if (position < 0)\n\t return this;\n\t\n\t if (list.length === 1) {\n\t list.length = 0;\n\t delete this._events[type];\n\t } else {\n\t list.splice(position, 1);\n\t }\n\t\n\t if (this._events.removeListener)\n\t this.emit('removeListener', type, listener);\n\t }\n\t\n\t return this;\n\t};\n\t\n\tEventEmitter.prototype.removeAllListeners = function(type) {\n\t var key, listeners;\n\t\n\t if (!this._events)\n\t return this;\n\t\n\t // not listening for removeListener, no need to emit\n\t if (!this._events.removeListener) {\n\t if (arguments.length === 0)\n\t this._events = {};\n\t else if (this._events[type])\n\t delete this._events[type];\n\t return this;\n\t }\n\t\n\t // emit removeListener for all listeners on all events\n\t if (arguments.length === 0) {\n\t for (key in this._events) {\n\t if (key === 'removeListener') continue;\n\t this.removeAllListeners(key);\n\t }\n\t this.removeAllListeners('removeListener');\n\t this._events = {};\n\t return this;\n\t }\n\t\n\t listeners = this._events[type];\n\t\n\t if (isFunction(listeners)) {\n\t this.removeListener(type, listeners);\n\t } else if (listeners) {\n\t // LIFO order\n\t while (listeners.length)\n\t this.removeListener(type, listeners[listeners.length - 1]);\n\t }\n\t delete this._events[type];\n\t\n\t return this;\n\t};\n\t\n\tEventEmitter.prototype.listeners = function(type) {\n\t var ret;\n\t if (!this._events || !this._events[type])\n\t ret = [];\n\t else if (isFunction(this._events[type]))\n\t ret = [this._events[type]];\n\t else\n\t ret = this._events[type].slice();\n\t return ret;\n\t};\n\t\n\tEventEmitter.prototype.listenerCount = function(type) {\n\t if (this._events) {\n\t var evlistener = this._events[type];\n\t\n\t if (isFunction(evlistener))\n\t return 1;\n\t else if (evlistener)\n\t return evlistener.length;\n\t }\n\t return 0;\n\t};\n\t\n\tEventEmitter.listenerCount = function(emitter, type) {\n\t return emitter.listenerCount(type);\n\t};\n\t\n\tfunction isFunction(arg) {\n\t return typeof arg === 'function';\n\t}\n\t\n\tfunction isNumber(arg) {\n\t return typeof arg === 'number';\n\t}\n\t\n\tfunction isObject(arg) {\n\t return typeof arg === 'object' && arg !== null;\n\t}\n\t\n\tfunction isUndefined(arg) {\n\t return arg === void 0;\n\t}\n\n\n/***/ },\n/* 7 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tmodule.exports = __webpack_require__(1).Buffer;\n\n\n/***/ },\n/* 8 */\n/***/ function(module, exports) {\n\n\t'use strict';\n\t\n\t\n\tvar TYPED_OK = (typeof Uint8Array !== 'undefined') &&\n\t (typeof Uint16Array !== 'undefined') &&\n\t (typeof Int32Array !== 'undefined');\n\t\n\t\n\texports.assign = function (obj /*from1, from2, from3, ...*/) {\n\t var sources = Array.prototype.slice.call(arguments, 1);\n\t while (sources.length) {\n\t var source = sources.shift();\n\t if (!source) { continue; }\n\t\n\t if (typeof source !== 'object') {\n\t throw new TypeError(source + 'must be non-object');\n\t }\n\t\n\t for (var p in source) {\n\t if (source.hasOwnProperty(p)) {\n\t obj[p] = source[p];\n\t }\n\t }\n\t }\n\t\n\t return obj;\n\t};\n\t\n\t\n\t// reduce buffer size, avoiding mem copy\n\texports.shrinkBuf = function (buf, size) {\n\t if (buf.length === size) { return buf; }\n\t if (buf.subarray) { return buf.subarray(0, size); }\n\t buf.length = size;\n\t return buf;\n\t};\n\t\n\t\n\tvar fnTyped = {\n\t arraySet: function (dest, src, src_offs, len, dest_offs) {\n\t if (src.subarray && dest.subarray) {\n\t dest.set(src.subarray(src_offs, src_offs + len), dest_offs);\n\t return;\n\t }\n\t // Fallback to ordinary array\n\t for (var i = 0; i < len; i++) {\n\t dest[dest_offs + i] = src[src_offs + i];\n\t }\n\t },\n\t // Join array of chunks to single array.\n\t flattenChunks: function (chunks) {\n\t var i, l, len, pos, chunk, result;\n\t\n\t // calculate data length\n\t len = 0;\n\t for (i = 0, l = chunks.length; i < l; i++) {\n\t len += chunks[i].length;\n\t }\n\t\n\t // join chunks\n\t result = new Uint8Array(len);\n\t pos = 0;\n\t for (i = 0, l = chunks.length; i < l; i++) {\n\t chunk = chunks[i];\n\t result.set(chunk, pos);\n\t pos += chunk.length;\n\t }\n\t\n\t return result;\n\t }\n\t};\n\t\n\tvar fnUntyped = {\n\t arraySet: function (dest, src, src_offs, len, dest_offs) {\n\t for (var i = 0; i < len; i++) {\n\t dest[dest_offs + i] = src[src_offs + i];\n\t }\n\t },\n\t // Join array of chunks to single array.\n\t flattenChunks: function (chunks) {\n\t return [].concat.apply([], chunks);\n\t }\n\t};\n\t\n\t\n\t// Enable/Disable typed arrays use, for testing\n\t//\n\texports.setTyped = function (on) {\n\t if (on) {\n\t exports.Buf8 = Uint8Array;\n\t exports.Buf16 = Uint16Array;\n\t exports.Buf32 = Int32Array;\n\t exports.assign(exports, fnTyped);\n\t } else {\n\t exports.Buf8 = Array;\n\t exports.Buf16 = Array;\n\t exports.Buf32 = Array;\n\t exports.assign(exports, fnUntyped);\n\t }\n\t};\n\t\n\texports.setTyped(TYPED_OK);\n\n\n/***/ },\n/* 9 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t// Copyright Joyent, Inc. and other Node contributors.\n\t//\n\t// Permission is hereby granted, free of charge, to any person obtaining a\n\t// copy of this software and associated documentation files (the\n\t// \"Software\"), to deal in the Software without restriction, including\n\t// without limitation the rights to use, copy, modify, merge, publish,\n\t// distribute, sublicense, and/or sell copies of the Software, and to permit\n\t// persons to whom the Software is furnished to do so, subject to the\n\t// following conditions:\n\t//\n\t// The above copyright notice and this permission notice shall be included\n\t// in all copies or substantial portions of the Software.\n\t//\n\t// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n\t// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n\t// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n\t// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n\t// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n\t// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n\t// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\t\n\tmodule.exports = Stream;\n\t\n\tvar EE = __webpack_require__(6).EventEmitter;\n\tvar inherits = __webpack_require__(4);\n\t\n\tinherits(Stream, EE);\n\tStream.Readable = __webpack_require__(37);\n\tStream.Writable = __webpack_require__(39);\n\tStream.Duplex = __webpack_require__(34);\n\tStream.Transform = __webpack_require__(38);\n\tStream.PassThrough = __webpack_require__(36);\n\t\n\t// Backwards-compat with node 0.4.x\n\tStream.Stream = Stream;\n\t\n\t\n\t\n\t// old-style streams. Note that the pipe method (the only relevant\n\t// part of this class) is overridden in the Readable class.\n\t\n\tfunction Stream() {\n\t EE.call(this);\n\t}\n\t\n\tStream.prototype.pipe = function(dest, options) {\n\t var source = this;\n\t\n\t function ondata(chunk) {\n\t if (dest.writable) {\n\t if (false === dest.write(chunk) && source.pause) {\n\t source.pause();\n\t }\n\t }\n\t }\n\t\n\t source.on('data', ondata);\n\t\n\t function ondrain() {\n\t if (source.readable && source.resume) {\n\t source.resume();\n\t }\n\t }\n\t\n\t dest.on('drain', ondrain);\n\t\n\t // If the 'end' option is not supplied, dest.end() will be called when\n\t // source gets the 'end' or 'close' events. Only dest.end() once.\n\t if (!dest._isStdio && (!options || options.end !== false)) {\n\t source.on('end', onend);\n\t source.on('close', onclose);\n\t }\n\t\n\t var didOnEnd = false;\n\t function onend() {\n\t if (didOnEnd) return;\n\t didOnEnd = true;\n\t\n\t dest.end();\n\t }\n\t\n\t\n\t function onclose() {\n\t if (didOnEnd) return;\n\t didOnEnd = true;\n\t\n\t if (typeof dest.destroy === 'function') dest.destroy();\n\t }\n\t\n\t // don't leave dangling pipes when there are errors.\n\t function onerror(er) {\n\t cleanup();\n\t if (EE.listenerCount(this, 'error') === 0) {\n\t throw er; // Unhandled stream error in pipe.\n\t }\n\t }\n\t\n\t source.on('error', onerror);\n\t dest.on('error', onerror);\n\t\n\t // remove all the event listeners that were added.\n\t function cleanup() {\n\t source.removeListener('data', ondata);\n\t dest.removeListener('drain', ondrain);\n\t\n\t source.removeListener('end', onend);\n\t source.removeListener('close', onclose);\n\t\n\t source.removeListener('error', onerror);\n\t dest.removeListener('error', onerror);\n\t\n\t source.removeListener('end', cleanup);\n\t source.removeListener('close', cleanup);\n\t\n\t dest.removeListener('close', cleanup);\n\t }\n\t\n\t source.on('end', cleanup);\n\t source.on('close', cleanup);\n\t\n\t dest.on('close', cleanup);\n\t\n\t dest.emit('pipe', source);\n\t\n\t // Allow for unix-like usage: A.pipe(B).pipe(C)\n\t return dest;\n\t};\n\n\n/***/ },\n/* 10 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t/* WEBPACK VAR INJECTION */(function(global) {'use strict';\n\t\n\tvar buffer = __webpack_require__(1);\n\tvar Buffer = buffer.Buffer;\n\tvar SlowBuffer = buffer.SlowBuffer;\n\tvar MAX_LEN = buffer.kMaxLength || 2147483647;\n\texports.alloc = function alloc(size, fill, encoding) {\n\t if (typeof Buffer.alloc === 'function') {\n\t return Buffer.alloc(size, fill, encoding);\n\t }\n\t if (typeof encoding === 'number') {\n\t throw new TypeError('encoding must not be number');\n\t }\n\t if (typeof size !== 'number') {\n\t throw new TypeError('size must be a number');\n\t }\n\t if (size > MAX_LEN) {\n\t throw new RangeError('size is too large');\n\t }\n\t var enc = encoding;\n\t var _fill = fill;\n\t if (_fill === undefined) {\n\t enc = undefined;\n\t _fill = 0;\n\t }\n\t var buf = new Buffer(size);\n\t if (typeof _fill === 'string') {\n\t var fillBuf = new Buffer(_fill, enc);\n\t var flen = fillBuf.length;\n\t var i = -1;\n\t while (++i < size) {\n\t buf[i] = fillBuf[i % flen];\n\t }\n\t } else {\n\t buf.fill(_fill);\n\t }\n\t return buf;\n\t}\n\texports.allocUnsafe = function allocUnsafe(size) {\n\t if (typeof Buffer.allocUnsafe === 'function') {\n\t return Buffer.allocUnsafe(size);\n\t }\n\t if (typeof size !== 'number') {\n\t throw new TypeError('size must be a number');\n\t }\n\t if (size > MAX_LEN) {\n\t throw new RangeError('size is too large');\n\t }\n\t return new Buffer(size);\n\t}\n\texports.from = function from(value, encodingOrOffset, length) {\n\t if (typeof Buffer.from === 'function' && (!global.Uint8Array || Uint8Array.from !== Buffer.from)) {\n\t return Buffer.from(value, encodingOrOffset, length);\n\t }\n\t if (typeof value === 'number') {\n\t throw new TypeError('\"value\" argument must not be a number');\n\t }\n\t if (typeof value === 'string') {\n\t return new Buffer(value, encodingOrOffset);\n\t }\n\t if (typeof ArrayBuffer !== 'undefined' && value instanceof ArrayBuffer) {\n\t var offset = encodingOrOffset;\n\t if (arguments.length === 1) {\n\t return new Buffer(value);\n\t }\n\t if (typeof offset === 'undefined') {\n\t offset = 0;\n\t }\n\t var len = length;\n\t if (typeof len === 'undefined') {\n\t len = value.byteLength - offset;\n\t }\n\t if (offset >= value.byteLength) {\n\t throw new RangeError('\\'offset\\' is out of bounds');\n\t }\n\t if (len > value.byteLength - offset) {\n\t throw new RangeError('\\'length\\' is out of bounds');\n\t }\n\t return new Buffer(value.slice(offset, offset + len));\n\t }\n\t if (Buffer.isBuffer(value)) {\n\t var out = new Buffer(value.length);\n\t value.copy(out, 0, 0, value.length);\n\t return out;\n\t }\n\t if (value) {\n\t if (Array.isArray(value) || (typeof ArrayBuffer !== 'undefined' && value.buffer instanceof ArrayBuffer) || 'length' in value) {\n\t return new Buffer(value);\n\t }\n\t if (value.type === 'Buffer' && Array.isArray(value.data)) {\n\t return new Buffer(value.data);\n\t }\n\t }\n\t\n\t throw new TypeError('First argument must be a string, Buffer, ' + 'ArrayBuffer, Array, or array-like object.');\n\t}\n\texports.allocUnsafeSlow = function allocUnsafeSlow(size) {\n\t if (typeof Buffer.allocUnsafeSlow === 'function') {\n\t return Buffer.allocUnsafeSlow(size);\n\t }\n\t if (typeof size !== 'number') {\n\t throw new TypeError('size must be a number');\n\t }\n\t if (size >= MAX_LEN) {\n\t throw new RangeError('size is too large');\n\t }\n\t return new SlowBuffer(size);\n\t}\n\t\n\t/* WEBPACK VAR INJECTION */}.call(exports, (function() { return this; }())))\n\n/***/ },\n/* 11 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t/* WEBPACK VAR INJECTION */(function(process) {'use strict';\n\t\n\tif (!process.version ||\n\t process.version.indexOf('v0.') === 0 ||\n\t process.version.indexOf('v1.') === 0 && process.version.indexOf('v1.8.') !== 0) {\n\t module.exports = nextTick;\n\t} else {\n\t module.exports = process.nextTick;\n\t}\n\t\n\tfunction nextTick(fn, arg1, arg2, arg3) {\n\t if (typeof fn !== 'function') {\n\t throw new TypeError('\"callback\" argument must be a function');\n\t }\n\t var len = arguments.length;\n\t var args, i;\n\t switch (len) {\n\t case 0:\n\t case 1:\n\t return process.nextTick(fn);\n\t case 2:\n\t return process.nextTick(function afterTickOne() {\n\t fn.call(null, arg1);\n\t });\n\t case 3:\n\t return process.nextTick(function afterTickTwo() {\n\t fn.call(null, arg1, arg2);\n\t });\n\t case 4:\n\t return process.nextTick(function afterTickThree() {\n\t fn.call(null, arg1, arg2, arg3);\n\t });\n\t default:\n\t args = new Array(len - 1);\n\t i = 0;\n\t while (i < args.length) {\n\t args[i++] = arguments[i];\n\t }\n\t return process.nextTick(function afterTick() {\n\t fn.apply(null, args);\n\t });\n\t }\n\t}\n\t\n\t/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(3)))\n\n/***/ },\n/* 12 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t// a transform stream is a readable/writable stream where you do\n\t// something with the data. Sometimes it's called a \"filter\",\n\t// but that's not a great name for it, since that implies a thing where\n\t// some bits pass through, and others are simply ignored. (That would\n\t// be a valid example of a transform, of course.)\n\t//\n\t// While the output is causally related to the input, it's not a\n\t// necessarily symmetric or synchronous transformation. For example,\n\t// a zlib stream might take multiple plain-text writes(), and then\n\t// emit a single compressed chunk some time in the future.\n\t//\n\t// Here's how this works:\n\t//\n\t// The Transform stream has all the aspects of the readable and writable\n\t// stream classes. When you write(chunk), that calls _write(chunk,cb)\n\t// internally, and returns false if there's a lot of pending writes\n\t// buffered up. When you call read(), that calls _read(n) until\n\t// there's enough pending readable data buffered up.\n\t//\n\t// In a transform stream, the written data is placed in a buffer. When\n\t// _read(n) is called, it transforms the queued up data, calling the\n\t// buffered _write cb's as it consumes chunks. If consuming a single\n\t// written chunk would result in multiple output chunks, then the first\n\t// outputted bit calls the readcb, and subsequent chunks just go into\n\t// the read buffer, and will cause it to emit 'readable' if necessary.\n\t//\n\t// This way, back-pressure is actually determined by the reading side,\n\t// since _read has to be called to start processing a new chunk. However,\n\t// a pathological inflate type of transform can cause excessive buffering\n\t// here. For example, imagine a stream where every byte of input is\n\t// interpreted as an integer from 0-255, and then results in that many\n\t// bytes of output. Writing the 4 bytes {ff,ff,ff,ff} would result in\n\t// 1kb of data being output. In this case, you could write a very small\n\t// amount of input, and end up with a very large amount of output. In\n\t// such a pathological inflating mechanism, there'd be no way to tell\n\t// the system to stop doing the transform. A single 4MB write could\n\t// cause the system to run out of memory.\n\t//\n\t// However, even in such a pathological case, only a single written chunk\n\t// would be consumed, and then the rest would wait (un-transformed) until\n\t// the results of the previous transformed chunk were consumed.\n\t\n\t'use strict';\n\t\n\tmodule.exports = Transform;\n\t\n\tvar Duplex = __webpack_require__(2);\n\t\n\t/**/\n\tvar util = __webpack_require__(5);\n\tutil.inherits = __webpack_require__(4);\n\t/**/\n\t\n\tutil.inherits(Transform, Duplex);\n\t\n\tfunction TransformState(stream) {\n\t this.afterTransform = function (er, data) {\n\t return afterTransform(stream, er, data);\n\t };\n\t\n\t this.needTransform = false;\n\t this.transforming = false;\n\t this.writecb = null;\n\t this.writechunk = null;\n\t this.writeencoding = null;\n\t}\n\t\n\tfunction afterTransform(stream, er, data) {\n\t var ts = stream._transformState;\n\t ts.transforming = false;\n\t\n\t var cb = ts.writecb;\n\t\n\t if (!cb) return stream.emit('error', new Error('no writecb in Transform class'));\n\t\n\t ts.writechunk = null;\n\t ts.writecb = null;\n\t\n\t if (data !== null && data !== undefined) stream.push(data);\n\t\n\t cb(er);\n\t\n\t var rs = stream._readableState;\n\t rs.reading = false;\n\t if (rs.needReadable || rs.length < rs.highWaterMark) {\n\t stream._read(rs.highWaterMark);\n\t }\n\t}\n\t\n\tfunction Transform(options) {\n\t if (!(this instanceof Transform)) return new Transform(options);\n\t\n\t Duplex.call(this, options);\n\t\n\t this._transformState = new TransformState(this);\n\t\n\t var stream = this;\n\t\n\t // start out asking for a readable event once data is transformed.\n\t this._readableState.needReadable = true;\n\t\n\t // we have implemented the _read method, and done the other things\n\t // that Readable wants before the first _read call, so unset the\n\t // sync guard flag.\n\t this._readableState.sync = false;\n\t\n\t if (options) {\n\t if (typeof options.transform === 'function') this._transform = options.transform;\n\t\n\t if (typeof options.flush === 'function') this._flush = options.flush;\n\t }\n\t\n\t // When the writable side finishes, then flush out anything remaining.\n\t this.once('prefinish', function () {\n\t if (typeof this._flush === 'function') this._flush(function (er, data) {\n\t done(stream, er, data);\n\t });else done(stream);\n\t });\n\t}\n\t\n\tTransform.prototype.push = function (chunk, encoding) {\n\t this._transformState.needTransform = false;\n\t return Duplex.prototype.push.call(this, chunk, encoding);\n\t};\n\t\n\t// This is the part where you do stuff!\n\t// override this function in implementation classes.\n\t// 'chunk' is an input chunk.\n\t//\n\t// Call `push(newChunk)` to pass along transformed output\n\t// to the readable side. You may call 'push' zero or more times.\n\t//\n\t// Call `cb(err)` when you are done with this chunk. If you pass\n\t// an error, then that'll put the hurt on the whole operation. If you\n\t// never call cb(), then you'll never get another chunk.\n\tTransform.prototype._transform = function (chunk, encoding, cb) {\n\t throw new Error('_transform() is not implemented');\n\t};\n\t\n\tTransform.prototype._write = function (chunk, encoding, cb) {\n\t var ts = this._transformState;\n\t ts.writecb = cb;\n\t ts.writechunk = chunk;\n\t ts.writeencoding = encoding;\n\t if (!ts.transforming) {\n\t var rs = this._readableState;\n\t if (ts.needTransform || rs.needReadable || rs.length < rs.highWaterMark) this._read(rs.highWaterMark);\n\t }\n\t};\n\t\n\t// Doesn't matter what the args are here.\n\t// _transform does all the work.\n\t// That we got here means that the readable side wants more data.\n\tTransform.prototype._read = function (n) {\n\t var ts = this._transformState;\n\t\n\t if (ts.writechunk !== null && ts.writecb && !ts.transforming) {\n\t ts.transforming = true;\n\t this._transform(ts.writechunk, ts.writeencoding, ts.afterTransform);\n\t } else {\n\t // mark that we need a transform, so that any data that comes in\n\t // will get processed, now that we've asked for it.\n\t ts.needTransform = true;\n\t }\n\t};\n\t\n\tfunction done(stream, er, data) {\n\t if (er) return stream.emit('error', er);\n\t\n\t if (data !== null && data !== undefined) stream.push(data);\n\t\n\t // if there's nothing in the write buffer, then that means\n\t // that nothing more will ever be provided\n\t var ws = stream._writableState;\n\t var ts = stream._transformState;\n\t\n\t if (ws.length) throw new Error('Calling transform done when ws.length != 0');\n\t\n\t if (ts.transforming) throw new Error('Calling transform done when still transforming');\n\t\n\t return stream.push(null);\n\t}\n\n/***/ },\n/* 13 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t/* WEBPACK VAR INJECTION */(function(process) {// A bit simpler than readable streams.\n\t// Implement an async ._write(chunk, encoding, cb), and it'll handle all\n\t// the drain event emission and buffering.\n\t\n\t'use strict';\n\t\n\tmodule.exports = Writable;\n\t\n\t/**/\n\tvar processNextTick = __webpack_require__(11);\n\t/**/\n\t\n\t/**/\n\tvar asyncWrite = !process.browser && ['v0.10', 'v0.9.'].indexOf(process.version.slice(0, 5)) > -1 ? setImmediate : processNextTick;\n\t/**/\n\t\n\t/**/\n\tvar Duplex;\n\t/**/\n\t\n\tWritable.WritableState = WritableState;\n\t\n\t/**/\n\tvar util = __webpack_require__(5);\n\tutil.inherits = __webpack_require__(4);\n\t/**/\n\t\n\t/**/\n\tvar internalUtil = {\n\t deprecate: __webpack_require__(40)\n\t};\n\t/**/\n\t\n\t/**/\n\tvar Stream;\n\t(function () {\n\t try {\n\t Stream = __webpack_require__(9);\n\t } catch (_) {} finally {\n\t if (!Stream) Stream = __webpack_require__(6).EventEmitter;\n\t }\n\t})();\n\t/**/\n\t\n\tvar Buffer = __webpack_require__(1).Buffer;\n\t/**/\n\tvar bufferShim = __webpack_require__(10);\n\t/**/\n\t\n\tutil.inherits(Writable, Stream);\n\t\n\tfunction nop() {}\n\t\n\tfunction WriteReq(chunk, encoding, cb) {\n\t this.chunk = chunk;\n\t this.encoding = encoding;\n\t this.callback = cb;\n\t this.next = null;\n\t}\n\t\n\tfunction WritableState(options, stream) {\n\t Duplex = Duplex || __webpack_require__(2);\n\t\n\t options = options || {};\n\t\n\t // object stream flag to indicate whether or not this stream\n\t // contains buffers or objects.\n\t this.objectMode = !!options.objectMode;\n\t\n\t if (stream instanceof Duplex) this.objectMode = this.objectMode || !!options.writableObjectMode;\n\t\n\t // the point at which write() starts returning false\n\t // Note: 0 is a valid value, means that we always return false if\n\t // the entire buffer is not flushed immediately on write()\n\t var hwm = options.highWaterMark;\n\t var defaultHwm = this.objectMode ? 16 : 16 * 1024;\n\t this.highWaterMark = hwm || hwm === 0 ? hwm : defaultHwm;\n\t\n\t // cast to ints.\n\t this.highWaterMark = ~ ~this.highWaterMark;\n\t\n\t // drain event flag.\n\t this.needDrain = false;\n\t // at the start of calling end()\n\t this.ending = false;\n\t // when end() has been called, and returned\n\t this.ended = false;\n\t // when 'finish' is emitted\n\t this.finished = false;\n\t\n\t // should we decode strings into buffers before passing to _write?\n\t // this is here so that some node-core streams can optimize string\n\t // handling at a lower level.\n\t var noDecode = options.decodeStrings === false;\n\t this.decodeStrings = !noDecode;\n\t\n\t // Crypto is kind of old and crusty. Historically, its default string\n\t // encoding is 'binary' so we have to make this configurable.\n\t // Everything else in the universe uses 'utf8', though.\n\t this.defaultEncoding = options.defaultEncoding || 'utf8';\n\t\n\t // not an actual buffer we keep track of, but a measurement\n\t // of how much we're waiting to get pushed to some underlying\n\t // socket or file.\n\t this.length = 0;\n\t\n\t // a flag to see when we're in the middle of a write.\n\t this.writing = false;\n\t\n\t // when true all writes will be buffered until .uncork() call\n\t this.corked = 0;\n\t\n\t // a flag to be able to tell if the onwrite cb is called immediately,\n\t // or on a later tick. We set this to true at first, because any\n\t // actions that shouldn't happen until \"later\" should generally also\n\t // not happen before the first write call.\n\t this.sync = true;\n\t\n\t // a flag to know if we're processing previously buffered items, which\n\t // may call the _write() callback in the same tick, so that we don't\n\t // end up in an overlapped onwrite situation.\n\t this.bufferProcessing = false;\n\t\n\t // the callback that's passed to _write(chunk,cb)\n\t this.onwrite = function (er) {\n\t onwrite(stream, er);\n\t };\n\t\n\t // the callback that the user supplies to write(chunk,encoding,cb)\n\t this.writecb = null;\n\t\n\t // the amount that is being written when _write is called.\n\t this.writelen = 0;\n\t\n\t this.bufferedRequest = null;\n\t this.lastBufferedRequest = null;\n\t\n\t // number of pending user-supplied write callbacks\n\t // this must be 0 before 'finish' can be emitted\n\t this.pendingcb = 0;\n\t\n\t // emit prefinish if the only thing we're waiting for is _write cbs\n\t // This is relevant for synchronous Transform streams\n\t this.prefinished = false;\n\t\n\t // True if the error was already emitted and should not be thrown again\n\t this.errorEmitted = false;\n\t\n\t // count buffered requests\n\t this.bufferedRequestCount = 0;\n\t\n\t // allocate the first CorkedRequest, there is always\n\t // one allocated and free to use, and we maintain at most two\n\t this.corkedRequestsFree = new CorkedRequest(this);\n\t}\n\t\n\tWritableState.prototype.getBuffer = function getBuffer() {\n\t var current = this.bufferedRequest;\n\t var out = [];\n\t while (current) {\n\t out.push(current);\n\t current = current.next;\n\t }\n\t return out;\n\t};\n\t\n\t(function () {\n\t try {\n\t Object.defineProperty(WritableState.prototype, 'buffer', {\n\t get: internalUtil.deprecate(function () {\n\t return this.getBuffer();\n\t }, '_writableState.buffer is deprecated. Use _writableState.getBuffer ' + 'instead.')\n\t });\n\t } catch (_) {}\n\t})();\n\t\n\t// Test _writableState for inheritance to account for Duplex streams,\n\t// whose prototype chain only points to Readable.\n\tvar realHasInstance;\n\tif (typeof Symbol === 'function' && Symbol.hasInstance && typeof Function.prototype[Symbol.hasInstance] === 'function') {\n\t realHasInstance = Function.prototype[Symbol.hasInstance];\n\t Object.defineProperty(Writable, Symbol.hasInstance, {\n\t value: function (object) {\n\t if (realHasInstance.call(this, object)) return true;\n\t\n\t return object && object._writableState instanceof WritableState;\n\t }\n\t });\n\t} else {\n\t realHasInstance = function (object) {\n\t return object instanceof this;\n\t };\n\t}\n\t\n\tfunction Writable(options) {\n\t Duplex = Duplex || __webpack_require__(2);\n\t\n\t // Writable ctor is applied to Duplexes, too.\n\t // `realHasInstance` is necessary because using plain `instanceof`\n\t // would return false, as no `_writableState` property is attached.\n\t\n\t // Trying to use the custom `instanceof` for Writable here will also break the\n\t // Node.js LazyTransform implementation, which has a non-trivial getter for\n\t // `_writableState` that would lead to infinite recursion.\n\t if (!realHasInstance.call(Writable, this) && !(this instanceof Duplex)) {\n\t return new Writable(options);\n\t }\n\t\n\t this._writableState = new WritableState(options, this);\n\t\n\t // legacy.\n\t this.writable = true;\n\t\n\t if (options) {\n\t if (typeof options.write === 'function') this._write = options.write;\n\t\n\t if (typeof options.writev === 'function') this._writev = options.writev;\n\t }\n\t\n\t Stream.call(this);\n\t}\n\t\n\t// Otherwise people can pipe Writable streams, which is just wrong.\n\tWritable.prototype.pipe = function () {\n\t this.emit('error', new Error('Cannot pipe, not readable'));\n\t};\n\t\n\tfunction writeAfterEnd(stream, cb) {\n\t var er = new Error('write after end');\n\t // TODO: defer error events consistently everywhere, not just the cb\n\t stream.emit('error', er);\n\t processNextTick(cb, er);\n\t}\n\t\n\t// If we get something that is not a buffer, string, null, or undefined,\n\t// and we're not in objectMode, then that's an error.\n\t// Otherwise stream chunks are all considered to be of length=1, and the\n\t// watermarks determine how many objects to keep in the buffer, rather than\n\t// how many bytes or characters.\n\tfunction validChunk(stream, state, chunk, cb) {\n\t var valid = true;\n\t var er = false;\n\t // Always throw error if a null is written\n\t // if we are not in object mode then throw\n\t // if it is not a buffer, string, or undefined.\n\t if (chunk === null) {\n\t er = new TypeError('May not write null values to stream');\n\t } else if (!Buffer.isBuffer(chunk) && typeof chunk !== 'string' && chunk !== undefined && !state.objectMode) {\n\t er = new TypeError('Invalid non-string/buffer chunk');\n\t }\n\t if (er) {\n\t stream.emit('error', er);\n\t processNextTick(cb, er);\n\t valid = false;\n\t }\n\t return valid;\n\t}\n\t\n\tWritable.prototype.write = function (chunk, encoding, cb) {\n\t var state = this._writableState;\n\t var ret = false;\n\t\n\t if (typeof encoding === 'function') {\n\t cb = encoding;\n\t encoding = null;\n\t }\n\t\n\t if (Buffer.isBuffer(chunk)) encoding = 'buffer';else if (!encoding) encoding = state.defaultEncoding;\n\t\n\t if (typeof cb !== 'function') cb = nop;\n\t\n\t if (state.ended) writeAfterEnd(this, cb);else if (validChunk(this, state, chunk, cb)) {\n\t state.pendingcb++;\n\t ret = writeOrBuffer(this, state, chunk, encoding, cb);\n\t }\n\t\n\t return ret;\n\t};\n\t\n\tWritable.prototype.cork = function () {\n\t var state = this._writableState;\n\t\n\t state.corked++;\n\t};\n\t\n\tWritable.prototype.uncork = function () {\n\t var state = this._writableState;\n\t\n\t if (state.corked) {\n\t state.corked--;\n\t\n\t if (!state.writing && !state.corked && !state.finished && !state.bufferProcessing && state.bufferedRequest) clearBuffer(this, state);\n\t }\n\t};\n\t\n\tWritable.prototype.setDefaultEncoding = function setDefaultEncoding(encoding) {\n\t // node::ParseEncoding() requires lower case.\n\t if (typeof encoding === 'string') encoding = encoding.toLowerCase();\n\t if (!(['hex', 'utf8', 'utf-8', 'ascii', 'binary', 'base64', 'ucs2', 'ucs-2', 'utf16le', 'utf-16le', 'raw'].indexOf((encoding + '').toLowerCase()) > -1)) throw new TypeError('Unknown encoding: ' + encoding);\n\t this._writableState.defaultEncoding = encoding;\n\t return this;\n\t};\n\t\n\tfunction decodeChunk(state, chunk, encoding) {\n\t if (!state.objectMode && state.decodeStrings !== false && typeof chunk === 'string') {\n\t chunk = bufferShim.from(chunk, encoding);\n\t }\n\t return chunk;\n\t}\n\t\n\t// if we're already writing something, then just put this\n\t// in the queue, and wait our turn. Otherwise, call _write\n\t// If we return false, then we need a drain event, so set that flag.\n\tfunction writeOrBuffer(stream, state, chunk, encoding, cb) {\n\t chunk = decodeChunk(state, chunk, encoding);\n\t\n\t if (Buffer.isBuffer(chunk)) encoding = 'buffer';\n\t var len = state.objectMode ? 1 : chunk.length;\n\t\n\t state.length += len;\n\t\n\t var ret = state.length < state.highWaterMark;\n\t // we must ensure that previous needDrain will not be reset to false.\n\t if (!ret) state.needDrain = true;\n\t\n\t if (state.writing || state.corked) {\n\t var last = state.lastBufferedRequest;\n\t state.lastBufferedRequest = new WriteReq(chunk, encoding, cb);\n\t if (last) {\n\t last.next = state.lastBufferedRequest;\n\t } else {\n\t state.bufferedRequest = state.lastBufferedRequest;\n\t }\n\t state.bufferedRequestCount += 1;\n\t } else {\n\t doWrite(stream, state, false, len, chunk, encoding, cb);\n\t }\n\t\n\t return ret;\n\t}\n\t\n\tfunction doWrite(stream, state, writev, len, chunk, encoding, cb) {\n\t state.writelen = len;\n\t state.writecb = cb;\n\t state.writing = true;\n\t state.sync = true;\n\t if (writev) stream._writev(chunk, state.onwrite);else stream._write(chunk, encoding, state.onwrite);\n\t state.sync = false;\n\t}\n\t\n\tfunction onwriteError(stream, state, sync, er, cb) {\n\t --state.pendingcb;\n\t if (sync) processNextTick(cb, er);else cb(er);\n\t\n\t stream._writableState.errorEmitted = true;\n\t stream.emit('error', er);\n\t}\n\t\n\tfunction onwriteStateUpdate(state) {\n\t state.writing = false;\n\t state.writecb = null;\n\t state.length -= state.writelen;\n\t state.writelen = 0;\n\t}\n\t\n\tfunction onwrite(stream, er) {\n\t var state = stream._writableState;\n\t var sync = state.sync;\n\t var cb = state.writecb;\n\t\n\t onwriteStateUpdate(state);\n\t\n\t if (er) onwriteError(stream, state, sync, er, cb);else {\n\t // Check if we're actually ready to finish, but don't emit yet\n\t var finished = needFinish(state);\n\t\n\t if (!finished && !state.corked && !state.bufferProcessing && state.bufferedRequest) {\n\t clearBuffer(stream, state);\n\t }\n\t\n\t if (sync) {\n\t /**/\n\t asyncWrite(afterWrite, stream, state, finished, cb);\n\t /**/\n\t } else {\n\t afterWrite(stream, state, finished, cb);\n\t }\n\t }\n\t}\n\t\n\tfunction afterWrite(stream, state, finished, cb) {\n\t if (!finished) onwriteDrain(stream, state);\n\t state.pendingcb--;\n\t cb();\n\t finishMaybe(stream, state);\n\t}\n\t\n\t// Must force callback to be called on nextTick, so that we don't\n\t// emit 'drain' before the write() consumer gets the 'false' return\n\t// value, and has a chance to attach a 'drain' listener.\n\tfunction onwriteDrain(stream, state) {\n\t if (state.length === 0 && state.needDrain) {\n\t state.needDrain = false;\n\t stream.emit('drain');\n\t }\n\t}\n\t\n\t// if there's something in the buffer waiting, then process it\n\tfunction clearBuffer(stream, state) {\n\t state.bufferProcessing = true;\n\t var entry = state.bufferedRequest;\n\t\n\t if (stream._writev && entry && entry.next) {\n\t // Fast case, write everything using _writev()\n\t var l = state.bufferedRequestCount;\n\t var buffer = new Array(l);\n\t var holder = state.corkedRequestsFree;\n\t holder.entry = entry;\n\t\n\t var count = 0;\n\t while (entry) {\n\t buffer[count] = entry;\n\t entry = entry.next;\n\t count += 1;\n\t }\n\t\n\t doWrite(stream, state, true, state.length, buffer, '', holder.finish);\n\t\n\t // doWrite is almost always async, defer these to save a bit of time\n\t // as the hot path ends with doWrite\n\t state.pendingcb++;\n\t state.lastBufferedRequest = null;\n\t if (holder.next) {\n\t state.corkedRequestsFree = holder.next;\n\t holder.next = null;\n\t } else {\n\t state.corkedRequestsFree = new CorkedRequest(state);\n\t }\n\t } else {\n\t // Slow case, write chunks one-by-one\n\t while (entry) {\n\t var chunk = entry.chunk;\n\t var encoding = entry.encoding;\n\t var cb = entry.callback;\n\t var len = state.objectMode ? 1 : chunk.length;\n\t\n\t doWrite(stream, state, false, len, chunk, encoding, cb);\n\t entry = entry.next;\n\t // if we didn't call the onwrite immediately, then\n\t // it means that we need to wait until it does.\n\t // also, that means that the chunk and cb are currently\n\t // being processed, so move the buffer counter past them.\n\t if (state.writing) {\n\t break;\n\t }\n\t }\n\t\n\t if (entry === null) state.lastBufferedRequest = null;\n\t }\n\t\n\t state.bufferedRequestCount = 0;\n\t state.bufferedRequest = entry;\n\t state.bufferProcessing = false;\n\t}\n\t\n\tWritable.prototype._write = function (chunk, encoding, cb) {\n\t cb(new Error('_write() is not implemented'));\n\t};\n\t\n\tWritable.prototype._writev = null;\n\t\n\tWritable.prototype.end = function (chunk, encoding, cb) {\n\t var state = this._writableState;\n\t\n\t if (typeof chunk === 'function') {\n\t cb = chunk;\n\t chunk = null;\n\t encoding = null;\n\t } else if (typeof encoding === 'function') {\n\t cb = encoding;\n\t encoding = null;\n\t }\n\t\n\t if (chunk !== null && chunk !== undefined) this.write(chunk, encoding);\n\t\n\t // .end() fully uncorks\n\t if (state.corked) {\n\t state.corked = 1;\n\t this.uncork();\n\t }\n\t\n\t // ignore unnecessary end() calls.\n\t if (!state.ending && !state.finished) endWritable(this, state, cb);\n\t};\n\t\n\tfunction needFinish(state) {\n\t return state.ending && state.length === 0 && state.bufferedRequest === null && !state.finished && !state.writing;\n\t}\n\t\n\tfunction prefinish(stream, state) {\n\t if (!state.prefinished) {\n\t state.prefinished = true;\n\t stream.emit('prefinish');\n\t }\n\t}\n\t\n\tfunction finishMaybe(stream, state) {\n\t var need = needFinish(state);\n\t if (need) {\n\t if (state.pendingcb === 0) {\n\t prefinish(stream, state);\n\t state.finished = true;\n\t stream.emit('finish');\n\t } else {\n\t prefinish(stream, state);\n\t }\n\t }\n\t return need;\n\t}\n\t\n\tfunction endWritable(stream, state, cb) {\n\t state.ending = true;\n\t finishMaybe(stream, state);\n\t if (cb) {\n\t if (state.finished) processNextTick(cb);else stream.once('finish', cb);\n\t }\n\t state.ended = true;\n\t stream.writable = false;\n\t}\n\t\n\t// It seems a linked list but it is not\n\t// there will be only 2 of these for each stream\n\tfunction CorkedRequest(state) {\n\t var _this = this;\n\t\n\t this.next = null;\n\t this.entry = null;\n\t\n\t this.finish = function (err) {\n\t var entry = _this.entry;\n\t _this.entry = null;\n\t while (entry) {\n\t var cb = entry.callback;\n\t state.pendingcb--;\n\t cb(err);\n\t entry = entry.next;\n\t }\n\t if (state.corkedRequestsFree) {\n\t state.corkedRequestsFree.next = _this;\n\t } else {\n\t state.corkedRequestsFree = _this;\n\t }\n\t };\n\t}\n\t/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(3)))\n\n/***/ },\n/* 14 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t/* WEBPACK VAR INJECTION */(function(process) {\"use strict\";\n\t// Split a filename into [root, dir, basename, ext], unix version\n\t// 'root' is just a slash, or nothing.\n\tvar splitPathRe = /^(\\/?|)([\\s\\S]*?)((?:\\.{1,2}|[^\\/]+?|)(\\.[^.\\/]*|))(?:[\\/]*)$/;\n\tfunction posixSplitPath(filename) {\n\t var out = splitPathRe.exec(filename);\n\t out.shift();\n\t return out;\n\t}\n\t/**\n\t * Emulates Node's `path` module. This module contains utilities for handling and\n\t * transforming file paths. **All** of these methods perform only string\n\t * transformations. The file system is not consulted to check whether paths are\n\t * valid.\n\t * @see http://nodejs.org/api/path.html\n\t * @class\n\t */\n\tvar path = (function () {\n\t function path() {\n\t }\n\t /**\n\t * Normalize a string path, taking care of '..' and '.' parts.\n\t *\n\t * When multiple slashes are found, they're replaced by a single one; when the path contains a trailing slash, it is preserved. On Windows backslashes are used.\n\t * @example Usage example\n\t * path.normalize('/foo/bar//baz/asdf/quux/..')\n\t * // returns\n\t * '/foo/bar/baz/asdf'\n\t * @param [String] p The path to normalize.\n\t * @return [String]\n\t */\n\t path.normalize = function (p) {\n\t // Special case: '' -> '.'\n\t if (p === '') {\n\t p = '.';\n\t }\n\t // It's very important to know if the path is relative or not, since it\n\t // changes how we process .. and reconstruct the split string.\n\t var absolute = p.charAt(0) === path.sep;\n\t // Remove repeated //s\n\t p = path._removeDuplicateSeps(p);\n\t // Try to remove as many '../' as possible, and remove '.' completely.\n\t var components = p.split(path.sep);\n\t var goodComponents = [];\n\t for (var idx = 0; idx < components.length; idx++) {\n\t var c = components[idx];\n\t if (c === '.') {\n\t continue;\n\t }\n\t else if (c === '..' && (absolute || (!absolute && goodComponents.length > 0 && goodComponents[0] !== '..'))) {\n\t // In the absolute case: Path is relative to root, so we may pop even if\n\t // goodComponents is empty (e.g. /../ => /)\n\t // In the relative case: We're getting rid of a directory that preceded\n\t // it (e.g. /foo/../bar -> /bar)\n\t goodComponents.pop();\n\t }\n\t else {\n\t goodComponents.push(c);\n\t }\n\t }\n\t // Add in '.' when it's a relative path with no other nonempty components.\n\t // Possible results: '.' and './' (input: [''] or [])\n\t // @todo Can probably simplify this logic.\n\t if (!absolute && goodComponents.length < 2) {\n\t switch (goodComponents.length) {\n\t case 1:\n\t if (goodComponents[0] === '') {\n\t goodComponents.unshift('.');\n\t }\n\t break;\n\t default:\n\t goodComponents.push('.');\n\t }\n\t }\n\t p = goodComponents.join(path.sep);\n\t if (absolute && p.charAt(0) !== path.sep) {\n\t p = path.sep + p;\n\t }\n\t return p;\n\t };\n\t /**\n\t * Join all arguments together and normalize the resulting path.\n\t *\n\t * Arguments must be strings.\n\t * @example Usage\n\t * path.join('/foo', 'bar', 'baz/asdf', 'quux', '..')\n\t * // returns\n\t * '/foo/bar/baz/asdf'\n\t *\n\t * path.join('foo', {}, 'bar')\n\t * // throws exception\n\t * TypeError: Arguments to path.join must be strings\n\t * @param [String,...] paths Each component of the path\n\t * @return [String]\n\t */\n\t path.join = function () {\n\t var paths = [];\n\t for (var _i = 0; _i < arguments.length; _i++) {\n\t paths[_i - 0] = arguments[_i];\n\t }\n\t // Required: Prune any non-strings from the path. I also prune empty segments\n\t // so we can do a simple join of the array.\n\t var processed = [];\n\t for (var i = 0; i < paths.length; i++) {\n\t var segment = paths[i];\n\t if (typeof segment !== 'string') {\n\t throw new TypeError(\"Invalid argument type to path.join: \" + (typeof segment));\n\t }\n\t else if (segment !== '') {\n\t processed.push(segment);\n\t }\n\t }\n\t return path.normalize(processed.join(path.sep));\n\t };\n\t /**\n\t * Resolves to to an absolute path.\n\t *\n\t * If to isn't already absolute from arguments are prepended in right to left\n\t * order, until an absolute path is found. If after using all from paths still\n\t * no absolute path is found, the current working directory is used as well.\n\t * The resulting path is normalized, and trailing slashes are removed unless\n\t * the path gets resolved to the root directory. Non-string arguments are\n\t * ignored.\n\t *\n\t * Another way to think of it is as a sequence of cd commands in a shell.\n\t *\n\t * path.resolve('foo/bar', '/tmp/file/', '..', 'a/../subfile')\n\t *\n\t * Is similar to:\n\t *\n\t * cd foo/bar\n\t * cd /tmp/file/\n\t * cd ..\n\t * cd a/../subfile\n\t * pwd\n\t *\n\t * The difference is that the different paths don't need to exist and may also\n\t * be files.\n\t * @example Usage example\n\t * path.resolve('/foo/bar', './baz')\n\t * // returns\n\t * '/foo/bar/baz'\n\t *\n\t * path.resolve('/foo/bar', '/tmp/file/')\n\t * // returns\n\t * '/tmp/file'\n\t *\n\t * path.resolve('wwwroot', 'static_files/png/', '../gif/image.gif')\n\t * // if currently in /home/myself/node, it returns\n\t * '/home/myself/node/wwwroot/static_files/gif/image.gif'\n\t * @param [String,...] paths\n\t * @return [String]\n\t */\n\t path.resolve = function () {\n\t var paths = [];\n\t for (var _i = 0; _i < arguments.length; _i++) {\n\t paths[_i - 0] = arguments[_i];\n\t }\n\t // Monitor for invalid paths, throw out empty paths, and look for the *last*\n\t // absolute path that we see.\n\t var processed = [];\n\t for (var i = 0; i < paths.length; i++) {\n\t var p = paths[i];\n\t if (typeof p !== 'string') {\n\t throw new TypeError(\"Invalid argument type to path.join: \" + (typeof p));\n\t }\n\t else if (p !== '') {\n\t // Remove anything that has occurred before this absolute path, as it\n\t // doesn't matter.\n\t if (p.charAt(0) === path.sep) {\n\t processed = [];\n\t }\n\t processed.push(p);\n\t }\n\t }\n\t // Special: Remove trailing slash unless it's the root\n\t var resolved = path.normalize(processed.join(path.sep));\n\t if (resolved.length > 1 && resolved.charAt(resolved.length - 1) === path.sep) {\n\t return resolved.substr(0, resolved.length - 1);\n\t }\n\t // Special: If it doesn't start with '/', it's relative and we need to append\n\t // the current directory.\n\t if (resolved.charAt(0) !== path.sep) {\n\t // Remove ./, since we're going to append the current directory.\n\t if (resolved.charAt(0) === '.' && (resolved.length === 1 || resolved.charAt(1) === path.sep)) {\n\t resolved = resolved.length === 1 ? '' : resolved.substr(2);\n\t }\n\t // Append the current directory, which *must* be an absolute path.\n\t var cwd = process.cwd();\n\t if (resolved !== '') {\n\t // cwd will never end in a /... unless it's the root.\n\t resolved = this.normalize(cwd + (cwd !== '/' ? path.sep : '') + resolved);\n\t }\n\t else {\n\t resolved = cwd;\n\t }\n\t }\n\t return resolved;\n\t };\n\t /**\n\t * Solve the relative path from from to to.\n\t *\n\t * At times we have two absolute paths, and we need to derive the relative path\n\t * from one to the other. This is actually the reverse transform of\n\t * path.resolve, which means we see that:\n\t *\n\t * path.resolve(from, path.relative(from, to)) == path.resolve(to)\n\t *\n\t * @example Usage example\n\t * path.relative('C:\\\\orandea\\\\test\\\\aaa', 'C:\\\\orandea\\\\impl\\\\bbb')\n\t * // returns\n\t * '..\\\\..\\\\impl\\\\bbb'\n\t *\n\t * path.relative('/data/orandea/test/aaa', '/data/orandea/impl/bbb')\n\t * // returns\n\t * '../../impl/bbb'\n\t * @param [String] from\n\t * @param [String] to\n\t * @return [String]\n\t */\n\t path.relative = function (from, to) {\n\t var i;\n\t // Alright. Let's resolve these two to absolute paths and remove any\n\t // weirdness.\n\t from = path.resolve(from);\n\t to = path.resolve(to);\n\t var fromSegs = from.split(path.sep);\n\t var toSegs = to.split(path.sep);\n\t // Remove the first segment on both, as it's '' (both are absolute paths)\n\t toSegs.shift();\n\t fromSegs.shift();\n\t // There are two segments to this path:\n\t // * Going *up* the directory hierarchy with '..'\n\t // * Going *down* the directory hierarchy with foo/baz/bat.\n\t var upCount = 0;\n\t var downSegs = [];\n\t // Figure out how many things in 'from' are shared with 'to'.\n\t for (i = 0; i < fromSegs.length; i++) {\n\t var seg = fromSegs[i];\n\t if (seg === toSegs[i]) {\n\t continue;\n\t }\n\t // The rest of 'from', including the current element, indicates how many\n\t // directories we need to go up.\n\t upCount = fromSegs.length - i;\n\t break;\n\t }\n\t // The rest of 'to' indicates where we need to change to. We place this\n\t // outside of the loop, as toSegs.length may be greater than fromSegs.length.\n\t downSegs = toSegs.slice(i);\n\t // Special case: If 'from' is '/'\n\t if (fromSegs.length === 1 && fromSegs[0] === '') {\n\t upCount = 0;\n\t }\n\t // upCount can't be greater than the number of fromSegs\n\t // (cd .. from / is still /)\n\t if (upCount > fromSegs.length) {\n\t upCount = fromSegs.length;\n\t }\n\t // Create the final string!\n\t var rv = '';\n\t for (i = 0; i < upCount; i++) {\n\t rv += '../';\n\t }\n\t rv += downSegs.join(path.sep);\n\t // Special case: Remove trailing '/'. Happens if it's all up and no down.\n\t if (rv.length > 1 && rv.charAt(rv.length - 1) === path.sep) {\n\t rv = rv.substr(0, rv.length - 1);\n\t }\n\t return rv;\n\t };\n\t /**\n\t * Return the directory name of a path. Similar to the Unix `dirname` command.\n\t *\n\t * Note that BrowserFS does not validate if the path is actually a valid\n\t * directory.\n\t * @example Usage example\n\t * path.dirname('/foo/bar/baz/asdf/quux')\n\t * // returns\n\t * '/foo/bar/baz/asdf'\n\t * @param [String] p The path to get the directory name of.\n\t * @return [String]\n\t */\n\t path.dirname = function (p) {\n\t // We get rid of //, but we don't modify anything else (e.g. any extraneous .\n\t // and ../ are kept intact)\n\t p = path._removeDuplicateSeps(p);\n\t var absolute = p.charAt(0) === path.sep;\n\t var sections = p.split(path.sep);\n\t // Do 1 if it's /foo/bar, 2 if it's /foo/bar/\n\t if (sections.pop() === '' && sections.length > 0) {\n\t sections.pop();\n\t }\n\t // # of sections needs to be > 1 if absolute, since the first section is '' for '/'.\n\t // If not absolute, the first section is the first part of the path, and is OK\n\t // to return.\n\t if (sections.length > 1 || (sections.length === 1 && !absolute)) {\n\t return sections.join(path.sep);\n\t }\n\t else if (absolute) {\n\t return path.sep;\n\t }\n\t else {\n\t return '.';\n\t }\n\t };\n\t /**\n\t * Return the last portion of a path. Similar to the Unix basename command.\n\t * @example Usage example\n\t * path.basename('/foo/bar/baz/asdf/quux.html')\n\t * // returns\n\t * 'quux.html'\n\t *\n\t * path.basename('/foo/bar/baz/asdf/quux.html', '.html')\n\t * // returns\n\t * 'quux'\n\t * @param [String] p\n\t * @param [String?] ext\n\t * @return [String]\n\t */\n\t path.basename = function (p, ext) {\n\t if (ext === void 0) { ext = \"\"; }\n\t // Special case: Normalize will modify this to '.'\n\t if (p === '') {\n\t return p;\n\t }\n\t // Normalize the string first to remove any weirdness.\n\t p = path.normalize(p);\n\t // Get the last part of the string.\n\t var sections = p.split(path.sep);\n\t var lastPart = sections[sections.length - 1];\n\t // Special case: If it's empty, then we have a string like so: foo/\n\t // Meaning, 'foo' is guaranteed to be a directory.\n\t if (lastPart === '' && sections.length > 1) {\n\t return sections[sections.length - 2];\n\t }\n\t // Remove the extension, if need be.\n\t if (ext.length > 0) {\n\t var lastPartExt = lastPart.substr(lastPart.length - ext.length);\n\t if (lastPartExt === ext) {\n\t return lastPart.substr(0, lastPart.length - ext.length);\n\t }\n\t }\n\t return lastPart;\n\t };\n\t /**\n\t * Return the extension of the path, from the last '.' to end of string in the\n\t * last portion of the path. If there is no '.' in the last portion of the path\n\t * or the first character of it is '.', then it returns an empty string.\n\t * @example Usage example\n\t * path.extname('index.html')\n\t * // returns\n\t * '.html'\n\t *\n\t * path.extname('index.')\n\t * // returns\n\t * '.'\n\t *\n\t * path.extname('index')\n\t * // returns\n\t * ''\n\t * @param [String] p\n\t * @return [String]\n\t */\n\t path.extname = function (p) {\n\t p = path.normalize(p);\n\t var sections = p.split(path.sep);\n\t p = sections.pop();\n\t // Special case: foo/file.ext/ should return '.ext'\n\t if (p === '' && sections.length > 0) {\n\t p = sections.pop();\n\t }\n\t if (p === '..') {\n\t return '';\n\t }\n\t var i = p.lastIndexOf('.');\n\t if (i === -1 || i === 0) {\n\t return '';\n\t }\n\t return p.substr(i);\n\t };\n\t /**\n\t * Checks if the given path is an absolute path.\n\t *\n\t * Despite not being documented, this is a tested part of Node's path API.\n\t * @param [String] p\n\t * @return [Boolean] True if the path appears to be an absolute path.\n\t */\n\t path.isAbsolute = function (p) {\n\t return p.length > 0 && p.charAt(0) === path.sep;\n\t };\n\t /**\n\t * Unknown. Undocumented.\n\t */\n\t path._makeLong = function (p) {\n\t return p;\n\t };\n\t /**\n\t * Returns an object from a path string.\n\t */\n\t path.parse = function (p) {\n\t var allParts = posixSplitPath(p);\n\t return {\n\t root: allParts[0],\n\t dir: allParts[0] + allParts[1].slice(0, -1),\n\t base: allParts[2],\n\t ext: allParts[3],\n\t name: allParts[2].slice(0, allParts[2].length - allParts[3].length)\n\t };\n\t };\n\t path.format = function (pathObject) {\n\t if (pathObject === null || typeof pathObject !== 'object') {\n\t throw new TypeError(\"Parameter 'pathObject' must be an object, not \" + typeof pathObject);\n\t }\n\t var root = pathObject.root || '';\n\t if (typeof root !== 'string') {\n\t throw new TypeError(\"'pathObject.root' must be a string or undefined, not \" +\n\t typeof pathObject.root);\n\t }\n\t var dir = pathObject.dir ? pathObject.dir + path.sep : '';\n\t var base = pathObject.base || '';\n\t return dir + base;\n\t };\n\t path._removeDuplicateSeps = function (p) {\n\t p = p.replace(this._replaceRegex, this.sep);\n\t return p;\n\t };\n\t // The platform-specific file separator. BrowserFS uses `/`.\n\t path.sep = '/';\n\t path._replaceRegex = new RegExp(\"//+\", 'g');\n\t // The platform-specific path delimiter. BrowserFS uses `:`.\n\t path.delimiter = ':';\n\t path.posix = path;\n\t // XXX: Typing hack. We don't actually support win32.\n\t path.win32 = path;\n\t return path;\n\t}());\n\tvar _ = path;\n\tmodule.exports = path;\n\t\n\t/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(3)))\n\n/***/ },\n/* 15 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t// a passthrough stream.\n\t// basically just the most minimal sort of Transform stream.\n\t// Every written chunk gets output as-is.\n\t\n\t'use strict';\n\t\n\tmodule.exports = PassThrough;\n\t\n\tvar Transform = __webpack_require__(12);\n\t\n\t/**/\n\tvar util = __webpack_require__(5);\n\tutil.inherits = __webpack_require__(4);\n\t/**/\n\t\n\tutil.inherits(PassThrough, Transform);\n\t\n\tfunction PassThrough(options) {\n\t if (!(this instanceof PassThrough)) return new PassThrough(options);\n\t\n\t Transform.call(this, options);\n\t}\n\t\n\tPassThrough.prototype._transform = function (chunk, encoding, cb) {\n\t cb(null, chunk);\n\t};\n\n/***/ },\n/* 16 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t/* WEBPACK VAR INJECTION */(function(process) {'use strict';\n\t\n\tmodule.exports = Readable;\n\t\n\t/**/\n\tvar processNextTick = __webpack_require__(11);\n\t/**/\n\t\n\t/**/\n\tvar isArray = __webpack_require__(22);\n\t/**/\n\t\n\t/**/\n\tvar Duplex;\n\t/**/\n\t\n\tReadable.ReadableState = ReadableState;\n\t\n\t/**/\n\tvar EE = __webpack_require__(6).EventEmitter;\n\t\n\tvar EElistenerCount = function (emitter, type) {\n\t return emitter.listeners(type).length;\n\t};\n\t/**/\n\t\n\t/**/\n\tvar Stream;\n\t(function () {\n\t try {\n\t Stream = __webpack_require__(9);\n\t } catch (_) {} finally {\n\t if (!Stream) Stream = __webpack_require__(6).EventEmitter;\n\t }\n\t})();\n\t/**/\n\t\n\tvar Buffer = __webpack_require__(1).Buffer;\n\t/**/\n\tvar bufferShim = __webpack_require__(10);\n\t/**/\n\t\n\t/**/\n\tvar util = __webpack_require__(5);\n\tutil.inherits = __webpack_require__(4);\n\t/**/\n\t\n\t/**/\n\tvar debugUtil = __webpack_require__(42);\n\tvar debug = void 0;\n\tif (debugUtil && debugUtil.debuglog) {\n\t debug = debugUtil.debuglog('stream');\n\t} else {\n\t debug = function () {};\n\t}\n\t/**/\n\t\n\tvar BufferList = __webpack_require__(35);\n\tvar StringDecoder;\n\t\n\tutil.inherits(Readable, Stream);\n\t\n\tfunction prependListener(emitter, event, fn) {\n\t // Sadly this is not cacheable as some libraries bundle their own\n\t // event emitter implementation with them.\n\t if (typeof emitter.prependListener === 'function') {\n\t return emitter.prependListener(event, fn);\n\t } else {\n\t // This is a hack to make sure that our error handler is attached before any\n\t // userland ones. NEVER DO THIS. This is here only because this code needs\n\t // to continue to work with older versions of Node.js that do not include\n\t // the prependListener() method. The goal is to eventually remove this hack.\n\t if (!emitter._events || !emitter._events[event]) emitter.on(event, fn);else if (isArray(emitter._events[event])) emitter._events[event].unshift(fn);else emitter._events[event] = [fn, emitter._events[event]];\n\t }\n\t}\n\t\n\tfunction ReadableState(options, stream) {\n\t Duplex = Duplex || __webpack_require__(2);\n\t\n\t options = options || {};\n\t\n\t // object stream flag. Used to make read(n) ignore n and to\n\t // make all the buffer merging and length checks go away\n\t this.objectMode = !!options.objectMode;\n\t\n\t if (stream instanceof Duplex) this.objectMode = this.objectMode || !!options.readableObjectMode;\n\t\n\t // the point at which it stops calling _read() to fill the buffer\n\t // Note: 0 is a valid value, means \"don't call _read preemptively ever\"\n\t var hwm = options.highWaterMark;\n\t var defaultHwm = this.objectMode ? 16 : 16 * 1024;\n\t this.highWaterMark = hwm || hwm === 0 ? hwm : defaultHwm;\n\t\n\t // cast to ints.\n\t this.highWaterMark = ~ ~this.highWaterMark;\n\t\n\t // A linked list is used to store data chunks instead of an array because the\n\t // linked list can remove elements from the beginning faster than\n\t // array.shift()\n\t this.buffer = new BufferList();\n\t this.length = 0;\n\t this.pipes = null;\n\t this.pipesCount = 0;\n\t this.flowing = null;\n\t this.ended = false;\n\t this.endEmitted = false;\n\t this.reading = false;\n\t\n\t // a flag to be able to tell if the onwrite cb is called immediately,\n\t // or on a later tick. We set this to true at first, because any\n\t // actions that shouldn't happen until \"later\" should generally also\n\t // not happen before the first write call.\n\t this.sync = true;\n\t\n\t // whenever we return null, then we set a flag to say\n\t // that we're awaiting a 'readable' event emission.\n\t this.needReadable = false;\n\t this.emittedReadable = false;\n\t this.readableListening = false;\n\t this.resumeScheduled = false;\n\t\n\t // Crypto is kind of old and crusty. Historically, its default string\n\t // encoding is 'binary' so we have to make this configurable.\n\t // Everything else in the universe uses 'utf8', though.\n\t this.defaultEncoding = options.defaultEncoding || 'utf8';\n\t\n\t // when piping, we only care about 'readable' events that happen\n\t // after read()ing all the bytes and not getting any pushback.\n\t this.ranOut = false;\n\t\n\t // the number of writers that are awaiting a drain event in .pipe()s\n\t this.awaitDrain = 0;\n\t\n\t // if true, a maybeReadMore has been scheduled\n\t this.readingMore = false;\n\t\n\t this.decoder = null;\n\t this.encoding = null;\n\t if (options.encoding) {\n\t if (!StringDecoder) StringDecoder = __webpack_require__(17).StringDecoder;\n\t this.decoder = new StringDecoder(options.encoding);\n\t this.encoding = options.encoding;\n\t }\n\t}\n\t\n\tfunction Readable(options) {\n\t Duplex = Duplex || __webpack_require__(2);\n\t\n\t if (!(this instanceof Readable)) return new Readable(options);\n\t\n\t this._readableState = new ReadableState(options, this);\n\t\n\t // legacy\n\t this.readable = true;\n\t\n\t if (options && typeof options.read === 'function') this._read = options.read;\n\t\n\t Stream.call(this);\n\t}\n\t\n\t// Manually shove something into the read() buffer.\n\t// This returns true if the highWaterMark has not been hit yet,\n\t// similar to how Writable.write() returns true if you should\n\t// write() some more.\n\tReadable.prototype.push = function (chunk, encoding) {\n\t var state = this._readableState;\n\t\n\t if (!state.objectMode && typeof chunk === 'string') {\n\t encoding = encoding || state.defaultEncoding;\n\t if (encoding !== state.encoding) {\n\t chunk = bufferShim.from(chunk, encoding);\n\t encoding = '';\n\t }\n\t }\n\t\n\t return readableAddChunk(this, state, chunk, encoding, false);\n\t};\n\t\n\t// Unshift should *always* be something directly out of read()\n\tReadable.prototype.unshift = function (chunk) {\n\t var state = this._readableState;\n\t return readableAddChunk(this, state, chunk, '', true);\n\t};\n\t\n\tReadable.prototype.isPaused = function () {\n\t return this._readableState.flowing === false;\n\t};\n\t\n\tfunction readableAddChunk(stream, state, chunk, encoding, addToFront) {\n\t var er = chunkInvalid(state, chunk);\n\t if (er) {\n\t stream.emit('error', er);\n\t } else if (chunk === null) {\n\t state.reading = false;\n\t onEofChunk(stream, state);\n\t } else if (state.objectMode || chunk && chunk.length > 0) {\n\t if (state.ended && !addToFront) {\n\t var e = new Error('stream.push() after EOF');\n\t stream.emit('error', e);\n\t } else if (state.endEmitted && addToFront) {\n\t var _e = new Error('stream.unshift() after end event');\n\t stream.emit('error', _e);\n\t } else {\n\t var skipAdd;\n\t if (state.decoder && !addToFront && !encoding) {\n\t chunk = state.decoder.write(chunk);\n\t skipAdd = !state.objectMode && chunk.length === 0;\n\t }\n\t\n\t if (!addToFront) state.reading = false;\n\t\n\t // Don't add to the buffer if we've decoded to an empty string chunk and\n\t // we're not in object mode\n\t if (!skipAdd) {\n\t // if we want the data now, just emit it.\n\t if (state.flowing && state.length === 0 && !state.sync) {\n\t stream.emit('data', chunk);\n\t stream.read(0);\n\t } else {\n\t // update the buffer info.\n\t state.length += state.objectMode ? 1 : chunk.length;\n\t if (addToFront) state.buffer.unshift(chunk);else state.buffer.push(chunk);\n\t\n\t if (state.needReadable) emitReadable(stream);\n\t }\n\t }\n\t\n\t maybeReadMore(stream, state);\n\t }\n\t } else if (!addToFront) {\n\t state.reading = false;\n\t }\n\t\n\t return needMoreData(state);\n\t}\n\t\n\t// if it's past the high water mark, we can push in some more.\n\t// Also, if we have no data yet, we can stand some\n\t// more bytes. This is to work around cases where hwm=0,\n\t// such as the repl. Also, if the push() triggered a\n\t// readable event, and the user called read(largeNumber) such that\n\t// needReadable was set, then we ought to push more, so that another\n\t// 'readable' event will be triggered.\n\tfunction needMoreData(state) {\n\t return !state.ended && (state.needReadable || state.length < state.highWaterMark || state.length === 0);\n\t}\n\t\n\t// backwards compatibility.\n\tReadable.prototype.setEncoding = function (enc) {\n\t if (!StringDecoder) StringDecoder = __webpack_require__(17).StringDecoder;\n\t this._readableState.decoder = new StringDecoder(enc);\n\t this._readableState.encoding = enc;\n\t return this;\n\t};\n\t\n\t// Don't raise the hwm > 8MB\n\tvar MAX_HWM = 0x800000;\n\tfunction computeNewHighWaterMark(n) {\n\t if (n >= MAX_HWM) {\n\t n = MAX_HWM;\n\t } else {\n\t // Get the next highest power of 2 to prevent increasing hwm excessively in\n\t // tiny amounts\n\t n--;\n\t n |= n >>> 1;\n\t n |= n >>> 2;\n\t n |= n >>> 4;\n\t n |= n >>> 8;\n\t n |= n >>> 16;\n\t n++;\n\t }\n\t return n;\n\t}\n\t\n\t// This function is designed to be inlinable, so please take care when making\n\t// changes to the function body.\n\tfunction howMuchToRead(n, state) {\n\t if (n <= 0 || state.length === 0 && state.ended) return 0;\n\t if (state.objectMode) return 1;\n\t if (n !== n) {\n\t // Only flow one buffer at a time\n\t if (state.flowing && state.length) return state.buffer.head.data.length;else return state.length;\n\t }\n\t // If we're asking for more than the current hwm, then raise the hwm.\n\t if (n > state.highWaterMark) state.highWaterMark = computeNewHighWaterMark(n);\n\t if (n <= state.length) return n;\n\t // Don't have enough\n\t if (!state.ended) {\n\t state.needReadable = true;\n\t return 0;\n\t }\n\t return state.length;\n\t}\n\t\n\t// you can override either this method, or the async _read(n) below.\n\tReadable.prototype.read = function (n) {\n\t debug('read', n);\n\t n = parseInt(n, 10);\n\t var state = this._readableState;\n\t var nOrig = n;\n\t\n\t if (n !== 0) state.emittedReadable = false;\n\t\n\t // if we're doing read(0) to trigger a readable event, but we\n\t // already have a bunch of data in the buffer, then just trigger\n\t // the 'readable' event and move on.\n\t if (n === 0 && state.needReadable && (state.length >= state.highWaterMark || state.ended)) {\n\t debug('read: emitReadable', state.length, state.ended);\n\t if (state.length === 0 && state.ended) endReadable(this);else emitReadable(this);\n\t return null;\n\t }\n\t\n\t n = howMuchToRead(n, state);\n\t\n\t // if we've ended, and we're now clear, then finish it up.\n\t if (n === 0 && state.ended) {\n\t if (state.length === 0) endReadable(this);\n\t return null;\n\t }\n\t\n\t // All the actual chunk generation logic needs to be\n\t // *below* the call to _read. The reason is that in certain\n\t // synthetic stream cases, such as passthrough streams, _read\n\t // may be a completely synchronous operation which may change\n\t // the state of the read buffer, providing enough data when\n\t // before there was *not* enough.\n\t //\n\t // So, the steps are:\n\t // 1. Figure out what the state of things will be after we do\n\t // a read from the buffer.\n\t //\n\t // 2. If that resulting state will trigger a _read, then call _read.\n\t // Note that this may be asynchronous, or synchronous. Yes, it is\n\t // deeply ugly to write APIs this way, but that still doesn't mean\n\t // that the Readable class should behave improperly, as streams are\n\t // designed to be sync/async agnostic.\n\t // Take note if the _read call is sync or async (ie, if the read call\n\t // has returned yet), so that we know whether or not it's safe to emit\n\t // 'readable' etc.\n\t //\n\t // 3. Actually pull the requested chunks out of the buffer and return.\n\t\n\t // if we need a readable event, then we need to do some reading.\n\t var doRead = state.needReadable;\n\t debug('need readable', doRead);\n\t\n\t // if we currently have less than the highWaterMark, then also read some\n\t if (state.length === 0 || state.length - n < state.highWaterMark) {\n\t doRead = true;\n\t debug('length less than watermark', doRead);\n\t }\n\t\n\t // however, if we've ended, then there's no point, and if we're already\n\t // reading, then it's unnecessary.\n\t if (state.ended || state.reading) {\n\t doRead = false;\n\t debug('reading or ended', doRead);\n\t } else if (doRead) {\n\t debug('do read');\n\t state.reading = true;\n\t state.sync = true;\n\t // if the length is currently zero, then we *need* a readable event.\n\t if (state.length === 0) state.needReadable = true;\n\t // call internal read method\n\t this._read(state.highWaterMark);\n\t state.sync = false;\n\t // If _read pushed data synchronously, then `reading` will be false,\n\t // and we need to re-evaluate how much data we can return to the user.\n\t if (!state.reading) n = howMuchToRead(nOrig, state);\n\t }\n\t\n\t var ret;\n\t if (n > 0) ret = fromList(n, state);else ret = null;\n\t\n\t if (ret === null) {\n\t state.needReadable = true;\n\t n = 0;\n\t } else {\n\t state.length -= n;\n\t }\n\t\n\t if (state.length === 0) {\n\t // If we have nothing in the buffer, then we want to know\n\t // as soon as we *do* get something into the buffer.\n\t if (!state.ended) state.needReadable = true;\n\t\n\t // If we tried to read() past the EOF, then emit end on the next tick.\n\t if (nOrig !== n && state.ended) endReadable(this);\n\t }\n\t\n\t if (ret !== null) this.emit('data', ret);\n\t\n\t return ret;\n\t};\n\t\n\tfunction chunkInvalid(state, chunk) {\n\t var er = null;\n\t if (!Buffer.isBuffer(chunk) && typeof chunk !== 'string' && chunk !== null && chunk !== undefined && !state.objectMode) {\n\t er = new TypeError('Invalid non-string/buffer chunk');\n\t }\n\t return er;\n\t}\n\t\n\tfunction onEofChunk(stream, state) {\n\t if (state.ended) return;\n\t if (state.decoder) {\n\t var chunk = state.decoder.end();\n\t if (chunk && chunk.length) {\n\t state.buffer.push(chunk);\n\t state.length += state.objectMode ? 1 : chunk.length;\n\t }\n\t }\n\t state.ended = true;\n\t\n\t // emit 'readable' now to make sure it gets picked up.\n\t emitReadable(stream);\n\t}\n\t\n\t// Don't emit readable right away in sync mode, because this can trigger\n\t// another read() call => stack overflow. This way, it might trigger\n\t// a nextTick recursion warning, but that's not so bad.\n\tfunction emitReadable(stream) {\n\t var state = stream._readableState;\n\t state.needReadable = false;\n\t if (!state.emittedReadable) {\n\t debug('emitReadable', state.flowing);\n\t state.emittedReadable = true;\n\t if (state.sync) processNextTick(emitReadable_, stream);else emitReadable_(stream);\n\t }\n\t}\n\t\n\tfunction emitReadable_(stream) {\n\t debug('emit readable');\n\t stream.emit('readable');\n\t flow(stream);\n\t}\n\t\n\t// at this point, the user has presumably seen the 'readable' event,\n\t// and called read() to consume some data. that may have triggered\n\t// in turn another _read(n) call, in which case reading = true if\n\t// it's in progress.\n\t// However, if we're not ended, or reading, and the length < hwm,\n\t// then go ahead and try to read some more preemptively.\n\tfunction maybeReadMore(stream, state) {\n\t if (!state.readingMore) {\n\t state.readingMore = true;\n\t processNextTick(maybeReadMore_, stream, state);\n\t }\n\t}\n\t\n\tfunction maybeReadMore_(stream, state) {\n\t var len = state.length;\n\t while (!state.reading && !state.flowing && !state.ended && state.length < state.highWaterMark) {\n\t debug('maybeReadMore read 0');\n\t stream.read(0);\n\t if (len === state.length)\n\t // didn't get any data, stop spinning.\n\t break;else len = state.length;\n\t }\n\t state.readingMore = false;\n\t}\n\t\n\t// abstract method. to be overridden in specific implementation classes.\n\t// call cb(er, data) where data is <= n in length.\n\t// for virtual (non-string, non-buffer) streams, \"length\" is somewhat\n\t// arbitrary, and perhaps not very meaningful.\n\tReadable.prototype._read = function (n) {\n\t this.emit('error', new Error('_read() is not implemented'));\n\t};\n\t\n\tReadable.prototype.pipe = function (dest, pipeOpts) {\n\t var src = this;\n\t var state = this._readableState;\n\t\n\t switch (state.pipesCount) {\n\t case 0:\n\t state.pipes = dest;\n\t break;\n\t case 1:\n\t state.pipes = [state.pipes, dest];\n\t break;\n\t default:\n\t state.pipes.push(dest);\n\t break;\n\t }\n\t state.pipesCount += 1;\n\t debug('pipe count=%d opts=%j', state.pipesCount, pipeOpts);\n\t\n\t var doEnd = (!pipeOpts || pipeOpts.end !== false) && dest !== process.stdout && dest !== process.stderr;\n\t\n\t var endFn = doEnd ? onend : cleanup;\n\t if (state.endEmitted) processNextTick(endFn);else src.once('end', endFn);\n\t\n\t dest.on('unpipe', onunpipe);\n\t function onunpipe(readable) {\n\t debug('onunpipe');\n\t if (readable === src) {\n\t cleanup();\n\t }\n\t }\n\t\n\t function onend() {\n\t debug('onend');\n\t dest.end();\n\t }\n\t\n\t // when the dest drains, it reduces the awaitDrain counter\n\t // on the source. This would be more elegant with a .once()\n\t // handler in flow(), but adding and removing repeatedly is\n\t // too slow.\n\t var ondrain = pipeOnDrain(src);\n\t dest.on('drain', ondrain);\n\t\n\t var cleanedUp = false;\n\t function cleanup() {\n\t debug('cleanup');\n\t // cleanup event handlers once the pipe is broken\n\t dest.removeListener('close', onclose);\n\t dest.removeListener('finish', onfinish);\n\t dest.removeListener('drain', ondrain);\n\t dest.removeListener('error', onerror);\n\t dest.removeListener('unpipe', onunpipe);\n\t src.removeListener('end', onend);\n\t src.removeListener('end', cleanup);\n\t src.removeListener('data', ondata);\n\t\n\t cleanedUp = true;\n\t\n\t // if the reader is waiting for a drain event from this\n\t // specific writer, then it would cause it to never start\n\t // flowing again.\n\t // So, if this is awaiting a drain, then we just call it now.\n\t // If we don't know, then assume that we are waiting for one.\n\t if (state.awaitDrain && (!dest._writableState || dest._writableState.needDrain)) ondrain();\n\t }\n\t\n\t // If the user pushes more data while we're writing to dest then we'll end up\n\t // in ondata again. However, we only want to increase awaitDrain once because\n\t // dest will only emit one 'drain' event for the multiple writes.\n\t // => Introduce a guard on increasing awaitDrain.\n\t var increasedAwaitDrain = false;\n\t src.on('data', ondata);\n\t function ondata(chunk) {\n\t debug('ondata');\n\t increasedAwaitDrain = false;\n\t var ret = dest.write(chunk);\n\t if (false === ret && !increasedAwaitDrain) {\n\t // If the user unpiped during `dest.write()`, it is possible\n\t // to get stuck in a permanently paused state if that write\n\t // also returned false.\n\t // => Check whether `dest` is still a piping destination.\n\t if ((state.pipesCount === 1 && state.pipes === dest || state.pipesCount > 1 && indexOf(state.pipes, dest) !== -1) && !cleanedUp) {\n\t debug('false write response, pause', src._readableState.awaitDrain);\n\t src._readableState.awaitDrain++;\n\t increasedAwaitDrain = true;\n\t }\n\t src.pause();\n\t }\n\t }\n\t\n\t // if the dest has an error, then stop piping into it.\n\t // however, don't suppress the throwing behavior for this.\n\t function onerror(er) {\n\t debug('onerror', er);\n\t unpipe();\n\t dest.removeListener('error', onerror);\n\t if (EElistenerCount(dest, 'error') === 0) dest.emit('error', er);\n\t }\n\t\n\t // Make sure our error handler is attached before userland ones.\n\t prependListener(dest, 'error', onerror);\n\t\n\t // Both close and finish should trigger unpipe, but only once.\n\t function onclose() {\n\t dest.removeListener('finish', onfinish);\n\t unpipe();\n\t }\n\t dest.once('close', onclose);\n\t function onfinish() {\n\t debug('onfinish');\n\t dest.removeListener('close', onclose);\n\t unpipe();\n\t }\n\t dest.once('finish', onfinish);\n\t\n\t function unpipe() {\n\t debug('unpipe');\n\t src.unpipe(dest);\n\t }\n\t\n\t // tell the dest that it's being piped to\n\t dest.emit('pipe', src);\n\t\n\t // start the flow if it hasn't been started already.\n\t if (!state.flowing) {\n\t debug('pipe resume');\n\t src.resume();\n\t }\n\t\n\t return dest;\n\t};\n\t\n\tfunction pipeOnDrain(src) {\n\t return function () {\n\t var state = src._readableState;\n\t debug('pipeOnDrain', state.awaitDrain);\n\t if (state.awaitDrain) state.awaitDrain--;\n\t if (state.awaitDrain === 0 && EElistenerCount(src, 'data')) {\n\t state.flowing = true;\n\t flow(src);\n\t }\n\t };\n\t}\n\t\n\tReadable.prototype.unpipe = function (dest) {\n\t var state = this._readableState;\n\t\n\t // if we're not piping anywhere, then do nothing.\n\t if (state.pipesCount === 0) return this;\n\t\n\t // just one destination. most common case.\n\t if (state.pipesCount === 1) {\n\t // passed in one, but it's not the right one.\n\t if (dest && dest !== state.pipes) return this;\n\t\n\t if (!dest) dest = state.pipes;\n\t\n\t // got a match.\n\t state.pipes = null;\n\t state.pipesCount = 0;\n\t state.flowing = false;\n\t if (dest) dest.emit('unpipe', this);\n\t return this;\n\t }\n\t\n\t // slow case. multiple pipe destinations.\n\t\n\t if (!dest) {\n\t // remove all.\n\t var dests = state.pipes;\n\t var len = state.pipesCount;\n\t state.pipes = null;\n\t state.pipesCount = 0;\n\t state.flowing = false;\n\t\n\t for (var i = 0; i < len; i++) {\n\t dests[i].emit('unpipe', this);\n\t }return this;\n\t }\n\t\n\t // try to find the right one.\n\t var index = indexOf(state.pipes, dest);\n\t if (index === -1) return this;\n\t\n\t state.pipes.splice(index, 1);\n\t state.pipesCount -= 1;\n\t if (state.pipesCount === 1) state.pipes = state.pipes[0];\n\t\n\t dest.emit('unpipe', this);\n\t\n\t return this;\n\t};\n\t\n\t// set up data events if they are asked for\n\t// Ensure readable listeners eventually get something\n\tReadable.prototype.on = function (ev, fn) {\n\t var res = Stream.prototype.on.call(this, ev, fn);\n\t\n\t if (ev === 'data') {\n\t // Start flowing on next tick if stream isn't explicitly paused\n\t if (this._readableState.flowing !== false) this.resume();\n\t } else if (ev === 'readable') {\n\t var state = this._readableState;\n\t if (!state.endEmitted && !state.readableListening) {\n\t state.readableListening = state.needReadable = true;\n\t state.emittedReadable = false;\n\t if (!state.reading) {\n\t processNextTick(nReadingNextTick, this);\n\t } else if (state.length) {\n\t emitReadable(this, state);\n\t }\n\t }\n\t }\n\t\n\t return res;\n\t};\n\tReadable.prototype.addListener = Readable.prototype.on;\n\t\n\tfunction nReadingNextTick(self) {\n\t debug('readable nexttick read 0');\n\t self.read(0);\n\t}\n\t\n\t// pause() and resume() are remnants of the legacy readable stream API\n\t// If the user uses them, then switch into old mode.\n\tReadable.prototype.resume = function () {\n\t var state = this._readableState;\n\t if (!state.flowing) {\n\t debug('resume');\n\t state.flowing = true;\n\t resume(this, state);\n\t }\n\t return this;\n\t};\n\t\n\tfunction resume(stream, state) {\n\t if (!state.resumeScheduled) {\n\t state.resumeScheduled = true;\n\t processNextTick(resume_, stream, state);\n\t }\n\t}\n\t\n\tfunction resume_(stream, state) {\n\t if (!state.reading) {\n\t debug('resume read 0');\n\t stream.read(0);\n\t }\n\t\n\t state.resumeScheduled = false;\n\t state.awaitDrain = 0;\n\t stream.emit('resume');\n\t flow(stream);\n\t if (state.flowing && !state.reading) stream.read(0);\n\t}\n\t\n\tReadable.prototype.pause = function () {\n\t debug('call pause flowing=%j', this._readableState.flowing);\n\t if (false !== this._readableState.flowing) {\n\t debug('pause');\n\t this._readableState.flowing = false;\n\t this.emit('pause');\n\t }\n\t return this;\n\t};\n\t\n\tfunction flow(stream) {\n\t var state = stream._readableState;\n\t debug('flow', state.flowing);\n\t while (state.flowing && stream.read() !== null) {}\n\t}\n\t\n\t// wrap an old-style stream as the async data source.\n\t// This is *not* part of the readable stream interface.\n\t// It is an ugly unfortunate mess of history.\n\tReadable.prototype.wrap = function (stream) {\n\t var state = this._readableState;\n\t var paused = false;\n\t\n\t var self = this;\n\t stream.on('end', function () {\n\t debug('wrapped end');\n\t if (state.decoder && !state.ended) {\n\t var chunk = state.decoder.end();\n\t if (chunk && chunk.length) self.push(chunk);\n\t }\n\t\n\t self.push(null);\n\t });\n\t\n\t stream.on('data', function (chunk) {\n\t debug('wrapped data');\n\t if (state.decoder) chunk = state.decoder.write(chunk);\n\t\n\t // don't skip over falsy values in objectMode\n\t if (state.objectMode && (chunk === null || chunk === undefined)) return;else if (!state.objectMode && (!chunk || !chunk.length)) return;\n\t\n\t var ret = self.push(chunk);\n\t if (!ret) {\n\t paused = true;\n\t stream.pause();\n\t }\n\t });\n\t\n\t // proxy all the other methods.\n\t // important when wrapping filters and duplexes.\n\t for (var i in stream) {\n\t if (this[i] === undefined && typeof stream[i] === 'function') {\n\t this[i] = function (method) {\n\t return function () {\n\t return stream[method].apply(stream, arguments);\n\t };\n\t }(i);\n\t }\n\t }\n\t\n\t // proxy certain important events.\n\t var events = ['error', 'close', 'destroy', 'pause', 'resume'];\n\t forEach(events, function (ev) {\n\t stream.on(ev, self.emit.bind(self, ev));\n\t });\n\t\n\t // when we try to consume some more bytes, simply unpause the\n\t // underlying stream.\n\t self._read = function (n) {\n\t debug('wrapped _read', n);\n\t if (paused) {\n\t paused = false;\n\t stream.resume();\n\t }\n\t };\n\t\n\t return self;\n\t};\n\t\n\t// exposed for testing purposes only.\n\tReadable._fromList = fromList;\n\t\n\t// Pluck off n bytes from an array of buffers.\n\t// Length is the combined lengths of all the buffers in the list.\n\t// This function is designed to be inlinable, so please take care when making\n\t// changes to the function body.\n\tfunction fromList(n, state) {\n\t // nothing buffered\n\t if (state.length === 0) return null;\n\t\n\t var ret;\n\t if (state.objectMode) ret = state.buffer.shift();else if (!n || n >= state.length) {\n\t // read it all, truncate the list\n\t if (state.decoder) ret = state.buffer.join('');else if (state.buffer.length === 1) ret = state.buffer.head.data;else ret = state.buffer.concat(state.length);\n\t state.buffer.clear();\n\t } else {\n\t // read part of list\n\t ret = fromListPartial(n, state.buffer, state.decoder);\n\t }\n\t\n\t return ret;\n\t}\n\t\n\t// Extracts only enough buffered data to satisfy the amount requested.\n\t// This function is designed to be inlinable, so please take care when making\n\t// changes to the function body.\n\tfunction fromListPartial(n, list, hasStrings) {\n\t var ret;\n\t if (n < list.head.data.length) {\n\t // slice is the same for buffers and strings\n\t ret = list.head.data.slice(0, n);\n\t list.head.data = list.head.data.slice(n);\n\t } else if (n === list.head.data.length) {\n\t // first chunk is a perfect match\n\t ret = list.shift();\n\t } else {\n\t // result spans more than one buffer\n\t ret = hasStrings ? copyFromBufferString(n, list) : copyFromBuffer(n, list);\n\t }\n\t return ret;\n\t}\n\t\n\t// Copies a specified amount of characters from the list of buffered data\n\t// chunks.\n\t// This function is designed to be inlinable, so please take care when making\n\t// changes to the function body.\n\tfunction copyFromBufferString(n, list) {\n\t var p = list.head;\n\t var c = 1;\n\t var ret = p.data;\n\t n -= ret.length;\n\t while (p = p.next) {\n\t var str = p.data;\n\t var nb = n > str.length ? str.length : n;\n\t if (nb === str.length) ret += str;else ret += str.slice(0, n);\n\t n -= nb;\n\t if (n === 0) {\n\t if (nb === str.length) {\n\t ++c;\n\t if (p.next) list.head = p.next;else list.head = list.tail = null;\n\t } else {\n\t list.head = p;\n\t p.data = str.slice(nb);\n\t }\n\t break;\n\t }\n\t ++c;\n\t }\n\t list.length -= c;\n\t return ret;\n\t}\n\t\n\t// Copies a specified amount of bytes from the list of buffered data chunks.\n\t// This function is designed to be inlinable, so please take care when making\n\t// changes to the function body.\n\tfunction copyFromBuffer(n, list) {\n\t var ret = bufferShim.allocUnsafe(n);\n\t var p = list.head;\n\t var c = 1;\n\t p.data.copy(ret);\n\t n -= p.data.length;\n\t while (p = p.next) {\n\t var buf = p.data;\n\t var nb = n > buf.length ? buf.length : n;\n\t buf.copy(ret, ret.length - n, 0, nb);\n\t n -= nb;\n\t if (n === 0) {\n\t if (nb === buf.length) {\n\t ++c;\n\t if (p.next) list.head = p.next;else list.head = list.tail = null;\n\t } else {\n\t list.head = p;\n\t p.data = buf.slice(nb);\n\t }\n\t break;\n\t }\n\t ++c;\n\t }\n\t list.length -= c;\n\t return ret;\n\t}\n\t\n\tfunction endReadable(stream) {\n\t var state = stream._readableState;\n\t\n\t // If we get here before consuming all the bytes, then that is a\n\t // bug in node. Should never happen.\n\t if (state.length > 0) throw new Error('\"endReadable()\" called on non-empty stream');\n\t\n\t if (!state.endEmitted) {\n\t state.ended = true;\n\t processNextTick(endReadableNT, state, stream);\n\t }\n\t}\n\t\n\tfunction endReadableNT(state, stream) {\n\t // Check that we didn't get one last unshift.\n\t if (!state.endEmitted && state.length === 0) {\n\t state.endEmitted = true;\n\t stream.readable = false;\n\t stream.emit('end');\n\t }\n\t}\n\t\n\tfunction forEach(xs, f) {\n\t for (var i = 0, l = xs.length; i < l; i++) {\n\t f(xs[i], i);\n\t }\n\t}\n\t\n\tfunction indexOf(xs, x) {\n\t for (var i = 0, l = xs.length; i < l; i++) {\n\t if (xs[i] === x) return i;\n\t }\n\t return -1;\n\t}\n\t/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(3)))\n\n/***/ },\n/* 17 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t// Copyright Joyent, Inc. and other Node contributors.\n\t//\n\t// Permission is hereby granted, free of charge, to any person obtaining a\n\t// copy of this software and associated documentation files (the\n\t// \"Software\"), to deal in the Software without restriction, including\n\t// without limitation the rights to use, copy, modify, merge, publish,\n\t// distribute, sublicense, and/or sell copies of the Software, and to permit\n\t// persons to whom the Software is furnished to do so, subject to the\n\t// following conditions:\n\t//\n\t// The above copyright notice and this permission notice shall be included\n\t// in all copies or substantial portions of the Software.\n\t//\n\t// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n\t// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n\t// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n\t// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n\t// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n\t// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n\t// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\t\n\tvar Buffer = __webpack_require__(1).Buffer;\n\t\n\tvar isBufferEncoding = Buffer.isEncoding\n\t || function(encoding) {\n\t switch (encoding && encoding.toLowerCase()) {\n\t case 'hex': case 'utf8': case 'utf-8': case 'ascii': case 'binary': case 'base64': case 'ucs2': case 'ucs-2': case 'utf16le': case 'utf-16le': case 'raw': return true;\n\t default: return false;\n\t }\n\t }\n\t\n\t\n\tfunction assertEncoding(encoding) {\n\t if (encoding && !isBufferEncoding(encoding)) {\n\t throw new Error('Unknown encoding: ' + encoding);\n\t }\n\t}\n\t\n\t// StringDecoder provides an interface for efficiently splitting a series of\n\t// buffers into a series of JS strings without breaking apart multi-byte\n\t// characters. CESU-8 is handled as part of the UTF-8 encoding.\n\t//\n\t// @TODO Handling all encodings inside a single object makes it very difficult\n\t// to reason about this code, so it should be split up in the future.\n\t// @TODO There should be a utf8-strict encoding that rejects invalid UTF-8 code\n\t// points as used by CESU-8.\n\tvar StringDecoder = exports.StringDecoder = function(encoding) {\n\t this.encoding = (encoding || 'utf8').toLowerCase().replace(/[-_]/, '');\n\t assertEncoding(encoding);\n\t switch (this.encoding) {\n\t case 'utf8':\n\t // CESU-8 represents each of Surrogate Pair by 3-bytes\n\t this.surrogateSize = 3;\n\t break;\n\t case 'ucs2':\n\t case 'utf16le':\n\t // UTF-16 represents each of Surrogate Pair by 2-bytes\n\t this.surrogateSize = 2;\n\t this.detectIncompleteChar = utf16DetectIncompleteChar;\n\t break;\n\t case 'base64':\n\t // Base-64 stores 3 bytes in 4 chars, and pads the remainder.\n\t this.surrogateSize = 3;\n\t this.detectIncompleteChar = base64DetectIncompleteChar;\n\t break;\n\t default:\n\t this.write = passThroughWrite;\n\t return;\n\t }\n\t\n\t // Enough space to store all bytes of a single character. UTF-8 needs 4\n\t // bytes, but CESU-8 may require up to 6 (3 bytes per surrogate).\n\t this.charBuffer = new Buffer(6);\n\t // Number of bytes received for the current incomplete multi-byte character.\n\t this.charReceived = 0;\n\t // Number of bytes expected for the current incomplete multi-byte character.\n\t this.charLength = 0;\n\t};\n\t\n\t\n\t// write decodes the given buffer and returns it as JS string that is\n\t// guaranteed to not contain any partial multi-byte characters. Any partial\n\t// character found at the end of the buffer is buffered up, and will be\n\t// returned when calling write again with the remaining bytes.\n\t//\n\t// Note: Converting a Buffer containing an orphan surrogate to a String\n\t// currently works, but converting a String to a Buffer (via `new Buffer`, or\n\t// Buffer#write) will replace incomplete surrogates with the unicode\n\t// replacement character. See https://codereview.chromium.org/121173009/ .\n\tStringDecoder.prototype.write = function(buffer) {\n\t var charStr = '';\n\t // if our last write ended with an incomplete multibyte character\n\t while (this.charLength) {\n\t // determine how many remaining bytes this buffer has to offer for this char\n\t var available = (buffer.length >= this.charLength - this.charReceived) ?\n\t this.charLength - this.charReceived :\n\t buffer.length;\n\t\n\t // add the new bytes to the char buffer\n\t buffer.copy(this.charBuffer, this.charReceived, 0, available);\n\t this.charReceived += available;\n\t\n\t if (this.charReceived < this.charLength) {\n\t // still not enough chars in this buffer? wait for more ...\n\t return '';\n\t }\n\t\n\t // remove bytes belonging to the current character from the buffer\n\t buffer = buffer.slice(available, buffer.length);\n\t\n\t // get the character that was split\n\t charStr = this.charBuffer.slice(0, this.charLength).toString(this.encoding);\n\t\n\t // CESU-8: lead surrogate (D800-DBFF) is also the incomplete character\n\t var charCode = charStr.charCodeAt(charStr.length - 1);\n\t if (charCode >= 0xD800 && charCode <= 0xDBFF) {\n\t this.charLength += this.surrogateSize;\n\t charStr = '';\n\t continue;\n\t }\n\t this.charReceived = this.charLength = 0;\n\t\n\t // if there are no more bytes in this buffer, just emit our char\n\t if (buffer.length === 0) {\n\t return charStr;\n\t }\n\t break;\n\t }\n\t\n\t // determine and set charLength / charReceived\n\t this.detectIncompleteChar(buffer);\n\t\n\t var end = buffer.length;\n\t if (this.charLength) {\n\t // buffer the incomplete character bytes we got\n\t buffer.copy(this.charBuffer, 0, buffer.length - this.charReceived, end);\n\t end -= this.charReceived;\n\t }\n\t\n\t charStr += buffer.toString(this.encoding, 0, end);\n\t\n\t var end = charStr.length - 1;\n\t var charCode = charStr.charCodeAt(end);\n\t // CESU-8: lead surrogate (D800-DBFF) is also the incomplete character\n\t if (charCode >= 0xD800 && charCode <= 0xDBFF) {\n\t var size = this.surrogateSize;\n\t this.charLength += size;\n\t this.charReceived += size;\n\t this.charBuffer.copy(this.charBuffer, size, 0, size);\n\t buffer.copy(this.charBuffer, 0, 0, size);\n\t return charStr.substring(0, end);\n\t }\n\t\n\t // or just emit the charStr\n\t return charStr;\n\t};\n\t\n\t// detectIncompleteChar determines if there is an incomplete UTF-8 character at\n\t// the end of the given buffer. If so, it sets this.charLength to the byte\n\t// length that character, and sets this.charReceived to the number of bytes\n\t// that are available for this character.\n\tStringDecoder.prototype.detectIncompleteChar = function(buffer) {\n\t // determine how many bytes we have to check at the end of this buffer\n\t var i = (buffer.length >= 3) ? 3 : buffer.length;\n\t\n\t // Figure out if one of the last i bytes of our buffer announces an\n\t // incomplete char.\n\t for (; i > 0; i--) {\n\t var c = buffer[buffer.length - i];\n\t\n\t // See http://en.wikipedia.org/wiki/UTF-8#Description\n\t\n\t // 110XXXXX\n\t if (i == 1 && c >> 5 == 0x06) {\n\t this.charLength = 2;\n\t break;\n\t }\n\t\n\t // 1110XXXX\n\t if (i <= 2 && c >> 4 == 0x0E) {\n\t this.charLength = 3;\n\t break;\n\t }\n\t\n\t // 11110XXX\n\t if (i <= 3 && c >> 3 == 0x1E) {\n\t this.charLength = 4;\n\t break;\n\t }\n\t }\n\t this.charReceived = i;\n\t};\n\t\n\tStringDecoder.prototype.end = function(buffer) {\n\t var res = '';\n\t if (buffer && buffer.length)\n\t res = this.write(buffer);\n\t\n\t if (this.charReceived) {\n\t var cr = this.charReceived;\n\t var buf = this.charBuffer;\n\t var enc = this.encoding;\n\t res += buf.slice(0, cr).toString(enc);\n\t }\n\t\n\t return res;\n\t};\n\t\n\tfunction passThroughWrite(buffer) {\n\t return buffer.toString(this.encoding);\n\t}\n\t\n\tfunction utf16DetectIncompleteChar(buffer) {\n\t this.charReceived = buffer.length % 2;\n\t this.charLength = this.charReceived ? 2 : 0;\n\t}\n\t\n\tfunction base64DetectIncompleteChar(buffer) {\n\t this.charReceived = buffer.length % 3;\n\t this.charLength = this.charReceived ? 3 : 0;\n\t}\n\n\n/***/ },\n/* 18 */\n/***/ function(module, exports) {\n\n\t'use strict'\n\t\n\texports.byteLength = byteLength\n\texports.toByteArray = toByteArray\n\texports.fromByteArray = fromByteArray\n\t\n\tvar lookup = []\n\tvar revLookup = []\n\tvar Arr = typeof Uint8Array !== 'undefined' ? Uint8Array : Array\n\t\n\tvar code = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'\n\tfor (var i = 0, len = code.length; i < len; ++i) {\n\t lookup[i] = code[i]\n\t revLookup[code.charCodeAt(i)] = i\n\t}\n\t\n\trevLookup['-'.charCodeAt(0)] = 62\n\trevLookup['_'.charCodeAt(0)] = 63\n\t\n\tfunction placeHoldersCount (b64) {\n\t var len = b64.length\n\t if (len % 4 > 0) {\n\t throw new Error('Invalid string. Length must be a multiple of 4')\n\t }\n\t\n\t // the number of equal signs (place holders)\n\t // if there are two placeholders, than the two characters before it\n\t // represent one byte\n\t // if there is only one, then the three characters before it represent 2 bytes\n\t // this is just a cheap hack to not do indexOf twice\n\t return b64[len - 2] === '=' ? 2 : b64[len - 1] === '=' ? 1 : 0\n\t}\n\t\n\tfunction byteLength (b64) {\n\t // base64 is 4/3 + up to two characters of the original data\n\t return b64.length * 3 / 4 - placeHoldersCount(b64)\n\t}\n\t\n\tfunction toByteArray (b64) {\n\t var i, j, l, tmp, placeHolders, arr\n\t var len = b64.length\n\t placeHolders = placeHoldersCount(b64)\n\t\n\t arr = new Arr(len * 3 / 4 - placeHolders)\n\t\n\t // if there are placeholders, only get up to the last complete 4 chars\n\t l = placeHolders > 0 ? len - 4 : len\n\t\n\t var L = 0\n\t\n\t for (i = 0, j = 0; i < l; i += 4, j += 3) {\n\t tmp = (revLookup[b64.charCodeAt(i)] << 18) | (revLookup[b64.charCodeAt(i + 1)] << 12) | (revLookup[b64.charCodeAt(i + 2)] << 6) | revLookup[b64.charCodeAt(i + 3)]\n\t arr[L++] = (tmp >> 16) & 0xFF\n\t arr[L++] = (tmp >> 8) & 0xFF\n\t arr[L++] = tmp & 0xFF\n\t }\n\t\n\t if (placeHolders === 2) {\n\t tmp = (revLookup[b64.charCodeAt(i)] << 2) | (revLookup[b64.charCodeAt(i + 1)] >> 4)\n\t arr[L++] = tmp & 0xFF\n\t } else if (placeHolders === 1) {\n\t tmp = (revLookup[b64.charCodeAt(i)] << 10) | (revLookup[b64.charCodeAt(i + 1)] << 4) | (revLookup[b64.charCodeAt(i + 2)] >> 2)\n\t arr[L++] = (tmp >> 8) & 0xFF\n\t arr[L++] = tmp & 0xFF\n\t }\n\t\n\t return arr\n\t}\n\t\n\tfunction tripletToBase64 (num) {\n\t return lookup[num >> 18 & 0x3F] + lookup[num >> 12 & 0x3F] + lookup[num >> 6 & 0x3F] + lookup[num & 0x3F]\n\t}\n\t\n\tfunction encodeChunk (uint8, start, end) {\n\t var tmp\n\t var output = []\n\t for (var i = start; i < end; i += 3) {\n\t tmp = (uint8[i] << 16) + (uint8[i + 1] << 8) + (uint8[i + 2])\n\t output.push(tripletToBase64(tmp))\n\t }\n\t return output.join('')\n\t}\n\t\n\tfunction fromByteArray (uint8) {\n\t var tmp\n\t var len = uint8.length\n\t var extraBytes = len % 3 // if we have 1 byte left, pad 2 bytes\n\t var output = ''\n\t var parts = []\n\t var maxChunkLength = 16383 // must be multiple of 3\n\t\n\t // go through the array every three bytes, we'll deal with trailing stuff later\n\t for (var i = 0, len2 = len - extraBytes; i < len2; i += maxChunkLength) {\n\t parts.push(encodeChunk(uint8, i, (i + maxChunkLength) > len2 ? len2 : (i + maxChunkLength)))\n\t }\n\t\n\t // pad the end with zeros, but make sure to not forget the extra bytes\n\t if (extraBytes === 1) {\n\t tmp = uint8[len - 1]\n\t output += lookup[tmp >> 2]\n\t output += lookup[(tmp << 4) & 0x3F]\n\t output += '=='\n\t } else if (extraBytes === 2) {\n\t tmp = (uint8[len - 2] << 8) + (uint8[len - 1])\n\t output += lookup[tmp >> 10]\n\t output += lookup[(tmp >> 4) & 0x3F]\n\t output += lookup[(tmp << 2) & 0x3F]\n\t output += '='\n\t }\n\t\n\t parts.push(output)\n\t\n\t return parts.join('')\n\t}\n\n\n/***/ },\n/* 19 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t/* WEBPACK VAR INJECTION */(function(__dirname) {\"use strict\";\n\tvar __extends = (this && this.__extends) || function (d, b) {\n\t for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];\n\t function __() { this.constructor = d; }\n\t d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n\t};\n\tvar events = __webpack_require__(6);\n\t// Path depends on process. Avoid a circular reference by dynamically including path when we need it.\n\tvar path = null;\n\tvar Item = (function () {\n\t function Item(fun, array) {\n\t this.fun = fun;\n\t this.array = array;\n\t }\n\t Item.prototype.run = function () {\n\t this.fun.apply(null, this.array);\n\t };\n\t return Item;\n\t}());\n\t/**\n\t * Contains a queue of Items for process.nextTick.\n\t * Inspired by node-process: https://github.com/defunctzombie/node-process\n\t */\n\tvar NextTickQueue = (function () {\n\t function NextTickQueue() {\n\t this._queue = [];\n\t this._draining = false;\n\t // Used/assigned by the drainQueue function.\n\t this._currentQueue = null;\n\t this._queueIndex = -1;\n\t }\n\t NextTickQueue.prototype.push = function (item) {\n\t var _this = this;\n\t if (this._queue.push(item) === 1 && !this._draining) {\n\t setTimeout(function () { return _this._drainQueue(); }, 0);\n\t }\n\t };\n\t NextTickQueue.prototype._cleanUpNextTick = function () {\n\t this._draining = false;\n\t if (this._currentQueue && this._currentQueue.length) {\n\t this._queue = this._currentQueue.concat(this._queue);\n\t }\n\t else {\n\t this._queueIndex = -1;\n\t }\n\t if (this._queue.length) {\n\t this._drainQueue();\n\t }\n\t };\n\t NextTickQueue.prototype._drainQueue = function () {\n\t var _this = this;\n\t if (this._draining) {\n\t return;\n\t }\n\t // If an Item throws an unhandled exception, this function will clean things up.\n\t var timeout = setTimeout(function () { return _this._cleanUpNextTick(); });\n\t this._draining = true;\n\t var len = this._queue.length;\n\t while (len) {\n\t this._currentQueue = this._queue;\n\t this._queue = [];\n\t while (++this._queueIndex < len) {\n\t if (this._currentQueue) {\n\t this._currentQueue[this._queueIndex].run();\n\t }\n\t }\n\t this._queueIndex = -1;\n\t len = this._queue.length;\n\t }\n\t this._currentQueue = null;\n\t this._draining = false;\n\t clearTimeout(timeout);\n\t };\n\t return NextTickQueue;\n\t}());\n\t/**\n\t * Partial implementation of Node's `process` module.\n\t * We implement the portions that are relevant for the filesystem.\n\t * @see http://nodejs.org/api/process.html\n\t * @class\n\t */\n\tvar Process = (function (_super) {\n\t __extends(Process, _super);\n\t function Process() {\n\t _super.apply(this, arguments);\n\t this.startTime = Date.now();\n\t this._cwd = '/';\n\t /**\n\t * Returns what platform you are running on.\n\t * @return [String]\n\t */\n\t this.platform = 'browser';\n\t this.argv = [];\n\t this.execArgv = [];\n\t this.stdout = null;\n\t this.stderr = null;\n\t this.stdin = null;\n\t this.domain = null;\n\t this._queue = new NextTickQueue();\n\t this.execPath = __dirname;\n\t this.env = {};\n\t this.exitCode = 0;\n\t this._gid = 1;\n\t this._uid = 1;\n\t this.version = 'v5.0';\n\t this.versions = {\n\t http_parser: '0.0',\n\t node: '5.0',\n\t v8: '0.0',\n\t uv: '0.0',\n\t zlib: '0.0',\n\t ares: '0.0',\n\t icu: '0.0',\n\t modules: '0',\n\t openssl: '0.0'\n\t };\n\t this.config = {\n\t target_defaults: { cflags: [],\n\t default_configuration: 'Release',\n\t defines: [],\n\t include_dirs: [],\n\t libraries: [] },\n\t variables: { clang: 0,\n\t host_arch: 'x32',\n\t node_install_npm: false,\n\t node_install_waf: false,\n\t node_prefix: '',\n\t node_shared_cares: false,\n\t node_shared_http_parser: false,\n\t node_shared_libuv: false,\n\t node_shared_zlib: false,\n\t node_shared_v8: false,\n\t node_use_dtrace: false,\n\t node_use_etw: false,\n\t node_use_openssl: false,\n\t node_shared_openssl: false,\n\t strict_aliasing: false,\n\t target_arch: 'x32',\n\t v8_use_snapshot: false,\n\t v8_no_strict_aliasing: 0,\n\t visibility: '' } };\n\t this.pid = (Math.random() * 1000) | 0;\n\t this.title = 'node';\n\t this.arch = 'x32';\n\t this._mask = 18;\n\t // Undefined in main thread. Worker-only.\n\t this.connected = undefined;\n\t }\n\t /**\n\t * Changes the current working directory.\n\t *\n\t * **Note**: BrowserFS does not validate that the directory actually exists.\n\t *\n\t * @example Usage example\n\t * console.log('Starting directory: ' + process.cwd());\n\t * process.chdir('/tmp');\n\t * console.log('New directory: ' + process.cwd());\n\t * @param [String] dir The directory to change to.\n\t */\n\t Process.prototype.chdir = function (dir) {\n\t // XXX: Circular dependency hack.\n\t if (path === null) {\n\t path = __webpack_require__(14);\n\t }\n\t this._cwd = path.resolve(dir);\n\t };\n\t /**\n\t * Returns the current working directory.\n\t * @example Usage example\n\t * console.log('Current directory: ' + process.cwd());\n\t * @return [String] The current working directory.\n\t */\n\t Process.prototype.cwd = function () {\n\t return this._cwd;\n\t };\n\t /**\n\t * Number of seconds BrowserFS has been running.\n\t * @return [Number]\n\t */\n\t Process.prototype.uptime = function () {\n\t return ((Date.now() - this.startTime) / 1000) | 0;\n\t };\n\t Process.prototype.nextTick = function (fun) {\n\t var args = [];\n\t for (var _i = 1; _i < arguments.length; _i++) {\n\t args[_i - 1] = arguments[_i];\n\t }\n\t this._queue.push(new Item(fun, args));\n\t };\n\t Process.prototype.abort = function () {\n\t this.emit('abort');\n\t };\n\t Process.prototype.exit = function (code) {\n\t this.exitCode = code;\n\t this.emit('exit', [code]);\n\t };\n\t Process.prototype.getgid = function () {\n\t return this._gid;\n\t };\n\t Process.prototype.setgid = function (gid) {\n\t if (typeof gid === 'number') {\n\t this._gid = gid;\n\t }\n\t else {\n\t this._gid = 1;\n\t }\n\t };\n\t Process.prototype.getuid = function () {\n\t return this._uid;\n\t };\n\t Process.prototype.setuid = function (uid) {\n\t if (typeof uid === 'number') {\n\t this._uid = uid;\n\t }\n\t else {\n\t this._uid = 1;\n\t }\n\t };\n\t Process.prototype.kill = function (pid, signal) {\n\t this.emit('kill', [pid, signal]);\n\t };\n\t Process.prototype.memoryUsage = function () {\n\t return { rss: 0, heapTotal: 0, heapUsed: 0 };\n\t };\n\t Process.prototype.umask = function (mask) {\n\t if (mask === void 0) { mask = this._mask; }\n\t var oldMask = this._mask;\n\t this._mask = mask;\n\t this.emit('umask', [mask]);\n\t return oldMask;\n\t };\n\t Process.prototype.hrtime = function () {\n\t var timeinfo;\n\t if (typeof performance !== 'undefined') {\n\t timeinfo = performance.now();\n\t }\n\t else if (Date['now']) {\n\t timeinfo = Date.now();\n\t }\n\t else {\n\t timeinfo = (new Date()).getTime();\n\t }\n\t var secs = (timeinfo / 1000) | 0;\n\t timeinfo -= secs * 1000;\n\t timeinfo = (timeinfo * 1000000) | 0;\n\t return [secs, timeinfo];\n\t };\n\t /**\n\t * [BFS only] Initialize the TTY devices.\n\t */\n\t Process.prototype.initializeTTYs = function () {\n\t // Guard against multiple invocations.\n\t if (this.stdout === null) {\n\t var TTY = __webpack_require__(20);\n\t this.stdout = new TTY();\n\t this.stderr = new TTY();\n\t this.stdin = new TTY();\n\t }\n\t };\n\t /**\n\t * Worker-only function; irrelevant here.\n\t */\n\t Process.prototype.disconnect = function () {\n\t };\n\t return Process;\n\t}(events.EventEmitter));\n\tmodule.exports = Process;\n\t\n\t/* WEBPACK VAR INJECTION */}.call(exports, \"/\"))\n\n/***/ },\n/* 20 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t/* WEBPACK VAR INJECTION */(function(Buffer) {\"use strict\";\n\tvar __extends = (this && this.__extends) || function (d, b) {\n\t for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];\n\t function __() { this.constructor = d; }\n\t d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n\t};\n\tvar stream = __webpack_require__(9);\n\tvar TTY = (function (_super) {\n\t __extends(TTY, _super);\n\t function TTY() {\n\t _super.call(this);\n\t this.isRaw = false;\n\t this.columns = 80;\n\t this.rows = 120;\n\t this.isTTY = true;\n\t this._bufferedWrites = [];\n\t this._waitingForWrites = false;\n\t }\n\t /**\n\t * Toggle raw mode.\n\t */\n\t TTY.prototype.setRawMode = function (mode) {\n\t if (this.isRaw !== mode) {\n\t this.isRaw = mode;\n\t // [BFS] TTY implementations can use this to change their event emitting\n\t // patterns.\n\t this.emit('modeChange');\n\t }\n\t };\n\t /**\n\t * [BFS] Update the number of columns available on the terminal.\n\t */\n\t TTY.prototype.changeColumns = function (columns) {\n\t if (columns !== this.columns) {\n\t this.columns = columns;\n\t // Resize event.\n\t this.emit('resize');\n\t }\n\t };\n\t /**\n\t * [BFS] Update the number of rows available on the terminal.\n\t */\n\t TTY.prototype.changeRows = function (rows) {\n\t if (rows !== this.rows) {\n\t this.rows = rows;\n\t // Resize event.\n\t this.emit('resize');\n\t }\n\t };\n\t /**\n\t * Returns 'true' if the given object is a TTY.\n\t */\n\t TTY.isatty = function (fd) {\n\t return fd && fd instanceof TTY;\n\t };\n\t TTY.prototype._write = function (chunk, encoding, cb) {\n\t var error;\n\t try {\n\t var data;\n\t if (typeof (chunk) === 'string') {\n\t data = new Buffer(chunk, encoding);\n\t }\n\t else {\n\t data = chunk;\n\t }\n\t this._bufferedWrites.push(data);\n\t if (this._waitingForWrites) {\n\t this._read(1024);\n\t }\n\t }\n\t catch (e) {\n\t error = e;\n\t }\n\t finally {\n\t cb(error);\n\t }\n\t };\n\t TTY.prototype._read = function (size) {\n\t // Size is advisory -- we can ignore it.\n\t if (this._bufferedWrites.length === 0) {\n\t this._waitingForWrites = true;\n\t }\n\t else {\n\t while (this._bufferedWrites.length > 0) {\n\t this._waitingForWrites = this.push(this._bufferedWrites.shift());\n\t if (!this._waitingForWrites) {\n\t break;\n\t }\n\t }\n\t }\n\t };\n\t return TTY;\n\t}(stream.Duplex));\n\tmodule.exports = TTY;\n\t\n\t/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(7)))\n\n/***/ },\n/* 21 */\n/***/ function(module, exports) {\n\n\texports.read = function (buffer, offset, isLE, mLen, nBytes) {\n\t var e, m\n\t var eLen = nBytes * 8 - mLen - 1\n\t var eMax = (1 << eLen) - 1\n\t var eBias = eMax >> 1\n\t var nBits = -7\n\t var i = isLE ? (nBytes - 1) : 0\n\t var d = isLE ? -1 : 1\n\t var s = buffer[offset + i]\n\t\n\t i += d\n\t\n\t e = s & ((1 << (-nBits)) - 1)\n\t s >>= (-nBits)\n\t nBits += eLen\n\t for (; nBits > 0; e = e * 256 + buffer[offset + i], i += d, nBits -= 8) {}\n\t\n\t m = e & ((1 << (-nBits)) - 1)\n\t e >>= (-nBits)\n\t nBits += mLen\n\t for (; nBits > 0; m = m * 256 + buffer[offset + i], i += d, nBits -= 8) {}\n\t\n\t if (e === 0) {\n\t e = 1 - eBias\n\t } else if (e === eMax) {\n\t return m ? NaN : ((s ? -1 : 1) * Infinity)\n\t } else {\n\t m = m + Math.pow(2, mLen)\n\t e = e - eBias\n\t }\n\t return (s ? -1 : 1) * m * Math.pow(2, e - mLen)\n\t}\n\t\n\texports.write = function (buffer, value, offset, isLE, mLen, nBytes) {\n\t var e, m, c\n\t var eLen = nBytes * 8 - mLen - 1\n\t var eMax = (1 << eLen) - 1\n\t var eBias = eMax >> 1\n\t var rt = (mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0)\n\t var i = isLE ? 0 : (nBytes - 1)\n\t var d = isLE ? 1 : -1\n\t var s = value < 0 || (value === 0 && 1 / value < 0) ? 1 : 0\n\t\n\t value = Math.abs(value)\n\t\n\t if (isNaN(value) || value === Infinity) {\n\t m = isNaN(value) ? 1 : 0\n\t e = eMax\n\t } else {\n\t e = Math.floor(Math.log(value) / Math.LN2)\n\t if (value * (c = Math.pow(2, -e)) < 1) {\n\t e--\n\t c *= 2\n\t }\n\t if (e + eBias >= 1) {\n\t value += rt / c\n\t } else {\n\t value += rt * Math.pow(2, 1 - eBias)\n\t }\n\t if (value * c >= 2) {\n\t e++\n\t c /= 2\n\t }\n\t\n\t if (e + eBias >= eMax) {\n\t m = 0\n\t e = eMax\n\t } else if (e + eBias >= 1) {\n\t m = (value * c - 1) * Math.pow(2, mLen)\n\t e = e + eBias\n\t } else {\n\t m = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen)\n\t e = 0\n\t }\n\t }\n\t\n\t for (; mLen >= 8; buffer[offset + i] = m & 0xff, i += d, m /= 256, mLen -= 8) {}\n\t\n\t e = (e << mLen) | m\n\t eLen += mLen\n\t for (; eLen > 0; buffer[offset + i] = e & 0xff, i += d, e /= 256, eLen -= 8) {}\n\t\n\t buffer[offset + i - d] |= s * 128\n\t}\n\n\n/***/ },\n/* 22 */\n/***/ function(module, exports) {\n\n\tvar toString = {}.toString;\n\t\n\tmodule.exports = Array.isArray || function (arr) {\n\t return toString.call(arr) == '[object Array]';\n\t};\n\n\n/***/ },\n/* 23 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\t\n\tvar zlib_inflate = __webpack_require__(30);\n\tvar utils = __webpack_require__(8);\n\tvar strings = __webpack_require__(24);\n\tvar c = __webpack_require__(26);\n\tvar msg = __webpack_require__(32);\n\tvar ZStream = __webpack_require__(33);\n\tvar GZheader = __webpack_require__(28);\n\t\n\tvar toString = Object.prototype.toString;\n\t\n\t/**\n\t * class Inflate\n\t *\n\t * Generic JS-style wrapper for zlib calls. If you don't need\n\t * streaming behaviour - use more simple functions: [[inflate]]\n\t * and [[inflateRaw]].\n\t **/\n\t\n\t/* internal\n\t * inflate.chunks -> Array\n\t *\n\t * Chunks of output data, if [[Inflate#onData]] not overriden.\n\t **/\n\t\n\t/**\n\t * Inflate.result -> Uint8Array|Array|String\n\t *\n\t * Uncompressed result, generated by default [[Inflate#onData]]\n\t * and [[Inflate#onEnd]] handlers. Filled after you push last chunk\n\t * (call [[Inflate#push]] with `Z_FINISH` / `true` param) or if you\n\t * push a chunk with explicit flush (call [[Inflate#push]] with\n\t * `Z_SYNC_FLUSH` param).\n\t **/\n\t\n\t/**\n\t * Inflate.err -> Number\n\t *\n\t * Error code after inflate finished. 0 (Z_OK) on success.\n\t * Should be checked if broken data possible.\n\t **/\n\t\n\t/**\n\t * Inflate.msg -> String\n\t *\n\t * Error message, if [[Inflate.err]] != 0\n\t **/\n\t\n\t\n\t/**\n\t * new Inflate(options)\n\t * - options (Object): zlib inflate options.\n\t *\n\t * Creates new inflator instance with specified params. Throws exception\n\t * on bad params. Supported options:\n\t *\n\t * - `windowBits`\n\t * - `dictionary`\n\t *\n\t * [http://zlib.net/manual.html#Advanced](http://zlib.net/manual.html#Advanced)\n\t * for more information on these.\n\t *\n\t * Additional options, for internal needs:\n\t *\n\t * - `chunkSize` - size of generated data chunks (16K by default)\n\t * - `raw` (Boolean) - do raw inflate\n\t * - `to` (String) - if equal to 'string', then result will be converted\n\t * from utf8 to utf16 (javascript) string. When string output requested,\n\t * chunk length can differ from `chunkSize`, depending on content.\n\t *\n\t * By default, when no options set, autodetect deflate/gzip data format via\n\t * wrapper header.\n\t *\n\t * ##### Example:\n\t *\n\t * ```javascript\n\t * var pako = require('pako')\n\t * , chunk1 = Uint8Array([1,2,3,4,5,6,7,8,9])\n\t * , chunk2 = Uint8Array([10,11,12,13,14,15,16,17,18,19]);\n\t *\n\t * var inflate = new pako.Inflate({ level: 3});\n\t *\n\t * inflate.push(chunk1, false);\n\t * inflate.push(chunk2, true); // true -> last chunk\n\t *\n\t * if (inflate.err) { throw new Error(inflate.err); }\n\t *\n\t * console.log(inflate.result);\n\t * ```\n\t **/\n\tfunction Inflate(options) {\n\t if (!(this instanceof Inflate)) return new Inflate(options);\n\t\n\t this.options = utils.assign({\n\t chunkSize: 16384,\n\t windowBits: 0,\n\t to: ''\n\t }, options || {});\n\t\n\t var opt = this.options;\n\t\n\t // Force window size for `raw` data, if not set directly,\n\t // because we have no header for autodetect.\n\t if (opt.raw && (opt.windowBits >= 0) && (opt.windowBits < 16)) {\n\t opt.windowBits = -opt.windowBits;\n\t if (opt.windowBits === 0) { opt.windowBits = -15; }\n\t }\n\t\n\t // If `windowBits` not defined (and mode not raw) - set autodetect flag for gzip/deflate\n\t if ((opt.windowBits >= 0) && (opt.windowBits < 16) &&\n\t !(options && options.windowBits)) {\n\t opt.windowBits += 32;\n\t }\n\t\n\t // Gzip header has no info about windows size, we can do autodetect only\n\t // for deflate. So, if window size not set, force it to max when gzip possible\n\t if ((opt.windowBits > 15) && (opt.windowBits < 48)) {\n\t // bit 3 (16) -> gzipped data\n\t // bit 4 (32) -> autodetect gzip/deflate\n\t if ((opt.windowBits & 15) === 0) {\n\t opt.windowBits |= 15;\n\t }\n\t }\n\t\n\t this.err = 0; // error code, if happens (0 = Z_OK)\n\t this.msg = ''; // error message\n\t this.ended = false; // used to avoid multiple onEnd() calls\n\t this.chunks = []; // chunks of compressed data\n\t\n\t this.strm = new ZStream();\n\t this.strm.avail_out = 0;\n\t\n\t var status = zlib_inflate.inflateInit2(\n\t this.strm,\n\t opt.windowBits\n\t );\n\t\n\t if (status !== c.Z_OK) {\n\t throw new Error(msg[status]);\n\t }\n\t\n\t this.header = new GZheader();\n\t\n\t zlib_inflate.inflateGetHeader(this.strm, this.header);\n\t}\n\t\n\t/**\n\t * Inflate#push(data[, mode]) -> Boolean\n\t * - data (Uint8Array|Array|ArrayBuffer|String): input data\n\t * - mode (Number|Boolean): 0..6 for corresponding Z_NO_FLUSH..Z_TREE modes.\n\t * See constants. Skipped or `false` means Z_NO_FLUSH, `true` meansh Z_FINISH.\n\t *\n\t * Sends input data to inflate pipe, generating [[Inflate#onData]] calls with\n\t * new output chunks. Returns `true` on success. The last data block must have\n\t * mode Z_FINISH (or `true`). That will flush internal pending buffers and call\n\t * [[Inflate#onEnd]]. For interim explicit flushes (without ending the stream) you\n\t * can use mode Z_SYNC_FLUSH, keeping the decompression context.\n\t *\n\t * On fail call [[Inflate#onEnd]] with error code and return false.\n\t *\n\t * We strongly recommend to use `Uint8Array` on input for best speed (output\n\t * format is detected automatically). Also, don't skip last param and always\n\t * use the same type in your code (boolean or number). That will improve JS speed.\n\t *\n\t * For regular `Array`-s make sure all elements are [0..255].\n\t *\n\t * ##### Example\n\t *\n\t * ```javascript\n\t * push(chunk, false); // push one of data chunks\n\t * ...\n\t * push(chunk, true); // push last chunk\n\t * ```\n\t **/\n\tInflate.prototype.push = function (data, mode) {\n\t var strm = this.strm;\n\t var chunkSize = this.options.chunkSize;\n\t var dictionary = this.options.dictionary;\n\t var status, _mode;\n\t var next_out_utf8, tail, utf8str;\n\t var dict;\n\t\n\t // Flag to properly process Z_BUF_ERROR on testing inflate call\n\t // when we check that all output data was flushed.\n\t var allowBufError = false;\n\t\n\t if (this.ended) { return false; }\n\t _mode = (mode === ~~mode) ? mode : ((mode === true) ? c.Z_FINISH : c.Z_NO_FLUSH);\n\t\n\t // Convert data if needed\n\t if (typeof data === 'string') {\n\t // Only binary strings can be decompressed on practice\n\t strm.input = strings.binstring2buf(data);\n\t } else if (toString.call(data) === '[object ArrayBuffer]') {\n\t strm.input = new Uint8Array(data);\n\t } else {\n\t strm.input = data;\n\t }\n\t\n\t strm.next_in = 0;\n\t strm.avail_in = strm.input.length;\n\t\n\t do {\n\t if (strm.avail_out === 0) {\n\t strm.output = new utils.Buf8(chunkSize);\n\t strm.next_out = 0;\n\t strm.avail_out = chunkSize;\n\t }\n\t\n\t status = zlib_inflate.inflate(strm, c.Z_NO_FLUSH); /* no bad return value */\n\t\n\t if (status === c.Z_NEED_DICT && dictionary) {\n\t // Convert data if needed\n\t if (typeof dictionary === 'string') {\n\t dict = strings.string2buf(dictionary);\n\t } else if (toString.call(dictionary) === '[object ArrayBuffer]') {\n\t dict = new Uint8Array(dictionary);\n\t } else {\n\t dict = dictionary;\n\t }\n\t\n\t status = zlib_inflate.inflateSetDictionary(this.strm, dict);\n\t\n\t }\n\t\n\t if (status === c.Z_BUF_ERROR && allowBufError === true) {\n\t status = c.Z_OK;\n\t allowBufError = false;\n\t }\n\t\n\t if (status !== c.Z_STREAM_END && status !== c.Z_OK) {\n\t this.onEnd(status);\n\t this.ended = true;\n\t return false;\n\t }\n\t\n\t if (strm.next_out) {\n\t if (strm.avail_out === 0 || status === c.Z_STREAM_END || (strm.avail_in === 0 && (_mode === c.Z_FINISH || _mode === c.Z_SYNC_FLUSH))) {\n\t\n\t if (this.options.to === 'string') {\n\t\n\t next_out_utf8 = strings.utf8border(strm.output, strm.next_out);\n\t\n\t tail = strm.next_out - next_out_utf8;\n\t utf8str = strings.buf2string(strm.output, next_out_utf8);\n\t\n\t // move tail\n\t strm.next_out = tail;\n\t strm.avail_out = chunkSize - tail;\n\t if (tail) { utils.arraySet(strm.output, strm.output, next_out_utf8, tail, 0); }\n\t\n\t this.onData(utf8str);\n\t\n\t } else {\n\t this.onData(utils.shrinkBuf(strm.output, strm.next_out));\n\t }\n\t }\n\t }\n\t\n\t // When no more input data, we should check that internal inflate buffers\n\t // are flushed. The only way to do it when avail_out = 0 - run one more\n\t // inflate pass. But if output data not exists, inflate return Z_BUF_ERROR.\n\t // Here we set flag to process this error properly.\n\t //\n\t // NOTE. Deflate does not return error in this case and does not needs such\n\t // logic.\n\t if (strm.avail_in === 0 && strm.avail_out === 0) {\n\t allowBufError = true;\n\t }\n\t\n\t } while ((strm.avail_in > 0 || strm.avail_out === 0) && status !== c.Z_STREAM_END);\n\t\n\t if (status === c.Z_STREAM_END) {\n\t _mode = c.Z_FINISH;\n\t }\n\t\n\t // Finalize on the last chunk.\n\t if (_mode === c.Z_FINISH) {\n\t status = zlib_inflate.inflateEnd(this.strm);\n\t this.onEnd(status);\n\t this.ended = true;\n\t return status === c.Z_OK;\n\t }\n\t\n\t // callback interim results if Z_SYNC_FLUSH.\n\t if (_mode === c.Z_SYNC_FLUSH) {\n\t this.onEnd(c.Z_OK);\n\t strm.avail_out = 0;\n\t return true;\n\t }\n\t\n\t return true;\n\t};\n\t\n\t\n\t/**\n\t * Inflate#onData(chunk) -> Void\n\t * - chunk (Uint8Array|Array|String): ouput data. Type of array depends\n\t * on js engine support. When string output requested, each chunk\n\t * will be string.\n\t *\n\t * By default, stores data blocks in `chunks[]` property and glue\n\t * those in `onEnd`. Override this handler, if you need another behaviour.\n\t **/\n\tInflate.prototype.onData = function (chunk) {\n\t this.chunks.push(chunk);\n\t};\n\t\n\t\n\t/**\n\t * Inflate#onEnd(status) -> Void\n\t * - status (Number): inflate status. 0 (Z_OK) on success,\n\t * other if not.\n\t *\n\t * Called either after you tell inflate that the input stream is\n\t * complete (Z_FINISH) or should be flushed (Z_SYNC_FLUSH)\n\t * or if an error happened. By default - join collected chunks,\n\t * free memory and fill `results` / `err` properties.\n\t **/\n\tInflate.prototype.onEnd = function (status) {\n\t // On success - join\n\t if (status === c.Z_OK) {\n\t if (this.options.to === 'string') {\n\t // Glue & convert here, until we teach pako to send\n\t // utf8 alligned strings to onData\n\t this.result = this.chunks.join('');\n\t } else {\n\t this.result = utils.flattenChunks(this.chunks);\n\t }\n\t }\n\t this.chunks = [];\n\t this.err = status;\n\t this.msg = this.strm.msg;\n\t};\n\t\n\t\n\t/**\n\t * inflate(data[, options]) -> Uint8Array|Array|String\n\t * - data (Uint8Array|Array|String): input data to decompress.\n\t * - options (Object): zlib inflate options.\n\t *\n\t * Decompress `data` with inflate/ungzip and `options`. Autodetect\n\t * format via wrapper header by default. That's why we don't provide\n\t * separate `ungzip` method.\n\t *\n\t * Supported options are:\n\t *\n\t * - windowBits\n\t *\n\t * [http://zlib.net/manual.html#Advanced](http://zlib.net/manual.html#Advanced)\n\t * for more information.\n\t *\n\t * Sugar (options):\n\t *\n\t * - `raw` (Boolean) - say that we work with raw stream, if you don't wish to specify\n\t * negative windowBits implicitly.\n\t * - `to` (String) - if equal to 'string', then result will be converted\n\t * from utf8 to utf16 (javascript) string. When string output requested,\n\t * chunk length can differ from `chunkSize`, depending on content.\n\t *\n\t *\n\t * ##### Example:\n\t *\n\t * ```javascript\n\t * var pako = require('pako')\n\t * , input = pako.deflate([1,2,3,4,5,6,7,8,9])\n\t * , output;\n\t *\n\t * try {\n\t * output = pako.inflate(input);\n\t * } catch (err)\n\t * console.log(err);\n\t * }\n\t * ```\n\t **/\n\tfunction inflate(input, options) {\n\t var inflator = new Inflate(options);\n\t\n\t inflator.push(input, true);\n\t\n\t // That will never happens, if you don't cheat with options :)\n\t if (inflator.err) { throw inflator.msg || msg[inflator.err]; }\n\t\n\t return inflator.result;\n\t}\n\t\n\t\n\t/**\n\t * inflateRaw(data[, options]) -> Uint8Array|Array|String\n\t * - data (Uint8Array|Array|String): input data to decompress.\n\t * - options (Object): zlib inflate options.\n\t *\n\t * The same as [[inflate]], but creates raw data, without wrapper\n\t * (header and adler32 crc).\n\t **/\n\tfunction inflateRaw(input, options) {\n\t options = options || {};\n\t options.raw = true;\n\t return inflate(input, options);\n\t}\n\t\n\t\n\t/**\n\t * ungzip(data[, options]) -> Uint8Array|Array|String\n\t * - data (Uint8Array|Array|String): input data to decompress.\n\t * - options (Object): zlib inflate options.\n\t *\n\t * Just shortcut to [[inflate]], because it autodetects format\n\t * by header.content. Done for convenience.\n\t **/\n\t\n\t\n\texports.Inflate = Inflate;\n\texports.inflate = inflate;\n\texports.inflateRaw = inflateRaw;\n\texports.ungzip = inflate;\n\n\n/***/ },\n/* 24 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t// String encode/decode helpers\n\t'use strict';\n\t\n\t\n\tvar utils = __webpack_require__(8);\n\t\n\t\n\t// Quick check if we can use fast array to bin string conversion\n\t//\n\t// - apply(Array) can fail on Android 2.2\n\t// - apply(Uint8Array) can fail on iOS 5.1 Safary\n\t//\n\tvar STR_APPLY_OK = true;\n\tvar STR_APPLY_UIA_OK = true;\n\t\n\ttry { String.fromCharCode.apply(null, [ 0 ]); } catch (__) { STR_APPLY_OK = false; }\n\ttry { String.fromCharCode.apply(null, new Uint8Array(1)); } catch (__) { STR_APPLY_UIA_OK = false; }\n\t\n\t\n\t// Table with utf8 lengths (calculated by first byte of sequence)\n\t// Note, that 5 & 6-byte values and some 4-byte values can not be represented in JS,\n\t// because max possible codepoint is 0x10ffff\n\tvar _utf8len = new utils.Buf8(256);\n\tfor (var q = 0; q < 256; q++) {\n\t _utf8len[q] = (q >= 252 ? 6 : q >= 248 ? 5 : q >= 240 ? 4 : q >= 224 ? 3 : q >= 192 ? 2 : 1);\n\t}\n\t_utf8len[254] = _utf8len[254] = 1; // Invalid sequence start\n\t\n\t\n\t// convert string to array (typed, when possible)\n\texports.string2buf = function (str) {\n\t var buf, c, c2, m_pos, i, str_len = str.length, buf_len = 0;\n\t\n\t // count binary size\n\t for (m_pos = 0; m_pos < str_len; m_pos++) {\n\t c = str.charCodeAt(m_pos);\n\t if ((c & 0xfc00) === 0xd800 && (m_pos + 1 < str_len)) {\n\t c2 = str.charCodeAt(m_pos + 1);\n\t if ((c2 & 0xfc00) === 0xdc00) {\n\t c = 0x10000 + ((c - 0xd800) << 10) + (c2 - 0xdc00);\n\t m_pos++;\n\t }\n\t }\n\t buf_len += c < 0x80 ? 1 : c < 0x800 ? 2 : c < 0x10000 ? 3 : 4;\n\t }\n\t\n\t // allocate buffer\n\t buf = new utils.Buf8(buf_len);\n\t\n\t // convert\n\t for (i = 0, m_pos = 0; i < buf_len; m_pos++) {\n\t c = str.charCodeAt(m_pos);\n\t if ((c & 0xfc00) === 0xd800 && (m_pos + 1 < str_len)) {\n\t c2 = str.charCodeAt(m_pos + 1);\n\t if ((c2 & 0xfc00) === 0xdc00) {\n\t c = 0x10000 + ((c - 0xd800) << 10) + (c2 - 0xdc00);\n\t m_pos++;\n\t }\n\t }\n\t if (c < 0x80) {\n\t /* one byte */\n\t buf[i++] = c;\n\t } else if (c < 0x800) {\n\t /* two bytes */\n\t buf[i++] = 0xC0 | (c >>> 6);\n\t buf[i++] = 0x80 | (c & 0x3f);\n\t } else if (c < 0x10000) {\n\t /* three bytes */\n\t buf[i++] = 0xE0 | (c >>> 12);\n\t buf[i++] = 0x80 | (c >>> 6 & 0x3f);\n\t buf[i++] = 0x80 | (c & 0x3f);\n\t } else {\n\t /* four bytes */\n\t buf[i++] = 0xf0 | (c >>> 18);\n\t buf[i++] = 0x80 | (c >>> 12 & 0x3f);\n\t buf[i++] = 0x80 | (c >>> 6 & 0x3f);\n\t buf[i++] = 0x80 | (c & 0x3f);\n\t }\n\t }\n\t\n\t return buf;\n\t};\n\t\n\t// Helper (used in 2 places)\n\tfunction buf2binstring(buf, len) {\n\t // use fallback for big arrays to avoid stack overflow\n\t if (len < 65537) {\n\t if ((buf.subarray && STR_APPLY_UIA_OK) || (!buf.subarray && STR_APPLY_OK)) {\n\t return String.fromCharCode.apply(null, utils.shrinkBuf(buf, len));\n\t }\n\t }\n\t\n\t var result = '';\n\t for (var i = 0; i < len; i++) {\n\t result += String.fromCharCode(buf[i]);\n\t }\n\t return result;\n\t}\n\t\n\t\n\t// Convert byte array to binary string\n\texports.buf2binstring = function (buf) {\n\t return buf2binstring(buf, buf.length);\n\t};\n\t\n\t\n\t// Convert binary string (typed, when possible)\n\texports.binstring2buf = function (str) {\n\t var buf = new utils.Buf8(str.length);\n\t for (var i = 0, len = buf.length; i < len; i++) {\n\t buf[i] = str.charCodeAt(i);\n\t }\n\t return buf;\n\t};\n\t\n\t\n\t// convert array to string\n\texports.buf2string = function (buf, max) {\n\t var i, out, c, c_len;\n\t var len = max || buf.length;\n\t\n\t // Reserve max possible length (2 words per char)\n\t // NB: by unknown reasons, Array is significantly faster for\n\t // String.fromCharCode.apply than Uint16Array.\n\t var utf16buf = new Array(len * 2);\n\t\n\t for (out = 0, i = 0; i < len;) {\n\t c = buf[i++];\n\t // quick process ascii\n\t if (c < 0x80) { utf16buf[out++] = c; continue; }\n\t\n\t c_len = _utf8len[c];\n\t // skip 5 & 6 byte codes\n\t if (c_len > 4) { utf16buf[out++] = 0xfffd; i += c_len - 1; continue; }\n\t\n\t // apply mask on first byte\n\t c &= c_len === 2 ? 0x1f : c_len === 3 ? 0x0f : 0x07;\n\t // join the rest\n\t while (c_len > 1 && i < len) {\n\t c = (c << 6) | (buf[i++] & 0x3f);\n\t c_len--;\n\t }\n\t\n\t // terminated by end of string?\n\t if (c_len > 1) { utf16buf[out++] = 0xfffd; continue; }\n\t\n\t if (c < 0x10000) {\n\t utf16buf[out++] = c;\n\t } else {\n\t c -= 0x10000;\n\t utf16buf[out++] = 0xd800 | ((c >> 10) & 0x3ff);\n\t utf16buf[out++] = 0xdc00 | (c & 0x3ff);\n\t }\n\t }\n\t\n\t return buf2binstring(utf16buf, out);\n\t};\n\t\n\t\n\t// Calculate max possible position in utf8 buffer,\n\t// that will not break sequence. If that's not possible\n\t// - (very small limits) return max size as is.\n\t//\n\t// buf[] - utf8 bytes array\n\t// max - length limit (mandatory);\n\texports.utf8border = function (buf, max) {\n\t var pos;\n\t\n\t max = max || buf.length;\n\t if (max > buf.length) { max = buf.length; }\n\t\n\t // go back from last position, until start of sequence found\n\t pos = max - 1;\n\t while (pos >= 0 && (buf[pos] & 0xC0) === 0x80) { pos--; }\n\t\n\t // Fuckup - very small and broken sequence,\n\t // return max, because we should return something anyway.\n\t if (pos < 0) { return max; }\n\t\n\t // If we came to start of buffer - that means vuffer is too small,\n\t // return max too.\n\t if (pos === 0) { return max; }\n\t\n\t return (pos + _utf8len[buf[pos]] > max) ? pos : max;\n\t};\n\n\n/***/ },\n/* 25 */\n/***/ function(module, exports) {\n\n\t'use strict';\n\t\n\t// Note: adler32 takes 12% for level 0 and 2% for level 6.\n\t// It doesn't worth to make additional optimizationa as in original.\n\t// Small size is preferable.\n\t\n\tfunction adler32(adler, buf, len, pos) {\n\t var s1 = (adler & 0xffff) |0,\n\t s2 = ((adler >>> 16) & 0xffff) |0,\n\t n = 0;\n\t\n\t while (len !== 0) {\n\t // Set limit ~ twice less than 5552, to keep\n\t // s2 in 31-bits, because we force signed ints.\n\t // in other case %= will fail.\n\t n = len > 2000 ? 2000 : len;\n\t len -= n;\n\t\n\t do {\n\t s1 = (s1 + buf[pos++]) |0;\n\t s2 = (s2 + s1) |0;\n\t } while (--n);\n\t\n\t s1 %= 65521;\n\t s2 %= 65521;\n\t }\n\t\n\t return (s1 | (s2 << 16)) |0;\n\t}\n\t\n\t\n\tmodule.exports = adler32;\n\n\n/***/ },\n/* 26 */\n/***/ function(module, exports) {\n\n\t'use strict';\n\t\n\t\n\tmodule.exports = {\n\t\n\t /* Allowed flush values; see deflate() and inflate() below for details */\n\t Z_NO_FLUSH: 0,\n\t Z_PARTIAL_FLUSH: 1,\n\t Z_SYNC_FLUSH: 2,\n\t Z_FULL_FLUSH: 3,\n\t Z_FINISH: 4,\n\t Z_BLOCK: 5,\n\t Z_TREES: 6,\n\t\n\t /* Return codes for the compression/decompression functions. Negative values\n\t * are errors, positive values are used for special but normal events.\n\t */\n\t Z_OK: 0,\n\t Z_STREAM_END: 1,\n\t Z_NEED_DICT: 2,\n\t Z_ERRNO: -1,\n\t Z_STREAM_ERROR: -2,\n\t Z_DATA_ERROR: -3,\n\t //Z_MEM_ERROR: -4,\n\t Z_BUF_ERROR: -5,\n\t //Z_VERSION_ERROR: -6,\n\t\n\t /* compression levels */\n\t Z_NO_COMPRESSION: 0,\n\t Z_BEST_SPEED: 1,\n\t Z_BEST_COMPRESSION: 9,\n\t Z_DEFAULT_COMPRESSION: -1,\n\t\n\t\n\t Z_FILTERED: 1,\n\t Z_HUFFMAN_ONLY: 2,\n\t Z_RLE: 3,\n\t Z_FIXED: 4,\n\t Z_DEFAULT_STRATEGY: 0,\n\t\n\t /* Possible values of the data_type field (though see inflate()) */\n\t Z_BINARY: 0,\n\t Z_TEXT: 1,\n\t //Z_ASCII: 1, // = Z_TEXT (deprecated)\n\t Z_UNKNOWN: 2,\n\t\n\t /* The deflate compression method */\n\t Z_DEFLATED: 8\n\t //Z_NULL: null // Use -1 or null inline, depending on var type\n\t};\n\n\n/***/ },\n/* 27 */\n/***/ function(module, exports) {\n\n\t'use strict';\n\t\n\t// Note: we can't get significant speed boost here.\n\t// So write code to minimize size - no pregenerated tables\n\t// and array tools dependencies.\n\t\n\t\n\t// Use ordinary array, since untyped makes no boost here\n\tfunction makeTable() {\n\t var c, table = [];\n\t\n\t for (var n = 0; n < 256; n++) {\n\t c = n;\n\t for (var k = 0; k < 8; k++) {\n\t c = ((c & 1) ? (0xEDB88320 ^ (c >>> 1)) : (c >>> 1));\n\t }\n\t table[n] = c;\n\t }\n\t\n\t return table;\n\t}\n\t\n\t// Create table on load. Just 255 signed longs. Not a problem.\n\tvar crcTable = makeTable();\n\t\n\t\n\tfunction crc32(crc, buf, len, pos) {\n\t var t = crcTable,\n\t end = pos + len;\n\t\n\t crc ^= -1;\n\t\n\t for (var i = pos; i < end; i++) {\n\t crc = (crc >>> 8) ^ t[(crc ^ buf[i]) & 0xFF];\n\t }\n\t\n\t return (crc ^ (-1)); // >>> 0;\n\t}\n\t\n\t\n\tmodule.exports = crc32;\n\n\n/***/ },\n/* 28 */\n/***/ function(module, exports) {\n\n\t'use strict';\n\t\n\t\n\tfunction GZheader() {\n\t /* true if compressed data believed to be text */\n\t this.text = 0;\n\t /* modification time */\n\t this.time = 0;\n\t /* extra flags (not used when writing a gzip file) */\n\t this.xflags = 0;\n\t /* operating system */\n\t this.os = 0;\n\t /* pointer to extra field or Z_NULL if none */\n\t this.extra = null;\n\t /* extra field length (valid if extra != Z_NULL) */\n\t this.extra_len = 0; // Actually, we don't need it in JS,\n\t // but leave for few code modifications\n\t\n\t //\n\t // Setup limits is not necessary because in js we should not preallocate memory\n\t // for inflate use constant limit in 65536 bytes\n\t //\n\t\n\t /* space at extra (only when reading header) */\n\t // this.extra_max = 0;\n\t /* pointer to zero-terminated file name or Z_NULL */\n\t this.name = '';\n\t /* space at name (only when reading header) */\n\t // this.name_max = 0;\n\t /* pointer to zero-terminated comment or Z_NULL */\n\t this.comment = '';\n\t /* space at comment (only when reading header) */\n\t // this.comm_max = 0;\n\t /* true if there was or will be a header crc */\n\t this.hcrc = 0;\n\t /* true when done reading gzip header (not used when writing a gzip file) */\n\t this.done = false;\n\t}\n\t\n\tmodule.exports = GZheader;\n\n\n/***/ },\n/* 29 */\n/***/ function(module, exports) {\n\n\t'use strict';\n\t\n\t// See state defs from inflate.js\n\tvar BAD = 30; /* got a data error -- remain here until reset */\n\tvar TYPE = 12; /* i: waiting for type bits, including last-flag bit */\n\t\n\t/*\n\t Decode literal, length, and distance codes and write out the resulting\n\t literal and match bytes until either not enough input or output is\n\t available, an end-of-block is encountered, or a data error is encountered.\n\t When large enough input and output buffers are supplied to inflate(), for\n\t example, a 16K input buffer and a 64K output buffer, more than 95% of the\n\t inflate execution time is spent in this routine.\n\t\n\t Entry assumptions:\n\t\n\t state.mode === LEN\n\t strm.avail_in >= 6\n\t strm.avail_out >= 258\n\t start >= strm.avail_out\n\t state.bits < 8\n\t\n\t On return, state.mode is one of:\n\t\n\t LEN -- ran out of enough output space or enough available input\n\t TYPE -- reached end of block code, inflate() to interpret next block\n\t BAD -- error in block data\n\t\n\t Notes:\n\t\n\t - The maximum input bits used by a length/distance pair is 15 bits for the\n\t length code, 5 bits for the length extra, 15 bits for the distance code,\n\t and 13 bits for the distance extra. This totals 48 bits, or six bytes.\n\t Therefore if strm.avail_in >= 6, then there is enough input to avoid\n\t checking for available input while decoding.\n\t\n\t - The maximum bytes that a single length/distance pair can output is 258\n\t bytes, which is the maximum length that can be coded. inflate_fast()\n\t requires strm.avail_out >= 258 for each loop to avoid checking for\n\t output space.\n\t */\n\tmodule.exports = function inflate_fast(strm, start) {\n\t var state;\n\t var _in; /* local strm.input */\n\t var last; /* have enough input while in < last */\n\t var _out; /* local strm.output */\n\t var beg; /* inflate()'s initial strm.output */\n\t var end; /* while out < end, enough space available */\n\t//#ifdef INFLATE_STRICT\n\t var dmax; /* maximum distance from zlib header */\n\t//#endif\n\t var wsize; /* window size or zero if not using window */\n\t var whave; /* valid bytes in the window */\n\t var wnext; /* window write index */\n\t // Use `s_window` instead `window`, avoid conflict with instrumentation tools\n\t var s_window; /* allocated sliding window, if wsize != 0 */\n\t var hold; /* local strm.hold */\n\t var bits; /* local strm.bits */\n\t var lcode; /* local strm.lencode */\n\t var dcode; /* local strm.distcode */\n\t var lmask; /* mask for first level of length codes */\n\t var dmask; /* mask for first level of distance codes */\n\t var here; /* retrieved table entry */\n\t var op; /* code bits, operation, extra bits, or */\n\t /* window position, window bytes to copy */\n\t var len; /* match length, unused bytes */\n\t var dist; /* match distance */\n\t var from; /* where to copy match from */\n\t var from_source;\n\t\n\t\n\t var input, output; // JS specific, because we have no pointers\n\t\n\t /* copy state to local variables */\n\t state = strm.state;\n\t //here = state.here;\n\t _in = strm.next_in;\n\t input = strm.input;\n\t last = _in + (strm.avail_in - 5);\n\t _out = strm.next_out;\n\t output = strm.output;\n\t beg = _out - (start - strm.avail_out);\n\t end = _out + (strm.avail_out - 257);\n\t//#ifdef INFLATE_STRICT\n\t dmax = state.dmax;\n\t//#endif\n\t wsize = state.wsize;\n\t whave = state.whave;\n\t wnext = state.wnext;\n\t s_window = state.window;\n\t hold = state.hold;\n\t bits = state.bits;\n\t lcode = state.lencode;\n\t dcode = state.distcode;\n\t lmask = (1 << state.lenbits) - 1;\n\t dmask = (1 << state.distbits) - 1;\n\t\n\t\n\t /* decode literals and length/distances until end-of-block or not enough\n\t input data or output space */\n\t\n\t top:\n\t do {\n\t if (bits < 15) {\n\t hold += input[_in++] << bits;\n\t bits += 8;\n\t hold += input[_in++] << bits;\n\t bits += 8;\n\t }\n\t\n\t here = lcode[hold & lmask];\n\t\n\t dolen:\n\t for (;;) { // Goto emulation\n\t op = here >>> 24/*here.bits*/;\n\t hold >>>= op;\n\t bits -= op;\n\t op = (here >>> 16) & 0xff/*here.op*/;\n\t if (op === 0) { /* literal */\n\t //Tracevv((stderr, here.val >= 0x20 && here.val < 0x7f ?\n\t // \"inflate: literal '%c'\\n\" :\n\t // \"inflate: literal 0x%02x\\n\", here.val));\n\t output[_out++] = here & 0xffff/*here.val*/;\n\t }\n\t else if (op & 16) { /* length base */\n\t len = here & 0xffff/*here.val*/;\n\t op &= 15; /* number of extra bits */\n\t if (op) {\n\t if (bits < op) {\n\t hold += input[_in++] << bits;\n\t bits += 8;\n\t }\n\t len += hold & ((1 << op) - 1);\n\t hold >>>= op;\n\t bits -= op;\n\t }\n\t //Tracevv((stderr, \"inflate: length %u\\n\", len));\n\t if (bits < 15) {\n\t hold += input[_in++] << bits;\n\t bits += 8;\n\t hold += input[_in++] << bits;\n\t bits += 8;\n\t }\n\t here = dcode[hold & dmask];\n\t\n\t dodist:\n\t for (;;) { // goto emulation\n\t op = here >>> 24/*here.bits*/;\n\t hold >>>= op;\n\t bits -= op;\n\t op = (here >>> 16) & 0xff/*here.op*/;\n\t\n\t if (op & 16) { /* distance base */\n\t dist = here & 0xffff/*here.val*/;\n\t op &= 15; /* number of extra bits */\n\t if (bits < op) {\n\t hold += input[_in++] << bits;\n\t bits += 8;\n\t if (bits < op) {\n\t hold += input[_in++] << bits;\n\t bits += 8;\n\t }\n\t }\n\t dist += hold & ((1 << op) - 1);\n\t//#ifdef INFLATE_STRICT\n\t if (dist > dmax) {\n\t strm.msg = 'invalid distance too far back';\n\t state.mode = BAD;\n\t break top;\n\t }\n\t//#endif\n\t hold >>>= op;\n\t bits -= op;\n\t //Tracevv((stderr, \"inflate: distance %u\\n\", dist));\n\t op = _out - beg; /* max distance in output */\n\t if (dist > op) { /* see if copy from window */\n\t op = dist - op; /* distance back in window */\n\t if (op > whave) {\n\t if (state.sane) {\n\t strm.msg = 'invalid distance too far back';\n\t state.mode = BAD;\n\t break top;\n\t }\n\t\n\t// (!) This block is disabled in zlib defailts,\n\t// don't enable it for binary compatibility\n\t//#ifdef INFLATE_ALLOW_INVALID_DISTANCE_TOOFAR_ARRR\n\t// if (len <= op - whave) {\n\t// do {\n\t// output[_out++] = 0;\n\t// } while (--len);\n\t// continue top;\n\t// }\n\t// len -= op - whave;\n\t// do {\n\t// output[_out++] = 0;\n\t// } while (--op > whave);\n\t// if (op === 0) {\n\t// from = _out - dist;\n\t// do {\n\t// output[_out++] = output[from++];\n\t// } while (--len);\n\t// continue top;\n\t// }\n\t//#endif\n\t }\n\t from = 0; // window index\n\t from_source = s_window;\n\t if (wnext === 0) { /* very common case */\n\t from += wsize - op;\n\t if (op < len) { /* some from window */\n\t len -= op;\n\t do {\n\t output[_out++] = s_window[from++];\n\t } while (--op);\n\t from = _out - dist; /* rest from output */\n\t from_source = output;\n\t }\n\t }\n\t else if (wnext < op) { /* wrap around window */\n\t from += wsize + wnext - op;\n\t op -= wnext;\n\t if (op < len) { /* some from end of window */\n\t len -= op;\n\t do {\n\t output[_out++] = s_window[from++];\n\t } while (--op);\n\t from = 0;\n\t if (wnext < len) { /* some from start of window */\n\t op = wnext;\n\t len -= op;\n\t do {\n\t output[_out++] = s_window[from++];\n\t } while (--op);\n\t from = _out - dist; /* rest from output */\n\t from_source = output;\n\t }\n\t }\n\t }\n\t else { /* contiguous in window */\n\t from += wnext - op;\n\t if (op < len) { /* some from window */\n\t len -= op;\n\t do {\n\t output[_out++] = s_window[from++];\n\t } while (--op);\n\t from = _out - dist; /* rest from output */\n\t from_source = output;\n\t }\n\t }\n\t while (len > 2) {\n\t output[_out++] = from_source[from++];\n\t output[_out++] = from_source[from++];\n\t output[_out++] = from_source[from++];\n\t len -= 3;\n\t }\n\t if (len) {\n\t output[_out++] = from_source[from++];\n\t if (len > 1) {\n\t output[_out++] = from_source[from++];\n\t }\n\t }\n\t }\n\t else {\n\t from = _out - dist; /* copy direct from output */\n\t do { /* minimum length is three */\n\t output[_out++] = output[from++];\n\t output[_out++] = output[from++];\n\t output[_out++] = output[from++];\n\t len -= 3;\n\t } while (len > 2);\n\t if (len) {\n\t output[_out++] = output[from++];\n\t if (len > 1) {\n\t output[_out++] = output[from++];\n\t }\n\t }\n\t }\n\t }\n\t else if ((op & 64) === 0) { /* 2nd level distance code */\n\t here = dcode[(here & 0xffff)/*here.val*/ + (hold & ((1 << op) - 1))];\n\t continue dodist;\n\t }\n\t else {\n\t strm.msg = 'invalid distance code';\n\t state.mode = BAD;\n\t break top;\n\t }\n\t\n\t break; // need to emulate goto via \"continue\"\n\t }\n\t }\n\t else if ((op & 64) === 0) { /* 2nd level length code */\n\t here = lcode[(here & 0xffff)/*here.val*/ + (hold & ((1 << op) - 1))];\n\t continue dolen;\n\t }\n\t else if (op & 32) { /* end-of-block */\n\t //Tracevv((stderr, \"inflate: end of block\\n\"));\n\t state.mode = TYPE;\n\t break top;\n\t }\n\t else {\n\t strm.msg = 'invalid literal/length code';\n\t state.mode = BAD;\n\t break top;\n\t }\n\t\n\t break; // need to emulate goto via \"continue\"\n\t }\n\t } while (_in < last && _out < end);\n\t\n\t /* return unused bytes (on entry, bits < 8, so in won't go too far back) */\n\t len = bits >> 3;\n\t _in -= len;\n\t bits -= len << 3;\n\t hold &= (1 << bits) - 1;\n\t\n\t /* update state and return */\n\t strm.next_in = _in;\n\t strm.next_out = _out;\n\t strm.avail_in = (_in < last ? 5 + (last - _in) : 5 - (_in - last));\n\t strm.avail_out = (_out < end ? 257 + (end - _out) : 257 - (_out - end));\n\t state.hold = hold;\n\t state.bits = bits;\n\t return;\n\t};\n\n\n/***/ },\n/* 30 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\t\n\tvar utils = __webpack_require__(8);\n\tvar adler32 = __webpack_require__(25);\n\tvar crc32 = __webpack_require__(27);\n\tvar inflate_fast = __webpack_require__(29);\n\tvar inflate_table = __webpack_require__(31);\n\t\n\tvar CODES = 0;\n\tvar LENS = 1;\n\tvar DISTS = 2;\n\t\n\t/* Public constants ==========================================================*/\n\t/* ===========================================================================*/\n\t\n\t\n\t/* Allowed flush values; see deflate() and inflate() below for details */\n\t//var Z_NO_FLUSH = 0;\n\t//var Z_PARTIAL_FLUSH = 1;\n\t//var Z_SYNC_FLUSH = 2;\n\t//var Z_FULL_FLUSH = 3;\n\tvar Z_FINISH = 4;\n\tvar Z_BLOCK = 5;\n\tvar Z_TREES = 6;\n\t\n\t\n\t/* Return codes for the compression/decompression functions. Negative values\n\t * are errors, positive values are used for special but normal events.\n\t */\n\tvar Z_OK = 0;\n\tvar Z_STREAM_END = 1;\n\tvar Z_NEED_DICT = 2;\n\t//var Z_ERRNO = -1;\n\tvar Z_STREAM_ERROR = -2;\n\tvar Z_DATA_ERROR = -3;\n\tvar Z_MEM_ERROR = -4;\n\tvar Z_BUF_ERROR = -5;\n\t//var Z_VERSION_ERROR = -6;\n\t\n\t/* The deflate compression method */\n\tvar Z_DEFLATED = 8;\n\t\n\t\n\t/* STATES ====================================================================*/\n\t/* ===========================================================================*/\n\t\n\t\n\tvar HEAD = 1; /* i: waiting for magic header */\n\tvar FLAGS = 2; /* i: waiting for method and flags (gzip) */\n\tvar TIME = 3; /* i: waiting for modification time (gzip) */\n\tvar OS = 4; /* i: waiting for extra flags and operating system (gzip) */\n\tvar EXLEN = 5; /* i: waiting for extra length (gzip) */\n\tvar EXTRA = 6; /* i: waiting for extra bytes (gzip) */\n\tvar NAME = 7; /* i: waiting for end of file name (gzip) */\n\tvar COMMENT = 8; /* i: waiting for end of comment (gzip) */\n\tvar HCRC = 9; /* i: waiting for header crc (gzip) */\n\tvar DICTID = 10; /* i: waiting for dictionary check value */\n\tvar DICT = 11; /* waiting for inflateSetDictionary() call */\n\tvar TYPE = 12; /* i: waiting for type bits, including last-flag bit */\n\tvar TYPEDO = 13; /* i: same, but skip check to exit inflate on new block */\n\tvar STORED = 14; /* i: waiting for stored size (length and complement) */\n\tvar COPY_ = 15; /* i/o: same as COPY below, but only first time in */\n\tvar COPY = 16; /* i/o: waiting for input or output to copy stored block */\n\tvar TABLE = 17; /* i: waiting for dynamic block table lengths */\n\tvar LENLENS = 18; /* i: waiting for code length code lengths */\n\tvar CODELENS = 19; /* i: waiting for length/lit and distance code lengths */\n\tvar LEN_ = 20; /* i: same as LEN below, but only first time in */\n\tvar LEN = 21; /* i: waiting for length/lit/eob code */\n\tvar LENEXT = 22; /* i: waiting for length extra bits */\n\tvar DIST = 23; /* i: waiting for distance code */\n\tvar DISTEXT = 24; /* i: waiting for distance extra bits */\n\tvar MATCH = 25; /* o: waiting for output space to copy string */\n\tvar LIT = 26; /* o: waiting for output space to write literal */\n\tvar CHECK = 27; /* i: waiting for 32-bit check value */\n\tvar LENGTH = 28; /* i: waiting for 32-bit length (gzip) */\n\tvar DONE = 29; /* finished check, done -- remain here until reset */\n\tvar BAD = 30; /* got a data error -- remain here until reset */\n\tvar MEM = 31; /* got an inflate() memory error -- remain here until reset */\n\tvar SYNC = 32; /* looking for synchronization bytes to restart inflate() */\n\t\n\t/* ===========================================================================*/\n\t\n\t\n\t\n\tvar ENOUGH_LENS = 852;\n\tvar ENOUGH_DISTS = 592;\n\t//var ENOUGH = (ENOUGH_LENS+ENOUGH_DISTS);\n\t\n\tvar MAX_WBITS = 15;\n\t/* 32K LZ77 window */\n\tvar DEF_WBITS = MAX_WBITS;\n\t\n\t\n\tfunction zswap32(q) {\n\t return (((q >>> 24) & 0xff) +\n\t ((q >>> 8) & 0xff00) +\n\t ((q & 0xff00) << 8) +\n\t ((q & 0xff) << 24));\n\t}\n\t\n\t\n\tfunction InflateState() {\n\t this.mode = 0; /* current inflate mode */\n\t this.last = false; /* true if processing last block */\n\t this.wrap = 0; /* bit 0 true for zlib, bit 1 true for gzip */\n\t this.havedict = false; /* true if dictionary provided */\n\t this.flags = 0; /* gzip header method and flags (0 if zlib) */\n\t this.dmax = 0; /* zlib header max distance (INFLATE_STRICT) */\n\t this.check = 0; /* protected copy of check value */\n\t this.total = 0; /* protected copy of output count */\n\t // TODO: may be {}\n\t this.head = null; /* where to save gzip header information */\n\t\n\t /* sliding window */\n\t this.wbits = 0; /* log base 2 of requested window size */\n\t this.wsize = 0; /* window size or zero if not using window */\n\t this.whave = 0; /* valid bytes in the window */\n\t this.wnext = 0; /* window write index */\n\t this.window = null; /* allocated sliding window, if needed */\n\t\n\t /* bit accumulator */\n\t this.hold = 0; /* input bit accumulator */\n\t this.bits = 0; /* number of bits in \"in\" */\n\t\n\t /* for string and stored block copying */\n\t this.length = 0; /* literal or length of data to copy */\n\t this.offset = 0; /* distance back to copy string from */\n\t\n\t /* for table and code decoding */\n\t this.extra = 0; /* extra bits needed */\n\t\n\t /* fixed and dynamic code tables */\n\t this.lencode = null; /* starting table for length/literal codes */\n\t this.distcode = null; /* starting table for distance codes */\n\t this.lenbits = 0; /* index bits for lencode */\n\t this.distbits = 0; /* index bits for distcode */\n\t\n\t /* dynamic table building */\n\t this.ncode = 0; /* number of code length code lengths */\n\t this.nlen = 0; /* number of length code lengths */\n\t this.ndist = 0; /* number of distance code lengths */\n\t this.have = 0; /* number of code lengths in lens[] */\n\t this.next = null; /* next available space in codes[] */\n\t\n\t this.lens = new utils.Buf16(320); /* temporary storage for code lengths */\n\t this.work = new utils.Buf16(288); /* work area for code table building */\n\t\n\t /*\n\t because we don't have pointers in js, we use lencode and distcode directly\n\t as buffers so we don't need codes\n\t */\n\t //this.codes = new utils.Buf32(ENOUGH); /* space for code tables */\n\t this.lendyn = null; /* dynamic table for length/literal codes (JS specific) */\n\t this.distdyn = null; /* dynamic table for distance codes (JS specific) */\n\t this.sane = 0; /* if false, allow invalid distance too far */\n\t this.back = 0; /* bits back of last unprocessed length/lit */\n\t this.was = 0; /* initial length of match */\n\t}\n\t\n\tfunction inflateResetKeep(strm) {\n\t var state;\n\t\n\t if (!strm || !strm.state) { return Z_STREAM_ERROR; }\n\t state = strm.state;\n\t strm.total_in = strm.total_out = state.total = 0;\n\t strm.msg = ''; /*Z_NULL*/\n\t if (state.wrap) { /* to support ill-conceived Java test suite */\n\t strm.adler = state.wrap & 1;\n\t }\n\t state.mode = HEAD;\n\t state.last = 0;\n\t state.havedict = 0;\n\t state.dmax = 32768;\n\t state.head = null/*Z_NULL*/;\n\t state.hold = 0;\n\t state.bits = 0;\n\t //state.lencode = state.distcode = state.next = state.codes;\n\t state.lencode = state.lendyn = new utils.Buf32(ENOUGH_LENS);\n\t state.distcode = state.distdyn = new utils.Buf32(ENOUGH_DISTS);\n\t\n\t state.sane = 1;\n\t state.back = -1;\n\t //Tracev((stderr, \"inflate: reset\\n\"));\n\t return Z_OK;\n\t}\n\t\n\tfunction inflateReset(strm) {\n\t var state;\n\t\n\t if (!strm || !strm.state) { return Z_STREAM_ERROR; }\n\t state = strm.state;\n\t state.wsize = 0;\n\t state.whave = 0;\n\t state.wnext = 0;\n\t return inflateResetKeep(strm);\n\t\n\t}\n\t\n\tfunction inflateReset2(strm, windowBits) {\n\t var wrap;\n\t var state;\n\t\n\t /* get the state */\n\t if (!strm || !strm.state) { return Z_STREAM_ERROR; }\n\t state = strm.state;\n\t\n\t /* extract wrap request from windowBits parameter */\n\t if (windowBits < 0) {\n\t wrap = 0;\n\t windowBits = -windowBits;\n\t }\n\t else {\n\t wrap = (windowBits >> 4) + 1;\n\t if (windowBits < 48) {\n\t windowBits &= 15;\n\t }\n\t }\n\t\n\t /* set number of window bits, free window if different */\n\t if (windowBits && (windowBits < 8 || windowBits > 15)) {\n\t return Z_STREAM_ERROR;\n\t }\n\t if (state.window !== null && state.wbits !== windowBits) {\n\t state.window = null;\n\t }\n\t\n\t /* update state and reset the rest of it */\n\t state.wrap = wrap;\n\t state.wbits = windowBits;\n\t return inflateReset(strm);\n\t}\n\t\n\tfunction inflateInit2(strm, windowBits) {\n\t var ret;\n\t var state;\n\t\n\t if (!strm) { return Z_STREAM_ERROR; }\n\t //strm.msg = Z_NULL; /* in case we return an error */\n\t\n\t state = new InflateState();\n\t\n\t //if (state === Z_NULL) return Z_MEM_ERROR;\n\t //Tracev((stderr, \"inflate: allocated\\n\"));\n\t strm.state = state;\n\t state.window = null/*Z_NULL*/;\n\t ret = inflateReset2(strm, windowBits);\n\t if (ret !== Z_OK) {\n\t strm.state = null/*Z_NULL*/;\n\t }\n\t return ret;\n\t}\n\t\n\tfunction inflateInit(strm) {\n\t return inflateInit2(strm, DEF_WBITS);\n\t}\n\t\n\t\n\t/*\n\t Return state with length and distance decoding tables and index sizes set to\n\t fixed code decoding. Normally this returns fixed tables from inffixed.h.\n\t If BUILDFIXED is defined, then instead this routine builds the tables the\n\t first time it's called, and returns those tables the first time and\n\t thereafter. This reduces the size of the code by about 2K bytes, in\n\t exchange for a little execution time. However, BUILDFIXED should not be\n\t used for threaded applications, since the rewriting of the tables and virgin\n\t may not be thread-safe.\n\t */\n\tvar virgin = true;\n\t\n\tvar lenfix, distfix; // We have no pointers in JS, so keep tables separate\n\t\n\tfunction fixedtables(state) {\n\t /* build fixed huffman tables if first call (may not be thread safe) */\n\t if (virgin) {\n\t var sym;\n\t\n\t lenfix = new utils.Buf32(512);\n\t distfix = new utils.Buf32(32);\n\t\n\t /* literal/length table */\n\t sym = 0;\n\t while (sym < 144) { state.lens[sym++] = 8; }\n\t while (sym < 256) { state.lens[sym++] = 9; }\n\t while (sym < 280) { state.lens[sym++] = 7; }\n\t while (sym < 288) { state.lens[sym++] = 8; }\n\t\n\t inflate_table(LENS, state.lens, 0, 288, lenfix, 0, state.work, { bits: 9 });\n\t\n\t /* distance table */\n\t sym = 0;\n\t while (sym < 32) { state.lens[sym++] = 5; }\n\t\n\t inflate_table(DISTS, state.lens, 0, 32, distfix, 0, state.work, { bits: 5 });\n\t\n\t /* do this just once */\n\t virgin = false;\n\t }\n\t\n\t state.lencode = lenfix;\n\t state.lenbits = 9;\n\t state.distcode = distfix;\n\t state.distbits = 5;\n\t}\n\t\n\t\n\t/*\n\t Update the window with the last wsize (normally 32K) bytes written before\n\t returning. If window does not exist yet, create it. This is only called\n\t when a window is already in use, or when output has been written during this\n\t inflate call, but the end of the deflate stream has not been reached yet.\n\t It is also called to create a window for dictionary data when a dictionary\n\t is loaded.\n\t\n\t Providing output buffers larger than 32K to inflate() should provide a speed\n\t advantage, since only the last 32K of output is copied to the sliding window\n\t upon return from inflate(), and since all distances after the first 32K of\n\t output will fall in the output data, making match copies simpler and faster.\n\t The advantage may be dependent on the size of the processor's data caches.\n\t */\n\tfunction updatewindow(strm, src, end, copy) {\n\t var dist;\n\t var state = strm.state;\n\t\n\t /* if it hasn't been done already, allocate space for the window */\n\t if (state.window === null) {\n\t state.wsize = 1 << state.wbits;\n\t state.wnext = 0;\n\t state.whave = 0;\n\t\n\t state.window = new utils.Buf8(state.wsize);\n\t }\n\t\n\t /* copy state->wsize or less output bytes into the circular window */\n\t if (copy >= state.wsize) {\n\t utils.arraySet(state.window, src, end - state.wsize, state.wsize, 0);\n\t state.wnext = 0;\n\t state.whave = state.wsize;\n\t }\n\t else {\n\t dist = state.wsize - state.wnext;\n\t if (dist > copy) {\n\t dist = copy;\n\t }\n\t //zmemcpy(state->window + state->wnext, end - copy, dist);\n\t utils.arraySet(state.window, src, end - copy, dist, state.wnext);\n\t copy -= dist;\n\t if (copy) {\n\t //zmemcpy(state->window, end - copy, copy);\n\t utils.arraySet(state.window, src, end - copy, copy, 0);\n\t state.wnext = copy;\n\t state.whave = state.wsize;\n\t }\n\t else {\n\t state.wnext += dist;\n\t if (state.wnext === state.wsize) { state.wnext = 0; }\n\t if (state.whave < state.wsize) { state.whave += dist; }\n\t }\n\t }\n\t return 0;\n\t}\n\t\n\tfunction inflate(strm, flush) {\n\t var state;\n\t var input, output; // input/output buffers\n\t var next; /* next input INDEX */\n\t var put; /* next output INDEX */\n\t var have, left; /* available input and output */\n\t var hold; /* bit buffer */\n\t var bits; /* bits in bit buffer */\n\t var _in, _out; /* save starting available input and output */\n\t var copy; /* number of stored or match bytes to copy */\n\t var from; /* where to copy match bytes from */\n\t var from_source;\n\t var here = 0; /* current decoding table entry */\n\t var here_bits, here_op, here_val; // paked \"here\" denormalized (JS specific)\n\t //var last; /* parent table entry */\n\t var last_bits, last_op, last_val; // paked \"last\" denormalized (JS specific)\n\t var len; /* length to copy for repeats, bits to drop */\n\t var ret; /* return code */\n\t var hbuf = new utils.Buf8(4); /* buffer for gzip header crc calculation */\n\t var opts;\n\t\n\t var n; // temporary var for NEED_BITS\n\t\n\t var order = /* permutation of code lengths */\n\t [ 16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15 ];\n\t\n\t\n\t if (!strm || !strm.state || !strm.output ||\n\t (!strm.input && strm.avail_in !== 0)) {\n\t return Z_STREAM_ERROR;\n\t }\n\t\n\t state = strm.state;\n\t if (state.mode === TYPE) { state.mode = TYPEDO; } /* skip check */\n\t\n\t\n\t //--- LOAD() ---\n\t put = strm.next_out;\n\t output = strm.output;\n\t left = strm.avail_out;\n\t next = strm.next_in;\n\t input = strm.input;\n\t have = strm.avail_in;\n\t hold = state.hold;\n\t bits = state.bits;\n\t //---\n\t\n\t _in = have;\n\t _out = left;\n\t ret = Z_OK;\n\t\n\t inf_leave: // goto emulation\n\t for (;;) {\n\t switch (state.mode) {\n\t case HEAD:\n\t if (state.wrap === 0) {\n\t state.mode = TYPEDO;\n\t break;\n\t }\n\t //=== NEEDBITS(16);\n\t while (bits < 16) {\n\t if (have === 0) { break inf_leave; }\n\t have--;\n\t hold += input[next++] << bits;\n\t bits += 8;\n\t }\n\t //===//\n\t if ((state.wrap & 2) && hold === 0x8b1f) { /* gzip header */\n\t state.check = 0/*crc32(0L, Z_NULL, 0)*/;\n\t //=== CRC2(state.check, hold);\n\t hbuf[0] = hold & 0xff;\n\t hbuf[1] = (hold >>> 8) & 0xff;\n\t state.check = crc32(state.check, hbuf, 2, 0);\n\t //===//\n\t\n\t //=== INITBITS();\n\t hold = 0;\n\t bits = 0;\n\t //===//\n\t state.mode = FLAGS;\n\t break;\n\t }\n\t state.flags = 0; /* expect zlib header */\n\t if (state.head) {\n\t state.head.done = false;\n\t }\n\t if (!(state.wrap & 1) || /* check if zlib header allowed */\n\t (((hold & 0xff)/*BITS(8)*/ << 8) + (hold >> 8)) % 31) {\n\t strm.msg = 'incorrect header check';\n\t state.mode = BAD;\n\t break;\n\t }\n\t if ((hold & 0x0f)/*BITS(4)*/ !== Z_DEFLATED) {\n\t strm.msg = 'unknown compression method';\n\t state.mode = BAD;\n\t break;\n\t }\n\t //--- DROPBITS(4) ---//\n\t hold >>>= 4;\n\t bits -= 4;\n\t //---//\n\t len = (hold & 0x0f)/*BITS(4)*/ + 8;\n\t if (state.wbits === 0) {\n\t state.wbits = len;\n\t }\n\t else if (len > state.wbits) {\n\t strm.msg = 'invalid window size';\n\t state.mode = BAD;\n\t break;\n\t }\n\t state.dmax = 1 << len;\n\t //Tracev((stderr, \"inflate: zlib header ok\\n\"));\n\t strm.adler = state.check = 1/*adler32(0L, Z_NULL, 0)*/;\n\t state.mode = hold & 0x200 ? DICTID : TYPE;\n\t //=== INITBITS();\n\t hold = 0;\n\t bits = 0;\n\t //===//\n\t break;\n\t case FLAGS:\n\t //=== NEEDBITS(16); */\n\t while (bits < 16) {\n\t if (have === 0) { break inf_leave; }\n\t have--;\n\t hold += input[next++] << bits;\n\t bits += 8;\n\t }\n\t //===//\n\t state.flags = hold;\n\t if ((state.flags & 0xff) !== Z_DEFLATED) {\n\t strm.msg = 'unknown compression method';\n\t state.mode = BAD;\n\t break;\n\t }\n\t if (state.flags & 0xe000) {\n\t strm.msg = 'unknown header flags set';\n\t state.mode = BAD;\n\t break;\n\t }\n\t if (state.head) {\n\t state.head.text = ((hold >> 8) & 1);\n\t }\n\t if (state.flags & 0x0200) {\n\t //=== CRC2(state.check, hold);\n\t hbuf[0] = hold & 0xff;\n\t hbuf[1] = (hold >>> 8) & 0xff;\n\t state.check = crc32(state.check, hbuf, 2, 0);\n\t //===//\n\t }\n\t //=== INITBITS();\n\t hold = 0;\n\t bits = 0;\n\t //===//\n\t state.mode = TIME;\n\t /* falls through */\n\t case TIME:\n\t //=== NEEDBITS(32); */\n\t while (bits < 32) {\n\t if (have === 0) { break inf_leave; }\n\t have--;\n\t hold += input[next++] << bits;\n\t bits += 8;\n\t }\n\t //===//\n\t if (state.head) {\n\t state.head.time = hold;\n\t }\n\t if (state.flags & 0x0200) {\n\t //=== CRC4(state.check, hold)\n\t hbuf[0] = hold & 0xff;\n\t hbuf[1] = (hold >>> 8) & 0xff;\n\t hbuf[2] = (hold >>> 16) & 0xff;\n\t hbuf[3] = (hold >>> 24) & 0xff;\n\t state.check = crc32(state.check, hbuf, 4, 0);\n\t //===\n\t }\n\t //=== INITBITS();\n\t hold = 0;\n\t bits = 0;\n\t //===//\n\t state.mode = OS;\n\t /* falls through */\n\t case OS:\n\t //=== NEEDBITS(16); */\n\t while (bits < 16) {\n\t if (have === 0) { break inf_leave; }\n\t have--;\n\t hold += input[next++] << bits;\n\t bits += 8;\n\t }\n\t //===//\n\t if (state.head) {\n\t state.head.xflags = (hold & 0xff);\n\t state.head.os = (hold >> 8);\n\t }\n\t if (state.flags & 0x0200) {\n\t //=== CRC2(state.check, hold);\n\t hbuf[0] = hold & 0xff;\n\t hbuf[1] = (hold >>> 8) & 0xff;\n\t state.check = crc32(state.check, hbuf, 2, 0);\n\t //===//\n\t }\n\t //=== INITBITS();\n\t hold = 0;\n\t bits = 0;\n\t //===//\n\t state.mode = EXLEN;\n\t /* falls through */\n\t case EXLEN:\n\t if (state.flags & 0x0400) {\n\t //=== NEEDBITS(16); */\n\t while (bits < 16) {\n\t if (have === 0) { break inf_leave; }\n\t have--;\n\t hold += input[next++] << bits;\n\t bits += 8;\n\t }\n\t //===//\n\t state.length = hold;\n\t if (state.head) {\n\t state.head.extra_len = hold;\n\t }\n\t if (state.flags & 0x0200) {\n\t //=== CRC2(state.check, hold);\n\t hbuf[0] = hold & 0xff;\n\t hbuf[1] = (hold >>> 8) & 0xff;\n\t state.check = crc32(state.check, hbuf, 2, 0);\n\t //===//\n\t }\n\t //=== INITBITS();\n\t hold = 0;\n\t bits = 0;\n\t //===//\n\t }\n\t else if (state.head) {\n\t state.head.extra = null/*Z_NULL*/;\n\t }\n\t state.mode = EXTRA;\n\t /* falls through */\n\t case EXTRA:\n\t if (state.flags & 0x0400) {\n\t copy = state.length;\n\t if (copy > have) { copy = have; }\n\t if (copy) {\n\t if (state.head) {\n\t len = state.head.extra_len - state.length;\n\t if (!state.head.extra) {\n\t // Use untyped array for more conveniend processing later\n\t state.head.extra = new Array(state.head.extra_len);\n\t }\n\t utils.arraySet(\n\t state.head.extra,\n\t input,\n\t next,\n\t // extra field is limited to 65536 bytes\n\t // - no need for additional size check\n\t copy,\n\t /*len + copy > state.head.extra_max - len ? state.head.extra_max : copy,*/\n\t len\n\t );\n\t //zmemcpy(state.head.extra + len, next,\n\t // len + copy > state.head.extra_max ?\n\t // state.head.extra_max - len : copy);\n\t }\n\t if (state.flags & 0x0200) {\n\t state.check = crc32(state.check, input, copy, next);\n\t }\n\t have -= copy;\n\t next += copy;\n\t state.length -= copy;\n\t }\n\t if (state.length) { break inf_leave; }\n\t }\n\t state.length = 0;\n\t state.mode = NAME;\n\t /* falls through */\n\t case NAME:\n\t if (state.flags & 0x0800) {\n\t if (have === 0) { break inf_leave; }\n\t copy = 0;\n\t do {\n\t // TODO: 2 or 1 bytes?\n\t len = input[next + copy++];\n\t /* use constant limit because in js we should not preallocate memory */\n\t if (state.head && len &&\n\t (state.length < 65536 /*state.head.name_max*/)) {\n\t state.head.name += String.fromCharCode(len);\n\t }\n\t } while (len && copy < have);\n\t\n\t if (state.flags & 0x0200) {\n\t state.check = crc32(state.check, input, copy, next);\n\t }\n\t have -= copy;\n\t next += copy;\n\t if (len) { break inf_leave; }\n\t }\n\t else if (state.head) {\n\t state.head.name = null;\n\t }\n\t state.length = 0;\n\t state.mode = COMMENT;\n\t /* falls through */\n\t case COMMENT:\n\t if (state.flags & 0x1000) {\n\t if (have === 0) { break inf_leave; }\n\t copy = 0;\n\t do {\n\t len = input[next + copy++];\n\t /* use constant limit because in js we should not preallocate memory */\n\t if (state.head && len &&\n\t (state.length < 65536 /*state.head.comm_max*/)) {\n\t state.head.comment += String.fromCharCode(len);\n\t }\n\t } while (len && copy < have);\n\t if (state.flags & 0x0200) {\n\t state.check = crc32(state.check, input, copy, next);\n\t }\n\t have -= copy;\n\t next += copy;\n\t if (len) { break inf_leave; }\n\t }\n\t else if (state.head) {\n\t state.head.comment = null;\n\t }\n\t state.mode = HCRC;\n\t /* falls through */\n\t case HCRC:\n\t if (state.flags & 0x0200) {\n\t //=== NEEDBITS(16); */\n\t while (bits < 16) {\n\t if (have === 0) { break inf_leave; }\n\t have--;\n\t hold += input[next++] << bits;\n\t bits += 8;\n\t }\n\t //===//\n\t if (hold !== (state.check & 0xffff)) {\n\t strm.msg = 'header crc mismatch';\n\t state.mode = BAD;\n\t break;\n\t }\n\t //=== INITBITS();\n\t hold = 0;\n\t bits = 0;\n\t //===//\n\t }\n\t if (state.head) {\n\t state.head.hcrc = ((state.flags >> 9) & 1);\n\t state.head.done = true;\n\t }\n\t strm.adler = state.check = 0;\n\t state.mode = TYPE;\n\t break;\n\t case DICTID:\n\t //=== NEEDBITS(32); */\n\t while (bits < 32) {\n\t if (have === 0) { break inf_leave; }\n\t have--;\n\t hold += input[next++] << bits;\n\t bits += 8;\n\t }\n\t //===//\n\t strm.adler = state.check = zswap32(hold);\n\t //=== INITBITS();\n\t hold = 0;\n\t bits = 0;\n\t //===//\n\t state.mode = DICT;\n\t /* falls through */\n\t case DICT:\n\t if (state.havedict === 0) {\n\t //--- RESTORE() ---\n\t strm.next_out = put;\n\t strm.avail_out = left;\n\t strm.next_in = next;\n\t strm.avail_in = have;\n\t state.hold = hold;\n\t state.bits = bits;\n\t //---\n\t return Z_NEED_DICT;\n\t }\n\t strm.adler = state.check = 1/*adler32(0L, Z_NULL, 0)*/;\n\t state.mode = TYPE;\n\t /* falls through */\n\t case TYPE:\n\t if (flush === Z_BLOCK || flush === Z_TREES) { break inf_leave; }\n\t /* falls through */\n\t case TYPEDO:\n\t if (state.last) {\n\t //--- BYTEBITS() ---//\n\t hold >>>= bits & 7;\n\t bits -= bits & 7;\n\t //---//\n\t state.mode = CHECK;\n\t break;\n\t }\n\t //=== NEEDBITS(3); */\n\t while (bits < 3) {\n\t if (have === 0) { break inf_leave; }\n\t have--;\n\t hold += input[next++] << bits;\n\t bits += 8;\n\t }\n\t //===//\n\t state.last = (hold & 0x01)/*BITS(1)*/;\n\t //--- DROPBITS(1) ---//\n\t hold >>>= 1;\n\t bits -= 1;\n\t //---//\n\t\n\t switch ((hold & 0x03)/*BITS(2)*/) {\n\t case 0: /* stored block */\n\t //Tracev((stderr, \"inflate: stored block%s\\n\",\n\t // state.last ? \" (last)\" : \"\"));\n\t state.mode = STORED;\n\t break;\n\t case 1: /* fixed block */\n\t fixedtables(state);\n\t //Tracev((stderr, \"inflate: fixed codes block%s\\n\",\n\t // state.last ? \" (last)\" : \"\"));\n\t state.mode = LEN_; /* decode codes */\n\t if (flush === Z_TREES) {\n\t //--- DROPBITS(2) ---//\n\t hold >>>= 2;\n\t bits -= 2;\n\t //---//\n\t break inf_leave;\n\t }\n\t break;\n\t case 2: /* dynamic block */\n\t //Tracev((stderr, \"inflate: dynamic codes block%s\\n\",\n\t // state.last ? \" (last)\" : \"\"));\n\t state.mode = TABLE;\n\t break;\n\t case 3:\n\t strm.msg = 'invalid block type';\n\t state.mode = BAD;\n\t }\n\t //--- DROPBITS(2) ---//\n\t hold >>>= 2;\n\t bits -= 2;\n\t //---//\n\t break;\n\t case STORED:\n\t //--- BYTEBITS() ---// /* go to byte boundary */\n\t hold >>>= bits & 7;\n\t bits -= bits & 7;\n\t //---//\n\t //=== NEEDBITS(32); */\n\t while (bits < 32) {\n\t if (have === 0) { break inf_leave; }\n\t have--;\n\t hold += input[next++] << bits;\n\t bits += 8;\n\t }\n\t //===//\n\t if ((hold & 0xffff) !== ((hold >>> 16) ^ 0xffff)) {\n\t strm.msg = 'invalid stored block lengths';\n\t state.mode = BAD;\n\t break;\n\t }\n\t state.length = hold & 0xffff;\n\t //Tracev((stderr, \"inflate: stored length %u\\n\",\n\t // state.length));\n\t //=== INITBITS();\n\t hold = 0;\n\t bits = 0;\n\t //===//\n\t state.mode = COPY_;\n\t if (flush === Z_TREES) { break inf_leave; }\n\t /* falls through */\n\t case COPY_:\n\t state.mode = COPY;\n\t /* falls through */\n\t case COPY:\n\t copy = state.length;\n\t if (copy) {\n\t if (copy > have) { copy = have; }\n\t if (copy > left) { copy = left; }\n\t if (copy === 0) { break inf_leave; }\n\t //--- zmemcpy(put, next, copy); ---\n\t utils.arraySet(output, input, next, copy, put);\n\t //---//\n\t have -= copy;\n\t next += copy;\n\t left -= copy;\n\t put += copy;\n\t state.length -= copy;\n\t break;\n\t }\n\t //Tracev((stderr, \"inflate: stored end\\n\"));\n\t state.mode = TYPE;\n\t break;\n\t case TABLE:\n\t //=== NEEDBITS(14); */\n\t while (bits < 14) {\n\t if (have === 0) { break inf_leave; }\n\t have--;\n\t hold += input[next++] << bits;\n\t bits += 8;\n\t }\n\t //===//\n\t state.nlen = (hold & 0x1f)/*BITS(5)*/ + 257;\n\t //--- DROPBITS(5) ---//\n\t hold >>>= 5;\n\t bits -= 5;\n\t //---//\n\t state.ndist = (hold & 0x1f)/*BITS(5)*/ + 1;\n\t //--- DROPBITS(5) ---//\n\t hold >>>= 5;\n\t bits -= 5;\n\t //---//\n\t state.ncode = (hold & 0x0f)/*BITS(4)*/ + 4;\n\t //--- DROPBITS(4) ---//\n\t hold >>>= 4;\n\t bits -= 4;\n\t //---//\n\t//#ifndef PKZIP_BUG_WORKAROUND\n\t if (state.nlen > 286 || state.ndist > 30) {\n\t strm.msg = 'too many length or distance symbols';\n\t state.mode = BAD;\n\t break;\n\t }\n\t//#endif\n\t //Tracev((stderr, \"inflate: table sizes ok\\n\"));\n\t state.have = 0;\n\t state.mode = LENLENS;\n\t /* falls through */\n\t case LENLENS:\n\t while (state.have < state.ncode) {\n\t //=== NEEDBITS(3);\n\t while (bits < 3) {\n\t if (have === 0) { break inf_leave; }\n\t have--;\n\t hold += input[next++] << bits;\n\t bits += 8;\n\t }\n\t //===//\n\t state.lens[order[state.have++]] = (hold & 0x07);//BITS(3);\n\t //--- DROPBITS(3) ---//\n\t hold >>>= 3;\n\t bits -= 3;\n\t //---//\n\t }\n\t while (state.have < 19) {\n\t state.lens[order[state.have++]] = 0;\n\t }\n\t // We have separate tables & no pointers. 2 commented lines below not needed.\n\t //state.next = state.codes;\n\t //state.lencode = state.next;\n\t // Switch to use dynamic table\n\t state.lencode = state.lendyn;\n\t state.lenbits = 7;\n\t\n\t opts = { bits: state.lenbits };\n\t ret = inflate_table(CODES, state.lens, 0, 19, state.lencode, 0, state.work, opts);\n\t state.lenbits = opts.bits;\n\t\n\t if (ret) {\n\t strm.msg = 'invalid code lengths set';\n\t state.mode = BAD;\n\t break;\n\t }\n\t //Tracev((stderr, \"inflate: code lengths ok\\n\"));\n\t state.have = 0;\n\t state.mode = CODELENS;\n\t /* falls through */\n\t case CODELENS:\n\t while (state.have < state.nlen + state.ndist) {\n\t for (;;) {\n\t here = state.lencode[hold & ((1 << state.lenbits) - 1)];/*BITS(state.lenbits)*/\n\t here_bits = here >>> 24;\n\t here_op = (here >>> 16) & 0xff;\n\t here_val = here & 0xffff;\n\t\n\t if ((here_bits) <= bits) { break; }\n\t //--- PULLBYTE() ---//\n\t if (have === 0) { break inf_leave; }\n\t have--;\n\t hold += input[next++] << bits;\n\t bits += 8;\n\t //---//\n\t }\n\t if (here_val < 16) {\n\t //--- DROPBITS(here.bits) ---//\n\t hold >>>= here_bits;\n\t bits -= here_bits;\n\t //---//\n\t state.lens[state.have++] = here_val;\n\t }\n\t else {\n\t if (here_val === 16) {\n\t //=== NEEDBITS(here.bits + 2);\n\t n = here_bits + 2;\n\t while (bits < n) {\n\t if (have === 0) { break inf_leave; }\n\t have--;\n\t hold += input[next++] << bits;\n\t bits += 8;\n\t }\n\t //===//\n\t //--- DROPBITS(here.bits) ---//\n\t hold >>>= here_bits;\n\t bits -= here_bits;\n\t //---//\n\t if (state.have === 0) {\n\t strm.msg = 'invalid bit length repeat';\n\t state.mode = BAD;\n\t break;\n\t }\n\t len = state.lens[state.have - 1];\n\t copy = 3 + (hold & 0x03);//BITS(2);\n\t //--- DROPBITS(2) ---//\n\t hold >>>= 2;\n\t bits -= 2;\n\t //---//\n\t }\n\t else if (here_val === 17) {\n\t //=== NEEDBITS(here.bits + 3);\n\t n = here_bits + 3;\n\t while (bits < n) {\n\t if (have === 0) { break inf_leave; }\n\t have--;\n\t hold += input[next++] << bits;\n\t bits += 8;\n\t }\n\t //===//\n\t //--- DROPBITS(here.bits) ---//\n\t hold >>>= here_bits;\n\t bits -= here_bits;\n\t //---//\n\t len = 0;\n\t copy = 3 + (hold & 0x07);//BITS(3);\n\t //--- DROPBITS(3) ---//\n\t hold >>>= 3;\n\t bits -= 3;\n\t //---//\n\t }\n\t else {\n\t //=== NEEDBITS(here.bits + 7);\n\t n = here_bits + 7;\n\t while (bits < n) {\n\t if (have === 0) { break inf_leave; }\n\t have--;\n\t hold += input[next++] << bits;\n\t bits += 8;\n\t }\n\t //===//\n\t //--- DROPBITS(here.bits) ---//\n\t hold >>>= here_bits;\n\t bits -= here_bits;\n\t //---//\n\t len = 0;\n\t copy = 11 + (hold & 0x7f);//BITS(7);\n\t //--- DROPBITS(7) ---//\n\t hold >>>= 7;\n\t bits -= 7;\n\t //---//\n\t }\n\t if (state.have + copy > state.nlen + state.ndist) {\n\t strm.msg = 'invalid bit length repeat';\n\t state.mode = BAD;\n\t break;\n\t }\n\t while (copy--) {\n\t state.lens[state.have++] = len;\n\t }\n\t }\n\t }\n\t\n\t /* handle error breaks in while */\n\t if (state.mode === BAD) { break; }\n\t\n\t /* check for end-of-block code (better have one) */\n\t if (state.lens[256] === 0) {\n\t strm.msg = 'invalid code -- missing end-of-block';\n\t state.mode = BAD;\n\t break;\n\t }\n\t\n\t /* build code tables -- note: do not change the lenbits or distbits\n\t values here (9 and 6) without reading the comments in inftrees.h\n\t concerning the ENOUGH constants, which depend on those values */\n\t state.lenbits = 9;\n\t\n\t opts = { bits: state.lenbits };\n\t ret = inflate_table(LENS, state.lens, 0, state.nlen, state.lencode, 0, state.work, opts);\n\t // We have separate tables & no pointers. 2 commented lines below not needed.\n\t // state.next_index = opts.table_index;\n\t state.lenbits = opts.bits;\n\t // state.lencode = state.next;\n\t\n\t if (ret) {\n\t strm.msg = 'invalid literal/lengths set';\n\t state.mode = BAD;\n\t break;\n\t }\n\t\n\t state.distbits = 6;\n\t //state.distcode.copy(state.codes);\n\t // Switch to use dynamic table\n\t state.distcode = state.distdyn;\n\t opts = { bits: state.distbits };\n\t ret = inflate_table(DISTS, state.lens, state.nlen, state.ndist, state.distcode, 0, state.work, opts);\n\t // We have separate tables & no pointers. 2 commented lines below not needed.\n\t // state.next_index = opts.table_index;\n\t state.distbits = opts.bits;\n\t // state.distcode = state.next;\n\t\n\t if (ret) {\n\t strm.msg = 'invalid distances set';\n\t state.mode = BAD;\n\t break;\n\t }\n\t //Tracev((stderr, 'inflate: codes ok\\n'));\n\t state.mode = LEN_;\n\t if (flush === Z_TREES) { break inf_leave; }\n\t /* falls through */\n\t case LEN_:\n\t state.mode = LEN;\n\t /* falls through */\n\t case LEN:\n\t if (have >= 6 && left >= 258) {\n\t //--- RESTORE() ---\n\t strm.next_out = put;\n\t strm.avail_out = left;\n\t strm.next_in = next;\n\t strm.avail_in = have;\n\t state.hold = hold;\n\t state.bits = bits;\n\t //---\n\t inflate_fast(strm, _out);\n\t //--- LOAD() ---\n\t put = strm.next_out;\n\t output = strm.output;\n\t left = strm.avail_out;\n\t next = strm.next_in;\n\t input = strm.input;\n\t have = strm.avail_in;\n\t hold = state.hold;\n\t bits = state.bits;\n\t //---\n\t\n\t if (state.mode === TYPE) {\n\t state.back = -1;\n\t }\n\t break;\n\t }\n\t state.back = 0;\n\t for (;;) {\n\t here = state.lencode[hold & ((1 << state.lenbits) - 1)]; /*BITS(state.lenbits)*/\n\t here_bits = here >>> 24;\n\t here_op = (here >>> 16) & 0xff;\n\t here_val = here & 0xffff;\n\t\n\t if (here_bits <= bits) { break; }\n\t //--- PULLBYTE() ---//\n\t if (have === 0) { break inf_leave; }\n\t have--;\n\t hold += input[next++] << bits;\n\t bits += 8;\n\t //---//\n\t }\n\t if (here_op && (here_op & 0xf0) === 0) {\n\t last_bits = here_bits;\n\t last_op = here_op;\n\t last_val = here_val;\n\t for (;;) {\n\t here = state.lencode[last_val +\n\t ((hold & ((1 << (last_bits + last_op)) - 1))/*BITS(last.bits + last.op)*/ >> last_bits)];\n\t here_bits = here >>> 24;\n\t here_op = (here >>> 16) & 0xff;\n\t here_val = here & 0xffff;\n\t\n\t if ((last_bits + here_bits) <= bits) { break; }\n\t //--- PULLBYTE() ---//\n\t if (have === 0) { break inf_leave; }\n\t have--;\n\t hold += input[next++] << bits;\n\t bits += 8;\n\t //---//\n\t }\n\t //--- DROPBITS(last.bits) ---//\n\t hold >>>= last_bits;\n\t bits -= last_bits;\n\t //---//\n\t state.back += last_bits;\n\t }\n\t //--- DROPBITS(here.bits) ---//\n\t hold >>>= here_bits;\n\t bits -= here_bits;\n\t //---//\n\t state.back += here_bits;\n\t state.length = here_val;\n\t if (here_op === 0) {\n\t //Tracevv((stderr, here.val >= 0x20 && here.val < 0x7f ?\n\t // \"inflate: literal '%c'\\n\" :\n\t // \"inflate: literal 0x%02x\\n\", here.val));\n\t state.mode = LIT;\n\t break;\n\t }\n\t if (here_op & 32) {\n\t //Tracevv((stderr, \"inflate: end of block\\n\"));\n\t state.back = -1;\n\t state.mode = TYPE;\n\t break;\n\t }\n\t if (here_op & 64) {\n\t strm.msg = 'invalid literal/length code';\n\t state.mode = BAD;\n\t break;\n\t }\n\t state.extra = here_op & 15;\n\t state.mode = LENEXT;\n\t /* falls through */\n\t case LENEXT:\n\t if (state.extra) {\n\t //=== NEEDBITS(state.extra);\n\t n = state.extra;\n\t while (bits < n) {\n\t if (have === 0) { break inf_leave; }\n\t have--;\n\t hold += input[next++] << bits;\n\t bits += 8;\n\t }\n\t //===//\n\t state.length += hold & ((1 << state.extra) - 1)/*BITS(state.extra)*/;\n\t //--- DROPBITS(state.extra) ---//\n\t hold >>>= state.extra;\n\t bits -= state.extra;\n\t //---//\n\t state.back += state.extra;\n\t }\n\t //Tracevv((stderr, \"inflate: length %u\\n\", state.length));\n\t state.was = state.length;\n\t state.mode = DIST;\n\t /* falls through */\n\t case DIST:\n\t for (;;) {\n\t here = state.distcode[hold & ((1 << state.distbits) - 1)];/*BITS(state.distbits)*/\n\t here_bits = here >>> 24;\n\t here_op = (here >>> 16) & 0xff;\n\t here_val = here & 0xffff;\n\t\n\t if ((here_bits) <= bits) { break; }\n\t //--- PULLBYTE() ---//\n\t if (have === 0) { break inf_leave; }\n\t have--;\n\t hold += input[next++] << bits;\n\t bits += 8;\n\t //---//\n\t }\n\t if ((here_op & 0xf0) === 0) {\n\t last_bits = here_bits;\n\t last_op = here_op;\n\t last_val = here_val;\n\t for (;;) {\n\t here = state.distcode[last_val +\n\t ((hold & ((1 << (last_bits + last_op)) - 1))/*BITS(last.bits + last.op)*/ >> last_bits)];\n\t here_bits = here >>> 24;\n\t here_op = (here >>> 16) & 0xff;\n\t here_val = here & 0xffff;\n\t\n\t if ((last_bits + here_bits) <= bits) { break; }\n\t //--- PULLBYTE() ---//\n\t if (have === 0) { break inf_leave; }\n\t have--;\n\t hold += input[next++] << bits;\n\t bits += 8;\n\t //---//\n\t }\n\t //--- DROPBITS(last.bits) ---//\n\t hold >>>= last_bits;\n\t bits -= last_bits;\n\t //---//\n\t state.back += last_bits;\n\t }\n\t //--- DROPBITS(here.bits) ---//\n\t hold >>>= here_bits;\n\t bits -= here_bits;\n\t //---//\n\t state.back += here_bits;\n\t if (here_op & 64) {\n\t strm.msg = 'invalid distance code';\n\t state.mode = BAD;\n\t break;\n\t }\n\t state.offset = here_val;\n\t state.extra = (here_op) & 15;\n\t state.mode = DISTEXT;\n\t /* falls through */\n\t case DISTEXT:\n\t if (state.extra) {\n\t //=== NEEDBITS(state.extra);\n\t n = state.extra;\n\t while (bits < n) {\n\t if (have === 0) { break inf_leave; }\n\t have--;\n\t hold += input[next++] << bits;\n\t bits += 8;\n\t }\n\t //===//\n\t state.offset += hold & ((1 << state.extra) - 1)/*BITS(state.extra)*/;\n\t //--- DROPBITS(state.extra) ---//\n\t hold >>>= state.extra;\n\t bits -= state.extra;\n\t //---//\n\t state.back += state.extra;\n\t }\n\t//#ifdef INFLATE_STRICT\n\t if (state.offset > state.dmax) {\n\t strm.msg = 'invalid distance too far back';\n\t state.mode = BAD;\n\t break;\n\t }\n\t//#endif\n\t //Tracevv((stderr, \"inflate: distance %u\\n\", state.offset));\n\t state.mode = MATCH;\n\t /* falls through */\n\t case MATCH:\n\t if (left === 0) { break inf_leave; }\n\t copy = _out - left;\n\t if (state.offset > copy) { /* copy from window */\n\t copy = state.offset - copy;\n\t if (copy > state.whave) {\n\t if (state.sane) {\n\t strm.msg = 'invalid distance too far back';\n\t state.mode = BAD;\n\t break;\n\t }\n\t// (!) This block is disabled in zlib defailts,\n\t// don't enable it for binary compatibility\n\t//#ifdef INFLATE_ALLOW_INVALID_DISTANCE_TOOFAR_ARRR\n\t// Trace((stderr, \"inflate.c too far\\n\"));\n\t// copy -= state.whave;\n\t// if (copy > state.length) { copy = state.length; }\n\t// if (copy > left) { copy = left; }\n\t// left -= copy;\n\t// state.length -= copy;\n\t// do {\n\t// output[put++] = 0;\n\t// } while (--copy);\n\t// if (state.length === 0) { state.mode = LEN; }\n\t// break;\n\t//#endif\n\t }\n\t if (copy > state.wnext) {\n\t copy -= state.wnext;\n\t from = state.wsize - copy;\n\t }\n\t else {\n\t from = state.wnext - copy;\n\t }\n\t if (copy > state.length) { copy = state.length; }\n\t from_source = state.window;\n\t }\n\t else { /* copy from output */\n\t from_source = output;\n\t from = put - state.offset;\n\t copy = state.length;\n\t }\n\t if (copy > left) { copy = left; }\n\t left -= copy;\n\t state.length -= copy;\n\t do {\n\t output[put++] = from_source[from++];\n\t } while (--copy);\n\t if (state.length === 0) { state.mode = LEN; }\n\t break;\n\t case LIT:\n\t if (left === 0) { break inf_leave; }\n\t output[put++] = state.length;\n\t left--;\n\t state.mode = LEN;\n\t break;\n\t case CHECK:\n\t if (state.wrap) {\n\t //=== NEEDBITS(32);\n\t while (bits < 32) {\n\t if (have === 0) { break inf_leave; }\n\t have--;\n\t // Use '|' insdead of '+' to make sure that result is signed\n\t hold |= input[next++] << bits;\n\t bits += 8;\n\t }\n\t //===//\n\t _out -= left;\n\t strm.total_out += _out;\n\t state.total += _out;\n\t if (_out) {\n\t strm.adler = state.check =\n\t /*UPDATE(state.check, put - _out, _out);*/\n\t (state.flags ? crc32(state.check, output, _out, put - _out) : adler32(state.check, output, _out, put - _out));\n\t\n\t }\n\t _out = left;\n\t // NB: crc32 stored as signed 32-bit int, zswap32 returns signed too\n\t if ((state.flags ? hold : zswap32(hold)) !== state.check) {\n\t strm.msg = 'incorrect data check';\n\t state.mode = BAD;\n\t break;\n\t }\n\t //=== INITBITS();\n\t hold = 0;\n\t bits = 0;\n\t //===//\n\t //Tracev((stderr, \"inflate: check matches trailer\\n\"));\n\t }\n\t state.mode = LENGTH;\n\t /* falls through */\n\t case LENGTH:\n\t if (state.wrap && state.flags) {\n\t //=== NEEDBITS(32);\n\t while (bits < 32) {\n\t if (have === 0) { break inf_leave; }\n\t have--;\n\t hold += input[next++] << bits;\n\t bits += 8;\n\t }\n\t //===//\n\t if (hold !== (state.total & 0xffffffff)) {\n\t strm.msg = 'incorrect length check';\n\t state.mode = BAD;\n\t break;\n\t }\n\t //=== INITBITS();\n\t hold = 0;\n\t bits = 0;\n\t //===//\n\t //Tracev((stderr, \"inflate: length matches trailer\\n\"));\n\t }\n\t state.mode = DONE;\n\t /* falls through */\n\t case DONE:\n\t ret = Z_STREAM_END;\n\t break inf_leave;\n\t case BAD:\n\t ret = Z_DATA_ERROR;\n\t break inf_leave;\n\t case MEM:\n\t return Z_MEM_ERROR;\n\t case SYNC:\n\t /* falls through */\n\t default:\n\t return Z_STREAM_ERROR;\n\t }\n\t }\n\t\n\t // inf_leave <- here is real place for \"goto inf_leave\", emulated via \"break inf_leave\"\n\t\n\t /*\n\t Return from inflate(), updating the total counts and the check value.\n\t If there was no progress during the inflate() call, return a buffer\n\t error. Call updatewindow() to create and/or update the window state.\n\t Note: a memory error from inflate() is non-recoverable.\n\t */\n\t\n\t //--- RESTORE() ---\n\t strm.next_out = put;\n\t strm.avail_out = left;\n\t strm.next_in = next;\n\t strm.avail_in = have;\n\t state.hold = hold;\n\t state.bits = bits;\n\t //---\n\t\n\t if (state.wsize || (_out !== strm.avail_out && state.mode < BAD &&\n\t (state.mode < CHECK || flush !== Z_FINISH))) {\n\t if (updatewindow(strm, strm.output, strm.next_out, _out - strm.avail_out)) {\n\t state.mode = MEM;\n\t return Z_MEM_ERROR;\n\t }\n\t }\n\t _in -= strm.avail_in;\n\t _out -= strm.avail_out;\n\t strm.total_in += _in;\n\t strm.total_out += _out;\n\t state.total += _out;\n\t if (state.wrap && _out) {\n\t strm.adler = state.check = /*UPDATE(state.check, strm.next_out - _out, _out);*/\n\t (state.flags ? crc32(state.check, output, _out, strm.next_out - _out) : adler32(state.check, output, _out, strm.next_out - _out));\n\t }\n\t strm.data_type = state.bits + (state.last ? 64 : 0) +\n\t (state.mode === TYPE ? 128 : 0) +\n\t (state.mode === LEN_ || state.mode === COPY_ ? 256 : 0);\n\t if (((_in === 0 && _out === 0) || flush === Z_FINISH) && ret === Z_OK) {\n\t ret = Z_BUF_ERROR;\n\t }\n\t return ret;\n\t}\n\t\n\tfunction inflateEnd(strm) {\n\t\n\t if (!strm || !strm.state /*|| strm->zfree == (free_func)0*/) {\n\t return Z_STREAM_ERROR;\n\t }\n\t\n\t var state = strm.state;\n\t if (state.window) {\n\t state.window = null;\n\t }\n\t strm.state = null;\n\t return Z_OK;\n\t}\n\t\n\tfunction inflateGetHeader(strm, head) {\n\t var state;\n\t\n\t /* check state */\n\t if (!strm || !strm.state) { return Z_STREAM_ERROR; }\n\t state = strm.state;\n\t if ((state.wrap & 2) === 0) { return Z_STREAM_ERROR; }\n\t\n\t /* save header structure */\n\t state.head = head;\n\t head.done = false;\n\t return Z_OK;\n\t}\n\t\n\tfunction inflateSetDictionary(strm, dictionary) {\n\t var dictLength = dictionary.length;\n\t\n\t var state;\n\t var dictid;\n\t var ret;\n\t\n\t /* check state */\n\t if (!strm /* == Z_NULL */ || !strm.state /* == Z_NULL */) { return Z_STREAM_ERROR; }\n\t state = strm.state;\n\t\n\t if (state.wrap !== 0 && state.mode !== DICT) {\n\t return Z_STREAM_ERROR;\n\t }\n\t\n\t /* check for correct dictionary identifier */\n\t if (state.mode === DICT) {\n\t dictid = 1; /* adler32(0, null, 0)*/\n\t /* dictid = adler32(dictid, dictionary, dictLength); */\n\t dictid = adler32(dictid, dictionary, dictLength, 0);\n\t if (dictid !== state.check) {\n\t return Z_DATA_ERROR;\n\t }\n\t }\n\t /* copy dictionary to window using updatewindow(), which will amend the\n\t existing dictionary if appropriate */\n\t ret = updatewindow(strm, dictionary, dictLength, dictLength);\n\t if (ret) {\n\t state.mode = MEM;\n\t return Z_MEM_ERROR;\n\t }\n\t state.havedict = 1;\n\t // Tracev((stderr, \"inflate: dictionary set\\n\"));\n\t return Z_OK;\n\t}\n\t\n\texports.inflateReset = inflateReset;\n\texports.inflateReset2 = inflateReset2;\n\texports.inflateResetKeep = inflateResetKeep;\n\texports.inflateInit = inflateInit;\n\texports.inflateInit2 = inflateInit2;\n\texports.inflate = inflate;\n\texports.inflateEnd = inflateEnd;\n\texports.inflateGetHeader = inflateGetHeader;\n\texports.inflateSetDictionary = inflateSetDictionary;\n\texports.inflateInfo = 'pako inflate (from Nodeca project)';\n\t\n\t/* Not implemented\n\texports.inflateCopy = inflateCopy;\n\texports.inflateGetDictionary = inflateGetDictionary;\n\texports.inflateMark = inflateMark;\n\texports.inflatePrime = inflatePrime;\n\texports.inflateSync = inflateSync;\n\texports.inflateSyncPoint = inflateSyncPoint;\n\texports.inflateUndermine = inflateUndermine;\n\t*/\n\n\n/***/ },\n/* 31 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\t\n\tvar utils = __webpack_require__(8);\n\t\n\tvar MAXBITS = 15;\n\tvar ENOUGH_LENS = 852;\n\tvar ENOUGH_DISTS = 592;\n\t//var ENOUGH = (ENOUGH_LENS+ENOUGH_DISTS);\n\t\n\tvar CODES = 0;\n\tvar LENS = 1;\n\tvar DISTS = 2;\n\t\n\tvar lbase = [ /* Length codes 257..285 base */\n\t 3, 4, 5, 6, 7, 8, 9, 10, 11, 13, 15, 17, 19, 23, 27, 31,\n\t 35, 43, 51, 59, 67, 83, 99, 115, 131, 163, 195, 227, 258, 0, 0\n\t];\n\t\n\tvar lext = [ /* Length codes 257..285 extra */\n\t 16, 16, 16, 16, 16, 16, 16, 16, 17, 17, 17, 17, 18, 18, 18, 18,\n\t 19, 19, 19, 19, 20, 20, 20, 20, 21, 21, 21, 21, 16, 72, 78\n\t];\n\t\n\tvar dbase = [ /* Distance codes 0..29 base */\n\t 1, 2, 3, 4, 5, 7, 9, 13, 17, 25, 33, 49, 65, 97, 129, 193,\n\t 257, 385, 513, 769, 1025, 1537, 2049, 3073, 4097, 6145,\n\t 8193, 12289, 16385, 24577, 0, 0\n\t];\n\t\n\tvar dext = [ /* Distance codes 0..29 extra */\n\t 16, 16, 16, 16, 17, 17, 18, 18, 19, 19, 20, 20, 21, 21, 22, 22,\n\t 23, 23, 24, 24, 25, 25, 26, 26, 27, 27,\n\t 28, 28, 29, 29, 64, 64\n\t];\n\t\n\tmodule.exports = function inflate_table(type, lens, lens_index, codes, table, table_index, work, opts)\n\t{\n\t var bits = opts.bits;\n\t //here = opts.here; /* table entry for duplication */\n\t\n\t var len = 0; /* a code's length in bits */\n\t var sym = 0; /* index of code symbols */\n\t var min = 0, max = 0; /* minimum and maximum code lengths */\n\t var root = 0; /* number of index bits for root table */\n\t var curr = 0; /* number of index bits for current table */\n\t var drop = 0; /* code bits to drop for sub-table */\n\t var left = 0; /* number of prefix codes available */\n\t var used = 0; /* code entries in table used */\n\t var huff = 0; /* Huffman code */\n\t var incr; /* for incrementing code, index */\n\t var fill; /* index for replicating entries */\n\t var low; /* low bits for current root entry */\n\t var mask; /* mask for low root bits */\n\t var next; /* next available space in table */\n\t var base = null; /* base value table to use */\n\t var base_index = 0;\n\t// var shoextra; /* extra bits table to use */\n\t var end; /* use base and extra for symbol > end */\n\t var count = new utils.Buf16(MAXBITS + 1); //[MAXBITS+1]; /* number of codes of each length */\n\t var offs = new utils.Buf16(MAXBITS + 1); //[MAXBITS+1]; /* offsets in table for each length */\n\t var extra = null;\n\t var extra_index = 0;\n\t\n\t var here_bits, here_op, here_val;\n\t\n\t /*\n\t Process a set of code lengths to create a canonical Huffman code. The\n\t code lengths are lens[0..codes-1]. Each length corresponds to the\n\t symbols 0..codes-1. The Huffman code is generated by first sorting the\n\t symbols by length from short to long, and retaining the symbol order\n\t for codes with equal lengths. Then the code starts with all zero bits\n\t for the first code of the shortest length, and the codes are integer\n\t increments for the same length, and zeros are appended as the length\n\t increases. For the deflate format, these bits are stored backwards\n\t from their more natural integer increment ordering, and so when the\n\t decoding tables are built in the large loop below, the integer codes\n\t are incremented backwards.\n\t\n\t This routine assumes, but does not check, that all of the entries in\n\t lens[] are in the range 0..MAXBITS. The caller must assure this.\n\t 1..MAXBITS is interpreted as that code length. zero means that that\n\t symbol does not occur in this code.\n\t\n\t The codes are sorted by computing a count of codes for each length,\n\t creating from that a table of starting indices for each length in the\n\t sorted table, and then entering the symbols in order in the sorted\n\t table. The sorted table is work[], with that space being provided by\n\t the caller.\n\t\n\t The length counts are used for other purposes as well, i.e. finding\n\t the minimum and maximum length codes, determining if there are any\n\t codes at all, checking for a valid set of lengths, and looking ahead\n\t at length counts to determine sub-table sizes when building the\n\t decoding tables.\n\t */\n\t\n\t /* accumulate lengths for codes (assumes lens[] all in 0..MAXBITS) */\n\t for (len = 0; len <= MAXBITS; len++) {\n\t count[len] = 0;\n\t }\n\t for (sym = 0; sym < codes; sym++) {\n\t count[lens[lens_index + sym]]++;\n\t }\n\t\n\t /* bound code lengths, force root to be within code lengths */\n\t root = bits;\n\t for (max = MAXBITS; max >= 1; max--) {\n\t if (count[max] !== 0) { break; }\n\t }\n\t if (root > max) {\n\t root = max;\n\t }\n\t if (max === 0) { /* no symbols to code at all */\n\t //table.op[opts.table_index] = 64; //here.op = (var char)64; /* invalid code marker */\n\t //table.bits[opts.table_index] = 1; //here.bits = (var char)1;\n\t //table.val[opts.table_index++] = 0; //here.val = (var short)0;\n\t table[table_index++] = (1 << 24) | (64 << 16) | 0;\n\t\n\t\n\t //table.op[opts.table_index] = 64;\n\t //table.bits[opts.table_index] = 1;\n\t //table.val[opts.table_index++] = 0;\n\t table[table_index++] = (1 << 24) | (64 << 16) | 0;\n\t\n\t opts.bits = 1;\n\t return 0; /* no symbols, but wait for decoding to report error */\n\t }\n\t for (min = 1; min < max; min++) {\n\t if (count[min] !== 0) { break; }\n\t }\n\t if (root < min) {\n\t root = min;\n\t }\n\t\n\t /* check for an over-subscribed or incomplete set of lengths */\n\t left = 1;\n\t for (len = 1; len <= MAXBITS; len++) {\n\t left <<= 1;\n\t left -= count[len];\n\t if (left < 0) {\n\t return -1;\n\t } /* over-subscribed */\n\t }\n\t if (left > 0 && (type === CODES || max !== 1)) {\n\t return -1; /* incomplete set */\n\t }\n\t\n\t /* generate offsets into symbol table for each length for sorting */\n\t offs[1] = 0;\n\t for (len = 1; len < MAXBITS; len++) {\n\t offs[len + 1] = offs[len] + count[len];\n\t }\n\t\n\t /* sort symbols by length, by symbol order within each length */\n\t for (sym = 0; sym < codes; sym++) {\n\t if (lens[lens_index + sym] !== 0) {\n\t work[offs[lens[lens_index + sym]]++] = sym;\n\t }\n\t }\n\t\n\t /*\n\t Create and fill in decoding tables. In this loop, the table being\n\t filled is at next and has curr index bits. The code being used is huff\n\t with length len. That code is converted to an index by dropping drop\n\t bits off of the bottom. For codes where len is less than drop + curr,\n\t those top drop + curr - len bits are incremented through all values to\n\t fill the table with replicated entries.\n\t\n\t root is the number of index bits for the root table. When len exceeds\n\t root, sub-tables are created pointed to by the root entry with an index\n\t of the low root bits of huff. This is saved in low to check for when a\n\t new sub-table should be started. drop is zero when the root table is\n\t being filled, and drop is root when sub-tables are being filled.\n\t\n\t When a new sub-table is needed, it is necessary to look ahead in the\n\t code lengths to determine what size sub-table is needed. The length\n\t counts are used for this, and so count[] is decremented as codes are\n\t entered in the tables.\n\t\n\t used keeps track of how many table entries have been allocated from the\n\t provided *table space. It is checked for LENS and DIST tables against\n\t the constants ENOUGH_LENS and ENOUGH_DISTS to guard against changes in\n\t the initial root table size constants. See the comments in inftrees.h\n\t for more information.\n\t\n\t sym increments through all symbols, and the loop terminates when\n\t all codes of length max, i.e. all codes, have been processed. This\n\t routine permits incomplete codes, so another loop after this one fills\n\t in the rest of the decoding tables with invalid code markers.\n\t */\n\t\n\t /* set up for code type */\n\t // poor man optimization - use if-else instead of switch,\n\t // to avoid deopts in old v8\n\t if (type === CODES) {\n\t base = extra = work; /* dummy value--not used */\n\t end = 19;\n\t\n\t } else if (type === LENS) {\n\t base = lbase;\n\t base_index -= 257;\n\t extra = lext;\n\t extra_index -= 257;\n\t end = 256;\n\t\n\t } else { /* DISTS */\n\t base = dbase;\n\t extra = dext;\n\t end = -1;\n\t }\n\t\n\t /* initialize opts for loop */\n\t huff = 0; /* starting code */\n\t sym = 0; /* starting code symbol */\n\t len = min; /* starting code length */\n\t next = table_index; /* current table to fill in */\n\t curr = root; /* current table index bits */\n\t drop = 0; /* current bits to drop from code for index */\n\t low = -1; /* trigger new sub-table when len > root */\n\t used = 1 << root; /* use root table entries */\n\t mask = used - 1; /* mask for comparing low */\n\t\n\t /* check available table space */\n\t if ((type === LENS && used > ENOUGH_LENS) ||\n\t (type === DISTS && used > ENOUGH_DISTS)) {\n\t return 1;\n\t }\n\t\n\t /* process all codes and make table entries */\n\t for (;;) {\n\t /* create table entry */\n\t here_bits = len - drop;\n\t if (work[sym] < end) {\n\t here_op = 0;\n\t here_val = work[sym];\n\t }\n\t else if (work[sym] > end) {\n\t here_op = extra[extra_index + work[sym]];\n\t here_val = base[base_index + work[sym]];\n\t }\n\t else {\n\t here_op = 32 + 64; /* end of block */\n\t here_val = 0;\n\t }\n\t\n\t /* replicate for those indices with low len bits equal to huff */\n\t incr = 1 << (len - drop);\n\t fill = 1 << curr;\n\t min = fill; /* save offset to next table */\n\t do {\n\t fill -= incr;\n\t table[next + (huff >> drop) + fill] = (here_bits << 24) | (here_op << 16) | here_val |0;\n\t } while (fill !== 0);\n\t\n\t /* backwards increment the len-bit code huff */\n\t incr = 1 << (len - 1);\n\t while (huff & incr) {\n\t incr >>= 1;\n\t }\n\t if (incr !== 0) {\n\t huff &= incr - 1;\n\t huff += incr;\n\t } else {\n\t huff = 0;\n\t }\n\t\n\t /* go to next symbol, update count, len */\n\t sym++;\n\t if (--count[len] === 0) {\n\t if (len === max) { break; }\n\t len = lens[lens_index + work[sym]];\n\t }\n\t\n\t /* create new sub-table if needed */\n\t if (len > root && (huff & mask) !== low) {\n\t /* if first time, transition to sub-tables */\n\t if (drop === 0) {\n\t drop = root;\n\t }\n\t\n\t /* increment past last table */\n\t next += min; /* here min is 1 << curr */\n\t\n\t /* determine length of next table */\n\t curr = len - drop;\n\t left = 1 << curr;\n\t while (curr + drop < max) {\n\t left -= count[curr + drop];\n\t if (left <= 0) { break; }\n\t curr++;\n\t left <<= 1;\n\t }\n\t\n\t /* check for enough space */\n\t used += 1 << curr;\n\t if ((type === LENS && used > ENOUGH_LENS) ||\n\t (type === DISTS && used > ENOUGH_DISTS)) {\n\t return 1;\n\t }\n\t\n\t /* point entry in root table to sub-table */\n\t low = huff & mask;\n\t /*table.op[low] = curr;\n\t table.bits[low] = root;\n\t table.val[low] = next - opts.table_index;*/\n\t table[low] = (root << 24) | (curr << 16) | (next - table_index) |0;\n\t }\n\t }\n\t\n\t /* fill in remaining table entry if code is incomplete (guaranteed to have\n\t at most one remaining entry, since if the code is incomplete, the\n\t maximum code length that was allowed to get this far is one bit) */\n\t if (huff !== 0) {\n\t //table.op[next + huff] = 64; /* invalid code marker */\n\t //table.bits[next + huff] = len - drop;\n\t //table.val[next + huff] = 0;\n\t table[next + huff] = ((len - drop) << 24) | (64 << 16) |0;\n\t }\n\t\n\t /* set return parameters */\n\t //opts.table_index += used;\n\t opts.bits = root;\n\t return 0;\n\t};\n\n\n/***/ },\n/* 32 */\n/***/ function(module, exports) {\n\n\t'use strict';\n\t\n\tmodule.exports = {\n\t 2: 'need dictionary', /* Z_NEED_DICT 2 */\n\t 1: 'stream end', /* Z_STREAM_END 1 */\n\t 0: '', /* Z_OK 0 */\n\t '-1': 'file error', /* Z_ERRNO (-1) */\n\t '-2': 'stream error', /* Z_STREAM_ERROR (-2) */\n\t '-3': 'data error', /* Z_DATA_ERROR (-3) */\n\t '-4': 'insufficient memory', /* Z_MEM_ERROR (-4) */\n\t '-5': 'buffer error', /* Z_BUF_ERROR (-5) */\n\t '-6': 'incompatible version' /* Z_VERSION_ERROR (-6) */\n\t};\n\n\n/***/ },\n/* 33 */\n/***/ function(module, exports) {\n\n\t'use strict';\n\t\n\t\n\tfunction ZStream() {\n\t /* next input byte */\n\t this.input = null; // JS specific, because we have no pointers\n\t this.next_in = 0;\n\t /* number of bytes available at input */\n\t this.avail_in = 0;\n\t /* total number of input bytes read so far */\n\t this.total_in = 0;\n\t /* next output byte should be put there */\n\t this.output = null; // JS specific, because we have no pointers\n\t this.next_out = 0;\n\t /* remaining free space at output */\n\t this.avail_out = 0;\n\t /* total number of bytes output so far */\n\t this.total_out = 0;\n\t /* last error message, NULL if no error */\n\t this.msg = ''/*Z_NULL*/;\n\t /* not visible by applications */\n\t this.state = null;\n\t /* best guess about the data type: binary or text */\n\t this.data_type = 2/*Z_UNKNOWN*/;\n\t /* adler32 value of the uncompressed data */\n\t this.adler = 0;\n\t}\n\t\n\tmodule.exports = ZStream;\n\n\n/***/ },\n/* 34 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tmodule.exports = __webpack_require__(2)\n\n\n/***/ },\n/* 35 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tvar Buffer = __webpack_require__(1).Buffer;\n\t/**/\n\tvar bufferShim = __webpack_require__(10);\n\t/**/\n\t\n\tmodule.exports = BufferList;\n\t\n\tfunction BufferList() {\n\t this.head = null;\n\t this.tail = null;\n\t this.length = 0;\n\t}\n\t\n\tBufferList.prototype.push = function (v) {\n\t var entry = { data: v, next: null };\n\t if (this.length > 0) this.tail.next = entry;else this.head = entry;\n\t this.tail = entry;\n\t ++this.length;\n\t};\n\t\n\tBufferList.prototype.unshift = function (v) {\n\t var entry = { data: v, next: this.head };\n\t if (this.length === 0) this.tail = entry;\n\t this.head = entry;\n\t ++this.length;\n\t};\n\t\n\tBufferList.prototype.shift = function () {\n\t if (this.length === 0) return;\n\t var ret = this.head.data;\n\t if (this.length === 1) this.head = this.tail = null;else this.head = this.head.next;\n\t --this.length;\n\t return ret;\n\t};\n\t\n\tBufferList.prototype.clear = function () {\n\t this.head = this.tail = null;\n\t this.length = 0;\n\t};\n\t\n\tBufferList.prototype.join = function (s) {\n\t if (this.length === 0) return '';\n\t var p = this.head;\n\t var ret = '' + p.data;\n\t while (p = p.next) {\n\t ret += s + p.data;\n\t }return ret;\n\t};\n\t\n\tBufferList.prototype.concat = function (n) {\n\t if (this.length === 0) return bufferShim.alloc(0);\n\t if (this.length === 1) return this.head.data;\n\t var ret = bufferShim.allocUnsafe(n >>> 0);\n\t var p = this.head;\n\t var i = 0;\n\t while (p) {\n\t p.data.copy(ret, i);\n\t i += p.data.length;\n\t p = p.next;\n\t }\n\t return ret;\n\t};\n\n/***/ },\n/* 36 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tmodule.exports = __webpack_require__(15)\n\n\n/***/ },\n/* 37 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t/* WEBPACK VAR INJECTION */(function(process) {var Stream = (function (){\n\t try {\n\t return __webpack_require__(9); // hack to fix a circular dependency issue when used with browserify\n\t } catch(_){}\n\t}());\n\texports = module.exports = __webpack_require__(16);\n\texports.Stream = Stream || exports;\n\texports.Readable = exports;\n\texports.Writable = __webpack_require__(13);\n\texports.Duplex = __webpack_require__(2);\n\texports.Transform = __webpack_require__(12);\n\texports.PassThrough = __webpack_require__(15);\n\t\n\tif (!process.browser && process.env.READABLE_STREAM === 'disable' && Stream) {\n\t module.exports = Stream;\n\t}\n\t\n\t/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(3)))\n\n/***/ },\n/* 38 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tmodule.exports = __webpack_require__(12)\n\n\n/***/ },\n/* 39 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tmodule.exports = __webpack_require__(13)\n\n\n/***/ },\n/* 40 */\n/***/ function(module, exports) {\n\n\t/* WEBPACK VAR INJECTION */(function(global) {\n\t/**\n\t * Module exports.\n\t */\n\t\n\tmodule.exports = deprecate;\n\t\n\t/**\n\t * Mark that a method should not be used.\n\t * Returns a modified function which warns once by default.\n\t *\n\t * If `localStorage.noDeprecation = true` is set, then it is a no-op.\n\t *\n\t * If `localStorage.throwDeprecation = true` is set, then deprecated functions\n\t * will throw an Error when invoked.\n\t *\n\t * If `localStorage.traceDeprecation = true` is set, then deprecated functions\n\t * will invoke `console.trace()` instead of `console.error()`.\n\t *\n\t * @param {Function} fn - the function to deprecate\n\t * @param {String} msg - the string to print to the console when `fn` is invoked\n\t * @returns {Function} a new \"deprecated\" version of `fn`\n\t * @api public\n\t */\n\t\n\tfunction deprecate (fn, msg) {\n\t if (config('noDeprecation')) {\n\t return fn;\n\t }\n\t\n\t var warned = false;\n\t function deprecated() {\n\t if (!warned) {\n\t if (config('throwDeprecation')) {\n\t throw new Error(msg);\n\t } else if (config('traceDeprecation')) {\n\t console.trace(msg);\n\t } else {\n\t console.warn(msg);\n\t }\n\t warned = true;\n\t }\n\t return fn.apply(this, arguments);\n\t }\n\t\n\t return deprecated;\n\t}\n\t\n\t/**\n\t * Checks `localStorage` for boolean values for the given `name`.\n\t *\n\t * @param {String} name\n\t * @returns {Boolean}\n\t * @api private\n\t */\n\t\n\tfunction config (name) {\n\t // accessing global.localStorage can trigger a DOMException in sandboxed iframes\n\t try {\n\t if (!global.localStorage) return false;\n\t } catch (_) {\n\t return false;\n\t }\n\t var val = global.localStorage[name];\n\t if (null == val) return false;\n\t return String(val).toLowerCase() === 'true';\n\t}\n\t\n\t/* WEBPACK VAR INJECTION */}.call(exports, (function() { return this; }())))\n\n/***/ },\n/* 41 */\n/***/ function(module, exports) {\n\n\tmodule.exports = function(module) {\r\n\t\tif(!module.webpackPolyfill) {\r\n\t\t\tmodule.deprecate = function() {};\r\n\t\t\tmodule.paths = [];\r\n\t\t\t// module.parent = undefined by default\r\n\t\t\tmodule.children = [];\r\n\t\t\tmodule.webpackPolyfill = 1;\r\n\t\t}\r\n\t\treturn module;\r\n\t}\r\n\n\n/***/ },\n/* 42 */\n/***/ function(module, exports) {\n\n\t/* (ignored) */\n\n/***/ }\n/******/ ])\n});\n;\n\n\n// WEBPACK FOOTER //\n// ../build/browserfs.min.js"," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId])\n \t\t\treturn installedModules[moduleId].exports;\n\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\texports: {},\n \t\t\tid: moduleId,\n \t\t\tloaded: false\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.loaded = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(0);\n\n\n\n// WEBPACK FOOTER //\n// webpack/bootstrap 971c321eaacbc0b5e6c1","import {File} from './file';\nimport {ApiError, ErrorCode} from './api_error';\nimport {FileSystem, BFSOneArgCallback, BFSCallback, BFSThreeArgCallback} from './file_system';\nimport {FileFlag} from './file_flag';\nimport * as path from 'path';\nimport Stats from './node_fs_stats';\n\n// Typing info only.\nimport * as _fs from 'fs';\n\n/**\n * Wraps a callback function. Used for unit testing. Defaults to a NOP.\n */\nlet wrapCb = function(cb: T, numArgs: number): T {\n return cb;\n};\n\nfunction assertRoot(fs?: FileSystem | null): FileSystem {\n if (fs) {\n return fs;\n }\n throw new ApiError(ErrorCode.EIO, `Initialize BrowserFS with a file system using BrowserFS.initialize(filesystem)`);\n}\n\nfunction normalizeMode(mode: number | string | null | undefined, def: number): number {\n switch (typeof mode) {\n case 'number':\n // (path, flag, mode, cb?)\n return mode;\n case 'string':\n // (path, flag, modeString, cb?)\n const trueMode = parseInt( mode, 8);\n if (!isNaN(trueMode)) {\n return trueMode;\n }\n // Invalid string.\n return def;\n default:\n return def;\n }\n}\n\nfunction normalizeTime(time: number | Date): Date {\n if (time instanceof Date) {\n return time;\n } else if (typeof time === 'number') {\n return new Date(time * 1000);\n } else {\n throw new ApiError(ErrorCode.EINVAL, `Invalid time.`);\n }\n}\n\nfunction normalizePath(p: string): string {\n // Node doesn't allow null characters in paths.\n if (p.indexOf('\\u0000') >= 0) {\n throw new ApiError(ErrorCode.EINVAL, 'Path must be a string without null bytes.');\n } else if (p === '') {\n throw new ApiError(ErrorCode.EINVAL, 'Path must not be empty.');\n }\n return path.resolve(p);\n}\n\nfunction normalizeOptions(options: any, defEnc: string | null, defFlag: string, defMode: number | null): {encoding: string; flag: string; mode: number} {\n switch (typeof options) {\n case 'object':\n return {\n encoding: typeof options['encoding'] !== 'undefined' ? options['encoding'] : defEnc,\n flag: typeof options['flag'] !== 'undefined' ? options['flag'] : defFlag,\n mode: normalizeMode(options['mode'], defMode!)\n };\n case 'string':\n return {\n encoding: options,\n flag: defFlag,\n mode: defMode!\n };\n default:\n return {\n encoding: defEnc!,\n flag: defFlag,\n mode: defMode!\n };\n }\n}\n\n// The default callback is a NOP.\nfunction nopCb() {\n // NOP.\n}\n\n/**\n * The node frontend to all filesystems.\n * This layer handles:\n *\n * * Sanity checking inputs.\n * * Normalizing paths.\n * * Resetting stack depth for asynchronous operations which may not go through\n * the browser by wrapping all input callbacks using `setImmediate`.\n * * Performing the requested operation through the filesystem or the file\n * descriptor, as appropriate.\n * * Handling optional arguments and setting default arguments.\n * @see http://nodejs.org/api/fs.html\n * @class\n */\nexport default class FS {\n /* tslint:disable:variable-name */\n // Exported fs.Stats.\n public static Stats = Stats;\n /* tslint:enable:variable-name */\n\n public F_OK: number = 0;\n public R_OK: number = 4;\n public W_OK: number = 2;\n public X_OK: number = 1;\n\n private root: FileSystem | null = null;\n private fdMap: {[fd: number]: File} = {};\n private nextFd = 100;\n\n public initialize(rootFS: FileSystem): FileSystem {\n if (!( rootFS).constructor.isAvailable()) {\n throw new ApiError(ErrorCode.EINVAL, 'Tried to instantiate BrowserFS with an unavailable file system.');\n }\n return this.root = rootFS;\n }\n\n /**\n * converts Date or number to a fractional UNIX timestamp\n * Grabbed from NodeJS sources (lib/fs.js)\n */\n public _toUnixTimestamp(time: Date | number): number {\n if (typeof time === 'number') {\n return time;\n } else if (time instanceof Date) {\n return time.getTime() / 1000;\n }\n throw new Error(\"Cannot parse time: \" + time);\n }\n\n /**\n * **NONSTANDARD**: Grab the FileSystem instance that backs this API.\n * @return [BrowserFS.FileSystem | null] Returns null if the file system has\n * not been initialized.\n */\n public getRootFS(): FileSystem | null {\n if (this.root) {\n return this.root;\n } else {\n return null;\n }\n }\n\n // FILE OR DIRECTORY METHODS\n\n /**\n * Asynchronous rename. No arguments other than a possible exception are given\n * to the completion callback.\n * @param oldPath\n * @param newPath\n * @param callback\n */\n public rename(oldPath: string, newPath: string, cb: BFSOneArgCallback = nopCb): void {\n const newCb = wrapCb(cb, 1);\n try {\n assertRoot(this.root).rename(normalizePath(oldPath), normalizePath(newPath), newCb);\n } catch (e) {\n newCb(e);\n }\n }\n\n /**\n * Synchronous rename.\n * @param oldPath\n * @param newPath\n */\n public renameSync(oldPath: string, newPath: string): void {\n assertRoot(this.root).renameSync(normalizePath(oldPath), normalizePath(newPath));\n }\n\n /**\n * Test whether or not the given path exists by checking with the file system.\n * Then call the callback argument with either true or false.\n * @example Sample invocation\n * fs.exists('/etc/passwd', function (exists) {\n * util.debug(exists ? \"it's there\" : \"no passwd!\");\n * });\n * @param path\n * @param callback\n */\n public exists(path: string, cb: (exists: boolean) => any = nopCb): void {\n const newCb = wrapCb(cb, 1);\n try {\n return assertRoot(this.root).exists(normalizePath(path), newCb);\n } catch (e) {\n // Doesn't return an error. If something bad happens, we assume it just\n // doesn't exist.\n return newCb(false);\n }\n }\n\n /**\n * Test whether or not the given path exists by checking with the file system.\n * @param path\n * @return [boolean]\n */\n public existsSync(path: string): boolean {\n try {\n return assertRoot(this.root).existsSync(normalizePath(path));\n } catch (e) {\n // Doesn't return an error. If something bad happens, we assume it just\n // doesn't exist.\n return false;\n }\n }\n\n /**\n * Asynchronous `stat`.\n * @param path\n * @param callback\n */\n public stat(path: string, cb: BFSCallback = nopCb): void {\n const newCb = wrapCb(cb, 2);\n try {\n return assertRoot(this.root).stat(normalizePath(path), false, newCb);\n } catch (e) {\n return newCb(e);\n }\n }\n\n /**\n * Synchronous `stat`.\n * @param path\n * @return [BrowserFS.node.fs.Stats]\n */\n public statSync(path: string): Stats {\n return assertRoot(this.root).statSync(normalizePath(path), false);\n }\n\n /**\n * Asynchronous `lstat`.\n * `lstat()` is identical to `stat()`, except that if path is a symbolic link,\n * then the link itself is stat-ed, not the file that it refers to.\n * @param path\n * @param callback\n */\n public lstat(path: string, cb: BFSCallback = nopCb): void {\n const newCb = wrapCb(cb, 2);\n try {\n return assertRoot(this.root).stat(normalizePath(path), true, newCb);\n } catch (e) {\n return newCb(e);\n }\n }\n\n /**\n * Synchronous `lstat`.\n * `lstat()` is identical to `stat()`, except that if path is a symbolic link,\n * then the link itself is stat-ed, not the file that it refers to.\n * @param path\n * @return [BrowserFS.node.fs.Stats]\n */\n public lstatSync(path: string): Stats {\n return assertRoot(this.root).statSync(normalizePath(path), true);\n }\n\n // FILE-ONLY METHODS\n\n /**\n * Asynchronous `truncate`.\n * @param path\n * @param len\n * @param callback\n */\n public truncate(path: string, cb?: BFSOneArgCallback): void;\n public truncate(path: string, len: number, cb?: BFSOneArgCallback): void;\n public truncate(path: string, arg2: any = 0, cb: BFSOneArgCallback = nopCb): void {\n let len = 0;\n if (typeof arg2 === 'function') {\n cb = arg2;\n } else if (typeof arg2 === 'number') {\n len = arg2;\n }\n\n const newCb = wrapCb(cb, 1);\n try {\n if (len < 0) {\n throw new ApiError(ErrorCode.EINVAL);\n }\n return assertRoot(this.root).truncate(normalizePath(path), len, newCb);\n } catch (e) {\n return newCb(e);\n }\n }\n\n /**\n * Synchronous `truncate`.\n * @param path\n * @param len\n */\n public truncateSync(path: string, len: number = 0): void {\n if (len < 0) {\n throw new ApiError(ErrorCode.EINVAL);\n }\n return assertRoot(this.root).truncateSync(normalizePath(path), len);\n }\n\n /**\n * Asynchronous `unlink`.\n * @param path\n * @param callback\n */\n public unlink(path: string, cb: BFSOneArgCallback = nopCb): void {\n const newCb = wrapCb(cb, 1);\n try {\n return assertRoot(this.root).unlink(normalizePath(path), newCb);\n } catch (e) {\n return newCb(e);\n }\n }\n\n /**\n * Synchronous `unlink`.\n * @param path\n */\n public unlinkSync(path: string): void {\n return assertRoot(this.root).unlinkSync(normalizePath(path));\n }\n\n /**\n * Asynchronous file open.\n * Exclusive mode ensures that path is newly created.\n *\n * `flags` can be:\n *\n * * `'r'` - Open file for reading. An exception occurs if the file does not exist.\n * * `'r+'` - Open file for reading and writing. An exception occurs if the file does not exist.\n * * `'rs'` - Open file for reading in synchronous mode. Instructs the filesystem to not cache writes.\n * * `'rs+'` - Open file for reading and writing, and opens the file in synchronous mode.\n * * `'w'` - Open file for writing. The file is created (if it does not exist) or truncated (if it exists).\n * * `'wx'` - Like 'w' but opens the file in exclusive mode.\n * * `'w+'` - Open file for reading and writing. The file is created (if it does not exist) or truncated (if it exists).\n * * `'wx+'` - Like 'w+' but opens the file in exclusive mode.\n * * `'a'` - Open file for appending. The file is created if it does not exist.\n * * `'ax'` - Like 'a' but opens the file in exclusive mode.\n * * `'a+'` - Open file for reading and appending. The file is created if it does not exist.\n * * `'ax+'` - Like 'a+' but opens the file in exclusive mode.\n *\n * @see http://www.manpagez.com/man/2/open/\n * @param path\n * @param flags\n * @param mode defaults to `0644`\n * @param callback\n */\n public open(path: string, flag: string, cb?: BFSCallback): void;\n public open(path: string, flag: string, mode: number|string, cb?: BFSCallback): void;\n public open(path: string, flag: string, arg2?: any, cb: BFSCallback = nopCb): void {\n const mode = normalizeMode(arg2, 0x1a4);\n cb = typeof arg2 === 'function' ? arg2 : cb;\n const newCb = wrapCb(cb, 2);\n try {\n assertRoot(this.root).open(normalizePath(path), FileFlag.getFileFlag(flag), mode, (e: ApiError, file?: File) => {\n if (file) {\n newCb(e, this.getFdForFile(file));\n } else {\n newCb(e);\n }\n });\n } catch (e) {\n newCb(e);\n }\n }\n\n /**\n * Synchronous file open.\n * @see http://www.manpagez.com/man/2/open/\n * @param path\n * @param flags\n * @param mode defaults to `0644`\n * @return [BrowserFS.File]\n */\n public openSync(path: string, flag: string, mode: number|string = 0x1a4): number {\n return this.getFdForFile(\n assertRoot(this.root).openSync(normalizePath(path), FileFlag.getFileFlag(flag), normalizeMode(mode, 0x1a4)));\n }\n\n /**\n * Asynchronously reads the entire contents of a file.\n * @example Usage example\n * fs.readFile('/etc/passwd', function (err, data) {\n * if (err) throw err;\n * console.log(data);\n * });\n * @param filename\n * @param options\n * @option options [String] encoding The string encoding for the file contents. Defaults to `null`.\n * @option options [String] flag Defaults to `'r'`.\n * @param callback If no encoding is specified, then the raw buffer is returned.\n */\n public readFile(filename: string, cb: BFSCallback): void;\n public readFile(filename: string, options: { flag?: string; }, callback: BFSCallback): void;\n public readFile(filename: string, options: { encoding: string; flag?: string; }, callback: BFSCallback): void;\n public readFile(filename: string, encoding: string, cb?: BFSCallback): void;\n public readFile(filename: string, arg2: any = {}, cb: BFSCallback = nopCb ) {\n const options = normalizeOptions(arg2, null, 'r', null);\n cb = typeof arg2 === 'function' ? arg2 : cb;\n const newCb = wrapCb(cb, 2);\n try {\n const flag = FileFlag.getFileFlag(options['flag']);\n if (!flag.isReadable()) {\n return newCb(new ApiError(ErrorCode.EINVAL, 'Flag passed to readFile must allow for reading.'));\n }\n return assertRoot(this.root).readFile(normalizePath(filename), options.encoding, flag, newCb);\n } catch (e) {\n return newCb(e);\n }\n }\n\n /**\n * Synchronously reads the entire contents of a file.\n * @param filename\n * @param options\n * @option options [String] encoding The string encoding for the file contents. Defaults to `null`.\n * @option options [String] flag Defaults to `'r'`.\n * @return [String | BrowserFS.node.Buffer]\n */\n public readFileSync(filename: string, options?: { flag?: string; }): Buffer;\n public readFileSync(filename: string, options: { encoding: string; flag?: string; }): string;\n public readFileSync(filename: string, encoding: string): string;\n public readFileSync(filename: string, arg2: any = {}): any {\n const options = normalizeOptions(arg2, null, 'r', null);\n const flag = FileFlag.getFileFlag(options.flag);\n if (!flag.isReadable()) {\n throw new ApiError(ErrorCode.EINVAL, 'Flag passed to readFile must allow for reading.');\n }\n return assertRoot(this.root).readFileSync(normalizePath(filename), options.encoding, flag);\n }\n\n /**\n * Asynchronously writes data to a file, replacing the file if it already\n * exists.\n *\n * The encoding option is ignored if data is a buffer.\n *\n * @example Usage example\n * fs.writeFile('message.txt', 'Hello Node', function (err) {\n * if (err) throw err;\n * console.log('It\\'s saved!');\n * });\n * @param filename\n * @param data\n * @param options\n * @option options [String] encoding Defaults to `'utf8'`.\n * @option options [Number] mode Defaults to `0644`.\n * @option options [String] flag Defaults to `'w'`.\n * @param callback\n */\n public writeFile(filename: string, data: any, cb?: BFSOneArgCallback): void;\n public writeFile(filename: string, data: any, encoding?: string, cb?: BFSOneArgCallback): void;\n public writeFile(filename: string, data: any, options?: { encoding?: string; mode?: string | number; flag?: string; }, cb?: BFSOneArgCallback): void;\n public writeFile(filename: string, data: any, arg3: any = {}, cb: BFSOneArgCallback = nopCb): void {\n const options = normalizeOptions(arg3, 'utf8', 'w', 0x1a4);\n cb = typeof arg3 === 'function' ? arg3 : cb;\n const newCb = wrapCb(cb, 1);\n try {\n const flag = FileFlag.getFileFlag(options.flag);\n if (!flag.isWriteable()) {\n return newCb(new ApiError(ErrorCode.EINVAL, 'Flag passed to writeFile must allow for writing.'));\n }\n return assertRoot(this.root).writeFile(normalizePath(filename), data, options.encoding, flag, options.mode, newCb);\n } catch (e) {\n return newCb(e);\n }\n }\n\n /**\n * Synchronously writes data to a file, replacing the file if it already\n * exists.\n *\n * The encoding option is ignored if data is a buffer.\n * @param filename\n * @param data\n * @param options\n * @option options [String] encoding Defaults to `'utf8'`.\n * @option options [Number] mode Defaults to `0644`.\n * @option options [String] flag Defaults to `'w'`.\n */\n public writeFileSync(filename: string, data: any, options?: { encoding?: string; mode?: number | string; flag?: string; }): void;\n public writeFileSync(filename: string, data: any, encoding?: string): void;\n public writeFileSync(filename: string, data: any, arg3?: any): void {\n const options = normalizeOptions(arg3, 'utf8', 'w', 0x1a4);\n const flag = FileFlag.getFileFlag(options.flag);\n if (!flag.isWriteable()) {\n throw new ApiError(ErrorCode.EINVAL, 'Flag passed to writeFile must allow for writing.');\n }\n return assertRoot(this.root).writeFileSync(normalizePath(filename), data, options.encoding, flag, options.mode);\n }\n\n /**\n * Asynchronously append data to a file, creating the file if it not yet\n * exists.\n *\n * @example Usage example\n * fs.appendFile('message.txt', 'data to append', function (err) {\n * if (err) throw err;\n * console.log('The \"data to append\" was appended to file!');\n * });\n * @param filename\n * @param data\n * @param options\n * @option options [String] encoding Defaults to `'utf8'`.\n * @option options [Number] mode Defaults to `0644`.\n * @option options [String] flag Defaults to `'a'`.\n * @param callback\n */\n public appendFile(filename: string, data: any, cb?: BFSOneArgCallback): void;\n public appendFile(filename: string, data: any, options?: { encoding?: string; mode?: number|string; flag?: string; }, cb?: BFSOneArgCallback): void;\n public appendFile(filename: string, data: any, encoding?: string, cb?: BFSOneArgCallback): void;\n public appendFile(filename: string, data: any, arg3?: any, cb: BFSOneArgCallback = nopCb): void {\n const options = normalizeOptions(arg3, 'utf8', 'a', 0x1a4);\n cb = typeof arg3 === 'function' ? arg3 : cb;\n const newCb = wrapCb(cb, 1);\n try {\n const flag = FileFlag.getFileFlag(options.flag);\n if (!flag.isAppendable()) {\n return newCb(new ApiError(ErrorCode.EINVAL, 'Flag passed to appendFile must allow for appending.'));\n }\n assertRoot(this.root).appendFile(normalizePath(filename), data, options.encoding, flag, options.mode, newCb);\n } catch (e) {\n newCb(e);\n }\n }\n\n /**\n * Asynchronously append data to a file, creating the file if it not yet\n * exists.\n *\n * @example Usage example\n * fs.appendFile('message.txt', 'data to append', function (err) {\n * if (err) throw err;\n * console.log('The \"data to append\" was appended to file!');\n * });\n * @param filename\n * @param data\n * @param options\n * @option options [String] encoding Defaults to `'utf8'`.\n * @option options [Number] mode Defaults to `0644`.\n * @option options [String] flag Defaults to `'a'`.\n */\n public appendFileSync(filename: string, data: any, options?: { encoding?: string; mode?: number | string; flag?: string; }): void;\n public appendFileSync(filename: string, data: any, encoding?: string): void;\n public appendFileSync(filename: string, data: any, arg3?: any): void {\n const options = normalizeOptions(arg3, 'utf8', 'a', 0x1a4);\n const flag = FileFlag.getFileFlag(options.flag);\n if (!flag.isAppendable()) {\n throw new ApiError(ErrorCode.EINVAL, 'Flag passed to appendFile must allow for appending.');\n }\n return assertRoot(this.root).appendFileSync(normalizePath(filename), data, options.encoding, flag, options.mode);\n }\n\n // FILE DESCRIPTOR METHODS\n\n /**\n * Asynchronous `fstat`.\n * `fstat()` is identical to `stat()`, except that the file to be stat-ed is\n * specified by the file descriptor `fd`.\n * @param fd\n * @param callback\n */\n public fstat(fd: number, cb: BFSCallback = nopCb): void {\n const newCb = wrapCb(cb, 2);\n try {\n const file = this.fd2file(fd);\n file.stat(newCb);\n } catch (e) {\n newCb(e);\n }\n }\n\n /**\n * Synchronous `fstat`.\n * `fstat()` is identical to `stat()`, except that the file to be stat-ed is\n * specified by the file descriptor `fd`.\n * @param fd\n * @return [BrowserFS.node.fs.Stats]\n */\n public fstatSync(fd: number): Stats {\n return this.fd2file(fd).statSync();\n }\n\n /**\n * Asynchronous close.\n * @param fd\n * @param callback\n */\n public close(fd: number, cb: BFSOneArgCallback = nopCb): void {\n const newCb = wrapCb(cb, 1);\n try {\n this.fd2file(fd).close((e: ApiError) => {\n if (!e) {\n this.closeFd(fd);\n }\n newCb(e);\n });\n } catch (e) {\n newCb(e);\n }\n }\n\n /**\n * Synchronous close.\n * @param fd\n */\n public closeSync(fd: number): void {\n this.fd2file(fd).closeSync();\n this.closeFd(fd);\n }\n\n /**\n * Asynchronous ftruncate.\n * @param fd\n * @param len\n * @param callback\n */\n public ftruncate(fd: number, cb?: BFSOneArgCallback): void;\n public ftruncate(fd: number, len?: number, cb?: BFSOneArgCallback): void;\n public ftruncate(fd: number, arg2?: any, cb: BFSOneArgCallback = nopCb): void {\n const length = typeof arg2 === 'number' ? arg2 : 0;\n cb = typeof arg2 === 'function' ? arg2 : cb;\n const newCb = wrapCb(cb, 1);\n try {\n const file = this.fd2file(fd);\n if (length < 0) {\n throw new ApiError(ErrorCode.EINVAL);\n }\n file.truncate(length, newCb);\n } catch (e) {\n newCb(e);\n }\n }\n\n /**\n * Synchronous ftruncate.\n * @param fd\n * @param len\n */\n public ftruncateSync(fd: number, len: number = 0): void {\n const file = this.fd2file(fd);\n if (len < 0) {\n throw new ApiError(ErrorCode.EINVAL);\n }\n file.truncateSync(len);\n }\n\n /**\n * Asynchronous fsync.\n * @param fd\n * @param callback\n */\n public fsync(fd: number, cb: BFSOneArgCallback = nopCb): void {\n const newCb = wrapCb(cb, 1);\n try {\n this.fd2file(fd).sync(newCb);\n } catch (e) {\n newCb(e);\n }\n }\n\n /**\n * Synchronous fsync.\n * @param fd\n */\n public fsyncSync(fd: number): void {\n this.fd2file(fd).syncSync();\n }\n\n /**\n * Asynchronous fdatasync.\n * @param fd\n * @param callback\n */\n public fdatasync(fd: number, cb: BFSOneArgCallback = nopCb): void {\n const newCb = wrapCb(cb, 1);\n try {\n this.fd2file(fd).datasync(newCb);\n } catch (e) {\n newCb(e);\n }\n }\n\n /**\n * Synchronous fdatasync.\n * @param fd\n */\n public fdatasyncSync(fd: number): void {\n this.fd2file(fd).datasyncSync();\n }\n\n /**\n * Write buffer to the file specified by `fd`.\n * Note that it is unsafe to use fs.write multiple times on the same file\n * without waiting for the callback.\n * @param fd\n * @param buffer Buffer containing the data to write to\n * the file.\n * @param offset Offset in the buffer to start reading data from.\n * @param length The amount of bytes to write to the file.\n * @param position Offset from the beginning of the file where this\n * data should be written. If position is null, the data will be written at\n * the current position.\n * @param callback The number specifies the number of bytes written into the file.\n */\n public write(fd: number, buffer: Buffer, offset: number, length: number, cb?: BFSThreeArgCallback): void;\n public write(fd: number, buffer: Buffer, offset: number, length: number, position: number | null, cb?: BFSThreeArgCallback): void;\n public write(fd: number, data: any, cb?: BFSThreeArgCallback): void;\n public write(fd: number, data: any, position: number | null, cb?: BFSThreeArgCallback): void;\n public write(fd: number, data: any, position: number | null, encoding: string, cb?: BFSThreeArgCallback): void;\n public write(fd: number, arg2: any, arg3?: any, arg4?: any, arg5?: any, cb: BFSThreeArgCallback = nopCb): void {\n let buffer: Buffer, offset: number, length: number, position: number | null = null;\n if (typeof arg2 === 'string') {\n // Signature 1: (fd, string, [position?, [encoding?]], cb?)\n let encoding = 'utf8';\n switch (typeof arg3) {\n case 'function':\n // (fd, string, cb)\n cb = arg3;\n break;\n case 'number':\n // (fd, string, position, encoding?, cb?)\n position = arg3;\n encoding = typeof arg4 === 'string' ? arg4 : 'utf8';\n cb = typeof arg5 === 'function' ? arg5 : cb;\n break;\n default:\n // ...try to find the callback and get out of here!\n cb = typeof arg4 === 'function' ? arg4 : typeof arg5 === 'function' ? arg5 : cb;\n return cb(new ApiError(ErrorCode.EINVAL, 'Invalid arguments.'));\n }\n buffer = new Buffer(arg2, encoding);\n offset = 0;\n length = buffer.length;\n } else {\n // Signature 2: (fd, buffer, offset, length, position?, cb?)\n buffer = arg2;\n offset = arg3;\n length = arg4;\n position = typeof arg5 === 'number' ? arg5 : null;\n cb = typeof arg5 === 'function' ? arg5 : cb;\n }\n\n const newCb = wrapCb(cb, 3);\n try {\n const file = this.fd2file(fd);\n if (position === undefined || position === null) {\n position = file.getPos()!;\n }\n file.write(buffer, offset, length, position, newCb);\n } catch (e) {\n newCb(e);\n }\n }\n\n /**\n * Write buffer to the file specified by `fd`.\n * Note that it is unsafe to use fs.write multiple times on the same file\n * without waiting for it to return.\n * @param fd\n * @param buffer Buffer containing the data to write to\n * the file.\n * @param offset Offset in the buffer to start reading data from.\n * @param length The amount of bytes to write to the file.\n * @param position Offset from the beginning of the file where this\n * data should be written. If position is null, the data will be written at\n * the current position.\n */\n public writeSync(fd: number, buffer: Buffer, offset: number, length: number, position?: number | null): number;\n public writeSync(fd: number, data: string, position?: number | null, encoding?: string): number;\n public writeSync(fd: number, arg2: any, arg3?: any, arg4?: any, arg5?: any): number {\n let buffer: Buffer, offset: number = 0, length: number, position: number | null;\n if (typeof arg2 === 'string') {\n // Signature 1: (fd, string, [position?, [encoding?]])\n position = typeof arg3 === 'number' ? arg3 : null;\n const encoding = typeof arg4 === 'string' ? arg4 : 'utf8';\n offset = 0;\n buffer = new Buffer(arg2, encoding);\n length = buffer.length;\n } else {\n // Signature 2: (fd, buffer, offset, length, position?)\n buffer = arg2;\n offset = arg3;\n length = arg4;\n position = typeof arg5 === 'number' ? arg5 : null;\n }\n\n const file = this.fd2file(fd);\n if (position === undefined || position === null) {\n position = file.getPos()!;\n }\n return file.writeSync(buffer, offset, length, position);\n }\n\n /**\n * Read data from the file specified by `fd`.\n * @param buffer The buffer that the data will be\n * written to.\n * @param offset The offset within the buffer where writing will\n * start.\n * @param length An integer specifying the number of bytes to read.\n * @param position An integer specifying where to begin reading from\n * in the file. If position is null, data will be read from the current file\n * position.\n * @param callback The number is the number of bytes read\n */\n public read(fd: number, length: number, position: number | null, encoding: string, cb?: BFSThreeArgCallback): void;\n public read(fd: number, buffer: Buffer, offset: number, length: number, position: number | null, cb?: BFSThreeArgCallback): void;\n public read(fd: number, arg2: any, arg3: any, arg4: any, arg5?: any, cb: BFSThreeArgCallback | BFSThreeArgCallback = nopCb): void {\n let position: number | null, offset: number, length: number, buffer: Buffer, newCb: BFSThreeArgCallback;\n if (typeof arg2 === 'number') {\n // legacy interface\n // (fd, length, position, encoding, callback)\n length = arg2;\n position = arg3;\n const encoding = arg4;\n cb = typeof arg5 === 'function' ? arg5 : cb;\n offset = 0;\n buffer = new Buffer(length);\n // XXX: Inefficient.\n // Wrap the cb so we shelter upper layers of the API from these\n // shenanigans.\n newCb = wrapCb((err?: ApiError | null, bytesRead?: number, buf?: Buffer) => {\n if (err) {\n return ( cb)(err);\n }\n (> cb)(err, buf!.toString(encoding), bytesRead!);\n }, 3);\n } else {\n buffer = arg2;\n offset = arg3;\n length = arg4;\n position = arg5;\n newCb = wrapCb(> cb, 3);\n }\n\n try {\n const file = this.fd2file(fd);\n if (position === undefined || position === null) {\n position = file.getPos()!;\n }\n file.read(buffer, offset, length, position, newCb);\n } catch (e) {\n newCb(e);\n }\n }\n\n /**\n * Read data from the file specified by `fd`.\n * @param fd\n * @param buffer The buffer that the data will be\n * written to.\n * @param offset The offset within the buffer where writing will\n * start.\n * @param length An integer specifying the number of bytes to read.\n * @param position An integer specifying where to begin reading from\n * in the file. If position is null, data will be read from the current file\n * position.\n * @return [Number]\n */\n public readSync(fd: number, length: number, position: number, encoding: string): string;\n public readSync(fd: number, buffer: Buffer, offset: number, length: number, position: number): number;\n public readSync(fd: number, arg2: any, arg3: any, arg4: any, arg5?: any): any {\n let shenanigans = false;\n let buffer: Buffer, offset: number, length: number, position: number, encoding: string = 'utf8';\n if (typeof arg2 === 'number') {\n length = arg2;\n position = arg3;\n encoding = arg4;\n offset = 0;\n buffer = new Buffer(length);\n shenanigans = true;\n } else {\n buffer = arg2;\n offset = arg3;\n length = arg4;\n position = arg5;\n }\n const file = this.fd2file(fd);\n if (position === undefined || position === null) {\n position = file.getPos()!;\n }\n\n const rv = file.readSync(buffer, offset, length, position);\n if (!shenanigans) {\n return rv;\n } else {\n return [buffer.toString(encoding), rv];\n }\n }\n\n /**\n * Asynchronous `fchown`.\n * @param fd\n * @param uid\n * @param gid\n * @param callback\n */\n public fchown(fd: number, uid: number, gid: number, callback: BFSOneArgCallback = nopCb): void {\n const newCb = wrapCb(callback, 1);\n try {\n this.fd2file(fd).chown(uid, gid, newCb);\n } catch (e) {\n newCb(e);\n }\n }\n\n /**\n * Synchronous `fchown`.\n * @param fd\n * @param uid\n * @param gid\n */\n public fchownSync(fd: number, uid: number, gid: number): void {\n this.fd2file(fd).chownSync(uid, gid);\n }\n\n /**\n * Asynchronous `fchmod`.\n * @param fd\n * @param mode\n * @param callback\n */\n public fchmod(fd: number, mode: string | number, cb: BFSOneArgCallback): void {\n const newCb = wrapCb(cb, 1);\n try {\n const numMode = typeof mode === 'string' ? parseInt(mode, 8) : mode;\n this.fd2file(fd).chmod(numMode, newCb);\n } catch (e) {\n newCb(e);\n }\n }\n\n /**\n * Synchronous `fchmod`.\n * @param fd\n * @param mode\n */\n public fchmodSync(fd: number, mode: number | string): void {\n const numMode = typeof mode === 'string' ? parseInt(mode, 8) : mode;\n this.fd2file(fd).chmodSync(numMode);\n }\n\n /**\n * Change the file timestamps of a file referenced by the supplied file\n * descriptor.\n * @param fd\n * @param atime\n * @param mtime\n * @param callback\n */\n public futimes(fd: number, atime: number | Date, mtime: number | Date, cb: BFSOneArgCallback = nopCb): void {\n const newCb = wrapCb(cb, 1);\n try {\n const file = this.fd2file(fd);\n if (typeof atime === 'number') {\n atime = new Date(atime * 1000);\n }\n if (typeof mtime === 'number') {\n mtime = new Date(mtime * 1000);\n }\n file.utimes(atime, mtime, newCb);\n } catch (e) {\n newCb(e);\n }\n }\n\n /**\n * Change the file timestamps of a file referenced by the supplied file\n * descriptor.\n * @param fd\n * @param atime\n * @param mtime\n */\n public futimesSync(fd: number, atime: number | Date, mtime: number | Date): void {\n this.fd2file(fd).utimesSync(normalizeTime(atime), normalizeTime(mtime));\n }\n\n // DIRECTORY-ONLY METHODS\n\n /**\n * Asynchronous `rmdir`.\n * @param path\n * @param callback\n */\n public rmdir(path: string, cb: BFSOneArgCallback = nopCb): void {\n const newCb = wrapCb(cb, 1);\n try {\n path = normalizePath(path);\n assertRoot(this.root).rmdir(path, newCb);\n } catch (e) {\n newCb(e);\n }\n }\n\n /**\n * Synchronous `rmdir`.\n * @param path\n */\n public rmdirSync(path: string): void {\n path = normalizePath(path);\n return assertRoot(this.root).rmdirSync(path);\n }\n\n /**\n * Asynchronous `mkdir`.\n * @param path\n * @param mode defaults to `0777`\n * @param callback\n */\n public mkdir(path: string, mode?: any, cb: BFSOneArgCallback = nopCb): void {\n if (typeof mode === 'function') {\n cb = mode;\n mode = 0x1ff;\n }\n const newCb = wrapCb(cb, 1);\n try {\n path = normalizePath(path);\n assertRoot(this.root).mkdir(path, mode, newCb);\n } catch (e) {\n newCb(e);\n }\n }\n\n /**\n * Synchronous `mkdir`.\n * @param path\n * @param mode defaults to `0777`\n */\n public mkdirSync(path: string, mode?: number | string): void {\n assertRoot(this.root).mkdirSync(normalizePath(path), normalizeMode(mode, 0x1ff));\n }\n\n /**\n * Asynchronous `readdir`. Reads the contents of a directory.\n * The callback gets two arguments `(err, files)` where `files` is an array of\n * the names of the files in the directory excluding `'.'` and `'..'`.\n * @param path\n * @param callback\n */\n public readdir(path: string, cb: BFSCallback = nopCb): void {\n const newCb = <(err: ApiError, files?: string[]) => void> wrapCb(cb, 2);\n try {\n path = normalizePath(path);\n assertRoot(this.root).readdir(path, newCb);\n } catch (e) {\n newCb(e);\n }\n }\n\n /**\n * Synchronous `readdir`. Reads the contents of a directory.\n * @param path\n * @return [String[]]\n */\n public readdirSync(path: string): string[] {\n path = normalizePath(path);\n return assertRoot(this.root).readdirSync(path);\n }\n\n // SYMLINK METHODS\n\n /**\n * Asynchronous `link`.\n * @param srcpath\n * @param dstpath\n * @param callback\n */\n public link(srcpath: string, dstpath: string, cb: BFSOneArgCallback = nopCb): void {\n const newCb = wrapCb(cb, 1);\n try {\n srcpath = normalizePath(srcpath);\n dstpath = normalizePath(dstpath);\n assertRoot(this.root).link(srcpath, dstpath, newCb);\n } catch (e) {\n newCb(e);\n }\n }\n\n /**\n * Synchronous `link`.\n * @param srcpath\n * @param dstpath\n */\n public linkSync(srcpath: string, dstpath: string): void {\n srcpath = normalizePath(srcpath);\n dstpath = normalizePath(dstpath);\n return assertRoot(this.root).linkSync(srcpath, dstpath);\n }\n\n /**\n * Asynchronous `symlink`.\n * @param srcpath\n * @param dstpath\n * @param type can be either `'dir'` or `'file'` (default is `'file'`)\n * @param callback\n */\n public symlink(srcpath: string, dstpath: string, cb?: BFSOneArgCallback): void;\n public symlink(srcpath: string, dstpath: string, type?: string, cb?: BFSOneArgCallback): void;\n public symlink(srcpath: string, dstpath: string, arg3?: any, cb: BFSOneArgCallback = nopCb): void {\n const type = typeof arg3 === 'string' ? arg3 : 'file';\n cb = typeof arg3 === 'function' ? arg3 : cb;\n const newCb = wrapCb(cb, 1);\n try {\n if (type !== 'file' && type !== 'dir') {\n return newCb(new ApiError(ErrorCode.EINVAL, \"Invalid type: \" + type));\n }\n srcpath = normalizePath(srcpath);\n dstpath = normalizePath(dstpath);\n assertRoot(this.root).symlink(srcpath, dstpath, type, newCb);\n } catch (e) {\n newCb(e);\n }\n }\n\n /**\n * Synchronous `symlink`.\n * @param srcpath\n * @param dstpath\n * @param type can be either `'dir'` or `'file'` (default is `'file'`)\n */\n public symlinkSync(srcpath: string, dstpath: string, type?: string): void {\n if (!type) {\n type = 'file';\n } else if (type !== 'file' && type !== 'dir') {\n throw new ApiError(ErrorCode.EINVAL, \"Invalid type: \" + type);\n }\n srcpath = normalizePath(srcpath);\n dstpath = normalizePath(dstpath);\n return assertRoot(this.root).symlinkSync(srcpath, dstpath, type);\n }\n\n /**\n * Asynchronous readlink.\n * @param path\n * @param callback\n */\n public readlink(path: string, cb: BFSCallback = nopCb): void {\n const newCb = wrapCb(cb, 2);\n try {\n path = normalizePath(path);\n assertRoot(this.root).readlink(path, newCb);\n } catch (e) {\n newCb(e);\n }\n }\n\n /**\n * Synchronous readlink.\n * @param path\n * @return [String]\n */\n public readlinkSync(path: string): string {\n path = normalizePath(path);\n return assertRoot(this.root).readlinkSync(path);\n }\n\n // PROPERTY OPERATIONS\n\n /**\n * Asynchronous `chown`.\n * @param path\n * @param uid\n * @param gid\n * @param callback\n */\n public chown(path: string, uid: number, gid: number, cb: BFSOneArgCallback = nopCb): void {\n const newCb = wrapCb(cb, 1);\n try {\n path = normalizePath(path);\n assertRoot(this.root).chown(path, false, uid, gid, newCb);\n } catch (e) {\n newCb(e);\n }\n }\n\n /**\n * Synchronous `chown`.\n * @param path\n * @param uid\n * @param gid\n */\n public chownSync(path: string, uid: number, gid: number): void {\n path = normalizePath(path);\n assertRoot(this.root).chownSync(path, false, uid, gid);\n }\n\n /**\n * Asynchronous `lchown`.\n * @param path\n * @param uid\n * @param gid\n * @param callback\n */\n public lchown(path: string, uid: number, gid: number, cb: BFSOneArgCallback = nopCb): void {\n const newCb = wrapCb(cb, 1);\n try {\n path = normalizePath(path);\n assertRoot(this.root).chown(path, true, uid, gid, newCb);\n } catch (e) {\n newCb(e);\n }\n }\n\n /**\n * Synchronous `lchown`.\n * @param path\n * @param uid\n * @param gid\n */\n public lchownSync(path: string, uid: number, gid: number): void {\n path = normalizePath(path);\n assertRoot(this.root).chownSync(path, true, uid, gid);\n }\n\n /**\n * Asynchronous `chmod`.\n * @param path\n * @param mode\n * @param callback\n */\n public chmod(path: string, mode: number | string, cb: BFSOneArgCallback = nopCb): void {\n const newCb = wrapCb(cb, 1);\n try {\n const numMode = normalizeMode(mode, -1);\n if (numMode < 0) {\n throw new ApiError(ErrorCode.EINVAL, `Invalid mode.`);\n }\n assertRoot(this.root).chmod(normalizePath(path), false, numMode, newCb);\n } catch (e) {\n newCb(e);\n }\n }\n\n /**\n * Synchronous `chmod`.\n * @param path\n * @param mode\n */\n public chmodSync(path: string, mode: string | number): void {\n const numMode = normalizeMode(mode, -1);\n if (numMode < 0) {\n throw new ApiError(ErrorCode.EINVAL, `Invalid mode.`);\n }\n path = normalizePath(path);\n assertRoot(this.root).chmodSync(path, false, numMode);\n }\n\n /**\n * Asynchronous `lchmod`.\n * @param path\n * @param mode\n * @param callback\n */\n public lchmod(path: string, mode: number | string, cb: BFSOneArgCallback = nopCb): void {\n const newCb = wrapCb(cb, 1);\n try {\n const numMode = normalizeMode(mode, -1);\n if (numMode < 0) {\n throw new ApiError(ErrorCode.EINVAL, `Invalid mode.`);\n }\n assertRoot(this.root).chmod(normalizePath(path), true, numMode, newCb);\n } catch (e) {\n newCb(e);\n }\n }\n\n /**\n * Synchronous `lchmod`.\n * @param path\n * @param mode\n */\n public lchmodSync(path: string, mode: number | string): void {\n const numMode = normalizeMode(mode, -1);\n if (numMode < 1) {\n throw new ApiError(ErrorCode.EINVAL, `Invalid mode.`);\n }\n assertRoot(this.root).chmodSync(normalizePath(path), true, numMode);\n }\n\n /**\n * Change file timestamps of the file referenced by the supplied path.\n * @param path\n * @param atime\n * @param mtime\n * @param callback\n */\n public utimes(path: string, atime: number | Date, mtime: number | Date, cb: BFSOneArgCallback = nopCb): void {\n const newCb = wrapCb(cb, 1);\n try {\n assertRoot(this.root).utimes(normalizePath(path), normalizeTime(atime), normalizeTime(mtime), newCb);\n } catch (e) {\n newCb(e);\n }\n }\n\n /**\n * Change file timestamps of the file referenced by the supplied path.\n * @param path\n * @param atime\n * @param mtime\n */\n public utimesSync(path: string, atime: number | Date, mtime: number | Date): void {\n assertRoot(this.root).utimesSync(normalizePath(path), normalizeTime(atime), normalizeTime(mtime));\n }\n\n /**\n * Asynchronous `realpath`. The callback gets two arguments\n * `(err, resolvedPath)`. May use `process.cwd` to resolve relative paths.\n *\n * @example Usage example\n * let cache = {'/etc':'/private/etc'};\n * fs.realpath('/etc/passwd', cache, function (err, resolvedPath) {\n * if (err) throw err;\n * console.log(resolvedPath);\n * });\n *\n * @param path\n * @param cache An object literal of mapped paths that can be used to\n * force a specific path resolution or avoid additional `fs.stat` calls for\n * known real paths.\n * @param callback\n */\n public realpath(path: string, cb?: BFSCallback): void;\n public realpath(path: string, cache: {[path: string]: string}, cb: BFSCallback): void;\n public realpath(path: string, arg2?: any, cb: BFSCallback = nopCb): void {\n const cache = typeof(arg2) === 'object' ? arg2 : {};\n cb = typeof(arg2) === 'function' ? arg2 : nopCb;\n const newCb = <(err: ApiError, resolvedPath?: string) => any> wrapCb(cb, 2);\n try {\n path = normalizePath(path);\n assertRoot(this.root).realpath(path, cache, newCb);\n } catch (e) {\n newCb(e);\n }\n }\n\n /**\n * Synchronous `realpath`.\n * @param path\n * @param cache An object literal of mapped paths that can be used to\n * force a specific path resolution or avoid additional `fs.stat` calls for\n * known real paths.\n * @return [String]\n */\n public realpathSync(path: string, cache: {[path: string]: string} = {}): string {\n path = normalizePath(path);\n return assertRoot(this.root).realpathSync(path, cache);\n }\n\n public watchFile(filename: string, listener: (curr: Stats, prev: Stats) => void): void;\n public watchFile(filename: string, options: { persistent?: boolean; interval?: number; }, listener: (curr: Stats, prev: Stats) => void): void;\n public watchFile(filename: string, arg2: any, listener: (curr: Stats, prev: Stats) => void = nopCb): void {\n throw new ApiError(ErrorCode.ENOTSUP);\n }\n\n public unwatchFile(filename: string, listener: (curr: Stats, prev: Stats) => void = nopCb): void {\n throw new ApiError(ErrorCode.ENOTSUP);\n }\n\n public watch(filename: string, listener?: (event: string, filename: string) => any): _fs.FSWatcher;\n public watch(filename: string, options: { persistent?: boolean; }, listener?: (event: string, filename: string) => any): _fs.FSWatcher;\n public watch(filename: string, arg2: any, listener: (event: string, filename: string) => any = nopCb): _fs.FSWatcher {\n throw new ApiError(ErrorCode.ENOTSUP);\n }\n\n public access(path: string, callback: (err: ApiError) => void): void;\n public access(path: string, mode: number, callback: (err: ApiError) => void): void;\n public access(path: string, arg2: any, cb: (e: ApiError) => void = nopCb): void {\n throw new ApiError(ErrorCode.ENOTSUP);\n }\n\n public accessSync(path: string, mode?: number): void {\n throw new ApiError(ErrorCode.ENOTSUP);\n }\n\n public createReadStream(path: string, options?: {\n flags?: string;\n encoding?: string;\n fd?: number;\n mode?: number;\n autoClose?: boolean;\n }): _fs.ReadStream {\n throw new ApiError(ErrorCode.ENOTSUP);\n }\n\n public createWriteStream(path: string, options?: {\n flags?: string;\n encoding?: string;\n fd?: number;\n mode?: number;\n }): _fs.WriteStream {\n throw new ApiError(ErrorCode.ENOTSUP);\n }\n\n /**\n * For unit testing. Passes all incoming callbacks to cbWrapper for wrapping.\n */\n public wrapCallbacks(cbWrapper: (cb: Function, args: number) => Function) {\n wrapCb = cbWrapper;\n }\n\n private getFdForFile(file: File): number {\n const fd = this.nextFd++;\n this.fdMap[fd] = file;\n return fd;\n }\n private fd2file(fd: number): File {\n const rv = this.fdMap[fd];\n if (rv) {\n return rv;\n } else {\n throw new ApiError(ErrorCode.EBADF, 'Invalid file descriptor.');\n }\n }\n private closeFd(fd: number): void {\n delete this.fdMap[fd];\n }\n}\n\nexport interface FSModule extends FS {\n /**\n * The FS constructor.\n */\n FS: typeof FS;\n /**\n * Retrieve the FS object backing the fs module.\n */\n getFSModule(): FS;\n /**\n * Set the FS object backing the fs module.\n */\n changeFSModule(newFs: FS): void;\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../src/core/FS.ts","/**\n * Grab bag of utility functions used across the code.\n */\nimport {FileSystem} from './file_system';\nimport * as path from 'path';\n\n/**\n * Checks for any IE version, including IE11 which removed MSIE from the\n * userAgent string.\n */\nexport const isIE: boolean = typeof navigator !== \"undefined\" && !!(/(msie) ([\\w.]+)/.exec(navigator.userAgent.toLowerCase()) || navigator.userAgent.indexOf('Trident') !== -1);\n\n/**å\n * Check if we're in a web worker.\n */\nexport const isWebWorker: boolean = typeof window === \"undefined\";\n\nexport interface Arrayish {\n [idx: number]: T;\n length: number;\n}\n\n/**\n * Throws an exception. Called on code paths that should be impossible.\n */\nexport function fail() {\n throw new Error(\"BFS has reached an impossible code path; please file a bug.\");\n}\n\n/**\n * Synchronous recursive makedir.\n */\nexport function mkdirpSync(p: string, mode: number, fs: FileSystem): void {\n if (!fs.existsSync(p)) {\n mkdirpSync(path.dirname(p), mode, fs);\n fs.mkdirSync(p, mode);\n }\n}\n\n/**\n * Converts a buffer into an array buffer. Attempts to do so in a\n * zero-copy manner, e.g. the array references the same memory.\n */\nexport function buffer2ArrayBuffer(buff: Buffer): ArrayBuffer {\n const u8 = buffer2Uint8array(buff),\n u8offset = u8.byteOffset,\n u8Len = u8.byteLength;\n if (u8offset === 0 && u8Len === u8.buffer.byteLength) {\n return u8.buffer;\n } else {\n return u8.buffer.slice(u8offset, u8offset + u8Len);\n }\n}\n\n/**\n * Converts a buffer into a Uint8Array. Attempts to do so in a\n * zero-copy manner, e.g. the array references the same memory.\n */\nexport function buffer2Uint8array(buff: Buffer): Uint8Array {\n if (buff instanceof Uint8Array) {\n // BFS & Node v4.0 buffers *are* Uint8Arrays.\n return buff;\n } else {\n // Uint8Arrays can be constructed from arrayish numbers.\n // At this point, we assume this isn't a BFS array.\n return new Uint8Array(buff);\n }\n}\n\n/**\n * Converts the given arrayish object into a Buffer. Attempts to\n * be zero-copy.\n */\nexport function arrayish2Buffer(arr: Arrayish): Buffer {\n if (arr instanceof Buffer) {\n return arr;\n } else if (arr instanceof Uint8Array) {\n return uint8Array2Buffer(arr);\n } else {\n return new Buffer( arr);\n }\n}\n\n/**\n * Converts the given Uint8Array into a Buffer. Attempts to be zero-copy.\n */\nexport function uint8Array2Buffer(u8: Uint8Array): Buffer {\n if (u8 instanceof Buffer) {\n return u8;\n } else if (u8.byteOffset === 0 && u8.byteLength === u8.buffer.byteLength) {\n return arrayBuffer2Buffer(u8.buffer);\n } else {\n return new Buffer(u8);\n }\n}\n\n/**\n * Converts the given array buffer into a Buffer. Attempts to be\n * zero-copy.\n */\nexport function arrayBuffer2Buffer(ab: ArrayBuffer): Buffer {\n try {\n // Works in BFS and Node v4.2.\n return new Buffer( ab);\n } catch (e) {\n // I believe this copies, but there's no avoiding it in Node < v4.2\n return new Buffer(new Uint8Array(ab));\n }\n}\n\n/**\n * Copies a slice of the given buffer\n */\nexport function copyingSlice(buff: Buffer, start: number = 0, end = buff.length): Buffer {\n if (start < 0 || end < 0 || end > buff.length || start > end) {\n throw new TypeError(`Invalid slice bounds on buffer of length ${buff.length}: [${start}, ${end}]`);\n }\n if (buff.length === 0) {\n // Avoid s0 corner case in ArrayBuffer case.\n return new Buffer(0);\n } else {\n const u8 = buffer2Uint8array(buff),\n s0 = buff[0],\n newS0 = (s0 + 1) % 0xFF;\n\n buff[0] = newS0;\n if (u8[0] === newS0) {\n // Same memory. Revert & copy.\n u8[0] = s0;\n return uint8Array2Buffer(u8.slice(start, end));\n } else {\n // Revert.\n buff[0] = s0;\n return uint8Array2Buffer(u8.subarray(start, end));\n }\n }\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../src/core/util.ts","/**\n * A faster alternative to `Function#apply`, this function invokes `func`\n * with the `this` binding of `thisArg` and the arguments of `args`.\n *\n * @private\n * @param {Function} func The function to invoke.\n * @param {*} thisArg The `this` binding of `func`.\n * @param {Array} args The arguments to invoke `func` with.\n * @returns {*} Returns the result of `func`.\n */\nfunction apply(func, thisArg, args) {\n switch (args.length) {\n case 0: return func.call(thisArg);\n case 1: return func.call(thisArg, args[0]);\n case 2: return func.call(thisArg, args[0], args[1]);\n case 3: return func.call(thisArg, args[0], args[1], args[2]);\n }\n return func.apply(thisArg, args);\n}\n\nexport default apply;\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/lodash-es/_apply.js","import apply from './_apply.js';\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max;\n\n/**\n * A specialized version of `baseRest` which transforms the rest array.\n *\n * @private\n * @param {Function} func The function to apply a rest parameter to.\n * @param {number} [start=func.length-1] The start position of the rest parameter.\n * @param {Function} transform The rest array transform.\n * @returns {Function} Returns the new function.\n */\nfunction overRest(func, start, transform) {\n start = nativeMax(start === undefined ? (func.length - 1) : start, 0);\n return function() {\n var args = arguments,\n index = -1,\n length = nativeMax(args.length - start, 0),\n array = Array(length);\n\n while (++index < length) {\n array[index] = args[start + index];\n }\n index = -1;\n var otherArgs = Array(start + 1);\n while (++index < start) {\n otherArgs[index] = args[index];\n }\n otherArgs[start] = transform(array);\n return apply(func, this, otherArgs);\n };\n}\n\nexport default overRest;\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/lodash-es/_overRest.js","/**\n * This method returns the first argument it receives.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Util\n * @param {*} value Any value.\n * @returns {*} Returns `value`.\n * @example\n *\n * var object = { 'a': 1 };\n *\n * console.log(_.identity(object) === object);\n * // => true\n */\nfunction identity(value) {\n return value;\n}\n\nexport default identity;\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/lodash-es/identity.js","import _overRest from 'lodash-es/_overRest';\nimport identity from 'lodash-es/identity';\n\n// Lodash rest function without function.toString()\n// remappings\nexport default function rest(func, start) {\n return _overRest(func, start, identity);\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/async-es/internal/rest.js","import rest from './rest';\nimport initialParams from './initialParams';\n\nexport default function applyEach(eachfn) {\n return rest(function(fns, args) {\n var go = initialParams(function(args, callback) {\n var that = this;\n return eachfn(fns, function (fn, cb) {\n fn.apply(that, args.concat([cb]));\n }, callback);\n });\n if (args.length) {\n return go.apply(this, args);\n }\n else {\n return go;\n }\n });\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/async-es/internal/applyEach.js","import Symbol from './_Symbol.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the raw `toStringTag`.\n */\nfunction getRawTag(value) {\n var isOwn = hasOwnProperty.call(value, symToStringTag),\n tag = value[symToStringTag];\n\n try {\n value[symToStringTag] = undefined;\n var unmasked = true;\n } catch (e) {}\n\n var result = nativeObjectToString.call(value);\n if (unmasked) {\n if (isOwn) {\n value[symToStringTag] = tag;\n } else {\n delete value[symToStringTag];\n }\n }\n return result;\n}\n\nexport default getRawTag;\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/lodash-es/_getRawTag.js","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/**\n * Converts `value` to a string using `Object.prototype.toString`.\n *\n * @private\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n */\nfunction objectToString(value) {\n return nativeObjectToString.call(value);\n}\n\nexport default objectToString;\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/lodash-es/_objectToString.js","import Symbol from './_Symbol.js';\nimport getRawTag from './_getRawTag.js';\nimport objectToString from './_objectToString.js';\n\n/** `Object#toString` result references. */\nvar nullTag = '[object Null]',\n undefinedTag = '[object Undefined]';\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * The base implementation of `getTag` without fallbacks for buggy environments.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nfunction baseGetTag(value) {\n if (value == null) {\n return value === undefined ? undefinedTag : nullTag;\n }\n return (symToStringTag && symToStringTag in Object(value))\n ? getRawTag(value)\n : objectToString(value);\n}\n\nexport default baseGetTag;\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/lodash-es/_baseGetTag.js","/**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\nfunction isObject(value) {\n var type = typeof value;\n return value != null && (type == 'object' || type == 'function');\n}\n\nexport default isObject;\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/lodash-es/isObject.js","import baseGetTag from './_baseGetTag.js';\nimport isObject from './isObject.js';\n\n/** `Object#toString` result references. */\nvar asyncTag = '[object AsyncFunction]',\n funcTag = '[object Function]',\n genTag = '[object GeneratorFunction]',\n proxyTag = '[object Proxy]';\n\n/**\n * Checks if `value` is classified as a `Function` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a function, else `false`.\n * @example\n *\n * _.isFunction(_);\n * // => true\n *\n * _.isFunction(/abc/);\n * // => false\n */\nfunction isFunction(value) {\n if (!isObject(value)) {\n return false;\n }\n // The use of `Object#toString` avoids issues with the `typeof` operator\n // in Safari 9 which returns 'object' for typed arrays and other constructors.\n var tag = baseGetTag(value);\n return tag == funcTag || tag == genTag || tag == asyncTag || tag == proxyTag;\n}\n\nexport default isFunction;\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/lodash-es/isFunction.js","/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/**\n * Checks if `value` is a valid array-like length.\n *\n * **Note:** This method is loosely based on\n * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.\n * @example\n *\n * _.isLength(3);\n * // => true\n *\n * _.isLength(Number.MIN_VALUE);\n * // => false\n *\n * _.isLength(Infinity);\n * // => false\n *\n * _.isLength('3');\n * // => false\n */\nfunction isLength(value) {\n return typeof value == 'number' &&\n value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;\n}\n\nexport default isLength;\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/lodash-es/isLength.js","import isFunction from './isFunction.js';\nimport isLength from './isLength.js';\n\n/**\n * Checks if `value` is array-like. A value is considered array-like if it's\n * not a function and has a `value.length` that's an integer greater than or\n * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is array-like, else `false`.\n * @example\n *\n * _.isArrayLike([1, 2, 3]);\n * // => true\n *\n * _.isArrayLike(document.body.children);\n * // => true\n *\n * _.isArrayLike('abc');\n * // => true\n *\n * _.isArrayLike(_.noop);\n * // => false\n */\nfunction isArrayLike(value) {\n return value != null && isLength(value.length) && !isFunction(value);\n}\n\nexport default isArrayLike;\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/lodash-es/isArrayLike.js","/**\n * This method returns `undefined`.\n *\n * @static\n * @memberOf _\n * @since 2.3.0\n * @category Util\n * @example\n *\n * _.times(2, _.noop);\n * // => [undefined, undefined]\n */\nfunction noop() {\n // No operation performed.\n}\n\nexport default noop;\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/lodash-es/noop.js","export default function once(fn) {\n return function () {\n if (fn === null) return;\n var callFn = fn;\n fn = null;\n callFn.apply(this, arguments);\n };\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/async-es/internal/once.js","/**\n * The base implementation of `_.times` without support for iteratee shorthands\n * or max array length checks.\n *\n * @private\n * @param {number} n The number of times to invoke `iteratee`.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the array of results.\n */\nfunction baseTimes(n, iteratee) {\n var index = -1,\n result = Array(n);\n\n while (++index < n) {\n result[index] = iteratee(index);\n }\n return result;\n}\n\nexport default baseTimes;\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/lodash-es/_baseTimes.js","/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n return value != null && typeof value == 'object';\n}\n\nexport default isObjectLike;\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/lodash-es/isObjectLike.js","import baseGetTag from './_baseGetTag.js';\nimport isObjectLike from './isObjectLike.js';\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]';\n\n/**\n * The base implementation of `_.isArguments`.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n */\nfunction baseIsArguments(value) {\n return isObjectLike(value) && baseGetTag(value) == argsTag;\n}\n\nexport default baseIsArguments;\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/lodash-es/_baseIsArguments.js","/**\n * This method returns `false`.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {boolean} Returns `false`.\n * @example\n *\n * _.times(2, _.stubFalse);\n * // => [false, false]\n */\nfunction stubFalse() {\n return false;\n}\n\nexport default stubFalse;\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/lodash-es/stubFalse.js","/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/** Used to detect unsigned integer values. */\nvar reIsUint = /^(?:0|[1-9]\\d*)$/;\n\n/**\n * Checks if `value` is a valid array-like index.\n *\n * @private\n * @param {*} value The value to check.\n * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.\n * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.\n */\nfunction isIndex(value, length) {\n length = length == null ? MAX_SAFE_INTEGER : length;\n return !!length &&\n (typeof value == 'number' || reIsUint.test(value)) &&\n (value > -1 && value % 1 == 0 && value < length);\n}\n\nexport default isIndex;\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/lodash-es/_isIndex.js","import baseGetTag from './_baseGetTag.js';\nimport isLength from './isLength.js';\nimport isObjectLike from './isObjectLike.js';\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n arrayTag = '[object Array]',\n boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n errorTag = '[object Error]',\n funcTag = '[object Function]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n objectTag = '[object Object]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n weakMapTag = '[object WeakMap]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]',\n float32Tag = '[object Float32Array]',\n float64Tag = '[object Float64Array]',\n int8Tag = '[object Int8Array]',\n int16Tag = '[object Int16Array]',\n int32Tag = '[object Int32Array]',\n uint8Tag = '[object Uint8Array]',\n uint8ClampedTag = '[object Uint8ClampedArray]',\n uint16Tag = '[object Uint16Array]',\n uint32Tag = '[object Uint32Array]';\n\n/** Used to identify `toStringTag` values of typed arrays. */\nvar typedArrayTags = {};\ntypedArrayTags[float32Tag] = typedArrayTags[float64Tag] =\ntypedArrayTags[int8Tag] = typedArrayTags[int16Tag] =\ntypedArrayTags[int32Tag] = typedArrayTags[uint8Tag] =\ntypedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] =\ntypedArrayTags[uint32Tag] = true;\ntypedArrayTags[argsTag] = typedArrayTags[arrayTag] =\ntypedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] =\ntypedArrayTags[dataViewTag] = typedArrayTags[dateTag] =\ntypedArrayTags[errorTag] = typedArrayTags[funcTag] =\ntypedArrayTags[mapTag] = typedArrayTags[numberTag] =\ntypedArrayTags[objectTag] = typedArrayTags[regexpTag] =\ntypedArrayTags[setTag] = typedArrayTags[stringTag] =\ntypedArrayTags[weakMapTag] = false;\n\n/**\n * The base implementation of `_.isTypedArray` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n */\nfunction baseIsTypedArray(value) {\n return isObjectLike(value) &&\n isLength(value.length) && !!typedArrayTags[baseGetTag(value)];\n}\n\nexport default baseIsTypedArray;\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/lodash-es/_baseIsTypedArray.js","/**\n * The base implementation of `_.unary` without support for storing metadata.\n *\n * @private\n * @param {Function} func The function to cap arguments for.\n * @returns {Function} Returns the new capped function.\n */\nfunction baseUnary(func) {\n return function(value) {\n return func(value);\n };\n}\n\nexport default baseUnary;\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/lodash-es/_baseUnary.js","import baseTimes from './_baseTimes.js';\nimport isArguments from './isArguments.js';\nimport isArray from './isArray.js';\nimport isBuffer from './isBuffer.js';\nimport isIndex from './_isIndex.js';\nimport isTypedArray from './isTypedArray.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Creates an array of the enumerable property names of the array-like `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @param {boolean} inherited Specify returning inherited property names.\n * @returns {Array} Returns the array of property names.\n */\nfunction arrayLikeKeys(value, inherited) {\n var isArr = isArray(value),\n isArg = !isArr && isArguments(value),\n isBuff = !isArr && !isArg && isBuffer(value),\n isType = !isArr && !isArg && !isBuff && isTypedArray(value),\n skipIndexes = isArr || isArg || isBuff || isType,\n result = skipIndexes ? baseTimes(value.length, String) : [],\n length = result.length;\n\n for (var key in value) {\n if ((inherited || hasOwnProperty.call(value, key)) &&\n !(skipIndexes && (\n // Safari 9 has enumerable `arguments.length` in strict mode.\n key == 'length' ||\n // Node.js 0.10 has enumerable non-index properties on buffers.\n (isBuff && (key == 'offset' || key == 'parent')) ||\n // PhantomJS 2 has enumerable non-index properties on typed arrays.\n (isType && (key == 'buffer' || key == 'byteLength' || key == 'byteOffset')) ||\n // Skip index properties.\n isIndex(key, length)\n ))) {\n result.push(key);\n }\n }\n return result;\n}\n\nexport default arrayLikeKeys;\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/lodash-es/_arrayLikeKeys.js","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Checks if `value` is likely a prototype object.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a prototype, else `false`.\n */\nfunction isPrototype(value) {\n var Ctor = value && value.constructor,\n proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto;\n\n return value === proto;\n}\n\nexport default isPrototype;\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/lodash-es/_isPrototype.js","/**\n * Creates a unary function that invokes `func` with its argument transformed.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {Function} transform The argument transform.\n * @returns {Function} Returns the new function.\n */\nfunction overArg(func, transform) {\n return function(arg) {\n return func(transform(arg));\n };\n}\n\nexport default overArg;\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/lodash-es/_overArg.js","import isPrototype from './_isPrototype.js';\nimport nativeKeys from './_nativeKeys.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * The base implementation of `_.keys` which doesn't treat sparse arrays as dense.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction baseKeys(object) {\n if (!isPrototype(object)) {\n return nativeKeys(object);\n }\n var result = [];\n for (var key in Object(object)) {\n if (hasOwnProperty.call(object, key) && key != 'constructor') {\n result.push(key);\n }\n }\n return result;\n}\n\nexport default baseKeys;\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/lodash-es/_baseKeys.js","import arrayLikeKeys from './_arrayLikeKeys.js';\nimport baseKeys from './_baseKeys.js';\nimport isArrayLike from './isArrayLike.js';\n\n/**\n * Creates an array of the own enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects. See the\n * [ES spec](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\n * for more details.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keys(new Foo);\n * // => ['a', 'b'] (iteration order is not guaranteed)\n *\n * _.keys('hi');\n * // => ['0', '1']\n */\nfunction keys(object) {\n return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object);\n}\n\nexport default keys;\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/lodash-es/keys.js","import isArrayLike from 'lodash-es/isArrayLike';\nimport getIterator from './getIterator';\nimport keys from 'lodash-es/keys';\n\nfunction createArrayIterator(coll) {\n var i = -1;\n var len = coll.length;\n return function next() {\n return ++i < len ? {value: coll[i], key: i} : null;\n }\n}\n\nfunction createES2015Iterator(iterator) {\n var i = -1;\n return function next() {\n var item = iterator.next();\n if (item.done)\n return null;\n i++;\n return {value: item.value, key: i};\n }\n}\n\nfunction createObjectIterator(obj) {\n var okeys = keys(obj);\n var i = -1;\n var len = okeys.length;\n return function next() {\n var key = okeys[++i];\n return i < len ? {value: obj[key], key: key} : null;\n };\n}\n\nexport default function iterator(coll) {\n if (isArrayLike(coll)) {\n return createArrayIterator(coll);\n }\n\n var iterator = getIterator(coll);\n return iterator ? createES2015Iterator(iterator) : createObjectIterator(coll);\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/async-es/internal/iterator.js","export default function onlyOnce(fn) {\n return function() {\n if (fn === null) throw new Error(\"Callback was already called.\");\n var callFn = fn;\n fn = null;\n callFn.apply(this, arguments);\n };\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/async-es/internal/onlyOnce.js","import noop from 'lodash-es/noop';\nimport once from './once';\n\nimport iterator from './iterator';\nimport onlyOnce from './onlyOnce';\n\nimport breakLoop from './breakLoop';\n\nexport default function _eachOfLimit(limit) {\n return function (obj, iteratee, callback) {\n callback = once(callback || noop);\n if (limit <= 0 || !obj) {\n return callback(null);\n }\n var nextElem = iterator(obj);\n var done = false;\n var running = 0;\n\n function iterateeCallback(err, value) {\n running -= 1;\n if (err) {\n done = true;\n callback(err);\n }\n else if (value === breakLoop || (done && running <= 0)) {\n done = true;\n return callback(null);\n }\n else {\n replenish();\n }\n }\n\n function replenish () {\n while (running < limit && !done) {\n var elem = nextElem();\n if (elem === null) {\n done = true;\n if (running <= 0) {\n callback(null);\n }\n return;\n }\n running += 1;\n iteratee(elem.value, elem.key, onlyOnce(iterateeCallback));\n }\n }\n\n replenish();\n };\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/async-es/internal/eachOfLimit.js","import _eachOfLimit from './internal/eachOfLimit';\n\n/**\n * The same as [`eachOf`]{@link module:Collections.eachOf} but runs a maximum of `limit` async operations at a\n * time.\n *\n * @name eachOfLimit\n * @static\n * @memberOf module:Collections\n * @method\n * @see [async.eachOf]{@link module:Collections.eachOf}\n * @alias forEachOfLimit\n * @category Collection\n * @param {Array|Iterable|Object} coll - A collection to iterate over.\n * @param {number} limit - The maximum number of async operations at a time.\n * @param {Function} iteratee - A function to apply to each\n * item in `coll`. The `key` is the item's key, or index in the case of an\n * array. The iteratee is passed a `callback(err)` which must be called once it\n * has completed. If no error has occurred, the callback should be run without\n * arguments or with an explicit `null` argument. Invoked with\n * (item, key, callback).\n * @param {Function} [callback] - A callback which is called when all\n * `iteratee` functions have finished, or an error occurs. Invoked with (err).\n */\nexport default function eachOfLimit(coll, limit, iteratee, callback) {\n _eachOfLimit(limit)(coll, iteratee, callback);\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/async-es/eachOfLimit.js","export default function doLimit(fn, limit) {\n return function (iterable, iteratee, callback) {\n return fn(iterable, limit, iteratee, callback);\n };\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/async-es/internal/doLimit.js","import isArrayLike from 'lodash-es/isArrayLike';\n\nimport eachOfLimit from './eachOfLimit';\nimport doLimit from './internal/doLimit';\nimport noop from 'lodash-es/noop';\nimport once from './internal/once';\nimport onlyOnce from './internal/onlyOnce';\n\n// eachOf implementation optimized for array-likes\nfunction eachOfArrayLike(coll, iteratee, callback) {\n callback = once(callback || noop);\n var index = 0,\n completed = 0,\n length = coll.length;\n if (length === 0) {\n callback(null);\n }\n\n function iteratorCallback(err) {\n if (err) {\n callback(err);\n } else if (++completed === length) {\n callback(null);\n }\n }\n\n for (; index < length; index++) {\n iteratee(coll[index], index, onlyOnce(iteratorCallback));\n }\n}\n\n// a generic version of eachOf which can handle array, object, and iterator cases.\nvar eachOfGeneric = doLimit(eachOfLimit, Infinity);\n\n/**\n * Like [`each`]{@link module:Collections.each}, except that it passes the key (or index) as the second argument\n * to the iteratee.\n *\n * @name eachOf\n * @static\n * @memberOf module:Collections\n * @method\n * @alias forEachOf\n * @category Collection\n * @see [async.each]{@link module:Collections.each}\n * @param {Array|Iterable|Object} coll - A collection to iterate over.\n * @param {Function} iteratee - A function to apply to each\n * item in `coll`. The `key` is the item's key, or index in the case of an\n * array. The iteratee is passed a `callback(err)` which must be called once it\n * has completed. If no error has occurred, the callback should be run without\n * arguments or with an explicit `null` argument. Invoked with\n * (item, key, callback).\n * @param {Function} [callback] - A callback which is called when all\n * `iteratee` functions have finished, or an error occurs. Invoked with (err).\n * @example\n *\n * var obj = {dev: \"/dev.json\", test: \"/test.json\", prod: \"/prod.json\"};\n * var configs = {};\n *\n * async.forEachOf(obj, function (value, key, callback) {\n * fs.readFile(__dirname + value, \"utf8\", function (err, data) {\n * if (err) return callback(err);\n * try {\n * configs[key] = JSON.parse(data);\n * } catch (e) {\n * return callback(e);\n * }\n * callback();\n * });\n * }, function (err) {\n * if (err) console.error(err.message);\n * // configs is now a map of JSON data\n * doSomethingWith(configs);\n * });\n */\nexport default function(coll, iteratee, callback) {\n var eachOfImplementation = isArrayLike(coll) ? eachOfArrayLike : eachOfGeneric;\n eachOfImplementation(coll, iteratee, callback);\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/async-es/eachOf.js","import eachOf from '../eachOf';\n\nexport default function doParallel(fn) {\n return function (obj, iteratee, callback) {\n return fn(eachOf, obj, iteratee, callback);\n };\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/async-es/internal/doParallel.js","import noop from 'lodash-es/noop';\n\nexport default function _asyncMap(eachfn, arr, iteratee, callback) {\n callback = callback || noop;\n arr = arr || [];\n var results = [];\n var counter = 0;\n\n eachfn(arr, function (value, _, callback) {\n var index = counter++;\n iteratee(value, function (err, v) {\n results[index] = v;\n callback(err);\n });\n }, function (err) {\n callback(err, results);\n });\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/async-es/internal/map.js","import eachOfLimit from './eachOfLimit';\n\nexport default function doParallelLimit(fn) {\n return function (obj, limit, iteratee, callback) {\n return fn(eachOfLimit(limit), obj, iteratee, callback);\n };\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/async-es/internal/doParallelLimit.js","/**\n * A specialized version of `_.forEach` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns `array`.\n */\nfunction arrayEach(array, iteratee) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n if (iteratee(array[index], index, array) === false) {\n break;\n }\n }\n return array;\n}\n\nexport default arrayEach;\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/lodash-es/_arrayEach.js","/**\n * Creates a base function for methods like `_.forIn` and `_.forOwn`.\n *\n * @private\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new base function.\n */\nfunction createBaseFor(fromRight) {\n return function(object, iteratee, keysFunc) {\n var index = -1,\n iterable = Object(object),\n props = keysFunc(object),\n length = props.length;\n\n while (length--) {\n var key = props[fromRight ? length : ++index];\n if (iteratee(iterable[key], key, iterable) === false) {\n break;\n }\n }\n return object;\n };\n}\n\nexport default createBaseFor;\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/lodash-es/_createBaseFor.js","'use strict';\n\nimport rest from './rest';\n\nexport var hasSetImmediate = typeof setImmediate === 'function' && setImmediate;\nexport var hasNextTick = typeof process === 'object' && typeof process.nextTick === 'function';\n\nexport function fallback(fn) {\n setTimeout(fn, 0);\n}\n\nexport function wrap(defer) {\n return rest(function (fn, args) {\n defer(function () {\n fn.apply(null, args);\n });\n });\n}\n\nvar _defer;\n\nif (hasSetImmediate) {\n _defer = setImmediate;\n} else if (hasNextTick) {\n _defer = process.nextTick;\n} else {\n _defer = fallback;\n}\n\nexport default wrap(_defer);\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/async-es/internal/setImmediate.js","import eachOfSeries from './eachOfSeries';\nimport noop from 'lodash-es/noop';\nimport once from './internal/once';\n\n/**\n * Reduces `coll` into a single value using an async `iteratee` to return each\n * successive step. `memo` is the initial state of the reduction. This function\n * only operates in series.\n *\n * For performance reasons, it may make sense to split a call to this function\n * into a parallel map, and then use the normal `Array.prototype.reduce` on the\n * results. This function is for situations where each step in the reduction\n * needs to be async; if you can get the data before reducing it, then it's\n * probably a good idea to do so.\n *\n * @name reduce\n * @static\n * @memberOf module:Collections\n * @method\n * @alias inject\n * @alias foldl\n * @category Collection\n * @param {Array|Iterable|Object} coll - A collection to iterate over.\n * @param {*} memo - The initial state of the reduction.\n * @param {Function} iteratee - A function applied to each item in the\n * array to produce the next step in the reduction. The `iteratee` is passed a\n * `callback(err, reduction)` which accepts an optional error as its first\n * argument, and the state of the reduction as the second. If an error is\n * passed to the callback, the reduction is stopped and the main `callback` is\n * immediately called with the error. Invoked with (memo, item, callback).\n * @param {Function} [callback] - A callback which is called after all the\n * `iteratee` functions have finished. Result is the reduced value. Invoked with\n * (err, result).\n * @example\n *\n * async.reduce([1,2,3], 0, function(memo, item, callback) {\n * // pointless async:\n * process.nextTick(function() {\n * callback(null, memo + item)\n * });\n * }, function(err, result) {\n * // result is now equal to the last value of memo, which is 6\n * });\n */\nexport default function reduce(coll, memo, iteratee, callback) {\n callback = once(callback || noop);\n eachOfSeries(coll, function(x, i, callback) {\n iteratee(memo, x, function(err, v) {\n memo = v;\n callback(err);\n });\n }, function(err) {\n callback(err, memo);\n });\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/async-es/reduce.js","import arrayEach from 'lodash-es/_arrayEach';\nimport rest from './rest';\n\nexport default function consoleFunc(name) {\n return rest(function (fn, args) {\n fn.apply(null, args.concat([rest(function (err, args) {\n if (typeof console === 'object') {\n if (err) {\n if (console.error) {\n console.error(err);\n }\n }\n else if (console[name]) {\n arrayEach(args, function (x) {\n console[name](x);\n });\n }\n }\n })]));\n });\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/async-es/internal/consoleFunc.js","export default function _withoutIndex(iteratee) {\n return function (value, index, callback) {\n return iteratee(value, callback);\n };\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/async-es/internal/withoutIndex.js","import eachOf from './eachOf';\nimport withoutIndex from './internal/withoutIndex';\n\n/**\n * Applies the function `iteratee` to each item in `coll`, in parallel.\n * The `iteratee` is called with an item from the list, and a callback for when\n * it has finished. If the `iteratee` passes an error to its `callback`, the\n * main `callback` (for the `each` function) is immediately called with the\n * error.\n *\n * Note, that since this function applies `iteratee` to each item in parallel,\n * there is no guarantee that the iteratee functions will complete in order.\n *\n * @name each\n * @static\n * @memberOf module:Collections\n * @method\n * @alias forEach\n * @category Collection\n * @param {Array|Iterable|Object} coll - A collection to iterate over.\n * @param {Function} iteratee - A function to apply to each item\n * in `coll`. The iteratee is passed a `callback(err)` which must be called once\n * it has completed. If no error has occurred, the `callback` should be run\n * without arguments or with an explicit `null` argument. The array index is not\n * passed to the iteratee. Invoked with (item, callback). If you need the index,\n * use `eachOf`.\n * @param {Function} [callback] - A callback which is called when all\n * `iteratee` functions have finished, or an error occurs. Invoked with (err).\n * @example\n *\n * // assuming openFiles is an array of file names and saveFile is a function\n * // to save the modified contents of that file:\n *\n * async.each(openFiles, saveFile, function(err){\n * // if any of the saves produced an error, err would equal that error\n * });\n *\n * // assuming openFiles is an array of file names\n * async.each(openFiles, function(file, callback) {\n *\n * // Perform operation on file here.\n * console.log('Processing file ' + file);\n *\n * if( file.length > 32 ) {\n * console.log('This file name is too long');\n * callback('File name too long');\n * } else {\n * // Do work to process file here\n * console.log('File processed');\n * callback();\n * }\n * }, function(err) {\n * // if any of the file processing produced an error, err would equal that error\n * if( err ) {\n * // One of the iterations produced an error.\n * // All processing will now stop.\n * console.log('A file failed to process');\n * } else {\n * console.log('All files have been processed successfully');\n * }\n * });\n */\nexport default function eachLimit(coll, iteratee, callback) {\n eachOf(coll, withoutIndex(iteratee), callback);\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/async-es/each.js","import PreloadFile from '../generic/preload_file';\nimport {BaseFileSystem, FileSystem, BFSOneArgCallback, BFSCallback} from '../core/file_system';\nimport {FileFlag} from '../core/file_flag';\nimport {default as Stats, FileType} from '../core/node_fs_stats';\nimport {ApiError, ErrorCode} from '../core/api_error';\nimport {File} from '../core/file';\nimport {each as asyncEach} from 'async';\nimport * as path from 'path';\nimport {arrayBuffer2Buffer, buffer2ArrayBuffer} from '../core/util';\n\nlet errorCodeLookup: {[dropboxErrorCode: number]: ErrorCode};\n// Lazily construct error code lookup, since DropboxJS might be loaded *after* BrowserFS (or not at all!)\nfunction constructErrorCodeLookup() {\n if (errorCodeLookup) {\n return;\n }\n errorCodeLookup = {};\n // This indicates a network transmission error on modern browsers. Internet Explorer might cause this code to be reported on some API server errors.\n errorCodeLookup[Dropbox.ApiError.NETWORK_ERROR] = ErrorCode.EIO;\n // This happens when the contentHash parameter passed to a Dropbox.Client#readdir or Dropbox.Client#stat matches the most recent content, so the API call response is omitted, to save bandwidth.\n // errorCodeLookup[Dropbox.ApiError.NO_CONTENT];\n // The error property on {Dropbox.ApiError#response} should indicate which input parameter is invalid and why.\n errorCodeLookup[Dropbox.ApiError.INVALID_PARAM] = ErrorCode.EINVAL;\n // The OAuth token used for the request will never become valid again, so the user should be re-authenticated.\n errorCodeLookup[Dropbox.ApiError.INVALID_TOKEN] = ErrorCode.EPERM;\n // This indicates a bug in dropbox.js and should never occur under normal circumstances.\n // ^ Actually, that's false. This occurs when you try to move folders to themselves, or move a file over another file.\n errorCodeLookup[Dropbox.ApiError.OAUTH_ERROR] = ErrorCode.EPERM;\n // This happens when trying to read from a non-existing file, readdir a non-existing directory, write a file into a non-existing directory, etc.\n errorCodeLookup[Dropbox.ApiError.NOT_FOUND] = ErrorCode.ENOENT;\n // This indicates a bug in dropbox.js and should never occur under normal circumstances.\n errorCodeLookup[Dropbox.ApiError.INVALID_METHOD] = ErrorCode.EINVAL;\n // This happens when a Dropbox.Client#readdir or Dropbox.Client#stat call would return more than a maximum amount of directory entries.\n errorCodeLookup[Dropbox.ApiError.NOT_ACCEPTABLE] = ErrorCode.EINVAL;\n // This is used by some backend methods to indicate that the client needs to download server-side changes and perform conflict resolution. Under normal usage, errors with this code should never surface to the code using dropbox.js.\n errorCodeLookup[Dropbox.ApiError.CONFLICT] = ErrorCode.EINVAL;\n // Status value indicating that the application is making too many requests.\n errorCodeLookup[Dropbox.ApiError.RATE_LIMITED] = ErrorCode.EBUSY;\n // The request should be retried after some time.\n errorCodeLookup[Dropbox.ApiError.SERVER_ERROR] = ErrorCode.EBUSY;\n // Status value indicating that the user's Dropbox is over its storage quota.\n errorCodeLookup[Dropbox.ApiError.OVER_QUOTA] = ErrorCode.ENOSPC;\n}\n\ninterface ICachedPathInfo {\n stat: Dropbox.File.Stat;\n}\n\ninterface ICachedFileInfo extends ICachedPathInfo {\n contents: ArrayBuffer;\n}\n\nfunction isFileInfo(cache: ICachedPathInfo): cache is ICachedFileInfo {\n return cache && cache.stat.isFile;\n}\n\ninterface ICachedDirInfo extends ICachedPathInfo {\n contents: string[];\n}\n\nfunction isDirInfo(cache: ICachedPathInfo): cache is ICachedDirInfo {\n return cache && cache.stat.isFolder;\n}\n\nfunction isArrayBuffer(ab: any): ab is ArrayBuffer {\n // Accept null / undefined, too.\n return ab === null || ab === undefined || (typeof(ab) === 'object' && typeof(ab['byteLength']) === 'number');\n}\n\n/**\n * Wraps a Dropbox client and caches operations.\n */\nclass CachedDropboxClient {\n private _cache: {[path: string]: ICachedPathInfo} = {};\n private _client: Dropbox.Client;\n\n constructor(client: Dropbox.Client) {\n this._client = client;\n }\n\n public readdir(p: string, cb: (error: Dropbox.ApiError | null, contents?: string[]) => void): void {\n const cacheInfo = this.getCachedDirInfo(p);\n\n this._wrap((interceptCb) => {\n if (cacheInfo !== null && cacheInfo.contents) {\n this._client.readdir(p, {\n contentHash: cacheInfo.stat.contentHash\n }, interceptCb);\n } else {\n this._client.readdir(p, interceptCb);\n }\n }, (err: Dropbox.ApiError, filenames: string[], stat: Dropbox.File.Stat, folderEntries: Dropbox.File.Stat[]) => {\n if (err) {\n if (err.status === Dropbox.ApiError.NO_CONTENT && cacheInfo !== null) {\n cb(null, cacheInfo.contents.slice(0));\n } else {\n cb(err);\n }\n } else {\n this.updateCachedDirInfo(p, stat, filenames.slice(0));\n folderEntries.forEach((entry) => {\n this.updateCachedInfo(path.join(p, entry.name), entry);\n });\n cb(null, filenames);\n }\n });\n }\n\n public remove(p: string, cb: (error?: Dropbox.ApiError | null) => void): void {\n this._wrap((interceptCb) => {\n this._client.remove(p, interceptCb);\n }, (err: Dropbox.ApiError, stat?: Dropbox.File.Stat) => {\n if (!err) {\n this.updateCachedInfo(p, stat!);\n }\n cb(err);\n });\n }\n\n public move(src: string, dest: string, cb: (error?: Dropbox.ApiError) => void): void {\n this._wrap((interceptCb) => {\n this._client.move(src, dest, interceptCb);\n }, (err: Dropbox.ApiError, stat: Dropbox.File.Stat) => {\n if (!err) {\n this.deleteCachedInfo(src);\n this.updateCachedInfo(dest, stat);\n }\n cb(err);\n });\n }\n\n public stat(p: string, cb: (error: Dropbox.ApiError, stat?: Dropbox.File.Stat) => void): void {\n this._wrap((interceptCb) => {\n this._client.stat(p, interceptCb);\n }, (err: Dropbox.ApiError, stat: Dropbox.File.Stat) => {\n if (!err) {\n this.updateCachedInfo(p, stat);\n }\n cb(err, stat);\n });\n }\n\n public readFile(p: string, cb: (error: Dropbox.ApiError, file?: ArrayBuffer, stat?: Dropbox.File.Stat) => void): void {\n const cacheInfo = this.getCachedFileInfo(p);\n if (cacheInfo !== null && cacheInfo.contents !== null) {\n // Try to use cached info; issue a stat to see if contents are up-to-date.\n this.stat(p, (error, stat?) => {\n if (error) {\n cb(error);\n } else if (stat!.contentHash === cacheInfo!.stat.contentHash) {\n // No file changes.\n cb(error, cacheInfo!.contents.slice(0), cacheInfo!.stat);\n } else {\n // File changes; rerun to trigger actual readFile.\n this.readFile(p, cb);\n }\n });\n } else {\n this._wrap((interceptCb) => {\n this._client.readFile(p, { arrayBuffer: true }, interceptCb);\n }, (err: Dropbox.ApiError, contents: any, stat: Dropbox.File.Stat) => {\n if (!err) {\n this.updateCachedInfo(p, stat, contents.slice(0));\n }\n cb(err, contents, stat);\n });\n }\n }\n\n public writeFile(p: string, contents: ArrayBuffer, cb: (error: Dropbox.ApiError, stat?: Dropbox.File.Stat) => void): void {\n this._wrap((interceptCb) => {\n this._client.writeFile(p, contents, interceptCb);\n }, (err: Dropbox.ApiError, stat: Dropbox.File.Stat) => {\n if (!err) {\n this.updateCachedInfo(p, stat, contents.slice(0));\n }\n cb(err, stat);\n });\n }\n\n public mkdir(p: string, cb: (error?: Dropbox.ApiError) => void): void {\n this._wrap((interceptCb) => {\n this._client.mkdir(p, interceptCb);\n }, (err: Dropbox.ApiError, stat: Dropbox.File.Stat) => {\n if (!err) {\n this.updateCachedInfo(p, stat, []);\n }\n cb(err);\n });\n }\n\n /**\n * Wraps an operation such that we retry a failed operation 3 times.\n * Necessary to deal with Dropbox rate limiting.\n *\n * @param performOp Function that performs the operation. Will be called up to three times.\n * @param cb Called when the operation succeeds, fails in a non-temporary manner, or fails three times.\n */\n private _wrap(performOp: (interceptCb: (error: Dropbox.ApiError) => void) => void, cb: Function): void {\n let numRun = 0;\n const interceptCb = function(error: Dropbox.ApiError): void {\n // Timeout duration, in seconds.\n const timeoutDuration: number = 2;\n if (error && 3 > (++numRun)) {\n switch (error.status) {\n case Dropbox.ApiError.SERVER_ERROR:\n case Dropbox.ApiError.NETWORK_ERROR:\n case Dropbox.ApiError.RATE_LIMITED:\n setTimeout(() => {\n performOp(interceptCb);\n }, timeoutDuration * 1000);\n break;\n default:\n cb.apply(null, arguments);\n break;\n }\n } else {\n cb.apply(null, arguments);\n }\n };\n\n performOp(interceptCb);\n }\n\n private getCachedInfo(p: string): ICachedPathInfo {\n return this._cache[p.toLowerCase()];\n }\n\n private putCachedInfo(p: string, cache: ICachedPathInfo): void {\n this._cache[p.toLowerCase()] = cache;\n }\n\n private deleteCachedInfo(p: string): void {\n delete this._cache[p.toLowerCase()];\n }\n\n private getCachedDirInfo(p: string): ICachedDirInfo | null {\n const info = this.getCachedInfo(p);\n if (isDirInfo(info)) {\n return info;\n } else {\n return null;\n }\n }\n\n private getCachedFileInfo(p: string): ICachedFileInfo | null {\n const info = this.getCachedInfo(p);\n if (isFileInfo(info)) {\n return info;\n } else {\n return null;\n }\n }\n\n private updateCachedDirInfo(p: string, stat: Dropbox.File.Stat, contents: string[] | null = null): void {\n const cachedInfo = this.getCachedInfo(p);\n // Dropbox uses the *contentHash* property for directories.\n // Ignore stat objects w/o a contentHash defined; those actually exist!!!\n // (Example: readdir returns an array of stat objs; stat objs for dirs in that context have no contentHash)\n if (stat.contentHash !== null && (cachedInfo === undefined || cachedInfo.stat.contentHash !== stat.contentHash)) {\n this.putCachedInfo(p, {\n stat: stat,\n contents: contents\n });\n }\n }\n\n private updateCachedFileInfo(p: string, stat: Dropbox.File.Stat, contents: ArrayBuffer | null = null): void {\n const cachedInfo = this.getCachedInfo(p);\n // Dropbox uses the *versionTag* property for files.\n // Ignore stat objects w/o a versionTag defined.\n if (stat.versionTag !== null && (cachedInfo === undefined || cachedInfo.stat.versionTag !== stat.versionTag)) {\n this.putCachedInfo(p, {\n stat: stat,\n contents: contents\n });\n }\n }\n\n private updateCachedInfo(p: string, stat: Dropbox.File.Stat, contents: ArrayBuffer | string[] | null = null): void {\n if (stat.isFile && isArrayBuffer(contents)) {\n this.updateCachedFileInfo(p, stat, contents);\n } else if (stat.isFolder && Array.isArray(contents)) {\n this.updateCachedDirInfo(p, stat, contents);\n }\n }\n}\n\nexport class DropboxFile extends PreloadFile implements File {\n constructor(_fs: DropboxFileSystem, _path: string, _flag: FileFlag, _stat: Stats, contents?: Buffer) {\n super(_fs, _path, _flag, _stat, contents);\n }\n\n public sync(cb: BFSOneArgCallback): void {\n if (this.isDirty()) {\n const buffer = this.getBuffer(),\n arrayBuffer = buffer2ArrayBuffer(buffer);\n this._fs._writeFileStrict(this.getPath(), arrayBuffer, (e?: ApiError) => {\n if (!e) {\n this.resetDirty();\n }\n cb(e);\n });\n } else {\n cb();\n }\n }\n\n public close(cb: BFSOneArgCallback): void {\n this.sync(cb);\n }\n}\n\nexport default class DropboxFileSystem extends BaseFileSystem implements FileSystem {\n public static isAvailable(): boolean {\n // Checks if the Dropbox library is loaded.\n return typeof Dropbox !== 'undefined';\n }\n\n // The Dropbox client.\n private _client: CachedDropboxClient;\n\n /**\n * Arguments: an authenticated Dropbox.js client\n */\n constructor(client: Dropbox.Client) {\n super();\n this._client = new CachedDropboxClient(client);\n constructErrorCodeLookup();\n }\n\n public getName(): string {\n return 'Dropbox';\n }\n\n public isReadOnly(): boolean {\n return false;\n }\n\n // Dropbox doesn't support symlinks, properties, or synchronous calls\n\n public supportsSymlinks(): boolean {\n return false;\n }\n\n public supportsProps(): boolean {\n return false;\n }\n\n public supportsSynch(): boolean {\n return false;\n }\n\n public empty(mainCb: BFSOneArgCallback): void {\n this._client.readdir('/', (error, files) => {\n if (error) {\n mainCb(this.convert(error, '/'));\n } else {\n const deleteFile = (file: string, cb: BFSOneArgCallback) => {\n const p = path.join('/', file);\n this._client.remove(p, (err) => {\n cb(err ? this.convert(err, p) : null);\n });\n };\n const finished = (err?: ApiError) => {\n if (err) {\n mainCb(err);\n } else {\n mainCb();\n }\n };\n // XXX: typing is to get around overly-restrictive ErrorCallback typing.\n asyncEach(files!, deleteFile, finished);\n }\n });\n }\n\n public rename(oldPath: string, newPath: string, cb: BFSOneArgCallback): void {\n this._client.move(oldPath, newPath, (error) => {\n if (error) {\n // the move is permitted if newPath is a file.\n // Check if this is the case, and remove if so.\n this._client.stat(newPath, (error2, stat) => {\n if (error2 || stat!.isFolder) {\n const missingPath = ( error.response).error.indexOf(oldPath) > -1 ? oldPath : newPath;\n cb(this.convert(error, missingPath));\n } else {\n // Delete file, repeat rename.\n this._client.remove(newPath, (error2) => {\n if (error2) {\n cb(this.convert(error2, newPath));\n } else {\n this.rename(oldPath, newPath, cb);\n }\n });\n }\n });\n } else {\n cb();\n }\n });\n }\n\n public stat(path: string, isLstat: boolean, cb: BFSCallback): void {\n // Ignore lstat case -- Dropbox doesn't support symlinks\n // Stat the file\n this._client.stat(path, (error, stat) => {\n if (error) {\n cb(this.convert(error, path));\n } else if (stat && stat.isRemoved) {\n // Dropbox keeps track of deleted files, so if a file has existed in the\n // past but doesn't any longer, you wont get an error\n cb(ApiError.FileError(ErrorCode.ENOENT, path));\n } else {\n const stats = new Stats(this._statType(stat!), stat!.size);\n return cb(null, stats);\n }\n });\n }\n\n public open(path: string, flags: FileFlag, mode: number, cb: BFSCallback): void {\n // Try and get the file's contents\n this._client.readFile(path, (error, content, dbStat) => {\n if (error) {\n // If the file's being opened for reading and doesn't exist, return an\n // error\n if (flags.isReadable()) {\n cb(this.convert(error, path));\n } else {\n switch (error.status) {\n // If it's being opened for writing or appending, create it so that\n // it can be written to\n case Dropbox.ApiError.NOT_FOUND:\n const ab = new ArrayBuffer(0);\n return this._writeFileStrict(path, ab, (error2: ApiError, stat?: Dropbox.File.Stat) => {\n if (error2) {\n cb(error2);\n } else {\n const file = this._makeFile(path, flags, stat!, arrayBuffer2Buffer(ab));\n cb(null, file);\n }\n });\n default:\n return cb(this.convert(error, path));\n }\n }\n } else {\n // No error\n let buffer: Buffer;\n // Dropbox.js seems to set `content` to `null` rather than to an empty\n // buffer when reading an empty file. Not sure why this is.\n if (content === null) {\n buffer = new Buffer(0);\n } else {\n buffer = arrayBuffer2Buffer(content!);\n }\n const file = this._makeFile(path, flags, dbStat!, buffer);\n return cb(null, file);\n }\n });\n }\n\n public _writeFileStrict(p: string, data: ArrayBuffer, cb: BFSCallback): void {\n const parent = path.dirname(p);\n this.stat(parent, false, (error: ApiError, stat?: Stats): void => {\n if (error) {\n cb(ApiError.FileError(ErrorCode.ENOENT, parent));\n } else {\n this._client.writeFile(p, data, (error2, stat) => {\n if (error2) {\n cb(this.convert(error2, p));\n } else {\n cb(null, stat);\n }\n });\n }\n });\n }\n\n /**\n * Private\n * Returns a BrowserFS object representing the type of a Dropbox.js stat object\n */\n public _statType(stat: Dropbox.File.Stat): FileType {\n return stat.isFile ? FileType.FILE : FileType.DIRECTORY;\n }\n\n /**\n * Private\n * Returns a BrowserFS object representing a File, created from the data\n * returned by calls to the Dropbox API.\n */\n public _makeFile(path: string, flag: FileFlag, stat: Dropbox.File.Stat, buffer: Buffer): DropboxFile {\n const type = this._statType(stat);\n const stats = new Stats(type, stat.size);\n return new DropboxFile(this, path, flag, stats, buffer);\n }\n\n /**\n * Private\n * Delete a file or directory from Dropbox\n * isFile should reflect which call was made to remove the it (`unlink` or\n * `rmdir`). If this doesn't match what's actually at `path`, an error will be\n * returned\n */\n public _remove(path: string, cb: BFSOneArgCallback, isFile: boolean): void {\n this._client.stat(path, (error, stat) => {\n if (error) {\n cb(this.convert(error, path));\n } else {\n if (stat!.isFile && !isFile) {\n cb(ApiError.FileError(ErrorCode.ENOTDIR, path));\n } else if (!stat!.isFile && isFile) {\n cb(ApiError.FileError(ErrorCode.EISDIR, path));\n } else {\n this._client.remove(path, (error) => {\n if (error) {\n cb(this.convert(error, path));\n } else {\n cb(null);\n }\n });\n }\n }\n });\n }\n\n /**\n * Delete a file\n */\n public unlink(path: string, cb: BFSOneArgCallback): void {\n this._remove(path, cb, true);\n }\n\n /**\n * Delete a directory\n */\n public rmdir(path: string, cb: BFSOneArgCallback): void {\n this._remove(path, cb, false);\n }\n\n /**\n * Create a directory\n */\n public mkdir(p: string, mode: number, cb: BFSOneArgCallback): void {\n // Dropbox.js' client.mkdir() behaves like `mkdir -p`, i.e. it creates a\n // directory and all its ancestors if they don't exist.\n // Node's fs.mkdir() behaves like `mkdir`, i.e. it throws an error if an attempt\n // is made to create a directory without a parent.\n // To handle this inconsistency, a check for the existence of `path`'s parent\n // must be performed before it is created, and an error thrown if it does\n // not exist\n const parent = path.dirname(p);\n this._client.stat(parent, (error, stat) => {\n if (error) {\n cb(this.convert(error, parent));\n } else {\n this._client.mkdir(p, (error) => {\n if (error) {\n cb(ApiError.FileError(ErrorCode.EEXIST, p));\n } else {\n cb(null);\n }\n });\n }\n });\n }\n\n /**\n * Get the names of the files in a directory\n */\n public readdir(path: string, cb: BFSCallback): void {\n this._client.readdir(path, (error, files) => {\n if (error) {\n return cb(this.convert(error));\n } else {\n return cb(null, files);\n }\n });\n }\n\n /**\n * Converts a Dropbox-JS error into a BFS error.\n */\n public convert(err: Dropbox.ApiError, path: string | null = null): ApiError {\n let errorCode = errorCodeLookup[err.status];\n if (errorCode === undefined) {\n errorCode = ErrorCode.EIO;\n }\n\n if (!path) {\n return new ApiError(errorCode);\n } else {\n return ApiError.FileError(errorCode, path);\n }\n }\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../src/backend/Dropbox.ts","import {SynchronousFileSystem, BFSOneArgCallback, BFSCallback, BFSThreeArgCallback} from '../core/file_system';\nimport {default as Stats, FileType} from '../core/node_fs_stats';\nimport {FileFlag} from '../core/file_flag';\nimport {BaseFile, File} from '../core/file';\nimport {uint8Array2Buffer, buffer2Uint8array} from '../core/util';\nimport {ApiError, ErrorCode, ErrorStrings} from '../core/api_error';\nimport {EmscriptenFSNode} from '../generic/emscripten_fs';\n\ninterface EmscriptenError {\n node: EmscriptenFSNode;\n errno: number;\n}\n\nfunction convertError(e: EmscriptenError, path: string = ''): ApiError {\n const errno = e.errno;\n let parent = e.node;\n const paths: string[] = [];\n while (parent) {\n paths.unshift(parent.name);\n if (parent === parent.parent) {\n break;\n }\n parent = parent.parent;\n }\n return new ApiError(errno, ErrorStrings[errno], paths.length > 0 ? '/' + paths.join('/') : path);\n}\n\nexport class EmscriptenFile extends BaseFile implements File {\n constructor(\n private _fs: EmscriptenFileSystem,\n private _FS: any,\n private _path: string,\n private _stream: any) {\n super();\n }\n public getPos(): number | undefined {\n return undefined;\n }\n public close(cb: BFSOneArgCallback): void {\n let err: ApiError | null = null;\n try {\n this.closeSync();\n } catch (e) {\n err = e;\n } finally {\n cb(err);\n }\n }\n public closeSync(): void {\n try {\n this._FS.close(this._stream);\n } catch (e) {\n throw convertError(e, this._path);\n }\n }\n public stat(cb: BFSCallback): void {\n try {\n cb(null, this.statSync());\n } catch (e) {\n cb(e);\n }\n }\n public statSync(): Stats {\n try {\n return this._fs.statSync(this._path, false);\n } catch (e) {\n throw convertError(e, this._path);\n }\n }\n public truncate(len: number, cb: BFSOneArgCallback): void {\n let err: ApiError | null = null;\n try {\n this.truncateSync(len);\n } catch (e) {\n err = e;\n } finally {\n cb(err);\n }\n }\n public truncateSync(len: number): void {\n try {\n this._FS.ftruncate(this._stream.fd, len);\n } catch (e) {\n throw convertError(e, this._path);\n }\n }\n public write(buffer: NodeBuffer, offset: number, length: number, position: number, cb: BFSThreeArgCallback): void {\n try {\n cb(null, this.writeSync(buffer, offset, length, position), buffer);\n } catch (e) {\n cb(e);\n }\n }\n public writeSync(buffer: NodeBuffer, offset: number, length: number, position: number | null): number {\n try {\n const u8 = buffer2Uint8array(buffer);\n // Emscripten is particular about what position is set to.\n const emPosition = position === null ? undefined : position;\n return this._FS.write(this._stream, u8, offset, length, emPosition);\n } catch (e) {\n throw convertError(e, this._path);\n }\n }\n public read(buffer: NodeBuffer, offset: number, length: number, position: number, cb: BFSThreeArgCallback): void {\n try {\n cb(null, this.readSync(buffer, offset, length, position), buffer);\n } catch (e) {\n cb(e);\n }\n }\n public readSync(buffer: NodeBuffer, offset: number, length: number, position: number | null): number {\n try {\n const u8 = buffer2Uint8array(buffer);\n // Emscripten is particular about what position is set to.\n const emPosition = position === null ? undefined : position;\n return this._FS.read(this._stream, u8, offset, length, emPosition);\n } catch (e) {\n throw convertError(e, this._path);\n }\n }\n public sync(cb: BFSOneArgCallback): void {\n // NOP.\n cb();\n }\n public syncSync(): void {\n // NOP.\n }\n public chown(uid: number, gid: number, cb: BFSOneArgCallback): void {\n let err: ApiError | null = null;\n try {\n this.chownSync(uid, gid);\n } catch (e) {\n err = e;\n } finally {\n cb(err);\n }\n }\n public chownSync(uid: number, gid: number): void {\n try {\n this._FS.fchown(this._stream.fd, uid, gid);\n } catch (e) {\n throw convertError(e, this._path);\n }\n }\n public chmod(mode: number, cb: BFSOneArgCallback): void {\n let err: ApiError | null = null;\n try {\n this.chmodSync(mode);\n } catch (e) {\n err = e;\n } finally {\n cb(err);\n }\n }\n public chmodSync(mode: number): void {\n try {\n this._FS.fchmod(this._stream.fd, mode);\n } catch (e) {\n throw convertError(e, this._path);\n }\n }\n public utimes(atime: Date, mtime: Date, cb: BFSOneArgCallback): void {\n let err: ApiError | null = null;\n try {\n this.utimesSync(atime, mtime);\n } catch (e) {\n err = e;\n } finally {\n cb(err);\n }\n }\n public utimesSync(atime: Date, mtime: Date): void {\n this._fs.utimesSync(this._path, atime, mtime);\n }\n}\n\n/**\n * A simple in-memory file system backed by an InMemoryStore.\n */\nexport default class EmscriptenFileSystem extends SynchronousFileSystem {\n public static isAvailable(): boolean { return true; }\n\n private _FS: any;\n\n constructor(_FS: any) {\n super();\n this._FS = _FS;\n }\n public getName(): string { return this._FS.DB_NAME(); }\n public isReadOnly(): boolean { return false; }\n public supportsLinks(): boolean { return true; }\n public supportsProps(): boolean { return true; }\n public supportsSynch(): boolean { return true; }\n\n public renameSync(oldPath: string, newPath: string): void {\n try {\n this._FS.rename(oldPath, newPath);\n } catch (e) {\n if (e.errno === ErrorCode.ENOENT) {\n throw convertError(e, this.existsSync(oldPath) ? newPath : oldPath);\n } else {\n throw convertError(e);\n }\n }\n }\n\n public statSync(p: string, isLstat: boolean): Stats {\n try {\n const stats = isLstat ? this._FS.lstat(p) : this._FS.stat(p);\n const itemType = this.modeToFileType(stats.mode);\n return new Stats(\n itemType,\n stats.size,\n stats.mode,\n stats.atime,\n stats.mtime,\n stats.ctime\n );\n } catch (e) {\n throw convertError(e, p);\n }\n }\n\n public openSync(p: string, flag: FileFlag, mode: number): EmscriptenFile {\n try {\n const stream = this._FS.open(p, flag.getFlagString(), mode);\n if (this._FS.isDir(stream.node.mode)) {\n this._FS.close(stream);\n throw ApiError.EISDIR(p);\n }\n return new EmscriptenFile(this, this._FS, p, stream);\n } catch (e) {\n throw convertError(e, p);\n }\n }\n\n public unlinkSync(p: string): void {\n try {\n this._FS.unlink(p);\n } catch (e) {\n throw convertError(e, p);\n }\n }\n\n public rmdirSync(p: string): void {\n try {\n this._FS.rmdir(p);\n } catch (e) {\n throw convertError(e, p);\n }\n }\n\n public mkdirSync(p: string, mode: number): void {\n try {\n this._FS.mkdir(p, mode);\n } catch (e) {\n throw convertError(e, p);\n }\n }\n\n public readdirSync(p: string): string[] {\n try {\n // Emscripten returns items for '.' and '..'. Node does not.\n return this._FS.readdir(p).filter((p: string) => p !== '.' && p !== '..');\n } catch (e) {\n throw convertError(e, p);\n }\n }\n\n public truncateSync(p: string, len: number): void {\n try {\n this._FS.truncate(p, len);\n } catch (e) {\n throw convertError(e, p);\n }\n }\n\n public readFileSync(p: string, encoding: string, flag: FileFlag): any {\n try {\n const data: Uint8Array = this._FS.readFile(p, { flags: flag.getFlagString() });\n const buff = uint8Array2Buffer(data);\n if (encoding) {\n return buff.toString(encoding);\n } else {\n return buff;\n }\n } catch (e) {\n throw convertError(e, p);\n }\n }\n\n public writeFileSync(p: string, data: any, encoding: string, flag: FileFlag, mode: number): void {\n try {\n if (encoding) {\n data = new Buffer(data, encoding);\n }\n const u8 = buffer2Uint8array(data);\n this._FS.writeFile(p, u8, { flags: flag.getFlagString(), encoding: 'binary' });\n this._FS.chmod(p, mode);\n } catch (e) {\n throw convertError(e, p);\n }\n }\n\n public chmodSync(p: string, isLchmod: boolean, mode: number) {\n try {\n isLchmod ? this._FS.lchmod(p, mode) : this._FS.chmod(p, mode);\n } catch (e) {\n throw convertError(e, p);\n }\n }\n\n public chownSync(p: string, isLchown: boolean, uid: number, gid: number): void {\n try {\n isLchown ? this._FS.lchown(p, uid, gid) : this._FS.chown(p, uid, gid);\n } catch (e) {\n throw convertError(e, p);\n }\n }\n\n public symlinkSync(srcpath: string, dstpath: string, type: string): void {\n try {\n this._FS.symlink(srcpath, dstpath);\n } catch (e) {\n throw convertError(e);\n }\n }\n\n public readlinkSync(p: string): string {\n try {\n return this._FS.readlink(p);\n } catch (e) {\n throw convertError(e, p);\n }\n }\n\n public utimesSync(p: string, atime: Date, mtime: Date): void {\n try {\n this._FS.utime(p, atime.getTime(), mtime.getTime());\n } catch (e) {\n throw convertError(e, p);\n }\n }\n\n private modeToFileType(mode: number): FileType {\n if (this._FS.isDir(mode)) {\n return FileType.DIRECTORY;\n } else if (this._FS.isFile(mode)) {\n return FileType.FILE;\n } else if (this._FS.isLink(mode)) {\n return FileType.SYMLINK;\n } else {\n throw ApiError.EPERM(`Invalid mode: ${mode}`);\n }\n }\n\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../src/backend/Emscripten.ts","import {BaseFileSystem, FileSystem} from '../core/file_system';\nimport * as path from 'path';\nimport {ApiError} from '../core/api_error';\n\n/**\n * The FolderAdapter file system wraps a file system, and scopes all interactions to a subfolder of that file system.\n */\nexport default class FolderAdapter extends BaseFileSystem implements FileSystem {\n public static isAvailable(): boolean {\n return true;\n }\n\n public _wrapped: FileSystem;\n public _folder: string;\n constructor(folder: string, wrapped: FileSystem) {\n super();\n this._folder = folder;\n this._wrapped = wrapped;\n }\n\n /**\n * Initialize the file system. Ensures that the wrapped file system\n * has the given folder.\n */\n public initialize(cb: (e?: ApiError) => void) {\n this._wrapped.exists(this._folder, (exists: boolean) => {\n if (exists) {\n cb();\n } else if (this._wrapped.isReadOnly()) {\n cb(ApiError.ENOENT(this._folder));\n } else {\n this._wrapped.mkdir(this._folder, 0x1ff, cb);\n }\n });\n }\n\n public getName(): string { return this._wrapped.getName(); }\n public isReadOnly(): boolean { return this._wrapped.isReadOnly(); }\n public supportsProps(): boolean { return this._wrapped.supportsProps(); }\n public supportsSynch(): boolean { return this._wrapped.supportsSynch(); }\n public supportsLinks(): boolean { return false; }\n}\n\nfunction translateError(folder: string, e: any): any {\n if (e !== null && typeof e === 'object') {\n const err = e;\n let p = err.path;\n if (p) {\n p = '/' + path.relative(folder, p);\n err.message = err.message.replace(err.path!, p);\n err.path = p;\n }\n }\n return e;\n}\n\nfunction wrapCallback(folder: string, cb: any): any {\n if (typeof cb === 'function') {\n return function(err: ApiError) {\n if (arguments.length > 0) {\n arguments[0] = translateError(folder, err);\n }\n ( cb).apply(null, arguments);\n };\n } else {\n return cb;\n }\n}\n\nfunction wrapFunction(name: string, wrapFirst: boolean, wrapSecond: boolean): Function {\n if (name.slice(name.length - 4) !== 'Sync') {\n // Async function. Translate error in callback.\n return function(this: FolderAdapter) {\n if (arguments.length > 0) {\n if (wrapFirst) {\n arguments[0] = path.join(this._folder, arguments[0]);\n }\n if (wrapSecond) {\n arguments[1] = path.join(this._folder, arguments[1]);\n }\n arguments[arguments.length - 1] = wrapCallback(this._folder, arguments[arguments.length - 1]);\n }\n return ( this._wrapped)[name].apply(this._wrapped, arguments);\n };\n } else {\n // Sync function. Translate error in catch.\n return function(this: FolderAdapter) {\n try {\n if (wrapFirst) {\n arguments[0] = path.join(this._folder, arguments[0]);\n }\n if (wrapSecond) {\n arguments[1] = path.join(this._folder, arguments[1]);\n }\n return ( this._wrapped)[name].apply(this._wrapped, arguments);\n } catch (e) {\n throw translateError(this._folder, e);\n }\n };\n }\n}\n\n// First argument is a path.\n['diskSpace', 'stat', 'statSync', 'open', 'openSync', 'unlink', 'unlinkSync',\n 'rmdir', 'rmdirSync', 'mkdir', 'mkdirSync', 'readdir', 'readdirSync', 'exists',\n 'existsSync', 'realpath', 'realpathSync', 'truncate', 'truncateSync', 'readFile',\n 'readFileSync', 'writeFile', 'writeFileSync', 'appendFile', 'appendFileSync',\n 'chmod', 'chmodSync', 'chown', 'chownSync', 'utimes', 'utimesSync', 'readlink',\n 'readlinkSync'].forEach((name: string) => {\n ( FolderAdapter.prototype)[name] = wrapFunction(name, true, false);\n});\n\n// First and second arguments are paths.\n['rename', 'renameSync', 'link', 'linkSync', 'symlink', 'symlinkSync'].forEach((name: string) => {\n ( FolderAdapter.prototype)[name] = wrapFunction(name, true, true);\n});\n\n\n\n// WEBPACK FOOTER //\n// ../../../../src/backend/FolderAdapter.ts","import PreloadFile from '../generic/preload_file';\nimport {BaseFileSystem, FileSystem as IFileSystem, BFSOneArgCallback, BFSCallback} from '../core/file_system';\nimport {ApiError, ErrorCode} from '../core/api_error';\nimport {FileFlag, ActionType} from '../core/file_flag';\nimport {default as Stats, FileType} from '../core/node_fs_stats';\nimport {File as IFile} from '../core/file';\nimport * as path from 'path';\nimport global from '../core/global';\nimport {each as asyncEach} from 'async';\nimport {buffer2ArrayBuffer, arrayBuffer2Buffer} from '../core/util';\n\nfunction isDirectoryEntry(entry: Entry): entry is DirectoryEntry {\n return entry.isDirectory;\n}\n\nconst _getFS: (type: number, size: number, successCallback: FileSystemCallback, errorCallback?: ErrorCallback) => void = global.webkitRequestFileSystem || global.requestFileSystem || null;\n\nfunction _requestQuota(type: number, size: number, success: (size: number) => void, errorCallback: ErrorCallback) {\n // We cast navigator and window to '' because everything here is\n // nonstandard functionality, despite the fact that Chrome has the only\n // implementation of the HTML5FS and is likely driving the standardization\n // process. Thus, these objects defined off of navigator and window are not\n // present in the DefinitelyTyped TypeScript typings for FileSystem.\n if (typeof ( navigator)['webkitPersistentStorage'] !== 'undefined') {\n switch (type) {\n case global.PERSISTENT:\n ( navigator).webkitPersistentStorage.requestQuota(size, success, errorCallback);\n break;\n case global.TEMPORARY:\n ( navigator).webkitTemporaryStorage.requestQuota(size, success, errorCallback);\n break;\n default:\n errorCallback(new TypeError(`Invalid storage type: ${type}`));\n break;\n }\n } else {\n ( global).webkitStorageInfo.requestQuota(type, size, success, errorCallback);\n }\n}\n\nfunction _toArray(list?: any[]): any[] {\n return Array.prototype.slice.call(list || [], 0);\n}\n\n/**\n * Converts the given DOMError into an appropriate ApiError.\n * Full list of values here:\n * https://developer.mozilla.org/en-US/docs/Web/API/DOMError\n */\nfunction convertError(err: DOMError, p: string, expectedDir: boolean): ApiError {\n switch (err.name) {\n /* The user agent failed to create a file or directory due to the existence of a file or\n directory with the same path. */\n case \"PathExistsError\":\n return ApiError.EEXIST(p);\n /* The operation failed because it would cause the application to exceed its storage quota. */\n case 'QuotaExceededError':\n return ApiError.FileError(ErrorCode.ENOSPC, p);\n /* A required file or directory could not be found at the time an operation was processed. */\n case 'NotFoundError':\n return ApiError.ENOENT(p);\n /* This is a security error code to be used in situations not covered by any other error codes.\n - A required file was unsafe for access within a Web application\n - Too many calls are being made on filesystem resources */\n case 'SecurityError':\n return ApiError.FileError(ErrorCode.EACCES, p);\n /* The modification requested was illegal. Examples of invalid modifications include moving a\n directory into its own child, moving a file into its parent directory without changing its name,\n or copying a directory to a path occupied by a file. */\n case 'InvalidModificationError':\n return ApiError.FileError(ErrorCode.EPERM, p);\n /* The user has attempted to look up a file or directory, but the Entry found is of the wrong type\n [e.g. is a DirectoryEntry when the user requested a FileEntry]. */\n case 'TypeMismatchError':\n return ApiError.FileError(expectedDir ? ErrorCode.ENOTDIR : ErrorCode.EISDIR, p);\n /* A path or URL supplied to the API was malformed. */\n case \"EncodingError\":\n /* An operation depended on state cached in an interface object, but that state that has changed\n since it was read from disk. */\n case \"InvalidStateError\":\n /* The user attempted to write to a file or directory which could not be modified due to the state\n of the underlying filesystem. */\n case \"NoModificationAllowedError\":\n default:\n return ApiError.FileError(ErrorCode.EINVAL, p);\n }\n}\n\n// A note about getFile and getDirectory options:\n// These methods are called at numerous places in this file, and are passed\n// some combination of these two options:\n// - create: If true, the entry will be created if it doesn't exist.\n// If false, an error will be thrown if it doesn't exist.\n// - exclusive: If true, only create the entry if it doesn't already exist,\n// and throw an error if it does.\n\nexport class HTML5FSFile extends PreloadFile implements IFile {\n private _entry: FileEntry;\n\n constructor(fs: HTML5FS, entry: FileEntry, path: string, flag: FileFlag, stat: Stats, contents?: Buffer) {\n super(fs, path, flag, stat, contents);\n this._entry = entry;\n }\n\n public sync(cb: BFSOneArgCallback): void {\n if (!this.isDirty()) {\n return cb();\n }\n\n this._entry.createWriter((writer) => {\n const buffer = this.getBuffer();\n const blob = new Blob([buffer2ArrayBuffer(buffer)]);\n const length = blob.size;\n writer.onwriteend = (err?: any) => {\n writer.onwriteend = null;\n writer.onerror = null;\n writer.truncate(length);\n this.resetDirty();\n cb();\n };\n writer.onerror = (err: any) => {\n cb(convertError(err, this.getPath(), false));\n };\n writer.write(blob);\n });\n }\n\n public close(cb: BFSOneArgCallback): void {\n this.sync(cb);\n }\n}\n\nexport default class HTML5FS extends BaseFileSystem implements IFileSystem {\n public static isAvailable(): boolean {\n return !!_getFS;\n }\n\n // HTML5File reaches into HTML5FS. :/\n public fs: FileSystem;\n private size: number;\n private type: number;\n /**\n * Arguments:\n * - type: PERSISTENT or TEMPORARY\n * - size: storage quota to request, in megabytes. Allocated value may be less.\n */\n constructor(size: number = 5, type: number = global.PERSISTENT) {\n super();\n // Convert MB to bytes.\n this.size = 1024 * 1024 * size;\n this.type = type;\n }\n\n public getName(): string {\n return 'HTML5 FileSystem';\n }\n\n public isReadOnly(): boolean {\n return false;\n }\n\n public supportsSymlinks(): boolean {\n return false;\n }\n\n public supportsProps(): boolean {\n return false;\n }\n\n public supportsSynch(): boolean {\n return false;\n }\n\n /**\n * Nonstandard\n * Requests a storage quota from the browser to back this FS.\n */\n public allocate(cb: BFSOneArgCallback = () => {/*nop*/}): void {\n const success = (fs: FileSystem): void => {\n this.fs = fs;\n cb();\n };\n const error = (err: DOMException): void => {\n cb(convertError(err, \"/\", true));\n };\n if (this.type === global.PERSISTENT) {\n _requestQuota(this.type, this.size, (granted: number) => {\n _getFS(this.type, granted, success, error);\n }, error);\n } else {\n _getFS(this.type, this.size, success, error);\n }\n }\n\n /**\n * Nonstandard\n * Deletes everything in the FS. Used for testing.\n * Karma clears the storage after you quit it but not between runs of the test\n * suite, and the tests expect an empty FS every time.\n */\n public empty(mainCb: BFSOneArgCallback): void {\n // Get a list of all entries in the root directory to delete them\n this._readdir('/', (err: ApiError, entries?: Entry[]): void => {\n if (err) {\n console.error('Failed to empty FS');\n mainCb(err);\n } else {\n // Called when every entry has been operated on\n const finished = (er: any): void => {\n if (err) {\n console.error(\"Failed to empty FS\");\n mainCb(err);\n } else {\n mainCb();\n }\n };\n // Removes files and recursively removes directories\n const deleteEntry = (entry: Entry, cb: (e?: any) => void): void => {\n const succ = () => {\n cb();\n };\n const error = (err: DOMException) => {\n cb(convertError(err, entry.fullPath, !entry.isDirectory));\n };\n if (isDirectoryEntry(entry)) {\n entry.removeRecursively(succ, error);\n } else {\n entry.remove(succ, error);\n }\n };\n // Loop through the entries and remove them, then call the callback\n // when they're all finished.\n asyncEach(entries!, deleteEntry, finished);\n }\n });\n }\n\n public rename(oldPath: string, newPath: string, cb: BFSOneArgCallback): void {\n let semaphore: number = 2;\n let successCount: number = 0;\n const root: DirectoryEntry = this.fs.root;\n let currentPath: string = oldPath;\n const error = (err: DOMException): void => {\n if (--semaphore <= 0) {\n cb(convertError(err, currentPath, false));\n }\n };\n const success = (file: Entry): void => {\n if (++successCount === 2) {\n return cb(new ApiError(ErrorCode.EINVAL, \"Something was identified as both a file and a directory. This should never happen.\"));\n }\n\n // SPECIAL CASE: If newPath === oldPath, and the path exists, then\n // this operation trivially succeeds.\n if (oldPath === newPath) {\n return cb();\n }\n\n // Get the new parent directory.\n currentPath = path.dirname(newPath);\n root.getDirectory(currentPath, {}, (parentDir: DirectoryEntry): void => {\n currentPath = path.basename(newPath);\n file.moveTo(parentDir, currentPath, (entry: Entry): void => { cb(); }, (err: DOMException): void => {\n // SPECIAL CASE: If oldPath is a directory, and newPath is a\n // file, rename should delete the file and perform the move.\n if (file.isDirectory) {\n currentPath = newPath;\n // Unlink only works on files. Try to delete newPath.\n this.unlink(newPath, (e?): void => {\n if (e) {\n // newPath is probably a directory.\n error(err);\n } else {\n // Recur, now that newPath doesn't exist.\n this.rename(oldPath, newPath, cb);\n }\n });\n } else {\n error(err);\n }\n });\n }, error);\n };\n\n // We don't know if oldPath is a *file* or a *directory*, and there's no\n // way to stat items. So launch both requests, see which one succeeds.\n root.getFile(oldPath, {}, success, error);\n root.getDirectory(oldPath, {}, success, error);\n }\n\n public stat(path: string, isLstat: boolean, cb: BFSCallback): void {\n // Throw an error if the entry doesn't exist, because then there's nothing\n // to stat.\n const opts = {\n create: false\n };\n // Called when the path has been successfully loaded as a file.\n const loadAsFile = (entry: FileEntry): void => {\n const fileFromEntry = (file: File): void => {\n const stat = new Stats(FileType.FILE, file.size);\n cb(null, stat);\n };\n entry.file(fileFromEntry, failedToLoad);\n };\n // Called when the path has been successfully loaded as a directory.\n const loadAsDir = (dir: DirectoryEntry): void => {\n // Directory entry size can't be determined from the HTML5 FS API, and is\n // implementation-dependant anyway, so a dummy value is used.\n const size = 4096;\n const stat = new Stats(FileType.DIRECTORY, size);\n cb(null, stat);\n };\n // Called when the path couldn't be opened as a directory or a file.\n const failedToLoad = (err: DOMException): void => {\n cb(convertError(err, path, false /* Unknown / irrelevant */));\n };\n // Called when the path couldn't be opened as a file, but might still be a\n // directory.\n const failedToLoadAsFile = (): void => {\n this.fs.root.getDirectory(path, opts, loadAsDir, failedToLoad);\n };\n // No method currently exists to determine whether a path refers to a\n // directory or a file, so this implementation tries both and uses the first\n // one that succeeds.\n this.fs.root.getFile(path, opts, loadAsFile, failedToLoadAsFile);\n }\n\n public open(p: string, flags: FileFlag, mode: number, cb: BFSCallback): void {\n // XXX: err is a DOMError\n const error = (err: any): void => {\n if (err.name === 'InvalidModificationError' && flags.isExclusive()) {\n cb(ApiError.EEXIST(p));\n } else {\n cb(convertError(err, p, false));\n }\n };\n\n this.fs.root.getFile(p, {\n create: flags.pathNotExistsAction() === ActionType.CREATE_FILE,\n exclusive: flags.isExclusive()\n }, (entry: FileEntry): void => {\n // Try to fetch corresponding file.\n entry.file((file: File): void => {\n const reader = new FileReader();\n reader.onloadend = (event: Event): void => {\n const bfsFile = this._makeFile(p, entry, flags, file, reader.result);\n cb(null, bfsFile);\n };\n reader.onerror = (ev: Event) => {\n error(reader.error);\n };\n reader.readAsArrayBuffer(file);\n }, error);\n }, error);\n }\n\n public unlink(path: string, cb: BFSOneArgCallback): void {\n this._remove(path, cb, true);\n }\n\n public rmdir(path: string, cb: BFSOneArgCallback): void {\n // Check if directory is non-empty, first.\n this.readdir(path, (e, files?) => {\n if (e) {\n cb(e);\n } else if (files!.length > 0) {\n cb(ApiError.ENOTEMPTY(path));\n } else {\n this._remove(path, cb, false);\n }\n });\n }\n\n public mkdir(path: string, mode: number, cb: BFSOneArgCallback): void {\n // Create the directory, but throw an error if it already exists, as per\n // mkdir(1)\n const opts = {\n create: true,\n exclusive: true\n };\n const success = (dir: DirectoryEntry): void => {\n cb();\n };\n const error = (err: DOMException): void => {\n cb(convertError(err, path, true));\n };\n this.fs.root.getDirectory(path, opts, success, error);\n }\n\n /**\n * Map _readdir's list of `FileEntry`s to their names and return that.\n */\n public readdir(path: string, cb: BFSCallback): void {\n this._readdir(path, (e: ApiError, entries?: Entry[]): void => {\n if (e) {\n return cb(e);\n }\n const rv: string[] = [];\n for (let i = 0; i < entries!.length; i++) {\n rv.push(entries![i].name);\n }\n cb(null, rv);\n });\n }\n\n /**\n * Returns a BrowserFS object representing a File.\n */\n private _makeFile(path: string, entry: FileEntry, flag: FileFlag, stat: File, data: ArrayBuffer = new ArrayBuffer(0)): HTML5FSFile {\n const stats = new Stats(FileType.FILE, stat.size);\n const buffer = arrayBuffer2Buffer(data);\n return new HTML5FSFile(this, entry, path, flag, stats, buffer);\n }\n\n /**\n * Returns an array of `FileEntry`s. Used internally by empty and readdir.\n */\n private _readdir(path: string, cb: BFSCallback): void {\n const error = (err: DOMException): void => {\n cb(convertError(err, path, true));\n };\n // Grab the requested directory.\n this.fs.root.getDirectory(path, { create: false }, (dirEntry: DirectoryEntry) => {\n const reader = dirEntry.createReader();\n let entries: Entry[] = [];\n\n // Call the reader.readEntries() until no more results are returned.\n const readEntries = () => {\n reader.readEntries(((results) => {\n if (results.length) {\n entries = entries.concat(_toArray(results));\n readEntries();\n } else {\n cb(null, entries);\n }\n }), error);\n };\n readEntries();\n }, error);\n }\n\n /**\n * Delete a file or directory from the file system\n * isFile should reflect which call was made to remove the it (`unlink` or\n * `rmdir`). If this doesn't match what's actually at `path`, an error will be\n * returned\n */\n private _remove(path: string, cb: BFSOneArgCallback, isFile: boolean): void {\n const success = (entry: Entry): void => {\n const succ = () => {\n cb();\n };\n const err = (err: DOMException) => {\n cb(convertError(err, path, !isFile));\n };\n entry.remove(succ, err);\n };\n const error = (err: DOMException): void => {\n cb(convertError(err, path, !isFile));\n };\n // Deleting the entry, so don't create it\n const opts = {\n create: false\n };\n\n if (isFile) {\n this.fs.root.getFile(path, opts, success, error);\n } else {\n this.fs.root.getDirectory(path, opts, success, error);\n }\n }\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../src/backend/HTML5FS.ts","import {BaseFileSystem, SynchronousFileSystem, BFSOneArgCallback, BFSCallback, BFSThreeArgCallback} from '../core/file_system';\nimport {ApiError, ErrorCode} from '../core/api_error';\nimport {default as Stats, FileType} from '../core/node_fs_stats';\nimport {File} from '../core/file';\nimport {FileFlag} from '../core/file_flag';\nimport * as path from 'path';\nimport Inode from '../generic/inode';\nimport PreloadFile from '../generic/preload_file';\nconst ROOT_NODE_ID: string = \"/\";\n\n/**\n * Generates a random ID.\n */\nfunction GenerateRandomID(): string {\n // From http://stackoverflow.com/questions/105034/how-to-create-a-guid-uuid-in-javascript\n return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function(c) {\n const r = Math.random() * 16 | 0;\n const v = c === 'x' ? r : (r & 0x3 | 0x8);\n return v.toString(16);\n });\n}\n\n/**\n * Helper function. Checks if 'e' is defined. If so, it triggers the callback\n * with 'e' and returns false. Otherwise, returns true.\n */\nfunction noError(e: ApiError | undefined | null, cb: (e: ApiError) => void): boolean {\n if (e) {\n cb(e);\n return false;\n }\n return true;\n}\n\n/**\n * Helper function. Checks if 'e' is defined. If so, it aborts the transaction,\n * triggers the callback with 'e', and returns false. Otherwise, returns true.\n */\nfunction noErrorTx(e: ApiError | undefined | null, tx: AsyncKeyValueRWTransaction, cb: (e: ApiError) => void): boolean {\n if (e) {\n tx.abort(() => {\n cb(e);\n });\n return false;\n }\n return true;\n}\n\n/**\n * Represents a *synchronous* key-value store.\n */\nexport interface SyncKeyValueStore {\n /**\n * The name of the key-value store.\n */\n name(): string;\n /**\n * Empties the key-value store completely.\n */\n clear(): void;\n /**\n * Begins a new read-only transaction.\n */\n beginTransaction(type: \"readonly\"): SyncKeyValueROTransaction;\n /**\n * Begins a new read-write transaction.\n */\n beginTransaction(type: \"readwrite\"): SyncKeyValueRWTransaction;\n beginTransaction(type: string): SyncKeyValueROTransaction;\n}\n\n/**\n * A read-only transaction for a synchronous key value store.\n */\nexport interface SyncKeyValueROTransaction {\n /**\n * Retrieves the data at the given key. Throws an ApiError if an error occurs\n * or if the key does not exist.\n * @param key The key to look under for data.\n * @return The data stored under the key, or undefined if not present.\n */\n get(key: string): Buffer | undefined;\n}\n\n/**\n * A read-write transaction for a synchronous key value store.\n */\nexport interface SyncKeyValueRWTransaction extends SyncKeyValueROTransaction {\n /**\n * Adds the data to the store under the given key.\n * @param key The key to add the data under.\n * @param data The data to add to the store.\n * @param overwrite If 'true', overwrite any existing data. If 'false',\n * avoids storing the data if the key exists.\n * @return True if storage succeeded, false otherwise.\n */\n put(key: string, data: Buffer, overwrite: boolean): boolean;\n /**\n * Deletes the data at the given key.\n * @param key The key to delete from the store.\n */\n del(key: string): void;\n /**\n * Commits the transaction.\n */\n commit(): void;\n /**\n * Aborts and rolls back the transaction.\n */\n abort(): void;\n}\n\n/**\n * An interface for simple synchronous key-value stores that don't have special\n * support for transactions and such.\n */\nexport interface SimpleSyncStore {\n get(key: string): Buffer | undefined;\n put(key: string, data: Buffer, overwrite: boolean): boolean;\n del(key: string): void;\n}\n\n/**\n * A simple RW transaction for simple synchronous key-value stores.\n */\nexport class SimpleSyncRWTransaction implements SyncKeyValueRWTransaction {\n /**\n * Stores data in the keys we modify prior to modifying them.\n * Allows us to roll back commits.\n */\n private originalData: { [key: string]: Buffer | undefined } = {};\n /**\n * List of keys modified in this transaction, if any.\n */\n private modifiedKeys: string[] = [];\n\n constructor(private store: SimpleSyncStore) { }\n\n public get(key: string): Buffer | undefined {\n const val = this.store.get(key);\n this.stashOldValue(key, val);\n return val;\n }\n\n public put(key: string, data: Buffer, overwrite: boolean): boolean {\n this.markModified(key);\n return this.store.put(key, data, overwrite);\n }\n\n public del(key: string): void {\n this.markModified(key);\n this.store.del(key);\n }\n\n public commit(): void {/* NOP */}\n\n public abort(): void {\n // Rollback old values.\n for (let i = 0; i < this.modifiedKeys.length; i++) {\n const key = this.modifiedKeys[i];\n const value = this.originalData[key];\n if (!value) {\n // Key didn't exist.\n this.store.del(key);\n } else {\n // Key existed. Store old value.\n this.store.put(key, value, true);\n }\n }\n }\n\n /**\n * Stashes given key value pair into `originalData` if it doesn't already\n * exist. Allows us to stash values the program is requesting anyway to\n * prevent needless `get` requests if the program modifies the data later\n * on during the transaction.\n */\n private stashOldValue(key: string, value: Buffer | undefined) {\n // Keep only the earliest value in the transaction.\n if (!this.originalData.hasOwnProperty(key)) {\n this.originalData[key] = value;\n }\n }\n\n /**\n * Marks the given key as modified, and stashes its value if it has not been\n * stashed already.\n */\n private markModified(key: string) {\n if (this.modifiedKeys.indexOf(key) === -1) {\n this.modifiedKeys.push(key);\n if (!this.originalData.hasOwnProperty(key)) {\n this.originalData[key] = this.store.get(key);\n }\n }\n }\n}\n\nexport interface SyncKeyValueFileSystemOptions {\n /**\n * The actual key-value store to read from/write to.\n */\n store: SyncKeyValueStore;\n /**\n * Should the file system support properties (mtime/atime/ctime/chmod/etc)?\n * Enabling this slightly increases the storage space per file, and adds\n * atime updates every time a file is accessed, mtime updates every time\n * a file is modified, and permission checks on every operation.\n *\n * Defaults to *false*.\n */\n // supportProps?: boolean;\n /**\n * Should the file system support links?\n */\n // supportLinks?: boolean;\n}\n\nexport class SyncKeyValueFile extends PreloadFile implements File {\n constructor(_fs: SyncKeyValueFileSystem, _path: string, _flag: FileFlag, _stat: Stats, contents?: Buffer) {\n super(_fs, _path, _flag, _stat, contents);\n }\n\n public syncSync(): void {\n if (this.isDirty()) {\n this._fs._syncSync(this.getPath(), this.getBuffer(), this.getStats());\n this.resetDirty();\n }\n }\n\n public closeSync(): void {\n this.syncSync();\n }\n}\n\n/**\n * A \"Synchronous key-value file system\". Stores data to/retrieves data from an\n * underlying key-value store.\n *\n * We use a unique ID for each node in the file system. The root node has a\n * fixed ID.\n * @todo Introduce Node ID caching.\n * @todo Check modes.\n */\nexport class SyncKeyValueFileSystem extends SynchronousFileSystem {\n public static isAvailable(): boolean { return true; }\n\n private store: SyncKeyValueStore;\n\n constructor(options: SyncKeyValueFileSystemOptions) {\n super();\n this.store = options.store;\n // INVARIANT: Ensure that the root exists.\n this.makeRootDirectory();\n }\n\n public getName(): string { return this.store.name(); }\n public isReadOnly(): boolean { return false; }\n public supportsSymlinks(): boolean { return false; }\n public supportsProps(): boolean { return false; }\n public supportsSynch(): boolean { return true; }\n\n /**\n * Delete all contents stored in the file system.\n */\n public empty(): void {\n this.store.clear();\n // INVARIANT: Root always exists.\n this.makeRootDirectory();\n }\n\n public renameSync(oldPath: string, newPath: string): void {\n const tx = this.store.beginTransaction('readwrite'),\n oldParent = path.dirname(oldPath), oldName = path.basename(oldPath),\n newParent = path.dirname(newPath), newName = path.basename(newPath),\n // Remove oldPath from parent's directory listing.\n oldDirNode = this.findINode(tx, oldParent),\n oldDirList = this.getDirListing(tx, oldParent, oldDirNode);\n\n if (!oldDirList[oldName]) {\n throw ApiError.ENOENT(oldPath);\n }\n const nodeId: string = oldDirList[oldName];\n delete oldDirList[oldName];\n\n // Invariant: Can't move a folder inside itself.\n // This funny little hack ensures that the check passes only if oldPath\n // is a subpath of newParent. We append '/' to avoid matching folders that\n // are a substring of the bottom-most folder in the path.\n if ((newParent + '/').indexOf(oldPath + '/') === 0) {\n throw new ApiError(ErrorCode.EBUSY, oldParent);\n }\n\n // Add newPath to parent's directory listing.\n let newDirNode: Inode, newDirList: typeof oldDirList;\n if (newParent === oldParent) {\n // Prevent us from re-grabbing the same directory listing, which still\n // contains oldName.\n newDirNode = oldDirNode;\n newDirList = oldDirList;\n } else {\n newDirNode = this.findINode(tx, newParent);\n newDirList = this.getDirListing(tx, newParent, newDirNode);\n }\n\n if (newDirList[newName]) {\n // If it's a file, delete it.\n const newNameNode = this.getINode(tx, newPath, newDirList[newName]);\n if (newNameNode.isFile()) {\n try {\n tx.del(newNameNode.id);\n tx.del(newDirList[newName]);\n } catch (e) {\n tx.abort();\n throw e;\n }\n } else {\n // If it's a directory, throw a permissions error.\n throw ApiError.EPERM(newPath);\n }\n }\n newDirList[newName] = nodeId;\n\n // Commit the two changed directory listings.\n try {\n tx.put(oldDirNode.id, new Buffer(JSON.stringify(oldDirList)), true);\n tx.put(newDirNode.id, new Buffer(JSON.stringify(newDirList)), true);\n } catch (e) {\n tx.abort();\n throw e;\n }\n\n tx.commit();\n }\n\n public statSync(p: string, isLstat: boolean): Stats {\n // Get the inode to the item, convert it into a Stats object.\n return this.findINode(this.store.beginTransaction('readonly'), p).toStats();\n }\n\n public createFileSync(p: string, flag: FileFlag, mode: number): File {\n const tx = this.store.beginTransaction('readwrite'),\n data = new Buffer(0),\n newFile = this.commitNewFile(tx, p, FileType.FILE, mode, data);\n // Open the file.\n return new SyncKeyValueFile(this, p, flag, newFile.toStats(), data);\n }\n\n public openFileSync(p: string, flag: FileFlag): File {\n const tx = this.store.beginTransaction('readonly'),\n node = this.findINode(tx, p),\n data = tx.get(node.id);\n if (data === undefined) {\n throw ApiError.ENOENT(p);\n }\n return new SyncKeyValueFile(this, p, flag, node.toStats(), data);\n }\n\n public unlinkSync(p: string): void {\n this.removeEntry(p, false);\n }\n\n public rmdirSync(p: string): void {\n // Check first if directory is empty.\n if (this.readdirSync(p).length > 0) {\n throw ApiError.ENOTEMPTY(p);\n } else {\n this.removeEntry(p, true);\n }\n }\n\n public mkdirSync(p: string, mode: number): void {\n const tx = this.store.beginTransaction('readwrite'),\n data = new Buffer('{}');\n this.commitNewFile(tx, p, FileType.DIRECTORY, mode, data);\n }\n\n public readdirSync(p: string): string[] {\n const tx = this.store.beginTransaction('readonly');\n return Object.keys(this.getDirListing(tx, p, this.findINode(tx, p)));\n }\n\n public _syncSync(p: string, data: Buffer, stats: Stats): void {\n // @todo Ensure mtime updates properly, and use that to determine if a data\n // update is required.\n const tx = this.store.beginTransaction('readwrite'),\n // We use the _findInode helper because we actually need the INode id.\n fileInodeId = this._findINode(tx, path.dirname(p), path.basename(p)),\n fileInode = this.getINode(tx, p, fileInodeId),\n inodeChanged = fileInode.update(stats);\n\n try {\n // Sync data.\n tx.put(fileInode.id, data, true);\n // Sync metadata.\n if (inodeChanged) {\n tx.put(fileInodeId, fileInode.toBuffer(), true);\n }\n } catch (e) {\n tx.abort();\n throw e;\n }\n tx.commit();\n }\n\n /**\n * Checks if the root directory exists. Creates it if it doesn't.\n */\n private makeRootDirectory() {\n const tx = this.store.beginTransaction('readwrite');\n if (tx.get(ROOT_NODE_ID) === undefined) {\n // Create new inode.\n const currTime = (new Date()).getTime(),\n // Mode 0666\n dirInode = new Inode(GenerateRandomID(), 4096, 511 | FileType.DIRECTORY, currTime, currTime, currTime);\n // If the root doesn't exist, the first random ID shouldn't exist,\n // either.\n tx.put(dirInode.id, new Buffer(\"{}\"), false);\n tx.put(ROOT_NODE_ID, dirInode.toBuffer(), false);\n tx.commit();\n }\n }\n\n /**\n * Helper function for findINode.\n * @param parent The parent directory of the file we are attempting to find.\n * @param filename The filename of the inode we are attempting to find, minus\n * the parent.\n * @return string The ID of the file's inode in the file system.\n */\n private _findINode(tx: SyncKeyValueROTransaction, parent: string, filename: string): string {\n const readDirectory = (inode: Inode): string => {\n // Get the root's directory listing.\n const dirList = this.getDirListing(tx, parent, inode);\n // Get the file's ID.\n if (dirList[filename]) {\n return dirList[filename];\n } else {\n throw ApiError.ENOENT(path.resolve(parent, filename));\n }\n };\n if (parent === '/') {\n if (filename === '') {\n // BASE CASE #1: Return the root's ID.\n return ROOT_NODE_ID;\n } else {\n // BASE CASE #2: Find the item in the root ndoe.\n return readDirectory(this.getINode(tx, parent, ROOT_NODE_ID));\n }\n } else {\n return readDirectory(this.getINode(tx, parent + path.sep + filename,\n this._findINode(tx, path.dirname(parent), path.basename(parent))));\n }\n }\n\n /**\n * Finds the Inode of the given path.\n * @param p The path to look up.\n * @return The Inode of the path p.\n * @todo memoize/cache\n */\n private findINode(tx: SyncKeyValueROTransaction, p: string): Inode {\n return this.getINode(tx, p, this._findINode(tx, path.dirname(p), path.basename(p)));\n }\n\n /**\n * Given the ID of a node, retrieves the corresponding Inode.\n * @param tx The transaction to use.\n * @param p The corresponding path to the file (used for error messages).\n * @param id The ID to look up.\n */\n private getINode(tx: SyncKeyValueROTransaction, p: string, id: string): Inode {\n const inode = tx.get(id);\n if (inode === undefined) {\n throw ApiError.ENOENT(p);\n }\n return Inode.fromBuffer(inode);\n }\n\n /**\n * Given the Inode of a directory, retrieves the corresponding directory\n * listing.\n */\n private getDirListing(tx: SyncKeyValueROTransaction, p: string, inode: Inode): { [fileName: string]: string } {\n if (!inode.isDirectory()) {\n throw ApiError.ENOTDIR(p);\n }\n const data = tx.get(inode.id);\n if (data === undefined) {\n throw ApiError.ENOENT(p);\n }\n return JSON.parse(data.toString());\n }\n\n /**\n * Creates a new node under a random ID. Retries 5 times before giving up in\n * the exceedingly unlikely chance that we try to reuse a random GUID.\n * @return The GUID that the data was stored under.\n */\n private addNewNode(tx: SyncKeyValueRWTransaction, data: Buffer): string {\n const retries = 0;\n let currId: string;\n while (retries < 5) {\n try {\n currId = GenerateRandomID();\n tx.put(currId, data, false);\n return currId;\n } catch (e) {\n // Ignore and reroll.\n }\n }\n throw new ApiError(ErrorCode.EIO, 'Unable to commit data to key-value store.');\n }\n\n /**\n * Commits a new file (well, a FILE or a DIRECTORY) to the file system with\n * the given mode.\n * Note: This will commit the transaction.\n * @param p The path to the new file.\n * @param type The type of the new file.\n * @param mode The mode to create the new file with.\n * @param data The data to store at the file's data node.\n * @return The Inode for the new file.\n */\n private commitNewFile(tx: SyncKeyValueRWTransaction, p: string, type: FileType, mode: number, data: Buffer): Inode {\n const parentDir = path.dirname(p),\n fname = path.basename(p),\n parentNode = this.findINode(tx, parentDir),\n dirListing = this.getDirListing(tx, parentDir, parentNode),\n currTime = (new Date()).getTime();\n\n // Invariant: The root always exists.\n // If we don't check this prior to taking steps below, we will create a\n // file with name '' in root should p == '/'.\n if (p === '/') {\n throw ApiError.EEXIST(p);\n }\n\n // Check if file already exists.\n if (dirListing[fname]) {\n throw ApiError.EEXIST(p);\n }\n\n let fileNode: Inode;\n try {\n // Commit data.\n const dataId = this.addNewNode(tx, data);\n fileNode = new Inode(dataId, data.length, mode | type, currTime, currTime, currTime);\n // Commit file node.\n const fileNodeId = this.addNewNode(tx, fileNode.toBuffer());\n // Update and commit parent directory listing.\n dirListing[fname] = fileNodeId;\n tx.put(parentNode.id, new Buffer(JSON.stringify(dirListing)), true);\n } catch (e) {\n tx.abort();\n throw e;\n }\n tx.commit();\n return fileNode;\n }\n\n /**\n * Remove all traces of the given path from the file system.\n * @param p The path to remove from the file system.\n * @param isDir Does the path belong to a directory, or a file?\n * @todo Update mtime.\n */\n private removeEntry(p: string, isDir: boolean): void {\n const tx = this.store.beginTransaction('readwrite'),\n parent: string = path.dirname(p),\n parentNode = this.findINode(tx, parent),\n parentListing = this.getDirListing(tx, parent, parentNode),\n fileName: string = path.basename(p);\n\n if (!parentListing[fileName]) {\n throw ApiError.ENOENT(p);\n }\n\n // Remove from directory listing of parent.\n const fileNodeId = parentListing[fileName];\n delete parentListing[fileName];\n\n // Get file inode.\n const fileNode = this.getINode(tx, p, fileNodeId);\n if (!isDir && fileNode.isDirectory()) {\n throw ApiError.EISDIR(p);\n } else if (isDir && !fileNode.isDirectory()) {\n throw ApiError.ENOTDIR(p);\n }\n\n try {\n // Delete data.\n tx.del(fileNode.id);\n // Delete node.\n tx.del(fileNodeId);\n // Update directory listing.\n tx.put(parentNode.id, new Buffer(JSON.stringify(parentListing)), true);\n } catch (e) {\n tx.abort();\n throw e;\n }\n // Success.\n tx.commit();\n }\n}\n\n/**\n * Represents an *asynchronous* key-value store.\n */\nexport interface AsyncKeyValueStore {\n /**\n * The name of the key-value store.\n */\n name(): string;\n /**\n * Empties the key-value store completely.\n */\n clear(cb: BFSOneArgCallback): void;\n /**\n * Begins a read-write transaction.\n */\n beginTransaction(type: 'readwrite'): AsyncKeyValueRWTransaction;\n /**\n * Begins a read-only transaction.\n */\n beginTransaction(type: 'readonly'): AsyncKeyValueROTransaction;\n beginTransaction(type: string): AsyncKeyValueROTransaction;\n}\n\n/**\n * Represents an asynchronous read-only transaction.\n */\nexport interface AsyncKeyValueROTransaction {\n /**\n * Retrieves the data at the given key.\n * @param key The key to look under for data.\n */\n get(key: string, cb: BFSCallback): void;\n}\n\n/**\n * Represents an asynchronous read-write transaction.\n */\nexport interface AsyncKeyValueRWTransaction extends AsyncKeyValueROTransaction {\n /**\n * Adds the data to the store under the given key. Overwrites any existing\n * data.\n * @param key The key to add the data under.\n * @param data The data to add to the store.\n * @param overwrite If 'true', overwrite any existing data. If 'false',\n * avoids writing the data if the key exists.\n * @param cb Triggered with an error and whether or not the value was\n * committed.\n */\n put(key: string, data: Buffer, overwrite: boolean, cb: (e: ApiError,\n committed?: boolean) => void): void;\n /**\n * Deletes the data at the given key.\n * @param key The key to delete from the store.\n */\n del(key: string, cb: BFSOneArgCallback): void;\n /**\n * Commits the transaction.\n */\n commit(cb: BFSOneArgCallback): void;\n /**\n * Aborts and rolls back the transaction.\n */\n abort(cb: BFSOneArgCallback): void;\n}\n\nexport class AsyncKeyValueFile extends PreloadFile implements File {\n constructor(_fs: AsyncKeyValueFileSystem, _path: string, _flag: FileFlag, _stat: Stats, contents?: Buffer) {\n super(_fs, _path, _flag, _stat, contents);\n }\n\n public sync(cb: BFSOneArgCallback): void {\n if (this.isDirty()) {\n this._fs._sync(this.getPath(), this.getBuffer(), this.getStats(), (e?: ApiError) => {\n if (!e) {\n this.resetDirty();\n }\n cb(e);\n });\n } else {\n cb();\n }\n }\n\n public close(cb: BFSOneArgCallback): void {\n this.sync(cb);\n }\n}\n\n/**\n * An \"Asynchronous key-value file system\". Stores data to/retrieves data from\n * an underlying asynchronous key-value store.\n */\nexport class AsyncKeyValueFileSystem extends BaseFileSystem {\n public static isAvailable(): boolean { return true; }\n\n private store: AsyncKeyValueStore;\n\n /**\n * Initializes the file system. Typically called by subclasses' async\n * constructors.\n */\n public init(store: AsyncKeyValueStore, cb: BFSOneArgCallback) {\n this.store = store;\n // INVARIANT: Ensure that the root exists.\n this.makeRootDirectory(cb);\n }\n public getName(): string { return this.store.name(); }\n public isReadOnly(): boolean { return false; }\n public supportsSymlinks(): boolean { return false; }\n public supportsProps(): boolean { return false; }\n public supportsSynch(): boolean { return false; }\n\n /**\n * Delete all contents stored in the file system.\n */\n public empty(cb: BFSOneArgCallback): void {\n this.store.clear((e?) => {\n if (noError(e, cb)) {\n // INVARIANT: Root always exists.\n this.makeRootDirectory(cb);\n }\n });\n }\n\n public rename(oldPath: string, newPath: string, cb: BFSOneArgCallback): void {\n const tx = this.store.beginTransaction('readwrite');\n const oldParent = path.dirname(oldPath), oldName = path.basename(oldPath);\n const newParent = path.dirname(newPath), newName = path.basename(newPath);\n const inodes: { [path: string]: Inode } = {};\n const lists: {\n [path: string]: { [file: string]: string }\n } = {};\n let errorOccurred: boolean = false;\n\n // Invariant: Can't move a folder inside itself.\n // This funny little hack ensures that the check passes only if oldPath\n // is a subpath of newParent. We append '/' to avoid matching folders that\n // are a substring of the bottom-most folder in the path.\n if ((newParent + '/').indexOf(oldPath + '/') === 0) {\n return cb(new ApiError(ErrorCode.EBUSY, oldParent));\n }\n\n /**\n * Responsible for Phase 2 of the rename operation: Modifying and\n * committing the directory listings. Called once we have successfully\n * retrieved both the old and new parent's inodes and listings.\n */\n const theOleSwitcharoo = (): void => {\n // Sanity check: Ensure both paths are present, and no error has occurred.\n if (errorOccurred || !lists.hasOwnProperty(oldParent) || !lists.hasOwnProperty(newParent)) {\n return;\n }\n const oldParentList = lists[oldParent], oldParentINode = inodes[oldParent],\n newParentList = lists[newParent], newParentINode = inodes[newParent];\n\n // Delete file from old parent.\n if (!oldParentList[oldName]) {\n cb(ApiError.ENOENT(oldPath));\n } else {\n const fileId = oldParentList[oldName];\n delete oldParentList[oldName];\n\n // Finishes off the renaming process by adding the file to the new\n // parent.\n const completeRename = () => {\n newParentList[newName] = fileId;\n // Commit old parent's list.\n tx.put(oldParentINode.id, new Buffer(JSON.stringify(oldParentList)), true, (e: ApiError) => {\n if (noErrorTx(e, tx, cb)) {\n if (oldParent === newParent) {\n // DONE!\n tx.commit(cb);\n } else {\n // Commit new parent's list.\n tx.put(newParentINode.id, new Buffer(JSON.stringify(newParentList)), true, (e: ApiError) => {\n if (noErrorTx(e, tx, cb)) {\n tx.commit(cb);\n }\n });\n }\n }\n });\n };\n\n if (newParentList[newName]) {\n // 'newPath' already exists. Check if it's a file or a directory, and\n // act accordingly.\n this.getINode(tx, newPath, newParentList[newName], (e: ApiError, inode?: Inode) => {\n if (noErrorTx(e, tx, cb)) {\n if (inode!.isFile()) {\n // Delete the file and continue.\n tx.del(inode!.id, (e?: ApiError) => {\n if (noErrorTx(e, tx, cb)) {\n tx.del(newParentList[newName], (e?: ApiError) => {\n if (noErrorTx(e, tx, cb)) {\n completeRename();\n }\n });\n }\n });\n } else {\n // Can't overwrite a directory using rename.\n tx.abort((e?) => {\n cb(ApiError.EPERM(newPath));\n });\n }\n }\n });\n } else {\n completeRename();\n }\n }\n };\n\n /**\n * Grabs a path's inode and directory listing, and shoves it into the\n * inodes and lists hashes.\n */\n const processInodeAndListings = (p: string): void => {\n this.findINodeAndDirListing(tx, p, (e?: ApiError | null, node?: Inode, dirList?: {[name: string]: string}): void => {\n if (e) {\n if (!errorOccurred) {\n errorOccurred = true;\n tx.abort(() => {\n cb(e);\n });\n }\n // If error has occurred already, just stop here.\n } else {\n inodes[p] = node!;\n lists[p] = dirList!;\n theOleSwitcharoo();\n }\n });\n };\n\n processInodeAndListings(oldParent);\n if (oldParent !== newParent) {\n processInodeAndListings(newParent);\n }\n }\n\n public stat(p: string, isLstat: boolean, cb: BFSCallback): void {\n const tx = this.store.beginTransaction('readonly');\n this.findINode(tx, p, (e: ApiError, inode?: Inode): void => {\n if (noError(e, cb)) {\n cb(null, inode!.toStats());\n }\n });\n }\n\n public createFile(p: string, flag: FileFlag, mode: number, cb: BFSCallback): void {\n const tx = this.store.beginTransaction('readwrite'),\n data = new Buffer(0);\n\n this.commitNewFile(tx, p, FileType.FILE, mode, data, (e: ApiError, newFile?: Inode): void => {\n if (noError(e, cb)) {\n cb(null, new AsyncKeyValueFile(this, p, flag, newFile!.toStats(), data));\n }\n });\n }\n\n public openFile(p: string, flag: FileFlag, cb: BFSCallback): void {\n const tx = this.store.beginTransaction('readonly');\n // Step 1: Grab the file's inode.\n this.findINode(tx, p, (e: ApiError, inode?: Inode) => {\n if (noError(e, cb)) {\n // Step 2: Grab the file's data.\n tx.get(inode!.id, (e: ApiError, data?: Buffer): void => {\n if (noError(e, cb)) {\n if (data === undefined) {\n cb(ApiError.ENOENT(p));\n } else {\n cb(null, new AsyncKeyValueFile(this, p, flag, inode!.toStats(), data));\n }\n }\n });\n }\n });\n }\n\n public unlink(p: string, cb: BFSOneArgCallback): void {\n this.removeEntry(p, false, cb);\n }\n\n public rmdir(p: string, cb: BFSOneArgCallback): void {\n // Check first if directory is empty.\n this.readdir(p, (err, files?) => {\n if (err) {\n cb(err);\n } else if (files!.length > 0) {\n cb(ApiError.ENOTEMPTY(p));\n } else {\n this.removeEntry(p, true, cb);\n }\n });\n }\n\n public mkdir(p: string, mode: number, cb: BFSOneArgCallback): void {\n const tx = this.store.beginTransaction('readwrite'),\n data = new Buffer('{}');\n this.commitNewFile(tx, p, FileType.DIRECTORY, mode, data, cb);\n }\n\n public readdir(p: string, cb: BFSCallback): void {\n const tx = this.store.beginTransaction('readonly');\n this.findINode(tx, p, (e: ApiError, inode?: Inode) => {\n if (noError(e, cb)) {\n this.getDirListing(tx, p, inode!, (e: ApiError, dirListing?: {[name: string]: string}) => {\n if (noError(e, cb)) {\n cb(null, Object.keys(dirListing));\n }\n });\n }\n });\n }\n\n public _sync(p: string, data: Buffer, stats: Stats, cb: BFSOneArgCallback): void {\n // @todo Ensure mtime updates properly, and use that to determine if a data\n // update is required.\n const tx = this.store.beginTransaction('readwrite');\n // Step 1: Get the file node's ID.\n this._findINode(tx, path.dirname(p), path.basename(p), (e: ApiError, fileInodeId?: string): void => {\n if (noErrorTx(e, tx, cb)) {\n // Step 2: Get the file inode.\n this.getINode(tx, p, fileInodeId!, (e: ApiError, fileInode?: Inode): void => {\n if (noErrorTx(e, tx, cb)) {\n const inodeChanged: boolean = fileInode!.update(stats);\n // Step 3: Sync the data.\n tx.put(fileInode!.id, data, true, (e: ApiError): void => {\n if (noErrorTx(e, tx, cb)) {\n // Step 4: Sync the metadata (if it changed)!\n if (inodeChanged) {\n tx.put(fileInodeId!, fileInode!.toBuffer(), true, (e: ApiError): void => {\n if (noErrorTx(e, tx, cb)) {\n tx.commit(cb);\n }\n });\n } else {\n // No need to sync metadata; return.\n tx.commit(cb);\n }\n }\n });\n }\n });\n }\n });\n }\n\n /**\n * Checks if the root directory exists. Creates it if it doesn't.\n */\n private makeRootDirectory(cb: BFSOneArgCallback) {\n const tx = this.store.beginTransaction('readwrite');\n tx.get(ROOT_NODE_ID, (e: ApiError, data?: Buffer) => {\n if (e || data === undefined) {\n // Create new inode.\n const currTime = (new Date()).getTime(),\n // Mode 0666\n dirInode = new Inode(GenerateRandomID(), 4096, 511 | FileType.DIRECTORY, currTime, currTime, currTime);\n // If the root doesn't exist, the first random ID shouldn't exist,\n // either.\n tx.put(dirInode.id, new Buffer(\"{}\"), false, (e?: ApiError) => {\n if (noErrorTx(e, tx, cb)) {\n tx.put(ROOT_NODE_ID, dirInode.toBuffer(), false, (e?: ApiError) => {\n if (e) {\n tx.abort(() => { cb(e); });\n } else {\n tx.commit(cb);\n }\n });\n }\n });\n } else {\n // We're good.\n tx.commit(cb);\n }\n });\n }\n\n /**\n * Helper function for findINode.\n * @param parent The parent directory of the file we are attempting to find.\n * @param filename The filename of the inode we are attempting to find, minus\n * the parent.\n * @param cb Passed an error or the ID of the file's inode in the file system.\n */\n private _findINode(tx: AsyncKeyValueROTransaction, parent: string, filename: string, cb: BFSCallback): void {\n const handleDirectoryListings = (e?: ApiError | null, inode?: Inode, dirList?: {[name: string]: string}): void => {\n if (e) {\n cb(e);\n } else if (dirList![filename]) {\n cb(null, dirList![filename]);\n } else {\n cb(ApiError.ENOENT(path.resolve(parent, filename)));\n }\n };\n\n if (parent === '/') {\n if (filename === '') {\n // BASE CASE #1: Return the root's ID.\n cb(null, ROOT_NODE_ID);\n } else {\n // BASE CASE #2: Find the item in the root node.\n this.getINode(tx, parent, ROOT_NODE_ID, (e: ApiError, inode?: Inode): void => {\n if (noError(e, cb)) {\n this.getDirListing(tx, parent, inode!, (e: ApiError, dirList?: {[name: string]: string}): void => {\n // handle_directory_listings will handle e for us.\n handleDirectoryListings(e, inode, dirList);\n });\n }\n });\n }\n } else {\n // Get the parent directory's INode, and find the file in its directory\n // listing.\n this.findINodeAndDirListing(tx, parent, handleDirectoryListings);\n }\n }\n\n /**\n * Finds the Inode of the given path.\n * @param p The path to look up.\n * @param cb Passed an error or the Inode of the path p.\n * @todo memoize/cache\n */\n private findINode(tx: AsyncKeyValueROTransaction, p: string, cb: BFSCallback): void {\n this._findINode(tx, path.dirname(p), path.basename(p), (e: ApiError, id?: string): void => {\n if (noError(e, cb)) {\n this.getINode(tx, p, id!, cb);\n }\n });\n }\n\n /**\n * Given the ID of a node, retrieves the corresponding Inode.\n * @param tx The transaction to use.\n * @param p The corresponding path to the file (used for error messages).\n * @param id The ID to look up.\n * @param cb Passed an error or the inode under the given id.\n */\n private getINode(tx: AsyncKeyValueROTransaction, p: string, id: string, cb: BFSCallback): void {\n tx.get(id, (e: ApiError, data?: Buffer): void => {\n if (noError(e, cb)) {\n if (data === undefined) {\n cb(ApiError.ENOENT(p));\n } else {\n cb(null, Inode.fromBuffer(data));\n }\n }\n });\n }\n\n /**\n * Given the Inode of a directory, retrieves the corresponding directory\n * listing.\n */\n private getDirListing(tx: AsyncKeyValueROTransaction, p: string, inode: Inode, cb: BFSCallback<{ [fileName: string]: string }>): void {\n if (!inode.isDirectory()) {\n cb(ApiError.ENOTDIR(p));\n } else {\n tx.get(inode.id, (e: ApiError, data?: Buffer): void => {\n if (noError(e, cb)) {\n try {\n cb(null, JSON.parse(data!.toString()));\n } catch (e) {\n // Occurs when data is undefined, or corresponds to something other\n // than a directory listing. The latter should never occur unless\n // the file system is corrupted.\n cb(ApiError.ENOENT(p));\n }\n }\n });\n }\n }\n\n /**\n * Given a path to a directory, retrieves the corresponding INode and\n * directory listing.\n */\n private findINodeAndDirListing(tx: AsyncKeyValueROTransaction, p: string, cb: BFSThreeArgCallback): void {\n this.findINode(tx, p, (e: ApiError, inode?: Inode): void => {\n if (noError(e, cb)) {\n this.getDirListing(tx, p, inode!, (e, listing?) => {\n if (noError(e, cb)) {\n cb(null, inode!, listing!);\n }\n });\n }\n });\n }\n\n /**\n * Adds a new node under a random ID. Retries 5 times before giving up in\n * the exceedingly unlikely chance that we try to reuse a random GUID.\n * @param cb Passed an error or the GUID that the data was stored under.\n */\n private addNewNode(tx: AsyncKeyValueRWTransaction, data: Buffer, cb: BFSCallback): void {\n let retries = 0, currId: string;\n const reroll = () => {\n if (++retries === 5) {\n // Max retries hit. Return with an error.\n cb(new ApiError(ErrorCode.EIO, 'Unable to commit data to key-value store.'));\n } else {\n // Try again.\n currId = GenerateRandomID();\n tx.put(currId, data, false, (e: ApiError, committed?: boolean) => {\n if (e || !committed) {\n reroll();\n } else {\n // Successfully stored under 'currId'.\n cb(null, currId);\n }\n });\n }\n };\n reroll();\n }\n\n /**\n * Commits a new file (well, a FILE or a DIRECTORY) to the file system with\n * the given mode.\n * Note: This will commit the transaction.\n * @param p The path to the new file.\n * @param type The type of the new file.\n * @param mode The mode to create the new file with.\n * @param data The data to store at the file's data node.\n * @param cb Passed an error or the Inode for the new file.\n */\n private commitNewFile(tx: AsyncKeyValueRWTransaction, p: string, type: FileType, mode: number, data: Buffer, cb: BFSCallback): void {\n const parentDir = path.dirname(p),\n fname = path.basename(p),\n currTime = (new Date()).getTime();\n\n // Invariant: The root always exists.\n // If we don't check this prior to taking steps below, we will create a\n // file with name '' in root should p == '/'.\n if (p === '/') {\n return cb(ApiError.EEXIST(p));\n }\n\n // Let's build a pyramid of code!\n\n // Step 1: Get the parent directory's inode and directory listing\n this.findINodeAndDirListing(tx, parentDir, (e?: ApiError | null, parentNode?: Inode, dirListing?: {[name: string]: string}): void => {\n if (noErrorTx(e, tx, cb)) {\n if (dirListing![fname]) {\n // File already exists.\n tx.abort(() => {\n cb(ApiError.EEXIST(p));\n });\n } else {\n // Step 2: Commit data to store.\n this.addNewNode(tx, data, (e: ApiError, dataId?: string): void => {\n if (noErrorTx(e, tx, cb)) {\n // Step 3: Commit the file's inode to the store.\n const fileInode = new Inode(dataId!, data.length, mode | type, currTime, currTime, currTime);\n this.addNewNode(tx, fileInode.toBuffer(), (e: ApiError, fileInodeId?: string): void => {\n if (noErrorTx(e, tx, cb)) {\n // Step 4: Update parent directory's listing.\n dirListing![fname] = fileInodeId!;\n tx.put(parentNode!.id, new Buffer(JSON.stringify(dirListing)), true, (e: ApiError): void => {\n if (noErrorTx(e, tx, cb)) {\n // Step 5: Commit and return the new inode.\n tx.commit((e?: ApiError): void => {\n if (noErrorTx(e, tx, cb)) {\n cb(null, fileInode);\n }\n });\n }\n });\n }\n });\n }\n });\n }\n }\n });\n }\n\n /**\n * Remove all traces of the given path from the file system.\n * @param p The path to remove from the file system.\n * @param isDir Does the path belong to a directory, or a file?\n * @todo Update mtime.\n */\n private removeEntry(p: string, isDir: boolean, cb: BFSOneArgCallback): void {\n const tx = this.store.beginTransaction('readwrite'),\n parent: string = path.dirname(p), fileName: string = path.basename(p);\n // Step 1: Get parent directory's node and directory listing.\n this.findINodeAndDirListing(tx, parent, (e?: ApiError | null, parentNode?: Inode, parentListing?: {[name: string]: string}): void => {\n if (noErrorTx(e, tx, cb)) {\n if (!parentListing![fileName]) {\n tx.abort(() => {\n cb(ApiError.ENOENT(p));\n });\n } else {\n // Remove from directory listing of parent.\n const fileNodeId = parentListing![fileName];\n delete parentListing![fileName];\n // Step 2: Get file inode.\n this.getINode(tx, p, fileNodeId, (e: ApiError, fileNode?: Inode): void => {\n if (noErrorTx(e, tx, cb)) {\n if (!isDir && fileNode!.isDirectory()) {\n tx.abort(() => {\n cb(ApiError.EISDIR(p));\n });\n } else if (isDir && !fileNode!.isDirectory()) {\n tx.abort(() => {\n cb(ApiError.ENOTDIR(p));\n });\n } else {\n // Step 3: Delete data.\n tx.del(fileNode!.id, (e?: ApiError): void => {\n if (noErrorTx(e, tx, cb)) {\n // Step 4: Delete node.\n tx.del(fileNodeId, (e?: ApiError): void => {\n if (noErrorTx(e, tx, cb)) {\n // Step 5: Update directory listing.\n tx.put(parentNode!.id, new Buffer(JSON.stringify(parentListing)), true, (e: ApiError): void => {\n if (noErrorTx(e, tx, cb)) {\n tx.commit(cb);\n }\n });\n }\n });\n }\n });\n }\n }\n });\n }\n }\n });\n }\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../src/generic/key_value_filesystem.ts","import {BFSOneArgCallback, BFSCallback} from '../core/file_system';\nimport {AsyncKeyValueROTransaction, AsyncKeyValueRWTransaction, AsyncKeyValueStore, AsyncKeyValueFileSystem} from '../generic/key_value_filesystem';\nimport {ApiError, ErrorCode} from '../core/api_error';\nimport global from '../core/global';\nimport {arrayBuffer2Buffer, buffer2ArrayBuffer} from '../core/util';\n/**\n * Get the indexedDB constructor for the current browser.\n */\nconst indexedDB: IDBFactory = global.indexedDB ||\n ( global).mozIndexedDB ||\n ( global).webkitIndexedDB ||\n global.msIndexedDB;\n\n/**\n * Converts a DOMException or a DOMError from an IndexedDB event into a\n * standardized BrowserFS API error.\n */\nfunction convertError(e: {name: string}, message: string = e.toString()): ApiError {\n switch (e.name) {\n case \"NotFoundError\":\n return new ApiError(ErrorCode.ENOENT, message);\n case \"QuotaExceededError\":\n return new ApiError(ErrorCode.ENOSPC, message);\n default:\n // The rest do not seem to map cleanly to standard error codes.\n return new ApiError(ErrorCode.EIO, message);\n }\n}\n\n/**\n * Produces a new onerror handler for IDB. Our errors are always fatal, so we\n * handle them generically: Call the user-supplied callback with a translated\n * version of the error, and let the error bubble up.\n */\nfunction onErrorHandler(cb: (e: ApiError) => void, code: ErrorCode = ErrorCode.EIO, message: string | null = null): (e?: any) => void {\n return function(e?: any): void {\n // Prevent the error from canceling the transaction.\n e.preventDefault();\n cb(new ApiError(code, message !== null ? message : undefined));\n };\n}\n\nexport class IndexedDBROTransaction implements AsyncKeyValueROTransaction {\n constructor(public tx: IDBTransaction, public store: IDBObjectStore) { }\n\n public get(key: string, cb: BFSCallback): void {\n try {\n const r: IDBRequest = this.store.get(key);\n r.onerror = onErrorHandler(cb);\n r.onsuccess = (event) => {\n // IDB returns the value 'undefined' when you try to get keys that\n // don't exist. The caller expects this behavior.\n const result: any = ( event.target).result;\n if (result === undefined) {\n cb(null, result);\n } else {\n // IDB data is stored as an ArrayBuffer\n cb(null, arrayBuffer2Buffer(result));\n }\n };\n } catch (e) {\n cb(convertError(e));\n }\n }\n}\n\nexport class IndexedDBRWTransaction extends IndexedDBROTransaction implements AsyncKeyValueRWTransaction, AsyncKeyValueROTransaction {\n constructor(tx: IDBTransaction, store: IDBObjectStore) {\n super(tx, store);\n }\n\n public put(key: string, data: Buffer, overwrite: boolean, cb: BFSCallback): void {\n try {\n const arraybuffer = buffer2ArrayBuffer(data);\n let r: IDBRequest;\n if (overwrite) {\n r = this.store.put(arraybuffer, key);\n } else {\n // 'add' will never overwrite an existing key.\n r = this.store.add(arraybuffer, key);\n }\n // XXX: NEED TO RETURN FALSE WHEN ADD HAS A KEY CONFLICT. NO ERROR.\n r.onerror = onErrorHandler(cb);\n r.onsuccess = (event) => {\n cb(null, true);\n };\n } catch (e) {\n cb(convertError(e));\n }\n }\n\n public del(key: string, cb: BFSOneArgCallback): void {\n try {\n // NOTE: IE8 has a bug with identifiers named 'delete' unless used as a string\n // like this.\n // http://stackoverflow.com/a/26479152\n const r: IDBRequest = this.store['delete'](key);\n r.onerror = onErrorHandler(cb);\n r.onsuccess = (event) => {\n cb();\n };\n } catch (e) {\n cb(convertError(e));\n }\n }\n\n public commit(cb: BFSOneArgCallback): void {\n // Return to the event loop to commit the transaction.\n setTimeout(cb, 0);\n }\n\n public abort(cb: BFSOneArgCallback): void {\n let _e: ApiError | null = null;\n try {\n this.tx.abort();\n } catch (e) {\n _e = convertError(e);\n } finally {\n cb(_e);\n }\n }\n}\n\nexport class IndexedDBStore implements AsyncKeyValueStore {\n private db: IDBDatabase;\n\n /**\n * Constructs an IndexedDB file system.\n * @param cb Called once the database is instantiated and ready for use.\n * Passes an error if there was an issue instantiating the database.\n * @param objectStoreName The name of this file system. You can have\n * multiple IndexedDB file systems operating at once, but each must have\n * a different name.\n */\n constructor(cb: BFSCallback, private storeName: string = 'browserfs') {\n const openReq: IDBOpenDBRequest = indexedDB.open(this.storeName, 1);\n\n openReq.onupgradeneeded = (event) => {\n const db: IDBDatabase = ( event.target).result;\n // Huh. This should never happen; we're at version 1. Why does another\n // database exist?\n if (db.objectStoreNames.contains(this.storeName)) {\n db.deleteObjectStore(this.storeName);\n }\n db.createObjectStore(this.storeName);\n };\n\n openReq.onsuccess = (event) => {\n this.db = ( event.target).result;\n cb(null, this);\n };\n\n openReq.onerror = onErrorHandler(cb, ErrorCode.EACCES);\n }\n\n public name(): string {\n return \"IndexedDB - \" + this.storeName;\n }\n\n public clear(cb: BFSOneArgCallback): void {\n try {\n const tx = this.db.transaction(this.storeName, 'readwrite'),\n objectStore = tx.objectStore(this.storeName),\n r: IDBRequest = objectStore.clear();\n r.onsuccess = (event) => {\n // Use setTimeout to commit transaction.\n setTimeout(cb, 0);\n };\n r.onerror = onErrorHandler(cb);\n } catch (e) {\n cb(convertError(e));\n }\n }\n\n public beginTransaction(type: 'readonly'): AsyncKeyValueROTransaction;\n public beginTransaction(type: 'readwrite'): AsyncKeyValueRWTransaction;\n public beginTransaction(type: string = 'readonly'): AsyncKeyValueROTransaction {\n const tx = this.db.transaction(this.storeName, type),\n objectStore = tx.objectStore(this.storeName);\n if (type === 'readwrite') {\n return new IndexedDBRWTransaction(tx, objectStore);\n } else if (type === 'readonly') {\n return new IndexedDBROTransaction(tx, objectStore);\n } else {\n throw new ApiError(ErrorCode.EINVAL, 'Invalid transaction type.');\n }\n }\n}\n\n/**\n * A file system that uses the IndexedDB key value file system.\n */\nexport default class IndexedDBFileSystem extends AsyncKeyValueFileSystem {\n public static isAvailable(): boolean {\n // In Safari's private browsing mode, indexedDB.open returns NULL.\n // In Firefox, it throws an exception.\n // In Chrome, it \"just works\", and clears the database when you leave the page.\n // Untested: Opera, IE.\n try {\n return typeof indexedDB !== 'undefined' && null !== indexedDB.open(\"__browserfs_test__\");\n } catch (e) {\n return false;\n }\n }\n constructor(cb: BFSCallback, storeName?: string) {\n super();\n const store = new IndexedDBStore((e): void => {\n if (e) {\n cb(e);\n } else {\n this.init(store, (e?) => {\n cb(e, this);\n });\n }\n }, storeName);\n }\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../src/backend/IndexedDB.ts","import {FileSystem, BaseFileSystem, BFSOneArgCallback, BFSCallback} from '../core/file_system';\nimport InMemoryFileSystem from './InMemory';\nimport {ApiError, ErrorCode} from '../core/api_error';\nimport fs from '../core/node_fs';\nimport * as path from 'path';\nimport {mkdirpSync} from '../core/util';\n\n/**\n * The MountableFileSystem allows you to mount multiple backend types or\n * multiple instantiations of the same backend into a single file system tree.\n * The file systems do not need to know about each other; all interactions are\n * automatically facilitated through this interface.\n *\n * For example, if a file system is mounted at /mnt/blah, and a request came in\n * for /mnt/blah/foo.txt, the file system would see a request for /foo.txt.\n */\nexport default class MountableFileSystem extends BaseFileSystem implements FileSystem {\n public static isAvailable(): boolean {\n return true;\n }\n\n private mntMap: {[path: string]: FileSystem};\n // Contains the list of mount points in mntMap, sorted by string length in decreasing order.\n // Ensures that we scan the most specific mount points for a match first, which lets us\n // nest mount points.\n private mountList: string[] = [];\n private rootFs: FileSystem;\n constructor() {\n super();\n this.mntMap = {};\n // The InMemory file system serves purely to provide directory listings for\n // mounted file systems.\n this.rootFs = new InMemoryFileSystem();\n }\n\n /**\n * Mounts the file system at the given mount point.\n */\n public mount(mountPoint: string, fs: FileSystem): void {\n if (mountPoint[0] !== '/') {\n mountPoint = `/${mountPoint}`;\n }\n mountPoint = path.resolve(mountPoint);\n if (this.mntMap[mountPoint]) {\n throw new ApiError(ErrorCode.EINVAL, \"Mount point \" + mountPoint + \" is already taken.\");\n }\n mkdirpSync(mountPoint, 0x1ff, this.rootFs);\n this.mntMap[mountPoint] = fs;\n this.mountList.push(mountPoint);\n this.mountList = this.mountList.sort((a, b) => b.length - a.length);\n }\n\n public umount(mountPoint: string): void {\n if (mountPoint[0] !== '/') {\n mountPoint = `/${mountPoint}`;\n }\n mountPoint = path.resolve(mountPoint);\n if (!this.mntMap[mountPoint]) {\n throw new ApiError(ErrorCode.EINVAL, \"Mount point \" + mountPoint + \" is already unmounted.\");\n }\n delete this.mntMap[mountPoint];\n this.mountList.splice(this.mountList.indexOf(mountPoint), 1);\n\n while (mountPoint !== '/') {\n if (this.rootFs.readdirSync(mountPoint).length === 0) {\n this.rootFs.rmdirSync(mountPoint);\n mountPoint = path.dirname(mountPoint);\n } else {\n break;\n }\n }\n }\n\n /**\n * Returns the file system that the path points to.\n */\n public _getFs(path: string): {fs: FileSystem; path: string} {\n const mountList = this.mountList, len = mountList.length;\n for (let i = 0; i < len; i++) {\n const mountPoint = mountList[i];\n // We know path is normalized, so it is a substring of the mount point.\n if (mountPoint.length <= path.length && path.indexOf(mountPoint) === 0) {\n path = path.substr(mountPoint.length > 1 ? mountPoint.length : 0);\n if (path === '') {\n path = '/';\n }\n return {fs: this.mntMap[mountPoint], path: path};\n }\n }\n // Query our root file system.\n return {fs: this.rootFs, path: path};\n }\n\n // Global information methods\n\n public getName(): string {\n return 'MountableFileSystem';\n }\n\n public diskSpace(path: string, cb: (total: number, free: number) => void): void {\n cb(0, 0);\n }\n\n public isReadOnly(): boolean {\n return false;\n }\n\n public supportsLinks(): boolean {\n // I'm not ready for cross-FS links yet.\n return false;\n }\n\n public supportsProps(): boolean {\n return false;\n }\n\n public supportsSynch(): boolean {\n return true;\n }\n\n /**\n * Fixes up error messages so they mention the mounted file location relative\n * to the MFS root, not to the particular FS's root.\n * Mutates the input error, and returns it.\n */\n public standardizeError(err: ApiError, path: string, realPath: string): ApiError {\n const index = err.message.indexOf(path);\n if (index !== -1) {\n err.message = err.message.substr(0, index) + realPath + err.message.substr(index + path.length);\n err.path = realPath;\n }\n return err;\n }\n\n // The following methods involve multiple file systems, and thus have custom\n // logic.\n // Note that we go through the Node API to use its robust default argument\n // processing.\n\n public rename(oldPath: string, newPath: string, cb: BFSOneArgCallback): void {\n // Scenario 1: old and new are on same FS.\n const fs1rv = this._getFs(oldPath);\n const fs2rv = this._getFs(newPath);\n if (fs1rv.fs === fs2rv.fs) {\n return fs1rv.fs.rename(fs1rv.path, fs2rv.path, (e?: ApiError) => {\n if (e) {\n this.standardizeError(this.standardizeError(e, fs1rv.path, oldPath), fs2rv.path, newPath);\n }\n cb(e);\n });\n }\n\n // Scenario 2: Different file systems.\n // Read old file, write new file, delete old file.\n return fs.readFile(oldPath, function(err: ApiError, data?: any) {\n if (err) {\n return cb(err);\n }\n fs.writeFile(newPath, data, function(err: ApiError) {\n if (err) {\n return cb(err);\n }\n fs.unlink(oldPath, cb);\n });\n });\n }\n\n public renameSync(oldPath: string, newPath: string): void {\n // Scenario 1: old and new are on same FS.\n const fs1rv = this._getFs(oldPath);\n const fs2rv = this._getFs(newPath);\n if (fs1rv.fs === fs2rv.fs) {\n try {\n return fs1rv.fs.renameSync(fs1rv.path, fs2rv.path);\n } catch (e) {\n this.standardizeError(this.standardizeError(e, fs1rv.path, oldPath), fs2rv.path, newPath);\n throw e;\n }\n }\n // Scenario 2: Different file systems.\n const data = fs.readFileSync(oldPath);\n fs.writeFileSync(newPath, data);\n return fs.unlinkSync(oldPath);\n }\n\n public readdirSync(p: string): string[] {\n const fsInfo = this._getFs(p);\n\n // If null, rootfs did not have the directory\n // (or the target FS is the root fs).\n let rv: string[] | null = null;\n // Mount points are all defined in the root FS.\n // Ensure that we list those, too.\n if (fsInfo.fs !== this.rootFs) {\n try {\n rv = this.rootFs.readdirSync(p);\n } catch (e) {\n // Ignore.\n }\n }\n\n try {\n const rv2 = fsInfo.fs.readdirSync(fsInfo.path);\n if (rv === null) {\n return rv2;\n } else {\n // Filter out duplicates.\n return rv2.concat(rv.filter((val) => rv2.indexOf(val) === -1));\n }\n } catch (e) {\n if (rv === null) {\n throw this.standardizeError(e, fsInfo.path, p);\n } else {\n // The root FS had something.\n return rv;\n }\n }\n }\n\n public readdir(p: string, cb: BFSCallback): void {\n const fsInfo = this._getFs(p);\n fsInfo.fs.readdir(fsInfo.path, (err, files) => {\n if (fsInfo.fs !== this.rootFs) {\n try {\n const rv = this.rootFs.readdirSync(p);\n if (files) {\n // Filter out duplicates.\n files = files.concat(rv.filter((val) => files!.indexOf(val) === -1));\n } else {\n files = rv;\n }\n } catch (e) {\n // Root FS and target FS did not have directory.\n if (err) {\n return cb(this.standardizeError(err, fsInfo.path, p));\n }\n }\n } else if (err) {\n // Root FS and target FS are the same, and did not have directory.\n return cb(this.standardizeError(err, fsInfo.path, p));\n }\n\n cb(null, files);\n });\n }\n\n public rmdirSync(p: string): void {\n const fsInfo = this._getFs(p);\n if (this._containsMountPt(p)) {\n throw ApiError.ENOTEMPTY(p);\n } else {\n try {\n fsInfo.fs.rmdirSync(fsInfo.path);\n } catch (e) {\n throw this.standardizeError(e, fsInfo.path, p);\n }\n }\n }\n\n public rmdir(p: string, cb: BFSOneArgCallback): void {\n const fsInfo = this._getFs(p);\n if (this._containsMountPt(p)) {\n cb(ApiError.ENOTEMPTY(p));\n } else {\n fsInfo.fs.rmdir(fsInfo.path, (err?) => {\n cb(err ? this.standardizeError(err, fsInfo.path, p) : null);\n });\n }\n }\n\n /**\n * Returns true if the given path contains a mount point.\n */\n private _containsMountPt(p: string): boolean {\n const mountPoints = this.mountList, len = mountPoints.length;\n for (let i = 0; i < len; i++) {\n const pt = mountPoints[i];\n if (pt.length >= p.length && pt.slice(0, p.length) === p) {\n return true;\n }\n }\n return false;\n }\n}\n\n/**\n * Tricky: Define all of the functions that merely forward arguments to the\n * relevant file system, or return/throw an error.\n * Take advantage of the fact that the *first* argument is always the path, and\n * the *last* is the callback function (if async).\n * @todo Can use numArgs to make proxying more efficient.\n */\nfunction defineFcn(name: string, isSync: boolean, numArgs: number): (...args: any[]) => any {\n if (isSync) {\n return function(this: MountableFileSystem, ...args: any[]) {\n const path = args[0];\n const rv = this._getFs(path);\n args[0] = rv.path;\n try {\n return ( rv.fs)[name].apply(rv.fs, args);\n } catch (e) {\n this.standardizeError(e, rv.path, path);\n throw e;\n }\n };\n } else {\n return function(this: MountableFileSystem, ...args: any[]) {\n const path = args[0];\n const rv = this._getFs(path);\n args[0] = rv.path;\n if (typeof args[args.length - 1] === 'function') {\n const cb = args[args.length - 1];\n args[args.length - 1] = (...args: any[]) => {\n if (args.length > 0 && args[0] instanceof ApiError) {\n this.standardizeError(args[0], rv.path, path);\n }\n cb.apply(null, args);\n };\n }\n return ( rv.fs)[name].apply(rv.fs, args);\n };\n }\n}\n\nconst fsCmdMap = [\n // 1 arg functions\n ['exists', 'unlink', 'readlink'],\n // 2 arg functions\n ['stat', 'mkdir', 'realpath', 'truncate'],\n // 3 arg functions\n ['open', 'readFile', 'chmod', 'utimes'],\n // 4 arg functions\n ['chown'],\n // 5 arg functions\n ['writeFile', 'appendFile']];\n\nfor (let i = 0; i < fsCmdMap.length; i++) {\n const cmds = fsCmdMap[i];\n for (let j = 0; j < cmds.length; j++) {\n const fnName = cmds[j];\n ( MountableFileSystem.prototype)[fnName] = defineFcn(fnName, false, i + 1);\n ( MountableFileSystem.prototype)[fnName + 'Sync'] = defineFcn(fnName + 'Sync', true, i + 1);\n }\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../src/backend/MountableFileSystem.ts","import {FileSystem, BaseFileSystem, BFSOneArgCallback, BFSCallback} from '../core/file_system';\nimport {ApiError, ErrorCode} from '../core/api_error';\nimport {FileFlag, ActionType} from '../core/file_flag';\nimport {File} from '../core/file';\nimport {default as Stats} from '../core/node_fs_stats';\nimport PreloadFile from '../generic/preload_file';\nimport LockedFS from '../generic/locked_fs';\nimport * as path from 'path';\nconst deletionLogPath = '/.deletedFiles.log';\n\n/**\n * Given a read-only mode, makes it writable.\n */\nfunction makeModeWritable(mode: number): number {\n return 0o222 | mode;\n}\n\nfunction getFlag(f: string): FileFlag {\n return FileFlag.getFileFlag(f);\n}\n\n/**\n * Overlays a RO file to make it writable.\n */\nclass OverlayFile extends PreloadFile implements File {\n constructor(fs: UnlockedOverlayFS, path: string, flag: FileFlag, stats: Stats, data: Buffer) {\n super(fs, path, flag, stats, data);\n }\n\n public sync(cb: BFSOneArgCallback): void {\n if (!this.isDirty()) {\n cb(null);\n return;\n }\n\n this._fs._syncAsync(this, (err: ApiError) => {\n this.resetDirty();\n cb(err);\n });\n }\n\n public syncSync(): void {\n if (this.isDirty()) {\n this._fs._syncSync(this);\n this.resetDirty();\n }\n }\n\n public close(cb: BFSOneArgCallback): void {\n this.sync(cb);\n }\n\n public closeSync(): void {\n this.syncSync();\n }\n}\n\n/**\n * OverlayFS makes a read-only filesystem writable by storing writes on a second,\n * writable file system. Deletes are persisted via metadata stored on the writable\n * file system.\n */\nexport class UnlockedOverlayFS extends BaseFileSystem implements FileSystem {\n public static isAvailable(): boolean {\n return true;\n }\n\n private _writable: FileSystem;\n private _readable: FileSystem;\n private _isInitialized: boolean = false;\n private _initializeCallbacks: (BFSOneArgCallback)[] = [];\n private _deletedFiles: {[path: string]: boolean} = {};\n private _deleteLog: string = '';\n // If 'true', we have scheduled a delete log update.\n private _deleteLogUpdatePending: boolean = false;\n // If 'true', a delete log update is needed after the scheduled delete log\n // update finishes.\n private _deleteLogUpdateNeeded: boolean = false;\n // If there was an error updating the delete log...\n private _deleteLogError: ApiError | null = null;\n\n constructor(writable: FileSystem, readable: FileSystem) {\n super();\n this._writable = writable;\n this._readable = readable;\n if (this._writable.isReadOnly()) {\n throw new ApiError(ErrorCode.EINVAL, \"Writable file system must be writable.\");\n }\n }\n\n public getOverlayedFileSystems(): { readable: FileSystem; writable: FileSystem; } {\n return {\n readable: this._readable,\n writable: this._writable\n };\n }\n\n public _syncAsync(file: PreloadFile, cb: BFSOneArgCallback): void {\n this.createParentDirectoriesAsync(file.getPath(), (err?: ApiError) => {\n if (err) {\n return cb(err);\n }\n this._writable.writeFile(file.getPath(), file.getBuffer(), null, getFlag('w'), file.getStats().mode, cb);\n });\n }\n\n public _syncSync(file: PreloadFile): void {\n this.createParentDirectories(file.getPath());\n this._writable.writeFileSync(file.getPath(), file.getBuffer(), null, getFlag('w'), file.getStats().mode);\n }\n\n public getName() {\n return \"OverlayFS\";\n }\n\n /**\n * Called once to load up metadata stored on the writable file system.\n */\n public initialize(cb: BFSOneArgCallback): void {\n const callbackArray = this._initializeCallbacks;\n\n const end = (e?: ApiError): void => {\n this._isInitialized = !e;\n this._initializeCallbacks = [];\n callbackArray.forEach(((cb) => cb(e)));\n };\n\n // if we're already initialized, immediately invoke the callback\n if (this._isInitialized) {\n return cb();\n }\n\n callbackArray.push(cb);\n // The first call to initialize initializes, the rest wait for it to complete.\n if (callbackArray.length !== 1) {\n return;\n }\n\n // Read deletion log, process into metadata.\n this._writable.readFile(deletionLogPath, 'utf8', getFlag('r'), (err: ApiError, data?: string) => {\n if (err) {\n // ENOENT === Newly-instantiated file system, and thus empty log.\n if (err.errno !== ErrorCode.ENOENT) {\n return end(err);\n }\n } else {\n this._deleteLog = data!;\n }\n this._reparseDeletionLog();\n end();\n });\n }\n\n public isReadOnly(): boolean { return false; }\n public supportsSynch(): boolean { return this._readable.supportsSynch() && this._writable.supportsSynch(); }\n public supportsLinks(): boolean { return false; }\n public supportsProps(): boolean { return this._readable.supportsProps() && this._writable.supportsProps(); }\n\n public getDeletionLog(): string {\n return this._deleteLog;\n }\n\n public restoreDeletionLog(log: string): void {\n this._deleteLog = log;\n this._reparseDeletionLog();\n this.updateLog('');\n }\n\n public rename(oldPath: string, newPath: string, cb: BFSOneArgCallback): void {\n if (!this.checkInitAsync(cb) || this.checkPathAsync(oldPath, cb) || this.checkPathAsync(newPath, cb)) {\n return;\n }\n\n if (oldPath === deletionLogPath || newPath === deletionLogPath) {\n return cb(ApiError.EPERM('Cannot rename deletion log.'));\n }\n\n // nothing to do if paths match\n if (oldPath === newPath) {\n return cb();\n }\n\n this.stat(oldPath, false, (oldErr: ApiError, oldStats?: Stats) => {\n if (oldErr) {\n return cb(oldErr);\n }\n\n return this.stat(newPath, false, (newErr: ApiError, newStats?: Stats) => {\n const self = this;\n // precondition: both oldPath and newPath exist and are dirs.\n // decreases: |files|\n // Need to move *every file/folder* currently stored on\n // readable to its new location on writable.\n function copyDirContents(files: string[]): void {\n const file = files.shift();\n if (!file) {\n return cb();\n }\n\n const oldFile = path.resolve(oldPath, file);\n const newFile = path.resolve(newPath, file);\n\n // Recursion! Should work for any nested files / folders.\n self.rename(oldFile, newFile, (err?: ApiError) => {\n if (err) {\n return cb(err);\n }\n copyDirContents(files);\n });\n }\n\n let mode = 0o777;\n\n // from linux's rename(2) manpage: oldpath can specify a\n // directory. In this case, newpath must either not exist, or\n // it must specify an empty directory.\n if (oldStats!.isDirectory()) {\n if (newErr) {\n if (newErr.errno !== ErrorCode.ENOENT) {\n return cb(newErr);\n }\n\n return this._writable.exists(oldPath, (exists: boolean) => {\n // simple case - both old and new are on the writable layer\n if (exists) {\n return this._writable.rename(oldPath, newPath, cb);\n }\n\n this._writable.mkdir(newPath, mode, (mkdirErr?: ApiError) => {\n if (mkdirErr) {\n return cb(mkdirErr);\n }\n\n this._readable.readdir(oldPath, (err: ApiError, files?: string[]) => {\n if (err) {\n return cb();\n }\n copyDirContents(files!);\n });\n });\n });\n }\n\n mode = newStats!.mode;\n if (!newStats!.isDirectory()) {\n return cb(ApiError.ENOTDIR(newPath));\n }\n\n this.readdir(newPath, (readdirErr: ApiError, files?: string[]) => {\n if (files && files.length) {\n return cb(ApiError.ENOTEMPTY(newPath));\n }\n\n this._readable.readdir(oldPath, (err: ApiError, files?: string[]) => {\n if (err) {\n return cb();\n }\n copyDirContents(files!);\n });\n });\n }\n\n if (newStats && newStats.isDirectory()) {\n return cb(ApiError.EISDIR(newPath));\n }\n\n this.readFile(oldPath, null, getFlag('r'), (err: ApiError, data?: any) => {\n if (err) {\n return cb(err);\n }\n\n return this.writeFile(newPath, data, null, getFlag('w'), oldStats!.mode, (err: ApiError) => {\n if (err) {\n return cb(err);\n }\n return this.unlink(oldPath, cb);\n });\n });\n });\n });\n }\n\n public renameSync(oldPath: string, newPath: string): void {\n this.checkInitialized();\n this.checkPath(oldPath);\n this.checkPath(newPath);\n if (oldPath === deletionLogPath || newPath === deletionLogPath) {\n throw ApiError.EPERM('Cannot rename deletion log.');\n }\n // Write newPath using oldPath's contents, delete oldPath.\n const oldStats = this.statSync(oldPath, false);\n if (oldStats.isDirectory()) {\n // Optimization: Don't bother moving if old === new.\n if (oldPath === newPath) {\n return;\n }\n\n let mode = 0o777;\n if (this.existsSync(newPath)) {\n const stats = this.statSync(newPath, false);\n mode = stats.mode;\n if (stats.isDirectory()) {\n if (this.readdirSync(newPath).length > 0) {\n throw ApiError.ENOTEMPTY(newPath);\n }\n } else {\n throw ApiError.ENOTDIR(newPath);\n }\n }\n\n // Take care of writable first. Move any files there, or create an empty directory\n // if it doesn't exist.\n if (this._writable.existsSync(oldPath)) {\n this._writable.renameSync(oldPath, newPath);\n } else if (!this._writable.existsSync(newPath)) {\n this._writable.mkdirSync(newPath, mode);\n }\n\n // Need to move *every file/folder* currently stored on readable to its new location\n // on writable.\n if (this._readable.existsSync(oldPath)) {\n this._readable.readdirSync(oldPath).forEach((name) => {\n // Recursion! Should work for any nested files / folders.\n this.renameSync(path.resolve(oldPath, name), path.resolve(newPath, name));\n });\n }\n } else {\n if (this.existsSync(newPath) && this.statSync(newPath, false).isDirectory()) {\n throw ApiError.EISDIR(newPath);\n }\n\n this.writeFileSync(newPath,\n this.readFileSync(oldPath, null, getFlag('r')), null, getFlag('w'), oldStats.mode);\n }\n\n if (oldPath !== newPath && this.existsSync(oldPath)) {\n this.unlinkSync(oldPath);\n }\n }\n\n public stat(p: string, isLstat: boolean, cb: BFSCallback): void {\n if (!this.checkInitAsync(cb)) {\n return;\n }\n this._writable.stat(p, isLstat, (err: ApiError, stat?: Stats) => {\n if (err && err.errno === ErrorCode.ENOENT) {\n if (this._deletedFiles[p]) {\n cb(ApiError.ENOENT(p));\n }\n this._readable.stat(p, isLstat, (err: ApiError, stat?: Stats) => {\n if (stat) {\n // Make the oldStat's mode writable. Preserve the topmost\n // part of the mode, which specifies if it is a file or a\n // directory.\n stat = stat.clone();\n stat.mode = makeModeWritable(stat.mode);\n }\n cb(err, stat);\n });\n } else {\n cb(err, stat);\n }\n });\n }\n\n public statSync(p: string, isLstat: boolean): Stats {\n this.checkInitialized();\n try {\n return this._writable.statSync(p, isLstat);\n } catch (e) {\n if (this._deletedFiles[p]) {\n throw ApiError.ENOENT(p);\n }\n const oldStat = this._readable.statSync(p, isLstat).clone();\n // Make the oldStat's mode writable. Preserve the topmost part of the\n // mode, which specifies if it is a file or a directory.\n oldStat.mode = makeModeWritable(oldStat.mode);\n return oldStat;\n }\n }\n\n public open(p: string, flag: FileFlag, mode: number, cb: BFSCallback): void {\n if (!this.checkInitAsync(cb) || this.checkPathAsync(p, cb)) {\n return;\n }\n this.stat(p, false, (err: ApiError, stats?: Stats) => {\n if (stats) {\n switch (flag.pathExistsAction()) {\n case ActionType.TRUNCATE_FILE:\n return this.createParentDirectoriesAsync(p, (err?: ApiError) => {\n if (err) {\n return cb(err);\n }\n this._writable.open(p, flag, mode, cb);\n });\n case ActionType.NOP:\n return this._writable.exists(p, (exists: boolean) => {\n if (exists) {\n this._writable.open(p, flag, mode, cb);\n } else {\n // at this point we know the stats object we got is from\n // the readable FS.\n stats = stats!.clone();\n stats.mode = mode;\n this._readable.readFile(p, null, getFlag('r'), (readFileErr: ApiError, data?: any) => {\n if (readFileErr) {\n return cb(readFileErr);\n }\n if (stats!.size === -1) {\n stats!.size = data.length;\n }\n const f = new OverlayFile(this, p, flag, stats!, data);\n cb(null, f);\n });\n }\n });\n default:\n return cb(ApiError.EEXIST(p));\n }\n } else {\n switch (flag.pathNotExistsAction()) {\n case ActionType.CREATE_FILE:\n return this.createParentDirectoriesAsync(p, (err?: ApiError) => {\n if (err) {\n return cb(err);\n }\n return this._writable.open(p, flag, mode, cb);\n });\n default:\n return cb(ApiError.ENOENT(p));\n }\n }\n });\n }\n\n public openSync(p: string, flag: FileFlag, mode: number): File {\n this.checkInitialized();\n this.checkPath(p);\n if (p === deletionLogPath) {\n throw ApiError.EPERM('Cannot open deletion log.');\n }\n if (this.existsSync(p)) {\n switch (flag.pathExistsAction()) {\n case ActionType.TRUNCATE_FILE:\n this.createParentDirectories(p);\n return this._writable.openSync(p, flag, mode);\n case ActionType.NOP:\n if (this._writable.existsSync(p)) {\n return this._writable.openSync(p, flag, mode);\n } else {\n // Create an OverlayFile.\n const buf = this._readable.readFileSync(p, null, getFlag('r'));\n const stats = this._readable.statSync(p, false).clone();\n stats.mode = mode;\n return new OverlayFile(this, p, flag, stats, buf);\n }\n default:\n throw ApiError.EEXIST(p);\n }\n } else {\n switch (flag.pathNotExistsAction()) {\n case ActionType.CREATE_FILE:\n this.createParentDirectories(p);\n return this._writable.openSync(p, flag, mode);\n default:\n throw ApiError.ENOENT(p);\n }\n }\n }\n\n public unlink(p: string, cb: BFSOneArgCallback): void {\n if (!this.checkInitAsync(cb) || this.checkPathAsync(p, cb)) {\n return;\n }\n this.exists(p, (exists: boolean) => {\n if (!exists) {\n return cb(ApiError.ENOENT(p));\n }\n\n this._writable.exists(p, (writableExists: boolean) => {\n if (writableExists) {\n return this._writable.unlink(p, (err: ApiError) => {\n if (err) {\n return cb(err);\n }\n\n this.exists(p, (readableExists: boolean) => {\n if (readableExists) {\n this.deletePath(p);\n }\n cb(null);\n });\n });\n } else {\n // if this only exists on the readable FS, add it to the\n // delete map.\n this.deletePath(p);\n cb(null);\n }\n });\n });\n }\n\n public unlinkSync(p: string): void {\n this.checkInitialized();\n this.checkPath(p);\n if (this.existsSync(p)) {\n if (this._writable.existsSync(p)) {\n this._writable.unlinkSync(p);\n }\n\n // if it still exists add to the delete log\n if (this.existsSync(p)) {\n this.deletePath(p);\n }\n } else {\n throw ApiError.ENOENT(p);\n }\n }\n\n public rmdir(p: string, cb: BFSOneArgCallback): void {\n if (!this.checkInitAsync(cb)) {\n return;\n }\n\n const rmdirLower = (): void => {\n this.readdir(p, (err: ApiError, files: string[]): void => {\n if (err) {\n return cb(err);\n }\n\n if (files.length) {\n return cb(ApiError.ENOTEMPTY(p));\n }\n\n this.deletePath(p);\n cb(null);\n });\n };\n\n this.exists(p, (exists: boolean) => {\n if (!exists) {\n return cb(ApiError.ENOENT(p));\n }\n\n this._writable.exists(p, (writableExists: boolean) => {\n if (writableExists) {\n this._writable.rmdir(p, (err: ApiError) => {\n if (err) {\n return cb(err);\n }\n\n this._readable.exists(p, (readableExists: boolean) => {\n if (readableExists) {\n rmdirLower();\n } else {\n cb();\n }\n });\n });\n } else {\n rmdirLower();\n }\n });\n });\n }\n\n public rmdirSync(p: string): void {\n this.checkInitialized();\n if (this.existsSync(p)) {\n if (this._writable.existsSync(p)) {\n this._writable.rmdirSync(p);\n }\n if (this.existsSync(p)) {\n // Check if directory is empty.\n if (this.readdirSync(p).length > 0) {\n throw ApiError.ENOTEMPTY(p);\n } else {\n this.deletePath(p);\n }\n }\n } else {\n throw ApiError.ENOENT(p);\n }\n }\n\n public mkdir(p: string, mode: number, cb: BFSCallback): void {\n if (!this.checkInitAsync(cb)) {\n return;\n }\n this.exists(p, (exists: boolean) => {\n if (exists) {\n return cb(ApiError.EEXIST(p));\n }\n\n // The below will throw should any of the parent directories\n // fail to exist on _writable.\n this.createParentDirectoriesAsync(p, (err: ApiError) => {\n if (err) {\n return cb(err);\n }\n this._writable.mkdir(p, mode, cb);\n });\n });\n }\n\n public mkdirSync(p: string, mode: number): void {\n this.checkInitialized();\n if (this.existsSync(p)) {\n throw ApiError.EEXIST(p);\n } else {\n // The below will throw should any of the parent directories fail to exist\n // on _writable.\n this.createParentDirectories(p);\n this._writable.mkdirSync(p, mode);\n }\n }\n\n public readdir(p: string, cb: BFSCallback): void {\n if (!this.checkInitAsync(cb)) {\n return;\n }\n this.stat(p, false, (err: ApiError, dirStats?: Stats) => {\n if (err) {\n return cb(err);\n }\n\n if (!dirStats!.isDirectory()) {\n return cb(ApiError.ENOTDIR(p));\n }\n\n this._writable.readdir(p, (err: ApiError, wFiles: string[]) => {\n if (err && err.code !== 'ENOENT') {\n return cb(err);\n } else if (err || !wFiles) {\n wFiles = [];\n }\n\n this._readable.readdir(p, (err: ApiError, rFiles: string[]) => {\n // if the directory doesn't exist on the lower FS set rFiles\n // here to simplify the following code.\n if (err || !rFiles) {\n rFiles = [];\n }\n\n // Readdir in both, check delete log on read-only file system's files, merge, return.\n const seenMap: {[name: string]: boolean} = {};\n const filtered: string[] = wFiles.concat(rFiles.filter((fPath: string) =>\n !this._deletedFiles[`${p}/${fPath}`]\n )).filter((fPath: string) => {\n // Remove duplicates.\n const result = !seenMap[fPath];\n seenMap[fPath] = true;\n return result;\n });\n cb(null, filtered);\n });\n });\n });\n }\n\n public readdirSync(p: string): string[] {\n this.checkInitialized();\n const dirStats = this.statSync(p, false);\n if (!dirStats.isDirectory()) {\n throw ApiError.ENOTDIR(p);\n }\n\n // Readdir in both, check delete log on RO file system's listing, merge, return.\n let contents: string[] = [];\n try {\n contents = contents.concat(this._writable.readdirSync(p));\n } catch (e) {\n // NOP.\n }\n try {\n contents = contents.concat(this._readable.readdirSync(p).filter((fPath: string) =>\n !this._deletedFiles[`${p}/${fPath}`]\n ));\n } catch (e) {\n // NOP.\n }\n const seenMap: {[name: string]: boolean} = {};\n return contents.filter((fileP: string) => {\n const result = !seenMap[fileP];\n seenMap[fileP] = true;\n return result;\n });\n }\n\n public exists(p: string, cb: (exists: boolean) => void): void {\n // Cannot pass an error back to callback, so throw an exception instead\n // if not initialized.\n this.checkInitialized();\n this._writable.exists(p, (existsWritable: boolean) => {\n if (existsWritable) {\n return cb(true);\n }\n\n this._readable.exists(p, (existsReadable: boolean) => {\n cb(existsReadable && this._deletedFiles[p] !== true);\n });\n });\n }\n\n public existsSync(p: string): boolean {\n this.checkInitialized();\n return this._writable.existsSync(p) || (this._readable.existsSync(p) && this._deletedFiles[p] !== true);\n }\n\n public chmod(p: string, isLchmod: boolean, mode: number, cb: BFSOneArgCallback): void {\n if (!this.checkInitAsync(cb)) {\n return;\n }\n this.operateOnWritableAsync(p, (err?: ApiError) => {\n if (err) {\n return cb(err);\n } else {\n this._writable.chmod(p, isLchmod, mode, cb);\n }\n });\n }\n\n public chmodSync(p: string, isLchmod: boolean, mode: number): void {\n this.checkInitialized();\n this.operateOnWritable(p, () => {\n this._writable.chmodSync(p, isLchmod, mode);\n });\n }\n\n public chown(p: string, isLchmod: boolean, uid: number, gid: number, cb: BFSOneArgCallback): void {\n if (!this.checkInitAsync(cb)) {\n return;\n }\n this.operateOnWritableAsync(p, (err?: ApiError) => {\n if (err) {\n return cb(err);\n } else {\n this._writable.chown(p, isLchmod, uid, gid, cb);\n }\n });\n }\n\n public chownSync(p: string, isLchown: boolean, uid: number, gid: number): void {\n this.checkInitialized();\n this.operateOnWritable(p, () => {\n this._writable.chownSync(p, isLchown, uid, gid);\n });\n }\n\n public utimes(p: string, atime: Date, mtime: Date, cb: BFSOneArgCallback): void {\n if (!this.checkInitAsync(cb)) {\n return;\n }\n this.operateOnWritableAsync(p, (err?: ApiError) => {\n if (err) {\n return cb(err);\n } else {\n this._writable.utimes(p, atime, mtime, cb);\n }\n });\n }\n\n public utimesSync(p: string, atime: Date, mtime: Date): void {\n this.checkInitialized();\n this.operateOnWritable(p, () => {\n this._writable.utimesSync(p, atime, mtime);\n });\n }\n\n private deletePath(p: string): void {\n this._deletedFiles[p] = true;\n this.updateLog(`d${p}\\n`);\n }\n\n private updateLog(addition: string) {\n this._deleteLog += addition;\n if (this._deleteLogUpdatePending) {\n this._deleteLogUpdateNeeded = true;\n } else {\n this._deleteLogUpdatePending = true;\n this._writable.writeFile(deletionLogPath, this._deleteLog, 'utf8', FileFlag.getFileFlag('w'), 0o644, (e) => {\n this._deleteLogUpdatePending = false;\n if (e) {\n this._deleteLogError = e;\n } else if (this._deleteLogUpdateNeeded) {\n this._deleteLogUpdateNeeded = false;\n this.updateLog('');\n }\n });\n }\n }\n\n private _reparseDeletionLog(): void {\n this._deletedFiles = {};\n this._deleteLog.split('\\n').forEach((path: string) => {\n // If the log entry begins w/ 'd', it's a deletion.\n this._deletedFiles[path.slice(1)] = path.slice(0, 1) === 'd';\n });\n }\n\n private checkInitialized(): void {\n if (!this._isInitialized) {\n throw new ApiError(ErrorCode.EPERM, \"OverlayFS is not initialized. Please initialize OverlayFS using its initialize() method before using it.\");\n } else if (this._deleteLogError !== null) {\n const e = this._deleteLogError;\n this._deleteLogError = null;\n throw e;\n }\n }\n\n private checkInitAsync(cb: BFSOneArgCallback): boolean {\n if (!this._isInitialized) {\n cb(new ApiError(ErrorCode.EPERM, \"OverlayFS is not initialized. Please initialize OverlayFS using its initialize() method before using it.\"));\n return false;\n } else if (this._deleteLogError !== null) {\n const e = this._deleteLogError;\n this._deleteLogError = null;\n cb(e);\n return false;\n }\n return true;\n }\n\n private checkPath(p: string): void {\n if (p === deletionLogPath) {\n throw ApiError.EPERM(p);\n }\n }\n\n private checkPathAsync(p: string, cb: BFSOneArgCallback): boolean {\n if (p === deletionLogPath) {\n cb(ApiError.EPERM(p));\n return true;\n }\n return false;\n }\n\n private createParentDirectoriesAsync(p: string, cb: BFSOneArgCallback): void {\n let parent = path.dirname(p);\n const toCreate: string[] = [];\n const self = this;\n\n this._writable.stat(parent, false, statDone);\n function statDone(err: ApiError, stat?: Stats): void {\n if (err) {\n toCreate.push(parent);\n parent = path.dirname(parent);\n self._writable.stat(parent, false, statDone);\n } else {\n createParents();\n }\n }\n\n function createParents(): void {\n if (!toCreate.length) {\n return cb();\n }\n\n const dir = toCreate.pop();\n self._readable.stat(dir!, false, (err: ApiError, stats?: Stats) => {\n // stop if we couldn't read the dir\n if (!stats) {\n return cb();\n }\n\n self._writable.mkdir(dir!, stats.mode, (err?: ApiError) => {\n if (err) {\n return cb(err);\n }\n createParents();\n });\n });\n }\n }\n\n /**\n * With the given path, create the needed parent directories on the writable storage\n * should they not exist. Use modes from the read-only storage.\n */\n private createParentDirectories(p: string): void {\n let parent = path.dirname(p), toCreate: string[] = [];\n while (!this._writable.existsSync(parent)) {\n toCreate.push(parent);\n parent = path.dirname(parent);\n }\n toCreate = toCreate.reverse();\n\n toCreate.forEach((p: string) => {\n this._writable.mkdirSync(p, this.statSync(p, false).mode);\n });\n }\n\n /**\n * Helper function:\n * - Ensures p is on writable before proceeding. Throws an error if it doesn't exist.\n * - Calls f to perform operation on writable.\n */\n private operateOnWritable(p: string, f: () => void): void {\n if (this.existsSync(p)) {\n if (!this._writable.existsSync(p)) {\n // File is on readable storage. Copy to writable storage before\n // changing its mode.\n this.copyToWritable(p);\n }\n f();\n } else {\n throw ApiError.ENOENT(p);\n }\n }\n\n private operateOnWritableAsync(p: string, cb: BFSOneArgCallback): void {\n this.exists(p, (exists: boolean) => {\n if (!exists) {\n return cb(ApiError.ENOENT(p));\n }\n\n this._writable.exists(p, (existsWritable: boolean) => {\n if (existsWritable) {\n cb();\n } else {\n return this.copyToWritableAsync(p, cb);\n }\n });\n });\n }\n\n /**\n * Copy from readable to writable storage.\n * PRECONDITION: File does not exist on writable storage.\n */\n private copyToWritable(p: string): void {\n const pStats = this.statSync(p, false);\n if (pStats.isDirectory()) {\n this._writable.mkdirSync(p, pStats.mode);\n } else {\n this.writeFileSync(p,\n this._readable.readFileSync(p, null, getFlag('r')), null,\n getFlag('w'), this.statSync(p, false).mode);\n }\n }\n\n private copyToWritableAsync(p: string, cb: BFSOneArgCallback): void {\n this.stat(p, false, (err: ApiError, pStats?: Stats) => {\n if (err) {\n return cb(err);\n }\n\n if (pStats!.isDirectory()) {\n return this._writable.mkdir(p, pStats!.mode, cb);\n }\n\n // need to copy file.\n this._readable.readFile(p, null, getFlag('r'), (err: ApiError, data?: Buffer) => {\n if (err) {\n return cb(err);\n }\n\n this.writeFile(p, data, null, getFlag('w'), pStats!.mode, cb);\n });\n });\n }\n}\n\nexport default class OverlayFS extends LockedFS {\n public static isAvailable(): boolean {\n return UnlockedOverlayFS.isAvailable();\n }\n\n constructor(writable: FileSystem, readable: FileSystem) {\n super(new UnlockedOverlayFS(writable, readable));\n }\n\n public initialize(cb: BFSOneArgCallback): void {\n super.initialize(cb);\n }\n\n public getOverlayedFileSystems(): { readable: FileSystem; writable: FileSystem; } {\n return super.getFSUnlocked().getOverlayedFileSystems();\n }\n\n public unwrap(): UnlockedOverlayFS {\n return super.getFSUnlocked();\n }\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../src/backend/OverlayFS.ts","import {BaseFileSystem, FileSystem, BFSOneArgCallback, BFSCallback} from '../core/file_system';\nimport {ApiError} from '../core/api_error';\nimport {FileFlag} from '../core/file_flag';\nimport {buffer2ArrayBuffer, arrayBuffer2Buffer} from '../core/util';\nimport {File, BaseFile} from '../core/file';\nimport {default as Stats} from '../core/node_fs_stats';\nimport PreloadFile from '../generic/preload_file';\nimport global from '../core/global';\nimport fs from '../core/node_fs';\n\ndeclare const importScripts: Function;\n\ninterface IBrowserFSMessage {\n browserfsMessage: boolean;\n}\n\nenum SpecialArgType {\n // Callback\n CB,\n // File descriptor\n FD,\n // API error\n API_ERROR,\n // Stats object\n STATS,\n // Initial probe for file system information.\n PROBE,\n // FileFlag object.\n FILEFLAG,\n // Buffer object.\n BUFFER,\n // Generic Error object.\n ERROR\n}\n\ninterface ISpecialArgument {\n type: SpecialArgType;\n}\n\ninterface IProbeResponse extends ISpecialArgument {\n isReadOnly: boolean;\n supportsLinks: boolean;\n supportsProps: boolean;\n}\n\ninterface ICallbackArgument extends ISpecialArgument {\n // The callback ID.\n id: number;\n}\n\n/**\n * Converts callback arguments into ICallbackArgument objects, and back\n * again.\n */\nclass CallbackArgumentConverter {\n private _callbacks: { [id: number]: Function } = {};\n private _nextId: number = 0;\n\n public toRemoteArg(cb: Function): ICallbackArgument {\n const id = this._nextId++;\n this._callbacks[id] = cb;\n return {\n type: SpecialArgType.CB,\n id: id\n };\n }\n\n public toLocalArg(id: number): Function {\n const cb = this._callbacks[id];\n delete this._callbacks[id];\n return cb;\n }\n}\n\ninterface IFileDescriptorArgument extends ISpecialArgument {\n // The file descriptor's id on the remote side.\n id: number;\n // The entire file's data, as an array buffer.\n data: ArrayBuffer;\n // The file's stat object, as an array buffer.\n stat: ArrayBuffer;\n // The path to the file.\n path: string;\n // The flag of the open file descriptor.\n flag: string;\n}\n\nclass FileDescriptorArgumentConverter {\n private _fileDescriptors: { [id: number]: File } = {};\n private _nextId: number = 0;\n\n public toRemoteArg(fd: File, p: string, flag: FileFlag, cb: BFSCallback): void {\n const id = this._nextId++;\n let data: ArrayBuffer;\n let stat: ArrayBuffer;\n this._fileDescriptors[id] = fd;\n\n // Extract needed information asynchronously.\n fd.stat((err, stats) => {\n if (err) {\n cb(err);\n } else {\n stat = bufferToTransferrableObject(stats!.toBuffer());\n // If it's a readable flag, we need to grab contents.\n if (flag.isReadable()) {\n fd.read(new Buffer(stats!.size), 0, stats!.size, 0, (err?: ApiError | null, bytesRead?: number, buff?: Buffer) => {\n if (err) {\n cb(err);\n } else {\n data = bufferToTransferrableObject(buff!);\n cb(null, {\n type: SpecialArgType.FD,\n id: id,\n data: data,\n stat: stat,\n path: p,\n flag: flag.getFlagString()\n });\n }\n });\n } else {\n // File is not readable, which means writing to it will append or\n // truncate/replace existing contents. Return an empty arraybuffer.\n cb(null, {\n type: SpecialArgType.FD,\n id: id,\n data: new ArrayBuffer(0),\n stat: stat,\n path: p,\n flag: flag.getFlagString()\n });\n }\n }\n });\n }\n\n public applyFdAPIRequest(request: IAPIRequest, cb: BFSOneArgCallback): void {\n const fdArg = request.args[0];\n this._applyFdChanges(fdArg, (err, fd?) => {\n if (err) {\n cb(err);\n } else {\n // Apply method on now-changed file descriptor.\n ( fd)[request.method]((e?: ApiError) => {\n if (request.method === 'close') {\n delete this._fileDescriptors[fdArg.id];\n }\n cb(e);\n });\n }\n });\n }\n\n private _applyFdChanges(remoteFd: IFileDescriptorArgument, cb: BFSCallback): void {\n const fd = this._fileDescriptors[remoteFd.id],\n data = transferrableObjectToBuffer(remoteFd.data),\n remoteStats = Stats.fromBuffer(transferrableObjectToBuffer(remoteFd.stat));\n\n // Write data if the file is writable.\n const flag = FileFlag.getFileFlag(remoteFd.flag);\n if (flag.isWriteable()) {\n // Appendable: Write to end of file.\n // Writeable: Replace entire contents of file.\n fd.write(data, 0, data.length, flag.isAppendable() ? fd.getPos()! : 0, (e?: ApiError | null) => {\n function applyStatChanges() {\n // Check if mode changed.\n fd.stat((e, stats?) => {\n if (e) {\n cb(e);\n } else {\n if (stats!.mode !== remoteStats.mode) {\n fd.chmod(remoteStats.mode, (e: any) => {\n cb(e, fd);\n });\n } else {\n cb(e, fd);\n }\n }\n });\n }\n if (e) {\n cb(e);\n } else {\n // If writeable & not appendable, we need to ensure file contents are\n // identical to those from the remote FD. Thus, we truncate to the\n // length of the remote file.\n if (!flag.isAppendable()) {\n fd.truncate(data.length, () => {\n applyStatChanges();\n });\n } else {\n applyStatChanges();\n }\n }\n });\n } else {\n cb(null, fd);\n }\n }\n}\n\ninterface IAPIErrorArgument extends ISpecialArgument {\n // The error object, as an array buffer.\n errorData: ArrayBuffer;\n}\n\nfunction apiErrorLocal2Remote(e: ApiError): IAPIErrorArgument {\n return {\n type: SpecialArgType.API_ERROR,\n errorData: bufferToTransferrableObject(e.writeToBuffer())\n };\n}\n\nfunction apiErrorRemote2Local(e: IAPIErrorArgument): ApiError {\n return ApiError.fromBuffer(transferrableObjectToBuffer(e.errorData));\n}\n\ninterface IErrorArgument extends ISpecialArgument {\n // The name of the error (e.g. 'TypeError').\n name: string;\n // The message associated with the error.\n message: string;\n // The stack associated with the error.\n stack: string;\n}\n\nfunction errorLocal2Remote(e: Error): IErrorArgument {\n return {\n type: SpecialArgType.ERROR,\n name: e.name,\n message: e.message,\n stack: e.stack!\n };\n}\n\nfunction errorRemote2Local(e: IErrorArgument): Error {\n let cnstr: {\n new (msg: string): Error;\n } = global[e.name];\n if (typeof(cnstr) !== 'function') {\n cnstr = Error;\n }\n const err = new cnstr(e.message);\n err.stack = e.stack;\n return err;\n}\n\ninterface IStatsArgument extends ISpecialArgument {\n // The stats object as an array buffer.\n statsData: ArrayBuffer;\n}\n\nfunction statsLocal2Remote(stats: Stats): IStatsArgument {\n return {\n type: SpecialArgType.STATS,\n statsData: bufferToTransferrableObject(stats.toBuffer())\n };\n}\n\nfunction statsRemote2Local(stats: IStatsArgument): Stats {\n return Stats.fromBuffer(transferrableObjectToBuffer(stats.statsData));\n}\n\ninterface IFileFlagArgument extends ISpecialArgument {\n flagStr: string;\n}\n\nfunction fileFlagLocal2Remote(flag: FileFlag): IFileFlagArgument {\n return {\n type: SpecialArgType.FILEFLAG,\n flagStr: flag.getFlagString()\n };\n}\n\nfunction fileFlagRemote2Local(remoteFlag: IFileFlagArgument): FileFlag {\n return FileFlag.getFileFlag(remoteFlag.flagStr);\n}\n\ninterface IBufferArgument extends ISpecialArgument {\n data: ArrayBuffer;\n}\n\nfunction bufferToTransferrableObject(buff: Buffer): ArrayBuffer {\n return buffer2ArrayBuffer(buff);\n}\n\nfunction transferrableObjectToBuffer(buff: ArrayBuffer): Buffer {\n return arrayBuffer2Buffer(buff);\n}\n\nfunction bufferLocal2Remote(buff: Buffer): IBufferArgument {\n return {\n type: SpecialArgType.BUFFER,\n data: bufferToTransferrableObject(buff)\n };\n}\n\nfunction bufferRemote2Local(buffArg: IBufferArgument): Buffer {\n return transferrableObjectToBuffer(buffArg.data);\n}\n\ninterface IAPIRequest extends IBrowserFSMessage {\n method: string;\n args: Array;\n}\n\nfunction isAPIRequest(data: any): data is IAPIRequest {\n return data && typeof data === 'object' && data.hasOwnProperty('browserfsMessage') && data['browserfsMessage'];\n}\n\ninterface IAPIResponse extends IBrowserFSMessage {\n cbId: number;\n args: Array;\n}\n\nfunction isAPIResponse(data: any): data is IAPIResponse {\n return data && typeof data === 'object' && data.hasOwnProperty('browserfsMessage') && data['browserfsMessage'];\n}\n\n/**\n * Represents a remote file in a different worker/thread.\n */\nclass WorkerFile extends PreloadFile {\n private _remoteFdId: number;\n\n constructor(_fs: WorkerFS, _path: string, _flag: FileFlag, _stat: Stats, remoteFdId: number, contents?: Buffer) {\n super(_fs, _path, _flag, _stat, contents);\n this._remoteFdId = remoteFdId;\n }\n\n public getRemoteFdId() {\n return this._remoteFdId;\n }\n\n public toRemoteArg(): IFileDescriptorArgument {\n return {\n type: SpecialArgType.FD,\n id: this._remoteFdId,\n data: bufferToTransferrableObject(this.getBuffer()),\n stat: bufferToTransferrableObject(this.getStats().toBuffer()),\n path: this.getPath(),\n flag: this.getFlag().getFlagString()\n };\n }\n\n public sync(cb: BFSOneArgCallback): void {\n this._syncClose('sync', cb);\n }\n\n public close(cb: BFSOneArgCallback): void {\n this._syncClose('close', cb);\n }\n\n private _syncClose(type: string, cb: BFSOneArgCallback): void {\n if (this.isDirty()) {\n ( this._fs).syncClose(type, this, (e?: ApiError) => {\n if (!e) {\n this.resetDirty();\n }\n cb(e);\n });\n } else {\n cb();\n }\n }\n}\n\n/**\n * WorkerFS lets you access a BrowserFS instance that is running in a different\n * JavaScript context (e.g. access BrowserFS in one of your WebWorkers, or\n * access BrowserFS running on the main page from a WebWorker).\n *\n * For example, to have a WebWorker access files in the main browser thread,\n * do the following:\n *\n * MAIN BROWSER THREAD:\n * ```\n * // Listen for remote file system requests.\n * BrowserFS.FileSystem.WorkerFS.attachRemoteListener(webWorkerObject);\n * ``\n *\n * WEBWORKER THREAD:\n * ```\n * // Set the remote file system as the root file system.\n * BrowserFS.initialize(new BrowserFS.FileSystem.WorkerFS(self));\n * ```\n *\n * Note that synchronous operations are not permitted on the WorkerFS, regardless\n * of the configuration option of the remote FS.\n */\nexport default class WorkerFS extends BaseFileSystem implements FileSystem {\n public static isAvailable(): boolean {\n return typeof(importScripts) !== 'undefined' || typeof(Worker) !== 'undefined';\n }\n\n /**\n * Attaches a listener to the remote worker for file system requests.\n */\n public static attachRemoteListener(worker: Worker) {\n const fdConverter = new FileDescriptorArgumentConverter();\n\n function argLocal2Remote(arg: any, requestArgs: any[], cb: BFSCallback): void {\n switch (typeof arg) {\n case 'object':\n if (arg instanceof Stats) {\n cb(null, statsLocal2Remote(arg));\n } else if (arg instanceof ApiError) {\n cb(null, apiErrorLocal2Remote(arg));\n } else if (arg instanceof BaseFile) {\n // Pass in p and flags from original request.\n cb(null, fdConverter.toRemoteArg( arg, requestArgs[0], requestArgs[1], cb));\n } else if (arg instanceof FileFlag) {\n cb(null, fileFlagLocal2Remote(arg));\n } else if (arg instanceof Buffer) {\n cb(null, bufferLocal2Remote(arg));\n } else if (arg instanceof Error) {\n cb(null, errorLocal2Remote(arg));\n } else {\n cb(null, arg);\n }\n break;\n default:\n cb(null, arg);\n break;\n }\n }\n\n function argRemote2Local(arg: any, fixedRequestArgs: any[]): any {\n if (!arg) {\n return arg;\n }\n switch (typeof arg) {\n case 'object':\n if (typeof arg['type'] === 'number') {\n const specialArg = arg;\n switch (specialArg.type) {\n case SpecialArgType.CB:\n const cbId = ( arg).id;\n return function() {\n let i: number;\n const fixedArgs = new Array(arguments.length);\n let message: IAPIResponse,\n countdown = arguments.length;\n\n function abortAndSendError(err: ApiError) {\n if (countdown > 0) {\n countdown = -1;\n message = {\n browserfsMessage: true,\n cbId: cbId,\n args: [apiErrorLocal2Remote(err)]\n };\n worker.postMessage(message);\n }\n }\n\n for (i = 0; i < arguments.length; i++) {\n // Capture i and argument.\n ((i: number, arg: any) => {\n argLocal2Remote(arg, fixedRequestArgs, (err, fixedArg?) => {\n fixedArgs[i] = fixedArg;\n if (err) {\n abortAndSendError(err);\n } else if (--countdown === 0) {\n message = {\n browserfsMessage: true,\n cbId: cbId,\n args: fixedArgs\n };\n worker.postMessage(message);\n }\n });\n })(i, arguments[i]);\n }\n\n if (arguments.length === 0) {\n message = {\n browserfsMessage: true,\n cbId: cbId,\n args: fixedArgs\n };\n worker.postMessage(message);\n }\n\n };\n case SpecialArgType.API_ERROR:\n return apiErrorRemote2Local( specialArg);\n case SpecialArgType.STATS:\n return statsRemote2Local( specialArg);\n case SpecialArgType.FILEFLAG:\n return fileFlagRemote2Local( specialArg);\n case SpecialArgType.BUFFER:\n return bufferRemote2Local( specialArg);\n case SpecialArgType.ERROR:\n return errorRemote2Local( specialArg);\n default:\n // No idea what this is.\n return arg;\n }\n } else {\n return arg;\n }\n default:\n return arg;\n }\n }\n\n worker.addEventListener('message', (e: MessageEvent) => {\n const request: Object = e.data;\n if (isAPIRequest(request)) {\n const args = request.args,\n fixedArgs = new Array(args.length);\n\n switch (request.method) {\n case 'close':\n case 'sync':\n (() => {\n // File descriptor-relative methods.\n const remoteCb = args[1];\n fdConverter.applyFdAPIRequest(request, (err?: ApiError) => {\n // Send response.\n const response: IAPIResponse = {\n browserfsMessage: true,\n cbId: remoteCb.id,\n args: err ? [apiErrorLocal2Remote(err)] : []\n };\n worker.postMessage(response);\n });\n })();\n break;\n case 'probe':\n (() => {\n const rootFs = fs.getRootFS(),\n remoteCb = args[1],\n probeResponse: IProbeResponse = {\n type: SpecialArgType.PROBE,\n isReadOnly: rootFs.isReadOnly(),\n supportsLinks: rootFs.supportsLinks(),\n supportsProps: rootFs.supportsProps()\n },\n response: IAPIResponse = {\n browserfsMessage: true,\n cbId: remoteCb.id,\n args: [probeResponse]\n };\n\n worker.postMessage(response);\n })();\n break;\n default:\n // File system methods.\n for (let i = 0; i < args.length; i++) {\n fixedArgs[i] = argRemote2Local(args[i], fixedArgs);\n }\n const rootFS = fs.getRootFS();\n ( ( rootFS)[request.method]).apply(rootFS, fixedArgs);\n break;\n }\n }\n });\n }\n\n private _worker: Worker;\n private _callbackConverter = new CallbackArgumentConverter();\n\n private _isInitialized: boolean = false;\n private _isReadOnly: boolean = false;\n private _supportLinks: boolean = false;\n private _supportProps: boolean = false;\n\n /**\n * Constructs a new WorkerFS instance that connects with BrowserFS running on\n * the specified worker.\n */\n constructor(worker: Worker) {\n super();\n this._worker = worker;\n this._worker.addEventListener('message', (e: MessageEvent) => {\n const resp: Object = e.data;\n if (isAPIResponse(resp)) {\n let i: number;\n const args = resp.args;\n const fixedArgs = new Array(args.length);\n // Dispatch event to correct id.\n for (i = 0; i < fixedArgs.length; i++) {\n fixedArgs[i] = this._argRemote2Local(args[i]);\n }\n this._callbackConverter.toLocalArg(resp.cbId).apply(null, fixedArgs);\n }\n });\n }\n\n public getName(): string {\n return 'WorkerFS';\n }\n\n /**\n * Converts a local argument into a remote argument. Public so WorkerFile objects can call it.\n */\n public _argLocal2Remote(arg: any): any {\n if (!arg) {\n return arg;\n }\n switch (typeof arg) {\n case \"object\":\n if (arg instanceof Stats) {\n return statsLocal2Remote(arg);\n } else if (arg instanceof ApiError) {\n return apiErrorLocal2Remote(arg);\n } else if (arg instanceof WorkerFile) {\n return ( arg).toRemoteArg();\n } else if (arg instanceof FileFlag) {\n return fileFlagLocal2Remote(arg);\n } else if (arg instanceof Buffer) {\n return bufferLocal2Remote(arg);\n } else if (arg instanceof Error) {\n return errorLocal2Remote(arg);\n } else {\n return \"Unknown argument\";\n }\n case \"function\":\n return this._callbackConverter.toRemoteArg(arg);\n default:\n return arg;\n }\n }\n\n /**\n * Called once both local and remote sides are set up.\n */\n public initialize(cb: () => void): void {\n if (!this._isInitialized) {\n const message: IAPIRequest = {\n browserfsMessage: true,\n method: 'probe',\n args: [this._argLocal2Remote(new Buffer(0)), this._callbackConverter.toRemoteArg((probeResponse: IProbeResponse) => {\n this._isInitialized = true;\n this._isReadOnly = probeResponse.isReadOnly;\n this._supportLinks = probeResponse.supportsLinks;\n this._supportProps = probeResponse.supportsProps;\n cb();\n })]\n };\n this._worker.postMessage(message);\n } else {\n cb();\n }\n }\n\n public isReadOnly(): boolean { return this._isReadOnly; }\n public supportsSynch(): boolean { return false; }\n public supportsLinks(): boolean { return this._supportLinks; }\n public supportsProps(): boolean { return this._supportProps; }\n\n public rename(oldPath: string, newPath: string, cb: BFSOneArgCallback): void {\n this._rpc('rename', arguments);\n }\n public stat(p: string, isLstat: boolean, cb: BFSCallback): void {\n this._rpc('stat', arguments);\n }\n public open(p: string, flag: FileFlag, mode: number, cb: BFSCallback): void {\n this._rpc('open', arguments);\n }\n public unlink(p: string, cb: Function): void {\n this._rpc('unlink', arguments);\n }\n public rmdir(p: string, cb: Function): void {\n this._rpc('rmdir', arguments);\n }\n public mkdir(p: string, mode: number, cb: Function): void {\n this._rpc('mkdir', arguments);\n }\n public readdir(p: string, cb: BFSCallback): void {\n this._rpc('readdir', arguments);\n }\n public exists(p: string, cb: (exists: boolean) => void): void {\n this._rpc('exists', arguments);\n }\n public realpath(p: string, cache: { [path: string]: string }, cb: BFSCallback): void {\n this._rpc('realpath', arguments);\n }\n public truncate(p: string, len: number, cb: Function): void {\n this._rpc('truncate', arguments);\n }\n public readFile(fname: string, encoding: string, flag: FileFlag, cb: BFSCallback): void {\n this._rpc('readFile', arguments);\n }\n public writeFile(fname: string, data: any, encoding: string, flag: FileFlag, mode: number, cb: BFSOneArgCallback): void {\n this._rpc('writeFile', arguments);\n }\n public appendFile(fname: string, data: any, encoding: string, flag: FileFlag, mode: number, cb: BFSOneArgCallback): void {\n this._rpc('appendFile', arguments);\n }\n public chmod(p: string, isLchmod: boolean, mode: number, cb: Function): void {\n this._rpc('chmod', arguments);\n }\n public chown(p: string, isLchown: boolean, uid: number, gid: number, cb: Function): void {\n this._rpc('chown', arguments);\n }\n public utimes(p: string, atime: Date, mtime: Date, cb: Function): void {\n this._rpc('utimes', arguments);\n }\n public link(srcpath: string, dstpath: string, cb: Function): void {\n this._rpc('link', arguments);\n }\n public symlink(srcpath: string, dstpath: string, type: string, cb: Function): void {\n this._rpc('symlink', arguments);\n }\n public readlink(p: string, cb: Function): void {\n this._rpc('readlink', arguments);\n }\n\n public syncClose(method: string, fd: File, cb: BFSOneArgCallback): void {\n this._worker.postMessage( {\n browserfsMessage: true,\n method: method,\n args: [( fd).toRemoteArg(), this._callbackConverter.toRemoteArg(cb)]\n });\n }\n\n private _argRemote2Local(arg: any): any {\n if (!arg) {\n return arg;\n }\n switch (typeof arg) {\n case 'object':\n if (typeof arg['type'] === 'number') {\n const specialArg = arg;\n switch (specialArg.type) {\n case SpecialArgType.API_ERROR:\n return apiErrorRemote2Local( specialArg);\n case SpecialArgType.FD:\n const fdArg = specialArg;\n return new WorkerFile(this, fdArg.path, FileFlag.getFileFlag(fdArg.flag), Stats.fromBuffer(transferrableObjectToBuffer(fdArg.stat)), fdArg.id, transferrableObjectToBuffer(fdArg.data));\n case SpecialArgType.STATS:\n return statsRemote2Local( specialArg);\n case SpecialArgType.FILEFLAG:\n return fileFlagRemote2Local( specialArg);\n case SpecialArgType.BUFFER:\n return bufferRemote2Local( specialArg);\n case SpecialArgType.ERROR:\n return errorRemote2Local( specialArg);\n default:\n return arg;\n }\n } else {\n return arg;\n }\n default:\n return arg;\n }\n }\n\n private _rpc(methodName: string, args: IArguments) {\n const fixedArgs = new Array(args.length);\n for (let i = 0; i < args.length; i++) {\n fixedArgs[i] = this._argLocal2Remote(args[i]);\n }\n const message: IAPIRequest = {\n browserfsMessage: true,\n method: methodName,\n args: fixedArgs\n };\n this._worker.postMessage(message);\n }\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../src/backend/WorkerFS.ts","/**\n * Contains utility methods for performing a variety of tasks with\n * XmlHttpRequest across browsers.\n */\n\nimport {isIE} from '../core/util';\nimport {ApiError, ErrorCode} from '../core/api_error';\nimport {BFSCallback} from '../core/file_system';\n\nfunction asyncDownloadFileModern(p: string, type: 'buffer', cb: BFSCallback): void;\nfunction asyncDownloadFileModern(p: string, type: 'json', cb: BFSCallback): void;\nfunction asyncDownloadFileModern(p: string, type: string, cb: BFSCallback): void;\nfunction asyncDownloadFileModern(p: string, type: string, cb: BFSCallback): void {\n const req = new XMLHttpRequest();\n req.open('GET', p, true);\n let jsonSupported = true;\n switch (type) {\n case 'buffer':\n req.responseType = 'arraybuffer';\n break;\n case 'json':\n // Some browsers don't support the JSON response type.\n // They either reset responseType, or throw an exception.\n // @see https://github.com/Modernizr/Modernizr/blob/master/src/testXhrType.js\n try {\n req.responseType = 'json';\n jsonSupported = req.responseType === 'json';\n } catch (e) {\n jsonSupported = false;\n }\n break;\n default:\n return cb(new ApiError(ErrorCode.EINVAL, \"Invalid download type: \" + type));\n }\n req.onreadystatechange = function(e) {\n if (req.readyState === 4) {\n if (req.status === 200) {\n switch (type) {\n case 'buffer':\n // XXX: WebKit-based browsers return *null* when XHRing an empty file.\n return cb(null, new Buffer(req.response ? req.response : 0));\n case 'json':\n if (jsonSupported) {\n return cb(null, req.response);\n } else {\n return cb(null, JSON.parse(req.responseText));\n }\n }\n } else {\n return cb(new ApiError(req.status, \"XHR error.\"));\n }\n }\n };\n req.send();\n}\n\nfunction syncDownloadFileModern(p: string, type: 'buffer'): Buffer;\nfunction syncDownloadFileModern(p: string, type: 'json'): any;\nfunction syncDownloadFileModern(p: string, type: string): any;\nfunction syncDownloadFileModern(p: string, type: string): any {\n const req = new XMLHttpRequest();\n req.open('GET', p, false);\n\n // On most platforms, we cannot set the responseType of synchronous downloads.\n // @todo Test for this; IE10 allows this, as do older versions of Chrome/FF.\n let data: any = null;\n let err: any = null;\n // Classic hack to download binary data as a string.\n req.overrideMimeType('text/plain; charset=x-user-defined');\n req.onreadystatechange = function(e) {\n if (req.readyState === 4) {\n if (req.status === 200) {\n switch (type) {\n case 'buffer':\n // Convert the text into a buffer.\n const text = req.responseText;\n data = new Buffer(text.length);\n // Throw away the upper bits of each character.\n for (let i = 0; i < text.length; i++) {\n // This will automatically throw away the upper bit of each\n // character for us.\n data[i] = text.charCodeAt(i);\n }\n return;\n case 'json':\n data = JSON.parse(req.responseText);\n return;\n }\n } else {\n err = new ApiError(req.status, \"XHR error.\");\n return;\n }\n }\n };\n req.send();\n if (err) {\n throw err;\n }\n return data;\n}\n\n/**\n * IE10 allows us to perform synchronous binary file downloads.\n * @todo Feature detect this, as older versions of FF/Chrome do too!\n */\nfunction syncDownloadFileIE10(p: string, type: 'buffer'): Buffer;\nfunction syncDownloadFileIE10(p: string, type: 'json'): any;\nfunction syncDownloadFileIE10(p: string, type: string): any;\nfunction syncDownloadFileIE10(p: string, type: string): any {\n const req = new XMLHttpRequest();\n req.open('GET', p, false);\n switch (type) {\n case 'buffer':\n req.responseType = 'arraybuffer';\n break;\n case 'json':\n // IE10 does not support the JSON type.\n break;\n default:\n throw new ApiError(ErrorCode.EINVAL, \"Invalid download type: \" + type);\n }\n let data: any;\n let err: any;\n req.onreadystatechange = function(e) {\n if (req.readyState === 4) {\n if (req.status === 200) {\n switch (type) {\n case 'buffer':\n data = new Buffer(req.response);\n break;\n case 'json':\n data = JSON.parse(req.response);\n break;\n }\n } else {\n err = new ApiError(req.status, \"XHR error.\");\n }\n }\n };\n req.send();\n if (err) {\n throw err;\n }\n return data;\n}\n\nfunction getFileSize(async: boolean, p: string, cb: BFSCallback): void {\n const req = new XMLHttpRequest();\n req.open('HEAD', p, async);\n req.onreadystatechange = function(e) {\n if (req.readyState === 4) {\n if (req.status === 200) {\n try {\n return cb(null, parseInt(req.getResponseHeader('Content-Length') || '-1', 10));\n } catch (e) {\n // In the event that the header isn't present or there is an error...\n return cb(new ApiError(ErrorCode.EIO, \"XHR HEAD error: Could not read content-length.\"));\n }\n } else {\n return cb(new ApiError(req.status, \"XHR HEAD error.\"));\n }\n }\n };\n req.send();\n}\n\n/**\n * Asynchronously download a file as a buffer or a JSON object.\n * Note that the third function signature with a non-specialized type is\n * invalid, but TypeScript requires it when you specialize string arguments to\n * constants.\n */\nexport let asyncDownloadFile: {\n (p: string, type: 'buffer', cb: BFSCallback): void;\n (p: string, type: 'json', cb: BFSCallback): void;\n (p: string, type: string, cb: BFSCallback): void;\n} = asyncDownloadFileModern;\n\n/**\n * Synchronously download a file as a buffer or a JSON object.\n * Note that the third function signature with a non-specialized type is\n * invalid, but TypeScript requires it when you specialize string arguments to\n * constants.\n */\nexport let syncDownloadFile: {\n (p: string, type: 'buffer'): Buffer;\n (p: string, type: 'json'): any;\n (p: string, type: string): any;\n} = (isIE && typeof Blob !== 'undefined') ? syncDownloadFileIE10 : syncDownloadFileModern;\n\n/**\n * Synchronously retrieves the size of the given file in bytes.\n */\nexport function getFileSizeSync(p: string): number {\n let rv: number = -1;\n getFileSize(false, p, function(err: ApiError, size?: number) {\n if (err) {\n throw err;\n }\n rv = size!;\n });\n return rv;\n}\n\n/**\n * Asynchronously retrieves the size of the given file in bytes.\n */\nexport function getFileSizeAsync(p: string, cb: (err: ApiError, size?: number) => void): void {\n getFileSize(true, p, cb);\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../src/generic/xhr.ts","import {default as Stats, FileType} from '../core/node_fs_stats';\nimport * as path from 'path';\n\n/**\n * A simple class for storing a filesystem index. Assumes that all paths passed\n * to it are *absolute* paths.\n *\n * Can be used as a partial or a full index, although care must be taken if used\n * for the former purpose, especially when directories are concerned.\n */\nexport class FileIndex {\n /**\n * Static method for constructing indices from a JSON listing.\n * @param listing Directory listing generated by tools/XHRIndexer.coffee\n * @return A new FileIndex object.\n */\n public static fromListing(listing: any): FileIndex {\n const idx = new FileIndex();\n // Add a root DirNode.\n const rootInode = new DirInode();\n idx._index['/'] = rootInode;\n const queue = [['', listing, rootInode]];\n while (queue.length > 0) {\n let inode: Inode;\n const next = queue.pop();\n const pwd = next![0];\n const tree = next![1];\n const parent = next![2];\n for (const node in tree) {\n if (tree.hasOwnProperty(node)) {\n const children = tree[node];\n const name = `${pwd}/${node}`;\n if (children) {\n idx._index[name] = inode = new DirInode();\n queue.push([name, children, inode]);\n } else {\n // This inode doesn't have correct size information, noted with -1.\n inode = new FileInode(new Stats(FileType.FILE, -1, 0x16D));\n }\n if (parent) {\n parent._ls[node] = inode;\n }\n }\n }\n }\n return idx;\n }\n\n // Maps directory paths to directory inodes, which contain files.\n private _index: {[path: string]: DirInode };\n\n /**\n * Constructs a new FileIndex.\n */\n constructor() {\n // _index is a single-level key,value store that maps *directory* paths to\n // DirInodes. File information is only contained in DirInodes themselves.\n this._index = {};\n // Create the root directory.\n this.addPath('/', new DirInode());\n }\n\n /**\n * Runs the given function over all files in the index.\n */\n public fileIterator(cb: (file: T | null) => void): void {\n for (const path in this._index) {\n if (this._index.hasOwnProperty(path)) {\n const dir = this._index[path];\n const files = dir.getListing();\n for (let i = 0; i < files.length; i++) {\n const item = dir.getItem(files[i]);\n if (isFileInode(item)) {\n cb(item.getData());\n }\n }\n }\n }\n }\n\n /**\n * Adds the given absolute path to the index if it is not already in the index.\n * Creates any needed parent directories.\n * @param path The path to add to the index.\n * @param inode The inode for the\n * path to add.\n * @return 'True' if it was added or already exists, 'false' if there\n * was an issue adding it (e.g. item in path is a file, item exists but is\n * different).\n * @todo If adding fails and implicitly creates directories, we do not clean up\n * the new empty directories.\n */\n public addPath(path: string, inode: Inode): boolean {\n if (!inode) {\n throw new Error('Inode must be specified');\n }\n if (path[0] !== '/') {\n throw new Error('Path must be absolute, got: ' + path);\n }\n\n // Check if it already exists.\n if (this._index.hasOwnProperty(path)) {\n return this._index[path] === inode;\n }\n\n const splitPath = this._split_path(path);\n const dirpath = splitPath[0];\n const itemname = splitPath[1];\n // Try to add to its parent directory first.\n let parent = this._index[dirpath];\n if (parent === undefined && path !== '/') {\n // Create parent.\n parent = new DirInode();\n if (!this.addPath(dirpath, parent)) {\n return false;\n }\n }\n // Add myself to my parent.\n if (path !== '/') {\n if (!parent.addItem(itemname, inode)) {\n return false;\n }\n }\n // If I'm a directory, add myself to the index.\n if (isDirInode(inode)) {\n this._index[path] = inode;\n }\n return true;\n }\n\n /**\n * Adds the given absolute path to the index if it is not already in the index.\n * The path is added without special treatment (no joining of adjacent separators, etc).\n * Creates any needed parent directories.\n * @param path The path to add to the index.\n * @param inode The inode for the\n * path to add.\n * @return 'True' if it was added or already exists, 'false' if there\n * was an issue adding it (e.g. item in path is a file, item exists but is\n * different).\n * @todo If adding fails and implicitly creates directories, we do not clean up\n * the new empty directories.\n */\n public addPathFast(path: string, inode: Inode): boolean {\n const itemNameMark = path.lastIndexOf('/');\n const parentPath = itemNameMark === 0 ? \"/\" : path.substring(0, itemNameMark);\n const itemName = path.substring(itemNameMark + 1);\n\n // Try to add to its parent directory first.\n let parent = this._index[parentPath];\n if (parent === undefined) {\n // Create parent.\n parent = new DirInode();\n this.addPathFast(parentPath, parent);\n }\n\n if (!parent.addItem(itemName, inode)) {\n return false;\n }\n\n // If adding a directory, add to the index as well.\n if (inode.isDir()) {\n this._index[path] = > inode;\n }\n return true;\n }\n\n /**\n * Removes the given path. Can be a file or a directory.\n * @return The removed item,\n * or null if it did not exist.\n */\n public removePath(path: string): Inode | null {\n const splitPath = this._split_path(path);\n const dirpath = splitPath[0];\n const itemname = splitPath[1];\n\n // Try to remove it from its parent directory first.\n const parent = this._index[dirpath];\n if (parent === undefined) {\n return null;\n }\n // Remove myself from my parent.\n const inode = parent.remItem(itemname);\n if (inode === null) {\n return null;\n }\n // If I'm a directory, remove myself from the index, and remove my children.\n if (isDirInode(inode)) {\n const children = inode.getListing();\n for (let i = 0; i < children.length; i++) {\n this.removePath(path + '/' + children[i]);\n }\n\n // Remove the directory from the index, unless it's the root.\n if (path !== '/') {\n delete this._index[path];\n }\n }\n return inode;\n }\n\n /**\n * Retrieves the directory listing of the given path.\n * @return An array of files in the given path, or 'null' if it does not exist.\n */\n public ls(path: string): string[] | null {\n const item = this._index[path];\n if (item === undefined) {\n return null;\n }\n return item.getListing();\n }\n\n /**\n * Returns the inode of the given item.\n * @return Returns null if the item does not exist.\n */\n public getInode(path: string): Inode | null {\n const splitPath = this._split_path(path);\n const dirpath = splitPath[0];\n const itemname = splitPath[1];\n // Retrieve from its parent directory.\n const parent = this._index[dirpath];\n if (parent === undefined) {\n return null;\n }\n // Root case\n if (dirpath === path) {\n return parent;\n }\n return parent.getItem(itemname);\n }\n\n /**\n * Split into a (directory path, item name) pair\n */\n private _split_path(p: string): string[] {\n const dirpath = path.dirname(p);\n const itemname = p.substr(dirpath.length + (dirpath === \"/\" ? 0 : 1));\n return [dirpath, itemname];\n }\n}\n\n/**\n * Generic interface for file/directory inodes.\n * Note that Stats objects are what we use for file inodes.\n */\nexport interface Inode {\n // Is this an inode for a file?\n isFile(): boolean;\n // Is this an inode for a directory?\n isDir(): boolean;\n}\n\n/**\n * Inode for a file. Stores an arbitrary (filesystem-specific) data payload.\n */\nexport class FileInode implements Inode {\n constructor(private data: T) { }\n public isFile(): boolean { return true; }\n public isDir(): boolean { return false; }\n public getData(): T { return this.data; }\n public setData(data: T): void { this.data = data; }\n}\n\n/**\n * Inode for a directory. Currently only contains the directory listing.\n */\nexport class DirInode implements Inode {\n private _ls: {[path: string]: Inode} = {};\n /**\n * Constructs an inode for a directory.\n */\n constructor(private data: T | null = null) {}\n public isFile(): boolean {\n return false;\n }\n public isDir(): boolean {\n return true;\n }\n public getData(): T | null { return this.data; }\n\n /**\n * Return a Stats object for this inode.\n * @todo Should probably remove this at some point. This isn't the\n * responsibility of the FileIndex.\n */\n public getStats(): Stats {\n return new Stats(FileType.DIRECTORY, 4096, 0x16D);\n }\n /**\n * Returns the directory listing for this directory. Paths in the directory are\n * relative to the directory's path.\n * @return The directory listing for this directory.\n */\n public getListing(): string[] {\n return Object.keys(this._ls);\n }\n /**\n * Returns the inode for the indicated item, or null if it does not exist.\n * @param p Name of item in this directory.\n */\n public getItem(p: string): Inode | null {\n const item = this._ls[p];\n return item ? item : null;\n }\n /**\n * Add the given item to the directory listing. Note that the given inode is\n * not copied, and will be mutated by the DirInode if it is a DirInode.\n * @param p Item name to add to the directory listing.\n * @param inode The inode for the\n * item to add to the directory inode.\n * @return True if it was added, false if it already existed.\n */\n public addItem(p: string, inode: Inode): boolean {\n if (p in this._ls) {\n return false;\n }\n this._ls[p] = inode;\n return true;\n }\n /**\n * Removes the given item from the directory listing.\n * @param p Name of item to remove from the directory listing.\n * @return Returns the item\n * removed, or null if the item did not exist.\n */\n public remItem(p: string): Inode | null {\n const item = this._ls[p];\n if (item === undefined) {\n return null;\n }\n delete this._ls[p];\n return item;\n }\n}\n\nexport function isFileInode(inode: Inode | null): inode is FileInode {\n return !!inode && inode.isFile();\n}\n\nexport function isDirInode(inode: Inode | null): inode is DirInode {\n return !!inode && inode.isDir();\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../src/generic/file_index.ts","import {BaseFileSystem, FileSystem, BFSCallback} from '../core/file_system';\nimport {ApiError, ErrorCode} from '../core/api_error';\nimport {FileFlag, ActionType} from '../core/file_flag';\nimport {copyingSlice} from '../core/util';\nimport {File} from '../core/file';\nimport Stats from '../core/node_fs_stats';\nimport {NoSyncFile} from '../generic/preload_file';\nimport {asyncDownloadFile, syncDownloadFile, getFileSizeAsync, getFileSizeSync} from '../generic/xhr';\nimport {FileIndex, isFileInode, isDirInode} from '../generic/file_index';\n\n/**\n * Try to convert the given buffer into a string, and pass it to the callback.\n * Optimization that removes the needed try/catch into a helper function, as\n * this is an uncommon case.\n */\nfunction tryToString(buff: Buffer, encoding: string, cb: BFSCallback) {\n try {\n cb(null, buff.toString(encoding));\n } catch (e) {\n cb(e);\n }\n}\n\n/**\n * A simple filesystem backed by XmlHttpRequests.\n */\nexport default class XmlHttpRequest extends BaseFileSystem implements FileSystem {\n public static isAvailable(): boolean {\n return typeof(XMLHttpRequest) !== \"undefined\" && XMLHttpRequest !== null;\n }\n\n public prefixUrl: string;\n private _index: FileIndex<{}>;\n /**\n * Constructs the file system.\n * @param listingUrlOrObj index object or the path to the JSON file index generated by\n * tools/XHRIndexer.coffee. This can be relative to the current webpage URL\n * or absolutely specified.\n * @param prefixUrl The url prefix to use for all web-server requests.\n */\n constructor(listingUrlOrObj: string | Object, prefixUrl: string = '') {\n super();\n if (!listingUrlOrObj) {\n listingUrlOrObj = 'index.json';\n }\n // prefix_url must end in a directory separator.\n if (prefixUrl.length > 0 && prefixUrl.charAt(prefixUrl.length - 1) !== '/') {\n prefixUrl = prefixUrl + '/';\n }\n this.prefixUrl = prefixUrl;\n\n let listing: Object | null = null;\n if (typeof(listingUrlOrObj) === \"string\") {\n listing = this._requestFileSync( listingUrlOrObj, 'json');\n if (!listing) {\n throw new Error(\"Unable to find listing at URL: ${listingUrlOrObj}\");\n }\n } else {\n listing = listingUrlOrObj;\n }\n\n this._index = FileIndex.fromListing(listing);\n }\n\n public empty(): void {\n this._index.fileIterator(function(file: Stats) {\n file.fileData = null;\n });\n }\n\n /**\n * Only requests the HEAD content, for the file size.\n */\n public _requestFileSizeAsync(path: string, cb: BFSCallback): void {\n getFileSizeAsync(this.getXhrPath(path), cb);\n }\n public _requestFileSizeSync(path: string): number {\n return getFileSizeSync(this.getXhrPath(path));\n }\n\n public getName(): string {\n return 'XmlHttpRequest';\n }\n\n public diskSpace(path: string, cb: (total: number, free: number) => void): void {\n // Read-only file system. We could calculate the total space, but that's not\n // important right now.\n cb(0, 0);\n }\n\n public isReadOnly(): boolean {\n return true;\n }\n\n public supportsLinks(): boolean {\n return false;\n }\n\n public supportsProps(): boolean {\n return false;\n }\n\n public supportsSynch(): boolean {\n return true;\n }\n\n /**\n * Special XHR function: Preload the given file into the index.\n * @param [String] path\n * @param [BrowserFS.Buffer] buffer\n */\n public preloadFile(path: string, buffer: Buffer): void {\n const inode = this._index.getInode(path);\n if (isFileInode(inode)) {\n if (inode === null) {\n throw ApiError.ENOENT(path);\n }\n const stats = inode.getData();\n stats.size = buffer.length;\n stats.fileData = buffer;\n } else {\n throw ApiError.EISDIR(path);\n }\n }\n\n public stat(path: string, isLstat: boolean, cb: BFSCallback): void {\n const inode = this._index.getInode(path);\n if (inode === null) {\n return cb(ApiError.ENOENT(path));\n }\n let stats: Stats;\n if (isFileInode(inode)) {\n stats = inode.getData();\n // At this point, a non-opened file will still have default stats from the listing.\n if (stats.size < 0) {\n this._requestFileSizeAsync(path, function(e: ApiError, size?: number) {\n if (e) {\n return cb(e);\n }\n stats.size = size!;\n cb(null, stats.clone());\n });\n } else {\n cb(null, stats.clone());\n }\n } else if (isDirInode(inode)) {\n stats = inode.getStats();\n cb(null, stats);\n } else {\n cb(ApiError.FileError(ErrorCode.EINVAL, path));\n }\n }\n\n public statSync(path: string, isLstat: boolean): Stats {\n const inode = this._index.getInode(path);\n if (inode === null) {\n throw ApiError.ENOENT(path);\n }\n let stats: Stats;\n if (isFileInode(inode)) {\n stats = inode.getData();\n // At this point, a non-opened file will still have default stats from the listing.\n if (stats.size < 0) {\n stats.size = this._requestFileSizeSync(path);\n }\n } else if (isDirInode(inode)) {\n stats = inode.getStats();\n } else {\n throw ApiError.FileError(ErrorCode.EINVAL, path);\n }\n return stats;\n }\n\n public open(path: string, flags: FileFlag, mode: number, cb: BFSCallback): void {\n // INVARIANT: You can't write to files on this file system.\n if (flags.isWriteable()) {\n return cb(new ApiError(ErrorCode.EPERM, path));\n }\n const self = this;\n // Check if the path exists, and is a file.\n const inode = this._index.getInode(path);\n if (inode === null) {\n return cb(ApiError.ENOENT(path));\n }\n if (isFileInode(inode)) {\n const stats = inode.getData();\n switch (flags.pathExistsAction()) {\n case ActionType.THROW_EXCEPTION:\n case ActionType.TRUNCATE_FILE:\n return cb(ApiError.EEXIST(path));\n case ActionType.NOP:\n // Use existing file contents.\n // XXX: Uh, this maintains the previously-used flag.\n if (stats.fileData) {\n return cb(null, new NoSyncFile(self, path, flags, stats.clone(), stats.fileData));\n }\n // @todo be lazier about actually requesting the file\n this._requestFileAsync(path, 'buffer', function(err: ApiError, buffer?: Buffer) {\n if (err) {\n return cb(err);\n }\n // we don't initially have file sizes\n stats.size = buffer!.length;\n stats.fileData = buffer!;\n return cb(null, new NoSyncFile(self, path, flags, stats.clone(), buffer));\n });\n break;\n default:\n return cb(new ApiError(ErrorCode.EINVAL, 'Invalid FileMode object.'));\n }\n } else {\n return cb(ApiError.EISDIR(path));\n }\n }\n\n public openSync(path: string, flags: FileFlag, mode: number): File {\n // INVARIANT: You can't write to files on this file system.\n if (flags.isWriteable()) {\n throw new ApiError(ErrorCode.EPERM, path);\n }\n // Check if the path exists, and is a file.\n const inode = this._index.getInode(path);\n if (inode === null) {\n throw ApiError.ENOENT(path);\n }\n if (isFileInode(inode)) {\n const stats = inode.getData();\n switch (flags.pathExistsAction()) {\n case ActionType.THROW_EXCEPTION:\n case ActionType.TRUNCATE_FILE:\n throw ApiError.EEXIST(path);\n case ActionType.NOP:\n // Use existing file contents.\n // XXX: Uh, this maintains the previously-used flag.\n if (stats.fileData) {\n return new NoSyncFile(this, path, flags, stats.clone(), stats.fileData);\n }\n // @todo be lazier about actually requesting the file\n const buffer = this._requestFileSync(path, 'buffer');\n // we don't initially have file sizes\n stats.size = buffer.length;\n stats.fileData = buffer;\n return new NoSyncFile(this, path, flags, stats.clone(), buffer);\n default:\n throw new ApiError(ErrorCode.EINVAL, 'Invalid FileMode object.');\n }\n } else {\n throw ApiError.EISDIR(path);\n }\n }\n\n public readdir(path: string, cb: BFSCallback): void {\n try {\n cb(null, this.readdirSync(path));\n } catch (e) {\n cb(e);\n }\n }\n\n public readdirSync(path: string): string[] {\n // Check if it exists.\n const inode = this._index.getInode(path);\n if (inode === null) {\n throw ApiError.ENOENT(path);\n } else if (isDirInode(inode)) {\n return inode.getListing();\n } else {\n throw ApiError.ENOTDIR(path);\n }\n }\n\n /**\n * We have the entire file as a buffer; optimize readFile.\n */\n public readFile(fname: string, encoding: string, flag: FileFlag, cb: BFSCallback): void {\n // Wrap cb in file closing code.\n const oldCb = cb;\n // Get file.\n this.open(fname, flag, 0x1a4, function(err: ApiError, fd?: File) {\n if (err) {\n return cb(err);\n }\n cb = function(err: ApiError, arg?: Buffer) {\n fd!.close(function(err2: any) {\n if (!err) {\n err = err2;\n }\n return oldCb(err, arg);\n });\n };\n const fdCast = > fd;\n const fdBuff = fdCast.getBuffer();\n if (encoding === null) {\n cb(err, copyingSlice(fdBuff));\n } else {\n tryToString(fdBuff, encoding, cb);\n }\n });\n }\n\n /**\n * Specially-optimized readfile.\n */\n public readFileSync(fname: string, encoding: string, flag: FileFlag): any {\n // Get file.\n const fd = this.openSync(fname, flag, 0x1a4);\n try {\n const fdCast = > fd;\n const fdBuff = fdCast.getBuffer();\n if (encoding === null) {\n return copyingSlice(fdBuff);\n }\n return fdBuff.toString(encoding);\n } finally {\n fd.closeSync();\n }\n }\n\n private getXhrPath(filePath: string): string {\n if (filePath.charAt(0) === '/') {\n filePath = filePath.slice(1);\n }\n return this.prefixUrl + filePath;\n }\n\n /**\n * Asynchronously download the given file.\n */\n private _requestFileAsync(p: string, type: 'buffer', cb: BFSCallback): void;\n private _requestFileAsync(p: string, type: 'json', cb: BFSCallback): void;\n private _requestFileAsync(p: string, type: string, cb: BFSCallback): void;\n private _requestFileAsync(p: string, type: string, cb: BFSCallback): void {\n asyncDownloadFile(this.getXhrPath(p), type, cb);\n }\n\n /**\n * Synchronously download the given file.\n */\n private _requestFileSync(p: string, type: 'buffer'): Buffer;\n private _requestFileSync(p: string, type: 'json'): any;\n private _requestFileSync(p: string, type: string): any;\n private _requestFileSync(p: string, type: string): any {\n return syncDownloadFile(this.getXhrPath(p), type);\n }\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../src/backend/XmlHttpRequest.ts","/**\n * Zip file-backed filesystem\n * Implemented according to the standard:\n * http://www.pkware.com/documents/casestudies/APPNOTE.TXT\n *\n * While there are a few zip libraries for JavaScript (e.g. JSZip and zip.js),\n * they are not a good match for BrowserFS. In particular, these libraries\n * perform a lot of unneeded data copying, and eagerly decompress every file\n * in the zip file upon loading to check the CRC32. They also eagerly decode\n * strings. Furthermore, these libraries duplicate functionality already present\n * in BrowserFS (e.g. UTF-8 decoding and binary data manipulation).\n *\n * This filesystem takes advantage of BrowserFS's Buffer implementation, which\n * efficiently represents the zip file in memory (in both ArrayBuffer-enabled\n * browsers *and* non-ArrayBuffer browsers), and which can neatly be 'sliced'\n * without copying data. Each struct defined in the standard is represented with\n * a buffer slice pointing to an offset in the zip file, and has getters for\n * each field. As we anticipate that this data will not be read often, we choose\n * not to store each struct field in the JavaScript object; instead, to reduce\n * memory consumption, we retrieve it directly from the binary data each time it\n * is requested.\n *\n * When the filesystem is instantiated, we determine the directory structure\n * of the zip file as quickly as possible. We lazily decompress and check the\n * CRC32 of files. We do not cache decompressed files; if this is a desired\n * feature, it is best implemented as a generic file system wrapper that can\n * cache data from arbitrary file systems.\n *\n * For inflation, we use `pako`'s implementation:\n * https://github.com/nodeca/pako\n *\n * Current limitations:\n * * No encryption.\n * * No ZIP64 support.\n * * Read-only.\n * Write support would require that we:\n * - Keep track of changed/new files.\n * - Compress changed files, and generate appropriate metadata for each.\n * - Update file offsets for other files in the zip file.\n * - Stream it out to a location.\n * This isn't that bad, so we might do this at a later date.\n */\nimport {ApiError, ErrorCode} from '../core/api_error';\nimport {default as Stats, FileType} from '../core/node_fs_stats';\nimport {SynchronousFileSystem, FileSystem} from '../core/file_system';\nimport {File} from '../core/file';\nimport {FileFlag, ActionType} from '../core/file_flag';\nimport {NoSyncFile} from '../generic/preload_file';\nimport {Arrayish, arrayish2Buffer, copyingSlice} from '../core/util';\nimport ExtendedASCII from '../generic/extended_ascii';\nconst inflateRaw:\n (data: Arrayish, options?: {\n chunkSize: number;\n }) => Arrayish = require('pako/lib/inflate').inflateRaw;\nimport {FileIndex, DirInode, FileInode, isDirInode, isFileInode} from '../generic/file_index';\n\n/**\n * Maps CompressionMethod => function that decompresses.\n */\nconst decompressionMethods: {[method: number]: (data: Buffer, compressedSize: number, uncompressedSize: number, flags: number) => Buffer} = {};\n\n/**\n * 4.4.2.2: Indicates the compatibiltiy of a file's external attributes.\n */\nexport enum ExternalFileAttributeType {\n MSDOS = 0, AMIGA = 1, OPENVMS = 2, UNIX = 3, VM_CMS = 4, ATARI_ST = 5,\n OS2_HPFS = 6, MAC = 7, Z_SYSTEM = 8, CP_M = 9, NTFS = 10, MVS = 11, VSE = 12,\n ACORN_RISC = 13, VFAT = 14, ALT_MVS = 15, BEOS = 16, TANDEM = 17, OS_400 = 18,\n OSX = 19\n}\n\n/**\n * 4.4.5\n */\nexport enum CompressionMethod {\n STORED = 0, // The file is stored (no compression)\n SHRUNK = 1, // The file is Shrunk\n REDUCED_1 = 2, // The file is Reduced with compression factor 1\n REDUCED_2 = 3, // The file is Reduced with compression factor 2\n REDUCED_3 = 4, // The file is Reduced with compression factor 3\n REDUCED_4 = 5, // The file is Reduced with compression factor 4\n IMPLODE = 6, // The file is Imploded\n DEFLATE = 8, // The file is Deflated\n DEFLATE64 = 9, // Enhanced Deflating using Deflate64(tm)\n TERSE_OLD = 10, // PKWARE Data Compression Library Imploding (old IBM TERSE)\n BZIP2 = 12, // File is compressed using BZIP2 algorithm\n LZMA = 14, // LZMA (EFS)\n TERSE_NEW = 18, // File is compressed using IBM TERSE (new)\n LZ77 = 19, // IBM LZ77 z Architecture (PFS)\n WAVPACK = 97, // WavPack compressed data\n PPMD = 98 // PPMd version I, Rev 1\n}\n\n/**\n * Converts the input time and date in MS-DOS format into a JavaScript Date\n * object.\n */\nfunction msdos2date(time: number, date: number): Date {\n // MS-DOS Date\n // |0 0 0 0 0|0 0 0 0|0 0 0 0 0 0 0\n // D (1-31) M (1-23) Y (from 1980)\n const day = date & 0x1F;\n // JS date is 0-indexed, DOS is 1-indexed.\n const month = ((date >> 5) & 0xF) - 1;\n const year = (date >> 9) + 1980;\n // MS DOS Time\n // |0 0 0 0 0|0 0 0 0 0 0|0 0 0 0 0\n // Second Minute Hour\n const second = time & 0x1F;\n const minute = (time >> 5) & 0x3F;\n const hour = time >> 11;\n return new Date(year, month, day, hour, minute, second);\n}\n\n/**\n * Safely returns the string from the buffer, even if it is 0 bytes long.\n * (Normally, calling toString() on a buffer with start === end causes an\n * exception).\n */\nfunction safeToString(buff: Buffer, useUTF8: boolean, start: number, length: number): string {\n if (length === 0) {\n return \"\";\n } else if (useUTF8) {\n return buff.toString('utf8', start, start + length);\n } else {\n return ExtendedASCII.byte2str(buff.slice(start, start + length));\n }\n}\n\n/*\n 4.3.6 Overall .ZIP file format:\n\n [local file header 1]\n [encryption header 1]\n [file data 1]\n [data descriptor 1]\n .\n .\n .\n [local file header n]\n [encryption header n]\n [file data n]\n [data descriptor n]\n [archive decryption header]\n [archive extra data record]\n [central directory header 1]\n .\n .\n .\n [central directory header n]\n [zip64 end of central directory record]\n [zip64 end of central directory locator]\n [end of central directory record]\n*/\n\n/*\n 4.3.7 Local file header:\n\n local file header signature 4 bytes (0x04034b50)\n version needed to extract 2 bytes\n general purpose bit flag 2 bytes\n compression method 2 bytes\n last mod file time 2 bytes\n last mod file date 2 bytes\n crc-32 4 bytes\n compressed size 4 bytes\n uncompressed size 4 bytes\n file name length 2 bytes\n extra field length 2 bytes\n\n file name (variable size)\n extra field (variable size)\n */\nexport class FileHeader {\n constructor(private data: Buffer) {\n if (data.readUInt32LE(0) !== 0x04034b50) {\n throw new ApiError(ErrorCode.EINVAL, \"Invalid Zip file: Local file header has invalid signature: \" + this.data.readUInt32LE(0));\n }\n }\n public versionNeeded(): number { return this.data.readUInt16LE(4); }\n public flags(): number { return this.data.readUInt16LE(6); }\n public compressionMethod(): CompressionMethod { return this.data.readUInt16LE(8); }\n public lastModFileTime(): Date {\n // Time and date is in MS-DOS format.\n return msdos2date(this.data.readUInt16LE(10), this.data.readUInt16LE(12));\n }\n public rawLastModFileTime(): number {\n return this.data.readUInt32LE(10);\n }\n public crc32(): number { return this.data.readUInt32LE(14); }\n /**\n * These two values are COMPLETELY USELESS.\n *\n * Section 4.4.9:\n * If bit 3 of the general purpose bit flag is set,\n * these fields are set to zero in the local header and the\n * correct values are put in the data descriptor and\n * in the central directory.\n *\n * So we'll just use the central directory's values.\n */\n // public compressedSize(): number { return this.data.readUInt32LE(18); }\n // public uncompressedSize(): number { return this.data.readUInt32LE(22); }\n public fileNameLength(): number { return this.data.readUInt16LE(26); }\n public extraFieldLength(): number { return this.data.readUInt16LE(28); }\n public fileName(): string {\n return safeToString(this.data, this.useUTF8(), 30, this.fileNameLength());\n }\n public extraField(): Buffer {\n const start = 30 + this.fileNameLength();\n return this.data.slice(start, start + this.extraFieldLength());\n }\n public totalSize(): number { return 30 + this.fileNameLength() + this.extraFieldLength(); }\n public useUTF8(): boolean { return (this.flags() & 0x800) === 0x800; }\n}\n\n/**\n * 4.3.8 File data\n *\n * Immediately following the local header for a file\n * SHOULD be placed the compressed or stored data for the file.\n * If the file is encrypted, the encryption header for the file\n * SHOULD be placed after the local header and before the file\n * data. The series of [local file header][encryption header]\n * [file data][data descriptor] repeats for each file in the\n * .ZIP archive.\n *\n * Zero-byte files, directories, and other file types that\n * contain no content MUST not include file data.\n */\nexport class FileData {\n constructor(private header: FileHeader, private record: CentralDirectory, private data: Buffer) {}\n public decompress(): Buffer {\n // Check the compression\n const compressionMethod: CompressionMethod = this.header.compressionMethod();\n const fcn = decompressionMethods[compressionMethod];\n if (fcn) {\n return fcn(this.data, this.record.compressedSize(), this.record.uncompressedSize(), this.record.flag());\n } else {\n let name: string = CompressionMethod[compressionMethod];\n if (!name) {\n name = `Unknown: ${compressionMethod}`;\n }\n throw new ApiError(ErrorCode.EINVAL, `Invalid compression method on file '${this.header.fileName()}': ${name}`);\n }\n }\n public getHeader(): FileHeader {\n return this.header;\n }\n public getRecord(): CentralDirectory {\n return this.record;\n }\n public getRawData(): Buffer {\n return this.data;\n }\n}\n\n/*\n 4.3.9 Data descriptor:\n\n crc-32 4 bytes\n compressed size 4 bytes\n uncompressed size 4 bytes\n */\nexport class DataDescriptor {\n constructor(private data: Buffer) {}\n public crc32(): number { return this.data.readUInt32LE(0); }\n public compressedSize(): number { return this.data.readUInt32LE(4); }\n public uncompressedSize(): number { return this.data.readUInt32LE(8); }\n}\n\n/*\n` 4.3.10 Archive decryption header:\n\n 4.3.10.1 The Archive Decryption Header is introduced in version 6.2\n of the ZIP format specification. This record exists in support\n of the Central Directory Encryption Feature implemented as part of\n the Strong Encryption Specification as described in this document.\n When the Central Directory Structure is encrypted, this decryption\n header MUST precede the encrypted data segment.\n */\n/*\n 4.3.11 Archive extra data record:\n\n archive extra data signature 4 bytes (0x08064b50)\n extra field length 4 bytes\n extra field data (variable size)\n\n 4.3.11.1 The Archive Extra Data Record is introduced in version 6.2\n of the ZIP format specification. This record MAY be used in support\n of the Central Directory Encryption Feature implemented as part of\n the Strong Encryption Specification as described in this document.\n When present, this record MUST immediately precede the central\n directory data structure.\n*/\nexport class ArchiveExtraDataRecord {\n constructor(private data: Buffer) {\n if (this.data.readUInt32LE(0) !== 0x08064b50) {\n throw new ApiError(ErrorCode.EINVAL, \"Invalid archive extra data record signature: \" + this.data.readUInt32LE(0));\n }\n }\n public length(): number { return this.data.readUInt32LE(4); }\n public extraFieldData(): Buffer { return this.data.slice(8, 8 + this.length()); }\n}\n\n/*\n 4.3.13 Digital signature:\n\n header signature 4 bytes (0x05054b50)\n size of data 2 bytes\n signature data (variable size)\n\n With the introduction of the Central Directory Encryption\n feature in version 6.2 of this specification, the Central\n Directory Structure MAY be stored both compressed and encrypted.\n Although not required, it is assumed when encrypting the\n Central Directory Structure, that it will be compressed\n for greater storage efficiency. Information on the\n Central Directory Encryption feature can be found in the section\n describing the Strong Encryption Specification. The Digital\n Signature record will be neither compressed nor encrypted.\n*/\nexport class DigitalSignature {\n constructor(private data: Buffer) {\n if (this.data.readUInt32LE(0) !== 0x05054b50) {\n throw new ApiError(ErrorCode.EINVAL, \"Invalid digital signature signature: \" + this.data.readUInt32LE(0));\n }\n }\n public size(): number { return this.data.readUInt16LE(4); }\n public signatureData(): Buffer { return this.data.slice(6, 6 + this.size()); }\n}\n\n/*\n 4.3.12 Central directory structure:\n\n central file header signature 4 bytes (0x02014b50)\n version made by 2 bytes\n version needed to extract 2 bytes\n general purpose bit flag 2 bytes\n compression method 2 bytes\n last mod file time 2 bytes\n last mod file date 2 bytes\n crc-32 4 bytes\n compressed size 4 bytes\n uncompressed size 4 bytes\n file name length 2 bytes\n extra field length 2 bytes\n file comment length 2 bytes\n disk number start 2 bytes\n internal file attributes 2 bytes\n external file attributes 4 bytes\n relative offset of local header 4 bytes\n\n file name (variable size)\n extra field (variable size)\n file comment (variable size)\n */\nexport class CentralDirectory {\n // Optimization: The filename is frequently read, so stash it here.\n private _filename: string;\n constructor(private zipData: Buffer, private data: Buffer) {\n // Sanity check.\n if (this.data.readUInt32LE(0) !== 0x02014b50) {\n throw new ApiError(ErrorCode.EINVAL, `Invalid Zip file: Central directory record has invalid signature: ${this.data.readUInt32LE(0)}`);\n }\n this._filename = this.produceFilename();\n }\n public versionMadeBy(): number { return this.data.readUInt16LE(4); }\n public versionNeeded(): number { return this.data.readUInt16LE(6); }\n public flag(): number { return this.data.readUInt16LE(8); }\n public compressionMethod(): CompressionMethod { return this.data.readUInt16LE(10); }\n public lastModFileTime(): Date {\n // Time and date is in MS-DOS format.\n return msdos2date(this.data.readUInt16LE(12), this.data.readUInt16LE(14));\n }\n public rawLastModFileTime(): number {\n return this.data.readUInt32LE(12);\n }\n public crc32(): number { return this.data.readUInt32LE(16); }\n public compressedSize(): number { return this.data.readUInt32LE(20); }\n public uncompressedSize(): number { return this.data.readUInt32LE(24); }\n public fileNameLength(): number { return this.data.readUInt16LE(28); }\n public extraFieldLength(): number { return this.data.readUInt16LE(30); }\n public fileCommentLength(): number { return this.data.readUInt16LE(32); }\n public diskNumberStart(): number { return this.data.readUInt16LE(34); }\n public internalAttributes(): number { return this.data.readUInt16LE(36); }\n public externalAttributes(): number { return this.data.readUInt32LE(38); }\n public headerRelativeOffset(): number { return this.data.readUInt32LE(42); }\n public produceFilename(): string {\n /*\n 4.4.17.1 claims:\n * All slashes are forward ('/') slashes.\n * Filename doesn't begin with a slash.\n * No drive letters or any nonsense like that.\n * If filename is missing, the input came from standard input.\n\n Unfortunately, this isn't true in practice. Some Windows zip utilities use\n a backslash here, but the correct Unix-style path in file headers.\n\n To avoid seeking all over the file to recover the known-good filenames\n from file headers, we simply convert '/' to '\\' here.\n */\n const fileName: string = safeToString(this.data, this.useUTF8(), 46, this.fileNameLength());\n return fileName.replace(/\\\\/g, \"/\");\n }\n public fileName(): string {\n return this._filename;\n }\n public rawFileName(): Buffer {\n return this.data.slice(46, 46 + this.fileNameLength());\n }\n public extraField(): Buffer {\n const start = 44 + this.fileNameLength();\n return this.data.slice(start, start + this.extraFieldLength());\n }\n public fileComment(): string {\n const start = 46 + this.fileNameLength() + this.extraFieldLength();\n return safeToString(this.data, this.useUTF8(), start, this.fileCommentLength());\n }\n public rawFileComment(): Buffer {\n const start = 46 + this.fileNameLength() + this.extraFieldLength();\n return this.data.slice(start, start + this.fileCommentLength());\n }\n public totalSize(): number {\n return 46 + this.fileNameLength() + this.extraFieldLength() + this.fileCommentLength();\n }\n public isDirectory(): boolean {\n // NOTE: This assumes that the zip file implementation uses the lower byte\n // of external attributes for DOS attributes for\n // backwards-compatibility. This is not mandated, but appears to be\n // commonplace.\n // According to the spec, the layout of external attributes is\n // platform-dependent.\n // If that fails, we also check if the name of the file ends in '/',\n // which is what Java's ZipFile implementation does.\n const fileName = this.fileName();\n return (this.externalAttributes() & 0x10 ? true : false) || (fileName.charAt(fileName.length - 1) === '/');\n }\n public isFile(): boolean { return !this.isDirectory(); }\n public useUTF8(): boolean { return (this.flag() & 0x800) === 0x800; }\n public isEncrypted(): boolean { return (this.flag() & 0x1) === 0x1; }\n public getFileData(): FileData {\n // Need to grab the header before we can figure out where the actual\n // compressed data starts.\n const start = this.headerRelativeOffset();\n const header = new FileHeader(this.zipData.slice(start));\n return new FileData(header, this, this.zipData.slice(start + header.totalSize()));\n }\n public getData(): Buffer {\n return this.getFileData().decompress();\n }\n public getRawData(): Buffer {\n return this.getFileData().getRawData();\n }\n public getStats(): Stats {\n return new Stats(FileType.FILE, this.uncompressedSize(), 0x16D, new Date(), this.lastModFileTime());\n }\n}\n\n/*\n 4.3.16: end of central directory record\n end of central dir signature 4 bytes (0x06054b50)\n number of this disk 2 bytes\n number of the disk with the\n start of the central directory 2 bytes\n total number of entries in the\n central directory on this disk 2 bytes\n total number of entries in\n the central directory 2 bytes\n size of the central directory 4 bytes\n offset of start of central\n directory with respect to\n the starting disk number 4 bytes\n .ZIP file comment length 2 bytes\n .ZIP file comment (variable size)\n*/\nexport class EndOfCentralDirectory {\n constructor(private data: Buffer) {\n if (this.data.readUInt32LE(0) !== 0x06054b50) {\n throw new ApiError(ErrorCode.EINVAL, `Invalid Zip file: End of central directory record has invalid signature: ${this.data.readUInt32LE(0)}`);\n }\n }\n public diskNumber(): number { return this.data.readUInt16LE(4); }\n public cdDiskNumber(): number { return this.data.readUInt16LE(6); }\n public cdDiskEntryCount(): number { return this.data.readUInt16LE(8); }\n public cdTotalEntryCount(): number { return this.data.readUInt16LE(10); }\n public cdSize(): number { return this.data.readUInt32LE(12); }\n public cdOffset(): number { return this.data.readUInt32LE(16); }\n public cdZipCommentLength(): number { return this.data.readUInt16LE(20); }\n public cdZipComment(): string {\n // Assuming UTF-8. The specification doesn't specify.\n return safeToString(this.data, true, 22, this.cdZipCommentLength());\n }\n public rawCdZipComment(): Buffer {\n return this.data.slice(22, 22 + this.cdZipCommentLength());\n }\n}\n\nexport class ZipTOC {\n constructor(public index: FileIndex, public directoryEntries: CentralDirectory[], public eocd: EndOfCentralDirectory, public data: Buffer) {\n }\n}\n\nexport default class ZipFS extends SynchronousFileSystem implements FileSystem {\n /* tslint:disable:variable-name */\n public static readonly CompressionMethod = CompressionMethod;\n /* tslint:enable:variable-name */\n\n public static isAvailable(): boolean { return true; }\n\n public static RegisterDecompressionMethod(m: CompressionMethod, fcn: (data: Buffer, compressedSize: number, uncompressedSize: number, flags: number) => Buffer): void {\n decompressionMethods[m] = fcn;\n }\n\n public static computeIndex(data: Buffer, cb: (zipTOC: ZipTOC) => void) {\n const index: FileIndex = new FileIndex();\n const eocd: EndOfCentralDirectory = ZipFS.getEOCD(data);\n if (eocd.diskNumber() !== eocd.cdDiskNumber()) {\n throw new ApiError(ErrorCode.EINVAL, \"ZipFS does not support spanned zip files.\");\n }\n\n const cdPtr = eocd.cdOffset();\n if (cdPtr === 0xFFFFFFFF) {\n throw new ApiError(ErrorCode.EINVAL, \"ZipFS does not support Zip64.\");\n }\n const cdEnd = cdPtr + eocd.cdSize();\n ZipFS.computeIndexResponsive(data, index, cdPtr, cdEnd, cb, [], eocd);\n }\n\n /**\n * Locates the end of central directory record at the end of the file.\n * Throws an exception if it cannot be found.\n */\n private static getEOCD(data: Buffer): EndOfCentralDirectory {\n // Unfortunately, the comment is variable size and up to 64K in size.\n // We assume that the magic signature does not appear in the comment, and\n // in the bytes between the comment and the signature. Other ZIP\n // implementations make this same assumption, since the alternative is to\n // read thread every entry in the file to get to it. :(\n // These are *negative* offsets from the end of the file.\n const startOffset = 22;\n const endOffset = Math.min(startOffset + 0xFFFF, data.length - 1);\n // There's not even a byte alignment guarantee on the comment so we need to\n // search byte by byte. *grumble grumble*\n for (let i = startOffset; i < endOffset; i++) {\n // Magic number: EOCD Signature\n if (data.readUInt32LE(data.length - i) === 0x06054b50) {\n return new EndOfCentralDirectory(data.slice(data.length - i));\n }\n }\n throw new ApiError(ErrorCode.EINVAL, \"Invalid ZIP file: Could not locate End of Central Directory signature.\");\n }\n\n private static addToIndex(cd: CentralDirectory, index: FileIndex) {\n // Paths must be absolute, yet zip file paths are always relative to the\n // zip root. So we append '/' and call it a day.\n let filename = cd.fileName();\n if (filename.charAt(0) === '/') {\n throw new Error(\"WHY IS THIS ABSOLUTE\");\n }\n // XXX: For the file index, strip the trailing '/'.\n if (filename.charAt(filename.length - 1) === '/') {\n filename = filename.substr(0, filename.length - 1);\n }\n\n if (cd.isDirectory()) {\n index.addPathFast('/' + filename, new DirInode(cd));\n } else {\n index.addPathFast('/' + filename, new FileInode(cd));\n }\n }\n\n private static computeIndexResponsive(data: Buffer, index: FileIndex, cdPtr: number, cdEnd: number, cb: (zipTOC: ZipTOC) => void, cdEntries: CentralDirectory[], eocd: EndOfCentralDirectory) {\n if (cdPtr < cdEnd) {\n let count = 0;\n while (count++ < 200 && cdPtr < cdEnd) {\n const cd: CentralDirectory = new CentralDirectory(data, data.slice(cdPtr));\n ZipFS.addToIndex(cd, index);\n cdPtr += cd.totalSize();\n cdEntries.push(cd);\n }\n setImmediate(() => {\n ZipFS.computeIndexResponsive(data, index, cdPtr, cdEnd, cb, cdEntries, eocd);\n });\n } else {\n cb(new ZipTOC(index, cdEntries, eocd, data));\n }\n }\n\n private _index: FileIndex = new FileIndex();\n private _directoryEntries: CentralDirectory[] = [];\n private _eocd: EndOfCentralDirectory | null = null;\n private data: Buffer;\n\n /**\n * Constructs a ZipFS from the given zip file data. Name is optional, and is\n * used primarily for our unit tests' purposes to differentiate different\n * test zip files in test output.\n */\n constructor(input: Buffer | ZipTOC, private name: string = '') {\n super();\n if (input instanceof ZipTOC) {\n this._index = input.index;\n this._directoryEntries = input.directoryEntries;\n this._eocd = input.eocd;\n this.data = input.data;\n } else {\n this.data = input as Buffer;\n this.populateIndex();\n }\n }\n\n public getName(): string {\n return 'ZipFS' + (this.name !== '' ? ' ' + this.name : '');\n }\n\n /**\n * Get the CentralDirectory object for the given path.\n */\n public getCentralDirectoryEntry(path: string): CentralDirectory {\n const inode = this._index.getInode(path);\n if (inode === null) {\n throw ApiError.ENOENT(path);\n }\n if (isFileInode(inode)) {\n return inode.getData();\n } else if (isDirInode(inode)) {\n return inode.getData()!;\n } else {\n // Should never occur.\n throw ApiError.EPERM(`Invalid inode: ${inode}`);\n }\n }\n\n public getCentralDirectoryEntryAt(index: number): CentralDirectory {\n const dirEntry = this._directoryEntries[index];\n if (!dirEntry) {\n throw new RangeError(`Invalid directory index: ${index}.`);\n }\n return dirEntry;\n }\n\n public getNumberOfCentralDirectoryEntries(): number {\n return this._directoryEntries.length;\n }\n\n public getEndOfCentralDirectory(): EndOfCentralDirectory | null {\n return this._eocd;\n }\n\n public diskSpace(path: string, cb: (total: number, free: number) => void): void {\n // Read-only file system.\n cb(this.data.length, 0);\n }\n\n public isReadOnly(): boolean {\n return true;\n }\n\n public supportsLinks(): boolean {\n return false;\n }\n\n public supportsProps(): boolean {\n return false;\n }\n\n public supportsSynch(): boolean {\n return true;\n }\n\n public statSync(path: string, isLstat: boolean): Stats {\n const inode = this._index.getInode(path);\n if (inode === null) {\n throw ApiError.ENOENT(path);\n }\n let stats: Stats;\n if (isFileInode(inode)) {\n stats = inode.getData().getStats();\n } else if (isDirInode(inode)) {\n stats = inode.getStats();\n } else {\n throw new ApiError(ErrorCode.EINVAL, \"Invalid inode.\");\n }\n return stats;\n }\n\n public openSync(path: string, flags: FileFlag, mode: number): File {\n // INVARIANT: Cannot write to RO file systems.\n if (flags.isWriteable()) {\n throw new ApiError(ErrorCode.EPERM, path);\n }\n // Check if the path exists, and is a file.\n const inode = this._index.getInode(path);\n if (!inode) {\n throw ApiError.ENOENT(path);\n } else if (isFileInode(inode)) {\n const cdRecord = inode.getData();\n const stats = cdRecord.getStats();\n switch (flags.pathExistsAction()) {\n case ActionType.THROW_EXCEPTION:\n case ActionType.TRUNCATE_FILE:\n throw ApiError.EEXIST(path);\n case ActionType.NOP:\n return new NoSyncFile(this, path, flags, stats, cdRecord.getData());\n default:\n throw new ApiError(ErrorCode.EINVAL, 'Invalid FileMode object.');\n }\n } else {\n throw ApiError.EISDIR(path);\n }\n }\n\n public readdirSync(path: string): string[] {\n // Check if it exists.\n const inode = this._index.getInode(path);\n if (!inode) {\n throw ApiError.ENOENT(path);\n } else if (isDirInode(inode)) {\n return inode.getListing();\n } else {\n throw ApiError.ENOTDIR(path);\n }\n }\n\n /**\n * Specially-optimized readfile.\n */\n public readFileSync(fname: string, encoding: string, flag: FileFlag): any {\n // Get file.\n const fd = this.openSync(fname, flag, 0x1a4);\n try {\n const fdCast = > fd;\n const fdBuff = fdCast.getBuffer();\n if (encoding === null) {\n return copyingSlice(fdBuff);\n }\n return fdBuff.toString(encoding);\n } finally {\n fd.closeSync();\n }\n }\n\n private populateIndex() {\n const eocd: EndOfCentralDirectory = this._eocd = ZipFS.getEOCD(this.data);\n if (eocd.diskNumber() !== eocd.cdDiskNumber()) {\n throw new ApiError(ErrorCode.EINVAL, \"ZipFS does not support spanned zip files.\");\n }\n\n let cdPtr = eocd.cdOffset();\n if (cdPtr === 0xFFFFFFFF) {\n throw new ApiError(ErrorCode.EINVAL, \"ZipFS does not support Zip64.\");\n }\n const cdEnd = cdPtr + eocd.cdSize();\n while (cdPtr < cdEnd) {\n const cd: CentralDirectory = new CentralDirectory(this.data, this.data.slice(cdPtr));\n cdPtr += cd.totalSize();\n ZipFS.addToIndex(cd, this._index);\n this._directoryEntries.push(cd);\n }\n }\n}\n\nZipFS.RegisterDecompressionMethod(CompressionMethod.DEFLATE, (data, compressedSize, uncompressedSize) => {\n return arrayish2Buffer(inflateRaw(\n data.slice(0, compressedSize),\n { chunkSize: uncompressedSize }\n ));\n});\n\nZipFS.RegisterDecompressionMethod(CompressionMethod.STORED, (data, compressedSize, uncompressedSize) => {\n return copyingSlice(data, 0, uncompressedSize);\n});\n\n\n\n// WEBPACK FOOTER //\n// ../../../../src/backend/ZipFS.ts","import {ApiError, ErrorCode} from '../core/api_error';\nimport {default as Stats, FileType} from '../core/node_fs_stats';\nimport {SynchronousFileSystem, FileSystem} from '../core/file_system';\nimport {File} from '../core/file';\nimport {FileFlag, ActionType} from '../core/file_flag';\nimport {NoSyncFile} from '../generic/preload_file';\nimport {copyingSlice} from '../core/util';\nimport * as path from 'path';\n\nconst rockRidgeIdentifier = \"IEEE_P1282\";\nconst enum VolumeDescriptorTypeCode {\n BootRecord = 0,\n PrimaryVolumeDescriptor = 1,\n SupplementaryVolumeDescriptor = 2,\n VolumePartitionDescriptor = 3,\n VolumeDescriptorSetTerminator = 255\n}\n\ntype TGetString = (d: Buffer, i: number, len: number) => string;\n\nfunction getASCIIString(data: Buffer, startIndex: number, length: number) {\n return data.toString('ascii', startIndex, startIndex + length).trim();\n}\n\nfunction getJolietString(data: Buffer, startIndex: number, length: number): string {\n if (length === 1) {\n // Special: Root, parent, current directory are still a single byte.\n return String.fromCharCode(data[startIndex]);\n }\n // UTF16-BE, which isn't natively supported by NodeJS Buffers.\n // Length should be even, but pessimistically floor just in case.\n const pairs = Math.floor(length / 2);\n const chars = new Array(pairs);\n for (let i = 0; i < pairs; i++) {\n const pos = startIndex + (i << 1);\n chars[i] = String.fromCharCode(data[pos + 1] | (data[pos] << 8));\n }\n return chars.join('');\n}\n\nfunction getDate(data: Buffer, startIndex: number): Date {\n const year = parseInt(getASCIIString(data, startIndex, 4), 10);\n const mon = parseInt(getASCIIString(data, startIndex + 4, 2), 10);\n const day = parseInt(getASCIIString(data, startIndex + 6, 2), 10);\n const hour = parseInt(getASCIIString(data, startIndex + 8, 2), 10);\n const min = parseInt(getASCIIString(data, startIndex + 10, 2), 10);\n const sec = parseInt(getASCIIString(data, startIndex + 12, 2), 10);\n const hundrethsSec = parseInt(getASCIIString(data, startIndex + 14, 2), 10);\n // Last is a time-zone offset, but JavaScript dates don't support time zones well.\n return new Date(year, mon, day, hour, min, sec, hundrethsSec * 100);\n}\n\nfunction getShortFormDate(data: Buffer, startIndex: number): Date {\n const yearsSince1900 = data[startIndex];\n const month = data[startIndex + 1];\n const day = data[startIndex + 2];\n const hour = data[startIndex + 3];\n const minute = data[startIndex + 4];\n const second = data[startIndex + 5];\n // JavaScript's Date support isn't so great; ignore timezone.\n // const offsetFromGMT = this._data[24];\n return new Date(yearsSince1900, month - 1, day, hour, minute, second);\n}\n\nfunction constructSystemUseEntry(bigData: Buffer, i: number): SystemUseEntry {\n const data = bigData.slice(i);\n const sue = new SystemUseEntry(data);\n switch (sue.signatureWord()) {\n case SystemUseEntrySignatures.CE:\n return new CEEntry(data);\n case SystemUseEntrySignatures.PD:\n return new PDEntry(data);\n case SystemUseEntrySignatures.SP:\n return new SPEntry(data);\n case SystemUseEntrySignatures.ST:\n return new STEntry(data);\n case SystemUseEntrySignatures.ER:\n return new EREntry(data);\n case SystemUseEntrySignatures.ES:\n return new ESEntry(data);\n case SystemUseEntrySignatures.PX:\n return new PXEntry(data);\n case SystemUseEntrySignatures.PN:\n return new PNEntry(data);\n case SystemUseEntrySignatures.SL:\n return new SLEntry(data);\n case SystemUseEntrySignatures.NM:\n return new NMEntry(data);\n case SystemUseEntrySignatures.CL:\n return new CLEntry(data);\n case SystemUseEntrySignatures.PL:\n return new PLEntry(data);\n case SystemUseEntrySignatures.RE:\n return new REEntry(data);\n case SystemUseEntrySignatures.TF:\n return new TFEntry(data);\n case SystemUseEntrySignatures.SF:\n return new SFEntry(data);\n case SystemUseEntrySignatures.RR:\n return new RREntry(data);\n default:\n return sue;\n }\n}\n\nfunction constructSystemUseEntries(data: Buffer, i: number, len: number, isoData: Buffer): SystemUseEntry[] {\n // If the remaining allocated space following the last recorded System Use Entry in a System\n // Use field or Continuation Area is less than four bytes long, it cannot contain a System\n // Use Entry and shall be ignored\n len = len - 4;\n let entries = new Array();\n while (i < len) {\n const entry = constructSystemUseEntry(data, i);\n const length = entry.length();\n if (length === 0) {\n // Invalid SU section; prevent infinite loop.\n return entries;\n }\n i += length;\n if (entry instanceof STEntry) {\n // ST indicates the end of entries.\n break;\n }\n if (entry instanceof CEEntry) {\n entries = entries.concat(entry.getEntries(isoData));\n } else {\n entries.push(entry);\n }\n }\n return entries;\n}\n\nclass VolumeDescriptor {\n protected _data: Buffer;\n constructor(data: Buffer) {\n this._data = data;\n }\n public type(): VolumeDescriptorTypeCode {\n return this._data[0];\n }\n public standardIdentifier(): string {\n return getASCIIString(this._data, 1, 5);\n }\n public version(): number {\n return this._data[6];\n }\n public data(): Buffer {\n return this._data.slice(7, 2048);\n }\n}\n\nabstract class PrimaryOrSupplementaryVolumeDescriptor extends VolumeDescriptor {\n private _root: DirectoryRecord | null = null;\n constructor(data: Buffer) {\n super(data);\n }\n public systemIdentifier(): string {\n return this._getString32(8);\n }\n public volumeIdentifier(): string {\n return this._getString32(40);\n }\n public volumeSpaceSize(): number {\n return this._data.readUInt32LE(80);\n }\n public volumeSetSize(): number {\n return this._data.readUInt16LE(120);\n }\n public volumeSequenceNumber(): number {\n return this._data.readUInt16LE(124);\n }\n public logicalBlockSize(): number {\n return this._data.readUInt16LE(128);\n }\n public pathTableSize(): number {\n return this._data.readUInt32LE(132);\n }\n public locationOfTypeLPathTable(): number {\n return this._data.readUInt32LE(140);\n }\n public locationOfOptionalTypeLPathTable(): number {\n return this._data.readUInt32LE(144);\n }\n public locationOfTypeMPathTable(): number {\n return this._data.readUInt32BE(148);\n }\n public locationOfOptionalTypeMPathTable(): number {\n return this._data.readUInt32BE(152);\n }\n public rootDirectoryEntry(isoData: Buffer): DirectoryRecord {\n if (this._root === null) {\n this._root = this._constructRootDirectoryRecord(this._data.slice(156));\n this._root.rootCheckForRockRidge(isoData);\n }\n return this._root;\n }\n public volumeSetIdentifier(): string {\n return this._getString(190, 128);\n }\n public publisherIdentifier(): string {\n return this._getString(318, 128);\n }\n public dataPreparerIdentifier(): string {\n return this._getString(446, 128);\n }\n public applicationIdentifier(): string {\n return this._getString(574, 128);\n }\n public copyrightFileIdentifier(): string {\n return this._getString(702, 38);\n }\n public abstractFileIdentifier(): string {\n return this._getString(740, 36);\n }\n public bibliographicFileIdentifier(): string {\n return this._getString(776, 37);\n }\n public volumeCreationDate(): Date {\n return getDate(this._data, 813);\n }\n public volumeModificationDate(): Date {\n return getDate(this._data, 830);\n }\n public volumeExpirationDate(): Date {\n return getDate(this._data, 847);\n }\n public volumeEffectiveDate(): Date {\n return getDate(this._data, 864);\n }\n public fileStructureVersion(): number {\n return this._data[881];\n }\n public applicationUsed(): Buffer {\n return this._data.slice(883, 883 + 512);\n }\n public reserved(): Buffer {\n return this._data.slice(1395, 1395 + 653);\n }\n public abstract name(): string;\n protected abstract _constructRootDirectoryRecord(data: Buffer): DirectoryRecord;\n protected abstract _getString(idx: number, len: number): string;\n protected _getString32(idx: number): string {\n return this._getString(idx, 32);\n }\n}\n\nclass PrimaryVolumeDescriptor extends PrimaryOrSupplementaryVolumeDescriptor {\n constructor(data: Buffer) {\n super(data);\n if (this.type() !== VolumeDescriptorTypeCode.PrimaryVolumeDescriptor) {\n throw new ApiError(ErrorCode.EIO, `Invalid primary volume descriptor.`);\n }\n }\n public name() {\n return \"ISO9660\";\n }\n protected _constructRootDirectoryRecord(data: Buffer): DirectoryRecord {\n return new ISODirectoryRecord(data, -1);\n }\n protected _getString(idx: number, len: number): string {\n return this._getString(idx, len);\n }\n}\n\nclass SupplementaryVolumeDescriptor extends PrimaryOrSupplementaryVolumeDescriptor {\n constructor(data: Buffer) {\n super(data);\n if (this.type() !== VolumeDescriptorTypeCode.SupplementaryVolumeDescriptor) {\n throw new ApiError(ErrorCode.EIO, `Invalid supplementary volume descriptor.`);\n }\n const escapeSequence = this.escapeSequence();\n const third = escapeSequence[2];\n // Third character identifies what 'level' of the UCS specification to follow.\n // We ignore it.\n if (escapeSequence[0] !== 0x25 || escapeSequence[1] !== 0x2F ||\n (third !== 0x40 && third !== 0x43 && third !== 0x45)) {\n throw new ApiError(ErrorCode.EIO, `Unrecognized escape sequence for SupplementaryVolumeDescriptor: ${escapeSequence.toString()}`);\n }\n }\n public name() {\n return \"Joliet\";\n }\n public escapeSequence(): Buffer {\n return this._data.slice(88, 120);\n }\n protected _constructRootDirectoryRecord(data: Buffer): DirectoryRecord {\n return new JolietDirectoryRecord(data, -1);\n }\n protected _getString(idx: number, len: number): string {\n return getJolietString(this._data, idx, len);\n }\n}\n\nconst enum FileFlags {\n Hidden = 1,\n Directory = 1 << 1,\n AssociatedFile = 1 << 2,\n EARContainsInfo = 1 << 3,\n EARContainsPerms = 1 << 4,\n FinalDirectoryRecordForFile = 1 << 5\n}\n\nabstract class DirectoryRecord {\n protected _data: Buffer;\n // Offset at which system use entries begin. Set to -1 if not enabled.\n protected _rockRidgeOffset: number;\n protected _suEntries: SystemUseEntry[] | null = null;\n private _fileOrDir: Buffer | Directory | null = null;\n constructor(data: Buffer, rockRidgeOffset: number) {\n this._data = data;\n this._rockRidgeOffset = rockRidgeOffset;\n }\n public hasRockRidge(): boolean {\n return this._rockRidgeOffset > -1;\n }\n public getRockRidgeOffset(): number {\n return this._rockRidgeOffset;\n }\n /**\n * !!ONLY VALID ON ROOT NODE!!\n * Checks if Rock Ridge is enabled, and sets the offset.\n */\n public rootCheckForRockRidge(isoData: Buffer): void {\n const dir = this.getDirectory(isoData);\n this._rockRidgeOffset = dir.getDotEntry(isoData)._getRockRidgeOffset(isoData);\n if (this._rockRidgeOffset > -1) {\n // Wipe out directory. Start over with RR knowledge.\n this._fileOrDir = null;\n }\n }\n public length(): number {\n return this._data[0];\n }\n public extendedAttributeRecordLength(): number {\n return this._data[1];\n }\n public lba(): number {\n return this._data.readUInt32LE(2) * 2048;\n }\n public dataLength(): number {\n return this._data.readUInt32LE(10);\n }\n public recordingDate(): Date {\n return getShortFormDate(this._data, 18);\n }\n public fileFlags(): number {\n return this._data[25];\n }\n public fileUnitSize(): number {\n return this._data[26];\n }\n public interleaveGapSize(): number {\n return this._data[27];\n }\n public volumeSequenceNumber(): number {\n return this._data.readUInt16LE(28);\n }\n public identifier(): string {\n return this._getString(33, this._data[32]);\n }\n public fileName(isoData: Buffer): string {\n if (this.hasRockRidge()) {\n const fn = this._rockRidgeFilename(isoData);\n if (fn !== null) {\n return fn;\n }\n }\n const ident = this.identifier();\n if (this.isDirectory(isoData)) {\n return ident;\n }\n // Files:\n // - MUST have 0x2E (.) separating the name from the extension\n // - MUST have 0x3B (;) separating the file name and extension from the version\n // Gets expanded to two-byte char in Unicode directory records.\n const versionSeparator = ident.indexOf(';');\n if (versionSeparator === -1) {\n // Some Joliet filenames lack the version separator, despite the standard\n // specifying that it should be there.\n return ident;\n } else if (ident[versionSeparator - 1] === '.') {\n // Empty extension. Do not include '.' in the filename.\n return ident.slice(0, versionSeparator - 1);\n } else {\n // Include up to version separator.\n return ident.slice(0, versionSeparator);\n }\n }\n public isDirectory(isoData: Buffer): boolean {\n let rv = !!(this.fileFlags() & FileFlags.Directory);\n // If it lacks the Directory flag, it may still be a directory if we've exceeded the directory\n // depth limit. Rock Ridge marks these as files and adds a special attribute.\n if (!rv && this.hasRockRidge()) {\n rv = this.getSUEntries(isoData).filter((e) => e instanceof CLEntry).length > 0;\n }\n return rv;\n }\n public isSymlink(isoData: Buffer): boolean {\n return this.hasRockRidge() && this.getSUEntries(isoData).filter((e) => e instanceof SLEntry).length > 0;\n }\n public getSymlinkPath(isoData: Buffer): string {\n let p = \"\";\n const entries = this.getSUEntries(isoData);\n const getStr = this._getGetString();\n for (let i = 0; i < entries.length; i++) {\n const entry = entries[i];\n if (entry instanceof SLEntry) {\n const components = entry.componentRecords();\n for (let j = 0; j < components.length; j++) {\n const component = components[j];\n const flags = component.flags();\n if (flags & SLComponentFlags.CURRENT) {\n p += \"./\";\n } else if (flags & SLComponentFlags.PARENT) {\n p += \"../\";\n } else if (flags & SLComponentFlags.ROOT) {\n p += \"/\";\n } else {\n p += component.content(getStr);\n if (!(flags & SLComponentFlags.CONTINUE)) {\n p += '/';\n }\n }\n }\n if (!entry.continueFlag()) {\n // We are done with this link.\n break;\n }\n }\n }\n if (p.length > 1 && p[p.length - 1] === '/') {\n // Trim trailing '/'.\n return p.slice(0, p.length - 1);\n } else {\n return p;\n }\n }\n public getFile(isoData: Buffer): Buffer {\n if (this.isDirectory(isoData)) {\n throw new Error(`Tried to get a File from a directory.`);\n }\n if (this._fileOrDir === null) {\n this._fileOrDir = isoData.slice(this.lba(), this.lba() + this.dataLength());\n }\n return this._fileOrDir;\n }\n public getDirectory(isoData: Buffer): Directory {\n if (!this.isDirectory(isoData)) {\n throw new Error(`Tried to get a Directory from a file.`);\n }\n if (this._fileOrDir === null) {\n this._fileOrDir = this._constructDirectory(isoData);\n }\n return > this._fileOrDir;\n }\n public getSUEntries(isoData: Buffer): SystemUseEntry[] {\n if (!this._suEntries) {\n this._constructSUEntries(isoData);\n }\n return this._suEntries!;\n }\n protected abstract _getString(i: number, len: number): string;\n protected abstract _getGetString(): TGetString;\n protected abstract _constructDirectory(isoData: Buffer): Directory;\n protected _rockRidgeFilename(isoData: Buffer): string | null {\n const nmEntries = this.getSUEntries(isoData).filter((e) => e instanceof NMEntry);\n if (nmEntries.length === 0 || nmEntries[0].flags() & (NMFlags.CURRENT | NMFlags.PARENT)) {\n return null;\n }\n let str = '';\n const getString = this._getGetString();\n for (let i = 0; i < nmEntries.length; i++) {\n const e = nmEntries[i];\n str += e.name(getString);\n if (!(e.flags() & NMFlags.CONTINUE)) {\n break;\n }\n }\n return str;\n }\n private _constructSUEntries(isoData: Buffer): void {\n let i = 33 + this._data[32];\n if (i % 2 === 1) {\n // Skip padding field.\n i++;\n }\n i += this._rockRidgeOffset;\n this._suEntries = constructSystemUseEntries(this._data, i, this.length(), isoData);\n }\n /**\n * !!ONLY VALID ON FIRST ENTRY OF ROOT DIRECTORY!!\n * Returns -1 if rock ridge is not enabled. Otherwise, returns the offset\n * at which system use fields begin.\n */\n private _getRockRidgeOffset(isoData: Buffer): number {\n // In the worst case, we get some garbage SU entries.\n // Fudge offset to 0 before proceeding.\n this._rockRidgeOffset = 0;\n const suEntries = this.getSUEntries(isoData);\n if (suEntries.length > 0) {\n const spEntry = suEntries[0];\n if (spEntry instanceof SPEntry && spEntry.checkBytesPass()) {\n // SUSP is in use.\n for (let i = 1; i < suEntries.length; i++) {\n const entry = suEntries[i];\n if (entry instanceof RREntry || (entry instanceof EREntry && entry.extensionIdentifier() === rockRidgeIdentifier)) {\n // Rock Ridge is in use!\n return spEntry.bytesSkipped();\n }\n }\n }\n }\n // Failed.\n this._rockRidgeOffset = -1;\n return -1;\n }\n}\n\nclass ISODirectoryRecord extends DirectoryRecord {\n constructor(data: Buffer, rockRidgeOffset: number) {\n super(data, rockRidgeOffset);\n }\n protected _getString(i: number, len: number): string {\n return getASCIIString(this._data, i, len);\n }\n protected _constructDirectory(isoData: Buffer): Directory {\n return new ISODirectory(this, isoData);\n }\n protected _getGetString(): TGetString {\n return getASCIIString;\n }\n}\n\nclass JolietDirectoryRecord extends DirectoryRecord {\n constructor(data: Buffer, rockRidgeOffset: number) {\n super(data, rockRidgeOffset);\n }\n protected _getString(i: number, len: number): string {\n return getJolietString(this._data, i, len);\n }\n protected _constructDirectory(isoData: Buffer): Directory {\n return new JolietDirectory(this, isoData);\n }\n protected _getGetString(): TGetString {\n return getJolietString;\n }\n}\n\nconst enum SystemUseEntrySignatures {\n CE = 0x4345,\n PD = 0x5044,\n SP = 0x5350,\n ST = 0x5354,\n ER = 0x4552,\n ES = 0x4553,\n PX = 0x5058,\n PN = 0x504E,\n SL = 0x534C,\n NM = 0x4E4D,\n CL = 0x434C,\n PL = 0x504C,\n RE = 0x5245,\n TF = 0x5446,\n SF = 0x5346,\n RR = 0x5252\n}\n\nclass SystemUseEntry {\n protected _data: Buffer;\n constructor(data: Buffer) {\n this._data = data;\n }\n public signatureWord(): SystemUseEntrySignatures {\n return this._data.readUInt16BE(0);\n }\n public signatureWordString(): string {\n return getASCIIString(this._data, 0, 2);\n }\n public length(): number {\n return this._data[2];\n }\n public suVersion(): number {\n return this._data[3];\n }\n}\n\n/**\n * Continuation entry.\n */\nclass CEEntry extends SystemUseEntry {\n private _entries: SystemUseEntry[] | null = null;\n constructor(data: Buffer) {\n super(data);\n }\n /**\n * Logical block address of the continuation area.\n */\n public continuationLba(): number {\n return this._data.readUInt32LE(4);\n }\n /**\n * Offset into the logical block.\n */\n public continuationLbaOffset(): number {\n return this._data.readUInt32LE(12);\n }\n /**\n * Length of the continuation area.\n */\n public continuationLength(): number {\n return this._data.readUInt32LE(20);\n }\n public getEntries(isoData: Buffer): SystemUseEntry[] {\n if (!this._entries) {\n const start = this.continuationLba() * 2048 + this.continuationLbaOffset();\n this._entries = constructSystemUseEntries(isoData, start, this.continuationLength(), isoData);\n }\n return this._entries;\n }\n}\n\n/**\n * Padding entry.\n */\nclass PDEntry extends SystemUseEntry {\n constructor(data: Buffer) {\n super(data);\n }\n}\n\n/**\n * Identifies that SUSP is in-use.\n */\nclass SPEntry extends SystemUseEntry {\n constructor(data: Buffer) {\n super(data);\n }\n public checkBytesPass(): boolean {\n return this._data[4] === 0xBE && this._data[5] === 0xEF;\n }\n public bytesSkipped(): number {\n return this._data[6];\n }\n}\n\n/**\n * Identifies the end of the SUSP entries.\n */\nclass STEntry extends SystemUseEntry {\n constructor(data: Buffer) {\n super(data);\n }\n}\n\n/**\n * Specifies system-specific extensions to SUSP.\n */\nclass EREntry extends SystemUseEntry {\n constructor(data: Buffer) {\n super(data);\n }\n public identifierLength(): number {\n return this._data[4];\n }\n public descriptorLength(): number {\n return this._data[5];\n }\n public sourceLength(): number {\n return this._data[6];\n }\n public extensionVersion(): number {\n return this._data[7];\n }\n public extensionIdentifier(): string {\n return getASCIIString(this._data, 8, this.identifierLength());\n }\n public extensionDescriptor(): string {\n return getASCIIString(this._data, 8 + this.identifierLength(), this.descriptorLength());\n }\n public extensionSource(): string {\n return getASCIIString(this._data, 8 + this.identifierLength() + this.descriptorLength(), this.sourceLength());\n }\n}\n\nclass ESEntry extends SystemUseEntry {\n constructor(data: Buffer) {\n super(data);\n }\n public extensionSequence(): number {\n return this._data[4];\n }\n}\n\n/**\n * RockRidge: Marks that RockRidge is in use [deprecated]\n */\nclass RREntry extends SystemUseEntry {\n constructor(data: Buffer) {\n super(data);\n }\n}\n\n/**\n * RockRidge: Records POSIX file attributes.\n */\nclass PXEntry extends SystemUseEntry {\n constructor(data: Buffer) {\n super(data);\n }\n public mode(): number {\n return this._data.readUInt32LE(4);\n }\n public fileLinks(): number {\n return this._data.readUInt32LE(12);\n }\n public uid(): number {\n return this._data.readUInt32LE(20);\n }\n public gid(): number {\n return this._data.readUInt32LE(28);\n }\n public inode(): number {\n return this._data.readUInt32LE(36);\n }\n}\n\n/**\n * RockRidge: Records POSIX device number.\n */\nclass PNEntry extends SystemUseEntry {\n constructor(data: Buffer) {\n super(data);\n }\n public devTHigh(): number {\n return this._data.readUInt32LE(4);\n }\n public devTLow(): number {\n return this._data.readUInt32LE(12);\n }\n}\n\n/**\n * RockRidge: Records symbolic link\n */\nclass SLEntry extends SystemUseEntry {\n constructor(data: Buffer) {\n super(data);\n }\n public flags(): number {\n return this._data[4];\n }\n public continueFlag(): number {\n return this.flags() & 0x1;\n }\n public componentRecords(): SLComponentRecord[] {\n const records = new Array();\n let i = 5;\n while (i < this.length()) {\n const record = new SLComponentRecord(this._data.slice(i));\n records.push(record);\n i += record.length();\n }\n return records;\n }\n}\n\nconst enum SLComponentFlags {\n CONTINUE = 1,\n CURRENT = 1 << 1,\n PARENT = 1 << 2,\n ROOT = 1 << 3\n}\n\nclass SLComponentRecord {\n private _data: Buffer;\n constructor(data: Buffer) {\n this._data = data;\n }\n public flags(): SLComponentFlags {\n return this._data[0];\n }\n public length(): number {\n return 2 + this.componentLength();\n }\n public componentLength(): number {\n return this._data[1];\n }\n public content(getString: TGetString): string {\n return getString(this._data, 2, this.componentLength());\n }\n}\n\nconst enum NMFlags {\n CONTINUE = 1,\n CURRENT = 1 << 1,\n PARENT = 1 << 2\n}\n\n/**\n * RockRidge: Records alternate file name\n */\nclass NMEntry extends SystemUseEntry {\n constructor(data: Buffer) {\n super(data);\n }\n public flags(): NMFlags {\n return this._data[4];\n }\n public name(getString: TGetString): string {\n return getString(this._data, 5, this.length() - 5);\n }\n}\n\n/**\n * RockRidge: Records child link\n */\nclass CLEntry extends SystemUseEntry {\n constructor(data: Buffer) {\n super(data);\n }\n public childDirectoryLba(): number {\n return this._data.readUInt32LE(4);\n }\n}\n\n/**\n * RockRidge: Records parent link.\n */\nclass PLEntry extends SystemUseEntry {\n constructor(data: Buffer) {\n super(data);\n }\n public parentDirectoryLba(): number {\n return this._data.readUInt32LE(4);\n }\n}\n\n/**\n * RockRidge: Records relocated directory.\n */\nclass REEntry extends SystemUseEntry {\n constructor(data: Buffer) {\n super(data);\n }\n}\n\nconst enum TFFlags {\n CREATION = 1,\n MODIFY = 1 << 1,\n ACCESS = 1 << 2,\n ATTRIBUTES = 1 << 3,\n BACKUP = 1 << 4,\n EXPIRATION = 1 << 5,\n EFFECTIVE = 1 << 6,\n LONG_FORM = 1 << 7\n}\n\n/**\n * RockRidge: Records file timestamps\n */\nclass TFEntry extends SystemUseEntry {\n constructor(data: Buffer) {\n super(data);\n }\n public flags(): number {\n return this._data[4];\n }\n public creation(): Date | null {\n if (this.flags() & TFFlags.CREATION) {\n if (this._longFormDates()) {\n return getDate(this._data, 5);\n } else {\n return getShortFormDate(this._data, 5);\n }\n } else {\n return null;\n }\n }\n public modify(): Date | null {\n if (this.flags() & TFFlags.MODIFY) {\n const previousDates = (this.flags() & TFFlags.CREATION) ? 1 : 0;\n if (this._longFormDates) {\n return getDate(this._data, 5 + (previousDates * 17));\n } else {\n return getShortFormDate(this._data, 5 + (previousDates * 7));\n }\n } else {\n return null;\n }\n }\n public access(): Date | null {\n if (this.flags() & TFFlags.ACCESS) {\n let previousDates = (this.flags() & TFFlags.CREATION) ? 1 : 0;\n previousDates += (this.flags() & TFFlags.MODIFY) ? 1 : 0;\n if (this._longFormDates) {\n return getDate(this._data, 5 + (previousDates * 17));\n } else {\n return getShortFormDate(this._data, 5 + (previousDates * 7));\n }\n } else {\n return null;\n }\n }\n public backup(): Date | null {\n if (this.flags() & TFFlags.BACKUP) {\n let previousDates = (this.flags() & TFFlags.CREATION) ? 1 : 0;\n previousDates += (this.flags() & TFFlags.MODIFY) ? 1 : 0;\n previousDates += (this.flags() & TFFlags.ACCESS) ? 1 : 0;\n if (this._longFormDates) {\n return getDate(this._data, 5 + (previousDates * 17));\n } else {\n return getShortFormDate(this._data, 5 + (previousDates * 7));\n }\n } else {\n return null;\n }\n }\n public expiration(): Date | null {\n if (this.flags() & TFFlags.EXPIRATION) {\n let previousDates = (this.flags() & TFFlags.CREATION) ? 1 : 0;\n previousDates += (this.flags() & TFFlags.MODIFY) ? 1 : 0;\n previousDates += (this.flags() & TFFlags.ACCESS) ? 1 : 0;\n previousDates += (this.flags() & TFFlags.BACKUP) ? 1 : 0;\n if (this._longFormDates) {\n return getDate(this._data, 5 + (previousDates * 17));\n } else {\n return getShortFormDate(this._data, 5 + (previousDates * 7));\n }\n } else {\n return null;\n }\n }\n public effective(): Date | null {\n if (this.flags() & TFFlags.EFFECTIVE) {\n let previousDates = (this.flags() & TFFlags.CREATION) ? 1 : 0;\n previousDates += (this.flags() & TFFlags.MODIFY) ? 1 : 0;\n previousDates += (this.flags() & TFFlags.ACCESS) ? 1 : 0;\n previousDates += (this.flags() & TFFlags.BACKUP) ? 1 : 0;\n previousDates += (this.flags() & TFFlags.EXPIRATION) ? 1 : 0;\n if (this._longFormDates) {\n return getDate(this._data, 5 + (previousDates * 17));\n } else {\n return getShortFormDate(this._data, 5 + (previousDates * 7));\n }\n } else {\n return null;\n }\n }\n private _longFormDates(): boolean {\n return !!(this.flags() && TFFlags.LONG_FORM);\n }\n}\n\n/**\n * RockRidge: File data in sparse format.\n */\nclass SFEntry extends SystemUseEntry {\n constructor(data: Buffer) {\n super(data);\n }\n public virtualSizeHigh(): number {\n return this._data.readUInt32LE(4);\n }\n public virtualSizeLow(): number {\n return this._data.readUInt32LE(12);\n }\n public tableDepth(): number {\n return this._data[20];\n }\n}\n\nabstract class Directory {\n protected _record: T;\n private _fileList: string[] = [];\n private _fileMap: {[name: string]: T} = {};\n constructor(record: T, isoData: Buffer) {\n this._record = record;\n let i = record.lba();\n let iLimit = i + record.dataLength();\n if (!(record.fileFlags() & FileFlags.Directory)) {\n // Must have a CL entry.\n const cl = record.getSUEntries(isoData).filter((e) => e instanceof CLEntry)[0];\n i = cl.childDirectoryLba() * 2048;\n iLimit = Infinity;\n }\n\n while (i < iLimit) {\n const len = isoData[i];\n // Zero-padding between sectors.\n // TODO: Could optimize this to seek to nearest-sector upon\n // seeing a 0.\n if (len === 0) {\n i++;\n continue;\n }\n const r = this._constructDirectoryRecord(isoData.slice(i));\n const fname = r.fileName(isoData);\n // Skip '.' and '..' entries.\n if (fname !== '\\u0000' && fname !== '\\u0001') {\n // Skip relocated entries.\n if (!r.hasRockRidge() || r.getSUEntries(isoData).filter((e) => e instanceof REEntry).length === 0) {\n this._fileMap[fname] = r;\n this._fileList.push(fname);\n }\n } else if (iLimit === Infinity) {\n // First entry contains needed data.\n iLimit = i + r.dataLength();\n }\n i += r.length();\n }\n }\n /**\n * Get the record with the given name.\n * Returns undefined if not present.\n */\n public getRecord(name: string): DirectoryRecord {\n return this._fileMap[name];\n }\n public getFileList(): string[] {\n return this._fileList;\n }\n public getDotEntry(isoData: Buffer): T {\n return this._constructDirectoryRecord(isoData.slice(this._record.lba()));\n }\n protected abstract _constructDirectoryRecord(data: Buffer): T;\n}\n\nclass ISODirectory extends Directory {\n constructor(record: ISODirectoryRecord, isoData: Buffer) {\n super(record, isoData);\n }\n protected _constructDirectoryRecord(data: Buffer): ISODirectoryRecord {\n return new ISODirectoryRecord(data, this._record.getRockRidgeOffset());\n }\n}\n\nclass JolietDirectory extends Directory {\n constructor(record: JolietDirectoryRecord, isoData: Buffer) {\n super(record, isoData);\n }\n protected _constructDirectoryRecord(data: Buffer): JolietDirectoryRecord {\n return new JolietDirectoryRecord(data, this._record.getRockRidgeOffset());\n }\n}\n\nexport default class IsoFS extends SynchronousFileSystem implements FileSystem {\n public static isAvailable(): boolean {\n return true;\n }\n\n private _data: Buffer;\n private _pvd: PrimaryOrSupplementaryVolumeDescriptor;\n private _root: DirectoryRecord;\n private _name: string;\n\n constructor(data: Buffer, name: string = \"\") {\n super();\n this._data = data;\n // Skip first 16 sectors.\n let vdTerminatorFound = false;\n let i = 16 * 2048;\n const candidateVDs = new Array();\n while (!vdTerminatorFound) {\n const slice = data.slice(i);\n const vd = new VolumeDescriptor(slice);\n switch (vd.type()) {\n case VolumeDescriptorTypeCode.PrimaryVolumeDescriptor:\n candidateVDs.push(new PrimaryVolumeDescriptor(slice));\n break;\n case VolumeDescriptorTypeCode.SupplementaryVolumeDescriptor:\n candidateVDs.push(new SupplementaryVolumeDescriptor(slice));\n break;\n case VolumeDescriptorTypeCode.VolumeDescriptorSetTerminator:\n vdTerminatorFound = true;\n break;\n }\n i += 2048;\n }\n if (candidateVDs.length === 0) {\n throw new ApiError(ErrorCode.EIO, `Unable to find a suitable volume descriptor.`);\n }\n candidateVDs.forEach((v) => {\n // Take an SVD over a PVD.\n if (!this._pvd || this._pvd.type() !== VolumeDescriptorTypeCode.SupplementaryVolumeDescriptor) {\n this._pvd = v;\n }\n });\n this._root = this._pvd.rootDirectoryEntry(data);\n this._name = name;\n }\n\n public getName(): string {\n let name = `IsoFS${this._name}-${this._pvd.name()}`;\n if (this._root.hasRockRidge()) {\n name += `-RockRidge`;\n }\n return name;\n }\n\n public diskSpace(path: string, cb: (total: number, free: number) => void): void {\n // Read-only file system.\n cb(this._data.length, 0);\n }\n\n public isReadOnly(): boolean {\n return true;\n }\n\n public supportsLinks(): boolean {\n return false;\n }\n\n public supportsProps(): boolean {\n return false;\n }\n\n public supportsSynch(): boolean {\n return true;\n }\n\n public statSync(p: string, isLstat: boolean): Stats {\n const record = this._getDirectoryRecord(p);\n if (record === null) {\n throw ApiError.ENOENT(p);\n }\n return this._getStats(p, record)!;\n }\n\n public openSync(p: string, flags: FileFlag, mode: number): File {\n // INVARIANT: Cannot write to RO file systems.\n if (flags.isWriteable()) {\n throw new ApiError(ErrorCode.EPERM, p);\n }\n // Check if the path exists, and is a file.\n const record = this._getDirectoryRecord(p);\n if (!record) {\n throw ApiError.ENOENT(p);\n } else if (record.isSymlink(this._data)) {\n return this.openSync(path.resolve(p, record.getSymlinkPath(this._data)), flags, mode);\n } else if (!record.isDirectory(this._data)) {\n const data = record.getFile(this._data);\n const stats = this._getStats(p, record)!;\n switch (flags.pathExistsAction()) {\n case ActionType.THROW_EXCEPTION:\n case ActionType.TRUNCATE_FILE:\n throw ApiError.EEXIST(p);\n case ActionType.NOP:\n return new NoSyncFile(this, p, flags, stats, data);\n default:\n throw new ApiError(ErrorCode.EINVAL, 'Invalid FileMode object.');\n }\n } else {\n throw ApiError.EISDIR(p);\n }\n }\n\n public readdirSync(path: string): string[] {\n // Check if it exists.\n const record = this._getDirectoryRecord(path);\n if (!record) {\n throw ApiError.ENOENT(path);\n } else if (record.isDirectory(this._data)) {\n return record.getDirectory(this._data).getFileList().slice(0);\n } else {\n throw ApiError.ENOTDIR(path);\n }\n }\n\n /**\n * Specially-optimized readfile.\n */\n public readFileSync(fname: string, encoding: string, flag: FileFlag): any {\n // Get file.\n const fd = this.openSync(fname, flag, 0x1a4);\n try {\n const fdCast = > fd;\n const fdBuff = fdCast.getBuffer();\n if (encoding === null) {\n return copyingSlice(fdBuff);\n }\n return fdBuff.toString(encoding);\n } finally {\n fd.closeSync();\n }\n }\n\n private _getDirectoryRecord(path: string): DirectoryRecord | null {\n // Special case.\n if (path === '/') {\n return this._root;\n }\n const components = path.split('/').slice(1);\n let dir = this._root;\n for (let i = 0; i < components.length; i++) {\n if (dir.isDirectory(this._data)) {\n dir = dir.getDirectory(this._data).getRecord(components[i]);\n if (!dir) {\n return null;\n }\n } else {\n return null;\n }\n }\n return dir;\n }\n\n private _getStats(p: string, record: DirectoryRecord): Stats | null {\n if (record.isSymlink(this._data)) {\n const newP = path.resolve(p, record.getSymlinkPath(this._data));\n const dirRec = this._getDirectoryRecord(newP);\n if (!dirRec) {\n return null;\n }\n return this._getStats(newP, dirRec);\n } else {\n const len = record.dataLength();\n let mode = 0x16D;\n const date = record.recordingDate();\n let atime = date;\n let mtime = date;\n let ctime = date;\n if (record.hasRockRidge()) {\n const entries = record.getSUEntries(this._data);\n for (let i = 0; i < entries.length; i++) {\n const entry = entries[i];\n if (entry instanceof PXEntry) {\n mode = entry.mode();\n } else if (entry instanceof TFEntry) {\n const flags = entry.flags();\n if (flags & TFFlags.ACCESS) {\n atime = entry.access()!;\n }\n if (flags & TFFlags.MODIFY) {\n mtime = entry.modify()!;\n }\n if (flags & TFFlags.CREATION) {\n ctime = entry.creation()!;\n }\n }\n }\n }\n // Mask out writeable flags. This is a RO file system.\n mode = mode & 0x16D;\n return new Stats(record.isDirectory(this._data) ? FileType.DIRECTORY : FileType.FILE, len, mode, atime, mtime, ctime);\n }\n }\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../src/backend/IsoFS.ts","/**\n * BrowserFS's main module. This is exposed in the browser via the BrowserFS global.\n */\n\nimport * as buffer from 'buffer';\nimport fs from './node_fs';\nimport * as path from 'path';\nimport {FileSystemConstructor, FileSystem} from './file_system';\nimport EmscriptenFS from '../generic/emscripten_fs';\nimport Backends from './backends';\nimport * as BFSUtils from './util';\nimport * as Errors from './api_error';\n\nif (( process)['initializeTTYs']) {\n ( process)['initializeTTYs']();\n}\n\n/**\n * Installs BrowserFS onto the given object.\n * We recommend that you run install with the 'window' object to make things\n * global, as in Node.\n *\n * Properties installed:\n *\n * * Buffer\n * * process\n * * require (we monkey-patch it)\n *\n * This allows you to write code as if you were running inside Node.\n * @param {object} obj - The object to install things onto (e.g. window)\n */\nexport function install(obj: any) {\n obj.Buffer = Buffer;\n obj.process = process;\n const oldRequire = obj.require ? obj.require : null;\n // Monkey-patch require for Node-style code.\n obj.require = function(arg: string) {\n const rv = BFSRequire(arg);\n if (!rv) {\n return oldRequire.apply(null, Array.prototype.slice.call(arguments, 0));\n } else {\n return rv;\n }\n };\n}\n\nexport function registerFileSystem(name: string, fs: FileSystemConstructor) {\n ( Backends)[name] = fs;\n}\n\nexport function BFSRequire(module: 'fs'): typeof fs;\nexport function BFSRequire(module: 'path'): typeof path;\nexport function BFSRequire(module: 'buffer'): typeof buffer;\nexport function BFSRequire(module: 'process'): typeof process;\nexport function BFSRequire(module: 'bfs_utils'): typeof BFSUtils;\nexport function BFSRequire(module: string): any;\nexport function BFSRequire(module: string): any {\n switch (module) {\n case 'fs':\n return fs;\n case 'path':\n return path;\n case 'buffer':\n // The 'buffer' module has 'Buffer' as a property.\n return buffer;\n case 'process':\n return process;\n case 'bfs_utils':\n return BFSUtils;\n default:\n return ( Backends)[module];\n }\n}\n\n/**\n * You must call this function with a properly-instantiated root file system\n * before using any file system API method.\n * @param {BrowserFS.FileSystem} rootFS - The root filesystem to use for the\n * entire BrowserFS file system.\n */\nexport function initialize(rootfs: FileSystem) {\n return fs.initialize(rootfs);\n}\n\nexport {EmscriptenFS, Backends as FileSystem, Errors};\n\n\n\n// WEBPACK FOOTER //\n// ../../../../src/core/browserfs.ts","/**\n * Exports the global scope variable.\n * In the main browser thread, this is \"window\".\n * In a WebWorker, this is \"self\".\n * In Node, this is \"global\".\n */\ndeclare var global: any;\nlet toExport: any;\nif (typeof(window) !== 'undefined') {\n toExport = window;\n} else if (typeof(self) !== 'undefined') {\n toExport = self;\n} else {\n toExport = global;\n}\nexport default toExport;\n\n\n\n// WEBPACK FOOTER //\n// ../../../../src/core/global.ts","/**\n * Standard libc error codes. Add more to this enum and ErrorStrings as they are\n * needed.\n * @url http://www.gnu.org/software/libc/manual/html_node/Error-Codes.html\n */\nexport enum ErrorCode {\n EPERM = 1,\n ENOENT = 2,\n EIO = 5,\n EBADF = 9,\n EACCES = 13,\n EBUSY = 16,\n EEXIST = 17,\n ENOTDIR = 20,\n EISDIR = 21,\n EINVAL = 22,\n EFBIG = 27,\n ENOSPC = 28,\n EROFS = 30,\n ENOTEMPTY = 39,\n ENOTSUP = 95,\n}\n/* tslint:disable:variable-name */\n/**\n * Strings associated with each error code.\n */\nexport const ErrorStrings: {[code: string]: string; [code: number]: string; } = {};\nErrorStrings[ErrorCode.EPERM] = 'Operation not permitted.';\nErrorStrings[ErrorCode.ENOENT] = 'No such file or directory.';\nErrorStrings[ErrorCode.EIO] = 'Input/output error.';\nErrorStrings[ErrorCode.EBADF] = 'Bad file descriptor.';\nErrorStrings[ErrorCode.EACCES] = 'Permission denied.';\nErrorStrings[ErrorCode.EBUSY] = 'Resource busy or locked.';\nErrorStrings[ErrorCode.EEXIST] = 'File exists.';\nErrorStrings[ErrorCode.ENOTDIR] = 'File is not a directory.';\nErrorStrings[ErrorCode.EISDIR] = 'File is a directory.';\nErrorStrings[ErrorCode.EINVAL] = 'Invalid argument.';\nErrorStrings[ErrorCode.EFBIG] = 'File is too big.';\nErrorStrings[ErrorCode.ENOSPC] = 'No space left on disk.';\nErrorStrings[ErrorCode.EROFS] = 'Cannot modify a read-only file system.';\nErrorStrings[ErrorCode.ENOTEMPTY] = 'Directory is not empty.';\nErrorStrings[ErrorCode.ENOTSUP] = 'Operation is not supported.';\n/* tslint:enable:variable-name */\n\n/**\n * Represents a BrowserFS error. Passed back to applications after a failed\n * call to the BrowserFS API.\n */\nexport class ApiError extends Error implements NodeJS.ErrnoException {\n public static fromJSON(json: any): ApiError {\n const err = new ApiError(0);\n err.errno = json.errno;\n err.code = json.code;\n err.path = json.path;\n err.stack = json.stack;\n err.message = json.message;\n return err;\n }\n\n /**\n * Creates an ApiError object from a buffer.\n */\n public static fromBuffer(buffer: Buffer, i: number = 0): ApiError {\n return ApiError.fromJSON(JSON.parse(buffer.toString('utf8', i + 4, i + 4 + buffer.readUInt32LE(i))));\n }\n\n public static FileError(code: ErrorCode, p: string): ApiError {\n return new ApiError(code, ErrorStrings[code], p);\n }\n public static ENOENT(path: string): ApiError {\n return this.FileError(ErrorCode.ENOENT, path);\n }\n\n public static EEXIST(path: string): ApiError {\n return this.FileError(ErrorCode.EEXIST, path);\n }\n\n public static EISDIR(path: string): ApiError {\n return this.FileError(ErrorCode.EISDIR, path);\n }\n\n public static ENOTDIR(path: string): ApiError {\n return this.FileError(ErrorCode.ENOTDIR, path);\n }\n\n public static EPERM(path: string): ApiError {\n return this.FileError(ErrorCode.EPERM, path);\n }\n\n public static ENOTEMPTY(path: string): ApiError {\n return this.FileError(ErrorCode.ENOTEMPTY, path);\n }\n\n public errno: ErrorCode;\n public code: string;\n public path: string | undefined;\n // Unsupported.\n public syscall: string = \"\";\n public stack: string | undefined;\n\n /**\n * Represents a BrowserFS error. Passed back to applications after a failed\n * call to the BrowserFS API.\n *\n * Error codes mirror those returned by regular Unix file operations, which is\n * what Node returns.\n * @constructor ApiError\n * @param type The type of the error.\n * @param [message] A descriptive error message.\n */\n constructor(type: ErrorCode, message: string = ErrorStrings[type], path?: string) {\n super(message);\n this.errno = type;\n this.code = ErrorCode[type];\n this.path = path;\n this.stack = new Error().stack;\n this.message = `Error: ${this.code}: ${message}${this.path ? `, '${this.path}'` : ''}`;\n }\n\n /**\n * @return A friendly error message.\n */\n public toString(): string {\n return this.message;\n }\n\n public toJSON(): any {\n return {\n errno: this.errno,\n code: this.code,\n path: this.path,\n stack: this.stack,\n message: this.message\n };\n }\n\n /**\n * Writes the API error into a buffer.\n */\n public writeToBuffer(buffer: Buffer = new Buffer(this.bufferSize()), i: number = 0): Buffer {\n const bytesWritten = buffer.write(JSON.stringify(this.toJSON()), i + 4);\n buffer.writeUInt32LE(bytesWritten, i);\n return buffer;\n }\n\n /**\n * The size of the API error in buffer-form in bytes.\n */\n public bufferSize(): number {\n // 4 bytes for string length.\n return 4 + Buffer.byteLength(JSON.stringify(this.toJSON()));\n }\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../src/core/api_error.ts","import {ErrorCode, ApiError} from './api_error';\n\nexport enum ActionType {\n // Indicates that the code should not do anything.\n NOP = 0,\n // Indicates that the code should throw an exception.\n THROW_EXCEPTION = 1,\n // Indicates that the code should truncate the file, but only if it is a file.\n TRUNCATE_FILE = 2,\n // Indicates that the code should create the file.\n CREATE_FILE = 3\n}\n\n/**\n * Represents one of the following file flags. A convenience object.\n *\n * * `'r'` - Open file for reading. An exception occurs if the file does not exist.\n * * `'r+'` - Open file for reading and writing. An exception occurs if the file does not exist.\n * * `'rs'` - Open file for reading in synchronous mode. Instructs the filesystem to not cache writes.\n * * `'rs+'` - Open file for reading and writing, and opens the file in synchronous mode.\n * * `'w'` - Open file for writing. The file is created (if it does not exist) or truncated (if it exists).\n * * `'wx'` - Like 'w' but opens the file in exclusive mode.\n * * `'w+'` - Open file for reading and writing. The file is created (if it does not exist) or truncated (if it exists).\n * * `'wx+'` - Like 'w+' but opens the file in exclusive mode.\n * * `'a'` - Open file for appending. The file is created if it does not exist.\n * * `'ax'` - Like 'a' but opens the file in exclusive mode.\n * * `'a+'` - Open file for reading and appending. The file is created if it does not exist.\n * * `'ax+'` - Like 'a+' but opens the file in exclusive mode.\n *\n * Exclusive mode ensures that the file path is newly created.\n */\nexport class FileFlag {\n // Contains cached FileMode instances.\n private static flagCache: { [mode: string]: FileFlag } = {};\n // Array of valid mode strings.\n private static validFlagStrs = ['r', 'r+', 'rs', 'rs+', 'w', 'wx', 'w+', 'wx+', 'a', 'ax', 'a+', 'ax+'];\n\n /**\n * Get an object representing the given file flag.\n * @param modeStr The string representing the flag\n * @return The FileFlag object representing the flag\n * @throw when the flag string is invalid\n */\n public static getFileFlag(flagStr: string): FileFlag {\n // Check cache first.\n if (FileFlag.flagCache.hasOwnProperty(flagStr)) {\n return FileFlag.flagCache[flagStr];\n }\n return FileFlag.flagCache[flagStr] = new FileFlag(flagStr);\n }\n\n private flagStr: string;\n /**\n * This should never be called directly.\n * @param modeStr The string representing the mode\n * @throw when the mode string is invalid\n */\n constructor(flagStr: string) {\n this.flagStr = flagStr;\n if (FileFlag.validFlagStrs.indexOf(flagStr) < 0) {\n throw new ApiError(ErrorCode.EINVAL, \"Invalid flag: \" + flagStr);\n }\n }\n\n /**\n * Get the underlying flag string for this flag.\n */\n public getFlagString(): string {\n return this.flagStr;\n }\n\n /**\n * Returns true if the file is readable.\n */\n public isReadable(): boolean {\n return this.flagStr.indexOf('r') !== -1 || this.flagStr.indexOf('+') !== -1;\n }\n /**\n * Returns true if the file is writeable.\n */\n public isWriteable(): boolean {\n return this.flagStr.indexOf('w') !== -1 || this.flagStr.indexOf('a') !== -1 || this.flagStr.indexOf('+') !== -1;\n }\n /**\n * Returns true if the file mode should truncate.\n */\n public isTruncating(): boolean {\n return this.flagStr.indexOf('w') !== -1;\n }\n /**\n * Returns true if the file is appendable.\n */\n public isAppendable(): boolean {\n return this.flagStr.indexOf('a') !== -1;\n }\n /**\n * Returns true if the file is open in synchronous mode.\n */\n public isSynchronous(): boolean {\n return this.flagStr.indexOf('s') !== -1;\n }\n /**\n * Returns true if the file is open in exclusive mode.\n */\n public isExclusive(): boolean {\n return this.flagStr.indexOf('x') !== -1;\n }\n /**\n * Returns one of the static fields on this object that indicates the\n * appropriate response to the path existing.\n */\n public pathExistsAction(): ActionType {\n if (this.isExclusive()) {\n return ActionType.THROW_EXCEPTION;\n } else if (this.isTruncating()) {\n return ActionType.TRUNCATE_FILE;\n } else {\n return ActionType.NOP;\n }\n }\n /**\n * Returns one of the static fields on this object that indicates the\n * appropriate response to the path not existing.\n */\n public pathNotExistsAction(): ActionType {\n if ((this.isWriteable() || this.isAppendable()) && this.flagStr !== 'r+') {\n return ActionType.CREATE_FILE;\n } else {\n return ActionType.THROW_EXCEPTION;\n }\n }\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../src/core/file_flag.ts","import * as fs from 'fs';\n\n/**\n * Indicates the type of the given file. Applied to 'mode'.\n */\nexport enum FileType {\n FILE = 0x8000,\n DIRECTORY = 0x4000,\n SYMLINK = 0xA000\n}\n\n/**\n * Emulation of Node's `fs.Stats` object.\n *\n * Attribute descriptions are from `man 2 stat'\n * @see http://nodejs.org/api/fs.html#fs_class_fs_stats\n * @see http://man7.org/linux/man-pages/man2/stat.2.html\n * @class\n */\nexport default class Stats implements fs.Stats {\n public static fromBuffer(buffer: Buffer): Stats {\n const size = buffer.readUInt32LE(0),\n mode = buffer.readUInt32LE(4),\n atime = buffer.readDoubleLE(8),\n mtime = buffer.readDoubleLE(16),\n ctime = buffer.readDoubleLE(24);\n\n return new Stats(mode & 0xF000, size, mode & 0xFFF, new Date(atime), new Date(mtime), new Date(ctime));\n }\n\n public blocks: number;\n public mode: number;\n /**\n * UNSUPPORTED ATTRIBUTES\n * I assume no one is going to need these details, although we could fake\n * appropriate values if need be.\n */\n // ID of device containing file\n public dev: number = 0;\n // inode number\n public ino: number = 0;\n // device ID (if special file)\n public rdev: number = 0;\n // number of hard links\n public nlink: number = 1;\n // blocksize for file system I/O\n public blksize: number = 4096;\n // @todo Maybe support these? atm, it's a one-user filesystem.\n // user ID of owner\n public uid: number = 0;\n // group ID of owner\n public gid: number = 0;\n // time file was created (currently unsupported)\n public birthtime: Date = new Date(0);\n // XXX: Some file systems stash data on stats objects.\n public fileData: Buffer | null= null;\n\n /**\n * Provides information about a particular entry in the file system.\n * @param [Number] item_type type of the item (FILE, DIRECTORY, SYMLINK, or SOCKET)\n * @param [Number] size Size of the item in bytes. For directories/symlinks,\n * this is normally the size of the struct that represents the item.\n * @param [Number] mode Unix-style file mode (e.g. 0o644)\n * @param [Date?] atime time of last access\n * @param [Date?] mtime time of last modification\n * @param [Date?] ctime time of creation\n */\n constructor(\n itemType: FileType,\n public size: number,\n mode?: number,\n public atime: Date = new Date(),\n public mtime: Date = new Date(),\n public ctime: Date = new Date()) {\n if (!mode) {\n switch (itemType) {\n case FileType.FILE:\n this.mode = 0x1a4;\n break;\n case FileType.DIRECTORY:\n default:\n this.mode = 0x1ff;\n }\n } else {\n this.mode = mode;\n }\n // number of 512B blocks allocated\n this.blocks = Math.ceil(size / 512);\n // Check if mode also includes top-most bits, which indicate the file's\n // type.\n if (this.mode < 0x1000) {\n this.mode |= itemType;\n }\n }\n\n public toBuffer(): Buffer {\n const buffer = new Buffer(32);\n buffer.writeUInt32LE(this.size, 0);\n buffer.writeUInt32LE(this.mode, 4);\n buffer.writeDoubleLE(this.atime.getTime(), 8);\n buffer.writeDoubleLE(this.mtime.getTime(), 16);\n buffer.writeDoubleLE(this.ctime.getTime(), 24);\n return buffer;\n }\n\n /**\n * **Nonstandard**: Clone the stats object.\n * @return [BrowserFS.node.fs.Stats]\n */\n public clone(): Stats {\n return new Stats(this.mode & 0xF000, this.size, this.mode & 0xFFF, this.atime, this.mtime, this.ctime);\n }\n\n /**\n * @return [Boolean] True if this item is a file.\n */\n public isFile(): boolean {\n return (this.mode & 0xF000) === FileType.FILE;\n }\n\n /**\n * @return [Boolean] True if this item is a directory.\n */\n public isDirectory(): boolean {\n return (this.mode & 0xF000) === FileType.DIRECTORY;\n }\n\n /**\n * @return [Boolean] True if this item is a symbolic link (only valid through lstat)\n */\n public isSymbolicLink(): boolean {\n return (this.mode & 0xF000) === FileType.SYMLINK;\n }\n\n /**\n * Change the mode of the file. We use this helper function to prevent messing\n * up the type of the file, which is encoded in mode.\n */\n public chmod(mode: number): void {\n this.mode = (this.mode & 0xF000) | mode;\n }\n\n // We don't support the following types of files.\n\n public isSocket(): boolean {\n return false;\n }\n\n public isBlockDevice(): boolean {\n return false;\n }\n\n public isCharacterDevice(): boolean {\n return false;\n }\n\n public isFIFO(): boolean {\n return false;\n }\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../src/core/node_fs_stats.ts","import {default as FS, FSModule} from './FS';\n\n// Manually export the individual public functions of fs.\n// Required because some code will invoke functions off of the module.\n// e.g.:\n// let writeFile = fs.writeFile;\n// writeFile(...)\n\nlet fs: any = new FS();\nconst _fsMock: FSModule = {};\n\nconst fsProto = FS.prototype;\nObject.keys(fsProto).forEach((key) => {\n if (typeof fs[key] === 'function') {\n ( _fsMock)[key] = function() {\n return ( fs[key]).apply(fs, arguments);\n };\n } else {\n ( _fsMock)[key] = fs[key];\n }\n});\n\n_fsMock['changeFSModule'] = function(newFs: FS): void {\n fs = newFs;\n};\n_fsMock['getFSModule'] = function(): FS {\n return fs;\n};\n_fsMock['FS'] = FS;\n\nexport default _fsMock;\n\n\n\n// WEBPACK FOOTER //\n// ../../../../src/core/node_fs.ts","/**\n * Defines an Emscripten file system object for use in the Emscripten virtual\n * filesystem. Allows you to use synchronous BrowserFS file systems from within\n * Emscripten.\n *\n * You can construct a BFSEmscriptenFS, mount it using its mount command,\n * and then mount it into Emscripten.\n *\n * Adapted from Emscripten's NodeFS:\n * https://raw.github.com/kripken/emscripten/master/src/library_nodefs.js\n */\nimport FS from '../core/FS';\nimport fs from '../core/node_fs';\nimport NodeStats from '../core/node_fs_stats';\nimport {uint8Array2Buffer} from '../core/util';\n\nexport interface Stats {\n dev: number;\n ino: number;\n mode: number;\n nlink: number;\n uid: number;\n gid: number;\n rdev: number;\n size: number;\n blksize: number;\n blocks: number;\n atime: Date;\n mtime: Date;\n ctime: Date;\n timestamp?: number;\n}\n\nexport interface EmscriptenFSNode {\n name: string;\n mode: number;\n parent: EmscriptenFSNode;\n mount: {opts: {root: string}};\n stream_ops: EmscriptenStreamOps;\n node_ops: EmscriptenNodeOps;\n}\n\nexport interface EmscriptenStream {\n node: EmscriptenFSNode;\n nfd: any;\n flags: string;\n position: number;\n}\n\nexport interface EmscriptenNodeOps {\n getattr(node: EmscriptenFSNode): Stats;\n setattr(node: EmscriptenFSNode, attr: Stats): void;\n lookup(parent: EmscriptenFSNode, name: string): EmscriptenFSNode;\n mknod(parent: EmscriptenFSNode, name: string, mode: number, dev: any): EmscriptenFSNode;\n rename(oldNode: EmscriptenFSNode, newDir: EmscriptenFSNode, newName: string): void;\n unlink(parent: EmscriptenFSNode, name: string): void;\n rmdir(parent: EmscriptenFSNode, name: string): void;\n readdir(node: EmscriptenFSNode): string[];\n symlink(parent: EmscriptenFSNode, newName: string, oldPath: string): void;\n readlink(node: EmscriptenFSNode): string;\n}\n\nexport interface EmscriptenStreamOps {\n open(stream: EmscriptenStream): void;\n close(stream: EmscriptenStream): void;\n read(stream: EmscriptenStream, buffer: Uint8Array, offset: number, length: number, position: number): number;\n write(stream: EmscriptenStream, buffer: Uint8Array, offset: number, length: number, position: number): number;\n llseek(stream: EmscriptenStream, offset: number, whence: number): number;\n}\n\nexport interface EmscriptenFS {\n node_ops: EmscriptenNodeOps;\n stream_ops: EmscriptenStreamOps;\n mount(mount: {opts: {root: string}}): EmscriptenFSNode;\n createNode(parent: EmscriptenFSNode, name: string, mode: number, dev?: any): EmscriptenFSNode;\n getMode(path: string): number;\n realPath(node: EmscriptenFSNode): string;\n}\n\nclass BFSEmscriptenStreamOps implements EmscriptenStreamOps {\n private FS: any;\n private PATH: any;\n private ERRNO_CODES: any;\n private nodefs: FS;\n\n constructor(private fs: BFSEmscriptenFS) {\n this.nodefs = fs.getNodeFS();\n this.FS = fs.getFS();\n this.PATH = fs.getPATH();\n this.ERRNO_CODES = fs.getERRNO_CODES();\n }\n\n public open(stream: EmscriptenStream): void {\n const path = this.fs.realPath(stream.node);\n const FS = this.FS;\n try {\n if (FS.isFile(stream.node.mode)) {\n stream.nfd = this.nodefs.openSync(path, this.fs.flagsToPermissionString(stream.flags));\n }\n } catch (e) {\n if (!e.code) {\n throw e;\n }\n throw new FS.ErrnoError(this.ERRNO_CODES[e.code]);\n }\n }\n\n public close(stream: EmscriptenStream): void {\n const FS = this.FS;\n try {\n if (FS.isFile(stream.node.mode) && stream.nfd) {\n this.nodefs.closeSync(stream.nfd);\n }\n } catch (e) {\n if (!e.code) {\n throw e;\n }\n throw new FS.ErrnoError(this.ERRNO_CODES[e.code]);\n }\n }\n\n public read(stream: EmscriptenStream, buffer: Uint8Array, offset: number, length: number, position: number): number {\n // Avoid copying overhead by reading directly into buffer.\n try {\n return this.nodefs.readSync(stream.nfd, uint8Array2Buffer(buffer), offset, length, position);\n } catch (e) {\n throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n }\n }\n\n public write(stream: EmscriptenStream, buffer: Uint8Array, offset: number, length: number, position: number): number {\n // Avoid copying overhead.\n try {\n return this.nodefs.writeSync(stream.nfd, uint8Array2Buffer(buffer), offset, length, position);\n } catch (e) {\n throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n }\n }\n\n public llseek(stream: EmscriptenStream, offset: number, whence: number): number {\n let position = offset;\n if (whence === 1) { // SEEK_CUR.\n position += stream.position;\n } else if (whence === 2) { // SEEK_END.\n if (this.FS.isFile(stream.node.mode)) {\n try {\n const stat = this.nodefs.fstatSync(stream.nfd);\n position += stat.size;\n } catch (e) {\n throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n }\n }\n }\n\n if (position < 0) {\n throw new this.FS.ErrnoError(this.ERRNO_CODES.EINVAL);\n }\n\n stream.position = position;\n return position;\n }\n}\n\nclass BFSEmscriptenNodeOps implements EmscriptenNodeOps {\n private FS: any;\n private PATH: any;\n private ERRNO_CODES: any;\n private nodefs: FS;\n\n constructor(private fs: BFSEmscriptenFS) {\n this.nodefs = fs.getNodeFS();\n this.FS = fs.getFS();\n this.PATH = fs.getPATH();\n this.ERRNO_CODES = fs.getERRNO_CODES();\n }\n\n public getattr(node: EmscriptenFSNode): Stats {\n const path = this.fs.realPath(node);\n let stat: NodeStats;\n try {\n stat = this.nodefs.lstatSync(path);\n } catch (e) {\n if (!e.code) {\n throw e;\n }\n throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n }\n return {\n dev: stat.dev,\n ino: stat.ino,\n mode: stat.mode,\n nlink: stat.nlink,\n uid: stat.uid,\n gid: stat.gid,\n rdev: stat.rdev,\n size: stat.size,\n atime: stat.atime,\n mtime: stat.mtime,\n ctime: stat.ctime,\n blksize: stat.blksize,\n blocks: stat.blocks\n };\n }\n\n public setattr(node: EmscriptenFSNode, attr: Stats): void {\n const path = this.fs.realPath(node);\n try {\n if (attr.mode !== undefined) {\n this.nodefs.chmodSync(path, attr.mode);\n // update the common node structure mode as well\n node.mode = attr.mode;\n }\n if (attr.timestamp !== undefined) {\n const date = new Date(attr.timestamp);\n this.nodefs.utimesSync(path, date, date);\n }\n } catch (e) {\n if (!e.code) {\n throw e;\n }\n // Ignore not supported errors. Emscripten does utimesSync when it\n // writes files, but never really requires the value to be set.\n if (e.code !== \"ENOTSUP\") {\n throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n }\n }\n if (attr.size !== undefined) {\n try {\n this.nodefs.truncateSync(path, attr.size);\n } catch (e) {\n if (!e.code) {\n throw e;\n }\n throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n }\n }\n }\n\n public lookup(parent: EmscriptenFSNode, name: string): EmscriptenFSNode {\n const path = this.PATH.join2(this.fs.realPath(parent), name);\n const mode = this.fs.getMode(path);\n return this.fs.createNode(parent, name, mode);\n }\n\n public mknod(parent: EmscriptenFSNode, name: string, mode: number, dev: any): EmscriptenFSNode {\n const node = this.fs.createNode(parent, name, mode, dev);\n // create the backing node for this in the fs root as well\n const path = this.fs.realPath(node);\n try {\n if (this.FS.isDir(node.mode)) {\n this.nodefs.mkdirSync(path, node.mode);\n } else {\n this.nodefs.writeFileSync(path, '', { mode: node.mode });\n }\n } catch (e) {\n if (!e.code) {\n throw e;\n }\n throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n }\n return node;\n }\n\n public rename(oldNode: EmscriptenFSNode, newDir: EmscriptenFSNode, newName: string): void {\n const oldPath = this.fs.realPath(oldNode);\n const newPath = this.PATH.join2(this.fs.realPath(newDir), newName);\n try {\n this.nodefs.renameSync(oldPath, newPath);\n // This logic is missing from the original NodeFS,\n // causing Emscripten's filesystem to think that the old file still exists.\n oldNode.name = newName;\n oldNode.parent = newDir;\n } catch (e) {\n if (!e.code) {\n throw e;\n }\n throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n }\n }\n\n public unlink(parent: EmscriptenFSNode, name: string): void {\n const path = this.PATH.join2(this.fs.realPath(parent), name);\n try {\n this.nodefs.unlinkSync(path);\n } catch (e) {\n if (!e.code) {\n throw e;\n }\n throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n }\n }\n\n public rmdir(parent: EmscriptenFSNode, name: string) {\n const path = this.PATH.join2(this.fs.realPath(parent), name);\n try {\n this.nodefs.rmdirSync(path);\n } catch (e) {\n if (!e.code) {\n throw e;\n }\n throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n }\n }\n\n public readdir(node: EmscriptenFSNode): string[] {\n const path = this.fs.realPath(node);\n try {\n // Node does not list . and .. in directory listings,\n // but Emscripten expects it.\n const contents = this.nodefs.readdirSync(path);\n contents.push('.', '..');\n return contents;\n } catch (e) {\n if (!e.code) {\n throw e;\n }\n throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n }\n }\n\n public symlink(parent: EmscriptenFSNode, newName: string, oldPath: string): void {\n const newPath = this.PATH.join2(this.fs.realPath(parent), newName);\n try {\n this.nodefs.symlinkSync(oldPath, newPath);\n } catch (e) {\n if (!e.code) {\n throw e;\n }\n throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n }\n }\n\n public readlink(node: EmscriptenFSNode): string {\n const path = this.fs.realPath(node);\n try {\n return this.nodefs.readlinkSync(path);\n } catch (e) {\n if (!e.code) {\n throw e;\n }\n throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n }\n }\n}\n\nexport default class BFSEmscriptenFS implements EmscriptenFS {\n // This maps the integer permission modes from http://linux.die.net/man/3/open\n // to node.js-specific file open permission strings at http://nodejs.org/api/fs.html#fs_fs_open_path_flags_mode_callback\n public flagsToPermissionStringMap = {\n 0/*O_RDONLY*/: 'r',\n 1/*O_WRONLY*/: 'r+',\n 2/*O_RDWR*/: 'r+',\n 64/*O_CREAT*/: 'r',\n 65/*O_WRONLY|O_CREAT*/: 'r+',\n 66/*O_RDWR|O_CREAT*/: 'r+',\n 129/*O_WRONLY|O_EXCL*/: 'rx+',\n 193/*O_WRONLY|O_CREAT|O_EXCL*/: 'rx+',\n 514/*O_RDWR|O_TRUNC*/: 'w+',\n 577/*O_WRONLY|O_CREAT|O_TRUNC*/: 'w',\n 578/*O_CREAT|O_RDWR|O_TRUNC*/: 'w+',\n 705/*O_WRONLY|O_CREAT|O_EXCL|O_TRUNC*/: 'wx',\n 706/*O_RDWR|O_CREAT|O_EXCL|O_TRUNC*/: 'wx+',\n 1024/*O_APPEND*/: 'a',\n 1025/*O_WRONLY|O_APPEND*/: 'a',\n 1026/*O_RDWR|O_APPEND*/: 'a+',\n 1089/*O_WRONLY|O_CREAT|O_APPEND*/: 'a',\n 1090/*O_RDWR|O_CREAT|O_APPEND*/: 'a+',\n 1153/*O_WRONLY|O_EXCL|O_APPEND*/: 'ax',\n 1154/*O_RDWR|O_EXCL|O_APPEND*/: 'ax+',\n 1217/*O_WRONLY|O_CREAT|O_EXCL|O_APPEND*/: 'ax',\n 1218/*O_RDWR|O_CREAT|O_EXCL|O_APPEND*/: 'ax+',\n 4096/*O_RDONLY|O_DSYNC*/: 'rs',\n 4098/*O_RDWR|O_DSYNC*/: 'rs+'\n };\n /* tslint:disable:variable-name */\n public node_ops: EmscriptenNodeOps;\n public stream_ops: EmscriptenStreamOps;\n /* tslint:enable:variable-name */\n\n private FS: any;\n private PATH: any;\n private ERRNO_CODES: any;\n private nodefs: FS;\n constructor(_FS = ( self)['FS'], _PATH = ( self)['PATH'], _ERRNO_CODES = ( self)['ERRNO_CODES'], nodefs: FS = fs) {\n this.nodefs = nodefs;\n this.FS = _FS;\n this.PATH = _PATH;\n this.ERRNO_CODES = _ERRNO_CODES;\n this.node_ops = new BFSEmscriptenNodeOps(this);\n this.stream_ops = new BFSEmscriptenStreamOps(this);\n }\n\n public mount(m: {opts: {root: string}}): EmscriptenFSNode {\n return this.createNode(null, '/', this.getMode(m.opts.root), 0);\n }\n\n public createNode(parent: EmscriptenFSNode | null, name: string, mode: number, dev?: any): EmscriptenFSNode {\n const FS = this.FS;\n if (!FS.isDir(mode) && !FS.isFile(mode) && !FS.isLink(mode)) {\n throw new FS.ErrnoError(this.ERRNO_CODES.EINVAL);\n }\n const node = FS.createNode(parent, name, mode);\n node.node_ops = this.node_ops;\n node.stream_ops = this.stream_ops;\n return node;\n }\n\n public getMode(path: string): number {\n let stat: NodeStats;\n try {\n stat = this.nodefs.lstatSync(path);\n } catch (e) {\n if (!e.code) {\n throw e;\n }\n throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n }\n return stat.mode;\n }\n\n public realPath(node: EmscriptenFSNode): string {\n const parts: string[] = [];\n while (node.parent !== node) {\n parts.push(node.name);\n node = node.parent;\n }\n parts.push(node.mount.opts.root);\n parts.reverse();\n return this.PATH.join.apply(null, parts);\n }\n\n public flagsToPermissionString(flags: string | number): string {\n let parsedFlags = (typeof flags === \"string\") ? parseInt(flags, 10) : flags;\n parsedFlags &= 0x1FFF;\n if (parsedFlags in this.flagsToPermissionStringMap) {\n return ( this.flagsToPermissionStringMap)[parsedFlags];\n } else {\n return flags;\n }\n }\n\n public getNodeFS() {\n return this.nodefs;\n }\n\n public getFS() {\n return this.FS;\n }\n\n public getPATH() {\n return this.PATH;\n }\n\n public getERRNO_CODES() {\n return this.ERRNO_CODES;\n }\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../src/generic/emscripten_fs.ts","import {ApiError, ErrorCode} from './api_error';\nimport Stats from './node_fs_stats';\nimport {File} from './file';\nimport {FileFlag, ActionType} from './file_flag';\nimport * as path from 'path';\nimport {fail} from './util';\n\nexport type BFSOneArgCallback = (e?: ApiError | null) => any;\nexport type BFSCallback = (e: ApiError | null | undefined, rv?: T) => any;\nexport type BFSThreeArgCallback =\n (e: ApiError | null | undefined, arg1?: T, arg2?: U) => any;\n\n/**\n * Interface for a filesystem. **All** BrowserFS FileSystems should implement\n * this interface.\n *\n * Below, we denote each API method as **Core**, **Supplemental**, or\n * **Optional**.\n *\n * ### Core Methods\n *\n * **Core** API methods *need* to be implemented for basic read/write\n * functionality.\n *\n * Note that read-only FileSystems can choose to not implement core methods\n * that mutate files or metadata. The default implementation will pass a\n * NOT_SUPPORTED error to the callback.\n *\n * ### Supplemental Methods\n *\n * **Supplemental** API methods do not need to be implemented by a filesystem.\n * The default implementation implements all of the supplemental API methods in\n * terms of the **core** API methods.\n *\n * Note that a file system may choose to implement supplemental methods for\n * efficiency reasons.\n *\n * The code for some supplemental methods was adapted directly from NodeJS's\n * fs.js source code.\n *\n * ### Optional Methods\n *\n * **Optional** API methods provide functionality that may not be available in\n * all filesystems. For example, all symlink/hardlink-related API methods fall\n * under this category.\n *\n * The default implementation will pass a NOT_SUPPORTED error to the callback.\n *\n * ### Argument Assumptions\n *\n * You can assume the following about arguments passed to each API method:\n *\n * * **Every path is an absolute path.** Meaning, `.`, `..`, and other items\n * are resolved into an absolute form.\n * * **All arguments are present.** Any optional arguments at the Node API level\n * have been passed in with their default values.\n * * **The callback will reset the stack depth.** When your filesystem calls the\n * callback with the requested information, it will use `setImmediate` to\n * reset the JavaScript stack depth before calling the user-supplied callback.\n * @class FileSystem\n */\nexport interface FileSystem {\n /**\n * **Optional**: Returns the name of the file system.\n */\n getName(): string;\n /**\n * **Optional**: Passes the following information to the callback:\n *\n * * Total number of bytes available on this file system.\n * * number of free bytes available on this file system.\n *\n * @todo This info is not available through the Node API. Perhaps we could do a\n * polyfill of diskspace.js, or add a new Node API function.\n * @param path The path to the location that is being queried. Only\n * useful for filesystems that support mount points.\n */\n diskSpace(p: string, cb: (total: number, free: number) => any): void;\n /**\n * **Core**: Is this filesystem read-only?\n * @return True if this FileSystem is inherently read-only.\n */\n isReadOnly(): boolean;\n /**\n * **Core**: Does the filesystem support optional symlink/hardlink-related\n * commands?\n * @return True if the FileSystem supports the optional\n * symlink/hardlink-related commands.\n */\n supportsLinks(): boolean;\n /**\n * **Core**: Does the filesystem support optional property-related commands?\n * @return True if the FileSystem supports the optional\n * property-related commands (permissions, utimes, etc).\n */\n supportsProps(): boolean;\n /**\n * **Core**: Does the filesystem support the optional synchronous interface?\n * @return True if the FileSystem supports synchronous operations.\n */\n supportsSynch(): boolean;\n // **CORE API METHODS**\n // File or directory operations\n /**\n * **Core**: Asynchronous rename. No arguments other than a possible exception\n * are given to the completion callback.\n */\n rename(oldPath: string, newPath: string, cb: BFSOneArgCallback): void;\n /**\n * **Core**: Synchronous rename.\n */\n renameSync(oldPath: string, newPath: string): void;\n /**\n * **Core**: Asynchronous `stat` or `lstat`.\n * @param isLstat True if this is `lstat`, false if this is regular\n * `stat`.\n */\n stat(p: string, isLstat: boolean | null, cb: BFSCallback): void;\n /**\n * **Core**: Synchronous `stat` or `lstat`.\n * @param isLstat True if this is `lstat`, false if this is regular\n * `stat`.\n */\n statSync(p: string, isLstat: boolean | null): Stats;\n // File operations\n /**\n * **Core**: Asynchronous file open.\n * @see http://www.manpagez.com/man/2/open/\n * @param flags Handles the complexity of the various file\n * modes. See its API for more details.\n * @param mode Mode to use to open the file. Can be ignored if the\n * filesystem doesn't support permissions.\n */\n open(p: string, flag: FileFlag, mode: number, cb: BFSCallback): void;\n /**\n * **Core**: Synchronous file open.\n * @see http://www.manpagez.com/man/2/open/\n * @param flags Handles the complexity of the various file\n * modes. See its API for more details.\n * @param mode Mode to use to open the file. Can be ignored if the\n * filesystem doesn't support permissions.\n */\n openSync(p: string, flag: FileFlag, mode: number): File;\n /**\n * **Core**: Asynchronous `unlink`.\n */\n unlink(p: string, cb: BFSOneArgCallback): void;\n /**\n * **Core**: Synchronous `unlink`.\n */\n unlinkSync(p: string): void;\n // Directory operations\n /**\n * **Core**: Asynchronous `rmdir`.\n */\n rmdir(p: string, cb: BFSOneArgCallback): void;\n /**\n * **Core**: Synchronous `rmdir`.\n */\n rmdirSync(p: string): void;\n /**\n * **Core**: Asynchronous `mkdir`.\n * @param mode Mode to make the directory using. Can be ignored if\n * the filesystem doesn't support permissions.\n */\n mkdir(p: string, mode: number, cb: BFSOneArgCallback): void;\n /**\n * **Core**: Synchronous `mkdir`.\n * @param mode Mode to make the directory using. Can be ignored if\n * the filesystem doesn't support permissions.\n */\n mkdirSync(p: string, mode: number): void;\n /**\n * **Core**: Asynchronous `readdir`. Reads the contents of a directory.\n *\n * The callback gets two arguments `(err, files)` where `files` is an array of\n * the names of the files in the directory excluding `'.'` and `'..'`.\n */\n readdir(p: string, cb: BFSCallback): void;\n /**\n * **Core**: Synchronous `readdir`. Reads the contents of a directory.\n */\n readdirSync(p: string): string[];\n // **SUPPLEMENTAL INTERFACE METHODS**\n // File or directory operations\n /**\n * **Supplemental**: Test whether or not the given path exists by checking with\n * the file system. Then call the callback argument with either true or false.\n */\n exists(p: string, cb: (exists: boolean) => void): void;\n /**\n * **Supplemental**: Test whether or not the given path exists by checking with\n * the file system.\n */\n existsSync(p: string): boolean;\n /**\n * **Supplemental**: Asynchronous `realpath`. The callback gets two arguments\n * `(err, resolvedPath)`.\n *\n * Note that the Node API will resolve `path` to an absolute path.\n * @param cache An object literal of mapped paths that can be used to\n * force a specific path resolution or avoid additional `fs.stat` calls for\n * known real paths. If not supplied by the user, it'll be an empty object.\n */\n realpath(p: string, cache: {[path: string]: string}, cb: BFSCallback): void;\n /**\n * **Supplemental**: Synchronous `realpath`.\n *\n * Note that the Node API will resolve `path` to an absolute path.\n * @param cache An object literal of mapped paths that can be used to\n * force a specific path resolution or avoid additional `fs.stat` calls for\n * known real paths. If not supplied by the user, it'll be an empty object.\n */\n realpathSync(p: string, cache: {[path: string]: string}): string;\n // File operations\n /**\n * **Supplemental**: Asynchronous `truncate`.\n */\n truncate(p: string, len: number, cb: BFSOneArgCallback): void;\n /**\n * **Supplemental**: Synchronous `truncate`.\n */\n truncateSync(p: string, len: number): void;\n /**\n * **Supplemental**: Asynchronously reads the entire contents of a file.\n * @param encoding If non-null, the file's contents should be decoded\n * into a string using that encoding. Otherwise, if encoding is null, fetch\n * the file's contents as a Buffer.\n * @param cb If no encoding is specified, then the raw buffer is returned.\n */\n readFile(fname: string, encoding: string | null, flag: FileFlag, cb: BFSCallback): void;\n /**\n * **Supplemental**: Synchronously reads the entire contents of a file.\n * @param encoding If non-null, the file's contents should be decoded\n * into a string using that encoding. Otherwise, if encoding is null, fetch\n * the file's contents as a Buffer.\n */\n readFileSync(fname: string, encoding: string | null, flag: FileFlag): any;\n /**\n * **Supplemental**: Asynchronously writes data to a file, replacing the file\n * if it already exists.\n *\n * The encoding option is ignored if data is a buffer.\n */\n writeFile(fname: string, data: any, encoding: string | null, flag: FileFlag, mode: number, cb: BFSOneArgCallback): void;\n /**\n * **Supplemental**: Synchronously writes data to a file, replacing the file\n * if it already exists.\n *\n * The encoding option is ignored if data is a buffer.\n */\n writeFileSync(fname: string, data: string | Buffer, encoding: string | null, flag: FileFlag, mode: number): void;\n /**\n * **Supplemental**: Asynchronously append data to a file, creating the file if\n * it not yet exists.\n */\n appendFile(fname: string, data: string | Buffer, encoding: string | null, flag: FileFlag, mode: number, cb: BFSOneArgCallback): void;\n /**\n * **Supplemental**: Synchronously append data to a file, creating the file if\n * it not yet exists.\n */\n appendFileSync(fname: string, data: string | Buffer, encoding: string | null, flag: FileFlag, mode: number): void;\n // **OPTIONAL INTERFACE METHODS**\n // Property operations\n // This isn't always possible on some filesystem types (e.g. Dropbox).\n /**\n * **Optional**: Asynchronous `chmod` or `lchmod`.\n * @param isLchmod `True` if `lchmod`, false if `chmod`. Has no\n * bearing on result if links aren't supported.\n */\n chmod(p: string, isLchmod: boolean, mode: number, cb: BFSOneArgCallback): void;\n /**\n * **Optional**: Synchronous `chmod` or `lchmod`.\n * @param isLchmod `True` if `lchmod`, false if `chmod`. Has no\n * bearing on result if links aren't supported.\n */\n chmodSync(p: string, isLchmod: boolean, mode: number): void;\n /**\n * **Optional**: Asynchronous `chown` or `lchown`.\n * @param isLchown `True` if `lchown`, false if `chown`. Has no\n * bearing on result if links aren't supported.\n */\n chown(p: string, isLchown: boolean, uid: number, gid: number, cb: BFSOneArgCallback): void;\n /**\n * **Optional**: Synchronous `chown` or `lchown`.\n * @param isLchown `True` if `lchown`, false if `chown`. Has no\n * bearing on result if links aren't supported.\n */\n chownSync(p: string, isLchown: boolean, uid: number, gid: number): void;\n /**\n * **Optional**: Change file timestamps of the file referenced by the supplied\n * path.\n */\n utimes(p: string, atime: Date, mtime: Date, cb: BFSOneArgCallback): void;\n /**\n * **Optional**: Change file timestamps of the file referenced by the supplied\n * path.\n */\n utimesSync(p: string, atime: Date, mtime: Date): void;\n // Symlink operations\n // Symlinks aren't always supported.\n /**\n * **Optional**: Asynchronous `link`.\n */\n link(srcpath: string, dstpath: string, cb: BFSOneArgCallback): void;\n /**\n * **Optional**: Synchronous `link`.\n */\n linkSync(srcpath: string, dstpath: string): void;\n /**\n * **Optional**: Asynchronous `symlink`.\n * @param type can be either `'dir'` or `'file'`\n */\n symlink(srcpath: string, dstpath: string, type: string, cb: BFSOneArgCallback): void;\n /**\n * **Optional**: Synchronous `symlink`.\n * @param type can be either `'dir'` or `'file'`\n */\n symlinkSync(srcpath: string, dstpath: string, type: string): void;\n /**\n * **Optional**: Asynchronous readlink.\n */\n readlink(p: string, cb: BFSCallback): void;\n /**\n * **Optional**: Synchronous readlink.\n */\n readlinkSync(p: string): string;\n}\n\n/**\n * Contains typings for static functions on the file system constructor.\n */\nexport interface FileSystemConstructor {\n /**\n * **Core**: Returns 'true' if this filesystem is available in the current\n * environment. For example, a `localStorage`-backed filesystem will return\n * 'false' if the browser does not support that API.\n *\n * Defaults to 'false', as the FileSystem base class isn't usable alone.\n */\n isAvailable(): boolean;\n}\n\n/**\n * Basic filesystem class. Most filesystems should extend this class, as it\n * provides default implementations for a handful of methods.\n */\nexport class BaseFileSystem {\n public supportsLinks(): boolean {\n return false;\n }\n public diskSpace(p: string, cb: (total: number, free: number) => any): void {\n cb(0, 0);\n }\n /**\n * Opens the file at path p with the given flag. The file must exist.\n * @param p The path to open.\n * @param flag The flag to use when opening the file.\n */\n public openFile(p: string, flag: FileFlag, cb: BFSCallback): void {\n throw new ApiError(ErrorCode.ENOTSUP);\n }\n /**\n * Create the file at path p with the given mode. Then, open it with the given\n * flag.\n */\n public createFile(p: string, flag: FileFlag, mode: number, cb: BFSCallback): void {\n throw new ApiError(ErrorCode.ENOTSUP);\n }\n public open(p: string, flag: FileFlag, mode: number, cb: BFSCallback): void {\n const mustBeFile = (e: ApiError, stats?: Stats): void => {\n if (e) {\n // File does not exist.\n switch (flag.pathNotExistsAction()) {\n case ActionType.CREATE_FILE:\n // Ensure parent exists.\n return this.stat(path.dirname(p), false, (e: ApiError, parentStats?: Stats) => {\n if (e) {\n cb(e);\n } else if (parentStats && !parentStats.isDirectory()) {\n cb(ApiError.ENOTDIR(path.dirname(p)));\n } else {\n this.createFile(p, flag, mode, cb);\n }\n });\n case ActionType.THROW_EXCEPTION:\n return cb(ApiError.ENOENT(p));\n default:\n return cb(new ApiError(ErrorCode.EINVAL, 'Invalid FileFlag object.'));\n }\n } else {\n // File exists.\n if (stats && stats.isDirectory()) {\n return cb(ApiError.EISDIR(p));\n }\n switch (flag.pathExistsAction()) {\n case ActionType.THROW_EXCEPTION:\n return cb(ApiError.EEXIST(p));\n case ActionType.TRUNCATE_FILE:\n // NOTE: In a previous implementation, we deleted the file and\n // re-created it. However, this created a race condition if another\n // asynchronous request was trying to read the file, as the file\n // would not exist for a small period of time.\n return this.openFile(p, flag, (e: ApiError, fd?: File): void => {\n if (e) {\n cb(e);\n } else if (fd) {\n fd.truncate(0, () => {\n fd.sync(() => {\n cb(null, fd);\n });\n });\n } else {\n fail();\n }\n });\n case ActionType.NOP:\n return this.openFile(p, flag, cb);\n default:\n return cb(new ApiError(ErrorCode.EINVAL, 'Invalid FileFlag object.'));\n }\n }\n };\n this.stat(p, false, mustBeFile);\n }\n public rename(oldPath: string, newPath: string, cb: BFSOneArgCallback): void {\n cb(new ApiError(ErrorCode.ENOTSUP));\n }\n public renameSync(oldPath: string, newPath: string): void {\n throw new ApiError(ErrorCode.ENOTSUP);\n }\n public stat(p: string, isLstat: boolean | null, cb: BFSCallback): void {\n cb(new ApiError(ErrorCode.ENOTSUP));\n }\n public statSync(p: string, isLstat: boolean | null): Stats {\n throw new ApiError(ErrorCode.ENOTSUP);\n }\n /**\n * Opens the file at path p with the given flag. The file must exist.\n * @param p The path to open.\n * @param flag The flag to use when opening the file.\n * @return A File object corresponding to the opened file.\n */\n public openFileSync(p: string, flag: FileFlag, mode: number): File {\n throw new ApiError(ErrorCode.ENOTSUP);\n }\n /**\n * Create the file at path p with the given mode. Then, open it with the given\n * flag.\n */\n public createFileSync(p: string, flag: FileFlag, mode: number): File {\n throw new ApiError(ErrorCode.ENOTSUP);\n }\n public openSync(p: string, flag: FileFlag, mode: number): File {\n // Check if the path exists, and is a file.\n let stats: Stats;\n try {\n stats = this.statSync(p, false);\n } catch (e) {\n // File does not exist.\n switch (flag.pathNotExistsAction()) {\n case ActionType.CREATE_FILE:\n // Ensure parent exists.\n const parentStats = this.statSync(path.dirname(p), false);\n if (!parentStats.isDirectory()) {\n throw ApiError.ENOTDIR(path.dirname(p));\n }\n return this.createFileSync(p, flag, mode);\n case ActionType.THROW_EXCEPTION:\n throw ApiError.ENOENT(p);\n default:\n throw new ApiError(ErrorCode.EINVAL, 'Invalid FileFlag object.');\n }\n }\n\n // File exists.\n if (stats.isDirectory()) {\n throw ApiError.EISDIR(p);\n }\n switch (flag.pathExistsAction()) {\n case ActionType.THROW_EXCEPTION:\n throw ApiError.EEXIST(p);\n case ActionType.TRUNCATE_FILE:\n // Delete file.\n this.unlinkSync(p);\n // Create file. Use the same mode as the old file.\n // Node itself modifies the ctime when this occurs, so this action\n // will preserve that behavior if the underlying file system\n // supports those properties.\n return this.createFileSync(p, flag, stats.mode);\n case ActionType.NOP:\n return this.openFileSync(p, flag, mode);\n default:\n throw new ApiError(ErrorCode.EINVAL, 'Invalid FileFlag object.');\n }\n }\n public unlink(p: string, cb: BFSOneArgCallback): void {\n cb(new ApiError(ErrorCode.ENOTSUP));\n }\n public unlinkSync(p: string): void {\n throw new ApiError(ErrorCode.ENOTSUP);\n }\n public rmdir(p: string, cb: BFSOneArgCallback): void {\n cb(new ApiError(ErrorCode.ENOTSUP));\n }\n public rmdirSync(p: string): void {\n throw new ApiError(ErrorCode.ENOTSUP);\n }\n public mkdir(p: string, mode: number, cb: BFSOneArgCallback): void {\n cb(new ApiError(ErrorCode.ENOTSUP));\n }\n public mkdirSync(p: string, mode: number): void {\n throw new ApiError(ErrorCode.ENOTSUP);\n }\n public readdir(p: string, cb: BFSCallback): void {\n cb(new ApiError(ErrorCode.ENOTSUP));\n }\n public readdirSync(p: string): string[] {\n throw new ApiError(ErrorCode.ENOTSUP);\n }\n public exists(p: string, cb: (exists: boolean) => void): void {\n this.stat(p, null, function(err) {\n cb(!err);\n });\n }\n public existsSync(p: string): boolean {\n try {\n this.statSync(p, true);\n return true;\n } catch (e) {\n return false;\n }\n }\n public realpath(p: string, cache: {[path: string]: string}, cb: BFSCallback): void {\n if (this.supportsLinks()) {\n // The path could contain symlinks. Split up the path,\n // resolve any symlinks, return the resolved string.\n const splitPath = p.split(path.sep);\n // TODO: Simpler to just pass through file, find sep and such.\n for (let i = 0; i < splitPath.length; i++) {\n const addPaths = splitPath.slice(0, i + 1);\n splitPath[i] = path.join.apply(null, addPaths);\n }\n } else {\n // No symlinks. We just need to verify that it exists.\n this.exists(p, function(doesExist) {\n if (doesExist) {\n cb(null, p);\n } else {\n cb(ApiError.ENOENT(p));\n }\n });\n }\n }\n public realpathSync(p: string, cache: {[path: string]: string}): string {\n if (this.supportsLinks()) {\n // The path could contain symlinks. Split up the path,\n // resolve any symlinks, return the resolved string.\n const splitPath = p.split(path.sep);\n // TODO: Simpler to just pass through file, find sep and such.\n for (let i = 0; i < splitPath.length; i++) {\n const addPaths = splitPath.slice(0, i + 1);\n splitPath[i] = path.join.apply(path, addPaths);\n }\n return splitPath.join(path.sep);\n } else {\n // No symlinks. We just need to verify that it exists.\n if (this.existsSync(p)) {\n return p;\n } else {\n throw ApiError.ENOENT(p);\n }\n }\n }\n public truncate(p: string, len: number, cb: BFSOneArgCallback): void {\n this.open(p, FileFlag.getFileFlag('r+'), 0x1a4, (function(er: ApiError, fd?: File) {\n if (er) {\n return cb(er);\n }\n fd!.truncate(len, (function(er: any) {\n fd!.close((function(er2: any) {\n cb(er || er2);\n }));\n }));\n }));\n }\n public truncateSync(p: string, len: number): void {\n const fd = this.openSync(p, FileFlag.getFileFlag('r+'), 0x1a4);\n // Need to safely close FD, regardless of whether or not truncate succeeds.\n try {\n fd.truncateSync(len);\n } catch (e) {\n throw e;\n } finally {\n fd.closeSync();\n }\n }\n public readFile(fname: string, encoding: string | null, flag: FileFlag, cb: BFSCallback): void {\n // Wrap cb in file closing code.\n const oldCb = cb;\n // Get file.\n this.open(fname, flag, 0x1a4, (err, fd) => {\n if (err) {\n return cb(err);\n }\n cb = function(err?: ApiError | null, arg?: string | Buffer) {\n fd!.close(function(err2: any) {\n if (!err) {\n err = err2;\n }\n return oldCb(err, arg);\n });\n };\n fd!.stat((err, stat?) => {\n if (err) {\n return cb(err);\n }\n // Allocate buffer.\n const buf = new Buffer(stat!.size);\n fd!.read(buf, 0, stat!.size, 0, (err?: ApiError | null) => {\n if (err) {\n return cb(err);\n } else if (encoding === null) {\n return cb(err, buf);\n }\n try {\n cb(null, buf.toString(encoding));\n } catch (e) {\n cb(e);\n }\n });\n });\n });\n }\n public readFileSync(fname: string, encoding: string | null, flag: FileFlag): any {\n // Get file.\n const fd = this.openSync(fname, flag, 0x1a4);\n try {\n const stat = fd.statSync();\n // Allocate buffer.\n const buf = new Buffer(stat.size);\n fd.readSync(buf, 0, stat.size, 0);\n fd.closeSync();\n if (encoding === null) {\n return buf;\n }\n return buf.toString(encoding);\n } finally {\n fd.closeSync();\n }\n }\n public writeFile(fname: string, data: any, encoding: string | null, flag: FileFlag, mode: number, cb: BFSOneArgCallback): void {\n // Wrap cb in file closing code.\n const oldCb = cb;\n // Get file.\n this.open(fname, flag, 0x1a4, function(err: ApiError, fd?: File) {\n if (err) {\n return cb(err);\n }\n cb = function(err: ApiError) {\n fd!.close(function(err2: any) {\n oldCb(err ? err : err2);\n });\n };\n\n try {\n if (typeof data === 'string') {\n data = new Buffer(data, encoding!);\n }\n } catch (e) {\n return cb(e);\n }\n // Write into file.\n fd!.write(data, 0, data.length, 0, cb);\n });\n }\n public writeFileSync(fname: string, data: any, encoding: string | null, flag: FileFlag, mode: number): void {\n // Get file.\n const fd = this.openSync(fname, flag, mode);\n try {\n if (typeof data === 'string') {\n data = new Buffer(data, encoding!);\n }\n // Write into file.\n fd.writeSync(data, 0, data.length, 0);\n } finally {\n fd.closeSync();\n }\n }\n public appendFile(fname: string, data: any, encoding: string | null, flag: FileFlag, mode: number, cb: BFSOneArgCallback): void {\n // Wrap cb in file closing code.\n const oldCb = cb;\n this.open(fname, flag, mode, function(err: ApiError, fd?: File) {\n if (err) {\n return cb(err);\n }\n cb = function(err: ApiError) {\n fd!.close(function(err2: any) {\n oldCb(err ? err : err2);\n });\n };\n if (typeof data === 'string') {\n data = new Buffer(data, encoding!);\n }\n fd!.write(data, 0, data.length, null, cb);\n });\n }\n public appendFileSync(fname: string, data: any, encoding: string | null, flag: FileFlag, mode: number): void {\n const fd = this.openSync(fname, flag, mode);\n try {\n if (typeof data === 'string') {\n data = new Buffer(data, encoding!);\n }\n fd.writeSync(data, 0, data.length, null);\n } finally {\n fd.closeSync();\n }\n }\n public chmod(p: string, isLchmod: boolean, mode: number, cb: BFSOneArgCallback): void {\n cb(new ApiError(ErrorCode.ENOTSUP));\n }\n public chmodSync(p: string, isLchmod: boolean, mode: number) {\n throw new ApiError(ErrorCode.ENOTSUP);\n }\n public chown(p: string, isLchown: boolean, uid: number, gid: number, cb: BFSOneArgCallback): void {\n cb(new ApiError(ErrorCode.ENOTSUP));\n }\n public chownSync(p: string, isLchown: boolean, uid: number, gid: number): void {\n throw new ApiError(ErrorCode.ENOTSUP);\n }\n public utimes(p: string, atime: Date, mtime: Date, cb: BFSOneArgCallback): void {\n cb(new ApiError(ErrorCode.ENOTSUP));\n }\n public utimesSync(p: string, atime: Date, mtime: Date): void {\n throw new ApiError(ErrorCode.ENOTSUP);\n }\n public link(srcpath: string, dstpath: string, cb: BFSOneArgCallback): void {\n cb(new ApiError(ErrorCode.ENOTSUP));\n }\n public linkSync(srcpath: string, dstpath: string): void {\n throw new ApiError(ErrorCode.ENOTSUP);\n }\n public symlink(srcpath: string, dstpath: string, type: string, cb: BFSOneArgCallback): void {\n cb(new ApiError(ErrorCode.ENOTSUP));\n }\n public symlinkSync(srcpath: string, dstpath: string, type: string): void {\n throw new ApiError(ErrorCode.ENOTSUP);\n }\n public readlink(p: string, cb: BFSOneArgCallback): void {\n cb(new ApiError(ErrorCode.ENOTSUP));\n }\n public readlinkSync(p: string): string {\n throw new ApiError(ErrorCode.ENOTSUP);\n }\n}\n\n/**\n * Implements the asynchronous API in terms of the synchronous API.\n * @class SynchronousFileSystem\n */\nexport class SynchronousFileSystem extends BaseFileSystem {\n public supportsSynch(): boolean {\n return true;\n }\n\n public rename(oldPath: string, newPath: string, cb: BFSOneArgCallback): void {\n try {\n this.renameSync(oldPath, newPath);\n cb();\n } catch (e) {\n cb(e);\n }\n }\n\n public stat(p: string, isLstat: boolean | null, cb: BFSCallback): void {\n try {\n cb(null, this.statSync(p, isLstat));\n } catch (e) {\n cb(e);\n }\n }\n\n public open(p: string, flags: FileFlag, mode: number, cb: BFSCallback): void {\n try {\n cb(null, this.openSync(p, flags, mode));\n } catch (e) {\n cb(e);\n }\n }\n\n public unlink(p: string, cb: BFSOneArgCallback): void {\n try {\n this.unlinkSync(p);\n cb();\n } catch (e) {\n cb(e);\n }\n }\n\n public rmdir(p: string, cb: BFSOneArgCallback): void {\n try {\n this.rmdirSync(p);\n cb();\n } catch (e) {\n cb(e);\n }\n }\n\n public mkdir(p: string, mode: number, cb: BFSOneArgCallback): void {\n try {\n this.mkdirSync(p, mode);\n cb();\n } catch (e) {\n cb(e);\n }\n }\n\n public readdir(p: string, cb: BFSCallback): void {\n try {\n cb(null, this.readdirSync(p));\n } catch (e) {\n cb(e);\n }\n }\n\n public chmod(p: string, isLchmod: boolean, mode: number, cb: BFSOneArgCallback): void {\n try {\n this.chmodSync(p, isLchmod, mode);\n cb();\n } catch (e) {\n cb(e);\n }\n }\n\n public chown(p: string, isLchown: boolean, uid: number, gid: number, cb: BFSOneArgCallback): void {\n try {\n this.chownSync(p, isLchown, uid, gid);\n cb();\n } catch (e) {\n cb(e);\n }\n }\n\n public utimes(p: string, atime: Date, mtime: Date, cb: BFSOneArgCallback): void {\n try {\n this.utimesSync(p, atime, mtime);\n cb();\n } catch (e) {\n cb(e);\n }\n }\n\n public link(srcpath: string, dstpath: string, cb: BFSOneArgCallback): void {\n try {\n this.linkSync(srcpath, dstpath);\n cb();\n } catch (e) {\n cb(e);\n }\n }\n\n public symlink(srcpath: string, dstpath: string, type: string, cb: BFSOneArgCallback): void {\n try {\n this.symlinkSync(srcpath, dstpath, type);\n cb();\n } catch (e) {\n cb(e);\n }\n }\n\n public readlink(p: string, cb: BFSCallback): void {\n try {\n cb(null, this.readlinkSync(p));\n } catch (e) {\n cb(e);\n }\n }\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../src/core/file_system.ts","import {ApiError, ErrorCode} from './api_error';\nimport Stats from './node_fs_stats';\nimport {BFSCallback, BFSOneArgCallback, BFSThreeArgCallback} from './file_system';\n\nexport interface File {\n /**\n * **Core**: Get the current file position.\n */\n getPos(): number | undefined;\n /**\n * **Core**: Asynchronous `stat`.\n */\n stat(cb: BFSCallback): void;\n /**\n * **Core**: Synchronous `stat`.\n */\n statSync(): Stats;\n /**\n * **Core**: Asynchronous close.\n */\n close(cb: BFSOneArgCallback): void;\n /**\n * **Core**: Synchronous close.\n */\n closeSync(): void;\n /**\n * **Core**: Asynchronous truncate.\n */\n truncate(len: number, cb: BFSOneArgCallback): void;\n /**\n * **Core**: Synchronous truncate.\n */\n truncateSync(len: number): void;\n /**\n * **Core**: Asynchronous sync.\n */\n sync(cb: BFSOneArgCallback): void;\n /**\n * **Core**: Synchronous sync.\n */\n syncSync(): void;\n /**\n * **Core**: Write buffer to the file.\n * Note that it is unsafe to use fs.write multiple times on the same file\n * without waiting for the callback.\n * @param buffer Buffer containing the data to write to\n * the file.\n * @param offset Offset in the buffer to start reading data from.\n * @param length The amount of bytes to write to the file.\n * @param position Offset from the beginning of the file where this\n * data should be written. If position is null, the data will be written at\n * the current position.\n * @param cb The number specifies the number of bytes written into the file.\n */\n write(buffer: Buffer, offset: number, length: number, position: number | null, cb: BFSThreeArgCallback): void;\n /**\n * **Core**: Write buffer to the file.\n * Note that it is unsafe to use fs.writeSync multiple times on the same file\n * without waiting for it to return.\n * @param buffer Buffer containing the data to write to\n * the file.\n * @param offset Offset in the buffer to start reading data from.\n * @param length The amount of bytes to write to the file.\n * @param position Offset from the beginning of the file where this\n * data should be written. If position is null, the data will be written at\n * the current position.\n */\n writeSync(buffer: Buffer, offset: number, length: number, position: number | null): number;\n /**\n * **Core**: Read data from the file.\n * @param buffer The buffer that the data will be\n * written to.\n * @param offset The offset within the buffer where writing will\n * start.\n * @param length An integer specifying the number of bytes to read.\n * @param position An integer specifying where to begin reading from\n * in the file. If position is null, data will be read from the current file\n * position.\n * @param cb The number is the number of bytes read\n */\n read(buffer: Buffer, offset: number, length: number, position: number | null, cb: BFSThreeArgCallback): void;\n /**\n * **Core**: Read data from the file.\n * @param buffer The buffer that the data will be written to.\n * @param offset The offset within the buffer where writing will start.\n * @param length An integer specifying the number of bytes to read.\n * @param position An integer specifying where to begin reading from\n * in the file. If position is null, data will be read from the current file\n * position.\n */\n readSync(buffer: Buffer, offset: number, length: number, position: number): number;\n /**\n * **Supplementary**: Asynchronous `datasync`.\n *\n * Default implementation maps to `sync`.\n */\n datasync(cb: BFSOneArgCallback): void;\n /**\n * **Supplementary**: Synchronous `datasync`.\n *\n * Default implementation maps to `syncSync`.\n */\n datasyncSync(): void;\n /**\n * **Optional**: Asynchronous `chown`.\n */\n chown(uid: number, gid: number, cb: BFSOneArgCallback): void;\n /**\n * **Optional**: Synchronous `chown`.\n */\n chownSync(uid: number, gid: number): void;\n /**\n * **Optional**: Asynchronous `fchmod`.\n */\n chmod(mode: number, cb: BFSOneArgCallback): void;\n /**\n * **Optional**: Synchronous `fchmod`.\n */\n chmodSync(mode: number): void;\n /**\n * **Optional**: Change the file timestamps of the file.\n */\n utimes(atime: Date, mtime: Date, cb: BFSOneArgCallback): void;\n /**\n * **Optional**: Change the file timestamps of the file.\n */\n utimesSync(atime: Date, mtime: Date): void;\n}\n\n/**\n * Base class that contains shared implementations of functions for the file\n * object.\n */\nexport class BaseFile {\n public sync(cb: BFSOneArgCallback): void {\n cb(new ApiError(ErrorCode.ENOTSUP));\n }\n public syncSync(): void {\n throw new ApiError(ErrorCode.ENOTSUP);\n }\n public datasync(cb: BFSOneArgCallback): void {\n this.sync(cb);\n }\n public datasyncSync(): void {\n return this.syncSync();\n }\n public chown(uid: number, gid: number, cb: BFSOneArgCallback): void {\n cb(new ApiError(ErrorCode.ENOTSUP));\n }\n public chownSync(uid: number, gid: number): void {\n throw new ApiError(ErrorCode.ENOTSUP);\n }\n public chmod(mode: number, cb: BFSOneArgCallback): void {\n cb(new ApiError(ErrorCode.ENOTSUP));\n }\n public chmodSync(mode: number): void {\n throw new ApiError(ErrorCode.ENOTSUP);\n }\n public utimes(atime: Date, mtime: Date, cb: BFSOneArgCallback): void {\n cb(new ApiError(ErrorCode.ENOTSUP));\n }\n public utimesSync(atime: Date, mtime: Date): void {\n throw new ApiError(ErrorCode.ENOTSUP);\n }\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../src/core/file.ts","import {BaseFile, File} from '../core/file';\nimport {FileSystem, BFSOneArgCallback, BFSCallback, BFSThreeArgCallback} from '../core/file_system';\nimport Stats from '../core/node_fs_stats';\nimport {FileFlag} from '../core/file_flag';\nimport {ApiError, ErrorCode} from '../core/api_error';\nimport fs from '../core/node_fs';\n\n/**\n * An implementation of the File interface that operates on a file that is\n * completely in-memory. PreloadFiles are backed by a Buffer.\n *\n * This is also an abstract class, as it lacks an implementation of 'sync' and\n * 'close'. Each filesystem that wishes to use this file representation must\n * extend this class and implement those two methods.\n * @todo 'close' lever that disables functionality once closed.\n */\nexport default class PreloadFile extends BaseFile {\n protected _fs: T;\n private _pos: number = 0;\n private _path: string;\n private _stat: Stats;\n private _flag: FileFlag;\n private _buffer: Buffer;\n private _dirty: boolean = false;\n /**\n * Creates a file with the given path and, optionally, the given contents. Note\n * that, if contents is specified, it will be mutated by the file!\n * @param _fs The file system that created the file.\n * @param _path\n * @param _mode The mode that the file was opened using.\n * Dictates permissions and where the file pointer starts.\n * @param _stat The stats object for the given file.\n * PreloadFile will mutate this object. Note that this object must contain\n * the appropriate mode that the file was opened as.\n * @param contents A buffer containing the entire\n * contents of the file. PreloadFile will mutate this buffer. If not\n * specified, we assume it is a new file.\n */\n constructor(_fs: T, _path: string, _flag: FileFlag, _stat: Stats, contents?: Buffer) {\n super();\n this._fs = _fs;\n this._path = _path;\n this._flag = _flag;\n this._stat = _stat;\n if (contents) {\n this._buffer = contents;\n } else {\n // Empty buffer. It'll expand once we write stuff to it.\n this._buffer = new Buffer(0);\n }\n // Note: This invariant is *not* maintained once the file starts getting\n // modified.\n // Note: Only actually matters if file is readable, as writeable modes may\n // truncate/append to file.\n if (this._stat.size !== this._buffer.length && this._flag.isReadable()) {\n throw new Error(`Invalid buffer: Buffer is ${this._buffer.length} long, yet Stats object specifies that file is ${this._stat.size} long.`);\n }\n }\n\n /**\n * NONSTANDARD: Get the underlying buffer for this file. !!DO NOT MUTATE!! Will mess up dirty tracking.\n */\n public getBuffer(): Buffer {\n return this._buffer;\n }\n\n /**\n * NONSTANDARD: Get underlying stats for this file. !!DO NOT MUTATE!!\n */\n public getStats(): Stats {\n return this._stat;\n }\n\n public getFlag(): FileFlag {\n return this._flag;\n }\n\n /**\n * Get the path to this file.\n * @return [String] The path to the file.\n */\n public getPath(): string {\n return this._path;\n }\n\n /**\n * Get the current file position.\n *\n * We emulate the following bug mentioned in the Node documentation:\n * > On Linux, positional writes don't work when the file is opened in append\n * mode. The kernel ignores the position argument and always appends the data\n * to the end of the file.\n * @return [Number] The current file position.\n */\n public getPos(): number {\n if (this._flag.isAppendable()) {\n return this._stat.size;\n }\n return this._pos;\n }\n\n /**\n * Advance the current file position by the indicated number of positions.\n * @param [Number] delta\n */\n public advancePos(delta: number): number {\n return this._pos += delta;\n }\n\n /**\n * Set the file position.\n * @param [Number] newPos\n */\n public setPos(newPos: number): number {\n return this._pos = newPos;\n }\n\n /**\n * **Core**: Asynchronous sync. Must be implemented by subclasses of this\n * class.\n * @param [Function(BrowserFS.ApiError)] cb\n */\n public sync(cb: BFSOneArgCallback): void {\n try {\n this.syncSync();\n cb();\n } catch (e) {\n cb(e);\n }\n }\n\n /**\n * **Core**: Synchronous sync.\n */\n public syncSync(): void {\n throw new ApiError(ErrorCode.ENOTSUP);\n }\n\n /**\n * **Core**: Asynchronous close. Must be implemented by subclasses of this\n * class.\n * @param [Function(BrowserFS.ApiError)] cb\n */\n public close(cb: BFSOneArgCallback): void {\n try {\n this.closeSync();\n cb();\n } catch (e) {\n cb(e);\n }\n }\n\n /**\n * **Core**: Synchronous close.\n */\n public closeSync(): void {\n throw new ApiError(ErrorCode.ENOTSUP);\n }\n\n /**\n * Asynchronous `stat`.\n * @param [Function(BrowserFS.ApiError, BrowserFS.node.fs.Stats)] cb\n */\n public stat(cb: BFSCallback): void {\n try {\n cb(null, this._stat.clone());\n } catch (e) {\n cb(e);\n }\n }\n\n /**\n * Synchronous `stat`.\n */\n public statSync(): Stats {\n return this._stat.clone();\n }\n\n /**\n * Asynchronous truncate.\n * @param [Number] len\n * @param [Function(BrowserFS.ApiError)] cb\n */\n public truncate(len: number, cb: BFSOneArgCallback): void {\n try {\n this.truncateSync(len);\n if (this._flag.isSynchronous() && !fs.getRootFS()!.supportsSynch()) {\n this.sync(cb);\n }\n cb();\n } catch (e) {\n return cb(e);\n }\n }\n\n /**\n * Synchronous truncate.\n * @param [Number] len\n */\n public truncateSync(len: number): void {\n this._dirty = true;\n if (!this._flag.isWriteable()) {\n throw new ApiError(ErrorCode.EPERM, 'File not opened with a writeable mode.');\n }\n this._stat.mtime = new Date();\n if (len > this._buffer.length) {\n const buf = new Buffer(len - this._buffer.length);\n buf.fill(0);\n // Write will set @_stat.size for us.\n this.writeSync(buf, 0, buf.length, this._buffer.length);\n if (this._flag.isSynchronous() && fs.getRootFS()!.supportsSynch()) {\n this.syncSync();\n }\n return;\n }\n this._stat.size = len;\n // Truncate buffer to 'len'.\n const newBuff = new Buffer(len);\n this._buffer.copy(newBuff, 0, 0, len);\n this._buffer = newBuff;\n if (this._flag.isSynchronous() && fs.getRootFS()!.supportsSynch()) {\n this.syncSync();\n }\n }\n\n /**\n * Write buffer to the file.\n * Note that it is unsafe to use fs.write multiple times on the same file\n * without waiting for the callback.\n * @param [BrowserFS.node.Buffer] buffer Buffer containing the data to write to\n * the file.\n * @param [Number] offset Offset in the buffer to start reading data from.\n * @param [Number] length The amount of bytes to write to the file.\n * @param [Number] position Offset from the beginning of the file where this\n * data should be written. If position is null, the data will be written at\n * the current position.\n * @param [Function(BrowserFS.ApiError, Number, BrowserFS.node.Buffer)]\n * cb The number specifies the number of bytes written into the file.\n */\n public write(buffer: Buffer, offset: number, length: number, position: number, cb: BFSThreeArgCallback): void {\n try {\n cb(null, this.writeSync(buffer, offset, length, position), buffer);\n } catch (e) {\n cb(e);\n }\n }\n\n /**\n * Write buffer to the file.\n * Note that it is unsafe to use fs.writeSync multiple times on the same file\n * without waiting for the callback.\n * @param [BrowserFS.node.Buffer] buffer Buffer containing the data to write to\n * the file.\n * @param [Number] offset Offset in the buffer to start reading data from.\n * @param [Number] length The amount of bytes to write to the file.\n * @param [Number] position Offset from the beginning of the file where this\n * data should be written. If position is null, the data will be written at\n * the current position.\n * @return [Number]\n */\n public writeSync(buffer: Buffer, offset: number, length: number, position: number): number {\n this._dirty = true;\n if (position === undefined || position === null) {\n position = this.getPos();\n }\n if (!this._flag.isWriteable()) {\n throw new ApiError(ErrorCode.EPERM, 'File not opened with a writeable mode.');\n }\n const endFp = position + length;\n if (endFp > this._stat.size) {\n this._stat.size = endFp;\n if (endFp > this._buffer.length) {\n // Extend the buffer!\n const newBuff = new Buffer(endFp);\n this._buffer.copy(newBuff);\n this._buffer = newBuff;\n }\n }\n const len = buffer.copy(this._buffer, position, offset, offset + length);\n this._stat.mtime = new Date();\n if (this._flag.isSynchronous()) {\n this.syncSync();\n return len;\n }\n this.setPos(position + len);\n return len;\n }\n\n /**\n * Read data from the file.\n * @param [BrowserFS.node.Buffer] buffer The buffer that the data will be\n * written to.\n * @param [Number] offset The offset within the buffer where writing will\n * start.\n * @param [Number] length An integer specifying the number of bytes to read.\n * @param [Number] position An integer specifying where to begin reading from\n * in the file. If position is null, data will be read from the current file\n * position.\n * @param [Function(BrowserFS.ApiError, Number, BrowserFS.node.Buffer)] cb The\n * number is the number of bytes read\n */\n public read(buffer: Buffer, offset: number, length: number, position: number, cb: BFSThreeArgCallback): void {\n try {\n cb(null, this.readSync(buffer, offset, length, position), buffer);\n } catch (e) {\n cb(e);\n }\n }\n\n /**\n * Read data from the file.\n * @param [BrowserFS.node.Buffer] buffer The buffer that the data will be\n * written to.\n * @param [Number] offset The offset within the buffer where writing will\n * start.\n * @param [Number] length An integer specifying the number of bytes to read.\n * @param [Number] position An integer specifying where to begin reading from\n * in the file. If position is null, data will be read from the current file\n * position.\n * @return [Number]\n */\n public readSync(buffer: Buffer, offset: number, length: number, position: number): number {\n if (!this._flag.isReadable()) {\n throw new ApiError(ErrorCode.EPERM, 'File not opened with a readable mode.');\n }\n if (position === undefined || position === null) {\n position = this.getPos();\n }\n const endRead = position + length;\n if (endRead > this._stat.size) {\n length = this._stat.size - position;\n }\n const rv = this._buffer.copy(buffer, offset, position, position + length);\n this._stat.atime = new Date();\n this._pos = position + length;\n return rv;\n }\n\n /**\n * Asynchronous `fchmod`.\n * @param [Number|String] mode\n * @param [Function(BrowserFS.ApiError)] cb\n */\n public chmod(mode: number, cb: BFSOneArgCallback): void {\n try {\n this.chmodSync(mode);\n cb();\n } catch (e) {\n cb(e);\n }\n }\n\n /**\n * Asynchronous `fchmod`.\n * @param [Number] mode\n */\n public chmodSync(mode: number): void {\n if (!this._fs.supportsProps()) {\n throw new ApiError(ErrorCode.ENOTSUP);\n }\n this._dirty = true;\n this._stat.chmod(mode);\n this.syncSync();\n }\n\n protected isDirty(): boolean {\n return this._dirty;\n }\n\n /**\n * Resets the dirty bit. Should only be called after a sync has completed successfully.\n */\n protected resetDirty() {\n this._dirty = false;\n }\n}\n\n/**\n * File class for the InMemory and XHR file systems.\n * Doesn't sync to anything, so it works nicely for memory-only files.\n */\nexport class NoSyncFile extends PreloadFile implements File {\n constructor(_fs: T, _path: string, _flag: FileFlag, _stat: Stats, contents?: Buffer) {\n super(_fs, _path, _flag, _stat, contents);\n }\n /**\n * Asynchronous sync. Doesn't do anything, simply calls the cb.\n * @param [Function(BrowserFS.ApiError)] cb\n */\n public sync(cb: BFSOneArgCallback): void {\n cb();\n }\n /**\n * Synchronous sync. Doesn't do anything.\n */\n public syncSync(): void {\n // NOP.\n }\n /**\n * Asynchronous close. Doesn't do anything, simply calls the cb.\n * @param [Function(BrowserFS.ApiError)] cb\n */\n public close(cb: BFSOneArgCallback): void {\n cb();\n }\n /**\n * Synchronous close. Doesn't do anything.\n */\n public closeSync(): void {\n // NOP.\n }\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../src/generic/preload_file.ts","import {FileSystem, SynchronousFileSystem, BFSOneArgCallback} from '../core/file_system';\nimport {ApiError, ErrorCode} from '../core/api_error';\nimport {FileFlag} from '../core/file_flag';\nimport {File} from '../core/file';\nimport Stats from '../core/node_fs_stats';\nimport PreloadFile from '../generic/preload_file';\nimport * as path from 'path';\n\ninterface IAsyncOperation {\n apiMethod: string;\n arguments: any[];\n}\n\n/**\n * We define our own file to interpose on syncSync() for mirroring purposes.\n */\nclass MirrorFile extends PreloadFile implements File {\n constructor(fs: AsyncMirror, path: string, flag: FileFlag, stat: Stats, data: Buffer) {\n super(fs, path, flag, stat, data);\n }\n\n public syncSync(): void {\n if (this.isDirty()) {\n this._fs._syncSync(this);\n this.resetDirty();\n }\n }\n\n public closeSync(): void {\n this.syncSync();\n }\n}\n\n/**\n * AsyncMirrorFS mirrors a synchronous filesystem into an asynchronous filesystem\n * by:\n * * Performing operations over the in-memory copy, while asynchronously pipelining them\n * to the backing store.\n * * During application loading, the contents of the async file system can be reloaded into\n * the synchronous store, if desired.\n * The two stores will be kept in sync. The most common use-case is to pair a synchronous\n * in-memory filesystem with an asynchronous backing store.\n */\nexport default class AsyncMirror extends SynchronousFileSystem implements FileSystem {\n public static isAvailable(): boolean {\n return true;\n }\n\n /**\n * Queue of pending asynchronous operations.\n */\n private _queue: IAsyncOperation[] = [];\n private _queueRunning: boolean = false;\n private _sync: FileSystem;\n private _async: FileSystem;\n private _isInitialized: boolean = false;\n private _initializeCallbacks: ((e?: ApiError) => void)[] = [];\n constructor(sync: FileSystem, async: FileSystem) {\n super();\n this._sync = sync;\n this._async = async;\n if (!sync.supportsSynch()) {\n throw new Error(\"The first argument to AsyncMirror needs to be a synchronous file system.\");\n }\n }\n\n public getName(): string {\n return \"AsyncMirror\";\n }\n\n public _syncSync(fd: PreloadFile) {\n this._sync.writeFileSync(fd.getPath(), fd.getBuffer(), null, FileFlag.getFileFlag('w'), fd.getStats().mode);\n this.enqueueOp({\n apiMethod: 'writeFile',\n arguments: [fd.getPath(), fd.getBuffer(), null, fd.getFlag(), fd.getStats().mode]\n });\n }\n\n /**\n * Called once to load up files from async storage into sync storage.\n */\n public initialize(userCb: BFSOneArgCallback): void {\n const callbacks = this._initializeCallbacks;\n\n const end = (e?: ApiError): void => {\n this._isInitialized = !e;\n this._initializeCallbacks = [];\n callbacks.forEach((cb) => cb(e));\n };\n\n if (!this._isInitialized) {\n // First call triggers initialization, the rest wait.\n if (callbacks.push(userCb) === 1) {\n const copyDirectory = (p: string, mode: number, cb: BFSOneArgCallback) => {\n if (p !== '/') {\n this._sync.mkdirSync(p, mode);\n }\n this._async.readdir(p, (err, files) => {\n let i = 0;\n // NOTE: This function must not be in a lexically nested statement,\n // such as an if or while statement. Safari refuses to run the\n // script since it is undefined behavior.\n function copyNextFile(err?: ApiError) {\n if (err) {\n cb(err);\n } else if (i < files!.length) {\n copyItem(path.join(p, files![i]), copyNextFile);\n i++;\n } else {\n cb();\n }\n }\n if (err) {\n cb(err);\n } else {\n copyNextFile();\n }\n });\n }, copyFile = (p: string, mode: number, cb: BFSOneArgCallback) => {\n this._async.readFile(p, null, FileFlag.getFileFlag('r'), (err, data) => {\n if (err) {\n cb(err);\n } else {\n try {\n this._sync.writeFileSync(p, data!, null, FileFlag.getFileFlag('w'), mode);\n } catch (e) {\n err = e;\n } finally {\n cb(err);\n }\n }\n });\n }, copyItem = (p: string, cb: BFSOneArgCallback) => {\n this._async.stat(p, false, (err, stats) => {\n if (err) {\n cb(err);\n } else if (stats!.isDirectory()) {\n copyDirectory(p, stats!.mode, cb);\n } else {\n copyFile(p, stats!.mode, cb);\n }\n });\n };\n copyDirectory('/', 0, end);\n }\n } else {\n userCb();\n }\n }\n\n public isReadOnly(): boolean { return false; }\n public supportsSynch(): boolean { return true; }\n public supportsLinks(): boolean { return false; }\n public supportsProps(): boolean { return this._sync.supportsProps() && this._async.supportsProps(); }\n\n public renameSync(oldPath: string, newPath: string): void {\n this.checkInitialized();\n this._sync.renameSync(oldPath, newPath);\n this.enqueueOp({\n apiMethod: 'rename',\n arguments: [oldPath, newPath]\n });\n }\n\n public statSync(p: string, isLstat: boolean): Stats {\n this.checkInitialized();\n return this._sync.statSync(p, isLstat);\n }\n\n public openSync(p: string, flag: FileFlag, mode: number): File {\n this.checkInitialized();\n // Sanity check: Is this open/close permitted?\n const fd = this._sync.openSync(p, flag, mode);\n fd.closeSync();\n return new MirrorFile(this, p, flag, this._sync.statSync(p, false), this._sync.readFileSync(p, null, FileFlag.getFileFlag('r')));\n }\n\n public unlinkSync(p: string): void {\n this.checkInitialized();\n this._sync.unlinkSync(p);\n this.enqueueOp({\n apiMethod: 'unlink',\n arguments: [p]\n });\n }\n\n public rmdirSync(p: string): void {\n this.checkInitialized();\n this._sync.rmdirSync(p);\n this.enqueueOp({\n apiMethod: 'rmdir',\n arguments: [p]\n });\n }\n\n public mkdirSync(p: string, mode: number): void {\n this.checkInitialized();\n this._sync.mkdirSync(p, mode);\n this.enqueueOp({\n apiMethod: 'mkdir',\n arguments: [p, mode]\n });\n }\n\n public readdirSync(p: string): string[] {\n this.checkInitialized();\n return this._sync.readdirSync(p);\n }\n\n public existsSync(p: string): boolean {\n this.checkInitialized();\n return this._sync.existsSync(p);\n }\n\n public chmodSync(p: string, isLchmod: boolean, mode: number): void {\n this.checkInitialized();\n this._sync.chmodSync(p, isLchmod, mode);\n this.enqueueOp({\n apiMethod: 'chmod',\n arguments: [p, isLchmod, mode]\n });\n }\n\n public chownSync(p: string, isLchown: boolean, uid: number, gid: number): void {\n this.checkInitialized();\n this._sync.chownSync(p, isLchown, uid, gid);\n this.enqueueOp({\n apiMethod: 'chown',\n arguments: [p, isLchown, uid, gid]\n });\n }\n\n public utimesSync(p: string, atime: Date, mtime: Date): void {\n this.checkInitialized();\n this._sync.utimesSync(p, atime, mtime);\n this.enqueueOp({\n apiMethod: 'utimes',\n arguments: [p, atime, mtime]\n });\n }\n\n private checkInitialized(): void {\n if (!this._isInitialized) {\n throw new ApiError(ErrorCode.EPERM, \"AsyncMirrorFS is not initialized. Please initialize AsyncMirrorFS using its initialize() method before using it.\");\n }\n }\n\n private enqueueOp(op: IAsyncOperation) {\n this._queue.push(op);\n if (!this._queueRunning) {\n this._queueRunning = true;\n const doNextOp = (err?: ApiError) => {\n if (err) {\n console.error(`WARNING: File system has desynchronized. Received following error: ${err}\\n$`);\n }\n if (this._queue.length > 0) {\n const op = this._queue.shift()!,\n args = op.arguments;\n args.push(doNextOp);\n ( ( this._async)[op.apiMethod]).apply(this._async, args);\n } else {\n this._queueRunning = false;\n }\n };\n doNextOp();\n }\n }\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../src/backend/AsyncMirror.ts","import rest from './rest';\n\nexport default function (fn) {\n return rest(function (args/*..., callback*/) {\n var callback = args.pop();\n fn.call(this, args, callback);\n });\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/async-es/internal/initialParams.js","/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\nexport default freeGlobal;\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/lodash-es/_freeGlobal.js","import freeGlobal from './_freeGlobal.js';\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = freeGlobal || freeSelf || Function('return this')();\n\nexport default root;\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/lodash-es/_root.js","import root from './_root.js';\n\n/** Built-in value references. */\nvar Symbol = root.Symbol;\n\nexport default Symbol;\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/lodash-es/_Symbol.js","var iteratorSymbol = typeof Symbol === 'function' && Symbol.iterator;\n\nexport default function (coll) {\n return iteratorSymbol && coll[iteratorSymbol] && coll[iteratorSymbol]();\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/async-es/internal/getIterator.js","import baseIsArguments from './_baseIsArguments.js';\nimport isObjectLike from './isObjectLike.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Built-in value references. */\nvar propertyIsEnumerable = objectProto.propertyIsEnumerable;\n\n/**\n * Checks if `value` is likely an `arguments` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n * else `false`.\n * @example\n *\n * _.isArguments(function() { return arguments; }());\n * // => true\n *\n * _.isArguments([1, 2, 3]);\n * // => false\n */\nvar isArguments = baseIsArguments(function() { return arguments; }()) ? baseIsArguments : function(value) {\n return isObjectLike(value) && hasOwnProperty.call(value, 'callee') &&\n !propertyIsEnumerable.call(value, 'callee');\n};\n\nexport default isArguments;\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/lodash-es/isArguments.js","/**\n * Checks if `value` is classified as an `Array` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array, else `false`.\n * @example\n *\n * _.isArray([1, 2, 3]);\n * // => true\n *\n * _.isArray(document.body.children);\n * // => false\n *\n * _.isArray('abc');\n * // => false\n *\n * _.isArray(_.noop);\n * // => false\n */\nvar isArray = Array.isArray;\n\nexport default isArray;\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/lodash-es/isArray.js","import root from './_root.js';\nimport stubFalse from './stubFalse.js';\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined;\n\n/**\n * Checks if `value` is a buffer.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a buffer, else `false`.\n * @example\n *\n * _.isBuffer(new Buffer(2));\n * // => true\n *\n * _.isBuffer(new Uint8Array(2));\n * // => false\n */\nvar isBuffer = nativeIsBuffer || stubFalse;\n\nexport default isBuffer;\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/lodash-es/isBuffer.js","import freeGlobal from './_freeGlobal.js';\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Detect free variable `process` from Node.js. */\nvar freeProcess = moduleExports && freeGlobal.process;\n\n/** Used to access faster Node.js helpers. */\nvar nodeUtil = (function() {\n try {\n return freeProcess && freeProcess.binding && freeProcess.binding('util');\n } catch (e) {}\n}());\n\nexport default nodeUtil;\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/lodash-es/_nodeUtil.js","import baseIsTypedArray from './_baseIsTypedArray.js';\nimport baseUnary from './_baseUnary.js';\nimport nodeUtil from './_nodeUtil.js';\n\n/* Node.js helper references. */\nvar nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray;\n\n/**\n * Checks if `value` is classified as a typed array.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n * @example\n *\n * _.isTypedArray(new Uint8Array);\n * // => true\n *\n * _.isTypedArray([]);\n * // => false\n */\nvar isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray;\n\nexport default isTypedArray;\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/lodash-es/isTypedArray.js","import overArg from './_overArg.js';\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeKeys = overArg(Object.keys, Object);\n\nexport default nativeKeys;\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/lodash-es/_nativeKeys.js","// A temporary value used to identify if the loop should be broken.\n// See #1064, #1293\nexport default {};\n\n\n// WEBPACK FOOTER //\n// ../../../../~/async-es/internal/breakLoop.js","import doParallel from './internal/doParallel';\nimport map from './internal/map';\n\n/**\n * Produces a new collection of values by mapping each value in `coll` through\n * the `iteratee` function. The `iteratee` is called with an item from `coll`\n * and a callback for when it has finished processing. Each of these callback\n * takes 2 arguments: an `error`, and the transformed item from `coll`. If\n * `iteratee` passes an error to its callback, the main `callback` (for the\n * `map` function) is immediately called with the error.\n *\n * Note, that since this function applies the `iteratee` to each item in\n * parallel, there is no guarantee that the `iteratee` functions will complete\n * in order. However, the results array will be in the same order as the\n * original `coll`.\n *\n * If `map` is passed an Object, the results will be an Array. The results\n * will roughly be in the order of the original Objects' keys (but this can\n * vary across JavaScript engines)\n *\n * @name map\n * @static\n * @memberOf module:Collections\n * @method\n * @category Collection\n * @param {Array|Iterable|Object} coll - A collection to iterate over.\n * @param {Function} iteratee - A function to apply to each item in `coll`.\n * The iteratee is passed a `callback(err, transformed)` which must be called\n * once it has completed with an error (which can be `null`) and a\n * transformed item. Invoked with (item, callback).\n * @param {Function} [callback] - A callback which is called when all `iteratee`\n * functions have finished, or an error occurs. Results is an Array of the\n * transformed items from the `coll`. Invoked with (err, results).\n * @example\n *\n * async.map(['file1','file2','file3'], fs.stat, function(err, results) {\n * // results is now an array of stats for each file\n * });\n */\nexport default doParallel(map);\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/async-es/map.js","import applyEach from './internal/applyEach';\nimport map from './map';\n\n/**\n * Applies the provided arguments to each function in the array, calling\n * `callback` after all functions have completed. If you only provide the first\n * argument, `fns`, then it will return a function which lets you pass in the\n * arguments as if it were a single function call. If more arguments are\n * provided, `callback` is required while `args` is still optional.\n *\n * @name applyEach\n * @static\n * @memberOf module:ControlFlow\n * @method\n * @category Control Flow\n * @param {Array|Iterable|Object} fns - A collection of asynchronous functions\n * to all call with the same arguments\n * @param {...*} [args] - any number of separate arguments to pass to the\n * function.\n * @param {Function} [callback] - the final argument should be the callback,\n * called when all functions have completed processing.\n * @returns {Function} - If only the first argument, `fns`, is provided, it will\n * return a function which lets you pass in the arguments as if it were a single\n * function call. The signature is `(..args, callback)`. If invoked with any\n * arguments, `callback` is required.\n * @example\n *\n * async.applyEach([enableSearch, updateSchema], 'bucket', callback);\n *\n * // partial application example:\n * async.each(\n * buckets,\n * async.applyEach([enableSearch, updateSchema]),\n * callback\n * );\n */\nexport default applyEach(map);\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/async-es/applyEach.js","import doParallelLimit from './internal/doParallelLimit';\nimport map from './internal/map';\n\n/**\n * The same as [`map`]{@link module:Collections.map} but runs a maximum of `limit` async operations at a time.\n *\n * @name mapLimit\n * @static\n * @memberOf module:Collections\n * @method\n * @see [async.map]{@link module:Collections.map}\n * @category Collection\n * @param {Array|Iterable|Object} coll - A collection to iterate over.\n * @param {number} limit - The maximum number of async operations at a time.\n * @param {Function} iteratee - A function to apply to each item in `coll`.\n * The iteratee is passed a `callback(err, transformed)` which must be called\n * once it has completed with an error (which can be `null`) and a transformed\n * item. Invoked with (item, callback).\n * @param {Function} [callback] - A callback which is called when all `iteratee`\n * functions have finished, or an error occurs. Results is an array of the\n * transformed items from the `coll`. Invoked with (err, results).\n */\nexport default doParallelLimit(map);\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/async-es/mapLimit.js","import mapLimit from './mapLimit';\nimport doLimit from './internal/doLimit';\n\n/**\n * The same as [`map`]{@link module:Collections.map} but runs only a single async operation at a time.\n *\n * @name mapSeries\n * @static\n * @memberOf module:Collections\n * @method\n * @see [async.map]{@link module:Collections.map}\n * @category Collection\n * @param {Array|Iterable|Object} coll - A collection to iterate over.\n * @param {Function} iteratee - A function to apply to each item in `coll`.\n * The iteratee is passed a `callback(err, transformed)` which must be called\n * once it has completed with an error (which can be `null`) and a\n * transformed item. Invoked with (item, callback).\n * @param {Function} [callback] - A callback which is called when all `iteratee`\n * functions have finished, or an error occurs. Results is an array of the\n * transformed items from the `coll`. Invoked with (err, results).\n */\nexport default doLimit(mapLimit, 1);\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/async-es/mapSeries.js","import applyEach from './internal/applyEach';\nimport mapSeries from './mapSeries';\n\n/**\n * The same as [`applyEach`]{@link module:ControlFlow.applyEach} but runs only a single async operation at a time.\n *\n * @name applyEachSeries\n * @static\n * @memberOf module:ControlFlow\n * @method\n * @see [async.applyEach]{@link module:ControlFlow.applyEach}\n * @category Control Flow\n * @param {Array|Iterable|Object} fns - A collection of asynchronous functions to all\n * call with the same arguments\n * @param {...*} [args] - any number of separate arguments to pass to the\n * function.\n * @param {Function} [callback] - the final argument should be the callback,\n * called when all functions have completed processing.\n * @returns {Function} - If only the first argument is provided, it will return\n * a function which lets you pass in the arguments as if it were a single\n * function call.\n */\nexport default applyEach(mapSeries);\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/async-es/applyEachSeries.js","import rest from './internal/rest';\n\n/**\n * Creates a continuation function with some arguments already applied.\n *\n * Useful as a shorthand when combined with other control flow functions. Any\n * arguments passed to the returned function are added to the arguments\n * originally passed to apply.\n *\n * @name apply\n * @static\n * @memberOf module:Utils\n * @method\n * @category Util\n * @param {Function} function - The function you want to eventually apply all\n * arguments to. Invokes with (arguments...).\n * @param {...*} arguments... - Any number of arguments to automatically apply\n * when the continuation is called.\n * @example\n *\n * // using apply\n * async.parallel([\n * async.apply(fs.writeFile, 'testfile1', 'test1'),\n * async.apply(fs.writeFile, 'testfile2', 'test2')\n * ]);\n *\n *\n * // the same process without using apply\n * async.parallel([\n * function(callback) {\n * fs.writeFile('testfile1', 'test1', callback);\n * },\n * function(callback) {\n * fs.writeFile('testfile2', 'test2', callback);\n * }\n * ]);\n *\n * // It's possible to pass any number of additional arguments when calling the\n * // continuation:\n *\n * node> var fn = async.apply(sys.puts, 'one');\n * node> fn('two', 'three');\n * one\n * two\n * three\n */\nexport default rest(function(fn, args) {\n return rest(function(callArgs) {\n return fn.apply(null, args.concat(callArgs));\n });\n});\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/async-es/apply.js","import createBaseFor from './_createBaseFor.js';\n\n/**\n * The base implementation of `baseForOwn` which iterates over `object`\n * properties returned by `keysFunc` and invokes `iteratee` for each property.\n * Iteratee functions may exit iteration early by explicitly returning `false`.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @returns {Object} Returns `object`.\n */\nvar baseFor = createBaseFor();\n\nexport default baseFor;\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/lodash-es/_baseFor.js","/** Used to compose unicode character classes. */\nvar rsAstralRange = '\\\\ud800-\\\\udfff',\n rsComboMarksRange = '\\\\u0300-\\\\u036f',\n reComboHalfMarksRange = '\\\\ufe20-\\\\ufe2f',\n rsComboSymbolsRange = '\\\\u20d0-\\\\u20ff',\n rsComboRange = rsComboMarksRange + reComboHalfMarksRange + rsComboSymbolsRange,\n rsVarRange = '\\\\ufe0e\\\\ufe0f';\n\n/** Used to compose unicode capture groups. */\nvar rsAstral = '[' + rsAstralRange + ']',\n rsCombo = '[' + rsComboRange + ']',\n rsFitz = '\\\\ud83c[\\\\udffb-\\\\udfff]',\n rsModifier = '(?:' + rsCombo + '|' + rsFitz + ')',\n rsNonAstral = '[^' + rsAstralRange + ']',\n rsRegional = '(?:\\\\ud83c[\\\\udde6-\\\\uddff]){2}',\n rsSurrPair = '[\\\\ud800-\\\\udbff][\\\\udc00-\\\\udfff]',\n rsZWJ = '\\\\u200d';\n\n/** Used to compose unicode regexes. */\nvar reOptMod = rsModifier + '?',\n rsOptVar = '[' + rsVarRange + ']?',\n rsOptJoin = '(?:' + rsZWJ + '(?:' + [rsNonAstral, rsRegional, rsSurrPair].join('|') + ')' + rsOptVar + reOptMod + ')*',\n rsSeq = rsOptVar + reOptMod + rsOptJoin,\n rsSymbol = '(?:' + [rsNonAstral + rsCombo + '?', rsCombo, rsRegional, rsSurrPair, rsAstral].join('|') + ')';\n\n/** Used to match [string symbols](https://mathiasbynens.be/notes/javascript-unicode). */\nvar reUnicode = RegExp(rsFitz + '(?=' + rsFitz + ')|' + rsSymbol + rsSeq, 'g');\n\n/**\n * Converts a Unicode `string` to an array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the converted array.\n */\nfunction unicodeToArray(string) {\n return string.match(reUnicode) || [];\n}\n\nexport default unicodeToArray;\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/lodash-es/_unicodeToArray.js","import eachOfLimit from './eachOfLimit';\nimport doLimit from './internal/doLimit';\n\n/**\n * The same as [`eachOf`]{@link module:Collections.eachOf} but runs only a single async operation at a time.\n *\n * @name eachOfSeries\n * @static\n * @memberOf module:Collections\n * @method\n * @see [async.eachOf]{@link module:Collections.eachOf}\n * @alias forEachOfSeries\n * @category Collection\n * @param {Array|Iterable|Object} coll - A collection to iterate over.\n * @param {Function} iteratee - A function to apply to each item in `coll`. The\n * `key` is the item's key, or index in the case of an array. The iteratee is\n * passed a `callback(err)` which must be called once it has completed. If no\n * error has occurred, the callback should be run without arguments or with an\n * explicit `null` argument. Invoked with (item, key, callback).\n * @param {Function} [callback] - A callback which is called when all `iteratee`\n * functions have finished, or an error occurs. Invoked with (err).\n */\nexport default doLimit(eachOfLimit, 1);\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/async-es/eachOfSeries.js","import noop from 'lodash-es/noop';\nimport rest from './internal/rest';\nimport reduce from './reduce';\n\n/**\n * Version of the compose function that is more natural to read. Each function\n * consumes the return value of the previous function. It is the equivalent of\n * [compose]{@link module:ControlFlow.compose} with the arguments reversed.\n *\n * Each function is executed with the `this` binding of the composed function.\n *\n * @name seq\n * @static\n * @memberOf module:ControlFlow\n * @method\n * @see [async.compose]{@link module:ControlFlow.compose}\n * @category Control Flow\n * @param {...Function} functions - the asynchronous functions to compose\n * @returns {Function} a function that composes the `functions` in order\n * @example\n *\n * // Requires lodash (or underscore), express3 and dresende's orm2.\n * // Part of an app, that fetches cats of the logged user.\n * // This example uses `seq` function to avoid overnesting and error\n * // handling clutter.\n * app.get('/cats', function(request, response) {\n * var User = request.models.User;\n * async.seq(\n * _.bind(User.get, User), // 'User.get' has signature (id, callback(err, data))\n * function(user, fn) {\n * user.getCats(fn); // 'getCats' has signature (callback(err, data))\n * }\n * )(req.session.user_id, function (err, cats) {\n * if (err) {\n * console.error(err);\n * response.json({ status: 'error', message: err.message });\n * } else {\n * response.json({ status: 'ok', message: 'Cats found', data: cats });\n * }\n * });\n * });\n */\nexport default rest(function seq(functions) {\n return rest(function(args) {\n var that = this;\n\n var cb = args[args.length - 1];\n if (typeof cb == 'function') {\n args.pop();\n } else {\n cb = noop;\n }\n\n reduce(functions, args, function(newargs, fn, cb) {\n fn.apply(that, newargs.concat([rest(function(err, nextargs) {\n cb(err, nextargs);\n })]));\n },\n function(err, results) {\n cb.apply(that, [err].concat(results));\n });\n });\n})\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/async-es/seq.js","import seq from './seq';\nimport rest from './internal/rest';\n\n/**\n * Creates a function which is a composition of the passed asynchronous\n * functions. Each function consumes the return value of the function that\n * follows. Composing functions `f()`, `g()`, and `h()` would produce the result\n * of `f(g(h()))`, only this version uses callbacks to obtain the return values.\n *\n * Each function is executed with the `this` binding of the composed function.\n *\n * @name compose\n * @static\n * @memberOf module:ControlFlow\n * @method\n * @category Control Flow\n * @param {...Function} functions - the asynchronous functions to compose\n * @returns {Function} an asynchronous function that is the composed\n * asynchronous `functions`\n * @example\n *\n * function add1(n, callback) {\n * setTimeout(function () {\n * callback(null, n + 1);\n * }, 10);\n * }\n *\n * function mul3(n, callback) {\n * setTimeout(function () {\n * callback(null, n * 3);\n * }, 10);\n * }\n *\n * var add1mul3 = async.compose(mul3, add1);\n * add1mul3(4, function (err, result) {\n * // result now equals 15\n * });\n */\nexport default rest(function(args) {\n return seq.apply(null, args.reverse());\n});\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/async-es/compose.js","import rest from './internal/rest';\nimport initialParams from './internal/initialParams';\n\n/**\n * Returns a function that when called, calls-back with the values provided.\n * Useful as the first function in a [`waterfall`]{@link module:ControlFlow.waterfall}, or for plugging values in to\n * [`auto`]{@link module:ControlFlow.auto}.\n *\n * @name constant\n * @static\n * @memberOf module:Utils\n * @method\n * @category Util\n * @param {...*} arguments... - Any number of arguments to automatically invoke\n * callback with.\n * @returns {Function} Returns a function that when invoked, automatically\n * invokes the callback with the previous given arguments.\n * @example\n *\n * async.waterfall([\n * async.constant(42),\n * function (value, next) {\n * // value === 42\n * },\n * //...\n * ], callback);\n *\n * async.waterfall([\n * async.constant(filename, \"utf8\"),\n * fs.readFile,\n * function (fileData, next) {\n * //...\n * }\n * //...\n * ], callback);\n *\n * async.auto({\n * hostname: async.constant(\"https://server.net/\"),\n * port: findFreePort,\n * launchServer: [\"hostname\", \"port\", function (options, cb) {\n * startServer(options, cb);\n * }],\n * //...\n * }, callback);\n */\nexport default rest(function(values) {\n var args = [null].concat(values);\n return initialParams(function (ignoredArgs, callback) {\n return callback.apply(this, args);\n });\n});\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/async-es/constant.js","import consoleFunc from './internal/consoleFunc';\n\n/**\n * Logs the result of an `async` function to the `console` using `console.dir`\n * to display the properties of the resulting object. Only works in Node.js or\n * in browsers that support `console.dir` and `console.error` (such as FF and\n * Chrome). If multiple arguments are returned from the async function,\n * `console.dir` is called on each argument in order.\n *\n * @name dir\n * @static\n * @memberOf module:Utils\n * @method\n * @category Util\n * @param {Function} function - The function you want to eventually apply all\n * arguments to.\n * @param {...*} arguments... - Any number of arguments to apply to the function.\n * @example\n *\n * // in a module\n * var hello = function(name, callback) {\n * setTimeout(function() {\n * callback(null, {hello: name});\n * }, 1000);\n * };\n *\n * // in the node repl\n * node> async.dir(hello, 'world');\n * {hello: 'world'}\n */\nexport default consoleFunc('dir');\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/async-es/dir.js","import consoleFunc from './internal/consoleFunc';\n\n/**\n * Logs the result of an `async` function to the `console`. Only works in\n * Node.js or in browsers that support `console.log` and `console.error` (such\n * as FF and Chrome). If multiple arguments are returned from the async\n * function, `console.log` is called on each argument in order.\n *\n * @name log\n * @static\n * @memberOf module:Utils\n * @method\n * @category Util\n * @param {Function} function - The function you want to eventually apply all\n * arguments to.\n * @param {...*} arguments... - Any number of arguments to apply to the function.\n * @example\n *\n * // in a module\n * var hello = function(name, callback) {\n * setTimeout(function() {\n * callback(null, 'hello ' + name);\n * }, 1000);\n * };\n *\n * // in the node repl\n * node> async.log(hello, 'world');\n * 'hello world'\n */\nexport default consoleFunc('log');\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/async-es/log.js","'use strict';\n\nimport { hasNextTick, hasSetImmediate, fallback, wrap } from './internal/setImmediate';\n\n/**\n * Calls `callback` on a later loop around the event loop. In Node.js this just\n * calls `setImmediate`. In the browser it will use `setImmediate` if\n * available, otherwise `setTimeout(callback, 0)`, which means other higher\n * priority events may precede the execution of `callback`.\n *\n * This is used internally for browser-compatibility purposes.\n *\n * @name nextTick\n * @static\n * @memberOf module:Utils\n * @method\n * @alias setImmediate\n * @category Util\n * @param {Function} callback - The function to call on a later loop around\n * the event loop. Invoked with (args...).\n * @param {...*} args... - any number of additional arguments to pass to the\n * callback on the next tick.\n * @example\n *\n * var call_order = [];\n * async.nextTick(function() {\n * call_order.push('two');\n * // call_order now equals ['one','two']\n * });\n * call_order.push('one');\n *\n * async.setImmediate(function (a, b, c) {\n * // a, b, and c equal 1, 2, and 3\n * }, 1, 2, 3);\n */\nvar _defer;\n\nif (hasNextTick) {\n _defer = process.nextTick;\n} else if (hasSetImmediate) {\n _defer = setImmediate;\n} else {\n _defer = fallback;\n}\n\nexport default wrap(_defer);\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/async-es/nextTick.js","/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeCeil = Math.ceil,\n nativeMax = Math.max;\n\n/**\n * The base implementation of `_.range` and `_.rangeRight` which doesn't\n * coerce arguments.\n *\n * @private\n * @param {number} start The start of the range.\n * @param {number} end The end of the range.\n * @param {number} step The value to increment or decrement by.\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Array} Returns the range of numbers.\n */\nfunction baseRange(start, end, step, fromRight) {\n var index = -1,\n length = nativeMax(nativeCeil((end - start) / (step || 1)), 0),\n result = Array(length);\n\n while (length--) {\n result[fromRight ? length : ++index] = start;\n start += step;\n }\n return result;\n}\n\nexport default baseRange;\n\n\n\n// WEBPACK FOOTER //\n// ../../../../~/lodash-es/_baseRange.js","import {default as Stats, FileType} from '../core/node_fs_stats';\n\n/**\n * Generic inode definition that can easily be serialized.\n */\nexport default class Inode {\n /**\n * Converts the buffer into an Inode.\n */\n public static fromBuffer(buffer: Buffer): Inode {\n if (buffer === undefined) {\n throw new Error(\"NO\");\n }\n return new Inode(buffer.toString('ascii', 30),\n buffer.readUInt32LE(0),\n buffer.readUInt16LE(4),\n buffer.readDoubleLE(6),\n buffer.readDoubleLE(14),\n buffer.readDoubleLE(22)\n );\n }\n\n constructor(public id: string,\n public size: number,\n public mode: number,\n public atime: number,\n public mtime: number,\n public ctime: number) { }\n\n /**\n * Handy function that converts the Inode to a Node Stats object.\n */\n public toStats(): Stats {\n return new Stats(\n (this.mode & 0xF000) === FileType.DIRECTORY ? FileType.DIRECTORY : FileType.FILE,\n this.size, this.mode, new Date(this.atime), new Date(this.mtime), new Date(this.ctime));\n }\n\n /**\n * Get the size of this Inode, in bytes.\n */\n public getSize(): number {\n // ASSUMPTION: ID is ASCII (1 byte per char).\n return 30 + this.id.length;\n }\n\n /**\n * Writes the inode into the start of the buffer.\n */\n public toBuffer(buff: Buffer = new Buffer(this.getSize())): Buffer {\n buff.writeUInt32LE(this.size, 0);\n buff.writeUInt16LE(this.mode, 4);\n buff.writeDoubleLE(this.atime, 6);\n buff.writeDoubleLE(this.mtime, 14);\n buff.writeDoubleLE(this.ctime, 22);\n buff.write(this.id, 30, this.id.length, 'ascii');\n return buff;\n }\n\n /**\n * Updates the Inode using information from the stats object. Used by file\n * systems at sync time, e.g.:\n * - Program opens file and gets a File object.\n * - Program mutates file. File object is responsible for maintaining\n * metadata changes locally -- typically in a Stats object.\n * - Program closes file. File object's metadata changes are synced with the\n * file system.\n * @return True if any changes have occurred.\n */\n public update(stats: Stats): boolean {\n let hasChanged = false;\n if (this.size !== stats.size) {\n this.size = stats.size;\n hasChanged = true;\n }\n\n if (this.mode !== stats.mode) {\n this.mode = stats.mode;\n hasChanged = true;\n }\n\n const atimeMs = stats.atime.getTime();\n if (this.atime !== atimeMs) {\n this.atime = atimeMs;\n hasChanged = true;\n }\n\n const mtimeMs = stats.mtime.getTime();\n if (this.mtime !== mtimeMs) {\n this.mtime = mtimeMs;\n hasChanged = true;\n }\n\n const ctimeMs = stats.ctime.getTime();\n if (this.ctime !== ctimeMs) {\n this.ctime = ctimeMs;\n hasChanged = true;\n }\n\n return hasChanged;\n }\n\n // XXX: Copied from Stats. Should reconcile these two into something more\n // compact.\n\n /**\n * @return [Boolean] True if this item is a file.\n */\n public isFile(): boolean {\n return (this.mode & 0xF000) === FileType.FILE;\n }\n\n /**\n * @return [Boolean] True if this item is a directory.\n */\n public isDirectory(): boolean {\n return (this.mode & 0xF000) === FileType.DIRECTORY;\n }\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../src/generic/inode.ts","import {SyncKeyValueStore, SimpleSyncStore, SimpleSyncRWTransaction, SyncKeyValueRWTransaction, SyncKeyValueFileSystem} from '../generic/key_value_filesystem';\n\n/**\n * A simple in-memory key-value store backed by a JavaScript object.\n */\nexport class InMemoryStore implements SyncKeyValueStore, SimpleSyncStore {\n private store: { [key: string]: Buffer } = {};\n\n public name() { return 'In-memory'; }\n public clear() { this.store = {}; }\n\n public beginTransaction(type: string): SyncKeyValueRWTransaction {\n return new SimpleSyncRWTransaction(this);\n }\n\n public get(key: string): Buffer {\n return this.store[key];\n }\n\n public put(key: string, data: Buffer, overwrite: boolean): boolean {\n if (!overwrite && this.store.hasOwnProperty(key)) {\n return false;\n }\n this.store[key] = data;\n return true;\n }\n\n public del(key: string): void {\n delete this.store[key];\n }\n}\n\n/**\n * A simple in-memory file system backed by an InMemoryStore.\n */\nexport default class InMemoryFileSystem extends SyncKeyValueFileSystem {\n constructor() {\n super({ store: new InMemoryStore() });\n }\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../src/backend/InMemory.ts","import {SyncKeyValueStore, SimpleSyncStore, SyncKeyValueFileSystem, SimpleSyncRWTransaction, SyncKeyValueRWTransaction} from '../generic/key_value_filesystem';\nimport {ApiError, ErrorCode} from '../core/api_error';\nimport global from '../core/global';\n\n// Some versions of FF and all versions of IE do not support the full range of\n// 16-bit numbers encoded as characters, as they enforce UTF-16 restrictions.\n// http://stackoverflow.com/questions/11170716/are-there-any-characters-that-are-not-allowed-in-localstorage/11173673#11173673\nlet supportsBinaryString: boolean = false,\n binaryEncoding: string;\ntry {\n global.localStorage.setItem(\"__test__\", String.fromCharCode(0xD800));\n supportsBinaryString = global.localStorage.getItem(\"__test__\") === String.fromCharCode(0xD800);\n} catch (e) {\n // IE throws an exception.\n supportsBinaryString = false;\n}\nbinaryEncoding = supportsBinaryString ? 'binary_string' : 'binary_string_ie';\nif (!Buffer.isEncoding(binaryEncoding)) {\n // Fallback for non BrowserFS implementations of buffer that lack a\n // binary_string format.\n binaryEncoding = \"base64\";\n}\n\n/**\n * A synchronous key-value store backed by localStorage.\n */\nexport class LocalStorageStore implements SyncKeyValueStore, SimpleSyncStore {\n public name(): string {\n return 'LocalStorage';\n }\n\n public clear(): void {\n global.localStorage.clear();\n }\n\n public beginTransaction(type: string): SyncKeyValueRWTransaction {\n // No need to differentiate.\n return new SimpleSyncRWTransaction(this);\n }\n\n public get(key: string): Buffer | undefined {\n try {\n const data = global.localStorage.getItem(key);\n if (data !== null) {\n return new Buffer(data, binaryEncoding);\n }\n } catch (e) {\n // Do nothing.\n }\n // Key doesn't exist, or a failure occurred.\n return undefined;\n }\n\n public put(key: string, data: Buffer, overwrite: boolean): boolean {\n try {\n if (!overwrite && global.localStorage.getItem(key) !== null) {\n // Don't want to overwrite the key!\n return false;\n }\n global.localStorage.setItem(key, data.toString(binaryEncoding));\n return true;\n } catch (e) {\n throw new ApiError(ErrorCode.ENOSPC, \"LocalStorage is full.\");\n }\n }\n\n public del(key: string): void {\n try {\n global.localStorage.removeItem(key);\n } catch (e) {\n throw new ApiError(ErrorCode.EIO, \"Unable to delete key \" + key + \": \" + e);\n }\n }\n}\n\n/**\n * A synchronous file system backed by localStorage. Connects our\n * LocalStorageStore to our SyncKeyValueFileSystem.\n */\nexport default class LocalStorageFileSystem extends SyncKeyValueFileSystem {\n public static isAvailable(): boolean {\n return typeof global.localStorage !== 'undefined';\n }\n constructor() { super({ store: new LocalStorageStore() }); }\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../src/backend/LocalStorage.ts","declare var setImmediate: (cb: Function) => void;\n\n/**\n * Non-recursive mutex\n */\nexport default class Mutex {\n private _locked: boolean = false;\n private _waiters: Function[] = [];\n\n public lock(cb: Function): void {\n if (this._locked) {\n this._waiters.push(cb);\n return;\n }\n this._locked = true;\n cb();\n }\n\n public unlock(): void {\n if (!this._locked) {\n throw new Error('unlock of a non-locked mutex');\n }\n\n const next = this._waiters.shift();\n // don't unlock - we want to queue up next for the\n // _end_ of the current task execution, but we don't\n // want it to be called inline with whatever the\n // current stack is. This way we still get the nice\n // behavior that an unlock immediately followed by a\n // lock won't cause starvation.\n if (next) {\n setImmediate(next);\n return;\n }\n\n this._locked = false;\n }\n\n public tryLock(): boolean {\n if (this._locked) {\n return false;\n }\n\n this._locked = true;\n return true;\n }\n\n public isLocked(): boolean {\n return this._locked;\n }\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../src/generic/mutex.ts","import Mutex from './mutex';\nimport {FileSystem, BFSOneArgCallback, BFSCallback} from '../core/file_system';\nimport {ApiError} from '../core/api_error';\nimport {FileFlag} from '../core/file_flag';\nimport {default as Stats} from '../core/node_fs_stats';\nimport {File} from '../core/file';\n\n/**\n * This class serializes access to an underlying async filesystem.\n * For example, on an OverlayFS instance with an async lower\n * directory operations like rename and rmdir may involve multiple\n * requests involving both the upper and lower filesystems -- they\n * are not executed in a single atomic step. OverlayFS uses this\n * LockedFS to avoid having to reason about the correctness of\n * multiple requests interleaving.\n */\nexport default class LockedFS implements FileSystem {\n private _fs: T;\n private _mu: Mutex;\n\n constructor(fs: T) {\n this._fs = fs;\n this._mu = new Mutex();\n }\n\n public getName(): string {\n return 'LockedFS<' + this._fs.getName() + '>';\n }\n\n public getFSUnlocked(): T {\n return this._fs;\n }\n\n public initialize(cb: BFSOneArgCallback): void {\n // FIXME: check to see if FS supports initialization\n ( this._fs).initialize(cb);\n }\n\n public diskSpace(p: string, cb: (total: number, free: number) => any): void {\n // FIXME: should this lock?\n this._fs.diskSpace(p, cb);\n }\n\n public isReadOnly(): boolean {\n return this._fs.isReadOnly();\n }\n\n public supportsLinks(): boolean {\n return this._fs.supportsLinks();\n }\n\n public supportsProps(): boolean {\n return this._fs.supportsProps();\n }\n\n public supportsSynch(): boolean {\n return this._fs.supportsSynch();\n }\n\n public rename(oldPath: string, newPath: string, cb: BFSOneArgCallback): void {\n this._mu.lock(() => {\n this._fs.rename(oldPath, newPath, (err?: ApiError) => {\n this._mu.unlock();\n cb(err);\n });\n });\n }\n\n public renameSync(oldPath: string, newPath: string): void {\n if (this._mu.isLocked()) {\n throw new Error('invalid sync call');\n }\n return this._fs.renameSync(oldPath, newPath);\n }\n\n public stat(p: string, isLstat: boolean, cb: BFSCallback): void {\n this._mu.lock(() => {\n this._fs.stat(p, isLstat, (err?: ApiError, stat?: Stats) => {\n this._mu.unlock();\n cb(err, stat);\n });\n });\n }\n\n public statSync(p: string, isLstat: boolean): Stats {\n if (this._mu.isLocked()) {\n throw new Error('invalid sync call');\n }\n return this._fs.statSync(p, isLstat);\n }\n\n public open(p: string, flag: FileFlag, mode: number, cb: BFSCallback): void {\n this._mu.lock(() => {\n this._fs.open(p, flag, mode, (err?: ApiError, fd?: File) => {\n this._mu.unlock();\n cb(err, fd);\n });\n });\n }\n\n public openSync(p: string, flag: FileFlag, mode: number): File {\n if (this._mu.isLocked()) {\n throw new Error('invalid sync call');\n }\n return this._fs.openSync(p, flag, mode);\n }\n\n public unlink(p: string, cb: BFSOneArgCallback): void {\n this._mu.lock(() => {\n this._fs.unlink(p, (err?: ApiError) => {\n this._mu.unlock();\n cb(err);\n });\n });\n }\n\n public unlinkSync(p: string): void {\n if (this._mu.isLocked()) {\n throw new Error('invalid sync call');\n }\n return this._fs.unlinkSync(p);\n }\n\n public rmdir(p: string, cb: BFSOneArgCallback): void {\n this._mu.lock(() => {\n this._fs.rmdir(p, (err?: ApiError) => {\n this._mu.unlock();\n cb(err);\n });\n });\n }\n\n public rmdirSync(p: string): void {\n if (this._mu.isLocked()) {\n throw new Error('invalid sync call');\n }\n return this._fs.rmdirSync(p);\n }\n\n public mkdir(p: string, mode: number, cb: BFSOneArgCallback): void {\n this._mu.lock(() => {\n this._fs.mkdir(p, mode, (err?: ApiError) => {\n this._mu.unlock();\n cb(err);\n });\n });\n }\n\n public mkdirSync(p: string, mode: number): void {\n if (this._mu.isLocked()) {\n throw new Error('invalid sync call');\n }\n return this._fs.mkdirSync(p, mode);\n }\n\n public readdir(p: string, cb: BFSCallback): void {\n this._mu.lock(() => {\n this._fs.readdir(p, (err?: ApiError, files?: string[]) => {\n this._mu.unlock();\n cb(err, files);\n });\n });\n }\n\n public readdirSync(p: string): string[] {\n if (this._mu.isLocked()) {\n throw new Error('invalid sync call');\n }\n return this._fs.readdirSync(p);\n }\n\n public exists(p: string, cb: (exists: boolean) => void): void {\n this._mu.lock(() => {\n this._fs.exists(p, (exists: boolean) => {\n this._mu.unlock();\n cb(exists);\n });\n });\n }\n\n public existsSync(p: string): boolean {\n if (this._mu.isLocked()) {\n throw new Error('invalid sync call');\n }\n return this._fs.existsSync(p);\n }\n\n public realpath(p: string, cache: {[path: string]: string}, cb: BFSCallback): void {\n this._mu.lock(() => {\n this._fs.realpath(p, cache, (err?: ApiError, resolvedPath?: string) => {\n this._mu.unlock();\n cb(err, resolvedPath);\n });\n });\n }\n\n public realpathSync(p: string, cache: {[path: string]: string}): string {\n if (this._mu.isLocked()) {\n throw new Error('invalid sync call');\n }\n return this._fs.realpathSync(p, cache);\n }\n\n public truncate(p: string, len: number, cb: BFSOneArgCallback): void {\n this._mu.lock(() => {\n this._fs.truncate(p, len, (err?: ApiError) => {\n this._mu.unlock();\n cb(err);\n });\n });\n }\n\n public truncateSync(p: string, len: number): void {\n if (this._mu.isLocked()) {\n throw new Error('invalid sync call');\n }\n return this._fs.truncateSync(p, len);\n }\n\n public readFile(fname: string, encoding: string, flag: FileFlag, cb: BFSCallback): void {\n this._mu.lock(() => {\n this._fs.readFile(fname, encoding, flag, (err?: ApiError, data?: any) => {\n this._mu.unlock();\n cb(err, data);\n });\n });\n }\n\n public readFileSync(fname: string, encoding: string, flag: FileFlag): any {\n if (this._mu.isLocked()) {\n throw new Error('invalid sync call');\n }\n return this._fs.readFileSync(fname, encoding, flag);\n }\n\n public writeFile(fname: string, data: any, encoding: string, flag: FileFlag, mode: number, cb: BFSOneArgCallback): void {\n this._mu.lock(() => {\n this._fs.writeFile(fname, data, encoding, flag, mode, (err?: ApiError) => {\n this._mu.unlock();\n cb(err);\n });\n });\n }\n\n public writeFileSync(fname: string, data: any, encoding: string, flag: FileFlag, mode: number): void {\n if (this._mu.isLocked()) {\n throw new Error('invalid sync call');\n }\n return this._fs.writeFileSync(fname, data, encoding, flag, mode);\n }\n\n public appendFile(fname: string, data: any, encoding: string, flag: FileFlag, mode: number, cb: BFSOneArgCallback): void {\n this._mu.lock(() => {\n this._fs.appendFile(fname, data, encoding, flag, mode, (err?: ApiError) => {\n this._mu.unlock();\n cb(err);\n });\n });\n }\n\n public appendFileSync(fname: string, data: any, encoding: string, flag: FileFlag, mode: number): void {\n if (this._mu.isLocked()) {\n throw new Error('invalid sync call');\n }\n return this._fs.appendFileSync(fname, data, encoding, flag, mode);\n }\n\n public chmod(p: string, isLchmod: boolean, mode: number, cb: BFSOneArgCallback): void {\n this._mu.lock(() => {\n this._fs.chmod(p, isLchmod, mode, (err?: ApiError) => {\n this._mu.unlock();\n cb(err);\n });\n });\n }\n\n public chmodSync(p: string, isLchmod: boolean, mode: number): void {\n if (this._mu.isLocked()) {\n throw new Error('invalid sync call');\n }\n return this._fs.chmodSync(p, isLchmod, mode);\n }\n\n public chown(p: string, isLchown: boolean, uid: number, gid: number, cb: BFSOneArgCallback): void {\n this._mu.lock(() => {\n this._fs.chown(p, isLchown, uid, gid, (err?: ApiError) => {\n this._mu.unlock();\n cb(err);\n });\n });\n }\n\n public chownSync(p: string, isLchown: boolean, uid: number, gid: number): void {\n if (this._mu.isLocked()) {\n throw new Error('invalid sync call');\n }\n return this._fs.chownSync(p, isLchown, uid, gid);\n }\n\n public utimes(p: string, atime: Date, mtime: Date, cb: BFSOneArgCallback): void {\n this._mu.lock(() => {\n this._fs.utimes(p, atime, mtime, (err?: ApiError) => {\n this._mu.unlock();\n cb(err);\n });\n });\n }\n\n public utimesSync(p: string, atime: Date, mtime: Date): void {\n if (this._mu.isLocked()) {\n throw new Error('invalid sync call');\n }\n return this._fs.utimesSync(p, atime, mtime);\n }\n\n public link(srcpath: string, dstpath: string, cb: BFSOneArgCallback): void {\n this._mu.lock(() => {\n this._fs.link(srcpath, dstpath, (err?: ApiError) => {\n this._mu.unlock();\n cb(err);\n });\n });\n }\n\n public linkSync(srcpath: string, dstpath: string): void {\n if (this._mu.isLocked()) {\n throw new Error('invalid sync call');\n }\n return this._fs.linkSync(srcpath, dstpath);\n }\n\n public symlink(srcpath: string, dstpath: string, type: string, cb: BFSOneArgCallback): void {\n this._mu.lock(() => {\n this._fs.symlink(srcpath, dstpath, type, (err?: ApiError) => {\n this._mu.unlock();\n cb(err);\n });\n });\n }\n\n public symlinkSync(srcpath: string, dstpath: string, type: string): void {\n if (this._mu.isLocked()) {\n throw new Error('invalid sync call');\n }\n return this._fs.symlinkSync(srcpath, dstpath, type);\n }\n\n public readlink(p: string, cb: BFSCallback): void {\n this._mu.lock(() => {\n this._fs.readlink(p, (err?: ApiError, linkString?: string) => {\n this._mu.unlock();\n cb(err, linkString);\n });\n });\n }\n\n public readlinkSync(p: string): string {\n if (this._mu.isLocked()) {\n throw new Error('invalid sync call');\n }\n return this._fs.readlinkSync(p);\n }\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../src/generic/locked_fs.ts","/**\n * (Nonstandard) String utility function for 8-bit ASCII with the extended\n * character set. Unlike the ASCII above, we do not mask the high bits.\n *\n * Placed into a separate file so it can be used with other Buffer implementations.\n * @see http://en.wikipedia.org/wiki/Extended_ASCII\n */\nexport default class ExtendedASCII {\n private static extendedChars = [ '\\u00C7', '\\u00FC', '\\u00E9', '\\u00E2', '\\u00E4',\n '\\u00E0', '\\u00E5', '\\u00E7', '\\u00EA', '\\u00EB', '\\u00E8', '\\u00EF',\n '\\u00EE', '\\u00EC', '\\u00C4', '\\u00C5', '\\u00C9', '\\u00E6', '\\u00C6',\n '\\u00F4', '\\u00F6', '\\u00F2', '\\u00FB', '\\u00F9', '\\u00FF', '\\u00D6',\n '\\u00DC', '\\u00F8', '\\u00A3', '\\u00D8', '\\u00D7', '\\u0192', '\\u00E1',\n '\\u00ED', '\\u00F3', '\\u00FA', '\\u00F1', '\\u00D1', '\\u00AA', '\\u00BA',\n '\\u00BF', '\\u00AE', '\\u00AC', '\\u00BD', '\\u00BC', '\\u00A1', '\\u00AB',\n '\\u00BB', '_', '_', '_', '\\u00A6', '\\u00A6', '\\u00C1', '\\u00C2', '\\u00C0',\n '\\u00A9', '\\u00A6', '\\u00A6', '+', '+', '\\u00A2', '\\u00A5', '+', '+', '-',\n '-', '+', '-', '+', '\\u00E3', '\\u00C3', '+', '+', '-', '-', '\\u00A6', '-',\n '+', '\\u00A4', '\\u00F0', '\\u00D0', '\\u00CA', '\\u00CB', '\\u00C8', 'i',\n '\\u00CD', '\\u00CE', '\\u00CF', '+', '+', '_', '_', '\\u00A6', '\\u00CC', '_',\n '\\u00D3', '\\u00DF', '\\u00D4', '\\u00D2', '\\u00F5', '\\u00D5', '\\u00B5',\n '\\u00FE', '\\u00DE', '\\u00DA', '\\u00DB', '\\u00D9', '\\u00FD', '\\u00DD',\n '\\u00AF', '\\u00B4', '\\u00AD', '\\u00B1', '_', '\\u00BE', '\\u00B6', '\\u00A7',\n '\\u00F7', '\\u00B8', '\\u00B0', '\\u00A8', '\\u00B7', '\\u00B9', '\\u00B3',\n '\\u00B2', '_', ' ' ];\n\n public static str2byte(str: string, buf: Buffer): number {\n const length = str.length > buf.length ? buf.length : str.length;\n for (let i = 0; i < length; i++) {\n let charCode = str.charCodeAt(i);\n if (charCode > 0x7F) {\n // Check if extended ASCII.\n const charIdx = ExtendedASCII.extendedChars.indexOf(str.charAt(i));\n if (charIdx > -1) {\n charCode = charIdx + 0x80;\n }\n // Otherwise, keep it as-is.\n }\n buf[charCode] = i;\n }\n return length;\n }\n\n public static byte2str(buff: Buffer): string {\n const chars = new Array(buff.length);\n for (let i = 0; i < buff.length; i++) {\n const charCode = buff[i];\n if (charCode > 0x7F) {\n chars[i] = ExtendedASCII.extendedChars[charCode - 128];\n } else {\n chars[i] = String.fromCharCode(charCode);\n }\n }\n return chars.join('');\n }\n\n public static byteLength(str: string): number { return str.length; }\n}\n\n\n\n// WEBPACK FOOTER //\n// ../../../../src/generic/extended_ascii.ts","import AsyncMirror from '../backend/AsyncMirror';\nimport Dropbox from '../backend/Dropbox';\nimport Emscripten from '../backend/Emscripten';\nimport FolderAdapter from '../backend/FolderAdapter';\nimport HTML5FS from '../backend/HTML5FS';\nimport InMemory from '../backend/InMemory';\nimport IndexedDB from '../backend/IndexedDB';\nimport LocalStorage from '../backend/LocalStorage';\nimport MountableFileSystem from '../backend/MountableFileSystem';\nimport OverlayFS from '../backend/OverlayFS';\nimport WorkerFS from '../backend/WorkerFS';\nimport XmlHttpRequest from '../backend/XmlHttpRequest';\nimport ZipFS from '../backend/ZipFS';\nimport IsoFS from '../backend/IsoFS';\n/* tslint:disable:variable-name */\nconst Backends = { AsyncMirror, Dropbox, Emscripten, FolderAdapter, HTML5FS, InMemory, IndexedDB, IsoFS, LocalStorage, MountableFileSystem, OverlayFS, WorkerFS, XmlHttpRequest, ZipFS };\nexport default Backends;\n/* tslint:enable:variable-name */\n\n\n\n// WEBPACK FOOTER //\n// ../../../../src/core/backends.ts","/**\n * BrowserFS's main entry point.\n * It installs all of the needed polyfills, and requires() the main module.\n */\nimport global from './core/global';\n\n// IE substr does not support negative indices\nif ('ab'.substr(-1) !== 'b') {\n String.prototype.substr = function(substr: (start: number, length?: number) => string) {\n return function(this: string, start: number, length?: number): string {\n // did we get a negative start, calculate how much it is from the\n // beginning of the string\n if (start < 0) {\n start = this.length + start;\n }\n // call the original function\n return substr.call(this, start, length);\n };\n }(String.prototype.substr);\n}\n\n// Only IE10 has setImmediate.\nif (typeof setImmediate === 'undefined') {\n const gScope = global;\n const timeouts: (() => void)[] = [];\n const messageName = \"zero-timeout-message\";\n const canUsePostMessage = function() {\n if (typeof gScope.importScripts !== 'undefined' || !gScope.postMessage) {\n return false;\n }\n let postMessageIsAsync = true;\n const oldOnMessage = gScope.onmessage;\n gScope.onmessage = function() {\n postMessageIsAsync = false;\n };\n gScope.postMessage('', '*');\n gScope.onmessage = oldOnMessage;\n return postMessageIsAsync;\n };\n if (canUsePostMessage()) {\n gScope.setImmediate = function(fn: () => void) {\n timeouts.push(fn);\n gScope.postMessage(messageName, \"*\");\n };\n const handleMessage = function(event: MessageEvent) {\n if (event.source === self && event.data === messageName) {\n if (event.stopPropagation) {\n event.stopPropagation();\n } else {\n event.cancelBubble = true;\n }\n if (timeouts.length > 0) {\n const fn = timeouts.shift()!;\n return fn();\n }\n }\n };\n if (gScope.addEventListener) {\n gScope.addEventListener('message', handleMessage, true);\n } else {\n gScope.attachEvent('onmessage', handleMessage);\n }\n } else if (gScope.MessageChannel) {\n // WebWorker MessageChannel\n const channel = new gScope.MessageChannel();\n channel.port1.onmessage = (event: any) => {\n if (timeouts.length > 0) {\n return timeouts.shift()!();\n }\n };\n gScope.setImmediate = (fn: () => void) => {\n timeouts.push(fn);\n channel.port2.postMessage('');\n };\n } else {\n gScope.setImmediate = function(fn: () => void) {\n return setTimeout(fn, 0);\n };\n }\n}\n\n// Polyfill for Uint8Array.prototype.slice.\n// Safari and some other browsers do not define it.\nif (typeof(ArrayBuffer) !== 'undefined' && typeof(Uint8Array) !== 'undefined') {\n if (!Uint8Array.prototype['slice']) {\n Uint8Array.prototype.slice = function(this: Uint8Array, start: number = 0, end: number = this.length): Uint8Array {\n const self: Uint8Array = this;\n if (start < 0) {\n start = this.length + start;\n if (start < 0) {\n start = 0;\n }\n }\n if (end < 0) {\n end = this.length + end;\n if (end < 0) {\n end = 0;\n }\n }\n if (end < start) {\n end = start;\n }\n return new Uint8Array(self.buffer, self.byteOffset + start, end - start);\n };\n }\n}\n\nexport * from './core/browserfs';\n\n\n\n// WEBPACK FOOTER //\n// ../../../../src/index.ts","/*!\n * The buffer module from node.js, for the browser.\n *\n * @author Feross Aboukhadijeh \n * @license MIT\n */\n/* eslint-disable no-proto */\n\n'use strict'\n\nvar base64 = require('base64-js')\nvar ieee754 = require('ieee754')\n\nexports.Buffer = Buffer\nexports.SlowBuffer = SlowBuffer\nexports.INSPECT_MAX_BYTES = 50\n\nvar K_MAX_LENGTH = 0x7fffffff\nexports.kMaxLength = K_MAX_LENGTH\n\n/**\n * If `Buffer.TYPED_ARRAY_SUPPORT`:\n * === true Use Uint8Array implementation (fastest)\n * === false Print warning and recommend using `buffer` v4.x which has an Object\n * implementation (most compatible, even IE6)\n *\n * Browsers that support typed arrays are IE 10+, Firefox 4+, Chrome 7+, Safari 5.1+,\n * Opera 11.6+, iOS 4.2+.\n *\n * We report that the browser does not support typed arrays if the are not subclassable\n * using __proto__. Firefox 4-29 lacks support for adding new properties to `Uint8Array`\n * (See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438). IE 10 lacks support\n * for __proto__ and has a buggy typed array implementation.\n */\nBuffer.TYPED_ARRAY_SUPPORT = typedArraySupport()\n\nif (!Buffer.TYPED_ARRAY_SUPPORT && typeof console !== 'undefined' &&\n typeof console.error === 'function') {\n console.error(\n 'This browser lacks typed array (Uint8Array) support which is required by ' +\n '`buffer` v5.x. Use `buffer` v4.x if you require old browser support.'\n )\n}\n\nfunction typedArraySupport () {\n // Can typed array instances can be augmented?\n try {\n var arr = new Uint8Array(1)\n arr.__proto__ = {__proto__: Uint8Array.prototype, foo: function () { return 42 }}\n return arr.foo() === 42\n } catch (e) {\n return false\n }\n}\n\nfunction createBuffer (length) {\n if (length > K_MAX_LENGTH) {\n throw new RangeError('Invalid typed array length')\n }\n // Return an augmented `Uint8Array` instance\n var buf = new Uint8Array(length)\n buf.__proto__ = Buffer.prototype\n return buf\n}\n\n/**\n * The Buffer constructor returns instances of `Uint8Array` that have their\n * prototype changed to `Buffer.prototype`. Furthermore, `Buffer` is a subclass of\n * `Uint8Array`, so the returned instances will have all the node `Buffer` methods\n * and the `Uint8Array` methods. Square bracket notation works as expected -- it\n * returns a single octet.\n *\n * The `Uint8Array` prototype remains unmodified.\n */\n\nfunction Buffer (arg, encodingOrOffset, length) {\n // Common case.\n if (typeof arg === 'number') {\n if (typeof encodingOrOffset === 'string') {\n throw new Error(\n 'If encoding is specified then the first argument must be a string'\n )\n }\n return allocUnsafe(arg)\n }\n return from(arg, encodingOrOffset, length)\n}\n\n// Fix subarray() in ES2016. See: https://github.com/feross/buffer/pull/97\nif (typeof Symbol !== 'undefined' && Symbol.species &&\n Buffer[Symbol.species] === Buffer) {\n Object.defineProperty(Buffer, Symbol.species, {\n value: null,\n configurable: true,\n enumerable: false,\n writable: false\n })\n}\n\nBuffer.poolSize = 8192 // not used by this implementation\n\nfunction from (value, encodingOrOffset, length) {\n if (typeof value === 'number') {\n throw new TypeError('\"value\" argument must not be a number')\n }\n\n if (typeof ArrayBuffer !== 'undefined' && value instanceof ArrayBuffer) {\n return fromArrayBuffer(value, encodingOrOffset, length)\n }\n\n if (typeof value === 'string') {\n return fromString(value, encodingOrOffset)\n }\n\n return fromObject(value)\n}\n\n/**\n * Functionally equivalent to Buffer(arg, encoding) but throws a TypeError\n * if value is a number.\n * Buffer.from(str[, encoding])\n * Buffer.from(array)\n * Buffer.from(buffer)\n * Buffer.from(arrayBuffer[, byteOffset[, length]])\n **/\nBuffer.from = function (value, encodingOrOffset, length) {\n return from(value, encodingOrOffset, length)\n}\n\n// Note: Change prototype *after* Buffer.from is defined to workaround Chrome bug:\n// https://github.com/feross/buffer/pull/148\nBuffer.prototype.__proto__ = Uint8Array.prototype\nBuffer.__proto__ = Uint8Array\n\nfunction assertSize (size) {\n if (typeof size !== 'number') {\n throw new TypeError('\"size\" argument must be a number')\n } else if (size < 0) {\n throw new RangeError('\"size\" argument must not be negative')\n }\n}\n\nfunction alloc (size, fill, encoding) {\n assertSize(size)\n if (size <= 0) {\n return createBuffer(size)\n }\n if (fill !== undefined) {\n // Only pay attention to encoding if it's a string. This\n // prevents accidentally sending in a number that would\n // be interpretted as a start offset.\n return typeof encoding === 'string'\n ? createBuffer(size).fill(fill, encoding)\n : createBuffer(size).fill(fill)\n }\n return createBuffer(size)\n}\n\n/**\n * Creates a new filled Buffer instance.\n * alloc(size[, fill[, encoding]])\n **/\nBuffer.alloc = function (size, fill, encoding) {\n return alloc(size, fill, encoding)\n}\n\nfunction allocUnsafe (size) {\n assertSize(size)\n return createBuffer(size < 0 ? 0 : checked(size) | 0)\n}\n\n/**\n * Equivalent to Buffer(num), by default creates a non-zero-filled Buffer instance.\n * */\nBuffer.allocUnsafe = function (size) {\n return allocUnsafe(size)\n}\n/**\n * Equivalent to SlowBuffer(num), by default creates a non-zero-filled Buffer instance.\n */\nBuffer.allocUnsafeSlow = function (size) {\n return allocUnsafe(size)\n}\n\nfunction fromString (string, encoding) {\n if (typeof encoding !== 'string' || encoding === '') {\n encoding = 'utf8'\n }\n\n if (!Buffer.isEncoding(encoding)) {\n throw new TypeError('\"encoding\" must be a valid string encoding')\n }\n\n var length = byteLength(string, encoding) | 0\n var buf = createBuffer(length)\n\n var actual = buf.write(string, encoding)\n\n if (actual !== length) {\n // Writing a hex string, for example, that contains invalid characters will\n // cause everything after the first invalid character to be ignored. (e.g.\n // 'abxxcd' will be treated as 'ab')\n buf = buf.slice(0, actual)\n }\n\n return buf\n}\n\nfunction fromArrayLike (array) {\n var length = array.length < 0 ? 0 : checked(array.length) | 0\n var buf = createBuffer(length)\n for (var i = 0; i < length; i += 1) {\n buf[i] = array[i] & 255\n }\n return buf\n}\n\nfunction fromArrayBuffer (array, byteOffset, length) {\n array.byteLength // this throws if `array` is not a valid ArrayBuffer\n\n if (byteOffset < 0 || array.byteLength < byteOffset) {\n throw new RangeError('\\'offset\\' is out of bounds')\n }\n\n if (array.byteLength < byteOffset + (length || 0)) {\n throw new RangeError('\\'length\\' is out of bounds')\n }\n\n var buf\n if (byteOffset === undefined && length === undefined) {\n buf = new Uint8Array(array)\n } else if (length === undefined) {\n buf = new Uint8Array(array, byteOffset)\n } else {\n buf = new Uint8Array(array, byteOffset, length)\n }\n\n // Return an augmented `Uint8Array` instance\n buf.__proto__ = Buffer.prototype\n return buf\n}\n\nfunction fromObject (obj) {\n if (Buffer.isBuffer(obj)) {\n var len = checked(obj.length) | 0\n var buf = createBuffer(len)\n\n if (buf.length === 0) {\n return buf\n }\n\n obj.copy(buf, 0, 0, len)\n return buf\n }\n\n if (obj) {\n if ((typeof ArrayBuffer !== 'undefined' &&\n obj.buffer instanceof ArrayBuffer) || 'length' in obj) {\n if (typeof obj.length !== 'number' || isnan(obj.length)) {\n return createBuffer(0)\n }\n return fromArrayLike(obj)\n }\n\n if (obj.type === 'Buffer' && Array.isArray(obj.data)) {\n return fromArrayLike(obj.data)\n }\n }\n\n throw new TypeError('First argument must be a string, Buffer, ArrayBuffer, Array, or array-like object.')\n}\n\nfunction checked (length) {\n // Note: cannot use `length < K_MAX_LENGTH` here because that fails when\n // length is NaN (which is otherwise coerced to zero.)\n if (length >= K_MAX_LENGTH) {\n throw new RangeError('Attempt to allocate Buffer larger than maximum ' +\n 'size: 0x' + K_MAX_LENGTH.toString(16) + ' bytes')\n }\n return length | 0\n}\n\nfunction SlowBuffer (length) {\n if (+length != length) { // eslint-disable-line eqeqeq\n length = 0\n }\n return Buffer.alloc(+length)\n}\n\nBuffer.isBuffer = function isBuffer (b) {\n return !!(b != null && b._isBuffer)\n}\n\nBuffer.compare = function compare (a, b) {\n if (!Buffer.isBuffer(a) || !Buffer.isBuffer(b)) {\n throw new TypeError('Arguments must be Buffers')\n }\n\n if (a === b) return 0\n\n var x = a.length\n var y = b.length\n\n for (var i = 0, len = Math.min(x, y); i < len; ++i) {\n if (a[i] !== b[i]) {\n x = a[i]\n y = b[i]\n break\n }\n }\n\n if (x < y) return -1\n if (y < x) return 1\n return 0\n}\n\nBuffer.isEncoding = function isEncoding (encoding) {\n switch (String(encoding).toLowerCase()) {\n case 'hex':\n case 'utf8':\n case 'utf-8':\n case 'ascii':\n case 'latin1':\n case 'binary':\n case 'base64':\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return true\n default:\n return false\n }\n}\n\nBuffer.concat = function concat (list, length) {\n if (!Array.isArray(list)) {\n throw new TypeError('\"list\" argument must be an Array of Buffers')\n }\n\n if (list.length === 0) {\n return Buffer.alloc(0)\n }\n\n var i\n if (length === undefined) {\n length = 0\n for (i = 0; i < list.length; ++i) {\n length += list[i].length\n }\n }\n\n var buffer = Buffer.allocUnsafe(length)\n var pos = 0\n for (i = 0; i < list.length; ++i) {\n var buf = list[i]\n if (!Buffer.isBuffer(buf)) {\n throw new TypeError('\"list\" argument must be an Array of Buffers')\n }\n buf.copy(buffer, pos)\n pos += buf.length\n }\n return buffer\n}\n\nfunction byteLength (string, encoding) {\n if (Buffer.isBuffer(string)) {\n return string.length\n }\n if (typeof ArrayBuffer !== 'undefined' && typeof ArrayBuffer.isView === 'function' &&\n (ArrayBuffer.isView(string) || string instanceof ArrayBuffer)) {\n return string.byteLength\n }\n if (typeof string !== 'string') {\n string = '' + string\n }\n\n var len = string.length\n if (len === 0) return 0\n\n // Use a for loop to avoid recursion\n var loweredCase = false\n for (;;) {\n switch (encoding) {\n case 'ascii':\n case 'latin1':\n case 'binary':\n return len\n case 'utf8':\n case 'utf-8':\n case undefined:\n return utf8ToBytes(string).length\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return len * 2\n case 'hex':\n return len >>> 1\n case 'base64':\n return base64ToBytes(string).length\n default:\n if (loweredCase) return utf8ToBytes(string).length // assume utf8\n encoding = ('' + encoding).toLowerCase()\n loweredCase = true\n }\n }\n}\nBuffer.byteLength = byteLength\n\nfunction slowToString (encoding, start, end) {\n var loweredCase = false\n\n // No need to verify that \"this.length <= MAX_UINT32\" since it's a read-only\n // property of a typed array.\n\n // This behaves neither like String nor Uint8Array in that we set start/end\n // to their upper/lower bounds if the value passed is out of range.\n // undefined is handled specially as per ECMA-262 6th Edition,\n // Section 13.3.3.7 Runtime Semantics: KeyedBindingInitialization.\n if (start === undefined || start < 0) {\n start = 0\n }\n // Return early if start > this.length. Done here to prevent potential uint32\n // coercion fail below.\n if (start > this.length) {\n return ''\n }\n\n if (end === undefined || end > this.length) {\n end = this.length\n }\n\n if (end <= 0) {\n return ''\n }\n\n // Force coersion to uint32. This will also coerce falsey/NaN values to 0.\n end >>>= 0\n start >>>= 0\n\n if (end <= start) {\n return ''\n }\n\n if (!encoding) encoding = 'utf8'\n\n while (true) {\n switch (encoding) {\n case 'hex':\n return hexSlice(this, start, end)\n\n case 'utf8':\n case 'utf-8':\n return utf8Slice(this, start, end)\n\n case 'ascii':\n return asciiSlice(this, start, end)\n\n case 'latin1':\n case 'binary':\n return latin1Slice(this, start, end)\n\n case 'base64':\n return base64Slice(this, start, end)\n\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return utf16leSlice(this, start, end)\n\n default:\n if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n encoding = (encoding + '').toLowerCase()\n loweredCase = true\n }\n }\n}\n\n// The property is used by `Buffer.isBuffer` and `is-buffer` (in Safari 5-7) to detect\n// Buffer instances.\nBuffer.prototype._isBuffer = true\n\nfunction swap (b, n, m) {\n var i = b[n]\n b[n] = b[m]\n b[m] = i\n}\n\nBuffer.prototype.swap16 = function swap16 () {\n var len = this.length\n if (len % 2 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 16-bits')\n }\n for (var i = 0; i < len; i += 2) {\n swap(this, i, i + 1)\n }\n return this\n}\n\nBuffer.prototype.swap32 = function swap32 () {\n var len = this.length\n if (len % 4 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 32-bits')\n }\n for (var i = 0; i < len; i += 4) {\n swap(this, i, i + 3)\n swap(this, i + 1, i + 2)\n }\n return this\n}\n\nBuffer.prototype.swap64 = function swap64 () {\n var len = this.length\n if (len % 8 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 64-bits')\n }\n for (var i = 0; i < len; i += 8) {\n swap(this, i, i + 7)\n swap(this, i + 1, i + 6)\n swap(this, i + 2, i + 5)\n swap(this, i + 3, i + 4)\n }\n return this\n}\n\nBuffer.prototype.toString = function toString () {\n var length = this.length\n if (length === 0) return ''\n if (arguments.length === 0) return utf8Slice(this, 0, length)\n return slowToString.apply(this, arguments)\n}\n\nBuffer.prototype.equals = function equals (b) {\n if (!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer')\n if (this === b) return true\n return Buffer.compare(this, b) === 0\n}\n\nBuffer.prototype.inspect = function inspect () {\n var str = ''\n var max = exports.INSPECT_MAX_BYTES\n if (this.length > 0) {\n str = this.toString('hex', 0, max).match(/.{2}/g).join(' ')\n if (this.length > max) str += ' ... '\n }\n return ''\n}\n\nBuffer.prototype.compare = function compare (target, start, end, thisStart, thisEnd) {\n if (!Buffer.isBuffer(target)) {\n throw new TypeError('Argument must be a Buffer')\n }\n\n if (start === undefined) {\n start = 0\n }\n if (end === undefined) {\n end = target ? target.length : 0\n }\n if (thisStart === undefined) {\n thisStart = 0\n }\n if (thisEnd === undefined) {\n thisEnd = this.length\n }\n\n if (start < 0 || end > target.length || thisStart < 0 || thisEnd > this.length) {\n throw new RangeError('out of range index')\n }\n\n if (thisStart >= thisEnd && start >= end) {\n return 0\n }\n if (thisStart >= thisEnd) {\n return -1\n }\n if (start >= end) {\n return 1\n }\n\n start >>>= 0\n end >>>= 0\n thisStart >>>= 0\n thisEnd >>>= 0\n\n if (this === target) return 0\n\n var x = thisEnd - thisStart\n var y = end - start\n var len = Math.min(x, y)\n\n var thisCopy = this.slice(thisStart, thisEnd)\n var targetCopy = target.slice(start, end)\n\n for (var i = 0; i < len; ++i) {\n if (thisCopy[i] !== targetCopy[i]) {\n x = thisCopy[i]\n y = targetCopy[i]\n break\n }\n }\n\n if (x < y) return -1\n if (y < x) return 1\n return 0\n}\n\n// Finds either the first index of `val` in `buffer` at offset >= `byteOffset`,\n// OR the last index of `val` in `buffer` at offset <= `byteOffset`.\n//\n// Arguments:\n// - buffer - a Buffer to search\n// - val - a string, Buffer, or number\n// - byteOffset - an index into `buffer`; will be clamped to an int32\n// - encoding - an optional encoding, relevant is val is a string\n// - dir - true for indexOf, false for lastIndexOf\nfunction bidirectionalIndexOf (buffer, val, byteOffset, encoding, dir) {\n // Empty buffer means no match\n if (buffer.length === 0) return -1\n\n // Normalize byteOffset\n if (typeof byteOffset === 'string') {\n encoding = byteOffset\n byteOffset = 0\n } else if (byteOffset > 0x7fffffff) {\n byteOffset = 0x7fffffff\n } else if (byteOffset < -0x80000000) {\n byteOffset = -0x80000000\n }\n byteOffset = +byteOffset // Coerce to Number.\n if (isNaN(byteOffset)) {\n // byteOffset: it it's undefined, null, NaN, \"foo\", etc, search whole buffer\n byteOffset = dir ? 0 : (buffer.length - 1)\n }\n\n // Normalize byteOffset: negative offsets start from the end of the buffer\n if (byteOffset < 0) byteOffset = buffer.length + byteOffset\n if (byteOffset >= buffer.length) {\n if (dir) return -1\n else byteOffset = buffer.length - 1\n } else if (byteOffset < 0) {\n if (dir) byteOffset = 0\n else return -1\n }\n\n // Normalize val\n if (typeof val === 'string') {\n val = Buffer.from(val, encoding)\n }\n\n // Finally, search either indexOf (if dir is true) or lastIndexOf\n if (Buffer.isBuffer(val)) {\n // Special case: looking for empty string/buffer always fails\n if (val.length === 0) {\n return -1\n }\n return arrayIndexOf(buffer, val, byteOffset, encoding, dir)\n } else if (typeof val === 'number') {\n val = val & 0xFF // Search for a byte value [0-255]\n if (typeof Uint8Array.prototype.indexOf === 'function') {\n if (dir) {\n return Uint8Array.prototype.indexOf.call(buffer, val, byteOffset)\n } else {\n return Uint8Array.prototype.lastIndexOf.call(buffer, val, byteOffset)\n }\n }\n return arrayIndexOf(buffer, [ val ], byteOffset, encoding, dir)\n }\n\n throw new TypeError('val must be string, number or Buffer')\n}\n\nfunction arrayIndexOf (arr, val, byteOffset, encoding, dir) {\n var indexSize = 1\n var arrLength = arr.length\n var valLength = val.length\n\n if (encoding !== undefined) {\n encoding = String(encoding).toLowerCase()\n if (encoding === 'ucs2' || encoding === 'ucs-2' ||\n encoding === 'utf16le' || encoding === 'utf-16le') {\n if (arr.length < 2 || val.length < 2) {\n return -1\n }\n indexSize = 2\n arrLength /= 2\n valLength /= 2\n byteOffset /= 2\n }\n }\n\n function read (buf, i) {\n if (indexSize === 1) {\n return buf[i]\n } else {\n return buf.readUInt16BE(i * indexSize)\n }\n }\n\n var i\n if (dir) {\n var foundIndex = -1\n for (i = byteOffset; i < arrLength; i++) {\n if (read(arr, i) === read(val, foundIndex === -1 ? 0 : i - foundIndex)) {\n if (foundIndex === -1) foundIndex = i\n if (i - foundIndex + 1 === valLength) return foundIndex * indexSize\n } else {\n if (foundIndex !== -1) i -= i - foundIndex\n foundIndex = -1\n }\n }\n } else {\n if (byteOffset + valLength > arrLength) byteOffset = arrLength - valLength\n for (i = byteOffset; i >= 0; i--) {\n var found = true\n for (var j = 0; j < valLength; j++) {\n if (read(arr, i + j) !== read(val, j)) {\n found = false\n break\n }\n }\n if (found) return i\n }\n }\n\n return -1\n}\n\nBuffer.prototype.includes = function includes (val, byteOffset, encoding) {\n return this.indexOf(val, byteOffset, encoding) !== -1\n}\n\nBuffer.prototype.indexOf = function indexOf (val, byteOffset, encoding) {\n return bidirectionalIndexOf(this, val, byteOffset, encoding, true)\n}\n\nBuffer.prototype.lastIndexOf = function lastIndexOf (val, byteOffset, encoding) {\n return bidirectionalIndexOf(this, val, byteOffset, encoding, false)\n}\n\nfunction hexWrite (buf, string, offset, length) {\n offset = Number(offset) || 0\n var remaining = buf.length - offset\n if (!length) {\n length = remaining\n } else {\n length = Number(length)\n if (length > remaining) {\n length = remaining\n }\n }\n\n // must be an even number of digits\n var strLen = string.length\n if (strLen % 2 !== 0) throw new TypeError('Invalid hex string')\n\n if (length > strLen / 2) {\n length = strLen / 2\n }\n for (var i = 0; i < length; ++i) {\n var parsed = parseInt(string.substr(i * 2, 2), 16)\n if (isNaN(parsed)) return i\n buf[offset + i] = parsed\n }\n return i\n}\n\nfunction utf8Write (buf, string, offset, length) {\n return blitBuffer(utf8ToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nfunction asciiWrite (buf, string, offset, length) {\n return blitBuffer(asciiToBytes(string), buf, offset, length)\n}\n\nfunction latin1Write (buf, string, offset, length) {\n return asciiWrite(buf, string, offset, length)\n}\n\nfunction base64Write (buf, string, offset, length) {\n return blitBuffer(base64ToBytes(string), buf, offset, length)\n}\n\nfunction ucs2Write (buf, string, offset, length) {\n return blitBuffer(utf16leToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nBuffer.prototype.write = function write (string, offset, length, encoding) {\n // Buffer#write(string)\n if (offset === undefined) {\n encoding = 'utf8'\n length = this.length\n offset = 0\n // Buffer#write(string, encoding)\n } else if (length === undefined && typeof offset === 'string') {\n encoding = offset\n length = this.length\n offset = 0\n // Buffer#write(string, offset[, length][, encoding])\n } else if (isFinite(offset)) {\n offset = offset >>> 0\n if (isFinite(length)) {\n length = length >>> 0\n if (encoding === undefined) encoding = 'utf8'\n } else {\n encoding = length\n length = undefined\n }\n } else {\n throw new Error(\n 'Buffer.write(string, encoding, offset[, length]) is no longer supported'\n )\n }\n\n var remaining = this.length - offset\n if (length === undefined || length > remaining) length = remaining\n\n if ((string.length > 0 && (length < 0 || offset < 0)) || offset > this.length) {\n throw new RangeError('Attempt to write outside buffer bounds')\n }\n\n if (!encoding) encoding = 'utf8'\n\n var loweredCase = false\n for (;;) {\n switch (encoding) {\n case 'hex':\n return hexWrite(this, string, offset, length)\n\n case 'utf8':\n case 'utf-8':\n return utf8Write(this, string, offset, length)\n\n case 'ascii':\n return asciiWrite(this, string, offset, length)\n\n case 'latin1':\n case 'binary':\n return latin1Write(this, string, offset, length)\n\n case 'base64':\n // Warning: maxLength not taken into account in base64Write\n return base64Write(this, string, offset, length)\n\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return ucs2Write(this, string, offset, length)\n\n default:\n if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n encoding = ('' + encoding).toLowerCase()\n loweredCase = true\n }\n }\n}\n\nBuffer.prototype.toJSON = function toJSON () {\n return {\n type: 'Buffer',\n data: Array.prototype.slice.call(this._arr || this, 0)\n }\n}\n\nfunction base64Slice (buf, start, end) {\n if (start === 0 && end === buf.length) {\n return base64.fromByteArray(buf)\n } else {\n return base64.fromByteArray(buf.slice(start, end))\n }\n}\n\nfunction utf8Slice (buf, start, end) {\n end = Math.min(buf.length, end)\n var res = []\n\n var i = start\n while (i < end) {\n var firstByte = buf[i]\n var codePoint = null\n var bytesPerSequence = (firstByte > 0xEF) ? 4\n : (firstByte > 0xDF) ? 3\n : (firstByte > 0xBF) ? 2\n : 1\n\n if (i + bytesPerSequence <= end) {\n var secondByte, thirdByte, fourthByte, tempCodePoint\n\n switch (bytesPerSequence) {\n case 1:\n if (firstByte < 0x80) {\n codePoint = firstByte\n }\n break\n case 2:\n secondByte = buf[i + 1]\n if ((secondByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0x1F) << 0x6 | (secondByte & 0x3F)\n if (tempCodePoint > 0x7F) {\n codePoint = tempCodePoint\n }\n }\n break\n case 3:\n secondByte = buf[i + 1]\n thirdByte = buf[i + 2]\n if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0xF) << 0xC | (secondByte & 0x3F) << 0x6 | (thirdByte & 0x3F)\n if (tempCodePoint > 0x7FF && (tempCodePoint < 0xD800 || tempCodePoint > 0xDFFF)) {\n codePoint = tempCodePoint\n }\n }\n break\n case 4:\n secondByte = buf[i + 1]\n thirdByte = buf[i + 2]\n fourthByte = buf[i + 3]\n if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80 && (fourthByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0xF) << 0x12 | (secondByte & 0x3F) << 0xC | (thirdByte & 0x3F) << 0x6 | (fourthByte & 0x3F)\n if (tempCodePoint > 0xFFFF && tempCodePoint < 0x110000) {\n codePoint = tempCodePoint\n }\n }\n }\n }\n\n if (codePoint === null) {\n // we did not generate a valid codePoint so insert a\n // replacement char (U+FFFD) and advance only 1 byte\n codePoint = 0xFFFD\n bytesPerSequence = 1\n } else if (codePoint > 0xFFFF) {\n // encode to utf16 (surrogate pair dance)\n codePoint -= 0x10000\n res.push(codePoint >>> 10 & 0x3FF | 0xD800)\n codePoint = 0xDC00 | codePoint & 0x3FF\n }\n\n res.push(codePoint)\n i += bytesPerSequence\n }\n\n return decodeCodePointsArray(res)\n}\n\n// Based on http://stackoverflow.com/a/22747272/680742, the browser with\n// the lowest limit is Chrome, with 0x10000 args.\n// We go 1 magnitude less, for safety\nvar MAX_ARGUMENTS_LENGTH = 0x1000\n\nfunction decodeCodePointsArray (codePoints) {\n var len = codePoints.length\n if (len <= MAX_ARGUMENTS_LENGTH) {\n return String.fromCharCode.apply(String, codePoints) // avoid extra slice()\n }\n\n // Decode in chunks to avoid \"call stack size exceeded\".\n var res = ''\n var i = 0\n while (i < len) {\n res += String.fromCharCode.apply(\n String,\n codePoints.slice(i, i += MAX_ARGUMENTS_LENGTH)\n )\n }\n return res\n}\n\nfunction asciiSlice (buf, start, end) {\n var ret = ''\n end = Math.min(buf.length, end)\n\n for (var i = start; i < end; ++i) {\n ret += String.fromCharCode(buf[i] & 0x7F)\n }\n return ret\n}\n\nfunction latin1Slice (buf, start, end) {\n var ret = ''\n end = Math.min(buf.length, end)\n\n for (var i = start; i < end; ++i) {\n ret += String.fromCharCode(buf[i])\n }\n return ret\n}\n\nfunction hexSlice (buf, start, end) {\n var len = buf.length\n\n if (!start || start < 0) start = 0\n if (!end || end < 0 || end > len) end = len\n\n var out = ''\n for (var i = start; i < end; ++i) {\n out += toHex(buf[i])\n }\n return out\n}\n\nfunction utf16leSlice (buf, start, end) {\n var bytes = buf.slice(start, end)\n var res = ''\n for (var i = 0; i < bytes.length; i += 2) {\n res += String.fromCharCode(bytes[i] + bytes[i + 1] * 256)\n }\n return res\n}\n\nBuffer.prototype.slice = function slice (start, end) {\n var len = this.length\n start = ~~start\n end = end === undefined ? len : ~~end\n\n if (start < 0) {\n start += len\n if (start < 0) start = 0\n } else if (start > len) {\n start = len\n }\n\n if (end < 0) {\n end += len\n if (end < 0) end = 0\n } else if (end > len) {\n end = len\n }\n\n if (end < start) end = start\n\n var newBuf = this.subarray(start, end)\n // Return an augmented `Uint8Array` instance\n newBuf.__proto__ = Buffer.prototype\n return newBuf\n}\n\n/*\n * Need to make sure that buffer isn't trying to write out of bounds.\n */\nfunction checkOffset (offset, ext, length) {\n if ((offset % 1) !== 0 || offset < 0) throw new RangeError('offset is not uint')\n if (offset + ext > length) throw new RangeError('Trying to access beyond buffer length')\n}\n\nBuffer.prototype.readUIntLE = function readUIntLE (offset, byteLength, noAssert) {\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n var val = this[offset]\n var mul = 1\n var i = 0\n while (++i < byteLength && (mul *= 0x100)) {\n val += this[offset + i] * mul\n }\n\n return val\n}\n\nBuffer.prototype.readUIntBE = function readUIntBE (offset, byteLength, noAssert) {\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) {\n checkOffset(offset, byteLength, this.length)\n }\n\n var val = this[offset + --byteLength]\n var mul = 1\n while (byteLength > 0 && (mul *= 0x100)) {\n val += this[offset + --byteLength] * mul\n }\n\n return val\n}\n\nBuffer.prototype.readUInt8 = function readUInt8 (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 1, this.length)\n return this[offset]\n}\n\nBuffer.prototype.readUInt16LE = function readUInt16LE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 2, this.length)\n return this[offset] | (this[offset + 1] << 8)\n}\n\nBuffer.prototype.readUInt16BE = function readUInt16BE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 2, this.length)\n return (this[offset] << 8) | this[offset + 1]\n}\n\nBuffer.prototype.readUInt32LE = function readUInt32LE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return ((this[offset]) |\n (this[offset + 1] << 8) |\n (this[offset + 2] << 16)) +\n (this[offset + 3] * 0x1000000)\n}\n\nBuffer.prototype.readUInt32BE = function readUInt32BE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return (this[offset] * 0x1000000) +\n ((this[offset + 1] << 16) |\n (this[offset + 2] << 8) |\n this[offset + 3])\n}\n\nBuffer.prototype.readIntLE = function readIntLE (offset, byteLength, noAssert) {\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n var val = this[offset]\n var mul = 1\n var i = 0\n while (++i < byteLength && (mul *= 0x100)) {\n val += this[offset + i] * mul\n }\n mul *= 0x80\n\n if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\n return val\n}\n\nBuffer.prototype.readIntBE = function readIntBE (offset, byteLength, noAssert) {\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n var i = byteLength\n var mul = 1\n var val = this[offset + --i]\n while (i > 0 && (mul *= 0x100)) {\n val += this[offset + --i] * mul\n }\n mul *= 0x80\n\n if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\n return val\n}\n\nBuffer.prototype.readInt8 = function readInt8 (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 1, this.length)\n if (!(this[offset] & 0x80)) return (this[offset])\n return ((0xff - this[offset] + 1) * -1)\n}\n\nBuffer.prototype.readInt16LE = function readInt16LE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 2, this.length)\n var val = this[offset] | (this[offset + 1] << 8)\n return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt16BE = function readInt16BE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 2, this.length)\n var val = this[offset + 1] | (this[offset] << 8)\n return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt32LE = function readInt32LE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return (this[offset]) |\n (this[offset + 1] << 8) |\n (this[offset + 2] << 16) |\n (this[offset + 3] << 24)\n}\n\nBuffer.prototype.readInt32BE = function readInt32BE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return (this[offset] << 24) |\n (this[offset + 1] << 16) |\n (this[offset + 2] << 8) |\n (this[offset + 3])\n}\n\nBuffer.prototype.readFloatLE = function readFloatLE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n return ieee754.read(this, offset, true, 23, 4)\n}\n\nBuffer.prototype.readFloatBE = function readFloatBE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n return ieee754.read(this, offset, false, 23, 4)\n}\n\nBuffer.prototype.readDoubleLE = function readDoubleLE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 8, this.length)\n return ieee754.read(this, offset, true, 52, 8)\n}\n\nBuffer.prototype.readDoubleBE = function readDoubleBE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 8, this.length)\n return ieee754.read(this, offset, false, 52, 8)\n}\n\nfunction checkInt (buf, value, offset, ext, max, min) {\n if (!Buffer.isBuffer(buf)) throw new TypeError('\"buffer\" argument must be a Buffer instance')\n if (value > max || value < min) throw new RangeError('\"value\" argument is out of bounds')\n if (offset + ext > buf.length) throw new RangeError('Index out of range')\n}\n\nBuffer.prototype.writeUIntLE = function writeUIntLE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) {\n var maxBytes = Math.pow(2, 8 * byteLength) - 1\n checkInt(this, value, offset, byteLength, maxBytes, 0)\n }\n\n var mul = 1\n var i = 0\n this[offset] = value & 0xFF\n while (++i < byteLength && (mul *= 0x100)) {\n this[offset + i] = (value / mul) & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeUIntBE = function writeUIntBE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) {\n var maxBytes = Math.pow(2, 8 * byteLength) - 1\n checkInt(this, value, offset, byteLength, maxBytes, 0)\n }\n\n var i = byteLength - 1\n var mul = 1\n this[offset + i] = value & 0xFF\n while (--i >= 0 && (mul *= 0x100)) {\n this[offset + i] = (value / mul) & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeUInt8 = function writeUInt8 (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 1, 0xff, 0)\n this[offset] = (value & 0xff)\n return offset + 1\n}\n\nBuffer.prototype.writeUInt16LE = function writeUInt16LE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n return offset + 2\n}\n\nBuffer.prototype.writeUInt16BE = function writeUInt16BE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n this[offset] = (value >>> 8)\n this[offset + 1] = (value & 0xff)\n return offset + 2\n}\n\nBuffer.prototype.writeUInt32LE = function writeUInt32LE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)\n this[offset + 3] = (value >>> 24)\n this[offset + 2] = (value >>> 16)\n this[offset + 1] = (value >>> 8)\n this[offset] = (value & 0xff)\n return offset + 4\n}\n\nBuffer.prototype.writeUInt32BE = function writeUInt32BE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)\n this[offset] = (value >>> 24)\n this[offset + 1] = (value >>> 16)\n this[offset + 2] = (value >>> 8)\n this[offset + 3] = (value & 0xff)\n return offset + 4\n}\n\nBuffer.prototype.writeIntLE = function writeIntLE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) {\n var limit = Math.pow(2, 8 * byteLength - 1)\n\n checkInt(this, value, offset, byteLength, limit - 1, -limit)\n }\n\n var i = 0\n var mul = 1\n var sub = 0\n this[offset] = value & 0xFF\n while (++i < byteLength && (mul *= 0x100)) {\n if (value < 0 && sub === 0 && this[offset + i - 1] !== 0) {\n sub = 1\n }\n this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeIntBE = function writeIntBE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) {\n var limit = Math.pow(2, 8 * byteLength - 1)\n\n checkInt(this, value, offset, byteLength, limit - 1, -limit)\n }\n\n var i = byteLength - 1\n var mul = 1\n var sub = 0\n this[offset + i] = value & 0xFF\n while (--i >= 0 && (mul *= 0x100)) {\n if (value < 0 && sub === 0 && this[offset + i + 1] !== 0) {\n sub = 1\n }\n this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeInt8 = function writeInt8 (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 1, 0x7f, -0x80)\n if (value < 0) value = 0xff + value + 1\n this[offset] = (value & 0xff)\n return offset + 1\n}\n\nBuffer.prototype.writeInt16LE = function writeInt16LE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n return offset + 2\n}\n\nBuffer.prototype.writeInt16BE = function writeInt16BE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n this[offset] = (value >>> 8)\n this[offset + 1] = (value & 0xff)\n return offset + 2\n}\n\nBuffer.prototype.writeInt32LE = function writeInt32LE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n this[offset + 2] = (value >>> 16)\n this[offset + 3] = (value >>> 24)\n return offset + 4\n}\n\nBuffer.prototype.writeInt32BE = function writeInt32BE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n if (value < 0) value = 0xffffffff + value + 1\n this[offset] = (value >>> 24)\n this[offset + 1] = (value >>> 16)\n this[offset + 2] = (value >>> 8)\n this[offset + 3] = (value & 0xff)\n return offset + 4\n}\n\nfunction checkIEEE754 (buf, value, offset, ext, max, min) {\n if (offset + ext > buf.length) throw new RangeError('Index out of range')\n if (offset < 0) throw new RangeError('Index out of range')\n}\n\nfunction writeFloat (buf, value, offset, littleEndian, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) {\n checkIEEE754(buf, value, offset, 4, 3.4028234663852886e+38, -3.4028234663852886e+38)\n }\n ieee754.write(buf, value, offset, littleEndian, 23, 4)\n return offset + 4\n}\n\nBuffer.prototype.writeFloatLE = function writeFloatLE (value, offset, noAssert) {\n return writeFloat(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeFloatBE = function writeFloatBE (value, offset, noAssert) {\n return writeFloat(this, value, offset, false, noAssert)\n}\n\nfunction writeDouble (buf, value, offset, littleEndian, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) {\n checkIEEE754(buf, value, offset, 8, 1.7976931348623157E+308, -1.7976931348623157E+308)\n }\n ieee754.write(buf, value, offset, littleEndian, 52, 8)\n return offset + 8\n}\n\nBuffer.prototype.writeDoubleLE = function writeDoubleLE (value, offset, noAssert) {\n return writeDouble(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeDoubleBE = function writeDoubleBE (value, offset, noAssert) {\n return writeDouble(this, value, offset, false, noAssert)\n}\n\n// copy(targetBuffer, targetStart=0, sourceStart=0, sourceEnd=buffer.length)\nBuffer.prototype.copy = function copy (target, targetStart, start, end) {\n if (!start) start = 0\n if (!end && end !== 0) end = this.length\n if (targetStart >= target.length) targetStart = target.length\n if (!targetStart) targetStart = 0\n if (end > 0 && end < start) end = start\n\n // Copy 0 bytes; we're done\n if (end === start) return 0\n if (target.length === 0 || this.length === 0) return 0\n\n // Fatal error conditions\n if (targetStart < 0) {\n throw new RangeError('targetStart out of bounds')\n }\n if (start < 0 || start >= this.length) throw new RangeError('sourceStart out of bounds')\n if (end < 0) throw new RangeError('sourceEnd out of bounds')\n\n // Are we oob?\n if (end > this.length) end = this.length\n if (target.length - targetStart < end - start) {\n end = target.length - targetStart + start\n }\n\n var len = end - start\n var i\n\n if (this === target && start < targetStart && targetStart < end) {\n // descending copy from end\n for (i = len - 1; i >= 0; --i) {\n target[i + targetStart] = this[i + start]\n }\n } else if (len < 1000) {\n // ascending copy from start\n for (i = 0; i < len; ++i) {\n target[i + targetStart] = this[i + start]\n }\n } else {\n Uint8Array.prototype.set.call(\n target,\n this.subarray(start, start + len),\n targetStart\n )\n }\n\n return len\n}\n\n// Usage:\n// buffer.fill(number[, offset[, end]])\n// buffer.fill(buffer[, offset[, end]])\n// buffer.fill(string[, offset[, end]][, encoding])\nBuffer.prototype.fill = function fill (val, start, end, encoding) {\n // Handle string cases:\n if (typeof val === 'string') {\n if (typeof start === 'string') {\n encoding = start\n start = 0\n end = this.length\n } else if (typeof end === 'string') {\n encoding = end\n end = this.length\n }\n if (val.length === 1) {\n var code = val.charCodeAt(0)\n if (code < 256) {\n val = code\n }\n }\n if (encoding !== undefined && typeof encoding !== 'string') {\n throw new TypeError('encoding must be a string')\n }\n if (typeof encoding === 'string' && !Buffer.isEncoding(encoding)) {\n throw new TypeError('Unknown encoding: ' + encoding)\n }\n } else if (typeof val === 'number') {\n val = val & 255\n }\n\n // Invalid ranges are not set to a default, so can range check early.\n if (start < 0 || this.length < start || this.length < end) {\n throw new RangeError('Out of range index')\n }\n\n if (end <= start) {\n return this\n }\n\n start = start >>> 0\n end = end === undefined ? this.length : end >>> 0\n\n if (!val) val = 0\n\n var i\n if (typeof val === 'number') {\n for (i = start; i < end; ++i) {\n this[i] = val\n }\n } else {\n var bytes = Buffer.isBuffer(val)\n ? val\n : new Buffer(val, encoding)\n var len = bytes.length\n for (i = 0; i < end - start; ++i) {\n this[i + start] = bytes[i % len]\n }\n }\n\n return this\n}\n\n// HELPER FUNCTIONS\n// ================\n\nvar INVALID_BASE64_RE = /[^+/0-9A-Za-z-_]/g\n\nfunction base64clean (str) {\n // Node strips out invalid characters like \\n and \\t from the string, base64-js does not\n str = stringtrim(str).replace(INVALID_BASE64_RE, '')\n // Node converts strings with length < 2 to ''\n if (str.length < 2) return ''\n // Node allows for non-padded base64 strings (missing trailing ===), base64-js does not\n while (str.length % 4 !== 0) {\n str = str + '='\n }\n return str\n}\n\nfunction stringtrim (str) {\n if (str.trim) return str.trim()\n return str.replace(/^\\s+|\\s+$/g, '')\n}\n\nfunction toHex (n) {\n if (n < 16) return '0' + n.toString(16)\n return n.toString(16)\n}\n\nfunction utf8ToBytes (string, units) {\n units = units || Infinity\n var codePoint\n var length = string.length\n var leadSurrogate = null\n var bytes = []\n\n for (var i = 0; i < length; ++i) {\n codePoint = string.charCodeAt(i)\n\n // is surrogate component\n if (codePoint > 0xD7FF && codePoint < 0xE000) {\n // last char was a lead\n if (!leadSurrogate) {\n // no lead yet\n if (codePoint > 0xDBFF) {\n // unexpected trail\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n continue\n } else if (i + 1 === length) {\n // unpaired lead\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n continue\n }\n\n // valid lead\n leadSurrogate = codePoint\n\n continue\n }\n\n // 2 leads in a row\n if (codePoint < 0xDC00) {\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n leadSurrogate = codePoint\n continue\n }\n\n // valid surrogate pair\n codePoint = (leadSurrogate - 0xD800 << 10 | codePoint - 0xDC00) + 0x10000\n } else if (leadSurrogate) {\n // valid bmp char, but last char was a lead\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n }\n\n leadSurrogate = null\n\n // encode utf8\n if (codePoint < 0x80) {\n if ((units -= 1) < 0) break\n bytes.push(codePoint)\n } else if (codePoint < 0x800) {\n if ((units -= 2) < 0) break\n bytes.push(\n codePoint >> 0x6 | 0xC0,\n codePoint & 0x3F | 0x80\n )\n } else if (codePoint < 0x10000) {\n if ((units -= 3) < 0) break\n bytes.push(\n codePoint >> 0xC | 0xE0,\n codePoint >> 0x6 & 0x3F | 0x80,\n codePoint & 0x3F | 0x80\n )\n } else if (codePoint < 0x110000) {\n if ((units -= 4) < 0) break\n bytes.push(\n codePoint >> 0x12 | 0xF0,\n codePoint >> 0xC & 0x3F | 0x80,\n codePoint >> 0x6 & 0x3F | 0x80,\n codePoint & 0x3F | 0x80\n )\n } else {\n throw new Error('Invalid code point')\n }\n }\n\n return bytes\n}\n\nfunction asciiToBytes (str) {\n var byteArray = []\n for (var i = 0; i < str.length; ++i) {\n // Node's code seems to be doing this and not & 0x7F..\n byteArray.push(str.charCodeAt(i) & 0xFF)\n }\n return byteArray\n}\n\nfunction utf16leToBytes (str, units) {\n var c, hi, lo\n var byteArray = []\n for (var i = 0; i < str.length; ++i) {\n if ((units -= 2) < 0) break\n\n c = str.charCodeAt(i)\n hi = c >> 8\n lo = c % 256\n byteArray.push(lo)\n byteArray.push(hi)\n }\n\n return byteArray\n}\n\nfunction base64ToBytes (str) {\n return base64.toByteArray(base64clean(str))\n}\n\nfunction blitBuffer (src, dst, offset, length) {\n for (var i = 0; i < length; ++i) {\n if ((i + offset >= dst.length) || (i >= src.length)) break\n dst[i + offset] = src[i]\n }\n return i\n}\n\nfunction isnan (val) {\n return val !== val // eslint-disable-line no-self-compare\n}\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/buffer/index.js\n// module id = 1\n// module chunks = 0","// a duplex stream is just a stream that is both readable and writable.\n// Since JS doesn't have multiple prototypal inheritance, this class\n// prototypally inherits from Readable, and then parasitically from\n// Writable.\n\n'use strict';\n\n/**/\n\nvar objectKeys = Object.keys || function (obj) {\n var keys = [];\n for (var key in obj) {\n keys.push(key);\n }return keys;\n};\n/**/\n\nmodule.exports = Duplex;\n\n/**/\nvar processNextTick = require('process-nextick-args');\n/**/\n\n/**/\nvar util = require('core-util-is');\nutil.inherits = require('inherits');\n/**/\n\nvar Readable = require('./_stream_readable');\nvar Writable = require('./_stream_writable');\n\nutil.inherits(Duplex, Readable);\n\nvar keys = objectKeys(Writable.prototype);\nfor (var v = 0; v < keys.length; v++) {\n var method = keys[v];\n if (!Duplex.prototype[method]) Duplex.prototype[method] = Writable.prototype[method];\n}\n\nfunction Duplex(options) {\n if (!(this instanceof Duplex)) return new Duplex(options);\n\n Readable.call(this, options);\n Writable.call(this, options);\n\n if (options && options.readable === false) this.readable = false;\n\n if (options && options.writable === false) this.writable = false;\n\n this.allowHalfOpen = true;\n if (options && options.allowHalfOpen === false) this.allowHalfOpen = false;\n\n this.once('end', onend);\n}\n\n// the no-half-open enforcer\nfunction onend() {\n // if we allow half-open state, or if the writable side ended,\n // then we're ok.\n if (this.allowHalfOpen || this._writableState.ended) return;\n\n // no more data can be written.\n // But allow more writes to happen in this tick.\n processNextTick(onEndNT, this);\n}\n\nfunction onEndNT(self) {\n self.end();\n}\n\nfunction forEach(xs, f) {\n for (var i = 0, l = xs.length; i < l; i++) {\n f(xs[i], i);\n }\n}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/readable-stream/lib/_stream_duplex.js\n// module id = 2\n// module chunks = 0","import Process = require('./process');\nimport TTD = require('./tty');\n\nvar process = new Process(),\n processProxy: Process = {};\n\nfunction defineKey(key: string) {\n if (( processProxy)[key]) {\n // Probably a builtin Object property we don't care about.\n return;\n }\n if (typeof ( process)[key] === 'function') {\n ( processProxy)[key] = function() {\n return ( ( process)[key]).apply(process, arguments);\n };\n } else {\n ( processProxy)[key] = ( process)[key];\n }\n}\n\nfor (var key in process) {\n // Don't check if process.hasOwnProperty; we want to also expose objects\n // up the prototype hierarchy.\n defineKey(key);\n}\n\n// Special key: Ensure we update public-facing values of stdin/stdout/stderr.\nprocessProxy.initializeTTYs = function() {\n if (process.stdin === null) {\n process.initializeTTYs();\n processProxy.stdin = process.stdin;\n processProxy.stdout = process.stdout;\n processProxy.stderr = process.stderr;\n }\n};\n\nprocess.nextTick(() => {\n processProxy.initializeTTYs();\n});\n\nexport = processProxy;\n\n\n\n// WEBPACK FOOTER //\n// ../ts/index.ts","if (typeof Object.create === 'function') {\n // implementation from standard node.js 'util' module\n module.exports = function inherits(ctor, superCtor) {\n ctor.super_ = superCtor\n ctor.prototype = Object.create(superCtor.prototype, {\n constructor: {\n value: ctor,\n enumerable: false,\n writable: true,\n configurable: true\n }\n });\n };\n} else {\n // old school shim for old browsers\n module.exports = function inherits(ctor, superCtor) {\n ctor.super_ = superCtor\n var TempCtor = function () {}\n TempCtor.prototype = superCtor.prototype\n ctor.prototype = new TempCtor()\n ctor.prototype.constructor = ctor\n }\n}\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/inherits/inherits_browser.js\n// module id = 4\n// module chunks = 0","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// NOTE: These type checking functions intentionally don't use `instanceof`\n// because it is fragile and can be easily faked with `Object.create()`.\n\nfunction isArray(arg) {\n if (Array.isArray) {\n return Array.isArray(arg);\n }\n return objectToString(arg) === '[object Array]';\n}\nexports.isArray = isArray;\n\nfunction isBoolean(arg) {\n return typeof arg === 'boolean';\n}\nexports.isBoolean = isBoolean;\n\nfunction isNull(arg) {\n return arg === null;\n}\nexports.isNull = isNull;\n\nfunction isNullOrUndefined(arg) {\n return arg == null;\n}\nexports.isNullOrUndefined = isNullOrUndefined;\n\nfunction isNumber(arg) {\n return typeof arg === 'number';\n}\nexports.isNumber = isNumber;\n\nfunction isString(arg) {\n return typeof arg === 'string';\n}\nexports.isString = isString;\n\nfunction isSymbol(arg) {\n return typeof arg === 'symbol';\n}\nexports.isSymbol = isSymbol;\n\nfunction isUndefined(arg) {\n return arg === void 0;\n}\nexports.isUndefined = isUndefined;\n\nfunction isRegExp(re) {\n return objectToString(re) === '[object RegExp]';\n}\nexports.isRegExp = isRegExp;\n\nfunction isObject(arg) {\n return typeof arg === 'object' && arg !== null;\n}\nexports.isObject = isObject;\n\nfunction isDate(d) {\n return objectToString(d) === '[object Date]';\n}\nexports.isDate = isDate;\n\nfunction isError(e) {\n return (objectToString(e) === '[object Error]' || e instanceof Error);\n}\nexports.isError = isError;\n\nfunction isFunction(arg) {\n return typeof arg === 'function';\n}\nexports.isFunction = isFunction;\n\nfunction isPrimitive(arg) {\n return arg === null ||\n typeof arg === 'boolean' ||\n typeof arg === 'number' ||\n typeof arg === 'string' ||\n typeof arg === 'symbol' || // ES6 symbol\n typeof arg === 'undefined';\n}\nexports.isPrimitive = isPrimitive;\n\nexports.isBuffer = Buffer.isBuffer;\n\nfunction objectToString(o) {\n return Object.prototype.toString.call(o);\n}\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/core-util-is/lib/util.js\n// module id = 5\n// module chunks = 0","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nfunction EventEmitter() {\n this._events = this._events || {};\n this._maxListeners = this._maxListeners || undefined;\n}\nmodule.exports = EventEmitter;\n\n// Backwards-compat with node 0.10.x\nEventEmitter.EventEmitter = EventEmitter;\n\nEventEmitter.prototype._events = undefined;\nEventEmitter.prototype._maxListeners = undefined;\n\n// By default EventEmitters will print a warning if more than 10 listeners are\n// added to it. This is a useful default which helps finding memory leaks.\nEventEmitter.defaultMaxListeners = 10;\n\n// Obviously not all Emitters should be limited to 10. This function allows\n// that to be increased. Set to zero for unlimited.\nEventEmitter.prototype.setMaxListeners = function(n) {\n if (!isNumber(n) || n < 0 || isNaN(n))\n throw TypeError('n must be a positive number');\n this._maxListeners = n;\n return this;\n};\n\nEventEmitter.prototype.emit = function(type) {\n var er, handler, len, args, i, listeners;\n\n if (!this._events)\n this._events = {};\n\n // If there is no 'error' event listener then throw.\n if (type === 'error') {\n if (!this._events.error ||\n (isObject(this._events.error) && !this._events.error.length)) {\n er = arguments[1];\n if (er instanceof Error) {\n throw er; // Unhandled 'error' event\n } else {\n // At least give some kind of context to the user\n var err = new Error('Uncaught, unspecified \"error\" event. (' + er + ')');\n err.context = er;\n throw err;\n }\n }\n }\n\n handler = this._events[type];\n\n if (isUndefined(handler))\n return false;\n\n if (isFunction(handler)) {\n switch (arguments.length) {\n // fast cases\n case 1:\n handler.call(this);\n break;\n case 2:\n handler.call(this, arguments[1]);\n break;\n case 3:\n handler.call(this, arguments[1], arguments[2]);\n break;\n // slower\n default:\n args = Array.prototype.slice.call(arguments, 1);\n handler.apply(this, args);\n }\n } else if (isObject(handler)) {\n args = Array.prototype.slice.call(arguments, 1);\n listeners = handler.slice();\n len = listeners.length;\n for (i = 0; i < len; i++)\n listeners[i].apply(this, args);\n }\n\n return true;\n};\n\nEventEmitter.prototype.addListener = function(type, listener) {\n var m;\n\n if (!isFunction(listener))\n throw TypeError('listener must be a function');\n\n if (!this._events)\n this._events = {};\n\n // To avoid recursion in the case that type === \"newListener\"! Before\n // adding it to the listeners, first emit \"newListener\".\n if (this._events.newListener)\n this.emit('newListener', type,\n isFunction(listener.listener) ?\n listener.listener : listener);\n\n if (!this._events[type])\n // Optimize the case of one listener. Don't need the extra array object.\n this._events[type] = listener;\n else if (isObject(this._events[type]))\n // If we've already got an array, just append.\n this._events[type].push(listener);\n else\n // Adding the second element, need to change to array.\n this._events[type] = [this._events[type], listener];\n\n // Check for listener leak\n if (isObject(this._events[type]) && !this._events[type].warned) {\n if (!isUndefined(this._maxListeners)) {\n m = this._maxListeners;\n } else {\n m = EventEmitter.defaultMaxListeners;\n }\n\n if (m && m > 0 && this._events[type].length > m) {\n this._events[type].warned = true;\n console.error('(node) warning: possible EventEmitter memory ' +\n 'leak detected. %d listeners added. ' +\n 'Use emitter.setMaxListeners() to increase limit.',\n this._events[type].length);\n if (typeof console.trace === 'function') {\n // not supported in IE 10\n console.trace();\n }\n }\n }\n\n return this;\n};\n\nEventEmitter.prototype.on = EventEmitter.prototype.addListener;\n\nEventEmitter.prototype.once = function(type, listener) {\n if (!isFunction(listener))\n throw TypeError('listener must be a function');\n\n var fired = false;\n\n function g() {\n this.removeListener(type, g);\n\n if (!fired) {\n fired = true;\n listener.apply(this, arguments);\n }\n }\n\n g.listener = listener;\n this.on(type, g);\n\n return this;\n};\n\n// emits a 'removeListener' event iff the listener was removed\nEventEmitter.prototype.removeListener = function(type, listener) {\n var list, position, length, i;\n\n if (!isFunction(listener))\n throw TypeError('listener must be a function');\n\n if (!this._events || !this._events[type])\n return this;\n\n list = this._events[type];\n length = list.length;\n position = -1;\n\n if (list === listener ||\n (isFunction(list.listener) && list.listener === listener)) {\n delete this._events[type];\n if (this._events.removeListener)\n this.emit('removeListener', type, listener);\n\n } else if (isObject(list)) {\n for (i = length; i-- > 0;) {\n if (list[i] === listener ||\n (list[i].listener && list[i].listener === listener)) {\n position = i;\n break;\n }\n }\n\n if (position < 0)\n return this;\n\n if (list.length === 1) {\n list.length = 0;\n delete this._events[type];\n } else {\n list.splice(position, 1);\n }\n\n if (this._events.removeListener)\n this.emit('removeListener', type, listener);\n }\n\n return this;\n};\n\nEventEmitter.prototype.removeAllListeners = function(type) {\n var key, listeners;\n\n if (!this._events)\n return this;\n\n // not listening for removeListener, no need to emit\n if (!this._events.removeListener) {\n if (arguments.length === 0)\n this._events = {};\n else if (this._events[type])\n delete this._events[type];\n return this;\n }\n\n // emit removeListener for all listeners on all events\n if (arguments.length === 0) {\n for (key in this._events) {\n if (key === 'removeListener') continue;\n this.removeAllListeners(key);\n }\n this.removeAllListeners('removeListener');\n this._events = {};\n return this;\n }\n\n listeners = this._events[type];\n\n if (isFunction(listeners)) {\n this.removeListener(type, listeners);\n } else if (listeners) {\n // LIFO order\n while (listeners.length)\n this.removeListener(type, listeners[listeners.length - 1]);\n }\n delete this._events[type];\n\n return this;\n};\n\nEventEmitter.prototype.listeners = function(type) {\n var ret;\n if (!this._events || !this._events[type])\n ret = [];\n else if (isFunction(this._events[type]))\n ret = [this._events[type]];\n else\n ret = this._events[type].slice();\n return ret;\n};\n\nEventEmitter.prototype.listenerCount = function(type) {\n if (this._events) {\n var evlistener = this._events[type];\n\n if (isFunction(evlistener))\n return 1;\n else if (evlistener)\n return evlistener.length;\n }\n return 0;\n};\n\nEventEmitter.listenerCount = function(emitter, type) {\n return emitter.listenerCount(type);\n};\n\nfunction isFunction(arg) {\n return typeof arg === 'function';\n}\n\nfunction isNumber(arg) {\n return typeof arg === 'number';\n}\n\nfunction isObject(arg) {\n return typeof arg === 'object' && arg !== null;\n}\n\nfunction isUndefined(arg) {\n return arg === void 0;\n}\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/events/events.js\n// module id = 6\n// module chunks = 0","module.exports = require('buffer').Buffer;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./build/temp/library/webpack/BFSBuffer.js\n// module id = 7\n// module chunks = 0","'use strict';\n\n\nvar TYPED_OK = (typeof Uint8Array !== 'undefined') &&\n (typeof Uint16Array !== 'undefined') &&\n (typeof Int32Array !== 'undefined');\n\n\nexports.assign = function (obj /*from1, from2, from3, ...*/) {\n var sources = Array.prototype.slice.call(arguments, 1);\n while (sources.length) {\n var source = sources.shift();\n if (!source) { continue; }\n\n if (typeof source !== 'object') {\n throw new TypeError(source + 'must be non-object');\n }\n\n for (var p in source) {\n if (source.hasOwnProperty(p)) {\n obj[p] = source[p];\n }\n }\n }\n\n return obj;\n};\n\n\n// reduce buffer size, avoiding mem copy\nexports.shrinkBuf = function (buf, size) {\n if (buf.length === size) { return buf; }\n if (buf.subarray) { return buf.subarray(0, size); }\n buf.length = size;\n return buf;\n};\n\n\nvar fnTyped = {\n arraySet: function (dest, src, src_offs, len, dest_offs) {\n if (src.subarray && dest.subarray) {\n dest.set(src.subarray(src_offs, src_offs + len), dest_offs);\n return;\n }\n // Fallback to ordinary array\n for (var i = 0; i < len; i++) {\n dest[dest_offs + i] = src[src_offs + i];\n }\n },\n // Join array of chunks to single array.\n flattenChunks: function (chunks) {\n var i, l, len, pos, chunk, result;\n\n // calculate data length\n len = 0;\n for (i = 0, l = chunks.length; i < l; i++) {\n len += chunks[i].length;\n }\n\n // join chunks\n result = new Uint8Array(len);\n pos = 0;\n for (i = 0, l = chunks.length; i < l; i++) {\n chunk = chunks[i];\n result.set(chunk, pos);\n pos += chunk.length;\n }\n\n return result;\n }\n};\n\nvar fnUntyped = {\n arraySet: function (dest, src, src_offs, len, dest_offs) {\n for (var i = 0; i < len; i++) {\n dest[dest_offs + i] = src[src_offs + i];\n }\n },\n // Join array of chunks to single array.\n flattenChunks: function (chunks) {\n return [].concat.apply([], chunks);\n }\n};\n\n\n// Enable/Disable typed arrays use, for testing\n//\nexports.setTyped = function (on) {\n if (on) {\n exports.Buf8 = Uint8Array;\n exports.Buf16 = Uint16Array;\n exports.Buf32 = Int32Array;\n exports.assign(exports, fnTyped);\n } else {\n exports.Buf8 = Array;\n exports.Buf16 = Array;\n exports.Buf32 = Array;\n exports.assign(exports, fnUntyped);\n }\n};\n\nexports.setTyped(TYPED_OK);\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/pako/lib/utils/common.js\n// module id = 8\n// module chunks = 0","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nmodule.exports = Stream;\n\nvar EE = require('events').EventEmitter;\nvar inherits = require('inherits');\n\ninherits(Stream, EE);\nStream.Readable = require('readable-stream/readable.js');\nStream.Writable = require('readable-stream/writable.js');\nStream.Duplex = require('readable-stream/duplex.js');\nStream.Transform = require('readable-stream/transform.js');\nStream.PassThrough = require('readable-stream/passthrough.js');\n\n// Backwards-compat with node 0.4.x\nStream.Stream = Stream;\n\n\n\n// old-style streams. Note that the pipe method (the only relevant\n// part of this class) is overridden in the Readable class.\n\nfunction Stream() {\n EE.call(this);\n}\n\nStream.prototype.pipe = function(dest, options) {\n var source = this;\n\n function ondata(chunk) {\n if (dest.writable) {\n if (false === dest.write(chunk) && source.pause) {\n source.pause();\n }\n }\n }\n\n source.on('data', ondata);\n\n function ondrain() {\n if (source.readable && source.resume) {\n source.resume();\n }\n }\n\n dest.on('drain', ondrain);\n\n // If the 'end' option is not supplied, dest.end() will be called when\n // source gets the 'end' or 'close' events. Only dest.end() once.\n if (!dest._isStdio && (!options || options.end !== false)) {\n source.on('end', onend);\n source.on('close', onclose);\n }\n\n var didOnEnd = false;\n function onend() {\n if (didOnEnd) return;\n didOnEnd = true;\n\n dest.end();\n }\n\n\n function onclose() {\n if (didOnEnd) return;\n didOnEnd = true;\n\n if (typeof dest.destroy === 'function') dest.destroy();\n }\n\n // don't leave dangling pipes when there are errors.\n function onerror(er) {\n cleanup();\n if (EE.listenerCount(this, 'error') === 0) {\n throw er; // Unhandled stream error in pipe.\n }\n }\n\n source.on('error', onerror);\n dest.on('error', onerror);\n\n // remove all the event listeners that were added.\n function cleanup() {\n source.removeListener('data', ondata);\n dest.removeListener('drain', ondrain);\n\n source.removeListener('end', onend);\n source.removeListener('close', onclose);\n\n source.removeListener('error', onerror);\n dest.removeListener('error', onerror);\n\n source.removeListener('end', cleanup);\n source.removeListener('close', cleanup);\n\n dest.removeListener('close', cleanup);\n }\n\n source.on('end', cleanup);\n source.on('close', cleanup);\n\n dest.on('close', cleanup);\n\n dest.emit('pipe', source);\n\n // Allow for unix-like usage: A.pipe(B).pipe(C)\n return dest;\n};\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/stream-browserify/index.js\n// module id = 9\n// module chunks = 0","'use strict';\n\nvar buffer = require('buffer');\nvar Buffer = buffer.Buffer;\nvar SlowBuffer = buffer.SlowBuffer;\nvar MAX_LEN = buffer.kMaxLength || 2147483647;\nexports.alloc = function alloc(size, fill, encoding) {\n if (typeof Buffer.alloc === 'function') {\n return Buffer.alloc(size, fill, encoding);\n }\n if (typeof encoding === 'number') {\n throw new TypeError('encoding must not be number');\n }\n if (typeof size !== 'number') {\n throw new TypeError('size must be a number');\n }\n if (size > MAX_LEN) {\n throw new RangeError('size is too large');\n }\n var enc = encoding;\n var _fill = fill;\n if (_fill === undefined) {\n enc = undefined;\n _fill = 0;\n }\n var buf = new Buffer(size);\n if (typeof _fill === 'string') {\n var fillBuf = new Buffer(_fill, enc);\n var flen = fillBuf.length;\n var i = -1;\n while (++i < size) {\n buf[i] = fillBuf[i % flen];\n }\n } else {\n buf.fill(_fill);\n }\n return buf;\n}\nexports.allocUnsafe = function allocUnsafe(size) {\n if (typeof Buffer.allocUnsafe === 'function') {\n return Buffer.allocUnsafe(size);\n }\n if (typeof size !== 'number') {\n throw new TypeError('size must be a number');\n }\n if (size > MAX_LEN) {\n throw new RangeError('size is too large');\n }\n return new Buffer(size);\n}\nexports.from = function from(value, encodingOrOffset, length) {\n if (typeof Buffer.from === 'function' && (!global.Uint8Array || Uint8Array.from !== Buffer.from)) {\n return Buffer.from(value, encodingOrOffset, length);\n }\n if (typeof value === 'number') {\n throw new TypeError('\"value\" argument must not be a number');\n }\n if (typeof value === 'string') {\n return new Buffer(value, encodingOrOffset);\n }\n if (typeof ArrayBuffer !== 'undefined' && value instanceof ArrayBuffer) {\n var offset = encodingOrOffset;\n if (arguments.length === 1) {\n return new Buffer(value);\n }\n if (typeof offset === 'undefined') {\n offset = 0;\n }\n var len = length;\n if (typeof len === 'undefined') {\n len = value.byteLength - offset;\n }\n if (offset >= value.byteLength) {\n throw new RangeError('\\'offset\\' is out of bounds');\n }\n if (len > value.byteLength - offset) {\n throw new RangeError('\\'length\\' is out of bounds');\n }\n return new Buffer(value.slice(offset, offset + len));\n }\n if (Buffer.isBuffer(value)) {\n var out = new Buffer(value.length);\n value.copy(out, 0, 0, value.length);\n return out;\n }\n if (value) {\n if (Array.isArray(value) || (typeof ArrayBuffer !== 'undefined' && value.buffer instanceof ArrayBuffer) || 'length' in value) {\n return new Buffer(value);\n }\n if (value.type === 'Buffer' && Array.isArray(value.data)) {\n return new Buffer(value.data);\n }\n }\n\n throw new TypeError('First argument must be a string, Buffer, ' + 'ArrayBuffer, Array, or array-like object.');\n}\nexports.allocUnsafeSlow = function allocUnsafeSlow(size) {\n if (typeof Buffer.allocUnsafeSlow === 'function') {\n return Buffer.allocUnsafeSlow(size);\n }\n if (typeof size !== 'number') {\n throw new TypeError('size must be a number');\n }\n if (size >= MAX_LEN) {\n throw new RangeError('size is too large');\n }\n return new SlowBuffer(size);\n}\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/buffer-shims/index.js\n// module id = 10\n// module chunks = 0","'use strict';\n\nif (!process.version ||\n process.version.indexOf('v0.') === 0 ||\n process.version.indexOf('v1.') === 0 && process.version.indexOf('v1.8.') !== 0) {\n module.exports = nextTick;\n} else {\n module.exports = process.nextTick;\n}\n\nfunction nextTick(fn, arg1, arg2, arg3) {\n if (typeof fn !== 'function') {\n throw new TypeError('\"callback\" argument must be a function');\n }\n var len = arguments.length;\n var args, i;\n switch (len) {\n case 0:\n case 1:\n return process.nextTick(fn);\n case 2:\n return process.nextTick(function afterTickOne() {\n fn.call(null, arg1);\n });\n case 3:\n return process.nextTick(function afterTickTwo() {\n fn.call(null, arg1, arg2);\n });\n case 4:\n return process.nextTick(function afterTickThree() {\n fn.call(null, arg1, arg2, arg3);\n });\n default:\n args = new Array(len - 1);\n i = 0;\n while (i < args.length) {\n args[i++] = arguments[i];\n }\n return process.nextTick(function afterTick() {\n fn.apply(null, args);\n });\n }\n}\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/process-nextick-args/index.js\n// module id = 11\n// module chunks = 0","// a transform stream is a readable/writable stream where you do\n// something with the data. Sometimes it's called a \"filter\",\n// but that's not a great name for it, since that implies a thing where\n// some bits pass through, and others are simply ignored. (That would\n// be a valid example of a transform, of course.)\n//\n// While the output is causally related to the input, it's not a\n// necessarily symmetric or synchronous transformation. For example,\n// a zlib stream might take multiple plain-text writes(), and then\n// emit a single compressed chunk some time in the future.\n//\n// Here's how this works:\n//\n// The Transform stream has all the aspects of the readable and writable\n// stream classes. When you write(chunk), that calls _write(chunk,cb)\n// internally, and returns false if there's a lot of pending writes\n// buffered up. When you call read(), that calls _read(n) until\n// there's enough pending readable data buffered up.\n//\n// In a transform stream, the written data is placed in a buffer. When\n// _read(n) is called, it transforms the queued up data, calling the\n// buffered _write cb's as it consumes chunks. If consuming a single\n// written chunk would result in multiple output chunks, then the first\n// outputted bit calls the readcb, and subsequent chunks just go into\n// the read buffer, and will cause it to emit 'readable' if necessary.\n//\n// This way, back-pressure is actually determined by the reading side,\n// since _read has to be called to start processing a new chunk. However,\n// a pathological inflate type of transform can cause excessive buffering\n// here. For example, imagine a stream where every byte of input is\n// interpreted as an integer from 0-255, and then results in that many\n// bytes of output. Writing the 4 bytes {ff,ff,ff,ff} would result in\n// 1kb of data being output. In this case, you could write a very small\n// amount of input, and end up with a very large amount of output. In\n// such a pathological inflating mechanism, there'd be no way to tell\n// the system to stop doing the transform. A single 4MB write could\n// cause the system to run out of memory.\n//\n// However, even in such a pathological case, only a single written chunk\n// would be consumed, and then the rest would wait (un-transformed) until\n// the results of the previous transformed chunk were consumed.\n\n'use strict';\n\nmodule.exports = Transform;\n\nvar Duplex = require('./_stream_duplex');\n\n/**/\nvar util = require('core-util-is');\nutil.inherits = require('inherits');\n/**/\n\nutil.inherits(Transform, Duplex);\n\nfunction TransformState(stream) {\n this.afterTransform = function (er, data) {\n return afterTransform(stream, er, data);\n };\n\n this.needTransform = false;\n this.transforming = false;\n this.writecb = null;\n this.writechunk = null;\n this.writeencoding = null;\n}\n\nfunction afterTransform(stream, er, data) {\n var ts = stream._transformState;\n ts.transforming = false;\n\n var cb = ts.writecb;\n\n if (!cb) return stream.emit('error', new Error('no writecb in Transform class'));\n\n ts.writechunk = null;\n ts.writecb = null;\n\n if (data !== null && data !== undefined) stream.push(data);\n\n cb(er);\n\n var rs = stream._readableState;\n rs.reading = false;\n if (rs.needReadable || rs.length < rs.highWaterMark) {\n stream._read(rs.highWaterMark);\n }\n}\n\nfunction Transform(options) {\n if (!(this instanceof Transform)) return new Transform(options);\n\n Duplex.call(this, options);\n\n this._transformState = new TransformState(this);\n\n var stream = this;\n\n // start out asking for a readable event once data is transformed.\n this._readableState.needReadable = true;\n\n // we have implemented the _read method, and done the other things\n // that Readable wants before the first _read call, so unset the\n // sync guard flag.\n this._readableState.sync = false;\n\n if (options) {\n if (typeof options.transform === 'function') this._transform = options.transform;\n\n if (typeof options.flush === 'function') this._flush = options.flush;\n }\n\n // When the writable side finishes, then flush out anything remaining.\n this.once('prefinish', function () {\n if (typeof this._flush === 'function') this._flush(function (er, data) {\n done(stream, er, data);\n });else done(stream);\n });\n}\n\nTransform.prototype.push = function (chunk, encoding) {\n this._transformState.needTransform = false;\n return Duplex.prototype.push.call(this, chunk, encoding);\n};\n\n// This is the part where you do stuff!\n// override this function in implementation classes.\n// 'chunk' is an input chunk.\n//\n// Call `push(newChunk)` to pass along transformed output\n// to the readable side. You may call 'push' zero or more times.\n//\n// Call `cb(err)` when you are done with this chunk. If you pass\n// an error, then that'll put the hurt on the whole operation. If you\n// never call cb(), then you'll never get another chunk.\nTransform.prototype._transform = function (chunk, encoding, cb) {\n throw new Error('_transform() is not implemented');\n};\n\nTransform.prototype._write = function (chunk, encoding, cb) {\n var ts = this._transformState;\n ts.writecb = cb;\n ts.writechunk = chunk;\n ts.writeencoding = encoding;\n if (!ts.transforming) {\n var rs = this._readableState;\n if (ts.needTransform || rs.needReadable || rs.length < rs.highWaterMark) this._read(rs.highWaterMark);\n }\n};\n\n// Doesn't matter what the args are here.\n// _transform does all the work.\n// That we got here means that the readable side wants more data.\nTransform.prototype._read = function (n) {\n var ts = this._transformState;\n\n if (ts.writechunk !== null && ts.writecb && !ts.transforming) {\n ts.transforming = true;\n this._transform(ts.writechunk, ts.writeencoding, ts.afterTransform);\n } else {\n // mark that we need a transform, so that any data that comes in\n // will get processed, now that we've asked for it.\n ts.needTransform = true;\n }\n};\n\nfunction done(stream, er, data) {\n if (er) return stream.emit('error', er);\n\n if (data !== null && data !== undefined) stream.push(data);\n\n // if there's nothing in the write buffer, then that means\n // that nothing more will ever be provided\n var ws = stream._writableState;\n var ts = stream._transformState;\n\n if (ws.length) throw new Error('Calling transform done when ws.length != 0');\n\n if (ts.transforming) throw new Error('Calling transform done when still transforming');\n\n return stream.push(null);\n}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/readable-stream/lib/_stream_transform.js\n// module id = 12\n// module chunks = 0","// A bit simpler than readable streams.\n// Implement an async ._write(chunk, encoding, cb), and it'll handle all\n// the drain event emission and buffering.\n\n'use strict';\n\nmodule.exports = Writable;\n\n/**/\nvar processNextTick = require('process-nextick-args');\n/**/\n\n/**/\nvar asyncWrite = !process.browser && ['v0.10', 'v0.9.'].indexOf(process.version.slice(0, 5)) > -1 ? setImmediate : processNextTick;\n/**/\n\n/**/\nvar Duplex;\n/**/\n\nWritable.WritableState = WritableState;\n\n/**/\nvar util = require('core-util-is');\nutil.inherits = require('inherits');\n/**/\n\n/**/\nvar internalUtil = {\n deprecate: require('util-deprecate')\n};\n/**/\n\n/**/\nvar Stream;\n(function () {\n try {\n Stream = require('st' + 'ream');\n } catch (_) {} finally {\n if (!Stream) Stream = require('events').EventEmitter;\n }\n})();\n/**/\n\nvar Buffer = require('buffer').Buffer;\n/**/\nvar bufferShim = require('buffer-shims');\n/**/\n\nutil.inherits(Writable, Stream);\n\nfunction nop() {}\n\nfunction WriteReq(chunk, encoding, cb) {\n this.chunk = chunk;\n this.encoding = encoding;\n this.callback = cb;\n this.next = null;\n}\n\nfunction WritableState(options, stream) {\n Duplex = Duplex || require('./_stream_duplex');\n\n options = options || {};\n\n // object stream flag to indicate whether or not this stream\n // contains buffers or objects.\n this.objectMode = !!options.objectMode;\n\n if (stream instanceof Duplex) this.objectMode = this.objectMode || !!options.writableObjectMode;\n\n // the point at which write() starts returning false\n // Note: 0 is a valid value, means that we always return false if\n // the entire buffer is not flushed immediately on write()\n var hwm = options.highWaterMark;\n var defaultHwm = this.objectMode ? 16 : 16 * 1024;\n this.highWaterMark = hwm || hwm === 0 ? hwm : defaultHwm;\n\n // cast to ints.\n this.highWaterMark = ~ ~this.highWaterMark;\n\n // drain event flag.\n this.needDrain = false;\n // at the start of calling end()\n this.ending = false;\n // when end() has been called, and returned\n this.ended = false;\n // when 'finish' is emitted\n this.finished = false;\n\n // should we decode strings into buffers before passing to _write?\n // this is here so that some node-core streams can optimize string\n // handling at a lower level.\n var noDecode = options.decodeStrings === false;\n this.decodeStrings = !noDecode;\n\n // Crypto is kind of old and crusty. Historically, its default string\n // encoding is 'binary' so we have to make this configurable.\n // Everything else in the universe uses 'utf8', though.\n this.defaultEncoding = options.defaultEncoding || 'utf8';\n\n // not an actual buffer we keep track of, but a measurement\n // of how much we're waiting to get pushed to some underlying\n // socket or file.\n this.length = 0;\n\n // a flag to see when we're in the middle of a write.\n this.writing = false;\n\n // when true all writes will be buffered until .uncork() call\n this.corked = 0;\n\n // a flag to be able to tell if the onwrite cb is called immediately,\n // or on a later tick. We set this to true at first, because any\n // actions that shouldn't happen until \"later\" should generally also\n // not happen before the first write call.\n this.sync = true;\n\n // a flag to know if we're processing previously buffered items, which\n // may call the _write() callback in the same tick, so that we don't\n // end up in an overlapped onwrite situation.\n this.bufferProcessing = false;\n\n // the callback that's passed to _write(chunk,cb)\n this.onwrite = function (er) {\n onwrite(stream, er);\n };\n\n // the callback that the user supplies to write(chunk,encoding,cb)\n this.writecb = null;\n\n // the amount that is being written when _write is called.\n this.writelen = 0;\n\n this.bufferedRequest = null;\n this.lastBufferedRequest = null;\n\n // number of pending user-supplied write callbacks\n // this must be 0 before 'finish' can be emitted\n this.pendingcb = 0;\n\n // emit prefinish if the only thing we're waiting for is _write cbs\n // This is relevant for synchronous Transform streams\n this.prefinished = false;\n\n // True if the error was already emitted and should not be thrown again\n this.errorEmitted = false;\n\n // count buffered requests\n this.bufferedRequestCount = 0;\n\n // allocate the first CorkedRequest, there is always\n // one allocated and free to use, and we maintain at most two\n this.corkedRequestsFree = new CorkedRequest(this);\n}\n\nWritableState.prototype.getBuffer = function getBuffer() {\n var current = this.bufferedRequest;\n var out = [];\n while (current) {\n out.push(current);\n current = current.next;\n }\n return out;\n};\n\n(function () {\n try {\n Object.defineProperty(WritableState.prototype, 'buffer', {\n get: internalUtil.deprecate(function () {\n return this.getBuffer();\n }, '_writableState.buffer is deprecated. Use _writableState.getBuffer ' + 'instead.')\n });\n } catch (_) {}\n})();\n\n// Test _writableState for inheritance to account for Duplex streams,\n// whose prototype chain only points to Readable.\nvar realHasInstance;\nif (typeof Symbol === 'function' && Symbol.hasInstance && typeof Function.prototype[Symbol.hasInstance] === 'function') {\n realHasInstance = Function.prototype[Symbol.hasInstance];\n Object.defineProperty(Writable, Symbol.hasInstance, {\n value: function (object) {\n if (realHasInstance.call(this, object)) return true;\n\n return object && object._writableState instanceof WritableState;\n }\n });\n} else {\n realHasInstance = function (object) {\n return object instanceof this;\n };\n}\n\nfunction Writable(options) {\n Duplex = Duplex || require('./_stream_duplex');\n\n // Writable ctor is applied to Duplexes, too.\n // `realHasInstance` is necessary because using plain `instanceof`\n // would return false, as no `_writableState` property is attached.\n\n // Trying to use the custom `instanceof` for Writable here will also break the\n // Node.js LazyTransform implementation, which has a non-trivial getter for\n // `_writableState` that would lead to infinite recursion.\n if (!realHasInstance.call(Writable, this) && !(this instanceof Duplex)) {\n return new Writable(options);\n }\n\n this._writableState = new WritableState(options, this);\n\n // legacy.\n this.writable = true;\n\n if (options) {\n if (typeof options.write === 'function') this._write = options.write;\n\n if (typeof options.writev === 'function') this._writev = options.writev;\n }\n\n Stream.call(this);\n}\n\n// Otherwise people can pipe Writable streams, which is just wrong.\nWritable.prototype.pipe = function () {\n this.emit('error', new Error('Cannot pipe, not readable'));\n};\n\nfunction writeAfterEnd(stream, cb) {\n var er = new Error('write after end');\n // TODO: defer error events consistently everywhere, not just the cb\n stream.emit('error', er);\n processNextTick(cb, er);\n}\n\n// If we get something that is not a buffer, string, null, or undefined,\n// and we're not in objectMode, then that's an error.\n// Otherwise stream chunks are all considered to be of length=1, and the\n// watermarks determine how many objects to keep in the buffer, rather than\n// how many bytes or characters.\nfunction validChunk(stream, state, chunk, cb) {\n var valid = true;\n var er = false;\n // Always throw error if a null is written\n // if we are not in object mode then throw\n // if it is not a buffer, string, or undefined.\n if (chunk === null) {\n er = new TypeError('May not write null values to stream');\n } else if (!Buffer.isBuffer(chunk) && typeof chunk !== 'string' && chunk !== undefined && !state.objectMode) {\n er = new TypeError('Invalid non-string/buffer chunk');\n }\n if (er) {\n stream.emit('error', er);\n processNextTick(cb, er);\n valid = false;\n }\n return valid;\n}\n\nWritable.prototype.write = function (chunk, encoding, cb) {\n var state = this._writableState;\n var ret = false;\n\n if (typeof encoding === 'function') {\n cb = encoding;\n encoding = null;\n }\n\n if (Buffer.isBuffer(chunk)) encoding = 'buffer';else if (!encoding) encoding = state.defaultEncoding;\n\n if (typeof cb !== 'function') cb = nop;\n\n if (state.ended) writeAfterEnd(this, cb);else if (validChunk(this, state, chunk, cb)) {\n state.pendingcb++;\n ret = writeOrBuffer(this, state, chunk, encoding, cb);\n }\n\n return ret;\n};\n\nWritable.prototype.cork = function () {\n var state = this._writableState;\n\n state.corked++;\n};\n\nWritable.prototype.uncork = function () {\n var state = this._writableState;\n\n if (state.corked) {\n state.corked--;\n\n if (!state.writing && !state.corked && !state.finished && !state.bufferProcessing && state.bufferedRequest) clearBuffer(this, state);\n }\n};\n\nWritable.prototype.setDefaultEncoding = function setDefaultEncoding(encoding) {\n // node::ParseEncoding() requires lower case.\n if (typeof encoding === 'string') encoding = encoding.toLowerCase();\n if (!(['hex', 'utf8', 'utf-8', 'ascii', 'binary', 'base64', 'ucs2', 'ucs-2', 'utf16le', 'utf-16le', 'raw'].indexOf((encoding + '').toLowerCase()) > -1)) throw new TypeError('Unknown encoding: ' + encoding);\n this._writableState.defaultEncoding = encoding;\n return this;\n};\n\nfunction decodeChunk(state, chunk, encoding) {\n if (!state.objectMode && state.decodeStrings !== false && typeof chunk === 'string') {\n chunk = bufferShim.from(chunk, encoding);\n }\n return chunk;\n}\n\n// if we're already writing something, then just put this\n// in the queue, and wait our turn. Otherwise, call _write\n// If we return false, then we need a drain event, so set that flag.\nfunction writeOrBuffer(stream, state, chunk, encoding, cb) {\n chunk = decodeChunk(state, chunk, encoding);\n\n if (Buffer.isBuffer(chunk)) encoding = 'buffer';\n var len = state.objectMode ? 1 : chunk.length;\n\n state.length += len;\n\n var ret = state.length < state.highWaterMark;\n // we must ensure that previous needDrain will not be reset to false.\n if (!ret) state.needDrain = true;\n\n if (state.writing || state.corked) {\n var last = state.lastBufferedRequest;\n state.lastBufferedRequest = new WriteReq(chunk, encoding, cb);\n if (last) {\n last.next = state.lastBufferedRequest;\n } else {\n state.bufferedRequest = state.lastBufferedRequest;\n }\n state.bufferedRequestCount += 1;\n } else {\n doWrite(stream, state, false, len, chunk, encoding, cb);\n }\n\n return ret;\n}\n\nfunction doWrite(stream, state, writev, len, chunk, encoding, cb) {\n state.writelen = len;\n state.writecb = cb;\n state.writing = true;\n state.sync = true;\n if (writev) stream._writev(chunk, state.onwrite);else stream._write(chunk, encoding, state.onwrite);\n state.sync = false;\n}\n\nfunction onwriteError(stream, state, sync, er, cb) {\n --state.pendingcb;\n if (sync) processNextTick(cb, er);else cb(er);\n\n stream._writableState.errorEmitted = true;\n stream.emit('error', er);\n}\n\nfunction onwriteStateUpdate(state) {\n state.writing = false;\n state.writecb = null;\n state.length -= state.writelen;\n state.writelen = 0;\n}\n\nfunction onwrite(stream, er) {\n var state = stream._writableState;\n var sync = state.sync;\n var cb = state.writecb;\n\n onwriteStateUpdate(state);\n\n if (er) onwriteError(stream, state, sync, er, cb);else {\n // Check if we're actually ready to finish, but don't emit yet\n var finished = needFinish(state);\n\n if (!finished && !state.corked && !state.bufferProcessing && state.bufferedRequest) {\n clearBuffer(stream, state);\n }\n\n if (sync) {\n /**/\n asyncWrite(afterWrite, stream, state, finished, cb);\n /**/\n } else {\n afterWrite(stream, state, finished, cb);\n }\n }\n}\n\nfunction afterWrite(stream, state, finished, cb) {\n if (!finished) onwriteDrain(stream, state);\n state.pendingcb--;\n cb();\n finishMaybe(stream, state);\n}\n\n// Must force callback to be called on nextTick, so that we don't\n// emit 'drain' before the write() consumer gets the 'false' return\n// value, and has a chance to attach a 'drain' listener.\nfunction onwriteDrain(stream, state) {\n if (state.length === 0 && state.needDrain) {\n state.needDrain = false;\n stream.emit('drain');\n }\n}\n\n// if there's something in the buffer waiting, then process it\nfunction clearBuffer(stream, state) {\n state.bufferProcessing = true;\n var entry = state.bufferedRequest;\n\n if (stream._writev && entry && entry.next) {\n // Fast case, write everything using _writev()\n var l = state.bufferedRequestCount;\n var buffer = new Array(l);\n var holder = state.corkedRequestsFree;\n holder.entry = entry;\n\n var count = 0;\n while (entry) {\n buffer[count] = entry;\n entry = entry.next;\n count += 1;\n }\n\n doWrite(stream, state, true, state.length, buffer, '', holder.finish);\n\n // doWrite is almost always async, defer these to save a bit of time\n // as the hot path ends with doWrite\n state.pendingcb++;\n state.lastBufferedRequest = null;\n if (holder.next) {\n state.corkedRequestsFree = holder.next;\n holder.next = null;\n } else {\n state.corkedRequestsFree = new CorkedRequest(state);\n }\n } else {\n // Slow case, write chunks one-by-one\n while (entry) {\n var chunk = entry.chunk;\n var encoding = entry.encoding;\n var cb = entry.callback;\n var len = state.objectMode ? 1 : chunk.length;\n\n doWrite(stream, state, false, len, chunk, encoding, cb);\n entry = entry.next;\n // if we didn't call the onwrite immediately, then\n // it means that we need to wait until it does.\n // also, that means that the chunk and cb are currently\n // being processed, so move the buffer counter past them.\n if (state.writing) {\n break;\n }\n }\n\n if (entry === null) state.lastBufferedRequest = null;\n }\n\n state.bufferedRequestCount = 0;\n state.bufferedRequest = entry;\n state.bufferProcessing = false;\n}\n\nWritable.prototype._write = function (chunk, encoding, cb) {\n cb(new Error('_write() is not implemented'));\n};\n\nWritable.prototype._writev = null;\n\nWritable.prototype.end = function (chunk, encoding, cb) {\n var state = this._writableState;\n\n if (typeof chunk === 'function') {\n cb = chunk;\n chunk = null;\n encoding = null;\n } else if (typeof encoding === 'function') {\n cb = encoding;\n encoding = null;\n }\n\n if (chunk !== null && chunk !== undefined) this.write(chunk, encoding);\n\n // .end() fully uncorks\n if (state.corked) {\n state.corked = 1;\n this.uncork();\n }\n\n // ignore unnecessary end() calls.\n if (!state.ending && !state.finished) endWritable(this, state, cb);\n};\n\nfunction needFinish(state) {\n return state.ending && state.length === 0 && state.bufferedRequest === null && !state.finished && !state.writing;\n}\n\nfunction prefinish(stream, state) {\n if (!state.prefinished) {\n state.prefinished = true;\n stream.emit('prefinish');\n }\n}\n\nfunction finishMaybe(stream, state) {\n var need = needFinish(state);\n if (need) {\n if (state.pendingcb === 0) {\n prefinish(stream, state);\n state.finished = true;\n stream.emit('finish');\n } else {\n prefinish(stream, state);\n }\n }\n return need;\n}\n\nfunction endWritable(stream, state, cb) {\n state.ending = true;\n finishMaybe(stream, state);\n if (cb) {\n if (state.finished) processNextTick(cb);else stream.once('finish', cb);\n }\n state.ended = true;\n stream.writable = false;\n}\n\n// It seems a linked list but it is not\n// there will be only 2 of these for each stream\nfunction CorkedRequest(state) {\n var _this = this;\n\n this.next = null;\n this.entry = null;\n\n this.finish = function (err) {\n var entry = _this.entry;\n _this.entry = null;\n while (entry) {\n var cb = entry.callback;\n state.pendingcb--;\n cb(err);\n entry = entry.next;\n }\n if (state.corkedRequestsFree) {\n state.corkedRequestsFree.next = _this;\n } else {\n state.corkedRequestsFree = _this;\n }\n };\n}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/readable-stream/lib/_stream_writable.js\n// module id = 13\n// module chunks = 0","// Type information only.\nimport _path = require('path');\n\n// Split a filename into [root, dir, basename, ext], unix version\n// 'root' is just a slash, or nothing.\nvar splitPathRe = /^(\\/?|)([\\s\\S]*?)((?:\\.{1,2}|[^\\/]+?|)(\\.[^.\\/]*|))(?:[\\/]*)$/;\nfunction posixSplitPath(filename: string): string[] {\n var out = splitPathRe.exec(filename);\n out.shift();\n return out;\n}\n\n/**\n * Emulates Node's `path` module. This module contains utilities for handling and\n * transforming file paths. **All** of these methods perform only string\n * transformations. The file system is not consulted to check whether paths are\n * valid.\n * @see http://nodejs.org/api/path.html\n * @class\n */\nclass path {\n /**\n * Normalize a string path, taking care of '..' and '.' parts.\n *\n * When multiple slashes are found, they're replaced by a single one; when the path contains a trailing slash, it is preserved. On Windows backslashes are used.\n * @example Usage example\n * path.normalize('/foo/bar//baz/asdf/quux/..')\n * // returns\n * '/foo/bar/baz/asdf'\n * @param [String] p The path to normalize.\n * @return [String]\n */\n public static normalize(p: string): string {\n // Special case: '' -> '.'\n if (p === '') {\n p = '.';\n }\n // It's very important to know if the path is relative or not, since it\n // changes how we process .. and reconstruct the split string.\n var absolute = p.charAt(0) === path.sep;\n // Remove repeated //s\n p = path._removeDuplicateSeps(p);\n // Try to remove as many '../' as possible, and remove '.' completely.\n var components = p.split(path.sep);\n var goodComponents: string[] = [];\n for (var idx = 0; idx < components.length; idx++) {\n var c = components[idx];\n if (c === '.') {\n continue;\n } else if (c === '..' && (absolute || (!absolute && goodComponents.length > 0 && goodComponents[0] !== '..'))) {\n // In the absolute case: Path is relative to root, so we may pop even if\n // goodComponents is empty (e.g. /../ => /)\n // In the relative case: We're getting rid of a directory that preceded\n // it (e.g. /foo/../bar -> /bar)\n goodComponents.pop();\n } else {\n goodComponents.push(c);\n }\n }\n\n // Add in '.' when it's a relative path with no other nonempty components.\n // Possible results: '.' and './' (input: [''] or [])\n // @todo Can probably simplify this logic.\n if (!absolute && goodComponents.length < 2) {\n switch (goodComponents.length) {\n case 1:\n if (goodComponents[0] === '') {\n goodComponents.unshift('.');\n }\n break;\n default:\n goodComponents.push('.');\n }\n }\n p = goodComponents.join(path.sep);\n if (absolute && p.charAt(0) !== path.sep) {\n p = path.sep + p;\n }\n return p;\n }\n\n /**\n * Join all arguments together and normalize the resulting path.\n *\n * Arguments must be strings.\n * @example Usage\n * path.join('/foo', 'bar', 'baz/asdf', 'quux', '..')\n * // returns\n * '/foo/bar/baz/asdf'\n *\n * path.join('foo', {}, 'bar')\n * // throws exception\n * TypeError: Arguments to path.join must be strings\n * @param [String,...] paths Each component of the path\n * @return [String]\n */\n public static join(...paths: any[]): string {\n // Required: Prune any non-strings from the path. I also prune empty segments\n // so we can do a simple join of the array.\n var processed: string[] = [];\n for (var i = 0; i < paths.length; i++) {\n var segment = paths[i];\n if (typeof segment !== 'string') {\n throw new TypeError(\"Invalid argument type to path.join: \" + (typeof segment));\n } else if (segment !== '') {\n processed.push(segment);\n }\n }\n return path.normalize(processed.join(path.sep));\n }\n\n /**\n * Resolves to to an absolute path.\n *\n * If to isn't already absolute from arguments are prepended in right to left\n * order, until an absolute path is found. If after using all from paths still\n * no absolute path is found, the current working directory is used as well.\n * The resulting path is normalized, and trailing slashes are removed unless\n * the path gets resolved to the root directory. Non-string arguments are\n * ignored.\n *\n * Another way to think of it is as a sequence of cd commands in a shell.\n *\n * path.resolve('foo/bar', '/tmp/file/', '..', 'a/../subfile')\n *\n * Is similar to:\n *\n * cd foo/bar\n * cd /tmp/file/\n * cd ..\n * cd a/../subfile\n * pwd\n *\n * The difference is that the different paths don't need to exist and may also\n * be files.\n * @example Usage example\n * path.resolve('/foo/bar', './baz')\n * // returns\n * '/foo/bar/baz'\n *\n * path.resolve('/foo/bar', '/tmp/file/')\n * // returns\n * '/tmp/file'\n *\n * path.resolve('wwwroot', 'static_files/png/', '../gif/image.gif')\n * // if currently in /home/myself/node, it returns\n * '/home/myself/node/wwwroot/static_files/gif/image.gif'\n * @param [String,...] paths\n * @return [String]\n */\n public static resolve(...paths: string[]): string {\n // Monitor for invalid paths, throw out empty paths, and look for the *last*\n // absolute path that we see.\n var processed: string[] = [];\n for (var i = 0; i < paths.length; i++) {\n var p = paths[i];\n if (typeof p !== 'string') {\n throw new TypeError(\"Invalid argument type to path.join: \" + (typeof p));\n } else if (p !== '') {\n // Remove anything that has occurred before this absolute path, as it\n // doesn't matter.\n if (p.charAt(0) === path.sep) {\n processed = [];\n }\n processed.push(p);\n }\n }\n // Special: Remove trailing slash unless it's the root\n var resolved = path.normalize(processed.join(path.sep));\n if (resolved.length > 1 && resolved.charAt(resolved.length - 1) === path.sep) {\n return resolved.substr(0, resolved.length - 1);\n }\n // Special: If it doesn't start with '/', it's relative and we need to append\n // the current directory.\n if (resolved.charAt(0) !== path.sep) {\n // Remove ./, since we're going to append the current directory.\n if (resolved.charAt(0) === '.' && (resolved.length === 1 || resolved.charAt(1) === path.sep)) {\n resolved = resolved.length === 1 ? '' : resolved.substr(2);\n }\n // Append the current directory, which *must* be an absolute path.\n var cwd = process.cwd();\n if (resolved !== '') {\n // cwd will never end in a /... unless it's the root.\n resolved = this.normalize(cwd + (cwd !== '/' ? path.sep : '') + resolved);\n } else {\n resolved = cwd;\n }\n }\n return resolved;\n }\n\n /**\n * Solve the relative path from from to to.\n *\n * At times we have two absolute paths, and we need to derive the relative path\n * from one to the other. This is actually the reverse transform of\n * path.resolve, which means we see that:\n *\n * path.resolve(from, path.relative(from, to)) == path.resolve(to)\n *\n * @example Usage example\n * path.relative('C:\\\\orandea\\\\test\\\\aaa', 'C:\\\\orandea\\\\impl\\\\bbb')\n * // returns\n * '..\\\\..\\\\impl\\\\bbb'\n *\n * path.relative('/data/orandea/test/aaa', '/data/orandea/impl/bbb')\n * // returns\n * '../../impl/bbb'\n * @param [String] from\n * @param [String] to\n * @return [String]\n */\n public static relative(from: string, to: string): string {\n var i: number;\n // Alright. Let's resolve these two to absolute paths and remove any\n // weirdness.\n from = path.resolve(from);\n to = path.resolve(to);\n var fromSegs = from.split(path.sep);\n var toSegs = to.split(path.sep);\n // Remove the first segment on both, as it's '' (both are absolute paths)\n toSegs.shift();\n fromSegs.shift();\n // There are two segments to this path:\n // * Going *up* the directory hierarchy with '..'\n // * Going *down* the directory hierarchy with foo/baz/bat.\n var upCount = 0;\n var downSegs: string[] = [];\n // Figure out how many things in 'from' are shared with 'to'.\n for (i = 0; i < fromSegs.length; i++) {\n var seg = fromSegs[i];\n if (seg === toSegs[i]) {\n continue;\n }\n // The rest of 'from', including the current element, indicates how many\n // directories we need to go up.\n upCount = fromSegs.length - i;\n break;\n }\n // The rest of 'to' indicates where we need to change to. We place this\n // outside of the loop, as toSegs.length may be greater than fromSegs.length.\n downSegs = toSegs.slice(i);\n // Special case: If 'from' is '/'\n if (fromSegs.length === 1 && fromSegs[0] === '') {\n upCount = 0;\n }\n // upCount can't be greater than the number of fromSegs\n // (cd .. from / is still /)\n if (upCount > fromSegs.length) {\n upCount = fromSegs.length;\n }\n // Create the final string!\n var rv = '';\n for (i = 0; i < upCount; i++) {\n rv += '../';\n }\n rv += downSegs.join(path.sep);\n // Special case: Remove trailing '/'. Happens if it's all up and no down.\n if (rv.length > 1 && rv.charAt(rv.length - 1) === path.sep) {\n rv = rv.substr(0, rv.length - 1);\n }\n return rv;\n }\n\n /**\n * Return the directory name of a path. Similar to the Unix `dirname` command.\n *\n * Note that BrowserFS does not validate if the path is actually a valid\n * directory.\n * @example Usage example\n * path.dirname('/foo/bar/baz/asdf/quux')\n * // returns\n * '/foo/bar/baz/asdf'\n * @param [String] p The path to get the directory name of.\n * @return [String]\n */\n public static dirname(p: string): string {\n // We get rid of //, but we don't modify anything else (e.g. any extraneous .\n // and ../ are kept intact)\n p = path._removeDuplicateSeps(p);\n var absolute = p.charAt(0) === path.sep;\n var sections = p.split(path.sep);\n // Do 1 if it's /foo/bar, 2 if it's /foo/bar/\n if (sections.pop() === '' && sections.length > 0) {\n sections.pop();\n }\n // # of sections needs to be > 1 if absolute, since the first section is '' for '/'.\n // If not absolute, the first section is the first part of the path, and is OK\n // to return.\n if (sections.length > 1 || (sections.length === 1 && !absolute)) {\n return sections.join(path.sep);\n } else if (absolute) {\n return path.sep;\n } else {\n return '.';\n }\n }\n\n /**\n * Return the last portion of a path. Similar to the Unix basename command.\n * @example Usage example\n * path.basename('/foo/bar/baz/asdf/quux.html')\n * // returns\n * 'quux.html'\n *\n * path.basename('/foo/bar/baz/asdf/quux.html', '.html')\n * // returns\n * 'quux'\n * @param [String] p\n * @param [String?] ext\n * @return [String]\n */\n public static basename(p: string, ext: string = \"\"): string {\n // Special case: Normalize will modify this to '.'\n if (p === '') {\n return p;\n }\n // Normalize the string first to remove any weirdness.\n p = path.normalize(p);\n // Get the last part of the string.\n var sections = p.split(path.sep);\n var lastPart = sections[sections.length - 1];\n // Special case: If it's empty, then we have a string like so: foo/\n // Meaning, 'foo' is guaranteed to be a directory.\n if (lastPart === '' && sections.length > 1) {\n return sections[sections.length - 2];\n }\n // Remove the extension, if need be.\n if (ext.length > 0) {\n var lastPartExt = lastPart.substr(lastPart.length - ext.length);\n if (lastPartExt === ext) {\n return lastPart.substr(0, lastPart.length - ext.length);\n }\n }\n return lastPart;\n }\n\n /**\n * Return the extension of the path, from the last '.' to end of string in the\n * last portion of the path. If there is no '.' in the last portion of the path\n * or the first character of it is '.', then it returns an empty string.\n * @example Usage example\n * path.extname('index.html')\n * // returns\n * '.html'\n *\n * path.extname('index.')\n * // returns\n * '.'\n *\n * path.extname('index')\n * // returns\n * ''\n * @param [String] p\n * @return [String]\n */\n public static extname(p: string): string {\n p = path.normalize(p);\n var sections = p.split(path.sep);\n p = sections.pop();\n // Special case: foo/file.ext/ should return '.ext'\n if (p === '' && sections.length > 0) {\n p = sections.pop();\n }\n if (p === '..') {\n return '';\n }\n var i = p.lastIndexOf('.');\n if (i === -1 || i === 0) {\n return '';\n }\n return p.substr(i);\n }\n\n /**\n * Checks if the given path is an absolute path.\n *\n * Despite not being documented, this is a tested part of Node's path API.\n * @param [String] p\n * @return [Boolean] True if the path appears to be an absolute path.\n */\n public static isAbsolute(p: string): boolean {\n return p.length > 0 && p.charAt(0) === path.sep;\n }\n\n /**\n * Unknown. Undocumented.\n */\n public static _makeLong(p: string): string {\n return p;\n }\n\n /**\n * Returns an object from a path string.\n */\n public static parse(p: string): _path.ParsedPath {\n var allParts = posixSplitPath(p);\n return {\n root: allParts[0],\n dir: allParts[0] + allParts[1].slice(0, -1),\n base: allParts[2],\n ext: allParts[3],\n name: allParts[2].slice(0, allParts[2].length - allParts[3].length)\n };\n }\n\n public static format(pathObject: _path.ParsedPath): string {\n if (pathObject === null || typeof pathObject !== 'object') {\n throw new TypeError(`Parameter 'pathObject' must be an object, not ${typeof pathObject}`);\n }\n\n var root = pathObject.root || '';\n\n if (typeof root !== 'string') {\n throw new TypeError(\n \"'pathObject.root' must be a string or undefined, not \" +\n typeof pathObject.root\n );\n }\n\n var dir = pathObject.dir ? pathObject.dir + path.sep : '';\n var base = pathObject.base || '';\n return dir + base;\n }\n\n // The platform-specific file separator. BrowserFS uses `/`.\n public static sep: string = '/';\n\n private static _replaceRegex = new RegExp(\"//+\", 'g');\n\n private static _removeDuplicateSeps(p: string): string {\n p = p.replace(this._replaceRegex, this.sep);\n return p;\n }\n\n // The platform-specific path delimiter. BrowserFS uses `:`.\n public static delimiter = ':';\n\n public static posix = path;\n // XXX: Typing hack. We don't actually support win32.\n public static win32 = path;\n}\n\nvar _: typeof _path = path;\n\nexport = path;\n\n\n\n// WEBPACK FOOTER //\n// ../ts/path.ts","// a passthrough stream.\n// basically just the most minimal sort of Transform stream.\n// Every written chunk gets output as-is.\n\n'use strict';\n\nmodule.exports = PassThrough;\n\nvar Transform = require('./_stream_transform');\n\n/**/\nvar util = require('core-util-is');\nutil.inherits = require('inherits');\n/**/\n\nutil.inherits(PassThrough, Transform);\n\nfunction PassThrough(options) {\n if (!(this instanceof PassThrough)) return new PassThrough(options);\n\n Transform.call(this, options);\n}\n\nPassThrough.prototype._transform = function (chunk, encoding, cb) {\n cb(null, chunk);\n};\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/readable-stream/lib/_stream_passthrough.js\n// module id = 15\n// module chunks = 0","'use strict';\n\nmodule.exports = Readable;\n\n/**/\nvar processNextTick = require('process-nextick-args');\n/**/\n\n/**/\nvar isArray = require('isarray');\n/**/\n\n/**/\nvar Duplex;\n/**/\n\nReadable.ReadableState = ReadableState;\n\n/**/\nvar EE = require('events').EventEmitter;\n\nvar EElistenerCount = function (emitter, type) {\n return emitter.listeners(type).length;\n};\n/**/\n\n/**/\nvar Stream;\n(function () {\n try {\n Stream = require('st' + 'ream');\n } catch (_) {} finally {\n if (!Stream) Stream = require('events').EventEmitter;\n }\n})();\n/**/\n\nvar Buffer = require('buffer').Buffer;\n/**/\nvar bufferShim = require('buffer-shims');\n/**/\n\n/**/\nvar util = require('core-util-is');\nutil.inherits = require('inherits');\n/**/\n\n/**/\nvar debugUtil = require('util');\nvar debug = void 0;\nif (debugUtil && debugUtil.debuglog) {\n debug = debugUtil.debuglog('stream');\n} else {\n debug = function () {};\n}\n/**/\n\nvar BufferList = require('./internal/streams/BufferList');\nvar StringDecoder;\n\nutil.inherits(Readable, Stream);\n\nfunction prependListener(emitter, event, fn) {\n // Sadly this is not cacheable as some libraries bundle their own\n // event emitter implementation with them.\n if (typeof emitter.prependListener === 'function') {\n return emitter.prependListener(event, fn);\n } else {\n // This is a hack to make sure that our error handler is attached before any\n // userland ones. NEVER DO THIS. This is here only because this code needs\n // to continue to work with older versions of Node.js that do not include\n // the prependListener() method. The goal is to eventually remove this hack.\n if (!emitter._events || !emitter._events[event]) emitter.on(event, fn);else if (isArray(emitter._events[event])) emitter._events[event].unshift(fn);else emitter._events[event] = [fn, emitter._events[event]];\n }\n}\n\nfunction ReadableState(options, stream) {\n Duplex = Duplex || require('./_stream_duplex');\n\n options = options || {};\n\n // object stream flag. Used to make read(n) ignore n and to\n // make all the buffer merging and length checks go away\n this.objectMode = !!options.objectMode;\n\n if (stream instanceof Duplex) this.objectMode = this.objectMode || !!options.readableObjectMode;\n\n // the point at which it stops calling _read() to fill the buffer\n // Note: 0 is a valid value, means \"don't call _read preemptively ever\"\n var hwm = options.highWaterMark;\n var defaultHwm = this.objectMode ? 16 : 16 * 1024;\n this.highWaterMark = hwm || hwm === 0 ? hwm : defaultHwm;\n\n // cast to ints.\n this.highWaterMark = ~ ~this.highWaterMark;\n\n // A linked list is used to store data chunks instead of an array because the\n // linked list can remove elements from the beginning faster than\n // array.shift()\n this.buffer = new BufferList();\n this.length = 0;\n this.pipes = null;\n this.pipesCount = 0;\n this.flowing = null;\n this.ended = false;\n this.endEmitted = false;\n this.reading = false;\n\n // a flag to be able to tell if the onwrite cb is called immediately,\n // or on a later tick. We set this to true at first, because any\n // actions that shouldn't happen until \"later\" should generally also\n // not happen before the first write call.\n this.sync = true;\n\n // whenever we return null, then we set a flag to say\n // that we're awaiting a 'readable' event emission.\n this.needReadable = false;\n this.emittedReadable = false;\n this.readableListening = false;\n this.resumeScheduled = false;\n\n // Crypto is kind of old and crusty. Historically, its default string\n // encoding is 'binary' so we have to make this configurable.\n // Everything else in the universe uses 'utf8', though.\n this.defaultEncoding = options.defaultEncoding || 'utf8';\n\n // when piping, we only care about 'readable' events that happen\n // after read()ing all the bytes and not getting any pushback.\n this.ranOut = false;\n\n // the number of writers that are awaiting a drain event in .pipe()s\n this.awaitDrain = 0;\n\n // if true, a maybeReadMore has been scheduled\n this.readingMore = false;\n\n this.decoder = null;\n this.encoding = null;\n if (options.encoding) {\n if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder;\n this.decoder = new StringDecoder(options.encoding);\n this.encoding = options.encoding;\n }\n}\n\nfunction Readable(options) {\n Duplex = Duplex || require('./_stream_duplex');\n\n if (!(this instanceof Readable)) return new Readable(options);\n\n this._readableState = new ReadableState(options, this);\n\n // legacy\n this.readable = true;\n\n if (options && typeof options.read === 'function') this._read = options.read;\n\n Stream.call(this);\n}\n\n// Manually shove something into the read() buffer.\n// This returns true if the highWaterMark has not been hit yet,\n// similar to how Writable.write() returns true if you should\n// write() some more.\nReadable.prototype.push = function (chunk, encoding) {\n var state = this._readableState;\n\n if (!state.objectMode && typeof chunk === 'string') {\n encoding = encoding || state.defaultEncoding;\n if (encoding !== state.encoding) {\n chunk = bufferShim.from(chunk, encoding);\n encoding = '';\n }\n }\n\n return readableAddChunk(this, state, chunk, encoding, false);\n};\n\n// Unshift should *always* be something directly out of read()\nReadable.prototype.unshift = function (chunk) {\n var state = this._readableState;\n return readableAddChunk(this, state, chunk, '', true);\n};\n\nReadable.prototype.isPaused = function () {\n return this._readableState.flowing === false;\n};\n\nfunction readableAddChunk(stream, state, chunk, encoding, addToFront) {\n var er = chunkInvalid(state, chunk);\n if (er) {\n stream.emit('error', er);\n } else if (chunk === null) {\n state.reading = false;\n onEofChunk(stream, state);\n } else if (state.objectMode || chunk && chunk.length > 0) {\n if (state.ended && !addToFront) {\n var e = new Error('stream.push() after EOF');\n stream.emit('error', e);\n } else if (state.endEmitted && addToFront) {\n var _e = new Error('stream.unshift() after end event');\n stream.emit('error', _e);\n } else {\n var skipAdd;\n if (state.decoder && !addToFront && !encoding) {\n chunk = state.decoder.write(chunk);\n skipAdd = !state.objectMode && chunk.length === 0;\n }\n\n if (!addToFront) state.reading = false;\n\n // Don't add to the buffer if we've decoded to an empty string chunk and\n // we're not in object mode\n if (!skipAdd) {\n // if we want the data now, just emit it.\n if (state.flowing && state.length === 0 && !state.sync) {\n stream.emit('data', chunk);\n stream.read(0);\n } else {\n // update the buffer info.\n state.length += state.objectMode ? 1 : chunk.length;\n if (addToFront) state.buffer.unshift(chunk);else state.buffer.push(chunk);\n\n if (state.needReadable) emitReadable(stream);\n }\n }\n\n maybeReadMore(stream, state);\n }\n } else if (!addToFront) {\n state.reading = false;\n }\n\n return needMoreData(state);\n}\n\n// if it's past the high water mark, we can push in some more.\n// Also, if we have no data yet, we can stand some\n// more bytes. This is to work around cases where hwm=0,\n// such as the repl. Also, if the push() triggered a\n// readable event, and the user called read(largeNumber) such that\n// needReadable was set, then we ought to push more, so that another\n// 'readable' event will be triggered.\nfunction needMoreData(state) {\n return !state.ended && (state.needReadable || state.length < state.highWaterMark || state.length === 0);\n}\n\n// backwards compatibility.\nReadable.prototype.setEncoding = function (enc) {\n if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder;\n this._readableState.decoder = new StringDecoder(enc);\n this._readableState.encoding = enc;\n return this;\n};\n\n// Don't raise the hwm > 8MB\nvar MAX_HWM = 0x800000;\nfunction computeNewHighWaterMark(n) {\n if (n >= MAX_HWM) {\n n = MAX_HWM;\n } else {\n // Get the next highest power of 2 to prevent increasing hwm excessively in\n // tiny amounts\n n--;\n n |= n >>> 1;\n n |= n >>> 2;\n n |= n >>> 4;\n n |= n >>> 8;\n n |= n >>> 16;\n n++;\n }\n return n;\n}\n\n// This function is designed to be inlinable, so please take care when making\n// changes to the function body.\nfunction howMuchToRead(n, state) {\n if (n <= 0 || state.length === 0 && state.ended) return 0;\n if (state.objectMode) return 1;\n if (n !== n) {\n // Only flow one buffer at a time\n if (state.flowing && state.length) return state.buffer.head.data.length;else return state.length;\n }\n // If we're asking for more than the current hwm, then raise the hwm.\n if (n > state.highWaterMark) state.highWaterMark = computeNewHighWaterMark(n);\n if (n <= state.length) return n;\n // Don't have enough\n if (!state.ended) {\n state.needReadable = true;\n return 0;\n }\n return state.length;\n}\n\n// you can override either this method, or the async _read(n) below.\nReadable.prototype.read = function (n) {\n debug('read', n);\n n = parseInt(n, 10);\n var state = this._readableState;\n var nOrig = n;\n\n if (n !== 0) state.emittedReadable = false;\n\n // if we're doing read(0) to trigger a readable event, but we\n // already have a bunch of data in the buffer, then just trigger\n // the 'readable' event and move on.\n if (n === 0 && state.needReadable && (state.length >= state.highWaterMark || state.ended)) {\n debug('read: emitReadable', state.length, state.ended);\n if (state.length === 0 && state.ended) endReadable(this);else emitReadable(this);\n return null;\n }\n\n n = howMuchToRead(n, state);\n\n // if we've ended, and we're now clear, then finish it up.\n if (n === 0 && state.ended) {\n if (state.length === 0) endReadable(this);\n return null;\n }\n\n // All the actual chunk generation logic needs to be\n // *below* the call to _read. The reason is that in certain\n // synthetic stream cases, such as passthrough streams, _read\n // may be a completely synchronous operation which may change\n // the state of the read buffer, providing enough data when\n // before there was *not* enough.\n //\n // So, the steps are:\n // 1. Figure out what the state of things will be after we do\n // a read from the buffer.\n //\n // 2. If that resulting state will trigger a _read, then call _read.\n // Note that this may be asynchronous, or synchronous. Yes, it is\n // deeply ugly to write APIs this way, but that still doesn't mean\n // that the Readable class should behave improperly, as streams are\n // designed to be sync/async agnostic.\n // Take note if the _read call is sync or async (ie, if the read call\n // has returned yet), so that we know whether or not it's safe to emit\n // 'readable' etc.\n //\n // 3. Actually pull the requested chunks out of the buffer and return.\n\n // if we need a readable event, then we need to do some reading.\n var doRead = state.needReadable;\n debug('need readable', doRead);\n\n // if we currently have less than the highWaterMark, then also read some\n if (state.length === 0 || state.length - n < state.highWaterMark) {\n doRead = true;\n debug('length less than watermark', doRead);\n }\n\n // however, if we've ended, then there's no point, and if we're already\n // reading, then it's unnecessary.\n if (state.ended || state.reading) {\n doRead = false;\n debug('reading or ended', doRead);\n } else if (doRead) {\n debug('do read');\n state.reading = true;\n state.sync = true;\n // if the length is currently zero, then we *need* a readable event.\n if (state.length === 0) state.needReadable = true;\n // call internal read method\n this._read(state.highWaterMark);\n state.sync = false;\n // If _read pushed data synchronously, then `reading` will be false,\n // and we need to re-evaluate how much data we can return to the user.\n if (!state.reading) n = howMuchToRead(nOrig, state);\n }\n\n var ret;\n if (n > 0) ret = fromList(n, state);else ret = null;\n\n if (ret === null) {\n state.needReadable = true;\n n = 0;\n } else {\n state.length -= n;\n }\n\n if (state.length === 0) {\n // If we have nothing in the buffer, then we want to know\n // as soon as we *do* get something into the buffer.\n if (!state.ended) state.needReadable = true;\n\n // If we tried to read() past the EOF, then emit end on the next tick.\n if (nOrig !== n && state.ended) endReadable(this);\n }\n\n if (ret !== null) this.emit('data', ret);\n\n return ret;\n};\n\nfunction chunkInvalid(state, chunk) {\n var er = null;\n if (!Buffer.isBuffer(chunk) && typeof chunk !== 'string' && chunk !== null && chunk !== undefined && !state.objectMode) {\n er = new TypeError('Invalid non-string/buffer chunk');\n }\n return er;\n}\n\nfunction onEofChunk(stream, state) {\n if (state.ended) return;\n if (state.decoder) {\n var chunk = state.decoder.end();\n if (chunk && chunk.length) {\n state.buffer.push(chunk);\n state.length += state.objectMode ? 1 : chunk.length;\n }\n }\n state.ended = true;\n\n // emit 'readable' now to make sure it gets picked up.\n emitReadable(stream);\n}\n\n// Don't emit readable right away in sync mode, because this can trigger\n// another read() call => stack overflow. This way, it might trigger\n// a nextTick recursion warning, but that's not so bad.\nfunction emitReadable(stream) {\n var state = stream._readableState;\n state.needReadable = false;\n if (!state.emittedReadable) {\n debug('emitReadable', state.flowing);\n state.emittedReadable = true;\n if (state.sync) processNextTick(emitReadable_, stream);else emitReadable_(stream);\n }\n}\n\nfunction emitReadable_(stream) {\n debug('emit readable');\n stream.emit('readable');\n flow(stream);\n}\n\n// at this point, the user has presumably seen the 'readable' event,\n// and called read() to consume some data. that may have triggered\n// in turn another _read(n) call, in which case reading = true if\n// it's in progress.\n// However, if we're not ended, or reading, and the length < hwm,\n// then go ahead and try to read some more preemptively.\nfunction maybeReadMore(stream, state) {\n if (!state.readingMore) {\n state.readingMore = true;\n processNextTick(maybeReadMore_, stream, state);\n }\n}\n\nfunction maybeReadMore_(stream, state) {\n var len = state.length;\n while (!state.reading && !state.flowing && !state.ended && state.length < state.highWaterMark) {\n debug('maybeReadMore read 0');\n stream.read(0);\n if (len === state.length)\n // didn't get any data, stop spinning.\n break;else len = state.length;\n }\n state.readingMore = false;\n}\n\n// abstract method. to be overridden in specific implementation classes.\n// call cb(er, data) where data is <= n in length.\n// for virtual (non-string, non-buffer) streams, \"length\" is somewhat\n// arbitrary, and perhaps not very meaningful.\nReadable.prototype._read = function (n) {\n this.emit('error', new Error('_read() is not implemented'));\n};\n\nReadable.prototype.pipe = function (dest, pipeOpts) {\n var src = this;\n var state = this._readableState;\n\n switch (state.pipesCount) {\n case 0:\n state.pipes = dest;\n break;\n case 1:\n state.pipes = [state.pipes, dest];\n break;\n default:\n state.pipes.push(dest);\n break;\n }\n state.pipesCount += 1;\n debug('pipe count=%d opts=%j', state.pipesCount, pipeOpts);\n\n var doEnd = (!pipeOpts || pipeOpts.end !== false) && dest !== process.stdout && dest !== process.stderr;\n\n var endFn = doEnd ? onend : cleanup;\n if (state.endEmitted) processNextTick(endFn);else src.once('end', endFn);\n\n dest.on('unpipe', onunpipe);\n function onunpipe(readable) {\n debug('onunpipe');\n if (readable === src) {\n cleanup();\n }\n }\n\n function onend() {\n debug('onend');\n dest.end();\n }\n\n // when the dest drains, it reduces the awaitDrain counter\n // on the source. This would be more elegant with a .once()\n // handler in flow(), but adding and removing repeatedly is\n // too slow.\n var ondrain = pipeOnDrain(src);\n dest.on('drain', ondrain);\n\n var cleanedUp = false;\n function cleanup() {\n debug('cleanup');\n // cleanup event handlers once the pipe is broken\n dest.removeListener('close', onclose);\n dest.removeListener('finish', onfinish);\n dest.removeListener('drain', ondrain);\n dest.removeListener('error', onerror);\n dest.removeListener('unpipe', onunpipe);\n src.removeListener('end', onend);\n src.removeListener('end', cleanup);\n src.removeListener('data', ondata);\n\n cleanedUp = true;\n\n // if the reader is waiting for a drain event from this\n // specific writer, then it would cause it to never start\n // flowing again.\n // So, if this is awaiting a drain, then we just call it now.\n // If we don't know, then assume that we are waiting for one.\n if (state.awaitDrain && (!dest._writableState || dest._writableState.needDrain)) ondrain();\n }\n\n // If the user pushes more data while we're writing to dest then we'll end up\n // in ondata again. However, we only want to increase awaitDrain once because\n // dest will only emit one 'drain' event for the multiple writes.\n // => Introduce a guard on increasing awaitDrain.\n var increasedAwaitDrain = false;\n src.on('data', ondata);\n function ondata(chunk) {\n debug('ondata');\n increasedAwaitDrain = false;\n var ret = dest.write(chunk);\n if (false === ret && !increasedAwaitDrain) {\n // If the user unpiped during `dest.write()`, it is possible\n // to get stuck in a permanently paused state if that write\n // also returned false.\n // => Check whether `dest` is still a piping destination.\n if ((state.pipesCount === 1 && state.pipes === dest || state.pipesCount > 1 && indexOf(state.pipes, dest) !== -1) && !cleanedUp) {\n debug('false write response, pause', src._readableState.awaitDrain);\n src._readableState.awaitDrain++;\n increasedAwaitDrain = true;\n }\n src.pause();\n }\n }\n\n // if the dest has an error, then stop piping into it.\n // however, don't suppress the throwing behavior for this.\n function onerror(er) {\n debug('onerror', er);\n unpipe();\n dest.removeListener('error', onerror);\n if (EElistenerCount(dest, 'error') === 0) dest.emit('error', er);\n }\n\n // Make sure our error handler is attached before userland ones.\n prependListener(dest, 'error', onerror);\n\n // Both close and finish should trigger unpipe, but only once.\n function onclose() {\n dest.removeListener('finish', onfinish);\n unpipe();\n }\n dest.once('close', onclose);\n function onfinish() {\n debug('onfinish');\n dest.removeListener('close', onclose);\n unpipe();\n }\n dest.once('finish', onfinish);\n\n function unpipe() {\n debug('unpipe');\n src.unpipe(dest);\n }\n\n // tell the dest that it's being piped to\n dest.emit('pipe', src);\n\n // start the flow if it hasn't been started already.\n if (!state.flowing) {\n debug('pipe resume');\n src.resume();\n }\n\n return dest;\n};\n\nfunction pipeOnDrain(src) {\n return function () {\n var state = src._readableState;\n debug('pipeOnDrain', state.awaitDrain);\n if (state.awaitDrain) state.awaitDrain--;\n if (state.awaitDrain === 0 && EElistenerCount(src, 'data')) {\n state.flowing = true;\n flow(src);\n }\n };\n}\n\nReadable.prototype.unpipe = function (dest) {\n var state = this._readableState;\n\n // if we're not piping anywhere, then do nothing.\n if (state.pipesCount === 0) return this;\n\n // just one destination. most common case.\n if (state.pipesCount === 1) {\n // passed in one, but it's not the right one.\n if (dest && dest !== state.pipes) return this;\n\n if (!dest) dest = state.pipes;\n\n // got a match.\n state.pipes = null;\n state.pipesCount = 0;\n state.flowing = false;\n if (dest) dest.emit('unpipe', this);\n return this;\n }\n\n // slow case. multiple pipe destinations.\n\n if (!dest) {\n // remove all.\n var dests = state.pipes;\n var len = state.pipesCount;\n state.pipes = null;\n state.pipesCount = 0;\n state.flowing = false;\n\n for (var i = 0; i < len; i++) {\n dests[i].emit('unpipe', this);\n }return this;\n }\n\n // try to find the right one.\n var index = indexOf(state.pipes, dest);\n if (index === -1) return this;\n\n state.pipes.splice(index, 1);\n state.pipesCount -= 1;\n if (state.pipesCount === 1) state.pipes = state.pipes[0];\n\n dest.emit('unpipe', this);\n\n return this;\n};\n\n// set up data events if they are asked for\n// Ensure readable listeners eventually get something\nReadable.prototype.on = function (ev, fn) {\n var res = Stream.prototype.on.call(this, ev, fn);\n\n if (ev === 'data') {\n // Start flowing on next tick if stream isn't explicitly paused\n if (this._readableState.flowing !== false) this.resume();\n } else if (ev === 'readable') {\n var state = this._readableState;\n if (!state.endEmitted && !state.readableListening) {\n state.readableListening = state.needReadable = true;\n state.emittedReadable = false;\n if (!state.reading) {\n processNextTick(nReadingNextTick, this);\n } else if (state.length) {\n emitReadable(this, state);\n }\n }\n }\n\n return res;\n};\nReadable.prototype.addListener = Readable.prototype.on;\n\nfunction nReadingNextTick(self) {\n debug('readable nexttick read 0');\n self.read(0);\n}\n\n// pause() and resume() are remnants of the legacy readable stream API\n// If the user uses them, then switch into old mode.\nReadable.prototype.resume = function () {\n var state = this._readableState;\n if (!state.flowing) {\n debug('resume');\n state.flowing = true;\n resume(this, state);\n }\n return this;\n};\n\nfunction resume(stream, state) {\n if (!state.resumeScheduled) {\n state.resumeScheduled = true;\n processNextTick(resume_, stream, state);\n }\n}\n\nfunction resume_(stream, state) {\n if (!state.reading) {\n debug('resume read 0');\n stream.read(0);\n }\n\n state.resumeScheduled = false;\n state.awaitDrain = 0;\n stream.emit('resume');\n flow(stream);\n if (state.flowing && !state.reading) stream.read(0);\n}\n\nReadable.prototype.pause = function () {\n debug('call pause flowing=%j', this._readableState.flowing);\n if (false !== this._readableState.flowing) {\n debug('pause');\n this._readableState.flowing = false;\n this.emit('pause');\n }\n return this;\n};\n\nfunction flow(stream) {\n var state = stream._readableState;\n debug('flow', state.flowing);\n while (state.flowing && stream.read() !== null) {}\n}\n\n// wrap an old-style stream as the async data source.\n// This is *not* part of the readable stream interface.\n// It is an ugly unfortunate mess of history.\nReadable.prototype.wrap = function (stream) {\n var state = this._readableState;\n var paused = false;\n\n var self = this;\n stream.on('end', function () {\n debug('wrapped end');\n if (state.decoder && !state.ended) {\n var chunk = state.decoder.end();\n if (chunk && chunk.length) self.push(chunk);\n }\n\n self.push(null);\n });\n\n stream.on('data', function (chunk) {\n debug('wrapped data');\n if (state.decoder) chunk = state.decoder.write(chunk);\n\n // don't skip over falsy values in objectMode\n if (state.objectMode && (chunk === null || chunk === undefined)) return;else if (!state.objectMode && (!chunk || !chunk.length)) return;\n\n var ret = self.push(chunk);\n if (!ret) {\n paused = true;\n stream.pause();\n }\n });\n\n // proxy all the other methods.\n // important when wrapping filters and duplexes.\n for (var i in stream) {\n if (this[i] === undefined && typeof stream[i] === 'function') {\n this[i] = function (method) {\n return function () {\n return stream[method].apply(stream, arguments);\n };\n }(i);\n }\n }\n\n // proxy certain important events.\n var events = ['error', 'close', 'destroy', 'pause', 'resume'];\n forEach(events, function (ev) {\n stream.on(ev, self.emit.bind(self, ev));\n });\n\n // when we try to consume some more bytes, simply unpause the\n // underlying stream.\n self._read = function (n) {\n debug('wrapped _read', n);\n if (paused) {\n paused = false;\n stream.resume();\n }\n };\n\n return self;\n};\n\n// exposed for testing purposes only.\nReadable._fromList = fromList;\n\n// Pluck off n bytes from an array of buffers.\n// Length is the combined lengths of all the buffers in the list.\n// This function is designed to be inlinable, so please take care when making\n// changes to the function body.\nfunction fromList(n, state) {\n // nothing buffered\n if (state.length === 0) return null;\n\n var ret;\n if (state.objectMode) ret = state.buffer.shift();else if (!n || n >= state.length) {\n // read it all, truncate the list\n if (state.decoder) ret = state.buffer.join('');else if (state.buffer.length === 1) ret = state.buffer.head.data;else ret = state.buffer.concat(state.length);\n state.buffer.clear();\n } else {\n // read part of list\n ret = fromListPartial(n, state.buffer, state.decoder);\n }\n\n return ret;\n}\n\n// Extracts only enough buffered data to satisfy the amount requested.\n// This function is designed to be inlinable, so please take care when making\n// changes to the function body.\nfunction fromListPartial(n, list, hasStrings) {\n var ret;\n if (n < list.head.data.length) {\n // slice is the same for buffers and strings\n ret = list.head.data.slice(0, n);\n list.head.data = list.head.data.slice(n);\n } else if (n === list.head.data.length) {\n // first chunk is a perfect match\n ret = list.shift();\n } else {\n // result spans more than one buffer\n ret = hasStrings ? copyFromBufferString(n, list) : copyFromBuffer(n, list);\n }\n return ret;\n}\n\n// Copies a specified amount of characters from the list of buffered data\n// chunks.\n// This function is designed to be inlinable, so please take care when making\n// changes to the function body.\nfunction copyFromBufferString(n, list) {\n var p = list.head;\n var c = 1;\n var ret = p.data;\n n -= ret.length;\n while (p = p.next) {\n var str = p.data;\n var nb = n > str.length ? str.length : n;\n if (nb === str.length) ret += str;else ret += str.slice(0, n);\n n -= nb;\n if (n === 0) {\n if (nb === str.length) {\n ++c;\n if (p.next) list.head = p.next;else list.head = list.tail = null;\n } else {\n list.head = p;\n p.data = str.slice(nb);\n }\n break;\n }\n ++c;\n }\n list.length -= c;\n return ret;\n}\n\n// Copies a specified amount of bytes from the list of buffered data chunks.\n// This function is designed to be inlinable, so please take care when making\n// changes to the function body.\nfunction copyFromBuffer(n, list) {\n var ret = bufferShim.allocUnsafe(n);\n var p = list.head;\n var c = 1;\n p.data.copy(ret);\n n -= p.data.length;\n while (p = p.next) {\n var buf = p.data;\n var nb = n > buf.length ? buf.length : n;\n buf.copy(ret, ret.length - n, 0, nb);\n n -= nb;\n if (n === 0) {\n if (nb === buf.length) {\n ++c;\n if (p.next) list.head = p.next;else list.head = list.tail = null;\n } else {\n list.head = p;\n p.data = buf.slice(nb);\n }\n break;\n }\n ++c;\n }\n list.length -= c;\n return ret;\n}\n\nfunction endReadable(stream) {\n var state = stream._readableState;\n\n // If we get here before consuming all the bytes, then that is a\n // bug in node. Should never happen.\n if (state.length > 0) throw new Error('\"endReadable()\" called on non-empty stream');\n\n if (!state.endEmitted) {\n state.ended = true;\n processNextTick(endReadableNT, state, stream);\n }\n}\n\nfunction endReadableNT(state, stream) {\n // Check that we didn't get one last unshift.\n if (!state.endEmitted && state.length === 0) {\n state.endEmitted = true;\n stream.readable = false;\n stream.emit('end');\n }\n}\n\nfunction forEach(xs, f) {\n for (var i = 0, l = xs.length; i < l; i++) {\n f(xs[i], i);\n }\n}\n\nfunction indexOf(xs, x) {\n for (var i = 0, l = xs.length; i < l; i++) {\n if (xs[i] === x) return i;\n }\n return -1;\n}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/readable-stream/lib/_stream_readable.js\n// module id = 16\n// module chunks = 0","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nvar Buffer = require('buffer').Buffer;\n\nvar isBufferEncoding = Buffer.isEncoding\n || function(encoding) {\n switch (encoding && encoding.toLowerCase()) {\n case 'hex': case 'utf8': case 'utf-8': case 'ascii': case 'binary': case 'base64': case 'ucs2': case 'ucs-2': case 'utf16le': case 'utf-16le': case 'raw': return true;\n default: return false;\n }\n }\n\n\nfunction assertEncoding(encoding) {\n if (encoding && !isBufferEncoding(encoding)) {\n throw new Error('Unknown encoding: ' + encoding);\n }\n}\n\n// StringDecoder provides an interface for efficiently splitting a series of\n// buffers into a series of JS strings without breaking apart multi-byte\n// characters. CESU-8 is handled as part of the UTF-8 encoding.\n//\n// @TODO Handling all encodings inside a single object makes it very difficult\n// to reason about this code, so it should be split up in the future.\n// @TODO There should be a utf8-strict encoding that rejects invalid UTF-8 code\n// points as used by CESU-8.\nvar StringDecoder = exports.StringDecoder = function(encoding) {\n this.encoding = (encoding || 'utf8').toLowerCase().replace(/[-_]/, '');\n assertEncoding(encoding);\n switch (this.encoding) {\n case 'utf8':\n // CESU-8 represents each of Surrogate Pair by 3-bytes\n this.surrogateSize = 3;\n break;\n case 'ucs2':\n case 'utf16le':\n // UTF-16 represents each of Surrogate Pair by 2-bytes\n this.surrogateSize = 2;\n this.detectIncompleteChar = utf16DetectIncompleteChar;\n break;\n case 'base64':\n // Base-64 stores 3 bytes in 4 chars, and pads the remainder.\n this.surrogateSize = 3;\n this.detectIncompleteChar = base64DetectIncompleteChar;\n break;\n default:\n this.write = passThroughWrite;\n return;\n }\n\n // Enough space to store all bytes of a single character. UTF-8 needs 4\n // bytes, but CESU-8 may require up to 6 (3 bytes per surrogate).\n this.charBuffer = new Buffer(6);\n // Number of bytes received for the current incomplete multi-byte character.\n this.charReceived = 0;\n // Number of bytes expected for the current incomplete multi-byte character.\n this.charLength = 0;\n};\n\n\n// write decodes the given buffer and returns it as JS string that is\n// guaranteed to not contain any partial multi-byte characters. Any partial\n// character found at the end of the buffer is buffered up, and will be\n// returned when calling write again with the remaining bytes.\n//\n// Note: Converting a Buffer containing an orphan surrogate to a String\n// currently works, but converting a String to a Buffer (via `new Buffer`, or\n// Buffer#write) will replace incomplete surrogates with the unicode\n// replacement character. See https://codereview.chromium.org/121173009/ .\nStringDecoder.prototype.write = function(buffer) {\n var charStr = '';\n // if our last write ended with an incomplete multibyte character\n while (this.charLength) {\n // determine how many remaining bytes this buffer has to offer for this char\n var available = (buffer.length >= this.charLength - this.charReceived) ?\n this.charLength - this.charReceived :\n buffer.length;\n\n // add the new bytes to the char buffer\n buffer.copy(this.charBuffer, this.charReceived, 0, available);\n this.charReceived += available;\n\n if (this.charReceived < this.charLength) {\n // still not enough chars in this buffer? wait for more ...\n return '';\n }\n\n // remove bytes belonging to the current character from the buffer\n buffer = buffer.slice(available, buffer.length);\n\n // get the character that was split\n charStr = this.charBuffer.slice(0, this.charLength).toString(this.encoding);\n\n // CESU-8: lead surrogate (D800-DBFF) is also the incomplete character\n var charCode = charStr.charCodeAt(charStr.length - 1);\n if (charCode >= 0xD800 && charCode <= 0xDBFF) {\n this.charLength += this.surrogateSize;\n charStr = '';\n continue;\n }\n this.charReceived = this.charLength = 0;\n\n // if there are no more bytes in this buffer, just emit our char\n if (buffer.length === 0) {\n return charStr;\n }\n break;\n }\n\n // determine and set charLength / charReceived\n this.detectIncompleteChar(buffer);\n\n var end = buffer.length;\n if (this.charLength) {\n // buffer the incomplete character bytes we got\n buffer.copy(this.charBuffer, 0, buffer.length - this.charReceived, end);\n end -= this.charReceived;\n }\n\n charStr += buffer.toString(this.encoding, 0, end);\n\n var end = charStr.length - 1;\n var charCode = charStr.charCodeAt(end);\n // CESU-8: lead surrogate (D800-DBFF) is also the incomplete character\n if (charCode >= 0xD800 && charCode <= 0xDBFF) {\n var size = this.surrogateSize;\n this.charLength += size;\n this.charReceived += size;\n this.charBuffer.copy(this.charBuffer, size, 0, size);\n buffer.copy(this.charBuffer, 0, 0, size);\n return charStr.substring(0, end);\n }\n\n // or just emit the charStr\n return charStr;\n};\n\n// detectIncompleteChar determines if there is an incomplete UTF-8 character at\n// the end of the given buffer. If so, it sets this.charLength to the byte\n// length that character, and sets this.charReceived to the number of bytes\n// that are available for this character.\nStringDecoder.prototype.detectIncompleteChar = function(buffer) {\n // determine how many bytes we have to check at the end of this buffer\n var i = (buffer.length >= 3) ? 3 : buffer.length;\n\n // Figure out if one of the last i bytes of our buffer announces an\n // incomplete char.\n for (; i > 0; i--) {\n var c = buffer[buffer.length - i];\n\n // See http://en.wikipedia.org/wiki/UTF-8#Description\n\n // 110XXXXX\n if (i == 1 && c >> 5 == 0x06) {\n this.charLength = 2;\n break;\n }\n\n // 1110XXXX\n if (i <= 2 && c >> 4 == 0x0E) {\n this.charLength = 3;\n break;\n }\n\n // 11110XXX\n if (i <= 3 && c >> 3 == 0x1E) {\n this.charLength = 4;\n break;\n }\n }\n this.charReceived = i;\n};\n\nStringDecoder.prototype.end = function(buffer) {\n var res = '';\n if (buffer && buffer.length)\n res = this.write(buffer);\n\n if (this.charReceived) {\n var cr = this.charReceived;\n var buf = this.charBuffer;\n var enc = this.encoding;\n res += buf.slice(0, cr).toString(enc);\n }\n\n return res;\n};\n\nfunction passThroughWrite(buffer) {\n return buffer.toString(this.encoding);\n}\n\nfunction utf16DetectIncompleteChar(buffer) {\n this.charReceived = buffer.length % 2;\n this.charLength = this.charReceived ? 2 : 0;\n}\n\nfunction base64DetectIncompleteChar(buffer) {\n this.charReceived = buffer.length % 3;\n this.charLength = this.charReceived ? 3 : 0;\n}\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/string_decoder/index.js\n// module id = 17\n// module chunks = 0","'use strict'\n\nexports.byteLength = byteLength\nexports.toByteArray = toByteArray\nexports.fromByteArray = fromByteArray\n\nvar lookup = []\nvar revLookup = []\nvar Arr = typeof Uint8Array !== 'undefined' ? Uint8Array : Array\n\nvar code = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'\nfor (var i = 0, len = code.length; i < len; ++i) {\n lookup[i] = code[i]\n revLookup[code.charCodeAt(i)] = i\n}\n\nrevLookup['-'.charCodeAt(0)] = 62\nrevLookup['_'.charCodeAt(0)] = 63\n\nfunction placeHoldersCount (b64) {\n var len = b64.length\n if (len % 4 > 0) {\n throw new Error('Invalid string. Length must be a multiple of 4')\n }\n\n // the number of equal signs (place holders)\n // if there are two placeholders, than the two characters before it\n // represent one byte\n // if there is only one, then the three characters before it represent 2 bytes\n // this is just a cheap hack to not do indexOf twice\n return b64[len - 2] === '=' ? 2 : b64[len - 1] === '=' ? 1 : 0\n}\n\nfunction byteLength (b64) {\n // base64 is 4/3 + up to two characters of the original data\n return b64.length * 3 / 4 - placeHoldersCount(b64)\n}\n\nfunction toByteArray (b64) {\n var i, j, l, tmp, placeHolders, arr\n var len = b64.length\n placeHolders = placeHoldersCount(b64)\n\n arr = new Arr(len * 3 / 4 - placeHolders)\n\n // if there are placeholders, only get up to the last complete 4 chars\n l = placeHolders > 0 ? len - 4 : len\n\n var L = 0\n\n for (i = 0, j = 0; i < l; i += 4, j += 3) {\n tmp = (revLookup[b64.charCodeAt(i)] << 18) | (revLookup[b64.charCodeAt(i + 1)] << 12) | (revLookup[b64.charCodeAt(i + 2)] << 6) | revLookup[b64.charCodeAt(i + 3)]\n arr[L++] = (tmp >> 16) & 0xFF\n arr[L++] = (tmp >> 8) & 0xFF\n arr[L++] = tmp & 0xFF\n }\n\n if (placeHolders === 2) {\n tmp = (revLookup[b64.charCodeAt(i)] << 2) | (revLookup[b64.charCodeAt(i + 1)] >> 4)\n arr[L++] = tmp & 0xFF\n } else if (placeHolders === 1) {\n tmp = (revLookup[b64.charCodeAt(i)] << 10) | (revLookup[b64.charCodeAt(i + 1)] << 4) | (revLookup[b64.charCodeAt(i + 2)] >> 2)\n arr[L++] = (tmp >> 8) & 0xFF\n arr[L++] = tmp & 0xFF\n }\n\n return arr\n}\n\nfunction tripletToBase64 (num) {\n return lookup[num >> 18 & 0x3F] + lookup[num >> 12 & 0x3F] + lookup[num >> 6 & 0x3F] + lookup[num & 0x3F]\n}\n\nfunction encodeChunk (uint8, start, end) {\n var tmp\n var output = []\n for (var i = start; i < end; i += 3) {\n tmp = (uint8[i] << 16) + (uint8[i + 1] << 8) + (uint8[i + 2])\n output.push(tripletToBase64(tmp))\n }\n return output.join('')\n}\n\nfunction fromByteArray (uint8) {\n var tmp\n var len = uint8.length\n var extraBytes = len % 3 // if we have 1 byte left, pad 2 bytes\n var output = ''\n var parts = []\n var maxChunkLength = 16383 // must be multiple of 3\n\n // go through the array every three bytes, we'll deal with trailing stuff later\n for (var i = 0, len2 = len - extraBytes; i < len2; i += maxChunkLength) {\n parts.push(encodeChunk(uint8, i, (i + maxChunkLength) > len2 ? len2 : (i + maxChunkLength)))\n }\n\n // pad the end with zeros, but make sure to not forget the extra bytes\n if (extraBytes === 1) {\n tmp = uint8[len - 1]\n output += lookup[tmp >> 2]\n output += lookup[(tmp << 4) & 0x3F]\n output += '=='\n } else if (extraBytes === 2) {\n tmp = (uint8[len - 2] << 8) + (uint8[len - 1])\n output += lookup[tmp >> 10]\n output += lookup[(tmp >> 4) & 0x3F]\n output += lookup[(tmp << 2) & 0x3F]\n output += '='\n }\n\n parts.push(output)\n\n return parts.join('')\n}\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/base64-js/index.js\n// module id = 18\n// module chunks = 0","// Use path and TTY for type information only. We lazily pull them in\n// to avoid circular dependencies :(\n// (path depends on process for cwd(), TTY depends on streams which depends\n// on process.nextTick/process.stdout/stderr/stdin).\nimport _path = require('path');\nimport _TTY = require('./tty');\nimport events = require('events');\n\n// Path depends on process. Avoid a circular reference by dynamically including path when we need it.\nvar path: typeof _path = null;\n\nclass Item {\n private fun: Function;\n private array: any[];\n constructor(fun: Function, array: any[]) {\n this.fun = fun;\n this.array = array;\n }\n\n public run(): void {\n this.fun.apply(null, this.array);\n }\n}\n\n/**\n * Contains a queue of Items for process.nextTick.\n * Inspired by node-process: https://github.com/defunctzombie/node-process\n */\nclass NextTickQueue {\n private _queue: Item[] = [];\n private _draining = false;\n // Used/assigned by the drainQueue function.\n private _currentQueue: Item[] = null;\n private _queueIndex = -1;\n\n public push(item: Item): void {\n if (this._queue.push(item) === 1 && !this._draining) {\n setTimeout(() => this._drainQueue(), 0);\n }\n }\n\n private _cleanUpNextTick() {\n this._draining = false;\n if (this._currentQueue && this._currentQueue.length) {\n this._queue = this._currentQueue.concat(this._queue);\n } else {\n this._queueIndex = -1;\n }\n if (this._queue.length) {\n this._drainQueue();\n }\n }\n\n private _drainQueue() {\n if (this._draining) {\n return;\n }\n // If an Item throws an unhandled exception, this function will clean things up.\n var timeout = setTimeout(() => this._cleanUpNextTick());\n this._draining = true;\n\n var len = this._queue.length;\n while(len) {\n this._currentQueue = this._queue;\n this._queue = [];\n while (++this._queueIndex < len) {\n if (this._currentQueue) {\n this._currentQueue[this._queueIndex].run();\n }\n }\n this._queueIndex = -1;\n len = this._queue.length;\n }\n this._currentQueue = null;\n this._draining = false;\n clearTimeout(timeout);\n }\n}\n\n/**\n * Partial implementation of Node's `process` module.\n * We implement the portions that are relevant for the filesystem.\n * @see http://nodejs.org/api/process.html\n * @class\n */\nclass Process extends events.EventEmitter implements NodeJS.Process {\n private startTime = Date.now();\n\n private _cwd: string = '/';\n /**\n * Changes the current working directory.\n *\n * **Note**: BrowserFS does not validate that the directory actually exists.\n *\n * @example Usage example\n * console.log('Starting directory: ' + process.cwd());\n * process.chdir('/tmp');\n * console.log('New directory: ' + process.cwd());\n * @param [String] dir The directory to change to.\n */\n public chdir(dir: string): void {\n // XXX: Circular dependency hack.\n if (path === null) {\n path = require('path');\n }\n this._cwd = path.resolve(dir);\n }\n /**\n * Returns the current working directory.\n * @example Usage example\n * console.log('Current directory: ' + process.cwd());\n * @return [String] The current working directory.\n */\n public cwd(): string {\n return this._cwd;\n }\n /**\n * Returns what platform you are running on.\n * @return [String]\n */\n public platform: string = 'browser';\n /**\n * Number of seconds BrowserFS has been running.\n * @return [Number]\n */\n public uptime(): number {\n return ((Date.now() - this.startTime) / 1000) | 0;\n }\n\n public argv: string[] = [];\n public execArgv: string[] = [];\n public stdout: _TTY = null;\n public stderr: _TTY = null;\n public stdin: _TTY = null;\n public domain: NodeJS.Domain = null;\n\n private _queue: NextTickQueue = new NextTickQueue();\n\n public nextTick(fun: any, ...args: any[]) {\n this._queue.push(new Item(fun, args));\n }\n\n public execPath = __dirname;\n\n public abort(): void {\n this.emit('abort');\n }\n\n public env: {[name: string]: string} = {};\n public exitCode: number = 0;\n public exit(code: number): void {\n this.exitCode = code;\n this.emit('exit', [code]);\n }\n\n private _gid: number = 1;\n public getgid(): number {\n return this._gid;\n }\n public setgid(gid: number | string): void {\n if (typeof gid === 'number') {\n this._gid = gid;\n } else {\n this._gid = 1;\n }\n }\n\n private _uid: number = 1;\n public getuid(): number {\n return this._uid;\n }\n public setuid(uid: number | string): void {\n if (typeof uid === 'number') {\n this._uid = uid;\n } else {\n this._uid = 1;\n }\n }\n\n public version: string = 'v5.0';\n\n public versions = {\n http_parser: '0.0',\n node: '5.0',\n v8: '0.0',\n uv: '0.0',\n zlib: '0.0',\n ares: '0.0',\n icu: '0.0',\n modules: '0',\n openssl: '0.0'\n };\n\n public config = {\n target_defaults:\n { cflags: [],\n default_configuration: 'Release',\n defines: [],\n include_dirs: [],\n libraries: [] },\n variables:\n { clang: 0,\n host_arch: 'x32',\n node_install_npm: false,\n node_install_waf: false,\n node_prefix: '',\n node_shared_cares: false,\n node_shared_http_parser: false,\n node_shared_libuv: false,\n node_shared_zlib: false,\n node_shared_v8: false,\n node_use_dtrace: false,\n node_use_etw: false,\n node_use_openssl: false,\n node_shared_openssl: false,\n strict_aliasing: false,\n target_arch: 'x32',\n v8_use_snapshot: false,\n v8_no_strict_aliasing: 0,\n visibility: '' } };\n\n public kill(pid: number, signal?: string): void {\n this.emit('kill', [pid, signal]);\n }\n\n public pid = (Math.random()*1000)|0;\n\n public title = 'node';\n public arch = 'x32';\n public memoryUsage(): {rss: number; heapTotal: number; heapUsed: number;} {\n return { rss: 0, heapTotal: 0, heapUsed: 0 }\n }\n\n private _mask = 18;\n public umask(mask: number = this._mask): number {\n let oldMask = this._mask;\n this._mask = mask;\n this.emit('umask', [mask]);\n return oldMask;\n }\n\n public hrtime(): [number, number] {\n let timeinfo: number;\n if (typeof performance !== 'undefined') {\n timeinfo = performance.now();\n } else if (Date['now']) {\n timeinfo = Date.now();\n } else {\n timeinfo = (new Date()).getTime();\n }\n let secs = (timeinfo / 1000)|0;\n timeinfo -= secs * 1000;\n timeinfo = (timeinfo * 1000000)|0;\n return [secs, timeinfo];\n }\n\n /**\n * [BFS only] Initialize the TTY devices.\n */\n public initializeTTYs(): void {\n // Guard against multiple invocations.\n if (this.stdout === null) {\n let TTY: typeof _TTY = require('./tty');\n this.stdout = new TTY();\n this.stderr = new TTY();\n this.stdin = new TTY();\n }\n }\n\n /**\n * Worker-only function; irrelevant here.\n */\n public disconnect(): void {\n\n }\n // Undefined in main thread. Worker-only.\n public connected: boolean = undefined;\n}\n\nexport = Process;\n\n\n// WEBPACK FOOTER //\n// ../ts/process.ts","import stream = require('stream');\n\nclass TTY extends stream.Duplex {\n public isRaw: boolean = false;\n public columns: number = 80;\n public rows: number = 120;\n public isTTY: boolean = true;\n private _bufferedWrites: Buffer[] = [];\n private _waitingForWrites: boolean = false;\n\n constructor() {\n super();\n }\n\n /**\n * Toggle raw mode.\n */\n public setRawMode(mode: boolean): void {\n if (this.isRaw !== mode) {\n this.isRaw = mode;\n // [BFS] TTY implementations can use this to change their event emitting\n // patterns.\n this.emit('modeChange');\n }\n }\n\n /**\n * [BFS] Update the number of columns available on the terminal.\n */\n public changeColumns(columns: number): void {\n if (columns !== this.columns) {\n this.columns = columns;\n // Resize event.\n this.emit('resize');\n }\n }\n\n /**\n * [BFS] Update the number of rows available on the terminal.\n */\n public changeRows(rows: number): void {\n if (rows !== this.rows) {\n this.rows = rows;\n // Resize event.\n this.emit('resize');\n }\n }\n\n /**\n * Returns 'true' if the given object is a TTY.\n */\n public static isatty(fd: any): fd is TTY {\n return fd && fd instanceof TTY;\n }\n\n public _write(chunk: any, encoding: string, cb: Function): void {\n var error: any;\n try {\n var data: Buffer;\n if (typeof(chunk) === 'string') {\n data = new Buffer(chunk, encoding);\n } else {\n data = chunk;\n }\n this._bufferedWrites.push(data);\n if (this._waitingForWrites) {\n this._read(1024);\n }\n } catch (e) {\n error = e;\n } finally {\n cb(error);\n }\n }\n\n public _read(size: number): void {\n // Size is advisory -- we can ignore it.\n if (this._bufferedWrites.length === 0) {\n this._waitingForWrites = true;\n } else {\n while (this._bufferedWrites.length > 0) {\n this._waitingForWrites = this.push(this._bufferedWrites.shift());\n if (!this._waitingForWrites) {\n break;\n }\n }\n }\n }\n}\n\nexport = TTY;\n\n\n\n// WEBPACK FOOTER //\n// ../ts/tty.ts","exports.read = function (buffer, offset, isLE, mLen, nBytes) {\n var e, m\n var eLen = nBytes * 8 - mLen - 1\n var eMax = (1 << eLen) - 1\n var eBias = eMax >> 1\n var nBits = -7\n var i = isLE ? (nBytes - 1) : 0\n var d = isLE ? -1 : 1\n var s = buffer[offset + i]\n\n i += d\n\n e = s & ((1 << (-nBits)) - 1)\n s >>= (-nBits)\n nBits += eLen\n for (; nBits > 0; e = e * 256 + buffer[offset + i], i += d, nBits -= 8) {}\n\n m = e & ((1 << (-nBits)) - 1)\n e >>= (-nBits)\n nBits += mLen\n for (; nBits > 0; m = m * 256 + buffer[offset + i], i += d, nBits -= 8) {}\n\n if (e === 0) {\n e = 1 - eBias\n } else if (e === eMax) {\n return m ? NaN : ((s ? -1 : 1) * Infinity)\n } else {\n m = m + Math.pow(2, mLen)\n e = e - eBias\n }\n return (s ? -1 : 1) * m * Math.pow(2, e - mLen)\n}\n\nexports.write = function (buffer, value, offset, isLE, mLen, nBytes) {\n var e, m, c\n var eLen = nBytes * 8 - mLen - 1\n var eMax = (1 << eLen) - 1\n var eBias = eMax >> 1\n var rt = (mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0)\n var i = isLE ? 0 : (nBytes - 1)\n var d = isLE ? 1 : -1\n var s = value < 0 || (value === 0 && 1 / value < 0) ? 1 : 0\n\n value = Math.abs(value)\n\n if (isNaN(value) || value === Infinity) {\n m = isNaN(value) ? 1 : 0\n e = eMax\n } else {\n e = Math.floor(Math.log(value) / Math.LN2)\n if (value * (c = Math.pow(2, -e)) < 1) {\n e--\n c *= 2\n }\n if (e + eBias >= 1) {\n value += rt / c\n } else {\n value += rt * Math.pow(2, 1 - eBias)\n }\n if (value * c >= 2) {\n e++\n c /= 2\n }\n\n if (e + eBias >= eMax) {\n m = 0\n e = eMax\n } else if (e + eBias >= 1) {\n m = (value * c - 1) * Math.pow(2, mLen)\n e = e + eBias\n } else {\n m = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen)\n e = 0\n }\n }\n\n for (; mLen >= 8; buffer[offset + i] = m & 0xff, i += d, m /= 256, mLen -= 8) {}\n\n e = (e << mLen) | m\n eLen += mLen\n for (; eLen > 0; buffer[offset + i] = e & 0xff, i += d, e /= 256, eLen -= 8) {}\n\n buffer[offset + i - d] |= s * 128\n}\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/ieee754/index.js\n// module id = 21\n// module chunks = 0","var toString = {}.toString;\n\nmodule.exports = Array.isArray || function (arr) {\n return toString.call(arr) == '[object Array]';\n};\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/isarray/index.js\n// module id = 22\n// module chunks = 0","'use strict';\n\n\nvar zlib_inflate = require('./zlib/inflate');\nvar utils = require('./utils/common');\nvar strings = require('./utils/strings');\nvar c = require('./zlib/constants');\nvar msg = require('./zlib/messages');\nvar ZStream = require('./zlib/zstream');\nvar GZheader = require('./zlib/gzheader');\n\nvar toString = Object.prototype.toString;\n\n/**\n * class Inflate\n *\n * Generic JS-style wrapper for zlib calls. If you don't need\n * streaming behaviour - use more simple functions: [[inflate]]\n * and [[inflateRaw]].\n **/\n\n/* internal\n * inflate.chunks -> Array\n *\n * Chunks of output data, if [[Inflate#onData]] not overriden.\n **/\n\n/**\n * Inflate.result -> Uint8Array|Array|String\n *\n * Uncompressed result, generated by default [[Inflate#onData]]\n * and [[Inflate#onEnd]] handlers. Filled after you push last chunk\n * (call [[Inflate#push]] with `Z_FINISH` / `true` param) or if you\n * push a chunk with explicit flush (call [[Inflate#push]] with\n * `Z_SYNC_FLUSH` param).\n **/\n\n/**\n * Inflate.err -> Number\n *\n * Error code after inflate finished. 0 (Z_OK) on success.\n * Should be checked if broken data possible.\n **/\n\n/**\n * Inflate.msg -> String\n *\n * Error message, if [[Inflate.err]] != 0\n **/\n\n\n/**\n * new Inflate(options)\n * - options (Object): zlib inflate options.\n *\n * Creates new inflator instance with specified params. Throws exception\n * on bad params. Supported options:\n *\n * - `windowBits`\n * - `dictionary`\n *\n * [http://zlib.net/manual.html#Advanced](http://zlib.net/manual.html#Advanced)\n * for more information on these.\n *\n * Additional options, for internal needs:\n *\n * - `chunkSize` - size of generated data chunks (16K by default)\n * - `raw` (Boolean) - do raw inflate\n * - `to` (String) - if equal to 'string', then result will be converted\n * from utf8 to utf16 (javascript) string. When string output requested,\n * chunk length can differ from `chunkSize`, depending on content.\n *\n * By default, when no options set, autodetect deflate/gzip data format via\n * wrapper header.\n *\n * ##### Example:\n *\n * ```javascript\n * var pako = require('pako')\n * , chunk1 = Uint8Array([1,2,3,4,5,6,7,8,9])\n * , chunk2 = Uint8Array([10,11,12,13,14,15,16,17,18,19]);\n *\n * var inflate = new pako.Inflate({ level: 3});\n *\n * inflate.push(chunk1, false);\n * inflate.push(chunk2, true); // true -> last chunk\n *\n * if (inflate.err) { throw new Error(inflate.err); }\n *\n * console.log(inflate.result);\n * ```\n **/\nfunction Inflate(options) {\n if (!(this instanceof Inflate)) return new Inflate(options);\n\n this.options = utils.assign({\n chunkSize: 16384,\n windowBits: 0,\n to: ''\n }, options || {});\n\n var opt = this.options;\n\n // Force window size for `raw` data, if not set directly,\n // because we have no header for autodetect.\n if (opt.raw && (opt.windowBits >= 0) && (opt.windowBits < 16)) {\n opt.windowBits = -opt.windowBits;\n if (opt.windowBits === 0) { opt.windowBits = -15; }\n }\n\n // If `windowBits` not defined (and mode not raw) - set autodetect flag for gzip/deflate\n if ((opt.windowBits >= 0) && (opt.windowBits < 16) &&\n !(options && options.windowBits)) {\n opt.windowBits += 32;\n }\n\n // Gzip header has no info about windows size, we can do autodetect only\n // for deflate. So, if window size not set, force it to max when gzip possible\n if ((opt.windowBits > 15) && (opt.windowBits < 48)) {\n // bit 3 (16) -> gzipped data\n // bit 4 (32) -> autodetect gzip/deflate\n if ((opt.windowBits & 15) === 0) {\n opt.windowBits |= 15;\n }\n }\n\n this.err = 0; // error code, if happens (0 = Z_OK)\n this.msg = ''; // error message\n this.ended = false; // used to avoid multiple onEnd() calls\n this.chunks = []; // chunks of compressed data\n\n this.strm = new ZStream();\n this.strm.avail_out = 0;\n\n var status = zlib_inflate.inflateInit2(\n this.strm,\n opt.windowBits\n );\n\n if (status !== c.Z_OK) {\n throw new Error(msg[status]);\n }\n\n this.header = new GZheader();\n\n zlib_inflate.inflateGetHeader(this.strm, this.header);\n}\n\n/**\n * Inflate#push(data[, mode]) -> Boolean\n * - data (Uint8Array|Array|ArrayBuffer|String): input data\n * - mode (Number|Boolean): 0..6 for corresponding Z_NO_FLUSH..Z_TREE modes.\n * See constants. Skipped or `false` means Z_NO_FLUSH, `true` meansh Z_FINISH.\n *\n * Sends input data to inflate pipe, generating [[Inflate#onData]] calls with\n * new output chunks. Returns `true` on success. The last data block must have\n * mode Z_FINISH (or `true`). That will flush internal pending buffers and call\n * [[Inflate#onEnd]]. For interim explicit flushes (without ending the stream) you\n * can use mode Z_SYNC_FLUSH, keeping the decompression context.\n *\n * On fail call [[Inflate#onEnd]] with error code and return false.\n *\n * We strongly recommend to use `Uint8Array` on input for best speed (output\n * format is detected automatically). Also, don't skip last param and always\n * use the same type in your code (boolean or number). That will improve JS speed.\n *\n * For regular `Array`-s make sure all elements are [0..255].\n *\n * ##### Example\n *\n * ```javascript\n * push(chunk, false); // push one of data chunks\n * ...\n * push(chunk, true); // push last chunk\n * ```\n **/\nInflate.prototype.push = function (data, mode) {\n var strm = this.strm;\n var chunkSize = this.options.chunkSize;\n var dictionary = this.options.dictionary;\n var status, _mode;\n var next_out_utf8, tail, utf8str;\n var dict;\n\n // Flag to properly process Z_BUF_ERROR on testing inflate call\n // when we check that all output data was flushed.\n var allowBufError = false;\n\n if (this.ended) { return false; }\n _mode = (mode === ~~mode) ? mode : ((mode === true) ? c.Z_FINISH : c.Z_NO_FLUSH);\n\n // Convert data if needed\n if (typeof data === 'string') {\n // Only binary strings can be decompressed on practice\n strm.input = strings.binstring2buf(data);\n } else if (toString.call(data) === '[object ArrayBuffer]') {\n strm.input = new Uint8Array(data);\n } else {\n strm.input = data;\n }\n\n strm.next_in = 0;\n strm.avail_in = strm.input.length;\n\n do {\n if (strm.avail_out === 0) {\n strm.output = new utils.Buf8(chunkSize);\n strm.next_out = 0;\n strm.avail_out = chunkSize;\n }\n\n status = zlib_inflate.inflate(strm, c.Z_NO_FLUSH); /* no bad return value */\n\n if (status === c.Z_NEED_DICT && dictionary) {\n // Convert data if needed\n if (typeof dictionary === 'string') {\n dict = strings.string2buf(dictionary);\n } else if (toString.call(dictionary) === '[object ArrayBuffer]') {\n dict = new Uint8Array(dictionary);\n } else {\n dict = dictionary;\n }\n\n status = zlib_inflate.inflateSetDictionary(this.strm, dict);\n\n }\n\n if (status === c.Z_BUF_ERROR && allowBufError === true) {\n status = c.Z_OK;\n allowBufError = false;\n }\n\n if (status !== c.Z_STREAM_END && status !== c.Z_OK) {\n this.onEnd(status);\n this.ended = true;\n return false;\n }\n\n if (strm.next_out) {\n if (strm.avail_out === 0 || status === c.Z_STREAM_END || (strm.avail_in === 0 && (_mode === c.Z_FINISH || _mode === c.Z_SYNC_FLUSH))) {\n\n if (this.options.to === 'string') {\n\n next_out_utf8 = strings.utf8border(strm.output, strm.next_out);\n\n tail = strm.next_out - next_out_utf8;\n utf8str = strings.buf2string(strm.output, next_out_utf8);\n\n // move tail\n strm.next_out = tail;\n strm.avail_out = chunkSize - tail;\n if (tail) { utils.arraySet(strm.output, strm.output, next_out_utf8, tail, 0); }\n\n this.onData(utf8str);\n\n } else {\n this.onData(utils.shrinkBuf(strm.output, strm.next_out));\n }\n }\n }\n\n // When no more input data, we should check that internal inflate buffers\n // are flushed. The only way to do it when avail_out = 0 - run one more\n // inflate pass. But if output data not exists, inflate return Z_BUF_ERROR.\n // Here we set flag to process this error properly.\n //\n // NOTE. Deflate does not return error in this case and does not needs such\n // logic.\n if (strm.avail_in === 0 && strm.avail_out === 0) {\n allowBufError = true;\n }\n\n } while ((strm.avail_in > 0 || strm.avail_out === 0) && status !== c.Z_STREAM_END);\n\n if (status === c.Z_STREAM_END) {\n _mode = c.Z_FINISH;\n }\n\n // Finalize on the last chunk.\n if (_mode === c.Z_FINISH) {\n status = zlib_inflate.inflateEnd(this.strm);\n this.onEnd(status);\n this.ended = true;\n return status === c.Z_OK;\n }\n\n // callback interim results if Z_SYNC_FLUSH.\n if (_mode === c.Z_SYNC_FLUSH) {\n this.onEnd(c.Z_OK);\n strm.avail_out = 0;\n return true;\n }\n\n return true;\n};\n\n\n/**\n * Inflate#onData(chunk) -> Void\n * - chunk (Uint8Array|Array|String): ouput data. Type of array depends\n * on js engine support. When string output requested, each chunk\n * will be string.\n *\n * By default, stores data blocks in `chunks[]` property and glue\n * those in `onEnd`. Override this handler, if you need another behaviour.\n **/\nInflate.prototype.onData = function (chunk) {\n this.chunks.push(chunk);\n};\n\n\n/**\n * Inflate#onEnd(status) -> Void\n * - status (Number): inflate status. 0 (Z_OK) on success,\n * other if not.\n *\n * Called either after you tell inflate that the input stream is\n * complete (Z_FINISH) or should be flushed (Z_SYNC_FLUSH)\n * or if an error happened. By default - join collected chunks,\n * free memory and fill `results` / `err` properties.\n **/\nInflate.prototype.onEnd = function (status) {\n // On success - join\n if (status === c.Z_OK) {\n if (this.options.to === 'string') {\n // Glue & convert here, until we teach pako to send\n // utf8 alligned strings to onData\n this.result = this.chunks.join('');\n } else {\n this.result = utils.flattenChunks(this.chunks);\n }\n }\n this.chunks = [];\n this.err = status;\n this.msg = this.strm.msg;\n};\n\n\n/**\n * inflate(data[, options]) -> Uint8Array|Array|String\n * - data (Uint8Array|Array|String): input data to decompress.\n * - options (Object): zlib inflate options.\n *\n * Decompress `data` with inflate/ungzip and `options`. Autodetect\n * format via wrapper header by default. That's why we don't provide\n * separate `ungzip` method.\n *\n * Supported options are:\n *\n * - windowBits\n *\n * [http://zlib.net/manual.html#Advanced](http://zlib.net/manual.html#Advanced)\n * for more information.\n *\n * Sugar (options):\n *\n * - `raw` (Boolean) - say that we work with raw stream, if you don't wish to specify\n * negative windowBits implicitly.\n * - `to` (String) - if equal to 'string', then result will be converted\n * from utf8 to utf16 (javascript) string. When string output requested,\n * chunk length can differ from `chunkSize`, depending on content.\n *\n *\n * ##### Example:\n *\n * ```javascript\n * var pako = require('pako')\n * , input = pako.deflate([1,2,3,4,5,6,7,8,9])\n * , output;\n *\n * try {\n * output = pako.inflate(input);\n * } catch (err)\n * console.log(err);\n * }\n * ```\n **/\nfunction inflate(input, options) {\n var inflator = new Inflate(options);\n\n inflator.push(input, true);\n\n // That will never happens, if you don't cheat with options :)\n if (inflator.err) { throw inflator.msg || msg[inflator.err]; }\n\n return inflator.result;\n}\n\n\n/**\n * inflateRaw(data[, options]) -> Uint8Array|Array|String\n * - data (Uint8Array|Array|String): input data to decompress.\n * - options (Object): zlib inflate options.\n *\n * The same as [[inflate]], but creates raw data, without wrapper\n * (header and adler32 crc).\n **/\nfunction inflateRaw(input, options) {\n options = options || {};\n options.raw = true;\n return inflate(input, options);\n}\n\n\n/**\n * ungzip(data[, options]) -> Uint8Array|Array|String\n * - data (Uint8Array|Array|String): input data to decompress.\n * - options (Object): zlib inflate options.\n *\n * Just shortcut to [[inflate]], because it autodetects format\n * by header.content. Done for convenience.\n **/\n\n\nexports.Inflate = Inflate;\nexports.inflate = inflate;\nexports.inflateRaw = inflateRaw;\nexports.ungzip = inflate;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/pako/lib/inflate.js\n// module id = 23\n// module chunks = 0","// String encode/decode helpers\n'use strict';\n\n\nvar utils = require('./common');\n\n\n// Quick check if we can use fast array to bin string conversion\n//\n// - apply(Array) can fail on Android 2.2\n// - apply(Uint8Array) can fail on iOS 5.1 Safary\n//\nvar STR_APPLY_OK = true;\nvar STR_APPLY_UIA_OK = true;\n\ntry { String.fromCharCode.apply(null, [ 0 ]); } catch (__) { STR_APPLY_OK = false; }\ntry { String.fromCharCode.apply(null, new Uint8Array(1)); } catch (__) { STR_APPLY_UIA_OK = false; }\n\n\n// Table with utf8 lengths (calculated by first byte of sequence)\n// Note, that 5 & 6-byte values and some 4-byte values can not be represented in JS,\n// because max possible codepoint is 0x10ffff\nvar _utf8len = new utils.Buf8(256);\nfor (var q = 0; q < 256; q++) {\n _utf8len[q] = (q >= 252 ? 6 : q >= 248 ? 5 : q >= 240 ? 4 : q >= 224 ? 3 : q >= 192 ? 2 : 1);\n}\n_utf8len[254] = _utf8len[254] = 1; // Invalid sequence start\n\n\n// convert string to array (typed, when possible)\nexports.string2buf = function (str) {\n var buf, c, c2, m_pos, i, str_len = str.length, buf_len = 0;\n\n // count binary size\n for (m_pos = 0; m_pos < str_len; m_pos++) {\n c = str.charCodeAt(m_pos);\n if ((c & 0xfc00) === 0xd800 && (m_pos + 1 < str_len)) {\n c2 = str.charCodeAt(m_pos + 1);\n if ((c2 & 0xfc00) === 0xdc00) {\n c = 0x10000 + ((c - 0xd800) << 10) + (c2 - 0xdc00);\n m_pos++;\n }\n }\n buf_len += c < 0x80 ? 1 : c < 0x800 ? 2 : c < 0x10000 ? 3 : 4;\n }\n\n // allocate buffer\n buf = new utils.Buf8(buf_len);\n\n // convert\n for (i = 0, m_pos = 0; i < buf_len; m_pos++) {\n c = str.charCodeAt(m_pos);\n if ((c & 0xfc00) === 0xd800 && (m_pos + 1 < str_len)) {\n c2 = str.charCodeAt(m_pos + 1);\n if ((c2 & 0xfc00) === 0xdc00) {\n c = 0x10000 + ((c - 0xd800) << 10) + (c2 - 0xdc00);\n m_pos++;\n }\n }\n if (c < 0x80) {\n /* one byte */\n buf[i++] = c;\n } else if (c < 0x800) {\n /* two bytes */\n buf[i++] = 0xC0 | (c >>> 6);\n buf[i++] = 0x80 | (c & 0x3f);\n } else if (c < 0x10000) {\n /* three bytes */\n buf[i++] = 0xE0 | (c >>> 12);\n buf[i++] = 0x80 | (c >>> 6 & 0x3f);\n buf[i++] = 0x80 | (c & 0x3f);\n } else {\n /* four bytes */\n buf[i++] = 0xf0 | (c >>> 18);\n buf[i++] = 0x80 | (c >>> 12 & 0x3f);\n buf[i++] = 0x80 | (c >>> 6 & 0x3f);\n buf[i++] = 0x80 | (c & 0x3f);\n }\n }\n\n return buf;\n};\n\n// Helper (used in 2 places)\nfunction buf2binstring(buf, len) {\n // use fallback for big arrays to avoid stack overflow\n if (len < 65537) {\n if ((buf.subarray && STR_APPLY_UIA_OK) || (!buf.subarray && STR_APPLY_OK)) {\n return String.fromCharCode.apply(null, utils.shrinkBuf(buf, len));\n }\n }\n\n var result = '';\n for (var i = 0; i < len; i++) {\n result += String.fromCharCode(buf[i]);\n }\n return result;\n}\n\n\n// Convert byte array to binary string\nexports.buf2binstring = function (buf) {\n return buf2binstring(buf, buf.length);\n};\n\n\n// Convert binary string (typed, when possible)\nexports.binstring2buf = function (str) {\n var buf = new utils.Buf8(str.length);\n for (var i = 0, len = buf.length; i < len; i++) {\n buf[i] = str.charCodeAt(i);\n }\n return buf;\n};\n\n\n// convert array to string\nexports.buf2string = function (buf, max) {\n var i, out, c, c_len;\n var len = max || buf.length;\n\n // Reserve max possible length (2 words per char)\n // NB: by unknown reasons, Array is significantly faster for\n // String.fromCharCode.apply than Uint16Array.\n var utf16buf = new Array(len * 2);\n\n for (out = 0, i = 0; i < len;) {\n c = buf[i++];\n // quick process ascii\n if (c < 0x80) { utf16buf[out++] = c; continue; }\n\n c_len = _utf8len[c];\n // skip 5 & 6 byte codes\n if (c_len > 4) { utf16buf[out++] = 0xfffd; i += c_len - 1; continue; }\n\n // apply mask on first byte\n c &= c_len === 2 ? 0x1f : c_len === 3 ? 0x0f : 0x07;\n // join the rest\n while (c_len > 1 && i < len) {\n c = (c << 6) | (buf[i++] & 0x3f);\n c_len--;\n }\n\n // terminated by end of string?\n if (c_len > 1) { utf16buf[out++] = 0xfffd; continue; }\n\n if (c < 0x10000) {\n utf16buf[out++] = c;\n } else {\n c -= 0x10000;\n utf16buf[out++] = 0xd800 | ((c >> 10) & 0x3ff);\n utf16buf[out++] = 0xdc00 | (c & 0x3ff);\n }\n }\n\n return buf2binstring(utf16buf, out);\n};\n\n\n// Calculate max possible position in utf8 buffer,\n// that will not break sequence. If that's not possible\n// - (very small limits) return max size as is.\n//\n// buf[] - utf8 bytes array\n// max - length limit (mandatory);\nexports.utf8border = function (buf, max) {\n var pos;\n\n max = max || buf.length;\n if (max > buf.length) { max = buf.length; }\n\n // go back from last position, until start of sequence found\n pos = max - 1;\n while (pos >= 0 && (buf[pos] & 0xC0) === 0x80) { pos--; }\n\n // Fuckup - very small and broken sequence,\n // return max, because we should return something anyway.\n if (pos < 0) { return max; }\n\n // If we came to start of buffer - that means vuffer is too small,\n // return max too.\n if (pos === 0) { return max; }\n\n return (pos + _utf8len[buf[pos]] > max) ? pos : max;\n};\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/pako/lib/utils/strings.js\n// module id = 24\n// module chunks = 0","'use strict';\n\n// Note: adler32 takes 12% for level 0 and 2% for level 6.\n// It doesn't worth to make additional optimizationa as in original.\n// Small size is preferable.\n\nfunction adler32(adler, buf, len, pos) {\n var s1 = (adler & 0xffff) |0,\n s2 = ((adler >>> 16) & 0xffff) |0,\n n = 0;\n\n while (len !== 0) {\n // Set limit ~ twice less than 5552, to keep\n // s2 in 31-bits, because we force signed ints.\n // in other case %= will fail.\n n = len > 2000 ? 2000 : len;\n len -= n;\n\n do {\n s1 = (s1 + buf[pos++]) |0;\n s2 = (s2 + s1) |0;\n } while (--n);\n\n s1 %= 65521;\n s2 %= 65521;\n }\n\n return (s1 | (s2 << 16)) |0;\n}\n\n\nmodule.exports = adler32;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/pako/lib/zlib/adler32.js\n// module id = 25\n// module chunks = 0","'use strict';\n\n\nmodule.exports = {\n\n /* Allowed flush values; see deflate() and inflate() below for details */\n Z_NO_FLUSH: 0,\n Z_PARTIAL_FLUSH: 1,\n Z_SYNC_FLUSH: 2,\n Z_FULL_FLUSH: 3,\n Z_FINISH: 4,\n Z_BLOCK: 5,\n Z_TREES: 6,\n\n /* Return codes for the compression/decompression functions. Negative values\n * are errors, positive values are used for special but normal events.\n */\n Z_OK: 0,\n Z_STREAM_END: 1,\n Z_NEED_DICT: 2,\n Z_ERRNO: -1,\n Z_STREAM_ERROR: -2,\n Z_DATA_ERROR: -3,\n //Z_MEM_ERROR: -4,\n Z_BUF_ERROR: -5,\n //Z_VERSION_ERROR: -6,\n\n /* compression levels */\n Z_NO_COMPRESSION: 0,\n Z_BEST_SPEED: 1,\n Z_BEST_COMPRESSION: 9,\n Z_DEFAULT_COMPRESSION: -1,\n\n\n Z_FILTERED: 1,\n Z_HUFFMAN_ONLY: 2,\n Z_RLE: 3,\n Z_FIXED: 4,\n Z_DEFAULT_STRATEGY: 0,\n\n /* Possible values of the data_type field (though see inflate()) */\n Z_BINARY: 0,\n Z_TEXT: 1,\n //Z_ASCII: 1, // = Z_TEXT (deprecated)\n Z_UNKNOWN: 2,\n\n /* The deflate compression method */\n Z_DEFLATED: 8\n //Z_NULL: null // Use -1 or null inline, depending on var type\n};\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/pako/lib/zlib/constants.js\n// module id = 26\n// module chunks = 0","'use strict';\n\n// Note: we can't get significant speed boost here.\n// So write code to minimize size - no pregenerated tables\n// and array tools dependencies.\n\n\n// Use ordinary array, since untyped makes no boost here\nfunction makeTable() {\n var c, table = [];\n\n for (var n = 0; n < 256; n++) {\n c = n;\n for (var k = 0; k < 8; k++) {\n c = ((c & 1) ? (0xEDB88320 ^ (c >>> 1)) : (c >>> 1));\n }\n table[n] = c;\n }\n\n return table;\n}\n\n// Create table on load. Just 255 signed longs. Not a problem.\nvar crcTable = makeTable();\n\n\nfunction crc32(crc, buf, len, pos) {\n var t = crcTable,\n end = pos + len;\n\n crc ^= -1;\n\n for (var i = pos; i < end; i++) {\n crc = (crc >>> 8) ^ t[(crc ^ buf[i]) & 0xFF];\n }\n\n return (crc ^ (-1)); // >>> 0;\n}\n\n\nmodule.exports = crc32;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/pako/lib/zlib/crc32.js\n// module id = 27\n// module chunks = 0","'use strict';\n\n\nfunction GZheader() {\n /* true if compressed data believed to be text */\n this.text = 0;\n /* modification time */\n this.time = 0;\n /* extra flags (not used when writing a gzip file) */\n this.xflags = 0;\n /* operating system */\n this.os = 0;\n /* pointer to extra field or Z_NULL if none */\n this.extra = null;\n /* extra field length (valid if extra != Z_NULL) */\n this.extra_len = 0; // Actually, we don't need it in JS,\n // but leave for few code modifications\n\n //\n // Setup limits is not necessary because in js we should not preallocate memory\n // for inflate use constant limit in 65536 bytes\n //\n\n /* space at extra (only when reading header) */\n // this.extra_max = 0;\n /* pointer to zero-terminated file name or Z_NULL */\n this.name = '';\n /* space at name (only when reading header) */\n // this.name_max = 0;\n /* pointer to zero-terminated comment or Z_NULL */\n this.comment = '';\n /* space at comment (only when reading header) */\n // this.comm_max = 0;\n /* true if there was or will be a header crc */\n this.hcrc = 0;\n /* true when done reading gzip header (not used when writing a gzip file) */\n this.done = false;\n}\n\nmodule.exports = GZheader;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/pako/lib/zlib/gzheader.js\n// module id = 28\n// module chunks = 0","'use strict';\n\n// See state defs from inflate.js\nvar BAD = 30; /* got a data error -- remain here until reset */\nvar TYPE = 12; /* i: waiting for type bits, including last-flag bit */\n\n/*\n Decode literal, length, and distance codes and write out the resulting\n literal and match bytes until either not enough input or output is\n available, an end-of-block is encountered, or a data error is encountered.\n When large enough input and output buffers are supplied to inflate(), for\n example, a 16K input buffer and a 64K output buffer, more than 95% of the\n inflate execution time is spent in this routine.\n\n Entry assumptions:\n\n state.mode === LEN\n strm.avail_in >= 6\n strm.avail_out >= 258\n start >= strm.avail_out\n state.bits < 8\n\n On return, state.mode is one of:\n\n LEN -- ran out of enough output space or enough available input\n TYPE -- reached end of block code, inflate() to interpret next block\n BAD -- error in block data\n\n Notes:\n\n - The maximum input bits used by a length/distance pair is 15 bits for the\n length code, 5 bits for the length extra, 15 bits for the distance code,\n and 13 bits for the distance extra. This totals 48 bits, or six bytes.\n Therefore if strm.avail_in >= 6, then there is enough input to avoid\n checking for available input while decoding.\n\n - The maximum bytes that a single length/distance pair can output is 258\n bytes, which is the maximum length that can be coded. inflate_fast()\n requires strm.avail_out >= 258 for each loop to avoid checking for\n output space.\n */\nmodule.exports = function inflate_fast(strm, start) {\n var state;\n var _in; /* local strm.input */\n var last; /* have enough input while in < last */\n var _out; /* local strm.output */\n var beg; /* inflate()'s initial strm.output */\n var end; /* while out < end, enough space available */\n//#ifdef INFLATE_STRICT\n var dmax; /* maximum distance from zlib header */\n//#endif\n var wsize; /* window size or zero if not using window */\n var whave; /* valid bytes in the window */\n var wnext; /* window write index */\n // Use `s_window` instead `window`, avoid conflict with instrumentation tools\n var s_window; /* allocated sliding window, if wsize != 0 */\n var hold; /* local strm.hold */\n var bits; /* local strm.bits */\n var lcode; /* local strm.lencode */\n var dcode; /* local strm.distcode */\n var lmask; /* mask for first level of length codes */\n var dmask; /* mask for first level of distance codes */\n var here; /* retrieved table entry */\n var op; /* code bits, operation, extra bits, or */\n /* window position, window bytes to copy */\n var len; /* match length, unused bytes */\n var dist; /* match distance */\n var from; /* where to copy match from */\n var from_source;\n\n\n var input, output; // JS specific, because we have no pointers\n\n /* copy state to local variables */\n state = strm.state;\n //here = state.here;\n _in = strm.next_in;\n input = strm.input;\n last = _in + (strm.avail_in - 5);\n _out = strm.next_out;\n output = strm.output;\n beg = _out - (start - strm.avail_out);\n end = _out + (strm.avail_out - 257);\n//#ifdef INFLATE_STRICT\n dmax = state.dmax;\n//#endif\n wsize = state.wsize;\n whave = state.whave;\n wnext = state.wnext;\n s_window = state.window;\n hold = state.hold;\n bits = state.bits;\n lcode = state.lencode;\n dcode = state.distcode;\n lmask = (1 << state.lenbits) - 1;\n dmask = (1 << state.distbits) - 1;\n\n\n /* decode literals and length/distances until end-of-block or not enough\n input data or output space */\n\n top:\n do {\n if (bits < 15) {\n hold += input[_in++] << bits;\n bits += 8;\n hold += input[_in++] << bits;\n bits += 8;\n }\n\n here = lcode[hold & lmask];\n\n dolen:\n for (;;) { // Goto emulation\n op = here >>> 24/*here.bits*/;\n hold >>>= op;\n bits -= op;\n op = (here >>> 16) & 0xff/*here.op*/;\n if (op === 0) { /* literal */\n //Tracevv((stderr, here.val >= 0x20 && here.val < 0x7f ?\n // \"inflate: literal '%c'\\n\" :\n // \"inflate: literal 0x%02x\\n\", here.val));\n output[_out++] = here & 0xffff/*here.val*/;\n }\n else if (op & 16) { /* length base */\n len = here & 0xffff/*here.val*/;\n op &= 15; /* number of extra bits */\n if (op) {\n if (bits < op) {\n hold += input[_in++] << bits;\n bits += 8;\n }\n len += hold & ((1 << op) - 1);\n hold >>>= op;\n bits -= op;\n }\n //Tracevv((stderr, \"inflate: length %u\\n\", len));\n if (bits < 15) {\n hold += input[_in++] << bits;\n bits += 8;\n hold += input[_in++] << bits;\n bits += 8;\n }\n here = dcode[hold & dmask];\n\n dodist:\n for (;;) { // goto emulation\n op = here >>> 24/*here.bits*/;\n hold >>>= op;\n bits -= op;\n op = (here >>> 16) & 0xff/*here.op*/;\n\n if (op & 16) { /* distance base */\n dist = here & 0xffff/*here.val*/;\n op &= 15; /* number of extra bits */\n if (bits < op) {\n hold += input[_in++] << bits;\n bits += 8;\n if (bits < op) {\n hold += input[_in++] << bits;\n bits += 8;\n }\n }\n dist += hold & ((1 << op) - 1);\n//#ifdef INFLATE_STRICT\n if (dist > dmax) {\n strm.msg = 'invalid distance too far back';\n state.mode = BAD;\n break top;\n }\n//#endif\n hold >>>= op;\n bits -= op;\n //Tracevv((stderr, \"inflate: distance %u\\n\", dist));\n op = _out - beg; /* max distance in output */\n if (dist > op) { /* see if copy from window */\n op = dist - op; /* distance back in window */\n if (op > whave) {\n if (state.sane) {\n strm.msg = 'invalid distance too far back';\n state.mode = BAD;\n break top;\n }\n\n// (!) This block is disabled in zlib defailts,\n// don't enable it for binary compatibility\n//#ifdef INFLATE_ALLOW_INVALID_DISTANCE_TOOFAR_ARRR\n// if (len <= op - whave) {\n// do {\n// output[_out++] = 0;\n// } while (--len);\n// continue top;\n// }\n// len -= op - whave;\n// do {\n// output[_out++] = 0;\n// } while (--op > whave);\n// if (op === 0) {\n// from = _out - dist;\n// do {\n// output[_out++] = output[from++];\n// } while (--len);\n// continue top;\n// }\n//#endif\n }\n from = 0; // window index\n from_source = s_window;\n if (wnext === 0) { /* very common case */\n from += wsize - op;\n if (op < len) { /* some from window */\n len -= op;\n do {\n output[_out++] = s_window[from++];\n } while (--op);\n from = _out - dist; /* rest from output */\n from_source = output;\n }\n }\n else if (wnext < op) { /* wrap around window */\n from += wsize + wnext - op;\n op -= wnext;\n if (op < len) { /* some from end of window */\n len -= op;\n do {\n output[_out++] = s_window[from++];\n } while (--op);\n from = 0;\n if (wnext < len) { /* some from start of window */\n op = wnext;\n len -= op;\n do {\n output[_out++] = s_window[from++];\n } while (--op);\n from = _out - dist; /* rest from output */\n from_source = output;\n }\n }\n }\n else { /* contiguous in window */\n from += wnext - op;\n if (op < len) { /* some from window */\n len -= op;\n do {\n output[_out++] = s_window[from++];\n } while (--op);\n from = _out - dist; /* rest from output */\n from_source = output;\n }\n }\n while (len > 2) {\n output[_out++] = from_source[from++];\n output[_out++] = from_source[from++];\n output[_out++] = from_source[from++];\n len -= 3;\n }\n if (len) {\n output[_out++] = from_source[from++];\n if (len > 1) {\n output[_out++] = from_source[from++];\n }\n }\n }\n else {\n from = _out - dist; /* copy direct from output */\n do { /* minimum length is three */\n output[_out++] = output[from++];\n output[_out++] = output[from++];\n output[_out++] = output[from++];\n len -= 3;\n } while (len > 2);\n if (len) {\n output[_out++] = output[from++];\n if (len > 1) {\n output[_out++] = output[from++];\n }\n }\n }\n }\n else if ((op & 64) === 0) { /* 2nd level distance code */\n here = dcode[(here & 0xffff)/*here.val*/ + (hold & ((1 << op) - 1))];\n continue dodist;\n }\n else {\n strm.msg = 'invalid distance code';\n state.mode = BAD;\n break top;\n }\n\n break; // need to emulate goto via \"continue\"\n }\n }\n else if ((op & 64) === 0) { /* 2nd level length code */\n here = lcode[(here & 0xffff)/*here.val*/ + (hold & ((1 << op) - 1))];\n continue dolen;\n }\n else if (op & 32) { /* end-of-block */\n //Tracevv((stderr, \"inflate: end of block\\n\"));\n state.mode = TYPE;\n break top;\n }\n else {\n strm.msg = 'invalid literal/length code';\n state.mode = BAD;\n break top;\n }\n\n break; // need to emulate goto via \"continue\"\n }\n } while (_in < last && _out < end);\n\n /* return unused bytes (on entry, bits < 8, so in won't go too far back) */\n len = bits >> 3;\n _in -= len;\n bits -= len << 3;\n hold &= (1 << bits) - 1;\n\n /* update state and return */\n strm.next_in = _in;\n strm.next_out = _out;\n strm.avail_in = (_in < last ? 5 + (last - _in) : 5 - (_in - last));\n strm.avail_out = (_out < end ? 257 + (end - _out) : 257 - (_out - end));\n state.hold = hold;\n state.bits = bits;\n return;\n};\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/pako/lib/zlib/inffast.js\n// module id = 29\n// module chunks = 0","'use strict';\n\n\nvar utils = require('../utils/common');\nvar adler32 = require('./adler32');\nvar crc32 = require('./crc32');\nvar inflate_fast = require('./inffast');\nvar inflate_table = require('./inftrees');\n\nvar CODES = 0;\nvar LENS = 1;\nvar DISTS = 2;\n\n/* Public constants ==========================================================*/\n/* ===========================================================================*/\n\n\n/* Allowed flush values; see deflate() and inflate() below for details */\n//var Z_NO_FLUSH = 0;\n//var Z_PARTIAL_FLUSH = 1;\n//var Z_SYNC_FLUSH = 2;\n//var Z_FULL_FLUSH = 3;\nvar Z_FINISH = 4;\nvar Z_BLOCK = 5;\nvar Z_TREES = 6;\n\n\n/* Return codes for the compression/decompression functions. Negative values\n * are errors, positive values are used for special but normal events.\n */\nvar Z_OK = 0;\nvar Z_STREAM_END = 1;\nvar Z_NEED_DICT = 2;\n//var Z_ERRNO = -1;\nvar Z_STREAM_ERROR = -2;\nvar Z_DATA_ERROR = -3;\nvar Z_MEM_ERROR = -4;\nvar Z_BUF_ERROR = -5;\n//var Z_VERSION_ERROR = -6;\n\n/* The deflate compression method */\nvar Z_DEFLATED = 8;\n\n\n/* STATES ====================================================================*/\n/* ===========================================================================*/\n\n\nvar HEAD = 1; /* i: waiting for magic header */\nvar FLAGS = 2; /* i: waiting for method and flags (gzip) */\nvar TIME = 3; /* i: waiting for modification time (gzip) */\nvar OS = 4; /* i: waiting for extra flags and operating system (gzip) */\nvar EXLEN = 5; /* i: waiting for extra length (gzip) */\nvar EXTRA = 6; /* i: waiting for extra bytes (gzip) */\nvar NAME = 7; /* i: waiting for end of file name (gzip) */\nvar COMMENT = 8; /* i: waiting for end of comment (gzip) */\nvar HCRC = 9; /* i: waiting for header crc (gzip) */\nvar DICTID = 10; /* i: waiting for dictionary check value */\nvar DICT = 11; /* waiting for inflateSetDictionary() call */\nvar TYPE = 12; /* i: waiting for type bits, including last-flag bit */\nvar TYPEDO = 13; /* i: same, but skip check to exit inflate on new block */\nvar STORED = 14; /* i: waiting for stored size (length and complement) */\nvar COPY_ = 15; /* i/o: same as COPY below, but only first time in */\nvar COPY = 16; /* i/o: waiting for input or output to copy stored block */\nvar TABLE = 17; /* i: waiting for dynamic block table lengths */\nvar LENLENS = 18; /* i: waiting for code length code lengths */\nvar CODELENS = 19; /* i: waiting for length/lit and distance code lengths */\nvar LEN_ = 20; /* i: same as LEN below, but only first time in */\nvar LEN = 21; /* i: waiting for length/lit/eob code */\nvar LENEXT = 22; /* i: waiting for length extra bits */\nvar DIST = 23; /* i: waiting for distance code */\nvar DISTEXT = 24; /* i: waiting for distance extra bits */\nvar MATCH = 25; /* o: waiting for output space to copy string */\nvar LIT = 26; /* o: waiting for output space to write literal */\nvar CHECK = 27; /* i: waiting for 32-bit check value */\nvar LENGTH = 28; /* i: waiting for 32-bit length (gzip) */\nvar DONE = 29; /* finished check, done -- remain here until reset */\nvar BAD = 30; /* got a data error -- remain here until reset */\nvar MEM = 31; /* got an inflate() memory error -- remain here until reset */\nvar SYNC = 32; /* looking for synchronization bytes to restart inflate() */\n\n/* ===========================================================================*/\n\n\n\nvar ENOUGH_LENS = 852;\nvar ENOUGH_DISTS = 592;\n//var ENOUGH = (ENOUGH_LENS+ENOUGH_DISTS);\n\nvar MAX_WBITS = 15;\n/* 32K LZ77 window */\nvar DEF_WBITS = MAX_WBITS;\n\n\nfunction zswap32(q) {\n return (((q >>> 24) & 0xff) +\n ((q >>> 8) & 0xff00) +\n ((q & 0xff00) << 8) +\n ((q & 0xff) << 24));\n}\n\n\nfunction InflateState() {\n this.mode = 0; /* current inflate mode */\n this.last = false; /* true if processing last block */\n this.wrap = 0; /* bit 0 true for zlib, bit 1 true for gzip */\n this.havedict = false; /* true if dictionary provided */\n this.flags = 0; /* gzip header method and flags (0 if zlib) */\n this.dmax = 0; /* zlib header max distance (INFLATE_STRICT) */\n this.check = 0; /* protected copy of check value */\n this.total = 0; /* protected copy of output count */\n // TODO: may be {}\n this.head = null; /* where to save gzip header information */\n\n /* sliding window */\n this.wbits = 0; /* log base 2 of requested window size */\n this.wsize = 0; /* window size or zero if not using window */\n this.whave = 0; /* valid bytes in the window */\n this.wnext = 0; /* window write index */\n this.window = null; /* allocated sliding window, if needed */\n\n /* bit accumulator */\n this.hold = 0; /* input bit accumulator */\n this.bits = 0; /* number of bits in \"in\" */\n\n /* for string and stored block copying */\n this.length = 0; /* literal or length of data to copy */\n this.offset = 0; /* distance back to copy string from */\n\n /* for table and code decoding */\n this.extra = 0; /* extra bits needed */\n\n /* fixed and dynamic code tables */\n this.lencode = null; /* starting table for length/literal codes */\n this.distcode = null; /* starting table for distance codes */\n this.lenbits = 0; /* index bits for lencode */\n this.distbits = 0; /* index bits for distcode */\n\n /* dynamic table building */\n this.ncode = 0; /* number of code length code lengths */\n this.nlen = 0; /* number of length code lengths */\n this.ndist = 0; /* number of distance code lengths */\n this.have = 0; /* number of code lengths in lens[] */\n this.next = null; /* next available space in codes[] */\n\n this.lens = new utils.Buf16(320); /* temporary storage for code lengths */\n this.work = new utils.Buf16(288); /* work area for code table building */\n\n /*\n because we don't have pointers in js, we use lencode and distcode directly\n as buffers so we don't need codes\n */\n //this.codes = new utils.Buf32(ENOUGH); /* space for code tables */\n this.lendyn = null; /* dynamic table for length/literal codes (JS specific) */\n this.distdyn = null; /* dynamic table for distance codes (JS specific) */\n this.sane = 0; /* if false, allow invalid distance too far */\n this.back = 0; /* bits back of last unprocessed length/lit */\n this.was = 0; /* initial length of match */\n}\n\nfunction inflateResetKeep(strm) {\n var state;\n\n if (!strm || !strm.state) { return Z_STREAM_ERROR; }\n state = strm.state;\n strm.total_in = strm.total_out = state.total = 0;\n strm.msg = ''; /*Z_NULL*/\n if (state.wrap) { /* to support ill-conceived Java test suite */\n strm.adler = state.wrap & 1;\n }\n state.mode = HEAD;\n state.last = 0;\n state.havedict = 0;\n state.dmax = 32768;\n state.head = null/*Z_NULL*/;\n state.hold = 0;\n state.bits = 0;\n //state.lencode = state.distcode = state.next = state.codes;\n state.lencode = state.lendyn = new utils.Buf32(ENOUGH_LENS);\n state.distcode = state.distdyn = new utils.Buf32(ENOUGH_DISTS);\n\n state.sane = 1;\n state.back = -1;\n //Tracev((stderr, \"inflate: reset\\n\"));\n return Z_OK;\n}\n\nfunction inflateReset(strm) {\n var state;\n\n if (!strm || !strm.state) { return Z_STREAM_ERROR; }\n state = strm.state;\n state.wsize = 0;\n state.whave = 0;\n state.wnext = 0;\n return inflateResetKeep(strm);\n\n}\n\nfunction inflateReset2(strm, windowBits) {\n var wrap;\n var state;\n\n /* get the state */\n if (!strm || !strm.state) { return Z_STREAM_ERROR; }\n state = strm.state;\n\n /* extract wrap request from windowBits parameter */\n if (windowBits < 0) {\n wrap = 0;\n windowBits = -windowBits;\n }\n else {\n wrap = (windowBits >> 4) + 1;\n if (windowBits < 48) {\n windowBits &= 15;\n }\n }\n\n /* set number of window bits, free window if different */\n if (windowBits && (windowBits < 8 || windowBits > 15)) {\n return Z_STREAM_ERROR;\n }\n if (state.window !== null && state.wbits !== windowBits) {\n state.window = null;\n }\n\n /* update state and reset the rest of it */\n state.wrap = wrap;\n state.wbits = windowBits;\n return inflateReset(strm);\n}\n\nfunction inflateInit2(strm, windowBits) {\n var ret;\n var state;\n\n if (!strm) { return Z_STREAM_ERROR; }\n //strm.msg = Z_NULL; /* in case we return an error */\n\n state = new InflateState();\n\n //if (state === Z_NULL) return Z_MEM_ERROR;\n //Tracev((stderr, \"inflate: allocated\\n\"));\n strm.state = state;\n state.window = null/*Z_NULL*/;\n ret = inflateReset2(strm, windowBits);\n if (ret !== Z_OK) {\n strm.state = null/*Z_NULL*/;\n }\n return ret;\n}\n\nfunction inflateInit(strm) {\n return inflateInit2(strm, DEF_WBITS);\n}\n\n\n/*\n Return state with length and distance decoding tables and index sizes set to\n fixed code decoding. Normally this returns fixed tables from inffixed.h.\n If BUILDFIXED is defined, then instead this routine builds the tables the\n first time it's called, and returns those tables the first time and\n thereafter. This reduces the size of the code by about 2K bytes, in\n exchange for a little execution time. However, BUILDFIXED should not be\n used for threaded applications, since the rewriting of the tables and virgin\n may not be thread-safe.\n */\nvar virgin = true;\n\nvar lenfix, distfix; // We have no pointers in JS, so keep tables separate\n\nfunction fixedtables(state) {\n /* build fixed huffman tables if first call (may not be thread safe) */\n if (virgin) {\n var sym;\n\n lenfix = new utils.Buf32(512);\n distfix = new utils.Buf32(32);\n\n /* literal/length table */\n sym = 0;\n while (sym < 144) { state.lens[sym++] = 8; }\n while (sym < 256) { state.lens[sym++] = 9; }\n while (sym < 280) { state.lens[sym++] = 7; }\n while (sym < 288) { state.lens[sym++] = 8; }\n\n inflate_table(LENS, state.lens, 0, 288, lenfix, 0, state.work, { bits: 9 });\n\n /* distance table */\n sym = 0;\n while (sym < 32) { state.lens[sym++] = 5; }\n\n inflate_table(DISTS, state.lens, 0, 32, distfix, 0, state.work, { bits: 5 });\n\n /* do this just once */\n virgin = false;\n }\n\n state.lencode = lenfix;\n state.lenbits = 9;\n state.distcode = distfix;\n state.distbits = 5;\n}\n\n\n/*\n Update the window with the last wsize (normally 32K) bytes written before\n returning. If window does not exist yet, create it. This is only called\n when a window is already in use, or when output has been written during this\n inflate call, but the end of the deflate stream has not been reached yet.\n It is also called to create a window for dictionary data when a dictionary\n is loaded.\n\n Providing output buffers larger than 32K to inflate() should provide a speed\n advantage, since only the last 32K of output is copied to the sliding window\n upon return from inflate(), and since all distances after the first 32K of\n output will fall in the output data, making match copies simpler and faster.\n The advantage may be dependent on the size of the processor's data caches.\n */\nfunction updatewindow(strm, src, end, copy) {\n var dist;\n var state = strm.state;\n\n /* if it hasn't been done already, allocate space for the window */\n if (state.window === null) {\n state.wsize = 1 << state.wbits;\n state.wnext = 0;\n state.whave = 0;\n\n state.window = new utils.Buf8(state.wsize);\n }\n\n /* copy state->wsize or less output bytes into the circular window */\n if (copy >= state.wsize) {\n utils.arraySet(state.window, src, end - state.wsize, state.wsize, 0);\n state.wnext = 0;\n state.whave = state.wsize;\n }\n else {\n dist = state.wsize - state.wnext;\n if (dist > copy) {\n dist = copy;\n }\n //zmemcpy(state->window + state->wnext, end - copy, dist);\n utils.arraySet(state.window, src, end - copy, dist, state.wnext);\n copy -= dist;\n if (copy) {\n //zmemcpy(state->window, end - copy, copy);\n utils.arraySet(state.window, src, end - copy, copy, 0);\n state.wnext = copy;\n state.whave = state.wsize;\n }\n else {\n state.wnext += dist;\n if (state.wnext === state.wsize) { state.wnext = 0; }\n if (state.whave < state.wsize) { state.whave += dist; }\n }\n }\n return 0;\n}\n\nfunction inflate(strm, flush) {\n var state;\n var input, output; // input/output buffers\n var next; /* next input INDEX */\n var put; /* next output INDEX */\n var have, left; /* available input and output */\n var hold; /* bit buffer */\n var bits; /* bits in bit buffer */\n var _in, _out; /* save starting available input and output */\n var copy; /* number of stored or match bytes to copy */\n var from; /* where to copy match bytes from */\n var from_source;\n var here = 0; /* current decoding table entry */\n var here_bits, here_op, here_val; // paked \"here\" denormalized (JS specific)\n //var last; /* parent table entry */\n var last_bits, last_op, last_val; // paked \"last\" denormalized (JS specific)\n var len; /* length to copy for repeats, bits to drop */\n var ret; /* return code */\n var hbuf = new utils.Buf8(4); /* buffer for gzip header crc calculation */\n var opts;\n\n var n; // temporary var for NEED_BITS\n\n var order = /* permutation of code lengths */\n [ 16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15 ];\n\n\n if (!strm || !strm.state || !strm.output ||\n (!strm.input && strm.avail_in !== 0)) {\n return Z_STREAM_ERROR;\n }\n\n state = strm.state;\n if (state.mode === TYPE) { state.mode = TYPEDO; } /* skip check */\n\n\n //--- LOAD() ---\n put = strm.next_out;\n output = strm.output;\n left = strm.avail_out;\n next = strm.next_in;\n input = strm.input;\n have = strm.avail_in;\n hold = state.hold;\n bits = state.bits;\n //---\n\n _in = have;\n _out = left;\n ret = Z_OK;\n\n inf_leave: // goto emulation\n for (;;) {\n switch (state.mode) {\n case HEAD:\n if (state.wrap === 0) {\n state.mode = TYPEDO;\n break;\n }\n //=== NEEDBITS(16);\n while (bits < 16) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if ((state.wrap & 2) && hold === 0x8b1f) { /* gzip header */\n state.check = 0/*crc32(0L, Z_NULL, 0)*/;\n //=== CRC2(state.check, hold);\n hbuf[0] = hold & 0xff;\n hbuf[1] = (hold >>> 8) & 0xff;\n state.check = crc32(state.check, hbuf, 2, 0);\n //===//\n\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = FLAGS;\n break;\n }\n state.flags = 0; /* expect zlib header */\n if (state.head) {\n state.head.done = false;\n }\n if (!(state.wrap & 1) || /* check if zlib header allowed */\n (((hold & 0xff)/*BITS(8)*/ << 8) + (hold >> 8)) % 31) {\n strm.msg = 'incorrect header check';\n state.mode = BAD;\n break;\n }\n if ((hold & 0x0f)/*BITS(4)*/ !== Z_DEFLATED) {\n strm.msg = 'unknown compression method';\n state.mode = BAD;\n break;\n }\n //--- DROPBITS(4) ---//\n hold >>>= 4;\n bits -= 4;\n //---//\n len = (hold & 0x0f)/*BITS(4)*/ + 8;\n if (state.wbits === 0) {\n state.wbits = len;\n }\n else if (len > state.wbits) {\n strm.msg = 'invalid window size';\n state.mode = BAD;\n break;\n }\n state.dmax = 1 << len;\n //Tracev((stderr, \"inflate: zlib header ok\\n\"));\n strm.adler = state.check = 1/*adler32(0L, Z_NULL, 0)*/;\n state.mode = hold & 0x200 ? DICTID : TYPE;\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n break;\n case FLAGS:\n //=== NEEDBITS(16); */\n while (bits < 16) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.flags = hold;\n if ((state.flags & 0xff) !== Z_DEFLATED) {\n strm.msg = 'unknown compression method';\n state.mode = BAD;\n break;\n }\n if (state.flags & 0xe000) {\n strm.msg = 'unknown header flags set';\n state.mode = BAD;\n break;\n }\n if (state.head) {\n state.head.text = ((hold >> 8) & 1);\n }\n if (state.flags & 0x0200) {\n //=== CRC2(state.check, hold);\n hbuf[0] = hold & 0xff;\n hbuf[1] = (hold >>> 8) & 0xff;\n state.check = crc32(state.check, hbuf, 2, 0);\n //===//\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = TIME;\n /* falls through */\n case TIME:\n //=== NEEDBITS(32); */\n while (bits < 32) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if (state.head) {\n state.head.time = hold;\n }\n if (state.flags & 0x0200) {\n //=== CRC4(state.check, hold)\n hbuf[0] = hold & 0xff;\n hbuf[1] = (hold >>> 8) & 0xff;\n hbuf[2] = (hold >>> 16) & 0xff;\n hbuf[3] = (hold >>> 24) & 0xff;\n state.check = crc32(state.check, hbuf, 4, 0);\n //===\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = OS;\n /* falls through */\n case OS:\n //=== NEEDBITS(16); */\n while (bits < 16) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if (state.head) {\n state.head.xflags = (hold & 0xff);\n state.head.os = (hold >> 8);\n }\n if (state.flags & 0x0200) {\n //=== CRC2(state.check, hold);\n hbuf[0] = hold & 0xff;\n hbuf[1] = (hold >>> 8) & 0xff;\n state.check = crc32(state.check, hbuf, 2, 0);\n //===//\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = EXLEN;\n /* falls through */\n case EXLEN:\n if (state.flags & 0x0400) {\n //=== NEEDBITS(16); */\n while (bits < 16) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.length = hold;\n if (state.head) {\n state.head.extra_len = hold;\n }\n if (state.flags & 0x0200) {\n //=== CRC2(state.check, hold);\n hbuf[0] = hold & 0xff;\n hbuf[1] = (hold >>> 8) & 0xff;\n state.check = crc32(state.check, hbuf, 2, 0);\n //===//\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n }\n else if (state.head) {\n state.head.extra = null/*Z_NULL*/;\n }\n state.mode = EXTRA;\n /* falls through */\n case EXTRA:\n if (state.flags & 0x0400) {\n copy = state.length;\n if (copy > have) { copy = have; }\n if (copy) {\n if (state.head) {\n len = state.head.extra_len - state.length;\n if (!state.head.extra) {\n // Use untyped array for more conveniend processing later\n state.head.extra = new Array(state.head.extra_len);\n }\n utils.arraySet(\n state.head.extra,\n input,\n next,\n // extra field is limited to 65536 bytes\n // - no need for additional size check\n copy,\n /*len + copy > state.head.extra_max - len ? state.head.extra_max : copy,*/\n len\n );\n //zmemcpy(state.head.extra + len, next,\n // len + copy > state.head.extra_max ?\n // state.head.extra_max - len : copy);\n }\n if (state.flags & 0x0200) {\n state.check = crc32(state.check, input, copy, next);\n }\n have -= copy;\n next += copy;\n state.length -= copy;\n }\n if (state.length) { break inf_leave; }\n }\n state.length = 0;\n state.mode = NAME;\n /* falls through */\n case NAME:\n if (state.flags & 0x0800) {\n if (have === 0) { break inf_leave; }\n copy = 0;\n do {\n // TODO: 2 or 1 bytes?\n len = input[next + copy++];\n /* use constant limit because in js we should not preallocate memory */\n if (state.head && len &&\n (state.length < 65536 /*state.head.name_max*/)) {\n state.head.name += String.fromCharCode(len);\n }\n } while (len && copy < have);\n\n if (state.flags & 0x0200) {\n state.check = crc32(state.check, input, copy, next);\n }\n have -= copy;\n next += copy;\n if (len) { break inf_leave; }\n }\n else if (state.head) {\n state.head.name = null;\n }\n state.length = 0;\n state.mode = COMMENT;\n /* falls through */\n case COMMENT:\n if (state.flags & 0x1000) {\n if (have === 0) { break inf_leave; }\n copy = 0;\n do {\n len = input[next + copy++];\n /* use constant limit because in js we should not preallocate memory */\n if (state.head && len &&\n (state.length < 65536 /*state.head.comm_max*/)) {\n state.head.comment += String.fromCharCode(len);\n }\n } while (len && copy < have);\n if (state.flags & 0x0200) {\n state.check = crc32(state.check, input, copy, next);\n }\n have -= copy;\n next += copy;\n if (len) { break inf_leave; }\n }\n else if (state.head) {\n state.head.comment = null;\n }\n state.mode = HCRC;\n /* falls through */\n case HCRC:\n if (state.flags & 0x0200) {\n //=== NEEDBITS(16); */\n while (bits < 16) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if (hold !== (state.check & 0xffff)) {\n strm.msg = 'header crc mismatch';\n state.mode = BAD;\n break;\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n }\n if (state.head) {\n state.head.hcrc = ((state.flags >> 9) & 1);\n state.head.done = true;\n }\n strm.adler = state.check = 0;\n state.mode = TYPE;\n break;\n case DICTID:\n //=== NEEDBITS(32); */\n while (bits < 32) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n strm.adler = state.check = zswap32(hold);\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = DICT;\n /* falls through */\n case DICT:\n if (state.havedict === 0) {\n //--- RESTORE() ---\n strm.next_out = put;\n strm.avail_out = left;\n strm.next_in = next;\n strm.avail_in = have;\n state.hold = hold;\n state.bits = bits;\n //---\n return Z_NEED_DICT;\n }\n strm.adler = state.check = 1/*adler32(0L, Z_NULL, 0)*/;\n state.mode = TYPE;\n /* falls through */\n case TYPE:\n if (flush === Z_BLOCK || flush === Z_TREES) { break inf_leave; }\n /* falls through */\n case TYPEDO:\n if (state.last) {\n //--- BYTEBITS() ---//\n hold >>>= bits & 7;\n bits -= bits & 7;\n //---//\n state.mode = CHECK;\n break;\n }\n //=== NEEDBITS(3); */\n while (bits < 3) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.last = (hold & 0x01)/*BITS(1)*/;\n //--- DROPBITS(1) ---//\n hold >>>= 1;\n bits -= 1;\n //---//\n\n switch ((hold & 0x03)/*BITS(2)*/) {\n case 0: /* stored block */\n //Tracev((stderr, \"inflate: stored block%s\\n\",\n // state.last ? \" (last)\" : \"\"));\n state.mode = STORED;\n break;\n case 1: /* fixed block */\n fixedtables(state);\n //Tracev((stderr, \"inflate: fixed codes block%s\\n\",\n // state.last ? \" (last)\" : \"\"));\n state.mode = LEN_; /* decode codes */\n if (flush === Z_TREES) {\n //--- DROPBITS(2) ---//\n hold >>>= 2;\n bits -= 2;\n //---//\n break inf_leave;\n }\n break;\n case 2: /* dynamic block */\n //Tracev((stderr, \"inflate: dynamic codes block%s\\n\",\n // state.last ? \" (last)\" : \"\"));\n state.mode = TABLE;\n break;\n case 3:\n strm.msg = 'invalid block type';\n state.mode = BAD;\n }\n //--- DROPBITS(2) ---//\n hold >>>= 2;\n bits -= 2;\n //---//\n break;\n case STORED:\n //--- BYTEBITS() ---// /* go to byte boundary */\n hold >>>= bits & 7;\n bits -= bits & 7;\n //---//\n //=== NEEDBITS(32); */\n while (bits < 32) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if ((hold & 0xffff) !== ((hold >>> 16) ^ 0xffff)) {\n strm.msg = 'invalid stored block lengths';\n state.mode = BAD;\n break;\n }\n state.length = hold & 0xffff;\n //Tracev((stderr, \"inflate: stored length %u\\n\",\n // state.length));\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = COPY_;\n if (flush === Z_TREES) { break inf_leave; }\n /* falls through */\n case COPY_:\n state.mode = COPY;\n /* falls through */\n case COPY:\n copy = state.length;\n if (copy) {\n if (copy > have) { copy = have; }\n if (copy > left) { copy = left; }\n if (copy === 0) { break inf_leave; }\n //--- zmemcpy(put, next, copy); ---\n utils.arraySet(output, input, next, copy, put);\n //---//\n have -= copy;\n next += copy;\n left -= copy;\n put += copy;\n state.length -= copy;\n break;\n }\n //Tracev((stderr, \"inflate: stored end\\n\"));\n state.mode = TYPE;\n break;\n case TABLE:\n //=== NEEDBITS(14); */\n while (bits < 14) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.nlen = (hold & 0x1f)/*BITS(5)*/ + 257;\n //--- DROPBITS(5) ---//\n hold >>>= 5;\n bits -= 5;\n //---//\n state.ndist = (hold & 0x1f)/*BITS(5)*/ + 1;\n //--- DROPBITS(5) ---//\n hold >>>= 5;\n bits -= 5;\n //---//\n state.ncode = (hold & 0x0f)/*BITS(4)*/ + 4;\n //--- DROPBITS(4) ---//\n hold >>>= 4;\n bits -= 4;\n //---//\n//#ifndef PKZIP_BUG_WORKAROUND\n if (state.nlen > 286 || state.ndist > 30) {\n strm.msg = 'too many length or distance symbols';\n state.mode = BAD;\n break;\n }\n//#endif\n //Tracev((stderr, \"inflate: table sizes ok\\n\"));\n state.have = 0;\n state.mode = LENLENS;\n /* falls through */\n case LENLENS:\n while (state.have < state.ncode) {\n //=== NEEDBITS(3);\n while (bits < 3) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.lens[order[state.have++]] = (hold & 0x07);//BITS(3);\n //--- DROPBITS(3) ---//\n hold >>>= 3;\n bits -= 3;\n //---//\n }\n while (state.have < 19) {\n state.lens[order[state.have++]] = 0;\n }\n // We have separate tables & no pointers. 2 commented lines below not needed.\n //state.next = state.codes;\n //state.lencode = state.next;\n // Switch to use dynamic table\n state.lencode = state.lendyn;\n state.lenbits = 7;\n\n opts = { bits: state.lenbits };\n ret = inflate_table(CODES, state.lens, 0, 19, state.lencode, 0, state.work, opts);\n state.lenbits = opts.bits;\n\n if (ret) {\n strm.msg = 'invalid code lengths set';\n state.mode = BAD;\n break;\n }\n //Tracev((stderr, \"inflate: code lengths ok\\n\"));\n state.have = 0;\n state.mode = CODELENS;\n /* falls through */\n case CODELENS:\n while (state.have < state.nlen + state.ndist) {\n for (;;) {\n here = state.lencode[hold & ((1 << state.lenbits) - 1)];/*BITS(state.lenbits)*/\n here_bits = here >>> 24;\n here_op = (here >>> 16) & 0xff;\n here_val = here & 0xffff;\n\n if ((here_bits) <= bits) { break; }\n //--- PULLBYTE() ---//\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n //---//\n }\n if (here_val < 16) {\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n state.lens[state.have++] = here_val;\n }\n else {\n if (here_val === 16) {\n //=== NEEDBITS(here.bits + 2);\n n = here_bits + 2;\n while (bits < n) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n if (state.have === 0) {\n strm.msg = 'invalid bit length repeat';\n state.mode = BAD;\n break;\n }\n len = state.lens[state.have - 1];\n copy = 3 + (hold & 0x03);//BITS(2);\n //--- DROPBITS(2) ---//\n hold >>>= 2;\n bits -= 2;\n //---//\n }\n else if (here_val === 17) {\n //=== NEEDBITS(here.bits + 3);\n n = here_bits + 3;\n while (bits < n) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n len = 0;\n copy = 3 + (hold & 0x07);//BITS(3);\n //--- DROPBITS(3) ---//\n hold >>>= 3;\n bits -= 3;\n //---//\n }\n else {\n //=== NEEDBITS(here.bits + 7);\n n = here_bits + 7;\n while (bits < n) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n len = 0;\n copy = 11 + (hold & 0x7f);//BITS(7);\n //--- DROPBITS(7) ---//\n hold >>>= 7;\n bits -= 7;\n //---//\n }\n if (state.have + copy > state.nlen + state.ndist) {\n strm.msg = 'invalid bit length repeat';\n state.mode = BAD;\n break;\n }\n while (copy--) {\n state.lens[state.have++] = len;\n }\n }\n }\n\n /* handle error breaks in while */\n if (state.mode === BAD) { break; }\n\n /* check for end-of-block code (better have one) */\n if (state.lens[256] === 0) {\n strm.msg = 'invalid code -- missing end-of-block';\n state.mode = BAD;\n break;\n }\n\n /* build code tables -- note: do not change the lenbits or distbits\n values here (9 and 6) without reading the comments in inftrees.h\n concerning the ENOUGH constants, which depend on those values */\n state.lenbits = 9;\n\n opts = { bits: state.lenbits };\n ret = inflate_table(LENS, state.lens, 0, state.nlen, state.lencode, 0, state.work, opts);\n // We have separate tables & no pointers. 2 commented lines below not needed.\n // state.next_index = opts.table_index;\n state.lenbits = opts.bits;\n // state.lencode = state.next;\n\n if (ret) {\n strm.msg = 'invalid literal/lengths set';\n state.mode = BAD;\n break;\n }\n\n state.distbits = 6;\n //state.distcode.copy(state.codes);\n // Switch to use dynamic table\n state.distcode = state.distdyn;\n opts = { bits: state.distbits };\n ret = inflate_table(DISTS, state.lens, state.nlen, state.ndist, state.distcode, 0, state.work, opts);\n // We have separate tables & no pointers. 2 commented lines below not needed.\n // state.next_index = opts.table_index;\n state.distbits = opts.bits;\n // state.distcode = state.next;\n\n if (ret) {\n strm.msg = 'invalid distances set';\n state.mode = BAD;\n break;\n }\n //Tracev((stderr, 'inflate: codes ok\\n'));\n state.mode = LEN_;\n if (flush === Z_TREES) { break inf_leave; }\n /* falls through */\n case LEN_:\n state.mode = LEN;\n /* falls through */\n case LEN:\n if (have >= 6 && left >= 258) {\n //--- RESTORE() ---\n strm.next_out = put;\n strm.avail_out = left;\n strm.next_in = next;\n strm.avail_in = have;\n state.hold = hold;\n state.bits = bits;\n //---\n inflate_fast(strm, _out);\n //--- LOAD() ---\n put = strm.next_out;\n output = strm.output;\n left = strm.avail_out;\n next = strm.next_in;\n input = strm.input;\n have = strm.avail_in;\n hold = state.hold;\n bits = state.bits;\n //---\n\n if (state.mode === TYPE) {\n state.back = -1;\n }\n break;\n }\n state.back = 0;\n for (;;) {\n here = state.lencode[hold & ((1 << state.lenbits) - 1)]; /*BITS(state.lenbits)*/\n here_bits = here >>> 24;\n here_op = (here >>> 16) & 0xff;\n here_val = here & 0xffff;\n\n if (here_bits <= bits) { break; }\n //--- PULLBYTE() ---//\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n //---//\n }\n if (here_op && (here_op & 0xf0) === 0) {\n last_bits = here_bits;\n last_op = here_op;\n last_val = here_val;\n for (;;) {\n here = state.lencode[last_val +\n ((hold & ((1 << (last_bits + last_op)) - 1))/*BITS(last.bits + last.op)*/ >> last_bits)];\n here_bits = here >>> 24;\n here_op = (here >>> 16) & 0xff;\n here_val = here & 0xffff;\n\n if ((last_bits + here_bits) <= bits) { break; }\n //--- PULLBYTE() ---//\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n //---//\n }\n //--- DROPBITS(last.bits) ---//\n hold >>>= last_bits;\n bits -= last_bits;\n //---//\n state.back += last_bits;\n }\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n state.back += here_bits;\n state.length = here_val;\n if (here_op === 0) {\n //Tracevv((stderr, here.val >= 0x20 && here.val < 0x7f ?\n // \"inflate: literal '%c'\\n\" :\n // \"inflate: literal 0x%02x\\n\", here.val));\n state.mode = LIT;\n break;\n }\n if (here_op & 32) {\n //Tracevv((stderr, \"inflate: end of block\\n\"));\n state.back = -1;\n state.mode = TYPE;\n break;\n }\n if (here_op & 64) {\n strm.msg = 'invalid literal/length code';\n state.mode = BAD;\n break;\n }\n state.extra = here_op & 15;\n state.mode = LENEXT;\n /* falls through */\n case LENEXT:\n if (state.extra) {\n //=== NEEDBITS(state.extra);\n n = state.extra;\n while (bits < n) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.length += hold & ((1 << state.extra) - 1)/*BITS(state.extra)*/;\n //--- DROPBITS(state.extra) ---//\n hold >>>= state.extra;\n bits -= state.extra;\n //---//\n state.back += state.extra;\n }\n //Tracevv((stderr, \"inflate: length %u\\n\", state.length));\n state.was = state.length;\n state.mode = DIST;\n /* falls through */\n case DIST:\n for (;;) {\n here = state.distcode[hold & ((1 << state.distbits) - 1)];/*BITS(state.distbits)*/\n here_bits = here >>> 24;\n here_op = (here >>> 16) & 0xff;\n here_val = here & 0xffff;\n\n if ((here_bits) <= bits) { break; }\n //--- PULLBYTE() ---//\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n //---//\n }\n if ((here_op & 0xf0) === 0) {\n last_bits = here_bits;\n last_op = here_op;\n last_val = here_val;\n for (;;) {\n here = state.distcode[last_val +\n ((hold & ((1 << (last_bits + last_op)) - 1))/*BITS(last.bits + last.op)*/ >> last_bits)];\n here_bits = here >>> 24;\n here_op = (here >>> 16) & 0xff;\n here_val = here & 0xffff;\n\n if ((last_bits + here_bits) <= bits) { break; }\n //--- PULLBYTE() ---//\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n //---//\n }\n //--- DROPBITS(last.bits) ---//\n hold >>>= last_bits;\n bits -= last_bits;\n //---//\n state.back += last_bits;\n }\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n state.back += here_bits;\n if (here_op & 64) {\n strm.msg = 'invalid distance code';\n state.mode = BAD;\n break;\n }\n state.offset = here_val;\n state.extra = (here_op) & 15;\n state.mode = DISTEXT;\n /* falls through */\n case DISTEXT:\n if (state.extra) {\n //=== NEEDBITS(state.extra);\n n = state.extra;\n while (bits < n) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.offset += hold & ((1 << state.extra) - 1)/*BITS(state.extra)*/;\n //--- DROPBITS(state.extra) ---//\n hold >>>= state.extra;\n bits -= state.extra;\n //---//\n state.back += state.extra;\n }\n//#ifdef INFLATE_STRICT\n if (state.offset > state.dmax) {\n strm.msg = 'invalid distance too far back';\n state.mode = BAD;\n break;\n }\n//#endif\n //Tracevv((stderr, \"inflate: distance %u\\n\", state.offset));\n state.mode = MATCH;\n /* falls through */\n case MATCH:\n if (left === 0) { break inf_leave; }\n copy = _out - left;\n if (state.offset > copy) { /* copy from window */\n copy = state.offset - copy;\n if (copy > state.whave) {\n if (state.sane) {\n strm.msg = 'invalid distance too far back';\n state.mode = BAD;\n break;\n }\n// (!) This block is disabled in zlib defailts,\n// don't enable it for binary compatibility\n//#ifdef INFLATE_ALLOW_INVALID_DISTANCE_TOOFAR_ARRR\n// Trace((stderr, \"inflate.c too far\\n\"));\n// copy -= state.whave;\n// if (copy > state.length) { copy = state.length; }\n// if (copy > left) { copy = left; }\n// left -= copy;\n// state.length -= copy;\n// do {\n// output[put++] = 0;\n// } while (--copy);\n// if (state.length === 0) { state.mode = LEN; }\n// break;\n//#endif\n }\n if (copy > state.wnext) {\n copy -= state.wnext;\n from = state.wsize - copy;\n }\n else {\n from = state.wnext - copy;\n }\n if (copy > state.length) { copy = state.length; }\n from_source = state.window;\n }\n else { /* copy from output */\n from_source = output;\n from = put - state.offset;\n copy = state.length;\n }\n if (copy > left) { copy = left; }\n left -= copy;\n state.length -= copy;\n do {\n output[put++] = from_source[from++];\n } while (--copy);\n if (state.length === 0) { state.mode = LEN; }\n break;\n case LIT:\n if (left === 0) { break inf_leave; }\n output[put++] = state.length;\n left--;\n state.mode = LEN;\n break;\n case CHECK:\n if (state.wrap) {\n //=== NEEDBITS(32);\n while (bits < 32) {\n if (have === 0) { break inf_leave; }\n have--;\n // Use '|' insdead of '+' to make sure that result is signed\n hold |= input[next++] << bits;\n bits += 8;\n }\n //===//\n _out -= left;\n strm.total_out += _out;\n state.total += _out;\n if (_out) {\n strm.adler = state.check =\n /*UPDATE(state.check, put - _out, _out);*/\n (state.flags ? crc32(state.check, output, _out, put - _out) : adler32(state.check, output, _out, put - _out));\n\n }\n _out = left;\n // NB: crc32 stored as signed 32-bit int, zswap32 returns signed too\n if ((state.flags ? hold : zswap32(hold)) !== state.check) {\n strm.msg = 'incorrect data check';\n state.mode = BAD;\n break;\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n //Tracev((stderr, \"inflate: check matches trailer\\n\"));\n }\n state.mode = LENGTH;\n /* falls through */\n case LENGTH:\n if (state.wrap && state.flags) {\n //=== NEEDBITS(32);\n while (bits < 32) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if (hold !== (state.total & 0xffffffff)) {\n strm.msg = 'incorrect length check';\n state.mode = BAD;\n break;\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n //Tracev((stderr, \"inflate: length matches trailer\\n\"));\n }\n state.mode = DONE;\n /* falls through */\n case DONE:\n ret = Z_STREAM_END;\n break inf_leave;\n case BAD:\n ret = Z_DATA_ERROR;\n break inf_leave;\n case MEM:\n return Z_MEM_ERROR;\n case SYNC:\n /* falls through */\n default:\n return Z_STREAM_ERROR;\n }\n }\n\n // inf_leave <- here is real place for \"goto inf_leave\", emulated via \"break inf_leave\"\n\n /*\n Return from inflate(), updating the total counts and the check value.\n If there was no progress during the inflate() call, return a buffer\n error. Call updatewindow() to create and/or update the window state.\n Note: a memory error from inflate() is non-recoverable.\n */\n\n //--- RESTORE() ---\n strm.next_out = put;\n strm.avail_out = left;\n strm.next_in = next;\n strm.avail_in = have;\n state.hold = hold;\n state.bits = bits;\n //---\n\n if (state.wsize || (_out !== strm.avail_out && state.mode < BAD &&\n (state.mode < CHECK || flush !== Z_FINISH))) {\n if (updatewindow(strm, strm.output, strm.next_out, _out - strm.avail_out)) {\n state.mode = MEM;\n return Z_MEM_ERROR;\n }\n }\n _in -= strm.avail_in;\n _out -= strm.avail_out;\n strm.total_in += _in;\n strm.total_out += _out;\n state.total += _out;\n if (state.wrap && _out) {\n strm.adler = state.check = /*UPDATE(state.check, strm.next_out - _out, _out);*/\n (state.flags ? crc32(state.check, output, _out, strm.next_out - _out) : adler32(state.check, output, _out, strm.next_out - _out));\n }\n strm.data_type = state.bits + (state.last ? 64 : 0) +\n (state.mode === TYPE ? 128 : 0) +\n (state.mode === LEN_ || state.mode === COPY_ ? 256 : 0);\n if (((_in === 0 && _out === 0) || flush === Z_FINISH) && ret === Z_OK) {\n ret = Z_BUF_ERROR;\n }\n return ret;\n}\n\nfunction inflateEnd(strm) {\n\n if (!strm || !strm.state /*|| strm->zfree == (free_func)0*/) {\n return Z_STREAM_ERROR;\n }\n\n var state = strm.state;\n if (state.window) {\n state.window = null;\n }\n strm.state = null;\n return Z_OK;\n}\n\nfunction inflateGetHeader(strm, head) {\n var state;\n\n /* check state */\n if (!strm || !strm.state) { return Z_STREAM_ERROR; }\n state = strm.state;\n if ((state.wrap & 2) === 0) { return Z_STREAM_ERROR; }\n\n /* save header structure */\n state.head = head;\n head.done = false;\n return Z_OK;\n}\n\nfunction inflateSetDictionary(strm, dictionary) {\n var dictLength = dictionary.length;\n\n var state;\n var dictid;\n var ret;\n\n /* check state */\n if (!strm /* == Z_NULL */ || !strm.state /* == Z_NULL */) { return Z_STREAM_ERROR; }\n state = strm.state;\n\n if (state.wrap !== 0 && state.mode !== DICT) {\n return Z_STREAM_ERROR;\n }\n\n /* check for correct dictionary identifier */\n if (state.mode === DICT) {\n dictid = 1; /* adler32(0, null, 0)*/\n /* dictid = adler32(dictid, dictionary, dictLength); */\n dictid = adler32(dictid, dictionary, dictLength, 0);\n if (dictid !== state.check) {\n return Z_DATA_ERROR;\n }\n }\n /* copy dictionary to window using updatewindow(), which will amend the\n existing dictionary if appropriate */\n ret = updatewindow(strm, dictionary, dictLength, dictLength);\n if (ret) {\n state.mode = MEM;\n return Z_MEM_ERROR;\n }\n state.havedict = 1;\n // Tracev((stderr, \"inflate: dictionary set\\n\"));\n return Z_OK;\n}\n\nexports.inflateReset = inflateReset;\nexports.inflateReset2 = inflateReset2;\nexports.inflateResetKeep = inflateResetKeep;\nexports.inflateInit = inflateInit;\nexports.inflateInit2 = inflateInit2;\nexports.inflate = inflate;\nexports.inflateEnd = inflateEnd;\nexports.inflateGetHeader = inflateGetHeader;\nexports.inflateSetDictionary = inflateSetDictionary;\nexports.inflateInfo = 'pako inflate (from Nodeca project)';\n\n/* Not implemented\nexports.inflateCopy = inflateCopy;\nexports.inflateGetDictionary = inflateGetDictionary;\nexports.inflateMark = inflateMark;\nexports.inflatePrime = inflatePrime;\nexports.inflateSync = inflateSync;\nexports.inflateSyncPoint = inflateSyncPoint;\nexports.inflateUndermine = inflateUndermine;\n*/\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/pako/lib/zlib/inflate.js\n// module id = 30\n// module chunks = 0","'use strict';\n\n\nvar utils = require('../utils/common');\n\nvar MAXBITS = 15;\nvar ENOUGH_LENS = 852;\nvar ENOUGH_DISTS = 592;\n//var ENOUGH = (ENOUGH_LENS+ENOUGH_DISTS);\n\nvar CODES = 0;\nvar LENS = 1;\nvar DISTS = 2;\n\nvar lbase = [ /* Length codes 257..285 base */\n 3, 4, 5, 6, 7, 8, 9, 10, 11, 13, 15, 17, 19, 23, 27, 31,\n 35, 43, 51, 59, 67, 83, 99, 115, 131, 163, 195, 227, 258, 0, 0\n];\n\nvar lext = [ /* Length codes 257..285 extra */\n 16, 16, 16, 16, 16, 16, 16, 16, 17, 17, 17, 17, 18, 18, 18, 18,\n 19, 19, 19, 19, 20, 20, 20, 20, 21, 21, 21, 21, 16, 72, 78\n];\n\nvar dbase = [ /* Distance codes 0..29 base */\n 1, 2, 3, 4, 5, 7, 9, 13, 17, 25, 33, 49, 65, 97, 129, 193,\n 257, 385, 513, 769, 1025, 1537, 2049, 3073, 4097, 6145,\n 8193, 12289, 16385, 24577, 0, 0\n];\n\nvar dext = [ /* Distance codes 0..29 extra */\n 16, 16, 16, 16, 17, 17, 18, 18, 19, 19, 20, 20, 21, 21, 22, 22,\n 23, 23, 24, 24, 25, 25, 26, 26, 27, 27,\n 28, 28, 29, 29, 64, 64\n];\n\nmodule.exports = function inflate_table(type, lens, lens_index, codes, table, table_index, work, opts)\n{\n var bits = opts.bits;\n //here = opts.here; /* table entry for duplication */\n\n var len = 0; /* a code's length in bits */\n var sym = 0; /* index of code symbols */\n var min = 0, max = 0; /* minimum and maximum code lengths */\n var root = 0; /* number of index bits for root table */\n var curr = 0; /* number of index bits for current table */\n var drop = 0; /* code bits to drop for sub-table */\n var left = 0; /* number of prefix codes available */\n var used = 0; /* code entries in table used */\n var huff = 0; /* Huffman code */\n var incr; /* for incrementing code, index */\n var fill; /* index for replicating entries */\n var low; /* low bits for current root entry */\n var mask; /* mask for low root bits */\n var next; /* next available space in table */\n var base = null; /* base value table to use */\n var base_index = 0;\n// var shoextra; /* extra bits table to use */\n var end; /* use base and extra for symbol > end */\n var count = new utils.Buf16(MAXBITS + 1); //[MAXBITS+1]; /* number of codes of each length */\n var offs = new utils.Buf16(MAXBITS + 1); //[MAXBITS+1]; /* offsets in table for each length */\n var extra = null;\n var extra_index = 0;\n\n var here_bits, here_op, here_val;\n\n /*\n Process a set of code lengths to create a canonical Huffman code. The\n code lengths are lens[0..codes-1]. Each length corresponds to the\n symbols 0..codes-1. The Huffman code is generated by first sorting the\n symbols by length from short to long, and retaining the symbol order\n for codes with equal lengths. Then the code starts with all zero bits\n for the first code of the shortest length, and the codes are integer\n increments for the same length, and zeros are appended as the length\n increases. For the deflate format, these bits are stored backwards\n from their more natural integer increment ordering, and so when the\n decoding tables are built in the large loop below, the integer codes\n are incremented backwards.\n\n This routine assumes, but does not check, that all of the entries in\n lens[] are in the range 0..MAXBITS. The caller must assure this.\n 1..MAXBITS is interpreted as that code length. zero means that that\n symbol does not occur in this code.\n\n The codes are sorted by computing a count of codes for each length,\n creating from that a table of starting indices for each length in the\n sorted table, and then entering the symbols in order in the sorted\n table. The sorted table is work[], with that space being provided by\n the caller.\n\n The length counts are used for other purposes as well, i.e. finding\n the minimum and maximum length codes, determining if there are any\n codes at all, checking for a valid set of lengths, and looking ahead\n at length counts to determine sub-table sizes when building the\n decoding tables.\n */\n\n /* accumulate lengths for codes (assumes lens[] all in 0..MAXBITS) */\n for (len = 0; len <= MAXBITS; len++) {\n count[len] = 0;\n }\n for (sym = 0; sym < codes; sym++) {\n count[lens[lens_index + sym]]++;\n }\n\n /* bound code lengths, force root to be within code lengths */\n root = bits;\n for (max = MAXBITS; max >= 1; max--) {\n if (count[max] !== 0) { break; }\n }\n if (root > max) {\n root = max;\n }\n if (max === 0) { /* no symbols to code at all */\n //table.op[opts.table_index] = 64; //here.op = (var char)64; /* invalid code marker */\n //table.bits[opts.table_index] = 1; //here.bits = (var char)1;\n //table.val[opts.table_index++] = 0; //here.val = (var short)0;\n table[table_index++] = (1 << 24) | (64 << 16) | 0;\n\n\n //table.op[opts.table_index] = 64;\n //table.bits[opts.table_index] = 1;\n //table.val[opts.table_index++] = 0;\n table[table_index++] = (1 << 24) | (64 << 16) | 0;\n\n opts.bits = 1;\n return 0; /* no symbols, but wait for decoding to report error */\n }\n for (min = 1; min < max; min++) {\n if (count[min] !== 0) { break; }\n }\n if (root < min) {\n root = min;\n }\n\n /* check for an over-subscribed or incomplete set of lengths */\n left = 1;\n for (len = 1; len <= MAXBITS; len++) {\n left <<= 1;\n left -= count[len];\n if (left < 0) {\n return -1;\n } /* over-subscribed */\n }\n if (left > 0 && (type === CODES || max !== 1)) {\n return -1; /* incomplete set */\n }\n\n /* generate offsets into symbol table for each length for sorting */\n offs[1] = 0;\n for (len = 1; len < MAXBITS; len++) {\n offs[len + 1] = offs[len] + count[len];\n }\n\n /* sort symbols by length, by symbol order within each length */\n for (sym = 0; sym < codes; sym++) {\n if (lens[lens_index + sym] !== 0) {\n work[offs[lens[lens_index + sym]]++] = sym;\n }\n }\n\n /*\n Create and fill in decoding tables. In this loop, the table being\n filled is at next and has curr index bits. The code being used is huff\n with length len. That code is converted to an index by dropping drop\n bits off of the bottom. For codes where len is less than drop + curr,\n those top drop + curr - len bits are incremented through all values to\n fill the table with replicated entries.\n\n root is the number of index bits for the root table. When len exceeds\n root, sub-tables are created pointed to by the root entry with an index\n of the low root bits of huff. This is saved in low to check for when a\n new sub-table should be started. drop is zero when the root table is\n being filled, and drop is root when sub-tables are being filled.\n\n When a new sub-table is needed, it is necessary to look ahead in the\n code lengths to determine what size sub-table is needed. The length\n counts are used for this, and so count[] is decremented as codes are\n entered in the tables.\n\n used keeps track of how many table entries have been allocated from the\n provided *table space. It is checked for LENS and DIST tables against\n the constants ENOUGH_LENS and ENOUGH_DISTS to guard against changes in\n the initial root table size constants. See the comments in inftrees.h\n for more information.\n\n sym increments through all symbols, and the loop terminates when\n all codes of length max, i.e. all codes, have been processed. This\n routine permits incomplete codes, so another loop after this one fills\n in the rest of the decoding tables with invalid code markers.\n */\n\n /* set up for code type */\n // poor man optimization - use if-else instead of switch,\n // to avoid deopts in old v8\n if (type === CODES) {\n base = extra = work; /* dummy value--not used */\n end = 19;\n\n } else if (type === LENS) {\n base = lbase;\n base_index -= 257;\n extra = lext;\n extra_index -= 257;\n end = 256;\n\n } else { /* DISTS */\n base = dbase;\n extra = dext;\n end = -1;\n }\n\n /* initialize opts for loop */\n huff = 0; /* starting code */\n sym = 0; /* starting code symbol */\n len = min; /* starting code length */\n next = table_index; /* current table to fill in */\n curr = root; /* current table index bits */\n drop = 0; /* current bits to drop from code for index */\n low = -1; /* trigger new sub-table when len > root */\n used = 1 << root; /* use root table entries */\n mask = used - 1; /* mask for comparing low */\n\n /* check available table space */\n if ((type === LENS && used > ENOUGH_LENS) ||\n (type === DISTS && used > ENOUGH_DISTS)) {\n return 1;\n }\n\n /* process all codes and make table entries */\n for (;;) {\n /* create table entry */\n here_bits = len - drop;\n if (work[sym] < end) {\n here_op = 0;\n here_val = work[sym];\n }\n else if (work[sym] > end) {\n here_op = extra[extra_index + work[sym]];\n here_val = base[base_index + work[sym]];\n }\n else {\n here_op = 32 + 64; /* end of block */\n here_val = 0;\n }\n\n /* replicate for those indices with low len bits equal to huff */\n incr = 1 << (len - drop);\n fill = 1 << curr;\n min = fill; /* save offset to next table */\n do {\n fill -= incr;\n table[next + (huff >> drop) + fill] = (here_bits << 24) | (here_op << 16) | here_val |0;\n } while (fill !== 0);\n\n /* backwards increment the len-bit code huff */\n incr = 1 << (len - 1);\n while (huff & incr) {\n incr >>= 1;\n }\n if (incr !== 0) {\n huff &= incr - 1;\n huff += incr;\n } else {\n huff = 0;\n }\n\n /* go to next symbol, update count, len */\n sym++;\n if (--count[len] === 0) {\n if (len === max) { break; }\n len = lens[lens_index + work[sym]];\n }\n\n /* create new sub-table if needed */\n if (len > root && (huff & mask) !== low) {\n /* if first time, transition to sub-tables */\n if (drop === 0) {\n drop = root;\n }\n\n /* increment past last table */\n next += min; /* here min is 1 << curr */\n\n /* determine length of next table */\n curr = len - drop;\n left = 1 << curr;\n while (curr + drop < max) {\n left -= count[curr + drop];\n if (left <= 0) { break; }\n curr++;\n left <<= 1;\n }\n\n /* check for enough space */\n used += 1 << curr;\n if ((type === LENS && used > ENOUGH_LENS) ||\n (type === DISTS && used > ENOUGH_DISTS)) {\n return 1;\n }\n\n /* point entry in root table to sub-table */\n low = huff & mask;\n /*table.op[low] = curr;\n table.bits[low] = root;\n table.val[low] = next - opts.table_index;*/\n table[low] = (root << 24) | (curr << 16) | (next - table_index) |0;\n }\n }\n\n /* fill in remaining table entry if code is incomplete (guaranteed to have\n at most one remaining entry, since if the code is incomplete, the\n maximum code length that was allowed to get this far is one bit) */\n if (huff !== 0) {\n //table.op[next + huff] = 64; /* invalid code marker */\n //table.bits[next + huff] = len - drop;\n //table.val[next + huff] = 0;\n table[next + huff] = ((len - drop) << 24) | (64 << 16) |0;\n }\n\n /* set return parameters */\n //opts.table_index += used;\n opts.bits = root;\n return 0;\n};\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/pako/lib/zlib/inftrees.js\n// module id = 31\n// module chunks = 0","'use strict';\n\nmodule.exports = {\n 2: 'need dictionary', /* Z_NEED_DICT 2 */\n 1: 'stream end', /* Z_STREAM_END 1 */\n 0: '', /* Z_OK 0 */\n '-1': 'file error', /* Z_ERRNO (-1) */\n '-2': 'stream error', /* Z_STREAM_ERROR (-2) */\n '-3': 'data error', /* Z_DATA_ERROR (-3) */\n '-4': 'insufficient memory', /* Z_MEM_ERROR (-4) */\n '-5': 'buffer error', /* Z_BUF_ERROR (-5) */\n '-6': 'incompatible version' /* Z_VERSION_ERROR (-6) */\n};\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/pako/lib/zlib/messages.js\n// module id = 32\n// module chunks = 0","'use strict';\n\n\nfunction ZStream() {\n /* next input byte */\n this.input = null; // JS specific, because we have no pointers\n this.next_in = 0;\n /* number of bytes available at input */\n this.avail_in = 0;\n /* total number of input bytes read so far */\n this.total_in = 0;\n /* next output byte should be put there */\n this.output = null; // JS specific, because we have no pointers\n this.next_out = 0;\n /* remaining free space at output */\n this.avail_out = 0;\n /* total number of bytes output so far */\n this.total_out = 0;\n /* last error message, NULL if no error */\n this.msg = ''/*Z_NULL*/;\n /* not visible by applications */\n this.state = null;\n /* best guess about the data type: binary or text */\n this.data_type = 2/*Z_UNKNOWN*/;\n /* adler32 value of the uncompressed data */\n this.adler = 0;\n}\n\nmodule.exports = ZStream;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/pako/lib/zlib/zstream.js\n// module id = 33\n// module chunks = 0","module.exports = require(\"./lib/_stream_duplex.js\")\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/readable-stream/duplex.js\n// module id = 34\n// module chunks = 0","'use strict';\n\nvar Buffer = require('buffer').Buffer;\n/**/\nvar bufferShim = require('buffer-shims');\n/**/\n\nmodule.exports = BufferList;\n\nfunction BufferList() {\n this.head = null;\n this.tail = null;\n this.length = 0;\n}\n\nBufferList.prototype.push = function (v) {\n var entry = { data: v, next: null };\n if (this.length > 0) this.tail.next = entry;else this.head = entry;\n this.tail = entry;\n ++this.length;\n};\n\nBufferList.prototype.unshift = function (v) {\n var entry = { data: v, next: this.head };\n if (this.length === 0) this.tail = entry;\n this.head = entry;\n ++this.length;\n};\n\nBufferList.prototype.shift = function () {\n if (this.length === 0) return;\n var ret = this.head.data;\n if (this.length === 1) this.head = this.tail = null;else this.head = this.head.next;\n --this.length;\n return ret;\n};\n\nBufferList.prototype.clear = function () {\n this.head = this.tail = null;\n this.length = 0;\n};\n\nBufferList.prototype.join = function (s) {\n if (this.length === 0) return '';\n var p = this.head;\n var ret = '' + p.data;\n while (p = p.next) {\n ret += s + p.data;\n }return ret;\n};\n\nBufferList.prototype.concat = function (n) {\n if (this.length === 0) return bufferShim.alloc(0);\n if (this.length === 1) return this.head.data;\n var ret = bufferShim.allocUnsafe(n >>> 0);\n var p = this.head;\n var i = 0;\n while (p) {\n p.data.copy(ret, i);\n i += p.data.length;\n p = p.next;\n }\n return ret;\n};\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/readable-stream/lib/internal/streams/BufferList.js\n// module id = 35\n// module chunks = 0","module.exports = require(\"./lib/_stream_passthrough.js\")\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/readable-stream/passthrough.js\n// module id = 36\n// module chunks = 0","var Stream = (function (){\n try {\n return require('st' + 'ream'); // hack to fix a circular dependency issue when used with browserify\n } catch(_){}\n}());\nexports = module.exports = require('./lib/_stream_readable.js');\nexports.Stream = Stream || exports;\nexports.Readable = exports;\nexports.Writable = require('./lib/_stream_writable.js');\nexports.Duplex = require('./lib/_stream_duplex.js');\nexports.Transform = require('./lib/_stream_transform.js');\nexports.PassThrough = require('./lib/_stream_passthrough.js');\n\nif (!process.browser && process.env.READABLE_STREAM === 'disable' && Stream) {\n module.exports = Stream;\n}\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/readable-stream/readable.js\n// module id = 37\n// module chunks = 0","module.exports = require(\"./lib/_stream_transform.js\")\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/readable-stream/transform.js\n// module id = 38\n// module chunks = 0","module.exports = require(\"./lib/_stream_writable.js\")\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/readable-stream/writable.js\n// module id = 39\n// module chunks = 0","\n/**\n * Module exports.\n */\n\nmodule.exports = deprecate;\n\n/**\n * Mark that a method should not be used.\n * Returns a modified function which warns once by default.\n *\n * If `localStorage.noDeprecation = true` is set, then it is a no-op.\n *\n * If `localStorage.throwDeprecation = true` is set, then deprecated functions\n * will throw an Error when invoked.\n *\n * If `localStorage.traceDeprecation = true` is set, then deprecated functions\n * will invoke `console.trace()` instead of `console.error()`.\n *\n * @param {Function} fn - the function to deprecate\n * @param {String} msg - the string to print to the console when `fn` is invoked\n * @returns {Function} a new \"deprecated\" version of `fn`\n * @api public\n */\n\nfunction deprecate (fn, msg) {\n if (config('noDeprecation')) {\n return fn;\n }\n\n var warned = false;\n function deprecated() {\n if (!warned) {\n if (config('throwDeprecation')) {\n throw new Error(msg);\n } else if (config('traceDeprecation')) {\n console.trace(msg);\n } else {\n console.warn(msg);\n }\n warned = true;\n }\n return fn.apply(this, arguments);\n }\n\n return deprecated;\n}\n\n/**\n * Checks `localStorage` for boolean values for the given `name`.\n *\n * @param {String} name\n * @returns {Boolean}\n * @api private\n */\n\nfunction config (name) {\n // accessing global.localStorage can trigger a DOMException in sandboxed iframes\n try {\n if (!global.localStorage) return false;\n } catch (_) {\n return false;\n }\n var val = global.localStorage[name];\n if (null == val) return false;\n return String(val).toLowerCase() === 'true';\n}\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/util-deprecate/browser.js\n// module id = 40\n// module chunks = 0","module.exports = function(module) {\r\n\tif(!module.webpackPolyfill) {\r\n\t\tmodule.deprecate = function() {};\r\n\t\tmodule.paths = [];\r\n\t\t// module.parent = undefined by default\r\n\t\tmodule.children = [];\r\n\t\tmodule.webpackPolyfill = 1;\r\n\t}\r\n\treturn module;\r\n}\r\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// (webpack)/buildin/module.js\n// module id = 41\n// module chunks = 0"],"sourceRoot":""} \ No newline at end of file +{"version":3,"sources":["webpack://BrowserFS/webpack/universalModuleDefinition","webpack://BrowserFS/webpack/bootstrap","webpack://BrowserFS/./node_modules/readable-stream/lib/_stream_duplex.js","webpack://BrowserFS/./node_modules/inherits/inherits_browser.js","webpack://BrowserFS/../ts/index.ts","webpack://BrowserFS/./node_modules/core-util-is/lib/util.js","webpack://BrowserFS/(webpack)/buildin/global.js","webpack://BrowserFS/./node_modules/events/events.js","webpack://BrowserFS/./node_modules/process-nextick-args/index.js","webpack://BrowserFS/./node_modules/safe-buffer/index.js","webpack://BrowserFS/./node_modules/pako/lib/utils/common.js","webpack://BrowserFS/./build/temp/library/webpack/BFSBuffer.js","webpack://BrowserFS/./node_modules/buffer/index.js","webpack://BrowserFS/./node_modules/readable-stream/readable-browser.js","webpack://BrowserFS/./node_modules/readable-stream/lib/_stream_writable.js","webpack://BrowserFS/../ts/path.ts","webpack://BrowserFS/./node_modules/readable-stream/lib/_stream_readable.js","webpack://BrowserFS/./node_modules/readable-stream/lib/internal/streams/stream-browser.js","webpack://BrowserFS/./node_modules/readable-stream/lib/internal/streams/destroy.js","webpack://BrowserFS/./node_modules/string_decoder/lib/string_decoder.js","webpack://BrowserFS/./node_modules/readable-stream/lib/_stream_transform.js","webpack://BrowserFS/./build/temp/library/rollup/browserfs.rollup.js","webpack://BrowserFS/./node_modules/base64-js/index.js","webpack://BrowserFS/./node_modules/ieee754/index.js","webpack://BrowserFS/../ts/process.ts","webpack://BrowserFS/../ts/tty.ts","webpack://BrowserFS/./node_modules/stream-browserify/index.js","webpack://BrowserFS/./node_modules/isarray/index.js","webpack://BrowserFS/./node_modules/readable-stream/lib/internal/streams/BufferList.js","webpack://BrowserFS/./node_modules/util-deprecate/browser.js","webpack://BrowserFS/./node_modules/readable-stream/lib/_stream_passthrough.js","webpack://BrowserFS/./node_modules/readable-stream/writable-browser.js","webpack://BrowserFS/./node_modules/readable-stream/duplex-browser.js","webpack://BrowserFS/./node_modules/readable-stream/transform.js","webpack://BrowserFS/./node_modules/readable-stream/passthrough.js","webpack://BrowserFS/(webpack)/buildin/module.js","webpack://BrowserFS/./node_modules/pako/lib/inflate.js","webpack://BrowserFS/./node_modules/pako/lib/zlib/inflate.js","webpack://BrowserFS/./node_modules/pako/lib/zlib/adler32.js","webpack://BrowserFS/./node_modules/pako/lib/zlib/crc32.js","webpack://BrowserFS/./node_modules/pako/lib/zlib/inffast.js","webpack://BrowserFS/./node_modules/pako/lib/zlib/inftrees.js","webpack://BrowserFS/./node_modules/pako/lib/utils/strings.js","webpack://BrowserFS/./node_modules/pako/lib/zlib/constants.js","webpack://BrowserFS/./node_modules/pako/lib/zlib/messages.js","webpack://BrowserFS/./node_modules/pako/lib/zlib/zstream.js","webpack://BrowserFS/./node_modules/pako/lib/zlib/gzheader.js"],"names":["root","factory","exports","module","define","amd","this","installedModules","__webpack_require__","moduleId","i","l","modules","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","pna","objectKeys","keys","obj","push","Duplex","util","inherits","Readable","Writable","v","length","method","options","readable","writable","allowHalfOpen","once","onend","_writableState","ended","nextTick","onEndNT","self","end","highWaterMark","undefined","_readableState","destroyed","set","_destroy","err","cb","ctor","superCtor","super_","constructor","configurable","TempCtor","process","processProxy","defineKey","apply","arguments","initializeTTYs","stdin","stdout","stderr","Buffer","objectToString","toString","isArray","arg","Array","isBoolean","isNull","isNullOrUndefined","isNumber","isString","isSymbol","isUndefined","isRegExp","re","isObject","isDate","isError","e","Error","isFunction","isPrimitive","isBuffer","g","Function","eval","window","ReflectOwnKeys","R","Reflect","ReflectApply","target","receiver","args","ownKeys","getOwnPropertySymbols","getOwnPropertyNames","concat","NumberIsNaN","Number","isNaN","EventEmitter","init","_events","_eventsCount","_maxListeners","defaultMaxListeners","checkListener","listener","TypeError","_getMaxListeners","that","_addListener","type","prepend","events","existing","newListener","emit","unshift","warned","w","String","emitter","count","warning","console","warn","ProcessEmitWarning","_onceWrap","state","fired","wrapFn","wrapped","removeListener","_listeners","unwrap","evlistener","arr","ret","unwrapListeners","arrayClone","listenerCount","copy","RangeError","getPrototypeOf","setMaxListeners","getMaxListeners","doError","error","er","message","context","handler","len","listeners","addListener","on","prependListener","prependOnceListener","list","position","originalListener","shift","index","pop","spliceOne","off","removeAllListeners","rawListeners","eventNames","version","indexOf","fn","arg1","arg2","arg3","buffer","copyProps","src","dst","SafeBuffer","encodingOrOffset","from","alloc","allocUnsafe","allocUnsafeSlow","size","fill","encoding","buf","SlowBuffer","TYPED_OK","Uint8Array","Uint16Array","Int32Array","_has","assign","sources","slice","source","shrinkBuf","subarray","fnTyped","arraySet","dest","src_offs","dest_offs","flattenChunks","chunks","pos","chunk","result","fnUntyped","setTyped","Buf8","Buf16","Buf32","base64","ieee754","INSPECT_MAX_BYTES","K_MAX_LENGTH","createBuffer","__proto__","isArrayBuffer","array","byteOffset","byteLength","fromArrayBuffer","string","isEncoding","actual","write","fromString","checked","ArrayBuffer","isView","numberIsNaN","fromArrayLike","data","fromObject","assertSize","loweredCase","utf8ToBytes","base64ToBytes","toLowerCase","swap","b","bidirectionalIndexOf","val","dir","arrayIndexOf","lastIndexOf","indexSize","arrLength","valLength","read","readUInt16BE","foundIndex","found","j","hexWrite","offset","remaining","strLen","parsed","parseInt","substr","utf8Write","blitBuffer","asciiWrite","str","byteArray","charCodeAt","asciiToBytes","latin1Write","base64Write","ucs2Write","units","hi","lo","utf16leToBytes","base64Slice","start","fromByteArray","utf8Slice","Math","min","res","secondByte","thirdByte","fourthByte","tempCodePoint","firstByte","codePoint","bytesPerSequence","codePoints","MAX_ARGUMENTS_LENGTH","fromCharCode","decodeCodePointsArray","kMaxLength","TYPED_ARRAY_SUPPORT","foo","typedArraySupport","species","poolSize","_isBuffer","compare","a","x","y","swap16","swap32","swap64","hexSlice","asciiSlice","latin1Slice","utf16leSlice","toLocaleString","equals","inspect","max","match","join","thisStart","thisEnd","thisCopy","targetCopy","includes","isFinite","toJSON","_arr","out","toHex","bytes","checkOffset","ext","checkInt","checkIEEE754","writeFloat","littleEndian","noAssert","writeDouble","newBuf","readUIntLE","mul","readUIntBE","readUInt8","readUInt16LE","readUInt32LE","readUInt32BE","readIntLE","pow","readIntBE","readInt8","readInt16LE","readInt16BE","readInt32LE","readInt32BE","readFloatLE","readFloatBE","readDoubleLE","readDoubleBE","writeUIntLE","writeUIntBE","writeUInt8","writeUInt16LE","writeUInt16BE","writeUInt32LE","writeUInt32BE","writeIntLE","limit","sub","writeIntBE","writeInt8","writeInt16LE","writeInt16BE","writeInt32LE","writeInt32BE","writeFloatLE","writeFloatBE","writeDoubleLE","writeDoubleBE","targetStart","copyWithin","code","INVALID_BASE64_RE","Infinity","leadSurrogate","toByteArray","split","trim","replace","base64clean","Stream","Transform","PassThrough","global","CorkedRequest","_this","next","entry","finish","corkReq","callback","pendingcb","corkedRequestsFree","onCorkedFinish","asyncWrite","browser","setImmediate","WritableState","internalUtil","deprecate","OurUint8Array","realHasInstance","destroyImpl","nop","stream","isDuplex","objectMode","writableObjectMode","hwm","writableHwm","writableHighWaterMark","defaultHwm","floor","finalCalled","needDrain","ending","finished","noDecode","decodeStrings","defaultEncoding","writing","corked","sync","bufferProcessing","onwrite","writecb","writelen","onwriteStateUpdate","finishMaybe","errorEmitted","onwriteError","needFinish","bufferedRequest","clearBuffer","afterWrite","lastBufferedRequest","prefinished","bufferedRequestCount","_write","writev","_writev","destroy","final","_final","doWrite","onwriteDrain","holder","allBuffers","isBuf","callFinal","need","prefinish","getBuffer","current","_","hasInstance","pipe","_isUint8Array","_uint8ArrayToBuffer","writeAfterEnd","valid","validChunk","newChunk","decodeChunk","last","writeOrBuffer","cork","uncork","setDefaultEncoding","endWritable","_undestroy","undestroy","splitPathRe","path","normalize","absolute","charAt","sep","components","_removeDuplicateSeps","goodComponents","idx","paths","_i","processed","segment","resolve","resolved","cwd","relative","to","fromSegs","toSegs","upCount","downSegs","rv","dirname","sections","basename","lastPart","extname","isAbsolute","_makeLong","parse","allParts","filename","exec","posixSplitPath","base","format","pathObject","_replaceRegex","RegExp","delimiter","posix","win32","ReadableState","EElistenerCount","debugUtil","debug","debuglog","StringDecoder","BufferList","kProxyEvents","readableObjectMode","readableHwm","readableHighWaterMark","pipes","pipesCount","flowing","endEmitted","reading","needReadable","emittedReadable","readableListening","resumeScheduled","awaitDrain","readingMore","decoder","_read","readableAddChunk","addToFront","skipChunkCheck","emitReadable","onEofChunk","chunkInvalid","addChunk","maybeReadMore","needMoreData","isPaused","setEncoding","enc","MAX_HWM","howMuchToRead","head","computeNewHighWaterMark","emitReadable_","flow","maybeReadMore_","nReadingNextTick","resume_","fromList","clear","hasStrings","nb","tail","copyFromBufferString","copyFromBuffer","fromListPartial","endReadable","endReadableNT","xs","nOrig","doRead","pipeOpts","endFn","unpipe","onunpipe","unpipeInfo","hasUnpiped","onclose","onfinish","ondrain","onerror","ondata","cleanedUp","pipeOnDrain","increasedAwaitDrain","pause","event","resume","dests","splice","ev","wrap","paused","_fromList","emitErrorNT","readableDestroyed","writableDestroyed","nenc","retried","_normalizeEncoding","normalizeEncoding","text","utf16Text","utf16End","fillLast","utf8FillLast","base64Text","base64End","simpleWrite","simpleEnd","lastNeed","lastTotal","lastChar","utf8CheckByte","byte","utf8CheckExtraBytes","total","utf8CheckIncomplete","_transformState","afterTransform","ts","transforming","writechunk","rs","needTransform","writeencoding","transform","_transform","flush","_flush","done","_this2","err2","ErrorCode","ErrorStrings","EPERM","ENOENT","EIO","EBADF","EACCES","EBUSY","EEXIST","ENOTDIR","EISDIR","EINVAL","EFBIG","ENOSPC","EROFS","ENOTEMPTY","ENOTSUP","ActionType","ApiError","path$$1","syscall","errno","stack","fromJSON","json","fromBuffer","buffer$$1","JSON","FileError","writeToBuffer","bufferSize","bytesWritten","stringify","api_error","freeze","FileType","FileFlag","flagStr","validFlagStrs","getFileFlag","flagCache","getFlagString","isReadable","isWriteable","isTruncating","isAppendable","isSynchronous","isExclusive","pathExistsAction","THROW_EXCEPTION","TRUNCATE_FILE","NOP","pathNotExistsAction","CREATE_FILE","Stats","itemType","atimeMs","mtimeMs","ctimeMs","birthtimeMs","dev","ino","rdev","nlink","blksize","uid","gid","fileData","currentTime","Date","now","FILE","DIRECTORY","blocks","ceil","prototypeAccessors","atime","mtime","ctime","birthtime","clone","toBuffer","getTime","isFile","isDirectory","isSymbolicLink","SYMLINK","chmod","isSocket","isBlockDevice","isCharacterDevice","isFIFO","defineProperties","bfsSetImmediate","toExport","gScope","timeouts","importScripts","postMessage","postMessageIsAsync","oldOnMessage","onmessage","canUsePostMessage","handleMessage","stopPropagation","cancelBubble","addEventListener","attachEvent","MessageChannel","channel","port1","port2","setTimeout","setImmediate$1","wrapCbHook","numArgs","wrapCb","hookedCb","assertRoot","fs","normalizeMode","def","trueMode","normalizeTime","time","normalizePath","normalizeOptions","defEnc","defFlag","defMode","flag","nopCb","FS","F_OK","R_OK","W_OK","X_OK","fdMap","nextFd","initialize","rootFS","isAvailable","_toUnixTimestamp","getRootFS","rename","oldPath","newPath","newCb","renameSync","exists","existsSync","stat","statSync","lstat","lstatSync","truncate","truncateSync","unlink","unlinkSync","open","this$1","file","getFdForFile","openSync","readFile","readFileSync","writeFile","writeFileSync","appendFile","appendFileSync","fstat","fd","fd2file","fstatSync","close","closeFd","closeSync","ftruncate","ftruncateSync","fsync","fsyncSync","syncSync","fdatasync","datasync","fdatasyncSync","datasyncSync","arg4","arg5","getPos","writeSync","bytesRead","readSync","shenanigans","fchown","chown","fchownSync","chownSync","fchmod","numMode","fchmodSync","chmodSync","futimes","utimes","futimesSync","utimesSync","rmdir","rmdirSync","mkdir","mkdirSync","readdir","readdirSync","link","srcpath","dstpath","linkSync","symlink","symlinkSync","readlink","readlinkSync","lchown","lchownSync","lchmod","lchmodSync","realpath","cache","realpathSync","watchFile","unwatchFile","watch","access","accessSync","createReadStream","createWriteStream","wrapCallbacks","cbWrapper","_fsMock","fsProto","_min","d0","d1","d2","bx","ay","forEach","newFs","isIE","navigator","userAgent","isWebWorker","fail","mkdirpSync","buffer2ArrayBuffer","buff","u8","buffer2Uint8array","u8offset","u8Len","arrayish2Buffer","uint8Array2Buffer","arrayBuffer2Buffer","ab","copyingSlice","emptyBuffer","s0","newS0","emptyBuff","bufferValidator","checkOptions","fsType","opts","optsInfo","Options","fsName","Name","pendingValidators","callbackCalled","loopEnded","validatorCallback","loop","optName","opt","providedValue","optional","incorrectOptions","filter","map","distance","tmp","la","lb","d3","vector","bx0","bx1","bx2","bx3","dd$1","y$1","dy","dd","bx0$1","y$2","dy$1","levenshtein","sort","validator","returned","BFSUtils","deprecationMessage","print","BFSEmscriptenStreamOps","nodefs","getNodeFS","getFS","PATH","getPATH","ERRNO_CODES","getERRNO_CODES","realPath","node","nfd","flagsToPermissionString","flags","ErrnoError","llseek","whence","BFSEmscriptenNodeOps","getattr","setattr","attr","timestamp","date","lookup","parent","join2","getMode","createNode","mknod","isDir","oldNode","newDir","newName","contents","BFSEmscriptenFS","_FS","_PATH","_ERRNO_CODES","flagsToPermissionStringMap","0","1","2","64","65","66","129","193","514","577","578","705","706","1024","1025","1026","1089","1090","1153","1154","1217","1218","4096","4098","node_ops","stream_ops","mount","isLink","parts","reverse","parsedFlags","BaseFileSystem","supportsLinks","diskSpace","openFile","createFile","stats","parentStats","isLstat","openFileSync","createFileSync","splitPath","addPaths","doesExist","er2","fname","oldCb","isLchmod","isLchown","SynchronousFileSystem","supportsSynch","BaseFile","PreloadFile","BaseFile$$1","_fs","_path","_flag","_stat","_pos","_dirty","_buffer","getStats","getFlag","getPath","advancePos","delta","setPos","newPos","newBuff","endFp","supportsProps","isDirty","resetDirty","NoSyncFile","MirrorFile","PreloadFile$$1","_syncSync","AsyncMirror","SynchronousFileSystem$$1","async","_queue","_queueRunning","_isInitialized","_initializeCallbacks","_sync","_async","Create","_initialize","getName","enqueueOp","apiMethod","isReadOnly","userCb","callbacks","copyDirectory","files","copyNextFile","copyItem","copyFile","op","doNextOp","description","Dropbox","FixPath","ExtractTheFuckingError","obj2","reason","obj2$1","GetErrorMessage","user_message","error_summary","LookupErrorToError","msg","WriteErrorToError","FilesDeleteWrapped","client","filesDeleteV2","then","catch","path_lookup","path_write","random","DropboxFile","_syncFile","DropboxFileSystem","BaseFileSystem$$1","_client","supportsSymlinks","empty","mainCb","relocationArg","from_path","to_path","filesMoveV2","from_lookup","from_write","filesGetMetadata","ref","fileMetadata","downloadArg","filesDownload","fileBlob","fr","FileReader","onload","readAsArrayBuffer","commitInfo","Blob","filesUpload","metadata","filesCreateFolderV2","filesListFolder","ContinueReadingDir","previousEntries","newEntries","entries","path_display","has_more","cursor","filesListFolderContinue","ProcessListFolderError",".tag","convertError","EmscriptenFile","_stream","emPosition","EmscriptenFileSystem","DB_NAME","modeToFileType","utime","FolderAdapter","folder","_folder","_wrapped","fa","translateError","wrapFunction","wrapFirst","wrapSecond","wrapCallback","arrayLike","newLen","newArr","hasSetImmediate","hasNextTick","fallback","setImmediate$2","defer","asyncify","func","initialParams","invokeCallback","rethrow","supportsSymbol","wrapAsync","asyncFn","isAsync","freeGlobal","freeSelf","Symbol$1","objectProto","nativeObjectToString","symToStringTag","nativeObjectToString$1","nullTag","undefinedTag","symToStringTag$1","baseGetTag","isOwn","tag","getRawTag","asyncTag","funcTag","genTag","proxyTag","MAX_SAFE_INTEGER","isLength","isArrayLike","breakLoop","noop","callFn","iteratorSymbol","iterator","isObjectLike","argsTag","baseIsArguments","objectProto$2","hasOwnProperty$1","propertyIsEnumerable","isArguments","freeExports","nodeType","freeModule","Buffer$1","MAX_SAFE_INTEGER$1","reIsUint","isIndex","test","typedArrayTags","freeExports$1","freeModule$1","freeProcess","nodeUtil","types","require","binding","nodeIsTypedArray","isTypedArray","baseUnary","hasOwnProperty$2","arrayLikeKeys","inherited","isArr","isArg","isBuff","isType","skipIndexes","iteratee","baseTimes","objectProto$4","nativeKeys","overArg","hasOwnProperty$3","baseKeys","Ctor","isPrototype","createObjectIterator","okeys","coll","createArrayIterator","getIterator","item","createES2015Iterator","onlyOnce","eachOfArrayLike","completed","iteratorCallback","eachOfGeneric","iterable","doLimit","nextElem","running","looping","iterateeCallback","replenish","elem","_eachOfLimit","symbolProto","eachLimit","eachOf","_withoutIndex","_getFS","webkitRequestFileSystem","requestFileSystem","convertError$1","expectedDir","HTML5FSFile","_entry","createWriter","writer","blob","onwriteend","HTML5FS","PERSISTENT","_allocate","_readdir","succ","fullPath","isDirectoryEntry","remove","removeRecursively","semaphore","successCount","currentPath","success","getDirectory","parentDir","moveTo","getFile","loadAsDir","dir$$1","failedToLoad","exclusive","reader","onloadend","bfsFile","_makeFile","_remove","dirEntry","createReader","readEntries","results","_toArray","errorCallback","webkitPersistentStorage","requestQuota","TEMPORARY","webkitTemporaryStorage","webkitStorageInfo","_requestQuota","granted","Inode","id","toStats","getSize","update","hasChanged","emptyDirNode","getEmptyDirNode","GenerateRandomID","noError","noErrorTx","tx","abort","LRUNode","prev","LRUCache","setHead","removeAll","SimpleSyncRWTransaction","store","originalData","modifiedKeys","stashOldValue","put","overwrite","markModified","del","commit","SyncKeyValueFile","SyncKeyValueFileSystem","makeRootDirectory","beginTransaction","oldParent","oldName","newParent","oldDirNode","findINode","oldDirList","getDirListing","newDirNode","newDirList","nodeId","newNameNode","getINode","newFile","commitNewFile","removeEntry","fileInodeId","_findINode","fileInode","inodeChanged","currTime","dirInode","readDirectory","inode","dirList","addNewNode","currId","fileNode","parentNode","dirListing","dataId","fileNodeId","parentListing","fileName","AsyncKeyValueFile","AsyncKeyValueFileSystem","cacheSize","_cache","inodes","lists","errorOccurred","processInodeAndListings","findINodeAndDirListing","oldParentList","oldParentINode","newParentList","newParentINode","fileId","completeRename","theOleSwitcharoo","handleDirectoryListings","listing","retries","reroll","committed","InMemoryStore","InMemoryFileSystem","SyncKeyValueFileSystem$$1","indexedDB","mozIndexedDB","webkitIndexedDB","msIndexedDB","_a","convertError$2","onErrorHandler","preventDefault","IndexedDBROTransaction","onsuccess","IndexedDBRWTransaction","arraybuffer","add","_e","IndexedDBStore","db","storeName","openReq","onupgradeneeded","objectStoreNames","contains","deleteObjectStore","createObjectStore","IndexedDBFileSystem","transaction","objectStore","AsyncKeyValueFileSystem$$1","idbfs","binaryEncoding","supportsBinaryString","localStorage","setItem","getItem","LocalStorageStore","LocalStorageFileSystem","removeItem","MountableFileSystem","rootFs","mountList","mntMap","imfs","mountPoint","umount","_getFs","standardizeError","fs1rv","fs2rv","fsInfo","rv2","mountedPath","_containsMountPt","mountPoints","pt","defineFcn","isSync","fsCmdMap","i$1","fnName","Mutex","_locked","_waiters","lock","unlock","tryLock","isLocked","LockedFS","_mu","getFSUnlocked","resolvedPath","linkString","deletionLogPath","makeModeWritable","f","SpecialArgType","OverlayFile","_syncAsync","UnlockedOverlayFS","_deletedFiles","_deleteLog","_deleteLogUpdatePending","_deleteLogUpdateNeeded","_deleteLogError","_writable","_readable","getOverlayedFileSystems","createParentDirectoriesAsync","createParentDirectories","OverlayFS","callbackArray","_reparseDeletionLog","getDeletionLog","restoreDeletionLog","log","updateLog","checkInitAsync","checkPathAsync","oldErr","oldStats","newErr","newStats","copyDirContents","oldFile","mkdirErr","readdirErr","checkInitialized","checkPath","oldStat","readFileErr","writableExists","readableExists","deletePath","rmdirLower","dirStats","wFiles","rFiles","seenMap","filtered","fPath","fileP","existsWritable","existsReadable","operateOnWritableAsync","operateOnWritable","addition","toCreate","statDone","createParents","copyToWritable","copyToWritableAsync","pStats","LockedFS$$1","CallbackArgumentConverter","_callbacks","_nextId","toRemoteArg","CB","toLocalArg","FileDescriptorArgumentConverter","_fileDescriptors","apiErrorLocal2Remote","API_ERROR","errorData","bufferToTransferrableObject","apiErrorRemote2Local","transferrableObjectToBuffer","errorLocal2Remote","ERROR","errorRemote2Local","cnstr","statsLocal2Remote","STATS","statsData","statsRemote2Local","fileFlagLocal2Remote","FILEFLAG","fileFlagRemote2Local","remoteFlag","bufferLocal2Remote","BUFFER","bufferRemote2Local","buffArg","FD","applyFdAPIRequest","request","fdArg","_applyFdChanges","remoteFd","remoteStats","applyStatChanges","WorkerFile","remoteFdId","_remoteFdId","getRemoteFdId","_syncClose","syncClose","WorkerFS","worker","_callbackConverter","_isReadOnly","_supportLinks","_supportProps","_worker","resp","isAPIResponse","fixedArgs","_argRemote2Local","cbId","attachRemoteListener","fdConverter","argLocal2Remote","requestArgs","argRemote2Local","fixedRequestArgs","specialArg","arguments$1","countdown","abortAndSendError","browserfsMessage","fixedArg","isAPIRequest","remoteCb","response","probeResponse","PROBE","_rpc","_argLocal2Remote","methodName","xhrIsAvailable","XMLHttpRequest","getFileSize","req","onreadystatechange","readyState","status","getResponseHeader","send","asyncDownloadFile","jsonSupported","responseType","responseText","syncDownloadFile","overrideMimeType","getFileSizeSync","getFileSizeAsync","fetchIsAvailable","fetch","fetchFileAsync","ok","arrayBuffer","fetchFileSizeAsync","headers","FileIndex","_index","addPath","DirInode","fromListing","rootInode","queue","pwd","tree","children","FileInode","_ls","fileIterator","getListing","isFileInode","getData","_split_path","dirpath","itemname","addItem","isDirInode","addPathFast","itemNameMark","parentPath","substring","itemName","removePath","remItem","child","ls","getInode","setData","syncNotAvailableError","HTTPRequest","prefixUrl","preferXHR","_requestFileAsyncInternal","_requestFileSizeAsyncInternal","_requestFileSyncInternal","_requestFileSizeSyncInternal","baseUrl","preloadFile","_requestFileSizeAsync","_requestFileSizeSync","_requestFileAsync","_requestFileSync","fdBuff","tryToString","_getHTTPPath","filePath","ExtendedASCII","str2byte","charCode","charIdx","extendedChars","byte2str","chars","ExternalFileAttributeType","CompressionMethod","inflateRaw","decompressionMethods","msdos2date","safeToString","useUTF8","FileHeader","versionNeeded","compressionMethod","lastModFileTime","rawLastModFileTime","crc32","fileNameLength","extraFieldLength","extraField","totalSize","FileData","header","record","decompress","fcn","compressedSize","uncompressedSize","getHeader","getRecord","getRawData","CentralDirectory","zipData","_filename","produceFilename","versionMadeBy","fileCommentLength","diskNumberStart","internalAttributes","externalAttributes","headerRelativeOffset","rawFileName","fileComment","rawFileComment","isEncrypted","getFileData","EndOfCentralDirectory","diskNumber","cdDiskNumber","cdDiskEntryCount","cdTotalEntryCount","cdSize","cdOffset","cdZipCommentLength","cdZipComment","rawCdZipComment","ZipFS","input","_directoryEntries","_eocd","directoryEntries","eocd","_computeIndex","zipTOC","RegisterDecompressionMethod","_getEOCD","endOffset","startOffset","_addToIndex","cd","cdPtr","cdEnd","_computeIndexResponsive","_computeIndexResponsiveTrampoline","cdEntries","getCentralDirectoryEntry","getCentralDirectoryEntryAt","getNumberOfCentralDirectoryEntries","getEndOfCentralDirectory","cdRecord","DEFLATE","chunkSize","STORED","getASCIIString","startIndex","getJolietString","pairs","getDate","year","mon","day","hour","sec","hundrethsSec","getShortFormDate","yearsSince1900","month","minute","second","constructSystemUseEntry","bigData","sue","SystemUseEntry","signatureWord","CEEntry","PDEntry","SPEntry","STEntry","EREntry","ESEntry","PXEntry","PNEntry","SLEntry","NMEntry","CLEntry","PLEntry","REEntry","TFEntry","SFEntry","RREntry","constructSystemUseEntries","isoData","getEntries","VolumeDescriptor","_data","standardIdentifier","PrimaryOrSupplementaryVolumeDescriptor","_root","systemIdentifier","_getString32","volumeIdentifier","volumeSpaceSize","volumeSetSize","volumeSequenceNumber","logicalBlockSize","pathTableSize","locationOfTypeLPathTable","locationOfOptionalTypeLPathTable","locationOfTypeMPathTable","locationOfOptionalTypeMPathTable","rootDirectoryEntry","_constructRootDirectoryRecord","rootCheckForRockRidge","volumeSetIdentifier","_getString","publisherIdentifier","dataPreparerIdentifier","applicationIdentifier","copyrightFileIdentifier","abstractFileIdentifier","bibliographicFileIdentifier","volumeCreationDate","volumeModificationDate","volumeExpirationDate","volumeEffectiveDate","fileStructureVersion","applicationUsed","reserved","PrimaryVolumeDescriptor","ISODirectoryRecord","SupplementaryVolumeDescriptor","escapeSequence","third","JolietDirectoryRecord","DirectoryRecord","rockRidgeOffset","_suEntries","_fileOrDir","_rockRidgeOffset","hasRockRidge","getRockRidgeOffset","getDotEntry","_getRockRidgeOffset","extendedAttributeRecordLength","lba","dataLength","recordingDate","fileFlags","fileUnitSize","interleaveGapSize","identifier","_rockRidgeFilename","ident","versionSeparator","getSUEntries","isSymlink","getSymlinkPath","getStr","_getGetString","list$1","componentRecords","component","content","continueFlag","_constructDirectory","_constructSUEntries","nmEntries","getString","suEntries","spEntry","checkBytesPass","extensionIdentifier","bytesSkipped","ISODirectory","JolietDirectory","signatureWordString","suVersion","_entries","continuationLba","continuationLbaOffset","continuationLength","identifierLength","descriptorLength","sourceLength","extensionVersion","extensionDescriptor","extensionSource","extensionSequence","fileLinks","devTHigh","devTLow","records","SLComponentRecord","componentLength","childDirectoryLba","parentDirectoryLba","creation","_longFormDates","modify","previousDates","backup","expiration","effective","virtualSizeHigh","virtualSizeLow","tableDepth","Directory","_fileList","_fileMap","_record","iLimit","_constructDirectoryRecord","getFileList","IsoFS","vdTerminatorFound","candidateVDs","_pvd","_name","_getDirectoryRecord","_getStats","newP","dirRec","oneArg","normalizedCb","normalizedOpts","Backends","Emscripten","InMemory","IndexedDB","LocalStorage","XmlHttpRequest","BFSRequire","rootfs","getFileSystem","config","waitCount","called","fsc","finishedIterating","k","install","oldRequire","registerFileSystem","configure","EmscriptenFS","FileSystem","Errors","b64","lens","getLens","validLen","placeHoldersLen","Arr","_byteLength","curByte","revLookup","uint8","extraBytes","len2","encodeChunk","tripletToBase64","num","output","isLE","mLen","nBytes","eLen","eMax","eBias","nBits","NaN","rt","abs","LN2","Item","fun","run","NextTickQueue","_draining","_currentQueue","_queueIndex","_drainQueue","_cleanUpNextTick","timeout","clearTimeout","Process","_super","startTime","_cwd","platform","argv","execArgv","domain","execPath","__dirname","env","exitCode","_gid","_uid","versions","http_parser","v8","uv","zlib","ares","icu","openssl","target_defaults","cflags","default_configuration","defines","include_dirs","libraries","variables","clang","host_arch","node_install_npm","node_install_waf","node_prefix","node_shared_cares","node_shared_http_parser","node_shared_libuv","node_shared_zlib","node_shared_v8","node_use_dtrace","node_use_etw","node_use_openssl","node_shared_openssl","strict_aliasing","target_arch","v8_use_snapshot","v8_no_strict_aliasing","visibility","pid","title","arch","_mask","connected","__extends","chdir","uptime","exit","getgid","setgid","getuid","setuid","kill","signal","memoryUsage","rss","heapTotal","heapUsed","umask","mask","oldMask","hrtime","timeinfo","secs","performance","TTY","disconnect","isRaw","columns","rows","isTTY","_bufferedWrites","_waitingForWrites","setRawMode","changeColumns","changeRows","isatty","EE","_isStdio","didOnEnd","cleanup","copyBuffer","instance","Constructor","_classCallCheck","custom","trace","webpackPolyfill","zlib_inflate","utils","strings","ZStream","GZheader","Inflate","windowBits","raw","strm","avail_out","inflateInit2","Z_OK","inflateGetHeader","dictionary","string2buf","inflateSetDictionary","inflate","inflator","_mode","next_out_utf8","utf8str","allowBufError","Z_FINISH","Z_NO_FLUSH","binstring2buf","next_in","avail_in","next_out","Z_NEED_DICT","Z_BUF_ERROR","Z_STREAM_END","onEnd","Z_SYNC_FLUSH","utf8border","buf2string","onData","inflateEnd","ungzip","adler32","inflate_fast","inflate_table","CODES","LENS","DISTS","Z_BLOCK","Z_TREES","Z_STREAM_ERROR","Z_DATA_ERROR","Z_MEM_ERROR","Z_DEFLATED","HEAD","FLAGS","TIME","OS","EXLEN","EXTRA","NAME","COMMENT","HCRC","DICTID","DICT","TYPE","TYPEDO","COPY_","COPY","TABLE","LENLENS","CODELENS","LEN_","LEN","LENEXT","DIST","DISTEXT","MATCH","LIT","CHECK","LENGTH","DONE","BAD","MEM","SYNC","ENOUGH_LENS","ENOUGH_DISTS","DEF_WBITS","zswap32","q","inflateResetKeep","total_in","total_out","adler","havedict","dmax","hold","bits","lencode","lendyn","distcode","distdyn","sane","back","inflateReset","wsize","whave","wnext","inflateReset2","wbits","check","extra","lenbits","distbits","ncode","nlen","ndist","have","work","was","lenfix","distfix","virgin","fixedtables","sym","updatewindow","dist","inflateInit","left","_in","_out","from_source","here_bits","here_op","here_val","last_bits","last_op","last_val","here","hbuf","order","inf_leave","xflags","os","extra_len","comment","hcrc","data_type","dictLength","inflateInfo","s1","s2","crcTable","table","makeTable","crc","beg","s_window","lcode","dcode","lmask","dmask","top","dolen","dodist","lbase","lext","dbase","dext","lens_index","codes","table_index","incr","low","curr","drop","used","huff","base_index","MAXBITS","offs","extra_index","STR_APPLY_OK","STR_APPLY_UIA_OK","__","_utf8len","buf2binstring","c2","m_pos","str_len","buf_len","c_len","utf16buf","Z_PARTIAL_FLUSH","Z_FULL_FLUSH","Z_ERRNO","Z_NO_COMPRESSION","Z_BEST_SPEED","Z_BEST_COMPRESSION","Z_DEFAULT_COMPRESSION","Z_FILTERED","Z_HUFFMAN_ONLY","Z_RLE","Z_FIXED","Z_DEFAULT_STRATEGY","Z_BINARY","Z_TEXT","Z_UNKNOWN","-1","-2","-3","-4","-5","-6"],"mappings":"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","file":"../build/browserfs.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"BrowserFS\"] = factory();\n\telse\n\t\troot[\"BrowserFS\"] = factory();\n})(this, function() {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 19);\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// a duplex stream is just a stream that is both readable and writable.\n// Since JS doesn't have multiple prototypal inheritance, this class\n// prototypally inherits from Readable, and then parasitically from\n// Writable.\n\n'use strict';\n\n/**/\n\nvar pna = require('process-nextick-args');\n/**/\n\n/**/\nvar objectKeys = Object.keys || function (obj) {\n var keys = [];\n for (var key in obj) {\n keys.push(key);\n }return keys;\n};\n/**/\n\nmodule.exports = Duplex;\n\n/**/\nvar util = Object.create(require('core-util-is'));\nutil.inherits = require('inherits');\n/**/\n\nvar Readable = require('./_stream_readable');\nvar Writable = require('./_stream_writable');\n\nutil.inherits(Duplex, Readable);\n\n{\n // avoid scope creep, the keys array can then be collected\n var keys = objectKeys(Writable.prototype);\n for (var v = 0; v < keys.length; v++) {\n var method = keys[v];\n if (!Duplex.prototype[method]) Duplex.prototype[method] = Writable.prototype[method];\n }\n}\n\nfunction Duplex(options) {\n if (!(this instanceof Duplex)) return new Duplex(options);\n\n Readable.call(this, options);\n Writable.call(this, options);\n\n if (options && options.readable === false) this.readable = false;\n\n if (options && options.writable === false) this.writable = false;\n\n this.allowHalfOpen = true;\n if (options && options.allowHalfOpen === false) this.allowHalfOpen = false;\n\n this.once('end', onend);\n}\n\nObject.defineProperty(Duplex.prototype, 'writableHighWaterMark', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function () {\n return this._writableState.highWaterMark;\n }\n});\n\n// the no-half-open enforcer\nfunction onend() {\n // if we allow half-open state, or if the writable side ended,\n // then we're ok.\n if (this.allowHalfOpen || this._writableState.ended) return;\n\n // no more data can be written.\n // But allow more writes to happen in this tick.\n pna.nextTick(onEndNT, this);\n}\n\nfunction onEndNT(self) {\n self.end();\n}\n\nObject.defineProperty(Duplex.prototype, 'destroyed', {\n get: function () {\n if (this._readableState === undefined || this._writableState === undefined) {\n return false;\n }\n return this._readableState.destroyed && this._writableState.destroyed;\n },\n set: function (value) {\n // we ignore the value if the stream\n // has not been initialized yet\n if (this._readableState === undefined || this._writableState === undefined) {\n return;\n }\n\n // backward compatibility, the user is explicitly\n // managing destroyed\n this._readableState.destroyed = value;\n this._writableState.destroyed = value;\n }\n});\n\nDuplex.prototype._destroy = function (err, cb) {\n this.push(null);\n this.end();\n\n pna.nextTick(cb, err);\n};","if (typeof Object.create === 'function') {\n // implementation from standard node.js 'util' module\n module.exports = function inherits(ctor, superCtor) {\n if (superCtor) {\n ctor.super_ = superCtor\n ctor.prototype = Object.create(superCtor.prototype, {\n constructor: {\n value: ctor,\n enumerable: false,\n writable: true,\n configurable: true\n }\n })\n }\n };\n} else {\n // old school shim for old browsers\n module.exports = function inherits(ctor, superCtor) {\n if (superCtor) {\n ctor.super_ = superCtor\n var TempCtor = function () {}\n TempCtor.prototype = superCtor.prototype\n ctor.prototype = new TempCtor()\n ctor.prototype.constructor = ctor\n }\n }\n}\n","import Process = require('./process');\nimport TTD = require('./tty');\n\nvar process = new Process(),\n processProxy: Process = {};\n\nfunction defineKey(key: string) {\n if (( processProxy)[key]) {\n // Probably a builtin Object property we don't care about.\n return;\n }\n if (typeof ( process)[key] === 'function') {\n ( processProxy)[key] = function() {\n return ( ( process)[key]).apply(process, arguments);\n };\n } else {\n ( processProxy)[key] = ( process)[key];\n }\n}\n\nfor (var key in process) {\n // Don't check if process.hasOwnProperty; we want to also expose objects\n // up the prototype hierarchy.\n defineKey(key);\n}\n\n// Special key: Ensure we update public-facing values of stdin/stdout/stderr.\nprocessProxy.initializeTTYs = function() {\n if (process.stdin === null) {\n process.initializeTTYs();\n processProxy.stdin = process.stdin;\n processProxy.stdout = process.stdout;\n processProxy.stderr = process.stderr;\n }\n};\n\nprocess.nextTick(() => {\n processProxy.initializeTTYs();\n});\n\nexport = processProxy;\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// NOTE: These type checking functions intentionally don't use `instanceof`\n// because it is fragile and can be easily faked with `Object.create()`.\n\nfunction isArray(arg) {\n if (Array.isArray) {\n return Array.isArray(arg);\n }\n return objectToString(arg) === '[object Array]';\n}\nexports.isArray = isArray;\n\nfunction isBoolean(arg) {\n return typeof arg === 'boolean';\n}\nexports.isBoolean = isBoolean;\n\nfunction isNull(arg) {\n return arg === null;\n}\nexports.isNull = isNull;\n\nfunction isNullOrUndefined(arg) {\n return arg == null;\n}\nexports.isNullOrUndefined = isNullOrUndefined;\n\nfunction isNumber(arg) {\n return typeof arg === 'number';\n}\nexports.isNumber = isNumber;\n\nfunction isString(arg) {\n return typeof arg === 'string';\n}\nexports.isString = isString;\n\nfunction isSymbol(arg) {\n return typeof arg === 'symbol';\n}\nexports.isSymbol = isSymbol;\n\nfunction isUndefined(arg) {\n return arg === void 0;\n}\nexports.isUndefined = isUndefined;\n\nfunction isRegExp(re) {\n return objectToString(re) === '[object RegExp]';\n}\nexports.isRegExp = isRegExp;\n\nfunction isObject(arg) {\n return typeof arg === 'object' && arg !== null;\n}\nexports.isObject = isObject;\n\nfunction isDate(d) {\n return objectToString(d) === '[object Date]';\n}\nexports.isDate = isDate;\n\nfunction isError(e) {\n return (objectToString(e) === '[object Error]' || e instanceof Error);\n}\nexports.isError = isError;\n\nfunction isFunction(arg) {\n return typeof arg === 'function';\n}\nexports.isFunction = isFunction;\n\nfunction isPrimitive(arg) {\n return arg === null ||\n typeof arg === 'boolean' ||\n typeof arg === 'number' ||\n typeof arg === 'string' ||\n typeof arg === 'symbol' || // ES6 symbol\n typeof arg === 'undefined';\n}\nexports.isPrimitive = isPrimitive;\n\nexports.isBuffer = Buffer.isBuffer;\n\nfunction objectToString(o) {\n return Object.prototype.toString.call(o);\n}\n","var g;\n\n// This works in non-strict mode\ng = (function() {\n\treturn this;\n})();\n\ntry {\n\t// This works if eval is allowed (see CSP)\n\tg = g || Function(\"return this\")() || (1, eval)(\"this\");\n} catch (e) {\n\t// This works if the window reference is available\n\tif (typeof window === \"object\") g = window;\n}\n\n// g can still be undefined, but nothing to do about it...\n// We return undefined, instead of nothing here, so it's\n// easier to handle this case. if(!global) { ...}\n\nmodule.exports = g;\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\nvar R = typeof Reflect === 'object' ? Reflect : null\nvar ReflectApply = R && typeof R.apply === 'function'\n ? R.apply\n : function ReflectApply(target, receiver, args) {\n return Function.prototype.apply.call(target, receiver, args);\n }\n\nvar ReflectOwnKeys\nif (R && typeof R.ownKeys === 'function') {\n ReflectOwnKeys = R.ownKeys\n} else if (Object.getOwnPropertySymbols) {\n ReflectOwnKeys = function ReflectOwnKeys(target) {\n return Object.getOwnPropertyNames(target)\n .concat(Object.getOwnPropertySymbols(target));\n };\n} else {\n ReflectOwnKeys = function ReflectOwnKeys(target) {\n return Object.getOwnPropertyNames(target);\n };\n}\n\nfunction ProcessEmitWarning(warning) {\n if (console && console.warn) console.warn(warning);\n}\n\nvar NumberIsNaN = Number.isNaN || function NumberIsNaN(value) {\n return value !== value;\n}\n\nfunction EventEmitter() {\n EventEmitter.init.call(this);\n}\nmodule.exports = EventEmitter;\n\n// Backwards-compat with node 0.10.x\nEventEmitter.EventEmitter = EventEmitter;\n\nEventEmitter.prototype._events = undefined;\nEventEmitter.prototype._eventsCount = 0;\nEventEmitter.prototype._maxListeners = undefined;\n\n// By default EventEmitters will print a warning if more than 10 listeners are\n// added to it. This is a useful default which helps finding memory leaks.\nvar defaultMaxListeners = 10;\n\nfunction checkListener(listener) {\n if (typeof listener !== 'function') {\n throw new TypeError('The \"listener\" argument must be of type Function. Received type ' + typeof listener);\n }\n}\n\nObject.defineProperty(EventEmitter, 'defaultMaxListeners', {\n enumerable: true,\n get: function() {\n return defaultMaxListeners;\n },\n set: function(arg) {\n if (typeof arg !== 'number' || arg < 0 || NumberIsNaN(arg)) {\n throw new RangeError('The value of \"defaultMaxListeners\" is out of range. It must be a non-negative number. Received ' + arg + '.');\n }\n defaultMaxListeners = arg;\n }\n});\n\nEventEmitter.init = function() {\n\n if (this._events === undefined ||\n this._events === Object.getPrototypeOf(this)._events) {\n this._events = Object.create(null);\n this._eventsCount = 0;\n }\n\n this._maxListeners = this._maxListeners || undefined;\n};\n\n// Obviously not all Emitters should be limited to 10. This function allows\n// that to be increased. Set to zero for unlimited.\nEventEmitter.prototype.setMaxListeners = function setMaxListeners(n) {\n if (typeof n !== 'number' || n < 0 || NumberIsNaN(n)) {\n throw new RangeError('The value of \"n\" is out of range. It must be a non-negative number. Received ' + n + '.');\n }\n this._maxListeners = n;\n return this;\n};\n\nfunction _getMaxListeners(that) {\n if (that._maxListeners === undefined)\n return EventEmitter.defaultMaxListeners;\n return that._maxListeners;\n}\n\nEventEmitter.prototype.getMaxListeners = function getMaxListeners() {\n return _getMaxListeners(this);\n};\n\nEventEmitter.prototype.emit = function emit(type) {\n var args = [];\n for (var i = 1; i < arguments.length; i++) args.push(arguments[i]);\n var doError = (type === 'error');\n\n var events = this._events;\n if (events !== undefined)\n doError = (doError && events.error === undefined);\n else if (!doError)\n return false;\n\n // If there is no 'error' event listener then throw.\n if (doError) {\n var er;\n if (args.length > 0)\n er = args[0];\n if (er instanceof Error) {\n // Note: The comments on the `throw` lines are intentional, they show\n // up in Node's output if this results in an unhandled exception.\n throw er; // Unhandled 'error' event\n }\n // At least give some kind of context to the user\n var err = new Error('Unhandled error.' + (er ? ' (' + er.message + ')' : ''));\n err.context = er;\n throw err; // Unhandled 'error' event\n }\n\n var handler = events[type];\n\n if (handler === undefined)\n return false;\n\n if (typeof handler === 'function') {\n ReflectApply(handler, this, args);\n } else {\n var len = handler.length;\n var listeners = arrayClone(handler, len);\n for (var i = 0; i < len; ++i)\n ReflectApply(listeners[i], this, args);\n }\n\n return true;\n};\n\nfunction _addListener(target, type, listener, prepend) {\n var m;\n var events;\n var existing;\n\n checkListener(listener);\n\n events = target._events;\n if (events === undefined) {\n events = target._events = Object.create(null);\n target._eventsCount = 0;\n } else {\n // To avoid recursion in the case that type === \"newListener\"! Before\n // adding it to the listeners, first emit \"newListener\".\n if (events.newListener !== undefined) {\n target.emit('newListener', type,\n listener.listener ? listener.listener : listener);\n\n // Re-assign `events` because a newListener handler could have caused the\n // this._events to be assigned to a new object\n events = target._events;\n }\n existing = events[type];\n }\n\n if (existing === undefined) {\n // Optimize the case of one listener. Don't need the extra array object.\n existing = events[type] = listener;\n ++target._eventsCount;\n } else {\n if (typeof existing === 'function') {\n // Adding the second element, need to change to array.\n existing = events[type] =\n prepend ? [listener, existing] : [existing, listener];\n // If we've already got an array, just append.\n } else if (prepend) {\n existing.unshift(listener);\n } else {\n existing.push(listener);\n }\n\n // Check for listener leak\n m = _getMaxListeners(target);\n if (m > 0 && existing.length > m && !existing.warned) {\n existing.warned = true;\n // No error code for this since it is a Warning\n // eslint-disable-next-line no-restricted-syntax\n var w = new Error('Possible EventEmitter memory leak detected. ' +\n existing.length + ' ' + String(type) + ' listeners ' +\n 'added. Use emitter.setMaxListeners() to ' +\n 'increase limit');\n w.name = 'MaxListenersExceededWarning';\n w.emitter = target;\n w.type = type;\n w.count = existing.length;\n ProcessEmitWarning(w);\n }\n }\n\n return target;\n}\n\nEventEmitter.prototype.addListener = function addListener(type, listener) {\n return _addListener(this, type, listener, false);\n};\n\nEventEmitter.prototype.on = EventEmitter.prototype.addListener;\n\nEventEmitter.prototype.prependListener =\n function prependListener(type, listener) {\n return _addListener(this, type, listener, true);\n };\n\nfunction onceWrapper() {\n if (!this.fired) {\n this.target.removeListener(this.type, this.wrapFn);\n this.fired = true;\n if (arguments.length === 0)\n return this.listener.call(this.target);\n return this.listener.apply(this.target, arguments);\n }\n}\n\nfunction _onceWrap(target, type, listener) {\n var state = { fired: false, wrapFn: undefined, target: target, type: type, listener: listener };\n var wrapped = onceWrapper.bind(state);\n wrapped.listener = listener;\n state.wrapFn = wrapped;\n return wrapped;\n}\n\nEventEmitter.prototype.once = function once(type, listener) {\n checkListener(listener);\n this.on(type, _onceWrap(this, type, listener));\n return this;\n};\n\nEventEmitter.prototype.prependOnceListener =\n function prependOnceListener(type, listener) {\n checkListener(listener);\n this.prependListener(type, _onceWrap(this, type, listener));\n return this;\n };\n\n// Emits a 'removeListener' event if and only if the listener was removed.\nEventEmitter.prototype.removeListener =\n function removeListener(type, listener) {\n var list, events, position, i, originalListener;\n\n checkListener(listener);\n\n events = this._events;\n if (events === undefined)\n return this;\n\n list = events[type];\n if (list === undefined)\n return this;\n\n if (list === listener || list.listener === listener) {\n if (--this._eventsCount === 0)\n this._events = Object.create(null);\n else {\n delete events[type];\n if (events.removeListener)\n this.emit('removeListener', type, list.listener || listener);\n }\n } else if (typeof list !== 'function') {\n position = -1;\n\n for (i = list.length - 1; i >= 0; i--) {\n if (list[i] === listener || list[i].listener === listener) {\n originalListener = list[i].listener;\n position = i;\n break;\n }\n }\n\n if (position < 0)\n return this;\n\n if (position === 0)\n list.shift();\n else {\n spliceOne(list, position);\n }\n\n if (list.length === 1)\n events[type] = list[0];\n\n if (events.removeListener !== undefined)\n this.emit('removeListener', type, originalListener || listener);\n }\n\n return this;\n };\n\nEventEmitter.prototype.off = EventEmitter.prototype.removeListener;\n\nEventEmitter.prototype.removeAllListeners =\n function removeAllListeners(type) {\n var listeners, events, i;\n\n events = this._events;\n if (events === undefined)\n return this;\n\n // not listening for removeListener, no need to emit\n if (events.removeListener === undefined) {\n if (arguments.length === 0) {\n this._events = Object.create(null);\n this._eventsCount = 0;\n } else if (events[type] !== undefined) {\n if (--this._eventsCount === 0)\n this._events = Object.create(null);\n else\n delete events[type];\n }\n return this;\n }\n\n // emit removeListener for all listeners on all events\n if (arguments.length === 0) {\n var keys = Object.keys(events);\n var key;\n for (i = 0; i < keys.length; ++i) {\n key = keys[i];\n if (key === 'removeListener') continue;\n this.removeAllListeners(key);\n }\n this.removeAllListeners('removeListener');\n this._events = Object.create(null);\n this._eventsCount = 0;\n return this;\n }\n\n listeners = events[type];\n\n if (typeof listeners === 'function') {\n this.removeListener(type, listeners);\n } else if (listeners !== undefined) {\n // LIFO order\n for (i = listeners.length - 1; i >= 0; i--) {\n this.removeListener(type, listeners[i]);\n }\n }\n\n return this;\n };\n\nfunction _listeners(target, type, unwrap) {\n var events = target._events;\n\n if (events === undefined)\n return [];\n\n var evlistener = events[type];\n if (evlistener === undefined)\n return [];\n\n if (typeof evlistener === 'function')\n return unwrap ? [evlistener.listener || evlistener] : [evlistener];\n\n return unwrap ?\n unwrapListeners(evlistener) : arrayClone(evlistener, evlistener.length);\n}\n\nEventEmitter.prototype.listeners = function listeners(type) {\n return _listeners(this, type, true);\n};\n\nEventEmitter.prototype.rawListeners = function rawListeners(type) {\n return _listeners(this, type, false);\n};\n\nEventEmitter.listenerCount = function(emitter, type) {\n if (typeof emitter.listenerCount === 'function') {\n return emitter.listenerCount(type);\n } else {\n return listenerCount.call(emitter, type);\n }\n};\n\nEventEmitter.prototype.listenerCount = listenerCount;\nfunction listenerCount(type) {\n var events = this._events;\n\n if (events !== undefined) {\n var evlistener = events[type];\n\n if (typeof evlistener === 'function') {\n return 1;\n } else if (evlistener !== undefined) {\n return evlistener.length;\n }\n }\n\n return 0;\n}\n\nEventEmitter.prototype.eventNames = function eventNames() {\n return this._eventsCount > 0 ? ReflectOwnKeys(this._events) : [];\n};\n\nfunction arrayClone(arr, n) {\n var copy = new Array(n);\n for (var i = 0; i < n; ++i)\n copy[i] = arr[i];\n return copy;\n}\n\nfunction spliceOne(list, index) {\n for (; index + 1 < list.length; index++)\n list[index] = list[index + 1];\n list.pop();\n}\n\nfunction unwrapListeners(arr) {\n var ret = new Array(arr.length);\n for (var i = 0; i < ret.length; ++i) {\n ret[i] = arr[i].listener || arr[i];\n }\n return ret;\n}\n","'use strict';\n\nif (typeof process === 'undefined' ||\n !process.version ||\n process.version.indexOf('v0.') === 0 ||\n process.version.indexOf('v1.') === 0 && process.version.indexOf('v1.8.') !== 0) {\n module.exports = { nextTick: nextTick };\n} else {\n module.exports = process\n}\n\nfunction nextTick(fn, arg1, arg2, arg3) {\n if (typeof fn !== 'function') {\n throw new TypeError('\"callback\" argument must be a function');\n }\n var len = arguments.length;\n var args, i;\n switch (len) {\n case 0:\n case 1:\n return process.nextTick(fn);\n case 2:\n return process.nextTick(function afterTickOne() {\n fn.call(null, arg1);\n });\n case 3:\n return process.nextTick(function afterTickTwo() {\n fn.call(null, arg1, arg2);\n });\n case 4:\n return process.nextTick(function afterTickThree() {\n fn.call(null, arg1, arg2, arg3);\n });\n default:\n args = new Array(len - 1);\n i = 0;\n while (i < args.length) {\n args[i++] = arguments[i];\n }\n return process.nextTick(function afterTick() {\n fn.apply(null, args);\n });\n }\n}\n\n","/* eslint-disable node/no-deprecated-api */\nvar buffer = require('buffer')\nvar Buffer = buffer.Buffer\n\n// alternative to using Object.keys for old browsers\nfunction copyProps (src, dst) {\n for (var key in src) {\n dst[key] = src[key]\n }\n}\nif (Buffer.from && Buffer.alloc && Buffer.allocUnsafe && Buffer.allocUnsafeSlow) {\n module.exports = buffer\n} else {\n // Copy properties from require('buffer')\n copyProps(buffer, exports)\n exports.Buffer = SafeBuffer\n}\n\nfunction SafeBuffer (arg, encodingOrOffset, length) {\n return Buffer(arg, encodingOrOffset, length)\n}\n\n// Copy static methods from Buffer\ncopyProps(Buffer, SafeBuffer)\n\nSafeBuffer.from = function (arg, encodingOrOffset, length) {\n if (typeof arg === 'number') {\n throw new TypeError('Argument must not be a number')\n }\n return Buffer(arg, encodingOrOffset, length)\n}\n\nSafeBuffer.alloc = function (size, fill, encoding) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n var buf = Buffer(size)\n if (fill !== undefined) {\n if (typeof encoding === 'string') {\n buf.fill(fill, encoding)\n } else {\n buf.fill(fill)\n }\n } else {\n buf.fill(0)\n }\n return buf\n}\n\nSafeBuffer.allocUnsafe = function (size) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n return Buffer(size)\n}\n\nSafeBuffer.allocUnsafeSlow = function (size) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n return buffer.SlowBuffer(size)\n}\n","'use strict';\n\n\nvar TYPED_OK = (typeof Uint8Array !== 'undefined') &&\n (typeof Uint16Array !== 'undefined') &&\n (typeof Int32Array !== 'undefined');\n\nfunction _has(obj, key) {\n return Object.prototype.hasOwnProperty.call(obj, key);\n}\n\nexports.assign = function (obj /*from1, from2, from3, ...*/) {\n var sources = Array.prototype.slice.call(arguments, 1);\n while (sources.length) {\n var source = sources.shift();\n if (!source) { continue; }\n\n if (typeof source !== 'object') {\n throw new TypeError(source + 'must be non-object');\n }\n\n for (var p in source) {\n if (_has(source, p)) {\n obj[p] = source[p];\n }\n }\n }\n\n return obj;\n};\n\n\n// reduce buffer size, avoiding mem copy\nexports.shrinkBuf = function (buf, size) {\n if (buf.length === size) { return buf; }\n if (buf.subarray) { return buf.subarray(0, size); }\n buf.length = size;\n return buf;\n};\n\n\nvar fnTyped = {\n arraySet: function (dest, src, src_offs, len, dest_offs) {\n if (src.subarray && dest.subarray) {\n dest.set(src.subarray(src_offs, src_offs + len), dest_offs);\n return;\n }\n // Fallback to ordinary array\n for (var i = 0; i < len; i++) {\n dest[dest_offs + i] = src[src_offs + i];\n }\n },\n // Join array of chunks to single array.\n flattenChunks: function (chunks) {\n var i, l, len, pos, chunk, result;\n\n // calculate data length\n len = 0;\n for (i = 0, l = chunks.length; i < l; i++) {\n len += chunks[i].length;\n }\n\n // join chunks\n result = new Uint8Array(len);\n pos = 0;\n for (i = 0, l = chunks.length; i < l; i++) {\n chunk = chunks[i];\n result.set(chunk, pos);\n pos += chunk.length;\n }\n\n return result;\n }\n};\n\nvar fnUntyped = {\n arraySet: function (dest, src, src_offs, len, dest_offs) {\n for (var i = 0; i < len; i++) {\n dest[dest_offs + i] = src[src_offs + i];\n }\n },\n // Join array of chunks to single array.\n flattenChunks: function (chunks) {\n return [].concat.apply([], chunks);\n }\n};\n\n\n// Enable/Disable typed arrays use, for testing\n//\nexports.setTyped = function (on) {\n if (on) {\n exports.Buf8 = Uint8Array;\n exports.Buf16 = Uint16Array;\n exports.Buf32 = Int32Array;\n exports.assign(exports, fnTyped);\n } else {\n exports.Buf8 = Array;\n exports.Buf16 = Array;\n exports.Buf32 = Array;\n exports.assign(exports, fnUntyped);\n }\n};\n\nexports.setTyped(TYPED_OK);\n","module.exports = require('buffer').Buffer;\n","/*!\n * The buffer module from node.js, for the browser.\n *\n * @author Feross Aboukhadijeh \n * @license MIT\n */\n/* eslint-disable no-proto */\n\n'use strict'\n\nvar base64 = require('base64-js')\nvar ieee754 = require('ieee754')\n\nexports.Buffer = Buffer\nexports.SlowBuffer = SlowBuffer\nexports.INSPECT_MAX_BYTES = 50\n\nvar K_MAX_LENGTH = 0x7fffffff\nexports.kMaxLength = K_MAX_LENGTH\n\n/**\n * If `Buffer.TYPED_ARRAY_SUPPORT`:\n * === true Use Uint8Array implementation (fastest)\n * === false Print warning and recommend using `buffer` v4.x which has an Object\n * implementation (most compatible, even IE6)\n *\n * Browsers that support typed arrays are IE 10+, Firefox 4+, Chrome 7+, Safari 5.1+,\n * Opera 11.6+, iOS 4.2+.\n *\n * We report that the browser does not support typed arrays if the are not subclassable\n * using __proto__. Firefox 4-29 lacks support for adding new properties to `Uint8Array`\n * (See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438). IE 10 lacks support\n * for __proto__ and has a buggy typed array implementation.\n */\nBuffer.TYPED_ARRAY_SUPPORT = typedArraySupport()\n\nif (!Buffer.TYPED_ARRAY_SUPPORT && typeof console !== 'undefined' &&\n typeof console.error === 'function') {\n console.error(\n 'This browser lacks typed array (Uint8Array) support which is required by ' +\n '`buffer` v5.x. Use `buffer` v4.x if you require old browser support.'\n )\n}\n\nfunction typedArraySupport () {\n // Can typed array instances can be augmented?\n try {\n var arr = new Uint8Array(1)\n arr.__proto__ = {__proto__: Uint8Array.prototype, foo: function () { return 42 }}\n return arr.foo() === 42\n } catch (e) {\n return false\n }\n}\n\nObject.defineProperty(Buffer.prototype, 'parent', {\n get: function () {\n if (!(this instanceof Buffer)) {\n return undefined\n }\n return this.buffer\n }\n})\n\nObject.defineProperty(Buffer.prototype, 'offset', {\n get: function () {\n if (!(this instanceof Buffer)) {\n return undefined\n }\n return this.byteOffset\n }\n})\n\nfunction createBuffer (length) {\n if (length > K_MAX_LENGTH) {\n throw new RangeError('Invalid typed array length')\n }\n // Return an augmented `Uint8Array` instance\n var buf = new Uint8Array(length)\n buf.__proto__ = Buffer.prototype\n return buf\n}\n\n/**\n * The Buffer constructor returns instances of `Uint8Array` that have their\n * prototype changed to `Buffer.prototype`. Furthermore, `Buffer` is a subclass of\n * `Uint8Array`, so the returned instances will have all the node `Buffer` methods\n * and the `Uint8Array` methods. Square bracket notation works as expected -- it\n * returns a single octet.\n *\n * The `Uint8Array` prototype remains unmodified.\n */\n\nfunction Buffer (arg, encodingOrOffset, length) {\n // Common case.\n if (typeof arg === 'number') {\n if (typeof encodingOrOffset === 'string') {\n throw new Error(\n 'If encoding is specified then the first argument must be a string'\n )\n }\n return allocUnsafe(arg)\n }\n return from(arg, encodingOrOffset, length)\n}\n\n// Fix subarray() in ES2016. See: https://github.com/feross/buffer/pull/97\nif (typeof Symbol !== 'undefined' && Symbol.species &&\n Buffer[Symbol.species] === Buffer) {\n Object.defineProperty(Buffer, Symbol.species, {\n value: null,\n configurable: true,\n enumerable: false,\n writable: false\n })\n}\n\nBuffer.poolSize = 8192 // not used by this implementation\n\nfunction from (value, encodingOrOffset, length) {\n if (typeof value === 'number') {\n throw new TypeError('\"value\" argument must not be a number')\n }\n\n if (isArrayBuffer(value) || (value && isArrayBuffer(value.buffer))) {\n return fromArrayBuffer(value, encodingOrOffset, length)\n }\n\n if (typeof value === 'string') {\n return fromString(value, encodingOrOffset)\n }\n\n return fromObject(value)\n}\n\n/**\n * Functionally equivalent to Buffer(arg, encoding) but throws a TypeError\n * if value is a number.\n * Buffer.from(str[, encoding])\n * Buffer.from(array)\n * Buffer.from(buffer)\n * Buffer.from(arrayBuffer[, byteOffset[, length]])\n **/\nBuffer.from = function (value, encodingOrOffset, length) {\n return from(value, encodingOrOffset, length)\n}\n\n// Note: Change prototype *after* Buffer.from is defined to workaround Chrome bug:\n// https://github.com/feross/buffer/pull/148\nBuffer.prototype.__proto__ = Uint8Array.prototype\nBuffer.__proto__ = Uint8Array\n\nfunction assertSize (size) {\n if (typeof size !== 'number') {\n throw new TypeError('\"size\" argument must be of type number')\n } else if (size < 0) {\n throw new RangeError('\"size\" argument must not be negative')\n }\n}\n\nfunction alloc (size, fill, encoding) {\n assertSize(size)\n if (size <= 0) {\n return createBuffer(size)\n }\n if (fill !== undefined) {\n // Only pay attention to encoding if it's a string. This\n // prevents accidentally sending in a number that would\n // be interpretted as a start offset.\n return typeof encoding === 'string'\n ? createBuffer(size).fill(fill, encoding)\n : createBuffer(size).fill(fill)\n }\n return createBuffer(size)\n}\n\n/**\n * Creates a new filled Buffer instance.\n * alloc(size[, fill[, encoding]])\n **/\nBuffer.alloc = function (size, fill, encoding) {\n return alloc(size, fill, encoding)\n}\n\nfunction allocUnsafe (size) {\n assertSize(size)\n return createBuffer(size < 0 ? 0 : checked(size) | 0)\n}\n\n/**\n * Equivalent to Buffer(num), by default creates a non-zero-filled Buffer instance.\n * */\nBuffer.allocUnsafe = function (size) {\n return allocUnsafe(size)\n}\n/**\n * Equivalent to SlowBuffer(num), by default creates a non-zero-filled Buffer instance.\n */\nBuffer.allocUnsafeSlow = function (size) {\n return allocUnsafe(size)\n}\n\nfunction fromString (string, encoding) {\n if (typeof encoding !== 'string' || encoding === '') {\n encoding = 'utf8'\n }\n\n if (!Buffer.isEncoding(encoding)) {\n throw new TypeError('Unknown encoding: ' + encoding)\n }\n\n var length = byteLength(string, encoding) | 0\n var buf = createBuffer(length)\n\n var actual = buf.write(string, encoding)\n\n if (actual !== length) {\n // Writing a hex string, for example, that contains invalid characters will\n // cause everything after the first invalid character to be ignored. (e.g.\n // 'abxxcd' will be treated as 'ab')\n buf = buf.slice(0, actual)\n }\n\n return buf\n}\n\nfunction fromArrayLike (array) {\n var length = array.length < 0 ? 0 : checked(array.length) | 0\n var buf = createBuffer(length)\n for (var i = 0; i < length; i += 1) {\n buf[i] = array[i] & 255\n }\n return buf\n}\n\nfunction fromArrayBuffer (array, byteOffset, length) {\n if (byteOffset < 0 || array.byteLength < byteOffset) {\n throw new RangeError('\"offset\" is outside of buffer bounds')\n }\n\n if (array.byteLength < byteOffset + (length || 0)) {\n throw new RangeError('\"length\" is outside of buffer bounds')\n }\n\n var buf\n if (byteOffset === undefined && length === undefined) {\n buf = new Uint8Array(array)\n } else if (length === undefined) {\n buf = new Uint8Array(array, byteOffset)\n } else {\n buf = new Uint8Array(array, byteOffset, length)\n }\n\n // Return an augmented `Uint8Array` instance\n buf.__proto__ = Buffer.prototype\n return buf\n}\n\nfunction fromObject (obj) {\n if (Buffer.isBuffer(obj)) {\n var len = checked(obj.length) | 0\n var buf = createBuffer(len)\n\n if (buf.length === 0) {\n return buf\n }\n\n obj.copy(buf, 0, 0, len)\n return buf\n }\n\n if (obj) {\n if (ArrayBuffer.isView(obj) || 'length' in obj) {\n if (typeof obj.length !== 'number' || numberIsNaN(obj.length)) {\n return createBuffer(0)\n }\n return fromArrayLike(obj)\n }\n\n if (obj.type === 'Buffer' && Array.isArray(obj.data)) {\n return fromArrayLike(obj.data)\n }\n }\n\n throw new TypeError('The first argument must be one of type string, Buffer, ArrayBuffer, Array, or Array-like Object.')\n}\n\nfunction checked (length) {\n // Note: cannot use `length < K_MAX_LENGTH` here because that fails when\n // length is NaN (which is otherwise coerced to zero.)\n if (length >= K_MAX_LENGTH) {\n throw new RangeError('Attempt to allocate Buffer larger than maximum ' +\n 'size: 0x' + K_MAX_LENGTH.toString(16) + ' bytes')\n }\n return length | 0\n}\n\nfunction SlowBuffer (length) {\n if (+length != length) { // eslint-disable-line eqeqeq\n length = 0\n }\n return Buffer.alloc(+length)\n}\n\nBuffer.isBuffer = function isBuffer (b) {\n return b != null && b._isBuffer === true\n}\n\nBuffer.compare = function compare (a, b) {\n if (!Buffer.isBuffer(a) || !Buffer.isBuffer(b)) {\n throw new TypeError('Arguments must be Buffers')\n }\n\n if (a === b) return 0\n\n var x = a.length\n var y = b.length\n\n for (var i = 0, len = Math.min(x, y); i < len; ++i) {\n if (a[i] !== b[i]) {\n x = a[i]\n y = b[i]\n break\n }\n }\n\n if (x < y) return -1\n if (y < x) return 1\n return 0\n}\n\nBuffer.isEncoding = function isEncoding (encoding) {\n switch (String(encoding).toLowerCase()) {\n case 'hex':\n case 'utf8':\n case 'utf-8':\n case 'ascii':\n case 'latin1':\n case 'binary':\n case 'base64':\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return true\n default:\n return false\n }\n}\n\nBuffer.concat = function concat (list, length) {\n if (!Array.isArray(list)) {\n throw new TypeError('\"list\" argument must be an Array of Buffers')\n }\n\n if (list.length === 0) {\n return Buffer.alloc(0)\n }\n\n var i\n if (length === undefined) {\n length = 0\n for (i = 0; i < list.length; ++i) {\n length += list[i].length\n }\n }\n\n var buffer = Buffer.allocUnsafe(length)\n var pos = 0\n for (i = 0; i < list.length; ++i) {\n var buf = list[i]\n if (ArrayBuffer.isView(buf)) {\n buf = Buffer.from(buf)\n }\n if (!Buffer.isBuffer(buf)) {\n throw new TypeError('\"list\" argument must be an Array of Buffers')\n }\n buf.copy(buffer, pos)\n pos += buf.length\n }\n return buffer\n}\n\nfunction byteLength (string, encoding) {\n if (Buffer.isBuffer(string)) {\n return string.length\n }\n if (ArrayBuffer.isView(string) || isArrayBuffer(string)) {\n return string.byteLength\n }\n if (typeof string !== 'string') {\n string = '' + string\n }\n\n var len = string.length\n if (len === 0) return 0\n\n // Use a for loop to avoid recursion\n var loweredCase = false\n for (;;) {\n switch (encoding) {\n case 'ascii':\n case 'latin1':\n case 'binary':\n return len\n case 'utf8':\n case 'utf-8':\n case undefined:\n return utf8ToBytes(string).length\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return len * 2\n case 'hex':\n return len >>> 1\n case 'base64':\n return base64ToBytes(string).length\n default:\n if (loweredCase) return utf8ToBytes(string).length // assume utf8\n encoding = ('' + encoding).toLowerCase()\n loweredCase = true\n }\n }\n}\nBuffer.byteLength = byteLength\n\nfunction slowToString (encoding, start, end) {\n var loweredCase = false\n\n // No need to verify that \"this.length <= MAX_UINT32\" since it's a read-only\n // property of a typed array.\n\n // This behaves neither like String nor Uint8Array in that we set start/end\n // to their upper/lower bounds if the value passed is out of range.\n // undefined is handled specially as per ECMA-262 6th Edition,\n // Section 13.3.3.7 Runtime Semantics: KeyedBindingInitialization.\n if (start === undefined || start < 0) {\n start = 0\n }\n // Return early if start > this.length. Done here to prevent potential uint32\n // coercion fail below.\n if (start > this.length) {\n return ''\n }\n\n if (end === undefined || end > this.length) {\n end = this.length\n }\n\n if (end <= 0) {\n return ''\n }\n\n // Force coersion to uint32. This will also coerce falsey/NaN values to 0.\n end >>>= 0\n start >>>= 0\n\n if (end <= start) {\n return ''\n }\n\n if (!encoding) encoding = 'utf8'\n\n while (true) {\n switch (encoding) {\n case 'hex':\n return hexSlice(this, start, end)\n\n case 'utf8':\n case 'utf-8':\n return utf8Slice(this, start, end)\n\n case 'ascii':\n return asciiSlice(this, start, end)\n\n case 'latin1':\n case 'binary':\n return latin1Slice(this, start, end)\n\n case 'base64':\n return base64Slice(this, start, end)\n\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return utf16leSlice(this, start, end)\n\n default:\n if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n encoding = (encoding + '').toLowerCase()\n loweredCase = true\n }\n }\n}\n\n// This property is used by `Buffer.isBuffer` (and the `is-buffer` npm package)\n// to detect a Buffer instance. It's not possible to use `instanceof Buffer`\n// reliably in a browserify context because there could be multiple different\n// copies of the 'buffer' package in use. This method works even for Buffer\n// instances that were created from another copy of the `buffer` package.\n// See: https://github.com/feross/buffer/issues/154\nBuffer.prototype._isBuffer = true\n\nfunction swap (b, n, m) {\n var i = b[n]\n b[n] = b[m]\n b[m] = i\n}\n\nBuffer.prototype.swap16 = function swap16 () {\n var len = this.length\n if (len % 2 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 16-bits')\n }\n for (var i = 0; i < len; i += 2) {\n swap(this, i, i + 1)\n }\n return this\n}\n\nBuffer.prototype.swap32 = function swap32 () {\n var len = this.length\n if (len % 4 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 32-bits')\n }\n for (var i = 0; i < len; i += 4) {\n swap(this, i, i + 3)\n swap(this, i + 1, i + 2)\n }\n return this\n}\n\nBuffer.prototype.swap64 = function swap64 () {\n var len = this.length\n if (len % 8 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 64-bits')\n }\n for (var i = 0; i < len; i += 8) {\n swap(this, i, i + 7)\n swap(this, i + 1, i + 6)\n swap(this, i + 2, i + 5)\n swap(this, i + 3, i + 4)\n }\n return this\n}\n\nBuffer.prototype.toString = function toString () {\n var length = this.length\n if (length === 0) return ''\n if (arguments.length === 0) return utf8Slice(this, 0, length)\n return slowToString.apply(this, arguments)\n}\n\nBuffer.prototype.toLocaleString = Buffer.prototype.toString\n\nBuffer.prototype.equals = function equals (b) {\n if (!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer')\n if (this === b) return true\n return Buffer.compare(this, b) === 0\n}\n\nBuffer.prototype.inspect = function inspect () {\n var str = ''\n var max = exports.INSPECT_MAX_BYTES\n if (this.length > 0) {\n str = this.toString('hex', 0, max).match(/.{2}/g).join(' ')\n if (this.length > max) str += ' ... '\n }\n return ''\n}\n\nBuffer.prototype.compare = function compare (target, start, end, thisStart, thisEnd) {\n if (!Buffer.isBuffer(target)) {\n throw new TypeError('Argument must be a Buffer')\n }\n\n if (start === undefined) {\n start = 0\n }\n if (end === undefined) {\n end = target ? target.length : 0\n }\n if (thisStart === undefined) {\n thisStart = 0\n }\n if (thisEnd === undefined) {\n thisEnd = this.length\n }\n\n if (start < 0 || end > target.length || thisStart < 0 || thisEnd > this.length) {\n throw new RangeError('out of range index')\n }\n\n if (thisStart >= thisEnd && start >= end) {\n return 0\n }\n if (thisStart >= thisEnd) {\n return -1\n }\n if (start >= end) {\n return 1\n }\n\n start >>>= 0\n end >>>= 0\n thisStart >>>= 0\n thisEnd >>>= 0\n\n if (this === target) return 0\n\n var x = thisEnd - thisStart\n var y = end - start\n var len = Math.min(x, y)\n\n var thisCopy = this.slice(thisStart, thisEnd)\n var targetCopy = target.slice(start, end)\n\n for (var i = 0; i < len; ++i) {\n if (thisCopy[i] !== targetCopy[i]) {\n x = thisCopy[i]\n y = targetCopy[i]\n break\n }\n }\n\n if (x < y) return -1\n if (y < x) return 1\n return 0\n}\n\n// Finds either the first index of `val` in `buffer` at offset >= `byteOffset`,\n// OR the last index of `val` in `buffer` at offset <= `byteOffset`.\n//\n// Arguments:\n// - buffer - a Buffer to search\n// - val - a string, Buffer, or number\n// - byteOffset - an index into `buffer`; will be clamped to an int32\n// - encoding - an optional encoding, relevant is val is a string\n// - dir - true for indexOf, false for lastIndexOf\nfunction bidirectionalIndexOf (buffer, val, byteOffset, encoding, dir) {\n // Empty buffer means no match\n if (buffer.length === 0) return -1\n\n // Normalize byteOffset\n if (typeof byteOffset === 'string') {\n encoding = byteOffset\n byteOffset = 0\n } else if (byteOffset > 0x7fffffff) {\n byteOffset = 0x7fffffff\n } else if (byteOffset < -0x80000000) {\n byteOffset = -0x80000000\n }\n byteOffset = +byteOffset // Coerce to Number.\n if (numberIsNaN(byteOffset)) {\n // byteOffset: it it's undefined, null, NaN, \"foo\", etc, search whole buffer\n byteOffset = dir ? 0 : (buffer.length - 1)\n }\n\n // Normalize byteOffset: negative offsets start from the end of the buffer\n if (byteOffset < 0) byteOffset = buffer.length + byteOffset\n if (byteOffset >= buffer.length) {\n if (dir) return -1\n else byteOffset = buffer.length - 1\n } else if (byteOffset < 0) {\n if (dir) byteOffset = 0\n else return -1\n }\n\n // Normalize val\n if (typeof val === 'string') {\n val = Buffer.from(val, encoding)\n }\n\n // Finally, search either indexOf (if dir is true) or lastIndexOf\n if (Buffer.isBuffer(val)) {\n // Special case: looking for empty string/buffer always fails\n if (val.length === 0) {\n return -1\n }\n return arrayIndexOf(buffer, val, byteOffset, encoding, dir)\n } else if (typeof val === 'number') {\n val = val & 0xFF // Search for a byte value [0-255]\n if (typeof Uint8Array.prototype.indexOf === 'function') {\n if (dir) {\n return Uint8Array.prototype.indexOf.call(buffer, val, byteOffset)\n } else {\n return Uint8Array.prototype.lastIndexOf.call(buffer, val, byteOffset)\n }\n }\n return arrayIndexOf(buffer, [ val ], byteOffset, encoding, dir)\n }\n\n throw new TypeError('val must be string, number or Buffer')\n}\n\nfunction arrayIndexOf (arr, val, byteOffset, encoding, dir) {\n var indexSize = 1\n var arrLength = arr.length\n var valLength = val.length\n\n if (encoding !== undefined) {\n encoding = String(encoding).toLowerCase()\n if (encoding === 'ucs2' || encoding === 'ucs-2' ||\n encoding === 'utf16le' || encoding === 'utf-16le') {\n if (arr.length < 2 || val.length < 2) {\n return -1\n }\n indexSize = 2\n arrLength /= 2\n valLength /= 2\n byteOffset /= 2\n }\n }\n\n function read (buf, i) {\n if (indexSize === 1) {\n return buf[i]\n } else {\n return buf.readUInt16BE(i * indexSize)\n }\n }\n\n var i\n if (dir) {\n var foundIndex = -1\n for (i = byteOffset; i < arrLength; i++) {\n if (read(arr, i) === read(val, foundIndex === -1 ? 0 : i - foundIndex)) {\n if (foundIndex === -1) foundIndex = i\n if (i - foundIndex + 1 === valLength) return foundIndex * indexSize\n } else {\n if (foundIndex !== -1) i -= i - foundIndex\n foundIndex = -1\n }\n }\n } else {\n if (byteOffset + valLength > arrLength) byteOffset = arrLength - valLength\n for (i = byteOffset; i >= 0; i--) {\n var found = true\n for (var j = 0; j < valLength; j++) {\n if (read(arr, i + j) !== read(val, j)) {\n found = false\n break\n }\n }\n if (found) return i\n }\n }\n\n return -1\n}\n\nBuffer.prototype.includes = function includes (val, byteOffset, encoding) {\n return this.indexOf(val, byteOffset, encoding) !== -1\n}\n\nBuffer.prototype.indexOf = function indexOf (val, byteOffset, encoding) {\n return bidirectionalIndexOf(this, val, byteOffset, encoding, true)\n}\n\nBuffer.prototype.lastIndexOf = function lastIndexOf (val, byteOffset, encoding) {\n return bidirectionalIndexOf(this, val, byteOffset, encoding, false)\n}\n\nfunction hexWrite (buf, string, offset, length) {\n offset = Number(offset) || 0\n var remaining = buf.length - offset\n if (!length) {\n length = remaining\n } else {\n length = Number(length)\n if (length > remaining) {\n length = remaining\n }\n }\n\n var strLen = string.length\n\n if (length > strLen / 2) {\n length = strLen / 2\n }\n for (var i = 0; i < length; ++i) {\n var parsed = parseInt(string.substr(i * 2, 2), 16)\n if (numberIsNaN(parsed)) return i\n buf[offset + i] = parsed\n }\n return i\n}\n\nfunction utf8Write (buf, string, offset, length) {\n return blitBuffer(utf8ToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nfunction asciiWrite (buf, string, offset, length) {\n return blitBuffer(asciiToBytes(string), buf, offset, length)\n}\n\nfunction latin1Write (buf, string, offset, length) {\n return asciiWrite(buf, string, offset, length)\n}\n\nfunction base64Write (buf, string, offset, length) {\n return blitBuffer(base64ToBytes(string), buf, offset, length)\n}\n\nfunction ucs2Write (buf, string, offset, length) {\n return blitBuffer(utf16leToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nBuffer.prototype.write = function write (string, offset, length, encoding) {\n // Buffer#write(string)\n if (offset === undefined) {\n encoding = 'utf8'\n length = this.length\n offset = 0\n // Buffer#write(string, encoding)\n } else if (length === undefined && typeof offset === 'string') {\n encoding = offset\n length = this.length\n offset = 0\n // Buffer#write(string, offset[, length][, encoding])\n } else if (isFinite(offset)) {\n offset = offset >>> 0\n if (isFinite(length)) {\n length = length >>> 0\n if (encoding === undefined) encoding = 'utf8'\n } else {\n encoding = length\n length = undefined\n }\n } else {\n throw new Error(\n 'Buffer.write(string, encoding, offset[, length]) is no longer supported'\n )\n }\n\n var remaining = this.length - offset\n if (length === undefined || length > remaining) length = remaining\n\n if ((string.length > 0 && (length < 0 || offset < 0)) || offset > this.length) {\n throw new RangeError('Attempt to write outside buffer bounds')\n }\n\n if (!encoding) encoding = 'utf8'\n\n var loweredCase = false\n for (;;) {\n switch (encoding) {\n case 'hex':\n return hexWrite(this, string, offset, length)\n\n case 'utf8':\n case 'utf-8':\n return utf8Write(this, string, offset, length)\n\n case 'ascii':\n return asciiWrite(this, string, offset, length)\n\n case 'latin1':\n case 'binary':\n return latin1Write(this, string, offset, length)\n\n case 'base64':\n // Warning: maxLength not taken into account in base64Write\n return base64Write(this, string, offset, length)\n\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return ucs2Write(this, string, offset, length)\n\n default:\n if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n encoding = ('' + encoding).toLowerCase()\n loweredCase = true\n }\n }\n}\n\nBuffer.prototype.toJSON = function toJSON () {\n return {\n type: 'Buffer',\n data: Array.prototype.slice.call(this._arr || this, 0)\n }\n}\n\nfunction base64Slice (buf, start, end) {\n if (start === 0 && end === buf.length) {\n return base64.fromByteArray(buf)\n } else {\n return base64.fromByteArray(buf.slice(start, end))\n }\n}\n\nfunction utf8Slice (buf, start, end) {\n end = Math.min(buf.length, end)\n var res = []\n\n var i = start\n while (i < end) {\n var firstByte = buf[i]\n var codePoint = null\n var bytesPerSequence = (firstByte > 0xEF) ? 4\n : (firstByte > 0xDF) ? 3\n : (firstByte > 0xBF) ? 2\n : 1\n\n if (i + bytesPerSequence <= end) {\n var secondByte, thirdByte, fourthByte, tempCodePoint\n\n switch (bytesPerSequence) {\n case 1:\n if (firstByte < 0x80) {\n codePoint = firstByte\n }\n break\n case 2:\n secondByte = buf[i + 1]\n if ((secondByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0x1F) << 0x6 | (secondByte & 0x3F)\n if (tempCodePoint > 0x7F) {\n codePoint = tempCodePoint\n }\n }\n break\n case 3:\n secondByte = buf[i + 1]\n thirdByte = buf[i + 2]\n if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0xF) << 0xC | (secondByte & 0x3F) << 0x6 | (thirdByte & 0x3F)\n if (tempCodePoint > 0x7FF && (tempCodePoint < 0xD800 || tempCodePoint > 0xDFFF)) {\n codePoint = tempCodePoint\n }\n }\n break\n case 4:\n secondByte = buf[i + 1]\n thirdByte = buf[i + 2]\n fourthByte = buf[i + 3]\n if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80 && (fourthByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0xF) << 0x12 | (secondByte & 0x3F) << 0xC | (thirdByte & 0x3F) << 0x6 | (fourthByte & 0x3F)\n if (tempCodePoint > 0xFFFF && tempCodePoint < 0x110000) {\n codePoint = tempCodePoint\n }\n }\n }\n }\n\n if (codePoint === null) {\n // we did not generate a valid codePoint so insert a\n // replacement char (U+FFFD) and advance only 1 byte\n codePoint = 0xFFFD\n bytesPerSequence = 1\n } else if (codePoint > 0xFFFF) {\n // encode to utf16 (surrogate pair dance)\n codePoint -= 0x10000\n res.push(codePoint >>> 10 & 0x3FF | 0xD800)\n codePoint = 0xDC00 | codePoint & 0x3FF\n }\n\n res.push(codePoint)\n i += bytesPerSequence\n }\n\n return decodeCodePointsArray(res)\n}\n\n// Based on http://stackoverflow.com/a/22747272/680742, the browser with\n// the lowest limit is Chrome, with 0x10000 args.\n// We go 1 magnitude less, for safety\nvar MAX_ARGUMENTS_LENGTH = 0x1000\n\nfunction decodeCodePointsArray (codePoints) {\n var len = codePoints.length\n if (len <= MAX_ARGUMENTS_LENGTH) {\n return String.fromCharCode.apply(String, codePoints) // avoid extra slice()\n }\n\n // Decode in chunks to avoid \"call stack size exceeded\".\n var res = ''\n var i = 0\n while (i < len) {\n res += String.fromCharCode.apply(\n String,\n codePoints.slice(i, i += MAX_ARGUMENTS_LENGTH)\n )\n }\n return res\n}\n\nfunction asciiSlice (buf, start, end) {\n var ret = ''\n end = Math.min(buf.length, end)\n\n for (var i = start; i < end; ++i) {\n ret += String.fromCharCode(buf[i] & 0x7F)\n }\n return ret\n}\n\nfunction latin1Slice (buf, start, end) {\n var ret = ''\n end = Math.min(buf.length, end)\n\n for (var i = start; i < end; ++i) {\n ret += String.fromCharCode(buf[i])\n }\n return ret\n}\n\nfunction hexSlice (buf, start, end) {\n var len = buf.length\n\n if (!start || start < 0) start = 0\n if (!end || end < 0 || end > len) end = len\n\n var out = ''\n for (var i = start; i < end; ++i) {\n out += toHex(buf[i])\n }\n return out\n}\n\nfunction utf16leSlice (buf, start, end) {\n var bytes = buf.slice(start, end)\n var res = ''\n for (var i = 0; i < bytes.length; i += 2) {\n res += String.fromCharCode(bytes[i] + (bytes[i + 1] * 256))\n }\n return res\n}\n\nBuffer.prototype.slice = function slice (start, end) {\n var len = this.length\n start = ~~start\n end = end === undefined ? len : ~~end\n\n if (start < 0) {\n start += len\n if (start < 0) start = 0\n } else if (start > len) {\n start = len\n }\n\n if (end < 0) {\n end += len\n if (end < 0) end = 0\n } else if (end > len) {\n end = len\n }\n\n if (end < start) end = start\n\n var newBuf = this.subarray(start, end)\n // Return an augmented `Uint8Array` instance\n newBuf.__proto__ = Buffer.prototype\n return newBuf\n}\n\n/*\n * Need to make sure that buffer isn't trying to write out of bounds.\n */\nfunction checkOffset (offset, ext, length) {\n if ((offset % 1) !== 0 || offset < 0) throw new RangeError('offset is not uint')\n if (offset + ext > length) throw new RangeError('Trying to access beyond buffer length')\n}\n\nBuffer.prototype.readUIntLE = function readUIntLE (offset, byteLength, noAssert) {\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n var val = this[offset]\n var mul = 1\n var i = 0\n while (++i < byteLength && (mul *= 0x100)) {\n val += this[offset + i] * mul\n }\n\n return val\n}\n\nBuffer.prototype.readUIntBE = function readUIntBE (offset, byteLength, noAssert) {\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) {\n checkOffset(offset, byteLength, this.length)\n }\n\n var val = this[offset + --byteLength]\n var mul = 1\n while (byteLength > 0 && (mul *= 0x100)) {\n val += this[offset + --byteLength] * mul\n }\n\n return val\n}\n\nBuffer.prototype.readUInt8 = function readUInt8 (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 1, this.length)\n return this[offset]\n}\n\nBuffer.prototype.readUInt16LE = function readUInt16LE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 2, this.length)\n return this[offset] | (this[offset + 1] << 8)\n}\n\nBuffer.prototype.readUInt16BE = function readUInt16BE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 2, this.length)\n return (this[offset] << 8) | this[offset + 1]\n}\n\nBuffer.prototype.readUInt32LE = function readUInt32LE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return ((this[offset]) |\n (this[offset + 1] << 8) |\n (this[offset + 2] << 16)) +\n (this[offset + 3] * 0x1000000)\n}\n\nBuffer.prototype.readUInt32BE = function readUInt32BE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return (this[offset] * 0x1000000) +\n ((this[offset + 1] << 16) |\n (this[offset + 2] << 8) |\n this[offset + 3])\n}\n\nBuffer.prototype.readIntLE = function readIntLE (offset, byteLength, noAssert) {\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n var val = this[offset]\n var mul = 1\n var i = 0\n while (++i < byteLength && (mul *= 0x100)) {\n val += this[offset + i] * mul\n }\n mul *= 0x80\n\n if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\n return val\n}\n\nBuffer.prototype.readIntBE = function readIntBE (offset, byteLength, noAssert) {\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n var i = byteLength\n var mul = 1\n var val = this[offset + --i]\n while (i > 0 && (mul *= 0x100)) {\n val += this[offset + --i] * mul\n }\n mul *= 0x80\n\n if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\n return val\n}\n\nBuffer.prototype.readInt8 = function readInt8 (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 1, this.length)\n if (!(this[offset] & 0x80)) return (this[offset])\n return ((0xff - this[offset] + 1) * -1)\n}\n\nBuffer.prototype.readInt16LE = function readInt16LE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 2, this.length)\n var val = this[offset] | (this[offset + 1] << 8)\n return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt16BE = function readInt16BE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 2, this.length)\n var val = this[offset + 1] | (this[offset] << 8)\n return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt32LE = function readInt32LE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return (this[offset]) |\n (this[offset + 1] << 8) |\n (this[offset + 2] << 16) |\n (this[offset + 3] << 24)\n}\n\nBuffer.prototype.readInt32BE = function readInt32BE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return (this[offset] << 24) |\n (this[offset + 1] << 16) |\n (this[offset + 2] << 8) |\n (this[offset + 3])\n}\n\nBuffer.prototype.readFloatLE = function readFloatLE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n return ieee754.read(this, offset, true, 23, 4)\n}\n\nBuffer.prototype.readFloatBE = function readFloatBE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n return ieee754.read(this, offset, false, 23, 4)\n}\n\nBuffer.prototype.readDoubleLE = function readDoubleLE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 8, this.length)\n return ieee754.read(this, offset, true, 52, 8)\n}\n\nBuffer.prototype.readDoubleBE = function readDoubleBE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 8, this.length)\n return ieee754.read(this, offset, false, 52, 8)\n}\n\nfunction checkInt (buf, value, offset, ext, max, min) {\n if (!Buffer.isBuffer(buf)) throw new TypeError('\"buffer\" argument must be a Buffer instance')\n if (value > max || value < min) throw new RangeError('\"value\" argument is out of bounds')\n if (offset + ext > buf.length) throw new RangeError('Index out of range')\n}\n\nBuffer.prototype.writeUIntLE = function writeUIntLE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) {\n var maxBytes = Math.pow(2, 8 * byteLength) - 1\n checkInt(this, value, offset, byteLength, maxBytes, 0)\n }\n\n var mul = 1\n var i = 0\n this[offset] = value & 0xFF\n while (++i < byteLength && (mul *= 0x100)) {\n this[offset + i] = (value / mul) & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeUIntBE = function writeUIntBE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) {\n var maxBytes = Math.pow(2, 8 * byteLength) - 1\n checkInt(this, value, offset, byteLength, maxBytes, 0)\n }\n\n var i = byteLength - 1\n var mul = 1\n this[offset + i] = value & 0xFF\n while (--i >= 0 && (mul *= 0x100)) {\n this[offset + i] = (value / mul) & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeUInt8 = function writeUInt8 (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 1, 0xff, 0)\n this[offset] = (value & 0xff)\n return offset + 1\n}\n\nBuffer.prototype.writeUInt16LE = function writeUInt16LE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n return offset + 2\n}\n\nBuffer.prototype.writeUInt16BE = function writeUInt16BE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n this[offset] = (value >>> 8)\n this[offset + 1] = (value & 0xff)\n return offset + 2\n}\n\nBuffer.prototype.writeUInt32LE = function writeUInt32LE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)\n this[offset + 3] = (value >>> 24)\n this[offset + 2] = (value >>> 16)\n this[offset + 1] = (value >>> 8)\n this[offset] = (value & 0xff)\n return offset + 4\n}\n\nBuffer.prototype.writeUInt32BE = function writeUInt32BE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)\n this[offset] = (value >>> 24)\n this[offset + 1] = (value >>> 16)\n this[offset + 2] = (value >>> 8)\n this[offset + 3] = (value & 0xff)\n return offset + 4\n}\n\nBuffer.prototype.writeIntLE = function writeIntLE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) {\n var limit = Math.pow(2, (8 * byteLength) - 1)\n\n checkInt(this, value, offset, byteLength, limit - 1, -limit)\n }\n\n var i = 0\n var mul = 1\n var sub = 0\n this[offset] = value & 0xFF\n while (++i < byteLength && (mul *= 0x100)) {\n if (value < 0 && sub === 0 && this[offset + i - 1] !== 0) {\n sub = 1\n }\n this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeIntBE = function writeIntBE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) {\n var limit = Math.pow(2, (8 * byteLength) - 1)\n\n checkInt(this, value, offset, byteLength, limit - 1, -limit)\n }\n\n var i = byteLength - 1\n var mul = 1\n var sub = 0\n this[offset + i] = value & 0xFF\n while (--i >= 0 && (mul *= 0x100)) {\n if (value < 0 && sub === 0 && this[offset + i + 1] !== 0) {\n sub = 1\n }\n this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeInt8 = function writeInt8 (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 1, 0x7f, -0x80)\n if (value < 0) value = 0xff + value + 1\n this[offset] = (value & 0xff)\n return offset + 1\n}\n\nBuffer.prototype.writeInt16LE = function writeInt16LE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n return offset + 2\n}\n\nBuffer.prototype.writeInt16BE = function writeInt16BE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n this[offset] = (value >>> 8)\n this[offset + 1] = (value & 0xff)\n return offset + 2\n}\n\nBuffer.prototype.writeInt32LE = function writeInt32LE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n this[offset + 2] = (value >>> 16)\n this[offset + 3] = (value >>> 24)\n return offset + 4\n}\n\nBuffer.prototype.writeInt32BE = function writeInt32BE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n if (value < 0) value = 0xffffffff + value + 1\n this[offset] = (value >>> 24)\n this[offset + 1] = (value >>> 16)\n this[offset + 2] = (value >>> 8)\n this[offset + 3] = (value & 0xff)\n return offset + 4\n}\n\nfunction checkIEEE754 (buf, value, offset, ext, max, min) {\n if (offset + ext > buf.length) throw new RangeError('Index out of range')\n if (offset < 0) throw new RangeError('Index out of range')\n}\n\nfunction writeFloat (buf, value, offset, littleEndian, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) {\n checkIEEE754(buf, value, offset, 4, 3.4028234663852886e+38, -3.4028234663852886e+38)\n }\n ieee754.write(buf, value, offset, littleEndian, 23, 4)\n return offset + 4\n}\n\nBuffer.prototype.writeFloatLE = function writeFloatLE (value, offset, noAssert) {\n return writeFloat(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeFloatBE = function writeFloatBE (value, offset, noAssert) {\n return writeFloat(this, value, offset, false, noAssert)\n}\n\nfunction writeDouble (buf, value, offset, littleEndian, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) {\n checkIEEE754(buf, value, offset, 8, 1.7976931348623157E+308, -1.7976931348623157E+308)\n }\n ieee754.write(buf, value, offset, littleEndian, 52, 8)\n return offset + 8\n}\n\nBuffer.prototype.writeDoubleLE = function writeDoubleLE (value, offset, noAssert) {\n return writeDouble(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeDoubleBE = function writeDoubleBE (value, offset, noAssert) {\n return writeDouble(this, value, offset, false, noAssert)\n}\n\n// copy(targetBuffer, targetStart=0, sourceStart=0, sourceEnd=buffer.length)\nBuffer.prototype.copy = function copy (target, targetStart, start, end) {\n if (!Buffer.isBuffer(target)) throw new TypeError('argument should be a Buffer')\n if (!start) start = 0\n if (!end && end !== 0) end = this.length\n if (targetStart >= target.length) targetStart = target.length\n if (!targetStart) targetStart = 0\n if (end > 0 && end < start) end = start\n\n // Copy 0 bytes; we're done\n if (end === start) return 0\n if (target.length === 0 || this.length === 0) return 0\n\n // Fatal error conditions\n if (targetStart < 0) {\n throw new RangeError('targetStart out of bounds')\n }\n if (start < 0 || start >= this.length) throw new RangeError('Index out of range')\n if (end < 0) throw new RangeError('sourceEnd out of bounds')\n\n // Are we oob?\n if (end > this.length) end = this.length\n if (target.length - targetStart < end - start) {\n end = target.length - targetStart + start\n }\n\n var len = end - start\n\n if (this === target && typeof Uint8Array.prototype.copyWithin === 'function') {\n // Use built-in when available, missing from IE11\n this.copyWithin(targetStart, start, end)\n } else if (this === target && start < targetStart && targetStart < end) {\n // descending copy from end\n for (var i = len - 1; i >= 0; --i) {\n target[i + targetStart] = this[i + start]\n }\n } else {\n Uint8Array.prototype.set.call(\n target,\n this.subarray(start, end),\n targetStart\n )\n }\n\n return len\n}\n\n// Usage:\n// buffer.fill(number[, offset[, end]])\n// buffer.fill(buffer[, offset[, end]])\n// buffer.fill(string[, offset[, end]][, encoding])\nBuffer.prototype.fill = function fill (val, start, end, encoding) {\n // Handle string cases:\n if (typeof val === 'string') {\n if (typeof start === 'string') {\n encoding = start\n start = 0\n end = this.length\n } else if (typeof end === 'string') {\n encoding = end\n end = this.length\n }\n if (encoding !== undefined && typeof encoding !== 'string') {\n throw new TypeError('encoding must be a string')\n }\n if (typeof encoding === 'string' && !Buffer.isEncoding(encoding)) {\n throw new TypeError('Unknown encoding: ' + encoding)\n }\n if (val.length === 1) {\n var code = val.charCodeAt(0)\n if ((encoding === 'utf8' && code < 128) ||\n encoding === 'latin1') {\n // Fast path: If `val` fits into a single byte, use that numeric value.\n val = code\n }\n }\n } else if (typeof val === 'number') {\n val = val & 255\n }\n\n // Invalid ranges are not set to a default, so can range check early.\n if (start < 0 || this.length < start || this.length < end) {\n throw new RangeError('Out of range index')\n }\n\n if (end <= start) {\n return this\n }\n\n start = start >>> 0\n end = end === undefined ? this.length : end >>> 0\n\n if (!val) val = 0\n\n var i\n if (typeof val === 'number') {\n for (i = start; i < end; ++i) {\n this[i] = val\n }\n } else {\n var bytes = Buffer.isBuffer(val)\n ? val\n : new Buffer(val, encoding)\n var len = bytes.length\n if (len === 0) {\n throw new TypeError('The value \"' + val +\n '\" is invalid for argument \"value\"')\n }\n for (i = 0; i < end - start; ++i) {\n this[i + start] = bytes[i % len]\n }\n }\n\n return this\n}\n\n// HELPER FUNCTIONS\n// ================\n\nvar INVALID_BASE64_RE = /[^+/0-9A-Za-z-_]/g\n\nfunction base64clean (str) {\n // Node takes equal signs as end of the Base64 encoding\n str = str.split('=')[0]\n // Node strips out invalid characters like \\n and \\t from the string, base64-js does not\n str = str.trim().replace(INVALID_BASE64_RE, '')\n // Node converts strings with length < 2 to ''\n if (str.length < 2) return ''\n // Node allows for non-padded base64 strings (missing trailing ===), base64-js does not\n while (str.length % 4 !== 0) {\n str = str + '='\n }\n return str\n}\n\nfunction toHex (n) {\n if (n < 16) return '0' + n.toString(16)\n return n.toString(16)\n}\n\nfunction utf8ToBytes (string, units) {\n units = units || Infinity\n var codePoint\n var length = string.length\n var leadSurrogate = null\n var bytes = []\n\n for (var i = 0; i < length; ++i) {\n codePoint = string.charCodeAt(i)\n\n // is surrogate component\n if (codePoint > 0xD7FF && codePoint < 0xE000) {\n // last char was a lead\n if (!leadSurrogate) {\n // no lead yet\n if (codePoint > 0xDBFF) {\n // unexpected trail\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n continue\n } else if (i + 1 === length) {\n // unpaired lead\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n continue\n }\n\n // valid lead\n leadSurrogate = codePoint\n\n continue\n }\n\n // 2 leads in a row\n if (codePoint < 0xDC00) {\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n leadSurrogate = codePoint\n continue\n }\n\n // valid surrogate pair\n codePoint = (leadSurrogate - 0xD800 << 10 | codePoint - 0xDC00) + 0x10000\n } else if (leadSurrogate) {\n // valid bmp char, but last char was a lead\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n }\n\n leadSurrogate = null\n\n // encode utf8\n if (codePoint < 0x80) {\n if ((units -= 1) < 0) break\n bytes.push(codePoint)\n } else if (codePoint < 0x800) {\n if ((units -= 2) < 0) break\n bytes.push(\n codePoint >> 0x6 | 0xC0,\n codePoint & 0x3F | 0x80\n )\n } else if (codePoint < 0x10000) {\n if ((units -= 3) < 0) break\n bytes.push(\n codePoint >> 0xC | 0xE0,\n codePoint >> 0x6 & 0x3F | 0x80,\n codePoint & 0x3F | 0x80\n )\n } else if (codePoint < 0x110000) {\n if ((units -= 4) < 0) break\n bytes.push(\n codePoint >> 0x12 | 0xF0,\n codePoint >> 0xC & 0x3F | 0x80,\n codePoint >> 0x6 & 0x3F | 0x80,\n codePoint & 0x3F | 0x80\n )\n } else {\n throw new Error('Invalid code point')\n }\n }\n\n return bytes\n}\n\nfunction asciiToBytes (str) {\n var byteArray = []\n for (var i = 0; i < str.length; ++i) {\n // Node's code seems to be doing this and not & 0x7F..\n byteArray.push(str.charCodeAt(i) & 0xFF)\n }\n return byteArray\n}\n\nfunction utf16leToBytes (str, units) {\n var c, hi, lo\n var byteArray = []\n for (var i = 0; i < str.length; ++i) {\n if ((units -= 2) < 0) break\n\n c = str.charCodeAt(i)\n hi = c >> 8\n lo = c % 256\n byteArray.push(lo)\n byteArray.push(hi)\n }\n\n return byteArray\n}\n\nfunction base64ToBytes (str) {\n return base64.toByteArray(base64clean(str))\n}\n\nfunction blitBuffer (src, dst, offset, length) {\n for (var i = 0; i < length; ++i) {\n if ((i + offset >= dst.length) || (i >= src.length)) break\n dst[i + offset] = src[i]\n }\n return i\n}\n\n// ArrayBuffers from another context (i.e. an iframe) do not pass the `instanceof` check\n// but they should be treated as valid. See: https://github.com/feross/buffer/issues/166\nfunction isArrayBuffer (obj) {\n return obj instanceof ArrayBuffer ||\n (obj != null && obj.constructor != null && obj.constructor.name === 'ArrayBuffer' &&\n typeof obj.byteLength === 'number')\n}\n\nfunction numberIsNaN (obj) {\n return obj !== obj // eslint-disable-line no-self-compare\n}\n","exports = module.exports = require('./lib/_stream_readable.js');\nexports.Stream = exports;\nexports.Readable = exports;\nexports.Writable = require('./lib/_stream_writable.js');\nexports.Duplex = require('./lib/_stream_duplex.js');\nexports.Transform = require('./lib/_stream_transform.js');\nexports.PassThrough = require('./lib/_stream_passthrough.js');\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// A bit simpler than readable streams.\n// Implement an async ._write(chunk, encoding, cb), and it'll handle all\n// the drain event emission and buffering.\n\n'use strict';\n\n/**/\n\nvar pna = require('process-nextick-args');\n/**/\n\nmodule.exports = Writable;\n\n/* */\nfunction WriteReq(chunk, encoding, cb) {\n this.chunk = chunk;\n this.encoding = encoding;\n this.callback = cb;\n this.next = null;\n}\n\n// It seems a linked list but it is not\n// there will be only 2 of these for each stream\nfunction CorkedRequest(state) {\n var _this = this;\n\n this.next = null;\n this.entry = null;\n this.finish = function () {\n onCorkedFinish(_this, state);\n };\n}\n/* */\n\n/**/\nvar asyncWrite = !process.browser && ['v0.10', 'v0.9.'].indexOf(process.version.slice(0, 5)) > -1 ? setImmediate : pna.nextTick;\n/**/\n\n/**/\nvar Duplex;\n/**/\n\nWritable.WritableState = WritableState;\n\n/**/\nvar util = Object.create(require('core-util-is'));\nutil.inherits = require('inherits');\n/**/\n\n/**/\nvar internalUtil = {\n deprecate: require('util-deprecate')\n};\n/**/\n\n/**/\nvar Stream = require('./internal/streams/stream');\n/**/\n\n/**/\n\nvar Buffer = require('safe-buffer').Buffer;\nvar OurUint8Array = global.Uint8Array || function () {};\nfunction _uint8ArrayToBuffer(chunk) {\n return Buffer.from(chunk);\n}\nfunction _isUint8Array(obj) {\n return Buffer.isBuffer(obj) || obj instanceof OurUint8Array;\n}\n\n/**/\n\nvar destroyImpl = require('./internal/streams/destroy');\n\nutil.inherits(Writable, Stream);\n\nfunction nop() {}\n\nfunction WritableState(options, stream) {\n Duplex = Duplex || require('./_stream_duplex');\n\n options = options || {};\n\n // Duplex streams are both readable and writable, but share\n // the same options object.\n // However, some cases require setting options to different\n // values for the readable and the writable sides of the duplex stream.\n // These options can be provided separately as readableXXX and writableXXX.\n var isDuplex = stream instanceof Duplex;\n\n // object stream flag to indicate whether or not this stream\n // contains buffers or objects.\n this.objectMode = !!options.objectMode;\n\n if (isDuplex) this.objectMode = this.objectMode || !!options.writableObjectMode;\n\n // the point at which write() starts returning false\n // Note: 0 is a valid value, means that we always return false if\n // the entire buffer is not flushed immediately on write()\n var hwm = options.highWaterMark;\n var writableHwm = options.writableHighWaterMark;\n var defaultHwm = this.objectMode ? 16 : 16 * 1024;\n\n if (hwm || hwm === 0) this.highWaterMark = hwm;else if (isDuplex && (writableHwm || writableHwm === 0)) this.highWaterMark = writableHwm;else this.highWaterMark = defaultHwm;\n\n // cast to ints.\n this.highWaterMark = Math.floor(this.highWaterMark);\n\n // if _final has been called\n this.finalCalled = false;\n\n // drain event flag.\n this.needDrain = false;\n // at the start of calling end()\n this.ending = false;\n // when end() has been called, and returned\n this.ended = false;\n // when 'finish' is emitted\n this.finished = false;\n\n // has it been destroyed\n this.destroyed = false;\n\n // should we decode strings into buffers before passing to _write?\n // this is here so that some node-core streams can optimize string\n // handling at a lower level.\n var noDecode = options.decodeStrings === false;\n this.decodeStrings = !noDecode;\n\n // Crypto is kind of old and crusty. Historically, its default string\n // encoding is 'binary' so we have to make this configurable.\n // Everything else in the universe uses 'utf8', though.\n this.defaultEncoding = options.defaultEncoding || 'utf8';\n\n // not an actual buffer we keep track of, but a measurement\n // of how much we're waiting to get pushed to some underlying\n // socket or file.\n this.length = 0;\n\n // a flag to see when we're in the middle of a write.\n this.writing = false;\n\n // when true all writes will be buffered until .uncork() call\n this.corked = 0;\n\n // a flag to be able to tell if the onwrite cb is called immediately,\n // or on a later tick. We set this to true at first, because any\n // actions that shouldn't happen until \"later\" should generally also\n // not happen before the first write call.\n this.sync = true;\n\n // a flag to know if we're processing previously buffered items, which\n // may call the _write() callback in the same tick, so that we don't\n // end up in an overlapped onwrite situation.\n this.bufferProcessing = false;\n\n // the callback that's passed to _write(chunk,cb)\n this.onwrite = function (er) {\n onwrite(stream, er);\n };\n\n // the callback that the user supplies to write(chunk,encoding,cb)\n this.writecb = null;\n\n // the amount that is being written when _write is called.\n this.writelen = 0;\n\n this.bufferedRequest = null;\n this.lastBufferedRequest = null;\n\n // number of pending user-supplied write callbacks\n // this must be 0 before 'finish' can be emitted\n this.pendingcb = 0;\n\n // emit prefinish if the only thing we're waiting for is _write cbs\n // This is relevant for synchronous Transform streams\n this.prefinished = false;\n\n // True if the error was already emitted and should not be thrown again\n this.errorEmitted = false;\n\n // count buffered requests\n this.bufferedRequestCount = 0;\n\n // allocate the first CorkedRequest, there is always\n // one allocated and free to use, and we maintain at most two\n this.corkedRequestsFree = new CorkedRequest(this);\n}\n\nWritableState.prototype.getBuffer = function getBuffer() {\n var current = this.bufferedRequest;\n var out = [];\n while (current) {\n out.push(current);\n current = current.next;\n }\n return out;\n};\n\n(function () {\n try {\n Object.defineProperty(WritableState.prototype, 'buffer', {\n get: internalUtil.deprecate(function () {\n return this.getBuffer();\n }, '_writableState.buffer is deprecated. Use _writableState.getBuffer ' + 'instead.', 'DEP0003')\n });\n } catch (_) {}\n})();\n\n// Test _writableState for inheritance to account for Duplex streams,\n// whose prototype chain only points to Readable.\nvar realHasInstance;\nif (typeof Symbol === 'function' && Symbol.hasInstance && typeof Function.prototype[Symbol.hasInstance] === 'function') {\n realHasInstance = Function.prototype[Symbol.hasInstance];\n Object.defineProperty(Writable, Symbol.hasInstance, {\n value: function (object) {\n if (realHasInstance.call(this, object)) return true;\n if (this !== Writable) return false;\n\n return object && object._writableState instanceof WritableState;\n }\n });\n} else {\n realHasInstance = function (object) {\n return object instanceof this;\n };\n}\n\nfunction Writable(options) {\n Duplex = Duplex || require('./_stream_duplex');\n\n // Writable ctor is applied to Duplexes, too.\n // `realHasInstance` is necessary because using plain `instanceof`\n // would return false, as no `_writableState` property is attached.\n\n // Trying to use the custom `instanceof` for Writable here will also break the\n // Node.js LazyTransform implementation, which has a non-trivial getter for\n // `_writableState` that would lead to infinite recursion.\n if (!realHasInstance.call(Writable, this) && !(this instanceof Duplex)) {\n return new Writable(options);\n }\n\n this._writableState = new WritableState(options, this);\n\n // legacy.\n this.writable = true;\n\n if (options) {\n if (typeof options.write === 'function') this._write = options.write;\n\n if (typeof options.writev === 'function') this._writev = options.writev;\n\n if (typeof options.destroy === 'function') this._destroy = options.destroy;\n\n if (typeof options.final === 'function') this._final = options.final;\n }\n\n Stream.call(this);\n}\n\n// Otherwise people can pipe Writable streams, which is just wrong.\nWritable.prototype.pipe = function () {\n this.emit('error', new Error('Cannot pipe, not readable'));\n};\n\nfunction writeAfterEnd(stream, cb) {\n var er = new Error('write after end');\n // TODO: defer error events consistently everywhere, not just the cb\n stream.emit('error', er);\n pna.nextTick(cb, er);\n}\n\n// Checks that a user-supplied chunk is valid, especially for the particular\n// mode the stream is in. Currently this means that `null` is never accepted\n// and undefined/non-string values are only allowed in object mode.\nfunction validChunk(stream, state, chunk, cb) {\n var valid = true;\n var er = false;\n\n if (chunk === null) {\n er = new TypeError('May not write null values to stream');\n } else if (typeof chunk !== 'string' && chunk !== undefined && !state.objectMode) {\n er = new TypeError('Invalid non-string/buffer chunk');\n }\n if (er) {\n stream.emit('error', er);\n pna.nextTick(cb, er);\n valid = false;\n }\n return valid;\n}\n\nWritable.prototype.write = function (chunk, encoding, cb) {\n var state = this._writableState;\n var ret = false;\n var isBuf = !state.objectMode && _isUint8Array(chunk);\n\n if (isBuf && !Buffer.isBuffer(chunk)) {\n chunk = _uint8ArrayToBuffer(chunk);\n }\n\n if (typeof encoding === 'function') {\n cb = encoding;\n encoding = null;\n }\n\n if (isBuf) encoding = 'buffer';else if (!encoding) encoding = state.defaultEncoding;\n\n if (typeof cb !== 'function') cb = nop;\n\n if (state.ended) writeAfterEnd(this, cb);else if (isBuf || validChunk(this, state, chunk, cb)) {\n state.pendingcb++;\n ret = writeOrBuffer(this, state, isBuf, chunk, encoding, cb);\n }\n\n return ret;\n};\n\nWritable.prototype.cork = function () {\n var state = this._writableState;\n\n state.corked++;\n};\n\nWritable.prototype.uncork = function () {\n var state = this._writableState;\n\n if (state.corked) {\n state.corked--;\n\n if (!state.writing && !state.corked && !state.finished && !state.bufferProcessing && state.bufferedRequest) clearBuffer(this, state);\n }\n};\n\nWritable.prototype.setDefaultEncoding = function setDefaultEncoding(encoding) {\n // node::ParseEncoding() requires lower case.\n if (typeof encoding === 'string') encoding = encoding.toLowerCase();\n if (!(['hex', 'utf8', 'utf-8', 'ascii', 'binary', 'base64', 'ucs2', 'ucs-2', 'utf16le', 'utf-16le', 'raw'].indexOf((encoding + '').toLowerCase()) > -1)) throw new TypeError('Unknown encoding: ' + encoding);\n this._writableState.defaultEncoding = encoding;\n return this;\n};\n\nfunction decodeChunk(state, chunk, encoding) {\n if (!state.objectMode && state.decodeStrings !== false && typeof chunk === 'string') {\n chunk = Buffer.from(chunk, encoding);\n }\n return chunk;\n}\n\nObject.defineProperty(Writable.prototype, 'writableHighWaterMark', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function () {\n return this._writableState.highWaterMark;\n }\n});\n\n// if we're already writing something, then just put this\n// in the queue, and wait our turn. Otherwise, call _write\n// If we return false, then we need a drain event, so set that flag.\nfunction writeOrBuffer(stream, state, isBuf, chunk, encoding, cb) {\n if (!isBuf) {\n var newChunk = decodeChunk(state, chunk, encoding);\n if (chunk !== newChunk) {\n isBuf = true;\n encoding = 'buffer';\n chunk = newChunk;\n }\n }\n var len = state.objectMode ? 1 : chunk.length;\n\n state.length += len;\n\n var ret = state.length < state.highWaterMark;\n // we must ensure that previous needDrain will not be reset to false.\n if (!ret) state.needDrain = true;\n\n if (state.writing || state.corked) {\n var last = state.lastBufferedRequest;\n state.lastBufferedRequest = {\n chunk: chunk,\n encoding: encoding,\n isBuf: isBuf,\n callback: cb,\n next: null\n };\n if (last) {\n last.next = state.lastBufferedRequest;\n } else {\n state.bufferedRequest = state.lastBufferedRequest;\n }\n state.bufferedRequestCount += 1;\n } else {\n doWrite(stream, state, false, len, chunk, encoding, cb);\n }\n\n return ret;\n}\n\nfunction doWrite(stream, state, writev, len, chunk, encoding, cb) {\n state.writelen = len;\n state.writecb = cb;\n state.writing = true;\n state.sync = true;\n if (writev) stream._writev(chunk, state.onwrite);else stream._write(chunk, encoding, state.onwrite);\n state.sync = false;\n}\n\nfunction onwriteError(stream, state, sync, er, cb) {\n --state.pendingcb;\n\n if (sync) {\n // defer the callback if we are being called synchronously\n // to avoid piling up things on the stack\n pna.nextTick(cb, er);\n // this can emit finish, and it will always happen\n // after error\n pna.nextTick(finishMaybe, stream, state);\n stream._writableState.errorEmitted = true;\n stream.emit('error', er);\n } else {\n // the caller expect this to happen before if\n // it is async\n cb(er);\n stream._writableState.errorEmitted = true;\n stream.emit('error', er);\n // this can emit finish, but finish must\n // always follow error\n finishMaybe(stream, state);\n }\n}\n\nfunction onwriteStateUpdate(state) {\n state.writing = false;\n state.writecb = null;\n state.length -= state.writelen;\n state.writelen = 0;\n}\n\nfunction onwrite(stream, er) {\n var state = stream._writableState;\n var sync = state.sync;\n var cb = state.writecb;\n\n onwriteStateUpdate(state);\n\n if (er) onwriteError(stream, state, sync, er, cb);else {\n // Check if we're actually ready to finish, but don't emit yet\n var finished = needFinish(state);\n\n if (!finished && !state.corked && !state.bufferProcessing && state.bufferedRequest) {\n clearBuffer(stream, state);\n }\n\n if (sync) {\n /**/\n asyncWrite(afterWrite, stream, state, finished, cb);\n /**/\n } else {\n afterWrite(stream, state, finished, cb);\n }\n }\n}\n\nfunction afterWrite(stream, state, finished, cb) {\n if (!finished) onwriteDrain(stream, state);\n state.pendingcb--;\n cb();\n finishMaybe(stream, state);\n}\n\n// Must force callback to be called on nextTick, so that we don't\n// emit 'drain' before the write() consumer gets the 'false' return\n// value, and has a chance to attach a 'drain' listener.\nfunction onwriteDrain(stream, state) {\n if (state.length === 0 && state.needDrain) {\n state.needDrain = false;\n stream.emit('drain');\n }\n}\n\n// if there's something in the buffer waiting, then process it\nfunction clearBuffer(stream, state) {\n state.bufferProcessing = true;\n var entry = state.bufferedRequest;\n\n if (stream._writev && entry && entry.next) {\n // Fast case, write everything using _writev()\n var l = state.bufferedRequestCount;\n var buffer = new Array(l);\n var holder = state.corkedRequestsFree;\n holder.entry = entry;\n\n var count = 0;\n var allBuffers = true;\n while (entry) {\n buffer[count] = entry;\n if (!entry.isBuf) allBuffers = false;\n entry = entry.next;\n count += 1;\n }\n buffer.allBuffers = allBuffers;\n\n doWrite(stream, state, true, state.length, buffer, '', holder.finish);\n\n // doWrite is almost always async, defer these to save a bit of time\n // as the hot path ends with doWrite\n state.pendingcb++;\n state.lastBufferedRequest = null;\n if (holder.next) {\n state.corkedRequestsFree = holder.next;\n holder.next = null;\n } else {\n state.corkedRequestsFree = new CorkedRequest(state);\n }\n state.bufferedRequestCount = 0;\n } else {\n // Slow case, write chunks one-by-one\n while (entry) {\n var chunk = entry.chunk;\n var encoding = entry.encoding;\n var cb = entry.callback;\n var len = state.objectMode ? 1 : chunk.length;\n\n doWrite(stream, state, false, len, chunk, encoding, cb);\n entry = entry.next;\n state.bufferedRequestCount--;\n // if we didn't call the onwrite immediately, then\n // it means that we need to wait until it does.\n // also, that means that the chunk and cb are currently\n // being processed, so move the buffer counter past them.\n if (state.writing) {\n break;\n }\n }\n\n if (entry === null) state.lastBufferedRequest = null;\n }\n\n state.bufferedRequest = entry;\n state.bufferProcessing = false;\n}\n\nWritable.prototype._write = function (chunk, encoding, cb) {\n cb(new Error('_write() is not implemented'));\n};\n\nWritable.prototype._writev = null;\n\nWritable.prototype.end = function (chunk, encoding, cb) {\n var state = this._writableState;\n\n if (typeof chunk === 'function') {\n cb = chunk;\n chunk = null;\n encoding = null;\n } else if (typeof encoding === 'function') {\n cb = encoding;\n encoding = null;\n }\n\n if (chunk !== null && chunk !== undefined) this.write(chunk, encoding);\n\n // .end() fully uncorks\n if (state.corked) {\n state.corked = 1;\n this.uncork();\n }\n\n // ignore unnecessary end() calls.\n if (!state.ending && !state.finished) endWritable(this, state, cb);\n};\n\nfunction needFinish(state) {\n return state.ending && state.length === 0 && state.bufferedRequest === null && !state.finished && !state.writing;\n}\nfunction callFinal(stream, state) {\n stream._final(function (err) {\n state.pendingcb--;\n if (err) {\n stream.emit('error', err);\n }\n state.prefinished = true;\n stream.emit('prefinish');\n finishMaybe(stream, state);\n });\n}\nfunction prefinish(stream, state) {\n if (!state.prefinished && !state.finalCalled) {\n if (typeof stream._final === 'function') {\n state.pendingcb++;\n state.finalCalled = true;\n pna.nextTick(callFinal, stream, state);\n } else {\n state.prefinished = true;\n stream.emit('prefinish');\n }\n }\n}\n\nfunction finishMaybe(stream, state) {\n var need = needFinish(state);\n if (need) {\n prefinish(stream, state);\n if (state.pendingcb === 0) {\n state.finished = true;\n stream.emit('finish');\n }\n }\n return need;\n}\n\nfunction endWritable(stream, state, cb) {\n state.ending = true;\n finishMaybe(stream, state);\n if (cb) {\n if (state.finished) pna.nextTick(cb);else stream.once('finish', cb);\n }\n state.ended = true;\n stream.writable = false;\n}\n\nfunction onCorkedFinish(corkReq, state, err) {\n var entry = corkReq.entry;\n corkReq.entry = null;\n while (entry) {\n var cb = entry.callback;\n state.pendingcb--;\n cb(err);\n entry = entry.next;\n }\n if (state.corkedRequestsFree) {\n state.corkedRequestsFree.next = corkReq;\n } else {\n state.corkedRequestsFree = corkReq;\n }\n}\n\nObject.defineProperty(Writable.prototype, 'destroyed', {\n get: function () {\n if (this._writableState === undefined) {\n return false;\n }\n return this._writableState.destroyed;\n },\n set: function (value) {\n // we ignore the value if the stream\n // has not been initialized yet\n if (!this._writableState) {\n return;\n }\n\n // backward compatibility, the user is explicitly\n // managing destroyed\n this._writableState.destroyed = value;\n }\n});\n\nWritable.prototype.destroy = destroyImpl.destroy;\nWritable.prototype._undestroy = destroyImpl.undestroy;\nWritable.prototype._destroy = function (err, cb) {\n this.end();\n cb(err);\n};","// Type information only.\nimport _path = require('path');\n\n// Split a filename into [root, dir, basename, ext], unix version\n// 'root' is just a slash, or nothing.\nvar splitPathRe = /^(\\/?|)([\\s\\S]*?)((?:\\.{1,2}|[^\\/]+?|)(\\.[^.\\/]*|))(?:[\\/]*)$/;\nfunction posixSplitPath(filename: string): string[] {\n var out = splitPathRe.exec(filename);\n out.shift();\n return out;\n}\n\n/**\n * Emulates Node's `path` module. This module contains utilities for handling and\n * transforming file paths. **All** of these methods perform only string\n * transformations. The file system is not consulted to check whether paths are\n * valid.\n * @see http://nodejs.org/api/path.html\n * @class\n */\nclass path {\n /**\n * Normalize a string path, taking care of '..' and '.' parts.\n *\n * When multiple slashes are found, they're replaced by a single one; when the path contains a trailing slash, it is preserved. On Windows backslashes are used.\n * @example Usage example\n * path.normalize('/foo/bar//baz/asdf/quux/..')\n * // returns\n * '/foo/bar/baz/asdf'\n * @param [String] p The path to normalize.\n * @return [String]\n */\n public static normalize(p: string): string {\n // Special case: '' -> '.'\n if (p === '') {\n p = '.';\n }\n // It's very important to know if the path is relative or not, since it\n // changes how we process .. and reconstruct the split string.\n var absolute = p.charAt(0) === path.sep;\n // Remove repeated //s\n p = path._removeDuplicateSeps(p);\n // Try to remove as many '../' as possible, and remove '.' completely.\n var components = p.split(path.sep);\n var goodComponents: string[] = [];\n for (var idx = 0; idx < components.length; idx++) {\n var c = components[idx];\n if (c === '.') {\n continue;\n } else if (c === '..' && (absolute || (!absolute && goodComponents.length > 0 && goodComponents[0] !== '..'))) {\n // In the absolute case: Path is relative to root, so we may pop even if\n // goodComponents is empty (e.g. /../ => /)\n // In the relative case: We're getting rid of a directory that preceded\n // it (e.g. /foo/../bar -> /bar)\n goodComponents.pop();\n } else {\n goodComponents.push(c);\n }\n }\n\n // Add in '.' when it's a relative path with no other nonempty components.\n // Possible results: '.' and './' (input: [''] or [])\n // @todo Can probably simplify this logic.\n if (!absolute && goodComponents.length < 2) {\n switch (goodComponents.length) {\n case 1:\n if (goodComponents[0] === '') {\n goodComponents.unshift('.');\n }\n break;\n default:\n goodComponents.push('.');\n }\n }\n p = goodComponents.join(path.sep);\n if (absolute && p.charAt(0) !== path.sep) {\n p = path.sep + p;\n }\n return p;\n }\n\n /**\n * Join all arguments together and normalize the resulting path.\n *\n * Arguments must be strings.\n * @example Usage\n * path.join('/foo', 'bar', 'baz/asdf', 'quux', '..')\n * // returns\n * '/foo/bar/baz/asdf'\n *\n * path.join('foo', {}, 'bar')\n * // throws exception\n * TypeError: Arguments to path.join must be strings\n * @param [String,...] paths Each component of the path\n * @return [String]\n */\n public static join(...paths: any[]): string {\n // Required: Prune any non-strings from the path. I also prune empty segments\n // so we can do a simple join of the array.\n var processed: string[] = [];\n for (var i = 0; i < paths.length; i++) {\n var segment = paths[i];\n if (typeof segment !== 'string') {\n throw new TypeError(\"Invalid argument type to path.join: \" + (typeof segment));\n } else if (segment !== '') {\n processed.push(segment);\n }\n }\n return path.normalize(processed.join(path.sep));\n }\n\n /**\n * Resolves to to an absolute path.\n *\n * If to isn't already absolute from arguments are prepended in right to left\n * order, until an absolute path is found. If after using all from paths still\n * no absolute path is found, the current working directory is used as well.\n * The resulting path is normalized, and trailing slashes are removed unless\n * the path gets resolved to the root directory. Non-string arguments are\n * ignored.\n *\n * Another way to think of it is as a sequence of cd commands in a shell.\n *\n * path.resolve('foo/bar', '/tmp/file/', '..', 'a/../subfile')\n *\n * Is similar to:\n *\n * cd foo/bar\n * cd /tmp/file/\n * cd ..\n * cd a/../subfile\n * pwd\n *\n * The difference is that the different paths don't need to exist and may also\n * be files.\n * @example Usage example\n * path.resolve('/foo/bar', './baz')\n * // returns\n * '/foo/bar/baz'\n *\n * path.resolve('/foo/bar', '/tmp/file/')\n * // returns\n * '/tmp/file'\n *\n * path.resolve('wwwroot', 'static_files/png/', '../gif/image.gif')\n * // if currently in /home/myself/node, it returns\n * '/home/myself/node/wwwroot/static_files/gif/image.gif'\n * @param [String,...] paths\n * @return [String]\n */\n public static resolve(...paths: string[]): string {\n // Monitor for invalid paths, throw out empty paths, and look for the *last*\n // absolute path that we see.\n var processed: string[] = [];\n for (var i = 0; i < paths.length; i++) {\n var p = paths[i];\n if (typeof p !== 'string') {\n throw new TypeError(\"Invalid argument type to path.join: \" + (typeof p));\n } else if (p !== '') {\n // Remove anything that has occurred before this absolute path, as it\n // doesn't matter.\n if (p.charAt(0) === path.sep) {\n processed = [];\n }\n processed.push(p);\n }\n }\n // Special: Remove trailing slash unless it's the root\n var resolved = path.normalize(processed.join(path.sep));\n if (resolved.length > 1 && resolved.charAt(resolved.length - 1) === path.sep) {\n return resolved.substr(0, resolved.length - 1);\n }\n // Special: If it doesn't start with '/', it's relative and we need to append\n // the current directory.\n if (resolved.charAt(0) !== path.sep) {\n // Remove ./, since we're going to append the current directory.\n if (resolved.charAt(0) === '.' && (resolved.length === 1 || resolved.charAt(1) === path.sep)) {\n resolved = resolved.length === 1 ? '' : resolved.substr(2);\n }\n // Append the current directory, which *must* be an absolute path.\n var cwd = process.cwd();\n if (resolved !== '') {\n // cwd will never end in a /... unless it's the root.\n resolved = this.normalize(cwd + (cwd !== '/' ? path.sep : '') + resolved);\n } else {\n resolved = cwd;\n }\n }\n return resolved;\n }\n\n /**\n * Solve the relative path from from to to.\n *\n * At times we have two absolute paths, and we need to derive the relative path\n * from one to the other. This is actually the reverse transform of\n * path.resolve, which means we see that:\n *\n * path.resolve(from, path.relative(from, to)) == path.resolve(to)\n *\n * @example Usage example\n * path.relative('C:\\\\orandea\\\\test\\\\aaa', 'C:\\\\orandea\\\\impl\\\\bbb')\n * // returns\n * '..\\\\..\\\\impl\\\\bbb'\n *\n * path.relative('/data/orandea/test/aaa', '/data/orandea/impl/bbb')\n * // returns\n * '../../impl/bbb'\n * @param [String] from\n * @param [String] to\n * @return [String]\n */\n public static relative(from: string, to: string): string {\n var i: number;\n // Alright. Let's resolve these two to absolute paths and remove any\n // weirdness.\n from = path.resolve(from);\n to = path.resolve(to);\n var fromSegs = from.split(path.sep);\n var toSegs = to.split(path.sep);\n // Remove the first segment on both, as it's '' (both are absolute paths)\n toSegs.shift();\n fromSegs.shift();\n // There are two segments to this path:\n // * Going *up* the directory hierarchy with '..'\n // * Going *down* the directory hierarchy with foo/baz/bat.\n var upCount = 0;\n var downSegs: string[] = [];\n // Figure out how many things in 'from' are shared with 'to'.\n for (i = 0; i < fromSegs.length; i++) {\n var seg = fromSegs[i];\n if (seg === toSegs[i]) {\n continue;\n }\n // The rest of 'from', including the current element, indicates how many\n // directories we need to go up.\n upCount = fromSegs.length - i;\n break;\n }\n // The rest of 'to' indicates where we need to change to. We place this\n // outside of the loop, as toSegs.length may be greater than fromSegs.length.\n downSegs = toSegs.slice(i);\n // Special case: If 'from' is '/'\n if (fromSegs.length === 1 && fromSegs[0] === '') {\n upCount = 0;\n }\n // upCount can't be greater than the number of fromSegs\n // (cd .. from / is still /)\n if (upCount > fromSegs.length) {\n upCount = fromSegs.length;\n }\n // Create the final string!\n var rv = '';\n for (i = 0; i < upCount; i++) {\n rv += '../';\n }\n rv += downSegs.join(path.sep);\n // Special case: Remove trailing '/'. Happens if it's all up and no down.\n if (rv.length > 1 && rv.charAt(rv.length - 1) === path.sep) {\n rv = rv.substr(0, rv.length - 1);\n }\n return rv;\n }\n\n /**\n * Return the directory name of a path. Similar to the Unix `dirname` command.\n *\n * Note that BrowserFS does not validate if the path is actually a valid\n * directory.\n * @example Usage example\n * path.dirname('/foo/bar/baz/asdf/quux')\n * // returns\n * '/foo/bar/baz/asdf'\n * @param [String] p The path to get the directory name of.\n * @return [String]\n */\n public static dirname(p: string): string {\n // We get rid of //, but we don't modify anything else (e.g. any extraneous .\n // and ../ are kept intact)\n p = path._removeDuplicateSeps(p);\n var absolute = p.charAt(0) === path.sep;\n var sections = p.split(path.sep);\n // Do 1 if it's /foo/bar, 2 if it's /foo/bar/\n if (sections.pop() === '' && sections.length > 0) {\n sections.pop();\n }\n // # of sections needs to be > 1 if absolute, since the first section is '' for '/'.\n // If not absolute, the first section is the first part of the path, and is OK\n // to return.\n if (sections.length > 1 || (sections.length === 1 && !absolute)) {\n return sections.join(path.sep);\n } else if (absolute) {\n return path.sep;\n } else {\n return '.';\n }\n }\n\n /**\n * Return the last portion of a path. Similar to the Unix basename command.\n * @example Usage example\n * path.basename('/foo/bar/baz/asdf/quux.html')\n * // returns\n * 'quux.html'\n *\n * path.basename('/foo/bar/baz/asdf/quux.html', '.html')\n * // returns\n * 'quux'\n * @param [String] p\n * @param [String?] ext\n * @return [String]\n */\n public static basename(p: string, ext: string = \"\"): string {\n // Special case: Normalize will modify this to '.'\n if (p === '') {\n return p;\n }\n // Normalize the string first to remove any weirdness.\n p = path.normalize(p);\n // Get the last part of the string.\n var sections = p.split(path.sep);\n var lastPart = sections[sections.length - 1];\n // Special case: If it's empty, then we have a string like so: foo/\n // Meaning, 'foo' is guaranteed to be a directory.\n if (lastPart === '' && sections.length > 1) {\n return sections[sections.length - 2];\n }\n // Remove the extension, if need be.\n if (ext.length > 0) {\n var lastPartExt = lastPart.substr(lastPart.length - ext.length);\n if (lastPartExt === ext) {\n return lastPart.substr(0, lastPart.length - ext.length);\n }\n }\n return lastPart;\n }\n\n /**\n * Return the extension of the path, from the last '.' to end of string in the\n * last portion of the path. If there is no '.' in the last portion of the path\n * or the first character of it is '.', then it returns an empty string.\n * @example Usage example\n * path.extname('index.html')\n * // returns\n * '.html'\n *\n * path.extname('index.')\n * // returns\n * '.'\n *\n * path.extname('index')\n * // returns\n * ''\n * @param [String] p\n * @return [String]\n */\n public static extname(p: string): string {\n p = path.normalize(p);\n var sections = p.split(path.sep);\n p = sections.pop();\n // Special case: foo/file.ext/ should return '.ext'\n if (p === '' && sections.length > 0) {\n p = sections.pop();\n }\n if (p === '..') {\n return '';\n }\n var i = p.lastIndexOf('.');\n if (i === -1 || i === 0) {\n return '';\n }\n return p.substr(i);\n }\n\n /**\n * Checks if the given path is an absolute path.\n *\n * Despite not being documented, this is a tested part of Node's path API.\n * @param [String] p\n * @return [Boolean] True if the path appears to be an absolute path.\n */\n public static isAbsolute(p: string): boolean {\n return p.length > 0 && p.charAt(0) === path.sep;\n }\n\n /**\n * Unknown. Undocumented.\n */\n public static _makeLong(p: string): string {\n return p;\n }\n\n /**\n * Returns an object from a path string.\n */\n public static parse(p: string): _path.ParsedPath {\n var allParts = posixSplitPath(p);\n return {\n root: allParts[0],\n dir: allParts[0] + allParts[1].slice(0, -1),\n base: allParts[2],\n ext: allParts[3],\n name: allParts[2].slice(0, allParts[2].length - allParts[3].length)\n };\n }\n\n public static format(pathObject: _path.ParsedPath): string {\n if (pathObject === null || typeof pathObject !== 'object') {\n throw new TypeError(`Parameter 'pathObject' must be an object, not ${typeof pathObject}`);\n }\n\n var root = pathObject.root || '';\n\n if (typeof root !== 'string') {\n throw new TypeError(\n \"'pathObject.root' must be a string or undefined, not \" +\n typeof pathObject.root\n );\n }\n\n var dir = pathObject.dir ? pathObject.dir + path.sep : '';\n var base = pathObject.base || '';\n return dir + base;\n }\n\n // The platform-specific file separator. BrowserFS uses `/`.\n public static sep: string = '/';\n\n private static _replaceRegex = new RegExp(\"//+\", 'g');\n\n private static _removeDuplicateSeps(p: string): string {\n p = p.replace(this._replaceRegex, this.sep);\n return p;\n }\n\n // The platform-specific path delimiter. BrowserFS uses `:`.\n public static delimiter = ':';\n\n public static posix = path;\n // XXX: Typing hack. We don't actually support win32.\n public static win32 = path;\n}\n\nvar _: typeof _path = path;\n\nexport = path;\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\n/**/\n\nvar pna = require('process-nextick-args');\n/**/\n\nmodule.exports = Readable;\n\n/**/\nvar isArray = require('isarray');\n/**/\n\n/**/\nvar Duplex;\n/**/\n\nReadable.ReadableState = ReadableState;\n\n/**/\nvar EE = require('events').EventEmitter;\n\nvar EElistenerCount = function (emitter, type) {\n return emitter.listeners(type).length;\n};\n/**/\n\n/**/\nvar Stream = require('./internal/streams/stream');\n/**/\n\n/**/\n\nvar Buffer = require('safe-buffer').Buffer;\nvar OurUint8Array = global.Uint8Array || function () {};\nfunction _uint8ArrayToBuffer(chunk) {\n return Buffer.from(chunk);\n}\nfunction _isUint8Array(obj) {\n return Buffer.isBuffer(obj) || obj instanceof OurUint8Array;\n}\n\n/**/\n\n/**/\nvar util = Object.create(require('core-util-is'));\nutil.inherits = require('inherits');\n/**/\n\n/**/\nvar debugUtil = require('util');\nvar debug = void 0;\nif (debugUtil && debugUtil.debuglog) {\n debug = debugUtil.debuglog('stream');\n} else {\n debug = function () {};\n}\n/**/\n\nvar BufferList = require('./internal/streams/BufferList');\nvar destroyImpl = require('./internal/streams/destroy');\nvar StringDecoder;\n\nutil.inherits(Readable, Stream);\n\nvar kProxyEvents = ['error', 'close', 'destroy', 'pause', 'resume'];\n\nfunction prependListener(emitter, event, fn) {\n // Sadly this is not cacheable as some libraries bundle their own\n // event emitter implementation with them.\n if (typeof emitter.prependListener === 'function') return emitter.prependListener(event, fn);\n\n // This is a hack to make sure that our error handler is attached before any\n // userland ones. NEVER DO THIS. This is here only because this code needs\n // to continue to work with older versions of Node.js that do not include\n // the prependListener() method. The goal is to eventually remove this hack.\n if (!emitter._events || !emitter._events[event]) emitter.on(event, fn);else if (isArray(emitter._events[event])) emitter._events[event].unshift(fn);else emitter._events[event] = [fn, emitter._events[event]];\n}\n\nfunction ReadableState(options, stream) {\n Duplex = Duplex || require('./_stream_duplex');\n\n options = options || {};\n\n // Duplex streams are both readable and writable, but share\n // the same options object.\n // However, some cases require setting options to different\n // values for the readable and the writable sides of the duplex stream.\n // These options can be provided separately as readableXXX and writableXXX.\n var isDuplex = stream instanceof Duplex;\n\n // object stream flag. Used to make read(n) ignore n and to\n // make all the buffer merging and length checks go away\n this.objectMode = !!options.objectMode;\n\n if (isDuplex) this.objectMode = this.objectMode || !!options.readableObjectMode;\n\n // the point at which it stops calling _read() to fill the buffer\n // Note: 0 is a valid value, means \"don't call _read preemptively ever\"\n var hwm = options.highWaterMark;\n var readableHwm = options.readableHighWaterMark;\n var defaultHwm = this.objectMode ? 16 : 16 * 1024;\n\n if (hwm || hwm === 0) this.highWaterMark = hwm;else if (isDuplex && (readableHwm || readableHwm === 0)) this.highWaterMark = readableHwm;else this.highWaterMark = defaultHwm;\n\n // cast to ints.\n this.highWaterMark = Math.floor(this.highWaterMark);\n\n // A linked list is used to store data chunks instead of an array because the\n // linked list can remove elements from the beginning faster than\n // array.shift()\n this.buffer = new BufferList();\n this.length = 0;\n this.pipes = null;\n this.pipesCount = 0;\n this.flowing = null;\n this.ended = false;\n this.endEmitted = false;\n this.reading = false;\n\n // a flag to be able to tell if the event 'readable'/'data' is emitted\n // immediately, or on a later tick. We set this to true at first, because\n // any actions that shouldn't happen until \"later\" should generally also\n // not happen before the first read call.\n this.sync = true;\n\n // whenever we return null, then we set a flag to say\n // that we're awaiting a 'readable' event emission.\n this.needReadable = false;\n this.emittedReadable = false;\n this.readableListening = false;\n this.resumeScheduled = false;\n\n // has it been destroyed\n this.destroyed = false;\n\n // Crypto is kind of old and crusty. Historically, its default string\n // encoding is 'binary' so we have to make this configurable.\n // Everything else in the universe uses 'utf8', though.\n this.defaultEncoding = options.defaultEncoding || 'utf8';\n\n // the number of writers that are awaiting a drain event in .pipe()s\n this.awaitDrain = 0;\n\n // if true, a maybeReadMore has been scheduled\n this.readingMore = false;\n\n this.decoder = null;\n this.encoding = null;\n if (options.encoding) {\n if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder;\n this.decoder = new StringDecoder(options.encoding);\n this.encoding = options.encoding;\n }\n}\n\nfunction Readable(options) {\n Duplex = Duplex || require('./_stream_duplex');\n\n if (!(this instanceof Readable)) return new Readable(options);\n\n this._readableState = new ReadableState(options, this);\n\n // legacy\n this.readable = true;\n\n if (options) {\n if (typeof options.read === 'function') this._read = options.read;\n\n if (typeof options.destroy === 'function') this._destroy = options.destroy;\n }\n\n Stream.call(this);\n}\n\nObject.defineProperty(Readable.prototype, 'destroyed', {\n get: function () {\n if (this._readableState === undefined) {\n return false;\n }\n return this._readableState.destroyed;\n },\n set: function (value) {\n // we ignore the value if the stream\n // has not been initialized yet\n if (!this._readableState) {\n return;\n }\n\n // backward compatibility, the user is explicitly\n // managing destroyed\n this._readableState.destroyed = value;\n }\n});\n\nReadable.prototype.destroy = destroyImpl.destroy;\nReadable.prototype._undestroy = destroyImpl.undestroy;\nReadable.prototype._destroy = function (err, cb) {\n this.push(null);\n cb(err);\n};\n\n// Manually shove something into the read() buffer.\n// This returns true if the highWaterMark has not been hit yet,\n// similar to how Writable.write() returns true if you should\n// write() some more.\nReadable.prototype.push = function (chunk, encoding) {\n var state = this._readableState;\n var skipChunkCheck;\n\n if (!state.objectMode) {\n if (typeof chunk === 'string') {\n encoding = encoding || state.defaultEncoding;\n if (encoding !== state.encoding) {\n chunk = Buffer.from(chunk, encoding);\n encoding = '';\n }\n skipChunkCheck = true;\n }\n } else {\n skipChunkCheck = true;\n }\n\n return readableAddChunk(this, chunk, encoding, false, skipChunkCheck);\n};\n\n// Unshift should *always* be something directly out of read()\nReadable.prototype.unshift = function (chunk) {\n return readableAddChunk(this, chunk, null, true, false);\n};\n\nfunction readableAddChunk(stream, chunk, encoding, addToFront, skipChunkCheck) {\n var state = stream._readableState;\n if (chunk === null) {\n state.reading = false;\n onEofChunk(stream, state);\n } else {\n var er;\n if (!skipChunkCheck) er = chunkInvalid(state, chunk);\n if (er) {\n stream.emit('error', er);\n } else if (state.objectMode || chunk && chunk.length > 0) {\n if (typeof chunk !== 'string' && !state.objectMode && Object.getPrototypeOf(chunk) !== Buffer.prototype) {\n chunk = _uint8ArrayToBuffer(chunk);\n }\n\n if (addToFront) {\n if (state.endEmitted) stream.emit('error', new Error('stream.unshift() after end event'));else addChunk(stream, state, chunk, true);\n } else if (state.ended) {\n stream.emit('error', new Error('stream.push() after EOF'));\n } else {\n state.reading = false;\n if (state.decoder && !encoding) {\n chunk = state.decoder.write(chunk);\n if (state.objectMode || chunk.length !== 0) addChunk(stream, state, chunk, false);else maybeReadMore(stream, state);\n } else {\n addChunk(stream, state, chunk, false);\n }\n }\n } else if (!addToFront) {\n state.reading = false;\n }\n }\n\n return needMoreData(state);\n}\n\nfunction addChunk(stream, state, chunk, addToFront) {\n if (state.flowing && state.length === 0 && !state.sync) {\n stream.emit('data', chunk);\n stream.read(0);\n } else {\n // update the buffer info.\n state.length += state.objectMode ? 1 : chunk.length;\n if (addToFront) state.buffer.unshift(chunk);else state.buffer.push(chunk);\n\n if (state.needReadable) emitReadable(stream);\n }\n maybeReadMore(stream, state);\n}\n\nfunction chunkInvalid(state, chunk) {\n var er;\n if (!_isUint8Array(chunk) && typeof chunk !== 'string' && chunk !== undefined && !state.objectMode) {\n er = new TypeError('Invalid non-string/buffer chunk');\n }\n return er;\n}\n\n// if it's past the high water mark, we can push in some more.\n// Also, if we have no data yet, we can stand some\n// more bytes. This is to work around cases where hwm=0,\n// such as the repl. Also, if the push() triggered a\n// readable event, and the user called read(largeNumber) such that\n// needReadable was set, then we ought to push more, so that another\n// 'readable' event will be triggered.\nfunction needMoreData(state) {\n return !state.ended && (state.needReadable || state.length < state.highWaterMark || state.length === 0);\n}\n\nReadable.prototype.isPaused = function () {\n return this._readableState.flowing === false;\n};\n\n// backwards compatibility.\nReadable.prototype.setEncoding = function (enc) {\n if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder;\n this._readableState.decoder = new StringDecoder(enc);\n this._readableState.encoding = enc;\n return this;\n};\n\n// Don't raise the hwm > 8MB\nvar MAX_HWM = 0x800000;\nfunction computeNewHighWaterMark(n) {\n if (n >= MAX_HWM) {\n n = MAX_HWM;\n } else {\n // Get the next highest power of 2 to prevent increasing hwm excessively in\n // tiny amounts\n n--;\n n |= n >>> 1;\n n |= n >>> 2;\n n |= n >>> 4;\n n |= n >>> 8;\n n |= n >>> 16;\n n++;\n }\n return n;\n}\n\n// This function is designed to be inlinable, so please take care when making\n// changes to the function body.\nfunction howMuchToRead(n, state) {\n if (n <= 0 || state.length === 0 && state.ended) return 0;\n if (state.objectMode) return 1;\n if (n !== n) {\n // Only flow one buffer at a time\n if (state.flowing && state.length) return state.buffer.head.data.length;else return state.length;\n }\n // If we're asking for more than the current hwm, then raise the hwm.\n if (n > state.highWaterMark) state.highWaterMark = computeNewHighWaterMark(n);\n if (n <= state.length) return n;\n // Don't have enough\n if (!state.ended) {\n state.needReadable = true;\n return 0;\n }\n return state.length;\n}\n\n// you can override either this method, or the async _read(n) below.\nReadable.prototype.read = function (n) {\n debug('read', n);\n n = parseInt(n, 10);\n var state = this._readableState;\n var nOrig = n;\n\n if (n !== 0) state.emittedReadable = false;\n\n // if we're doing read(0) to trigger a readable event, but we\n // already have a bunch of data in the buffer, then just trigger\n // the 'readable' event and move on.\n if (n === 0 && state.needReadable && (state.length >= state.highWaterMark || state.ended)) {\n debug('read: emitReadable', state.length, state.ended);\n if (state.length === 0 && state.ended) endReadable(this);else emitReadable(this);\n return null;\n }\n\n n = howMuchToRead(n, state);\n\n // if we've ended, and we're now clear, then finish it up.\n if (n === 0 && state.ended) {\n if (state.length === 0) endReadable(this);\n return null;\n }\n\n // All the actual chunk generation logic needs to be\n // *below* the call to _read. The reason is that in certain\n // synthetic stream cases, such as passthrough streams, _read\n // may be a completely synchronous operation which may change\n // the state of the read buffer, providing enough data when\n // before there was *not* enough.\n //\n // So, the steps are:\n // 1. Figure out what the state of things will be after we do\n // a read from the buffer.\n //\n // 2. If that resulting state will trigger a _read, then call _read.\n // Note that this may be asynchronous, or synchronous. Yes, it is\n // deeply ugly to write APIs this way, but that still doesn't mean\n // that the Readable class should behave improperly, as streams are\n // designed to be sync/async agnostic.\n // Take note if the _read call is sync or async (ie, if the read call\n // has returned yet), so that we know whether or not it's safe to emit\n // 'readable' etc.\n //\n // 3. Actually pull the requested chunks out of the buffer and return.\n\n // if we need a readable event, then we need to do some reading.\n var doRead = state.needReadable;\n debug('need readable', doRead);\n\n // if we currently have less than the highWaterMark, then also read some\n if (state.length === 0 || state.length - n < state.highWaterMark) {\n doRead = true;\n debug('length less than watermark', doRead);\n }\n\n // however, if we've ended, then there's no point, and if we're already\n // reading, then it's unnecessary.\n if (state.ended || state.reading) {\n doRead = false;\n debug('reading or ended', doRead);\n } else if (doRead) {\n debug('do read');\n state.reading = true;\n state.sync = true;\n // if the length is currently zero, then we *need* a readable event.\n if (state.length === 0) state.needReadable = true;\n // call internal read method\n this._read(state.highWaterMark);\n state.sync = false;\n // If _read pushed data synchronously, then `reading` will be false,\n // and we need to re-evaluate how much data we can return to the user.\n if (!state.reading) n = howMuchToRead(nOrig, state);\n }\n\n var ret;\n if (n > 0) ret = fromList(n, state);else ret = null;\n\n if (ret === null) {\n state.needReadable = true;\n n = 0;\n } else {\n state.length -= n;\n }\n\n if (state.length === 0) {\n // If we have nothing in the buffer, then we want to know\n // as soon as we *do* get something into the buffer.\n if (!state.ended) state.needReadable = true;\n\n // If we tried to read() past the EOF, then emit end on the next tick.\n if (nOrig !== n && state.ended) endReadable(this);\n }\n\n if (ret !== null) this.emit('data', ret);\n\n return ret;\n};\n\nfunction onEofChunk(stream, state) {\n if (state.ended) return;\n if (state.decoder) {\n var chunk = state.decoder.end();\n if (chunk && chunk.length) {\n state.buffer.push(chunk);\n state.length += state.objectMode ? 1 : chunk.length;\n }\n }\n state.ended = true;\n\n // emit 'readable' now to make sure it gets picked up.\n emitReadable(stream);\n}\n\n// Don't emit readable right away in sync mode, because this can trigger\n// another read() call => stack overflow. This way, it might trigger\n// a nextTick recursion warning, but that's not so bad.\nfunction emitReadable(stream) {\n var state = stream._readableState;\n state.needReadable = false;\n if (!state.emittedReadable) {\n debug('emitReadable', state.flowing);\n state.emittedReadable = true;\n if (state.sync) pna.nextTick(emitReadable_, stream);else emitReadable_(stream);\n }\n}\n\nfunction emitReadable_(stream) {\n debug('emit readable');\n stream.emit('readable');\n flow(stream);\n}\n\n// at this point, the user has presumably seen the 'readable' event,\n// and called read() to consume some data. that may have triggered\n// in turn another _read(n) call, in which case reading = true if\n// it's in progress.\n// However, if we're not ended, or reading, and the length < hwm,\n// then go ahead and try to read some more preemptively.\nfunction maybeReadMore(stream, state) {\n if (!state.readingMore) {\n state.readingMore = true;\n pna.nextTick(maybeReadMore_, stream, state);\n }\n}\n\nfunction maybeReadMore_(stream, state) {\n var len = state.length;\n while (!state.reading && !state.flowing && !state.ended && state.length < state.highWaterMark) {\n debug('maybeReadMore read 0');\n stream.read(0);\n if (len === state.length)\n // didn't get any data, stop spinning.\n break;else len = state.length;\n }\n state.readingMore = false;\n}\n\n// abstract method. to be overridden in specific implementation classes.\n// call cb(er, data) where data is <= n in length.\n// for virtual (non-string, non-buffer) streams, \"length\" is somewhat\n// arbitrary, and perhaps not very meaningful.\nReadable.prototype._read = function (n) {\n this.emit('error', new Error('_read() is not implemented'));\n};\n\nReadable.prototype.pipe = function (dest, pipeOpts) {\n var src = this;\n var state = this._readableState;\n\n switch (state.pipesCount) {\n case 0:\n state.pipes = dest;\n break;\n case 1:\n state.pipes = [state.pipes, dest];\n break;\n default:\n state.pipes.push(dest);\n break;\n }\n state.pipesCount += 1;\n debug('pipe count=%d opts=%j', state.pipesCount, pipeOpts);\n\n var doEnd = (!pipeOpts || pipeOpts.end !== false) && dest !== process.stdout && dest !== process.stderr;\n\n var endFn = doEnd ? onend : unpipe;\n if (state.endEmitted) pna.nextTick(endFn);else src.once('end', endFn);\n\n dest.on('unpipe', onunpipe);\n function onunpipe(readable, unpipeInfo) {\n debug('onunpipe');\n if (readable === src) {\n if (unpipeInfo && unpipeInfo.hasUnpiped === false) {\n unpipeInfo.hasUnpiped = true;\n cleanup();\n }\n }\n }\n\n function onend() {\n debug('onend');\n dest.end();\n }\n\n // when the dest drains, it reduces the awaitDrain counter\n // on the source. This would be more elegant with a .once()\n // handler in flow(), but adding and removing repeatedly is\n // too slow.\n var ondrain = pipeOnDrain(src);\n dest.on('drain', ondrain);\n\n var cleanedUp = false;\n function cleanup() {\n debug('cleanup');\n // cleanup event handlers once the pipe is broken\n dest.removeListener('close', onclose);\n dest.removeListener('finish', onfinish);\n dest.removeListener('drain', ondrain);\n dest.removeListener('error', onerror);\n dest.removeListener('unpipe', onunpipe);\n src.removeListener('end', onend);\n src.removeListener('end', unpipe);\n src.removeListener('data', ondata);\n\n cleanedUp = true;\n\n // if the reader is waiting for a drain event from this\n // specific writer, then it would cause it to never start\n // flowing again.\n // So, if this is awaiting a drain, then we just call it now.\n // If we don't know, then assume that we are waiting for one.\n if (state.awaitDrain && (!dest._writableState || dest._writableState.needDrain)) ondrain();\n }\n\n // If the user pushes more data while we're writing to dest then we'll end up\n // in ondata again. However, we only want to increase awaitDrain once because\n // dest will only emit one 'drain' event for the multiple writes.\n // => Introduce a guard on increasing awaitDrain.\n var increasedAwaitDrain = false;\n src.on('data', ondata);\n function ondata(chunk) {\n debug('ondata');\n increasedAwaitDrain = false;\n var ret = dest.write(chunk);\n if (false === ret && !increasedAwaitDrain) {\n // If the user unpiped during `dest.write()`, it is possible\n // to get stuck in a permanently paused state if that write\n // also returned false.\n // => Check whether `dest` is still a piping destination.\n if ((state.pipesCount === 1 && state.pipes === dest || state.pipesCount > 1 && indexOf(state.pipes, dest) !== -1) && !cleanedUp) {\n debug('false write response, pause', src._readableState.awaitDrain);\n src._readableState.awaitDrain++;\n increasedAwaitDrain = true;\n }\n src.pause();\n }\n }\n\n // if the dest has an error, then stop piping into it.\n // however, don't suppress the throwing behavior for this.\n function onerror(er) {\n debug('onerror', er);\n unpipe();\n dest.removeListener('error', onerror);\n if (EElistenerCount(dest, 'error') === 0) dest.emit('error', er);\n }\n\n // Make sure our error handler is attached before userland ones.\n prependListener(dest, 'error', onerror);\n\n // Both close and finish should trigger unpipe, but only once.\n function onclose() {\n dest.removeListener('finish', onfinish);\n unpipe();\n }\n dest.once('close', onclose);\n function onfinish() {\n debug('onfinish');\n dest.removeListener('close', onclose);\n unpipe();\n }\n dest.once('finish', onfinish);\n\n function unpipe() {\n debug('unpipe');\n src.unpipe(dest);\n }\n\n // tell the dest that it's being piped to\n dest.emit('pipe', src);\n\n // start the flow if it hasn't been started already.\n if (!state.flowing) {\n debug('pipe resume');\n src.resume();\n }\n\n return dest;\n};\n\nfunction pipeOnDrain(src) {\n return function () {\n var state = src._readableState;\n debug('pipeOnDrain', state.awaitDrain);\n if (state.awaitDrain) state.awaitDrain--;\n if (state.awaitDrain === 0 && EElistenerCount(src, 'data')) {\n state.flowing = true;\n flow(src);\n }\n };\n}\n\nReadable.prototype.unpipe = function (dest) {\n var state = this._readableState;\n var unpipeInfo = { hasUnpiped: false };\n\n // if we're not piping anywhere, then do nothing.\n if (state.pipesCount === 0) return this;\n\n // just one destination. most common case.\n if (state.pipesCount === 1) {\n // passed in one, but it's not the right one.\n if (dest && dest !== state.pipes) return this;\n\n if (!dest) dest = state.pipes;\n\n // got a match.\n state.pipes = null;\n state.pipesCount = 0;\n state.flowing = false;\n if (dest) dest.emit('unpipe', this, unpipeInfo);\n return this;\n }\n\n // slow case. multiple pipe destinations.\n\n if (!dest) {\n // remove all.\n var dests = state.pipes;\n var len = state.pipesCount;\n state.pipes = null;\n state.pipesCount = 0;\n state.flowing = false;\n\n for (var i = 0; i < len; i++) {\n dests[i].emit('unpipe', this, unpipeInfo);\n }return this;\n }\n\n // try to find the right one.\n var index = indexOf(state.pipes, dest);\n if (index === -1) return this;\n\n state.pipes.splice(index, 1);\n state.pipesCount -= 1;\n if (state.pipesCount === 1) state.pipes = state.pipes[0];\n\n dest.emit('unpipe', this, unpipeInfo);\n\n return this;\n};\n\n// set up data events if they are asked for\n// Ensure readable listeners eventually get something\nReadable.prototype.on = function (ev, fn) {\n var res = Stream.prototype.on.call(this, ev, fn);\n\n if (ev === 'data') {\n // Start flowing on next tick if stream isn't explicitly paused\n if (this._readableState.flowing !== false) this.resume();\n } else if (ev === 'readable') {\n var state = this._readableState;\n if (!state.endEmitted && !state.readableListening) {\n state.readableListening = state.needReadable = true;\n state.emittedReadable = false;\n if (!state.reading) {\n pna.nextTick(nReadingNextTick, this);\n } else if (state.length) {\n emitReadable(this);\n }\n }\n }\n\n return res;\n};\nReadable.prototype.addListener = Readable.prototype.on;\n\nfunction nReadingNextTick(self) {\n debug('readable nexttick read 0');\n self.read(0);\n}\n\n// pause() and resume() are remnants of the legacy readable stream API\n// If the user uses them, then switch into old mode.\nReadable.prototype.resume = function () {\n var state = this._readableState;\n if (!state.flowing) {\n debug('resume');\n state.flowing = true;\n resume(this, state);\n }\n return this;\n};\n\nfunction resume(stream, state) {\n if (!state.resumeScheduled) {\n state.resumeScheduled = true;\n pna.nextTick(resume_, stream, state);\n }\n}\n\nfunction resume_(stream, state) {\n if (!state.reading) {\n debug('resume read 0');\n stream.read(0);\n }\n\n state.resumeScheduled = false;\n state.awaitDrain = 0;\n stream.emit('resume');\n flow(stream);\n if (state.flowing && !state.reading) stream.read(0);\n}\n\nReadable.prototype.pause = function () {\n debug('call pause flowing=%j', this._readableState.flowing);\n if (false !== this._readableState.flowing) {\n debug('pause');\n this._readableState.flowing = false;\n this.emit('pause');\n }\n return this;\n};\n\nfunction flow(stream) {\n var state = stream._readableState;\n debug('flow', state.flowing);\n while (state.flowing && stream.read() !== null) {}\n}\n\n// wrap an old-style stream as the async data source.\n// This is *not* part of the readable stream interface.\n// It is an ugly unfortunate mess of history.\nReadable.prototype.wrap = function (stream) {\n var _this = this;\n\n var state = this._readableState;\n var paused = false;\n\n stream.on('end', function () {\n debug('wrapped end');\n if (state.decoder && !state.ended) {\n var chunk = state.decoder.end();\n if (chunk && chunk.length) _this.push(chunk);\n }\n\n _this.push(null);\n });\n\n stream.on('data', function (chunk) {\n debug('wrapped data');\n if (state.decoder) chunk = state.decoder.write(chunk);\n\n // don't skip over falsy values in objectMode\n if (state.objectMode && (chunk === null || chunk === undefined)) return;else if (!state.objectMode && (!chunk || !chunk.length)) return;\n\n var ret = _this.push(chunk);\n if (!ret) {\n paused = true;\n stream.pause();\n }\n });\n\n // proxy all the other methods.\n // important when wrapping filters and duplexes.\n for (var i in stream) {\n if (this[i] === undefined && typeof stream[i] === 'function') {\n this[i] = function (method) {\n return function () {\n return stream[method].apply(stream, arguments);\n };\n }(i);\n }\n }\n\n // proxy certain important events.\n for (var n = 0; n < kProxyEvents.length; n++) {\n stream.on(kProxyEvents[n], this.emit.bind(this, kProxyEvents[n]));\n }\n\n // when we try to consume some more bytes, simply unpause the\n // underlying stream.\n this._read = function (n) {\n debug('wrapped _read', n);\n if (paused) {\n paused = false;\n stream.resume();\n }\n };\n\n return this;\n};\n\nObject.defineProperty(Readable.prototype, 'readableHighWaterMark', {\n // making it explicit this property is not enumerable\n // because otherwise some prototype manipulation in\n // userland will fail\n enumerable: false,\n get: function () {\n return this._readableState.highWaterMark;\n }\n});\n\n// exposed for testing purposes only.\nReadable._fromList = fromList;\n\n// Pluck off n bytes from an array of buffers.\n// Length is the combined lengths of all the buffers in the list.\n// This function is designed to be inlinable, so please take care when making\n// changes to the function body.\nfunction fromList(n, state) {\n // nothing buffered\n if (state.length === 0) return null;\n\n var ret;\n if (state.objectMode) ret = state.buffer.shift();else if (!n || n >= state.length) {\n // read it all, truncate the list\n if (state.decoder) ret = state.buffer.join('');else if (state.buffer.length === 1) ret = state.buffer.head.data;else ret = state.buffer.concat(state.length);\n state.buffer.clear();\n } else {\n // read part of list\n ret = fromListPartial(n, state.buffer, state.decoder);\n }\n\n return ret;\n}\n\n// Extracts only enough buffered data to satisfy the amount requested.\n// This function is designed to be inlinable, so please take care when making\n// changes to the function body.\nfunction fromListPartial(n, list, hasStrings) {\n var ret;\n if (n < list.head.data.length) {\n // slice is the same for buffers and strings\n ret = list.head.data.slice(0, n);\n list.head.data = list.head.data.slice(n);\n } else if (n === list.head.data.length) {\n // first chunk is a perfect match\n ret = list.shift();\n } else {\n // result spans more than one buffer\n ret = hasStrings ? copyFromBufferString(n, list) : copyFromBuffer(n, list);\n }\n return ret;\n}\n\n// Copies a specified amount of characters from the list of buffered data\n// chunks.\n// This function is designed to be inlinable, so please take care when making\n// changes to the function body.\nfunction copyFromBufferString(n, list) {\n var p = list.head;\n var c = 1;\n var ret = p.data;\n n -= ret.length;\n while (p = p.next) {\n var str = p.data;\n var nb = n > str.length ? str.length : n;\n if (nb === str.length) ret += str;else ret += str.slice(0, n);\n n -= nb;\n if (n === 0) {\n if (nb === str.length) {\n ++c;\n if (p.next) list.head = p.next;else list.head = list.tail = null;\n } else {\n list.head = p;\n p.data = str.slice(nb);\n }\n break;\n }\n ++c;\n }\n list.length -= c;\n return ret;\n}\n\n// Copies a specified amount of bytes from the list of buffered data chunks.\n// This function is designed to be inlinable, so please take care when making\n// changes to the function body.\nfunction copyFromBuffer(n, list) {\n var ret = Buffer.allocUnsafe(n);\n var p = list.head;\n var c = 1;\n p.data.copy(ret);\n n -= p.data.length;\n while (p = p.next) {\n var buf = p.data;\n var nb = n > buf.length ? buf.length : n;\n buf.copy(ret, ret.length - n, 0, nb);\n n -= nb;\n if (n === 0) {\n if (nb === buf.length) {\n ++c;\n if (p.next) list.head = p.next;else list.head = list.tail = null;\n } else {\n list.head = p;\n p.data = buf.slice(nb);\n }\n break;\n }\n ++c;\n }\n list.length -= c;\n return ret;\n}\n\nfunction endReadable(stream) {\n var state = stream._readableState;\n\n // If we get here before consuming all the bytes, then that is a\n // bug in node. Should never happen.\n if (state.length > 0) throw new Error('\"endReadable()\" called on non-empty stream');\n\n if (!state.endEmitted) {\n state.ended = true;\n pna.nextTick(endReadableNT, state, stream);\n }\n}\n\nfunction endReadableNT(state, stream) {\n // Check that we didn't get one last unshift.\n if (!state.endEmitted && state.length === 0) {\n state.endEmitted = true;\n stream.readable = false;\n stream.emit('end');\n }\n}\n\nfunction indexOf(xs, x) {\n for (var i = 0, l = xs.length; i < l; i++) {\n if (xs[i] === x) return i;\n }\n return -1;\n}","module.exports = require('events').EventEmitter;\n","'use strict';\n\n/**/\n\nvar pna = require('process-nextick-args');\n/**/\n\n// undocumented cb() API, needed for core, not for public API\nfunction destroy(err, cb) {\n var _this = this;\n\n var readableDestroyed = this._readableState && this._readableState.destroyed;\n var writableDestroyed = this._writableState && this._writableState.destroyed;\n\n if (readableDestroyed || writableDestroyed) {\n if (cb) {\n cb(err);\n } else if (err && (!this._writableState || !this._writableState.errorEmitted)) {\n pna.nextTick(emitErrorNT, this, err);\n }\n return this;\n }\n\n // we set destroyed to true before firing error callbacks in order\n // to make it re-entrance safe in case destroy() is called within callbacks\n\n if (this._readableState) {\n this._readableState.destroyed = true;\n }\n\n // if this is a duplex stream mark the writable part as destroyed as well\n if (this._writableState) {\n this._writableState.destroyed = true;\n }\n\n this._destroy(err || null, function (err) {\n if (!cb && err) {\n pna.nextTick(emitErrorNT, _this, err);\n if (_this._writableState) {\n _this._writableState.errorEmitted = true;\n }\n } else if (cb) {\n cb(err);\n }\n });\n\n return this;\n}\n\nfunction undestroy() {\n if (this._readableState) {\n this._readableState.destroyed = false;\n this._readableState.reading = false;\n this._readableState.ended = false;\n this._readableState.endEmitted = false;\n }\n\n if (this._writableState) {\n this._writableState.destroyed = false;\n this._writableState.ended = false;\n this._writableState.ending = false;\n this._writableState.finished = false;\n this._writableState.errorEmitted = false;\n }\n}\n\nfunction emitErrorNT(self, err) {\n self.emit('error', err);\n}\n\nmodule.exports = {\n destroy: destroy,\n undestroy: undestroy\n};","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\n/**/\n\nvar Buffer = require('safe-buffer').Buffer;\n/**/\n\nvar isEncoding = Buffer.isEncoding || function (encoding) {\n encoding = '' + encoding;\n switch (encoding && encoding.toLowerCase()) {\n case 'hex':case 'utf8':case 'utf-8':case 'ascii':case 'binary':case 'base64':case 'ucs2':case 'ucs-2':case 'utf16le':case 'utf-16le':case 'raw':\n return true;\n default:\n return false;\n }\n};\n\nfunction _normalizeEncoding(enc) {\n if (!enc) return 'utf8';\n var retried;\n while (true) {\n switch (enc) {\n case 'utf8':\n case 'utf-8':\n return 'utf8';\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return 'utf16le';\n case 'latin1':\n case 'binary':\n return 'latin1';\n case 'base64':\n case 'ascii':\n case 'hex':\n return enc;\n default:\n if (retried) return; // undefined\n enc = ('' + enc).toLowerCase();\n retried = true;\n }\n }\n};\n\n// Do not cache `Buffer.isEncoding` when checking encoding names as some\n// modules monkey-patch it to support additional encodings\nfunction normalizeEncoding(enc) {\n var nenc = _normalizeEncoding(enc);\n if (typeof nenc !== 'string' && (Buffer.isEncoding === isEncoding || !isEncoding(enc))) throw new Error('Unknown encoding: ' + enc);\n return nenc || enc;\n}\n\n// StringDecoder provides an interface for efficiently splitting a series of\n// buffers into a series of JS strings without breaking apart multi-byte\n// characters.\nexports.StringDecoder = StringDecoder;\nfunction StringDecoder(encoding) {\n this.encoding = normalizeEncoding(encoding);\n var nb;\n switch (this.encoding) {\n case 'utf16le':\n this.text = utf16Text;\n this.end = utf16End;\n nb = 4;\n break;\n case 'utf8':\n this.fillLast = utf8FillLast;\n nb = 4;\n break;\n case 'base64':\n this.text = base64Text;\n this.end = base64End;\n nb = 3;\n break;\n default:\n this.write = simpleWrite;\n this.end = simpleEnd;\n return;\n }\n this.lastNeed = 0;\n this.lastTotal = 0;\n this.lastChar = Buffer.allocUnsafe(nb);\n}\n\nStringDecoder.prototype.write = function (buf) {\n if (buf.length === 0) return '';\n var r;\n var i;\n if (this.lastNeed) {\n r = this.fillLast(buf);\n if (r === undefined) return '';\n i = this.lastNeed;\n this.lastNeed = 0;\n } else {\n i = 0;\n }\n if (i < buf.length) return r ? r + this.text(buf, i) : this.text(buf, i);\n return r || '';\n};\n\nStringDecoder.prototype.end = utf8End;\n\n// Returns only complete characters in a Buffer\nStringDecoder.prototype.text = utf8Text;\n\n// Attempts to complete a partial non-UTF-8 character using bytes from a Buffer\nStringDecoder.prototype.fillLast = function (buf) {\n if (this.lastNeed <= buf.length) {\n buf.copy(this.lastChar, this.lastTotal - this.lastNeed, 0, this.lastNeed);\n return this.lastChar.toString(this.encoding, 0, this.lastTotal);\n }\n buf.copy(this.lastChar, this.lastTotal - this.lastNeed, 0, buf.length);\n this.lastNeed -= buf.length;\n};\n\n// Checks the type of a UTF-8 byte, whether it's ASCII, a leading byte, or a\n// continuation byte. If an invalid byte is detected, -2 is returned.\nfunction utf8CheckByte(byte) {\n if (byte <= 0x7F) return 0;else if (byte >> 5 === 0x06) return 2;else if (byte >> 4 === 0x0E) return 3;else if (byte >> 3 === 0x1E) return 4;\n return byte >> 6 === 0x02 ? -1 : -2;\n}\n\n// Checks at most 3 bytes at the end of a Buffer in order to detect an\n// incomplete multi-byte UTF-8 character. The total number of bytes (2, 3, or 4)\n// needed to complete the UTF-8 character (if applicable) are returned.\nfunction utf8CheckIncomplete(self, buf, i) {\n var j = buf.length - 1;\n if (j < i) return 0;\n var nb = utf8CheckByte(buf[j]);\n if (nb >= 0) {\n if (nb > 0) self.lastNeed = nb - 1;\n return nb;\n }\n if (--j < i || nb === -2) return 0;\n nb = utf8CheckByte(buf[j]);\n if (nb >= 0) {\n if (nb > 0) self.lastNeed = nb - 2;\n return nb;\n }\n if (--j < i || nb === -2) return 0;\n nb = utf8CheckByte(buf[j]);\n if (nb >= 0) {\n if (nb > 0) {\n if (nb === 2) nb = 0;else self.lastNeed = nb - 3;\n }\n return nb;\n }\n return 0;\n}\n\n// Validates as many continuation bytes for a multi-byte UTF-8 character as\n// needed or are available. If we see a non-continuation byte where we expect\n// one, we \"replace\" the validated continuation bytes we've seen so far with\n// a single UTF-8 replacement character ('\\ufffd'), to match v8's UTF-8 decoding\n// behavior. The continuation byte check is included three times in the case\n// where all of the continuation bytes for a character exist in the same buffer.\n// It is also done this way as a slight performance increase instead of using a\n// loop.\nfunction utf8CheckExtraBytes(self, buf, p) {\n if ((buf[0] & 0xC0) !== 0x80) {\n self.lastNeed = 0;\n return '\\ufffd';\n }\n if (self.lastNeed > 1 && buf.length > 1) {\n if ((buf[1] & 0xC0) !== 0x80) {\n self.lastNeed = 1;\n return '\\ufffd';\n }\n if (self.lastNeed > 2 && buf.length > 2) {\n if ((buf[2] & 0xC0) !== 0x80) {\n self.lastNeed = 2;\n return '\\ufffd';\n }\n }\n }\n}\n\n// Attempts to complete a multi-byte UTF-8 character using bytes from a Buffer.\nfunction utf8FillLast(buf) {\n var p = this.lastTotal - this.lastNeed;\n var r = utf8CheckExtraBytes(this, buf, p);\n if (r !== undefined) return r;\n if (this.lastNeed <= buf.length) {\n buf.copy(this.lastChar, p, 0, this.lastNeed);\n return this.lastChar.toString(this.encoding, 0, this.lastTotal);\n }\n buf.copy(this.lastChar, p, 0, buf.length);\n this.lastNeed -= buf.length;\n}\n\n// Returns all complete UTF-8 characters in a Buffer. If the Buffer ended on a\n// partial character, the character's bytes are buffered until the required\n// number of bytes are available.\nfunction utf8Text(buf, i) {\n var total = utf8CheckIncomplete(this, buf, i);\n if (!this.lastNeed) return buf.toString('utf8', i);\n this.lastTotal = total;\n var end = buf.length - (total - this.lastNeed);\n buf.copy(this.lastChar, 0, end);\n return buf.toString('utf8', i, end);\n}\n\n// For UTF-8, a replacement character is added when ending on a partial\n// character.\nfunction utf8End(buf) {\n var r = buf && buf.length ? this.write(buf) : '';\n if (this.lastNeed) return r + '\\ufffd';\n return r;\n}\n\n// UTF-16LE typically needs two bytes per character, but even if we have an even\n// number of bytes available, we need to check if we end on a leading/high\n// surrogate. In that case, we need to wait for the next two bytes in order to\n// decode the last character properly.\nfunction utf16Text(buf, i) {\n if ((buf.length - i) % 2 === 0) {\n var r = buf.toString('utf16le', i);\n if (r) {\n var c = r.charCodeAt(r.length - 1);\n if (c >= 0xD800 && c <= 0xDBFF) {\n this.lastNeed = 2;\n this.lastTotal = 4;\n this.lastChar[0] = buf[buf.length - 2];\n this.lastChar[1] = buf[buf.length - 1];\n return r.slice(0, -1);\n }\n }\n return r;\n }\n this.lastNeed = 1;\n this.lastTotal = 2;\n this.lastChar[0] = buf[buf.length - 1];\n return buf.toString('utf16le', i, buf.length - 1);\n}\n\n// For UTF-16LE we do not explicitly append special replacement characters if we\n// end on a partial character, we simply let v8 handle that.\nfunction utf16End(buf) {\n var r = buf && buf.length ? this.write(buf) : '';\n if (this.lastNeed) {\n var end = this.lastTotal - this.lastNeed;\n return r + this.lastChar.toString('utf16le', 0, end);\n }\n return r;\n}\n\nfunction base64Text(buf, i) {\n var n = (buf.length - i) % 3;\n if (n === 0) return buf.toString('base64', i);\n this.lastNeed = 3 - n;\n this.lastTotal = 3;\n if (n === 1) {\n this.lastChar[0] = buf[buf.length - 1];\n } else {\n this.lastChar[0] = buf[buf.length - 2];\n this.lastChar[1] = buf[buf.length - 1];\n }\n return buf.toString('base64', i, buf.length - n);\n}\n\nfunction base64End(buf) {\n var r = buf && buf.length ? this.write(buf) : '';\n if (this.lastNeed) return r + this.lastChar.toString('base64', 0, 3 - this.lastNeed);\n return r;\n}\n\n// Pass bytes on through for single-byte encodings (e.g. ascii, latin1, hex)\nfunction simpleWrite(buf) {\n return buf.toString(this.encoding);\n}\n\nfunction simpleEnd(buf) {\n return buf && buf.length ? this.write(buf) : '';\n}","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// a transform stream is a readable/writable stream where you do\n// something with the data. Sometimes it's called a \"filter\",\n// but that's not a great name for it, since that implies a thing where\n// some bits pass through, and others are simply ignored. (That would\n// be a valid example of a transform, of course.)\n//\n// While the output is causally related to the input, it's not a\n// necessarily symmetric or synchronous transformation. For example,\n// a zlib stream might take multiple plain-text writes(), and then\n// emit a single compressed chunk some time in the future.\n//\n// Here's how this works:\n//\n// The Transform stream has all the aspects of the readable and writable\n// stream classes. When you write(chunk), that calls _write(chunk,cb)\n// internally, and returns false if there's a lot of pending writes\n// buffered up. When you call read(), that calls _read(n) until\n// there's enough pending readable data buffered up.\n//\n// In a transform stream, the written data is placed in a buffer. When\n// _read(n) is called, it transforms the queued up data, calling the\n// buffered _write cb's as it consumes chunks. If consuming a single\n// written chunk would result in multiple output chunks, then the first\n// outputted bit calls the readcb, and subsequent chunks just go into\n// the read buffer, and will cause it to emit 'readable' if necessary.\n//\n// This way, back-pressure is actually determined by the reading side,\n// since _read has to be called to start processing a new chunk. However,\n// a pathological inflate type of transform can cause excessive buffering\n// here. For example, imagine a stream where every byte of input is\n// interpreted as an integer from 0-255, and then results in that many\n// bytes of output. Writing the 4 bytes {ff,ff,ff,ff} would result in\n// 1kb of data being output. In this case, you could write a very small\n// amount of input, and end up with a very large amount of output. In\n// such a pathological inflating mechanism, there'd be no way to tell\n// the system to stop doing the transform. A single 4MB write could\n// cause the system to run out of memory.\n//\n// However, even in such a pathological case, only a single written chunk\n// would be consumed, and then the rest would wait (un-transformed) until\n// the results of the previous transformed chunk were consumed.\n\n'use strict';\n\nmodule.exports = Transform;\n\nvar Duplex = require('./_stream_duplex');\n\n/**/\nvar util = Object.create(require('core-util-is'));\nutil.inherits = require('inherits');\n/**/\n\nutil.inherits(Transform, Duplex);\n\nfunction afterTransform(er, data) {\n var ts = this._transformState;\n ts.transforming = false;\n\n var cb = ts.writecb;\n\n if (!cb) {\n return this.emit('error', new Error('write callback called multiple times'));\n }\n\n ts.writechunk = null;\n ts.writecb = null;\n\n if (data != null) // single equals check for both `null` and `undefined`\n this.push(data);\n\n cb(er);\n\n var rs = this._readableState;\n rs.reading = false;\n if (rs.needReadable || rs.length < rs.highWaterMark) {\n this._read(rs.highWaterMark);\n }\n}\n\nfunction Transform(options) {\n if (!(this instanceof Transform)) return new Transform(options);\n\n Duplex.call(this, options);\n\n this._transformState = {\n afterTransform: afterTransform.bind(this),\n needTransform: false,\n transforming: false,\n writecb: null,\n writechunk: null,\n writeencoding: null\n };\n\n // start out asking for a readable event once data is transformed.\n this._readableState.needReadable = true;\n\n // we have implemented the _read method, and done the other things\n // that Readable wants before the first _read call, so unset the\n // sync guard flag.\n this._readableState.sync = false;\n\n if (options) {\n if (typeof options.transform === 'function') this._transform = options.transform;\n\n if (typeof options.flush === 'function') this._flush = options.flush;\n }\n\n // When the writable side finishes, then flush out anything remaining.\n this.on('prefinish', prefinish);\n}\n\nfunction prefinish() {\n var _this = this;\n\n if (typeof this._flush === 'function') {\n this._flush(function (er, data) {\n done(_this, er, data);\n });\n } else {\n done(this, null, null);\n }\n}\n\nTransform.prototype.push = function (chunk, encoding) {\n this._transformState.needTransform = false;\n return Duplex.prototype.push.call(this, chunk, encoding);\n};\n\n// This is the part where you do stuff!\n// override this function in implementation classes.\n// 'chunk' is an input chunk.\n//\n// Call `push(newChunk)` to pass along transformed output\n// to the readable side. You may call 'push' zero or more times.\n//\n// Call `cb(err)` when you are done with this chunk. If you pass\n// an error, then that'll put the hurt on the whole operation. If you\n// never call cb(), then you'll never get another chunk.\nTransform.prototype._transform = function (chunk, encoding, cb) {\n throw new Error('_transform() is not implemented');\n};\n\nTransform.prototype._write = function (chunk, encoding, cb) {\n var ts = this._transformState;\n ts.writecb = cb;\n ts.writechunk = chunk;\n ts.writeencoding = encoding;\n if (!ts.transforming) {\n var rs = this._readableState;\n if (ts.needTransform || rs.needReadable || rs.length < rs.highWaterMark) this._read(rs.highWaterMark);\n }\n};\n\n// Doesn't matter what the args are here.\n// _transform does all the work.\n// That we got here means that the readable side wants more data.\nTransform.prototype._read = function (n) {\n var ts = this._transformState;\n\n if (ts.writechunk !== null && ts.writecb && !ts.transforming) {\n ts.transforming = true;\n this._transform(ts.writechunk, ts.writeencoding, ts.afterTransform);\n } else {\n // mark that we need a transform, so that any data that comes in\n // will get processed, now that we've asked for it.\n ts.needTransform = true;\n }\n};\n\nTransform.prototype._destroy = function (err, cb) {\n var _this2 = this;\n\n Duplex.prototype._destroy.call(this, err, function (err2) {\n cb(err2);\n _this2.emit('close');\n });\n};\n\nfunction done(stream, er, data) {\n if (er) return stream.emit('error', er);\n\n if (data != null) // single equals check for both `null` and `undefined`\n stream.push(data);\n\n // if there's nothing in the write buffer, then that means\n // that nothing more will ever be provided\n if (stream._writableState.length) throw new Error('Calling transform done when ws.length != 0');\n\n if (stream._transformState.transforming) throw new Error('Calling transform done when still transforming');\n\n return stream.push(null);\n}","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar path = require('path');\nvar buffer = require('buffer');\n\n/**\n * Standard libc error codes. Add more to this enum and ErrorStrings as they are\n * needed.\n * @url http://www.gnu.org/software/libc/manual/html_node/Error-Codes.html\n */\nvar ErrorCode;\n(function (ErrorCode) {\n ErrorCode[ErrorCode[\"EPERM\"] = 1] = \"EPERM\";\n ErrorCode[ErrorCode[\"ENOENT\"] = 2] = \"ENOENT\";\n ErrorCode[ErrorCode[\"EIO\"] = 5] = \"EIO\";\n ErrorCode[ErrorCode[\"EBADF\"] = 9] = \"EBADF\";\n ErrorCode[ErrorCode[\"EACCES\"] = 13] = \"EACCES\";\n ErrorCode[ErrorCode[\"EBUSY\"] = 16] = \"EBUSY\";\n ErrorCode[ErrorCode[\"EEXIST\"] = 17] = \"EEXIST\";\n ErrorCode[ErrorCode[\"ENOTDIR\"] = 20] = \"ENOTDIR\";\n ErrorCode[ErrorCode[\"EISDIR\"] = 21] = \"EISDIR\";\n ErrorCode[ErrorCode[\"EINVAL\"] = 22] = \"EINVAL\";\n ErrorCode[ErrorCode[\"EFBIG\"] = 27] = \"EFBIG\";\n ErrorCode[ErrorCode[\"ENOSPC\"] = 28] = \"ENOSPC\";\n ErrorCode[ErrorCode[\"EROFS\"] = 30] = \"EROFS\";\n ErrorCode[ErrorCode[\"ENOTEMPTY\"] = 39] = \"ENOTEMPTY\";\n ErrorCode[ErrorCode[\"ENOTSUP\"] = 95] = \"ENOTSUP\";\n})(ErrorCode || (ErrorCode = {}));\n/* tslint:disable:variable-name */\n/**\n * Strings associated with each error code.\n * @hidden\n */\nvar ErrorStrings = {};\nErrorStrings[ErrorCode.EPERM] = 'Operation not permitted.';\nErrorStrings[ErrorCode.ENOENT] = 'No such file or directory.';\nErrorStrings[ErrorCode.EIO] = 'Input/output error.';\nErrorStrings[ErrorCode.EBADF] = 'Bad file descriptor.';\nErrorStrings[ErrorCode.EACCES] = 'Permission denied.';\nErrorStrings[ErrorCode.EBUSY] = 'Resource busy or locked.';\nErrorStrings[ErrorCode.EEXIST] = 'File exists.';\nErrorStrings[ErrorCode.ENOTDIR] = 'File is not a directory.';\nErrorStrings[ErrorCode.EISDIR] = 'File is a directory.';\nErrorStrings[ErrorCode.EINVAL] = 'Invalid argument.';\nErrorStrings[ErrorCode.EFBIG] = 'File is too big.';\nErrorStrings[ErrorCode.ENOSPC] = 'No space left on disk.';\nErrorStrings[ErrorCode.EROFS] = 'Cannot modify a read-only file system.';\nErrorStrings[ErrorCode.ENOTEMPTY] = 'Directory is not empty.';\nErrorStrings[ErrorCode.ENOTSUP] = 'Operation is not supported.';\n/* tslint:enable:variable-name */\n/**\n * Represents a BrowserFS error. Passed back to applications after a failed\n * call to the BrowserFS API.\n */\nvar ApiError = /*@__PURE__*/(function (Error) {\n function ApiError(type, message, path$$1) {\n if ( message === void 0 ) message = ErrorStrings[type];\n\n Error.call(this, message);\n // Unsupported.\n this.syscall = \"\";\n this.errno = type;\n this.code = ErrorCode[type];\n this.path = path$$1;\n this.stack = new Error().stack;\n this.message = \"Error: \" + (this.code) + \": \" + message + (this.path ? (\", '\" + (this.path) + \"'\") : '');\n }\n\n if ( Error ) ApiError.__proto__ = Error;\n ApiError.prototype = Object.create( Error && Error.prototype );\n ApiError.prototype.constructor = ApiError;\n ApiError.fromJSON = function fromJSON (json) {\n var err = new ApiError(0);\n err.errno = json.errno;\n err.code = json.code;\n err.path = json.path;\n err.stack = json.stack;\n err.message = json.message;\n return err;\n };\n /**\n * Creates an ApiError object from a buffer.\n */\n ApiError.fromBuffer = function fromBuffer (buffer$$1, i) {\n if ( i === void 0 ) i = 0;\n\n return ApiError.fromJSON(JSON.parse(buffer$$1.toString('utf8', i + 4, i + 4 + buffer$$1.readUInt32LE(i))));\n };\n ApiError.FileError = function FileError (code, p) {\n return new ApiError(code, ErrorStrings[code], p);\n };\n ApiError.ENOENT = function ENOENT (path$$1) {\n return this.FileError(ErrorCode.ENOENT, path$$1);\n };\n ApiError.EEXIST = function EEXIST (path$$1) {\n return this.FileError(ErrorCode.EEXIST, path$$1);\n };\n ApiError.EISDIR = function EISDIR (path$$1) {\n return this.FileError(ErrorCode.EISDIR, path$$1);\n };\n ApiError.ENOTDIR = function ENOTDIR (path$$1) {\n return this.FileError(ErrorCode.ENOTDIR, path$$1);\n };\n ApiError.EPERM = function EPERM (path$$1) {\n return this.FileError(ErrorCode.EPERM, path$$1);\n };\n ApiError.ENOTEMPTY = function ENOTEMPTY (path$$1) {\n return this.FileError(ErrorCode.ENOTEMPTY, path$$1);\n };\n /**\n * @return A friendly error message.\n */\n ApiError.prototype.toString = function toString () {\n return this.message;\n };\n ApiError.prototype.toJSON = function toJSON () {\n return {\n errno: this.errno,\n code: this.code,\n path: this.path,\n stack: this.stack,\n message: this.message\n };\n };\n /**\n * Writes the API error into a buffer.\n */\n ApiError.prototype.writeToBuffer = function writeToBuffer (buffer$$1, i) {\n if ( buffer$$1 === void 0 ) buffer$$1 = Buffer.alloc(this.bufferSize());\n if ( i === void 0 ) i = 0;\n\n var bytesWritten = buffer$$1.write(JSON.stringify(this.toJSON()), i + 4);\n buffer$$1.writeUInt32LE(bytesWritten, i);\n return buffer$$1;\n };\n /**\n * The size of the API error in buffer-form in bytes.\n */\n ApiError.prototype.bufferSize = function bufferSize () {\n // 4 bytes for string length.\n return 4 + Buffer.byteLength(JSON.stringify(this.toJSON()));\n };\n\n return ApiError;\n}(Error));\n\nvar api_error = /*#__PURE__*/Object.freeze({\n get ErrorCode () { return ErrorCode; },\n ErrorStrings: ErrorStrings,\n ApiError: ApiError\n});\n\nvar ActionType;\n(function (ActionType) {\n // Indicates that the code should not do anything.\n ActionType[ActionType[\"NOP\"] = 0] = \"NOP\";\n // Indicates that the code should throw an exception.\n ActionType[ActionType[\"THROW_EXCEPTION\"] = 1] = \"THROW_EXCEPTION\";\n // Indicates that the code should truncate the file, but only if it is a file.\n ActionType[ActionType[\"TRUNCATE_FILE\"] = 2] = \"TRUNCATE_FILE\";\n // Indicates that the code should create the file.\n ActionType[ActionType[\"CREATE_FILE\"] = 3] = \"CREATE_FILE\";\n})(ActionType || (ActionType = {}));\n/**\n * Represents one of the following file flags. A convenience object.\n *\n * * `'r'` - Open file for reading. An exception occurs if the file does not exist.\n * * `'r+'` - Open file for reading and writing. An exception occurs if the file does not exist.\n * * `'rs'` - Open file for reading in synchronous mode. Instructs the filesystem to not cache writes.\n * * `'rs+'` - Open file for reading and writing, and opens the file in synchronous mode.\n * * `'w'` - Open file for writing. The file is created (if it does not exist) or truncated (if it exists).\n * * `'wx'` - Like 'w' but opens the file in exclusive mode.\n * * `'w+'` - Open file for reading and writing. The file is created (if it does not exist) or truncated (if it exists).\n * * `'wx+'` - Like 'w+' but opens the file in exclusive mode.\n * * `'a'` - Open file for appending. The file is created if it does not exist.\n * * `'ax'` - Like 'a' but opens the file in exclusive mode.\n * * `'a+'` - Open file for reading and appending. The file is created if it does not exist.\n * * `'ax+'` - Like 'a+' but opens the file in exclusive mode.\n *\n * Exclusive mode ensures that the file path is newly created.\n */\nvar FileFlag = function FileFlag(flagStr) {\n this.flagStr = flagStr;\n if (FileFlag.validFlagStrs.indexOf(flagStr) < 0) {\n throw new ApiError(ErrorCode.EINVAL, \"Invalid flag: \" + flagStr);\n }\n};\n/**\n * Get an object representing the given file flag.\n * @param modeStr The string representing the flag\n * @return The FileFlag object representing the flag\n * @throw when the flag string is invalid\n */\nFileFlag.getFileFlag = function getFileFlag (flagStr) {\n // Check cache first.\n if (FileFlag.flagCache.hasOwnProperty(flagStr)) {\n return FileFlag.flagCache[flagStr];\n }\n return FileFlag.flagCache[flagStr] = new FileFlag(flagStr);\n};\n/**\n * Get the underlying flag string for this flag.\n */\nFileFlag.prototype.getFlagString = function getFlagString () {\n return this.flagStr;\n};\n/**\n * Returns true if the file is readable.\n */\nFileFlag.prototype.isReadable = function isReadable () {\n return this.flagStr.indexOf('r') !== -1 || this.flagStr.indexOf('+') !== -1;\n};\n/**\n * Returns true if the file is writeable.\n */\nFileFlag.prototype.isWriteable = function isWriteable () {\n return this.flagStr.indexOf('w') !== -1 || this.flagStr.indexOf('a') !== -1 || this.flagStr.indexOf('+') !== -1;\n};\n/**\n * Returns true if the file mode should truncate.\n */\nFileFlag.prototype.isTruncating = function isTruncating () {\n return this.flagStr.indexOf('w') !== -1;\n};\n/**\n * Returns true if the file is appendable.\n */\nFileFlag.prototype.isAppendable = function isAppendable () {\n return this.flagStr.indexOf('a') !== -1;\n};\n/**\n * Returns true if the file is open in synchronous mode.\n */\nFileFlag.prototype.isSynchronous = function isSynchronous () {\n return this.flagStr.indexOf('s') !== -1;\n};\n/**\n * Returns true if the file is open in exclusive mode.\n */\nFileFlag.prototype.isExclusive = function isExclusive () {\n return this.flagStr.indexOf('x') !== -1;\n};\n/**\n * Returns one of the static fields on this object that indicates the\n * appropriate response to the path existing.\n */\nFileFlag.prototype.pathExistsAction = function pathExistsAction () {\n if (this.isExclusive()) {\n return ActionType.THROW_EXCEPTION;\n }\n else if (this.isTruncating()) {\n return ActionType.TRUNCATE_FILE;\n }\n else {\n return ActionType.NOP;\n }\n};\n/**\n * Returns one of the static fields on this object that indicates the\n * appropriate response to the path not existing.\n */\nFileFlag.prototype.pathNotExistsAction = function pathNotExistsAction () {\n if ((this.isWriteable() || this.isAppendable()) && this.flagStr !== 'r+') {\n return ActionType.CREATE_FILE;\n }\n else {\n return ActionType.THROW_EXCEPTION;\n }\n};\n// Contains cached FileMode instances.\nFileFlag.flagCache = {};\n// Array of valid mode strings.\nFileFlag.validFlagStrs = ['r', 'r+', 'rs', 'rs+', 'w', 'wx', 'w+', 'wx+', 'a', 'ax', 'a+', 'ax+'];\n\n/**\n * Indicates the type of the given file. Applied to 'mode'.\n */\nvar FileType;\n(function (FileType) {\n FileType[FileType[\"FILE\"] = 32768] = \"FILE\";\n FileType[FileType[\"DIRECTORY\"] = 16384] = \"DIRECTORY\";\n FileType[FileType[\"SYMLINK\"] = 40960] = \"SYMLINK\";\n})(FileType || (FileType = {}));\n/**\n * Emulation of Node's `fs.Stats` object.\n *\n * Attribute descriptions are from `man 2 stat'\n * @see http://nodejs.org/api/fs.html#fs_class_fs_stats\n * @see http://man7.org/linux/man-pages/man2/stat.2.html\n */\nvar Stats = function Stats(itemType, size, mode, atimeMs, mtimeMs, ctimeMs, birthtimeMs) {\n /**\n * UNSUPPORTED ATTRIBUTES\n * I assume no one is going to need these details, although we could fake\n * appropriate values if need be.\n */\n // ID of device containing file\n this.dev = 0;\n // inode number\n this.ino = 0;\n // device ID (if special file)\n this.rdev = 0;\n // number of hard links\n this.nlink = 1;\n // blocksize for file system I/O\n this.blksize = 4096;\n // @todo Maybe support these? atm, it's a one-user filesystem.\n // user ID of owner\n this.uid = 0;\n // group ID of owner\n this.gid = 0;\n // XXX: Some file systems stash data on stats objects.\n this.fileData = null;\n this.size = size;\n var currentTime = 0;\n if (typeof (atimeMs) !== 'number') {\n currentTime = Date.now();\n atimeMs = currentTime;\n }\n if (typeof (mtimeMs) !== 'number') {\n if (!currentTime) {\n currentTime = Date.now();\n }\n mtimeMs = currentTime;\n }\n if (typeof (ctimeMs) !== 'number') {\n if (!currentTime) {\n currentTime = Date.now();\n }\n ctimeMs = currentTime;\n }\n if (typeof (birthtimeMs) !== 'number') {\n if (!currentTime) {\n currentTime = Date.now();\n }\n birthtimeMs = currentTime;\n }\n this.atimeMs = atimeMs;\n this.ctimeMs = ctimeMs;\n this.mtimeMs = mtimeMs;\n this.birthtimeMs = birthtimeMs;\n if (!mode) {\n switch (itemType) {\n case FileType.FILE:\n this.mode = 0x1a4;\n break;\n case FileType.DIRECTORY:\n default:\n this.mode = 0x1ff;\n }\n }\n else {\n this.mode = mode;\n }\n // number of 512B blocks allocated\n this.blocks = Math.ceil(size / 512);\n // Check if mode also includes top-most bits, which indicate the file's\n // type.\n if (this.mode < 0x1000) {\n this.mode |= itemType;\n }\n};\n\nvar prototypeAccessors = { atime: { configurable: true },mtime: { configurable: true },ctime: { configurable: true },birthtime: { configurable: true } };\nStats.fromBuffer = function fromBuffer (buffer$$1) {\n var size = buffer$$1.readUInt32LE(0), mode = buffer$$1.readUInt32LE(4), atime = buffer$$1.readDoubleLE(8), mtime = buffer$$1.readDoubleLE(16), ctime = buffer$$1.readDoubleLE(24);\n return new Stats(mode & 0xF000, size, mode & 0xFFF, atime, mtime, ctime);\n};\n/**\n * Clones the stats object.\n */\nStats.clone = function clone (s) {\n return new Stats(s.mode & 0xF000, s.size, s.mode & 0xFFF, s.atimeMs, s.mtimeMs, s.ctimeMs, s.birthtimeMs);\n};\nprototypeAccessors.atime.get = function () {\n return new Date(this.atimeMs);\n};\nprototypeAccessors.mtime.get = function () {\n return new Date(this.mtimeMs);\n};\nprototypeAccessors.ctime.get = function () {\n return new Date(this.ctimeMs);\n};\nprototypeAccessors.birthtime.get = function () {\n return new Date(this.birthtimeMs);\n};\nStats.prototype.toBuffer = function toBuffer () {\n var buffer$$1 = Buffer.alloc(32);\n buffer$$1.writeUInt32LE(this.size, 0);\n buffer$$1.writeUInt32LE(this.mode, 4);\n buffer$$1.writeDoubleLE(this.atime.getTime(), 8);\n buffer$$1.writeDoubleLE(this.mtime.getTime(), 16);\n buffer$$1.writeDoubleLE(this.ctime.getTime(), 24);\n return buffer$$1;\n};\n/**\n * @return [Boolean] True if this item is a file.\n */\nStats.prototype.isFile = function isFile () {\n return (this.mode & 0xF000) === FileType.FILE;\n};\n/**\n * @return [Boolean] True if this item is a directory.\n */\nStats.prototype.isDirectory = function isDirectory () {\n return (this.mode & 0xF000) === FileType.DIRECTORY;\n};\n/**\n * @return [Boolean] True if this item is a symbolic link (only valid through lstat)\n */\nStats.prototype.isSymbolicLink = function isSymbolicLink () {\n return (this.mode & 0xF000) === FileType.SYMLINK;\n};\n/**\n * Change the mode of the file. We use this helper function to prevent messing\n * up the type of the file, which is encoded in mode.\n */\nStats.prototype.chmod = function chmod (mode) {\n this.mode = (this.mode & 0xF000) | mode;\n};\n// We don't support the following types of files.\nStats.prototype.isSocket = function isSocket () {\n return false;\n};\nStats.prototype.isBlockDevice = function isBlockDevice () {\n return false;\n};\nStats.prototype.isCharacterDevice = function isCharacterDevice () {\n return false;\n};\nStats.prototype.isFIFO = function isFIFO () {\n return false;\n};\n\nObject.defineProperties( Stats.prototype, prototypeAccessors );\n\n/**\n * @hidden\n */\nvar toExport = typeof (window) !== 'undefined' ? window : typeof (self) !== 'undefined' ? self : global;\n\n/**\n * @hidden\n */\nvar bfsSetImmediate;\nif (typeof (setImmediate) !== \"undefined\") {\n bfsSetImmediate = setImmediate;\n}\nelse {\n var gScope = toExport;\n var timeouts = [];\n var messageName = \"zero-timeout-message\";\n var canUsePostMessage = function () {\n if (typeof gScope.importScripts !== 'undefined' || !gScope.postMessage) {\n return false;\n }\n var postMessageIsAsync = true;\n var oldOnMessage = gScope.onmessage;\n gScope.onmessage = function () {\n postMessageIsAsync = false;\n };\n gScope.postMessage('', '*');\n gScope.onmessage = oldOnMessage;\n return postMessageIsAsync;\n };\n if (canUsePostMessage()) {\n bfsSetImmediate = function (fn) {\n timeouts.push(fn);\n gScope.postMessage(messageName, \"*\");\n };\n var handleMessage = function (event) {\n if (event.source === self && event.data === messageName) {\n if (event.stopPropagation) {\n event.stopPropagation();\n }\n else {\n event.cancelBubble = true;\n }\n if (timeouts.length > 0) {\n var fn = timeouts.shift();\n return fn();\n }\n }\n };\n if (gScope.addEventListener) {\n gScope.addEventListener('message', handleMessage, true);\n }\n else {\n gScope.attachEvent('onmessage', handleMessage);\n }\n }\n else if (gScope.MessageChannel) {\n // WebWorker MessageChannel\n var channel = new gScope.MessageChannel();\n channel.port1.onmessage = function (event) {\n if (timeouts.length > 0) {\n return timeouts.shift()();\n }\n };\n bfsSetImmediate = function (fn) {\n timeouts.push(fn);\n channel.port2.postMessage('');\n };\n }\n else {\n bfsSetImmediate = function (fn) {\n return setTimeout(fn, 0);\n };\n }\n}\nvar setImmediate$1 = bfsSetImmediate;\n\n/** Used for unit testing. Defaults to a NOP. */\nvar wrapCbHook = function (cb, numArgs) {\n return cb;\n};\n/**\n * Wraps a callback function, ensuring it is invoked through setImmediate.\n * @hidden\n */\nfunction wrapCb(cb, numArgs) {\n if (typeof cb !== 'function') {\n throw new Error('Callback must be a function.');\n }\n var hookedCb = wrapCbHook(cb, numArgs);\n // We could use `arguments`, but Function.call/apply is expensive. And we only\n // need to handle 1-3 arguments\n switch (numArgs) {\n case 1:\n return function (arg1) {\n setImmediate$1(function () {\n return hookedCb(arg1);\n });\n };\n case 2:\n return function (arg1, arg2) {\n setImmediate$1(function () {\n return hookedCb(arg1, arg2);\n });\n };\n case 3:\n return function (arg1, arg2, arg3) {\n setImmediate$1(function () {\n return hookedCb(arg1, arg2, arg3);\n });\n };\n default:\n throw new Error('Invalid invocation of wrapCb.');\n }\n}\n/**\n * @hidden\n */\nfunction assertRoot(fs) {\n if (fs) {\n return fs;\n }\n throw new ApiError(ErrorCode.EIO, \"Initialize BrowserFS with a file system using BrowserFS.initialize(filesystem)\");\n}\n/**\n * @hidden\n */\nfunction normalizeMode(mode, def) {\n switch (typeof mode) {\n case 'number':\n // (path, flag, mode, cb?)\n return mode;\n case 'string':\n // (path, flag, modeString, cb?)\n var trueMode = parseInt(mode, 8);\n if (!isNaN(trueMode)) {\n return trueMode;\n }\n // Invalid string.\n return def;\n default:\n return def;\n }\n}\n/**\n * @hidden\n */\nfunction normalizeTime(time) {\n if (time instanceof Date) {\n return time;\n }\n else if (typeof time === 'number') {\n return new Date(time * 1000);\n }\n else {\n throw new ApiError(ErrorCode.EINVAL, \"Invalid time.\");\n }\n}\n/**\n * @hidden\n */\nfunction normalizePath(p) {\n // Node doesn't allow null characters in paths.\n if (p.indexOf('\\u0000') >= 0) {\n throw new ApiError(ErrorCode.EINVAL, 'Path must be a string without null bytes.');\n }\n else if (p === '') {\n throw new ApiError(ErrorCode.EINVAL, 'Path must not be empty.');\n }\n return path.resolve(p);\n}\n/**\n * @hidden\n */\nfunction normalizeOptions(options, defEnc, defFlag, defMode) {\n // typeof null === 'object' so special-case handing is needed.\n switch (options === null ? 'null' : typeof options) {\n case 'object':\n return {\n encoding: typeof options['encoding'] !== 'undefined' ? options['encoding'] : defEnc,\n flag: typeof options['flag'] !== 'undefined' ? options['flag'] : defFlag,\n mode: normalizeMode(options['mode'], defMode)\n };\n case 'string':\n return {\n encoding: options,\n flag: defFlag,\n mode: defMode\n };\n case 'null':\n case 'undefined':\n case 'function':\n return {\n encoding: defEnc,\n flag: defFlag,\n mode: defMode\n };\n default:\n throw new TypeError((\"\\\"options\\\" must be a string or an object, got \" + (typeof options) + \" instead.\"));\n }\n}\n/**\n * The default callback is a NOP.\n * @hidden\n * @private\n */\nfunction nopCb() {\n // NOP.\n}\n/**\n * The node frontend to all filesystems.\n * This layer handles:\n *\n * * Sanity checking inputs.\n * * Normalizing paths.\n * * Resetting stack depth for asynchronous operations which may not go through\n * the browser by wrapping all input callbacks using `setImmediate`.\n * * Performing the requested operation through the filesystem or the file\n * descriptor, as appropriate.\n * * Handling optional arguments and setting default arguments.\n * @see http://nodejs.org/api/fs.html\n */\nvar FS = function FS() {\n /* tslint:enable:variable-name */\n this.F_OK = 0;\n this.R_OK = 4;\n this.W_OK = 2;\n this.X_OK = 1;\n this.root = null;\n this.fdMap = {};\n this.nextFd = 100;\n};\nFS.prototype.initialize = function initialize (rootFS) {\n if (!rootFS.constructor.isAvailable()) {\n throw new ApiError(ErrorCode.EINVAL, 'Tried to instantiate BrowserFS with an unavailable file system.');\n }\n return this.root = rootFS;\n};\n/**\n * converts Date or number to a fractional UNIX timestamp\n * Grabbed from NodeJS sources (lib/fs.js)\n */\nFS.prototype._toUnixTimestamp = function _toUnixTimestamp (time) {\n if (typeof time === 'number') {\n return time;\n }\n else if (time instanceof Date) {\n return time.getTime() / 1000;\n }\n throw new Error(\"Cannot parse time: \" + time);\n};\n/**\n * **NONSTANDARD**: Grab the FileSystem instance that backs this API.\n * @return [BrowserFS.FileSystem | null] Returns null if the file system has\n * not been initialized.\n */\nFS.prototype.getRootFS = function getRootFS () {\n if (this.root) {\n return this.root;\n }\n else {\n return null;\n }\n};\n// FILE OR DIRECTORY METHODS\n/**\n * Asynchronous rename. No arguments other than a possible exception are given\n * to the completion callback.\n * @param oldPath\n * @param newPath\n * @param callback\n */\nFS.prototype.rename = function rename (oldPath, newPath, cb) {\n if ( cb === void 0 ) cb = nopCb;\n\n var newCb = wrapCb(cb, 1);\n try {\n assertRoot(this.root).rename(normalizePath(oldPath), normalizePath(newPath), newCb);\n }\n catch (e) {\n newCb(e);\n }\n};\n/**\n * Synchronous rename.\n * @param oldPath\n * @param newPath\n */\nFS.prototype.renameSync = function renameSync (oldPath, newPath) {\n assertRoot(this.root).renameSync(normalizePath(oldPath), normalizePath(newPath));\n};\n/**\n * Test whether or not the given path exists by checking with the file system.\n * Then call the callback argument with either true or false.\n * @example Sample invocation\n * fs.exists('/etc/passwd', function (exists) {\n * util.debug(exists ? \"it's there\" : \"no passwd!\");\n * });\n * @param path\n * @param callback\n */\nFS.prototype.exists = function exists (path$$1, cb) {\n if ( cb === void 0 ) cb = nopCb;\n\n var newCb = wrapCb(cb, 1);\n try {\n return assertRoot(this.root).exists(normalizePath(path$$1), newCb);\n }\n catch (e) {\n // Doesn't return an error. If something bad happens, we assume it just\n // doesn't exist.\n return newCb(false);\n }\n};\n/**\n * Test whether or not the given path exists by checking with the file system.\n * @param path\n * @return [boolean]\n */\nFS.prototype.existsSync = function existsSync (path$$1) {\n try {\n return assertRoot(this.root).existsSync(normalizePath(path$$1));\n }\n catch (e) {\n // Doesn't return an error. If something bad happens, we assume it just\n // doesn't exist.\n return false;\n }\n};\n/**\n * Asynchronous `stat`.\n * @param path\n * @param callback\n */\nFS.prototype.stat = function stat (path$$1, cb) {\n if ( cb === void 0 ) cb = nopCb;\n\n var newCb = wrapCb(cb, 2);\n try {\n return assertRoot(this.root).stat(normalizePath(path$$1), false, newCb);\n }\n catch (e) {\n return newCb(e);\n }\n};\n/**\n * Synchronous `stat`.\n * @param path\n * @return [BrowserFS.node.fs.Stats]\n */\nFS.prototype.statSync = function statSync (path$$1) {\n return assertRoot(this.root).statSync(normalizePath(path$$1), false);\n};\n/**\n * Asynchronous `lstat`.\n * `lstat()` is identical to `stat()`, except that if path is a symbolic link,\n * then the link itself is stat-ed, not the file that it refers to.\n * @param path\n * @param callback\n */\nFS.prototype.lstat = function lstat (path$$1, cb) {\n if ( cb === void 0 ) cb = nopCb;\n\n var newCb = wrapCb(cb, 2);\n try {\n return assertRoot(this.root).stat(normalizePath(path$$1), true, newCb);\n }\n catch (e) {\n return newCb(e);\n }\n};\n/**\n * Synchronous `lstat`.\n * `lstat()` is identical to `stat()`, except that if path is a symbolic link,\n * then the link itself is stat-ed, not the file that it refers to.\n * @param path\n * @return [BrowserFS.node.fs.Stats]\n */\nFS.prototype.lstatSync = function lstatSync (path$$1) {\n return assertRoot(this.root).statSync(normalizePath(path$$1), true);\n};\nFS.prototype.truncate = function truncate (path$$1, arg2, cb) {\n if ( arg2 === void 0 ) arg2 = 0;\n if ( cb === void 0 ) cb = nopCb;\n\n var len = 0;\n if (typeof arg2 === 'function') {\n cb = arg2;\n }\n else if (typeof arg2 === 'number') {\n len = arg2;\n }\n var newCb = wrapCb(cb, 1);\n try {\n if (len < 0) {\n throw new ApiError(ErrorCode.EINVAL);\n }\n return assertRoot(this.root).truncate(normalizePath(path$$1), len, newCb);\n }\n catch (e) {\n return newCb(e);\n }\n};\n/**\n * Synchronous `truncate`.\n * @param path\n * @param len\n */\nFS.prototype.truncateSync = function truncateSync (path$$1, len) {\n if ( len === void 0 ) len = 0;\n\n if (len < 0) {\n throw new ApiError(ErrorCode.EINVAL);\n }\n return assertRoot(this.root).truncateSync(normalizePath(path$$1), len);\n};\n/**\n * Asynchronous `unlink`.\n * @param path\n * @param callback\n */\nFS.prototype.unlink = function unlink (path$$1, cb) {\n if ( cb === void 0 ) cb = nopCb;\n\n var newCb = wrapCb(cb, 1);\n try {\n return assertRoot(this.root).unlink(normalizePath(path$$1), newCb);\n }\n catch (e) {\n return newCb(e);\n }\n};\n/**\n * Synchronous `unlink`.\n * @param path\n */\nFS.prototype.unlinkSync = function unlinkSync (path$$1) {\n return assertRoot(this.root).unlinkSync(normalizePath(path$$1));\n};\nFS.prototype.open = function open (path$$1, flag, arg2, cb) {\n var this$1 = this;\n if ( cb === void 0 ) cb = nopCb;\n\n var mode = normalizeMode(arg2, 0x1a4);\n cb = typeof arg2 === 'function' ? arg2 : cb;\n var newCb = wrapCb(cb, 2);\n try {\n assertRoot(this.root).open(normalizePath(path$$1), FileFlag.getFileFlag(flag), mode, function (e, file) {\n if (file) {\n newCb(e, this$1.getFdForFile(file));\n }\n else {\n newCb(e);\n }\n });\n }\n catch (e) {\n newCb(e);\n }\n};\n/**\n * Synchronous file open.\n * @see http://www.manpagez.com/man/2/open/\n * @param path\n * @param flags\n * @param mode defaults to `0644`\n * @return [BrowserFS.File]\n */\nFS.prototype.openSync = function openSync (path$$1, flag, mode) {\n if ( mode === void 0 ) mode = 0x1a4;\n\n return this.getFdForFile(assertRoot(this.root).openSync(normalizePath(path$$1), FileFlag.getFileFlag(flag), normalizeMode(mode, 0x1a4)));\n};\nFS.prototype.readFile = function readFile (filename, arg2, cb) {\n if ( arg2 === void 0 ) arg2 = {};\n if ( cb === void 0 ) cb = nopCb;\n\n var options = normalizeOptions(arg2, null, 'r', null);\n cb = typeof arg2 === 'function' ? arg2 : cb;\n var newCb = wrapCb(cb, 2);\n try {\n var flag = FileFlag.getFileFlag(options['flag']);\n if (!flag.isReadable()) {\n return newCb(new ApiError(ErrorCode.EINVAL, 'Flag passed to readFile must allow for reading.'));\n }\n return assertRoot(this.root).readFile(normalizePath(filename), options.encoding, flag, newCb);\n }\n catch (e) {\n return newCb(e);\n }\n};\nFS.prototype.readFileSync = function readFileSync (filename, arg2) {\n if ( arg2 === void 0 ) arg2 = {};\n\n var options = normalizeOptions(arg2, null, 'r', null);\n var flag = FileFlag.getFileFlag(options.flag);\n if (!flag.isReadable()) {\n throw new ApiError(ErrorCode.EINVAL, 'Flag passed to readFile must allow for reading.');\n }\n return assertRoot(this.root).readFileSync(normalizePath(filename), options.encoding, flag);\n};\nFS.prototype.writeFile = function writeFile (filename, data, arg3, cb) {\n if ( arg3 === void 0 ) arg3 = {};\n if ( cb === void 0 ) cb = nopCb;\n\n var options = normalizeOptions(arg3, 'utf8', 'w', 0x1a4);\n cb = typeof arg3 === 'function' ? arg3 : cb;\n var newCb = wrapCb(cb, 1);\n try {\n var flag = FileFlag.getFileFlag(options.flag);\n if (!flag.isWriteable()) {\n return newCb(new ApiError(ErrorCode.EINVAL, 'Flag passed to writeFile must allow for writing.'));\n }\n return assertRoot(this.root).writeFile(normalizePath(filename), data, options.encoding, flag, options.mode, newCb);\n }\n catch (e) {\n return newCb(e);\n }\n};\nFS.prototype.writeFileSync = function writeFileSync (filename, data, arg3) {\n var options = normalizeOptions(arg3, 'utf8', 'w', 0x1a4);\n var flag = FileFlag.getFileFlag(options.flag);\n if (!flag.isWriteable()) {\n throw new ApiError(ErrorCode.EINVAL, 'Flag passed to writeFile must allow for writing.');\n }\n return assertRoot(this.root).writeFileSync(normalizePath(filename), data, options.encoding, flag, options.mode);\n};\nFS.prototype.appendFile = function appendFile (filename, data, arg3, cb) {\n if ( cb === void 0 ) cb = nopCb;\n\n var options = normalizeOptions(arg3, 'utf8', 'a', 0x1a4);\n cb = typeof arg3 === 'function' ? arg3 : cb;\n var newCb = wrapCb(cb, 1);\n try {\n var flag = FileFlag.getFileFlag(options.flag);\n if (!flag.isAppendable()) {\n return newCb(new ApiError(ErrorCode.EINVAL, 'Flag passed to appendFile must allow for appending.'));\n }\n assertRoot(this.root).appendFile(normalizePath(filename), data, options.encoding, flag, options.mode, newCb);\n }\n catch (e) {\n newCb(e);\n }\n};\nFS.prototype.appendFileSync = function appendFileSync (filename, data, arg3) {\n var options = normalizeOptions(arg3, 'utf8', 'a', 0x1a4);\n var flag = FileFlag.getFileFlag(options.flag);\n if (!flag.isAppendable()) {\n throw new ApiError(ErrorCode.EINVAL, 'Flag passed to appendFile must allow for appending.');\n }\n return assertRoot(this.root).appendFileSync(normalizePath(filename), data, options.encoding, flag, options.mode);\n};\n// FILE DESCRIPTOR METHODS\n/**\n * Asynchronous `fstat`.\n * `fstat()` is identical to `stat()`, except that the file to be stat-ed is\n * specified by the file descriptor `fd`.\n * @param fd\n * @param callback\n */\nFS.prototype.fstat = function fstat (fd, cb) {\n if ( cb === void 0 ) cb = nopCb;\n\n var newCb = wrapCb(cb, 2);\n try {\n var file = this.fd2file(fd);\n file.stat(newCb);\n }\n catch (e) {\n newCb(e);\n }\n};\n/**\n * Synchronous `fstat`.\n * `fstat()` is identical to `stat()`, except that the file to be stat-ed is\n * specified by the file descriptor `fd`.\n * @param fd\n * @return [BrowserFS.node.fs.Stats]\n */\nFS.prototype.fstatSync = function fstatSync (fd) {\n return this.fd2file(fd).statSync();\n};\n/**\n * Asynchronous close.\n * @param fd\n * @param callback\n */\nFS.prototype.close = function close (fd, cb) {\n var this$1 = this;\n if ( cb === void 0 ) cb = nopCb;\n\n var newCb = wrapCb(cb, 1);\n try {\n this.fd2file(fd).close(function (e) {\n if (!e) {\n this$1.closeFd(fd);\n }\n newCb(e);\n });\n }\n catch (e) {\n newCb(e);\n }\n};\n/**\n * Synchronous close.\n * @param fd\n */\nFS.prototype.closeSync = function closeSync (fd) {\n this.fd2file(fd).closeSync();\n this.closeFd(fd);\n};\nFS.prototype.ftruncate = function ftruncate (fd, arg2, cb) {\n if ( cb === void 0 ) cb = nopCb;\n\n var length = typeof arg2 === 'number' ? arg2 : 0;\n cb = typeof arg2 === 'function' ? arg2 : cb;\n var newCb = wrapCb(cb, 1);\n try {\n var file = this.fd2file(fd);\n if (length < 0) {\n throw new ApiError(ErrorCode.EINVAL);\n }\n file.truncate(length, newCb);\n }\n catch (e) {\n newCb(e);\n }\n};\n/**\n * Synchronous ftruncate.\n * @param fd\n * @param len\n */\nFS.prototype.ftruncateSync = function ftruncateSync (fd, len) {\n if ( len === void 0 ) len = 0;\n\n var file = this.fd2file(fd);\n if (len < 0) {\n throw new ApiError(ErrorCode.EINVAL);\n }\n file.truncateSync(len);\n};\n/**\n * Asynchronous fsync.\n * @param fd\n * @param callback\n */\nFS.prototype.fsync = function fsync (fd, cb) {\n if ( cb === void 0 ) cb = nopCb;\n\n var newCb = wrapCb(cb, 1);\n try {\n this.fd2file(fd).sync(newCb);\n }\n catch (e) {\n newCb(e);\n }\n};\n/**\n * Synchronous fsync.\n * @param fd\n */\nFS.prototype.fsyncSync = function fsyncSync (fd) {\n this.fd2file(fd).syncSync();\n};\n/**\n * Asynchronous fdatasync.\n * @param fd\n * @param callback\n */\nFS.prototype.fdatasync = function fdatasync (fd, cb) {\n if ( cb === void 0 ) cb = nopCb;\n\n var newCb = wrapCb(cb, 1);\n try {\n this.fd2file(fd).datasync(newCb);\n }\n catch (e) {\n newCb(e);\n }\n};\n/**\n * Synchronous fdatasync.\n * @param fd\n */\nFS.prototype.fdatasyncSync = function fdatasyncSync (fd) {\n this.fd2file(fd).datasyncSync();\n};\nFS.prototype.write = function write (fd, arg2, arg3, arg4, arg5, cb) {\n if ( cb === void 0 ) cb = nopCb;\n\n var buffer$$1, offset, length, position = null;\n if (typeof arg2 === 'string') {\n // Signature 1: (fd, string, [position?, [encoding?]], cb?)\n var encoding = 'utf8';\n switch (typeof arg3) {\n case 'function':\n // (fd, string, cb)\n cb = arg3;\n break;\n case 'number':\n // (fd, string, position, encoding?, cb?)\n position = arg3;\n encoding = typeof arg4 === 'string' ? arg4 : 'utf8';\n cb = typeof arg5 === 'function' ? arg5 : cb;\n break;\n default:\n // ...try to find the callback and get out of here!\n cb = typeof arg4 === 'function' ? arg4 : typeof arg5 === 'function' ? arg5 : cb;\n return cb(new ApiError(ErrorCode.EINVAL, 'Invalid arguments.'));\n }\n buffer$$1 = Buffer.from(arg2, encoding);\n offset = 0;\n length = buffer$$1.length;\n }\n else {\n // Signature 2: (fd, buffer, offset, length, position?, cb?)\n buffer$$1 = arg2;\n offset = arg3;\n length = arg4;\n position = typeof arg5 === 'number' ? arg5 : null;\n cb = typeof arg5 === 'function' ? arg5 : cb;\n }\n var newCb = wrapCb(cb, 3);\n try {\n var file = this.fd2file(fd);\n if (position === undefined || position === null) {\n position = file.getPos();\n }\n file.write(buffer$$1, offset, length, position, newCb);\n }\n catch (e) {\n newCb(e);\n }\n};\nFS.prototype.writeSync = function writeSync (fd, arg2, arg3, arg4, arg5) {\n var buffer$$1, offset = 0, length, position;\n if (typeof arg2 === 'string') {\n // Signature 1: (fd, string, [position?, [encoding?]])\n position = typeof arg3 === 'number' ? arg3 : null;\n var encoding = typeof arg4 === 'string' ? arg4 : 'utf8';\n offset = 0;\n buffer$$1 = Buffer.from(arg2, encoding);\n length = buffer$$1.length;\n }\n else {\n // Signature 2: (fd, buffer, offset, length, position?)\n buffer$$1 = arg2;\n offset = arg3;\n length = arg4;\n position = typeof arg5 === 'number' ? arg5 : null;\n }\n var file = this.fd2file(fd);\n if (position === undefined || position === null) {\n position = file.getPos();\n }\n return file.writeSync(buffer$$1, offset, length, position);\n};\nFS.prototype.read = function read (fd, arg2, arg3, arg4, arg5, cb) {\n if ( cb === void 0 ) cb = nopCb;\n\n var position, offset, length, buffer$$1, newCb;\n if (typeof arg2 === 'number') {\n // legacy interface\n // (fd, length, position, encoding, callback)\n length = arg2;\n position = arg3;\n var encoding = arg4;\n cb = typeof arg5 === 'function' ? arg5 : cb;\n offset = 0;\n buffer$$1 = Buffer.alloc(length);\n // XXX: Inefficient.\n // Wrap the cb so we shelter upper layers of the API from these\n // shenanigans.\n newCb = wrapCb(function (err, bytesRead, buf) {\n if (err) {\n return cb(err);\n }\n cb(err, buf.toString(encoding), bytesRead);\n }, 3);\n }\n else {\n buffer$$1 = arg2;\n offset = arg3;\n length = arg4;\n position = arg5;\n newCb = wrapCb(cb, 3);\n }\n try {\n var file = this.fd2file(fd);\n if (position === undefined || position === null) {\n position = file.getPos();\n }\n file.read(buffer$$1, offset, length, position, newCb);\n }\n catch (e) {\n newCb(e);\n }\n};\nFS.prototype.readSync = function readSync (fd, arg2, arg3, arg4, arg5) {\n var shenanigans = false;\n var buffer$$1, offset, length, position, encoding = 'utf8';\n if (typeof arg2 === 'number') {\n length = arg2;\n position = arg3;\n encoding = arg4;\n offset = 0;\n buffer$$1 = Buffer.alloc(length);\n shenanigans = true;\n }\n else {\n buffer$$1 = arg2;\n offset = arg3;\n length = arg4;\n position = arg5;\n }\n var file = this.fd2file(fd);\n if (position === undefined || position === null) {\n position = file.getPos();\n }\n var rv = file.readSync(buffer$$1, offset, length, position);\n if (!shenanigans) {\n return rv;\n }\n else {\n return [buffer$$1.toString(encoding), rv];\n }\n};\n/**\n * Asynchronous `fchown`.\n * @param fd\n * @param uid\n * @param gid\n * @param callback\n */\nFS.prototype.fchown = function fchown (fd, uid, gid, callback) {\n if ( callback === void 0 ) callback = nopCb;\n\n var newCb = wrapCb(callback, 1);\n try {\n this.fd2file(fd).chown(uid, gid, newCb);\n }\n catch (e) {\n newCb(e);\n }\n};\n/**\n * Synchronous `fchown`.\n * @param fd\n * @param uid\n * @param gid\n */\nFS.prototype.fchownSync = function fchownSync (fd, uid, gid) {\n this.fd2file(fd).chownSync(uid, gid);\n};\n/**\n * Asynchronous `fchmod`.\n * @param fd\n * @param mode\n * @param callback\n */\nFS.prototype.fchmod = function fchmod (fd, mode, cb) {\n var newCb = wrapCb(cb, 1);\n try {\n var numMode = typeof mode === 'string' ? parseInt(mode, 8) : mode;\n this.fd2file(fd).chmod(numMode, newCb);\n }\n catch (e) {\n newCb(e);\n }\n};\n/**\n * Synchronous `fchmod`.\n * @param fd\n * @param mode\n */\nFS.prototype.fchmodSync = function fchmodSync (fd, mode) {\n var numMode = typeof mode === 'string' ? parseInt(mode, 8) : mode;\n this.fd2file(fd).chmodSync(numMode);\n};\n/**\n * Change the file timestamps of a file referenced by the supplied file\n * descriptor.\n * @param fd\n * @param atime\n * @param mtime\n * @param callback\n */\nFS.prototype.futimes = function futimes (fd, atime, mtime, cb) {\n if ( cb === void 0 ) cb = nopCb;\n\n var newCb = wrapCb(cb, 1);\n try {\n var file = this.fd2file(fd);\n if (typeof atime === 'number') {\n atime = new Date(atime * 1000);\n }\n if (typeof mtime === 'number') {\n mtime = new Date(mtime * 1000);\n }\n file.utimes(atime, mtime, newCb);\n }\n catch (e) {\n newCb(e);\n }\n};\n/**\n * Change the file timestamps of a file referenced by the supplied file\n * descriptor.\n * @param fd\n * @param atime\n * @param mtime\n */\nFS.prototype.futimesSync = function futimesSync (fd, atime, mtime) {\n this.fd2file(fd).utimesSync(normalizeTime(atime), normalizeTime(mtime));\n};\n// DIRECTORY-ONLY METHODS\n/**\n * Asynchronous `rmdir`.\n * @param path\n * @param callback\n */\nFS.prototype.rmdir = function rmdir (path$$1, cb) {\n if ( cb === void 0 ) cb = nopCb;\n\n var newCb = wrapCb(cb, 1);\n try {\n path$$1 = normalizePath(path$$1);\n assertRoot(this.root).rmdir(path$$1, newCb);\n }\n catch (e) {\n newCb(e);\n }\n};\n/**\n * Synchronous `rmdir`.\n * @param path\n */\nFS.prototype.rmdirSync = function rmdirSync (path$$1) {\n path$$1 = normalizePath(path$$1);\n return assertRoot(this.root).rmdirSync(path$$1);\n};\n/**\n * Asynchronous `mkdir`.\n * @param path\n * @param mode defaults to `0777`\n * @param callback\n */\nFS.prototype.mkdir = function mkdir (path$$1, mode, cb) {\n if ( cb === void 0 ) cb = nopCb;\n\n if (typeof mode === 'function') {\n cb = mode;\n mode = 0x1ff;\n }\n var newCb = wrapCb(cb, 1);\n try {\n path$$1 = normalizePath(path$$1);\n assertRoot(this.root).mkdir(path$$1, mode, newCb);\n }\n catch (e) {\n newCb(e);\n }\n};\n/**\n * Synchronous `mkdir`.\n * @param path\n * @param mode defaults to `0777`\n */\nFS.prototype.mkdirSync = function mkdirSync (path$$1, mode) {\n assertRoot(this.root).mkdirSync(normalizePath(path$$1), normalizeMode(mode, 0x1ff));\n};\n/**\n * Asynchronous `readdir`. Reads the contents of a directory.\n * The callback gets two arguments `(err, files)` where `files` is an array of\n * the names of the files in the directory excluding `'.'` and `'..'`.\n * @param path\n * @param callback\n */\nFS.prototype.readdir = function readdir (path$$1, cb) {\n if ( cb === void 0 ) cb = nopCb;\n\n var newCb = wrapCb(cb, 2);\n try {\n path$$1 = normalizePath(path$$1);\n assertRoot(this.root).readdir(path$$1, newCb);\n }\n catch (e) {\n newCb(e);\n }\n};\n/**\n * Synchronous `readdir`. Reads the contents of a directory.\n * @param path\n * @return [String[]]\n */\nFS.prototype.readdirSync = function readdirSync (path$$1) {\n path$$1 = normalizePath(path$$1);\n return assertRoot(this.root).readdirSync(path$$1);\n};\n// SYMLINK METHODS\n/**\n * Asynchronous `link`.\n * @param srcpath\n * @param dstpath\n * @param callback\n */\nFS.prototype.link = function link (srcpath, dstpath, cb) {\n if ( cb === void 0 ) cb = nopCb;\n\n var newCb = wrapCb(cb, 1);\n try {\n srcpath = normalizePath(srcpath);\n dstpath = normalizePath(dstpath);\n assertRoot(this.root).link(srcpath, dstpath, newCb);\n }\n catch (e) {\n newCb(e);\n }\n};\n/**\n * Synchronous `link`.\n * @param srcpath\n * @param dstpath\n */\nFS.prototype.linkSync = function linkSync (srcpath, dstpath) {\n srcpath = normalizePath(srcpath);\n dstpath = normalizePath(dstpath);\n return assertRoot(this.root).linkSync(srcpath, dstpath);\n};\nFS.prototype.symlink = function symlink (srcpath, dstpath, arg3, cb) {\n if ( cb === void 0 ) cb = nopCb;\n\n var type = typeof arg3 === 'string' ? arg3 : 'file';\n cb = typeof arg3 === 'function' ? arg3 : cb;\n var newCb = wrapCb(cb, 1);\n try {\n if (type !== 'file' && type !== 'dir') {\n return newCb(new ApiError(ErrorCode.EINVAL, \"Invalid type: \" + type));\n }\n srcpath = normalizePath(srcpath);\n dstpath = normalizePath(dstpath);\n assertRoot(this.root).symlink(srcpath, dstpath, type, newCb);\n }\n catch (e) {\n newCb(e);\n }\n};\n/**\n * Synchronous `symlink`.\n * @param srcpath\n * @param dstpath\n * @param type can be either `'dir'` or `'file'` (default is `'file'`)\n */\nFS.prototype.symlinkSync = function symlinkSync (srcpath, dstpath, type) {\n if (!type) {\n type = 'file';\n }\n else if (type !== 'file' && type !== 'dir') {\n throw new ApiError(ErrorCode.EINVAL, \"Invalid type: \" + type);\n }\n srcpath = normalizePath(srcpath);\n dstpath = normalizePath(dstpath);\n return assertRoot(this.root).symlinkSync(srcpath, dstpath, type);\n};\n/**\n * Asynchronous readlink.\n * @param path\n * @param callback\n */\nFS.prototype.readlink = function readlink (path$$1, cb) {\n if ( cb === void 0 ) cb = nopCb;\n\n var newCb = wrapCb(cb, 2);\n try {\n path$$1 = normalizePath(path$$1);\n assertRoot(this.root).readlink(path$$1, newCb);\n }\n catch (e) {\n newCb(e);\n }\n};\n/**\n * Synchronous readlink.\n * @param path\n * @return [String]\n */\nFS.prototype.readlinkSync = function readlinkSync (path$$1) {\n path$$1 = normalizePath(path$$1);\n return assertRoot(this.root).readlinkSync(path$$1);\n};\n// PROPERTY OPERATIONS\n/**\n * Asynchronous `chown`.\n * @param path\n * @param uid\n * @param gid\n * @param callback\n */\nFS.prototype.chown = function chown (path$$1, uid, gid, cb) {\n if ( cb === void 0 ) cb = nopCb;\n\n var newCb = wrapCb(cb, 1);\n try {\n path$$1 = normalizePath(path$$1);\n assertRoot(this.root).chown(path$$1, false, uid, gid, newCb);\n }\n catch (e) {\n newCb(e);\n }\n};\n/**\n * Synchronous `chown`.\n * @param path\n * @param uid\n * @param gid\n */\nFS.prototype.chownSync = function chownSync (path$$1, uid, gid) {\n path$$1 = normalizePath(path$$1);\n assertRoot(this.root).chownSync(path$$1, false, uid, gid);\n};\n/**\n * Asynchronous `lchown`.\n * @param path\n * @param uid\n * @param gid\n * @param callback\n */\nFS.prototype.lchown = function lchown (path$$1, uid, gid, cb) {\n if ( cb === void 0 ) cb = nopCb;\n\n var newCb = wrapCb(cb, 1);\n try {\n path$$1 = normalizePath(path$$1);\n assertRoot(this.root).chown(path$$1, true, uid, gid, newCb);\n }\n catch (e) {\n newCb(e);\n }\n};\n/**\n * Synchronous `lchown`.\n * @param path\n * @param uid\n * @param gid\n */\nFS.prototype.lchownSync = function lchownSync (path$$1, uid, gid) {\n path$$1 = normalizePath(path$$1);\n assertRoot(this.root).chownSync(path$$1, true, uid, gid);\n};\n/**\n * Asynchronous `chmod`.\n * @param path\n * @param mode\n * @param callback\n */\nFS.prototype.chmod = function chmod (path$$1, mode, cb) {\n if ( cb === void 0 ) cb = nopCb;\n\n var newCb = wrapCb(cb, 1);\n try {\n var numMode = normalizeMode(mode, -1);\n if (numMode < 0) {\n throw new ApiError(ErrorCode.EINVAL, \"Invalid mode.\");\n }\n assertRoot(this.root).chmod(normalizePath(path$$1), false, numMode, newCb);\n }\n catch (e) {\n newCb(e);\n }\n};\n/**\n * Synchronous `chmod`.\n * @param path\n * @param mode\n */\nFS.prototype.chmodSync = function chmodSync (path$$1, mode) {\n var numMode = normalizeMode(mode, -1);\n if (numMode < 0) {\n throw new ApiError(ErrorCode.EINVAL, \"Invalid mode.\");\n }\n path$$1 = normalizePath(path$$1);\n assertRoot(this.root).chmodSync(path$$1, false, numMode);\n};\n/**\n * Asynchronous `lchmod`.\n * @param path\n * @param mode\n * @param callback\n */\nFS.prototype.lchmod = function lchmod (path$$1, mode, cb) {\n if ( cb === void 0 ) cb = nopCb;\n\n var newCb = wrapCb(cb, 1);\n try {\n var numMode = normalizeMode(mode, -1);\n if (numMode < 0) {\n throw new ApiError(ErrorCode.EINVAL, \"Invalid mode.\");\n }\n assertRoot(this.root).chmod(normalizePath(path$$1), true, numMode, newCb);\n }\n catch (e) {\n newCb(e);\n }\n};\n/**\n * Synchronous `lchmod`.\n * @param path\n * @param mode\n */\nFS.prototype.lchmodSync = function lchmodSync (path$$1, mode) {\n var numMode = normalizeMode(mode, -1);\n if (numMode < 1) {\n throw new ApiError(ErrorCode.EINVAL, \"Invalid mode.\");\n }\n assertRoot(this.root).chmodSync(normalizePath(path$$1), true, numMode);\n};\n/**\n * Change file timestamps of the file referenced by the supplied path.\n * @param path\n * @param atime\n * @param mtime\n * @param callback\n */\nFS.prototype.utimes = function utimes (path$$1, atime, mtime, cb) {\n if ( cb === void 0 ) cb = nopCb;\n\n var newCb = wrapCb(cb, 1);\n try {\n assertRoot(this.root).utimes(normalizePath(path$$1), normalizeTime(atime), normalizeTime(mtime), newCb);\n }\n catch (e) {\n newCb(e);\n }\n};\n/**\n * Change file timestamps of the file referenced by the supplied path.\n * @param path\n * @param atime\n * @param mtime\n */\nFS.prototype.utimesSync = function utimesSync (path$$1, atime, mtime) {\n assertRoot(this.root).utimesSync(normalizePath(path$$1), normalizeTime(atime), normalizeTime(mtime));\n};\nFS.prototype.realpath = function realpath (path$$1, arg2, cb) {\n if ( cb === void 0 ) cb = nopCb;\n\n var cache = typeof (arg2) === 'object' ? arg2 : {};\n cb = typeof (arg2) === 'function' ? arg2 : nopCb;\n var newCb = wrapCb(cb, 2);\n try {\n path$$1 = normalizePath(path$$1);\n assertRoot(this.root).realpath(path$$1, cache, newCb);\n }\n catch (e) {\n newCb(e);\n }\n};\n/**\n * Synchronous `realpath`.\n * @param path\n * @param cache An object literal of mapped paths that can be used to\n * force a specific path resolution or avoid additional `fs.stat` calls for\n * known real paths.\n * @return [String]\n */\nFS.prototype.realpathSync = function realpathSync (path$$1, cache) {\n if ( cache === void 0 ) cache = {};\n\n path$$1 = normalizePath(path$$1);\n return assertRoot(this.root).realpathSync(path$$1, cache);\n};\nFS.prototype.watchFile = function watchFile (filename, arg2, listener) {\n if ( listener === void 0 ) listener = nopCb;\n\n throw new ApiError(ErrorCode.ENOTSUP);\n};\nFS.prototype.unwatchFile = function unwatchFile (filename, listener) {\n if ( listener === void 0 ) listener = nopCb;\n\n throw new ApiError(ErrorCode.ENOTSUP);\n};\nFS.prototype.watch = function watch (filename, arg2, listener) {\n if ( listener === void 0 ) listener = nopCb;\n\n throw new ApiError(ErrorCode.ENOTSUP);\n};\nFS.prototype.access = function access (path$$1, arg2, cb) {\n if ( cb === void 0 ) cb = nopCb;\n\n throw new ApiError(ErrorCode.ENOTSUP);\n};\nFS.prototype.accessSync = function accessSync (path$$1, mode) {\n throw new ApiError(ErrorCode.ENOTSUP);\n};\nFS.prototype.createReadStream = function createReadStream (path$$1, options) {\n throw new ApiError(ErrorCode.ENOTSUP);\n};\nFS.prototype.createWriteStream = function createWriteStream (path$$1, options) {\n throw new ApiError(ErrorCode.ENOTSUP);\n};\n/**\n * For unit testing. Passes all incoming callbacks to cbWrapper for wrapping.\n */\nFS.prototype.wrapCallbacks = function wrapCallbacks (cbWrapper) {\n wrapCbHook = cbWrapper;\n};\nFS.prototype.getFdForFile = function getFdForFile (file) {\n var fd = this.nextFd++;\n this.fdMap[fd] = file;\n return fd;\n};\nFS.prototype.fd2file = function fd2file (fd) {\n var rv = this.fdMap[fd];\n if (rv) {\n return rv;\n }\n else {\n throw new ApiError(ErrorCode.EBADF, 'Invalid file descriptor.');\n }\n};\nFS.prototype.closeFd = function closeFd (fd) {\n delete this.fdMap[fd];\n};\n/* tslint:disable:variable-name */\n// Exported fs.Stats.\nFS.Stats = Stats;\n\n// Manually export the individual public functions of fs.\n// Required because some code will invoke functions off of the module.\n// e.g.:\n// let writeFile = fs.writeFile;\n// writeFile(...)\n/**\n * @hidden\n */\nvar fs = new FS();\n/**\n * @hidden\n */\nvar _fsMock = {};\n/**\n * @hidden\n */\nvar fsProto = FS.prototype;\nObject.keys(fsProto).forEach(function (key) {\n if (typeof fs[key] === 'function') {\n _fsMock[key] = function () {\n return fs[key].apply(fs, arguments);\n };\n }\n else {\n _fsMock[key] = fs[key];\n }\n});\n_fsMock['changeFSModule'] = function (newFs) {\n fs = newFs;\n};\n_fsMock['getFSModule'] = function () {\n return fs;\n};\n_fsMock['FS'] = FS;\n_fsMock['Stats'] = FS.Stats;\n\n/*\n * Levenshtein distance, from the `js-levenshtein` NPM module.\n * Copied here to avoid complexity of adding another CommonJS module dependency.\n */\nfunction _min(d0, d1, d2, bx, ay) {\n return d0 < d1 || d2 < d1\n ? d0 > d2\n ? d2 + 1\n : d0 + 1\n : bx === ay\n ? d1\n : d1 + 1;\n}\n/**\n * Calculates levenshtein distance.\n * @param a\n * @param b\n */\nfunction levenshtein(a, b) {\n if (a === b) {\n return 0;\n }\n if (a.length > b.length) {\n var tmp = a;\n a = b;\n b = tmp;\n }\n var la = a.length;\n var lb = b.length;\n while (la > 0 && (a.charCodeAt(la - 1) === b.charCodeAt(lb - 1))) {\n la--;\n lb--;\n }\n var offset = 0;\n while (offset < la && (a.charCodeAt(offset) === b.charCodeAt(offset))) {\n offset++;\n }\n la -= offset;\n lb -= offset;\n if (la === 0 || lb === 1) {\n return lb;\n }\n var vector = new Array(la << 1);\n for (var y = 0; y < la;) {\n vector[la + y] = a.charCodeAt(offset + y);\n vector[y] = ++y;\n }\n var x;\n var d0;\n var d1;\n var d2;\n var d3;\n for (x = 0; (x + 3) < lb;) {\n var bx0 = b.charCodeAt(offset + (d0 = x));\n var bx1 = b.charCodeAt(offset + (d1 = x + 1));\n var bx2 = b.charCodeAt(offset + (d2 = x + 2));\n var bx3 = b.charCodeAt(offset + (d3 = x + 3));\n var dd$1 = (x += 4);\n for (var y$1 = 0; y$1 < la;) {\n var ay = vector[la + y$1];\n var dy = vector[y$1];\n d0 = _min(dy, d0, d1, bx0, ay);\n d1 = _min(d0, d1, d2, bx1, ay);\n d2 = _min(d1, d2, d3, bx2, ay);\n dd$1 = _min(d2, d3, dd$1, bx3, ay);\n vector[y$1++] = dd$1;\n d3 = d2;\n d2 = d1;\n d1 = d0;\n d0 = dy;\n }\n }\n var dd = 0;\n for (; x < lb;) {\n var bx0$1 = b.charCodeAt(offset + (d0 = x));\n dd = ++x;\n for (var y$2 = 0; y$2 < la; y$2++) {\n var dy$1 = vector[y$2];\n vector[y$2] = dd = dy$1 < d0 || dd < d0\n ? dy$1 > dd ? dd + 1 : dy$1 + 1\n : bx0$1 === vector[la + y$2]\n ? d0\n : d0 + 1;\n d0 = dy$1;\n }\n }\n return dd;\n}\n\nfunction deprecationMessage(print, fsName, opts) {\n if (print) {\n // tslint:disable-next-line:no-console\n console.warn((\"[\" + fsName + \"] Direct file system constructor usage is deprecated for this file system, and will be removed in the next major version. Please use the '\" + fsName + \".Create(\" + (JSON.stringify(opts)) + \", callback)' method instead. See https://github.com/jvilk/BrowserFS/issues/176 for more details.\"));\n // tslint:enable-next-line:no-console\n }\n}\n/**\n * Checks for any IE version, including IE11 which removed MSIE from the\n * userAgent string.\n * @hidden\n */\nvar isIE = typeof navigator !== \"undefined\" && !!(/(msie) ([\\w.]+)/.exec(navigator.userAgent.toLowerCase()) || navigator.userAgent.indexOf('Trident') !== -1);\n/**\n * Check if we're in a web worker.\n * @hidden\n */\nvar isWebWorker = typeof window === \"undefined\";\n/**\n * Throws an exception. Called on code paths that should be impossible.\n * @hidden\n */\nfunction fail() {\n throw new Error(\"BFS has reached an impossible code path; please file a bug.\");\n}\n/**\n * Synchronous recursive makedir.\n * @hidden\n */\nfunction mkdirpSync(p, mode, fs) {\n if (!fs.existsSync(p)) {\n mkdirpSync(path.dirname(p), mode, fs);\n fs.mkdirSync(p, mode);\n }\n}\n/**\n * Converts a buffer into an array buffer. Attempts to do so in a\n * zero-copy manner, e.g. the array references the same memory.\n * @hidden\n */\nfunction buffer2ArrayBuffer(buff) {\n var u8 = buffer2Uint8array(buff), u8offset = u8.byteOffset, u8Len = u8.byteLength;\n if (u8offset === 0 && u8Len === u8.buffer.byteLength) {\n return u8.buffer;\n }\n else {\n return u8.buffer.slice(u8offset, u8offset + u8Len);\n }\n}\n/**\n * Converts a buffer into a Uint8Array. Attempts to do so in a\n * zero-copy manner, e.g. the array references the same memory.\n * @hidden\n */\nfunction buffer2Uint8array(buff) {\n if (buff instanceof Uint8Array) {\n // BFS & Node v4.0 buffers *are* Uint8Arrays.\n return buff;\n }\n else {\n // Uint8Arrays can be constructed from arrayish numbers.\n // At this point, we assume this isn't a BFS array.\n return new Uint8Array(buff);\n }\n}\n/**\n * Converts the given arrayish object into a Buffer. Attempts to\n * be zero-copy.\n * @hidden\n */\nfunction arrayish2Buffer(arr) {\n if (arr instanceof Buffer) {\n return arr;\n }\n else if (arr instanceof Uint8Array) {\n return uint8Array2Buffer(arr);\n }\n else {\n return Buffer.from(arr);\n }\n}\n/**\n * Converts the given Uint8Array into a Buffer. Attempts to be zero-copy.\n * @hidden\n */\nfunction uint8Array2Buffer(u8) {\n if (u8 instanceof Buffer) {\n return u8;\n }\n else if (u8.byteOffset === 0 && u8.byteLength === u8.buffer.byteLength) {\n return arrayBuffer2Buffer(u8.buffer);\n }\n else {\n return Buffer.from(u8.buffer, u8.byteOffset, u8.byteLength);\n }\n}\n/**\n * Converts the given array buffer into a Buffer. Attempts to be\n * zero-copy.\n * @hidden\n */\nfunction arrayBuffer2Buffer(ab) {\n return Buffer.from(ab);\n}\n/**\n * Copies a slice of the given buffer\n * @hidden\n */\nfunction copyingSlice(buff, start, end) {\n if ( start === void 0 ) start = 0;\n if ( end === void 0 ) end = buff.length;\n\n if (start < 0 || end < 0 || end > buff.length || start > end) {\n throw new TypeError((\"Invalid slice bounds on buffer of length \" + (buff.length) + \": [\" + start + \", \" + end + \"]\"));\n }\n if (buff.length === 0) {\n // Avoid s0 corner case in ArrayBuffer case.\n return emptyBuffer();\n }\n else {\n var u8 = buffer2Uint8array(buff), s0 = buff[0], newS0 = (s0 + 1) % 0xFF;\n buff[0] = newS0;\n if (u8[0] === newS0) {\n // Same memory. Revert & copy.\n u8[0] = s0;\n return uint8Array2Buffer(u8.slice(start, end));\n }\n else {\n // Revert.\n buff[0] = s0;\n return uint8Array2Buffer(u8.subarray(start, end));\n }\n }\n}\n/**\n * @hidden\n */\nvar emptyBuff = null;\n/**\n * Returns an empty buffer.\n * @hidden\n */\nfunction emptyBuffer() {\n if (emptyBuff) {\n return emptyBuff;\n }\n return emptyBuff = Buffer.alloc(0);\n}\n/**\n * Option validator for a Buffer file system option.\n * @hidden\n */\nfunction bufferValidator(v, cb) {\n if (Buffer.isBuffer(v)) {\n cb();\n }\n else {\n cb(new ApiError(ErrorCode.EINVAL, \"option must be a Buffer.\"));\n }\n}\n/**\n * Checks that the given options object is valid for the file system options.\n * @hidden\n */\nfunction checkOptions(fsType, opts, cb) {\n var optsInfo = fsType.Options;\n var fsName = fsType.Name;\n var pendingValidators = 0;\n var callbackCalled = false;\n var loopEnded = false;\n function validatorCallback(e) {\n if (!callbackCalled) {\n if (e) {\n callbackCalled = true;\n cb(e);\n }\n pendingValidators--;\n if (pendingValidators === 0 && loopEnded) {\n cb();\n }\n }\n }\n // Check for required options.\n var loop = function ( optName ) {\n if (optsInfo.hasOwnProperty(optName)) {\n var opt = optsInfo[optName];\n var providedValue = opts[optName];\n if (providedValue === undefined || providedValue === null) {\n if (!opt.optional) {\n // Required option, not provided.\n // Any incorrect options provided? Which ones are close to the provided one?\n // (edit distance 5 === close)\n var incorrectOptions = Object.keys(opts).filter(function (o) { return !(o in optsInfo); }).map(function (a) {\n return { str: a, distance: levenshtein(optName, a) };\n }).filter(function (o) { return o.distance < 5; }).sort(function (a, b) { return a.distance - b.distance; });\n // Validators may be synchronous.\n if (callbackCalled) {\n return {};\n }\n callbackCalled = true;\n return { v: cb(new ApiError(ErrorCode.EINVAL, (\"[\" + fsName + \"] Required option '\" + optName + \"' not provided.\" + (incorrectOptions.length > 0 ? (\" You provided unrecognized option '\" + (incorrectOptions[0].str) + \"'; perhaps you meant to type '\" + optName + \"'.\") : '') + \"\\nOption description: \" + (opt.description)))) };\n }\n // Else: Optional option, not provided. That is OK.\n }\n else {\n // Option provided! Check type.\n var typeMatches = false;\n if (Array.isArray(opt.type)) {\n typeMatches = opt.type.indexOf(typeof (providedValue)) !== -1;\n }\n else {\n typeMatches = typeof (providedValue) === opt.type;\n }\n if (!typeMatches) {\n // Validators may be synchronous.\n if (callbackCalled) {\n return {};\n }\n callbackCalled = true;\n return { v: cb(new ApiError(ErrorCode.EINVAL, (\"[\" + fsName + \"] Value provided for option \" + optName + \" is not the proper type. Expected \" + (Array.isArray(opt.type) ? (\"one of {\" + (opt.type.join(\", \")) + \"}\") : opt.type) + \", but received \" + (typeof (providedValue)) + \"\\nOption description: \" + (opt.description)))) };\n }\n else if (opt.validator) {\n pendingValidators++;\n opt.validator(providedValue, validatorCallback);\n }\n // Otherwise: All good!\n }\n }\n };\n\n for (var optName in optsInfo) {\n var returned = loop( optName );\n\n if ( returned ) return returned.v;\n }\n loopEnded = true;\n if (pendingValidators === 0 && !callbackCalled) {\n cb();\n }\n}\n\nvar BFSUtils = /*#__PURE__*/Object.freeze({\n deprecationMessage: deprecationMessage,\n isIE: isIE,\n isWebWorker: isWebWorker,\n fail: fail,\n mkdirpSync: mkdirpSync,\n buffer2ArrayBuffer: buffer2ArrayBuffer,\n buffer2Uint8array: buffer2Uint8array,\n arrayish2Buffer: arrayish2Buffer,\n uint8Array2Buffer: uint8Array2Buffer,\n arrayBuffer2Buffer: arrayBuffer2Buffer,\n copyingSlice: copyingSlice,\n emptyBuffer: emptyBuffer,\n bufferValidator: bufferValidator,\n checkOptions: checkOptions\n});\n\nvar BFSEmscriptenStreamOps = function BFSEmscriptenStreamOps(fs) {\n this.fs = fs;\n this.nodefs = fs.getNodeFS();\n this.FS = fs.getFS();\n this.PATH = fs.getPATH();\n this.ERRNO_CODES = fs.getERRNO_CODES();\n};\nBFSEmscriptenStreamOps.prototype.open = function open (stream) {\n var path$$1 = this.fs.realPath(stream.node);\n var FS = this.FS;\n try {\n if (FS.isFile(stream.node.mode)) {\n stream.nfd = this.nodefs.openSync(path$$1, this.fs.flagsToPermissionString(stream.flags));\n }\n }\n catch (e) {\n if (!e.code) {\n throw e;\n }\n throw new FS.ErrnoError(this.ERRNO_CODES[e.code]);\n }\n};\nBFSEmscriptenStreamOps.prototype.close = function close (stream) {\n var FS = this.FS;\n try {\n if (FS.isFile(stream.node.mode) && stream.nfd) {\n this.nodefs.closeSync(stream.nfd);\n }\n }\n catch (e) {\n if (!e.code) {\n throw e;\n }\n throw new FS.ErrnoError(this.ERRNO_CODES[e.code]);\n }\n};\nBFSEmscriptenStreamOps.prototype.read = function read (stream, buffer$$1, offset, length, position) {\n // Avoid copying overhead by reading directly into buffer.\n try {\n return this.nodefs.readSync(stream.nfd, uint8Array2Buffer(buffer$$1), offset, length, position);\n }\n catch (e) {\n throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n }\n};\nBFSEmscriptenStreamOps.prototype.write = function write (stream, buffer$$1, offset, length, position) {\n // Avoid copying overhead.\n try {\n return this.nodefs.writeSync(stream.nfd, uint8Array2Buffer(buffer$$1), offset, length, position);\n }\n catch (e) {\n throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n }\n};\nBFSEmscriptenStreamOps.prototype.llseek = function llseek (stream, offset, whence) {\n var position = offset;\n if (whence === 1) { // SEEK_CUR.\n position += stream.position;\n }\n else if (whence === 2) { // SEEK_END.\n if (this.FS.isFile(stream.node.mode)) {\n try {\n var stat = this.nodefs.fstatSync(stream.nfd);\n position += stat.size;\n }\n catch (e) {\n throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n }\n }\n }\n if (position < 0) {\n throw new this.FS.ErrnoError(this.ERRNO_CODES.EINVAL);\n }\n stream.position = position;\n return position;\n};\nvar BFSEmscriptenNodeOps = function BFSEmscriptenNodeOps(fs) {\n this.fs = fs;\n this.nodefs = fs.getNodeFS();\n this.FS = fs.getFS();\n this.PATH = fs.getPATH();\n this.ERRNO_CODES = fs.getERRNO_CODES();\n};\nBFSEmscriptenNodeOps.prototype.getattr = function getattr (node) {\n var path$$1 = this.fs.realPath(node);\n var stat;\n try {\n stat = this.nodefs.lstatSync(path$$1);\n }\n catch (e) {\n if (!e.code) {\n throw e;\n }\n throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n }\n return {\n dev: stat.dev,\n ino: stat.ino,\n mode: stat.mode,\n nlink: stat.nlink,\n uid: stat.uid,\n gid: stat.gid,\n rdev: stat.rdev,\n size: stat.size,\n atime: stat.atime,\n mtime: stat.mtime,\n ctime: stat.ctime,\n blksize: stat.blksize,\n blocks: stat.blocks\n };\n};\nBFSEmscriptenNodeOps.prototype.setattr = function setattr (node, attr) {\n var path$$1 = this.fs.realPath(node);\n try {\n if (attr.mode !== undefined) {\n this.nodefs.chmodSync(path$$1, attr.mode);\n // update the common node structure mode as well\n node.mode = attr.mode;\n }\n if (attr.timestamp !== undefined) {\n var date = new Date(attr.timestamp);\n this.nodefs.utimesSync(path$$1, date, date);\n }\n }\n catch (e) {\n if (!e.code) {\n throw e;\n }\n // Ignore not supported errors. Emscripten does utimesSync when it\n // writes files, but never really requires the value to be set.\n if (e.code !== \"ENOTSUP\") {\n throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n }\n }\n if (attr.size !== undefined) {\n try {\n this.nodefs.truncateSync(path$$1, attr.size);\n }\n catch (e) {\n if (!e.code) {\n throw e;\n }\n throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n }\n }\n};\nBFSEmscriptenNodeOps.prototype.lookup = function lookup (parent, name) {\n var path$$1 = this.PATH.join2(this.fs.realPath(parent), name);\n var mode = this.fs.getMode(path$$1);\n return this.fs.createNode(parent, name, mode);\n};\nBFSEmscriptenNodeOps.prototype.mknod = function mknod (parent, name, mode, dev) {\n var node = this.fs.createNode(parent, name, mode, dev);\n // create the backing node for this in the fs root as well\n var path$$1 = this.fs.realPath(node);\n try {\n if (this.FS.isDir(node.mode)) {\n this.nodefs.mkdirSync(path$$1, node.mode);\n }\n else {\n this.nodefs.writeFileSync(path$$1, '', { mode: node.mode });\n }\n }\n catch (e) {\n if (!e.code) {\n throw e;\n }\n throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n }\n return node;\n};\nBFSEmscriptenNodeOps.prototype.rename = function rename (oldNode, newDir, newName) {\n var oldPath = this.fs.realPath(oldNode);\n var newPath = this.PATH.join2(this.fs.realPath(newDir), newName);\n try {\n this.nodefs.renameSync(oldPath, newPath);\n // This logic is missing from the original NodeFS,\n // causing Emscripten's filesystem to think that the old file still exists.\n oldNode.name = newName;\n oldNode.parent = newDir;\n }\n catch (e) {\n if (!e.code) {\n throw e;\n }\n throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n }\n};\nBFSEmscriptenNodeOps.prototype.unlink = function unlink (parent, name) {\n var path$$1 = this.PATH.join2(this.fs.realPath(parent), name);\n try {\n this.nodefs.unlinkSync(path$$1);\n }\n catch (e) {\n if (!e.code) {\n throw e;\n }\n throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n }\n};\nBFSEmscriptenNodeOps.prototype.rmdir = function rmdir (parent, name) {\n var path$$1 = this.PATH.join2(this.fs.realPath(parent), name);\n try {\n this.nodefs.rmdirSync(path$$1);\n }\n catch (e) {\n if (!e.code) {\n throw e;\n }\n throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n }\n};\nBFSEmscriptenNodeOps.prototype.readdir = function readdir (node) {\n var path$$1 = this.fs.realPath(node);\n try {\n // Node does not list . and .. in directory listings,\n // but Emscripten expects it.\n var contents = this.nodefs.readdirSync(path$$1);\n contents.push('.', '..');\n return contents;\n }\n catch (e) {\n if (!e.code) {\n throw e;\n }\n throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n }\n};\nBFSEmscriptenNodeOps.prototype.symlink = function symlink (parent, newName, oldPath) {\n var newPath = this.PATH.join2(this.fs.realPath(parent), newName);\n try {\n this.nodefs.symlinkSync(oldPath, newPath);\n }\n catch (e) {\n if (!e.code) {\n throw e;\n }\n throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n }\n};\nBFSEmscriptenNodeOps.prototype.readlink = function readlink (node) {\n var path$$1 = this.fs.realPath(node);\n try {\n return this.nodefs.readlinkSync(path$$1);\n }\n catch (e) {\n if (!e.code) {\n throw e;\n }\n throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n }\n};\nvar BFSEmscriptenFS = function BFSEmscriptenFS(_FS, _PATH, _ERRNO_CODES, nodefs) {\n if ( _FS === void 0 ) _FS = self['FS'];\n if ( _PATH === void 0 ) _PATH = self['PATH'];\n if ( _ERRNO_CODES === void 0 ) _ERRNO_CODES = self['ERRNO_CODES'];\n if ( nodefs === void 0 ) nodefs = _fsMock;\n\n // This maps the integer permission modes from http://linux.die.net/man/3/open\n // to node.js-specific file open permission strings at http://nodejs.org/api/fs.html#fs_fs_open_path_flags_mode_callback\n this.flagsToPermissionStringMap = {\n 0 /*O_RDONLY*/: 'r',\n 1 /*O_WRONLY*/: 'r+',\n 2 /*O_RDWR*/: 'r+',\n 64 /*O_CREAT*/: 'r',\n 65 /*O_WRONLY|O_CREAT*/: 'r+',\n 66 /*O_RDWR|O_CREAT*/: 'r+',\n 129 /*O_WRONLY|O_EXCL*/: 'rx+',\n 193 /*O_WRONLY|O_CREAT|O_EXCL*/: 'rx+',\n 514 /*O_RDWR|O_TRUNC*/: 'w+',\n 577 /*O_WRONLY|O_CREAT|O_TRUNC*/: 'w',\n 578 /*O_CREAT|O_RDWR|O_TRUNC*/: 'w+',\n 705 /*O_WRONLY|O_CREAT|O_EXCL|O_TRUNC*/: 'wx',\n 706 /*O_RDWR|O_CREAT|O_EXCL|O_TRUNC*/: 'wx+',\n 1024 /*O_APPEND*/: 'a',\n 1025 /*O_WRONLY|O_APPEND*/: 'a',\n 1026 /*O_RDWR|O_APPEND*/: 'a+',\n 1089 /*O_WRONLY|O_CREAT|O_APPEND*/: 'a',\n 1090 /*O_RDWR|O_CREAT|O_APPEND*/: 'a+',\n 1153 /*O_WRONLY|O_EXCL|O_APPEND*/: 'ax',\n 1154 /*O_RDWR|O_EXCL|O_APPEND*/: 'ax+',\n 1217 /*O_WRONLY|O_CREAT|O_EXCL|O_APPEND*/: 'ax',\n 1218 /*O_RDWR|O_CREAT|O_EXCL|O_APPEND*/: 'ax+',\n 4096 /*O_RDONLY|O_DSYNC*/: 'rs',\n 4098 /*O_RDWR|O_DSYNC*/: 'rs+'\n };\n this.nodefs = nodefs;\n this.FS = _FS;\n this.PATH = _PATH;\n this.ERRNO_CODES = _ERRNO_CODES;\n this.node_ops = new BFSEmscriptenNodeOps(this);\n this.stream_ops = new BFSEmscriptenStreamOps(this);\n};\nBFSEmscriptenFS.prototype.mount = function mount (m) {\n return this.createNode(null, '/', this.getMode(m.opts.root), 0);\n};\nBFSEmscriptenFS.prototype.createNode = function createNode (parent, name, mode, dev) {\n var FS = this.FS;\n if (!FS.isDir(mode) && !FS.isFile(mode) && !FS.isLink(mode)) {\n throw new FS.ErrnoError(this.ERRNO_CODES.EINVAL);\n }\n var node = FS.createNode(parent, name, mode);\n node.node_ops = this.node_ops;\n node.stream_ops = this.stream_ops;\n return node;\n};\nBFSEmscriptenFS.prototype.getMode = function getMode (path$$1) {\n var stat;\n try {\n stat = this.nodefs.lstatSync(path$$1);\n }\n catch (e) {\n if (!e.code) {\n throw e;\n }\n throw new this.FS.ErrnoError(this.ERRNO_CODES[e.code]);\n }\n return stat.mode;\n};\nBFSEmscriptenFS.prototype.realPath = function realPath (node) {\n var parts = [];\n while (node.parent !== node) {\n parts.push(node.name);\n node = node.parent;\n }\n parts.push(node.mount.opts.root);\n parts.reverse();\n return this.PATH.join.apply(null, parts);\n};\nBFSEmscriptenFS.prototype.flagsToPermissionString = function flagsToPermissionString (flags) {\n var parsedFlags = (typeof flags === \"string\") ? parseInt(flags, 10) : flags;\n parsedFlags &= 0x1FFF;\n if (parsedFlags in this.flagsToPermissionStringMap) {\n return this.flagsToPermissionStringMap[parsedFlags];\n }\n else {\n return flags;\n }\n};\nBFSEmscriptenFS.prototype.getNodeFS = function getNodeFS () {\n return this.nodefs;\n};\nBFSEmscriptenFS.prototype.getFS = function getFS () {\n return this.FS;\n};\nBFSEmscriptenFS.prototype.getPATH = function getPATH () {\n return this.PATH;\n};\nBFSEmscriptenFS.prototype.getERRNO_CODES = function getERRNO_CODES () {\n return this.ERRNO_CODES;\n};\n\n/**\n * Basic filesystem class. Most filesystems should extend this class, as it\n * provides default implementations for a handful of methods.\n */\nvar BaseFileSystem = function BaseFileSystem () {};\n\nBaseFileSystem.prototype.supportsLinks = function supportsLinks () {\n return false;\n};\nBaseFileSystem.prototype.diskSpace = function diskSpace (p, cb) {\n cb(0, 0);\n};\n/**\n * Opens the file at path p with the given flag. The file must exist.\n * @param p The path to open.\n * @param flag The flag to use when opening the file.\n */\nBaseFileSystem.prototype.openFile = function openFile (p, flag, cb) {\n throw new ApiError(ErrorCode.ENOTSUP);\n};\n/**\n * Create the file at path p with the given mode. Then, open it with the given\n * flag.\n */\nBaseFileSystem.prototype.createFile = function createFile (p, flag, mode, cb) {\n throw new ApiError(ErrorCode.ENOTSUP);\n};\nBaseFileSystem.prototype.open = function open (p, flag, mode, cb) {\n var this$1 = this;\n\n var mustBeFile = function (e, stats) {\n if (e) {\n // File does not exist.\n switch (flag.pathNotExistsAction()) {\n case ActionType.CREATE_FILE:\n // Ensure parent exists.\n return this$1.stat(path.dirname(p), false, function (e, parentStats) {\n if (e) {\n cb(e);\n }\n else if (parentStats && !parentStats.isDirectory()) {\n cb(ApiError.ENOTDIR(path.dirname(p)));\n }\n else {\n this$1.createFile(p, flag, mode, cb);\n }\n });\n case ActionType.THROW_EXCEPTION:\n return cb(ApiError.ENOENT(p));\n default:\n return cb(new ApiError(ErrorCode.EINVAL, 'Invalid FileFlag object.'));\n }\n }\n else {\n // File exists.\n if (stats && stats.isDirectory()) {\n return cb(ApiError.EISDIR(p));\n }\n switch (flag.pathExistsAction()) {\n case ActionType.THROW_EXCEPTION:\n return cb(ApiError.EEXIST(p));\n case ActionType.TRUNCATE_FILE:\n // NOTE: In a previous implementation, we deleted the file and\n // re-created it. However, this created a race condition if another\n // asynchronous request was trying to read the file, as the file\n // would not exist for a small period of time.\n return this$1.openFile(p, flag, function (e, fd) {\n if (e) {\n cb(e);\n }\n else if (fd) {\n fd.truncate(0, function () {\n fd.sync(function () {\n cb(null, fd);\n });\n });\n }\n else {\n fail();\n }\n });\n case ActionType.NOP:\n return this$1.openFile(p, flag, cb);\n default:\n return cb(new ApiError(ErrorCode.EINVAL, 'Invalid FileFlag object.'));\n }\n }\n };\n this.stat(p, false, mustBeFile);\n};\nBaseFileSystem.prototype.rename = function rename (oldPath, newPath, cb) {\n cb(new ApiError(ErrorCode.ENOTSUP));\n};\nBaseFileSystem.prototype.renameSync = function renameSync (oldPath, newPath) {\n throw new ApiError(ErrorCode.ENOTSUP);\n};\nBaseFileSystem.prototype.stat = function stat (p, isLstat, cb) {\n cb(new ApiError(ErrorCode.ENOTSUP));\n};\nBaseFileSystem.prototype.statSync = function statSync (p, isLstat) {\n throw new ApiError(ErrorCode.ENOTSUP);\n};\n/**\n * Opens the file at path p with the given flag. The file must exist.\n * @param p The path to open.\n * @param flag The flag to use when opening the file.\n * @return A File object corresponding to the opened file.\n */\nBaseFileSystem.prototype.openFileSync = function openFileSync (p, flag, mode) {\n throw new ApiError(ErrorCode.ENOTSUP);\n};\n/**\n * Create the file at path p with the given mode. Then, open it with the given\n * flag.\n */\nBaseFileSystem.prototype.createFileSync = function createFileSync (p, flag, mode) {\n throw new ApiError(ErrorCode.ENOTSUP);\n};\nBaseFileSystem.prototype.openSync = function openSync (p, flag, mode) {\n // Check if the path exists, and is a file.\n var stats;\n try {\n stats = this.statSync(p, false);\n }\n catch (e) {\n // File does not exist.\n switch (flag.pathNotExistsAction()) {\n case ActionType.CREATE_FILE:\n // Ensure parent exists.\n var parentStats = this.statSync(path.dirname(p), false);\n if (!parentStats.isDirectory()) {\n throw ApiError.ENOTDIR(path.dirname(p));\n }\n return this.createFileSync(p, flag, mode);\n case ActionType.THROW_EXCEPTION:\n throw ApiError.ENOENT(p);\n default:\n throw new ApiError(ErrorCode.EINVAL, 'Invalid FileFlag object.');\n }\n }\n // File exists.\n if (stats.isDirectory()) {\n throw ApiError.EISDIR(p);\n }\n switch (flag.pathExistsAction()) {\n case ActionType.THROW_EXCEPTION:\n throw ApiError.EEXIST(p);\n case ActionType.TRUNCATE_FILE:\n // Delete file.\n this.unlinkSync(p);\n // Create file. Use the same mode as the old file.\n // Node itself modifies the ctime when this occurs, so this action\n // will preserve that behavior if the underlying file system\n // supports those properties.\n return this.createFileSync(p, flag, stats.mode);\n case ActionType.NOP:\n return this.openFileSync(p, flag, mode);\n default:\n throw new ApiError(ErrorCode.EINVAL, 'Invalid FileFlag object.');\n }\n};\nBaseFileSystem.prototype.unlink = function unlink (p, cb) {\n cb(new ApiError(ErrorCode.ENOTSUP));\n};\nBaseFileSystem.prototype.unlinkSync = function unlinkSync (p) {\n throw new ApiError(ErrorCode.ENOTSUP);\n};\nBaseFileSystem.prototype.rmdir = function rmdir (p, cb) {\n cb(new ApiError(ErrorCode.ENOTSUP));\n};\nBaseFileSystem.prototype.rmdirSync = function rmdirSync (p) {\n throw new ApiError(ErrorCode.ENOTSUP);\n};\nBaseFileSystem.prototype.mkdir = function mkdir (p, mode, cb) {\n cb(new ApiError(ErrorCode.ENOTSUP));\n};\nBaseFileSystem.prototype.mkdirSync = function mkdirSync (p, mode) {\n throw new ApiError(ErrorCode.ENOTSUP);\n};\nBaseFileSystem.prototype.readdir = function readdir (p, cb) {\n cb(new ApiError(ErrorCode.ENOTSUP));\n};\nBaseFileSystem.prototype.readdirSync = function readdirSync (p) {\n throw new ApiError(ErrorCode.ENOTSUP);\n};\nBaseFileSystem.prototype.exists = function exists (p, cb) {\n this.stat(p, null, function (err) {\n cb(!err);\n });\n};\nBaseFileSystem.prototype.existsSync = function existsSync (p) {\n try {\n this.statSync(p, true);\n return true;\n }\n catch (e) {\n return false;\n }\n};\nBaseFileSystem.prototype.realpath = function realpath (p, cache, cb) {\n if (this.supportsLinks()) {\n // The path could contain symlinks. Split up the path,\n // resolve any symlinks, return the resolved string.\n var splitPath = p.split(path.sep);\n // TODO: Simpler to just pass through file, find sep and such.\n for (var i = 0; i < splitPath.length; i++) {\n var addPaths = splitPath.slice(0, i + 1);\n splitPath[i] = path.join.apply(null, addPaths);\n }\n }\n else {\n // No symlinks. We just need to verify that it exists.\n this.exists(p, function (doesExist) {\n if (doesExist) {\n cb(null, p);\n }\n else {\n cb(ApiError.ENOENT(p));\n }\n });\n }\n};\nBaseFileSystem.prototype.realpathSync = function realpathSync (p, cache) {\n if (this.supportsLinks()) {\n // The path could contain symlinks. Split up the path,\n // resolve any symlinks, return the resolved string.\n var splitPath = p.split(path.sep);\n // TODO: Simpler to just pass through file, find sep and such.\n for (var i = 0; i < splitPath.length; i++) {\n var addPaths = splitPath.slice(0, i + 1);\n splitPath[i] = path.join.apply(path, addPaths);\n }\n return splitPath.join(path.sep);\n }\n else {\n // No symlinks. We just need to verify that it exists.\n if (this.existsSync(p)) {\n return p;\n }\n else {\n throw ApiError.ENOENT(p);\n }\n }\n};\nBaseFileSystem.prototype.truncate = function truncate (p, len, cb) {\n this.open(p, FileFlag.getFileFlag('r+'), 0x1a4, (function (er, fd) {\n if (er) {\n return cb(er);\n }\n fd.truncate(len, (function (er) {\n fd.close((function (er2) {\n cb(er || er2);\n }));\n }));\n }));\n};\nBaseFileSystem.prototype.truncateSync = function truncateSync (p, len) {\n var fd = this.openSync(p, FileFlag.getFileFlag('r+'), 0x1a4);\n // Need to safely close FD, regardless of whether or not truncate succeeds.\n try {\n fd.truncateSync(len);\n }\n catch (e) {\n throw e;\n }\n finally {\n fd.closeSync();\n }\n};\nBaseFileSystem.prototype.readFile = function readFile (fname, encoding, flag, cb) {\n // Wrap cb in file closing code.\n var oldCb = cb;\n // Get file.\n this.open(fname, flag, 0x1a4, function (err, fd) {\n if (err) {\n return cb(err);\n }\n cb = function (err, arg) {\n fd.close(function (err2) {\n if (!err) {\n err = err2;\n }\n return oldCb(err, arg);\n });\n };\n fd.stat(function (err, stat) {\n if (err) {\n return cb(err);\n }\n // Allocate buffer.\n var buf = Buffer.alloc(stat.size);\n fd.read(buf, 0, stat.size, 0, function (err) {\n if (err) {\n return cb(err);\n }\n else if (encoding === null) {\n return cb(err, buf);\n }\n try {\n cb(null, buf.toString(encoding));\n }\n catch (e) {\n cb(e);\n }\n });\n });\n });\n};\nBaseFileSystem.prototype.readFileSync = function readFileSync (fname, encoding, flag) {\n // Get file.\n var fd = this.openSync(fname, flag, 0x1a4);\n try {\n var stat = fd.statSync();\n // Allocate buffer.\n var buf = Buffer.alloc(stat.size);\n fd.readSync(buf, 0, stat.size, 0);\n fd.closeSync();\n if (encoding === null) {\n return buf;\n }\n return buf.toString(encoding);\n }\n finally {\n fd.closeSync();\n }\n};\nBaseFileSystem.prototype.writeFile = function writeFile (fname, data, encoding, flag, mode, cb) {\n // Wrap cb in file closing code.\n var oldCb = cb;\n // Get file.\n this.open(fname, flag, 0x1a4, function (err, fd) {\n if (err) {\n return cb(err);\n }\n cb = function (err) {\n fd.close(function (err2) {\n oldCb(err ? err : err2);\n });\n };\n try {\n if (typeof data === 'string') {\n data = Buffer.from(data, encoding);\n }\n }\n catch (e) {\n return cb(e);\n }\n // Write into file.\n fd.write(data, 0, data.length, 0, cb);\n });\n};\nBaseFileSystem.prototype.writeFileSync = function writeFileSync (fname, data, encoding, flag, mode) {\n // Get file.\n var fd = this.openSync(fname, flag, mode);\n try {\n if (typeof data === 'string') {\n data = Buffer.from(data, encoding);\n }\n // Write into file.\n fd.writeSync(data, 0, data.length, 0);\n }\n finally {\n fd.closeSync();\n }\n};\nBaseFileSystem.prototype.appendFile = function appendFile (fname, data, encoding, flag, mode, cb) {\n // Wrap cb in file closing code.\n var oldCb = cb;\n this.open(fname, flag, mode, function (err, fd) {\n if (err) {\n return cb(err);\n }\n cb = function (err) {\n fd.close(function (err2) {\n oldCb(err ? err : err2);\n });\n };\n if (typeof data === 'string') {\n data = Buffer.from(data, encoding);\n }\n fd.write(data, 0, data.length, null, cb);\n });\n};\nBaseFileSystem.prototype.appendFileSync = function appendFileSync (fname, data, encoding, flag, mode) {\n var fd = this.openSync(fname, flag, mode);\n try {\n if (typeof data === 'string') {\n data = Buffer.from(data, encoding);\n }\n fd.writeSync(data, 0, data.length, null);\n }\n finally {\n fd.closeSync();\n }\n};\nBaseFileSystem.prototype.chmod = function chmod (p, isLchmod, mode, cb) {\n cb(new ApiError(ErrorCode.ENOTSUP));\n};\nBaseFileSystem.prototype.chmodSync = function chmodSync (p, isLchmod, mode) {\n throw new ApiError(ErrorCode.ENOTSUP);\n};\nBaseFileSystem.prototype.chown = function chown (p, isLchown, uid, gid, cb) {\n cb(new ApiError(ErrorCode.ENOTSUP));\n};\nBaseFileSystem.prototype.chownSync = function chownSync (p, isLchown, uid, gid) {\n throw new ApiError(ErrorCode.ENOTSUP);\n};\nBaseFileSystem.prototype.utimes = function utimes (p, atime, mtime, cb) {\n cb(new ApiError(ErrorCode.ENOTSUP));\n};\nBaseFileSystem.prototype.utimesSync = function utimesSync (p, atime, mtime) {\n throw new ApiError(ErrorCode.ENOTSUP);\n};\nBaseFileSystem.prototype.link = function link (srcpath, dstpath, cb) {\n cb(new ApiError(ErrorCode.ENOTSUP));\n};\nBaseFileSystem.prototype.linkSync = function linkSync (srcpath, dstpath) {\n throw new ApiError(ErrorCode.ENOTSUP);\n};\nBaseFileSystem.prototype.symlink = function symlink (srcpath, dstpath, type, cb) {\n cb(new ApiError(ErrorCode.ENOTSUP));\n};\nBaseFileSystem.prototype.symlinkSync = function symlinkSync (srcpath, dstpath, type) {\n throw new ApiError(ErrorCode.ENOTSUP);\n};\nBaseFileSystem.prototype.readlink = function readlink (p, cb) {\n cb(new ApiError(ErrorCode.ENOTSUP));\n};\nBaseFileSystem.prototype.readlinkSync = function readlinkSync (p) {\n throw new ApiError(ErrorCode.ENOTSUP);\n};\n/**\n * Implements the asynchronous API in terms of the synchronous API.\n * @class SynchronousFileSystem\n */\nvar SynchronousFileSystem = /*@__PURE__*/(function (BaseFileSystem) {\n function SynchronousFileSystem () {\n BaseFileSystem.apply(this, arguments);\n }\n\n if ( BaseFileSystem ) SynchronousFileSystem.__proto__ = BaseFileSystem;\n SynchronousFileSystem.prototype = Object.create( BaseFileSystem && BaseFileSystem.prototype );\n SynchronousFileSystem.prototype.constructor = SynchronousFileSystem;\n\n SynchronousFileSystem.prototype.supportsSynch = function supportsSynch () {\n return true;\n };\n SynchronousFileSystem.prototype.rename = function rename (oldPath, newPath, cb) {\n try {\n this.renameSync(oldPath, newPath);\n cb();\n }\n catch (e) {\n cb(e);\n }\n };\n SynchronousFileSystem.prototype.stat = function stat (p, isLstat, cb) {\n try {\n cb(null, this.statSync(p, isLstat));\n }\n catch (e) {\n cb(e);\n }\n };\n SynchronousFileSystem.prototype.open = function open (p, flags, mode, cb) {\n try {\n cb(null, this.openSync(p, flags, mode));\n }\n catch (e) {\n cb(e);\n }\n };\n SynchronousFileSystem.prototype.unlink = function unlink (p, cb) {\n try {\n this.unlinkSync(p);\n cb();\n }\n catch (e) {\n cb(e);\n }\n };\n SynchronousFileSystem.prototype.rmdir = function rmdir (p, cb) {\n try {\n this.rmdirSync(p);\n cb();\n }\n catch (e) {\n cb(e);\n }\n };\n SynchronousFileSystem.prototype.mkdir = function mkdir (p, mode, cb) {\n try {\n this.mkdirSync(p, mode);\n cb();\n }\n catch (e) {\n cb(e);\n }\n };\n SynchronousFileSystem.prototype.readdir = function readdir (p, cb) {\n try {\n cb(null, this.readdirSync(p));\n }\n catch (e) {\n cb(e);\n }\n };\n SynchronousFileSystem.prototype.chmod = function chmod (p, isLchmod, mode, cb) {\n try {\n this.chmodSync(p, isLchmod, mode);\n cb();\n }\n catch (e) {\n cb(e);\n }\n };\n SynchronousFileSystem.prototype.chown = function chown (p, isLchown, uid, gid, cb) {\n try {\n this.chownSync(p, isLchown, uid, gid);\n cb();\n }\n catch (e) {\n cb(e);\n }\n };\n SynchronousFileSystem.prototype.utimes = function utimes (p, atime, mtime, cb) {\n try {\n this.utimesSync(p, atime, mtime);\n cb();\n }\n catch (e) {\n cb(e);\n }\n };\n SynchronousFileSystem.prototype.link = function link (srcpath, dstpath, cb) {\n try {\n this.linkSync(srcpath, dstpath);\n cb();\n }\n catch (e) {\n cb(e);\n }\n };\n SynchronousFileSystem.prototype.symlink = function symlink (srcpath, dstpath, type, cb) {\n try {\n this.symlinkSync(srcpath, dstpath, type);\n cb();\n }\n catch (e) {\n cb(e);\n }\n };\n SynchronousFileSystem.prototype.readlink = function readlink (p, cb) {\n try {\n cb(null, this.readlinkSync(p));\n }\n catch (e) {\n cb(e);\n }\n };\n\n return SynchronousFileSystem;\n}(BaseFileSystem));\n\n/**\n * Base class that contains shared implementations of functions for the file\n * object.\n */\nvar BaseFile = function BaseFile () {};\n\nBaseFile.prototype.sync = function sync (cb) {\n cb(new ApiError(ErrorCode.ENOTSUP));\n};\nBaseFile.prototype.syncSync = function syncSync () {\n throw new ApiError(ErrorCode.ENOTSUP);\n};\nBaseFile.prototype.datasync = function datasync (cb) {\n this.sync(cb);\n};\nBaseFile.prototype.datasyncSync = function datasyncSync () {\n return this.syncSync();\n};\nBaseFile.prototype.chown = function chown (uid, gid, cb) {\n cb(new ApiError(ErrorCode.ENOTSUP));\n};\nBaseFile.prototype.chownSync = function chownSync (uid, gid) {\n throw new ApiError(ErrorCode.ENOTSUP);\n};\nBaseFile.prototype.chmod = function chmod (mode, cb) {\n cb(new ApiError(ErrorCode.ENOTSUP));\n};\nBaseFile.prototype.chmodSync = function chmodSync (mode) {\n throw new ApiError(ErrorCode.ENOTSUP);\n};\nBaseFile.prototype.utimes = function utimes (atime, mtime, cb) {\n cb(new ApiError(ErrorCode.ENOTSUP));\n};\nBaseFile.prototype.utimesSync = function utimesSync (atime, mtime) {\n throw new ApiError(ErrorCode.ENOTSUP);\n};\n\n/**\n * An implementation of the File interface that operates on a file that is\n * completely in-memory. PreloadFiles are backed by a Buffer.\n *\n * This is also an abstract class, as it lacks an implementation of 'sync' and\n * 'close'. Each filesystem that wishes to use this file representation must\n * extend this class and implement those two methods.\n * @todo 'close' lever that disables functionality once closed.\n */\nvar PreloadFile = /*@__PURE__*/(function (BaseFile$$1) {\n function PreloadFile(_fs, _path, _flag, _stat, contents) {\n BaseFile$$1.call(this);\n this._pos = 0;\n this._dirty = false;\n this._fs = _fs;\n this._path = _path;\n this._flag = _flag;\n this._stat = _stat;\n this._buffer = contents ? contents : emptyBuffer();\n // Note: This invariant is *not* maintained once the file starts getting\n // modified.\n // Note: Only actually matters if file is readable, as writeable modes may\n // truncate/append to file.\n if (this._stat.size !== this._buffer.length && this._flag.isReadable()) {\n throw new Error((\"Invalid buffer: Buffer is \" + (this._buffer.length) + \" long, yet Stats object specifies that file is \" + (this._stat.size) + \" long.\"));\n }\n }\n\n if ( BaseFile$$1 ) PreloadFile.__proto__ = BaseFile$$1;\n PreloadFile.prototype = Object.create( BaseFile$$1 && BaseFile$$1.prototype );\n PreloadFile.prototype.constructor = PreloadFile;\n /**\n * NONSTANDARD: Get the underlying buffer for this file. !!DO NOT MUTATE!! Will mess up dirty tracking.\n */\n PreloadFile.prototype.getBuffer = function getBuffer () {\n return this._buffer;\n };\n /**\n * NONSTANDARD: Get underlying stats for this file. !!DO NOT MUTATE!!\n */\n PreloadFile.prototype.getStats = function getStats () {\n return this._stat;\n };\n PreloadFile.prototype.getFlag = function getFlag () {\n return this._flag;\n };\n /**\n * Get the path to this file.\n * @return [String] The path to the file.\n */\n PreloadFile.prototype.getPath = function getPath () {\n return this._path;\n };\n /**\n * Get the current file position.\n *\n * We emulate the following bug mentioned in the Node documentation:\n * > On Linux, positional writes don't work when the file is opened in append\n * mode. The kernel ignores the position argument and always appends the data\n * to the end of the file.\n * @return [Number] The current file position.\n */\n PreloadFile.prototype.getPos = function getPos () {\n if (this._flag.isAppendable()) {\n return this._stat.size;\n }\n return this._pos;\n };\n /**\n * Advance the current file position by the indicated number of positions.\n * @param [Number] delta\n */\n PreloadFile.prototype.advancePos = function advancePos (delta) {\n return this._pos += delta;\n };\n /**\n * Set the file position.\n * @param [Number] newPos\n */\n PreloadFile.prototype.setPos = function setPos (newPos) {\n return this._pos = newPos;\n };\n /**\n * **Core**: Asynchronous sync. Must be implemented by subclasses of this\n * class.\n * @param [Function(BrowserFS.ApiError)] cb\n */\n PreloadFile.prototype.sync = function sync (cb) {\n try {\n this.syncSync();\n cb();\n }\n catch (e) {\n cb(e);\n }\n };\n /**\n * **Core**: Synchronous sync.\n */\n PreloadFile.prototype.syncSync = function syncSync () {\n throw new ApiError(ErrorCode.ENOTSUP);\n };\n /**\n * **Core**: Asynchronous close. Must be implemented by subclasses of this\n * class.\n * @param [Function(BrowserFS.ApiError)] cb\n */\n PreloadFile.prototype.close = function close (cb) {\n try {\n this.closeSync();\n cb();\n }\n catch (e) {\n cb(e);\n }\n };\n /**\n * **Core**: Synchronous close.\n */\n PreloadFile.prototype.closeSync = function closeSync () {\n throw new ApiError(ErrorCode.ENOTSUP);\n };\n /**\n * Asynchronous `stat`.\n * @param [Function(BrowserFS.ApiError, BrowserFS.node.fs.Stats)] cb\n */\n PreloadFile.prototype.stat = function stat (cb) {\n try {\n cb(null, Stats.clone(this._stat));\n }\n catch (e) {\n cb(e);\n }\n };\n /**\n * Synchronous `stat`.\n */\n PreloadFile.prototype.statSync = function statSync () {\n return Stats.clone(this._stat);\n };\n /**\n * Asynchronous truncate.\n * @param [Number] len\n * @param [Function(BrowserFS.ApiError)] cb\n */\n PreloadFile.prototype.truncate = function truncate (len, cb) {\n try {\n this.truncateSync(len);\n if (this._flag.isSynchronous() && !_fsMock.getRootFS().supportsSynch()) {\n this.sync(cb);\n }\n cb();\n }\n catch (e) {\n return cb(e);\n }\n };\n /**\n * Synchronous truncate.\n * @param [Number] len\n */\n PreloadFile.prototype.truncateSync = function truncateSync (len) {\n this._dirty = true;\n if (!this._flag.isWriteable()) {\n throw new ApiError(ErrorCode.EPERM, 'File not opened with a writeable mode.');\n }\n this._stat.mtimeMs = Date.now();\n if (len > this._buffer.length) {\n var buf = Buffer.alloc(len - this._buffer.length, 0);\n // Write will set @_stat.size for us.\n this.writeSync(buf, 0, buf.length, this._buffer.length);\n if (this._flag.isSynchronous() && _fsMock.getRootFS().supportsSynch()) {\n this.syncSync();\n }\n return;\n }\n this._stat.size = len;\n // Truncate buffer to 'len'.\n var newBuff = Buffer.alloc(len);\n this._buffer.copy(newBuff, 0, 0, len);\n this._buffer = newBuff;\n if (this._flag.isSynchronous() && _fsMock.getRootFS().supportsSynch()) {\n this.syncSync();\n }\n };\n /**\n * Write buffer to the file.\n * Note that it is unsafe to use fs.write multiple times on the same file\n * without waiting for the callback.\n * @param [BrowserFS.node.Buffer] buffer Buffer containing the data to write to\n * the file.\n * @param [Number] offset Offset in the buffer to start reading data from.\n * @param [Number] length The amount of bytes to write to the file.\n * @param [Number] position Offset from the beginning of the file where this\n * data should be written. If position is null, the data will be written at\n * the current position.\n * @param [Function(BrowserFS.ApiError, Number, BrowserFS.node.Buffer)]\n * cb The number specifies the number of bytes written into the file.\n */\n PreloadFile.prototype.write = function write (buffer$$1, offset, length, position, cb) {\n try {\n cb(null, this.writeSync(buffer$$1, offset, length, position), buffer$$1);\n }\n catch (e) {\n cb(e);\n }\n };\n /**\n * Write buffer to the file.\n * Note that it is unsafe to use fs.writeSync multiple times on the same file\n * without waiting for the callback.\n * @param [BrowserFS.node.Buffer] buffer Buffer containing the data to write to\n * the file.\n * @param [Number] offset Offset in the buffer to start reading data from.\n * @param [Number] length The amount of bytes to write to the file.\n * @param [Number] position Offset from the beginning of the file where this\n * data should be written. If position is null, the data will be written at\n * the current position.\n * @return [Number]\n */\n PreloadFile.prototype.writeSync = function writeSync (buffer$$1, offset, length, position) {\n this._dirty = true;\n if (position === undefined || position === null) {\n position = this.getPos();\n }\n if (!this._flag.isWriteable()) {\n throw new ApiError(ErrorCode.EPERM, 'File not opened with a writeable mode.');\n }\n var endFp = position + length;\n if (endFp > this._stat.size) {\n this._stat.size = endFp;\n if (endFp > this._buffer.length) {\n // Extend the buffer!\n var newBuff = Buffer.alloc(endFp);\n this._buffer.copy(newBuff);\n this._buffer = newBuff;\n }\n }\n var len = buffer$$1.copy(this._buffer, position, offset, offset + length);\n this._stat.mtimeMs = Date.now();\n if (this._flag.isSynchronous()) {\n this.syncSync();\n return len;\n }\n this.setPos(position + len);\n return len;\n };\n /**\n * Read data from the file.\n * @param [BrowserFS.node.Buffer] buffer The buffer that the data will be\n * written to.\n * @param [Number] offset The offset within the buffer where writing will\n * start.\n * @param [Number] length An integer specifying the number of bytes to read.\n * @param [Number] position An integer specifying where to begin reading from\n * in the file. If position is null, data will be read from the current file\n * position.\n * @param [Function(BrowserFS.ApiError, Number, BrowserFS.node.Buffer)] cb The\n * number is the number of bytes read\n */\n PreloadFile.prototype.read = function read (buffer$$1, offset, length, position, cb) {\n try {\n cb(null, this.readSync(buffer$$1, offset, length, position), buffer$$1);\n }\n catch (e) {\n cb(e);\n }\n };\n /**\n * Read data from the file.\n * @param [BrowserFS.node.Buffer] buffer The buffer that the data will be\n * written to.\n * @param [Number] offset The offset within the buffer where writing will\n * start.\n * @param [Number] length An integer specifying the number of bytes to read.\n * @param [Number] position An integer specifying where to begin reading from\n * in the file. If position is null, data will be read from the current file\n * position.\n * @return [Number]\n */\n PreloadFile.prototype.readSync = function readSync (buffer$$1, offset, length, position) {\n if (!this._flag.isReadable()) {\n throw new ApiError(ErrorCode.EPERM, 'File not opened with a readable mode.');\n }\n if (position === undefined || position === null) {\n position = this.getPos();\n }\n var endRead = position + length;\n if (endRead > this._stat.size) {\n length = this._stat.size - position;\n }\n var rv = this._buffer.copy(buffer$$1, offset, position, position + length);\n this._stat.atimeMs = Date.now();\n this._pos = position + length;\n return rv;\n };\n /**\n * Asynchronous `fchmod`.\n * @param [Number|String] mode\n * @param [Function(BrowserFS.ApiError)] cb\n */\n PreloadFile.prototype.chmod = function chmod (mode, cb) {\n try {\n this.chmodSync(mode);\n cb();\n }\n catch (e) {\n cb(e);\n }\n };\n /**\n * Asynchronous `fchmod`.\n * @param [Number] mode\n */\n PreloadFile.prototype.chmodSync = function chmodSync (mode) {\n if (!this._fs.supportsProps()) {\n throw new ApiError(ErrorCode.ENOTSUP);\n }\n this._dirty = true;\n this._stat.chmod(mode);\n this.syncSync();\n };\n PreloadFile.prototype.isDirty = function isDirty () {\n return this._dirty;\n };\n /**\n * Resets the dirty bit. Should only be called after a sync has completed successfully.\n */\n PreloadFile.prototype.resetDirty = function resetDirty () {\n this._dirty = false;\n };\n\n return PreloadFile;\n}(BaseFile));\n/**\n * File class for the InMemory and XHR file systems.\n * Doesn't sync to anything, so it works nicely for memory-only files.\n */\nvar NoSyncFile = /*@__PURE__*/(function (PreloadFile) {\n function NoSyncFile(_fs, _path, _flag, _stat, contents) {\n PreloadFile.call(this, _fs, _path, _flag, _stat, contents);\n }\n\n if ( PreloadFile ) NoSyncFile.__proto__ = PreloadFile;\n NoSyncFile.prototype = Object.create( PreloadFile && PreloadFile.prototype );\n NoSyncFile.prototype.constructor = NoSyncFile;\n /**\n * Asynchronous sync. Doesn't do anything, simply calls the cb.\n * @param [Function(BrowserFS.ApiError)] cb\n */\n NoSyncFile.prototype.sync = function sync (cb) {\n cb();\n };\n /**\n * Synchronous sync. Doesn't do anything.\n */\n NoSyncFile.prototype.syncSync = function syncSync () {\n // NOP.\n };\n /**\n * Asynchronous close. Doesn't do anything, simply calls the cb.\n * @param [Function(BrowserFS.ApiError)] cb\n */\n NoSyncFile.prototype.close = function close (cb) {\n cb();\n };\n /**\n * Synchronous close. Doesn't do anything.\n */\n NoSyncFile.prototype.closeSync = function closeSync () {\n // NOP.\n };\n\n return NoSyncFile;\n}(PreloadFile));\n\n/**\n * We define our own file to interpose on syncSync() for mirroring purposes.\n */\nvar MirrorFile = /*@__PURE__*/(function (PreloadFile$$1) {\n function MirrorFile(fs, path$$1, flag, stat, data) {\n PreloadFile$$1.call(this, fs, path$$1, flag, stat, data);\n }\n\n if ( PreloadFile$$1 ) MirrorFile.__proto__ = PreloadFile$$1;\n MirrorFile.prototype = Object.create( PreloadFile$$1 && PreloadFile$$1.prototype );\n MirrorFile.prototype.constructor = MirrorFile;\n MirrorFile.prototype.syncSync = function syncSync () {\n if (this.isDirty()) {\n this._fs._syncSync(this);\n this.resetDirty();\n }\n };\n MirrorFile.prototype.closeSync = function closeSync () {\n this.syncSync();\n };\n\n return MirrorFile;\n}(PreloadFile));\n/**\n * AsyncMirrorFS mirrors a synchronous filesystem into an asynchronous filesystem\n * by:\n *\n * * Performing operations over the in-memory copy, while asynchronously pipelining them\n * to the backing store.\n * * During application loading, the contents of the async file system can be reloaded into\n * the synchronous store, if desired.\n *\n * The two stores will be kept in sync. The most common use-case is to pair a synchronous\n * in-memory filesystem with an asynchronous backing store.\n *\n * Example: Mirroring an IndexedDB file system to an in memory file system. Now, you can use\n * IndexedDB synchronously.\n *\n * ```javascript\n * BrowserFS.configure({\n * fs: \"AsyncMirror\",\n * options: {\n * sync: { fs: \"InMemory\" },\n * async: { fs: \"IndexedDB\" }\n * }\n * }, function(e) {\n * // BrowserFS is initialized and ready-to-use!\n * });\n * ```\n *\n * Or, alternatively:\n *\n * ```javascript\n * BrowserFS.FileSystem.IndexedDB.Create(function(e, idbfs) {\n * BrowserFS.FileSystem.InMemory.Create(function(e, inMemory) {\n * BrowserFS.FileSystem.AsyncMirror({\n * sync: inMemory, async: idbfs\n * }, function(e, mirrored) {\n * BrowserFS.initialize(mirrored);\n * });\n * });\n * });\n * ```\n */\nvar AsyncMirror = /*@__PURE__*/(function (SynchronousFileSystem$$1) {\n function AsyncMirror(sync, async) {\n SynchronousFileSystem$$1.call(this);\n /**\n * Queue of pending asynchronous operations.\n */\n this._queue = [];\n this._queueRunning = false;\n this._isInitialized = false;\n this._initializeCallbacks = [];\n this._sync = sync;\n this._async = async;\n }\n\n if ( SynchronousFileSystem$$1 ) AsyncMirror.__proto__ = SynchronousFileSystem$$1;\n AsyncMirror.prototype = Object.create( SynchronousFileSystem$$1 && SynchronousFileSystem$$1.prototype );\n AsyncMirror.prototype.constructor = AsyncMirror;\n /**\n * Constructs and initializes an AsyncMirror file system with the given options.\n */\n AsyncMirror.Create = function Create (opts, cb) {\n try {\n var fs = new AsyncMirror(opts.sync, opts.async);\n fs._initialize(function (e) {\n if (e) {\n cb(e);\n }\n else {\n cb(null, fs);\n }\n });\n }\n catch (e) {\n cb(e);\n }\n };\n AsyncMirror.isAvailable = function isAvailable () {\n return true;\n };\n AsyncMirror.prototype.getName = function getName () {\n return AsyncMirror.Name;\n };\n AsyncMirror.prototype._syncSync = function _syncSync (fd) {\n this._sync.writeFileSync(fd.getPath(), fd.getBuffer(), null, FileFlag.getFileFlag('w'), fd.getStats().mode);\n this.enqueueOp({\n apiMethod: 'writeFile',\n arguments: [fd.getPath(), fd.getBuffer(), null, fd.getFlag(), fd.getStats().mode]\n });\n };\n AsyncMirror.prototype.isReadOnly = function isReadOnly () { return false; };\n AsyncMirror.prototype.supportsSynch = function supportsSynch () { return true; };\n AsyncMirror.prototype.supportsLinks = function supportsLinks () { return false; };\n AsyncMirror.prototype.supportsProps = function supportsProps () { return this._sync.supportsProps() && this._async.supportsProps(); };\n AsyncMirror.prototype.renameSync = function renameSync (oldPath, newPath) {\n this._sync.renameSync(oldPath, newPath);\n this.enqueueOp({\n apiMethod: 'rename',\n arguments: [oldPath, newPath]\n });\n };\n AsyncMirror.prototype.statSync = function statSync (p, isLstat) {\n return this._sync.statSync(p, isLstat);\n };\n AsyncMirror.prototype.openSync = function openSync (p, flag, mode) {\n // Sanity check: Is this open/close permitted?\n var fd = this._sync.openSync(p, flag, mode);\n fd.closeSync();\n return new MirrorFile(this, p, flag, this._sync.statSync(p, false), this._sync.readFileSync(p, null, FileFlag.getFileFlag('r')));\n };\n AsyncMirror.prototype.unlinkSync = function unlinkSync (p) {\n this._sync.unlinkSync(p);\n this.enqueueOp({\n apiMethod: 'unlink',\n arguments: [p]\n });\n };\n AsyncMirror.prototype.rmdirSync = function rmdirSync (p) {\n this._sync.rmdirSync(p);\n this.enqueueOp({\n apiMethod: 'rmdir',\n arguments: [p]\n });\n };\n AsyncMirror.prototype.mkdirSync = function mkdirSync (p, mode) {\n this._sync.mkdirSync(p, mode);\n this.enqueueOp({\n apiMethod: 'mkdir',\n arguments: [p, mode]\n });\n };\n AsyncMirror.prototype.readdirSync = function readdirSync (p) {\n return this._sync.readdirSync(p);\n };\n AsyncMirror.prototype.existsSync = function existsSync (p) {\n return this._sync.existsSync(p);\n };\n AsyncMirror.prototype.chmodSync = function chmodSync (p, isLchmod, mode) {\n this._sync.chmodSync(p, isLchmod, mode);\n this.enqueueOp({\n apiMethod: 'chmod',\n arguments: [p, isLchmod, mode]\n });\n };\n AsyncMirror.prototype.chownSync = function chownSync (p, isLchown, uid, gid) {\n this._sync.chownSync(p, isLchown, uid, gid);\n this.enqueueOp({\n apiMethod: 'chown',\n arguments: [p, isLchown, uid, gid]\n });\n };\n AsyncMirror.prototype.utimesSync = function utimesSync (p, atime, mtime) {\n this._sync.utimesSync(p, atime, mtime);\n this.enqueueOp({\n apiMethod: 'utimes',\n arguments: [p, atime, mtime]\n });\n };\n /**\n * Called once to load up files from async storage into sync storage.\n */\n AsyncMirror.prototype._initialize = function _initialize (userCb) {\n var this$1 = this;\n\n var callbacks = this._initializeCallbacks;\n var end = function (e) {\n this$1._isInitialized = !e;\n this$1._initializeCallbacks = [];\n callbacks.forEach(function (cb) { return cb(e); });\n };\n if (!this._isInitialized) {\n // First call triggers initialization, the rest wait.\n if (callbacks.push(userCb) === 1) {\n var copyDirectory = function (p, mode, cb) {\n if (p !== '/') {\n this$1._sync.mkdirSync(p, mode);\n }\n this$1._async.readdir(p, function (err, files) {\n var i = 0;\n // NOTE: This function must not be in a lexically nested statement,\n // such as an if or while statement. Safari refuses to run the\n // script since it is undefined behavior.\n function copyNextFile(err) {\n if (err) {\n cb(err);\n }\n else if (i < files.length) {\n copyItem(path.join(p, files[i]), copyNextFile);\n i++;\n }\n else {\n cb();\n }\n }\n if (err) {\n cb(err);\n }\n else {\n copyNextFile();\n }\n });\n }, copyFile = function (p, mode, cb) {\n this$1._async.readFile(p, null, FileFlag.getFileFlag('r'), function (err, data) {\n if (err) {\n cb(err);\n }\n else {\n try {\n this$1._sync.writeFileSync(p, data, null, FileFlag.getFileFlag('w'), mode);\n }\n catch (e) {\n err = e;\n }\n finally {\n cb(err);\n }\n }\n });\n }, copyItem = function (p, cb) {\n this$1._async.stat(p, false, function (err, stats) {\n if (err) {\n cb(err);\n }\n else if (stats.isDirectory()) {\n copyDirectory(p, stats.mode, cb);\n }\n else {\n copyFile(p, stats.mode, cb);\n }\n });\n };\n copyDirectory('/', 0, end);\n }\n }\n else {\n userCb();\n }\n };\n AsyncMirror.prototype.enqueueOp = function enqueueOp (op) {\n var this$1 = this;\n\n this._queue.push(op);\n if (!this._queueRunning) {\n this._queueRunning = true;\n var doNextOp = function (err) {\n if (err) {\n throw new Error((\"WARNING: File system has desynchronized. Received following error: \" + err + \"\\n$\"));\n }\n if (this$1._queue.length > 0) {\n var op = this$1._queue.shift(), args = op.arguments;\n args.push(doNextOp);\n this$1._async[op.apiMethod].apply(this$1._async, args);\n }\n else {\n this$1._queueRunning = false;\n }\n };\n doNextOp();\n }\n };\n\n return AsyncMirror;\n}(SynchronousFileSystem));\nAsyncMirror.Name = \"AsyncMirror\";\nAsyncMirror.Options = {\n sync: {\n type: \"object\",\n description: \"The synchronous file system to mirror the asynchronous file system to.\",\n validator: function (v, cb) {\n if (v && typeof (v['supportsSynch']) === \"function\" && v.supportsSynch()) {\n cb();\n }\n else {\n cb(new ApiError(ErrorCode.EINVAL, \"'sync' option must be a file system that supports synchronous operations\"));\n }\n }\n },\n async: {\n type: \"object\",\n description: \"The asynchronous file system to mirror.\"\n }\n};\n\n// If Dropbox isn't on the webpage, then set this to null.\nvar Dropbox = toExport.Dropbox ? toExport.Dropbox.Dropbox : undefined;\n\n/**\n * Dropbox paths do not begin with a /, they just begin with a folder at the root node.\n * Here, we strip the `/`.\n * @param p An absolute path\n */\nfunction FixPath(p) {\n if (p === '/') {\n return '';\n }\n else {\n return p;\n }\n}\n/**\n * HACK: Dropbox errors are FUBAR'd sometimes.\n * @url https://github.com/dropbox/dropbox-sdk-js/issues/146\n * @param e\n */\nfunction ExtractTheFuckingError(e) {\n var obj = e.error;\n if (obj['.tag']) {\n // Everything is OK.\n return obj;\n }\n else if (obj['error']) {\n // Terrible nested object bug.\n var obj2 = obj.error;\n if (obj2['.tag']) {\n return obj2;\n }\n else if (obj2['reason'] && obj2['reason']['.tag']) {\n return obj2.reason;\n }\n else {\n return obj2;\n }\n }\n else if (typeof (obj) === 'string') {\n // Might be a fucking JSON object error.\n try {\n var obj2$1 = JSON.parse(obj);\n if (obj2$1['error'] && obj2$1['error']['reason'] && obj2$1['error']['reason']['.tag']) {\n return obj2$1.error.reason;\n }\n }\n catch (e) {\n // Nope. Give up.\n }\n }\n return obj;\n}\n/**\n * Returns a user-facing error message given an error.\n *\n * HACK: Dropbox error messages sometimes lack a `user_message` field.\n * Sometimes, they are even strings. Ugh.\n * @url https://github.com/dropbox/dropbox-sdk-js/issues/146\n * @url https://github.com/dropbox/dropbox-sdk-js/issues/145\n * @url https://github.com/dropbox/dropbox-sdk-js/issues/144\n * @param err An error.\n */\nfunction GetErrorMessage(err) {\n if (err['user_message']) {\n return err.user_message.text;\n }\n else if (err['error_summary']) {\n return err.error_summary;\n }\n else if (typeof (err.error) === \"string\") {\n return err.error;\n }\n else if (typeof (err.error) === \"object\") {\n // DROPBOX BUG: Sometimes, error is a nested error.\n return GetErrorMessage(err.error);\n }\n else {\n throw new Error((\"Dropbox's servers gave us a garbage error message: \" + (JSON.stringify(err))));\n }\n}\nfunction LookupErrorToError(err, p, msg) {\n switch (err['.tag']) {\n case 'malformed_path':\n return new ApiError(ErrorCode.EBADF, msg, p);\n case 'not_found':\n return ApiError.ENOENT(p);\n case 'not_file':\n return ApiError.EISDIR(p);\n case 'not_folder':\n return ApiError.ENOTDIR(p);\n case 'restricted_content':\n return ApiError.EPERM(p);\n case 'other':\n default:\n return new ApiError(ErrorCode.EIO, msg, p);\n }\n}\nfunction WriteErrorToError(err, p, msg) {\n switch (err['.tag']) {\n case 'malformed_path':\n case 'disallowed_name':\n return new ApiError(ErrorCode.EBADF, msg, p);\n case 'conflict':\n case 'no_write_permission':\n case 'team_folder':\n return ApiError.EPERM(p);\n case 'insufficient_space':\n return new ApiError(ErrorCode.ENOSPC, msg);\n case 'other':\n default:\n return new ApiError(ErrorCode.EIO, msg, p);\n }\n}\nfunction FilesDeleteWrapped(client, p, cb) {\n var arg = {\n path: FixPath(p)\n };\n client.filesDeleteV2(arg)\n .then(function () {\n cb();\n }).catch(function (e) {\n var err = ExtractTheFuckingError(e);\n switch (err['.tag']) {\n case 'path_lookup':\n cb(LookupErrorToError(err.path_lookup, p, GetErrorMessage(e)));\n break;\n case 'path_write':\n cb(WriteErrorToError(err.path_write, p, GetErrorMessage(e)));\n break;\n case 'too_many_write_operations':\n setTimeout(function () { return FilesDeleteWrapped(client, p, cb); }, 500 + (300 * (Math.random())));\n break;\n case 'other':\n default:\n cb(new ApiError(ErrorCode.EIO, GetErrorMessage(e), p));\n break;\n }\n });\n}\nvar DropboxFile = /*@__PURE__*/(function (PreloadFile$$1) {\n function DropboxFile(_fs, _path, _flag, _stat, contents) {\n PreloadFile$$1.call(this, _fs, _path, _flag, _stat, contents);\n }\n\n if ( PreloadFile$$1 ) DropboxFile.__proto__ = PreloadFile$$1;\n DropboxFile.prototype = Object.create( PreloadFile$$1 && PreloadFile$$1.prototype );\n DropboxFile.prototype.constructor = DropboxFile;\n DropboxFile.prototype.sync = function sync (cb) {\n this._fs._syncFile(this.getPath(), this.getBuffer(), cb);\n };\n DropboxFile.prototype.close = function close (cb) {\n this.sync(cb);\n };\n\n return DropboxFile;\n}(PreloadFile));\n/**\n * A read/write file system backed by Dropbox cloud storage.\n *\n * Uses the Dropbox V2 API, and the 2.x JS SDK.\n */\nvar DropboxFileSystem = /*@__PURE__*/(function (BaseFileSystem$$1) {\n function DropboxFileSystem(client) {\n BaseFileSystem$$1.call(this);\n this._client = client;\n }\n\n if ( BaseFileSystem$$1 ) DropboxFileSystem.__proto__ = BaseFileSystem$$1;\n DropboxFileSystem.prototype = Object.create( BaseFileSystem$$1 && BaseFileSystem$$1.prototype );\n DropboxFileSystem.prototype.constructor = DropboxFileSystem;\n /**\n * Creates a new DropboxFileSystem instance with the given options.\n * Must be given an *authenticated* Dropbox client from 2.x JS SDK.\n */\n DropboxFileSystem.Create = function Create (opts, cb) {\n cb(null, new DropboxFileSystem(opts.client));\n };\n DropboxFileSystem.isAvailable = function isAvailable () {\n // Checks if the Dropbox library is loaded.\n return typeof Dropbox !== 'undefined';\n };\n DropboxFileSystem.prototype.getName = function getName () {\n return DropboxFileSystem.Name;\n };\n DropboxFileSystem.prototype.isReadOnly = function isReadOnly () {\n return false;\n };\n // Dropbox doesn't support symlinks, properties, or synchronous calls\n // TODO: does it???\n DropboxFileSystem.prototype.supportsSymlinks = function supportsSymlinks () {\n return false;\n };\n DropboxFileSystem.prototype.supportsProps = function supportsProps () {\n return false;\n };\n DropboxFileSystem.prototype.supportsSynch = function supportsSynch () {\n return false;\n };\n /**\n * Deletes *everything* in the file system. Mainly intended for unit testing!\n * @param mainCb Called when operation completes.\n */\n DropboxFileSystem.prototype.empty = function empty (mainCb) {\n var this$1 = this;\n\n this.readdir('/', function (e, paths) {\n if (paths) {\n var next = function (e) {\n if (paths.length === 0) {\n mainCb();\n }\n else {\n FilesDeleteWrapped(this$1._client, paths.shift(), next);\n }\n };\n next();\n }\n else {\n mainCb(e);\n }\n });\n };\n DropboxFileSystem.prototype.rename = function rename (oldPath, newPath, cb) {\n var this$1 = this;\n\n // Dropbox doesn't let you rename things over existing things, but POSIX does.\n // So, we need to see if newPath exists...\n this.stat(newPath, false, function (e, stats) {\n var rename = function () {\n var relocationArg = {\n from_path: FixPath(oldPath),\n to_path: FixPath(newPath)\n };\n this$1._client.filesMoveV2(relocationArg)\n .then(function () { return cb(); })\n .catch(function (e) {\n var err = ExtractTheFuckingError(e);\n switch (err['.tag']) {\n case 'from_lookup':\n cb(LookupErrorToError(err.from_lookup, oldPath, GetErrorMessage(e)));\n break;\n case 'from_write':\n cb(WriteErrorToError(err.from_write, oldPath, GetErrorMessage(e)));\n break;\n case 'to':\n cb(WriteErrorToError(err.to, newPath, GetErrorMessage(e)));\n break;\n case 'cant_copy_shared_folder':\n case 'cant_nest_shared_folder':\n cb(new ApiError(ErrorCode.EPERM, GetErrorMessage(e), oldPath));\n break;\n case 'cant_move_folder_into_itself':\n case 'duplicated_or_nested_paths':\n cb(new ApiError(ErrorCode.EBADF, GetErrorMessage(e), oldPath));\n break;\n case 'too_many_files':\n cb(new ApiError(ErrorCode.ENOSPC, GetErrorMessage(e), oldPath));\n break;\n case 'other':\n default:\n cb(new ApiError(ErrorCode.EIO, GetErrorMessage(e), oldPath));\n break;\n }\n });\n };\n if (e) {\n // Doesn't exist. Proceed!\n rename();\n }\n else if (oldPath === newPath) {\n // NOP if the path exists. Error if it doesn't exist.\n if (e) {\n cb(ApiError.ENOENT(newPath));\n }\n else {\n cb();\n }\n }\n else if (stats && stats.isDirectory()) {\n // Exists, is a directory. Cannot rename over an existing directory.\n cb(ApiError.EISDIR(newPath));\n }\n else {\n // Exists, is a file, and differs from oldPath. Delete and rename.\n this$1.unlink(newPath, function (e) {\n if (e) {\n cb(e);\n }\n else {\n rename();\n }\n });\n }\n });\n };\n DropboxFileSystem.prototype.stat = function stat (path$$1, isLstat, cb) {\n if (path$$1 === '/') {\n // Dropbox doesn't support querying the root directory.\n setImmediate$1(function () {\n cb(null, new Stats(FileType.DIRECTORY, 4096));\n });\n return;\n }\n var arg = {\n path: FixPath(path$$1)\n };\n this._client.filesGetMetadata(arg).then(function (ref) {\n switch (ref['.tag']) {\n case 'file':\n var fileMetadata = ref;\n // TODO: Parse time fields.\n cb(null, new Stats(FileType.FILE, fileMetadata.size));\n break;\n case 'folder':\n cb(null, new Stats(FileType.DIRECTORY, 4096));\n break;\n case 'deleted':\n cb(ApiError.ENOENT(path$$1));\n break;\n default:\n // Unknown.\n break;\n }\n }).catch(function (e) {\n var err = ExtractTheFuckingError(e);\n switch (err['.tag']) {\n case 'path':\n cb(LookupErrorToError(err.path, path$$1, GetErrorMessage(e)));\n break;\n default:\n cb(new ApiError(ErrorCode.EIO, GetErrorMessage(e), path$$1));\n break;\n }\n });\n };\n DropboxFileSystem.prototype.openFile = function openFile (path$$1, flags, cb) {\n var this$1 = this;\n\n var downloadArg = {\n path: FixPath(path$$1)\n };\n this._client.filesDownload(downloadArg).then(function (res) {\n var b = res.fileBlob;\n var fr = new FileReader();\n fr.onload = function () {\n var ab = fr.result;\n cb(null, new DropboxFile(this$1, path$$1, flags, new Stats(FileType.FILE, ab.byteLength), arrayBuffer2Buffer(ab)));\n };\n fr.readAsArrayBuffer(b);\n }).catch(function (e) {\n var err = ExtractTheFuckingError(e);\n switch (err['.tag']) {\n case 'path':\n var dpError = err;\n cb(LookupErrorToError(dpError.path, path$$1, GetErrorMessage(e)));\n break;\n case 'other':\n default:\n cb(new ApiError(ErrorCode.EIO, GetErrorMessage(e), path$$1));\n break;\n }\n });\n };\n DropboxFileSystem.prototype.createFile = function createFile (p, flags, mode, cb) {\n var this$1 = this;\n\n var fileData = Buffer.alloc(0);\n var blob = new Blob([buffer2ArrayBuffer(fileData)], { type: \"octet/stream\" });\n var commitInfo = {\n contents: blob,\n path: FixPath(p)\n };\n this._client.filesUpload(commitInfo).then(function (metadata) {\n cb(null, new DropboxFile(this$1, p, flags, new Stats(FileType.FILE, 0), fileData));\n }).catch(function (e) {\n var err = ExtractTheFuckingError(e);\n // HACK: Casting to 'any' since tag can be 'too_many_write_operations'.\n switch (err['.tag']) {\n case 'path':\n var upError = err;\n cb(WriteErrorToError(upError.path.reason, p, GetErrorMessage(e)));\n break;\n case 'too_many_write_operations':\n // Retry in (500, 800) ms.\n setTimeout(function () { return this$1.createFile(p, flags, mode, cb); }, 500 + (300 * (Math.random())));\n break;\n case 'other':\n default:\n cb(new ApiError(ErrorCode.EIO, GetErrorMessage(e), p));\n break;\n }\n });\n };\n /**\n * Delete a file\n */\n DropboxFileSystem.prototype.unlink = function unlink (path$$1, cb) {\n var this$1 = this;\n\n // Must be a file. Check first.\n this.stat(path$$1, false, function (e, stat) {\n if (stat) {\n if (stat.isDirectory()) {\n cb(ApiError.EISDIR(path$$1));\n }\n else {\n FilesDeleteWrapped(this$1._client, path$$1, cb);\n }\n }\n else {\n cb(e);\n }\n });\n };\n /**\n * Delete a directory\n */\n DropboxFileSystem.prototype.rmdir = function rmdir (path$$1, cb) {\n var this$1 = this;\n\n this.readdir(path$$1, function (e, paths) {\n if (paths) {\n if (paths.length > 0) {\n cb(ApiError.ENOTEMPTY(path$$1));\n }\n else {\n FilesDeleteWrapped(this$1._client, path$$1, cb);\n }\n }\n else {\n cb(e);\n }\n });\n };\n /**\n * Create a directory\n */\n DropboxFileSystem.prototype.mkdir = function mkdir (p, mode, cb) {\n var this$1 = this;\n\n // Dropbox's create_folder is recursive. Check if parent exists.\n var parent = path.dirname(p);\n this.stat(parent, false, function (e, stats) {\n if (e) {\n cb(e);\n }\n else if (stats && !stats.isDirectory()) {\n cb(ApiError.ENOTDIR(parent));\n }\n else {\n var arg = {\n path: FixPath(p)\n };\n this$1._client.filesCreateFolderV2(arg).then(function () { return cb(); }).catch(function (e) {\n var err = ExtractTheFuckingError(e);\n if (err['.tag'] === \"too_many_write_operations\") {\n // Retry in a bit.\n setTimeout(function () { return this$1.mkdir(p, mode, cb); }, 500 + (300 * (Math.random())));\n }\n else {\n cb(WriteErrorToError(ExtractTheFuckingError(e).path, p, GetErrorMessage(e)));\n }\n });\n }\n });\n };\n /**\n * Get the names of the files in a directory\n */\n DropboxFileSystem.prototype.readdir = function readdir (path$$1, cb) {\n var this$1 = this;\n\n var arg = {\n path: FixPath(path$$1)\n };\n this._client.filesListFolder(arg).then(function (res) {\n ContinueReadingDir(this$1._client, path$$1, res, [], cb);\n }).catch(function (e) {\n ProcessListFolderError(e, path$$1, cb);\n });\n };\n /**\n * (Internal) Syncs file to Dropbox.\n */\n DropboxFileSystem.prototype._syncFile = function _syncFile (p, d, cb) {\n var this$1 = this;\n\n var blob = new Blob([buffer2ArrayBuffer(d)], { type: \"octet/stream\" });\n var arg = {\n contents: blob,\n path: FixPath(p),\n mode: {\n '.tag': 'overwrite'\n }\n };\n this._client.filesUpload(arg).then(function () {\n cb();\n }).catch(function (e) {\n var err = ExtractTheFuckingError(e);\n switch (err['.tag']) {\n case 'path':\n var upError = err;\n cb(WriteErrorToError(upError.path.reason, p, GetErrorMessage(e)));\n break;\n case 'too_many_write_operations':\n setTimeout(function () { return this$1._syncFile(p, d, cb); }, 500 + (300 * (Math.random())));\n break;\n case 'other':\n default:\n cb(new ApiError(ErrorCode.EIO, GetErrorMessage(e), p));\n break;\n }\n });\n };\n\n return DropboxFileSystem;\n}(BaseFileSystem));\nDropboxFileSystem.Name = \"DropboxV2\";\nDropboxFileSystem.Options = {\n client: {\n type: \"object\",\n description: \"An *authenticated* Dropbox client. Must be from the 2.5.x JS SDK.\"\n }\n};\nfunction ProcessListFolderError(e, path$$1, cb) {\n var err = ExtractTheFuckingError(e);\n switch (err['.tag']) {\n case 'path':\n var pathError = err;\n cb(LookupErrorToError(pathError.path, path$$1, GetErrorMessage(e)));\n break;\n case 'other':\n default:\n cb(new ApiError(ErrorCode.EIO, GetErrorMessage(e), path$$1));\n break;\n }\n}\nfunction ContinueReadingDir(client, path$$1, res, previousEntries, cb) {\n var newEntries = res.entries.map(function (e) { return e.path_display; }).filter(function (p) { return !!p; });\n var entries = previousEntries.concat(newEntries);\n if (!res.has_more) {\n cb(null, entries);\n }\n else {\n var arg = {\n cursor: res.cursor\n };\n client.filesListFolderContinue(arg).then(function (res) {\n ContinueReadingDir(client, path$$1, res, entries, cb);\n }).catch(function (e) {\n ProcessListFolderError(e, path$$1, cb);\n });\n }\n}\n\n/**\n * @hidden\n */\nfunction convertError(e, path$$1) {\n if ( path$$1 === void 0 ) path$$1 = '';\n\n var errno = e.errno;\n var parent = e.node;\n var paths = [];\n while (parent) {\n paths.unshift(parent.name);\n if (parent === parent.parent) {\n break;\n }\n parent = parent.parent;\n }\n return new ApiError(errno, ErrorStrings[errno], paths.length > 0 ? '/' + paths.join('/') : path$$1);\n}\nvar EmscriptenFile = /*@__PURE__*/(function (BaseFile$$1) {\n function EmscriptenFile(_fs, _FS, _path, _stream) {\n BaseFile$$1.call(this);\n this._fs = _fs;\n this._FS = _FS;\n this._path = _path;\n this._stream = _stream;\n }\n\n if ( BaseFile$$1 ) EmscriptenFile.__proto__ = BaseFile$$1;\n EmscriptenFile.prototype = Object.create( BaseFile$$1 && BaseFile$$1.prototype );\n EmscriptenFile.prototype.constructor = EmscriptenFile;\n EmscriptenFile.prototype.getPos = function getPos () {\n return undefined;\n };\n EmscriptenFile.prototype.close = function close (cb) {\n var err = null;\n try {\n this.closeSync();\n }\n catch (e) {\n err = e;\n }\n finally {\n cb(err);\n }\n };\n EmscriptenFile.prototype.closeSync = function closeSync () {\n try {\n this._FS.close(this._stream);\n }\n catch (e) {\n throw convertError(e, this._path);\n }\n };\n EmscriptenFile.prototype.stat = function stat (cb) {\n try {\n cb(null, this.statSync());\n }\n catch (e) {\n cb(e);\n }\n };\n EmscriptenFile.prototype.statSync = function statSync () {\n try {\n return this._fs.statSync(this._path, false);\n }\n catch (e) {\n throw convertError(e, this._path);\n }\n };\n EmscriptenFile.prototype.truncate = function truncate (len, cb) {\n var err = null;\n try {\n this.truncateSync(len);\n }\n catch (e) {\n err = e;\n }\n finally {\n cb(err);\n }\n };\n EmscriptenFile.prototype.truncateSync = function truncateSync (len) {\n try {\n this._FS.ftruncate(this._stream.fd, len);\n }\n catch (e) {\n throw convertError(e, this._path);\n }\n };\n EmscriptenFile.prototype.write = function write (buffer$$1, offset, length, position, cb) {\n try {\n cb(null, this.writeSync(buffer$$1, offset, length, position), buffer$$1);\n }\n catch (e) {\n cb(e);\n }\n };\n EmscriptenFile.prototype.writeSync = function writeSync (buffer$$1, offset, length, position) {\n try {\n var u8 = buffer2Uint8array(buffer$$1);\n // Emscripten is particular about what position is set to.\n var emPosition = position === null ? undefined : position;\n return this._FS.write(this._stream, u8, offset, length, emPosition);\n }\n catch (e) {\n throw convertError(e, this._path);\n }\n };\n EmscriptenFile.prototype.read = function read (buffer$$1, offset, length, position, cb) {\n try {\n cb(null, this.readSync(buffer$$1, offset, length, position), buffer$$1);\n }\n catch (e) {\n cb(e);\n }\n };\n EmscriptenFile.prototype.readSync = function readSync (buffer$$1, offset, length, position) {\n try {\n var u8 = buffer2Uint8array(buffer$$1);\n // Emscripten is particular about what position is set to.\n var emPosition = position === null ? undefined : position;\n return this._FS.read(this._stream, u8, offset, length, emPosition);\n }\n catch (e) {\n throw convertError(e, this._path);\n }\n };\n EmscriptenFile.prototype.sync = function sync (cb) {\n // NOP.\n cb();\n };\n EmscriptenFile.prototype.syncSync = function syncSync () {\n // NOP.\n };\n EmscriptenFile.prototype.chown = function chown (uid, gid, cb) {\n var err = null;\n try {\n this.chownSync(uid, gid);\n }\n catch (e) {\n err = e;\n }\n finally {\n cb(err);\n }\n };\n EmscriptenFile.prototype.chownSync = function chownSync (uid, gid) {\n try {\n this._FS.fchown(this._stream.fd, uid, gid);\n }\n catch (e) {\n throw convertError(e, this._path);\n }\n };\n EmscriptenFile.prototype.chmod = function chmod (mode, cb) {\n var err = null;\n try {\n this.chmodSync(mode);\n }\n catch (e) {\n err = e;\n }\n finally {\n cb(err);\n }\n };\n EmscriptenFile.prototype.chmodSync = function chmodSync (mode) {\n try {\n this._FS.fchmod(this._stream.fd, mode);\n }\n catch (e) {\n throw convertError(e, this._path);\n }\n };\n EmscriptenFile.prototype.utimes = function utimes (atime, mtime, cb) {\n var err = null;\n try {\n this.utimesSync(atime, mtime);\n }\n catch (e) {\n err = e;\n }\n finally {\n cb(err);\n }\n };\n EmscriptenFile.prototype.utimesSync = function utimesSync (atime, mtime) {\n this._fs.utimesSync(this._path, atime, mtime);\n };\n\n return EmscriptenFile;\n}(BaseFile));\n/**\n * Mounts an Emscripten file system into the BrowserFS file system.\n */\nvar EmscriptenFileSystem = /*@__PURE__*/(function (SynchronousFileSystem$$1) {\n function EmscriptenFileSystem(_FS) {\n SynchronousFileSystem$$1.call(this);\n this._FS = _FS;\n }\n\n if ( SynchronousFileSystem$$1 ) EmscriptenFileSystem.__proto__ = SynchronousFileSystem$$1;\n EmscriptenFileSystem.prototype = Object.create( SynchronousFileSystem$$1 && SynchronousFileSystem$$1.prototype );\n EmscriptenFileSystem.prototype.constructor = EmscriptenFileSystem;\n /**\n * Create an EmscriptenFileSystem instance with the given options.\n */\n EmscriptenFileSystem.Create = function Create (opts, cb) {\n cb(null, new EmscriptenFileSystem(opts.FS));\n };\n EmscriptenFileSystem.isAvailable = function isAvailable () { return true; };\n EmscriptenFileSystem.prototype.getName = function getName () { return this._FS.DB_NAME(); };\n EmscriptenFileSystem.prototype.isReadOnly = function isReadOnly () { return false; };\n EmscriptenFileSystem.prototype.supportsLinks = function supportsLinks () { return true; };\n EmscriptenFileSystem.prototype.supportsProps = function supportsProps () { return true; };\n EmscriptenFileSystem.prototype.supportsSynch = function supportsSynch () { return true; };\n EmscriptenFileSystem.prototype.renameSync = function renameSync (oldPath, newPath) {\n try {\n this._FS.rename(oldPath, newPath);\n }\n catch (e) {\n if (e.errno === ErrorCode.ENOENT) {\n throw convertError(e, this.existsSync(oldPath) ? newPath : oldPath);\n }\n else {\n throw convertError(e);\n }\n }\n };\n EmscriptenFileSystem.prototype.statSync = function statSync (p, isLstat) {\n try {\n var stats = isLstat ? this._FS.lstat(p) : this._FS.stat(p);\n var itemType = this.modeToFileType(stats.mode);\n return new Stats(itemType, stats.size, stats.mode, stats.atime.getTime(), stats.mtime.getTime(), stats.ctime.getTime());\n }\n catch (e) {\n throw convertError(e, p);\n }\n };\n EmscriptenFileSystem.prototype.openSync = function openSync (p, flag, mode) {\n try {\n var stream = this._FS.open(p, flag.getFlagString(), mode);\n if (this._FS.isDir(stream.node.mode)) {\n this._FS.close(stream);\n throw ApiError.EISDIR(p);\n }\n return new EmscriptenFile(this, this._FS, p, stream);\n }\n catch (e) {\n throw convertError(e, p);\n }\n };\n EmscriptenFileSystem.prototype.unlinkSync = function unlinkSync (p) {\n try {\n this._FS.unlink(p);\n }\n catch (e) {\n throw convertError(e, p);\n }\n };\n EmscriptenFileSystem.prototype.rmdirSync = function rmdirSync (p) {\n try {\n this._FS.rmdir(p);\n }\n catch (e) {\n throw convertError(e, p);\n }\n };\n EmscriptenFileSystem.prototype.mkdirSync = function mkdirSync (p, mode) {\n try {\n this._FS.mkdir(p, mode);\n }\n catch (e) {\n throw convertError(e, p);\n }\n };\n EmscriptenFileSystem.prototype.readdirSync = function readdirSync (p) {\n try {\n // Emscripten returns items for '.' and '..'. Node does not.\n return this._FS.readdir(p).filter(function (p) { return p !== '.' && p !== '..'; });\n }\n catch (e) {\n throw convertError(e, p);\n }\n };\n EmscriptenFileSystem.prototype.truncateSync = function truncateSync (p, len) {\n try {\n this._FS.truncate(p, len);\n }\n catch (e) {\n throw convertError(e, p);\n }\n };\n EmscriptenFileSystem.prototype.readFileSync = function readFileSync (p, encoding, flag) {\n try {\n var data = this._FS.readFile(p, { flags: flag.getFlagString() });\n var buff = uint8Array2Buffer(data);\n if (encoding) {\n return buff.toString(encoding);\n }\n else {\n return buff;\n }\n }\n catch (e) {\n throw convertError(e, p);\n }\n };\n EmscriptenFileSystem.prototype.writeFileSync = function writeFileSync (p, data, encoding, flag, mode) {\n try {\n if (encoding) {\n data = Buffer.from(data, encoding);\n }\n var u8 = buffer2Uint8array(data);\n this._FS.writeFile(p, u8, { flags: flag.getFlagString(), encoding: 'binary' });\n this._FS.chmod(p, mode);\n }\n catch (e) {\n throw convertError(e, p);\n }\n };\n EmscriptenFileSystem.prototype.chmodSync = function chmodSync (p, isLchmod, mode) {\n try {\n isLchmod ? this._FS.lchmod(p, mode) : this._FS.chmod(p, mode);\n }\n catch (e) {\n throw convertError(e, p);\n }\n };\n EmscriptenFileSystem.prototype.chownSync = function chownSync (p, isLchown, uid, gid) {\n try {\n isLchown ? this._FS.lchown(p, uid, gid) : this._FS.chown(p, uid, gid);\n }\n catch (e) {\n throw convertError(e, p);\n }\n };\n EmscriptenFileSystem.prototype.symlinkSync = function symlinkSync (srcpath, dstpath, type) {\n try {\n this._FS.symlink(srcpath, dstpath);\n }\n catch (e) {\n throw convertError(e);\n }\n };\n EmscriptenFileSystem.prototype.readlinkSync = function readlinkSync (p) {\n try {\n return this._FS.readlink(p);\n }\n catch (e) {\n throw convertError(e, p);\n }\n };\n EmscriptenFileSystem.prototype.utimesSync = function utimesSync (p, atime, mtime) {\n try {\n this._FS.utime(p, atime.getTime(), mtime.getTime());\n }\n catch (e) {\n throw convertError(e, p);\n }\n };\n EmscriptenFileSystem.prototype.modeToFileType = function modeToFileType (mode) {\n if (this._FS.isDir(mode)) {\n return FileType.DIRECTORY;\n }\n else if (this._FS.isFile(mode)) {\n return FileType.FILE;\n }\n else if (this._FS.isLink(mode)) {\n return FileType.SYMLINK;\n }\n else {\n throw ApiError.EPERM((\"Invalid mode: \" + mode));\n }\n };\n\n return EmscriptenFileSystem;\n}(SynchronousFileSystem));\nEmscriptenFileSystem.Name = \"EmscriptenFileSystem\";\nEmscriptenFileSystem.Options = {\n FS: {\n type: \"object\",\n description: \"The Emscripten file system to use (the `FS` variable)\"\n }\n};\n\n/**\n * The FolderAdapter file system wraps a file system, and scopes all interactions to a subfolder of that file system.\n *\n * Example: Given a file system `foo` with folder `bar` and file `bar/baz`...\n *\n * ```javascript\n * BrowserFS.configure({\n * fs: \"FolderAdapter\",\n * options: {\n * folder: \"bar\",\n * wrapped: foo\n * }\n * }, function(e) {\n * var fs = BrowserFS.BFSRequire('fs');\n * fs.readdirSync('/'); // ['baz']\n * });\n * ```\n */\nvar FolderAdapter = /*@__PURE__*/(function (BaseFileSystem$$1) {\n function FolderAdapter(folder, wrapped) {\n BaseFileSystem$$1.call(this);\n this._folder = folder;\n this._wrapped = wrapped;\n }\n\n if ( BaseFileSystem$$1 ) FolderAdapter.__proto__ = BaseFileSystem$$1;\n FolderAdapter.prototype = Object.create( BaseFileSystem$$1 && BaseFileSystem$$1.prototype );\n FolderAdapter.prototype.constructor = FolderAdapter;\n /**\n * Creates a FolderAdapter instance with the given options.\n */\n FolderAdapter.Create = function Create (opts, cb) {\n var fa = new FolderAdapter(opts.folder, opts.wrapped);\n fa._initialize(function (e) {\n if (e) {\n cb(e);\n }\n else {\n cb(null, fa);\n }\n });\n };\n FolderAdapter.isAvailable = function isAvailable () {\n return true;\n };\n FolderAdapter.prototype.getName = function getName () { return this._wrapped.getName(); };\n FolderAdapter.prototype.isReadOnly = function isReadOnly () { return this._wrapped.isReadOnly(); };\n FolderAdapter.prototype.supportsProps = function supportsProps () { return this._wrapped.supportsProps(); };\n FolderAdapter.prototype.supportsSynch = function supportsSynch () { return this._wrapped.supportsSynch(); };\n FolderAdapter.prototype.supportsLinks = function supportsLinks () { return false; };\n /**\n * Initialize the file system. Ensures that the wrapped file system\n * has the given folder.\n */\n FolderAdapter.prototype._initialize = function _initialize (cb) {\n var this$1 = this;\n\n this._wrapped.exists(this._folder, function (exists) {\n if (exists) {\n cb();\n }\n else if (this$1._wrapped.isReadOnly()) {\n cb(ApiError.ENOENT(this$1._folder));\n }\n else {\n this$1._wrapped.mkdir(this$1._folder, 0x1ff, cb);\n }\n });\n };\n\n return FolderAdapter;\n}(BaseFileSystem));\nFolderAdapter.Name = \"FolderAdapter\";\nFolderAdapter.Options = {\n folder: {\n type: \"string\",\n description: \"The folder to use as the root directory\"\n },\n wrapped: {\n type: \"object\",\n description: \"The file system to wrap\"\n }\n};\n/**\n * @hidden\n */\nfunction translateError(folder, e) {\n if (e !== null && typeof e === 'object') {\n var err = e;\n var p = err.path;\n if (p) {\n p = '/' + path.relative(folder, p);\n err.message = err.message.replace(err.path, p);\n err.path = p;\n }\n }\n return e;\n}\n/**\n * @hidden\n */\nfunction wrapCallback(folder, cb) {\n if (typeof cb === 'function') {\n return function (err) {\n if (arguments.length > 0) {\n arguments[0] = translateError(folder, err);\n }\n cb.apply(null, arguments);\n };\n }\n else {\n return cb;\n }\n}\n/**\n * @hidden\n */\nfunction wrapFunction(name, wrapFirst, wrapSecond) {\n if (name.slice(name.length - 4) !== 'Sync') {\n // Async function. Translate error in callback.\n return function () {\n if (arguments.length > 0) {\n if (wrapFirst) {\n arguments[0] = path.join(this._folder, arguments[0]);\n }\n if (wrapSecond) {\n arguments[1] = path.join(this._folder, arguments[1]);\n }\n arguments[arguments.length - 1] = wrapCallback(this._folder, arguments[arguments.length - 1]);\n }\n return this._wrapped[name].apply(this._wrapped, arguments);\n };\n }\n else {\n // Sync function. Translate error in catch.\n return function () {\n try {\n if (wrapFirst) {\n arguments[0] = path.join(this._folder, arguments[0]);\n }\n if (wrapSecond) {\n arguments[1] = path.join(this._folder, arguments[1]);\n }\n return this._wrapped[name].apply(this._wrapped, arguments);\n }\n catch (e) {\n throw translateError(this._folder, e);\n }\n };\n }\n}\n// First argument is a path.\n['diskSpace', 'stat', 'statSync', 'open', 'openSync', 'unlink', 'unlinkSync',\n 'rmdir', 'rmdirSync', 'mkdir', 'mkdirSync', 'readdir', 'readdirSync', 'exists',\n 'existsSync', 'realpath', 'realpathSync', 'truncate', 'truncateSync', 'readFile',\n 'readFileSync', 'writeFile', 'writeFileSync', 'appendFile', 'appendFileSync',\n 'chmod', 'chmodSync', 'chown', 'chownSync', 'utimes', 'utimesSync', 'readlink',\n 'readlinkSync'].forEach(function (name) {\n FolderAdapter.prototype[name] = wrapFunction(name, true, false);\n});\n// First and second arguments are paths.\n['rename', 'renameSync', 'link', 'linkSync', 'symlink', 'symlinkSync'].forEach(function (name) {\n FolderAdapter.prototype[name] = wrapFunction(name, true, true);\n});\n\nfunction slice(arrayLike, start) {\n start = start|0;\n var newLen = Math.max(arrayLike.length - start, 0);\n var newArr = Array(newLen);\n for(var idx = 0; idx < newLen; idx++) {\n newArr[idx] = arrayLike[start + idx];\n }\n return newArr;\n}\n\nfunction initialParams (fn) {\n return function (/*...args, callback*/) {\n var args = slice(arguments);\n var callback = args.pop();\n fn.call(this, args, callback);\n };\n}\n\n/**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\nfunction isObject(value) {\n var type = typeof value;\n return value != null && (type == 'object' || type == 'function');\n}\n\nvar hasSetImmediate = typeof setImmediate === 'function' && setImmediate;\nvar hasNextTick = typeof process === 'object' && typeof process.nextTick === 'function';\n\nfunction fallback(fn) {\n setTimeout(fn, 0);\n}\n\nfunction wrap(defer) {\n return function (fn/*, ...args*/) {\n var args = slice(arguments, 1);\n defer(function () {\n fn.apply(null, args);\n });\n };\n}\n\nvar _defer;\n\nif (hasSetImmediate) {\n _defer = setImmediate;\n} else if (hasNextTick) {\n _defer = process.nextTick;\n} else {\n _defer = fallback;\n}\n\nvar setImmediate$2 = wrap(_defer);\n\n/**\n * Take a sync function and make it async, passing its return value to a\n * callback. This is useful for plugging sync functions into a waterfall,\n * series, or other async functions. Any arguments passed to the generated\n * function will be passed to the wrapped function (except for the final\n * callback argument). Errors thrown will be passed to the callback.\n *\n * If the function passed to `asyncify` returns a Promise, that promises's\n * resolved/rejected state will be used to call the callback, rather than simply\n * the synchronous return value.\n *\n * This also means you can asyncify ES2017 `async` functions.\n *\n * @name asyncify\n * @static\n * @memberOf module:Utils\n * @method\n * @alias wrapSync\n * @category Util\n * @param {Function} func - The synchronous function, or Promise-returning\n * function to convert to an {@link AsyncFunction}.\n * @returns {AsyncFunction} An asynchronous wrapper of the `func`. To be\n * invoked with `(args..., callback)`.\n * @example\n *\n * // passing a regular synchronous function\n * async.waterfall([\n * async.apply(fs.readFile, filename, \"utf8\"),\n * async.asyncify(JSON.parse),\n * function (data, next) {\n * // data is the result of parsing the text.\n * // If there was a parsing error, it would have been caught.\n * }\n * ], callback);\n *\n * // passing a function returning a promise\n * async.waterfall([\n * async.apply(fs.readFile, filename, \"utf8\"),\n * async.asyncify(function (contents) {\n * return db.model.create(contents);\n * }),\n * function (model, next) {\n * // `model` is the instantiated model object.\n * // If there was an error, this function would be skipped.\n * }\n * ], callback);\n *\n * // es2017 example, though `asyncify` is not needed if your JS environment\n * // supports async functions out of the box\n * var q = async.queue(async.asyncify(async function(file) {\n * var intermediateStep = await processFile(file);\n * return await somePromise(intermediateStep)\n * }));\n *\n * q.push(files);\n */\nfunction asyncify(func) {\n return initialParams(function (args, callback) {\n var result;\n try {\n result = func.apply(this, args);\n } catch (e) {\n return callback(e);\n }\n // if result is Promise object\n if (isObject(result) && typeof result.then === 'function') {\n result.then(function(value) {\n invokeCallback(callback, null, value);\n }, function(err) {\n invokeCallback(callback, err.message ? err : new Error(err));\n });\n } else {\n callback(null, result);\n }\n });\n}\n\nfunction invokeCallback(callback, error, value) {\n try {\n callback(error, value);\n } catch (e) {\n setImmediate$2(rethrow, e);\n }\n}\n\nfunction rethrow(error) {\n throw error;\n}\n\nvar supportsSymbol = typeof Symbol === 'function';\n\nfunction isAsync(fn) {\n return supportsSymbol && fn[Symbol.toStringTag] === 'AsyncFunction';\n}\n\nfunction wrapAsync(asyncFn) {\n return isAsync(asyncFn) ? asyncify(asyncFn) : asyncFn;\n}\n\n/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = freeGlobal || freeSelf || Function('return this')();\n\n/** Built-in value references. */\nvar Symbol$1 = root.Symbol;\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/** Built-in value references. */\nvar symToStringTag = Symbol$1 ? Symbol$1.toStringTag : undefined;\n\n/**\n * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the raw `toStringTag`.\n */\nfunction getRawTag(value) {\n var isOwn = hasOwnProperty.call(value, symToStringTag),\n tag = value[symToStringTag];\n\n try {\n value[symToStringTag] = undefined;\n } catch (e) {}\n\n var result = nativeObjectToString.call(value);\n {\n if (isOwn) {\n value[symToStringTag] = tag;\n } else {\n delete value[symToStringTag];\n }\n }\n return result;\n}\n\n/** Used for built-in method references. */\nvar objectProto$1 = Object.prototype;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString$1 = objectProto$1.toString;\n\n/**\n * Converts `value` to a string using `Object.prototype.toString`.\n *\n * @private\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n */\nfunction objectToString(value) {\n return nativeObjectToString$1.call(value);\n}\n\n/** `Object#toString` result references. */\nvar nullTag = '[object Null]',\n undefinedTag = '[object Undefined]';\n\n/** Built-in value references. */\nvar symToStringTag$1 = Symbol$1 ? Symbol$1.toStringTag : undefined;\n\n/**\n * The base implementation of `getTag` without fallbacks for buggy environments.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nfunction baseGetTag(value) {\n if (value == null) {\n return value === undefined ? undefinedTag : nullTag;\n }\n return (symToStringTag$1 && symToStringTag$1 in Object(value))\n ? getRawTag(value)\n : objectToString(value);\n}\n\n/** `Object#toString` result references. */\nvar asyncTag = '[object AsyncFunction]',\n funcTag = '[object Function]',\n genTag = '[object GeneratorFunction]',\n proxyTag = '[object Proxy]';\n\n/**\n * Checks if `value` is classified as a `Function` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a function, else `false`.\n * @example\n *\n * _.isFunction(_);\n * // => true\n *\n * _.isFunction(/abc/);\n * // => false\n */\nfunction isFunction(value) {\n if (!isObject(value)) {\n return false;\n }\n // The use of `Object#toString` avoids issues with the `typeof` operator\n // in Safari 9 which returns 'object' for typed arrays and other constructors.\n var tag = baseGetTag(value);\n return tag == funcTag || tag == genTag || tag == asyncTag || tag == proxyTag;\n}\n\n/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/**\n * Checks if `value` is a valid array-like length.\n *\n * **Note:** This method is loosely based on\n * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.\n * @example\n *\n * _.isLength(3);\n * // => true\n *\n * _.isLength(Number.MIN_VALUE);\n * // => false\n *\n * _.isLength(Infinity);\n * // => false\n *\n * _.isLength('3');\n * // => false\n */\nfunction isLength(value) {\n return typeof value == 'number' &&\n value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;\n}\n\n/**\n * Checks if `value` is array-like. A value is considered array-like if it's\n * not a function and has a `value.length` that's an integer greater than or\n * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is array-like, else `false`.\n * @example\n *\n * _.isArrayLike([1, 2, 3]);\n * // => true\n *\n * _.isArrayLike(document.body.children);\n * // => true\n *\n * _.isArrayLike('abc');\n * // => true\n *\n * _.isArrayLike(_.noop);\n * // => false\n */\nfunction isArrayLike(value) {\n return value != null && isLength(value.length) && !isFunction(value);\n}\n\n// A temporary value used to identify if the loop should be broken.\n// See #1064, #1293\nvar breakLoop = {};\n\n/**\n * This method returns `undefined`.\n *\n * @static\n * @memberOf _\n * @since 2.3.0\n * @category Util\n * @example\n *\n * _.times(2, _.noop);\n * // => [undefined, undefined]\n */\nfunction noop() {\n // No operation performed.\n}\n\nfunction once(fn) {\n return function () {\n if (fn === null) { return; }\n var callFn = fn;\n fn = null;\n callFn.apply(this, arguments);\n };\n}\n\nvar iteratorSymbol = typeof Symbol === 'function' && Symbol.iterator;\n\nfunction getIterator (coll) {\n return iteratorSymbol && coll[iteratorSymbol] && coll[iteratorSymbol]();\n}\n\n/**\n * The base implementation of `_.times` without support for iteratee shorthands\n * or max array length checks.\n *\n * @private\n * @param {number} n The number of times to invoke `iteratee`.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the array of results.\n */\nfunction baseTimes(n, iteratee) {\n var index = -1,\n result = Array(n);\n\n while (++index < n) {\n result[index] = iteratee(index);\n }\n return result;\n}\n\n/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n return value != null && typeof value == 'object';\n}\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]';\n\n/**\n * The base implementation of `_.isArguments`.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n */\nfunction baseIsArguments(value) {\n return isObjectLike(value) && baseGetTag(value) == argsTag;\n}\n\n/** Used for built-in method references. */\nvar objectProto$2 = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty$1 = objectProto$2.hasOwnProperty;\n\n/** Built-in value references. */\nvar propertyIsEnumerable = objectProto$2.propertyIsEnumerable;\n\n/**\n * Checks if `value` is likely an `arguments` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n * else `false`.\n * @example\n *\n * _.isArguments(function() { return arguments; }());\n * // => true\n *\n * _.isArguments([1, 2, 3]);\n * // => false\n */\nvar isArguments = baseIsArguments(function() { return arguments; }()) ? baseIsArguments : function(value) {\n return isObjectLike(value) && hasOwnProperty$1.call(value, 'callee') &&\n !propertyIsEnumerable.call(value, 'callee');\n};\n\n/**\n * Checks if `value` is classified as an `Array` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array, else `false`.\n * @example\n *\n * _.isArray([1, 2, 3]);\n * // => true\n *\n * _.isArray(document.body.children);\n * // => false\n *\n * _.isArray('abc');\n * // => false\n *\n * _.isArray(_.noop);\n * // => false\n */\nvar isArray = Array.isArray;\n\n/**\n * This method returns `false`.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {boolean} Returns `false`.\n * @example\n *\n * _.times(2, _.stubFalse);\n * // => [false, false]\n */\nfunction stubFalse() {\n return false;\n}\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Built-in value references. */\nvar Buffer$1 = moduleExports ? root.Buffer : undefined;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeIsBuffer = Buffer$1 ? Buffer$1.isBuffer : undefined;\n\n/**\n * Checks if `value` is a buffer.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a buffer, else `false`.\n * @example\n *\n * _.isBuffer(new Buffer(2));\n * // => true\n *\n * _.isBuffer(new Uint8Array(2));\n * // => false\n */\nvar isBuffer = nativeIsBuffer || stubFalse;\n\n/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER$1 = 9007199254740991;\n\n/** Used to detect unsigned integer values. */\nvar reIsUint = /^(?:0|[1-9]\\d*)$/;\n\n/**\n * Checks if `value` is a valid array-like index.\n *\n * @private\n * @param {*} value The value to check.\n * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.\n * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.\n */\nfunction isIndex(value, length) {\n var type = typeof value;\n length = length == null ? MAX_SAFE_INTEGER$1 : length;\n\n return !!length &&\n (type == 'number' ||\n (type != 'symbol' && reIsUint.test(value))) &&\n (value > -1 && value % 1 == 0 && value < length);\n}\n\n/** `Object#toString` result references. */\nvar argsTag$1 = '[object Arguments]',\n arrayTag = '[object Array]',\n boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n errorTag = '[object Error]',\n funcTag$1 = '[object Function]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n objectTag = '[object Object]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n weakMapTag = '[object WeakMap]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]',\n float32Tag = '[object Float32Array]',\n float64Tag = '[object Float64Array]',\n int8Tag = '[object Int8Array]',\n int16Tag = '[object Int16Array]',\n int32Tag = '[object Int32Array]',\n uint8Tag = '[object Uint8Array]',\n uint8ClampedTag = '[object Uint8ClampedArray]',\n uint16Tag = '[object Uint16Array]',\n uint32Tag = '[object Uint32Array]';\n\n/** Used to identify `toStringTag` values of typed arrays. */\nvar typedArrayTags = {};\ntypedArrayTags[float32Tag] = typedArrayTags[float64Tag] =\ntypedArrayTags[int8Tag] = typedArrayTags[int16Tag] =\ntypedArrayTags[int32Tag] = typedArrayTags[uint8Tag] =\ntypedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] =\ntypedArrayTags[uint32Tag] = true;\ntypedArrayTags[argsTag$1] = typedArrayTags[arrayTag] =\ntypedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] =\ntypedArrayTags[dataViewTag] = typedArrayTags[dateTag] =\ntypedArrayTags[errorTag] = typedArrayTags[funcTag$1] =\ntypedArrayTags[mapTag] = typedArrayTags[numberTag] =\ntypedArrayTags[objectTag] = typedArrayTags[regexpTag] =\ntypedArrayTags[setTag] = typedArrayTags[stringTag] =\ntypedArrayTags[weakMapTag] = false;\n\n/**\n * The base implementation of `_.isTypedArray` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n */\nfunction baseIsTypedArray(value) {\n return isObjectLike(value) &&\n isLength(value.length) && !!typedArrayTags[baseGetTag(value)];\n}\n\n/**\n * The base implementation of `_.unary` without support for storing metadata.\n *\n * @private\n * @param {Function} func The function to cap arguments for.\n * @returns {Function} Returns the new capped function.\n */\nfunction baseUnary(func) {\n return function(value) {\n return func(value);\n };\n}\n\n/** Detect free variable `exports`. */\nvar freeExports$1 = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule$1 = freeExports$1 && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports$1 = freeModule$1 && freeModule$1.exports === freeExports$1;\n\n/** Detect free variable `process` from Node.js. */\nvar freeProcess = moduleExports$1 && freeGlobal.process;\n\n/** Used to access faster Node.js helpers. */\nvar nodeUtil = (function() {\n try {\n // Use `util.types` for Node.js 10+.\n var types = freeModule$1 && freeModule$1.require && freeModule$1.require('util').types;\n\n if (types) {\n return types;\n }\n\n // Legacy `process.binding('util')` for Node.js < 10.\n return freeProcess && freeProcess.binding && freeProcess.binding('util');\n } catch (e) {}\n}());\n\n/* Node.js helper references. */\nvar nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray;\n\n/**\n * Checks if `value` is classified as a typed array.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n * @example\n *\n * _.isTypedArray(new Uint8Array);\n * // => true\n *\n * _.isTypedArray([]);\n * // => false\n */\nvar isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray;\n\n/** Used for built-in method references. */\nvar objectProto$3 = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty$2 = objectProto$3.hasOwnProperty;\n\n/**\n * Creates an array of the enumerable property names of the array-like `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @param {boolean} inherited Specify returning inherited property names.\n * @returns {Array} Returns the array of property names.\n */\nfunction arrayLikeKeys(value, inherited) {\n var isArr = isArray(value),\n isArg = !isArr && isArguments(value),\n isBuff = !isArr && !isArg && isBuffer(value),\n isType = !isArr && !isArg && !isBuff && isTypedArray(value),\n skipIndexes = isArr || isArg || isBuff || isType,\n result = skipIndexes ? baseTimes(value.length, String) : [],\n length = result.length;\n\n for (var key in value) {\n if ((inherited || hasOwnProperty$2.call(value, key)) &&\n !(skipIndexes && (\n // Safari 9 has enumerable `arguments.length` in strict mode.\n key == 'length' ||\n // Node.js 0.10 has enumerable non-index properties on buffers.\n (isBuff && (key == 'offset' || key == 'parent')) ||\n // PhantomJS 2 has enumerable non-index properties on typed arrays.\n (isType && (key == 'buffer' || key == 'byteLength' || key == 'byteOffset')) ||\n // Skip index properties.\n isIndex(key, length)\n ))) {\n result.push(key);\n }\n }\n return result;\n}\n\n/** Used for built-in method references. */\nvar objectProto$4 = Object.prototype;\n\n/**\n * Checks if `value` is likely a prototype object.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a prototype, else `false`.\n */\nfunction isPrototype(value) {\n var Ctor = value && value.constructor,\n proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto$4;\n\n return value === proto;\n}\n\n/**\n * Creates a unary function that invokes `func` with its argument transformed.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {Function} transform The argument transform.\n * @returns {Function} Returns the new function.\n */\nfunction overArg(func, transform) {\n return function(arg) {\n return func(transform(arg));\n };\n}\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeKeys = overArg(Object.keys, Object);\n\n/** Used for built-in method references. */\nvar objectProto$5 = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty$3 = objectProto$5.hasOwnProperty;\n\n/**\n * The base implementation of `_.keys` which doesn't treat sparse arrays as dense.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction baseKeys(object) {\n if (!isPrototype(object)) {\n return nativeKeys(object);\n }\n var result = [];\n for (var key in Object(object)) {\n if (hasOwnProperty$3.call(object, key) && key != 'constructor') {\n result.push(key);\n }\n }\n return result;\n}\n\n/**\n * Creates an array of the own enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects. See the\n * [ES spec](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\n * for more details.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keys(new Foo);\n * // => ['a', 'b'] (iteration order is not guaranteed)\n *\n * _.keys('hi');\n * // => ['0', '1']\n */\nfunction keys(object) {\n return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object);\n}\n\nfunction createArrayIterator(coll) {\n var i = -1;\n var len = coll.length;\n return function next() {\n return ++i < len ? {value: coll[i], key: i} : null;\n }\n}\n\nfunction createES2015Iterator(iterator) {\n var i = -1;\n return function next() {\n var item = iterator.next();\n if (item.done)\n { return null; }\n i++;\n return {value: item.value, key: i};\n }\n}\n\nfunction createObjectIterator(obj) {\n var okeys = keys(obj);\n var i = -1;\n var len = okeys.length;\n return function next() {\n var key = okeys[++i];\n return i < len ? {value: obj[key], key: key} : null;\n };\n}\n\nfunction iterator(coll) {\n if (isArrayLike(coll)) {\n return createArrayIterator(coll);\n }\n\n var iterator = getIterator(coll);\n return iterator ? createES2015Iterator(iterator) : createObjectIterator(coll);\n}\n\nfunction onlyOnce(fn) {\n return function() {\n if (fn === null) { throw new Error(\"Callback was already called.\"); }\n var callFn = fn;\n fn = null;\n callFn.apply(this, arguments);\n };\n}\n\nfunction _eachOfLimit(limit) {\n return function (obj, iteratee, callback) {\n callback = once(callback || noop);\n if (limit <= 0 || !obj) {\n return callback(null);\n }\n var nextElem = iterator(obj);\n var done = false;\n var running = 0;\n var looping = false;\n\n function iterateeCallback(err, value) {\n running -= 1;\n if (err) {\n done = true;\n callback(err);\n }\n else if (value === breakLoop || (done && running <= 0)) {\n done = true;\n return callback(null);\n }\n else if (!looping) {\n replenish();\n }\n }\n\n function replenish () {\n looping = true;\n while (running < limit && !done) {\n var elem = nextElem();\n if (elem === null) {\n done = true;\n if (running <= 0) {\n callback(null);\n }\n return;\n }\n running += 1;\n iteratee(elem.value, elem.key, onlyOnce(iterateeCallback));\n }\n looping = false;\n }\n\n replenish();\n };\n}\n\n/**\n * The same as [`eachOf`]{@link module:Collections.eachOf} but runs a maximum of `limit` async operations at a\n * time.\n *\n * @name eachOfLimit\n * @static\n * @memberOf module:Collections\n * @method\n * @see [async.eachOf]{@link module:Collections.eachOf}\n * @alias forEachOfLimit\n * @category Collection\n * @param {Array|Iterable|Object} coll - A collection to iterate over.\n * @param {number} limit - The maximum number of async operations at a time.\n * @param {AsyncFunction} iteratee - An async function to apply to each\n * item in `coll`. The `key` is the item's key, or index in the case of an\n * array.\n * Invoked with (item, key, callback).\n * @param {Function} [callback] - A callback which is called when all\n * `iteratee` functions have finished, or an error occurs. Invoked with (err).\n */\nfunction eachOfLimit(coll, limit, iteratee, callback) {\n _eachOfLimit(limit)(coll, wrapAsync(iteratee), callback);\n}\n\nfunction doLimit(fn, limit) {\n return function (iterable, iteratee, callback) {\n return fn(iterable, limit, iteratee, callback);\n };\n}\n\n// eachOf implementation optimized for array-likes\nfunction eachOfArrayLike(coll, iteratee, callback) {\n callback = once(callback || noop);\n var index = 0,\n completed = 0,\n length = coll.length;\n if (length === 0) {\n callback(null);\n }\n\n function iteratorCallback(err, value) {\n if (err) {\n callback(err);\n } else if ((++completed === length) || value === breakLoop) {\n callback(null);\n }\n }\n\n for (; index < length; index++) {\n iteratee(coll[index], index, onlyOnce(iteratorCallback));\n }\n}\n\n// a generic version of eachOf which can handle array, object, and iterator cases.\nvar eachOfGeneric = doLimit(eachOfLimit, Infinity);\n\n/**\n * Like [`each`]{@link module:Collections.each}, except that it passes the key (or index) as the second argument\n * to the iteratee.\n *\n * @name eachOf\n * @static\n * @memberOf module:Collections\n * @method\n * @alias forEachOf\n * @category Collection\n * @see [async.each]{@link module:Collections.each}\n * @param {Array|Iterable|Object} coll - A collection to iterate over.\n * @param {AsyncFunction} iteratee - A function to apply to each\n * item in `coll`.\n * The `key` is the item's key, or index in the case of an array.\n * Invoked with (item, key, callback).\n * @param {Function} [callback] - A callback which is called when all\n * `iteratee` functions have finished, or an error occurs. Invoked with (err).\n * @example\n *\n * var obj = {dev: \"/dev.json\", test: \"/test.json\", prod: \"/prod.json\"};\n * var configs = {};\n *\n * async.forEachOf(obj, function (value, key, callback) {\n * fs.readFile(__dirname + value, \"utf8\", function (err, data) {\n * if (err) return callback(err);\n * try {\n * configs[key] = JSON.parse(data);\n * } catch (e) {\n * return callback(e);\n * }\n * callback();\n * });\n * }, function (err) {\n * if (err) console.error(err.message);\n * // configs is now a map of JSON data\n * doSomethingWith(configs);\n * });\n */\nfunction eachOf(coll, iteratee, callback) {\n var eachOfImplementation = isArrayLike(coll) ? eachOfArrayLike : eachOfGeneric;\n eachOfImplementation(coll, wrapAsync(iteratee), callback);\n}\n\n/**\n * A specialized version of `_.forEach` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns `array`.\n */\n\n/**\n * Creates a base function for methods like `_.forIn` and `_.forOwn`.\n *\n * @private\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new base function.\n */\n\n/**\n * The base implementation of `_.findIndex` and `_.findLastIndex` without\n * support for iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {Function} predicate The function invoked per iteration.\n * @param {number} fromIndex The index to search from.\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\n\n/**\n * The base implementation of `_.isNaN` without support for number objects.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is `NaN`, else `false`.\n */\n\n/**\n * A specialized version of `_.indexOf` which performs strict equality\n * comparisons of values, i.e. `===`.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @param {number} fromIndex The index to search from.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\n\n/**\n * A specialized version of `_.map` for arrays without support for iteratee\n * shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the new mapped array.\n */\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol$1 ? Symbol$1.prototype : undefined,\n symbolToString = symbolProto ? symbolProto.toString : undefined;\n\n/**\n * The base implementation of `_.slice` without an iteratee call guard.\n *\n * @private\n * @param {Array} array The array to slice.\n * @param {number} [start=0] The start position.\n * @param {number} [end=array.length] The end position.\n * @returns {Array} Returns the slice of `array`.\n */\n\n/**\n * Converts an ASCII `string` to an array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the converted array.\n */\n\n/** Used to compose unicode character classes. */\n\n/** Used to compose unicode character classes. */\n\n// Simple doubly linked list (https://en.wikipedia.org/wiki/Doubly_linked_list) implementation\n\n/**\n * This method returns the first argument it receives.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Util\n * @param {*} value Any value.\n * @returns {*} Returns `value`.\n * @example\n *\n * var object = { 'a': 1 };\n *\n * console.log(_.identity(object) === object);\n * // => true\n */\n\nfunction _withoutIndex(iteratee) {\n return function (value, index, callback) {\n return iteratee(value, callback);\n };\n}\n\n/**\n * Applies the function `iteratee` to each item in `coll`, in parallel.\n * The `iteratee` is called with an item from the list, and a callback for when\n * it has finished. If the `iteratee` passes an error to its `callback`, the\n * main `callback` (for the `each` function) is immediately called with the\n * error.\n *\n * Note, that since this function applies `iteratee` to each item in parallel,\n * there is no guarantee that the iteratee functions will complete in order.\n *\n * @name each\n * @static\n * @memberOf module:Collections\n * @method\n * @alias forEach\n * @category Collection\n * @param {Array|Iterable|Object} coll - A collection to iterate over.\n * @param {AsyncFunction} iteratee - An async function to apply to\n * each item in `coll`. Invoked with (item, callback).\n * The array index is not passed to the iteratee.\n * If you need the index, use `eachOf`.\n * @param {Function} [callback] - A callback which is called when all\n * `iteratee` functions have finished, or an error occurs. Invoked with (err).\n * @example\n *\n * // assuming openFiles is an array of file names and saveFile is a function\n * // to save the modified contents of that file:\n *\n * async.each(openFiles, saveFile, function(err){\n * // if any of the saves produced an error, err would equal that error\n * });\n *\n * // assuming openFiles is an array of file names\n * async.each(openFiles, function(file, callback) {\n *\n * // Perform operation on file here.\n * console.log('Processing file ' + file);\n *\n * if( file.length > 32 ) {\n * console.log('This file name is too long');\n * callback('File name too long');\n * } else {\n * // Do work to process file here\n * console.log('File processed');\n * callback();\n * }\n * }, function(err) {\n * // if any of the file processing produced an error, err would equal that error\n * if( err ) {\n * // One of the iterations produced an error.\n * // All processing will now stop.\n * console.log('A file failed to process');\n * } else {\n * console.log('All files have been processed successfully');\n * }\n * });\n */\nfunction eachLimit(coll, iteratee, callback) {\n eachOf(coll, _withoutIndex(wrapAsync(iteratee)), callback);\n}\n\n/**\n * The base implementation of `_.property` without support for deep paths.\n *\n * @private\n * @param {string} key The key of the property to get.\n * @returns {Function} Returns the new accessor function.\n */\n\n/**\n * Calls `callback` on a later loop around the event loop. In Node.js this just\n * calls `process.nextTick`. In the browser it will use `setImmediate` if\n * available, otherwise `setTimeout(callback, 0)`, which means other higher\n * priority events may precede the execution of `callback`.\n *\n * This is used internally for browser-compatibility purposes.\n *\n * @name nextTick\n * @static\n * @memberOf module:Utils\n * @method\n * @see [async.setImmediate]{@link module:Utils.setImmediate}\n * @category Util\n * @param {Function} callback - The function to call on a later loop around\n * the event loop. Invoked with (args...).\n * @param {...*} args... - any number of additional arguments to pass to the\n * callback on the next tick.\n * @example\n *\n * var call_order = [];\n * async.nextTick(function() {\n * call_order.push('two');\n * // call_order now equals ['one','two']\n * });\n * call_order.push('one');\n *\n * async.setImmediate(function (a, b, c) {\n * // a, b, and c equal 1, 2, and 3\n * }, 1, 2, 3);\n */\nvar _defer$1;\n\nif (hasNextTick) {\n _defer$1 = process.nextTick;\n} else if (hasSetImmediate) {\n _defer$1 = setImmediate;\n} else {\n _defer$1 = fallback;\n}\n\n/**\n * Creates a function that returns `value`.\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Util\n * @param {*} value The value to return from the new function.\n * @returns {Function} Returns the new constant function.\n * @example\n *\n * var objects = _.times(2, _.constant({ 'a': 1 }));\n *\n * console.log(objects);\n * // => [{ 'a': 1 }, { 'a': 1 }]\n *\n * console.log(objects[0] === objects[1]);\n * // => true\n */\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\n\n/**\n * Undoes a [memoize]{@link module:Utils.memoize}d function, reverting it to the original,\n * unmemoized form. Handy for testing.\n *\n * @name unmemoize\n * @static\n * @memberOf module:Utils\n * @method\n * @see [async.memoize]{@link module:Utils.memoize}\n * @category Util\n * @param {AsyncFunction} fn - the memoized function\n * @returns {AsyncFunction} a function that calls the original unmemoized function\n */\n\n/**\n * An \"async function\" in the context of Async is an asynchronous function with\n * a variable number of parameters, with the final parameter being a callback.\n * (`function (arg1, arg2, ..., callback) {}`)\n * The final callback is of the form `callback(err, results...)`, which must be\n * called once the function is completed. The callback should be called with a\n * Error as its first argument to signal that an error occurred.\n * Otherwise, if no error occurred, it should be called with `null` as the first\n * argument, and any additional `result` arguments that may apply, to signal\n * successful completion.\n * The callback must be called exactly once, ideally on a later tick of the\n * JavaScript event loop.\n *\n * This type of function is also referred to as a \"Node-style async function\",\n * or a \"continuation passing-style function\" (CPS). Most of the methods of this\n * library are themselves CPS/Node-style async functions, or functions that\n * return CPS/Node-style async functions.\n *\n * Wherever we accept a Node-style async function, we also directly accept an\n * [ES2017 `async` function]{@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/async_function}.\n * In this case, the `async` function will not be passed a final callback\n * argument, and any thrown error will be used as the `err` argument of the\n * implicit callback, and the return value will be used as the `result` value.\n * (i.e. a `rejected` of the returned Promise becomes the `err` callback\n * argument, and a `resolved` value becomes the `result`.)\n *\n * Note, due to JavaScript limitations, we can only detect native `async`\n * functions and not transpilied implementations.\n * Your environment must have `async`/`await` support for this to work.\n * (e.g. Node > v7.6, or a recent version of a modern browser).\n * If you are using `async` functions through a transpiler (e.g. Babel), you\n * must still wrap the function with [asyncify]{@link module:Utils.asyncify},\n * because the `async function` will be compiled to an ordinary function that\n * returns a promise.\n *\n * @typedef {Function} AsyncFunction\n * @static\n */\n\n/**\n * @hidden\n */\nfunction isDirectoryEntry(entry) {\n return entry.isDirectory;\n}\n/**\n * @hidden\n */\nvar _getFS = toExport.webkitRequestFileSystem || toExport.requestFileSystem || null;\n/**\n * @hidden\n */\nfunction _requestQuota(type, size, success, errorCallback) {\n // We cast navigator and window to '' because everything here is\n // nonstandard functionality, despite the fact that Chrome has the only\n // implementation of the HTML5FS and is likely driving the standardization\n // process. Thus, these objects defined off of navigator and window are not\n // present in the DefinitelyTyped TypeScript typings for FileSystem.\n if (typeof navigator['webkitPersistentStorage'] !== 'undefined') {\n switch (type) {\n case toExport.PERSISTENT:\n navigator.webkitPersistentStorage.requestQuota(size, success, errorCallback);\n break;\n case toExport.TEMPORARY:\n navigator.webkitTemporaryStorage.requestQuota(size, success, errorCallback);\n break;\n default:\n errorCallback(new TypeError((\"Invalid storage type: \" + type)));\n break;\n }\n }\n else {\n toExport.webkitStorageInfo.requestQuota(type, size, success, errorCallback);\n }\n}\n/**\n * @hidden\n */\nfunction _toArray(list) {\n return Array.prototype.slice.call(list || [], 0);\n}\n/**\n * Converts the given DOMError into an appropriate ApiError.\n * @url https://developer.mozilla.org/en-US/docs/Web/API/DOMError\n * @hidden\n */\nfunction convertError$1(err, p, expectedDir) {\n switch (err.name) {\n /* The user agent failed to create a file or directory due to the existence of a file or\n directory with the same path. */\n case \"PathExistsError\":\n return ApiError.EEXIST(p);\n /* The operation failed because it would cause the application to exceed its storage quota. */\n case 'QuotaExceededError':\n return ApiError.FileError(ErrorCode.ENOSPC, p);\n /* A required file or directory could not be found at the time an operation was processed. */\n case 'NotFoundError':\n return ApiError.ENOENT(p);\n /* This is a security error code to be used in situations not covered by any other error codes.\n - A required file was unsafe for access within a Web application\n - Too many calls are being made on filesystem resources */\n case 'SecurityError':\n return ApiError.FileError(ErrorCode.EACCES, p);\n /* The modification requested was illegal. Examples of invalid modifications include moving a\n directory into its own child, moving a file into its parent directory without changing its name,\n or copying a directory to a path occupied by a file. */\n case 'InvalidModificationError':\n return ApiError.FileError(ErrorCode.EPERM, p);\n /* The user has attempted to look up a file or directory, but the Entry found is of the wrong type\n [e.g. is a DirectoryEntry when the user requested a FileEntry]. */\n case 'TypeMismatchError':\n return ApiError.FileError(expectedDir ? ErrorCode.ENOTDIR : ErrorCode.EISDIR, p);\n /* A path or URL supplied to the API was malformed. */\n case \"EncodingError\":\n /* An operation depended on state cached in an interface object, but that state that has changed\n since it was read from disk. */\n case \"InvalidStateError\":\n /* The user attempted to write to a file or directory which could not be modified due to the state\n of the underlying filesystem. */\n case \"NoModificationAllowedError\":\n default:\n return ApiError.FileError(ErrorCode.EINVAL, p);\n }\n}\n// A note about getFile and getDirectory options:\n// These methods are called at numerous places in this file, and are passed\n// some combination of these two options:\n// - create: If true, the entry will be created if it doesn't exist.\n// If false, an error will be thrown if it doesn't exist.\n// - exclusive: If true, only create the entry if it doesn't already exist,\n// and throw an error if it does.\nvar HTML5FSFile = /*@__PURE__*/(function (PreloadFile$$1) {\n function HTML5FSFile(fs, entry, path$$1, flag, stat, contents) {\n PreloadFile$$1.call(this, fs, path$$1, flag, stat, contents);\n this._entry = entry;\n }\n\n if ( PreloadFile$$1 ) HTML5FSFile.__proto__ = PreloadFile$$1;\n HTML5FSFile.prototype = Object.create( PreloadFile$$1 && PreloadFile$$1.prototype );\n HTML5FSFile.prototype.constructor = HTML5FSFile;\n HTML5FSFile.prototype.sync = function sync (cb) {\n var this$1 = this;\n\n if (!this.isDirty()) {\n return cb();\n }\n this._entry.createWriter(function (writer) {\n var buffer$$1 = this$1.getBuffer();\n var blob = new Blob([buffer2ArrayBuffer(buffer$$1)]);\n var length = blob.size;\n writer.onwriteend = function (err) {\n writer.onwriteend = null;\n writer.onerror = null;\n writer.truncate(length);\n this$1.resetDirty();\n cb();\n };\n writer.onerror = function (err) {\n cb(convertError$1(err, this$1.getPath(), false));\n };\n writer.write(blob);\n });\n };\n HTML5FSFile.prototype.close = function close (cb) {\n this.sync(cb);\n };\n\n return HTML5FSFile;\n}(PreloadFile));\n/**\n * A read-write filesystem backed by the HTML5 FileSystem API.\n *\n * As the HTML5 FileSystem is only implemented in Blink, this interface is\n * only available in Chrome.\n */\nvar HTML5FS = /*@__PURE__*/(function (BaseFileSystem$$1) {\n function HTML5FS(size, type) {\n if ( size === void 0 ) size = 5;\n if ( type === void 0 ) type = toExport.PERSISTENT;\n\n BaseFileSystem$$1.call(this);\n // Convert MB to bytes.\n this.size = 1024 * 1024 * size;\n this.type = type;\n }\n\n if ( BaseFileSystem$$1 ) HTML5FS.__proto__ = BaseFileSystem$$1;\n HTML5FS.prototype = Object.create( BaseFileSystem$$1 && BaseFileSystem$$1.prototype );\n HTML5FS.prototype.constructor = HTML5FS;\n /**\n * Creates an HTML5FS instance with the given options.\n */\n HTML5FS.Create = function Create (opts, cb) {\n var fs = new HTML5FS(opts.size, opts.type);\n fs._allocate(function (e) { return e ? cb(e) : cb(null, fs); });\n };\n HTML5FS.isAvailable = function isAvailable () {\n return !!_getFS;\n };\n HTML5FS.prototype.getName = function getName () {\n return HTML5FS.Name;\n };\n HTML5FS.prototype.isReadOnly = function isReadOnly () {\n return false;\n };\n HTML5FS.prototype.supportsSymlinks = function supportsSymlinks () {\n return false;\n };\n HTML5FS.prototype.supportsProps = function supportsProps () {\n return false;\n };\n HTML5FS.prototype.supportsSynch = function supportsSynch () {\n return false;\n };\n /**\n * Deletes everything in the FS. Used for testing.\n * Karma clears the storage after you quit it but not between runs of the test\n * suite, and the tests expect an empty FS every time.\n */\n HTML5FS.prototype.empty = function empty (mainCb) {\n // Get a list of all entries in the root directory to delete them\n this._readdir('/', function (err, entries) {\n if (err) {\n mainCb(err);\n }\n else {\n // Called when every entry has been operated on\n var finished = function (er) {\n if (err) {\n mainCb(err);\n }\n else {\n mainCb();\n }\n };\n // Removes files and recursively removes directories\n var deleteEntry = function (entry, cb) {\n var succ = function () {\n cb();\n };\n var error = function (err) {\n cb(convertError$1(err, entry.fullPath, !entry.isDirectory));\n };\n if (isDirectoryEntry(entry)) {\n entry.removeRecursively(succ, error);\n }\n else {\n entry.remove(succ, error);\n }\n };\n // Loop through the entries and remove them, then call the callback\n // when they're all finished.\n eachLimit(entries, deleteEntry, finished);\n }\n });\n };\n HTML5FS.prototype.rename = function rename (oldPath, newPath, cb) {\n var this$1 = this;\n\n var semaphore = 2;\n var successCount = 0;\n var root = this.fs.root;\n var currentPath = oldPath;\n var error = function (err) {\n if (--semaphore <= 0) {\n cb(convertError$1(err, currentPath, false));\n }\n };\n var success = function (file) {\n if (++successCount === 2) {\n return cb(new ApiError(ErrorCode.EINVAL, \"Something was identified as both a file and a directory. This should never happen.\"));\n }\n // SPECIAL CASE: If newPath === oldPath, and the path exists, then\n // this operation trivially succeeds.\n if (oldPath === newPath) {\n return cb();\n }\n // Get the new parent directory.\n currentPath = path.dirname(newPath);\n root.getDirectory(currentPath, {}, function (parentDir) {\n currentPath = path.basename(newPath);\n file.moveTo(parentDir, currentPath, function (entry) { cb(); }, function (err) {\n // SPECIAL CASE: If oldPath is a directory, and newPath is a\n // file, rename should delete the file and perform the move.\n if (file.isDirectory) {\n currentPath = newPath;\n // Unlink only works on files. Try to delete newPath.\n this$1.unlink(newPath, function (e) {\n if (e) {\n // newPath is probably a directory.\n error(err);\n }\n else {\n // Recur, now that newPath doesn't exist.\n this$1.rename(oldPath, newPath, cb);\n }\n });\n }\n else {\n error(err);\n }\n });\n }, error);\n };\n // We don't know if oldPath is a *file* or a *directory*, and there's no\n // way to stat items. So launch both requests, see which one succeeds.\n root.getFile(oldPath, {}, success, error);\n root.getDirectory(oldPath, {}, success, error);\n };\n HTML5FS.prototype.stat = function stat (path$$1, isLstat, cb) {\n var this$1 = this;\n\n // Throw an error if the entry doesn't exist, because then there's nothing\n // to stat.\n var opts = {\n create: false\n };\n // Called when the path has been successfully loaded as a file.\n var loadAsFile = function (entry) {\n var fileFromEntry = function (file) {\n var stat = new Stats(FileType.FILE, file.size);\n cb(null, stat);\n };\n entry.file(fileFromEntry, failedToLoad);\n };\n // Called when the path has been successfully loaded as a directory.\n var loadAsDir = function (dir$$1) {\n // Directory entry size can't be determined from the HTML5 FS API, and is\n // implementation-dependant anyway, so a dummy value is used.\n var size = 4096;\n var stat = new Stats(FileType.DIRECTORY, size);\n cb(null, stat);\n };\n // Called when the path couldn't be opened as a directory or a file.\n var failedToLoad = function (err) {\n cb(convertError$1(err, path$$1, false /* Unknown / irrelevant */));\n };\n // Called when the path couldn't be opened as a file, but might still be a\n // directory.\n var failedToLoadAsFile = function () {\n this$1.fs.root.getDirectory(path$$1, opts, loadAsDir, failedToLoad);\n };\n // No method currently exists to determine whether a path refers to a\n // directory or a file, so this implementation tries both and uses the first\n // one that succeeds.\n this.fs.root.getFile(path$$1, opts, loadAsFile, failedToLoadAsFile);\n };\n HTML5FS.prototype.open = function open (p, flags, mode, cb) {\n var this$1 = this;\n\n // XXX: err is a DOMError\n var error = function (err) {\n if (err.name === 'InvalidModificationError' && flags.isExclusive()) {\n cb(ApiError.EEXIST(p));\n }\n else {\n cb(convertError$1(err, p, false));\n }\n };\n this.fs.root.getFile(p, {\n create: flags.pathNotExistsAction() === ActionType.CREATE_FILE,\n exclusive: flags.isExclusive()\n }, function (entry) {\n // Try to fetch corresponding file.\n entry.file(function (file) {\n var reader = new FileReader();\n reader.onloadend = function (event) {\n var bfsFile = this$1._makeFile(p, entry, flags, file, reader.result);\n cb(null, bfsFile);\n };\n reader.onerror = function (ev) {\n error(reader.error);\n };\n reader.readAsArrayBuffer(file);\n }, error);\n }, error);\n };\n HTML5FS.prototype.unlink = function unlink (path$$1, cb) {\n this._remove(path$$1, cb, true);\n };\n HTML5FS.prototype.rmdir = function rmdir (path$$1, cb) {\n var this$1 = this;\n\n // Check if directory is non-empty, first.\n this.readdir(path$$1, function (e, files) {\n if (e) {\n cb(e);\n }\n else if (files.length > 0) {\n cb(ApiError.ENOTEMPTY(path$$1));\n }\n else {\n this$1._remove(path$$1, cb, false);\n }\n });\n };\n HTML5FS.prototype.mkdir = function mkdir (path$$1, mode, cb) {\n // Create the directory, but throw an error if it already exists, as per\n // mkdir(1)\n var opts = {\n create: true,\n exclusive: true\n };\n var success = function (dir$$1) {\n cb();\n };\n var error = function (err) {\n cb(convertError$1(err, path$$1, true));\n };\n this.fs.root.getDirectory(path$$1, opts, success, error);\n };\n /**\n * Map _readdir's list of `FileEntry`s to their names and return that.\n */\n HTML5FS.prototype.readdir = function readdir (path$$1, cb) {\n this._readdir(path$$1, function (e, entries) {\n if (entries) {\n var rv = [];\n for (var i = 0, list = entries; i < list.length; i += 1) {\n var entry = list[i];\n\n rv.push(entry.name);\n }\n cb(null, rv);\n }\n else {\n return cb(e);\n }\n });\n };\n /**\n * Returns a BrowserFS object representing a File.\n */\n HTML5FS.prototype._makeFile = function _makeFile (path$$1, entry, flag, stat, data) {\n if ( data === void 0 ) data = new ArrayBuffer(0);\n\n var stats = new Stats(FileType.FILE, stat.size);\n var buffer$$1 = arrayBuffer2Buffer(data);\n return new HTML5FSFile(this, entry, path$$1, flag, stats, buffer$$1);\n };\n /**\n * Returns an array of `FileEntry`s. Used internally by empty and readdir.\n */\n HTML5FS.prototype._readdir = function _readdir (path$$1, cb) {\n var error = function (err) {\n cb(convertError$1(err, path$$1, true));\n };\n // Grab the requested directory.\n this.fs.root.getDirectory(path$$1, { create: false }, function (dirEntry) {\n var reader = dirEntry.createReader();\n var entries = [];\n // Call the reader.readEntries() until no more results are returned.\n var readEntries = function () {\n reader.readEntries((function (results) {\n if (results.length) {\n entries = entries.concat(_toArray(results));\n readEntries();\n }\n else {\n cb(null, entries);\n }\n }), error);\n };\n readEntries();\n }, error);\n };\n /**\n * Requests a storage quota from the browser to back this FS.\n */\n HTML5FS.prototype._allocate = function _allocate (cb) {\n var this$1 = this;\n\n var success = function (fs) {\n this$1.fs = fs;\n cb();\n };\n var error = function (err) {\n cb(convertError$1(err, \"/\", true));\n };\n if (this.type === toExport.PERSISTENT) {\n _requestQuota(this.type, this.size, function (granted) {\n _getFS(this$1.type, granted, success, error);\n }, error);\n }\n else {\n _getFS(this.type, this.size, success, error);\n }\n };\n /**\n * Delete a file or directory from the file system\n * isFile should reflect which call was made to remove the it (`unlink` or\n * `rmdir`). If this doesn't match what's actually at `path`, an error will be\n * returned\n */\n HTML5FS.prototype._remove = function _remove (path$$1, cb, isFile) {\n var success = function (entry) {\n var succ = function () {\n cb();\n };\n var err = function (err) {\n cb(convertError$1(err, path$$1, !isFile));\n };\n entry.remove(succ, err);\n };\n var error = function (err) {\n cb(convertError$1(err, path$$1, !isFile));\n };\n // Deleting the entry, so don't create it\n var opts = {\n create: false\n };\n if (isFile) {\n this.fs.root.getFile(path$$1, opts, success, error);\n }\n else {\n this.fs.root.getDirectory(path$$1, opts, success, error);\n }\n };\n\n return HTML5FS;\n}(BaseFileSystem));\nHTML5FS.Name = \"HTML5FS\";\nHTML5FS.Options = {\n size: {\n type: \"number\",\n optional: true,\n description: \"Storage quota to request, in megabytes. Allocated value may be less. Defaults to 5.\"\n },\n type: {\n type: \"number\",\n optional: true,\n description: \"window.PERSISTENT or window.TEMPORARY. Defaults to PERSISTENT.\"\n }\n};\n\n/**\n * Generic inode definition that can easily be serialized.\n */\nvar Inode = function Inode(id, size, mode, atime, mtime, ctime) {\n this.id = id;\n this.size = size;\n this.mode = mode;\n this.atime = atime;\n this.mtime = mtime;\n this.ctime = ctime;\n};\n/**\n * Converts the buffer into an Inode.\n */\nInode.fromBuffer = function fromBuffer (buffer$$1) {\n if (buffer$$1 === undefined) {\n throw new Error(\"NO\");\n }\n return new Inode(buffer$$1.toString('ascii', 30), buffer$$1.readUInt32LE(0), buffer$$1.readUInt16LE(4), buffer$$1.readDoubleLE(6), buffer$$1.readDoubleLE(14), buffer$$1.readDoubleLE(22));\n};\n/**\n * Handy function that converts the Inode to a Node Stats object.\n */\nInode.prototype.toStats = function toStats () {\n return new Stats((this.mode & 0xF000) === FileType.DIRECTORY ? FileType.DIRECTORY : FileType.FILE, this.size, this.mode, this.atime, this.mtime, this.ctime);\n};\n/**\n * Get the size of this Inode, in bytes.\n */\nInode.prototype.getSize = function getSize () {\n // ASSUMPTION: ID is ASCII (1 byte per char).\n return 30 + this.id.length;\n};\n/**\n * Writes the inode into the start of the buffer.\n */\nInode.prototype.toBuffer = function toBuffer (buff) {\n if ( buff === void 0 ) buff = Buffer.alloc(this.getSize());\n\n buff.writeUInt32LE(this.size, 0);\n buff.writeUInt16LE(this.mode, 4);\n buff.writeDoubleLE(this.atime, 6);\n buff.writeDoubleLE(this.mtime, 14);\n buff.writeDoubleLE(this.ctime, 22);\n buff.write(this.id, 30, this.id.length, 'ascii');\n return buff;\n};\n/**\n * Updates the Inode using information from the stats object. Used by file\n * systems at sync time, e.g.:\n * - Program opens file and gets a File object.\n * - Program mutates file. File object is responsible for maintaining\n * metadata changes locally -- typically in a Stats object.\n * - Program closes file. File object's metadata changes are synced with the\n * file system.\n * @return True if any changes have occurred.\n */\nInode.prototype.update = function update (stats) {\n var hasChanged = false;\n if (this.size !== stats.size) {\n this.size = stats.size;\n hasChanged = true;\n }\n if (this.mode !== stats.mode) {\n this.mode = stats.mode;\n hasChanged = true;\n }\n var atimeMs = stats.atime.getTime();\n if (this.atime !== atimeMs) {\n this.atime = atimeMs;\n hasChanged = true;\n }\n var mtimeMs = stats.mtime.getTime();\n if (this.mtime !== mtimeMs) {\n this.mtime = mtimeMs;\n hasChanged = true;\n }\n var ctimeMs = stats.ctime.getTime();\n if (this.ctime !== ctimeMs) {\n this.ctime = ctimeMs;\n hasChanged = true;\n }\n return hasChanged;\n};\n// XXX: Copied from Stats. Should reconcile these two into something more\n// compact.\n/**\n * @return [Boolean] True if this item is a file.\n */\nInode.prototype.isFile = function isFile () {\n return (this.mode & 0xF000) === FileType.FILE;\n};\n/**\n * @return [Boolean] True if this item is a directory.\n */\nInode.prototype.isDirectory = function isDirectory () {\n return (this.mode & 0xF000) === FileType.DIRECTORY;\n};\n\n/**\n * @hidden\n */\nvar ROOT_NODE_ID = \"/\";\n/**\n * @hidden\n */\nvar emptyDirNode = null;\n/**\n * Returns an empty directory node.\n * @hidden\n */\nfunction getEmptyDirNode() {\n if (emptyDirNode) {\n return emptyDirNode;\n }\n return emptyDirNode = Buffer.from(\"{}\");\n}\n/**\n * Generates a random ID.\n * @hidden\n */\nfunction GenerateRandomID() {\n // From http://stackoverflow.com/questions/105034/how-to-create-a-guid-uuid-in-javascript\n return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function (c) {\n var r = Math.random() * 16 | 0;\n var v = c === 'x' ? r : (r & 0x3 | 0x8);\n return v.toString(16);\n });\n}\n/**\n * Helper function. Checks if 'e' is defined. If so, it triggers the callback\n * with 'e' and returns false. Otherwise, returns true.\n * @hidden\n */\nfunction noError(e, cb) {\n if (e) {\n cb(e);\n return false;\n }\n return true;\n}\n/**\n * Helper function. Checks if 'e' is defined. If so, it aborts the transaction,\n * triggers the callback with 'e', and returns false. Otherwise, returns true.\n * @hidden\n */\nfunction noErrorTx(e, tx, cb) {\n if (e) {\n tx.abort(function () {\n cb(e);\n });\n return false;\n }\n return true;\n}\nvar LRUNode = function LRUNode(key, value) {\n this.key = key;\n this.value = value;\n this.prev = null;\n this.next = null;\n};\n// Adapted from https://chrisrng.svbtle.com/lru-cache-in-javascript\nvar LRUCache = function LRUCache(limit) {\n this.limit = limit;\n this.size = 0;\n this.map = {};\n this.head = null;\n this.tail = null;\n};\n/**\n * Change or add a new value in the cache\n * We overwrite the entry if it already exists\n */\nLRUCache.prototype.set = function set (key, value) {\n var node = new LRUNode(key, value);\n if (this.map[key]) {\n this.map[key].value = node.value;\n this.remove(node.key);\n }\n else {\n if (this.size >= this.limit) {\n delete this.map[this.tail.key];\n this.size--;\n this.tail = this.tail.prev;\n this.tail.next = null;\n }\n }\n this.setHead(node);\n};\n/* Retrieve a single entry from the cache */\nLRUCache.prototype.get = function get (key) {\n if (this.map[key]) {\n var value = this.map[key].value;\n var node = new LRUNode(key, value);\n this.remove(key);\n this.setHead(node);\n return value;\n }\n else {\n return null;\n }\n};\n/* Remove a single entry from the cache */\nLRUCache.prototype.remove = function remove (key) {\n var node = this.map[key];\n if (!node) {\n return;\n }\n if (node.prev !== null) {\n node.prev.next = node.next;\n }\n else {\n this.head = node.next;\n }\n if (node.next !== null) {\n node.next.prev = node.prev;\n }\n else {\n this.tail = node.prev;\n }\n delete this.map[key];\n this.size--;\n};\n/* Resets the entire cache - Argument limit is optional to be reset */\nLRUCache.prototype.removeAll = function removeAll () {\n this.size = 0;\n this.map = {};\n this.head = null;\n this.tail = null;\n};\nLRUCache.prototype.setHead = function setHead (node) {\n node.next = this.head;\n node.prev = null;\n if (this.head !== null) {\n this.head.prev = node;\n }\n this.head = node;\n if (this.tail === null) {\n this.tail = node;\n }\n this.size++;\n this.map[node.key] = node;\n};\n/**\n * A simple RW transaction for simple synchronous key-value stores.\n */\nvar SimpleSyncRWTransaction = function SimpleSyncRWTransaction(store) {\n this.store = store;\n /**\n * Stores data in the keys we modify prior to modifying them.\n * Allows us to roll back commits.\n */\n this.originalData = {};\n /**\n * List of keys modified in this transaction, if any.\n */\n this.modifiedKeys = [];\n};\nSimpleSyncRWTransaction.prototype.get = function get (key) {\n var val = this.store.get(key);\n this.stashOldValue(key, val);\n return val;\n};\nSimpleSyncRWTransaction.prototype.put = function put (key, data, overwrite) {\n this.markModified(key);\n return this.store.put(key, data, overwrite);\n};\nSimpleSyncRWTransaction.prototype.del = function del (key) {\n this.markModified(key);\n this.store.del(key);\n};\nSimpleSyncRWTransaction.prototype.commit = function commit () { };\nSimpleSyncRWTransaction.prototype.abort = function abort () {\n // Rollback old values.\n for (var i = 0, list = this.modifiedKeys; i < list.length; i += 1) {\n var key = list[i];\n\n var value = this.originalData[key];\n if (!value) {\n // Key didn't exist.\n this.store.del(key);\n }\n else {\n // Key existed. Store old value.\n this.store.put(key, value, true);\n }\n }\n};\n/**\n * Stashes given key value pair into `originalData` if it doesn't already\n * exist. Allows us to stash values the program is requesting anyway to\n * prevent needless `get` requests if the program modifies the data later\n * on during the transaction.\n */\nSimpleSyncRWTransaction.prototype.stashOldValue = function stashOldValue (key, value) {\n // Keep only the earliest value in the transaction.\n if (!this.originalData.hasOwnProperty(key)) {\n this.originalData[key] = value;\n }\n};\n/**\n * Marks the given key as modified, and stashes its value if it has not been\n * stashed already.\n */\nSimpleSyncRWTransaction.prototype.markModified = function markModified (key) {\n if (this.modifiedKeys.indexOf(key) === -1) {\n this.modifiedKeys.push(key);\n if (!this.originalData.hasOwnProperty(key)) {\n this.originalData[key] = this.store.get(key);\n }\n }\n};\nvar SyncKeyValueFile = /*@__PURE__*/(function (PreloadFile$$1) {\n function SyncKeyValueFile(_fs, _path, _flag, _stat, contents) {\n PreloadFile$$1.call(this, _fs, _path, _flag, _stat, contents);\n }\n\n if ( PreloadFile$$1 ) SyncKeyValueFile.__proto__ = PreloadFile$$1;\n SyncKeyValueFile.prototype = Object.create( PreloadFile$$1 && PreloadFile$$1.prototype );\n SyncKeyValueFile.prototype.constructor = SyncKeyValueFile;\n SyncKeyValueFile.prototype.syncSync = function syncSync () {\n if (this.isDirty()) {\n this._fs._syncSync(this.getPath(), this.getBuffer(), this.getStats());\n this.resetDirty();\n }\n };\n SyncKeyValueFile.prototype.closeSync = function closeSync () {\n this.syncSync();\n };\n\n return SyncKeyValueFile;\n}(PreloadFile));\n/**\n * A \"Synchronous key-value file system\". Stores data to/retrieves data from an\n * underlying key-value store.\n *\n * We use a unique ID for each node in the file system. The root node has a\n * fixed ID.\n * @todo Introduce Node ID caching.\n * @todo Check modes.\n */\nvar SyncKeyValueFileSystem = /*@__PURE__*/(function (SynchronousFileSystem$$1) {\n function SyncKeyValueFileSystem(options) {\n SynchronousFileSystem$$1.call(this);\n this.store = options.store;\n // INVARIANT: Ensure that the root exists.\n this.makeRootDirectory();\n }\n\n if ( SynchronousFileSystem$$1 ) SyncKeyValueFileSystem.__proto__ = SynchronousFileSystem$$1;\n SyncKeyValueFileSystem.prototype = Object.create( SynchronousFileSystem$$1 && SynchronousFileSystem$$1.prototype );\n SyncKeyValueFileSystem.prototype.constructor = SyncKeyValueFileSystem;\n SyncKeyValueFileSystem.isAvailable = function isAvailable () { return true; };\n\n SyncKeyValueFileSystem.prototype.getName = function getName () { return this.store.name(); };\n SyncKeyValueFileSystem.prototype.isReadOnly = function isReadOnly () { return false; };\n SyncKeyValueFileSystem.prototype.supportsSymlinks = function supportsSymlinks () { return false; };\n SyncKeyValueFileSystem.prototype.supportsProps = function supportsProps () { return false; };\n SyncKeyValueFileSystem.prototype.supportsSynch = function supportsSynch () { return true; };\n /**\n * Delete all contents stored in the file system.\n */\n SyncKeyValueFileSystem.prototype.empty = function empty () {\n this.store.clear();\n // INVARIANT: Root always exists.\n this.makeRootDirectory();\n };\n SyncKeyValueFileSystem.prototype.renameSync = function renameSync (oldPath, newPath) {\n var tx = this.store.beginTransaction('readwrite'), oldParent = path.dirname(oldPath), oldName = path.basename(oldPath), newParent = path.dirname(newPath), newName = path.basename(newPath), \n // Remove oldPath from parent's directory listing.\n oldDirNode = this.findINode(tx, oldParent), oldDirList = this.getDirListing(tx, oldParent, oldDirNode);\n if (!oldDirList[oldName]) {\n throw ApiError.ENOENT(oldPath);\n }\n var nodeId = oldDirList[oldName];\n delete oldDirList[oldName];\n // Invariant: Can't move a folder inside itself.\n // This funny little hack ensures that the check passes only if oldPath\n // is a subpath of newParent. We append '/' to avoid matching folders that\n // are a substring of the bottom-most folder in the path.\n if ((newParent + '/').indexOf(oldPath + '/') === 0) {\n throw new ApiError(ErrorCode.EBUSY, oldParent);\n }\n // Add newPath to parent's directory listing.\n var newDirNode, newDirList;\n if (newParent === oldParent) {\n // Prevent us from re-grabbing the same directory listing, which still\n // contains oldName.\n newDirNode = oldDirNode;\n newDirList = oldDirList;\n }\n else {\n newDirNode = this.findINode(tx, newParent);\n newDirList = this.getDirListing(tx, newParent, newDirNode);\n }\n if (newDirList[newName]) {\n // If it's a file, delete it.\n var newNameNode = this.getINode(tx, newPath, newDirList[newName]);\n if (newNameNode.isFile()) {\n try {\n tx.del(newNameNode.id);\n tx.del(newDirList[newName]);\n }\n catch (e) {\n tx.abort();\n throw e;\n }\n }\n else {\n // If it's a directory, throw a permissions error.\n throw ApiError.EPERM(newPath);\n }\n }\n newDirList[newName] = nodeId;\n // Commit the two changed directory listings.\n try {\n tx.put(oldDirNode.id, Buffer.from(JSON.stringify(oldDirList)), true);\n tx.put(newDirNode.id, Buffer.from(JSON.stringify(newDirList)), true);\n }\n catch (e) {\n tx.abort();\n throw e;\n }\n tx.commit();\n };\n SyncKeyValueFileSystem.prototype.statSync = function statSync (p, isLstat) {\n // Get the inode to the item, convert it into a Stats object.\n return this.findINode(this.store.beginTransaction('readonly'), p).toStats();\n };\n SyncKeyValueFileSystem.prototype.createFileSync = function createFileSync (p, flag, mode) {\n var tx = this.store.beginTransaction('readwrite'), data = emptyBuffer(), newFile = this.commitNewFile(tx, p, FileType.FILE, mode, data);\n // Open the file.\n return new SyncKeyValueFile(this, p, flag, newFile.toStats(), data);\n };\n SyncKeyValueFileSystem.prototype.openFileSync = function openFileSync (p, flag) {\n var tx = this.store.beginTransaction('readonly'), node = this.findINode(tx, p), data = tx.get(node.id);\n if (data === undefined) {\n throw ApiError.ENOENT(p);\n }\n return new SyncKeyValueFile(this, p, flag, node.toStats(), data);\n };\n SyncKeyValueFileSystem.prototype.unlinkSync = function unlinkSync (p) {\n this.removeEntry(p, false);\n };\n SyncKeyValueFileSystem.prototype.rmdirSync = function rmdirSync (p) {\n // Check first if directory is empty.\n if (this.readdirSync(p).length > 0) {\n throw ApiError.ENOTEMPTY(p);\n }\n else {\n this.removeEntry(p, true);\n }\n };\n SyncKeyValueFileSystem.prototype.mkdirSync = function mkdirSync (p, mode) {\n var tx = this.store.beginTransaction('readwrite'), data = Buffer.from('{}');\n this.commitNewFile(tx, p, FileType.DIRECTORY, mode, data);\n };\n SyncKeyValueFileSystem.prototype.readdirSync = function readdirSync (p) {\n var tx = this.store.beginTransaction('readonly');\n return Object.keys(this.getDirListing(tx, p, this.findINode(tx, p)));\n };\n SyncKeyValueFileSystem.prototype._syncSync = function _syncSync (p, data, stats) {\n // @todo Ensure mtime updates properly, and use that to determine if a data\n // update is required.\n var tx = this.store.beginTransaction('readwrite'), \n // We use the _findInode helper because we actually need the INode id.\n fileInodeId = this._findINode(tx, path.dirname(p), path.basename(p)), fileInode = this.getINode(tx, p, fileInodeId), inodeChanged = fileInode.update(stats);\n try {\n // Sync data.\n tx.put(fileInode.id, data, true);\n // Sync metadata.\n if (inodeChanged) {\n tx.put(fileInodeId, fileInode.toBuffer(), true);\n }\n }\n catch (e) {\n tx.abort();\n throw e;\n }\n tx.commit();\n };\n /**\n * Checks if the root directory exists. Creates it if it doesn't.\n */\n SyncKeyValueFileSystem.prototype.makeRootDirectory = function makeRootDirectory () {\n var tx = this.store.beginTransaction('readwrite');\n if (tx.get(ROOT_NODE_ID) === undefined) {\n // Create new inode.\n var currTime = (new Date()).getTime(), \n // Mode 0666\n dirInode = new Inode(GenerateRandomID(), 4096, 511 | FileType.DIRECTORY, currTime, currTime, currTime);\n // If the root doesn't exist, the first random ID shouldn't exist,\n // either.\n tx.put(dirInode.id, getEmptyDirNode(), false);\n tx.put(ROOT_NODE_ID, dirInode.toBuffer(), false);\n tx.commit();\n }\n };\n /**\n * Helper function for findINode.\n * @param parent The parent directory of the file we are attempting to find.\n * @param filename The filename of the inode we are attempting to find, minus\n * the parent.\n * @return string The ID of the file's inode in the file system.\n */\n SyncKeyValueFileSystem.prototype._findINode = function _findINode (tx, parent, filename) {\n var this$1 = this;\n\n var readDirectory = function (inode) {\n // Get the root's directory listing.\n var dirList = this$1.getDirListing(tx, parent, inode);\n // Get the file's ID.\n if (dirList[filename]) {\n return dirList[filename];\n }\n else {\n throw ApiError.ENOENT(path.resolve(parent, filename));\n }\n };\n if (parent === '/') {\n if (filename === '') {\n // BASE CASE #1: Return the root's ID.\n return ROOT_NODE_ID;\n }\n else {\n // BASE CASE #2: Find the item in the root ndoe.\n return readDirectory(this.getINode(tx, parent, ROOT_NODE_ID));\n }\n }\n else {\n return readDirectory(this.getINode(tx, parent + path.sep + filename, this._findINode(tx, path.dirname(parent), path.basename(parent))));\n }\n };\n /**\n * Finds the Inode of the given path.\n * @param p The path to look up.\n * @return The Inode of the path p.\n * @todo memoize/cache\n */\n SyncKeyValueFileSystem.prototype.findINode = function findINode (tx, p) {\n return this.getINode(tx, p, this._findINode(tx, path.dirname(p), path.basename(p)));\n };\n /**\n * Given the ID of a node, retrieves the corresponding Inode.\n * @param tx The transaction to use.\n * @param p The corresponding path to the file (used for error messages).\n * @param id The ID to look up.\n */\n SyncKeyValueFileSystem.prototype.getINode = function getINode (tx, p, id) {\n var inode = tx.get(id);\n if (inode === undefined) {\n throw ApiError.ENOENT(p);\n }\n return Inode.fromBuffer(inode);\n };\n /**\n * Given the Inode of a directory, retrieves the corresponding directory\n * listing.\n */\n SyncKeyValueFileSystem.prototype.getDirListing = function getDirListing (tx, p, inode) {\n if (!inode.isDirectory()) {\n throw ApiError.ENOTDIR(p);\n }\n var data = tx.get(inode.id);\n if (data === undefined) {\n throw ApiError.ENOENT(p);\n }\n return JSON.parse(data.toString());\n };\n /**\n * Creates a new node under a random ID. Retries 5 times before giving up in\n * the exceedingly unlikely chance that we try to reuse a random GUID.\n * @return The GUID that the data was stored under.\n */\n SyncKeyValueFileSystem.prototype.addNewNode = function addNewNode (tx, data) {\n var retries = 0;\n var currId;\n while (retries < 5) {\n try {\n currId = GenerateRandomID();\n tx.put(currId, data, false);\n return currId;\n }\n catch (e) {\n // Ignore and reroll.\n }\n }\n throw new ApiError(ErrorCode.EIO, 'Unable to commit data to key-value store.');\n };\n /**\n * Commits a new file (well, a FILE or a DIRECTORY) to the file system with\n * the given mode.\n * Note: This will commit the transaction.\n * @param p The path to the new file.\n * @param type The type of the new file.\n * @param mode The mode to create the new file with.\n * @param data The data to store at the file's data node.\n * @return The Inode for the new file.\n */\n SyncKeyValueFileSystem.prototype.commitNewFile = function commitNewFile (tx, p, type, mode, data) {\n var parentDir = path.dirname(p), fname = path.basename(p), parentNode = this.findINode(tx, parentDir), dirListing = this.getDirListing(tx, parentDir, parentNode), currTime = (new Date()).getTime();\n // Invariant: The root always exists.\n // If we don't check this prior to taking steps below, we will create a\n // file with name '' in root should p == '/'.\n if (p === '/') {\n throw ApiError.EEXIST(p);\n }\n // Check if file already exists.\n if (dirListing[fname]) {\n throw ApiError.EEXIST(p);\n }\n var fileNode;\n try {\n // Commit data.\n var dataId = this.addNewNode(tx, data);\n fileNode = new Inode(dataId, data.length, mode | type, currTime, currTime, currTime);\n // Commit file node.\n var fileNodeId = this.addNewNode(tx, fileNode.toBuffer());\n // Update and commit parent directory listing.\n dirListing[fname] = fileNodeId;\n tx.put(parentNode.id, Buffer.from(JSON.stringify(dirListing)), true);\n }\n catch (e) {\n tx.abort();\n throw e;\n }\n tx.commit();\n return fileNode;\n };\n /**\n * Remove all traces of the given path from the file system.\n * @param p The path to remove from the file system.\n * @param isDir Does the path belong to a directory, or a file?\n * @todo Update mtime.\n */\n SyncKeyValueFileSystem.prototype.removeEntry = function removeEntry (p, isDir) {\n var tx = this.store.beginTransaction('readwrite'), parent = path.dirname(p), parentNode = this.findINode(tx, parent), parentListing = this.getDirListing(tx, parent, parentNode), fileName = path.basename(p);\n if (!parentListing[fileName]) {\n throw ApiError.ENOENT(p);\n }\n // Remove from directory listing of parent.\n var fileNodeId = parentListing[fileName];\n delete parentListing[fileName];\n // Get file inode.\n var fileNode = this.getINode(tx, p, fileNodeId);\n if (!isDir && fileNode.isDirectory()) {\n throw ApiError.EISDIR(p);\n }\n else if (isDir && !fileNode.isDirectory()) {\n throw ApiError.ENOTDIR(p);\n }\n try {\n // Delete data.\n tx.del(fileNode.id);\n // Delete node.\n tx.del(fileNodeId);\n // Update directory listing.\n tx.put(parentNode.id, Buffer.from(JSON.stringify(parentListing)), true);\n }\n catch (e) {\n tx.abort();\n throw e;\n }\n // Success.\n tx.commit();\n };\n\n return SyncKeyValueFileSystem;\n}(SynchronousFileSystem));\nvar AsyncKeyValueFile = /*@__PURE__*/(function (PreloadFile$$1) {\n function AsyncKeyValueFile(_fs, _path, _flag, _stat, contents) {\n PreloadFile$$1.call(this, _fs, _path, _flag, _stat, contents);\n }\n\n if ( PreloadFile$$1 ) AsyncKeyValueFile.__proto__ = PreloadFile$$1;\n AsyncKeyValueFile.prototype = Object.create( PreloadFile$$1 && PreloadFile$$1.prototype );\n AsyncKeyValueFile.prototype.constructor = AsyncKeyValueFile;\n AsyncKeyValueFile.prototype.sync = function sync (cb) {\n var this$1 = this;\n\n if (this.isDirty()) {\n this._fs._sync(this.getPath(), this.getBuffer(), this.getStats(), function (e) {\n if (!e) {\n this$1.resetDirty();\n }\n cb(e);\n });\n }\n else {\n cb();\n }\n };\n AsyncKeyValueFile.prototype.close = function close (cb) {\n this.sync(cb);\n };\n\n return AsyncKeyValueFile;\n}(PreloadFile));\n/**\n * An \"Asynchronous key-value file system\". Stores data to/retrieves data from\n * an underlying asynchronous key-value store.\n */\nvar AsyncKeyValueFileSystem = /*@__PURE__*/(function (BaseFileSystem$$1) {\n function AsyncKeyValueFileSystem(cacheSize) {\n BaseFileSystem$$1.call(this);\n this._cache = null;\n if (cacheSize > 0) {\n this._cache = new LRUCache(cacheSize);\n }\n }\n\n if ( BaseFileSystem$$1 ) AsyncKeyValueFileSystem.__proto__ = BaseFileSystem$$1;\n AsyncKeyValueFileSystem.prototype = Object.create( BaseFileSystem$$1 && BaseFileSystem$$1.prototype );\n AsyncKeyValueFileSystem.prototype.constructor = AsyncKeyValueFileSystem;\n AsyncKeyValueFileSystem.isAvailable = function isAvailable () { return true; };\n /**\n * Initializes the file system. Typically called by subclasses' async\n * constructors.\n */\n AsyncKeyValueFileSystem.prototype.init = function init (store, cb) {\n this.store = store;\n // INVARIANT: Ensure that the root exists.\n this.makeRootDirectory(cb);\n };\n AsyncKeyValueFileSystem.prototype.getName = function getName () { return this.store.name(); };\n AsyncKeyValueFileSystem.prototype.isReadOnly = function isReadOnly () { return false; };\n AsyncKeyValueFileSystem.prototype.supportsSymlinks = function supportsSymlinks () { return false; };\n AsyncKeyValueFileSystem.prototype.supportsProps = function supportsProps () { return false; };\n AsyncKeyValueFileSystem.prototype.supportsSynch = function supportsSynch () { return false; };\n /**\n * Delete all contents stored in the file system.\n */\n AsyncKeyValueFileSystem.prototype.empty = function empty (cb) {\n var this$1 = this;\n\n if (this._cache) {\n this._cache.removeAll();\n }\n this.store.clear(function (e) {\n if (noError(e, cb)) {\n // INVARIANT: Root always exists.\n this$1.makeRootDirectory(cb);\n }\n });\n };\n AsyncKeyValueFileSystem.prototype.rename = function rename (oldPath, newPath, cb) {\n var this$1 = this;\n\n // TODO: Make rename compatible with the cache.\n if (this._cache) {\n // Clear and disable cache during renaming process.\n var c = this._cache;\n this._cache = null;\n c.removeAll();\n var oldCb = cb;\n cb = function (e) {\n // Restore empty cache.\n this$1._cache = c;\n oldCb(e);\n };\n }\n var tx = this.store.beginTransaction('readwrite');\n var oldParent = path.dirname(oldPath), oldName = path.basename(oldPath);\n var newParent = path.dirname(newPath), newName = path.basename(newPath);\n var inodes = {};\n var lists = {};\n var errorOccurred = false;\n // Invariant: Can't move a folder inside itself.\n // This funny little hack ensures that the check passes only if oldPath\n // is a subpath of newParent. We append '/' to avoid matching folders that\n // are a substring of the bottom-most folder in the path.\n if ((newParent + '/').indexOf(oldPath + '/') === 0) {\n return cb(new ApiError(ErrorCode.EBUSY, oldParent));\n }\n /**\n * Responsible for Phase 2 of the rename operation: Modifying and\n * committing the directory listings. Called once we have successfully\n * retrieved both the old and new parent's inodes and listings.\n */\n var theOleSwitcharoo = function () {\n // Sanity check: Ensure both paths are present, and no error has occurred.\n if (errorOccurred || !lists.hasOwnProperty(oldParent) || !lists.hasOwnProperty(newParent)) {\n return;\n }\n var oldParentList = lists[oldParent], oldParentINode = inodes[oldParent], newParentList = lists[newParent], newParentINode = inodes[newParent];\n // Delete file from old parent.\n if (!oldParentList[oldName]) {\n cb(ApiError.ENOENT(oldPath));\n }\n else {\n var fileId = oldParentList[oldName];\n delete oldParentList[oldName];\n // Finishes off the renaming process by adding the file to the new\n // parent.\n var completeRename = function () {\n newParentList[newName] = fileId;\n // Commit old parent's list.\n tx.put(oldParentINode.id, Buffer.from(JSON.stringify(oldParentList)), true, function (e) {\n if (noErrorTx(e, tx, cb)) {\n if (oldParent === newParent) {\n // DONE!\n tx.commit(cb);\n }\n else {\n // Commit new parent's list.\n tx.put(newParentINode.id, Buffer.from(JSON.stringify(newParentList)), true, function (e) {\n if (noErrorTx(e, tx, cb)) {\n tx.commit(cb);\n }\n });\n }\n }\n });\n };\n if (newParentList[newName]) {\n // 'newPath' already exists. Check if it's a file or a directory, and\n // act accordingly.\n this$1.getINode(tx, newPath, newParentList[newName], function (e, inode) {\n if (noErrorTx(e, tx, cb)) {\n if (inode.isFile()) {\n // Delete the file and continue.\n tx.del(inode.id, function (e) {\n if (noErrorTx(e, tx, cb)) {\n tx.del(newParentList[newName], function (e) {\n if (noErrorTx(e, tx, cb)) {\n completeRename();\n }\n });\n }\n });\n }\n else {\n // Can't overwrite a directory using rename.\n tx.abort(function (e) {\n cb(ApiError.EPERM(newPath));\n });\n }\n }\n });\n }\n else {\n completeRename();\n }\n }\n };\n /**\n * Grabs a path's inode and directory listing, and shoves it into the\n * inodes and lists hashes.\n */\n var processInodeAndListings = function (p) {\n this$1.findINodeAndDirListing(tx, p, function (e, node, dirList) {\n if (e) {\n if (!errorOccurred) {\n errorOccurred = true;\n tx.abort(function () {\n cb(e);\n });\n }\n // If error has occurred already, just stop here.\n }\n else {\n inodes[p] = node;\n lists[p] = dirList;\n theOleSwitcharoo();\n }\n });\n };\n processInodeAndListings(oldParent);\n if (oldParent !== newParent) {\n processInodeAndListings(newParent);\n }\n };\n AsyncKeyValueFileSystem.prototype.stat = function stat (p, isLstat, cb) {\n var tx = this.store.beginTransaction('readonly');\n this.findINode(tx, p, function (e, inode) {\n if (noError(e, cb)) {\n cb(null, inode.toStats());\n }\n });\n };\n AsyncKeyValueFileSystem.prototype.createFile = function createFile (p, flag, mode, cb) {\n var this$1 = this;\n\n var tx = this.store.beginTransaction('readwrite'), data = emptyBuffer();\n this.commitNewFile(tx, p, FileType.FILE, mode, data, function (e, newFile) {\n if (noError(e, cb)) {\n cb(null, new AsyncKeyValueFile(this$1, p, flag, newFile.toStats(), data));\n }\n });\n };\n AsyncKeyValueFileSystem.prototype.openFile = function openFile (p, flag, cb) {\n var this$1 = this;\n\n var tx = this.store.beginTransaction('readonly');\n // Step 1: Grab the file's inode.\n this.findINode(tx, p, function (e, inode) {\n if (noError(e, cb)) {\n // Step 2: Grab the file's data.\n tx.get(inode.id, function (e, data) {\n if (noError(e, cb)) {\n if (data === undefined) {\n cb(ApiError.ENOENT(p));\n }\n else {\n cb(null, new AsyncKeyValueFile(this$1, p, flag, inode.toStats(), data));\n }\n }\n });\n }\n });\n };\n AsyncKeyValueFileSystem.prototype.unlink = function unlink (p, cb) {\n this.removeEntry(p, false, cb);\n };\n AsyncKeyValueFileSystem.prototype.rmdir = function rmdir (p, cb) {\n var this$1 = this;\n\n // Check first if directory is empty.\n this.readdir(p, function (err, files) {\n if (err) {\n cb(err);\n }\n else if (files.length > 0) {\n cb(ApiError.ENOTEMPTY(p));\n }\n else {\n this$1.removeEntry(p, true, cb);\n }\n });\n };\n AsyncKeyValueFileSystem.prototype.mkdir = function mkdir (p, mode, cb) {\n var tx = this.store.beginTransaction('readwrite'), data = Buffer.from('{}');\n this.commitNewFile(tx, p, FileType.DIRECTORY, mode, data, cb);\n };\n AsyncKeyValueFileSystem.prototype.readdir = function readdir (p, cb) {\n var this$1 = this;\n\n var tx = this.store.beginTransaction('readonly');\n this.findINode(tx, p, function (e, inode) {\n if (noError(e, cb)) {\n this$1.getDirListing(tx, p, inode, function (e, dirListing) {\n if (noError(e, cb)) {\n cb(null, Object.keys(dirListing));\n }\n });\n }\n });\n };\n AsyncKeyValueFileSystem.prototype._sync = function _sync (p, data, stats, cb) {\n var this$1 = this;\n\n // @todo Ensure mtime updates properly, and use that to determine if a data\n // update is required.\n var tx = this.store.beginTransaction('readwrite');\n // Step 1: Get the file node's ID.\n this._findINode(tx, path.dirname(p), path.basename(p), function (e, fileInodeId) {\n if (noErrorTx(e, tx, cb)) {\n // Step 2: Get the file inode.\n this$1.getINode(tx, p, fileInodeId, function (e, fileInode) {\n if (noErrorTx(e, tx, cb)) {\n var inodeChanged = fileInode.update(stats);\n // Step 3: Sync the data.\n tx.put(fileInode.id, data, true, function (e) {\n if (noErrorTx(e, tx, cb)) {\n // Step 4: Sync the metadata (if it changed)!\n if (inodeChanged) {\n tx.put(fileInodeId, fileInode.toBuffer(), true, function (e) {\n if (noErrorTx(e, tx, cb)) {\n tx.commit(cb);\n }\n });\n }\n else {\n // No need to sync metadata; return.\n tx.commit(cb);\n }\n }\n });\n }\n });\n }\n });\n };\n /**\n * Checks if the root directory exists. Creates it if it doesn't.\n */\n AsyncKeyValueFileSystem.prototype.makeRootDirectory = function makeRootDirectory (cb) {\n var tx = this.store.beginTransaction('readwrite');\n tx.get(ROOT_NODE_ID, function (e, data) {\n if (e || data === undefined) {\n // Create new inode.\n var currTime = (new Date()).getTime(), \n // Mode 0666\n dirInode = new Inode(GenerateRandomID(), 4096, 511 | FileType.DIRECTORY, currTime, currTime, currTime);\n // If the root doesn't exist, the first random ID shouldn't exist,\n // either.\n tx.put(dirInode.id, getEmptyDirNode(), false, function (e) {\n if (noErrorTx(e, tx, cb)) {\n tx.put(ROOT_NODE_ID, dirInode.toBuffer(), false, function (e) {\n if (e) {\n tx.abort(function () { cb(e); });\n }\n else {\n tx.commit(cb);\n }\n });\n }\n });\n }\n else {\n // We're good.\n tx.commit(cb);\n }\n });\n };\n /**\n * Helper function for findINode.\n * @param parent The parent directory of the file we are attempting to find.\n * @param filename The filename of the inode we are attempting to find, minus\n * the parent.\n * @param cb Passed an error or the ID of the file's inode in the file system.\n */\n AsyncKeyValueFileSystem.prototype._findINode = function _findINode (tx, parent, filename, cb) {\n var this$1 = this;\n\n if (this._cache) {\n var id = this._cache.get(path.join(parent, filename));\n if (id) {\n return cb(null, id);\n }\n }\n var handleDirectoryListings = function (e, inode, dirList) {\n if (e) {\n cb(e);\n }\n else if (dirList[filename]) {\n var id = dirList[filename];\n if (this$1._cache) {\n this$1._cache.set(path.join(parent, filename), id);\n }\n cb(null, id);\n }\n else {\n cb(ApiError.ENOENT(path.resolve(parent, filename)));\n }\n };\n if (parent === '/') {\n if (filename === '') {\n // BASE CASE #1: Return the root's ID.\n if (this._cache) {\n this._cache.set(path.join(parent, filename), ROOT_NODE_ID);\n }\n cb(null, ROOT_NODE_ID);\n }\n else {\n // BASE CASE #2: Find the item in the root node.\n this.getINode(tx, parent, ROOT_NODE_ID, function (e, inode) {\n if (noError(e, cb)) {\n this$1.getDirListing(tx, parent, inode, function (e, dirList) {\n // handle_directory_listings will handle e for us.\n handleDirectoryListings(e, inode, dirList);\n });\n }\n });\n }\n }\n else {\n // Get the parent directory's INode, and find the file in its directory\n // listing.\n this.findINodeAndDirListing(tx, parent, handleDirectoryListings);\n }\n };\n /**\n * Finds the Inode of the given path.\n * @param p The path to look up.\n * @param cb Passed an error or the Inode of the path p.\n * @todo memoize/cache\n */\n AsyncKeyValueFileSystem.prototype.findINode = function findINode (tx, p, cb) {\n var this$1 = this;\n\n this._findINode(tx, path.dirname(p), path.basename(p), function (e, id) {\n if (noError(e, cb)) {\n this$1.getINode(tx, p, id, cb);\n }\n });\n };\n /**\n * Given the ID of a node, retrieves the corresponding Inode.\n * @param tx The transaction to use.\n * @param p The corresponding path to the file (used for error messages).\n * @param id The ID to look up.\n * @param cb Passed an error or the inode under the given id.\n */\n AsyncKeyValueFileSystem.prototype.getINode = function getINode (tx, p, id, cb) {\n tx.get(id, function (e, data) {\n if (noError(e, cb)) {\n if (data === undefined) {\n cb(ApiError.ENOENT(p));\n }\n else {\n cb(null, Inode.fromBuffer(data));\n }\n }\n });\n };\n /**\n * Given the Inode of a directory, retrieves the corresponding directory\n * listing.\n */\n AsyncKeyValueFileSystem.prototype.getDirListing = function getDirListing (tx, p, inode, cb) {\n if (!inode.isDirectory()) {\n cb(ApiError.ENOTDIR(p));\n }\n else {\n tx.get(inode.id, function (e, data) {\n if (noError(e, cb)) {\n try {\n cb(null, JSON.parse(data.toString()));\n }\n catch (e) {\n // Occurs when data is undefined, or corresponds to something other\n // than a directory listing. The latter should never occur unless\n // the file system is corrupted.\n cb(ApiError.ENOENT(p));\n }\n }\n });\n }\n };\n /**\n * Given a path to a directory, retrieves the corresponding INode and\n * directory listing.\n */\n AsyncKeyValueFileSystem.prototype.findINodeAndDirListing = function findINodeAndDirListing (tx, p, cb) {\n var this$1 = this;\n\n this.findINode(tx, p, function (e, inode) {\n if (noError(e, cb)) {\n this$1.getDirListing(tx, p, inode, function (e, listing) {\n if (noError(e, cb)) {\n cb(null, inode, listing);\n }\n });\n }\n });\n };\n /**\n * Adds a new node under a random ID. Retries 5 times before giving up in\n * the exceedingly unlikely chance that we try to reuse a random GUID.\n * @param cb Passed an error or the GUID that the data was stored under.\n */\n AsyncKeyValueFileSystem.prototype.addNewNode = function addNewNode (tx, data, cb) {\n var retries = 0, currId;\n var reroll = function () {\n if (++retries === 5) {\n // Max retries hit. Return with an error.\n cb(new ApiError(ErrorCode.EIO, 'Unable to commit data to key-value store.'));\n }\n else {\n // Try again.\n currId = GenerateRandomID();\n tx.put(currId, data, false, function (e, committed) {\n if (e || !committed) {\n reroll();\n }\n else {\n // Successfully stored under 'currId'.\n cb(null, currId);\n }\n });\n }\n };\n reroll();\n };\n /**\n * Commits a new file (well, a FILE or a DIRECTORY) to the file system with\n * the given mode.\n * Note: This will commit the transaction.\n * @param p The path to the new file.\n * @param type The type of the new file.\n * @param mode The mode to create the new file with.\n * @param data The data to store at the file's data node.\n * @param cb Passed an error or the Inode for the new file.\n */\n AsyncKeyValueFileSystem.prototype.commitNewFile = function commitNewFile (tx, p, type, mode, data, cb) {\n var this$1 = this;\n\n var parentDir = path.dirname(p), fname = path.basename(p), currTime = (new Date()).getTime();\n // Invariant: The root always exists.\n // If we don't check this prior to taking steps below, we will create a\n // file with name '' in root should p == '/'.\n if (p === '/') {\n return cb(ApiError.EEXIST(p));\n }\n // Let's build a pyramid of code!\n // Step 1: Get the parent directory's inode and directory listing\n this.findINodeAndDirListing(tx, parentDir, function (e, parentNode, dirListing) {\n if (noErrorTx(e, tx, cb)) {\n if (dirListing[fname]) {\n // File already exists.\n tx.abort(function () {\n cb(ApiError.EEXIST(p));\n });\n }\n else {\n // Step 2: Commit data to store.\n this$1.addNewNode(tx, data, function (e, dataId) {\n if (noErrorTx(e, tx, cb)) {\n // Step 3: Commit the file's inode to the store.\n var fileInode = new Inode(dataId, data.length, mode | type, currTime, currTime, currTime);\n this$1.addNewNode(tx, fileInode.toBuffer(), function (e, fileInodeId) {\n if (noErrorTx(e, tx, cb)) {\n // Step 4: Update parent directory's listing.\n dirListing[fname] = fileInodeId;\n tx.put(parentNode.id, Buffer.from(JSON.stringify(dirListing)), true, function (e) {\n if (noErrorTx(e, tx, cb)) {\n // Step 5: Commit and return the new inode.\n tx.commit(function (e) {\n if (noErrorTx(e, tx, cb)) {\n cb(null, fileInode);\n }\n });\n }\n });\n }\n });\n }\n });\n }\n }\n });\n };\n /**\n * Remove all traces of the given path from the file system.\n * @param p The path to remove from the file system.\n * @param isDir Does the path belong to a directory, or a file?\n * @todo Update mtime.\n */\n AsyncKeyValueFileSystem.prototype.removeEntry = function removeEntry (p, isDir, cb) {\n var this$1 = this;\n\n // Eagerly delete from cache (harmless even if removal fails)\n if (this._cache) {\n this._cache.remove(p);\n }\n var tx = this.store.beginTransaction('readwrite'), parent = path.dirname(p), fileName = path.basename(p);\n // Step 1: Get parent directory's node and directory listing.\n this.findINodeAndDirListing(tx, parent, function (e, parentNode, parentListing) {\n if (noErrorTx(e, tx, cb)) {\n if (!parentListing[fileName]) {\n tx.abort(function () {\n cb(ApiError.ENOENT(p));\n });\n }\n else {\n // Remove from directory listing of parent.\n var fileNodeId = parentListing[fileName];\n delete parentListing[fileName];\n // Step 2: Get file inode.\n this$1.getINode(tx, p, fileNodeId, function (e, fileNode) {\n if (noErrorTx(e, tx, cb)) {\n if (!isDir && fileNode.isDirectory()) {\n tx.abort(function () {\n cb(ApiError.EISDIR(p));\n });\n }\n else if (isDir && !fileNode.isDirectory()) {\n tx.abort(function () {\n cb(ApiError.ENOTDIR(p));\n });\n }\n else {\n // Step 3: Delete data.\n tx.del(fileNode.id, function (e) {\n if (noErrorTx(e, tx, cb)) {\n // Step 4: Delete node.\n tx.del(fileNodeId, function (e) {\n if (noErrorTx(e, tx, cb)) {\n // Step 5: Update directory listing.\n tx.put(parentNode.id, Buffer.from(JSON.stringify(parentListing)), true, function (e) {\n if (noErrorTx(e, tx, cb)) {\n tx.commit(cb);\n }\n });\n }\n });\n }\n });\n }\n }\n });\n }\n }\n });\n };\n\n return AsyncKeyValueFileSystem;\n}(BaseFileSystem));\n\n/**\n * A simple in-memory key-value store backed by a JavaScript object.\n */\nvar InMemoryStore = function InMemoryStore() {\n this.store = {};\n};\nInMemoryStore.prototype.name = function name () { return InMemoryFileSystem.Name; };\nInMemoryStore.prototype.clear = function clear () { this.store = {}; };\nInMemoryStore.prototype.beginTransaction = function beginTransaction (type) {\n return new SimpleSyncRWTransaction(this);\n};\nInMemoryStore.prototype.get = function get (key) {\n return this.store[key];\n};\nInMemoryStore.prototype.put = function put (key, data, overwrite) {\n if (!overwrite && this.store.hasOwnProperty(key)) {\n return false;\n }\n this.store[key] = data;\n return true;\n};\nInMemoryStore.prototype.del = function del (key) {\n delete this.store[key];\n};\n/**\n * A simple in-memory file system backed by an InMemoryStore.\n * Files are not persisted across page loads.\n */\nvar InMemoryFileSystem = /*@__PURE__*/(function (SyncKeyValueFileSystem$$1) {\n function InMemoryFileSystem() {\n SyncKeyValueFileSystem$$1.call(this, { store: new InMemoryStore() });\n }\n\n if ( SyncKeyValueFileSystem$$1 ) InMemoryFileSystem.__proto__ = SyncKeyValueFileSystem$$1;\n InMemoryFileSystem.prototype = Object.create( SyncKeyValueFileSystem$$1 && SyncKeyValueFileSystem$$1.prototype );\n InMemoryFileSystem.prototype.constructor = InMemoryFileSystem;\n /**\n * Creates an InMemoryFileSystem instance.\n */\n InMemoryFileSystem.Create = function Create (options, cb) {\n cb(null, new InMemoryFileSystem());\n };\n\n return InMemoryFileSystem;\n}(SyncKeyValueFileSystem));\nInMemoryFileSystem.Name = \"InMemory\";\nInMemoryFileSystem.Options = {};\n\n/**\n * Get the indexedDB constructor for the current browser.\n * @hidden\n */\nvar indexedDB = (function () {\n try {\n return toExport.indexedDB ||\n toExport.mozIndexedDB ||\n toExport.webkitIndexedDB ||\n toExport.msIndexedDB;\n }\n catch (_a) {\n return null;\n }\n})();\n/**\n * Converts a DOMException or a DOMError from an IndexedDB event into a\n * standardized BrowserFS API error.\n * @hidden\n */\nfunction convertError$2(e, message) {\n if ( message === void 0 ) message = e.toString();\n\n switch (e.name) {\n case \"NotFoundError\":\n return new ApiError(ErrorCode.ENOENT, message);\n case \"QuotaExceededError\":\n return new ApiError(ErrorCode.ENOSPC, message);\n default:\n // The rest do not seem to map cleanly to standard error codes.\n return new ApiError(ErrorCode.EIO, message);\n }\n}\n/**\n * Produces a new onerror handler for IDB. Our errors are always fatal, so we\n * handle them generically: Call the user-supplied callback with a translated\n * version of the error, and let the error bubble up.\n * @hidden\n */\nfunction onErrorHandler(cb, code, message) {\n if ( code === void 0 ) code = ErrorCode.EIO;\n if ( message === void 0 ) message = null;\n\n return function (e) {\n // Prevent the error from canceling the transaction.\n e.preventDefault();\n cb(new ApiError(code, message !== null ? message : undefined));\n };\n}\n/**\n * @hidden\n */\nvar IndexedDBROTransaction = function IndexedDBROTransaction(tx, store) {\n this.tx = tx;\n this.store = store;\n};\nIndexedDBROTransaction.prototype.get = function get (key, cb) {\n try {\n var r = this.store.get(key);\n r.onerror = onErrorHandler(cb);\n r.onsuccess = function (event) {\n // IDB returns the value 'undefined' when you try to get keys that\n // don't exist. The caller expects this behavior.\n var result = event.target.result;\n if (result === undefined) {\n cb(null, result);\n }\n else {\n // IDB data is stored as an ArrayBuffer\n cb(null, arrayBuffer2Buffer(result));\n }\n };\n }\n catch (e) {\n cb(convertError$2(e));\n }\n};\n/**\n * @hidden\n */\nvar IndexedDBRWTransaction = /*@__PURE__*/(function (IndexedDBROTransaction) {\n function IndexedDBRWTransaction(tx, store) {\n IndexedDBROTransaction.call(this, tx, store);\n }\n\n if ( IndexedDBROTransaction ) IndexedDBRWTransaction.__proto__ = IndexedDBROTransaction;\n IndexedDBRWTransaction.prototype = Object.create( IndexedDBROTransaction && IndexedDBROTransaction.prototype );\n IndexedDBRWTransaction.prototype.constructor = IndexedDBRWTransaction;\n IndexedDBRWTransaction.prototype.put = function put (key, data, overwrite, cb) {\n try {\n var arraybuffer = buffer2ArrayBuffer(data);\n var r;\n // Note: 'add' will never overwrite an existing key.\n r = overwrite ? this.store.put(arraybuffer, key) : this.store.add(arraybuffer, key);\n // XXX: NEED TO RETURN FALSE WHEN ADD HAS A KEY CONFLICT. NO ERROR.\n r.onerror = onErrorHandler(cb);\n r.onsuccess = function (event) {\n cb(null, true);\n };\n }\n catch (e) {\n cb(convertError$2(e));\n }\n };\n IndexedDBRWTransaction.prototype.del = function del (key, cb) {\n try {\n // NOTE: IE8 has a bug with identifiers named 'delete' unless used as a string\n // like this.\n // http://stackoverflow.com/a/26479152\n var r = this.store['delete'](key);\n r.onerror = onErrorHandler(cb);\n r.onsuccess = function (event) {\n cb();\n };\n }\n catch (e) {\n cb(convertError$2(e));\n }\n };\n IndexedDBRWTransaction.prototype.commit = function commit (cb) {\n // Return to the event loop to commit the transaction.\n setTimeout(cb, 0);\n };\n IndexedDBRWTransaction.prototype.abort = function abort (cb) {\n var _e = null;\n try {\n this.tx.abort();\n }\n catch (e) {\n _e = convertError$2(e);\n }\n finally {\n cb(_e);\n }\n };\n\n return IndexedDBRWTransaction;\n}(IndexedDBROTransaction));\nvar IndexedDBStore = function IndexedDBStore(db, storeName) {\n this.db = db;\n this.storeName = storeName;\n};\nIndexedDBStore.Create = function Create (storeName, cb) {\n var openReq = indexedDB.open(storeName, 1);\n openReq.onupgradeneeded = function (event) {\n var db = event.target.result;\n // Huh. This should never happen; we're at version 1. Why does another\n // database exist?\n if (db.objectStoreNames.contains(storeName)) {\n db.deleteObjectStore(storeName);\n }\n db.createObjectStore(storeName);\n };\n openReq.onsuccess = function (event) {\n cb(null, new IndexedDBStore(event.target.result, storeName));\n };\n openReq.onerror = onErrorHandler(cb, ErrorCode.EACCES);\n};\nIndexedDBStore.prototype.name = function name () {\n return IndexedDBFileSystem.Name + \" - \" + this.storeName;\n};\nIndexedDBStore.prototype.clear = function clear (cb) {\n try {\n var tx = this.db.transaction(this.storeName, 'readwrite'), objectStore = tx.objectStore(this.storeName), r = objectStore.clear();\n r.onsuccess = function (event) {\n // Use setTimeout to commit transaction.\n setTimeout(cb, 0);\n };\n r.onerror = onErrorHandler(cb);\n }\n catch (e) {\n cb(convertError$2(e));\n }\n};\nIndexedDBStore.prototype.beginTransaction = function beginTransaction (type) {\n if ( type === void 0 ) type = 'readonly';\n\n var tx = this.db.transaction(this.storeName, type), objectStore = tx.objectStore(this.storeName);\n if (type === 'readwrite') {\n return new IndexedDBRWTransaction(tx, objectStore);\n }\n else if (type === 'readonly') {\n return new IndexedDBROTransaction(tx, objectStore);\n }\n else {\n throw new ApiError(ErrorCode.EINVAL, 'Invalid transaction type.');\n }\n};\n/**\n * A file system that uses the IndexedDB key value file system.\n */\nvar IndexedDBFileSystem = /*@__PURE__*/(function (AsyncKeyValueFileSystem$$1) {\n function IndexedDBFileSystem(cacheSize) {\n AsyncKeyValueFileSystem$$1.call(this, cacheSize);\n }\n\n if ( AsyncKeyValueFileSystem$$1 ) IndexedDBFileSystem.__proto__ = AsyncKeyValueFileSystem$$1;\n IndexedDBFileSystem.prototype = Object.create( AsyncKeyValueFileSystem$$1 && AsyncKeyValueFileSystem$$1.prototype );\n IndexedDBFileSystem.prototype.constructor = IndexedDBFileSystem;\n /**\n * Constructs an IndexedDB file system with the given options.\n */\n IndexedDBFileSystem.Create = function Create (opts, cb) {\n if ( opts === void 0 ) opts = {};\n\n IndexedDBStore.Create(opts.storeName ? opts.storeName : 'browserfs', function (e, store) {\n if (store) {\n var idbfs = new IndexedDBFileSystem(typeof (opts.cacheSize) === 'number' ? opts.cacheSize : 100);\n idbfs.init(store, function (e) {\n if (e) {\n cb(e);\n }\n else {\n cb(null, idbfs);\n }\n });\n }\n else {\n cb(e);\n }\n });\n };\n IndexedDBFileSystem.isAvailable = function isAvailable () {\n // In Safari's private browsing mode, indexedDB.open returns NULL.\n // In Firefox, it throws an exception.\n // In Chrome, it \"just works\", and clears the database when you leave the page.\n // Untested: Opera, IE.\n try {\n return typeof indexedDB !== 'undefined' && null !== indexedDB.open(\"__browserfs_test__\");\n }\n catch (e) {\n return false;\n }\n };\n\n return IndexedDBFileSystem;\n}(AsyncKeyValueFileSystem));\nIndexedDBFileSystem.Name = \"IndexedDB\";\nIndexedDBFileSystem.Options = {\n storeName: {\n type: \"string\",\n optional: true,\n description: \"The name of this file system. You can have multiple IndexedDB file systems operating at once, but each must have a different name.\"\n },\n cacheSize: {\n type: \"number\",\n optional: true,\n description: \"The size of the inode cache. Defaults to 100. A size of 0 or below disables caching.\"\n }\n};\n\n/**\n * Some versions of FF and all versions of IE do not support the full range of\n * 16-bit numbers encoded as characters, as they enforce UTF-16 restrictions.\n * @url http://stackoverflow.com/questions/11170716/are-there-any-characters-that-are-not-allowed-in-localstorage/11173673#11173673\n * @hidden\n */\nvar supportsBinaryString = false, binaryEncoding;\ntry {\n toExport.localStorage.setItem(\"__test__\", String.fromCharCode(0xD800));\n supportsBinaryString = toExport.localStorage.getItem(\"__test__\") === String.fromCharCode(0xD800);\n}\ncatch (e) {\n // IE throws an exception.\n supportsBinaryString = false;\n}\nbinaryEncoding = supportsBinaryString ? 'binary_string' : 'binary_string_ie';\nif (!Buffer.isEncoding(binaryEncoding)) {\n // Fallback for non BrowserFS implementations of buffer that lack a\n // binary_string format.\n binaryEncoding = \"base64\";\n}\n/**\n * A synchronous key-value store backed by localStorage.\n */\nvar LocalStorageStore = function LocalStorageStore () {};\n\nLocalStorageStore.prototype.name = function name () {\n return LocalStorageFileSystem.Name;\n};\nLocalStorageStore.prototype.clear = function clear () {\n toExport.localStorage.clear();\n};\nLocalStorageStore.prototype.beginTransaction = function beginTransaction (type) {\n // No need to differentiate.\n return new SimpleSyncRWTransaction(this);\n};\nLocalStorageStore.prototype.get = function get (key) {\n try {\n var data = toExport.localStorage.getItem(key);\n if (data !== null) {\n return Buffer.from(data, binaryEncoding);\n }\n }\n catch (e) {\n // Do nothing.\n }\n // Key doesn't exist, or a failure occurred.\n return undefined;\n};\nLocalStorageStore.prototype.put = function put (key, data, overwrite) {\n try {\n if (!overwrite && toExport.localStorage.getItem(key) !== null) {\n // Don't want to overwrite the key!\n return false;\n }\n toExport.localStorage.setItem(key, data.toString(binaryEncoding));\n return true;\n }\n catch (e) {\n throw new ApiError(ErrorCode.ENOSPC, \"LocalStorage is full.\");\n }\n};\nLocalStorageStore.prototype.del = function del (key) {\n try {\n toExport.localStorage.removeItem(key);\n }\n catch (e) {\n throw new ApiError(ErrorCode.EIO, \"Unable to delete key \" + key + \": \" + e);\n }\n};\n/**\n * A synchronous file system backed by localStorage. Connects our\n * LocalStorageStore to our SyncKeyValueFileSystem.\n */\nvar LocalStorageFileSystem = /*@__PURE__*/(function (SyncKeyValueFileSystem$$1) {\n function LocalStorageFileSystem() { SyncKeyValueFileSystem$$1.call(this, { store: new LocalStorageStore() }); }\n\n if ( SyncKeyValueFileSystem$$1 ) LocalStorageFileSystem.__proto__ = SyncKeyValueFileSystem$$1;\n LocalStorageFileSystem.prototype = Object.create( SyncKeyValueFileSystem$$1 && SyncKeyValueFileSystem$$1.prototype );\n LocalStorageFileSystem.prototype.constructor = LocalStorageFileSystem;\n /**\n * Creates a LocalStorageFileSystem instance.\n */\n LocalStorageFileSystem.Create = function Create (options, cb) {\n cb(null, new LocalStorageFileSystem());\n };\n LocalStorageFileSystem.isAvailable = function isAvailable () {\n return typeof toExport.localStorage !== 'undefined';\n };\n\n return LocalStorageFileSystem;\n}(SyncKeyValueFileSystem));\nLocalStorageFileSystem.Name = \"LocalStorage\";\nLocalStorageFileSystem.Options = {};\n\n/**\n * The MountableFileSystem allows you to mount multiple backend types or\n * multiple instantiations of the same backend into a single file system tree.\n * The file systems do not need to know about each other; all interactions are\n * automatically facilitated through this interface.\n *\n * For example, if a file system is mounted at /mnt/blah, and a request came in\n * for /mnt/blah/foo.txt, the file system would see a request for /foo.txt.\n *\n * You can mount file systems when you configure the file system:\n * ```javascript\n * BrowserFS.configure({\n * fs: \"MountableFileSystem\",\n * options: {\n * '/data': { fs: 'HTTPRequest', options: { index: \"http://mysite.com/files/index.json\" } },\n * '/home': { fs: 'LocalStorage' }\n * }\n * }, function(e) {\n *\n * });\n * ```\n *\n * For advanced users, you can also mount file systems *after* MFS is constructed:\n * ```javascript\n * BrowserFS.FileSystem.HTTPRequest.Create({\n * index: \"http://mysite.com/files/index.json\"\n * }, function(e, xhrfs) {\n * BrowserFS.FileSystem.MountableFileSystem.Create({\n * '/data': xhrfs\n * }, function(e, mfs) {\n * BrowserFS.initialize(mfs);\n *\n * // Added after-the-fact...\n * BrowserFS.FileSystem.LocalStorage.Create(function(e, lsfs) {\n * mfs.mount('/home', lsfs);\n * });\n * });\n * });\n * ```\n *\n * Since MountableFileSystem simply proxies requests to mounted file systems, it supports all of the operations that the mounted file systems support.\n *\n * With no mounted file systems, `MountableFileSystem` acts as a simple `InMemory` filesystem.\n */\nvar MountableFileSystem = /*@__PURE__*/(function (BaseFileSystem$$1) {\n function MountableFileSystem(rootFs) {\n BaseFileSystem$$1.call(this);\n // Contains the list of mount points in mntMap, sorted by string length in decreasing order.\n // Ensures that we scan the most specific mount points for a match first, which lets us\n // nest mount points.\n this.mountList = [];\n this.mntMap = {};\n this.rootFs = rootFs;\n }\n\n if ( BaseFileSystem$$1 ) MountableFileSystem.__proto__ = BaseFileSystem$$1;\n MountableFileSystem.prototype = Object.create( BaseFileSystem$$1 && BaseFileSystem$$1.prototype );\n MountableFileSystem.prototype.constructor = MountableFileSystem;\n /**\n * Creates a MountableFileSystem instance with the given options.\n */\n MountableFileSystem.Create = function Create (opts, cb) {\n InMemoryFileSystem.Create({}, function (e, imfs) {\n if (imfs) {\n var fs = new MountableFileSystem(imfs);\n try {\n Object.keys(opts).forEach(function (mountPoint) {\n fs.mount(mountPoint, opts[mountPoint]);\n });\n }\n catch (e) {\n return cb(e);\n }\n cb(null, fs);\n }\n else {\n cb(e);\n }\n });\n };\n MountableFileSystem.isAvailable = function isAvailable () {\n return true;\n };\n /**\n * Mounts the file system at the given mount point.\n */\n MountableFileSystem.prototype.mount = function mount (mountPoint, fs) {\n if (mountPoint[0] !== '/') {\n mountPoint = \"/\" + mountPoint;\n }\n mountPoint = path.resolve(mountPoint);\n if (this.mntMap[mountPoint]) {\n throw new ApiError(ErrorCode.EINVAL, \"Mount point \" + mountPoint + \" is already taken.\");\n }\n mkdirpSync(mountPoint, 0x1ff, this.rootFs);\n this.mntMap[mountPoint] = fs;\n this.mountList.push(mountPoint);\n this.mountList = this.mountList.sort(function (a, b) { return b.length - a.length; });\n };\n MountableFileSystem.prototype.umount = function umount (mountPoint) {\n if (mountPoint[0] !== '/') {\n mountPoint = \"/\" + mountPoint;\n }\n mountPoint = path.resolve(mountPoint);\n if (!this.mntMap[mountPoint]) {\n throw new ApiError(ErrorCode.EINVAL, \"Mount point \" + mountPoint + \" is already unmounted.\");\n }\n delete this.mntMap[mountPoint];\n this.mountList.splice(this.mountList.indexOf(mountPoint), 1);\n while (mountPoint !== '/') {\n if (this.rootFs.readdirSync(mountPoint).length === 0) {\n this.rootFs.rmdirSync(mountPoint);\n mountPoint = path.dirname(mountPoint);\n }\n else {\n break;\n }\n }\n };\n /**\n * Returns the file system that the path points to.\n */\n MountableFileSystem.prototype._getFs = function _getFs (path$$1) {\n var mountList = this.mountList, len = mountList.length;\n for (var i = 0; i < len; i++) {\n var mountPoint = mountList[i];\n // We know path is normalized, so it is a substring of the mount point.\n if (mountPoint.length <= path$$1.length && path$$1.indexOf(mountPoint) === 0) {\n path$$1 = path$$1.substr(mountPoint.length > 1 ? mountPoint.length : 0);\n if (path$$1 === '') {\n path$$1 = '/';\n }\n return { fs: this.mntMap[mountPoint], path: path$$1, mountPoint: mountPoint };\n }\n }\n // Query our root file system.\n return { fs: this.rootFs, path: path$$1, mountPoint: '/' };\n };\n // Global information methods\n MountableFileSystem.prototype.getName = function getName () {\n return MountableFileSystem.Name;\n };\n MountableFileSystem.prototype.diskSpace = function diskSpace (path$$1, cb) {\n cb(0, 0);\n };\n MountableFileSystem.prototype.isReadOnly = function isReadOnly () {\n return false;\n };\n MountableFileSystem.prototype.supportsLinks = function supportsLinks () {\n // I'm not ready for cross-FS links yet.\n return false;\n };\n MountableFileSystem.prototype.supportsProps = function supportsProps () {\n return false;\n };\n MountableFileSystem.prototype.supportsSynch = function supportsSynch () {\n return true;\n };\n /**\n * Fixes up error messages so they mention the mounted file location relative\n * to the MFS root, not to the particular FS's root.\n * Mutates the input error, and returns it.\n */\n MountableFileSystem.prototype.standardizeError = function standardizeError (err, path$$1, realPath) {\n var index = err.message.indexOf(path$$1);\n if (index !== -1) {\n err.message = err.message.substr(0, index) + realPath + err.message.substr(index + path$$1.length);\n err.path = realPath;\n }\n return err;\n };\n // The following methods involve multiple file systems, and thus have custom\n // logic.\n // Note that we go through the Node API to use its robust default argument\n // processing.\n MountableFileSystem.prototype.rename = function rename (oldPath, newPath, cb) {\n var this$1 = this;\n\n // Scenario 1: old and new are on same FS.\n var fs1rv = this._getFs(oldPath);\n var fs2rv = this._getFs(newPath);\n if (fs1rv.fs === fs2rv.fs) {\n return fs1rv.fs.rename(fs1rv.path, fs2rv.path, function (e) {\n if (e) {\n this$1.standardizeError(this$1.standardizeError(e, fs1rv.path, oldPath), fs2rv.path, newPath);\n }\n cb(e);\n });\n }\n // Scenario 2: Different file systems.\n // Read old file, write new file, delete old file.\n return _fsMock.readFile(oldPath, function (err, data) {\n if (err) {\n return cb(err);\n }\n _fsMock.writeFile(newPath, data, function (err) {\n if (err) {\n return cb(err);\n }\n _fsMock.unlink(oldPath, cb);\n });\n });\n };\n MountableFileSystem.prototype.renameSync = function renameSync (oldPath, newPath) {\n // Scenario 1: old and new are on same FS.\n var fs1rv = this._getFs(oldPath);\n var fs2rv = this._getFs(newPath);\n if (fs1rv.fs === fs2rv.fs) {\n try {\n return fs1rv.fs.renameSync(fs1rv.path, fs2rv.path);\n }\n catch (e) {\n this.standardizeError(this.standardizeError(e, fs1rv.path, oldPath), fs2rv.path, newPath);\n throw e;\n }\n }\n // Scenario 2: Different file systems.\n var data = _fsMock.readFileSync(oldPath);\n _fsMock.writeFileSync(newPath, data);\n return _fsMock.unlinkSync(oldPath);\n };\n MountableFileSystem.prototype.readdirSync = function readdirSync (p) {\n var fsInfo = this._getFs(p);\n // If null, rootfs did not have the directory\n // (or the target FS is the root fs).\n var rv = null;\n // Mount points are all defined in the root FS.\n // Ensure that we list those, too.\n if (fsInfo.fs !== this.rootFs) {\n try {\n rv = this.rootFs.readdirSync(p);\n }\n catch (e) {\n // Ignore.\n }\n }\n try {\n var rv2 = fsInfo.fs.readdirSync(fsInfo.path);\n if (rv === null) {\n return rv2;\n }\n else {\n // Filter out duplicates.\n return rv2.concat(rv.filter(function (val) { return rv2.indexOf(val) === -1; }));\n }\n }\n catch (e) {\n if (rv === null) {\n throw this.standardizeError(e, fsInfo.path, p);\n }\n else {\n // The root FS had something.\n return rv;\n }\n }\n };\n MountableFileSystem.prototype.readdir = function readdir (p, cb) {\n var this$1 = this;\n\n var fsInfo = this._getFs(p);\n fsInfo.fs.readdir(fsInfo.path, function (err, files) {\n if (fsInfo.fs !== this$1.rootFs) {\n try {\n var rv = this$1.rootFs.readdirSync(p);\n if (files) {\n // Filter out duplicates.\n files = files.concat(rv.filter(function (val) { return files.indexOf(val) === -1; }));\n }\n else {\n files = rv;\n }\n }\n catch (e) {\n // Root FS and target FS did not have directory.\n if (err) {\n return cb(this$1.standardizeError(err, fsInfo.path, p));\n }\n }\n }\n else if (err) {\n // Root FS and target FS are the same, and did not have directory.\n return cb(this$1.standardizeError(err, fsInfo.path, p));\n }\n cb(null, files);\n });\n };\n MountableFileSystem.prototype.realpathSync = function realpathSync (p, cache) {\n var fsInfo = this._getFs(p);\n try {\n var mountedPath = fsInfo.fs.realpathSync(fsInfo.path, {});\n // resolve is there to remove any trailing slash that may be present\n return path.resolve(path.join(fsInfo.mountPoint, mountedPath));\n }\n catch (e) {\n throw this.standardizeError(e, fsInfo.path, p);\n }\n };\n MountableFileSystem.prototype.realpath = function realpath (p, cache, cb) {\n var this$1 = this;\n\n var fsInfo = this._getFs(p);\n fsInfo.fs.realpath(fsInfo.path, {}, function (err, rv) {\n if (err) {\n cb(this$1.standardizeError(err, fsInfo.path, p));\n }\n else {\n // resolve is there to remove any trailing slash that may be present\n cb(null, path.resolve(path.join(fsInfo.mountPoint, rv)));\n }\n });\n };\n MountableFileSystem.prototype.rmdirSync = function rmdirSync (p) {\n var fsInfo = this._getFs(p);\n if (this._containsMountPt(p)) {\n throw ApiError.ENOTEMPTY(p);\n }\n else {\n try {\n fsInfo.fs.rmdirSync(fsInfo.path);\n }\n catch (e) {\n throw this.standardizeError(e, fsInfo.path, p);\n }\n }\n };\n MountableFileSystem.prototype.rmdir = function rmdir (p, cb) {\n var this$1 = this;\n\n var fsInfo = this._getFs(p);\n if (this._containsMountPt(p)) {\n cb(ApiError.ENOTEMPTY(p));\n }\n else {\n fsInfo.fs.rmdir(fsInfo.path, function (err) {\n cb(err ? this$1.standardizeError(err, fsInfo.path, p) : null);\n });\n }\n };\n /**\n * Returns true if the given path contains a mount point.\n */\n MountableFileSystem.prototype._containsMountPt = function _containsMountPt (p) {\n var mountPoints = this.mountList, len = mountPoints.length;\n for (var i = 0; i < len; i++) {\n var pt = mountPoints[i];\n if (pt.length >= p.length && pt.slice(0, p.length) === p) {\n return true;\n }\n }\n return false;\n };\n\n return MountableFileSystem;\n}(BaseFileSystem));\nMountableFileSystem.Name = \"MountableFileSystem\";\nMountableFileSystem.Options = {};\n/**\n * Tricky: Define all of the functions that merely forward arguments to the\n * relevant file system, or return/throw an error.\n * Take advantage of the fact that the *first* argument is always the path, and\n * the *last* is the callback function (if async).\n * @todo Can use numArgs to make proxying more efficient.\n * @hidden\n */\nfunction defineFcn(name, isSync, numArgs) {\n if (isSync) {\n return function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var path$$1 = args[0];\n var rv = this._getFs(path$$1);\n args[0] = rv.path;\n try {\n return rv.fs[name].apply(rv.fs, args);\n }\n catch (e) {\n this.standardizeError(e, rv.path, path$$1);\n throw e;\n }\n };\n }\n else {\n return function () {\n var this$1 = this;\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var path$$1 = args[0];\n var rv = this._getFs(path$$1);\n args[0] = rv.path;\n if (typeof args[args.length - 1] === 'function') {\n var cb = args[args.length - 1];\n args[args.length - 1] = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n if (args.length > 0 && args[0] instanceof ApiError) {\n this$1.standardizeError(args[0], rv.path, path$$1);\n }\n cb.apply(null, args);\n };\n }\n return rv.fs[name].apply(rv.fs, args);\n };\n }\n}\n/**\n * @hidden\n */\nvar fsCmdMap = [\n // 1 arg functions\n ['exists', 'unlink', 'readlink'],\n // 2 arg functions\n ['stat', 'mkdir', 'truncate'],\n // 3 arg functions\n ['open', 'readFile', 'chmod', 'utimes'],\n // 4 arg functions\n ['chown'],\n // 5 arg functions\n ['writeFile', 'appendFile']\n];\nfor (var i = 0; i < fsCmdMap.length; i++) {\n var cmds = fsCmdMap[i];\n for (var i$1 = 0, list = cmds; i$1 < list.length; i$1 += 1) {\n var fnName = list[i$1];\n\n MountableFileSystem.prototype[fnName] = defineFcn(fnName, false, i + 1);\n MountableFileSystem.prototype[fnName + 'Sync'] = defineFcn(fnName + 'Sync', true, i + 1);\n }\n}\n\n/**\n * Non-recursive mutex\n * @hidden\n */\nvar Mutex = function Mutex() {\n this._locked = false;\n this._waiters = [];\n};\nMutex.prototype.lock = function lock (cb) {\n if (this._locked) {\n this._waiters.push(cb);\n return;\n }\n this._locked = true;\n cb();\n};\nMutex.prototype.unlock = function unlock () {\n if (!this._locked) {\n throw new Error('unlock of a non-locked mutex');\n }\n var next = this._waiters.shift();\n // don't unlock - we want to queue up next for the\n // _end_ of the current task execution, but we don't\n // want it to be called inline with whatever the\n // current stack is. This way we still get the nice\n // behavior that an unlock immediately followed by a\n // lock won't cause starvation.\n if (next) {\n setImmediate$1(next);\n return;\n }\n this._locked = false;\n};\nMutex.prototype.tryLock = function tryLock () {\n if (this._locked) {\n return false;\n }\n this._locked = true;\n return true;\n};\nMutex.prototype.isLocked = function isLocked () {\n return this._locked;\n};\n\n/**\n * This class serializes access to an underlying async filesystem.\n * For example, on an OverlayFS instance with an async lower\n * directory operations like rename and rmdir may involve multiple\n * requests involving both the upper and lower filesystems -- they\n * are not executed in a single atomic step. OverlayFS uses this\n * LockedFS to avoid having to reason about the correctness of\n * multiple requests interleaving.\n */\nvar LockedFS = function LockedFS(fs) {\n this._fs = fs;\n this._mu = new Mutex();\n};\nLockedFS.prototype.getName = function getName () {\n return 'LockedFS<' + this._fs.getName() + '>';\n};\nLockedFS.prototype.getFSUnlocked = function getFSUnlocked () {\n return this._fs;\n};\nLockedFS.prototype.diskSpace = function diskSpace (p, cb) {\n // FIXME: should this lock?\n this._fs.diskSpace(p, cb);\n};\nLockedFS.prototype.isReadOnly = function isReadOnly () {\n return this._fs.isReadOnly();\n};\nLockedFS.prototype.supportsLinks = function supportsLinks () {\n return this._fs.supportsLinks();\n};\nLockedFS.prototype.supportsProps = function supportsProps () {\n return this._fs.supportsProps();\n};\nLockedFS.prototype.supportsSynch = function supportsSynch () {\n return this._fs.supportsSynch();\n};\nLockedFS.prototype.rename = function rename (oldPath, newPath, cb) {\n var this$1 = this;\n\n this._mu.lock(function () {\n this$1._fs.rename(oldPath, newPath, function (err) {\n this$1._mu.unlock();\n cb(err);\n });\n });\n};\nLockedFS.prototype.renameSync = function renameSync (oldPath, newPath) {\n if (this._mu.isLocked()) {\n throw new Error('invalid sync call');\n }\n return this._fs.renameSync(oldPath, newPath);\n};\nLockedFS.prototype.stat = function stat (p, isLstat, cb) {\n var this$1 = this;\n\n this._mu.lock(function () {\n this$1._fs.stat(p, isLstat, function (err, stat) {\n this$1._mu.unlock();\n cb(err, stat);\n });\n });\n};\nLockedFS.prototype.statSync = function statSync (p, isLstat) {\n if (this._mu.isLocked()) {\n throw new Error('invalid sync call');\n }\n return this._fs.statSync(p, isLstat);\n};\nLockedFS.prototype.open = function open (p, flag, mode, cb) {\n var this$1 = this;\n\n this._mu.lock(function () {\n this$1._fs.open(p, flag, mode, function (err, fd) {\n this$1._mu.unlock();\n cb(err, fd);\n });\n });\n};\nLockedFS.prototype.openSync = function openSync (p, flag, mode) {\n if (this._mu.isLocked()) {\n throw new Error('invalid sync call');\n }\n return this._fs.openSync(p, flag, mode);\n};\nLockedFS.prototype.unlink = function unlink (p, cb) {\n var this$1 = this;\n\n this._mu.lock(function () {\n this$1._fs.unlink(p, function (err) {\n this$1._mu.unlock();\n cb(err);\n });\n });\n};\nLockedFS.prototype.unlinkSync = function unlinkSync (p) {\n if (this._mu.isLocked()) {\n throw new Error('invalid sync call');\n }\n return this._fs.unlinkSync(p);\n};\nLockedFS.prototype.rmdir = function rmdir (p, cb) {\n var this$1 = this;\n\n this._mu.lock(function () {\n this$1._fs.rmdir(p, function (err) {\n this$1._mu.unlock();\n cb(err);\n });\n });\n};\nLockedFS.prototype.rmdirSync = function rmdirSync (p) {\n if (this._mu.isLocked()) {\n throw new Error('invalid sync call');\n }\n return this._fs.rmdirSync(p);\n};\nLockedFS.prototype.mkdir = function mkdir (p, mode, cb) {\n var this$1 = this;\n\n this._mu.lock(function () {\n this$1._fs.mkdir(p, mode, function (err) {\n this$1._mu.unlock();\n cb(err);\n });\n });\n};\nLockedFS.prototype.mkdirSync = function mkdirSync (p, mode) {\n if (this._mu.isLocked()) {\n throw new Error('invalid sync call');\n }\n return this._fs.mkdirSync(p, mode);\n};\nLockedFS.prototype.readdir = function readdir (p, cb) {\n var this$1 = this;\n\n this._mu.lock(function () {\n this$1._fs.readdir(p, function (err, files) {\n this$1._mu.unlock();\n cb(err, files);\n });\n });\n};\nLockedFS.prototype.readdirSync = function readdirSync (p) {\n if (this._mu.isLocked()) {\n throw new Error('invalid sync call');\n }\n return this._fs.readdirSync(p);\n};\nLockedFS.prototype.exists = function exists (p, cb) {\n var this$1 = this;\n\n this._mu.lock(function () {\n this$1._fs.exists(p, function (exists) {\n this$1._mu.unlock();\n cb(exists);\n });\n });\n};\nLockedFS.prototype.existsSync = function existsSync (p) {\n if (this._mu.isLocked()) {\n throw new Error('invalid sync call');\n }\n return this._fs.existsSync(p);\n};\nLockedFS.prototype.realpath = function realpath (p, cache, cb) {\n var this$1 = this;\n\n this._mu.lock(function () {\n this$1._fs.realpath(p, cache, function (err, resolvedPath) {\n this$1._mu.unlock();\n cb(err, resolvedPath);\n });\n });\n};\nLockedFS.prototype.realpathSync = function realpathSync (p, cache) {\n if (this._mu.isLocked()) {\n throw new Error('invalid sync call');\n }\n return this._fs.realpathSync(p, cache);\n};\nLockedFS.prototype.truncate = function truncate (p, len, cb) {\n var this$1 = this;\n\n this._mu.lock(function () {\n this$1._fs.truncate(p, len, function (err) {\n this$1._mu.unlock();\n cb(err);\n });\n });\n};\nLockedFS.prototype.truncateSync = function truncateSync (p, len) {\n if (this._mu.isLocked()) {\n throw new Error('invalid sync call');\n }\n return this._fs.truncateSync(p, len);\n};\nLockedFS.prototype.readFile = function readFile (fname, encoding, flag, cb) {\n var this$1 = this;\n\n this._mu.lock(function () {\n this$1._fs.readFile(fname, encoding, flag, function (err, data) {\n this$1._mu.unlock();\n cb(err, data);\n });\n });\n};\nLockedFS.prototype.readFileSync = function readFileSync (fname, encoding, flag) {\n if (this._mu.isLocked()) {\n throw new Error('invalid sync call');\n }\n return this._fs.readFileSync(fname, encoding, flag);\n};\nLockedFS.prototype.writeFile = function writeFile (fname, data, encoding, flag, mode, cb) {\n var this$1 = this;\n\n this._mu.lock(function () {\n this$1._fs.writeFile(fname, data, encoding, flag, mode, function (err) {\n this$1._mu.unlock();\n cb(err);\n });\n });\n};\nLockedFS.prototype.writeFileSync = function writeFileSync (fname, data, encoding, flag, mode) {\n if (this._mu.isLocked()) {\n throw new Error('invalid sync call');\n }\n return this._fs.writeFileSync(fname, data, encoding, flag, mode);\n};\nLockedFS.prototype.appendFile = function appendFile (fname, data, encoding, flag, mode, cb) {\n var this$1 = this;\n\n this._mu.lock(function () {\n this$1._fs.appendFile(fname, data, encoding, flag, mode, function (err) {\n this$1._mu.unlock();\n cb(err);\n });\n });\n};\nLockedFS.prototype.appendFileSync = function appendFileSync (fname, data, encoding, flag, mode) {\n if (this._mu.isLocked()) {\n throw new Error('invalid sync call');\n }\n return this._fs.appendFileSync(fname, data, encoding, flag, mode);\n};\nLockedFS.prototype.chmod = function chmod (p, isLchmod, mode, cb) {\n var this$1 = this;\n\n this._mu.lock(function () {\n this$1._fs.chmod(p, isLchmod, mode, function (err) {\n this$1._mu.unlock();\n cb(err);\n });\n });\n};\nLockedFS.prototype.chmodSync = function chmodSync (p, isLchmod, mode) {\n if (this._mu.isLocked()) {\n throw new Error('invalid sync call');\n }\n return this._fs.chmodSync(p, isLchmod, mode);\n};\nLockedFS.prototype.chown = function chown (p, isLchown, uid, gid, cb) {\n var this$1 = this;\n\n this._mu.lock(function () {\n this$1._fs.chown(p, isLchown, uid, gid, function (err) {\n this$1._mu.unlock();\n cb(err);\n });\n });\n};\nLockedFS.prototype.chownSync = function chownSync (p, isLchown, uid, gid) {\n if (this._mu.isLocked()) {\n throw new Error('invalid sync call');\n }\n return this._fs.chownSync(p, isLchown, uid, gid);\n};\nLockedFS.prototype.utimes = function utimes (p, atime, mtime, cb) {\n var this$1 = this;\n\n this._mu.lock(function () {\n this$1._fs.utimes(p, atime, mtime, function (err) {\n this$1._mu.unlock();\n cb(err);\n });\n });\n};\nLockedFS.prototype.utimesSync = function utimesSync (p, atime, mtime) {\n if (this._mu.isLocked()) {\n throw new Error('invalid sync call');\n }\n return this._fs.utimesSync(p, atime, mtime);\n};\nLockedFS.prototype.link = function link (srcpath, dstpath, cb) {\n var this$1 = this;\n\n this._mu.lock(function () {\n this$1._fs.link(srcpath, dstpath, function (err) {\n this$1._mu.unlock();\n cb(err);\n });\n });\n};\nLockedFS.prototype.linkSync = function linkSync (srcpath, dstpath) {\n if (this._mu.isLocked()) {\n throw new Error('invalid sync call');\n }\n return this._fs.linkSync(srcpath, dstpath);\n};\nLockedFS.prototype.symlink = function symlink (srcpath, dstpath, type, cb) {\n var this$1 = this;\n\n this._mu.lock(function () {\n this$1._fs.symlink(srcpath, dstpath, type, function (err) {\n this$1._mu.unlock();\n cb(err);\n });\n });\n};\nLockedFS.prototype.symlinkSync = function symlinkSync (srcpath, dstpath, type) {\n if (this._mu.isLocked()) {\n throw new Error('invalid sync call');\n }\n return this._fs.symlinkSync(srcpath, dstpath, type);\n};\nLockedFS.prototype.readlink = function readlink (p, cb) {\n var this$1 = this;\n\n this._mu.lock(function () {\n this$1._fs.readlink(p, function (err, linkString) {\n this$1._mu.unlock();\n cb(err, linkString);\n });\n });\n};\nLockedFS.prototype.readlinkSync = function readlinkSync (p) {\n if (this._mu.isLocked()) {\n throw new Error('invalid sync call');\n }\n return this._fs.readlinkSync(p);\n};\n\n/**\n * @hidden\n */\nvar deletionLogPath = '/.deletedFiles.log';\n/**\n * Given a read-only mode, makes it writable.\n * @hidden\n */\nfunction makeModeWritable(mode) {\n return 146 | mode;\n}\n/**\n * @hidden\n */\nfunction getFlag(f) {\n return FileFlag.getFileFlag(f);\n}\n/**\n * Overlays a RO file to make it writable.\n */\nvar OverlayFile = /*@__PURE__*/(function (PreloadFile$$1) {\n function OverlayFile(fs, path$$1, flag, stats, data) {\n PreloadFile$$1.call(this, fs, path$$1, flag, stats, data);\n }\n\n if ( PreloadFile$$1 ) OverlayFile.__proto__ = PreloadFile$$1;\n OverlayFile.prototype = Object.create( PreloadFile$$1 && PreloadFile$$1.prototype );\n OverlayFile.prototype.constructor = OverlayFile;\n OverlayFile.prototype.sync = function sync (cb) {\n var this$1 = this;\n\n if (!this.isDirty()) {\n cb(null);\n return;\n }\n this._fs._syncAsync(this, function (err) {\n this$1.resetDirty();\n cb(err);\n });\n };\n OverlayFile.prototype.syncSync = function syncSync () {\n if (this.isDirty()) {\n this._fs._syncSync(this);\n this.resetDirty();\n }\n };\n OverlayFile.prototype.close = function close (cb) {\n this.sync(cb);\n };\n OverlayFile.prototype.closeSync = function closeSync () {\n this.syncSync();\n };\n\n return OverlayFile;\n}(PreloadFile));\n/**\n * *INTERNAL, DO NOT USE DIRECTLY!*\n *\n * Core OverlayFS class that contains no locking whatsoever. We wrap these objects\n * in a LockedFS to prevent races.\n */\nvar UnlockedOverlayFS = /*@__PURE__*/(function (BaseFileSystem$$1) {\n function UnlockedOverlayFS(writable, readable) {\n BaseFileSystem$$1.call(this);\n this._isInitialized = false;\n this._initializeCallbacks = [];\n this._deletedFiles = {};\n this._deleteLog = '';\n // If 'true', we have scheduled a delete log update.\n this._deleteLogUpdatePending = false;\n // If 'true', a delete log update is needed after the scheduled delete log\n // update finishes.\n this._deleteLogUpdateNeeded = false;\n // If there was an error updating the delete log...\n this._deleteLogError = null;\n this._writable = writable;\n this._readable = readable;\n if (this._writable.isReadOnly()) {\n throw new ApiError(ErrorCode.EINVAL, \"Writable file system must be writable.\");\n }\n }\n\n if ( BaseFileSystem$$1 ) UnlockedOverlayFS.__proto__ = BaseFileSystem$$1;\n UnlockedOverlayFS.prototype = Object.create( BaseFileSystem$$1 && BaseFileSystem$$1.prototype );\n UnlockedOverlayFS.prototype.constructor = UnlockedOverlayFS;\n UnlockedOverlayFS.isAvailable = function isAvailable () {\n return true;\n };\n UnlockedOverlayFS.prototype.getOverlayedFileSystems = function getOverlayedFileSystems () {\n return {\n readable: this._readable,\n writable: this._writable\n };\n };\n UnlockedOverlayFS.prototype._syncAsync = function _syncAsync (file, cb) {\n var this$1 = this;\n\n this.createParentDirectoriesAsync(file.getPath(), function (err) {\n if (err) {\n return cb(err);\n }\n this$1._writable.writeFile(file.getPath(), file.getBuffer(), null, getFlag('w'), file.getStats().mode, cb);\n });\n };\n UnlockedOverlayFS.prototype._syncSync = function _syncSync (file) {\n this.createParentDirectories(file.getPath());\n this._writable.writeFileSync(file.getPath(), file.getBuffer(), null, getFlag('w'), file.getStats().mode);\n };\n UnlockedOverlayFS.prototype.getName = function getName () {\n return OverlayFS.Name;\n };\n /**\n * **INTERNAL METHOD**\n *\n * Called once to load up metadata stored on the writable file system.\n */\n UnlockedOverlayFS.prototype._initialize = function _initialize (cb) {\n var this$1 = this;\n\n var callbackArray = this._initializeCallbacks;\n var end = function (e) {\n this$1._isInitialized = !e;\n this$1._initializeCallbacks = [];\n callbackArray.forEach((function (cb) { return cb(e); }));\n };\n // if we're already initialized, immediately invoke the callback\n if (this._isInitialized) {\n return cb();\n }\n callbackArray.push(cb);\n // The first call to initialize initializes, the rest wait for it to complete.\n if (callbackArray.length !== 1) {\n return;\n }\n // Read deletion log, process into metadata.\n this._writable.readFile(deletionLogPath, 'utf8', getFlag('r'), function (err, data) {\n if (err) {\n // ENOENT === Newly-instantiated file system, and thus empty log.\n if (err.errno !== ErrorCode.ENOENT) {\n return end(err);\n }\n }\n else {\n this$1._deleteLog = data;\n }\n this$1._reparseDeletionLog();\n end();\n });\n };\n UnlockedOverlayFS.prototype.isReadOnly = function isReadOnly () { return false; };\n UnlockedOverlayFS.prototype.supportsSynch = function supportsSynch () { return this._readable.supportsSynch() && this._writable.supportsSynch(); };\n UnlockedOverlayFS.prototype.supportsLinks = function supportsLinks () { return false; };\n UnlockedOverlayFS.prototype.supportsProps = function supportsProps () { return this._readable.supportsProps() && this._writable.supportsProps(); };\n UnlockedOverlayFS.prototype.getDeletionLog = function getDeletionLog () {\n return this._deleteLog;\n };\n UnlockedOverlayFS.prototype.restoreDeletionLog = function restoreDeletionLog (log) {\n this._deleteLog = log;\n this._reparseDeletionLog();\n this.updateLog('');\n };\n UnlockedOverlayFS.prototype.rename = function rename (oldPath, newPath, cb) {\n var this$1 = this;\n\n if (!this.checkInitAsync(cb) || this.checkPathAsync(oldPath, cb) || this.checkPathAsync(newPath, cb)) {\n return;\n }\n if (oldPath === deletionLogPath || newPath === deletionLogPath) {\n return cb(ApiError.EPERM('Cannot rename deletion log.'));\n }\n // nothing to do if paths match\n if (oldPath === newPath) {\n return cb();\n }\n this.stat(oldPath, false, function (oldErr, oldStats) {\n if (oldErr) {\n return cb(oldErr);\n }\n return this$1.stat(newPath, false, function (newErr, newStats) {\n var self = this$1;\n // precondition: both oldPath and newPath exist and are dirs.\n // decreases: |files|\n // Need to move *every file/folder* currently stored on\n // readable to its new location on writable.\n function copyDirContents(files) {\n var file = files.shift();\n if (!file) {\n return cb();\n }\n var oldFile = path.resolve(oldPath, file);\n var newFile = path.resolve(newPath, file);\n // Recursion! Should work for any nested files / folders.\n self.rename(oldFile, newFile, function (err) {\n if (err) {\n return cb(err);\n }\n copyDirContents(files);\n });\n }\n var mode = 511;\n // from linux's rename(2) manpage: oldpath can specify a\n // directory. In this case, newpath must either not exist, or\n // it must specify an empty directory.\n if (oldStats.isDirectory()) {\n if (newErr) {\n if (newErr.errno !== ErrorCode.ENOENT) {\n return cb(newErr);\n }\n return this$1._writable.exists(oldPath, function (exists) {\n // simple case - both old and new are on the writable layer\n if (exists) {\n return this$1._writable.rename(oldPath, newPath, cb);\n }\n this$1._writable.mkdir(newPath, mode, function (mkdirErr) {\n if (mkdirErr) {\n return cb(mkdirErr);\n }\n this$1._readable.readdir(oldPath, function (err, files) {\n if (err) {\n return cb();\n }\n copyDirContents(files);\n });\n });\n });\n }\n mode = newStats.mode;\n if (!newStats.isDirectory()) {\n return cb(ApiError.ENOTDIR(newPath));\n }\n this$1.readdir(newPath, function (readdirErr, files) {\n if (files && files.length) {\n return cb(ApiError.ENOTEMPTY(newPath));\n }\n this$1._readable.readdir(oldPath, function (err, files) {\n if (err) {\n return cb();\n }\n copyDirContents(files);\n });\n });\n }\n if (newStats && newStats.isDirectory()) {\n return cb(ApiError.EISDIR(newPath));\n }\n this$1.readFile(oldPath, null, getFlag('r'), function (err, data) {\n if (err) {\n return cb(err);\n }\n return this$1.writeFile(newPath, data, null, getFlag('w'), oldStats.mode, function (err) {\n if (err) {\n return cb(err);\n }\n return this$1.unlink(oldPath, cb);\n });\n });\n });\n });\n };\n UnlockedOverlayFS.prototype.renameSync = function renameSync (oldPath, newPath) {\n var this$1 = this;\n\n this.checkInitialized();\n this.checkPath(oldPath);\n this.checkPath(newPath);\n if (oldPath === deletionLogPath || newPath === deletionLogPath) {\n throw ApiError.EPERM('Cannot rename deletion log.');\n }\n // Write newPath using oldPath's contents, delete oldPath.\n var oldStats = this.statSync(oldPath, false);\n if (oldStats.isDirectory()) {\n // Optimization: Don't bother moving if old === new.\n if (oldPath === newPath) {\n return;\n }\n var mode = 511;\n if (this.existsSync(newPath)) {\n var stats = this.statSync(newPath, false);\n mode = stats.mode;\n if (stats.isDirectory()) {\n if (this.readdirSync(newPath).length > 0) {\n throw ApiError.ENOTEMPTY(newPath);\n }\n }\n else {\n throw ApiError.ENOTDIR(newPath);\n }\n }\n // Take care of writable first. Move any files there, or create an empty directory\n // if it doesn't exist.\n if (this._writable.existsSync(oldPath)) {\n this._writable.renameSync(oldPath, newPath);\n }\n else if (!this._writable.existsSync(newPath)) {\n this._writable.mkdirSync(newPath, mode);\n }\n // Need to move *every file/folder* currently stored on readable to its new location\n // on writable.\n if (this._readable.existsSync(oldPath)) {\n this._readable.readdirSync(oldPath).forEach(function (name) {\n // Recursion! Should work for any nested files / folders.\n this$1.renameSync(path.resolve(oldPath, name), path.resolve(newPath, name));\n });\n }\n }\n else {\n if (this.existsSync(newPath) && this.statSync(newPath, false).isDirectory()) {\n throw ApiError.EISDIR(newPath);\n }\n this.writeFileSync(newPath, this.readFileSync(oldPath, null, getFlag('r')), null, getFlag('w'), oldStats.mode);\n }\n if (oldPath !== newPath && this.existsSync(oldPath)) {\n this.unlinkSync(oldPath);\n }\n };\n UnlockedOverlayFS.prototype.stat = function stat (p, isLstat, cb) {\n var this$1 = this;\n\n if (!this.checkInitAsync(cb)) {\n return;\n }\n this._writable.stat(p, isLstat, function (err, stat) {\n if (err && err.errno === ErrorCode.ENOENT) {\n if (this$1._deletedFiles[p]) {\n cb(ApiError.ENOENT(p));\n }\n this$1._readable.stat(p, isLstat, function (err, stat) {\n if (stat) {\n // Make the oldStat's mode writable. Preserve the topmost\n // part of the mode, which specifies if it is a file or a\n // directory.\n stat = Stats.clone(stat);\n stat.mode = makeModeWritable(stat.mode);\n }\n cb(err, stat);\n });\n }\n else {\n cb(err, stat);\n }\n });\n };\n UnlockedOverlayFS.prototype.statSync = function statSync (p, isLstat) {\n this.checkInitialized();\n try {\n return this._writable.statSync(p, isLstat);\n }\n catch (e) {\n if (this._deletedFiles[p]) {\n throw ApiError.ENOENT(p);\n }\n var oldStat = Stats.clone(this._readable.statSync(p, isLstat));\n // Make the oldStat's mode writable. Preserve the topmost part of the\n // mode, which specifies if it is a file or a directory.\n oldStat.mode = makeModeWritable(oldStat.mode);\n return oldStat;\n }\n };\n UnlockedOverlayFS.prototype.open = function open (p, flag, mode, cb) {\n var this$1 = this;\n\n if (!this.checkInitAsync(cb) || this.checkPathAsync(p, cb)) {\n return;\n }\n this.stat(p, false, function (err, stats) {\n if (stats) {\n switch (flag.pathExistsAction()) {\n case ActionType.TRUNCATE_FILE:\n return this$1.createParentDirectoriesAsync(p, function (err) {\n if (err) {\n return cb(err);\n }\n this$1._writable.open(p, flag, mode, cb);\n });\n case ActionType.NOP:\n return this$1._writable.exists(p, function (exists) {\n if (exists) {\n this$1._writable.open(p, flag, mode, cb);\n }\n else {\n // at this point we know the stats object we got is from\n // the readable FS.\n stats = Stats.clone(stats);\n stats.mode = mode;\n this$1._readable.readFile(p, null, getFlag('r'), function (readFileErr, data) {\n if (readFileErr) {\n return cb(readFileErr);\n }\n if (stats.size === -1) {\n stats.size = data.length;\n }\n var f = new OverlayFile(this$1, p, flag, stats, data);\n cb(null, f);\n });\n }\n });\n default:\n return cb(ApiError.EEXIST(p));\n }\n }\n else {\n switch (flag.pathNotExistsAction()) {\n case ActionType.CREATE_FILE:\n return this$1.createParentDirectoriesAsync(p, function (err) {\n if (err) {\n return cb(err);\n }\n return this$1._writable.open(p, flag, mode, cb);\n });\n default:\n return cb(ApiError.ENOENT(p));\n }\n }\n });\n };\n UnlockedOverlayFS.prototype.openSync = function openSync (p, flag, mode) {\n this.checkInitialized();\n this.checkPath(p);\n if (p === deletionLogPath) {\n throw ApiError.EPERM('Cannot open deletion log.');\n }\n if (this.existsSync(p)) {\n switch (flag.pathExistsAction()) {\n case ActionType.TRUNCATE_FILE:\n this.createParentDirectories(p);\n return this._writable.openSync(p, flag, mode);\n case ActionType.NOP:\n if (this._writable.existsSync(p)) {\n return this._writable.openSync(p, flag, mode);\n }\n else {\n // Create an OverlayFile.\n var buf = this._readable.readFileSync(p, null, getFlag('r'));\n var stats = Stats.clone(this._readable.statSync(p, false));\n stats.mode = mode;\n return new OverlayFile(this, p, flag, stats, buf);\n }\n default:\n throw ApiError.EEXIST(p);\n }\n }\n else {\n switch (flag.pathNotExistsAction()) {\n case ActionType.CREATE_FILE:\n this.createParentDirectories(p);\n return this._writable.openSync(p, flag, mode);\n default:\n throw ApiError.ENOENT(p);\n }\n }\n };\n UnlockedOverlayFS.prototype.unlink = function unlink (p, cb) {\n var this$1 = this;\n\n if (!this.checkInitAsync(cb) || this.checkPathAsync(p, cb)) {\n return;\n }\n this.exists(p, function (exists) {\n if (!exists) {\n return cb(ApiError.ENOENT(p));\n }\n this$1._writable.exists(p, function (writableExists) {\n if (writableExists) {\n return this$1._writable.unlink(p, function (err) {\n if (err) {\n return cb(err);\n }\n this$1.exists(p, function (readableExists) {\n if (readableExists) {\n this$1.deletePath(p);\n }\n cb(null);\n });\n });\n }\n else {\n // if this only exists on the readable FS, add it to the\n // delete map.\n this$1.deletePath(p);\n cb(null);\n }\n });\n });\n };\n UnlockedOverlayFS.prototype.unlinkSync = function unlinkSync (p) {\n this.checkInitialized();\n this.checkPath(p);\n if (this.existsSync(p)) {\n if (this._writable.existsSync(p)) {\n this._writable.unlinkSync(p);\n }\n // if it still exists add to the delete log\n if (this.existsSync(p)) {\n this.deletePath(p);\n }\n }\n else {\n throw ApiError.ENOENT(p);\n }\n };\n UnlockedOverlayFS.prototype.rmdir = function rmdir (p, cb) {\n var this$1 = this;\n\n if (!this.checkInitAsync(cb)) {\n return;\n }\n var rmdirLower = function () {\n this$1.readdir(p, function (err, files) {\n if (err) {\n return cb(err);\n }\n if (files.length) {\n return cb(ApiError.ENOTEMPTY(p));\n }\n this$1.deletePath(p);\n cb(null);\n });\n };\n this.exists(p, function (exists) {\n if (!exists) {\n return cb(ApiError.ENOENT(p));\n }\n this$1._writable.exists(p, function (writableExists) {\n if (writableExists) {\n this$1._writable.rmdir(p, function (err) {\n if (err) {\n return cb(err);\n }\n this$1._readable.exists(p, function (readableExists) {\n if (readableExists) {\n rmdirLower();\n }\n else {\n cb();\n }\n });\n });\n }\n else {\n rmdirLower();\n }\n });\n });\n };\n UnlockedOverlayFS.prototype.rmdirSync = function rmdirSync (p) {\n this.checkInitialized();\n if (this.existsSync(p)) {\n if (this._writable.existsSync(p)) {\n this._writable.rmdirSync(p);\n }\n if (this.existsSync(p)) {\n // Check if directory is empty.\n if (this.readdirSync(p).length > 0) {\n throw ApiError.ENOTEMPTY(p);\n }\n else {\n this.deletePath(p);\n }\n }\n }\n else {\n throw ApiError.ENOENT(p);\n }\n };\n UnlockedOverlayFS.prototype.mkdir = function mkdir (p, mode, cb) {\n var this$1 = this;\n\n if (!this.checkInitAsync(cb)) {\n return;\n }\n this.exists(p, function (exists) {\n if (exists) {\n return cb(ApiError.EEXIST(p));\n }\n // The below will throw should any of the parent directories\n // fail to exist on _writable.\n this$1.createParentDirectoriesAsync(p, function (err) {\n if (err) {\n return cb(err);\n }\n this$1._writable.mkdir(p, mode, cb);\n });\n });\n };\n UnlockedOverlayFS.prototype.mkdirSync = function mkdirSync (p, mode) {\n this.checkInitialized();\n if (this.existsSync(p)) {\n throw ApiError.EEXIST(p);\n }\n else {\n // The below will throw should any of the parent directories fail to exist\n // on _writable.\n this.createParentDirectories(p);\n this._writable.mkdirSync(p, mode);\n }\n };\n UnlockedOverlayFS.prototype.readdir = function readdir (p, cb) {\n var this$1 = this;\n\n if (!this.checkInitAsync(cb)) {\n return;\n }\n this.stat(p, false, function (err, dirStats) {\n if (err) {\n return cb(err);\n }\n if (!dirStats.isDirectory()) {\n return cb(ApiError.ENOTDIR(p));\n }\n this$1._writable.readdir(p, function (err, wFiles) {\n if (err && err.code !== 'ENOENT') {\n return cb(err);\n }\n else if (err || !wFiles) {\n wFiles = [];\n }\n this$1._readable.readdir(p, function (err, rFiles) {\n // if the directory doesn't exist on the lower FS set rFiles\n // here to simplify the following code.\n if (err || !rFiles) {\n rFiles = [];\n }\n // Readdir in both, check delete log on read-only file system's files, merge, return.\n var seenMap = {};\n var filtered = wFiles.concat(rFiles.filter(function (fPath) { return !this$1._deletedFiles[(p + \"/\" + fPath)]; })).filter(function (fPath) {\n // Remove duplicates.\n var result = !seenMap[fPath];\n seenMap[fPath] = true;\n return result;\n });\n cb(null, filtered);\n });\n });\n });\n };\n UnlockedOverlayFS.prototype.readdirSync = function readdirSync (p) {\n var this$1 = this;\n\n this.checkInitialized();\n var dirStats = this.statSync(p, false);\n if (!dirStats.isDirectory()) {\n throw ApiError.ENOTDIR(p);\n }\n // Readdir in both, check delete log on RO file system's listing, merge, return.\n var contents = [];\n try {\n contents = contents.concat(this._writable.readdirSync(p));\n }\n catch (e) {\n // NOP.\n }\n try {\n contents = contents.concat(this._readable.readdirSync(p).filter(function (fPath) { return !this$1._deletedFiles[(p + \"/\" + fPath)]; }));\n }\n catch (e) {\n // NOP.\n }\n var seenMap = {};\n return contents.filter(function (fileP) {\n var result = !seenMap[fileP];\n seenMap[fileP] = true;\n return result;\n });\n };\n UnlockedOverlayFS.prototype.exists = function exists (p, cb) {\n var this$1 = this;\n\n // Cannot pass an error back to callback, so throw an exception instead\n // if not initialized.\n this.checkInitialized();\n this._writable.exists(p, function (existsWritable) {\n if (existsWritable) {\n return cb(true);\n }\n this$1._readable.exists(p, function (existsReadable) {\n cb(existsReadable && this$1._deletedFiles[p] !== true);\n });\n });\n };\n UnlockedOverlayFS.prototype.existsSync = function existsSync (p) {\n this.checkInitialized();\n return this._writable.existsSync(p) || (this._readable.existsSync(p) && this._deletedFiles[p] !== true);\n };\n UnlockedOverlayFS.prototype.chmod = function chmod (p, isLchmod, mode, cb) {\n var this$1 = this;\n\n if (!this.checkInitAsync(cb)) {\n return;\n }\n this.operateOnWritableAsync(p, function (err) {\n if (err) {\n return cb(err);\n }\n else {\n this$1._writable.chmod(p, isLchmod, mode, cb);\n }\n });\n };\n UnlockedOverlayFS.prototype.chmodSync = function chmodSync (p, isLchmod, mode) {\n var this$1 = this;\n\n this.checkInitialized();\n this.operateOnWritable(p, function () {\n this$1._writable.chmodSync(p, isLchmod, mode);\n });\n };\n UnlockedOverlayFS.prototype.chown = function chown (p, isLchmod, uid, gid, cb) {\n var this$1 = this;\n\n if (!this.checkInitAsync(cb)) {\n return;\n }\n this.operateOnWritableAsync(p, function (err) {\n if (err) {\n return cb(err);\n }\n else {\n this$1._writable.chown(p, isLchmod, uid, gid, cb);\n }\n });\n };\n UnlockedOverlayFS.prototype.chownSync = function chownSync (p, isLchown, uid, gid) {\n var this$1 = this;\n\n this.checkInitialized();\n this.operateOnWritable(p, function () {\n this$1._writable.chownSync(p, isLchown, uid, gid);\n });\n };\n UnlockedOverlayFS.prototype.utimes = function utimes (p, atime, mtime, cb) {\n var this$1 = this;\n\n if (!this.checkInitAsync(cb)) {\n return;\n }\n this.operateOnWritableAsync(p, function (err) {\n if (err) {\n return cb(err);\n }\n else {\n this$1._writable.utimes(p, atime, mtime, cb);\n }\n });\n };\n UnlockedOverlayFS.prototype.utimesSync = function utimesSync (p, atime, mtime) {\n var this$1 = this;\n\n this.checkInitialized();\n this.operateOnWritable(p, function () {\n this$1._writable.utimesSync(p, atime, mtime);\n });\n };\n UnlockedOverlayFS.prototype.deletePath = function deletePath (p) {\n this._deletedFiles[p] = true;\n this.updateLog((\"d\" + p + \"\\n\"));\n };\n UnlockedOverlayFS.prototype.updateLog = function updateLog (addition) {\n var this$1 = this;\n\n this._deleteLog += addition;\n if (this._deleteLogUpdatePending) {\n this._deleteLogUpdateNeeded = true;\n }\n else {\n this._deleteLogUpdatePending = true;\n this._writable.writeFile(deletionLogPath, this._deleteLog, 'utf8', FileFlag.getFileFlag('w'), 420, function (e) {\n this$1._deleteLogUpdatePending = false;\n if (e) {\n this$1._deleteLogError = e;\n }\n else if (this$1._deleteLogUpdateNeeded) {\n this$1._deleteLogUpdateNeeded = false;\n this$1.updateLog('');\n }\n });\n }\n };\n UnlockedOverlayFS.prototype._reparseDeletionLog = function _reparseDeletionLog () {\n var this$1 = this;\n\n this._deletedFiles = {};\n this._deleteLog.split('\\n').forEach(function (path$$1) {\n // If the log entry begins w/ 'd', it's a deletion.\n this$1._deletedFiles[path$$1.slice(1)] = path$$1.slice(0, 1) === 'd';\n });\n };\n UnlockedOverlayFS.prototype.checkInitialized = function checkInitialized () {\n if (!this._isInitialized) {\n throw new ApiError(ErrorCode.EPERM, \"OverlayFS is not initialized. Please initialize OverlayFS using its initialize() method before using it.\");\n }\n else if (this._deleteLogError !== null) {\n var e = this._deleteLogError;\n this._deleteLogError = null;\n throw e;\n }\n };\n UnlockedOverlayFS.prototype.checkInitAsync = function checkInitAsync (cb) {\n if (!this._isInitialized) {\n cb(new ApiError(ErrorCode.EPERM, \"OverlayFS is not initialized. Please initialize OverlayFS using its initialize() method before using it.\"));\n return false;\n }\n else if (this._deleteLogError !== null) {\n var e = this._deleteLogError;\n this._deleteLogError = null;\n cb(e);\n return false;\n }\n return true;\n };\n UnlockedOverlayFS.prototype.checkPath = function checkPath (p) {\n if (p === deletionLogPath) {\n throw ApiError.EPERM(p);\n }\n };\n UnlockedOverlayFS.prototype.checkPathAsync = function checkPathAsync (p, cb) {\n if (p === deletionLogPath) {\n cb(ApiError.EPERM(p));\n return true;\n }\n return false;\n };\n UnlockedOverlayFS.prototype.createParentDirectoriesAsync = function createParentDirectoriesAsync (p, cb) {\n var parent = path.dirname(p);\n var toCreate = [];\n var self = this;\n this._writable.stat(parent, false, statDone);\n function statDone(err, stat) {\n if (err) {\n if (parent === \"/\") {\n cb(new ApiError(ErrorCode.EBUSY, \"Invariant failed: root does not exist!\"));\n }\n else {\n toCreate.push(parent);\n parent = path.dirname(parent);\n self._writable.stat(parent, false, statDone);\n }\n }\n else {\n createParents();\n }\n }\n function createParents() {\n if (!toCreate.length) {\n return cb();\n }\n var dir = toCreate.pop();\n self._readable.stat(dir, false, function (err, stats) {\n // stop if we couldn't read the dir\n if (!stats) {\n return cb();\n }\n self._writable.mkdir(dir, stats.mode, function (err) {\n if (err) {\n return cb(err);\n }\n createParents();\n });\n });\n }\n };\n /**\n * With the given path, create the needed parent directories on the writable storage\n * should they not exist. Use modes from the read-only storage.\n */\n UnlockedOverlayFS.prototype.createParentDirectories = function createParentDirectories (p) {\n var this$1 = this;\n\n var parent = path.dirname(p), toCreate = [];\n while (!this._writable.existsSync(parent)) {\n toCreate.push(parent);\n parent = path.dirname(parent);\n }\n toCreate = toCreate.reverse();\n toCreate.forEach(function (p) {\n this$1._writable.mkdirSync(p, this$1.statSync(p, false).mode);\n });\n };\n /**\n * Helper function:\n * - Ensures p is on writable before proceeding. Throws an error if it doesn't exist.\n * - Calls f to perform operation on writable.\n */\n UnlockedOverlayFS.prototype.operateOnWritable = function operateOnWritable (p, f) {\n if (this.existsSync(p)) {\n if (!this._writable.existsSync(p)) {\n // File is on readable storage. Copy to writable storage before\n // changing its mode.\n this.copyToWritable(p);\n }\n f();\n }\n else {\n throw ApiError.ENOENT(p);\n }\n };\n UnlockedOverlayFS.prototype.operateOnWritableAsync = function operateOnWritableAsync (p, cb) {\n var this$1 = this;\n\n this.exists(p, function (exists) {\n if (!exists) {\n return cb(ApiError.ENOENT(p));\n }\n this$1._writable.exists(p, function (existsWritable) {\n if (existsWritable) {\n cb();\n }\n else {\n return this$1.copyToWritableAsync(p, cb);\n }\n });\n });\n };\n /**\n * Copy from readable to writable storage.\n * PRECONDITION: File does not exist on writable storage.\n */\n UnlockedOverlayFS.prototype.copyToWritable = function copyToWritable (p) {\n var pStats = this.statSync(p, false);\n if (pStats.isDirectory()) {\n this._writable.mkdirSync(p, pStats.mode);\n }\n else {\n this.writeFileSync(p, this._readable.readFileSync(p, null, getFlag('r')), null, getFlag('w'), this.statSync(p, false).mode);\n }\n };\n UnlockedOverlayFS.prototype.copyToWritableAsync = function copyToWritableAsync (p, cb) {\n var this$1 = this;\n\n this.stat(p, false, function (err, pStats) {\n if (err) {\n return cb(err);\n }\n if (pStats.isDirectory()) {\n return this$1._writable.mkdir(p, pStats.mode, cb);\n }\n // need to copy file.\n this$1._readable.readFile(p, null, getFlag('r'), function (err, data) {\n if (err) {\n return cb(err);\n }\n this$1.writeFile(p, data, null, getFlag('w'), pStats.mode, cb);\n });\n });\n };\n\n return UnlockedOverlayFS;\n}(BaseFileSystem));\n/**\n * OverlayFS makes a read-only filesystem writable by storing writes on a second,\n * writable file system. Deletes are persisted via metadata stored on the writable\n * file system.\n */\nvar OverlayFS = /*@__PURE__*/(function (LockedFS$$1) {\n function OverlayFS(writable, readable) {\n LockedFS$$1.call(this, new UnlockedOverlayFS(writable, readable));\n }\n\n if ( LockedFS$$1 ) OverlayFS.__proto__ = LockedFS$$1;\n OverlayFS.prototype = Object.create( LockedFS$$1 && LockedFS$$1.prototype );\n OverlayFS.prototype.constructor = OverlayFS;\n /**\n * Constructs and initializes an OverlayFS instance with the given options.\n */\n OverlayFS.Create = function Create (opts, cb) {\n try {\n var fs = new OverlayFS(opts.writable, opts.readable);\n fs._initialize(function (e) {\n cb(e, fs);\n });\n }\n catch (e) {\n cb(e);\n }\n };\n OverlayFS.isAvailable = function isAvailable () {\n return UnlockedOverlayFS.isAvailable();\n };\n OverlayFS.prototype.getOverlayedFileSystems = function getOverlayedFileSystems () {\n return LockedFS$$1.prototype.getFSUnlocked.call(this).getOverlayedFileSystems();\n };\n OverlayFS.prototype.unwrap = function unwrap () {\n return LockedFS$$1.prototype.getFSUnlocked.call(this);\n };\n OverlayFS.prototype._initialize = function _initialize (cb) {\n LockedFS$$1.prototype.getFSUnlocked.call(this)._initialize(cb);\n };\n\n return OverlayFS;\n}(LockedFS));\nOverlayFS.Name = \"OverlayFS\";\nOverlayFS.Options = {\n writable: {\n type: \"object\",\n description: \"The file system to write modified files to.\"\n },\n readable: {\n type: \"object\",\n description: \"The file system that initially populates this file system.\"\n }\n};\n\n/**\n * @hidden\n */\nvar SpecialArgType;\n(function (SpecialArgType) {\n // Callback\n SpecialArgType[SpecialArgType[\"CB\"] = 0] = \"CB\";\n // File descriptor\n SpecialArgType[SpecialArgType[\"FD\"] = 1] = \"FD\";\n // API error\n SpecialArgType[SpecialArgType[\"API_ERROR\"] = 2] = \"API_ERROR\";\n // Stats object\n SpecialArgType[SpecialArgType[\"STATS\"] = 3] = \"STATS\";\n // Initial probe for file system information.\n SpecialArgType[SpecialArgType[\"PROBE\"] = 4] = \"PROBE\";\n // FileFlag object.\n SpecialArgType[SpecialArgType[\"FILEFLAG\"] = 5] = \"FILEFLAG\";\n // Buffer object.\n SpecialArgType[SpecialArgType[\"BUFFER\"] = 6] = \"BUFFER\";\n // Generic Error object.\n SpecialArgType[SpecialArgType[\"ERROR\"] = 7] = \"ERROR\";\n})(SpecialArgType || (SpecialArgType = {}));\n/**\n * Converts callback arguments into ICallbackArgument objects, and back\n * again.\n * @hidden\n */\nvar CallbackArgumentConverter = function CallbackArgumentConverter() {\n this._callbacks = {};\n this._nextId = 0;\n};\nCallbackArgumentConverter.prototype.toRemoteArg = function toRemoteArg (cb) {\n var id = this._nextId++;\n this._callbacks[id] = cb;\n return {\n type: SpecialArgType.CB,\n id: id\n };\n};\nCallbackArgumentConverter.prototype.toLocalArg = function toLocalArg (id) {\n var cb = this._callbacks[id];\n delete this._callbacks[id];\n return cb;\n};\n/**\n * @hidden\n */\nvar FileDescriptorArgumentConverter = function FileDescriptorArgumentConverter() {\n this._fileDescriptors = {};\n this._nextId = 0;\n};\nFileDescriptorArgumentConverter.prototype.toRemoteArg = function toRemoteArg (fd, p, flag, cb) {\n var id = this._nextId++;\n var data;\n var stat;\n this._fileDescriptors[id] = fd;\n // Extract needed information asynchronously.\n fd.stat(function (err, stats) {\n if (err) {\n cb(err);\n }\n else {\n stat = bufferToTransferrableObject(stats.toBuffer());\n // If it's a readable flag, we need to grab contents.\n if (flag.isReadable()) {\n fd.read(Buffer.alloc(stats.size), 0, stats.size, 0, function (err, bytesRead, buff) {\n if (err) {\n cb(err);\n }\n else {\n data = bufferToTransferrableObject(buff);\n cb(null, {\n type: SpecialArgType.FD,\n id: id,\n data: data,\n stat: stat,\n path: p,\n flag: flag.getFlagString()\n });\n }\n });\n }\n else {\n // File is not readable, which means writing to it will append or\n // truncate/replace existing contents. Return an empty arraybuffer.\n cb(null, {\n type: SpecialArgType.FD,\n id: id,\n data: new ArrayBuffer(0),\n stat: stat,\n path: p,\n flag: flag.getFlagString()\n });\n }\n }\n });\n};\nFileDescriptorArgumentConverter.prototype.applyFdAPIRequest = function applyFdAPIRequest (request, cb) {\n var this$1 = this;\n\n var fdArg = request.args[0];\n this._applyFdChanges(fdArg, function (err, fd) {\n if (err) {\n cb(err);\n }\n else {\n // Apply method on now-changed file descriptor.\n fd[request.method](function (e) {\n if (request.method === 'close') {\n delete this$1._fileDescriptors[fdArg.id];\n }\n cb(e);\n });\n }\n });\n};\nFileDescriptorArgumentConverter.prototype._applyFdChanges = function _applyFdChanges (remoteFd, cb) {\n var fd = this._fileDescriptors[remoteFd.id], data = transferrableObjectToBuffer(remoteFd.data), remoteStats = Stats.fromBuffer(transferrableObjectToBuffer(remoteFd.stat));\n // Write data if the file is writable.\n var flag = FileFlag.getFileFlag(remoteFd.flag);\n if (flag.isWriteable()) {\n // Appendable: Write to end of file.\n // Writeable: Replace entire contents of file.\n fd.write(data, 0, data.length, flag.isAppendable() ? fd.getPos() : 0, function (e) {\n function applyStatChanges() {\n // Check if mode changed.\n fd.stat(function (e, stats) {\n if (e) {\n cb(e);\n }\n else {\n if (stats.mode !== remoteStats.mode) {\n fd.chmod(remoteStats.mode, function (e) {\n cb(e, fd);\n });\n }\n else {\n cb(e, fd);\n }\n }\n });\n }\n if (e) {\n cb(e);\n }\n else {\n // If writeable & not appendable, we need to ensure file contents are\n // identical to those from the remote FD. Thus, we truncate to the\n // length of the remote file.\n if (!flag.isAppendable()) {\n fd.truncate(data.length, function () {\n applyStatChanges();\n });\n }\n else {\n applyStatChanges();\n }\n }\n });\n }\n else {\n cb(null, fd);\n }\n};\n/**\n * @hidden\n */\nfunction apiErrorLocal2Remote(e) {\n return {\n type: SpecialArgType.API_ERROR,\n errorData: bufferToTransferrableObject(e.writeToBuffer())\n };\n}\n/**\n * @hidden\n */\nfunction apiErrorRemote2Local(e) {\n return ApiError.fromBuffer(transferrableObjectToBuffer(e.errorData));\n}\n/**\n * @hidden\n */\nfunction errorLocal2Remote(e) {\n return {\n type: SpecialArgType.ERROR,\n name: e.name,\n message: e.message,\n stack: e.stack\n };\n}\n/**\n * @hidden\n */\nfunction errorRemote2Local(e) {\n var cnstr = toExport[e.name];\n if (typeof (cnstr) !== 'function') {\n cnstr = Error;\n }\n var err = new cnstr(e.message);\n err.stack = e.stack;\n return err;\n}\n/**\n * @hidden\n */\nfunction statsLocal2Remote(stats) {\n return {\n type: SpecialArgType.STATS,\n statsData: bufferToTransferrableObject(stats.toBuffer())\n };\n}\n/**\n * @hidden\n */\nfunction statsRemote2Local(stats) {\n return Stats.fromBuffer(transferrableObjectToBuffer(stats.statsData));\n}\n/**\n * @hidden\n */\nfunction fileFlagLocal2Remote(flag) {\n return {\n type: SpecialArgType.FILEFLAG,\n flagStr: flag.getFlagString()\n };\n}\n/**\n * @hidden\n */\nfunction fileFlagRemote2Local(remoteFlag) {\n return FileFlag.getFileFlag(remoteFlag.flagStr);\n}\n/**\n * @hidden\n */\nfunction bufferToTransferrableObject(buff) {\n return buffer2ArrayBuffer(buff);\n}\n/**\n * @hidden\n */\nfunction transferrableObjectToBuffer(buff) {\n return arrayBuffer2Buffer(buff);\n}\n/**\n * @hidden\n */\nfunction bufferLocal2Remote(buff) {\n return {\n type: SpecialArgType.BUFFER,\n data: bufferToTransferrableObject(buff)\n };\n}\n/**\n * @hidden\n */\nfunction bufferRemote2Local(buffArg) {\n return transferrableObjectToBuffer(buffArg.data);\n}\n/**\n * @hidden\n */\nfunction isAPIRequest(data) {\n return data && typeof data === 'object' && data.hasOwnProperty('browserfsMessage') && data['browserfsMessage'];\n}\n/**\n * @hidden\n */\nfunction isAPIResponse(data) {\n return data && typeof data === 'object' && data.hasOwnProperty('browserfsMessage') && data['browserfsMessage'];\n}\n/**\n * Represents a remote file in a different worker/thread.\n */\nvar WorkerFile = /*@__PURE__*/(function (PreloadFile$$1) {\n function WorkerFile(_fs, _path, _flag, _stat, remoteFdId, contents) {\n PreloadFile$$1.call(this, _fs, _path, _flag, _stat, contents);\n this._remoteFdId = remoteFdId;\n }\n\n if ( PreloadFile$$1 ) WorkerFile.__proto__ = PreloadFile$$1;\n WorkerFile.prototype = Object.create( PreloadFile$$1 && PreloadFile$$1.prototype );\n WorkerFile.prototype.constructor = WorkerFile;\n WorkerFile.prototype.getRemoteFdId = function getRemoteFdId () {\n return this._remoteFdId;\n };\n /**\n * @hidden\n */\n WorkerFile.prototype.toRemoteArg = function toRemoteArg () {\n return {\n type: SpecialArgType.FD,\n id: this._remoteFdId,\n data: bufferToTransferrableObject(this.getBuffer()),\n stat: bufferToTransferrableObject(this.getStats().toBuffer()),\n path: this.getPath(),\n flag: this.getFlag().getFlagString()\n };\n };\n WorkerFile.prototype.sync = function sync (cb) {\n this._syncClose('sync', cb);\n };\n WorkerFile.prototype.close = function close (cb) {\n this._syncClose('close', cb);\n };\n WorkerFile.prototype._syncClose = function _syncClose (type, cb) {\n var this$1 = this;\n\n if (this.isDirty()) {\n this._fs.syncClose(type, this, function (e) {\n if (!e) {\n this$1.resetDirty();\n }\n cb(e);\n });\n }\n else {\n cb();\n }\n };\n\n return WorkerFile;\n}(PreloadFile));\n/**\n * WorkerFS lets you access a BrowserFS instance that is running in a different\n * JavaScript context (e.g. access BrowserFS in one of your WebWorkers, or\n * access BrowserFS running on the main page from a WebWorker).\n *\n * For example, to have a WebWorker access files in the main browser thread,\n * do the following:\n *\n * MAIN BROWSER THREAD:\n *\n * ```javascript\n * // Listen for remote file system requests.\n * BrowserFS.FileSystem.WorkerFS.attachRemoteListener(webWorkerObject);\n * ```\n *\n * WEBWORKER THREAD:\n *\n * ```javascript\n * // Set the remote file system as the root file system.\n * BrowserFS.configure({ fs: \"WorkerFS\", options: { worker: self }}, function(e) {\n * // Ready!\n * });\n * ```\n *\n * Note that synchronous operations are not permitted on the WorkerFS, regardless\n * of the configuration option of the remote FS.\n */\nvar WorkerFS = /*@__PURE__*/(function (BaseFileSystem$$1) {\n function WorkerFS(worker) {\n var this$1 = this;\n\n BaseFileSystem$$1.call(this);\n this._callbackConverter = new CallbackArgumentConverter();\n this._isInitialized = false;\n this._isReadOnly = false;\n this._supportLinks = false;\n this._supportProps = false;\n this._worker = worker;\n this._worker.addEventListener('message', function (e) {\n var resp = e.data;\n if (isAPIResponse(resp)) {\n var i;\n var args = resp.args;\n var fixedArgs = new Array(args.length);\n // Dispatch event to correct id.\n for (i = 0; i < fixedArgs.length; i++) {\n fixedArgs[i] = this$1._argRemote2Local(args[i]);\n }\n this$1._callbackConverter.toLocalArg(resp.cbId).apply(null, fixedArgs);\n }\n });\n }\n\n if ( BaseFileSystem$$1 ) WorkerFS.__proto__ = BaseFileSystem$$1;\n WorkerFS.prototype = Object.create( BaseFileSystem$$1 && BaseFileSystem$$1.prototype );\n WorkerFS.prototype.constructor = WorkerFS;\n WorkerFS.Create = function Create (opts, cb) {\n var fs = new WorkerFS(opts.worker);\n fs._initialize(function () {\n cb(null, fs);\n });\n };\n WorkerFS.isAvailable = function isAvailable () {\n return typeof (importScripts) !== 'undefined' || typeof (Worker) !== 'undefined';\n };\n /**\n * Attaches a listener to the remote worker for file system requests.\n */\n WorkerFS.attachRemoteListener = function attachRemoteListener (worker) {\n var fdConverter = new FileDescriptorArgumentConverter();\n function argLocal2Remote(arg, requestArgs, cb) {\n switch (typeof arg) {\n case 'object':\n if (arg instanceof Stats) {\n cb(null, statsLocal2Remote(arg));\n }\n else if (arg instanceof ApiError) {\n cb(null, apiErrorLocal2Remote(arg));\n }\n else if (arg instanceof BaseFile) {\n // Pass in p and flags from original request.\n cb(null, fdConverter.toRemoteArg(arg, requestArgs[0], requestArgs[1], cb));\n }\n else if (arg instanceof FileFlag) {\n cb(null, fileFlagLocal2Remote(arg));\n }\n else if (arg instanceof Buffer) {\n cb(null, bufferLocal2Remote(arg));\n }\n else if (arg instanceof Error) {\n cb(null, errorLocal2Remote(arg));\n }\n else {\n cb(null, arg);\n }\n break;\n default:\n cb(null, arg);\n break;\n }\n }\n function argRemote2Local(arg, fixedRequestArgs) {\n if (!arg) {\n return arg;\n }\n switch (typeof arg) {\n case 'object':\n if (typeof arg['type'] === 'number') {\n var specialArg = arg;\n switch (specialArg.type) {\n case SpecialArgType.CB:\n var cbId = arg.id;\n return function () {\n var arguments$1 = arguments;\n\n var i;\n var fixedArgs = new Array(arguments.length);\n var message, countdown = arguments.length;\n function abortAndSendError(err) {\n if (countdown > 0) {\n countdown = -1;\n message = {\n browserfsMessage: true,\n cbId: cbId,\n args: [apiErrorLocal2Remote(err)]\n };\n worker.postMessage(message);\n }\n }\n for (i = 0; i < arguments.length; i++) {\n // Capture i and argument.\n (function (i, arg) {\n argLocal2Remote(arg, fixedRequestArgs, function (err, fixedArg) {\n fixedArgs[i] = fixedArg;\n if (err) {\n abortAndSendError(err);\n }\n else if (--countdown === 0) {\n message = {\n browserfsMessage: true,\n cbId: cbId,\n args: fixedArgs\n };\n worker.postMessage(message);\n }\n });\n })(i, arguments$1[i]);\n }\n if (arguments.length === 0) {\n message = {\n browserfsMessage: true,\n cbId: cbId,\n args: fixedArgs\n };\n worker.postMessage(message);\n }\n };\n case SpecialArgType.API_ERROR:\n return apiErrorRemote2Local(specialArg);\n case SpecialArgType.STATS:\n return statsRemote2Local(specialArg);\n case SpecialArgType.FILEFLAG:\n return fileFlagRemote2Local(specialArg);\n case SpecialArgType.BUFFER:\n return bufferRemote2Local(specialArg);\n case SpecialArgType.ERROR:\n return errorRemote2Local(specialArg);\n default:\n // No idea what this is.\n return arg;\n }\n }\n else {\n return arg;\n }\n default:\n return arg;\n }\n }\n worker.addEventListener('message', function (e) {\n var request = e.data;\n if (isAPIRequest(request)) {\n var args = request.args, fixedArgs = new Array(args.length);\n switch (request.method) {\n case 'close':\n case 'sync':\n (function () {\n // File descriptor-relative methods.\n var remoteCb = args[1];\n fdConverter.applyFdAPIRequest(request, function (err) {\n // Send response.\n var response = {\n browserfsMessage: true,\n cbId: remoteCb.id,\n args: err ? [apiErrorLocal2Remote(err)] : []\n };\n worker.postMessage(response);\n });\n })();\n break;\n case 'probe':\n (function () {\n var rootFs = _fsMock.getRootFS(), remoteCb = args[1], probeResponse = {\n type: SpecialArgType.PROBE,\n isReadOnly: rootFs.isReadOnly(),\n supportsLinks: rootFs.supportsLinks(),\n supportsProps: rootFs.supportsProps()\n }, response = {\n browserfsMessage: true,\n cbId: remoteCb.id,\n args: [probeResponse]\n };\n worker.postMessage(response);\n })();\n break;\n default:\n // File system methods.\n for (var i = 0; i < args.length; i++) {\n fixedArgs[i] = argRemote2Local(args[i], fixedArgs);\n }\n var rootFS = _fsMock.getRootFS();\n rootFS[request.method].apply(rootFS, fixedArgs);\n break;\n }\n }\n });\n };\n WorkerFS.prototype.getName = function getName () {\n return WorkerFS.Name;\n };\n WorkerFS.prototype.isReadOnly = function isReadOnly () { return this._isReadOnly; };\n WorkerFS.prototype.supportsSynch = function supportsSynch () { return false; };\n WorkerFS.prototype.supportsLinks = function supportsLinks () { return this._supportLinks; };\n WorkerFS.prototype.supportsProps = function supportsProps () { return this._supportProps; };\n WorkerFS.prototype.rename = function rename (oldPath, newPath, cb) {\n this._rpc('rename', arguments);\n };\n WorkerFS.prototype.stat = function stat (p, isLstat, cb) {\n this._rpc('stat', arguments);\n };\n WorkerFS.prototype.open = function open (p, flag, mode, cb) {\n this._rpc('open', arguments);\n };\n WorkerFS.prototype.unlink = function unlink (p, cb) {\n this._rpc('unlink', arguments);\n };\n WorkerFS.prototype.rmdir = function rmdir (p, cb) {\n this._rpc('rmdir', arguments);\n };\n WorkerFS.prototype.mkdir = function mkdir (p, mode, cb) {\n this._rpc('mkdir', arguments);\n };\n WorkerFS.prototype.readdir = function readdir (p, cb) {\n this._rpc('readdir', arguments);\n };\n WorkerFS.prototype.exists = function exists (p, cb) {\n this._rpc('exists', arguments);\n };\n WorkerFS.prototype.realpath = function realpath (p, cache, cb) {\n this._rpc('realpath', arguments);\n };\n WorkerFS.prototype.truncate = function truncate (p, len, cb) {\n this._rpc('truncate', arguments);\n };\n WorkerFS.prototype.readFile = function readFile (fname, encoding, flag, cb) {\n this._rpc('readFile', arguments);\n };\n WorkerFS.prototype.writeFile = function writeFile (fname, data, encoding, flag, mode, cb) {\n this._rpc('writeFile', arguments);\n };\n WorkerFS.prototype.appendFile = function appendFile (fname, data, encoding, flag, mode, cb) {\n this._rpc('appendFile', arguments);\n };\n WorkerFS.prototype.chmod = function chmod (p, isLchmod, mode, cb) {\n this._rpc('chmod', arguments);\n };\n WorkerFS.prototype.chown = function chown (p, isLchown, uid, gid, cb) {\n this._rpc('chown', arguments);\n };\n WorkerFS.prototype.utimes = function utimes (p, atime, mtime, cb) {\n this._rpc('utimes', arguments);\n };\n WorkerFS.prototype.link = function link (srcpath, dstpath, cb) {\n this._rpc('link', arguments);\n };\n WorkerFS.prototype.symlink = function symlink (srcpath, dstpath, type, cb) {\n this._rpc('symlink', arguments);\n };\n WorkerFS.prototype.readlink = function readlink (p, cb) {\n this._rpc('readlink', arguments);\n };\n WorkerFS.prototype.syncClose = function syncClose (method, fd, cb) {\n this._worker.postMessage({\n browserfsMessage: true,\n method: method,\n args: [fd.toRemoteArg(), this._callbackConverter.toRemoteArg(cb)]\n });\n };\n /**\n * Called once both local and remote sides are set up.\n */\n WorkerFS.prototype._initialize = function _initialize (cb) {\n var this$1 = this;\n\n if (!this._isInitialized) {\n var message = {\n browserfsMessage: true,\n method: 'probe',\n args: [this._argLocal2Remote(emptyBuffer()), this._callbackConverter.toRemoteArg(function (probeResponse) {\n this$1._isInitialized = true;\n this$1._isReadOnly = probeResponse.isReadOnly;\n this$1._supportLinks = probeResponse.supportsLinks;\n this$1._supportProps = probeResponse.supportsProps;\n cb();\n })]\n };\n this._worker.postMessage(message);\n }\n else {\n cb();\n }\n };\n WorkerFS.prototype._argRemote2Local = function _argRemote2Local (arg) {\n if (!arg) {\n return arg;\n }\n switch (typeof arg) {\n case 'object':\n if (typeof arg['type'] === 'number') {\n var specialArg = arg;\n switch (specialArg.type) {\n case SpecialArgType.API_ERROR:\n return apiErrorRemote2Local(specialArg);\n case SpecialArgType.FD:\n var fdArg = specialArg;\n return new WorkerFile(this, fdArg.path, FileFlag.getFileFlag(fdArg.flag), Stats.fromBuffer(transferrableObjectToBuffer(fdArg.stat)), fdArg.id, transferrableObjectToBuffer(fdArg.data));\n case SpecialArgType.STATS:\n return statsRemote2Local(specialArg);\n case SpecialArgType.FILEFLAG:\n return fileFlagRemote2Local(specialArg);\n case SpecialArgType.BUFFER:\n return bufferRemote2Local(specialArg);\n case SpecialArgType.ERROR:\n return errorRemote2Local(specialArg);\n default:\n return arg;\n }\n }\n else {\n return arg;\n }\n default:\n return arg;\n }\n };\n WorkerFS.prototype._rpc = function _rpc (methodName, args) {\n var fixedArgs = new Array(args.length);\n for (var i = 0; i < args.length; i++) {\n fixedArgs[i] = this._argLocal2Remote(args[i]);\n }\n var message = {\n browserfsMessage: true,\n method: methodName,\n args: fixedArgs\n };\n this._worker.postMessage(message);\n };\n /**\n * Converts a local argument into a remote argument. Public so WorkerFile objects can call it.\n */\n WorkerFS.prototype._argLocal2Remote = function _argLocal2Remote (arg) {\n if (!arg) {\n return arg;\n }\n switch (typeof arg) {\n case \"object\":\n if (arg instanceof Stats) {\n return statsLocal2Remote(arg);\n }\n else if (arg instanceof ApiError) {\n return apiErrorLocal2Remote(arg);\n }\n else if (arg instanceof WorkerFile) {\n return arg.toRemoteArg();\n }\n else if (arg instanceof FileFlag) {\n return fileFlagLocal2Remote(arg);\n }\n else if (arg instanceof Buffer) {\n return bufferLocal2Remote(arg);\n }\n else if (arg instanceof Error) {\n return errorLocal2Remote(arg);\n }\n else {\n return \"Unknown argument\";\n }\n case \"function\":\n return this._callbackConverter.toRemoteArg(arg);\n default:\n return arg;\n }\n };\n\n return WorkerFS;\n}(BaseFileSystem));\nWorkerFS.Name = \"WorkerFS\";\nWorkerFS.Options = {\n worker: {\n type: \"object\",\n description: \"The target worker that you want to connect to, or the current worker if in a worker context.\",\n validator: function (v, cb) {\n // Check for a `postMessage` function.\n if (v['postMessage']) {\n cb();\n }\n else {\n cb(new ApiError(ErrorCode.EINVAL, \"option must be a Web Worker instance.\"));\n }\n }\n }\n};\n\n/**\n * Contains utility methods for performing a variety of tasks with\n * XmlHttpRequest across browsers.\n */\nvar xhrIsAvailable = (typeof (XMLHttpRequest) !== \"undefined\" && XMLHttpRequest !== null);\nfunction asyncDownloadFileModern(p, type, cb) {\n var req = new XMLHttpRequest();\n req.open('GET', p, true);\n var jsonSupported = true;\n switch (type) {\n case 'buffer':\n req.responseType = 'arraybuffer';\n break;\n case 'json':\n // Some browsers don't support the JSON response type.\n // They either reset responseType, or throw an exception.\n // @see https://github.com/Modernizr/Modernizr/blob/master/src/testXhrType.js\n try {\n req.responseType = 'json';\n jsonSupported = req.responseType === 'json';\n }\n catch (e) {\n jsonSupported = false;\n }\n break;\n default:\n return cb(new ApiError(ErrorCode.EINVAL, \"Invalid download type: \" + type));\n }\n req.onreadystatechange = function (e) {\n if (req.readyState === 4) {\n if (req.status === 200) {\n switch (type) {\n case 'buffer':\n // XXX: WebKit-based browsers return *null* when XHRing an empty file.\n return cb(null, req.response ? Buffer.from(req.response) : emptyBuffer());\n case 'json':\n if (jsonSupported) {\n return cb(null, req.response);\n }\n else {\n return cb(null, JSON.parse(req.responseText));\n }\n }\n }\n else {\n return cb(new ApiError(ErrorCode.EIO, (\"XHR error: response returned code \" + (req.status))));\n }\n }\n };\n req.send();\n}\nfunction syncDownloadFileModern(p, type) {\n var req = new XMLHttpRequest();\n req.open('GET', p, false);\n // On most platforms, we cannot set the responseType of synchronous downloads.\n // @todo Test for this; IE10 allows this, as do older versions of Chrome/FF.\n var data = null;\n var err = null;\n // Classic hack to download binary data as a string.\n req.overrideMimeType('text/plain; charset=x-user-defined');\n req.onreadystatechange = function (e) {\n if (req.readyState === 4) {\n if (req.status === 200) {\n switch (type) {\n case 'buffer':\n // Convert the text into a buffer.\n var text = req.responseText;\n data = Buffer.alloc(text.length);\n // Throw away the upper bits of each character.\n for (var i = 0; i < text.length; i++) {\n // This will automatically throw away the upper bit of each\n // character for us.\n data[i] = text.charCodeAt(i);\n }\n return;\n case 'json':\n data = JSON.parse(req.responseText);\n return;\n }\n }\n else {\n err = new ApiError(ErrorCode.EIO, (\"XHR error: response returned code \" + (req.status)));\n return;\n }\n }\n };\n req.send();\n if (err) {\n throw err;\n }\n return data;\n}\nfunction syncDownloadFileIE10(p, type) {\n var req = new XMLHttpRequest();\n req.open('GET', p, false);\n switch (type) {\n case 'buffer':\n req.responseType = 'arraybuffer';\n break;\n case 'json':\n // IE10 does not support the JSON type.\n break;\n default:\n throw new ApiError(ErrorCode.EINVAL, \"Invalid download type: \" + type);\n }\n var data;\n var err;\n req.onreadystatechange = function (e) {\n if (req.readyState === 4) {\n if (req.status === 200) {\n switch (type) {\n case 'buffer':\n data = Buffer.from(req.response);\n break;\n case 'json':\n data = JSON.parse(req.response);\n break;\n }\n }\n else {\n err = new ApiError(ErrorCode.EIO, (\"XHR error: response returned code \" + (req.status)));\n }\n }\n };\n req.send();\n if (err) {\n throw err;\n }\n return data;\n}\n/**\n * @hidden\n */\nfunction getFileSize(async, p, cb) {\n var req = new XMLHttpRequest();\n req.open('HEAD', p, async);\n req.onreadystatechange = function (e) {\n if (req.readyState === 4) {\n if (req.status === 200) {\n try {\n return cb(null, parseInt(req.getResponseHeader('Content-Length') || '-1', 10));\n }\n catch (e) {\n // In the event that the header isn't present or there is an error...\n return cb(new ApiError(ErrorCode.EIO, \"XHR HEAD error: Could not read content-length.\"));\n }\n }\n else {\n return cb(new ApiError(ErrorCode.EIO, (\"XHR HEAD error: response returned code \" + (req.status))));\n }\n }\n };\n req.send();\n}\n/**\n * Asynchronously download a file as a buffer or a JSON object.\n * Note that the third function signature with a non-specialized type is\n * invalid, but TypeScript requires it when you specialize string arguments to\n * constants.\n * @hidden\n */\nvar asyncDownloadFile = asyncDownloadFileModern;\n/**\n * Synchronously download a file as a buffer or a JSON object.\n * Note that the third function signature with a non-specialized type is\n * invalid, but TypeScript requires it when you specialize string arguments to\n * constants.\n * @hidden\n */\nvar syncDownloadFile = (isIE && typeof Blob !== 'undefined') ? syncDownloadFileIE10 : syncDownloadFileModern;\n/**\n * Synchronously retrieves the size of the given file in bytes.\n * @hidden\n */\nfunction getFileSizeSync(p) {\n var rv = -1;\n getFileSize(false, p, function (err, size) {\n if (err) {\n throw err;\n }\n rv = size;\n });\n return rv;\n}\n/**\n * Asynchronously retrieves the size of the given file in bytes.\n * @hidden\n */\nfunction getFileSizeAsync(p, cb) {\n getFileSize(true, p, cb);\n}\n\n/**\n * Contains utility methods using 'fetch'.\n */\nvar fetchIsAvailable = (typeof (fetch) !== \"undefined\" && fetch !== null);\nfunction fetchFileAsync(p, type, cb) {\n var request;\n try {\n request = fetch(p);\n }\n catch (e) {\n // XXX: fetch will throw a TypeError if the URL has credentials in it\n return cb(new ApiError(ErrorCode.EINVAL, e.message));\n }\n request\n .then(function (res) {\n if (!res.ok) {\n return cb(new ApiError(ErrorCode.EIO, (\"fetch error: response returned code \" + (res.status))));\n }\n else {\n switch (type) {\n case 'buffer':\n res.arrayBuffer()\n .then(function (buf) { return cb(null, Buffer.from(buf)); })\n .catch(function (err) { return cb(new ApiError(ErrorCode.EIO, err.message)); });\n break;\n case 'json':\n res.json()\n .then(function (json) { return cb(null, json); })\n .catch(function (err) { return cb(new ApiError(ErrorCode.EIO, err.message)); });\n break;\n default:\n cb(new ApiError(ErrorCode.EINVAL, \"Invalid download type: \" + type));\n }\n }\n })\n .catch(function (err) { return cb(new ApiError(ErrorCode.EIO, err.message)); });\n}\n/**\n * Asynchronously retrieves the size of the given file in bytes.\n * @hidden\n */\nfunction fetchFileSizeAsync(p, cb) {\n fetch(p, { method: 'HEAD' })\n .then(function (res) {\n if (!res.ok) {\n return cb(new ApiError(ErrorCode.EIO, (\"fetch HEAD error: response returned code \" + (res.status))));\n }\n else {\n return cb(null, parseInt(res.headers.get('Content-Length') || '-1', 10));\n }\n })\n .catch(function (err) { return cb(new ApiError(ErrorCode.EIO, err.message)); });\n}\n\n/**\n * A simple class for storing a filesystem index. Assumes that all paths passed\n * to it are *absolute* paths.\n *\n * Can be used as a partial or a full index, although care must be taken if used\n * for the former purpose, especially when directories are concerned.\n */\nvar FileIndex = function FileIndex() {\n // _index is a single-level key,value store that maps *directory* paths to\n // DirInodes. File information is only contained in DirInodes themselves.\n this._index = {};\n // Create the root directory.\n this.addPath('/', new DirInode());\n};\n/**\n * Static method for constructing indices from a JSON listing.\n * @param listing Directory listing generated by tools/XHRIndexer.coffee\n * @return A new FileIndex object.\n */\nFileIndex.fromListing = function fromListing (listing) {\n var idx = new FileIndex();\n // Add a root DirNode.\n var rootInode = new DirInode();\n idx._index['/'] = rootInode;\n var queue = [['', listing, rootInode]];\n while (queue.length > 0) {\n var inode = (void 0);\n var next = queue.pop();\n var pwd = next[0];\n var tree = next[1];\n var parent = next[2];\n for (var node in tree) {\n if (tree.hasOwnProperty(node)) {\n var children = tree[node];\n var name = pwd + \"/\" + node;\n if (children) {\n idx._index[name] = inode = new DirInode();\n queue.push([name, children, inode]);\n }\n else {\n // This inode doesn't have correct size information, noted with -1.\n inode = new FileInode(new Stats(FileType.FILE, -1, 0x16D));\n }\n if (parent) {\n parent._ls[node] = inode;\n }\n }\n }\n }\n return idx;\n};\n/**\n * Runs the given function over all files in the index.\n */\nFileIndex.prototype.fileIterator = function fileIterator (cb) {\n for (var path$$1 in this._index) {\n if (this._index.hasOwnProperty(path$$1)) {\n var dir = this._index[path$$1];\n var files = dir.getListing();\n for (var i = 0, list = files; i < list.length; i += 1) {\n var file = list[i];\n\n var item = dir.getItem(file);\n if (isFileInode(item)) {\n cb(item.getData());\n }\n }\n }\n }\n};\n/**\n * Adds the given absolute path to the index if it is not already in the index.\n * Creates any needed parent directories.\n * @param path The path to add to the index.\n * @param inode The inode for the\n * path to add.\n * @return 'True' if it was added or already exists, 'false' if there\n * was an issue adding it (e.g. item in path is a file, item exists but is\n * different).\n * @todo If adding fails and implicitly creates directories, we do not clean up\n * the new empty directories.\n */\nFileIndex.prototype.addPath = function addPath (path$$1, inode) {\n if (!inode) {\n throw new Error('Inode must be specified');\n }\n if (path$$1[0] !== '/') {\n throw new Error('Path must be absolute, got: ' + path$$1);\n }\n // Check if it already exists.\n if (this._index.hasOwnProperty(path$$1)) {\n return this._index[path$$1] === inode;\n }\n var splitPath = this._split_path(path$$1);\n var dirpath = splitPath[0];\n var itemname = splitPath[1];\n // Try to add to its parent directory first.\n var parent = this._index[dirpath];\n if (parent === undefined && path$$1 !== '/') {\n // Create parent.\n parent = new DirInode();\n if (!this.addPath(dirpath, parent)) {\n return false;\n }\n }\n // Add myself to my parent.\n if (path$$1 !== '/') {\n if (!parent.addItem(itemname, inode)) {\n return false;\n }\n }\n // If I'm a directory, add myself to the index.\n if (isDirInode(inode)) {\n this._index[path$$1] = inode;\n }\n return true;\n};\n/**\n * Adds the given absolute path to the index if it is not already in the index.\n * The path is added without special treatment (no joining of adjacent separators, etc).\n * Creates any needed parent directories.\n * @param path The path to add to the index.\n * @param inode The inode for the\n * path to add.\n * @return 'True' if it was added or already exists, 'false' if there\n * was an issue adding it (e.g. item in path is a file, item exists but is\n * different).\n * @todo If adding fails and implicitly creates directories, we do not clean up\n * the new empty directories.\n */\nFileIndex.prototype.addPathFast = function addPathFast (path$$1, inode) {\n var itemNameMark = path$$1.lastIndexOf('/');\n var parentPath = itemNameMark === 0 ? \"/\" : path$$1.substring(0, itemNameMark);\n var itemName = path$$1.substring(itemNameMark + 1);\n // Try to add to its parent directory first.\n var parent = this._index[parentPath];\n if (parent === undefined) {\n // Create parent.\n parent = new DirInode();\n this.addPathFast(parentPath, parent);\n }\n if (!parent.addItem(itemName, inode)) {\n return false;\n }\n // If adding a directory, add to the index as well.\n if (inode.isDir()) {\n this._index[path$$1] = inode;\n }\n return true;\n};\n/**\n * Removes the given path. Can be a file or a directory.\n * @return The removed item,\n * or null if it did not exist.\n */\nFileIndex.prototype.removePath = function removePath (path$$1) {\n var splitPath = this._split_path(path$$1);\n var dirpath = splitPath[0];\n var itemname = splitPath[1];\n // Try to remove it from its parent directory first.\n var parent = this._index[dirpath];\n if (parent === undefined) {\n return null;\n }\n // Remove myself from my parent.\n var inode = parent.remItem(itemname);\n if (inode === null) {\n return null;\n }\n // If I'm a directory, remove myself from the index, and remove my children.\n if (isDirInode(inode)) {\n var children = inode.getListing();\n for (var i = 0, list = children; i < list.length; i += 1) {\n var child = list[i];\n\n this.removePath(path$$1 + '/' + child);\n }\n // Remove the directory from the index, unless it's the root.\n if (path$$1 !== '/') {\n delete this._index[path$$1];\n }\n }\n return inode;\n};\n/**\n * Retrieves the directory listing of the given path.\n * @return An array of files in the given path, or 'null' if it does not exist.\n */\nFileIndex.prototype.ls = function ls (path$$1) {\n var item = this._index[path$$1];\n if (item === undefined) {\n return null;\n }\n return item.getListing();\n};\n/**\n * Returns the inode of the given item.\n * @return Returns null if the item does not exist.\n */\nFileIndex.prototype.getInode = function getInode (path$$1) {\n var splitPath = this._split_path(path$$1);\n var dirpath = splitPath[0];\n var itemname = splitPath[1];\n // Retrieve from its parent directory.\n var parent = this._index[dirpath];\n if (parent === undefined) {\n return null;\n }\n // Root case\n if (dirpath === path$$1) {\n return parent;\n }\n return parent.getItem(itemname);\n};\n/**\n * Split into a (directory path, item name) pair\n */\nFileIndex.prototype._split_path = function _split_path (p) {\n var dirpath = path.dirname(p);\n var itemname = p.substr(dirpath.length + (dirpath === \"/\" ? 0 : 1));\n return [dirpath, itemname];\n};\n/**\n * Inode for a file. Stores an arbitrary (filesystem-specific) data payload.\n */\nvar FileInode = function FileInode(data) {\n this.data = data;\n};\nFileInode.prototype.isFile = function isFile () { return true; };\nFileInode.prototype.isDir = function isDir () { return false; };\nFileInode.prototype.getData = function getData () { return this.data; };\nFileInode.prototype.setData = function setData (data) { this.data = data; };\n/**\n * Inode for a directory. Currently only contains the directory listing.\n */\nvar DirInode = function DirInode(data) {\n if ( data === void 0 ) data = null;\n\n this.data = data;\n this._ls = {};\n};\nDirInode.prototype.isFile = function isFile () {\n return false;\n};\nDirInode.prototype.isDir = function isDir () {\n return true;\n};\nDirInode.prototype.getData = function getData () { return this.data; };\n/**\n * Return a Stats object for this inode.\n * @todo Should probably remove this at some point. This isn't the\n * responsibility of the FileIndex.\n */\nDirInode.prototype.getStats = function getStats () {\n return new Stats(FileType.DIRECTORY, 4096, 0x16D);\n};\n/**\n * Returns the directory listing for this directory. Paths in the directory are\n * relative to the directory's path.\n * @return The directory listing for this directory.\n */\nDirInode.prototype.getListing = function getListing () {\n return Object.keys(this._ls);\n};\n/**\n * Returns the inode for the indicated item, or null if it does not exist.\n * @param p Name of item in this directory.\n */\nDirInode.prototype.getItem = function getItem (p) {\n var item = this._ls[p];\n return item ? item : null;\n};\n/**\n * Add the given item to the directory listing. Note that the given inode is\n * not copied, and will be mutated by the DirInode if it is a DirInode.\n * @param p Item name to add to the directory listing.\n * @param inode The inode for the\n * item to add to the directory inode.\n * @return True if it was added, false if it already existed.\n */\nDirInode.prototype.addItem = function addItem (p, inode) {\n if (p in this._ls) {\n return false;\n }\n this._ls[p] = inode;\n return true;\n};\n/**\n * Removes the given item from the directory listing.\n * @param p Name of item to remove from the directory listing.\n * @return Returns the item\n * removed, or null if the item did not exist.\n */\nDirInode.prototype.remItem = function remItem (p) {\n var item = this._ls[p];\n if (item === undefined) {\n return null;\n }\n delete this._ls[p];\n return item;\n};\n/**\n * @hidden\n */\nfunction isFileInode(inode) {\n return !!inode && inode.isFile();\n}\n/**\n * @hidden\n */\nfunction isDirInode(inode) {\n return !!inode && inode.isDir();\n}\n\n/**\n * Try to convert the given buffer into a string, and pass it to the callback.\n * Optimization that removes the needed try/catch into a helper function, as\n * this is an uncommon case.\n * @hidden\n */\nfunction tryToString(buff, encoding, cb) {\n try {\n cb(null, buff.toString(encoding));\n }\n catch (e) {\n cb(e);\n }\n}\nfunction syncNotAvailableError() {\n throw new ApiError(ErrorCode.ENOTSUP, \"Synchronous HTTP download methods are not available in this environment.\");\n}\n/**\n * A simple filesystem backed by HTTP downloads. You must create a directory listing using the\n * `make_http_index` tool provided by BrowserFS.\n *\n * If you install BrowserFS globally with `npm i -g browserfs`, you can generate a listing by\n * running `make_http_index` in your terminal in the directory you would like to index:\n *\n * ```\n * make_http_index > index.json\n * ```\n *\n * Listings objects look like the following:\n *\n * ```json\n * {\n * \"home\": {\n * \"jvilk\": {\n * \"someFile.txt\": null,\n * \"someDir\": {\n * // Empty directory\n * }\n * }\n * }\n * }\n * ```\n *\n * *This example has the folder `/home/jvilk` with subfile `someFile.txt` and subfolder `someDir`.*\n */\nvar HTTPRequest = /*@__PURE__*/(function (BaseFileSystem$$1) {\n function HTTPRequest(index, prefixUrl, preferXHR) {\n if ( prefixUrl === void 0 ) prefixUrl = '';\n if ( preferXHR === void 0 ) preferXHR = false;\n\n BaseFileSystem$$1.call(this);\n // prefix_url must end in a directory separator.\n if (prefixUrl.length > 0 && prefixUrl.charAt(prefixUrl.length - 1) !== '/') {\n prefixUrl = prefixUrl + '/';\n }\n this.prefixUrl = prefixUrl;\n this._index = FileIndex.fromListing(index);\n if (fetchIsAvailable && (!preferXHR || !xhrIsAvailable)) {\n this._requestFileAsyncInternal = fetchFileAsync;\n this._requestFileSizeAsyncInternal = fetchFileSizeAsync;\n }\n else {\n this._requestFileAsyncInternal = asyncDownloadFile;\n this._requestFileSizeAsyncInternal = getFileSizeAsync;\n }\n if (xhrIsAvailable) {\n this._requestFileSyncInternal = syncDownloadFile;\n this._requestFileSizeSyncInternal = getFileSizeSync;\n }\n else {\n this._requestFileSyncInternal = syncNotAvailableError;\n this._requestFileSizeSyncInternal = syncNotAvailableError;\n }\n }\n\n if ( BaseFileSystem$$1 ) HTTPRequest.__proto__ = BaseFileSystem$$1;\n HTTPRequest.prototype = Object.create( BaseFileSystem$$1 && BaseFileSystem$$1.prototype );\n HTTPRequest.prototype.constructor = HTTPRequest;\n /**\n * Construct an HTTPRequest file system backend with the given options.\n */\n HTTPRequest.Create = function Create (opts, cb) {\n if (opts.index === undefined) {\n opts.index = \"index.json\";\n }\n if (typeof (opts.index) === \"string\") {\n asyncDownloadFile(opts.index, \"json\", function (e, data) {\n if (e) {\n cb(e);\n }\n else {\n cb(null, new HTTPRequest(data, opts.baseUrl));\n }\n });\n }\n else {\n cb(null, new HTTPRequest(opts.index, opts.baseUrl));\n }\n };\n HTTPRequest.isAvailable = function isAvailable () {\n return xhrIsAvailable || fetchIsAvailable;\n };\n HTTPRequest.prototype.empty = function empty () {\n this._index.fileIterator(function (file) {\n file.fileData = null;\n });\n };\n HTTPRequest.prototype.getName = function getName () {\n return HTTPRequest.Name;\n };\n HTTPRequest.prototype.diskSpace = function diskSpace (path$$1, cb) {\n // Read-only file system. We could calculate the total space, but that's not\n // important right now.\n cb(0, 0);\n };\n HTTPRequest.prototype.isReadOnly = function isReadOnly () {\n return true;\n };\n HTTPRequest.prototype.supportsLinks = function supportsLinks () {\n return false;\n };\n HTTPRequest.prototype.supportsProps = function supportsProps () {\n return false;\n };\n HTTPRequest.prototype.supportsSynch = function supportsSynch () {\n // Synchronous operations are only available via the XHR interface for now.\n return xhrIsAvailable;\n };\n /**\n * Special HTTPFS function: Preload the given file into the index.\n * @param [String] path\n * @param [BrowserFS.Buffer] buffer\n */\n HTTPRequest.prototype.preloadFile = function preloadFile (path$$1, buffer$$1) {\n var inode = this._index.getInode(path$$1);\n if (isFileInode(inode)) {\n if (inode === null) {\n throw ApiError.ENOENT(path$$1);\n }\n var stats = inode.getData();\n stats.size = buffer$$1.length;\n stats.fileData = buffer$$1;\n }\n else {\n throw ApiError.EISDIR(path$$1);\n }\n };\n HTTPRequest.prototype.stat = function stat (path$$1, isLstat, cb) {\n var inode = this._index.getInode(path$$1);\n if (inode === null) {\n return cb(ApiError.ENOENT(path$$1));\n }\n var stats;\n if (isFileInode(inode)) {\n stats = inode.getData();\n // At this point, a non-opened file will still have default stats from the listing.\n if (stats.size < 0) {\n this._requestFileSizeAsync(path$$1, function (e, size) {\n if (e) {\n return cb(e);\n }\n stats.size = size;\n cb(null, Stats.clone(stats));\n });\n }\n else {\n cb(null, Stats.clone(stats));\n }\n }\n else if (isDirInode(inode)) {\n stats = inode.getStats();\n cb(null, stats);\n }\n else {\n cb(ApiError.FileError(ErrorCode.EINVAL, path$$1));\n }\n };\n HTTPRequest.prototype.statSync = function statSync (path$$1, isLstat) {\n var inode = this._index.getInode(path$$1);\n if (inode === null) {\n throw ApiError.ENOENT(path$$1);\n }\n var stats;\n if (isFileInode(inode)) {\n stats = inode.getData();\n // At this point, a non-opened file will still have default stats from the listing.\n if (stats.size < 0) {\n stats.size = this._requestFileSizeSync(path$$1);\n }\n }\n else if (isDirInode(inode)) {\n stats = inode.getStats();\n }\n else {\n throw ApiError.FileError(ErrorCode.EINVAL, path$$1);\n }\n return stats;\n };\n HTTPRequest.prototype.open = function open (path$$1, flags, mode, cb) {\n // INVARIANT: You can't write to files on this file system.\n if (flags.isWriteable()) {\n return cb(new ApiError(ErrorCode.EPERM, path$$1));\n }\n var self = this;\n // Check if the path exists, and is a file.\n var inode = this._index.getInode(path$$1);\n if (inode === null) {\n return cb(ApiError.ENOENT(path$$1));\n }\n if (isFileInode(inode)) {\n var stats = inode.getData();\n switch (flags.pathExistsAction()) {\n case ActionType.THROW_EXCEPTION:\n case ActionType.TRUNCATE_FILE:\n return cb(ApiError.EEXIST(path$$1));\n case ActionType.NOP:\n // Use existing file contents.\n // XXX: Uh, this maintains the previously-used flag.\n if (stats.fileData) {\n return cb(null, new NoSyncFile(self, path$$1, flags, Stats.clone(stats), stats.fileData));\n }\n // @todo be lazier about actually requesting the file\n this._requestFileAsync(path$$1, 'buffer', function (err, buffer$$1) {\n if (err) {\n return cb(err);\n }\n // we don't initially have file sizes\n stats.size = buffer$$1.length;\n stats.fileData = buffer$$1;\n return cb(null, new NoSyncFile(self, path$$1, flags, Stats.clone(stats), buffer$$1));\n });\n break;\n default:\n return cb(new ApiError(ErrorCode.EINVAL, 'Invalid FileMode object.'));\n }\n }\n else {\n return cb(ApiError.EISDIR(path$$1));\n }\n };\n HTTPRequest.prototype.openSync = function openSync (path$$1, flags, mode) {\n // INVARIANT: You can't write to files on this file system.\n if (flags.isWriteable()) {\n throw new ApiError(ErrorCode.EPERM, path$$1);\n }\n // Check if the path exists, and is a file.\n var inode = this._index.getInode(path$$1);\n if (inode === null) {\n throw ApiError.ENOENT(path$$1);\n }\n if (isFileInode(inode)) {\n var stats = inode.getData();\n switch (flags.pathExistsAction()) {\n case ActionType.THROW_EXCEPTION:\n case ActionType.TRUNCATE_FILE:\n throw ApiError.EEXIST(path$$1);\n case ActionType.NOP:\n // Use existing file contents.\n // XXX: Uh, this maintains the previously-used flag.\n if (stats.fileData) {\n return new NoSyncFile(this, path$$1, flags, Stats.clone(stats), stats.fileData);\n }\n // @todo be lazier about actually requesting the file\n var buffer$$1 = this._requestFileSync(path$$1, 'buffer');\n // we don't initially have file sizes\n stats.size = buffer$$1.length;\n stats.fileData = buffer$$1;\n return new NoSyncFile(this, path$$1, flags, Stats.clone(stats), buffer$$1);\n default:\n throw new ApiError(ErrorCode.EINVAL, 'Invalid FileMode object.');\n }\n }\n else {\n throw ApiError.EISDIR(path$$1);\n }\n };\n HTTPRequest.prototype.readdir = function readdir (path$$1, cb) {\n try {\n cb(null, this.readdirSync(path$$1));\n }\n catch (e) {\n cb(e);\n }\n };\n HTTPRequest.prototype.readdirSync = function readdirSync (path$$1) {\n // Check if it exists.\n var inode = this._index.getInode(path$$1);\n if (inode === null) {\n throw ApiError.ENOENT(path$$1);\n }\n else if (isDirInode(inode)) {\n return inode.getListing();\n }\n else {\n throw ApiError.ENOTDIR(path$$1);\n }\n };\n /**\n * We have the entire file as a buffer; optimize readFile.\n */\n HTTPRequest.prototype.readFile = function readFile (fname, encoding, flag, cb) {\n // Wrap cb in file closing code.\n var oldCb = cb;\n // Get file.\n this.open(fname, flag, 0x1a4, function (err, fd) {\n if (err) {\n return cb(err);\n }\n cb = function (err, arg) {\n fd.close(function (err2) {\n if (!err) {\n err = err2;\n }\n return oldCb(err, arg);\n });\n };\n var fdCast = fd;\n var fdBuff = fdCast.getBuffer();\n if (encoding === null) {\n cb(err, copyingSlice(fdBuff));\n }\n else {\n tryToString(fdBuff, encoding, cb);\n }\n });\n };\n /**\n * Specially-optimized readfile.\n */\n HTTPRequest.prototype.readFileSync = function readFileSync (fname, encoding, flag) {\n // Get file.\n var fd = this.openSync(fname, flag, 0x1a4);\n try {\n var fdCast = fd;\n var fdBuff = fdCast.getBuffer();\n if (encoding === null) {\n return copyingSlice(fdBuff);\n }\n return fdBuff.toString(encoding);\n }\n finally {\n fd.closeSync();\n }\n };\n HTTPRequest.prototype._getHTTPPath = function _getHTTPPath (filePath) {\n if (filePath.charAt(0) === '/') {\n filePath = filePath.slice(1);\n }\n return this.prefixUrl + filePath;\n };\n HTTPRequest.prototype._requestFileAsync = function _requestFileAsync (p, type, cb) {\n this._requestFileAsyncInternal(this._getHTTPPath(p), type, cb);\n };\n HTTPRequest.prototype._requestFileSync = function _requestFileSync (p, type) {\n return this._requestFileSyncInternal(this._getHTTPPath(p), type);\n };\n /**\n * Only requests the HEAD content, for the file size.\n */\n HTTPRequest.prototype._requestFileSizeAsync = function _requestFileSizeAsync (path$$1, cb) {\n this._requestFileSizeAsyncInternal(this._getHTTPPath(path$$1), cb);\n };\n HTTPRequest.prototype._requestFileSizeSync = function _requestFileSizeSync (path$$1) {\n return this._requestFileSizeSyncInternal(this._getHTTPPath(path$$1));\n };\n\n return HTTPRequest;\n}(BaseFileSystem));\nHTTPRequest.Name = \"HTTPRequest\";\nHTTPRequest.Options = {\n index: {\n type: [\"string\", \"object\"],\n optional: true,\n description: \"URL to a file index as a JSON file or the file index object itself, generated with the make_http_index script. Defaults to `index.json`.\"\n },\n baseUrl: {\n type: \"string\",\n optional: true,\n description: \"Used as the URL prefix for fetched files. Default: Fetch files relative to the index.\"\n },\n preferXHR: {\n type: \"boolean\",\n optional: true,\n description: \"Whether to prefer XmlHttpRequest or fetch for async operations if both are available. Default: false\"\n }\n};\n\n/**\n * (Nonstandard) String utility function for 8-bit ASCII with the extended\n * character set. Unlike the ASCII above, we do not mask the high bits.\n *\n * Placed into a separate file so it can be used with other Buffer implementations.\n * @see http://en.wikipedia.org/wiki/Extended_ASCII\n */\nvar ExtendedASCII = function ExtendedASCII () {};\n\nExtendedASCII.str2byte = function str2byte (str, buf) {\n var length = str.length > buf.length ? buf.length : str.length;\n for (var i = 0; i < length; i++) {\n var charCode = str.charCodeAt(i);\n if (charCode > 0x7F) {\n // Check if extended ASCII.\n var charIdx = ExtendedASCII.extendedChars.indexOf(str.charAt(i));\n if (charIdx > -1) {\n charCode = charIdx + 0x80;\n }\n // Otherwise, keep it as-is.\n }\n buf[charCode] = i;\n }\n return length;\n};\nExtendedASCII.byte2str = function byte2str (buff) {\n var chars = new Array(buff.length);\n for (var i = 0; i < buff.length; i++) {\n var charCode = buff[i];\n if (charCode > 0x7F) {\n chars[i] = ExtendedASCII.extendedChars[charCode - 128];\n }\n else {\n chars[i] = String.fromCharCode(charCode);\n }\n }\n return chars.join('');\n};\nExtendedASCII.byteLength = function byteLength (str) { return str.length; };\nExtendedASCII.extendedChars = ['\\u00C7', '\\u00FC', '\\u00E9', '\\u00E2', '\\u00E4',\n '\\u00E0', '\\u00E5', '\\u00E7', '\\u00EA', '\\u00EB', '\\u00E8', '\\u00EF',\n '\\u00EE', '\\u00EC', '\\u00C4', '\\u00C5', '\\u00C9', '\\u00E6', '\\u00C6',\n '\\u00F4', '\\u00F6', '\\u00F2', '\\u00FB', '\\u00F9', '\\u00FF', '\\u00D6',\n '\\u00DC', '\\u00F8', '\\u00A3', '\\u00D8', '\\u00D7', '\\u0192', '\\u00E1',\n '\\u00ED', '\\u00F3', '\\u00FA', '\\u00F1', '\\u00D1', '\\u00AA', '\\u00BA',\n '\\u00BF', '\\u00AE', '\\u00AC', '\\u00BD', '\\u00BC', '\\u00A1', '\\u00AB',\n '\\u00BB', '_', '_', '_', '\\u00A6', '\\u00A6', '\\u00C1', '\\u00C2', '\\u00C0',\n '\\u00A9', '\\u00A6', '\\u00A6', '+', '+', '\\u00A2', '\\u00A5', '+', '+', '-',\n '-', '+', '-', '+', '\\u00E3', '\\u00C3', '+', '+', '-', '-', '\\u00A6', '-',\n '+', '\\u00A4', '\\u00F0', '\\u00D0', '\\u00CA', '\\u00CB', '\\u00C8', 'i',\n '\\u00CD', '\\u00CE', '\\u00CF', '+', '+', '_', '_', '\\u00A6', '\\u00CC', '_',\n '\\u00D3', '\\u00DF', '\\u00D4', '\\u00D2', '\\u00F5', '\\u00D5', '\\u00B5',\n '\\u00FE', '\\u00DE', '\\u00DA', '\\u00DB', '\\u00D9', '\\u00FD', '\\u00DD',\n '\\u00AF', '\\u00B4', '\\u00AD', '\\u00B1', '_', '\\u00BE', '\\u00B6', '\\u00A7',\n '\\u00F7', '\\u00B8', '\\u00B0', '\\u00A8', '\\u00B7', '\\u00B9', '\\u00B3',\n '\\u00B2', '_', ' '];\n\n/**\n * @hidden\n */\nvar inflateRaw = require('pako/lib/inflate').inflateRaw;\n/**\n * Maps CompressionMethod => function that decompresses.\n * @hidden\n */\nvar decompressionMethods = {};\n/**\n * 4.4.2.2: Indicates the compatibiltiy of a file's external attributes.\n */\nvar ExternalFileAttributeType;\n(function (ExternalFileAttributeType) {\n ExternalFileAttributeType[ExternalFileAttributeType[\"MSDOS\"] = 0] = \"MSDOS\";\n ExternalFileAttributeType[ExternalFileAttributeType[\"AMIGA\"] = 1] = \"AMIGA\";\n ExternalFileAttributeType[ExternalFileAttributeType[\"OPENVMS\"] = 2] = \"OPENVMS\";\n ExternalFileAttributeType[ExternalFileAttributeType[\"UNIX\"] = 3] = \"UNIX\";\n ExternalFileAttributeType[ExternalFileAttributeType[\"VM_CMS\"] = 4] = \"VM_CMS\";\n ExternalFileAttributeType[ExternalFileAttributeType[\"ATARI_ST\"] = 5] = \"ATARI_ST\";\n ExternalFileAttributeType[ExternalFileAttributeType[\"OS2_HPFS\"] = 6] = \"OS2_HPFS\";\n ExternalFileAttributeType[ExternalFileAttributeType[\"MAC\"] = 7] = \"MAC\";\n ExternalFileAttributeType[ExternalFileAttributeType[\"Z_SYSTEM\"] = 8] = \"Z_SYSTEM\";\n ExternalFileAttributeType[ExternalFileAttributeType[\"CP_M\"] = 9] = \"CP_M\";\n ExternalFileAttributeType[ExternalFileAttributeType[\"NTFS\"] = 10] = \"NTFS\";\n ExternalFileAttributeType[ExternalFileAttributeType[\"MVS\"] = 11] = \"MVS\";\n ExternalFileAttributeType[ExternalFileAttributeType[\"VSE\"] = 12] = \"VSE\";\n ExternalFileAttributeType[ExternalFileAttributeType[\"ACORN_RISC\"] = 13] = \"ACORN_RISC\";\n ExternalFileAttributeType[ExternalFileAttributeType[\"VFAT\"] = 14] = \"VFAT\";\n ExternalFileAttributeType[ExternalFileAttributeType[\"ALT_MVS\"] = 15] = \"ALT_MVS\";\n ExternalFileAttributeType[ExternalFileAttributeType[\"BEOS\"] = 16] = \"BEOS\";\n ExternalFileAttributeType[ExternalFileAttributeType[\"TANDEM\"] = 17] = \"TANDEM\";\n ExternalFileAttributeType[ExternalFileAttributeType[\"OS_400\"] = 18] = \"OS_400\";\n ExternalFileAttributeType[ExternalFileAttributeType[\"OSX\"] = 19] = \"OSX\";\n})(ExternalFileAttributeType || (ExternalFileAttributeType = {}));\n/**\n * 4.4.5\n */\nvar CompressionMethod;\n(function (CompressionMethod) {\n CompressionMethod[CompressionMethod[\"STORED\"] = 0] = \"STORED\";\n CompressionMethod[CompressionMethod[\"SHRUNK\"] = 1] = \"SHRUNK\";\n CompressionMethod[CompressionMethod[\"REDUCED_1\"] = 2] = \"REDUCED_1\";\n CompressionMethod[CompressionMethod[\"REDUCED_2\"] = 3] = \"REDUCED_2\";\n CompressionMethod[CompressionMethod[\"REDUCED_3\"] = 4] = \"REDUCED_3\";\n CompressionMethod[CompressionMethod[\"REDUCED_4\"] = 5] = \"REDUCED_4\";\n CompressionMethod[CompressionMethod[\"IMPLODE\"] = 6] = \"IMPLODE\";\n CompressionMethod[CompressionMethod[\"DEFLATE\"] = 8] = \"DEFLATE\";\n CompressionMethod[CompressionMethod[\"DEFLATE64\"] = 9] = \"DEFLATE64\";\n CompressionMethod[CompressionMethod[\"TERSE_OLD\"] = 10] = \"TERSE_OLD\";\n CompressionMethod[CompressionMethod[\"BZIP2\"] = 12] = \"BZIP2\";\n CompressionMethod[CompressionMethod[\"LZMA\"] = 14] = \"LZMA\";\n CompressionMethod[CompressionMethod[\"TERSE_NEW\"] = 18] = \"TERSE_NEW\";\n CompressionMethod[CompressionMethod[\"LZ77\"] = 19] = \"LZ77\";\n CompressionMethod[CompressionMethod[\"WAVPACK\"] = 97] = \"WAVPACK\";\n CompressionMethod[CompressionMethod[\"PPMD\"] = 98] = \"PPMD\"; // PPMd version I, Rev 1\n})(CompressionMethod || (CompressionMethod = {}));\n/**\n * Converts the input time and date in MS-DOS format into a JavaScript Date\n * object.\n * @hidden\n */\nfunction msdos2date(time, date) {\n // MS-DOS Date\n // |0 0 0 0 0|0 0 0 0|0 0 0 0 0 0 0\n // D (1-31) M (1-23) Y (from 1980)\n var day = date & 0x1F;\n // JS date is 0-indexed, DOS is 1-indexed.\n var month = ((date >> 5) & 0xF) - 1;\n var year = (date >> 9) + 1980;\n // MS DOS Time\n // |0 0 0 0 0|0 0 0 0 0 0|0 0 0 0 0\n // Second Minute Hour\n var second = time & 0x1F;\n var minute = (time >> 5) & 0x3F;\n var hour = time >> 11;\n return new Date(year, month, day, hour, minute, second);\n}\n/**\n * Safely returns the string from the buffer, even if it is 0 bytes long.\n * (Normally, calling toString() on a buffer with start === end causes an\n * exception).\n * @hidden\n */\nfunction safeToString(buff, useUTF8, start, length) {\n if (length === 0) {\n return \"\";\n }\n else if (useUTF8) {\n return buff.toString('utf8', start, start + length);\n }\n else {\n return ExtendedASCII.byte2str(buff.slice(start, start + length));\n }\n}\n/*\n 4.3.6 Overall .ZIP file format:\n\n [local file header 1]\n [encryption header 1]\n [file data 1]\n [data descriptor 1]\n .\n .\n .\n [local file header n]\n [encryption header n]\n [file data n]\n [data descriptor n]\n [archive decryption header]\n [archive extra data record]\n [central directory header 1]\n .\n .\n .\n [central directory header n]\n [zip64 end of central directory record]\n [zip64 end of central directory locator]\n [end of central directory record]\n*/\n/**\n * 4.3.7 Local file header:\n *\n * local file header signature 4 bytes (0x04034b50)\n * version needed to extract 2 bytes\n * general purpose bit flag 2 bytes\n * compression method 2 bytes\n * last mod file time 2 bytes\n * last mod file date 2 bytes\n * crc-32 4 bytes\n * compressed size 4 bytes\n * uncompressed size 4 bytes\n * file name length 2 bytes\n * extra field length 2 bytes\n *\n * file name (variable size)\n * extra field (variable size)\n */\nvar FileHeader = function FileHeader(data) {\n this.data = data;\n if (data.readUInt32LE(0) !== 0x04034b50) {\n throw new ApiError(ErrorCode.EINVAL, \"Invalid Zip file: Local file header has invalid signature: \" + this.data.readUInt32LE(0));\n }\n };\n FileHeader.prototype.versionNeeded = function versionNeeded () { return this.data.readUInt16LE(4); };\n FileHeader.prototype.flags = function flags () { return this.data.readUInt16LE(6); };\n FileHeader.prototype.compressionMethod = function compressionMethod () { return this.data.readUInt16LE(8); };\n FileHeader.prototype.lastModFileTime = function lastModFileTime () {\n // Time and date is in MS-DOS format.\n return msdos2date(this.data.readUInt16LE(10), this.data.readUInt16LE(12));\n };\n FileHeader.prototype.rawLastModFileTime = function rawLastModFileTime () {\n return this.data.readUInt32LE(10);\n };\n FileHeader.prototype.crc32 = function crc32 () { return this.data.readUInt32LE(14); };\n /**\n * These two values are COMPLETELY USELESS.\n *\n * Section 4.4.9:\n *If bit 3 of the general purpose bit flag is set,\n *these fields are set to zero in the local header and the\n *correct values are put in the data descriptor and\n *in the central directory.\n *\n * So we'll just use the central directory's values.\n */\n // public compressedSize(): number { return this.data.readUInt32LE(18); }\n // public uncompressedSize(): number { return this.data.readUInt32LE(22); }\n FileHeader.prototype.fileNameLength = function fileNameLength () { return this.data.readUInt16LE(26); };\n FileHeader.prototype.extraFieldLength = function extraFieldLength () { return this.data.readUInt16LE(28); };\n FileHeader.prototype.fileName = function fileName () {\n return safeToString(this.data, this.useUTF8(), 30, this.fileNameLength());\n };\n FileHeader.prototype.extraField = function extraField () {\n var start = 30 + this.fileNameLength();\n return this.data.slice(start, start + this.extraFieldLength());\n };\n FileHeader.prototype.totalSize = function totalSize () { return 30 + this.fileNameLength() + this.extraFieldLength(); };\n FileHeader.prototype.useUTF8 = function useUTF8 () { return (this.flags() & 0x800) === 0x800; };\n/**\n * 4.3.8 File data\n *\n * Immediately following the local header for a file\n * SHOULD be placed the compressed or stored data for the file.\n * If the file is encrypted, the encryption header for the file\n * SHOULD be placed after the local header and before the file\n * data. The series of [local file header][encryption header]\n * [file data][data descriptor] repeats for each file in the\n * .ZIP archive.\n *\n * Zero-byte files, directories, and other file types that\n * contain no content MUST not include file data.\n */\nvar FileData = function FileData(header, record, data) {\n this.header = header;\n this.record = record;\n this.data = data;\n };\n FileData.prototype.decompress = function decompress () {\n // Check the compression\n var compressionMethod = this.header.compressionMethod();\n var fcn = decompressionMethods[compressionMethod];\n if (fcn) {\n return fcn(this.data, this.record.compressedSize(), this.record.uncompressedSize(), this.record.flag());\n }\n else {\n var name = CompressionMethod[compressionMethod];\n if (!name) {\n name = \"Unknown: \" + compressionMethod;\n }\n throw new ApiError(ErrorCode.EINVAL, (\"Invalid compression method on file '\" + (this.header.fileName()) + \"': \" + name));\n }\n };\n FileData.prototype.getHeader = function getHeader () {\n return this.header;\n };\n FileData.prototype.getRecord = function getRecord () {\n return this.record;\n };\n FileData.prototype.getRawData = function getRawData () {\n return this.data;\n };\n/**\n * 4.3.12 Central directory structure:\n *\n * central file header signature 4 bytes (0x02014b50)\n * version made by 2 bytes\n * version needed to extract 2 bytes\n * general purpose bit flag 2 bytes\n * compression method 2 bytes\n * last mod file time 2 bytes\n * last mod file date 2 bytes\n * crc-32 4 bytes\n * compressed size 4 bytes\n * uncompressed size 4 bytes\n * file name length 2 bytes\n * extra field length 2 bytes\n * file comment length 2 bytes\n * disk number start 2 bytes\n * internal file attributes 2 bytes\n * external file attributes 4 bytes\n * relative offset of local header 4 bytes\n *\n * file name (variable size)\n * extra field (variable size)\n * file comment (variable size)\n */\nvar CentralDirectory = function CentralDirectory(zipData, data) {\n this.zipData = zipData;\n this.data = data;\n // Sanity check.\n if (this.data.readUInt32LE(0) !== 0x02014b50) {\n throw new ApiError(ErrorCode.EINVAL, (\"Invalid Zip file: Central directory record has invalid signature: \" + (this.data.readUInt32LE(0))));\n }\n this._filename = this.produceFilename();\n };\n CentralDirectory.prototype.versionMadeBy = function versionMadeBy () { return this.data.readUInt16LE(4); };\n CentralDirectory.prototype.versionNeeded = function versionNeeded () { return this.data.readUInt16LE(6); };\n CentralDirectory.prototype.flag = function flag () { return this.data.readUInt16LE(8); };\n CentralDirectory.prototype.compressionMethod = function compressionMethod () { return this.data.readUInt16LE(10); };\n CentralDirectory.prototype.lastModFileTime = function lastModFileTime () {\n // Time and date is in MS-DOS format.\n return msdos2date(this.data.readUInt16LE(12), this.data.readUInt16LE(14));\n };\n CentralDirectory.prototype.rawLastModFileTime = function rawLastModFileTime () {\n return this.data.readUInt32LE(12);\n };\n CentralDirectory.prototype.crc32 = function crc32 () { return this.data.readUInt32LE(16); };\n CentralDirectory.prototype.compressedSize = function compressedSize () { return this.data.readUInt32LE(20); };\n CentralDirectory.prototype.uncompressedSize = function uncompressedSize () { return this.data.readUInt32LE(24); };\n CentralDirectory.prototype.fileNameLength = function fileNameLength () { return this.data.readUInt16LE(28); };\n CentralDirectory.prototype.extraFieldLength = function extraFieldLength () { return this.data.readUInt16LE(30); };\n CentralDirectory.prototype.fileCommentLength = function fileCommentLength () { return this.data.readUInt16LE(32); };\n CentralDirectory.prototype.diskNumberStart = function diskNumberStart () { return this.data.readUInt16LE(34); };\n CentralDirectory.prototype.internalAttributes = function internalAttributes () { return this.data.readUInt16LE(36); };\n CentralDirectory.prototype.externalAttributes = function externalAttributes () { return this.data.readUInt32LE(38); };\n CentralDirectory.prototype.headerRelativeOffset = function headerRelativeOffset () { return this.data.readUInt32LE(42); };\n CentralDirectory.prototype.produceFilename = function produceFilename () {\n /*\n 4.4.17.1 claims:\n * All slashes are forward ('/') slashes.\n * Filename doesn't begin with a slash.\n * No drive letters or any nonsense like that.\n * If filename is missing, the input came from standard input.\n \n Unfortunately, this isn't true in practice. Some Windows zip utilities use\n a backslash here, but the correct Unix-style path in file headers.\n \n To avoid seeking all over the file to recover the known-good filenames\n from file headers, we simply convert '/' to '\\' here.\n */\n var fileName = safeToString(this.data, this.useUTF8(), 46, this.fileNameLength());\n return fileName.replace(/\\\\/g, \"/\");\n };\n CentralDirectory.prototype.fileName = function fileName () {\n return this._filename;\n };\n CentralDirectory.prototype.rawFileName = function rawFileName () {\n return this.data.slice(46, 46 + this.fileNameLength());\n };\n CentralDirectory.prototype.extraField = function extraField () {\n var start = 44 + this.fileNameLength();\n return this.data.slice(start, start + this.extraFieldLength());\n };\n CentralDirectory.prototype.fileComment = function fileComment () {\n var start = 46 + this.fileNameLength() + this.extraFieldLength();\n return safeToString(this.data, this.useUTF8(), start, this.fileCommentLength());\n };\n CentralDirectory.prototype.rawFileComment = function rawFileComment () {\n var start = 46 + this.fileNameLength() + this.extraFieldLength();\n return this.data.slice(start, start + this.fileCommentLength());\n };\n CentralDirectory.prototype.totalSize = function totalSize () {\n return 46 + this.fileNameLength() + this.extraFieldLength() + this.fileCommentLength();\n };\n CentralDirectory.prototype.isDirectory = function isDirectory () {\n // NOTE: This assumes that the zip file implementation uses the lower byte\n // of external attributes for DOS attributes for\n // backwards-compatibility. This is not mandated, but appears to be\n // commonplace.\n // According to the spec, the layout of external attributes is\n // platform-dependent.\n // If that fails, we also check if the name of the file ends in '/',\n // which is what Java's ZipFile implementation does.\n var fileName = this.fileName();\n return (this.externalAttributes() & 0x10 ? true : false) || (fileName.charAt(fileName.length - 1) === '/');\n };\n CentralDirectory.prototype.isFile = function isFile () { return !this.isDirectory(); };\n CentralDirectory.prototype.useUTF8 = function useUTF8 () { return (this.flag() & 0x800) === 0x800; };\n CentralDirectory.prototype.isEncrypted = function isEncrypted () { return (this.flag() & 0x1) === 0x1; };\n CentralDirectory.prototype.getFileData = function getFileData () {\n // Need to grab the header before we can figure out where the actual\n // compressed data starts.\n var start = this.headerRelativeOffset();\n var header = new FileHeader(this.zipData.slice(start));\n return new FileData(header, this, this.zipData.slice(start + header.totalSize()));\n };\n CentralDirectory.prototype.getData = function getData () {\n return this.getFileData().decompress();\n };\n CentralDirectory.prototype.getRawData = function getRawData () {\n return this.getFileData().getRawData();\n };\n CentralDirectory.prototype.getStats = function getStats () {\n return new Stats(FileType.FILE, this.uncompressedSize(), 0x16D, Date.now(), this.lastModFileTime().getTime());\n };\n/**\n * 4.3.16: end of central directory record\n * end of central dir signature 4 bytes (0x06054b50)\n * number of this disk 2 bytes\n * number of the disk with the\n * start of the central directory 2 bytes\n * total number of entries in the\n * central directory on this disk 2 bytes\n * total number of entries in\n * the central directory 2 bytes\n * size of the central directory 4 bytes\n * offset of start of central\n * directory with respect to\n * the starting disk number 4 bytes\n * .ZIP file comment length 2 bytes\n * .ZIP file comment (variable size)\n */\nvar EndOfCentralDirectory = function EndOfCentralDirectory(data) {\n this.data = data;\n if (this.data.readUInt32LE(0) !== 0x06054b50) {\n throw new ApiError(ErrorCode.EINVAL, (\"Invalid Zip file: End of central directory record has invalid signature: \" + (this.data.readUInt32LE(0))));\n }\n };\n EndOfCentralDirectory.prototype.diskNumber = function diskNumber () { return this.data.readUInt16LE(4); };\n EndOfCentralDirectory.prototype.cdDiskNumber = function cdDiskNumber () { return this.data.readUInt16LE(6); };\n EndOfCentralDirectory.prototype.cdDiskEntryCount = function cdDiskEntryCount () { return this.data.readUInt16LE(8); };\n EndOfCentralDirectory.prototype.cdTotalEntryCount = function cdTotalEntryCount () { return this.data.readUInt16LE(10); };\n EndOfCentralDirectory.prototype.cdSize = function cdSize () { return this.data.readUInt32LE(12); };\n EndOfCentralDirectory.prototype.cdOffset = function cdOffset () { return this.data.readUInt32LE(16); };\n EndOfCentralDirectory.prototype.cdZipCommentLength = function cdZipCommentLength () { return this.data.readUInt16LE(20); };\n EndOfCentralDirectory.prototype.cdZipComment = function cdZipComment () {\n // Assuming UTF-8. The specification doesn't specify.\n return safeToString(this.data, true, 22, this.cdZipCommentLength());\n };\n EndOfCentralDirectory.prototype.rawCdZipComment = function rawCdZipComment () {\n return this.data.slice(22, 22 + this.cdZipCommentLength());\n };\n/**\n * Contains the table of contents of a Zip file.\n */\nvar ZipTOC = function ZipTOC(index, directoryEntries, eocd, data) {\n this.index = index;\n this.directoryEntries = directoryEntries;\n this.eocd = eocd;\n this.data = data;\n };\n/**\n * Zip file-backed filesystem\n * Implemented according to the standard:\n * http://www.pkware.com/documents/casestudies/APPNOTE.TXT\n *\n * While there are a few zip libraries for JavaScript (e.g. JSZip and zip.js),\n * they are not a good match for BrowserFS. In particular, these libraries\n * perform a lot of unneeded data copying, and eagerly decompress every file\n * in the zip file upon loading to check the CRC32. They also eagerly decode\n * strings. Furthermore, these libraries duplicate functionality already present\n * in BrowserFS (e.g. UTF-8 decoding and binary data manipulation).\n *\n * This filesystem takes advantage of BrowserFS's Buffer implementation, which\n * efficiently represents the zip file in memory (in both ArrayBuffer-enabled\n * browsers *and* non-ArrayBuffer browsers), and which can neatly be 'sliced'\n * without copying data. Each struct defined in the standard is represented with\n * a buffer slice pointing to an offset in the zip file, and has getters for\n * each field. As we anticipate that this data will not be read often, we choose\n * not to store each struct field in the JavaScript object; instead, to reduce\n * memory consumption, we retrieve it directly from the binary data each time it\n * is requested.\n *\n * When the filesystem is instantiated, we determine the directory structure\n * of the zip file as quickly as possible. We lazily decompress and check the\n * CRC32 of files. We do not cache decompressed files; if this is a desired\n * feature, it is best implemented as a generic file system wrapper that can\n * cache data from arbitrary file systems.\n *\n * For inflation, we use `pako`'s implementation:\n * https://github.com/nodeca/pako\n *\n * Current limitations:\n * * No encryption.\n * * No ZIP64 support.\n * * Read-only.\n * Write support would require that we:\n * - Keep track of changed/new files.\n * - Compress changed files, and generate appropriate metadata for each.\n * - Update file offsets for other files in the zip file.\n * - Stream it out to a location.\n * This isn't that bad, so we might do this at a later date.\n */\nvar ZipFS = /*@__PURE__*/(function (SynchronousFileSystem$$1) {\n function ZipFS(input, name) {\n if ( name === void 0 ) name = '';\n\n SynchronousFileSystem$$1.call(this);\n this.name = name;\n this._index = new FileIndex();\n this._directoryEntries = [];\n this._eocd = null;\n this._index = input.index;\n this._directoryEntries = input.directoryEntries;\n this._eocd = input.eocd;\n this.data = input.data;\n }\n\n if ( SynchronousFileSystem$$1 ) ZipFS.__proto__ = SynchronousFileSystem$$1;\n ZipFS.prototype = Object.create( SynchronousFileSystem$$1 && SynchronousFileSystem$$1.prototype );\n ZipFS.prototype.constructor = ZipFS;\n /**\n * Constructs a ZipFS instance with the given options.\n */\n ZipFS.Create = function Create (opts, cb) {\n try {\n ZipFS._computeIndex(opts.zipData, function (e, zipTOC) {\n if (zipTOC) {\n var fs = new ZipFS(zipTOC, opts.name);\n cb(null, fs);\n }\n else {\n cb(e);\n }\n });\n }\n catch (e) {\n cb(e);\n }\n };\n ZipFS.isAvailable = function isAvailable () { return true; };\n ZipFS.RegisterDecompressionMethod = function RegisterDecompressionMethod (m, fcn) {\n decompressionMethods[m] = fcn;\n };\n /**\n * Locates the end of central directory record at the end of the file.\n * Throws an exception if it cannot be found.\n */\n ZipFS._getEOCD = function _getEOCD (data) {\n // Unfortunately, the comment is variable size and up to 64K in size.\n // We assume that the magic signature does not appear in the comment, and\n // in the bytes between the comment and the signature. Other ZIP\n // implementations make this same assumption, since the alternative is to\n // read thread every entry in the file to get to it. :(\n // These are *negative* offsets from the end of the file.\n var startOffset = 22;\n var endOffset = Math.min(startOffset + 0xFFFF, data.length - 1);\n // There's not even a byte alignment guarantee on the comment so we need to\n // search byte by byte. *grumble grumble*\n for (var i = startOffset; i < endOffset; i++) {\n // Magic number: EOCD Signature\n if (data.readUInt32LE(data.length - i) === 0x06054b50) {\n return new EndOfCentralDirectory(data.slice(data.length - i));\n }\n }\n throw new ApiError(ErrorCode.EINVAL, \"Invalid ZIP file: Could not locate End of Central Directory signature.\");\n };\n ZipFS._addToIndex = function _addToIndex (cd, index) {\n // Paths must be absolute, yet zip file paths are always relative to the\n // zip root. So we append '/' and call it a day.\n var filename = cd.fileName();\n if (filename.charAt(0) === '/') {\n throw new ApiError(ErrorCode.EPERM, \"Unexpectedly encountered an absolute path in a zip file. Please file a bug.\");\n }\n // XXX: For the file index, strip the trailing '/'.\n if (filename.charAt(filename.length - 1) === '/') {\n filename = filename.substr(0, filename.length - 1);\n }\n if (cd.isDirectory()) {\n index.addPathFast('/' + filename, new DirInode(cd));\n }\n else {\n index.addPathFast('/' + filename, new FileInode(cd));\n }\n };\n ZipFS._computeIndex = function _computeIndex (data, cb) {\n try {\n var index = new FileIndex();\n var eocd = ZipFS._getEOCD(data);\n if (eocd.diskNumber() !== eocd.cdDiskNumber()) {\n return cb(new ApiError(ErrorCode.EINVAL, \"ZipFS does not support spanned zip files.\"));\n }\n var cdPtr = eocd.cdOffset();\n if (cdPtr === 0xFFFFFFFF) {\n return cb(new ApiError(ErrorCode.EINVAL, \"ZipFS does not support Zip64.\"));\n }\n var cdEnd = cdPtr + eocd.cdSize();\n ZipFS._computeIndexResponsive(data, index, cdPtr, cdEnd, cb, [], eocd);\n }\n catch (e) {\n cb(e);\n }\n };\n ZipFS._computeIndexResponsiveTrampoline = function _computeIndexResponsiveTrampoline (data, index, cdPtr, cdEnd, cb, cdEntries, eocd) {\n try {\n ZipFS._computeIndexResponsive(data, index, cdPtr, cdEnd, cb, cdEntries, eocd);\n }\n catch (e) {\n cb(e);\n }\n };\n ZipFS._computeIndexResponsive = function _computeIndexResponsive (data, index, cdPtr, cdEnd, cb, cdEntries, eocd) {\n if (cdPtr < cdEnd) {\n var count = 0;\n while (count++ < 200 && cdPtr < cdEnd) {\n var cd = new CentralDirectory(data, data.slice(cdPtr));\n ZipFS._addToIndex(cd, index);\n cdPtr += cd.totalSize();\n cdEntries.push(cd);\n }\n setImmediate$1(function () {\n ZipFS._computeIndexResponsiveTrampoline(data, index, cdPtr, cdEnd, cb, cdEntries, eocd);\n });\n }\n else {\n cb(null, new ZipTOC(index, cdEntries, eocd, data));\n }\n };\n ZipFS.prototype.getName = function getName () {\n return ZipFS.Name + (this.name !== '' ? (\" \" + (this.name)) : '');\n };\n /**\n * Get the CentralDirectory object for the given path.\n */\n ZipFS.prototype.getCentralDirectoryEntry = function getCentralDirectoryEntry (path$$1) {\n var inode = this._index.getInode(path$$1);\n if (inode === null) {\n throw ApiError.ENOENT(path$$1);\n }\n if (isFileInode(inode)) {\n return inode.getData();\n }\n else if (isDirInode(inode)) {\n return inode.getData();\n }\n else {\n // Should never occur.\n throw ApiError.EPERM((\"Invalid inode: \" + inode));\n }\n };\n ZipFS.prototype.getCentralDirectoryEntryAt = function getCentralDirectoryEntryAt (index) {\n var dirEntry = this._directoryEntries[index];\n if (!dirEntry) {\n throw new RangeError((\"Invalid directory index: \" + index + \".\"));\n }\n return dirEntry;\n };\n ZipFS.prototype.getNumberOfCentralDirectoryEntries = function getNumberOfCentralDirectoryEntries () {\n return this._directoryEntries.length;\n };\n ZipFS.prototype.getEndOfCentralDirectory = function getEndOfCentralDirectory () {\n return this._eocd;\n };\n ZipFS.prototype.diskSpace = function diskSpace (path$$1, cb) {\n // Read-only file system.\n cb(this.data.length, 0);\n };\n ZipFS.prototype.isReadOnly = function isReadOnly () {\n return true;\n };\n ZipFS.prototype.supportsLinks = function supportsLinks () {\n return false;\n };\n ZipFS.prototype.supportsProps = function supportsProps () {\n return false;\n };\n ZipFS.prototype.supportsSynch = function supportsSynch () {\n return true;\n };\n ZipFS.prototype.statSync = function statSync (path$$1, isLstat) {\n var inode = this._index.getInode(path$$1);\n if (inode === null) {\n throw ApiError.ENOENT(path$$1);\n }\n var stats;\n if (isFileInode(inode)) {\n stats = inode.getData().getStats();\n }\n else if (isDirInode(inode)) {\n stats = inode.getStats();\n }\n else {\n throw new ApiError(ErrorCode.EINVAL, \"Invalid inode.\");\n }\n return stats;\n };\n ZipFS.prototype.openSync = function openSync (path$$1, flags, mode) {\n // INVARIANT: Cannot write to RO file systems.\n if (flags.isWriteable()) {\n throw new ApiError(ErrorCode.EPERM, path$$1);\n }\n // Check if the path exists, and is a file.\n var inode = this._index.getInode(path$$1);\n if (!inode) {\n throw ApiError.ENOENT(path$$1);\n }\n else if (isFileInode(inode)) {\n var cdRecord = inode.getData();\n var stats = cdRecord.getStats();\n switch (flags.pathExistsAction()) {\n case ActionType.THROW_EXCEPTION:\n case ActionType.TRUNCATE_FILE:\n throw ApiError.EEXIST(path$$1);\n case ActionType.NOP:\n return new NoSyncFile(this, path$$1, flags, stats, cdRecord.getData());\n default:\n throw new ApiError(ErrorCode.EINVAL, 'Invalid FileMode object.');\n }\n }\n else {\n throw ApiError.EISDIR(path$$1);\n }\n };\n ZipFS.prototype.readdirSync = function readdirSync (path$$1) {\n // Check if it exists.\n var inode = this._index.getInode(path$$1);\n if (!inode) {\n throw ApiError.ENOENT(path$$1);\n }\n else if (isDirInode(inode)) {\n return inode.getListing();\n }\n else {\n throw ApiError.ENOTDIR(path$$1);\n }\n };\n /**\n * Specially-optimized readfile.\n */\n ZipFS.prototype.readFileSync = function readFileSync (fname, encoding, flag) {\n // Get file.\n var fd = this.openSync(fname, flag, 0x1a4);\n try {\n var fdCast = fd;\n var fdBuff = fdCast.getBuffer();\n if (encoding === null) {\n return copyingSlice(fdBuff);\n }\n return fdBuff.toString(encoding);\n }\n finally {\n fd.closeSync();\n }\n };\n\n return ZipFS;\n}(SynchronousFileSystem));\nZipFS.Name = \"ZipFS\";\nZipFS.Options = {\n zipData: {\n type: \"object\",\n description: \"The zip file as a Buffer object.\",\n validator: bufferValidator\n },\n name: {\n type: \"string\",\n optional: true,\n description: \"The name of the zip file (optional).\"\n }\n};\nZipFS.CompressionMethod = CompressionMethod;\nZipFS.RegisterDecompressionMethod(CompressionMethod.DEFLATE, function (data, compressedSize, uncompressedSize) {\n return arrayish2Buffer(inflateRaw(data.slice(0, compressedSize), { chunkSize: uncompressedSize }));\n});\nZipFS.RegisterDecompressionMethod(CompressionMethod.STORED, function (data, compressedSize, uncompressedSize) {\n return copyingSlice(data, 0, uncompressedSize);\n});\n\n/**\n * @hidden\n */\nvar rockRidgeIdentifier = \"IEEE_P1282\";\n/**\n * @hidden\n */\nfunction getASCIIString(data, startIndex, length) {\n return data.toString('ascii', startIndex, startIndex + length).trim();\n}\n/**\n * @hidden\n */\nfunction getJolietString(data, startIndex, length) {\n if (length === 1) {\n // Special: Root, parent, current directory are still a single byte.\n return String.fromCharCode(data[startIndex]);\n }\n // UTF16-BE, which isn't natively supported by NodeJS Buffers.\n // Length should be even, but pessimistically floor just in case.\n var pairs = Math.floor(length / 2);\n var chars = new Array(pairs);\n for (var i = 0; i < pairs; i++) {\n var pos = startIndex + (i << 1);\n chars[i] = String.fromCharCode(data[pos + 1] | (data[pos] << 8));\n }\n return chars.join('');\n}\n/**\n * @hidden\n */\nfunction getDate(data, startIndex) {\n var year = parseInt(getASCIIString(data, startIndex, 4), 10);\n var mon = parseInt(getASCIIString(data, startIndex + 4, 2), 10);\n var day = parseInt(getASCIIString(data, startIndex + 6, 2), 10);\n var hour = parseInt(getASCIIString(data, startIndex + 8, 2), 10);\n var min = parseInt(getASCIIString(data, startIndex + 10, 2), 10);\n var sec = parseInt(getASCIIString(data, startIndex + 12, 2), 10);\n var hundrethsSec = parseInt(getASCIIString(data, startIndex + 14, 2), 10);\n // Last is a time-zone offset, but JavaScript dates don't support time zones well.\n return new Date(year, mon, day, hour, min, sec, hundrethsSec * 100);\n}\n/**\n * @hidden\n */\nfunction getShortFormDate(data, startIndex) {\n var yearsSince1900 = data[startIndex];\n var month = data[startIndex + 1];\n var day = data[startIndex + 2];\n var hour = data[startIndex + 3];\n var minute = data[startIndex + 4];\n var second = data[startIndex + 5];\n // JavaScript's Date support isn't so great; ignore timezone.\n // const offsetFromGMT = this._data[24];\n return new Date(yearsSince1900, month - 1, day, hour, minute, second);\n}\n/**\n * @hidden\n */\nfunction constructSystemUseEntry(bigData, i) {\n var data = bigData.slice(i);\n var sue = new SystemUseEntry(data);\n switch (sue.signatureWord()) {\n case 17221 /* CE */:\n return new CEEntry(data);\n case 20548 /* PD */:\n return new PDEntry(data);\n case 21328 /* SP */:\n return new SPEntry(data);\n case 21332 /* ST */:\n return new STEntry(data);\n case 17746 /* ER */:\n return new EREntry(data);\n case 17747 /* ES */:\n return new ESEntry(data);\n case 20568 /* PX */:\n return new PXEntry(data);\n case 20558 /* PN */:\n return new PNEntry(data);\n case 21324 /* SL */:\n return new SLEntry(data);\n case 20045 /* NM */:\n return new NMEntry(data);\n case 17228 /* CL */:\n return new CLEntry(data);\n case 20556 /* PL */:\n return new PLEntry(data);\n case 21061 /* RE */:\n return new REEntry(data);\n case 21574 /* TF */:\n return new TFEntry(data);\n case 21318 /* SF */:\n return new SFEntry(data);\n case 21074 /* RR */:\n return new RREntry(data);\n default:\n return sue;\n }\n}\n/**\n * @hidden\n */\nfunction constructSystemUseEntries(data, i, len, isoData) {\n // If the remaining allocated space following the last recorded System Use Entry in a System\n // Use field or Continuation Area is less than four bytes long, it cannot contain a System\n // Use Entry and shall be ignored\n len = len - 4;\n var entries = new Array();\n while (i < len) {\n var entry = constructSystemUseEntry(data, i);\n var length = entry.length();\n if (length === 0) {\n // Invalid SU section; prevent infinite loop.\n return entries;\n }\n i += length;\n if (entry instanceof STEntry) {\n // ST indicates the end of entries.\n break;\n }\n if (entry instanceof CEEntry) {\n entries = entries.concat(entry.getEntries(isoData));\n }\n else {\n entries.push(entry);\n }\n }\n return entries;\n}\n/**\n * @hidden\n */\nvar VolumeDescriptor = function VolumeDescriptor(data) {\n this._data = data;\n};\nVolumeDescriptor.prototype.type = function type () {\n return this._data[0];\n};\nVolumeDescriptor.prototype.standardIdentifier = function standardIdentifier () {\n return getASCIIString(this._data, 1, 5);\n};\nVolumeDescriptor.prototype.version = function version () {\n return this._data[6];\n};\nVolumeDescriptor.prototype.data = function data () {\n return this._data.slice(7, 2048);\n};\n/**\n * @hidden\n */\nvar PrimaryOrSupplementaryVolumeDescriptor = /*@__PURE__*/(function (VolumeDescriptor) {\n function PrimaryOrSupplementaryVolumeDescriptor(data) {\n VolumeDescriptor.call(this, data);\n this._root = null;\n }\n\n if ( VolumeDescriptor ) PrimaryOrSupplementaryVolumeDescriptor.__proto__ = VolumeDescriptor;\n PrimaryOrSupplementaryVolumeDescriptor.prototype = Object.create( VolumeDescriptor && VolumeDescriptor.prototype );\n PrimaryOrSupplementaryVolumeDescriptor.prototype.constructor = PrimaryOrSupplementaryVolumeDescriptor;\n PrimaryOrSupplementaryVolumeDescriptor.prototype.systemIdentifier = function systemIdentifier () {\n return this._getString32(8);\n };\n PrimaryOrSupplementaryVolumeDescriptor.prototype.volumeIdentifier = function volumeIdentifier () {\n return this._getString32(40);\n };\n PrimaryOrSupplementaryVolumeDescriptor.prototype.volumeSpaceSize = function volumeSpaceSize () {\n return this._data.readUInt32LE(80);\n };\n PrimaryOrSupplementaryVolumeDescriptor.prototype.volumeSetSize = function volumeSetSize () {\n return this._data.readUInt16LE(120);\n };\n PrimaryOrSupplementaryVolumeDescriptor.prototype.volumeSequenceNumber = function volumeSequenceNumber () {\n return this._data.readUInt16LE(124);\n };\n PrimaryOrSupplementaryVolumeDescriptor.prototype.logicalBlockSize = function logicalBlockSize () {\n return this._data.readUInt16LE(128);\n };\n PrimaryOrSupplementaryVolumeDescriptor.prototype.pathTableSize = function pathTableSize () {\n return this._data.readUInt32LE(132);\n };\n PrimaryOrSupplementaryVolumeDescriptor.prototype.locationOfTypeLPathTable = function locationOfTypeLPathTable () {\n return this._data.readUInt32LE(140);\n };\n PrimaryOrSupplementaryVolumeDescriptor.prototype.locationOfOptionalTypeLPathTable = function locationOfOptionalTypeLPathTable () {\n return this._data.readUInt32LE(144);\n };\n PrimaryOrSupplementaryVolumeDescriptor.prototype.locationOfTypeMPathTable = function locationOfTypeMPathTable () {\n return this._data.readUInt32BE(148);\n };\n PrimaryOrSupplementaryVolumeDescriptor.prototype.locationOfOptionalTypeMPathTable = function locationOfOptionalTypeMPathTable () {\n return this._data.readUInt32BE(152);\n };\n PrimaryOrSupplementaryVolumeDescriptor.prototype.rootDirectoryEntry = function rootDirectoryEntry (isoData) {\n if (this._root === null) {\n this._root = this._constructRootDirectoryRecord(this._data.slice(156));\n this._root.rootCheckForRockRidge(isoData);\n }\n return this._root;\n };\n PrimaryOrSupplementaryVolumeDescriptor.prototype.volumeSetIdentifier = function volumeSetIdentifier () {\n return this._getString(190, 128);\n };\n PrimaryOrSupplementaryVolumeDescriptor.prototype.publisherIdentifier = function publisherIdentifier () {\n return this._getString(318, 128);\n };\n PrimaryOrSupplementaryVolumeDescriptor.prototype.dataPreparerIdentifier = function dataPreparerIdentifier () {\n return this._getString(446, 128);\n };\n PrimaryOrSupplementaryVolumeDescriptor.prototype.applicationIdentifier = function applicationIdentifier () {\n return this._getString(574, 128);\n };\n PrimaryOrSupplementaryVolumeDescriptor.prototype.copyrightFileIdentifier = function copyrightFileIdentifier () {\n return this._getString(702, 38);\n };\n PrimaryOrSupplementaryVolumeDescriptor.prototype.abstractFileIdentifier = function abstractFileIdentifier () {\n return this._getString(740, 36);\n };\n PrimaryOrSupplementaryVolumeDescriptor.prototype.bibliographicFileIdentifier = function bibliographicFileIdentifier () {\n return this._getString(776, 37);\n };\n PrimaryOrSupplementaryVolumeDescriptor.prototype.volumeCreationDate = function volumeCreationDate () {\n return getDate(this._data, 813);\n };\n PrimaryOrSupplementaryVolumeDescriptor.prototype.volumeModificationDate = function volumeModificationDate () {\n return getDate(this._data, 830);\n };\n PrimaryOrSupplementaryVolumeDescriptor.prototype.volumeExpirationDate = function volumeExpirationDate () {\n return getDate(this._data, 847);\n };\n PrimaryOrSupplementaryVolumeDescriptor.prototype.volumeEffectiveDate = function volumeEffectiveDate () {\n return getDate(this._data, 864);\n };\n PrimaryOrSupplementaryVolumeDescriptor.prototype.fileStructureVersion = function fileStructureVersion () {\n return this._data[881];\n };\n PrimaryOrSupplementaryVolumeDescriptor.prototype.applicationUsed = function applicationUsed () {\n return this._data.slice(883, 883 + 512);\n };\n PrimaryOrSupplementaryVolumeDescriptor.prototype.reserved = function reserved () {\n return this._data.slice(1395, 1395 + 653);\n };\n PrimaryOrSupplementaryVolumeDescriptor.prototype._getString32 = function _getString32 (idx) {\n return this._getString(idx, 32);\n };\n\n return PrimaryOrSupplementaryVolumeDescriptor;\n}(VolumeDescriptor));\n/**\n * @hidden\n */\nvar PrimaryVolumeDescriptor = /*@__PURE__*/(function (PrimaryOrSupplementaryVolumeDescriptor) {\n function PrimaryVolumeDescriptor(data) {\n PrimaryOrSupplementaryVolumeDescriptor.call(this, data);\n if (this.type() !== 1 /* PrimaryVolumeDescriptor */) {\n throw new ApiError(ErrorCode.EIO, \"Invalid primary volume descriptor.\");\n }\n }\n\n if ( PrimaryOrSupplementaryVolumeDescriptor ) PrimaryVolumeDescriptor.__proto__ = PrimaryOrSupplementaryVolumeDescriptor;\n PrimaryVolumeDescriptor.prototype = Object.create( PrimaryOrSupplementaryVolumeDescriptor && PrimaryOrSupplementaryVolumeDescriptor.prototype );\n PrimaryVolumeDescriptor.prototype.constructor = PrimaryVolumeDescriptor;\n PrimaryVolumeDescriptor.prototype.name = function name () {\n return \"ISO9660\";\n };\n PrimaryVolumeDescriptor.prototype._constructRootDirectoryRecord = function _constructRootDirectoryRecord (data) {\n return new ISODirectoryRecord(data, -1);\n };\n PrimaryVolumeDescriptor.prototype._getString = function _getString (idx, len) {\n return this._getString(idx, len);\n };\n\n return PrimaryVolumeDescriptor;\n}(PrimaryOrSupplementaryVolumeDescriptor));\n/**\n * @hidden\n */\nvar SupplementaryVolumeDescriptor = /*@__PURE__*/(function (PrimaryOrSupplementaryVolumeDescriptor) {\n function SupplementaryVolumeDescriptor(data) {\n PrimaryOrSupplementaryVolumeDescriptor.call(this, data);\n if (this.type() !== 2 /* SupplementaryVolumeDescriptor */) {\n throw new ApiError(ErrorCode.EIO, \"Invalid supplementary volume descriptor.\");\n }\n var escapeSequence = this.escapeSequence();\n var third = escapeSequence[2];\n // Third character identifies what 'level' of the UCS specification to follow.\n // We ignore it.\n if (escapeSequence[0] !== 0x25 || escapeSequence[1] !== 0x2F ||\n (third !== 0x40 && third !== 0x43 && third !== 0x45)) {\n throw new ApiError(ErrorCode.EIO, (\"Unrecognized escape sequence for SupplementaryVolumeDescriptor: \" + (escapeSequence.toString())));\n }\n }\n\n if ( PrimaryOrSupplementaryVolumeDescriptor ) SupplementaryVolumeDescriptor.__proto__ = PrimaryOrSupplementaryVolumeDescriptor;\n SupplementaryVolumeDescriptor.prototype = Object.create( PrimaryOrSupplementaryVolumeDescriptor && PrimaryOrSupplementaryVolumeDescriptor.prototype );\n SupplementaryVolumeDescriptor.prototype.constructor = SupplementaryVolumeDescriptor;\n SupplementaryVolumeDescriptor.prototype.name = function name () {\n return \"Joliet\";\n };\n SupplementaryVolumeDescriptor.prototype.escapeSequence = function escapeSequence () {\n return this._data.slice(88, 120);\n };\n SupplementaryVolumeDescriptor.prototype._constructRootDirectoryRecord = function _constructRootDirectoryRecord (data) {\n return new JolietDirectoryRecord(data, -1);\n };\n SupplementaryVolumeDescriptor.prototype._getString = function _getString (idx, len) {\n return getJolietString(this._data, idx, len);\n };\n\n return SupplementaryVolumeDescriptor;\n}(PrimaryOrSupplementaryVolumeDescriptor));\n/**\n * @hidden\n */\nvar DirectoryRecord = function DirectoryRecord(data, rockRidgeOffset) {\n this._suEntries = null;\n this._fileOrDir = null;\n this._data = data;\n this._rockRidgeOffset = rockRidgeOffset;\n};\nDirectoryRecord.prototype.hasRockRidge = function hasRockRidge () {\n return this._rockRidgeOffset > -1;\n};\nDirectoryRecord.prototype.getRockRidgeOffset = function getRockRidgeOffset () {\n return this._rockRidgeOffset;\n};\n/**\n * !!ONLY VALID ON ROOT NODE!!\n * Checks if Rock Ridge is enabled, and sets the offset.\n */\nDirectoryRecord.prototype.rootCheckForRockRidge = function rootCheckForRockRidge (isoData) {\n var dir = this.getDirectory(isoData);\n this._rockRidgeOffset = dir.getDotEntry(isoData)._getRockRidgeOffset(isoData);\n if (this._rockRidgeOffset > -1) {\n // Wipe out directory. Start over with RR knowledge.\n this._fileOrDir = null;\n }\n};\nDirectoryRecord.prototype.length = function length () {\n return this._data[0];\n};\nDirectoryRecord.prototype.extendedAttributeRecordLength = function extendedAttributeRecordLength () {\n return this._data[1];\n};\nDirectoryRecord.prototype.lba = function lba () {\n return this._data.readUInt32LE(2) * 2048;\n};\nDirectoryRecord.prototype.dataLength = function dataLength () {\n return this._data.readUInt32LE(10);\n};\nDirectoryRecord.prototype.recordingDate = function recordingDate () {\n return getShortFormDate(this._data, 18);\n};\nDirectoryRecord.prototype.fileFlags = function fileFlags () {\n return this._data[25];\n};\nDirectoryRecord.prototype.fileUnitSize = function fileUnitSize () {\n return this._data[26];\n};\nDirectoryRecord.prototype.interleaveGapSize = function interleaveGapSize () {\n return this._data[27];\n};\nDirectoryRecord.prototype.volumeSequenceNumber = function volumeSequenceNumber () {\n return this._data.readUInt16LE(28);\n};\nDirectoryRecord.prototype.identifier = function identifier () {\n return this._getString(33, this._data[32]);\n};\nDirectoryRecord.prototype.fileName = function fileName (isoData) {\n if (this.hasRockRidge()) {\n var fn = this._rockRidgeFilename(isoData);\n if (fn !== null) {\n return fn;\n }\n }\n var ident = this.identifier();\n if (this.isDirectory(isoData)) {\n return ident;\n }\n // Files:\n // - MUST have 0x2E (.) separating the name from the extension\n // - MUST have 0x3B (;) separating the file name and extension from the version\n // Gets expanded to two-byte char in Unicode directory records.\n var versionSeparator = ident.indexOf(';');\n if (versionSeparator === -1) {\n // Some Joliet filenames lack the version separator, despite the standard\n // specifying that it should be there.\n return ident;\n }\n else if (ident[versionSeparator - 1] === '.') {\n // Empty extension. Do not include '.' in the filename.\n return ident.slice(0, versionSeparator - 1);\n }\n else {\n // Include up to version separator.\n return ident.slice(0, versionSeparator);\n }\n};\nDirectoryRecord.prototype.isDirectory = function isDirectory (isoData) {\n var rv = !!(this.fileFlags() & 2 /* Directory */);\n // If it lacks the Directory flag, it may still be a directory if we've exceeded the directory\n // depth limit. Rock Ridge marks these as files and adds a special attribute.\n if (!rv && this.hasRockRidge()) {\n rv = this.getSUEntries(isoData).filter(function (e) { return e instanceof CLEntry; }).length > 0;\n }\n return rv;\n};\nDirectoryRecord.prototype.isSymlink = function isSymlink (isoData) {\n return this.hasRockRidge() && this.getSUEntries(isoData).filter(function (e) { return e instanceof SLEntry; }).length > 0;\n};\nDirectoryRecord.prototype.getSymlinkPath = function getSymlinkPath (isoData) {\n var p = \"\";\n var entries = this.getSUEntries(isoData);\n var getStr = this._getGetString();\n for (var i$1 = 0, list$1 = entries; i$1 < list$1.length; i$1 += 1) {\n var entry = list$1[i$1];\n\n if (entry instanceof SLEntry) {\n var components = entry.componentRecords();\n for (var i = 0, list = components; i < list.length; i += 1) {\n var component = list[i];\n\n var flags = component.flags();\n if (flags & 2 /* CURRENT */) {\n p += \"./\";\n }\n else if (flags & 4 /* PARENT */) {\n p += \"../\";\n }\n else if (flags & 8 /* ROOT */) {\n p += \"/\";\n }\n else {\n p += component.content(getStr);\n if (!(flags & 1 /* CONTINUE */)) {\n p += '/';\n }\n }\n }\n if (!entry.continueFlag()) {\n // We are done with this link.\n break;\n }\n }\n }\n if (p.length > 1 && p[p.length - 1] === '/') {\n // Trim trailing '/'.\n return p.slice(0, p.length - 1);\n }\n else {\n return p;\n }\n};\nDirectoryRecord.prototype.getFile = function getFile (isoData) {\n if (this.isDirectory(isoData)) {\n throw new Error(\"Tried to get a File from a directory.\");\n }\n if (this._fileOrDir === null) {\n this._fileOrDir = isoData.slice(this.lba(), this.lba() + this.dataLength());\n }\n return this._fileOrDir;\n};\nDirectoryRecord.prototype.getDirectory = function getDirectory (isoData) {\n if (!this.isDirectory(isoData)) {\n throw new Error(\"Tried to get a Directory from a file.\");\n }\n if (this._fileOrDir === null) {\n this._fileOrDir = this._constructDirectory(isoData);\n }\n return this._fileOrDir;\n};\nDirectoryRecord.prototype.getSUEntries = function getSUEntries (isoData) {\n if (!this._suEntries) {\n this._constructSUEntries(isoData);\n }\n return this._suEntries;\n};\nDirectoryRecord.prototype._rockRidgeFilename = function _rockRidgeFilename (isoData) {\n var nmEntries = this.getSUEntries(isoData).filter(function (e) { return e instanceof NMEntry; });\n if (nmEntries.length === 0 || nmEntries[0].flags() & (2 /* CURRENT */ | 4 /* PARENT */)) {\n return null;\n }\n var str = '';\n var getString = this._getGetString();\n for (var i = 0, list = nmEntries; i < list.length; i += 1) {\n var e = list[i];\n\n str += e.name(getString);\n if (!(e.flags() & 1 /* CONTINUE */)) {\n break;\n }\n }\n return str;\n};\nDirectoryRecord.prototype._constructSUEntries = function _constructSUEntries (isoData) {\n var i = 33 + this._data[32];\n if (i % 2 === 1) {\n // Skip padding field.\n i++;\n }\n i += this._rockRidgeOffset;\n this._suEntries = constructSystemUseEntries(this._data, i, this.length(), isoData);\n};\n/**\n * !!ONLY VALID ON FIRST ENTRY OF ROOT DIRECTORY!!\n * Returns -1 if rock ridge is not enabled. Otherwise, returns the offset\n * at which system use fields begin.\n */\nDirectoryRecord.prototype._getRockRidgeOffset = function _getRockRidgeOffset (isoData) {\n // In the worst case, we get some garbage SU entries.\n // Fudge offset to 0 before proceeding.\n this._rockRidgeOffset = 0;\n var suEntries = this.getSUEntries(isoData);\n if (suEntries.length > 0) {\n var spEntry = suEntries[0];\n if (spEntry instanceof SPEntry && spEntry.checkBytesPass()) {\n // SUSP is in use.\n for (var i = 1; i < suEntries.length; i++) {\n var entry = suEntries[i];\n if (entry instanceof RREntry || (entry instanceof EREntry && entry.extensionIdentifier() === rockRidgeIdentifier)) {\n // Rock Ridge is in use!\n return spEntry.bytesSkipped();\n }\n }\n }\n }\n // Failed.\n this._rockRidgeOffset = -1;\n return -1;\n};\n/**\n * @hidden\n */\nvar ISODirectoryRecord = /*@__PURE__*/(function (DirectoryRecord) {\n function ISODirectoryRecord(data, rockRidgeOffset) {\n DirectoryRecord.call(this, data, rockRidgeOffset);\n }\n\n if ( DirectoryRecord ) ISODirectoryRecord.__proto__ = DirectoryRecord;\n ISODirectoryRecord.prototype = Object.create( DirectoryRecord && DirectoryRecord.prototype );\n ISODirectoryRecord.prototype.constructor = ISODirectoryRecord;\n ISODirectoryRecord.prototype._getString = function _getString (i, len) {\n return getASCIIString(this._data, i, len);\n };\n ISODirectoryRecord.prototype._constructDirectory = function _constructDirectory (isoData) {\n return new ISODirectory(this, isoData);\n };\n ISODirectoryRecord.prototype._getGetString = function _getGetString () {\n return getASCIIString;\n };\n\n return ISODirectoryRecord;\n}(DirectoryRecord));\n/**\n * @hidden\n */\nvar JolietDirectoryRecord = /*@__PURE__*/(function (DirectoryRecord) {\n function JolietDirectoryRecord(data, rockRidgeOffset) {\n DirectoryRecord.call(this, data, rockRidgeOffset);\n }\n\n if ( DirectoryRecord ) JolietDirectoryRecord.__proto__ = DirectoryRecord;\n JolietDirectoryRecord.prototype = Object.create( DirectoryRecord && DirectoryRecord.prototype );\n JolietDirectoryRecord.prototype.constructor = JolietDirectoryRecord;\n JolietDirectoryRecord.prototype._getString = function _getString (i, len) {\n return getJolietString(this._data, i, len);\n };\n JolietDirectoryRecord.prototype._constructDirectory = function _constructDirectory (isoData) {\n return new JolietDirectory(this, isoData);\n };\n JolietDirectoryRecord.prototype._getGetString = function _getGetString () {\n return getJolietString;\n };\n\n return JolietDirectoryRecord;\n}(DirectoryRecord));\n/**\n * @hidden\n */\nvar SystemUseEntry = function SystemUseEntry(data) {\n this._data = data;\n};\nSystemUseEntry.prototype.signatureWord = function signatureWord () {\n return this._data.readUInt16BE(0);\n};\nSystemUseEntry.prototype.signatureWordString = function signatureWordString () {\n return getASCIIString(this._data, 0, 2);\n};\nSystemUseEntry.prototype.length = function length () {\n return this._data[2];\n};\nSystemUseEntry.prototype.suVersion = function suVersion () {\n return this._data[3];\n};\n/**\n * Continuation entry.\n * @hidden\n */\nvar CEEntry = /*@__PURE__*/(function (SystemUseEntry) {\n function CEEntry(data) {\n SystemUseEntry.call(this, data);\n this._entries = null;\n }\n\n if ( SystemUseEntry ) CEEntry.__proto__ = SystemUseEntry;\n CEEntry.prototype = Object.create( SystemUseEntry && SystemUseEntry.prototype );\n CEEntry.prototype.constructor = CEEntry;\n /**\n * Logical block address of the continuation area.\n */\n CEEntry.prototype.continuationLba = function continuationLba () {\n return this._data.readUInt32LE(4);\n };\n /**\n * Offset into the logical block.\n */\n CEEntry.prototype.continuationLbaOffset = function continuationLbaOffset () {\n return this._data.readUInt32LE(12);\n };\n /**\n * Length of the continuation area.\n */\n CEEntry.prototype.continuationLength = function continuationLength () {\n return this._data.readUInt32LE(20);\n };\n CEEntry.prototype.getEntries = function getEntries (isoData) {\n if (!this._entries) {\n var start = this.continuationLba() * 2048 + this.continuationLbaOffset();\n this._entries = constructSystemUseEntries(isoData, start, this.continuationLength(), isoData);\n }\n return this._entries;\n };\n\n return CEEntry;\n}(SystemUseEntry));\n/**\n * Padding entry.\n * @hidden\n */\nvar PDEntry = /*@__PURE__*/(function (SystemUseEntry) {\n function PDEntry(data) {\n SystemUseEntry.call(this, data);\n }\n\n if ( SystemUseEntry ) PDEntry.__proto__ = SystemUseEntry;\n PDEntry.prototype = Object.create( SystemUseEntry && SystemUseEntry.prototype );\n PDEntry.prototype.constructor = PDEntry;\n\n return PDEntry;\n}(SystemUseEntry));\n/**\n * Identifies that SUSP is in-use.\n * @hidden\n */\nvar SPEntry = /*@__PURE__*/(function (SystemUseEntry) {\n function SPEntry(data) {\n SystemUseEntry.call(this, data);\n }\n\n if ( SystemUseEntry ) SPEntry.__proto__ = SystemUseEntry;\n SPEntry.prototype = Object.create( SystemUseEntry && SystemUseEntry.prototype );\n SPEntry.prototype.constructor = SPEntry;\n SPEntry.prototype.checkBytesPass = function checkBytesPass () {\n return this._data[4] === 0xBE && this._data[5] === 0xEF;\n };\n SPEntry.prototype.bytesSkipped = function bytesSkipped () {\n return this._data[6];\n };\n\n return SPEntry;\n}(SystemUseEntry));\n/**\n * Identifies the end of the SUSP entries.\n * @hidden\n */\nvar STEntry = /*@__PURE__*/(function (SystemUseEntry) {\n function STEntry(data) {\n SystemUseEntry.call(this, data);\n }\n\n if ( SystemUseEntry ) STEntry.__proto__ = SystemUseEntry;\n STEntry.prototype = Object.create( SystemUseEntry && SystemUseEntry.prototype );\n STEntry.prototype.constructor = STEntry;\n\n return STEntry;\n}(SystemUseEntry));\n/**\n * Specifies system-specific extensions to SUSP.\n * @hidden\n */\nvar EREntry = /*@__PURE__*/(function (SystemUseEntry) {\n function EREntry(data) {\n SystemUseEntry.call(this, data);\n }\n\n if ( SystemUseEntry ) EREntry.__proto__ = SystemUseEntry;\n EREntry.prototype = Object.create( SystemUseEntry && SystemUseEntry.prototype );\n EREntry.prototype.constructor = EREntry;\n EREntry.prototype.identifierLength = function identifierLength () {\n return this._data[4];\n };\n EREntry.prototype.descriptorLength = function descriptorLength () {\n return this._data[5];\n };\n EREntry.prototype.sourceLength = function sourceLength () {\n return this._data[6];\n };\n EREntry.prototype.extensionVersion = function extensionVersion () {\n return this._data[7];\n };\n EREntry.prototype.extensionIdentifier = function extensionIdentifier () {\n return getASCIIString(this._data, 8, this.identifierLength());\n };\n EREntry.prototype.extensionDescriptor = function extensionDescriptor () {\n return getASCIIString(this._data, 8 + this.identifierLength(), this.descriptorLength());\n };\n EREntry.prototype.extensionSource = function extensionSource () {\n return getASCIIString(this._data, 8 + this.identifierLength() + this.descriptorLength(), this.sourceLength());\n };\n\n return EREntry;\n}(SystemUseEntry));\n/**\n * @hidden\n */\nvar ESEntry = /*@__PURE__*/(function (SystemUseEntry) {\n function ESEntry(data) {\n SystemUseEntry.call(this, data);\n }\n\n if ( SystemUseEntry ) ESEntry.__proto__ = SystemUseEntry;\n ESEntry.prototype = Object.create( SystemUseEntry && SystemUseEntry.prototype );\n ESEntry.prototype.constructor = ESEntry;\n ESEntry.prototype.extensionSequence = function extensionSequence () {\n return this._data[4];\n };\n\n return ESEntry;\n}(SystemUseEntry));\n/**\n * RockRidge: Marks that RockRidge is in use [deprecated]\n * @hidden\n */\nvar RREntry = /*@__PURE__*/(function (SystemUseEntry) {\n function RREntry(data) {\n SystemUseEntry.call(this, data);\n }\n\n if ( SystemUseEntry ) RREntry.__proto__ = SystemUseEntry;\n RREntry.prototype = Object.create( SystemUseEntry && SystemUseEntry.prototype );\n RREntry.prototype.constructor = RREntry;\n\n return RREntry;\n}(SystemUseEntry));\n/**\n * RockRidge: Records POSIX file attributes.\n * @hidden\n */\nvar PXEntry = /*@__PURE__*/(function (SystemUseEntry) {\n function PXEntry(data) {\n SystemUseEntry.call(this, data);\n }\n\n if ( SystemUseEntry ) PXEntry.__proto__ = SystemUseEntry;\n PXEntry.prototype = Object.create( SystemUseEntry && SystemUseEntry.prototype );\n PXEntry.prototype.constructor = PXEntry;\n PXEntry.prototype.mode = function mode () {\n return this._data.readUInt32LE(4);\n };\n PXEntry.prototype.fileLinks = function fileLinks () {\n return this._data.readUInt32LE(12);\n };\n PXEntry.prototype.uid = function uid () {\n return this._data.readUInt32LE(20);\n };\n PXEntry.prototype.gid = function gid () {\n return this._data.readUInt32LE(28);\n };\n PXEntry.prototype.inode = function inode () {\n return this._data.readUInt32LE(36);\n };\n\n return PXEntry;\n}(SystemUseEntry));\n/**\n * RockRidge: Records POSIX device number.\n * @hidden\n */\nvar PNEntry = /*@__PURE__*/(function (SystemUseEntry) {\n function PNEntry(data) {\n SystemUseEntry.call(this, data);\n }\n\n if ( SystemUseEntry ) PNEntry.__proto__ = SystemUseEntry;\n PNEntry.prototype = Object.create( SystemUseEntry && SystemUseEntry.prototype );\n PNEntry.prototype.constructor = PNEntry;\n PNEntry.prototype.devTHigh = function devTHigh () {\n return this._data.readUInt32LE(4);\n };\n PNEntry.prototype.devTLow = function devTLow () {\n return this._data.readUInt32LE(12);\n };\n\n return PNEntry;\n}(SystemUseEntry));\n/**\n * RockRidge: Records symbolic link\n * @hidden\n */\nvar SLEntry = /*@__PURE__*/(function (SystemUseEntry) {\n function SLEntry(data) {\n SystemUseEntry.call(this, data);\n }\n\n if ( SystemUseEntry ) SLEntry.__proto__ = SystemUseEntry;\n SLEntry.prototype = Object.create( SystemUseEntry && SystemUseEntry.prototype );\n SLEntry.prototype.constructor = SLEntry;\n SLEntry.prototype.flags = function flags () {\n return this._data[4];\n };\n SLEntry.prototype.continueFlag = function continueFlag () {\n return this.flags() & 0x1;\n };\n SLEntry.prototype.componentRecords = function componentRecords () {\n var records = new Array();\n var i = 5;\n while (i < this.length()) {\n var record = new SLComponentRecord(this._data.slice(i));\n records.push(record);\n i += record.length();\n }\n return records;\n };\n\n return SLEntry;\n}(SystemUseEntry));\n/**\n * @hidden\n */\nvar SLComponentRecord = function SLComponentRecord(data) {\n this._data = data;\n};\nSLComponentRecord.prototype.flags = function flags () {\n return this._data[0];\n};\nSLComponentRecord.prototype.length = function length () {\n return 2 + this.componentLength();\n};\nSLComponentRecord.prototype.componentLength = function componentLength () {\n return this._data[1];\n};\nSLComponentRecord.prototype.content = function content (getString) {\n return getString(this._data, 2, this.componentLength());\n};\n/**\n * RockRidge: Records alternate file name\n * @hidden\n */\nvar NMEntry = /*@__PURE__*/(function (SystemUseEntry) {\n function NMEntry(data) {\n SystemUseEntry.call(this, data);\n }\n\n if ( SystemUseEntry ) NMEntry.__proto__ = SystemUseEntry;\n NMEntry.prototype = Object.create( SystemUseEntry && SystemUseEntry.prototype );\n NMEntry.prototype.constructor = NMEntry;\n NMEntry.prototype.flags = function flags () {\n return this._data[4];\n };\n NMEntry.prototype.name = function name (getString) {\n return getString(this._data, 5, this.length() - 5);\n };\n\n return NMEntry;\n}(SystemUseEntry));\n/**\n * RockRidge: Records child link\n * @hidden\n */\nvar CLEntry = /*@__PURE__*/(function (SystemUseEntry) {\n function CLEntry(data) {\n SystemUseEntry.call(this, data);\n }\n\n if ( SystemUseEntry ) CLEntry.__proto__ = SystemUseEntry;\n CLEntry.prototype = Object.create( SystemUseEntry && SystemUseEntry.prototype );\n CLEntry.prototype.constructor = CLEntry;\n CLEntry.prototype.childDirectoryLba = function childDirectoryLba () {\n return this._data.readUInt32LE(4);\n };\n\n return CLEntry;\n}(SystemUseEntry));\n/**\n * RockRidge: Records parent link.\n * @hidden\n */\nvar PLEntry = /*@__PURE__*/(function (SystemUseEntry) {\n function PLEntry(data) {\n SystemUseEntry.call(this, data);\n }\n\n if ( SystemUseEntry ) PLEntry.__proto__ = SystemUseEntry;\n PLEntry.prototype = Object.create( SystemUseEntry && SystemUseEntry.prototype );\n PLEntry.prototype.constructor = PLEntry;\n PLEntry.prototype.parentDirectoryLba = function parentDirectoryLba () {\n return this._data.readUInt32LE(4);\n };\n\n return PLEntry;\n}(SystemUseEntry));\n/**\n * RockRidge: Records relocated directory.\n * @hidden\n */\nvar REEntry = /*@__PURE__*/(function (SystemUseEntry) {\n function REEntry(data) {\n SystemUseEntry.call(this, data);\n }\n\n if ( SystemUseEntry ) REEntry.__proto__ = SystemUseEntry;\n REEntry.prototype = Object.create( SystemUseEntry && SystemUseEntry.prototype );\n REEntry.prototype.constructor = REEntry;\n\n return REEntry;\n}(SystemUseEntry));\n/**\n * RockRidge: Records file timestamps\n * @hidden\n */\nvar TFEntry = /*@__PURE__*/(function (SystemUseEntry) {\n function TFEntry(data) {\n SystemUseEntry.call(this, data);\n }\n\n if ( SystemUseEntry ) TFEntry.__proto__ = SystemUseEntry;\n TFEntry.prototype = Object.create( SystemUseEntry && SystemUseEntry.prototype );\n TFEntry.prototype.constructor = TFEntry;\n TFEntry.prototype.flags = function flags () {\n return this._data[4];\n };\n TFEntry.prototype.creation = function creation () {\n if (this.flags() & 1 /* CREATION */) {\n if (this._longFormDates()) {\n return getDate(this._data, 5);\n }\n else {\n return getShortFormDate(this._data, 5);\n }\n }\n else {\n return null;\n }\n };\n TFEntry.prototype.modify = function modify () {\n if (this.flags() & 2 /* MODIFY */) {\n var previousDates = (this.flags() & 1 /* CREATION */) ? 1 : 0;\n if (this._longFormDates) {\n return getDate(this._data, 5 + (previousDates * 17));\n }\n else {\n return getShortFormDate(this._data, 5 + (previousDates * 7));\n }\n }\n else {\n return null;\n }\n };\n TFEntry.prototype.access = function access () {\n if (this.flags() & 4 /* ACCESS */) {\n var previousDates = (this.flags() & 1 /* CREATION */) ? 1 : 0;\n previousDates += (this.flags() & 2 /* MODIFY */) ? 1 : 0;\n if (this._longFormDates) {\n return getDate(this._data, 5 + (previousDates * 17));\n }\n else {\n return getShortFormDate(this._data, 5 + (previousDates * 7));\n }\n }\n else {\n return null;\n }\n };\n TFEntry.prototype.backup = function backup () {\n if (this.flags() & 16 /* BACKUP */) {\n var previousDates = (this.flags() & 1 /* CREATION */) ? 1 : 0;\n previousDates += (this.flags() & 2 /* MODIFY */) ? 1 : 0;\n previousDates += (this.flags() & 4 /* ACCESS */) ? 1 : 0;\n if (this._longFormDates) {\n return getDate(this._data, 5 + (previousDates * 17));\n }\n else {\n return getShortFormDate(this._data, 5 + (previousDates * 7));\n }\n }\n else {\n return null;\n }\n };\n TFEntry.prototype.expiration = function expiration () {\n if (this.flags() & 32 /* EXPIRATION */) {\n var previousDates = (this.flags() & 1 /* CREATION */) ? 1 : 0;\n previousDates += (this.flags() & 2 /* MODIFY */) ? 1 : 0;\n previousDates += (this.flags() & 4 /* ACCESS */) ? 1 : 0;\n previousDates += (this.flags() & 16 /* BACKUP */) ? 1 : 0;\n if (this._longFormDates) {\n return getDate(this._data, 5 + (previousDates * 17));\n }\n else {\n return getShortFormDate(this._data, 5 + (previousDates * 7));\n }\n }\n else {\n return null;\n }\n };\n TFEntry.prototype.effective = function effective () {\n if (this.flags() & 64 /* EFFECTIVE */) {\n var previousDates = (this.flags() & 1 /* CREATION */) ? 1 : 0;\n previousDates += (this.flags() & 2 /* MODIFY */) ? 1 : 0;\n previousDates += (this.flags() & 4 /* ACCESS */) ? 1 : 0;\n previousDates += (this.flags() & 16 /* BACKUP */) ? 1 : 0;\n previousDates += (this.flags() & 32 /* EXPIRATION */) ? 1 : 0;\n if (this._longFormDates) {\n return getDate(this._data, 5 + (previousDates * 17));\n }\n else {\n return getShortFormDate(this._data, 5 + (previousDates * 7));\n }\n }\n else {\n return null;\n }\n };\n TFEntry.prototype._longFormDates = function _longFormDates () {\n return !!(this.flags() && 128 /* LONG_FORM */);\n };\n\n return TFEntry;\n}(SystemUseEntry));\n/**\n * RockRidge: File data in sparse format.\n * @hidden\n */\nvar SFEntry = /*@__PURE__*/(function (SystemUseEntry) {\n function SFEntry(data) {\n SystemUseEntry.call(this, data);\n }\n\n if ( SystemUseEntry ) SFEntry.__proto__ = SystemUseEntry;\n SFEntry.prototype = Object.create( SystemUseEntry && SystemUseEntry.prototype );\n SFEntry.prototype.constructor = SFEntry;\n SFEntry.prototype.virtualSizeHigh = function virtualSizeHigh () {\n return this._data.readUInt32LE(4);\n };\n SFEntry.prototype.virtualSizeLow = function virtualSizeLow () {\n return this._data.readUInt32LE(12);\n };\n SFEntry.prototype.tableDepth = function tableDepth () {\n return this._data[20];\n };\n\n return SFEntry;\n}(SystemUseEntry));\n/**\n * @hidden\n */\nvar Directory = function Directory(record, isoData) {\n this._fileList = [];\n this._fileMap = {};\n this._record = record;\n var i = record.lba();\n var iLimit = i + record.dataLength();\n if (!(record.fileFlags() & 2 /* Directory */)) {\n // Must have a CL entry.\n var cl = record.getSUEntries(isoData).filter(function (e) { return e instanceof CLEntry; })[0];\n i = cl.childDirectoryLba() * 2048;\n iLimit = Infinity;\n }\n while (i < iLimit) {\n var len = isoData[i];\n // Zero-padding between sectors.\n // TODO: Could optimize this to seek to nearest-sector upon\n // seeing a 0.\n if (len === 0) {\n i++;\n continue;\n }\n var r = this._constructDirectoryRecord(isoData.slice(i));\n var fname = r.fileName(isoData);\n // Skip '.' and '..' entries.\n if (fname !== '\\u0000' && fname !== '\\u0001') {\n // Skip relocated entries.\n if (!r.hasRockRidge() || r.getSUEntries(isoData).filter(function (e) { return e instanceof REEntry; }).length === 0) {\n this._fileMap[fname] = r;\n this._fileList.push(fname);\n }\n }\n else if (iLimit === Infinity) {\n // First entry contains needed data.\n iLimit = i + r.dataLength();\n }\n i += r.length();\n }\n};\n/**\n * Get the record with the given name.\n * Returns undefined if not present.\n */\nDirectory.prototype.getRecord = function getRecord (name) {\n return this._fileMap[name];\n};\nDirectory.prototype.getFileList = function getFileList () {\n return this._fileList;\n};\nDirectory.prototype.getDotEntry = function getDotEntry (isoData) {\n return this._constructDirectoryRecord(isoData.slice(this._record.lba()));\n};\n/**\n * @hidden\n */\nvar ISODirectory = /*@__PURE__*/(function (Directory) {\n function ISODirectory(record, isoData) {\n Directory.call(this, record, isoData);\n }\n\n if ( Directory ) ISODirectory.__proto__ = Directory;\n ISODirectory.prototype = Object.create( Directory && Directory.prototype );\n ISODirectory.prototype.constructor = ISODirectory;\n ISODirectory.prototype._constructDirectoryRecord = function _constructDirectoryRecord (data) {\n return new ISODirectoryRecord(data, this._record.getRockRidgeOffset());\n };\n\n return ISODirectory;\n}(Directory));\n/**\n * @hidden\n */\nvar JolietDirectory = /*@__PURE__*/(function (Directory) {\n function JolietDirectory(record, isoData) {\n Directory.call(this, record, isoData);\n }\n\n if ( Directory ) JolietDirectory.__proto__ = Directory;\n JolietDirectory.prototype = Object.create( Directory && Directory.prototype );\n JolietDirectory.prototype.constructor = JolietDirectory;\n JolietDirectory.prototype._constructDirectoryRecord = function _constructDirectoryRecord (data) {\n return new JolietDirectoryRecord(data, this._record.getRockRidgeOffset());\n };\n\n return JolietDirectory;\n}(Directory));\n/**\n * Mounts an ISO file as a read-only file system.\n *\n * Supports:\n * * Vanilla ISO9660 ISOs\n * * Microsoft Joliet and Rock Ridge extensions to the ISO9660 standard\n */\nvar IsoFS = /*@__PURE__*/(function (SynchronousFileSystem$$1) {\n function IsoFS(data, name) {\n var this$1 = this;\n if ( name === void 0 ) name = \"\";\n\n SynchronousFileSystem$$1.call(this);\n this._data = data;\n // Skip first 16 sectors.\n var vdTerminatorFound = false;\n var i = 16 * 2048;\n var candidateVDs = new Array();\n while (!vdTerminatorFound) {\n var slice = data.slice(i);\n var vd = new VolumeDescriptor(slice);\n switch (vd.type()) {\n case 1 /* PrimaryVolumeDescriptor */:\n candidateVDs.push(new PrimaryVolumeDescriptor(slice));\n break;\n case 2 /* SupplementaryVolumeDescriptor */:\n candidateVDs.push(new SupplementaryVolumeDescriptor(slice));\n break;\n case 255 /* VolumeDescriptorSetTerminator */:\n vdTerminatorFound = true;\n break;\n }\n i += 2048;\n }\n if (candidateVDs.length === 0) {\n throw new ApiError(ErrorCode.EIO, \"Unable to find a suitable volume descriptor.\");\n }\n candidateVDs.forEach(function (v) {\n // Take an SVD over a PVD.\n if (!this$1._pvd || this$1._pvd.type() !== 2 /* SupplementaryVolumeDescriptor */) {\n this$1._pvd = v;\n }\n });\n this._root = this._pvd.rootDirectoryEntry(data);\n this._name = name;\n }\n\n if ( SynchronousFileSystem$$1 ) IsoFS.__proto__ = SynchronousFileSystem$$1;\n IsoFS.prototype = Object.create( SynchronousFileSystem$$1 && SynchronousFileSystem$$1.prototype );\n IsoFS.prototype.constructor = IsoFS;\n /**\n * Creates an IsoFS instance with the given options.\n */\n IsoFS.Create = function Create (opts, cb) {\n try {\n cb(null, new IsoFS(opts.data, opts.name));\n }\n catch (e) {\n cb(e);\n }\n };\n IsoFS.isAvailable = function isAvailable () {\n return true;\n };\n IsoFS.prototype.getName = function getName () {\n var name = \"IsoFS\" + (this._name) + (this._pvd ? (\"-\" + (this._pvd.name())) : '');\n if (this._root && this._root.hasRockRidge()) {\n name += \"-RockRidge\";\n }\n return name;\n };\n IsoFS.prototype.diskSpace = function diskSpace (path$$1, cb) {\n // Read-only file system.\n cb(this._data.length, 0);\n };\n IsoFS.prototype.isReadOnly = function isReadOnly () {\n return true;\n };\n IsoFS.prototype.supportsLinks = function supportsLinks () {\n return false;\n };\n IsoFS.prototype.supportsProps = function supportsProps () {\n return false;\n };\n IsoFS.prototype.supportsSynch = function supportsSynch () {\n return true;\n };\n IsoFS.prototype.statSync = function statSync (p, isLstat) {\n var record = this._getDirectoryRecord(p);\n if (record === null) {\n throw ApiError.ENOENT(p);\n }\n return this._getStats(p, record);\n };\n IsoFS.prototype.openSync = function openSync (p, flags, mode) {\n // INVARIANT: Cannot write to RO file systems.\n if (flags.isWriteable()) {\n throw new ApiError(ErrorCode.EPERM, p);\n }\n // Check if the path exists, and is a file.\n var record = this._getDirectoryRecord(p);\n if (!record) {\n throw ApiError.ENOENT(p);\n }\n else if (record.isSymlink(this._data)) {\n return this.openSync(path.resolve(p, record.getSymlinkPath(this._data)), flags, mode);\n }\n else if (!record.isDirectory(this._data)) {\n var data = record.getFile(this._data);\n var stats = this._getStats(p, record);\n switch (flags.pathExistsAction()) {\n case ActionType.THROW_EXCEPTION:\n case ActionType.TRUNCATE_FILE:\n throw ApiError.EEXIST(p);\n case ActionType.NOP:\n return new NoSyncFile(this, p, flags, stats, data);\n default:\n throw new ApiError(ErrorCode.EINVAL, 'Invalid FileMode object.');\n }\n }\n else {\n throw ApiError.EISDIR(p);\n }\n };\n IsoFS.prototype.readdirSync = function readdirSync (path$$1) {\n // Check if it exists.\n var record = this._getDirectoryRecord(path$$1);\n if (!record) {\n throw ApiError.ENOENT(path$$1);\n }\n else if (record.isDirectory(this._data)) {\n return record.getDirectory(this._data).getFileList().slice(0);\n }\n else {\n throw ApiError.ENOTDIR(path$$1);\n }\n };\n /**\n * Specially-optimized readfile.\n */\n IsoFS.prototype.readFileSync = function readFileSync (fname, encoding, flag) {\n // Get file.\n var fd = this.openSync(fname, flag, 0x1a4);\n try {\n var fdCast = fd;\n var fdBuff = fdCast.getBuffer();\n if (encoding === null) {\n return copyingSlice(fdBuff);\n }\n return fdBuff.toString(encoding);\n }\n finally {\n fd.closeSync();\n }\n };\n IsoFS.prototype._getDirectoryRecord = function _getDirectoryRecord (path$$1) {\n // Special case.\n if (path$$1 === '/') {\n return this._root;\n }\n var components = path$$1.split('/').slice(1);\n var dir = this._root;\n for (var i = 0, list = components; i < list.length; i += 1) {\n var component = list[i];\n\n if (dir.isDirectory(this._data)) {\n dir = dir.getDirectory(this._data).getRecord(component);\n if (!dir) {\n return null;\n }\n }\n else {\n return null;\n }\n }\n return dir;\n };\n IsoFS.prototype._getStats = function _getStats (p, record) {\n if (record.isSymlink(this._data)) {\n var newP = path.resolve(p, record.getSymlinkPath(this._data));\n var dirRec = this._getDirectoryRecord(newP);\n if (!dirRec) {\n return null;\n }\n return this._getStats(newP, dirRec);\n }\n else {\n var len = record.dataLength();\n var mode = 0x16D;\n var date = record.recordingDate().getTime();\n var atime = date;\n var mtime = date;\n var ctime = date;\n if (record.hasRockRidge()) {\n var entries = record.getSUEntries(this._data);\n for (var i = 0, list = entries; i < list.length; i += 1) {\n var entry = list[i];\n\n if (entry instanceof PXEntry) {\n mode = entry.mode();\n }\n else if (entry instanceof TFEntry) {\n var flags = entry.flags();\n if (flags & 4 /* ACCESS */) {\n atime = entry.access().getTime();\n }\n if (flags & 2 /* MODIFY */) {\n mtime = entry.modify().getTime();\n }\n if (flags & 1 /* CREATION */) {\n ctime = entry.creation().getTime();\n }\n }\n }\n }\n // Mask out writeable flags. This is a RO file system.\n mode = mode & 0x16D;\n return new Stats(record.isDirectory(this._data) ? FileType.DIRECTORY : FileType.FILE, len, mode, atime, mtime, ctime);\n }\n };\n\n return IsoFS;\n}(SynchronousFileSystem));\nIsoFS.Name = \"IsoFS\";\nIsoFS.Options = {\n data: {\n type: \"object\",\n description: \"The ISO file in a buffer\",\n validator: bufferValidator\n }\n};\n\n// Monkey-patch `Create` functions to check options before file system initialization.\n[AsyncMirror, DropboxFileSystem, EmscriptenFileSystem, FolderAdapter, HTML5FS, InMemoryFileSystem, IndexedDBFileSystem, IsoFS, LocalStorageFileSystem, MountableFileSystem, OverlayFS, WorkerFS, HTTPRequest, ZipFS].forEach(function (fsType) {\n var create = fsType.Create;\n fsType.Create = function (opts, cb) {\n var oneArg = typeof (opts) === \"function\";\n var normalizedCb = oneArg ? opts : cb;\n var normalizedOpts = oneArg ? {} : opts;\n function wrappedCb(e) {\n if (e) {\n normalizedCb(e);\n }\n else {\n create.call(fsType, normalizedOpts, normalizedCb);\n }\n }\n checkOptions(fsType, normalizedOpts, wrappedCb);\n };\n});\n/**\n * @hidden\n */\nvar Backends = { AsyncMirror: AsyncMirror, Dropbox: DropboxFileSystem, Emscripten: EmscriptenFileSystem, FolderAdapter: FolderAdapter, HTML5FS: HTML5FS, InMemory: InMemoryFileSystem, IndexedDB: IndexedDBFileSystem, IsoFS: IsoFS, LocalStorage: LocalStorageFileSystem, MountableFileSystem: MountableFileSystem, OverlayFS: OverlayFS, WorkerFS: WorkerFS, HTTPRequest: HTTPRequest, XmlHttpRequest: HTTPRequest, ZipFS: ZipFS };\n\n/**\n * BrowserFS's main module. This is exposed in the browser via the BrowserFS global.\n * Due to limitations in typedoc, we document these functions in ./typedoc.ts.\n */\nif (process['initializeTTYs']) {\n process['initializeTTYs']();\n}\n/**\n * Installs BFSRequire as global `require`, a Node Buffer polyfill as the global `Buffer` variable,\n * and a Node process polyfill as the global `process` variable.\n */\nfunction install(obj) {\n obj.Buffer = Buffer;\n obj.process = process;\n var oldRequire = obj.require ? obj.require : null;\n // Monkey-patch require for Node-style code.\n obj.require = function (arg) {\n var rv = BFSRequire(arg);\n if (!rv) {\n return oldRequire.apply(null, Array.prototype.slice.call(arguments, 0));\n }\n else {\n return rv;\n }\n };\n}\n/**\n * @hidden\n */\nfunction registerFileSystem(name, fs) {\n Backends[name] = fs;\n}\nfunction BFSRequire(module) {\n switch (module) {\n case 'fs':\n return _fsMock;\n case 'path':\n return path;\n case 'buffer':\n // The 'buffer' module has 'Buffer' as a property.\n return buffer;\n case 'process':\n return process;\n case 'bfs_utils':\n return BFSUtils;\n default:\n return Backends[module];\n }\n}\n/**\n * Initializes BrowserFS with the given root file system.\n */\nfunction initialize(rootfs) {\n return _fsMock.initialize(rootfs);\n}\n/**\n * Creates a file system with the given configuration, and initializes BrowserFS with it.\n * See the FileSystemConfiguration type for more info on the configuration object.\n */\nfunction configure(config, cb) {\n getFileSystem(config, function (e, fs) {\n if (fs) {\n initialize(fs);\n cb();\n }\n else {\n cb(e);\n }\n });\n}\n/**\n * Retrieve a file system with the given configuration.\n * @param config A FileSystemConfiguration object. See FileSystemConfiguration for details.\n * @param cb Called when the file system is constructed, or when an error occurs.\n */\nfunction getFileSystem(config, cb) {\n var fsName = config['fs'];\n if (!fsName) {\n return cb(new ApiError(ErrorCode.EPERM, 'Missing \"fs\" property on configuration object.'));\n }\n var options = config['options'];\n var waitCount = 0;\n var called = false;\n function finish() {\n if (!called) {\n called = true;\n var fsc = Backends[fsName];\n if (!fsc) {\n cb(new ApiError(ErrorCode.EPERM, (\"File system \" + fsName + \" is not available in BrowserFS.\")));\n }\n else {\n fsc.Create(options, cb);\n }\n }\n }\n if (options !== null && typeof (options) === \"object\") {\n var finishedIterating = false;\n var props = Object.keys(options).filter(function (k) { return k !== 'fs'; });\n // Check recursively if other fields have 'fs' properties.\n props.forEach(function (p) {\n var d = options[p];\n if (d !== null && typeof (d) === \"object\" && d['fs']) {\n waitCount++;\n getFileSystem(d, function (e, fs) {\n waitCount--;\n if (e) {\n if (called) {\n return;\n }\n called = true;\n cb(e);\n }\n else {\n options[p] = fs;\n if (waitCount === 0 && finishedIterating) {\n finish();\n }\n }\n });\n }\n });\n finishedIterating = true;\n }\n if (waitCount === 0) {\n finish();\n }\n}\n\n/**\n * BrowserFS's main entry point.\n * It installs all of the needed polyfills, and requires() the main module.\n */\n// IE substr does not support negative indices\nif ('ab'.substr(-1) !== 'b') {\n String.prototype.substr = function (substr) {\n return function (start, length) {\n // did we get a negative start, calculate how much it is from the\n // beginning of the string\n if (start < 0) {\n start = this.length + start;\n }\n // call the original function\n return substr.call(this, start, length);\n };\n }(String.prototype.substr);\n}\n// Polyfill for Uint8Array.prototype.slice.\n// Safari and some other browsers do not define it.\nif (typeof (ArrayBuffer) !== 'undefined' && typeof (Uint8Array) !== 'undefined') {\n if (!Uint8Array.prototype['slice']) {\n Uint8Array.prototype.slice = function (start, end) {\n if ( start === void 0 ) start = 0;\n if ( end === void 0 ) end = this.length;\n\n var self = this;\n if (start < 0) {\n start = this.length + start;\n if (start < 0) {\n start = 0;\n }\n }\n if (end < 0) {\n end = this.length + end;\n if (end < 0) {\n end = 0;\n }\n }\n if (end < start) {\n end = start;\n }\n return new Uint8Array(self.buffer, self.byteOffset + start, end - start);\n };\n }\n}\n\nexports.install = install;\nexports.registerFileSystem = registerFileSystem;\nexports.BFSRequire = BFSRequire;\nexports.initialize = initialize;\nexports.configure = configure;\nexports.getFileSystem = getFileSystem;\nexports.EmscriptenFS = BFSEmscriptenFS;\nexports.FileSystem = Backends;\nexports.Errors = api_error;\nexports.setImmediate = setImmediate$1;\n","'use strict'\n\nexports.byteLength = byteLength\nexports.toByteArray = toByteArray\nexports.fromByteArray = fromByteArray\n\nvar lookup = []\nvar revLookup = []\nvar Arr = typeof Uint8Array !== 'undefined' ? Uint8Array : Array\n\nvar code = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'\nfor (var i = 0, len = code.length; i < len; ++i) {\n lookup[i] = code[i]\n revLookup[code.charCodeAt(i)] = i\n}\n\n// Support decoding URL-safe base64 strings, as Node.js does.\n// See: https://en.wikipedia.org/wiki/Base64#URL_applications\nrevLookup['-'.charCodeAt(0)] = 62\nrevLookup['_'.charCodeAt(0)] = 63\n\nfunction getLens (b64) {\n var len = b64.length\n\n if (len % 4 > 0) {\n throw new Error('Invalid string. Length must be a multiple of 4')\n }\n\n // Trim off extra bytes after placeholder bytes are found\n // See: https://github.com/beatgammit/base64-js/issues/42\n var validLen = b64.indexOf('=')\n if (validLen === -1) validLen = len\n\n var placeHoldersLen = validLen === len\n ? 0\n : 4 - (validLen % 4)\n\n return [validLen, placeHoldersLen]\n}\n\n// base64 is 4/3 + up to two characters of the original data\nfunction byteLength (b64) {\n var lens = getLens(b64)\n var validLen = lens[0]\n var placeHoldersLen = lens[1]\n return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen\n}\n\nfunction _byteLength (b64, validLen, placeHoldersLen) {\n return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen\n}\n\nfunction toByteArray (b64) {\n var tmp\n var lens = getLens(b64)\n var validLen = lens[0]\n var placeHoldersLen = lens[1]\n\n var arr = new Arr(_byteLength(b64, validLen, placeHoldersLen))\n\n var curByte = 0\n\n // if there are placeholders, only get up to the last complete 4 chars\n var len = placeHoldersLen > 0\n ? validLen - 4\n : validLen\n\n var i\n for (i = 0; i < len; i += 4) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 18) |\n (revLookup[b64.charCodeAt(i + 1)] << 12) |\n (revLookup[b64.charCodeAt(i + 2)] << 6) |\n revLookup[b64.charCodeAt(i + 3)]\n arr[curByte++] = (tmp >> 16) & 0xFF\n arr[curByte++] = (tmp >> 8) & 0xFF\n arr[curByte++] = tmp & 0xFF\n }\n\n if (placeHoldersLen === 2) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 2) |\n (revLookup[b64.charCodeAt(i + 1)] >> 4)\n arr[curByte++] = tmp & 0xFF\n }\n\n if (placeHoldersLen === 1) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 10) |\n (revLookup[b64.charCodeAt(i + 1)] << 4) |\n (revLookup[b64.charCodeAt(i + 2)] >> 2)\n arr[curByte++] = (tmp >> 8) & 0xFF\n arr[curByte++] = tmp & 0xFF\n }\n\n return arr\n}\n\nfunction tripletToBase64 (num) {\n return lookup[num >> 18 & 0x3F] +\n lookup[num >> 12 & 0x3F] +\n lookup[num >> 6 & 0x3F] +\n lookup[num & 0x3F]\n}\n\nfunction encodeChunk (uint8, start, end) {\n var tmp\n var output = []\n for (var i = start; i < end; i += 3) {\n tmp =\n ((uint8[i] << 16) & 0xFF0000) +\n ((uint8[i + 1] << 8) & 0xFF00) +\n (uint8[i + 2] & 0xFF)\n output.push(tripletToBase64(tmp))\n }\n return output.join('')\n}\n\nfunction fromByteArray (uint8) {\n var tmp\n var len = uint8.length\n var extraBytes = len % 3 // if we have 1 byte left, pad 2 bytes\n var parts = []\n var maxChunkLength = 16383 // must be multiple of 3\n\n // go through the array every three bytes, we'll deal with trailing stuff later\n for (var i = 0, len2 = len - extraBytes; i < len2; i += maxChunkLength) {\n parts.push(encodeChunk(\n uint8, i, (i + maxChunkLength) > len2 ? len2 : (i + maxChunkLength)\n ))\n }\n\n // pad the end with zeros, but make sure to not forget the extra bytes\n if (extraBytes === 1) {\n tmp = uint8[len - 1]\n parts.push(\n lookup[tmp >> 2] +\n lookup[(tmp << 4) & 0x3F] +\n '=='\n )\n } else if (extraBytes === 2) {\n tmp = (uint8[len - 2] << 8) + uint8[len - 1]\n parts.push(\n lookup[tmp >> 10] +\n lookup[(tmp >> 4) & 0x3F] +\n lookup[(tmp << 2) & 0x3F] +\n '='\n )\n }\n\n return parts.join('')\n}\n","exports.read = function (buffer, offset, isLE, mLen, nBytes) {\n var e, m\n var eLen = (nBytes * 8) - mLen - 1\n var eMax = (1 << eLen) - 1\n var eBias = eMax >> 1\n var nBits = -7\n var i = isLE ? (nBytes - 1) : 0\n var d = isLE ? -1 : 1\n var s = buffer[offset + i]\n\n i += d\n\n e = s & ((1 << (-nBits)) - 1)\n s >>= (-nBits)\n nBits += eLen\n for (; nBits > 0; e = (e * 256) + buffer[offset + i], i += d, nBits -= 8) {}\n\n m = e & ((1 << (-nBits)) - 1)\n e >>= (-nBits)\n nBits += mLen\n for (; nBits > 0; m = (m * 256) + buffer[offset + i], i += d, nBits -= 8) {}\n\n if (e === 0) {\n e = 1 - eBias\n } else if (e === eMax) {\n return m ? NaN : ((s ? -1 : 1) * Infinity)\n } else {\n m = m + Math.pow(2, mLen)\n e = e - eBias\n }\n return (s ? -1 : 1) * m * Math.pow(2, e - mLen)\n}\n\nexports.write = function (buffer, value, offset, isLE, mLen, nBytes) {\n var e, m, c\n var eLen = (nBytes * 8) - mLen - 1\n var eMax = (1 << eLen) - 1\n var eBias = eMax >> 1\n var rt = (mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0)\n var i = isLE ? 0 : (nBytes - 1)\n var d = isLE ? 1 : -1\n var s = value < 0 || (value === 0 && 1 / value < 0) ? 1 : 0\n\n value = Math.abs(value)\n\n if (isNaN(value) || value === Infinity) {\n m = isNaN(value) ? 1 : 0\n e = eMax\n } else {\n e = Math.floor(Math.log(value) / Math.LN2)\n if (value * (c = Math.pow(2, -e)) < 1) {\n e--\n c *= 2\n }\n if (e + eBias >= 1) {\n value += rt / c\n } else {\n value += rt * Math.pow(2, 1 - eBias)\n }\n if (value * c >= 2) {\n e++\n c /= 2\n }\n\n if (e + eBias >= eMax) {\n m = 0\n e = eMax\n } else if (e + eBias >= 1) {\n m = ((value * c) - 1) * Math.pow(2, mLen)\n e = e + eBias\n } else {\n m = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen)\n e = 0\n }\n }\n\n for (; mLen >= 8; buffer[offset + i] = m & 0xff, i += d, m /= 256, mLen -= 8) {}\n\n e = (e << mLen) | m\n eLen += mLen\n for (; eLen > 0; buffer[offset + i] = e & 0xff, i += d, e /= 256, eLen -= 8) {}\n\n buffer[offset + i - d] |= s * 128\n}\n","// Use path and TTY for type information only. We lazily pull them in\n// to avoid circular dependencies :(\n// (path depends on process for cwd(), TTY depends on streams which depends\n// on process.nextTick/process.stdout/stderr/stdin).\nimport _path = require('path');\nimport _TTY = require('./tty');\nimport events = require('events');\n\n// Path depends on process. Avoid a circular reference by dynamically including path when we need it.\nvar path: typeof _path = null;\n\nclass Item {\n private fun: Function;\n private array: any[];\n constructor(fun: Function, array: any[]) {\n this.fun = fun;\n this.array = array;\n }\n\n public run(): void {\n this.fun.apply(null, this.array);\n }\n}\n\n/**\n * Contains a queue of Items for process.nextTick.\n * Inspired by node-process: https://github.com/defunctzombie/node-process\n */\nclass NextTickQueue {\n private _queue: Item[] = [];\n private _draining = false;\n // Used/assigned by the drainQueue function.\n private _currentQueue: Item[] = null;\n private _queueIndex = -1;\n\n public push(item: Item): void {\n if (this._queue.push(item) === 1 && !this._draining) {\n setTimeout(() => this._drainQueue(), 0);\n }\n }\n\n private _cleanUpNextTick() {\n this._draining = false;\n if (this._currentQueue && this._currentQueue.length) {\n this._queue = this._currentQueue.concat(this._queue);\n } else {\n this._queueIndex = -1;\n }\n if (this._queue.length) {\n this._drainQueue();\n }\n }\n\n private _drainQueue() {\n if (this._draining) {\n return;\n }\n // If an Item throws an unhandled exception, this function will clean things up.\n var timeout = setTimeout(() => this._cleanUpNextTick());\n this._draining = true;\n\n var len = this._queue.length;\n while(len) {\n this._currentQueue = this._queue;\n this._queue = [];\n while (++this._queueIndex < len) {\n if (this._currentQueue) {\n this._currentQueue[this._queueIndex].run();\n }\n }\n this._queueIndex = -1;\n len = this._queue.length;\n }\n this._currentQueue = null;\n this._draining = false;\n clearTimeout(timeout);\n }\n}\n\n/**\n * Partial implementation of Node's `process` module.\n * We implement the portions that are relevant for the filesystem.\n * @see http://nodejs.org/api/process.html\n * @class\n */\nclass Process extends events.EventEmitter implements NodeJS.Process {\n private startTime = Date.now();\n\n private _cwd: string = '/';\n /**\n * Changes the current working directory.\n *\n * **Note**: BrowserFS does not validate that the directory actually exists.\n *\n * @example Usage example\n * console.log('Starting directory: ' + process.cwd());\n * process.chdir('/tmp');\n * console.log('New directory: ' + process.cwd());\n * @param [String] dir The directory to change to.\n */\n public chdir(dir: string): void {\n // XXX: Circular dependency hack.\n if (path === null) {\n path = require('path');\n }\n this._cwd = path.resolve(dir);\n }\n /**\n * Returns the current working directory.\n * @example Usage example\n * console.log('Current directory: ' + process.cwd());\n * @return [String] The current working directory.\n */\n public cwd(): string {\n return this._cwd;\n }\n /**\n * Returns what platform you are running on.\n * @return [String]\n */\n public platform: string = 'browser';\n /**\n * Number of seconds BrowserFS has been running.\n * @return [Number]\n */\n public uptime(): number {\n return ((Date.now() - this.startTime) / 1000) | 0;\n }\n\n public argv: string[] = [];\n public execArgv: string[] = [];\n public stdout: _TTY = null;\n public stderr: _TTY = null;\n public stdin: _TTY = null;\n public domain: NodeJS.Domain = null;\n\n private _queue: NextTickQueue = new NextTickQueue();\n\n public nextTick(fun: any, ...args: any[]) {\n this._queue.push(new Item(fun, args));\n }\n\n public execPath = __dirname;\n\n public abort(): void {\n this.emit('abort');\n }\n\n public env: {[name: string]: string} = {};\n public exitCode: number = 0;\n public exit(code: number): void {\n this.exitCode = code;\n this.emit('exit', [code]);\n }\n\n private _gid: number = 1;\n public getgid(): number {\n return this._gid;\n }\n public setgid(gid: number | string): void {\n if (typeof gid === 'number') {\n this._gid = gid;\n } else {\n this._gid = 1;\n }\n }\n\n private _uid: number = 1;\n public getuid(): number {\n return this._uid;\n }\n public setuid(uid: number | string): void {\n if (typeof uid === 'number') {\n this._uid = uid;\n } else {\n this._uid = 1;\n }\n }\n\n public version: string = 'v5.0';\n\n public versions = {\n http_parser: '0.0',\n node: '5.0',\n v8: '0.0',\n uv: '0.0',\n zlib: '0.0',\n ares: '0.0',\n icu: '0.0',\n modules: '0',\n openssl: '0.0'\n };\n\n public config = {\n target_defaults:\n { cflags: [],\n default_configuration: 'Release',\n defines: [],\n include_dirs: [],\n libraries: [] },\n variables:\n { clang: 0,\n host_arch: 'x32',\n node_install_npm: false,\n node_install_waf: false,\n node_prefix: '',\n node_shared_cares: false,\n node_shared_http_parser: false,\n node_shared_libuv: false,\n node_shared_zlib: false,\n node_shared_v8: false,\n node_use_dtrace: false,\n node_use_etw: false,\n node_use_openssl: false,\n node_shared_openssl: false,\n strict_aliasing: false,\n target_arch: 'x32',\n v8_use_snapshot: false,\n v8_no_strict_aliasing: 0,\n visibility: '' } };\n\n public kill(pid: number, signal?: string): void {\n this.emit('kill', [pid, signal]);\n }\n\n public pid = (Math.random()*1000)|0;\n\n public title = 'node';\n public arch = 'x32';\n public memoryUsage(): {rss: number; heapTotal: number; heapUsed: number;} {\n return { rss: 0, heapTotal: 0, heapUsed: 0 }\n }\n\n private _mask = 18;\n public umask(mask: number = this._mask): number {\n let oldMask = this._mask;\n this._mask = mask;\n this.emit('umask', [mask]);\n return oldMask;\n }\n\n public hrtime(): [number, number] {\n let timeinfo: number;\n if (typeof performance !== 'undefined') {\n timeinfo = performance.now();\n } else if (Date['now']) {\n timeinfo = Date.now();\n } else {\n timeinfo = (new Date()).getTime();\n }\n let secs = (timeinfo / 1000)|0;\n timeinfo -= secs * 1000;\n timeinfo = (timeinfo * 1000000)|0;\n return [secs, timeinfo];\n }\n\n /**\n * [BFS only] Initialize the TTY devices.\n */\n public initializeTTYs(): void {\n // Guard against multiple invocations.\n if (this.stdout === null) {\n let TTY: typeof _TTY = require('./tty');\n this.stdout = new TTY();\n this.stderr = new TTY();\n this.stdin = new TTY();\n }\n }\n\n /**\n * Worker-only function; irrelevant here.\n */\n public disconnect(): void {\n\n }\n // Undefined in main thread. Worker-only.\n public connected: boolean = undefined;\n}\n\nexport = Process;","import stream = require('stream');\n\nclass TTY extends stream.Duplex {\n public isRaw: boolean = false;\n public columns: number = 80;\n public rows: number = 120;\n public isTTY: boolean = true;\n private _bufferedWrites: Buffer[] = [];\n private _waitingForWrites: boolean = false;\n\n constructor() {\n super();\n }\n\n /**\n * Toggle raw mode.\n */\n public setRawMode(mode: boolean): void {\n if (this.isRaw !== mode) {\n this.isRaw = mode;\n // [BFS] TTY implementations can use this to change their event emitting\n // patterns.\n this.emit('modeChange');\n }\n }\n\n /**\n * [BFS] Update the number of columns available on the terminal.\n */\n public changeColumns(columns: number): void {\n if (columns !== this.columns) {\n this.columns = columns;\n // Resize event.\n this.emit('resize');\n }\n }\n\n /**\n * [BFS] Update the number of rows available on the terminal.\n */\n public changeRows(rows: number): void {\n if (rows !== this.rows) {\n this.rows = rows;\n // Resize event.\n this.emit('resize');\n }\n }\n\n /**\n * Returns 'true' if the given object is a TTY.\n */\n public static isatty(fd: any): fd is TTY {\n return fd && fd instanceof TTY;\n }\n\n public _write(chunk: any, encoding: string, cb: Function): void {\n var error: any;\n try {\n var data: Buffer;\n if (typeof(chunk) === 'string') {\n data = new Buffer(chunk, encoding);\n } else {\n data = chunk;\n }\n this._bufferedWrites.push(data);\n if (this._waitingForWrites) {\n this._read(1024);\n }\n } catch (e) {\n error = e;\n } finally {\n cb(error);\n }\n }\n\n public _read(size: number): void {\n // Size is advisory -- we can ignore it.\n if (this._bufferedWrites.length === 0) {\n this._waitingForWrites = true;\n } else {\n while (this._bufferedWrites.length > 0) {\n this._waitingForWrites = this.push(this._bufferedWrites.shift());\n if (!this._waitingForWrites) {\n break;\n }\n }\n }\n }\n}\n\nexport = TTY;\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nmodule.exports = Stream;\n\nvar EE = require('events').EventEmitter;\nvar inherits = require('inherits');\n\ninherits(Stream, EE);\nStream.Readable = require('readable-stream/readable.js');\nStream.Writable = require('readable-stream/writable.js');\nStream.Duplex = require('readable-stream/duplex.js');\nStream.Transform = require('readable-stream/transform.js');\nStream.PassThrough = require('readable-stream/passthrough.js');\n\n// Backwards-compat with node 0.4.x\nStream.Stream = Stream;\n\n\n\n// old-style streams. Note that the pipe method (the only relevant\n// part of this class) is overridden in the Readable class.\n\nfunction Stream() {\n EE.call(this);\n}\n\nStream.prototype.pipe = function(dest, options) {\n var source = this;\n\n function ondata(chunk) {\n if (dest.writable) {\n if (false === dest.write(chunk) && source.pause) {\n source.pause();\n }\n }\n }\n\n source.on('data', ondata);\n\n function ondrain() {\n if (source.readable && source.resume) {\n source.resume();\n }\n }\n\n dest.on('drain', ondrain);\n\n // If the 'end' option is not supplied, dest.end() will be called when\n // source gets the 'end' or 'close' events. Only dest.end() once.\n if (!dest._isStdio && (!options || options.end !== false)) {\n source.on('end', onend);\n source.on('close', onclose);\n }\n\n var didOnEnd = false;\n function onend() {\n if (didOnEnd) return;\n didOnEnd = true;\n\n dest.end();\n }\n\n\n function onclose() {\n if (didOnEnd) return;\n didOnEnd = true;\n\n if (typeof dest.destroy === 'function') dest.destroy();\n }\n\n // don't leave dangling pipes when there are errors.\n function onerror(er) {\n cleanup();\n if (EE.listenerCount(this, 'error') === 0) {\n throw er; // Unhandled stream error in pipe.\n }\n }\n\n source.on('error', onerror);\n dest.on('error', onerror);\n\n // remove all the event listeners that were added.\n function cleanup() {\n source.removeListener('data', ondata);\n dest.removeListener('drain', ondrain);\n\n source.removeListener('end', onend);\n source.removeListener('close', onclose);\n\n source.removeListener('error', onerror);\n dest.removeListener('error', onerror);\n\n source.removeListener('end', cleanup);\n source.removeListener('close', cleanup);\n\n dest.removeListener('close', cleanup);\n }\n\n source.on('end', cleanup);\n source.on('close', cleanup);\n\n dest.on('close', cleanup);\n\n dest.emit('pipe', source);\n\n // Allow for unix-like usage: A.pipe(B).pipe(C)\n return dest;\n};\n","var toString = {}.toString;\n\nmodule.exports = Array.isArray || function (arr) {\n return toString.call(arr) == '[object Array]';\n};\n","'use strict';\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nvar Buffer = require('safe-buffer').Buffer;\nvar util = require('util');\n\nfunction copyBuffer(src, target, offset) {\n src.copy(target, offset);\n}\n\nmodule.exports = function () {\n function BufferList() {\n _classCallCheck(this, BufferList);\n\n this.head = null;\n this.tail = null;\n this.length = 0;\n }\n\n BufferList.prototype.push = function push(v) {\n var entry = { data: v, next: null };\n if (this.length > 0) this.tail.next = entry;else this.head = entry;\n this.tail = entry;\n ++this.length;\n };\n\n BufferList.prototype.unshift = function unshift(v) {\n var entry = { data: v, next: this.head };\n if (this.length === 0) this.tail = entry;\n this.head = entry;\n ++this.length;\n };\n\n BufferList.prototype.shift = function shift() {\n if (this.length === 0) return;\n var ret = this.head.data;\n if (this.length === 1) this.head = this.tail = null;else this.head = this.head.next;\n --this.length;\n return ret;\n };\n\n BufferList.prototype.clear = function clear() {\n this.head = this.tail = null;\n this.length = 0;\n };\n\n BufferList.prototype.join = function join(s) {\n if (this.length === 0) return '';\n var p = this.head;\n var ret = '' + p.data;\n while (p = p.next) {\n ret += s + p.data;\n }return ret;\n };\n\n BufferList.prototype.concat = function concat(n) {\n if (this.length === 0) return Buffer.alloc(0);\n if (this.length === 1) return this.head.data;\n var ret = Buffer.allocUnsafe(n >>> 0);\n var p = this.head;\n var i = 0;\n while (p) {\n copyBuffer(p.data, ret, i);\n i += p.data.length;\n p = p.next;\n }\n return ret;\n };\n\n return BufferList;\n}();\n\nif (util && util.inspect && util.inspect.custom) {\n module.exports.prototype[util.inspect.custom] = function () {\n var obj = util.inspect({ length: this.length });\n return this.constructor.name + ' ' + obj;\n };\n}","\n/**\n * Module exports.\n */\n\nmodule.exports = deprecate;\n\n/**\n * Mark that a method should not be used.\n * Returns a modified function which warns once by default.\n *\n * If `localStorage.noDeprecation = true` is set, then it is a no-op.\n *\n * If `localStorage.throwDeprecation = true` is set, then deprecated functions\n * will throw an Error when invoked.\n *\n * If `localStorage.traceDeprecation = true` is set, then deprecated functions\n * will invoke `console.trace()` instead of `console.error()`.\n *\n * @param {Function} fn - the function to deprecate\n * @param {String} msg - the string to print to the console when `fn` is invoked\n * @returns {Function} a new \"deprecated\" version of `fn`\n * @api public\n */\n\nfunction deprecate (fn, msg) {\n if (config('noDeprecation')) {\n return fn;\n }\n\n var warned = false;\n function deprecated() {\n if (!warned) {\n if (config('throwDeprecation')) {\n throw new Error(msg);\n } else if (config('traceDeprecation')) {\n console.trace(msg);\n } else {\n console.warn(msg);\n }\n warned = true;\n }\n return fn.apply(this, arguments);\n }\n\n return deprecated;\n}\n\n/**\n * Checks `localStorage` for boolean values for the given `name`.\n *\n * @param {String} name\n * @returns {Boolean}\n * @api private\n */\n\nfunction config (name) {\n // accessing global.localStorage can trigger a DOMException in sandboxed iframes\n try {\n if (!global.localStorage) return false;\n } catch (_) {\n return false;\n }\n var val = global.localStorage[name];\n if (null == val) return false;\n return String(val).toLowerCase() === 'true';\n}\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// a passthrough stream.\n// basically just the most minimal sort of Transform stream.\n// Every written chunk gets output as-is.\n\n'use strict';\n\nmodule.exports = PassThrough;\n\nvar Transform = require('./_stream_transform');\n\n/**/\nvar util = Object.create(require('core-util-is'));\nutil.inherits = require('inherits');\n/**/\n\nutil.inherits(PassThrough, Transform);\n\nfunction PassThrough(options) {\n if (!(this instanceof PassThrough)) return new PassThrough(options);\n\n Transform.call(this, options);\n}\n\nPassThrough.prototype._transform = function (chunk, encoding, cb) {\n cb(null, chunk);\n};","module.exports = require('./lib/_stream_writable.js');\n","module.exports = require('./lib/_stream_duplex.js');\n","module.exports = require('./readable').Transform\n","module.exports = require('./readable').PassThrough\n","module.exports = function(module) {\n\tif (!module.webpackPolyfill) {\n\t\tmodule.deprecate = function() {};\n\t\tmodule.paths = [];\n\t\t// module.parent = undefined by default\n\t\tif (!module.children) module.children = [];\n\t\tObject.defineProperty(module, \"loaded\", {\n\t\t\tenumerable: true,\n\t\t\tget: function() {\n\t\t\t\treturn module.l;\n\t\t\t}\n\t\t});\n\t\tObject.defineProperty(module, \"id\", {\n\t\t\tenumerable: true,\n\t\t\tget: function() {\n\t\t\t\treturn module.i;\n\t\t\t}\n\t\t});\n\t\tmodule.webpackPolyfill = 1;\n\t}\n\treturn module;\n};\n","'use strict';\n\n\nvar zlib_inflate = require('./zlib/inflate');\nvar utils = require('./utils/common');\nvar strings = require('./utils/strings');\nvar c = require('./zlib/constants');\nvar msg = require('./zlib/messages');\nvar ZStream = require('./zlib/zstream');\nvar GZheader = require('./zlib/gzheader');\n\nvar toString = Object.prototype.toString;\n\n/**\n * class Inflate\n *\n * Generic JS-style wrapper for zlib calls. If you don't need\n * streaming behaviour - use more simple functions: [[inflate]]\n * and [[inflateRaw]].\n **/\n\n/* internal\n * inflate.chunks -> Array\n *\n * Chunks of output data, if [[Inflate#onData]] not overridden.\n **/\n\n/**\n * Inflate.result -> Uint8Array|Array|String\n *\n * Uncompressed result, generated by default [[Inflate#onData]]\n * and [[Inflate#onEnd]] handlers. Filled after you push last chunk\n * (call [[Inflate#push]] with `Z_FINISH` / `true` param) or if you\n * push a chunk with explicit flush (call [[Inflate#push]] with\n * `Z_SYNC_FLUSH` param).\n **/\n\n/**\n * Inflate.err -> Number\n *\n * Error code after inflate finished. 0 (Z_OK) on success.\n * Should be checked if broken data possible.\n **/\n\n/**\n * Inflate.msg -> String\n *\n * Error message, if [[Inflate.err]] != 0\n **/\n\n\n/**\n * new Inflate(options)\n * - options (Object): zlib inflate options.\n *\n * Creates new inflator instance with specified params. Throws exception\n * on bad params. Supported options:\n *\n * - `windowBits`\n * - `dictionary`\n *\n * [http://zlib.net/manual.html#Advanced](http://zlib.net/manual.html#Advanced)\n * for more information on these.\n *\n * Additional options, for internal needs:\n *\n * - `chunkSize` - size of generated data chunks (16K by default)\n * - `raw` (Boolean) - do raw inflate\n * - `to` (String) - if equal to 'string', then result will be converted\n * from utf8 to utf16 (javascript) string. When string output requested,\n * chunk length can differ from `chunkSize`, depending on content.\n *\n * By default, when no options set, autodetect deflate/gzip data format via\n * wrapper header.\n *\n * ##### Example:\n *\n * ```javascript\n * var pako = require('pako')\n * , chunk1 = Uint8Array([1,2,3,4,5,6,7,8,9])\n * , chunk2 = Uint8Array([10,11,12,13,14,15,16,17,18,19]);\n *\n * var inflate = new pako.Inflate({ level: 3});\n *\n * inflate.push(chunk1, false);\n * inflate.push(chunk2, true); // true -> last chunk\n *\n * if (inflate.err) { throw new Error(inflate.err); }\n *\n * console.log(inflate.result);\n * ```\n **/\nfunction Inflate(options) {\n if (!(this instanceof Inflate)) return new Inflate(options);\n\n this.options = utils.assign({\n chunkSize: 16384,\n windowBits: 0,\n to: ''\n }, options || {});\n\n var opt = this.options;\n\n // Force window size for `raw` data, if not set directly,\n // because we have no header for autodetect.\n if (opt.raw && (opt.windowBits >= 0) && (opt.windowBits < 16)) {\n opt.windowBits = -opt.windowBits;\n if (opt.windowBits === 0) { opt.windowBits = -15; }\n }\n\n // If `windowBits` not defined (and mode not raw) - set autodetect flag for gzip/deflate\n if ((opt.windowBits >= 0) && (opt.windowBits < 16) &&\n !(options && options.windowBits)) {\n opt.windowBits += 32;\n }\n\n // Gzip header has no info about windows size, we can do autodetect only\n // for deflate. So, if window size not set, force it to max when gzip possible\n if ((opt.windowBits > 15) && (opt.windowBits < 48)) {\n // bit 3 (16) -> gzipped data\n // bit 4 (32) -> autodetect gzip/deflate\n if ((opt.windowBits & 15) === 0) {\n opt.windowBits |= 15;\n }\n }\n\n this.err = 0; // error code, if happens (0 = Z_OK)\n this.msg = ''; // error message\n this.ended = false; // used to avoid multiple onEnd() calls\n this.chunks = []; // chunks of compressed data\n\n this.strm = new ZStream();\n this.strm.avail_out = 0;\n\n var status = zlib_inflate.inflateInit2(\n this.strm,\n opt.windowBits\n );\n\n if (status !== c.Z_OK) {\n throw new Error(msg[status]);\n }\n\n this.header = new GZheader();\n\n zlib_inflate.inflateGetHeader(this.strm, this.header);\n\n // Setup dictionary\n if (opt.dictionary) {\n // Convert data if needed\n if (typeof opt.dictionary === 'string') {\n opt.dictionary = strings.string2buf(opt.dictionary);\n } else if (toString.call(opt.dictionary) === '[object ArrayBuffer]') {\n opt.dictionary = new Uint8Array(opt.dictionary);\n }\n if (opt.raw) { //In raw mode we need to set the dictionary early\n status = zlib_inflate.inflateSetDictionary(this.strm, opt.dictionary);\n if (status !== c.Z_OK) {\n throw new Error(msg[status]);\n }\n }\n }\n}\n\n/**\n * Inflate#push(data[, mode]) -> Boolean\n * - data (Uint8Array|Array|ArrayBuffer|String): input data\n * - mode (Number|Boolean): 0..6 for corresponding Z_NO_FLUSH..Z_TREE modes.\n * See constants. Skipped or `false` means Z_NO_FLUSH, `true` means Z_FINISH.\n *\n * Sends input data to inflate pipe, generating [[Inflate#onData]] calls with\n * new output chunks. Returns `true` on success. The last data block must have\n * mode Z_FINISH (or `true`). That will flush internal pending buffers and call\n * [[Inflate#onEnd]]. For interim explicit flushes (without ending the stream) you\n * can use mode Z_SYNC_FLUSH, keeping the decompression context.\n *\n * On fail call [[Inflate#onEnd]] with error code and return false.\n *\n * We strongly recommend to use `Uint8Array` on input for best speed (output\n * format is detected automatically). Also, don't skip last param and always\n * use the same type in your code (boolean or number). That will improve JS speed.\n *\n * For regular `Array`-s make sure all elements are [0..255].\n *\n * ##### Example\n *\n * ```javascript\n * push(chunk, false); // push one of data chunks\n * ...\n * push(chunk, true); // push last chunk\n * ```\n **/\nInflate.prototype.push = function (data, mode) {\n var strm = this.strm;\n var chunkSize = this.options.chunkSize;\n var dictionary = this.options.dictionary;\n var status, _mode;\n var next_out_utf8, tail, utf8str;\n\n // Flag to properly process Z_BUF_ERROR on testing inflate call\n // when we check that all output data was flushed.\n var allowBufError = false;\n\n if (this.ended) { return false; }\n _mode = (mode === ~~mode) ? mode : ((mode === true) ? c.Z_FINISH : c.Z_NO_FLUSH);\n\n // Convert data if needed\n if (typeof data === 'string') {\n // Only binary strings can be decompressed on practice\n strm.input = strings.binstring2buf(data);\n } else if (toString.call(data) === '[object ArrayBuffer]') {\n strm.input = new Uint8Array(data);\n } else {\n strm.input = data;\n }\n\n strm.next_in = 0;\n strm.avail_in = strm.input.length;\n\n do {\n if (strm.avail_out === 0) {\n strm.output = new utils.Buf8(chunkSize);\n strm.next_out = 0;\n strm.avail_out = chunkSize;\n }\n\n status = zlib_inflate.inflate(strm, c.Z_NO_FLUSH); /* no bad return value */\n\n if (status === c.Z_NEED_DICT && dictionary) {\n status = zlib_inflate.inflateSetDictionary(this.strm, dictionary);\n }\n\n if (status === c.Z_BUF_ERROR && allowBufError === true) {\n status = c.Z_OK;\n allowBufError = false;\n }\n\n if (status !== c.Z_STREAM_END && status !== c.Z_OK) {\n this.onEnd(status);\n this.ended = true;\n return false;\n }\n\n if (strm.next_out) {\n if (strm.avail_out === 0 || status === c.Z_STREAM_END || (strm.avail_in === 0 && (_mode === c.Z_FINISH || _mode === c.Z_SYNC_FLUSH))) {\n\n if (this.options.to === 'string') {\n\n next_out_utf8 = strings.utf8border(strm.output, strm.next_out);\n\n tail = strm.next_out - next_out_utf8;\n utf8str = strings.buf2string(strm.output, next_out_utf8);\n\n // move tail\n strm.next_out = tail;\n strm.avail_out = chunkSize - tail;\n if (tail) { utils.arraySet(strm.output, strm.output, next_out_utf8, tail, 0); }\n\n this.onData(utf8str);\n\n } else {\n this.onData(utils.shrinkBuf(strm.output, strm.next_out));\n }\n }\n }\n\n // When no more input data, we should check that internal inflate buffers\n // are flushed. The only way to do it when avail_out = 0 - run one more\n // inflate pass. But if output data not exists, inflate return Z_BUF_ERROR.\n // Here we set flag to process this error properly.\n //\n // NOTE. Deflate does not return error in this case and does not needs such\n // logic.\n if (strm.avail_in === 0 && strm.avail_out === 0) {\n allowBufError = true;\n }\n\n } while ((strm.avail_in > 0 || strm.avail_out === 0) && status !== c.Z_STREAM_END);\n\n if (status === c.Z_STREAM_END) {\n _mode = c.Z_FINISH;\n }\n\n // Finalize on the last chunk.\n if (_mode === c.Z_FINISH) {\n status = zlib_inflate.inflateEnd(this.strm);\n this.onEnd(status);\n this.ended = true;\n return status === c.Z_OK;\n }\n\n // callback interim results if Z_SYNC_FLUSH.\n if (_mode === c.Z_SYNC_FLUSH) {\n this.onEnd(c.Z_OK);\n strm.avail_out = 0;\n return true;\n }\n\n return true;\n};\n\n\n/**\n * Inflate#onData(chunk) -> Void\n * - chunk (Uint8Array|Array|String): output data. Type of array depends\n * on js engine support. When string output requested, each chunk\n * will be string.\n *\n * By default, stores data blocks in `chunks[]` property and glue\n * those in `onEnd`. Override this handler, if you need another behaviour.\n **/\nInflate.prototype.onData = function (chunk) {\n this.chunks.push(chunk);\n};\n\n\n/**\n * Inflate#onEnd(status) -> Void\n * - status (Number): inflate status. 0 (Z_OK) on success,\n * other if not.\n *\n * Called either after you tell inflate that the input stream is\n * complete (Z_FINISH) or should be flushed (Z_SYNC_FLUSH)\n * or if an error happened. By default - join collected chunks,\n * free memory and fill `results` / `err` properties.\n **/\nInflate.prototype.onEnd = function (status) {\n // On success - join\n if (status === c.Z_OK) {\n if (this.options.to === 'string') {\n // Glue & convert here, until we teach pako to send\n // utf8 aligned strings to onData\n this.result = this.chunks.join('');\n } else {\n this.result = utils.flattenChunks(this.chunks);\n }\n }\n this.chunks = [];\n this.err = status;\n this.msg = this.strm.msg;\n};\n\n\n/**\n * inflate(data[, options]) -> Uint8Array|Array|String\n * - data (Uint8Array|Array|String): input data to decompress.\n * - options (Object): zlib inflate options.\n *\n * Decompress `data` with inflate/ungzip and `options`. Autodetect\n * format via wrapper header by default. That's why we don't provide\n * separate `ungzip` method.\n *\n * Supported options are:\n *\n * - windowBits\n *\n * [http://zlib.net/manual.html#Advanced](http://zlib.net/manual.html#Advanced)\n * for more information.\n *\n * Sugar (options):\n *\n * - `raw` (Boolean) - say that we work with raw stream, if you don't wish to specify\n * negative windowBits implicitly.\n * - `to` (String) - if equal to 'string', then result will be converted\n * from utf8 to utf16 (javascript) string. When string output requested,\n * chunk length can differ from `chunkSize`, depending on content.\n *\n *\n * ##### Example:\n *\n * ```javascript\n * var pako = require('pako')\n * , input = pako.deflate([1,2,3,4,5,6,7,8,9])\n * , output;\n *\n * try {\n * output = pako.inflate(input);\n * } catch (err)\n * console.log(err);\n * }\n * ```\n **/\nfunction inflate(input, options) {\n var inflator = new Inflate(options);\n\n inflator.push(input, true);\n\n // That will never happens, if you don't cheat with options :)\n if (inflator.err) { throw inflator.msg || msg[inflator.err]; }\n\n return inflator.result;\n}\n\n\n/**\n * inflateRaw(data[, options]) -> Uint8Array|Array|String\n * - data (Uint8Array|Array|String): input data to decompress.\n * - options (Object): zlib inflate options.\n *\n * The same as [[inflate]], but creates raw data, without wrapper\n * (header and adler32 crc).\n **/\nfunction inflateRaw(input, options) {\n options = options || {};\n options.raw = true;\n return inflate(input, options);\n}\n\n\n/**\n * ungzip(data[, options]) -> Uint8Array|Array|String\n * - data (Uint8Array|Array|String): input data to decompress.\n * - options (Object): zlib inflate options.\n *\n * Just shortcut to [[inflate]], because it autodetects format\n * by header.content. Done for convenience.\n **/\n\n\nexports.Inflate = Inflate;\nexports.inflate = inflate;\nexports.inflateRaw = inflateRaw;\nexports.ungzip = inflate;\n","'use strict';\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nvar utils = require('../utils/common');\nvar adler32 = require('./adler32');\nvar crc32 = require('./crc32');\nvar inflate_fast = require('./inffast');\nvar inflate_table = require('./inftrees');\n\nvar CODES = 0;\nvar LENS = 1;\nvar DISTS = 2;\n\n/* Public constants ==========================================================*/\n/* ===========================================================================*/\n\n\n/* Allowed flush values; see deflate() and inflate() below for details */\n//var Z_NO_FLUSH = 0;\n//var Z_PARTIAL_FLUSH = 1;\n//var Z_SYNC_FLUSH = 2;\n//var Z_FULL_FLUSH = 3;\nvar Z_FINISH = 4;\nvar Z_BLOCK = 5;\nvar Z_TREES = 6;\n\n\n/* Return codes for the compression/decompression functions. Negative values\n * are errors, positive values are used for special but normal events.\n */\nvar Z_OK = 0;\nvar Z_STREAM_END = 1;\nvar Z_NEED_DICT = 2;\n//var Z_ERRNO = -1;\nvar Z_STREAM_ERROR = -2;\nvar Z_DATA_ERROR = -3;\nvar Z_MEM_ERROR = -4;\nvar Z_BUF_ERROR = -5;\n//var Z_VERSION_ERROR = -6;\n\n/* The deflate compression method */\nvar Z_DEFLATED = 8;\n\n\n/* STATES ====================================================================*/\n/* ===========================================================================*/\n\n\nvar HEAD = 1; /* i: waiting for magic header */\nvar FLAGS = 2; /* i: waiting for method and flags (gzip) */\nvar TIME = 3; /* i: waiting for modification time (gzip) */\nvar OS = 4; /* i: waiting for extra flags and operating system (gzip) */\nvar EXLEN = 5; /* i: waiting for extra length (gzip) */\nvar EXTRA = 6; /* i: waiting for extra bytes (gzip) */\nvar NAME = 7; /* i: waiting for end of file name (gzip) */\nvar COMMENT = 8; /* i: waiting for end of comment (gzip) */\nvar HCRC = 9; /* i: waiting for header crc (gzip) */\nvar DICTID = 10; /* i: waiting for dictionary check value */\nvar DICT = 11; /* waiting for inflateSetDictionary() call */\nvar TYPE = 12; /* i: waiting for type bits, including last-flag bit */\nvar TYPEDO = 13; /* i: same, but skip check to exit inflate on new block */\nvar STORED = 14; /* i: waiting for stored size (length and complement) */\nvar COPY_ = 15; /* i/o: same as COPY below, but only first time in */\nvar COPY = 16; /* i/o: waiting for input or output to copy stored block */\nvar TABLE = 17; /* i: waiting for dynamic block table lengths */\nvar LENLENS = 18; /* i: waiting for code length code lengths */\nvar CODELENS = 19; /* i: waiting for length/lit and distance code lengths */\nvar LEN_ = 20; /* i: same as LEN below, but only first time in */\nvar LEN = 21; /* i: waiting for length/lit/eob code */\nvar LENEXT = 22; /* i: waiting for length extra bits */\nvar DIST = 23; /* i: waiting for distance code */\nvar DISTEXT = 24; /* i: waiting for distance extra bits */\nvar MATCH = 25; /* o: waiting for output space to copy string */\nvar LIT = 26; /* o: waiting for output space to write literal */\nvar CHECK = 27; /* i: waiting for 32-bit check value */\nvar LENGTH = 28; /* i: waiting for 32-bit length (gzip) */\nvar DONE = 29; /* finished check, done -- remain here until reset */\nvar BAD = 30; /* got a data error -- remain here until reset */\nvar MEM = 31; /* got an inflate() memory error -- remain here until reset */\nvar SYNC = 32; /* looking for synchronization bytes to restart inflate() */\n\n/* ===========================================================================*/\n\n\n\nvar ENOUGH_LENS = 852;\nvar ENOUGH_DISTS = 592;\n//var ENOUGH = (ENOUGH_LENS+ENOUGH_DISTS);\n\nvar MAX_WBITS = 15;\n/* 32K LZ77 window */\nvar DEF_WBITS = MAX_WBITS;\n\n\nfunction zswap32(q) {\n return (((q >>> 24) & 0xff) +\n ((q >>> 8) & 0xff00) +\n ((q & 0xff00) << 8) +\n ((q & 0xff) << 24));\n}\n\n\nfunction InflateState() {\n this.mode = 0; /* current inflate mode */\n this.last = false; /* true if processing last block */\n this.wrap = 0; /* bit 0 true for zlib, bit 1 true for gzip */\n this.havedict = false; /* true if dictionary provided */\n this.flags = 0; /* gzip header method and flags (0 if zlib) */\n this.dmax = 0; /* zlib header max distance (INFLATE_STRICT) */\n this.check = 0; /* protected copy of check value */\n this.total = 0; /* protected copy of output count */\n // TODO: may be {}\n this.head = null; /* where to save gzip header information */\n\n /* sliding window */\n this.wbits = 0; /* log base 2 of requested window size */\n this.wsize = 0; /* window size or zero if not using window */\n this.whave = 0; /* valid bytes in the window */\n this.wnext = 0; /* window write index */\n this.window = null; /* allocated sliding window, if needed */\n\n /* bit accumulator */\n this.hold = 0; /* input bit accumulator */\n this.bits = 0; /* number of bits in \"in\" */\n\n /* for string and stored block copying */\n this.length = 0; /* literal or length of data to copy */\n this.offset = 0; /* distance back to copy string from */\n\n /* for table and code decoding */\n this.extra = 0; /* extra bits needed */\n\n /* fixed and dynamic code tables */\n this.lencode = null; /* starting table for length/literal codes */\n this.distcode = null; /* starting table for distance codes */\n this.lenbits = 0; /* index bits for lencode */\n this.distbits = 0; /* index bits for distcode */\n\n /* dynamic table building */\n this.ncode = 0; /* number of code length code lengths */\n this.nlen = 0; /* number of length code lengths */\n this.ndist = 0; /* number of distance code lengths */\n this.have = 0; /* number of code lengths in lens[] */\n this.next = null; /* next available space in codes[] */\n\n this.lens = new utils.Buf16(320); /* temporary storage for code lengths */\n this.work = new utils.Buf16(288); /* work area for code table building */\n\n /*\n because we don't have pointers in js, we use lencode and distcode directly\n as buffers so we don't need codes\n */\n //this.codes = new utils.Buf32(ENOUGH); /* space for code tables */\n this.lendyn = null; /* dynamic table for length/literal codes (JS specific) */\n this.distdyn = null; /* dynamic table for distance codes (JS specific) */\n this.sane = 0; /* if false, allow invalid distance too far */\n this.back = 0; /* bits back of last unprocessed length/lit */\n this.was = 0; /* initial length of match */\n}\n\nfunction inflateResetKeep(strm) {\n var state;\n\n if (!strm || !strm.state) { return Z_STREAM_ERROR; }\n state = strm.state;\n strm.total_in = strm.total_out = state.total = 0;\n strm.msg = ''; /*Z_NULL*/\n if (state.wrap) { /* to support ill-conceived Java test suite */\n strm.adler = state.wrap & 1;\n }\n state.mode = HEAD;\n state.last = 0;\n state.havedict = 0;\n state.dmax = 32768;\n state.head = null/*Z_NULL*/;\n state.hold = 0;\n state.bits = 0;\n //state.lencode = state.distcode = state.next = state.codes;\n state.lencode = state.lendyn = new utils.Buf32(ENOUGH_LENS);\n state.distcode = state.distdyn = new utils.Buf32(ENOUGH_DISTS);\n\n state.sane = 1;\n state.back = -1;\n //Tracev((stderr, \"inflate: reset\\n\"));\n return Z_OK;\n}\n\nfunction inflateReset(strm) {\n var state;\n\n if (!strm || !strm.state) { return Z_STREAM_ERROR; }\n state = strm.state;\n state.wsize = 0;\n state.whave = 0;\n state.wnext = 0;\n return inflateResetKeep(strm);\n\n}\n\nfunction inflateReset2(strm, windowBits) {\n var wrap;\n var state;\n\n /* get the state */\n if (!strm || !strm.state) { return Z_STREAM_ERROR; }\n state = strm.state;\n\n /* extract wrap request from windowBits parameter */\n if (windowBits < 0) {\n wrap = 0;\n windowBits = -windowBits;\n }\n else {\n wrap = (windowBits >> 4) + 1;\n if (windowBits < 48) {\n windowBits &= 15;\n }\n }\n\n /* set number of window bits, free window if different */\n if (windowBits && (windowBits < 8 || windowBits > 15)) {\n return Z_STREAM_ERROR;\n }\n if (state.window !== null && state.wbits !== windowBits) {\n state.window = null;\n }\n\n /* update state and reset the rest of it */\n state.wrap = wrap;\n state.wbits = windowBits;\n return inflateReset(strm);\n}\n\nfunction inflateInit2(strm, windowBits) {\n var ret;\n var state;\n\n if (!strm) { return Z_STREAM_ERROR; }\n //strm.msg = Z_NULL; /* in case we return an error */\n\n state = new InflateState();\n\n //if (state === Z_NULL) return Z_MEM_ERROR;\n //Tracev((stderr, \"inflate: allocated\\n\"));\n strm.state = state;\n state.window = null/*Z_NULL*/;\n ret = inflateReset2(strm, windowBits);\n if (ret !== Z_OK) {\n strm.state = null/*Z_NULL*/;\n }\n return ret;\n}\n\nfunction inflateInit(strm) {\n return inflateInit2(strm, DEF_WBITS);\n}\n\n\n/*\n Return state with length and distance decoding tables and index sizes set to\n fixed code decoding. Normally this returns fixed tables from inffixed.h.\n If BUILDFIXED is defined, then instead this routine builds the tables the\n first time it's called, and returns those tables the first time and\n thereafter. This reduces the size of the code by about 2K bytes, in\n exchange for a little execution time. However, BUILDFIXED should not be\n used for threaded applications, since the rewriting of the tables and virgin\n may not be thread-safe.\n */\nvar virgin = true;\n\nvar lenfix, distfix; // We have no pointers in JS, so keep tables separate\n\nfunction fixedtables(state) {\n /* build fixed huffman tables if first call (may not be thread safe) */\n if (virgin) {\n var sym;\n\n lenfix = new utils.Buf32(512);\n distfix = new utils.Buf32(32);\n\n /* literal/length table */\n sym = 0;\n while (sym < 144) { state.lens[sym++] = 8; }\n while (sym < 256) { state.lens[sym++] = 9; }\n while (sym < 280) { state.lens[sym++] = 7; }\n while (sym < 288) { state.lens[sym++] = 8; }\n\n inflate_table(LENS, state.lens, 0, 288, lenfix, 0, state.work, { bits: 9 });\n\n /* distance table */\n sym = 0;\n while (sym < 32) { state.lens[sym++] = 5; }\n\n inflate_table(DISTS, state.lens, 0, 32, distfix, 0, state.work, { bits: 5 });\n\n /* do this just once */\n virgin = false;\n }\n\n state.lencode = lenfix;\n state.lenbits = 9;\n state.distcode = distfix;\n state.distbits = 5;\n}\n\n\n/*\n Update the window with the last wsize (normally 32K) bytes written before\n returning. If window does not exist yet, create it. This is only called\n when a window is already in use, or when output has been written during this\n inflate call, but the end of the deflate stream has not been reached yet.\n It is also called to create a window for dictionary data when a dictionary\n is loaded.\n\n Providing output buffers larger than 32K to inflate() should provide a speed\n advantage, since only the last 32K of output is copied to the sliding window\n upon return from inflate(), and since all distances after the first 32K of\n output will fall in the output data, making match copies simpler and faster.\n The advantage may be dependent on the size of the processor's data caches.\n */\nfunction updatewindow(strm, src, end, copy) {\n var dist;\n var state = strm.state;\n\n /* if it hasn't been done already, allocate space for the window */\n if (state.window === null) {\n state.wsize = 1 << state.wbits;\n state.wnext = 0;\n state.whave = 0;\n\n state.window = new utils.Buf8(state.wsize);\n }\n\n /* copy state->wsize or less output bytes into the circular window */\n if (copy >= state.wsize) {\n utils.arraySet(state.window, src, end - state.wsize, state.wsize, 0);\n state.wnext = 0;\n state.whave = state.wsize;\n }\n else {\n dist = state.wsize - state.wnext;\n if (dist > copy) {\n dist = copy;\n }\n //zmemcpy(state->window + state->wnext, end - copy, dist);\n utils.arraySet(state.window, src, end - copy, dist, state.wnext);\n copy -= dist;\n if (copy) {\n //zmemcpy(state->window, end - copy, copy);\n utils.arraySet(state.window, src, end - copy, copy, 0);\n state.wnext = copy;\n state.whave = state.wsize;\n }\n else {\n state.wnext += dist;\n if (state.wnext === state.wsize) { state.wnext = 0; }\n if (state.whave < state.wsize) { state.whave += dist; }\n }\n }\n return 0;\n}\n\nfunction inflate(strm, flush) {\n var state;\n var input, output; // input/output buffers\n var next; /* next input INDEX */\n var put; /* next output INDEX */\n var have, left; /* available input and output */\n var hold; /* bit buffer */\n var bits; /* bits in bit buffer */\n var _in, _out; /* save starting available input and output */\n var copy; /* number of stored or match bytes to copy */\n var from; /* where to copy match bytes from */\n var from_source;\n var here = 0; /* current decoding table entry */\n var here_bits, here_op, here_val; // paked \"here\" denormalized (JS specific)\n //var last; /* parent table entry */\n var last_bits, last_op, last_val; // paked \"last\" denormalized (JS specific)\n var len; /* length to copy for repeats, bits to drop */\n var ret; /* return code */\n var hbuf = new utils.Buf8(4); /* buffer for gzip header crc calculation */\n var opts;\n\n var n; // temporary var for NEED_BITS\n\n var order = /* permutation of code lengths */\n [ 16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15 ];\n\n\n if (!strm || !strm.state || !strm.output ||\n (!strm.input && strm.avail_in !== 0)) {\n return Z_STREAM_ERROR;\n }\n\n state = strm.state;\n if (state.mode === TYPE) { state.mode = TYPEDO; } /* skip check */\n\n\n //--- LOAD() ---\n put = strm.next_out;\n output = strm.output;\n left = strm.avail_out;\n next = strm.next_in;\n input = strm.input;\n have = strm.avail_in;\n hold = state.hold;\n bits = state.bits;\n //---\n\n _in = have;\n _out = left;\n ret = Z_OK;\n\n inf_leave: // goto emulation\n for (;;) {\n switch (state.mode) {\n case HEAD:\n if (state.wrap === 0) {\n state.mode = TYPEDO;\n break;\n }\n //=== NEEDBITS(16);\n while (bits < 16) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if ((state.wrap & 2) && hold === 0x8b1f) { /* gzip header */\n state.check = 0/*crc32(0L, Z_NULL, 0)*/;\n //=== CRC2(state.check, hold);\n hbuf[0] = hold & 0xff;\n hbuf[1] = (hold >>> 8) & 0xff;\n state.check = crc32(state.check, hbuf, 2, 0);\n //===//\n\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = FLAGS;\n break;\n }\n state.flags = 0; /* expect zlib header */\n if (state.head) {\n state.head.done = false;\n }\n if (!(state.wrap & 1) || /* check if zlib header allowed */\n (((hold & 0xff)/*BITS(8)*/ << 8) + (hold >> 8)) % 31) {\n strm.msg = 'incorrect header check';\n state.mode = BAD;\n break;\n }\n if ((hold & 0x0f)/*BITS(4)*/ !== Z_DEFLATED) {\n strm.msg = 'unknown compression method';\n state.mode = BAD;\n break;\n }\n //--- DROPBITS(4) ---//\n hold >>>= 4;\n bits -= 4;\n //---//\n len = (hold & 0x0f)/*BITS(4)*/ + 8;\n if (state.wbits === 0) {\n state.wbits = len;\n }\n else if (len > state.wbits) {\n strm.msg = 'invalid window size';\n state.mode = BAD;\n break;\n }\n state.dmax = 1 << len;\n //Tracev((stderr, \"inflate: zlib header ok\\n\"));\n strm.adler = state.check = 1/*adler32(0L, Z_NULL, 0)*/;\n state.mode = hold & 0x200 ? DICTID : TYPE;\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n break;\n case FLAGS:\n //=== NEEDBITS(16); */\n while (bits < 16) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.flags = hold;\n if ((state.flags & 0xff) !== Z_DEFLATED) {\n strm.msg = 'unknown compression method';\n state.mode = BAD;\n break;\n }\n if (state.flags & 0xe000) {\n strm.msg = 'unknown header flags set';\n state.mode = BAD;\n break;\n }\n if (state.head) {\n state.head.text = ((hold >> 8) & 1);\n }\n if (state.flags & 0x0200) {\n //=== CRC2(state.check, hold);\n hbuf[0] = hold & 0xff;\n hbuf[1] = (hold >>> 8) & 0xff;\n state.check = crc32(state.check, hbuf, 2, 0);\n //===//\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = TIME;\n /* falls through */\n case TIME:\n //=== NEEDBITS(32); */\n while (bits < 32) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if (state.head) {\n state.head.time = hold;\n }\n if (state.flags & 0x0200) {\n //=== CRC4(state.check, hold)\n hbuf[0] = hold & 0xff;\n hbuf[1] = (hold >>> 8) & 0xff;\n hbuf[2] = (hold >>> 16) & 0xff;\n hbuf[3] = (hold >>> 24) & 0xff;\n state.check = crc32(state.check, hbuf, 4, 0);\n //===\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = OS;\n /* falls through */\n case OS:\n //=== NEEDBITS(16); */\n while (bits < 16) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if (state.head) {\n state.head.xflags = (hold & 0xff);\n state.head.os = (hold >> 8);\n }\n if (state.flags & 0x0200) {\n //=== CRC2(state.check, hold);\n hbuf[0] = hold & 0xff;\n hbuf[1] = (hold >>> 8) & 0xff;\n state.check = crc32(state.check, hbuf, 2, 0);\n //===//\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = EXLEN;\n /* falls through */\n case EXLEN:\n if (state.flags & 0x0400) {\n //=== NEEDBITS(16); */\n while (bits < 16) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.length = hold;\n if (state.head) {\n state.head.extra_len = hold;\n }\n if (state.flags & 0x0200) {\n //=== CRC2(state.check, hold);\n hbuf[0] = hold & 0xff;\n hbuf[1] = (hold >>> 8) & 0xff;\n state.check = crc32(state.check, hbuf, 2, 0);\n //===//\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n }\n else if (state.head) {\n state.head.extra = null/*Z_NULL*/;\n }\n state.mode = EXTRA;\n /* falls through */\n case EXTRA:\n if (state.flags & 0x0400) {\n copy = state.length;\n if (copy > have) { copy = have; }\n if (copy) {\n if (state.head) {\n len = state.head.extra_len - state.length;\n if (!state.head.extra) {\n // Use untyped array for more convenient processing later\n state.head.extra = new Array(state.head.extra_len);\n }\n utils.arraySet(\n state.head.extra,\n input,\n next,\n // extra field is limited to 65536 bytes\n // - no need for additional size check\n copy,\n /*len + copy > state.head.extra_max - len ? state.head.extra_max : copy,*/\n len\n );\n //zmemcpy(state.head.extra + len, next,\n // len + copy > state.head.extra_max ?\n // state.head.extra_max - len : copy);\n }\n if (state.flags & 0x0200) {\n state.check = crc32(state.check, input, copy, next);\n }\n have -= copy;\n next += copy;\n state.length -= copy;\n }\n if (state.length) { break inf_leave; }\n }\n state.length = 0;\n state.mode = NAME;\n /* falls through */\n case NAME:\n if (state.flags & 0x0800) {\n if (have === 0) { break inf_leave; }\n copy = 0;\n do {\n // TODO: 2 or 1 bytes?\n len = input[next + copy++];\n /* use constant limit because in js we should not preallocate memory */\n if (state.head && len &&\n (state.length < 65536 /*state.head.name_max*/)) {\n state.head.name += String.fromCharCode(len);\n }\n } while (len && copy < have);\n\n if (state.flags & 0x0200) {\n state.check = crc32(state.check, input, copy, next);\n }\n have -= copy;\n next += copy;\n if (len) { break inf_leave; }\n }\n else if (state.head) {\n state.head.name = null;\n }\n state.length = 0;\n state.mode = COMMENT;\n /* falls through */\n case COMMENT:\n if (state.flags & 0x1000) {\n if (have === 0) { break inf_leave; }\n copy = 0;\n do {\n len = input[next + copy++];\n /* use constant limit because in js we should not preallocate memory */\n if (state.head && len &&\n (state.length < 65536 /*state.head.comm_max*/)) {\n state.head.comment += String.fromCharCode(len);\n }\n } while (len && copy < have);\n if (state.flags & 0x0200) {\n state.check = crc32(state.check, input, copy, next);\n }\n have -= copy;\n next += copy;\n if (len) { break inf_leave; }\n }\n else if (state.head) {\n state.head.comment = null;\n }\n state.mode = HCRC;\n /* falls through */\n case HCRC:\n if (state.flags & 0x0200) {\n //=== NEEDBITS(16); */\n while (bits < 16) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if (hold !== (state.check & 0xffff)) {\n strm.msg = 'header crc mismatch';\n state.mode = BAD;\n break;\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n }\n if (state.head) {\n state.head.hcrc = ((state.flags >> 9) & 1);\n state.head.done = true;\n }\n strm.adler = state.check = 0;\n state.mode = TYPE;\n break;\n case DICTID:\n //=== NEEDBITS(32); */\n while (bits < 32) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n strm.adler = state.check = zswap32(hold);\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = DICT;\n /* falls through */\n case DICT:\n if (state.havedict === 0) {\n //--- RESTORE() ---\n strm.next_out = put;\n strm.avail_out = left;\n strm.next_in = next;\n strm.avail_in = have;\n state.hold = hold;\n state.bits = bits;\n //---\n return Z_NEED_DICT;\n }\n strm.adler = state.check = 1/*adler32(0L, Z_NULL, 0)*/;\n state.mode = TYPE;\n /* falls through */\n case TYPE:\n if (flush === Z_BLOCK || flush === Z_TREES) { break inf_leave; }\n /* falls through */\n case TYPEDO:\n if (state.last) {\n //--- BYTEBITS() ---//\n hold >>>= bits & 7;\n bits -= bits & 7;\n //---//\n state.mode = CHECK;\n break;\n }\n //=== NEEDBITS(3); */\n while (bits < 3) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.last = (hold & 0x01)/*BITS(1)*/;\n //--- DROPBITS(1) ---//\n hold >>>= 1;\n bits -= 1;\n //---//\n\n switch ((hold & 0x03)/*BITS(2)*/) {\n case 0: /* stored block */\n //Tracev((stderr, \"inflate: stored block%s\\n\",\n // state.last ? \" (last)\" : \"\"));\n state.mode = STORED;\n break;\n case 1: /* fixed block */\n fixedtables(state);\n //Tracev((stderr, \"inflate: fixed codes block%s\\n\",\n // state.last ? \" (last)\" : \"\"));\n state.mode = LEN_; /* decode codes */\n if (flush === Z_TREES) {\n //--- DROPBITS(2) ---//\n hold >>>= 2;\n bits -= 2;\n //---//\n break inf_leave;\n }\n break;\n case 2: /* dynamic block */\n //Tracev((stderr, \"inflate: dynamic codes block%s\\n\",\n // state.last ? \" (last)\" : \"\"));\n state.mode = TABLE;\n break;\n case 3:\n strm.msg = 'invalid block type';\n state.mode = BAD;\n }\n //--- DROPBITS(2) ---//\n hold >>>= 2;\n bits -= 2;\n //---//\n break;\n case STORED:\n //--- BYTEBITS() ---// /* go to byte boundary */\n hold >>>= bits & 7;\n bits -= bits & 7;\n //---//\n //=== NEEDBITS(32); */\n while (bits < 32) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if ((hold & 0xffff) !== ((hold >>> 16) ^ 0xffff)) {\n strm.msg = 'invalid stored block lengths';\n state.mode = BAD;\n break;\n }\n state.length = hold & 0xffff;\n //Tracev((stderr, \"inflate: stored length %u\\n\",\n // state.length));\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = COPY_;\n if (flush === Z_TREES) { break inf_leave; }\n /* falls through */\n case COPY_:\n state.mode = COPY;\n /* falls through */\n case COPY:\n copy = state.length;\n if (copy) {\n if (copy > have) { copy = have; }\n if (copy > left) { copy = left; }\n if (copy === 0) { break inf_leave; }\n //--- zmemcpy(put, next, copy); ---\n utils.arraySet(output, input, next, copy, put);\n //---//\n have -= copy;\n next += copy;\n left -= copy;\n put += copy;\n state.length -= copy;\n break;\n }\n //Tracev((stderr, \"inflate: stored end\\n\"));\n state.mode = TYPE;\n break;\n case TABLE:\n //=== NEEDBITS(14); */\n while (bits < 14) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.nlen = (hold & 0x1f)/*BITS(5)*/ + 257;\n //--- DROPBITS(5) ---//\n hold >>>= 5;\n bits -= 5;\n //---//\n state.ndist = (hold & 0x1f)/*BITS(5)*/ + 1;\n //--- DROPBITS(5) ---//\n hold >>>= 5;\n bits -= 5;\n //---//\n state.ncode = (hold & 0x0f)/*BITS(4)*/ + 4;\n //--- DROPBITS(4) ---//\n hold >>>= 4;\n bits -= 4;\n //---//\n//#ifndef PKZIP_BUG_WORKAROUND\n if (state.nlen > 286 || state.ndist > 30) {\n strm.msg = 'too many length or distance symbols';\n state.mode = BAD;\n break;\n }\n//#endif\n //Tracev((stderr, \"inflate: table sizes ok\\n\"));\n state.have = 0;\n state.mode = LENLENS;\n /* falls through */\n case LENLENS:\n while (state.have < state.ncode) {\n //=== NEEDBITS(3);\n while (bits < 3) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.lens[order[state.have++]] = (hold & 0x07);//BITS(3);\n //--- DROPBITS(3) ---//\n hold >>>= 3;\n bits -= 3;\n //---//\n }\n while (state.have < 19) {\n state.lens[order[state.have++]] = 0;\n }\n // We have separate tables & no pointers. 2 commented lines below not needed.\n //state.next = state.codes;\n //state.lencode = state.next;\n // Switch to use dynamic table\n state.lencode = state.lendyn;\n state.lenbits = 7;\n\n opts = { bits: state.lenbits };\n ret = inflate_table(CODES, state.lens, 0, 19, state.lencode, 0, state.work, opts);\n state.lenbits = opts.bits;\n\n if (ret) {\n strm.msg = 'invalid code lengths set';\n state.mode = BAD;\n break;\n }\n //Tracev((stderr, \"inflate: code lengths ok\\n\"));\n state.have = 0;\n state.mode = CODELENS;\n /* falls through */\n case CODELENS:\n while (state.have < state.nlen + state.ndist) {\n for (;;) {\n here = state.lencode[hold & ((1 << state.lenbits) - 1)];/*BITS(state.lenbits)*/\n here_bits = here >>> 24;\n here_op = (here >>> 16) & 0xff;\n here_val = here & 0xffff;\n\n if ((here_bits) <= bits) { break; }\n //--- PULLBYTE() ---//\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n //---//\n }\n if (here_val < 16) {\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n state.lens[state.have++] = here_val;\n }\n else {\n if (here_val === 16) {\n //=== NEEDBITS(here.bits + 2);\n n = here_bits + 2;\n while (bits < n) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n if (state.have === 0) {\n strm.msg = 'invalid bit length repeat';\n state.mode = BAD;\n break;\n }\n len = state.lens[state.have - 1];\n copy = 3 + (hold & 0x03);//BITS(2);\n //--- DROPBITS(2) ---//\n hold >>>= 2;\n bits -= 2;\n //---//\n }\n else if (here_val === 17) {\n //=== NEEDBITS(here.bits + 3);\n n = here_bits + 3;\n while (bits < n) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n len = 0;\n copy = 3 + (hold & 0x07);//BITS(3);\n //--- DROPBITS(3) ---//\n hold >>>= 3;\n bits -= 3;\n //---//\n }\n else {\n //=== NEEDBITS(here.bits + 7);\n n = here_bits + 7;\n while (bits < n) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n len = 0;\n copy = 11 + (hold & 0x7f);//BITS(7);\n //--- DROPBITS(7) ---//\n hold >>>= 7;\n bits -= 7;\n //---//\n }\n if (state.have + copy > state.nlen + state.ndist) {\n strm.msg = 'invalid bit length repeat';\n state.mode = BAD;\n break;\n }\n while (copy--) {\n state.lens[state.have++] = len;\n }\n }\n }\n\n /* handle error breaks in while */\n if (state.mode === BAD) { break; }\n\n /* check for end-of-block code (better have one) */\n if (state.lens[256] === 0) {\n strm.msg = 'invalid code -- missing end-of-block';\n state.mode = BAD;\n break;\n }\n\n /* build code tables -- note: do not change the lenbits or distbits\n values here (9 and 6) without reading the comments in inftrees.h\n concerning the ENOUGH constants, which depend on those values */\n state.lenbits = 9;\n\n opts = { bits: state.lenbits };\n ret = inflate_table(LENS, state.lens, 0, state.nlen, state.lencode, 0, state.work, opts);\n // We have separate tables & no pointers. 2 commented lines below not needed.\n // state.next_index = opts.table_index;\n state.lenbits = opts.bits;\n // state.lencode = state.next;\n\n if (ret) {\n strm.msg = 'invalid literal/lengths set';\n state.mode = BAD;\n break;\n }\n\n state.distbits = 6;\n //state.distcode.copy(state.codes);\n // Switch to use dynamic table\n state.distcode = state.distdyn;\n opts = { bits: state.distbits };\n ret = inflate_table(DISTS, state.lens, state.nlen, state.ndist, state.distcode, 0, state.work, opts);\n // We have separate tables & no pointers. 2 commented lines below not needed.\n // state.next_index = opts.table_index;\n state.distbits = opts.bits;\n // state.distcode = state.next;\n\n if (ret) {\n strm.msg = 'invalid distances set';\n state.mode = BAD;\n break;\n }\n //Tracev((stderr, 'inflate: codes ok\\n'));\n state.mode = LEN_;\n if (flush === Z_TREES) { break inf_leave; }\n /* falls through */\n case LEN_:\n state.mode = LEN;\n /* falls through */\n case LEN:\n if (have >= 6 && left >= 258) {\n //--- RESTORE() ---\n strm.next_out = put;\n strm.avail_out = left;\n strm.next_in = next;\n strm.avail_in = have;\n state.hold = hold;\n state.bits = bits;\n //---\n inflate_fast(strm, _out);\n //--- LOAD() ---\n put = strm.next_out;\n output = strm.output;\n left = strm.avail_out;\n next = strm.next_in;\n input = strm.input;\n have = strm.avail_in;\n hold = state.hold;\n bits = state.bits;\n //---\n\n if (state.mode === TYPE) {\n state.back = -1;\n }\n break;\n }\n state.back = 0;\n for (;;) {\n here = state.lencode[hold & ((1 << state.lenbits) - 1)]; /*BITS(state.lenbits)*/\n here_bits = here >>> 24;\n here_op = (here >>> 16) & 0xff;\n here_val = here & 0xffff;\n\n if (here_bits <= bits) { break; }\n //--- PULLBYTE() ---//\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n //---//\n }\n if (here_op && (here_op & 0xf0) === 0) {\n last_bits = here_bits;\n last_op = here_op;\n last_val = here_val;\n for (;;) {\n here = state.lencode[last_val +\n ((hold & ((1 << (last_bits + last_op)) - 1))/*BITS(last.bits + last.op)*/ >> last_bits)];\n here_bits = here >>> 24;\n here_op = (here >>> 16) & 0xff;\n here_val = here & 0xffff;\n\n if ((last_bits + here_bits) <= bits) { break; }\n //--- PULLBYTE() ---//\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n //---//\n }\n //--- DROPBITS(last.bits) ---//\n hold >>>= last_bits;\n bits -= last_bits;\n //---//\n state.back += last_bits;\n }\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n state.back += here_bits;\n state.length = here_val;\n if (here_op === 0) {\n //Tracevv((stderr, here.val >= 0x20 && here.val < 0x7f ?\n // \"inflate: literal '%c'\\n\" :\n // \"inflate: literal 0x%02x\\n\", here.val));\n state.mode = LIT;\n break;\n }\n if (here_op & 32) {\n //Tracevv((stderr, \"inflate: end of block\\n\"));\n state.back = -1;\n state.mode = TYPE;\n break;\n }\n if (here_op & 64) {\n strm.msg = 'invalid literal/length code';\n state.mode = BAD;\n break;\n }\n state.extra = here_op & 15;\n state.mode = LENEXT;\n /* falls through */\n case LENEXT:\n if (state.extra) {\n //=== NEEDBITS(state.extra);\n n = state.extra;\n while (bits < n) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.length += hold & ((1 << state.extra) - 1)/*BITS(state.extra)*/;\n //--- DROPBITS(state.extra) ---//\n hold >>>= state.extra;\n bits -= state.extra;\n //---//\n state.back += state.extra;\n }\n //Tracevv((stderr, \"inflate: length %u\\n\", state.length));\n state.was = state.length;\n state.mode = DIST;\n /* falls through */\n case DIST:\n for (;;) {\n here = state.distcode[hold & ((1 << state.distbits) - 1)];/*BITS(state.distbits)*/\n here_bits = here >>> 24;\n here_op = (here >>> 16) & 0xff;\n here_val = here & 0xffff;\n\n if ((here_bits) <= bits) { break; }\n //--- PULLBYTE() ---//\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n //---//\n }\n if ((here_op & 0xf0) === 0) {\n last_bits = here_bits;\n last_op = here_op;\n last_val = here_val;\n for (;;) {\n here = state.distcode[last_val +\n ((hold & ((1 << (last_bits + last_op)) - 1))/*BITS(last.bits + last.op)*/ >> last_bits)];\n here_bits = here >>> 24;\n here_op = (here >>> 16) & 0xff;\n here_val = here & 0xffff;\n\n if ((last_bits + here_bits) <= bits) { break; }\n //--- PULLBYTE() ---//\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n //---//\n }\n //--- DROPBITS(last.bits) ---//\n hold >>>= last_bits;\n bits -= last_bits;\n //---//\n state.back += last_bits;\n }\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n state.back += here_bits;\n if (here_op & 64) {\n strm.msg = 'invalid distance code';\n state.mode = BAD;\n break;\n }\n state.offset = here_val;\n state.extra = (here_op) & 15;\n state.mode = DISTEXT;\n /* falls through */\n case DISTEXT:\n if (state.extra) {\n //=== NEEDBITS(state.extra);\n n = state.extra;\n while (bits < n) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.offset += hold & ((1 << state.extra) - 1)/*BITS(state.extra)*/;\n //--- DROPBITS(state.extra) ---//\n hold >>>= state.extra;\n bits -= state.extra;\n //---//\n state.back += state.extra;\n }\n//#ifdef INFLATE_STRICT\n if (state.offset > state.dmax) {\n strm.msg = 'invalid distance too far back';\n state.mode = BAD;\n break;\n }\n//#endif\n //Tracevv((stderr, \"inflate: distance %u\\n\", state.offset));\n state.mode = MATCH;\n /* falls through */\n case MATCH:\n if (left === 0) { break inf_leave; }\n copy = _out - left;\n if (state.offset > copy) { /* copy from window */\n copy = state.offset - copy;\n if (copy > state.whave) {\n if (state.sane) {\n strm.msg = 'invalid distance too far back';\n state.mode = BAD;\n break;\n }\n// (!) This block is disabled in zlib defaults,\n// don't enable it for binary compatibility\n//#ifdef INFLATE_ALLOW_INVALID_DISTANCE_TOOFAR_ARRR\n// Trace((stderr, \"inflate.c too far\\n\"));\n// copy -= state.whave;\n// if (copy > state.length) { copy = state.length; }\n// if (copy > left) { copy = left; }\n// left -= copy;\n// state.length -= copy;\n// do {\n// output[put++] = 0;\n// } while (--copy);\n// if (state.length === 0) { state.mode = LEN; }\n// break;\n//#endif\n }\n if (copy > state.wnext) {\n copy -= state.wnext;\n from = state.wsize - copy;\n }\n else {\n from = state.wnext - copy;\n }\n if (copy > state.length) { copy = state.length; }\n from_source = state.window;\n }\n else { /* copy from output */\n from_source = output;\n from = put - state.offset;\n copy = state.length;\n }\n if (copy > left) { copy = left; }\n left -= copy;\n state.length -= copy;\n do {\n output[put++] = from_source[from++];\n } while (--copy);\n if (state.length === 0) { state.mode = LEN; }\n break;\n case LIT:\n if (left === 0) { break inf_leave; }\n output[put++] = state.length;\n left--;\n state.mode = LEN;\n break;\n case CHECK:\n if (state.wrap) {\n //=== NEEDBITS(32);\n while (bits < 32) {\n if (have === 0) { break inf_leave; }\n have--;\n // Use '|' instead of '+' to make sure that result is signed\n hold |= input[next++] << bits;\n bits += 8;\n }\n //===//\n _out -= left;\n strm.total_out += _out;\n state.total += _out;\n if (_out) {\n strm.adler = state.check =\n /*UPDATE(state.check, put - _out, _out);*/\n (state.flags ? crc32(state.check, output, _out, put - _out) : adler32(state.check, output, _out, put - _out));\n\n }\n _out = left;\n // NB: crc32 stored as signed 32-bit int, zswap32 returns signed too\n if ((state.flags ? hold : zswap32(hold)) !== state.check) {\n strm.msg = 'incorrect data check';\n state.mode = BAD;\n break;\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n //Tracev((stderr, \"inflate: check matches trailer\\n\"));\n }\n state.mode = LENGTH;\n /* falls through */\n case LENGTH:\n if (state.wrap && state.flags) {\n //=== NEEDBITS(32);\n while (bits < 32) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if (hold !== (state.total & 0xffffffff)) {\n strm.msg = 'incorrect length check';\n state.mode = BAD;\n break;\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n //Tracev((stderr, \"inflate: length matches trailer\\n\"));\n }\n state.mode = DONE;\n /* falls through */\n case DONE:\n ret = Z_STREAM_END;\n break inf_leave;\n case BAD:\n ret = Z_DATA_ERROR;\n break inf_leave;\n case MEM:\n return Z_MEM_ERROR;\n case SYNC:\n /* falls through */\n default:\n return Z_STREAM_ERROR;\n }\n }\n\n // inf_leave <- here is real place for \"goto inf_leave\", emulated via \"break inf_leave\"\n\n /*\n Return from inflate(), updating the total counts and the check value.\n If there was no progress during the inflate() call, return a buffer\n error. Call updatewindow() to create and/or update the window state.\n Note: a memory error from inflate() is non-recoverable.\n */\n\n //--- RESTORE() ---\n strm.next_out = put;\n strm.avail_out = left;\n strm.next_in = next;\n strm.avail_in = have;\n state.hold = hold;\n state.bits = bits;\n //---\n\n if (state.wsize || (_out !== strm.avail_out && state.mode < BAD &&\n (state.mode < CHECK || flush !== Z_FINISH))) {\n if (updatewindow(strm, strm.output, strm.next_out, _out - strm.avail_out)) {\n state.mode = MEM;\n return Z_MEM_ERROR;\n }\n }\n _in -= strm.avail_in;\n _out -= strm.avail_out;\n strm.total_in += _in;\n strm.total_out += _out;\n state.total += _out;\n if (state.wrap && _out) {\n strm.adler = state.check = /*UPDATE(state.check, strm.next_out - _out, _out);*/\n (state.flags ? crc32(state.check, output, _out, strm.next_out - _out) : adler32(state.check, output, _out, strm.next_out - _out));\n }\n strm.data_type = state.bits + (state.last ? 64 : 0) +\n (state.mode === TYPE ? 128 : 0) +\n (state.mode === LEN_ || state.mode === COPY_ ? 256 : 0);\n if (((_in === 0 && _out === 0) || flush === Z_FINISH) && ret === Z_OK) {\n ret = Z_BUF_ERROR;\n }\n return ret;\n}\n\nfunction inflateEnd(strm) {\n\n if (!strm || !strm.state /*|| strm->zfree == (free_func)0*/) {\n return Z_STREAM_ERROR;\n }\n\n var state = strm.state;\n if (state.window) {\n state.window = null;\n }\n strm.state = null;\n return Z_OK;\n}\n\nfunction inflateGetHeader(strm, head) {\n var state;\n\n /* check state */\n if (!strm || !strm.state) { return Z_STREAM_ERROR; }\n state = strm.state;\n if ((state.wrap & 2) === 0) { return Z_STREAM_ERROR; }\n\n /* save header structure */\n state.head = head;\n head.done = false;\n return Z_OK;\n}\n\nfunction inflateSetDictionary(strm, dictionary) {\n var dictLength = dictionary.length;\n\n var state;\n var dictid;\n var ret;\n\n /* check state */\n if (!strm /* == Z_NULL */ || !strm.state /* == Z_NULL */) { return Z_STREAM_ERROR; }\n state = strm.state;\n\n if (state.wrap !== 0 && state.mode !== DICT) {\n return Z_STREAM_ERROR;\n }\n\n /* check for correct dictionary identifier */\n if (state.mode === DICT) {\n dictid = 1; /* adler32(0, null, 0)*/\n /* dictid = adler32(dictid, dictionary, dictLength); */\n dictid = adler32(dictid, dictionary, dictLength, 0);\n if (dictid !== state.check) {\n return Z_DATA_ERROR;\n }\n }\n /* copy dictionary to window using updatewindow(), which will amend the\n existing dictionary if appropriate */\n ret = updatewindow(strm, dictionary, dictLength, dictLength);\n if (ret) {\n state.mode = MEM;\n return Z_MEM_ERROR;\n }\n state.havedict = 1;\n // Tracev((stderr, \"inflate: dictionary set\\n\"));\n return Z_OK;\n}\n\nexports.inflateReset = inflateReset;\nexports.inflateReset2 = inflateReset2;\nexports.inflateResetKeep = inflateResetKeep;\nexports.inflateInit = inflateInit;\nexports.inflateInit2 = inflateInit2;\nexports.inflate = inflate;\nexports.inflateEnd = inflateEnd;\nexports.inflateGetHeader = inflateGetHeader;\nexports.inflateSetDictionary = inflateSetDictionary;\nexports.inflateInfo = 'pako inflate (from Nodeca project)';\n\n/* Not implemented\nexports.inflateCopy = inflateCopy;\nexports.inflateGetDictionary = inflateGetDictionary;\nexports.inflateMark = inflateMark;\nexports.inflatePrime = inflatePrime;\nexports.inflateSync = inflateSync;\nexports.inflateSyncPoint = inflateSyncPoint;\nexports.inflateUndermine = inflateUndermine;\n*/\n","'use strict';\n\n// Note: adler32 takes 12% for level 0 and 2% for level 6.\n// It isn't worth it to make additional optimizations as in original.\n// Small size is preferable.\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nfunction adler32(adler, buf, len, pos) {\n var s1 = (adler & 0xffff) |0,\n s2 = ((adler >>> 16) & 0xffff) |0,\n n = 0;\n\n while (len !== 0) {\n // Set limit ~ twice less than 5552, to keep\n // s2 in 31-bits, because we force signed ints.\n // in other case %= will fail.\n n = len > 2000 ? 2000 : len;\n len -= n;\n\n do {\n s1 = (s1 + buf[pos++]) |0;\n s2 = (s2 + s1) |0;\n } while (--n);\n\n s1 %= 65521;\n s2 %= 65521;\n }\n\n return (s1 | (s2 << 16)) |0;\n}\n\n\nmodule.exports = adler32;\n","'use strict';\n\n// Note: we can't get significant speed boost here.\n// So write code to minimize size - no pregenerated tables\n// and array tools dependencies.\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\n// Use ordinary array, since untyped makes no boost here\nfunction makeTable() {\n var c, table = [];\n\n for (var n = 0; n < 256; n++) {\n c = n;\n for (var k = 0; k < 8; k++) {\n c = ((c & 1) ? (0xEDB88320 ^ (c >>> 1)) : (c >>> 1));\n }\n table[n] = c;\n }\n\n return table;\n}\n\n// Create table on load. Just 255 signed longs. Not a problem.\nvar crcTable = makeTable();\n\n\nfunction crc32(crc, buf, len, pos) {\n var t = crcTable,\n end = pos + len;\n\n crc ^= -1;\n\n for (var i = pos; i < end; i++) {\n crc = (crc >>> 8) ^ t[(crc ^ buf[i]) & 0xFF];\n }\n\n return (crc ^ (-1)); // >>> 0;\n}\n\n\nmodule.exports = crc32;\n","'use strict';\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\n// See state defs from inflate.js\nvar BAD = 30; /* got a data error -- remain here until reset */\nvar TYPE = 12; /* i: waiting for type bits, including last-flag bit */\n\n/*\n Decode literal, length, and distance codes and write out the resulting\n literal and match bytes until either not enough input or output is\n available, an end-of-block is encountered, or a data error is encountered.\n When large enough input and output buffers are supplied to inflate(), for\n example, a 16K input buffer and a 64K output buffer, more than 95% of the\n inflate execution time is spent in this routine.\n\n Entry assumptions:\n\n state.mode === LEN\n strm.avail_in >= 6\n strm.avail_out >= 258\n start >= strm.avail_out\n state.bits < 8\n\n On return, state.mode is one of:\n\n LEN -- ran out of enough output space or enough available input\n TYPE -- reached end of block code, inflate() to interpret next block\n BAD -- error in block data\n\n Notes:\n\n - The maximum input bits used by a length/distance pair is 15 bits for the\n length code, 5 bits for the length extra, 15 bits for the distance code,\n and 13 bits for the distance extra. This totals 48 bits, or six bytes.\n Therefore if strm.avail_in >= 6, then there is enough input to avoid\n checking for available input while decoding.\n\n - The maximum bytes that a single length/distance pair can output is 258\n bytes, which is the maximum length that can be coded. inflate_fast()\n requires strm.avail_out >= 258 for each loop to avoid checking for\n output space.\n */\nmodule.exports = function inflate_fast(strm, start) {\n var state;\n var _in; /* local strm.input */\n var last; /* have enough input while in < last */\n var _out; /* local strm.output */\n var beg; /* inflate()'s initial strm.output */\n var end; /* while out < end, enough space available */\n//#ifdef INFLATE_STRICT\n var dmax; /* maximum distance from zlib header */\n//#endif\n var wsize; /* window size or zero if not using window */\n var whave; /* valid bytes in the window */\n var wnext; /* window write index */\n // Use `s_window` instead `window`, avoid conflict with instrumentation tools\n var s_window; /* allocated sliding window, if wsize != 0 */\n var hold; /* local strm.hold */\n var bits; /* local strm.bits */\n var lcode; /* local strm.lencode */\n var dcode; /* local strm.distcode */\n var lmask; /* mask for first level of length codes */\n var dmask; /* mask for first level of distance codes */\n var here; /* retrieved table entry */\n var op; /* code bits, operation, extra bits, or */\n /* window position, window bytes to copy */\n var len; /* match length, unused bytes */\n var dist; /* match distance */\n var from; /* where to copy match from */\n var from_source;\n\n\n var input, output; // JS specific, because we have no pointers\n\n /* copy state to local variables */\n state = strm.state;\n //here = state.here;\n _in = strm.next_in;\n input = strm.input;\n last = _in + (strm.avail_in - 5);\n _out = strm.next_out;\n output = strm.output;\n beg = _out - (start - strm.avail_out);\n end = _out + (strm.avail_out - 257);\n//#ifdef INFLATE_STRICT\n dmax = state.dmax;\n//#endif\n wsize = state.wsize;\n whave = state.whave;\n wnext = state.wnext;\n s_window = state.window;\n hold = state.hold;\n bits = state.bits;\n lcode = state.lencode;\n dcode = state.distcode;\n lmask = (1 << state.lenbits) - 1;\n dmask = (1 << state.distbits) - 1;\n\n\n /* decode literals and length/distances until end-of-block or not enough\n input data or output space */\n\n top:\n do {\n if (bits < 15) {\n hold += input[_in++] << bits;\n bits += 8;\n hold += input[_in++] << bits;\n bits += 8;\n }\n\n here = lcode[hold & lmask];\n\n dolen:\n for (;;) { // Goto emulation\n op = here >>> 24/*here.bits*/;\n hold >>>= op;\n bits -= op;\n op = (here >>> 16) & 0xff/*here.op*/;\n if (op === 0) { /* literal */\n //Tracevv((stderr, here.val >= 0x20 && here.val < 0x7f ?\n // \"inflate: literal '%c'\\n\" :\n // \"inflate: literal 0x%02x\\n\", here.val));\n output[_out++] = here & 0xffff/*here.val*/;\n }\n else if (op & 16) { /* length base */\n len = here & 0xffff/*here.val*/;\n op &= 15; /* number of extra bits */\n if (op) {\n if (bits < op) {\n hold += input[_in++] << bits;\n bits += 8;\n }\n len += hold & ((1 << op) - 1);\n hold >>>= op;\n bits -= op;\n }\n //Tracevv((stderr, \"inflate: length %u\\n\", len));\n if (bits < 15) {\n hold += input[_in++] << bits;\n bits += 8;\n hold += input[_in++] << bits;\n bits += 8;\n }\n here = dcode[hold & dmask];\n\n dodist:\n for (;;) { // goto emulation\n op = here >>> 24/*here.bits*/;\n hold >>>= op;\n bits -= op;\n op = (here >>> 16) & 0xff/*here.op*/;\n\n if (op & 16) { /* distance base */\n dist = here & 0xffff/*here.val*/;\n op &= 15; /* number of extra bits */\n if (bits < op) {\n hold += input[_in++] << bits;\n bits += 8;\n if (bits < op) {\n hold += input[_in++] << bits;\n bits += 8;\n }\n }\n dist += hold & ((1 << op) - 1);\n//#ifdef INFLATE_STRICT\n if (dist > dmax) {\n strm.msg = 'invalid distance too far back';\n state.mode = BAD;\n break top;\n }\n//#endif\n hold >>>= op;\n bits -= op;\n //Tracevv((stderr, \"inflate: distance %u\\n\", dist));\n op = _out - beg; /* max distance in output */\n if (dist > op) { /* see if copy from window */\n op = dist - op; /* distance back in window */\n if (op > whave) {\n if (state.sane) {\n strm.msg = 'invalid distance too far back';\n state.mode = BAD;\n break top;\n }\n\n// (!) This block is disabled in zlib defaults,\n// don't enable it for binary compatibility\n//#ifdef INFLATE_ALLOW_INVALID_DISTANCE_TOOFAR_ARRR\n// if (len <= op - whave) {\n// do {\n// output[_out++] = 0;\n// } while (--len);\n// continue top;\n// }\n// len -= op - whave;\n// do {\n// output[_out++] = 0;\n// } while (--op > whave);\n// if (op === 0) {\n// from = _out - dist;\n// do {\n// output[_out++] = output[from++];\n// } while (--len);\n// continue top;\n// }\n//#endif\n }\n from = 0; // window index\n from_source = s_window;\n if (wnext === 0) { /* very common case */\n from += wsize - op;\n if (op < len) { /* some from window */\n len -= op;\n do {\n output[_out++] = s_window[from++];\n } while (--op);\n from = _out - dist; /* rest from output */\n from_source = output;\n }\n }\n else if (wnext < op) { /* wrap around window */\n from += wsize + wnext - op;\n op -= wnext;\n if (op < len) { /* some from end of window */\n len -= op;\n do {\n output[_out++] = s_window[from++];\n } while (--op);\n from = 0;\n if (wnext < len) { /* some from start of window */\n op = wnext;\n len -= op;\n do {\n output[_out++] = s_window[from++];\n } while (--op);\n from = _out - dist; /* rest from output */\n from_source = output;\n }\n }\n }\n else { /* contiguous in window */\n from += wnext - op;\n if (op < len) { /* some from window */\n len -= op;\n do {\n output[_out++] = s_window[from++];\n } while (--op);\n from = _out - dist; /* rest from output */\n from_source = output;\n }\n }\n while (len > 2) {\n output[_out++] = from_source[from++];\n output[_out++] = from_source[from++];\n output[_out++] = from_source[from++];\n len -= 3;\n }\n if (len) {\n output[_out++] = from_source[from++];\n if (len > 1) {\n output[_out++] = from_source[from++];\n }\n }\n }\n else {\n from = _out - dist; /* copy direct from output */\n do { /* minimum length is three */\n output[_out++] = output[from++];\n output[_out++] = output[from++];\n output[_out++] = output[from++];\n len -= 3;\n } while (len > 2);\n if (len) {\n output[_out++] = output[from++];\n if (len > 1) {\n output[_out++] = output[from++];\n }\n }\n }\n }\n else if ((op & 64) === 0) { /* 2nd level distance code */\n here = dcode[(here & 0xffff)/*here.val*/ + (hold & ((1 << op) - 1))];\n continue dodist;\n }\n else {\n strm.msg = 'invalid distance code';\n state.mode = BAD;\n break top;\n }\n\n break; // need to emulate goto via \"continue\"\n }\n }\n else if ((op & 64) === 0) { /* 2nd level length code */\n here = lcode[(here & 0xffff)/*here.val*/ + (hold & ((1 << op) - 1))];\n continue dolen;\n }\n else if (op & 32) { /* end-of-block */\n //Tracevv((stderr, \"inflate: end of block\\n\"));\n state.mode = TYPE;\n break top;\n }\n else {\n strm.msg = 'invalid literal/length code';\n state.mode = BAD;\n break top;\n }\n\n break; // need to emulate goto via \"continue\"\n }\n } while (_in < last && _out < end);\n\n /* return unused bytes (on entry, bits < 8, so in won't go too far back) */\n len = bits >> 3;\n _in -= len;\n bits -= len << 3;\n hold &= (1 << bits) - 1;\n\n /* update state and return */\n strm.next_in = _in;\n strm.next_out = _out;\n strm.avail_in = (_in < last ? 5 + (last - _in) : 5 - (_in - last));\n strm.avail_out = (_out < end ? 257 + (end - _out) : 257 - (_out - end));\n state.hold = hold;\n state.bits = bits;\n return;\n};\n","'use strict';\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nvar utils = require('../utils/common');\n\nvar MAXBITS = 15;\nvar ENOUGH_LENS = 852;\nvar ENOUGH_DISTS = 592;\n//var ENOUGH = (ENOUGH_LENS+ENOUGH_DISTS);\n\nvar CODES = 0;\nvar LENS = 1;\nvar DISTS = 2;\n\nvar lbase = [ /* Length codes 257..285 base */\n 3, 4, 5, 6, 7, 8, 9, 10, 11, 13, 15, 17, 19, 23, 27, 31,\n 35, 43, 51, 59, 67, 83, 99, 115, 131, 163, 195, 227, 258, 0, 0\n];\n\nvar lext = [ /* Length codes 257..285 extra */\n 16, 16, 16, 16, 16, 16, 16, 16, 17, 17, 17, 17, 18, 18, 18, 18,\n 19, 19, 19, 19, 20, 20, 20, 20, 21, 21, 21, 21, 16, 72, 78\n];\n\nvar dbase = [ /* Distance codes 0..29 base */\n 1, 2, 3, 4, 5, 7, 9, 13, 17, 25, 33, 49, 65, 97, 129, 193,\n 257, 385, 513, 769, 1025, 1537, 2049, 3073, 4097, 6145,\n 8193, 12289, 16385, 24577, 0, 0\n];\n\nvar dext = [ /* Distance codes 0..29 extra */\n 16, 16, 16, 16, 17, 17, 18, 18, 19, 19, 20, 20, 21, 21, 22, 22,\n 23, 23, 24, 24, 25, 25, 26, 26, 27, 27,\n 28, 28, 29, 29, 64, 64\n];\n\nmodule.exports = function inflate_table(type, lens, lens_index, codes, table, table_index, work, opts)\n{\n var bits = opts.bits;\n //here = opts.here; /* table entry for duplication */\n\n var len = 0; /* a code's length in bits */\n var sym = 0; /* index of code symbols */\n var min = 0, max = 0; /* minimum and maximum code lengths */\n var root = 0; /* number of index bits for root table */\n var curr = 0; /* number of index bits for current table */\n var drop = 0; /* code bits to drop for sub-table */\n var left = 0; /* number of prefix codes available */\n var used = 0; /* code entries in table used */\n var huff = 0; /* Huffman code */\n var incr; /* for incrementing code, index */\n var fill; /* index for replicating entries */\n var low; /* low bits for current root entry */\n var mask; /* mask for low root bits */\n var next; /* next available space in table */\n var base = null; /* base value table to use */\n var base_index = 0;\n// var shoextra; /* extra bits table to use */\n var end; /* use base and extra for symbol > end */\n var count = new utils.Buf16(MAXBITS + 1); //[MAXBITS+1]; /* number of codes of each length */\n var offs = new utils.Buf16(MAXBITS + 1); //[MAXBITS+1]; /* offsets in table for each length */\n var extra = null;\n var extra_index = 0;\n\n var here_bits, here_op, here_val;\n\n /*\n Process a set of code lengths to create a canonical Huffman code. The\n code lengths are lens[0..codes-1]. Each length corresponds to the\n symbols 0..codes-1. The Huffman code is generated by first sorting the\n symbols by length from short to long, and retaining the symbol order\n for codes with equal lengths. Then the code starts with all zero bits\n for the first code of the shortest length, and the codes are integer\n increments for the same length, and zeros are appended as the length\n increases. For the deflate format, these bits are stored backwards\n from their more natural integer increment ordering, and so when the\n decoding tables are built in the large loop below, the integer codes\n are incremented backwards.\n\n This routine assumes, but does not check, that all of the entries in\n lens[] are in the range 0..MAXBITS. The caller must assure this.\n 1..MAXBITS is interpreted as that code length. zero means that that\n symbol does not occur in this code.\n\n The codes are sorted by computing a count of codes for each length,\n creating from that a table of starting indices for each length in the\n sorted table, and then entering the symbols in order in the sorted\n table. The sorted table is work[], with that space being provided by\n the caller.\n\n The length counts are used for other purposes as well, i.e. finding\n the minimum and maximum length codes, determining if there are any\n codes at all, checking for a valid set of lengths, and looking ahead\n at length counts to determine sub-table sizes when building the\n decoding tables.\n */\n\n /* accumulate lengths for codes (assumes lens[] all in 0..MAXBITS) */\n for (len = 0; len <= MAXBITS; len++) {\n count[len] = 0;\n }\n for (sym = 0; sym < codes; sym++) {\n count[lens[lens_index + sym]]++;\n }\n\n /* bound code lengths, force root to be within code lengths */\n root = bits;\n for (max = MAXBITS; max >= 1; max--) {\n if (count[max] !== 0) { break; }\n }\n if (root > max) {\n root = max;\n }\n if (max === 0) { /* no symbols to code at all */\n //table.op[opts.table_index] = 64; //here.op = (var char)64; /* invalid code marker */\n //table.bits[opts.table_index] = 1; //here.bits = (var char)1;\n //table.val[opts.table_index++] = 0; //here.val = (var short)0;\n table[table_index++] = (1 << 24) | (64 << 16) | 0;\n\n\n //table.op[opts.table_index] = 64;\n //table.bits[opts.table_index] = 1;\n //table.val[opts.table_index++] = 0;\n table[table_index++] = (1 << 24) | (64 << 16) | 0;\n\n opts.bits = 1;\n return 0; /* no symbols, but wait for decoding to report error */\n }\n for (min = 1; min < max; min++) {\n if (count[min] !== 0) { break; }\n }\n if (root < min) {\n root = min;\n }\n\n /* check for an over-subscribed or incomplete set of lengths */\n left = 1;\n for (len = 1; len <= MAXBITS; len++) {\n left <<= 1;\n left -= count[len];\n if (left < 0) {\n return -1;\n } /* over-subscribed */\n }\n if (left > 0 && (type === CODES || max !== 1)) {\n return -1; /* incomplete set */\n }\n\n /* generate offsets into symbol table for each length for sorting */\n offs[1] = 0;\n for (len = 1; len < MAXBITS; len++) {\n offs[len + 1] = offs[len] + count[len];\n }\n\n /* sort symbols by length, by symbol order within each length */\n for (sym = 0; sym < codes; sym++) {\n if (lens[lens_index + sym] !== 0) {\n work[offs[lens[lens_index + sym]]++] = sym;\n }\n }\n\n /*\n Create and fill in decoding tables. In this loop, the table being\n filled is at next and has curr index bits. The code being used is huff\n with length len. That code is converted to an index by dropping drop\n bits off of the bottom. For codes where len is less than drop + curr,\n those top drop + curr - len bits are incremented through all values to\n fill the table with replicated entries.\n\n root is the number of index bits for the root table. When len exceeds\n root, sub-tables are created pointed to by the root entry with an index\n of the low root bits of huff. This is saved in low to check for when a\n new sub-table should be started. drop is zero when the root table is\n being filled, and drop is root when sub-tables are being filled.\n\n When a new sub-table is needed, it is necessary to look ahead in the\n code lengths to determine what size sub-table is needed. The length\n counts are used for this, and so count[] is decremented as codes are\n entered in the tables.\n\n used keeps track of how many table entries have been allocated from the\n provided *table space. It is checked for LENS and DIST tables against\n the constants ENOUGH_LENS and ENOUGH_DISTS to guard against changes in\n the initial root table size constants. See the comments in inftrees.h\n for more information.\n\n sym increments through all symbols, and the loop terminates when\n all codes of length max, i.e. all codes, have been processed. This\n routine permits incomplete codes, so another loop after this one fills\n in the rest of the decoding tables with invalid code markers.\n */\n\n /* set up for code type */\n // poor man optimization - use if-else instead of switch,\n // to avoid deopts in old v8\n if (type === CODES) {\n base = extra = work; /* dummy value--not used */\n end = 19;\n\n } else if (type === LENS) {\n base = lbase;\n base_index -= 257;\n extra = lext;\n extra_index -= 257;\n end = 256;\n\n } else { /* DISTS */\n base = dbase;\n extra = dext;\n end = -1;\n }\n\n /* initialize opts for loop */\n huff = 0; /* starting code */\n sym = 0; /* starting code symbol */\n len = min; /* starting code length */\n next = table_index; /* current table to fill in */\n curr = root; /* current table index bits */\n drop = 0; /* current bits to drop from code for index */\n low = -1; /* trigger new sub-table when len > root */\n used = 1 << root; /* use root table entries */\n mask = used - 1; /* mask for comparing low */\n\n /* check available table space */\n if ((type === LENS && used > ENOUGH_LENS) ||\n (type === DISTS && used > ENOUGH_DISTS)) {\n return 1;\n }\n\n /* process all codes and make table entries */\n for (;;) {\n /* create table entry */\n here_bits = len - drop;\n if (work[sym] < end) {\n here_op = 0;\n here_val = work[sym];\n }\n else if (work[sym] > end) {\n here_op = extra[extra_index + work[sym]];\n here_val = base[base_index + work[sym]];\n }\n else {\n here_op = 32 + 64; /* end of block */\n here_val = 0;\n }\n\n /* replicate for those indices with low len bits equal to huff */\n incr = 1 << (len - drop);\n fill = 1 << curr;\n min = fill; /* save offset to next table */\n do {\n fill -= incr;\n table[next + (huff >> drop) + fill] = (here_bits << 24) | (here_op << 16) | here_val |0;\n } while (fill !== 0);\n\n /* backwards increment the len-bit code huff */\n incr = 1 << (len - 1);\n while (huff & incr) {\n incr >>= 1;\n }\n if (incr !== 0) {\n huff &= incr - 1;\n huff += incr;\n } else {\n huff = 0;\n }\n\n /* go to next symbol, update count, len */\n sym++;\n if (--count[len] === 0) {\n if (len === max) { break; }\n len = lens[lens_index + work[sym]];\n }\n\n /* create new sub-table if needed */\n if (len > root && (huff & mask) !== low) {\n /* if first time, transition to sub-tables */\n if (drop === 0) {\n drop = root;\n }\n\n /* increment past last table */\n next += min; /* here min is 1 << curr */\n\n /* determine length of next table */\n curr = len - drop;\n left = 1 << curr;\n while (curr + drop < max) {\n left -= count[curr + drop];\n if (left <= 0) { break; }\n curr++;\n left <<= 1;\n }\n\n /* check for enough space */\n used += 1 << curr;\n if ((type === LENS && used > ENOUGH_LENS) ||\n (type === DISTS && used > ENOUGH_DISTS)) {\n return 1;\n }\n\n /* point entry in root table to sub-table */\n low = huff & mask;\n /*table.op[low] = curr;\n table.bits[low] = root;\n table.val[low] = next - opts.table_index;*/\n table[low] = (root << 24) | (curr << 16) | (next - table_index) |0;\n }\n }\n\n /* fill in remaining table entry if code is incomplete (guaranteed to have\n at most one remaining entry, since if the code is incomplete, the\n maximum code length that was allowed to get this far is one bit) */\n if (huff !== 0) {\n //table.op[next + huff] = 64; /* invalid code marker */\n //table.bits[next + huff] = len - drop;\n //table.val[next + huff] = 0;\n table[next + huff] = ((len - drop) << 24) | (64 << 16) |0;\n }\n\n /* set return parameters */\n //opts.table_index += used;\n opts.bits = root;\n return 0;\n};\n","// String encode/decode helpers\n'use strict';\n\n\nvar utils = require('./common');\n\n\n// Quick check if we can use fast array to bin string conversion\n//\n// - apply(Array) can fail on Android 2.2\n// - apply(Uint8Array) can fail on iOS 5.1 Safari\n//\nvar STR_APPLY_OK = true;\nvar STR_APPLY_UIA_OK = true;\n\ntry { String.fromCharCode.apply(null, [ 0 ]); } catch (__) { STR_APPLY_OK = false; }\ntry { String.fromCharCode.apply(null, new Uint8Array(1)); } catch (__) { STR_APPLY_UIA_OK = false; }\n\n\n// Table with utf8 lengths (calculated by first byte of sequence)\n// Note, that 5 & 6-byte values and some 4-byte values can not be represented in JS,\n// because max possible codepoint is 0x10ffff\nvar _utf8len = new utils.Buf8(256);\nfor (var q = 0; q < 256; q++) {\n _utf8len[q] = (q >= 252 ? 6 : q >= 248 ? 5 : q >= 240 ? 4 : q >= 224 ? 3 : q >= 192 ? 2 : 1);\n}\n_utf8len[254] = _utf8len[254] = 1; // Invalid sequence start\n\n\n// convert string to array (typed, when possible)\nexports.string2buf = function (str) {\n var buf, c, c2, m_pos, i, str_len = str.length, buf_len = 0;\n\n // count binary size\n for (m_pos = 0; m_pos < str_len; m_pos++) {\n c = str.charCodeAt(m_pos);\n if ((c & 0xfc00) === 0xd800 && (m_pos + 1 < str_len)) {\n c2 = str.charCodeAt(m_pos + 1);\n if ((c2 & 0xfc00) === 0xdc00) {\n c = 0x10000 + ((c - 0xd800) << 10) + (c2 - 0xdc00);\n m_pos++;\n }\n }\n buf_len += c < 0x80 ? 1 : c < 0x800 ? 2 : c < 0x10000 ? 3 : 4;\n }\n\n // allocate buffer\n buf = new utils.Buf8(buf_len);\n\n // convert\n for (i = 0, m_pos = 0; i < buf_len; m_pos++) {\n c = str.charCodeAt(m_pos);\n if ((c & 0xfc00) === 0xd800 && (m_pos + 1 < str_len)) {\n c2 = str.charCodeAt(m_pos + 1);\n if ((c2 & 0xfc00) === 0xdc00) {\n c = 0x10000 + ((c - 0xd800) << 10) + (c2 - 0xdc00);\n m_pos++;\n }\n }\n if (c < 0x80) {\n /* one byte */\n buf[i++] = c;\n } else if (c < 0x800) {\n /* two bytes */\n buf[i++] = 0xC0 | (c >>> 6);\n buf[i++] = 0x80 | (c & 0x3f);\n } else if (c < 0x10000) {\n /* three bytes */\n buf[i++] = 0xE0 | (c >>> 12);\n buf[i++] = 0x80 | (c >>> 6 & 0x3f);\n buf[i++] = 0x80 | (c & 0x3f);\n } else {\n /* four bytes */\n buf[i++] = 0xf0 | (c >>> 18);\n buf[i++] = 0x80 | (c >>> 12 & 0x3f);\n buf[i++] = 0x80 | (c >>> 6 & 0x3f);\n buf[i++] = 0x80 | (c & 0x3f);\n }\n }\n\n return buf;\n};\n\n// Helper (used in 2 places)\nfunction buf2binstring(buf, len) {\n // On Chrome, the arguments in a function call that are allowed is `65534`.\n // If the length of the buffer is smaller than that, we can use this optimization,\n // otherwise we will take a slower path.\n if (len < 65534) {\n if ((buf.subarray && STR_APPLY_UIA_OK) || (!buf.subarray && STR_APPLY_OK)) {\n return String.fromCharCode.apply(null, utils.shrinkBuf(buf, len));\n }\n }\n\n var result = '';\n for (var i = 0; i < len; i++) {\n result += String.fromCharCode(buf[i]);\n }\n return result;\n}\n\n\n// Convert byte array to binary string\nexports.buf2binstring = function (buf) {\n return buf2binstring(buf, buf.length);\n};\n\n\n// Convert binary string (typed, when possible)\nexports.binstring2buf = function (str) {\n var buf = new utils.Buf8(str.length);\n for (var i = 0, len = buf.length; i < len; i++) {\n buf[i] = str.charCodeAt(i);\n }\n return buf;\n};\n\n\n// convert array to string\nexports.buf2string = function (buf, max) {\n var i, out, c, c_len;\n var len = max || buf.length;\n\n // Reserve max possible length (2 words per char)\n // NB: by unknown reasons, Array is significantly faster for\n // String.fromCharCode.apply than Uint16Array.\n var utf16buf = new Array(len * 2);\n\n for (out = 0, i = 0; i < len;) {\n c = buf[i++];\n // quick process ascii\n if (c < 0x80) { utf16buf[out++] = c; continue; }\n\n c_len = _utf8len[c];\n // skip 5 & 6 byte codes\n if (c_len > 4) { utf16buf[out++] = 0xfffd; i += c_len - 1; continue; }\n\n // apply mask on first byte\n c &= c_len === 2 ? 0x1f : c_len === 3 ? 0x0f : 0x07;\n // join the rest\n while (c_len > 1 && i < len) {\n c = (c << 6) | (buf[i++] & 0x3f);\n c_len--;\n }\n\n // terminated by end of string?\n if (c_len > 1) { utf16buf[out++] = 0xfffd; continue; }\n\n if (c < 0x10000) {\n utf16buf[out++] = c;\n } else {\n c -= 0x10000;\n utf16buf[out++] = 0xd800 | ((c >> 10) & 0x3ff);\n utf16buf[out++] = 0xdc00 | (c & 0x3ff);\n }\n }\n\n return buf2binstring(utf16buf, out);\n};\n\n\n// Calculate max possible position in utf8 buffer,\n// that will not break sequence. If that's not possible\n// - (very small limits) return max size as is.\n//\n// buf[] - utf8 bytes array\n// max - length limit (mandatory);\nexports.utf8border = function (buf, max) {\n var pos;\n\n max = max || buf.length;\n if (max > buf.length) { max = buf.length; }\n\n // go back from last position, until start of sequence found\n pos = max - 1;\n while (pos >= 0 && (buf[pos] & 0xC0) === 0x80) { pos--; }\n\n // Very small and broken sequence,\n // return max, because we should return something anyway.\n if (pos < 0) { return max; }\n\n // If we came to start of buffer - that means buffer is too small,\n // return max too.\n if (pos === 0) { return max; }\n\n return (pos + _utf8len[buf[pos]] > max) ? pos : max;\n};\n","'use strict';\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nmodule.exports = {\n\n /* Allowed flush values; see deflate() and inflate() below for details */\n Z_NO_FLUSH: 0,\n Z_PARTIAL_FLUSH: 1,\n Z_SYNC_FLUSH: 2,\n Z_FULL_FLUSH: 3,\n Z_FINISH: 4,\n Z_BLOCK: 5,\n Z_TREES: 6,\n\n /* Return codes for the compression/decompression functions. Negative values\n * are errors, positive values are used for special but normal events.\n */\n Z_OK: 0,\n Z_STREAM_END: 1,\n Z_NEED_DICT: 2,\n Z_ERRNO: -1,\n Z_STREAM_ERROR: -2,\n Z_DATA_ERROR: -3,\n //Z_MEM_ERROR: -4,\n Z_BUF_ERROR: -5,\n //Z_VERSION_ERROR: -6,\n\n /* compression levels */\n Z_NO_COMPRESSION: 0,\n Z_BEST_SPEED: 1,\n Z_BEST_COMPRESSION: 9,\n Z_DEFAULT_COMPRESSION: -1,\n\n\n Z_FILTERED: 1,\n Z_HUFFMAN_ONLY: 2,\n Z_RLE: 3,\n Z_FIXED: 4,\n Z_DEFAULT_STRATEGY: 0,\n\n /* Possible values of the data_type field (though see inflate()) */\n Z_BINARY: 0,\n Z_TEXT: 1,\n //Z_ASCII: 1, // = Z_TEXT (deprecated)\n Z_UNKNOWN: 2,\n\n /* The deflate compression method */\n Z_DEFLATED: 8\n //Z_NULL: null // Use -1 or null inline, depending on var type\n};\n","'use strict';\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nmodule.exports = {\n 2: 'need dictionary', /* Z_NEED_DICT 2 */\n 1: 'stream end', /* Z_STREAM_END 1 */\n 0: '', /* Z_OK 0 */\n '-1': 'file error', /* Z_ERRNO (-1) */\n '-2': 'stream error', /* Z_STREAM_ERROR (-2) */\n '-3': 'data error', /* Z_DATA_ERROR (-3) */\n '-4': 'insufficient memory', /* Z_MEM_ERROR (-4) */\n '-5': 'buffer error', /* Z_BUF_ERROR (-5) */\n '-6': 'incompatible version' /* Z_VERSION_ERROR (-6) */\n};\n","'use strict';\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nfunction ZStream() {\n /* next input byte */\n this.input = null; // JS specific, because we have no pointers\n this.next_in = 0;\n /* number of bytes available at input */\n this.avail_in = 0;\n /* total number of input bytes read so far */\n this.total_in = 0;\n /* next output byte should be put there */\n this.output = null; // JS specific, because we have no pointers\n this.next_out = 0;\n /* remaining free space at output */\n this.avail_out = 0;\n /* total number of bytes output so far */\n this.total_out = 0;\n /* last error message, NULL if no error */\n this.msg = ''/*Z_NULL*/;\n /* not visible by applications */\n this.state = null;\n /* best guess about the data type: binary or text */\n this.data_type = 2/*Z_UNKNOWN*/;\n /* adler32 value of the uncompressed data */\n this.adler = 0;\n}\n\nmodule.exports = ZStream;\n","'use strict';\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nfunction GZheader() {\n /* true if compressed data believed to be text */\n this.text = 0;\n /* modification time */\n this.time = 0;\n /* extra flags (not used when writing a gzip file) */\n this.xflags = 0;\n /* operating system */\n this.os = 0;\n /* pointer to extra field or Z_NULL if none */\n this.extra = null;\n /* extra field length (valid if extra != Z_NULL) */\n this.extra_len = 0; // Actually, we don't need it in JS,\n // but leave for few code modifications\n\n //\n // Setup limits is not necessary because in js we should not preallocate memory\n // for inflate use constant limit in 65536 bytes\n //\n\n /* space at extra (only when reading header) */\n // this.extra_max = 0;\n /* pointer to zero-terminated file name or Z_NULL */\n this.name = '';\n /* space at name (only when reading header) */\n // this.name_max = 0;\n /* pointer to zero-terminated comment or Z_NULL */\n this.comment = '';\n /* space at comment (only when reading header) */\n // this.comm_max = 0;\n /* true if there was or will be a header crc */\n this.hcrc = 0;\n /* true when done reading gzip header (not used when writing a gzip file) */\n this.done = false;\n}\n\nmodule.exports = GZheader;\n"],"sourceRoot":""}