node-zlib.dev.js
322 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
/** @license zlib.js 2012 - imaya [ https://github.com/imaya/zlib.js ] The MIT License */(function() {'use strict';function q(b){throw b;}var t=void 0,v=!0;var B="undefined"!==typeof Uint8Array&&"undefined"!==typeof Uint16Array&&"undefined"!==typeof Uint32Array&&"undefined"!==typeof DataView;function G(b,a){this.index="number"===typeof a?a:0;this.m=0;this.buffer=b instanceof(B?Uint8Array:Array)?b:new (B?Uint8Array:Array)(32768);2*this.buffer.length<=this.index&&q(Error("invalid index"));this.buffer.length<=this.index&&this.f()}G.prototype.f=function(){var b=this.buffer,a,c=b.length,d=new (B?Uint8Array:Array)(c<<1);if(B)d.set(b);else for(a=0;a<c;++a)d[a]=b[a];return this.buffer=d};
G.prototype.d=function(b,a,c){var d=this.buffer,e=this.index,f=this.m,g=d[e],k;c&&1<a&&(b=8<a?(I[b&255]<<24|I[b>>>8&255]<<16|I[b>>>16&255]<<8|I[b>>>24&255])>>32-a:I[b]>>8-a);if(8>a+f)g=g<<a|b,f+=a;else for(k=0;k<a;++k)g=g<<1|b>>a-k-1&1,8===++f&&(f=0,d[e++]=I[g],g=0,e===d.length&&(d=this.f()));d[e]=g;this.buffer=d;this.m=f;this.index=e};G.prototype.finish=function(){var b=this.buffer,a=this.index,c;0<this.m&&(b[a]<<=8-this.m,b[a]=I[b[a]],a++);B?c=b.subarray(0,a):(b.length=a,c=b);return c};
var aa=new (B?Uint8Array:Array)(256),L;for(L=0;256>L;++L){for(var R=L,ba=R,ca=7,R=R>>>1;R;R>>>=1)ba<<=1,ba|=R&1,--ca;aa[L]=(ba<<ca&255)>>>0}var I=aa;function ha(b,a,c){var d,e="number"===typeof a?a:a=0,f="number"===typeof c?c:b.length;d=-1;for(e=f&7;e--;++a)d=d>>>8^S[(d^b[a])&255];for(e=f>>3;e--;a+=8)d=d>>>8^S[(d^b[a])&255],d=d>>>8^S[(d^b[a+1])&255],d=d>>>8^S[(d^b[a+2])&255],d=d>>>8^S[(d^b[a+3])&255],d=d>>>8^S[(d^b[a+4])&255],d=d>>>8^S[(d^b[a+5])&255],d=d>>>8^S[(d^b[a+6])&255],d=d>>>8^S[(d^b[a+7])&255];return(d^4294967295)>>>0}
var ia=[0,1996959894,3993919788,2567524794,124634137,1886057615,3915621685,2657392035,249268274,2044508324,3772115230,2547177864,162941995,2125561021,3887607047,2428444049,498536548,1789927666,4089016648,2227061214,450548861,1843258603,4107580753,2211677639,325883990,1684777152,4251122042,2321926636,335633487,1661365465,4195302755,2366115317,997073096,1281953886,3579855332,2724688242,1006888145,1258607687,3524101629,2768942443,901097722,1119000684,3686517206,2898065728,853044451,1172266101,3705015759,
2882616665,651767980,1373503546,3369554304,3218104598,565507253,1454621731,3485111705,3099436303,671266974,1594198024,3322730930,2970347812,795835527,1483230225,3244367275,3060149565,1994146192,31158534,2563907772,4023717930,1907459465,112637215,2680153253,3904427059,2013776290,251722036,2517215374,3775830040,2137656763,141376813,2439277719,3865271297,1802195444,476864866,2238001368,4066508878,1812370925,453092731,2181625025,4111451223,1706088902,314042704,2344532202,4240017532,1658658271,366619977,
2362670323,4224994405,1303535960,984961486,2747007092,3569037538,1256170817,1037604311,2765210733,3554079995,1131014506,879679996,2909243462,3663771856,1141124467,855842277,2852801631,3708648649,1342533948,654459306,3188396048,3373015174,1466479909,544179635,3110523913,3462522015,1591671054,702138776,2966460450,3352799412,1504918807,783551873,3082640443,3233442989,3988292384,2596254646,62317068,1957810842,3939845945,2647816111,81470997,1943803523,3814918930,2489596804,225274430,2053790376,3826175755,
2466906013,167816743,2097651377,4027552580,2265490386,503444072,1762050814,4150417245,2154129355,426522225,1852507879,4275313526,2312317920,282753626,1742555852,4189708143,2394877945,397917763,1622183637,3604390888,2714866558,953729732,1340076626,3518719985,2797360999,1068828381,1219638859,3624741850,2936675148,906185462,1090812512,3747672003,2825379669,829329135,1181335161,3412177804,3160834842,628085408,1382605366,3423369109,3138078467,570562233,1426400815,3317316542,2998733608,733239954,1555261956,
3268935591,3050360625,752459403,1541320221,2607071920,3965973030,1969922972,40735498,2617837225,3943577151,1913087877,83908371,2512341634,3803740692,2075208622,213261112,2463272603,3855990285,2094854071,198958881,2262029012,4057260610,1759359992,534414190,2176718541,4139329115,1873836001,414664567,2282248934,4279200368,1711684554,285281116,2405801727,4167216745,1634467795,376229701,2685067896,3608007406,1308918612,956543938,2808555105,3495958263,1231636301,1047427035,2932959818,3654703836,1088359270,
936918E3,2847714899,3736837829,1202900863,817233897,3183342108,3401237130,1404277552,615818150,3134207493,3453421203,1423857449,601450431,3009837614,3294710456,1567103746,711928724,3020668471,3272380065,1510334235,755167117],S=B?new Uint32Array(ia):ia;function ja(){};function ka(b){this.buffer=new (B?Uint16Array:Array)(2*b);this.length=0}ka.prototype.getParent=function(b){return 2*((b-2)/4|0)};ka.prototype.push=function(b,a){var c,d,e=this.buffer,f;c=this.length;e[this.length++]=a;for(e[this.length++]=b;0<c;)if(d=this.getParent(c),e[c]>e[d])f=e[c],e[c]=e[d],e[d]=f,f=e[c+1],e[c+1]=e[d+1],e[d+1]=f,c=d;else break;return this.length};
ka.prototype.pop=function(){var b,a,c=this.buffer,d,e,f;a=c[0];b=c[1];this.length-=2;c[0]=c[this.length];c[1]=c[this.length+1];for(f=0;;){e=2*f+2;if(e>=this.length)break;e+2<this.length&&c[e+2]>c[e]&&(e+=2);if(c[e]>c[f])d=c[f],c[f]=c[e],c[e]=d,d=c[f+1],c[f+1]=c[e+1],c[e+1]=d;else break;f=e}return{index:b,value:a,length:this.length}};function T(b){var a=b.length,c=0,d=Number.POSITIVE_INFINITY,e,f,g,k,h,m,r,p,l,n;for(p=0;p<a;++p)b[p]>c&&(c=b[p]),b[p]<d&&(d=b[p]);e=1<<c;f=new (B?Uint32Array:Array)(e);g=1;k=0;for(h=2;g<=c;){for(p=0;p<a;++p)if(b[p]===g){m=0;r=k;for(l=0;l<g;++l)m=m<<1|r&1,r>>=1;n=g<<16|p;for(l=m;l<e;l+=h)f[l]=n;++k}++g;k<<=1;h<<=1}return[f,c,d]};function na(b,a){this.k=oa;this.F=0;this.input=B&&b instanceof Array?new Uint8Array(b):b;this.b=0;a&&(a.lazy&&(this.F=a.lazy),"number"===typeof a.compressionType&&(this.k=a.compressionType),a.outputBuffer&&(this.a=B&&a.outputBuffer instanceof Array?new Uint8Array(a.outputBuffer):a.outputBuffer),"number"===typeof a.outputIndex&&(this.b=a.outputIndex));this.a||(this.a=new (B?Uint8Array:Array)(32768))}var oa=2,pa={NONE:0,L:1,t:oa,X:3},qa=[],U;
for(U=0;288>U;U++)switch(v){case 143>=U:qa.push([U+48,8]);break;case 255>=U:qa.push([U-144+400,9]);break;case 279>=U:qa.push([U-256+0,7]);break;case 287>=U:qa.push([U-280+192,8]);break;default:q("invalid literal: "+U)}
na.prototype.h=function(){var b,a,c,d,e=this.input;switch(this.k){case 0:c=0;for(d=e.length;c<d;){a=B?e.subarray(c,c+65535):e.slice(c,c+65535);c+=a.length;var f=a,g=c===d,k=t,h=t,m=t,r=t,p=t,l=this.a,n=this.b;if(B){for(l=new Uint8Array(this.a.buffer);l.length<=n+f.length+5;)l=new Uint8Array(l.length<<1);l.set(this.a)}k=g?1:0;l[n++]=k|0;h=f.length;m=~h+65536&65535;l[n++]=h&255;l[n++]=h>>>8&255;l[n++]=m&255;l[n++]=m>>>8&255;if(B)l.set(f,n),n+=f.length,l=l.subarray(0,n);else{r=0;for(p=f.length;r<p;++r)l[n++]=
f[r];l.length=n}this.b=n;this.a=l}break;case 1:var s=new G(B?new Uint8Array(this.a.buffer):this.a,this.b);s.d(1,1,v);s.d(1,2,v);var u=ra(this,e),w,C,x;w=0;for(C=u.length;w<C;w++)if(x=u[w],G.prototype.d.apply(s,qa[x]),256<x)s.d(u[++w],u[++w],v),s.d(u[++w],5),s.d(u[++w],u[++w],v);else if(256===x)break;this.a=s.finish();this.b=this.a.length;break;case oa:var D=new G(B?new Uint8Array(this.a.buffer):this.a,this.b),M,z,N,X,Y,qb=[16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15],da,Fa,ea,Ga,la,ta=Array(19),
Ha,Z,ma,E,Ia;M=oa;D.d(1,1,v);D.d(M,2,v);z=ra(this,e);da=sa(this.U,15);Fa=ua(da);ea=sa(this.T,7);Ga=ua(ea);for(N=286;257<N&&0===da[N-1];N--);for(X=30;1<X&&0===ea[X-1];X--);var Ja=N,Ka=X,K=new (B?Uint32Array:Array)(Ja+Ka),y,O,A,fa,J=new (B?Uint32Array:Array)(316),H,F,P=new (B?Uint8Array:Array)(19);for(y=O=0;y<Ja;y++)K[O++]=da[y];for(y=0;y<Ka;y++)K[O++]=ea[y];if(!B){y=0;for(fa=P.length;y<fa;++y)P[y]=0}y=H=0;for(fa=K.length;y<fa;y+=O){for(O=1;y+O<fa&&K[y+O]===K[y];++O);A=O;if(0===K[y])if(3>A)for(;0<A--;)J[H++]=
0,P[0]++;else for(;0<A;)F=138>A?A:138,F>A-3&&F<A&&(F=A-3),10>=F?(J[H++]=17,J[H++]=F-3,P[17]++):(J[H++]=18,J[H++]=F-11,P[18]++),A-=F;else if(J[H++]=K[y],P[K[y]]++,A--,3>A)for(;0<A--;)J[H++]=K[y],P[K[y]]++;else for(;0<A;)F=6>A?A:6,F>A-3&&F<A&&(F=A-3),J[H++]=16,J[H++]=F-3,P[16]++,A-=F}b=B?J.subarray(0,H):J.slice(0,H);la=sa(P,7);for(E=0;19>E;E++)ta[E]=la[qb[E]];for(Y=19;4<Y&&0===ta[Y-1];Y--);Ha=ua(la);D.d(N-257,5,v);D.d(X-1,5,v);D.d(Y-4,4,v);for(E=0;E<Y;E++)D.d(ta[E],3,v);E=0;for(Ia=b.length;E<Ia;E++)if(Z=
b[E],D.d(Ha[Z],la[Z],v),16<=Z){E++;switch(Z){case 16:ma=2;break;case 17:ma=3;break;case 18:ma=7;break;default:q("invalid code: "+Z)}D.d(b[E],ma,v)}var La=[Fa,da],Ma=[Ga,ea],Q,Na,ga,wa,Oa,Pa,Qa,Ra;Oa=La[0];Pa=La[1];Qa=Ma[0];Ra=Ma[1];Q=0;for(Na=z.length;Q<Na;++Q)if(ga=z[Q],D.d(Oa[ga],Pa[ga],v),256<ga)D.d(z[++Q],z[++Q],v),wa=z[++Q],D.d(Qa[wa],Ra[wa],v),D.d(z[++Q],z[++Q],v);else if(256===ga)break;this.a=D.finish();this.b=this.a.length;break;default:q("invalid compression type")}return this.a};
function va(b,a){this.length=b;this.N=a}
var xa=function(){function b(a){switch(v){case 3===a:return[257,a-3,0];case 4===a:return[258,a-4,0];case 5===a:return[259,a-5,0];case 6===a:return[260,a-6,0];case 7===a:return[261,a-7,0];case 8===a:return[262,a-8,0];case 9===a:return[263,a-9,0];case 10===a:return[264,a-10,0];case 12>=a:return[265,a-11,1];case 14>=a:return[266,a-13,1];case 16>=a:return[267,a-15,1];case 18>=a:return[268,a-17,1];case 22>=a:return[269,a-19,2];case 26>=a:return[270,a-23,2];case 30>=a:return[271,a-27,2];case 34>=a:return[272,
a-31,2];case 42>=a:return[273,a-35,3];case 50>=a:return[274,a-43,3];case 58>=a:return[275,a-51,3];case 66>=a:return[276,a-59,3];case 82>=a:return[277,a-67,4];case 98>=a:return[278,a-83,4];case 114>=a:return[279,a-99,4];case 130>=a:return[280,a-115,4];case 162>=a:return[281,a-131,5];case 194>=a:return[282,a-163,5];case 226>=a:return[283,a-195,5];case 257>=a:return[284,a-227,5];case 258===a:return[285,a-258,0];default:q("invalid length: "+a)}}var a=[],c,d;for(c=3;258>=c;c++)d=b(c),a[c]=d[2]<<24|d[1]<<
16|d[0];return a}(),ya=B?new Uint32Array(xa):xa;
function ra(b,a){function c(a,c){var b=a.N,d=[],f=0,e;e=ya[a.length];d[f++]=e&65535;d[f++]=e>>16&255;d[f++]=e>>24;var g;switch(v){case 1===b:g=[0,b-1,0];break;case 2===b:g=[1,b-2,0];break;case 3===b:g=[2,b-3,0];break;case 4===b:g=[3,b-4,0];break;case 6>=b:g=[4,b-5,1];break;case 8>=b:g=[5,b-7,1];break;case 12>=b:g=[6,b-9,2];break;case 16>=b:g=[7,b-13,2];break;case 24>=b:g=[8,b-17,3];break;case 32>=b:g=[9,b-25,3];break;case 48>=b:g=[10,b-33,4];break;case 64>=b:g=[11,b-49,4];break;case 96>=b:g=[12,b-
65,5];break;case 128>=b:g=[13,b-97,5];break;case 192>=b:g=[14,b-129,6];break;case 256>=b:g=[15,b-193,6];break;case 384>=b:g=[16,b-257,7];break;case 512>=b:g=[17,b-385,7];break;case 768>=b:g=[18,b-513,8];break;case 1024>=b:g=[19,b-769,8];break;case 1536>=b:g=[20,b-1025,9];break;case 2048>=b:g=[21,b-1537,9];break;case 3072>=b:g=[22,b-2049,10];break;case 4096>=b:g=[23,b-3073,10];break;case 6144>=b:g=[24,b-4097,11];break;case 8192>=b:g=[25,b-6145,11];break;case 12288>=b:g=[26,b-8193,12];break;case 16384>=
b:g=[27,b-12289,12];break;case 24576>=b:g=[28,b-16385,13];break;case 32768>=b:g=[29,b-24577,13];break;default:q("invalid distance")}e=g;d[f++]=e[0];d[f++]=e[1];d[f++]=e[2];var h,k;h=0;for(k=d.length;h<k;++h)l[n++]=d[h];u[d[0]]++;w[d[3]]++;s=a.length+c-1;p=null}var d,e,f,g,k,h={},m,r,p,l=B?new Uint16Array(2*a.length):[],n=0,s=0,u=new (B?Uint32Array:Array)(286),w=new (B?Uint32Array:Array)(30),C=b.F,x;if(!B){for(f=0;285>=f;)u[f++]=0;for(f=0;29>=f;)w[f++]=0}u[256]=1;d=0;for(e=a.length;d<e;++d){f=k=0;
for(g=3;f<g&&d+f!==e;++f)k=k<<8|a[d+f];h[k]===t&&(h[k]=[]);m=h[k];if(!(0<s--)){for(;0<m.length&&32768<d-m[0];)m.shift();if(d+3>=e){p&&c(p,-1);f=0;for(g=e-d;f<g;++f)x=a[d+f],l[n++]=x,++u[x];break}0<m.length?(r=za(a,d,m),p?p.length<r.length?(x=a[d-1],l[n++]=x,++u[x],c(r,0)):c(p,-1):r.length<C?p=r:c(r,0)):p?c(p,-1):(x=a[d],l[n++]=x,++u[x])}m.push(d)}l[n++]=256;u[256]++;b.U=u;b.T=w;return B?l.subarray(0,n):l}
function za(b,a,c){var d,e,f=0,g,k,h,m,r=b.length;k=0;m=c.length;a:for(;k<m;k++){d=c[m-k-1];g=3;if(3<f){for(h=f;3<h;h--)if(b[d+h-1]!==b[a+h-1])continue a;g=f}for(;258>g&&a+g<r&&b[d+g]===b[a+g];)++g;g>f&&(e=d,f=g);if(258===g)break}return new va(f,a-e)}
function sa(b,a){var c=b.length,d=new ka(572),e=new (B?Uint8Array:Array)(c),f,g,k,h,m;if(!B)for(h=0;h<c;h++)e[h]=0;for(h=0;h<c;++h)0<b[h]&&d.push(h,b[h]);f=Array(d.length/2);g=new (B?Uint32Array:Array)(d.length/2);if(1===f.length)return e[d.pop().index]=1,e;h=0;for(m=d.length/2;h<m;++h)f[h]=d.pop(),g[h]=f[h].value;k=Aa(g,g.length,a);h=0;for(m=f.length;h<m;++h)e[f[h].index]=k[h];return e}
function Aa(b,a,c){function d(b){var c=h[b][m[b]];c===a?(d(b+1),d(b+1)):--g[c];++m[b]}var e=new (B?Uint16Array:Array)(c),f=new (B?Uint8Array:Array)(c),g=new (B?Uint8Array:Array)(a),k=Array(c),h=Array(c),m=Array(c),r=(1<<c)-a,p=1<<c-1,l,n,s,u,w;e[c-1]=a;for(n=0;n<c;++n)r<p?f[n]=0:(f[n]=1,r-=p),r<<=1,e[c-2-n]=(e[c-1-n]/2|0)+a;e[0]=f[0];k[0]=Array(e[0]);h[0]=Array(e[0]);for(n=1;n<c;++n)e[n]>2*e[n-1]+f[n]&&(e[n]=2*e[n-1]+f[n]),k[n]=Array(e[n]),h[n]=Array(e[n]);for(l=0;l<a;++l)g[l]=c;for(s=0;s<e[c-1];++s)k[c-
1][s]=b[s],h[c-1][s]=s;for(l=0;l<c;++l)m[l]=0;1===f[c-1]&&(--g[0],++m[c-1]);for(n=c-2;0<=n;--n){u=l=0;w=m[n+1];for(s=0;s<e[n];s++)u=k[n+1][w]+k[n+1][w+1],u>b[l]?(k[n][s]=u,h[n][s]=a,w+=2):(k[n][s]=b[l],h[n][s]=l,++l);m[n]=0;1===f[n]&&d(n)}return g}
function ua(b){var a=new (B?Uint16Array:Array)(b.length),c=[],d=[],e=0,f,g,k,h;f=0;for(g=b.length;f<g;f++)c[b[f]]=(c[b[f]]|0)+1;f=1;for(g=16;f<=g;f++)d[f]=e,e+=c[f]|0,e<<=1;f=0;for(g=b.length;f<g;f++){e=d[b[f]];d[b[f]]+=1;k=a[f]=0;for(h=b[f];k<h;k++)a[f]=a[f]<<1|e&1,e>>>=1}return a};function Ba(b,a){this.input=b;this.b=this.c=0;this.g={};a&&(a.flags&&(this.g=a.flags),"string"===typeof a.filename&&(this.filename=a.filename),"string"===typeof a.comment&&(this.w=a.comment),a.deflateOptions&&(this.l=a.deflateOptions));this.l||(this.l={})}
Ba.prototype.h=function(){var b,a,c,d,e,f,g,k,h=new (B?Uint8Array:Array)(32768),m=0,r=this.input,p=this.c,l=this.filename,n=this.w;h[m++]=31;h[m++]=139;h[m++]=8;b=0;this.g.fname&&(b|=Ca);this.g.fcomment&&(b|=Da);this.g.fhcrc&&(b|=Ea);h[m++]=b;a=(Date.now?Date.now():+new Date)/1E3|0;h[m++]=a&255;h[m++]=a>>>8&255;h[m++]=a>>>16&255;h[m++]=a>>>24&255;h[m++]=0;h[m++]=Sa;if(this.g.fname!==t){g=0;for(k=l.length;g<k;++g)f=l.charCodeAt(g),255<f&&(h[m++]=f>>>8&255),h[m++]=f&255;h[m++]=0}if(this.g.comment){g=
0;for(k=n.length;g<k;++g)f=n.charCodeAt(g),255<f&&(h[m++]=f>>>8&255),h[m++]=f&255;h[m++]=0}this.g.fhcrc&&(c=ha(h,0,m)&65535,h[m++]=c&255,h[m++]=c>>>8&255);this.l.outputBuffer=h;this.l.outputIndex=m;e=new na(r,this.l);h=e.h();m=e.b;B&&(m+8>h.buffer.byteLength?(this.a=new Uint8Array(m+8),this.a.set(new Uint8Array(h.buffer)),h=this.a):h=new Uint8Array(h.buffer));d=ha(r,t,t);h[m++]=d&255;h[m++]=d>>>8&255;h[m++]=d>>>16&255;h[m++]=d>>>24&255;k=r.length;h[m++]=k&255;h[m++]=k>>>8&255;h[m++]=k>>>16&255;h[m++]=
k>>>24&255;this.c=p;B&&m<h.length&&(this.a=h=h.subarray(0,m));return h};var Sa=255,Ea=2,Ca=8,Da=16;function V(b,a){this.o=[];this.p=32768;this.e=this.j=this.c=this.s=0;this.input=B?new Uint8Array(b):b;this.u=!1;this.q=Ta;this.K=!1;if(a||!(a={}))a.index&&(this.c=a.index),a.bufferSize&&(this.p=a.bufferSize),a.bufferType&&(this.q=a.bufferType),a.resize&&(this.K=a.resize);switch(this.q){case Ua:this.b=32768;this.a=new (B?Uint8Array:Array)(32768+this.p+258);break;case Ta:this.b=0;this.a=new (B?Uint8Array:Array)(this.p);this.f=this.S;this.z=this.O;this.r=this.Q;break;default:q(Error("invalid inflate mode"))}}
var Ua=0,Ta=1;
V.prototype.i=function(){for(;!this.u;){var b=W(this,3);b&1&&(this.u=v);b>>>=1;switch(b){case 0:var a=this.input,c=this.c,d=this.a,e=this.b,f=a.length,g=t,k=t,h=d.length,m=t;this.e=this.j=0;c+1>=f&&q(Error("invalid uncompressed block header: LEN"));g=a[c++]|a[c++]<<8;c+1>=f&&q(Error("invalid uncompressed block header: NLEN"));k=a[c++]|a[c++]<<8;g===~k&&q(Error("invalid uncompressed block header: length verify"));c+g>a.length&&q(Error("input buffer is broken"));switch(this.q){case Ua:for(;e+g>d.length;){m=
h-e;g-=m;if(B)d.set(a.subarray(c,c+m),e),e+=m,c+=m;else for(;m--;)d[e++]=a[c++];this.b=e;d=this.f();e=this.b}break;case Ta:for(;e+g>d.length;)d=this.f({B:2});break;default:q(Error("invalid inflate mode"))}if(B)d.set(a.subarray(c,c+g),e),e+=g,c+=g;else for(;g--;)d[e++]=a[c++];this.c=c;this.b=e;this.a=d;break;case 1:this.r(Va,Wa);break;case 2:for(var r=W(this,5)+257,p=W(this,5)+1,l=W(this,4)+4,n=new (B?Uint8Array:Array)(Xa.length),s=t,u=t,w=t,C=t,x=t,D=t,M=t,z=t,N=t,z=0;z<l;++z)n[Xa[z]]=W(this,3);if(!B){z=
l;for(l=n.length;z<l;++z)n[Xa[z]]=0}s=T(n);C=new (B?Uint8Array:Array)(r+p);z=0;for(N=r+p;z<N;)switch(x=Ya(this,s),x){case 16:for(M=3+W(this,2);M--;)C[z++]=D;break;case 17:for(M=3+W(this,3);M--;)C[z++]=0;D=0;break;case 18:for(M=11+W(this,7);M--;)C[z++]=0;D=0;break;default:D=C[z++]=x}u=B?T(C.subarray(0,r)):T(C.slice(0,r));w=B?T(C.subarray(r)):T(C.slice(r));this.r(u,w);break;default:q(Error("unknown BTYPE: "+b))}}return this.z()};
var Za=[16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15],Xa=B?new Uint16Array(Za):Za,$a=[3,4,5,6,7,8,9,10,11,13,15,17,19,23,27,31,35,43,51,59,67,83,99,115,131,163,195,227,258,258,258],ab=B?new Uint16Array($a):$a,bb=[0,0,0,0,0,0,0,0,1,1,1,1,2,2,2,2,3,3,3,3,4,4,4,4,5,5,5,5,0,0,0],cb=B?new Uint8Array(bb):bb,db=[1,2,3,4,5,7,9,13,17,25,33,49,65,97,129,193,257,385,513,769,1025,1537,2049,3073,4097,6145,8193,12289,16385,24577],eb=B?new Uint16Array(db):db,fb=[0,0,0,0,1,1,2,2,3,3,4,4,5,5,6,6,7,7,8,8,9,9,10,
10,11,11,12,12,13,13],gb=B?new Uint8Array(fb):fb,hb=new (B?Uint8Array:Array)(288),$,ib;$=0;for(ib=hb.length;$<ib;++$)hb[$]=143>=$?8:255>=$?9:279>=$?7:8;var Va=T(hb),jb=new (B?Uint8Array:Array)(30),kb,lb;kb=0;for(lb=jb.length;kb<lb;++kb)jb[kb]=5;var Wa=T(jb);function W(b,a){for(var c=b.j,d=b.e,e=b.input,f=b.c,g=e.length,k;d<a;)f>=g&&q(Error("input buffer is broken")),c|=e[f++]<<d,d+=8;k=c&(1<<a)-1;b.j=c>>>a;b.e=d-a;b.c=f;return k}
function Ya(b,a){for(var c=b.j,d=b.e,e=b.input,f=b.c,g=e.length,k=a[0],h=a[1],m,r;d<h&&!(f>=g);)c|=e[f++]<<d,d+=8;m=k[c&(1<<h)-1];r=m>>>16;r>d&&q(Error("invalid code length: "+r));b.j=c>>r;b.e=d-r;b.c=f;return m&65535}
V.prototype.r=function(b,a){var c=this.a,d=this.b;this.A=b;for(var e=c.length-258,f,g,k,h;256!==(f=Ya(this,b));)if(256>f)d>=e&&(this.b=d,c=this.f(),d=this.b),c[d++]=f;else{g=f-257;h=ab[g];0<cb[g]&&(h+=W(this,cb[g]));f=Ya(this,a);k=eb[f];0<gb[f]&&(k+=W(this,gb[f]));d>=e&&(this.b=d,c=this.f(),d=this.b);for(;h--;)c[d]=c[d++-k]}for(;8<=this.e;)this.e-=8,this.c--;this.b=d};
V.prototype.Q=function(b,a){var c=this.a,d=this.b;this.A=b;for(var e=c.length,f,g,k,h;256!==(f=Ya(this,b));)if(256>f)d>=e&&(c=this.f(),e=c.length),c[d++]=f;else{g=f-257;h=ab[g];0<cb[g]&&(h+=W(this,cb[g]));f=Ya(this,a);k=eb[f];0<gb[f]&&(k+=W(this,gb[f]));d+h>e&&(c=this.f(),e=c.length);for(;h--;)c[d]=c[d++-k]}for(;8<=this.e;)this.e-=8,this.c--;this.b=d};
V.prototype.f=function(){var b=new (B?Uint8Array:Array)(this.b-32768),a=this.b-32768,c,d,e=this.a;if(B)b.set(e.subarray(32768,b.length));else{c=0;for(d=b.length;c<d;++c)b[c]=e[c+32768]}this.o.push(b);this.s+=b.length;if(B)e.set(e.subarray(a,a+32768));else for(c=0;32768>c;++c)e[c]=e[a+c];this.b=32768;return e};
V.prototype.S=function(b){var a,c=this.input.length/this.c+1|0,d,e,f,g=this.input,k=this.a;b&&("number"===typeof b.B&&(c=b.B),"number"===typeof b.M&&(c+=b.M));2>c?(d=(g.length-this.c)/this.A[2],f=258*(d/2)|0,e=f<k.length?k.length+f:k.length<<1):e=k.length*c;B?(a=new Uint8Array(e),a.set(k)):a=k;return this.a=a};
V.prototype.z=function(){var b=0,a=this.a,c=this.o,d,e=new (B?Uint8Array:Array)(this.s+(this.b-32768)),f,g,k,h;if(0===c.length)return B?this.a.subarray(32768,this.b):this.a.slice(32768,this.b);f=0;for(g=c.length;f<g;++f){d=c[f];k=0;for(h=d.length;k<h;++k)e[b++]=d[k]}f=32768;for(g=this.b;f<g;++f)e[b++]=a[f];this.o=[];return this.buffer=e};
V.prototype.O=function(){var b,a=this.b;B?this.K?(b=new Uint8Array(a),b.set(this.a.subarray(0,a))):b=this.a.subarray(0,a):(this.a.length>a&&(this.a.length=a),b=this.a);return this.buffer=b};function mb(b){this.input=b;this.c=0;this.G=[];this.R=!1}
mb.prototype.i=function(){for(var b=this.input.length;this.c<b;){var a=new ja,c=t,d=t,e=t,f=t,g=t,k=t,h=t,m=t,r=t,p=this.input,l=this.c;a.C=p[l++];a.D=p[l++];(31!==a.C||139!==a.D)&&q(Error("invalid file signature:"+a.C+","+a.D));a.v=p[l++];switch(a.v){case 8:break;default:q(Error("unknown compression method: "+a.v))}a.n=p[l++];m=p[l++]|p[l++]<<8|p[l++]<<16|p[l++]<<24;a.$=new Date(1E3*m);a.ba=p[l++];a.aa=p[l++];0<(a.n&4)&&(a.W=p[l++]|p[l++]<<8,l+=a.W);if(0<(a.n&Ca)){h=[];for(k=0;0<(g=p[l++]);)h[k++]=
String.fromCharCode(g);a.name=h.join("")}if(0<(a.n&Da)){h=[];for(k=0;0<(g=p[l++]);)h[k++]=String.fromCharCode(g);a.w=h.join("")}0<(a.n&Ea)&&(a.P=ha(p,0,l)&65535,a.P!==(p[l++]|p[l++]<<8)&&q(Error("invalid header crc16")));c=p[p.length-4]|p[p.length-3]<<8|p[p.length-2]<<16|p[p.length-1]<<24;p.length-l-4-4<512*c&&(f=c);d=new V(p,{index:l,bufferSize:f});a.data=e=d.i();l=d.c;a.Y=r=(p[l++]|p[l++]<<8|p[l++]<<16|p[l++]<<24)>>>0;ha(e,t,t)!==r&&q(Error("invalid CRC-32 checksum: 0x"+ha(e,t,t).toString(16)+" / 0x"+
r.toString(16)));a.Z=c=(p[l++]|p[l++]<<8|p[l++]<<16|p[l++]<<24)>>>0;(e.length&4294967295)!==c&&q(Error("invalid input size: "+(e.length&4294967295)+" / "+c));this.G.push(a);this.c=l}this.R=v;var n=this.G,s,u,w=0,C=0,x;s=0;for(u=n.length;s<u;++s)C+=n[s].data.length;if(B){x=new Uint8Array(C);for(s=0;s<u;++s)x.set(n[s].data,w),w+=n[s].data.length}else{x=[];for(s=0;s<u;++s)x[s]=n[s].data;x=Array.prototype.concat.apply([],x)}return x};function nb(b){if("string"===typeof b){var a=b.split(""),c,d;c=0;for(d=a.length;c<d;c++)a[c]=(a[c].charCodeAt(0)&255)>>>0;b=a}for(var e=1,f=0,g=b.length,k,h=0;0<g;){k=1024<g?1024:g;g-=k;do e+=b[h++],f+=e;while(--k);e%=65521;f%=65521}return(f<<16|e)>>>0};function ob(b,a){var c,d;this.input=b;this.c=0;if(a||!(a={}))a.index&&(this.c=a.index),a.verify&&(this.V=a.verify);c=b[this.c++];d=b[this.c++];switch(c&15){case pb:this.method=pb;break;default:q(Error("unsupported compression method"))}0!==((c<<8)+d)%31&&q(Error("invalid fcheck flag:"+((c<<8)+d)%31));d&32&&q(Error("fdict flag is not supported"));this.J=new V(b,{index:this.c,bufferSize:a.bufferSize,bufferType:a.bufferType,resize:a.resize})}
ob.prototype.i=function(){var b=this.input,a,c;a=this.J.i();this.c=this.J.c;this.V&&(c=(b[this.c++]<<24|b[this.c++]<<16|b[this.c++]<<8|b[this.c++])>>>0,c!==nb(a)&&q(Error("invalid adler-32 checksum")));return a};var pb=8;function rb(b,a){this.input=b;this.a=new (B?Uint8Array:Array)(32768);this.k=sb.t;var c={},d;if((a||!(a={}))&&"number"===typeof a.compressionType)this.k=a.compressionType;for(d in a)c[d]=a[d];c.outputBuffer=this.a;this.I=new na(this.input,c)}var sb=pa;
rb.prototype.h=function(){var b,a,c,d,e,f,g,k=0;g=this.a;b=pb;switch(b){case pb:a=Math.LOG2E*Math.log(32768)-8;break;default:q(Error("invalid compression method"))}c=a<<4|b;g[k++]=c;switch(b){case pb:switch(this.k){case sb.NONE:e=0;break;case sb.L:e=1;break;case sb.t:e=2;break;default:q(Error("unsupported compression type"))}break;default:q(Error("invalid compression method"))}d=e<<6|0;g[k++]=d|31-(256*c+d)%31;f=nb(this.input);this.I.b=k;g=this.I.h();k=g.length;B&&(g=new Uint8Array(g.buffer),g.length<=
k+4&&(this.a=new Uint8Array(g.length+4),this.a.set(g),g=this.a),g=g.subarray(0,k+4));g[k++]=f>>24&255;g[k++]=f>>16&255;g[k++]=f>>8&255;g[k++]=f&255;return g};exports.deflate=tb;exports.deflateSync=ub;exports.inflate=vb;exports.inflateSync=wb;exports.gzip=xb;exports.gzipSync=yb;exports.gunzip=zb;exports.gunzipSync=Ab;function tb(b,a,c){process.nextTick(function(){var d,e;try{e=ub(b,c)}catch(f){d=f}a(d,e)})}function ub(b,a){var c;c=(new rb(b)).h();a||(a={});return a.H?c:Bb(c)}function vb(b,a,c){process.nextTick(function(){var d,e;try{e=wb(b,c)}catch(f){d=f}a(d,e)})}
function wb(b,a){var c;b.subarray=b.slice;c=(new ob(b)).i();a||(a={});return a.noBuffer?c:Bb(c)}function xb(b,a,c){process.nextTick(function(){var d,e;try{e=yb(b,c)}catch(f){d=f}a(d,e)})}function yb(b,a){var c;b.subarray=b.slice;c=(new Ba(b)).h();a||(a={});return a.H?c:Bb(c)}function zb(b,a,c){process.nextTick(function(){var d,e;try{e=Ab(b,c)}catch(f){d=f}a(d,e)})}function Ab(b,a){var c;b.subarray=b.slice;c=(new mb(b)).i();a||(a={});return a.H?c:Bb(c)}
function Bb(b){var a=new Buffer(b.length),c,d;c=0;for(d=b.length;c<d;++c)a[c]=b[c];return a};}).call(this);
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"bin/node-zlib.js","lineCount":53,"mappings":"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","sources":["closure-primitives/base.js","define/typedarray/hybrid.js","src/bitstream.js","src/crc32.js","src/gunzip_member.js","src/heap.js","src/huffman.js","src/rawdeflate.js","src/gzip.js","src/rawinflate.js","src/gunzip.js","src/adler32.js","src/util.js","src/inflate.js","src/zlib.js","src/deflate.js","node/exports.js"],"names":["USE_TYPEDARRAY","Uint8Array","Uint16Array","Uint32Array","DataView","Zlib.BitStream","buffer","bufferPosition","index","bitindex","Array","Zlib.BitStream.DefaultBlockSize","length","JSCompiler_alias_THROW","Error","expandBuffer","prototype","Zlib.BitStream.prototype.expandBuffer","oldbuf","i","il","set","writeBits","Zlib.BitStream.prototype.writeBits","number","n","reverse","current","Zlib.BitStream.ReverseTable","finish","Zlib.BitStream.prototype.finish","output","subarray","table","r","s","Zlib.CRC32.update","data","pos","crc","Zlib.CRC32.Table","Zlib.CRC32.Table_","Zlib.GunzipMember","Zlib.Heap","getParent","Zlib.Heap.prototype.getParent","push","Zlib.Heap.prototype.push","value","parent","heap","swap","pop","Zlib.Heap.prototype.pop","Zlib.Huffman.buildHuffmanTable","lengths","listSize","maxCodeLength","minCodeLength","Number","POSITIVE_INFINITY","size","bitLength","code","skip","reversed","rtemp","j","Zlib.RawDeflate","input","opt_params","compressionType","Zlib.RawDeflate.CompressionType.DYNAMIC","lazy","op","DYNAMIC","Zlib.RawDeflate.CompressionType","NONE","FIXED","RESERVED","JSCompiler_alias_TRUE","compress","Zlib.RawDeflate.prototype.compress","blockArray","position","slice","bfinal","JSCompiler_alias_VOID","len","nlen","makeNocompressBlock","isFinalBlock","stream","makeFixedHuffmanBlock","lz77","literal","dataArray","apply","makeDynamicHuffmanBlock","btype","hlit","hdist","hclen","hclenOrder","litLenLengths","litLenCodes","distLengths","distCodes","treeLengths","transLengths","treeCodes","bitlen","getLengths_","freqsLitLen","getCodesFromLengths_","freqsDist","src","runLength","l","result","nResult","rpt","freqs","codes","litLen","dist","Zlib.RawDeflate.Lz77Match","backwardDistance","c","Zlib.RawDeflate.Lz77Match.LengthCodeTable","Zlib.RawDeflate.prototype.lz77","writeMatch","match","offset","codeArray","lz77buf","skipLength","prevMatch","matchKey","matchList","longestMatch","tmp","Zlib.RawDeflate.Lz77MinLength","Zlib.RawDeflate.WindowSize","shift","searchLongestMatch_","Zlib.RawDeflate.prototype.searchLongestMatch_","currentMatch","matchMax","matchLength","dl","Zlib.RawDeflate.Lz77MaxLength","Zlib.RawDeflate.prototype.getLengths_","limit","nSymbols","nodes","values","codeLength","reversePackageMerge_","Zlib.RawDeflate.prototype.reversePackageMerge_","symbols","takePackage","x","type","currentPosition","minimumCost","flag","excess","half","t","weight","next","Zlib.RawDeflate.prototype.getCodesFromLengths_","count","startCode","m","Zlib.RawDeflate.MaxCodeLength","Zlib.Gzip","ip","flags","filename","comment","deflateOptions","Zlib.Gzip.prototype.compress","flg","mtime","crc16","crc32","rawdeflate","Zlib.Gzip.DefaultBufferSize","Zlib.Gzip.FlagsMask.FNAME","Zlib.Gzip.FlagsMask.FCOMMENT","Zlib.Gzip.FlagsMask.FHCRC","Date","now","Zlib.Gzip.OperatingSystem.UNKNOWN","charCodeAt","byteLength","UNKNOWN","FHCRC","FNAME","FCOMMENT","Zlib.RawInflate","blocks","bufferSize","ZLIB_RAW_INFLATE_BUFFER_SIZE","bitsbuflen","bitsbuf","totalpos","bufferType","Zlib.RawInflate.BufferType.ADAPTIVE","resize","Zlib.RawInflate.BufferType.BLOCK","Zlib.RawInflate.MaxBackwardLength","Zlib.RawInflate.MaxCopyLength","expandBufferAdaptive","concatBuffer","concatBufferDynamic","decodeHuffman","decodeHuffmanAdaptive","BLOCK","ADAPTIVE","decompress","Zlib.RawInflate.prototype.decompress","hdr","readBits","parseBlock","inputLength","olength","preCopy","Zlib.RawInflate.FixedLiteralLengthTable","Zlib.RawInflate.FixedDistanceTable","codeLengths","Zlib.RawInflate.Order.length","codeLengthsTable","litlenTable","distTable","lengthTable","prev","repeat","Zlib.RawInflate.Order","readCodeByTable","Zlib.RawInflate.LengthCodeTable","Zlib.RawInflate.LengthExtraTable","Zlib.RawInflate.DistCodeTable","Zlib.RawInflate.DistExtraTable","Zlib.RawInflate.prototype.readBits","octet","Zlib.RawInflate.prototype.readCodeByTable","codeTable","codeWithLength","Zlib.RawInflate.prototype.decodeHuffman","litlen","currentLitlenTable","ti","codeDist","Zlib.RawInflate.prototype.decodeHuffmanAdaptive","Zlib.RawInflate.prototype.expandBuffer","backward","Zlib.RawInflate.prototype.expandBufferAdaptive","opt_param","ratio","maxHuffCode","newSize","maxInflateSize","fixRatio","addRatio","Zlib.RawInflate.prototype.concatBuffer","block","jl","Zlib.RawInflate.prototype.concatBufferDynamic","Zlib.Gunzip","member","decompressed","Zlib.Gunzip.prototype.decompress","isize","rawinflate","inflated","inflen","ci","str","decodeMember","id1","id2","cm","xfl","os","FEXTRA","xlen","String","fromCharCode","name","join","toString","concatMember","p","concat","Zlib.Adler32","array","split","s1","s2","tlen","Zlib.Adler32.OptimizationParameter","Zlib.Inflate","cmf","verify","Zlib.CompressionMethod.DEFLATE","method","Zlib.Inflate.prototype.decompress","adler32","DEFLATE","Zlib.Deflate","Zlib.Deflate.DefaultBufferSize","Zlib.Deflate.CompressionType.DYNAMIC","rawDeflateOption","prop","rawDeflate","Zlib.Deflate.CompressionType","Zlib.Deflate.prototype.compress","cinfo","flevel","adler","Math","LOG2E","log","Zlib.Deflate.CompressionType.NONE","Zlib.Deflate.CompressionType.FIXED","exports","deflate","deflateSync","inflate","inflateSync","gzip","gzipSync","gunzip","gunzipSync","callback","process","nextTick","error","deflated","e","noBuffer","toBuffer","Buffer"],"sourcesContent":["// Copyright 2006 The Closure Library Authors. All Rights Reserved.\n//\n// Licensed under the Apache License, Version 2.0 (the \"License\");\n// you may not use this file except in compliance with the License.\n// You may obtain a copy of the License at\n//\n//      http://www.apache.org/licenses/LICENSE-2.0\n//\n// Unless required by applicable law or agreed to in writing, software\n// distributed under the License is distributed on an \"AS-IS\" BASIS,\n// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n// See the License for the specific language governing permissions and\n// limitations under the License.\n\n/**\n * @fileoverview Bootstrap for the Google JS Library (Closure).\n *\n * In uncompiled mode base.js will write out Closure's deps file, unless the\n * global <code>CLOSURE_NO_DEPS</code> is set to true.  This allows projects to\n * include their own deps file(s) from different locations.\n *\n */\n\n\n/**\n * @define {boolean} Overridden to true by the compiler when --closure_pass\n *     or --mark_as_compiled is specified.\n */\nvar COMPILED = false;\n\n\n/**\n * Base namespace for the Closure library.  Checks to see goog is\n * already defined in the current scope before assigning to prevent\n * clobbering if base.js is loaded more than once.\n *\n * @const\n */\nvar goog = goog || {}; // Identifies this file as the Closure base.\n\n\n/**\n * Reference to the global context.  In most cases this will be 'window'.\n */\ngoog.global = this;\n\n\n/**\n * @define {boolean} DEBUG is provided as a convenience so that debugging code\n * that should not be included in a production js_binary can be easily stripped\n * by specifying --define goog.DEBUG=false to the JSCompiler. For example, most\n * toString() methods should be declared inside an \"if (goog.DEBUG)\" conditional\n * because they are generally used for debugging purposes and it is difficult\n * for the JSCompiler to statically determine whether they are used.\n */\ngoog.DEBUG = true;\n\n\n/**\n * @define {string} LOCALE defines the locale being used for compilation. It is\n * used to select locale specific data to be compiled in js binary. BUILD rule\n * can specify this value by \"--define goog.LOCALE=<locale_name>\" as JSCompiler\n * option.\n *\n * Take into account that the locale code format is important. You should use\n * the canonical Unicode format with hyphen as a delimiter. Language must be\n * lowercase, Language Script - Capitalized, Region - UPPERCASE.\n * There are few examples: pt-BR, en, en-US, sr-Latin-BO, zh-Hans-CN.\n *\n * See more info about locale codes here:\n * http://www.unicode.org/reports/tr35/#Unicode_Language_and_Locale_Identifiers\n *\n * For language codes you should use values defined by ISO 693-1. See it here\n * http://www.w3.org/WAI/ER/IG/ert/iso639.htm. There is only one exception from\n * this rule: the Hebrew language. For legacy reasons the old code (iw) should\n * be used instead of the new code (he), see http://wiki/Main/IIISynonyms.\n */\ngoog.LOCALE = 'en';  // default to en\n\n\n/**\n * Creates object stubs for a namespace.  The presence of one or more\n * goog.provide() calls indicate that the file defines the given\n * objects/namespaces.  Build tools also scan for provide/require statements\n * to discern dependencies, build dependency files (see deps.js), etc.\n * @see goog.require\n * @param {string} name Namespace provided by this file in the form\n *     \"goog.package.part\".\n */\ngoog.provide = function(name) {\n  if (!COMPILED) {\n    // Ensure that the same namespace isn't provided twice. This is intended\n    // to teach new developers that 'goog.provide' is effectively a variable\n    // declaration. And when JSCompiler transforms goog.provide into a real\n    // variable declaration, the compiled JS should work the same as the raw\n    // JS--even when the raw JS uses goog.provide incorrectly.\n    if (goog.isProvided_(name)) {\n      throw Error('Namespace \"' + name + '\" already declared.');\n    }\n    delete goog.implicitNamespaces_[name];\n\n    var namespace = name;\n    while ((namespace = namespace.substring(0, namespace.lastIndexOf('.')))) {\n      if (goog.getObjectByName(namespace)) {\n        break;\n      }\n      goog.implicitNamespaces_[namespace] = true;\n    }\n  }\n\n  goog.exportPath_(name);\n};\n\n\n/**\n * Marks that the current file should only be used for testing, and never for\n * live code in production.\n * @param {string=} opt_message Optional message to add to the error that's\n *     raised when used in production code.\n */\ngoog.setTestOnly = function(opt_message) {\n  if (COMPILED && !goog.DEBUG) {\n    opt_message = opt_message || '';\n    throw Error('Importing test-only code into non-debug environment' +\n                opt_message ? ': ' + opt_message : '.');\n  }\n};\n\n\nif (!COMPILED) {\n\n  /**\n   * Check if the given name has been goog.provided. This will return false for\n   * names that are available only as implicit namespaces.\n   * @param {string} name name of the object to look for.\n   * @return {boolean} Whether the name has been provided.\n   * @private\n   */\n  goog.isProvided_ = function(name) {\n    return !goog.implicitNamespaces_[name] && !!goog.getObjectByName(name);\n  };\n\n  /**\n   * Namespaces implicitly defined by goog.provide. For example,\n   * goog.provide('goog.events.Event') implicitly declares\n   * that 'goog' and 'goog.events' must be namespaces.\n   *\n   * @type {Object}\n   * @private\n   */\n  goog.implicitNamespaces_ = {};\n}\n\n\n/**\n * Builds an object structure for the provided namespace path,\n * ensuring that names that already exist are not overwritten. For\n * example:\n * \"a.b.c\" -> a = {};a.b={};a.b.c={};\n * Used by goog.provide and goog.exportSymbol.\n * @param {string} name name of the object that this file defines.\n * @param {*=} opt_object the object to expose at the end of the path.\n * @param {Object=} opt_objectToExportTo The object to add the path to; default\n *     is |goog.global|.\n * @private\n */\ngoog.exportPath_ = function(name, opt_object, opt_objectToExportTo) {\n  var parts = name.split('.');\n  var cur = opt_objectToExportTo || goog.global;\n\n  // Internet Explorer exhibits strange behavior when throwing errors from\n  // methods externed in this manner.  See the testExportSymbolExceptions in\n  // base_test.html for an example.\n  if (!(parts[0] in cur) && cur.execScript) {\n    cur.execScript('var ' + parts[0]);\n  }\n\n  // Certain browsers cannot parse code in the form for((a in b); c;);\n  // This pattern is produced by the JSCompiler when it collapses the\n  // statement above into the conditional loop below. To prevent this from\n  // happening, use a for-loop and reserve the init logic as below.\n\n  // Parentheses added to eliminate strict JS warning in Firefox.\n  for (var part; parts.length && (part = parts.shift());) {\n    if (!parts.length && goog.isDef(opt_object)) {\n      // last part and we have an object; use it\n      cur[part] = opt_object;\n    } else if (cur[part]) {\n      cur = cur[part];\n    } else {\n      cur = cur[part] = {};\n    }\n  }\n};\n\n\n/**\n * Returns an object based on its fully qualified external name.  If you are\n * using a compilation pass that renames property names beware that using this\n * function will not find renamed properties.\n *\n * @param {string} name The fully qualified name.\n * @param {Object=} opt_obj The object within which to look; default is\n *     |goog.global|.\n * @return {?} The value (object or primitive) or, if not found, null.\n */\ngoog.getObjectByName = function(name, opt_obj) {\n  var parts = name.split('.');\n  var cur = opt_obj || goog.global;\n  for (var part; part = parts.shift(); ) {\n    if (goog.isDefAndNotNull(cur[part])) {\n      cur = cur[part];\n    } else {\n      return null;\n    }\n  }\n  return cur;\n};\n\n\n/**\n * Globalizes a whole namespace, such as goog or goog.lang.\n *\n * @param {Object} obj The namespace to globalize.\n * @param {Object=} opt_global The object to add the properties to.\n * @deprecated Properties may be explicitly exported to the global scope, but\n *     this should no longer be done in bulk.\n */\ngoog.globalize = function(obj, opt_global) {\n  var global = opt_global || goog.global;\n  for (var x in obj) {\n    global[x] = obj[x];\n  }\n};\n\n\n/**\n * Adds a dependency from a file to the files it requires.\n * @param {string} relPath The path to the js file.\n * @param {Array} provides An array of strings with the names of the objects\n *                         this file provides.\n * @param {Array} requires An array of strings with the names of the objects\n *                         this file requires.\n */\ngoog.addDependency = function(relPath, provides, requires) {\n  if (!COMPILED) {\n    var provide, require;\n    var path = relPath.replace(/\\\\/g, '/');\n    var deps = goog.dependencies_;\n    for (var i = 0; provide = provides[i]; i++) {\n      deps.nameToPath[provide] = path;\n      if (!(path in deps.pathToNames)) {\n        deps.pathToNames[path] = {};\n      }\n      deps.pathToNames[path][provide] = true;\n    }\n    for (var j = 0; require = requires[j]; j++) {\n      if (!(path in deps.requires)) {\n        deps.requires[path] = {};\n      }\n      deps.requires[path][require] = true;\n    }\n  }\n};\n\n\n\n\n// NOTE(nnaze): The debug DOM loader was included in base.js as an orignal\n// way to do \"debug-mode\" development.  The dependency system can sometimes\n// be confusing, as can the debug DOM loader's asyncronous nature.\n//\n// With the DOM loader, a call to goog.require() is not blocking -- the\n// script will not load until some point after the current script.  If a\n// namespace is needed at runtime, it needs to be defined in a previous\n// script, or loaded via require() with its registered dependencies.\n// User-defined namespaces may need their own deps file.  See http://go/js_deps,\n// http://go/genjsdeps, or, externally, DepsWriter.\n// http://code.google.com/closure/library/docs/depswriter.html\n//\n// Because of legacy clients, the DOM loader can't be easily removed from\n// base.js.  Work is being done to make it disableable or replaceable for\n// different environments (DOM-less JavaScript interpreters like Rhino or V8,\n// for example). See bootstrap/ for more information.\n\n\n/**\n * @define {boolean} Whether to enable the debug loader.\n *\n * If enabled, a call to goog.require() will attempt to load the namespace by\n * appending a script tag to the DOM (if the namespace has been registered).\n *\n * If disabled, goog.require() will simply assert that the namespace has been\n * provided (and depend on the fact that some outside tool correctly ordered\n * the script).\n */\ngoog.ENABLE_DEBUG_LOADER = true;\n\n\n/**\n * Implements a system for the dynamic resolution of dependencies\n * that works in parallel with the BUILD system. Note that all calls\n * to goog.require will be stripped by the JSCompiler when the\n * --closure_pass option is used.\n * @see goog.provide\n * @param {string} name Namespace to include (as was given in goog.provide())\n *     in the form \"goog.package.part\".\n */\ngoog.require = function(name) {\n\n  // if the object already exists we do not need do do anything\n  // TODO(arv): If we start to support require based on file name this has\n  //            to change\n  // TODO(arv): If we allow goog.foo.* this has to change\n  // TODO(arv): If we implement dynamic load after page load we should probably\n  //            not remove this code for the compiled output\n  if (!COMPILED) {\n    if (goog.isProvided_(name)) {\n      return;\n    }\n\n    if (goog.ENABLE_DEBUG_LOADER) {\n      var path = goog.getPathFromDeps_(name);\n      if (path) {\n        goog.included_[path] = true;\n        goog.writeScripts_();\n        return;\n      }\n    }\n\n    var errorMessage = 'goog.require could not find: ' + name;\n    if (goog.global.console) {\n      goog.global.console['error'](errorMessage);\n    }\n\n\n      throw Error(errorMessage);\n\n  }\n};\n\n\n/**\n * Path for included scripts\n * @type {string}\n */\ngoog.basePath = '';\n\n\n/**\n * A hook for overriding the base path.\n * @type {string|undefined}\n */\ngoog.global.CLOSURE_BASE_PATH;\n\n\n/**\n * Whether to write out Closure's deps file. By default,\n * the deps are written.\n * @type {boolean|undefined}\n */\ngoog.global.CLOSURE_NO_DEPS;\n\n\n/**\n * A function to import a single script. This is meant to be overridden when\n * Closure is being run in non-HTML contexts, such as web workers. It's defined\n * in the global scope so that it can be set before base.js is loaded, which\n * allows deps.js to be imported properly.\n *\n * The function is passed the script source, which is a relative URI. It should\n * return true if the script was imported, false otherwise.\n */\ngoog.global.CLOSURE_IMPORT_SCRIPT;\n\n\n/**\n * Null function used for default values of callbacks, etc.\n * @return {void} Nothing.\n */\ngoog.nullFunction = function() {};\n\n\n/**\n * The identity function. Returns its first argument.\n *\n * @param {*=} opt_returnValue The single value that will be returned.\n * @param {...*} var_args Optional trailing arguments. These are ignored.\n * @return {?} The first argument. We can't know the type -- just pass it along\n *      without type.\n * @deprecated Use goog.functions.identity instead.\n */\ngoog.identityFunction = function(opt_returnValue, var_args) {\n  return opt_returnValue;\n};\n\n\n/**\n * When defining a class Foo with an abstract method bar(), you can do:\n *\n * Foo.prototype.bar = goog.abstractMethod\n *\n * Now if a subclass of Foo fails to override bar(), an error\n * will be thrown when bar() is invoked.\n *\n * Note: This does not take the name of the function to override as\n * an argument because that would make it more difficult to obfuscate\n * our JavaScript code.\n *\n * @type {!Function}\n * @throws {Error} when invoked to indicate the method should be\n *   overridden.\n */\ngoog.abstractMethod = function() {\n  throw Error('unimplemented abstract method');\n};\n\n\n/**\n * Adds a {@code getInstance} static method that always return the same instance\n * object.\n * @param {!Function} ctor The constructor for the class to add the static\n *     method to.\n */\ngoog.addSingletonGetter = function(ctor) {\n  ctor.getInstance = function() {\n    if (ctor.instance_) {\n      return ctor.instance_;\n    }\n    if (goog.DEBUG) {\n      // NOTE: JSCompiler can't optimize away Array#push.\n      goog.instantiatedSingletons_[goog.instantiatedSingletons_.length] = ctor;\n    }\n    return ctor.instance_ = new ctor;\n  };\n};\n\n\n/**\n * All singleton classes that have been instantiated, for testing. Don't read\n * it directly, use the {@code goog.testing.singleton} module. The compiler\n * removes this variable if unused.\n * @type {!Array.<!Function>}\n * @private\n */\ngoog.instantiatedSingletons_ = [];\n\n\nif (!COMPILED && goog.ENABLE_DEBUG_LOADER) {\n  /**\n   * Object used to keep track of urls that have already been added. This\n   * record allows the prevention of circular dependencies.\n   * @type {Object}\n   * @private\n   */\n  goog.included_ = {};\n\n\n  /**\n   * This object is used to keep track of dependencies and other data that is\n   * used for loading scripts\n   * @private\n   * @type {Object}\n   */\n  goog.dependencies_ = {\n    pathToNames: {}, // 1 to many\n    nameToPath: {}, // 1 to 1\n    requires: {}, // 1 to many\n    // used when resolving dependencies to prevent us from\n    // visiting the file twice\n    visited: {},\n    written: {} // used to keep track of script files we have written\n  };\n\n\n  /**\n   * Tries to detect whether is in the context of an HTML document.\n   * @return {boolean} True if it looks like HTML document.\n   * @private\n   */\n  goog.inHtmlDocument_ = function() {\n    var doc = goog.global.document;\n    return typeof doc != 'undefined' &&\n           'write' in doc;  // XULDocument misses write.\n  };\n\n\n  /**\n   * Tries to detect the base path of the base.js script that bootstraps Closure\n   * @private\n   */\n  goog.findBasePath_ = function() {\n    if (goog.global.CLOSURE_BASE_PATH) {\n      goog.basePath = goog.global.CLOSURE_BASE_PATH;\n      return;\n    } else if (!goog.inHtmlDocument_()) {\n      return;\n    }\n    var doc = goog.global.document;\n    var scripts = doc.getElementsByTagName('script');\n    // Search backwards since the current script is in almost all cases the one\n    // that has base.js.\n    for (var i = scripts.length - 1; i >= 0; --i) {\n      var src = scripts[i].src;\n      var qmark = src.lastIndexOf('?');\n      var l = qmark == -1 ? src.length : qmark;\n      if (src.substr(l - 7, 7) == 'base.js') {\n        goog.basePath = src.substr(0, l - 7);\n        return;\n      }\n    }\n  };\n\n\n  /**\n   * Imports a script if, and only if, that script hasn't already been imported.\n   * (Must be called at execution time)\n   * @param {string} src Script source.\n   * @private\n   */\n  goog.importScript_ = function(src) {\n    var importScript = goog.global.CLOSURE_IMPORT_SCRIPT ||\n        goog.writeScriptTag_;\n    if (!goog.dependencies_.written[src] && importScript(src)) {\n      goog.dependencies_.written[src] = true;\n    }\n  };\n\n\n  /**\n   * The default implementation of the import function. Writes a script tag to\n   * import the script.\n   *\n   * @param {string} src The script source.\n   * @return {boolean} True if the script was imported, false otherwise.\n   * @private\n   */\n  goog.writeScriptTag_ = function(src) {\n    if (goog.inHtmlDocument_()) {\n      var doc = goog.global.document;\n      doc.write(\n          '<script type=\"text/javascript\" src=\"' + src + '\"></' + 'script>');\n      return true;\n    } else {\n      return false;\n    }\n  };\n\n\n  /**\n   * Resolves dependencies based on the dependencies added using addDependency\n   * and calls importScript_ in the correct order.\n   * @private\n   */\n  goog.writeScripts_ = function() {\n    // the scripts we need to write this time\n    var scripts = [];\n    var seenScript = {};\n    var deps = goog.dependencies_;\n\n    function visitNode(path) {\n      if (path in deps.written) {\n        return;\n      }\n\n      // we have already visited this one. We can get here if we have cyclic\n      // dependencies\n      if (path in deps.visited) {\n        if (!(path in seenScript)) {\n          seenScript[path] = true;\n          scripts.push(path);\n        }\n        return;\n      }\n\n      deps.visited[path] = true;\n\n      if (path in deps.requires) {\n        for (var requireName in deps.requires[path]) {\n          // If the required name is defined, we assume that it was already\n          // bootstrapped by other means.\n          if (!goog.isProvided_(requireName)) {\n            if (requireName in deps.nameToPath) {\n              visitNode(deps.nameToPath[requireName]);\n            } else {\n              throw Error('Undefined nameToPath for ' + requireName);\n            }\n          }\n        }\n      }\n\n      if (!(path in seenScript)) {\n        seenScript[path] = true;\n        scripts.push(path);\n      }\n    }\n\n    for (var path in goog.included_) {\n      if (!deps.written[path]) {\n        visitNode(path);\n      }\n    }\n\n    for (var i = 0; i < scripts.length; i++) {\n      if (scripts[i]) {\n        goog.importScript_(goog.basePath + scripts[i]);\n      } else {\n        throw Error('Undefined script input');\n      }\n    }\n  };\n\n\n  /**\n   * Looks at the dependency rules and tries to determine the script file that\n   * fulfills a particular rule.\n   * @param {string} rule In the form goog.namespace.Class or project.script.\n   * @return {?string} Url corresponding to the rule, or null.\n   * @private\n   */\n  goog.getPathFromDeps_ = function(rule) {\n    if (rule in goog.dependencies_.nameToPath) {\n      return goog.dependencies_.nameToPath[rule];\n    } else {\n      return null;\n    }\n  };\n\n  goog.findBasePath_();\n\n  // Allow projects to manage the deps files themselves.\n  if (!goog.global.CLOSURE_NO_DEPS) {\n    goog.importScript_(goog.basePath + 'deps.js');\n  }\n}\n\n\n\n//==============================================================================\n// Language Enhancements\n//==============================================================================\n\n\n/**\n * This is a \"fixed\" version of the typeof operator.  It differs from the typeof\n * operator in such a way that null returns 'null' and arrays return 'array'.\n * @param {*} value The value to get the type of.\n * @return {string} The name of the type.\n */\ngoog.typeOf = function(value) {\n  var s = typeof value;\n  if (s == 'object') {\n    if (value) {\n      // Check these first, so we can avoid calling Object.prototype.toString if\n      // possible.\n      //\n      // IE improperly marshals tyepof across execution contexts, but a\n      // cross-context object will still return false for \"instanceof Object\".\n      if (value instanceof Array) {\n        return 'array';\n      } else if (value instanceof Object) {\n        return s;\n      }\n\n      // HACK: In order to use an Object prototype method on the arbitrary\n      //   value, the compiler requires the value be cast to type Object,\n      //   even though the ECMA spec explicitly allows it.\n      var className = Object.prototype.toString.call(\n          /** @type {Object} */ (value));\n      // In Firefox 3.6, attempting to access iframe window objects' length\n      // property throws an NS_ERROR_FAILURE, so we need to special-case it\n      // here.\n      if (className == '[object Window]') {\n        return 'object';\n      }\n\n      // We cannot always use constructor == Array or instanceof Array because\n      // different frames have different Array objects. In IE6, if the iframe\n      // where the array was created is destroyed, the array loses its\n      // prototype. Then dereferencing val.splice here throws an exception, so\n      // we can't use goog.isFunction. Calling typeof directly returns 'unknown'\n      // so that will work. In this case, this function will return false and\n      // most array functions will still work because the array is still\n      // array-like (supports length and []) even though it has lost its\n      // prototype.\n      // Mark Miller noticed that Object.prototype.toString\n      // allows access to the unforgeable [[Class]] property.\n      //  15.2.4.2 Object.prototype.toString ( )\n      //  When the toString method is called, the following steps are taken:\n      //      1. Get the [[Class]] property of this object.\n      //      2. Compute a string value by concatenating the three strings\n      //         \"[object \", Result(1), and \"]\".\n      //      3. Return Result(2).\n      // and this behavior survives the destruction of the execution context.\n      if ((className == '[object Array]' ||\n           // In IE all non value types are wrapped as objects across window\n           // boundaries (not iframe though) so we have to do object detection\n           // for this edge case\n           typeof value.length == 'number' &&\n           typeof value.splice != 'undefined' &&\n           typeof value.propertyIsEnumerable != 'undefined' &&\n           !value.propertyIsEnumerable('splice')\n\n          )) {\n        return 'array';\n      }\n      // HACK: There is still an array case that fails.\n      //     function ArrayImpostor() {}\n      //     ArrayImpostor.prototype = [];\n      //     var impostor = new ArrayImpostor;\n      // this can be fixed by getting rid of the fast path\n      // (value instanceof Array) and solely relying on\n      // (value && Object.prototype.toString.vall(value) === '[object Array]')\n      // but that would require many more function calls and is not warranted\n      // unless closure code is receiving objects from untrusted sources.\n\n      // IE in cross-window calls does not correctly marshal the function type\n      // (it appears just as an object) so we cannot use just typeof val ==\n      // 'function'. However, if the object has a call property, it is a\n      // function.\n      if ((className == '[object Function]' ||\n          typeof value.call != 'undefined' &&\n          typeof value.propertyIsEnumerable != 'undefined' &&\n          !value.propertyIsEnumerable('call'))) {\n        return 'function';\n      }\n\n\n    } else {\n      return 'null';\n    }\n\n  } else if (s == 'function' && typeof value.call == 'undefined') {\n    // In Safari typeof nodeList returns 'function', and on Firefox\n    // typeof behaves similarly for HTML{Applet,Embed,Object}Elements\n    // and RegExps.  We would like to return object for those and we can\n    // detect an invalid function by making sure that the function\n    // object has a call method.\n    return 'object';\n  }\n  return s;\n};\n\n\n/**\n * Returns true if the specified value is not |undefined|.\n * WARNING: Do not use this to test if an object has a property. Use the in\n * operator instead.  Additionally, this function assumes that the global\n * undefined variable has not been redefined.\n * @param {*} val Variable to test.\n * @return {boolean} Whether variable is defined.\n */\ngoog.isDef = function(val) {\n  return val !== undefined;\n};\n\n\n/**\n * Returns true if the specified value is |null|\n * @param {*} val Variable to test.\n * @return {boolean} Whether variable is null.\n */\ngoog.isNull = function(val) {\n  return val === null;\n};\n\n\n/**\n * Returns true if the specified value is defined and not null\n * @param {*} val Variable to test.\n * @return {boolean} Whether variable is defined and not null.\n */\ngoog.isDefAndNotNull = function(val) {\n  // Note that undefined == null.\n  return val != null;\n};\n\n\n/**\n * Returns true if the specified value is an array\n * @param {*} val Variable to test.\n * @return {boolean} Whether variable is an array.\n */\ngoog.isArray = function(val) {\n  return goog.typeOf(val) == 'array';\n};\n\n\n/**\n * Returns true if the object looks like an array. To qualify as array like\n * the value needs to be either a NodeList or an object with a Number length\n * property.\n * @param {*} val Variable to test.\n * @return {boolean} Whether variable is an array.\n */\ngoog.isArrayLike = function(val) {\n  var type = goog.typeOf(val);\n  return type == 'array' || type == 'object' && typeof val.length == 'number';\n};\n\n\n/**\n * Returns true if the object looks like a Date. To qualify as Date-like\n * the value needs to be an object and have a getFullYear() function.\n * @param {*} val Variable to test.\n * @return {boolean} Whether variable is a like a Date.\n */\ngoog.isDateLike = function(val) {\n  return goog.isObject(val) && typeof val.getFullYear == 'function';\n};\n\n\n/**\n * Returns true if the specified value is a string\n * @param {*} val Variable to test.\n * @return {boolean} Whether variable is a string.\n */\ngoog.isString = function(val) {\n  return typeof val == 'string';\n};\n\n\n/**\n * Returns true if the specified value is a boolean\n * @param {*} val Variable to test.\n * @return {boolean} Whether variable is boolean.\n */\ngoog.isBoolean = function(val) {\n  return typeof val == 'boolean';\n};\n\n\n/**\n * Returns true if the specified value is a number\n * @param {*} val Variable to test.\n * @return {boolean} Whether variable is a number.\n */\ngoog.isNumber = function(val) {\n  return typeof val == 'number';\n};\n\n\n/**\n * Returns true if the specified value is a function\n * @param {*} val Variable to test.\n * @return {boolean} Whether variable is a function.\n */\ngoog.isFunction = function(val) {\n  return goog.typeOf(val) == 'function';\n};\n\n\n/**\n * Returns true if the specified value is an object.  This includes arrays\n * and functions.\n * @param {*} val Variable to test.\n * @return {boolean} Whether variable is an object.\n */\ngoog.isObject = function(val) {\n  var type = typeof val;\n  return type == 'object' && val != null || type == 'function';\n  // return Object(val) === val also works, but is slower, especially if val is\n  // not an object.\n};\n\n\n/**\n * Gets a unique ID for an object. This mutates the object so that further\n * calls with the same object as a parameter returns the same value. The unique\n * ID is guaranteed to be unique across the current session amongst objects that\n * are passed into {@code getUid}. There is no guarantee that the ID is unique\n * or consistent across sessions. It is unsafe to generate unique ID for\n * function prototypes.\n *\n * @param {Object} obj The object to get the unique ID for.\n * @return {number} The unique ID for the object.\n */\ngoog.getUid = function(obj) {\n  // TODO(arv): Make the type stricter, do not accept null.\n\n  // In Opera window.hasOwnProperty exists but always returns false so we avoid\n  // using it. As a consequence the unique ID generated for BaseClass.prototype\n  // and SubClass.prototype will be the same.\n  return obj[goog.UID_PROPERTY_] ||\n      (obj[goog.UID_PROPERTY_] = ++goog.uidCounter_);\n};\n\n\n/**\n * Removes the unique ID from an object. This is useful if the object was\n * previously mutated using {@code goog.getUid} in which case the mutation is\n * undone.\n * @param {Object} obj The object to remove the unique ID field from.\n */\ngoog.removeUid = function(obj) {\n  // TODO(arv): Make the type stricter, do not accept null.\n\n  // DOM nodes in IE are not instance of Object and throws exception\n  // for delete. Instead we try to use removeAttribute\n  if ('removeAttribute' in obj) {\n    obj.removeAttribute(goog.UID_PROPERTY_);\n  }\n  /** @preserveTry */\n  try {\n    delete obj[goog.UID_PROPERTY_];\n  } catch (ex) {\n  }\n};\n\n\n/**\n * Name for unique ID property. Initialized in a way to help avoid collisions\n * with other closure javascript on the same page.\n * @type {string}\n * @private\n */\ngoog.UID_PROPERTY_ = 'closure_uid_' +\n    Math.floor(Math.random() * 2147483648).toString(36);\n\n\n/**\n * Counter for UID.\n * @type {number}\n * @private\n */\ngoog.uidCounter_ = 0;\n\n\n/**\n * Adds a hash code field to an object. The hash code is unique for the\n * given object.\n * @param {Object} obj The object to get the hash code for.\n * @return {number} The hash code for the object.\n * @deprecated Use goog.getUid instead.\n */\ngoog.getHashCode = goog.getUid;\n\n\n/**\n * Removes the hash code field from an object.\n * @param {Object} obj The object to remove the field from.\n * @deprecated Use goog.removeUid instead.\n */\ngoog.removeHashCode = goog.removeUid;\n\n\n/**\n * Clones a value. The input may be an Object, Array, or basic type. Objects and\n * arrays will be cloned recursively.\n *\n * WARNINGS:\n * <code>goog.cloneObject</code> does not detect reference loops. Objects that\n * refer to themselves will cause infinite recursion.\n *\n * <code>goog.cloneObject</code> is unaware of unique identifiers, and copies\n * UIDs created by <code>getUid</code> into cloned results.\n *\n * @param {*} obj The value to clone.\n * @return {*} A clone of the input value.\n * @deprecated goog.cloneObject is unsafe. Prefer the goog.object methods.\n */\ngoog.cloneObject = function(obj) {\n  var type = goog.typeOf(obj);\n  if (type == 'object' || type == 'array') {\n    if (obj.clone) {\n      return obj.clone();\n    }\n    var clone = type == 'array' ? [] : {};\n    for (var key in obj) {\n      clone[key] = goog.cloneObject(obj[key]);\n    }\n    return clone;\n  }\n\n  return obj;\n};\n\n\n/**\n * Forward declaration for the clone method. This is necessary until the\n * compiler can better support duck-typing constructs as used in\n * goog.cloneObject.\n *\n * TODO(brenneman): Remove once the JSCompiler can infer that the check for\n * proto.clone is safe in goog.cloneObject.\n *\n * @type {Function}\n */\nObject.prototype.clone;\n\n\n/**\n * A native implementation of goog.bind.\n * @param {Function} fn A function to partially apply.\n * @param {Object|undefined} selfObj Specifies the object which |this| should\n *     point to when the function is run.\n * @param {...*} var_args Additional arguments that are partially\n *     applied to the function.\n * @return {!Function} A partially-applied form of the function bind() was\n *     invoked as a method of.\n * @private\n * @suppress {deprecated} The compiler thinks that Function.prototype.bind\n *     is deprecated because some people have declared a pure-JS version.\n *     Only the pure-JS version is truly deprecated.\n */\ngoog.bindNative_ = function(fn, selfObj, var_args) {\n  return /** @type {!Function} */ (fn.call.apply(fn.bind, arguments));\n};\n\n\n/**\n * A pure-JS implementation of goog.bind.\n * @param {Function} fn A function to partially apply.\n * @param {Object|undefined} selfObj Specifies the object which |this| should\n *     point to when the function is run.\n * @param {...*} var_args Additional arguments that are partially\n *     applied to the function.\n * @return {!Function} A partially-applied form of the function bind() was\n *     invoked as a method of.\n * @private\n */\ngoog.bindJs_ = function(fn, selfObj, var_args) {\n  if (!fn) {\n    throw new Error();\n  }\n\n  if (arguments.length > 2) {\n    var boundArgs = Array.prototype.slice.call(arguments, 2);\n    return function() {\n      // Prepend the bound arguments to the current arguments.\n      var newArgs = Array.prototype.slice.call(arguments);\n      Array.prototype.unshift.apply(newArgs, boundArgs);\n      return fn.apply(selfObj, newArgs);\n    };\n\n  } else {\n    return function() {\n      return fn.apply(selfObj, arguments);\n    };\n  }\n};\n\n\n/**\n * Partially applies this function to a particular 'this object' and zero or\n * more arguments. The result is a new function with some arguments of the first\n * function pre-filled and the value of |this| 'pre-specified'.<br><br>\n *\n * Remaining arguments specified at call-time are appended to the pre-\n * specified ones.<br><br>\n *\n * Also see: {@link #partial}.<br><br>\n *\n * Usage:\n * <pre>var barMethBound = bind(myFunction, myObj, 'arg1', 'arg2');\n * barMethBound('arg3', 'arg4');</pre>\n *\n * @param {Function} fn A function to partially apply.\n * @param {Object|undefined} selfObj Specifies the object which |this| should\n *     point to when the function is run.\n * @param {...*} var_args Additional arguments that are partially\n *     applied to the function.\n * @return {!Function} A partially-applied form of the function bind() was\n *     invoked as a method of.\n * @suppress {deprecated} See above.\n */\ngoog.bind = function(fn, selfObj, var_args) {\n  // TODO(nicksantos): narrow the type signature.\n  if (Function.prototype.bind &&\n      // NOTE(nicksantos): Somebody pulled base.js into the default\n      // Chrome extension environment. This means that for Chrome extensions,\n      // they get the implementation of Function.prototype.bind that\n      // calls goog.bind instead of the native one. Even worse, we don't want\n      // to introduce a circular dependency between goog.bind and\n      // Function.prototype.bind, so we have to hack this to make sure it\n      // works correctly.\n      Function.prototype.bind.toString().indexOf('native code') != -1) {\n    goog.bind = goog.bindNative_;\n  } else {\n    goog.bind = goog.bindJs_;\n  }\n  return goog.bind.apply(null, arguments);\n};\n\n\n/**\n * Like bind(), except that a 'this object' is not required. Useful when the\n * target function is already bound.\n *\n * Usage:\n * var g = partial(f, arg1, arg2);\n * g(arg3, arg4);\n *\n * @param {Function} fn A function to partially apply.\n * @param {...*} var_args Additional arguments that are partially\n *     applied to fn.\n * @return {!Function} A partially-applied form of the function bind() was\n *     invoked as a method of.\n */\ngoog.partial = function(fn, var_args) {\n  var args = Array.prototype.slice.call(arguments, 1);\n  return function() {\n    // Prepend the bound arguments to the current arguments.\n    var newArgs = Array.prototype.slice.call(arguments);\n    newArgs.unshift.apply(newArgs, args);\n    return fn.apply(this, newArgs);\n  };\n};\n\n\n/**\n * Copies all the members of a source object to a target object. This method\n * does not work on all browsers for all objects that contain keys such as\n * toString or hasOwnProperty. Use goog.object.extend for this purpose.\n * @param {Object} target Target.\n * @param {Object} source Source.\n */\ngoog.mixin = function(target, source) {\n  for (var x in source) {\n    target[x] = source[x];\n  }\n\n  // For IE7 or lower, the for-in-loop does not contain any properties that are\n  // not enumerable on the prototype object (for example, isPrototypeOf from\n  // Object.prototype) but also it will not include 'replace' on objects that\n  // extend String and change 'replace' (not that it is common for anyone to\n  // extend anything except Object).\n};\n\n\n/**\n * @return {number} An integer value representing the number of milliseconds\n *     between midnight, January 1, 1970 and the current time.\n */\ngoog.now = Date.now || (function() {\n  // Unary plus operator converts its operand to a number which in the case of\n  // a date is done by calling getTime().\n  return +new Date();\n});\n\n\n/**\n * Evals javascript in the global scope.  In IE this uses execScript, other\n * browsers use goog.global.eval. If goog.global.eval does not evaluate in the\n * global scope (for example, in Safari), appends a script tag instead.\n * Throws an exception if neither execScript or eval is defined.\n * @param {string} script JavaScript string.\n */\ngoog.globalEval = function(script) {\n  if (goog.global.execScript) {\n    goog.global.execScript(script, 'JavaScript');\n  } else if (goog.global.eval) {\n    // Test to see if eval works\n    if (goog.evalWorksForGlobals_ == null) {\n      goog.global.eval('var _et_ = 1;');\n      if (typeof goog.global['_et_'] != 'undefined') {\n        delete goog.global['_et_'];\n        goog.evalWorksForGlobals_ = true;\n      } else {\n        goog.evalWorksForGlobals_ = false;\n      }\n    }\n\n    if (goog.evalWorksForGlobals_) {\n      goog.global.eval(script);\n    } else {\n      var doc = goog.global.document;\n      var scriptElt = doc.createElement('script');\n      scriptElt.type = 'text/javascript';\n      scriptElt.defer = false;\n      // Note(user): can't use .innerHTML since \"t('<test>')\" will fail and\n      // .text doesn't work in Safari 2.  Therefore we append a text node.\n      scriptElt.appendChild(doc.createTextNode(script));\n      doc.body.appendChild(scriptElt);\n      doc.body.removeChild(scriptElt);\n    }\n  } else {\n    throw Error('goog.globalEval not available');\n  }\n};\n\n\n/**\n * Indicates whether or not we can call 'eval' directly to eval code in the\n * global scope. Set to a Boolean by the first call to goog.globalEval (which\n * empirically tests whether eval works for globals). @see goog.globalEval\n * @type {?boolean}\n * @private\n */\ngoog.evalWorksForGlobals_ = null;\n\n\n/**\n * Optional map of CSS class names to obfuscated names used with\n * goog.getCssName().\n * @type {Object|undefined}\n * @private\n * @see goog.setCssNameMapping\n */\ngoog.cssNameMapping_;\n\n\n/**\n * Optional obfuscation style for CSS class names. Should be set to either\n * 'BY_WHOLE' or 'BY_PART' if defined.\n * @type {string|undefined}\n * @private\n * @see goog.setCssNameMapping\n */\ngoog.cssNameMappingStyle_;\n\n\n/**\n * Handles strings that are intended to be used as CSS class names.\n *\n * This function works in tandem with @see goog.setCssNameMapping.\n *\n * Without any mapping set, the arguments are simple joined with a\n * hyphen and passed through unaltered.\n *\n * When there is a mapping, there are two possible styles in which\n * these mappings are used. In the BY_PART style, each part (i.e. in\n * between hyphens) of the passed in css name is rewritten according\n * to the map. In the BY_WHOLE style, the full css name is looked up in\n * the map directly. If a rewrite is not specified by the map, the\n * compiler will output a warning.\n *\n * When the mapping is passed to the compiler, it will replace calls\n * to goog.getCssName with the strings from the mapping, e.g.\n *     var x = goog.getCssName('foo');\n *     var y = goog.getCssName(this.baseClass, 'active');\n *  becomes:\n *     var x= 'foo';\n *     var y = this.baseClass + '-active';\n *\n * If one argument is passed it will be processed, if two are passed\n * only the modifier will be processed, as it is assumed the first\n * argument was generated as a result of calling goog.getCssName.\n *\n * @param {string} className The class name.\n * @param {string=} opt_modifier A modifier to be appended to the class name.\n * @return {string} The class name or the concatenation of the class name and\n *     the modifier.\n */\ngoog.getCssName = function(className, opt_modifier) {\n  var getMapping = function(cssName) {\n    return goog.cssNameMapping_[cssName] || cssName;\n  };\n\n  var renameByParts = function(cssName) {\n    // Remap all the parts individually.\n    var parts = cssName.split('-');\n    var mapped = [];\n    for (var i = 0; i < parts.length; i++) {\n      mapped.push(getMapping(parts[i]));\n    }\n    return mapped.join('-');\n  };\n\n  var rename;\n  if (goog.cssNameMapping_) {\n    rename = goog.cssNameMappingStyle_ == 'BY_WHOLE' ?\n        getMapping : renameByParts;\n  } else {\n    rename = function(a) {\n      return a;\n    };\n  }\n\n  if (opt_modifier) {\n    return className + '-' + rename(opt_modifier);\n  } else {\n    return rename(className);\n  }\n};\n\n\n/**\n * Sets the map to check when returning a value from goog.getCssName(). Example:\n * <pre>\n * goog.setCssNameMapping({\n *   \"goog\": \"a\",\n *   \"disabled\": \"b\",\n * });\n *\n * var x = goog.getCssName('goog');\n * // The following evaluates to: \"a a-b\".\n * goog.getCssName('goog') + ' ' + goog.getCssName(x, 'disabled')\n * </pre>\n * When declared as a map of string literals to string literals, the JSCompiler\n * will replace all calls to goog.getCssName() using the supplied map if the\n * --closure_pass flag is set.\n *\n * @param {!Object} mapping A map of strings to strings where keys are possible\n *     arguments to goog.getCssName() and values are the corresponding values\n *     that should be returned.\n * @param {string=} opt_style The style of css name mapping. There are two valid\n *     options: 'BY_PART', and 'BY_WHOLE'.\n * @see goog.getCssName for a description.\n */\ngoog.setCssNameMapping = function(mapping, opt_style) {\n  goog.cssNameMapping_ = mapping;\n  goog.cssNameMappingStyle_ = opt_style;\n};\n\n\n/**\n * To use CSS renaming in compiled mode, one of the input files should have a\n * call to goog.setCssNameMapping() with an object literal that the JSCompiler\n * can extract and use to replace all calls to goog.getCssName(). In uncompiled\n * mode, JavaScript code should be loaded before this base.js file that declares\n * a global variable, CLOSURE_CSS_NAME_MAPPING, which is used below. This is\n * to ensure that the mapping is loaded before any calls to goog.getCssName()\n * are made in uncompiled mode.\n *\n * A hook for overriding the CSS name mapping.\n * @type {Object|undefined}\n */\ngoog.global.CLOSURE_CSS_NAME_MAPPING;\n\n\nif (!COMPILED && goog.global.CLOSURE_CSS_NAME_MAPPING) {\n  // This does not call goog.setCssNameMapping() because the JSCompiler\n  // requires that goog.setCssNameMapping() be called with an object literal.\n  goog.cssNameMapping_ = goog.global.CLOSURE_CSS_NAME_MAPPING;\n}\n\n\n/**\n * Abstract implementation of goog.getMsg for use with localized messages.\n * @param {string} str Translatable string, places holders in the form {$foo}.\n * @param {Object=} opt_values Map of place holder name to value.\n * @return {string} message with placeholders filled.\n */\ngoog.getMsg = function(str, opt_values) {\n  var values = opt_values || {};\n  for (var key in values) {\n    var value = ('' + values[key]).replace(/\\$/g, '$$$$');\n    str = str.replace(new RegExp('\\\\{\\\\$' + key + '\\\\}', 'gi'), value);\n  }\n  return str;\n};\n\n\n/**\n * Exposes an unobfuscated global namespace path for the given object.\n * Note that fields of the exported object *will* be obfuscated,\n * unless they are exported in turn via this function or\n * goog.exportProperty\n *\n * <p>Also handy for making public items that are defined in anonymous\n * closures.\n *\n * ex. goog.exportSymbol('public.path.Foo', Foo);\n *\n * ex. goog.exportSymbol('public.path.Foo.staticFunction',\n *                       Foo.staticFunction);\n *     public.path.Foo.staticFunction();\n *\n * ex. goog.exportSymbol('public.path.Foo.prototype.myMethod',\n *                       Foo.prototype.myMethod);\n *     new public.path.Foo().myMethod();\n *\n * @param {string} publicPath Unobfuscated name to export.\n * @param {*} object Object the name should point to.\n * @param {Object=} opt_objectToExportTo The object to add the path to; default\n *     is |goog.global|.\n */\ngoog.exportSymbol = function(publicPath, object, opt_objectToExportTo) {\n  goog.exportPath_(publicPath, object, opt_objectToExportTo);\n};\n\n\n/**\n * Exports a property unobfuscated into the object's namespace.\n * ex. goog.exportProperty(Foo, 'staticFunction', Foo.staticFunction);\n * ex. goog.exportProperty(Foo.prototype, 'myMethod', Foo.prototype.myMethod);\n * @param {Object} object Object whose static property is being exported.\n * @param {string} publicName Unobfuscated name to export.\n * @param {*} symbol Object the name should point to.\n */\ngoog.exportProperty = function(object, publicName, symbol) {\n  object[publicName] = symbol;\n};\n\n\n/**\n * Inherit the prototype methods from one constructor into another.\n *\n * Usage:\n * <pre>\n * function ParentClass(a, b) { }\n * ParentClass.prototype.foo = function(a) { }\n *\n * function ChildClass(a, b, c) {\n *   goog.base(this, a, b);\n * }\n * goog.inherits(ChildClass, ParentClass);\n *\n * var child = new ChildClass('a', 'b', 'see');\n * child.foo(); // works\n * </pre>\n *\n * In addition, a superclass' implementation of a method can be invoked\n * as follows:\n *\n * <pre>\n * ChildClass.prototype.foo = function(a) {\n *   ChildClass.superClass_.foo.call(this, a);\n *   // other code\n * };\n * </pre>\n *\n * @param {Function} childCtor Child class.\n * @param {Function} parentCtor Parent class.\n */\ngoog.inherits = function(childCtor, parentCtor) {\n  /** @constructor */\n  function tempCtor() {};\n  tempCtor.prototype = parentCtor.prototype;\n  childCtor.superClass_ = parentCtor.prototype;\n  childCtor.prototype = new tempCtor();\n  childCtor.prototype.constructor = childCtor;\n};\n\n\n/**\n * Call up to the superclass.\n *\n * If this is called from a constructor, then this calls the superclass\n * contructor with arguments 1-N.\n *\n * If this is called from a prototype method, then you must pass\n * the name of the method as the second argument to this function. If\n * you do not, you will get a runtime error. This calls the superclass'\n * method with arguments 2-N.\n *\n * This function only works if you use goog.inherits to express\n * inheritance relationships between your classes.\n *\n * This function is a compiler primitive. At compile-time, the\n * compiler will do macro expansion to remove a lot of\n * the extra overhead that this function introduces. The compiler\n * will also enforce a lot of the assumptions that this function\n * makes, and treat it as a compiler error if you break them.\n *\n * @param {!Object} me Should always be \"this\".\n * @param {*=} opt_methodName The method name if calling a super method.\n * @param {...*} var_args The rest of the arguments.\n * @return {*} The return value of the superclass method.\n */\ngoog.base = function(me, opt_methodName, var_args) {\n  var caller = arguments.callee.caller;\n  if (caller.superClass_) {\n    // This is a constructor. Call the superclass constructor.\n    return caller.superClass_.constructor.apply(\n        me, Array.prototype.slice.call(arguments, 1));\n  }\n\n  var args = Array.prototype.slice.call(arguments, 2);\n  var foundCaller = false;\n  for (var ctor = me.constructor;\n       ctor; ctor = ctor.superClass_ && ctor.superClass_.constructor) {\n    if (ctor.prototype[opt_methodName] === caller) {\n      foundCaller = true;\n    } else if (foundCaller) {\n      return ctor.prototype[opt_methodName].apply(me, args);\n    }\n  }\n\n  // If we did not find the caller in the prototype chain,\n  // then one of two things happened:\n  // 1) The caller is an instance method.\n  // 2) This method was not called by the right caller.\n  if (me[opt_methodName] === caller) {\n    return me.constructor.prototype[opt_methodName].apply(me, args);\n  } else {\n    throw Error(\n        'goog.base called from a method of one name ' +\n        'to a method of a different name');\n  }\n};\n\n\n/**\n * Allow for aliasing within scope functions.  This function exists for\n * uncompiled code - in compiled code the calls will be inlined and the\n * aliases applied.  In uncompiled code the function is simply run since the\n * aliases as written are valid JavaScript.\n * @param {function()} fn Function to call.  This function can contain aliases\n *     to namespaces (e.g. \"var dom = goog.dom\") or classes\n *    (e.g. \"var Timer = goog.Timer\").\n */\ngoog.scope = function(fn) {\n  fn.call(goog.global);\n};\n\n\n","/**\n * defines\n */\n\ngoog.provide('USE_TYPEDARRAY');\n\n// Safari が typeof Uint8Array === 'object' になるため、\n// 未定義か否かで Typed Array の使用を決定する\n\n/** @const {boolean} use typed array flag. */\nvar USE_TYPEDARRAY =\n  (typeof Uint8Array !== 'undefined') &&\n  (typeof Uint16Array !== 'undefined') &&\n  (typeof Uint32Array !== 'undefined') &&\n  (typeof DataView !== 'undefined');\n","/**\n * @fileoverview bit 単位での書き込み実装.\n */\ngoog.provide('Zlib.BitStream');\n\ngoog.require('USE_TYPEDARRAY');\n\ngoog.scope(function() {\n\n/**\n * ビットストリーム\n * @constructor\n * @param {!(Array|Uint8Array)=} buffer output buffer.\n * @param {number=} bufferPosition start buffer pointer.\n */\nZlib.BitStream = function(buffer, bufferPosition) {\n  /** @type {number} buffer index. */\n  this.index = typeof bufferPosition === 'number' ? bufferPosition : 0;\n  /** @type {number} bit index. */\n  this.bitindex = 0;\n  /** @type {!(Array|Uint8Array)} bit-stream output buffer. */\n  this.buffer = buffer instanceof (USE_TYPEDARRAY ? Uint8Array : Array) ?\n    buffer :\n    new (USE_TYPEDARRAY ? Uint8Array : Array)(Zlib.BitStream.DefaultBlockSize);\n\n  // 入力された index が足りなかったら拡張するが、倍にしてもダメなら不正とする\n  if (this.buffer.length * 2 <= this.index) {\n    throw new Error(\"invalid index\");\n  } else if (this.buffer.length <= this.index) {\n    this.expandBuffer();\n  }\n};\n\n/**\n * デフォルトブロックサイズ.\n * @const\n * @type {number}\n */\nZlib.BitStream.DefaultBlockSize = 0x8000;\n\n/**\n * expand buffer.\n * @return {!(Array|Uint8Array)} new buffer.\n */\nZlib.BitStream.prototype.expandBuffer = function() {\n  /** @type {!(Array|Uint8Array)} old buffer. */\n  var oldbuf = this.buffer;\n  /** @type {number} loop counter. */\n  var i;\n  /** @type {number} loop limiter. */\n  var il = oldbuf.length;\n  /** @type {!(Array|Uint8Array)} new buffer. */\n  var buffer =\n    new (USE_TYPEDARRAY ? Uint8Array : Array)(il << 1);\n\n  // copy buffer\n  if (USE_TYPEDARRAY) {\n    buffer.set(oldbuf);\n  } else {\n    // XXX: loop unrolling\n    for (i = 0; i < il; ++i) {\n      buffer[i] = oldbuf[i];\n    }\n  }\n\n  return (this.buffer = buffer);\n};\n\n\n/**\n * 数値をビットで指定した数だけ書き込む.\n * @param {number} number 書き込む数値.\n * @param {number} n 書き込むビット数.\n * @param {boolean=} reverse 逆順に書き込むならば true.\n */\nZlib.BitStream.prototype.writeBits = function(number, n, reverse) {\n  var buffer = this.buffer;\n  var index = this.index;\n  var bitindex = this.bitindex;\n\n  /** @type {number} current octet. */\n  var current = buffer[index];\n  /** @type {number} loop counter. */\n  var i;\n\n  /**\n   * 32-bit 整数のビット順を逆にする\n   * @param {number} n 32-bit integer.\n   * @return {number} reversed 32-bit integer.\n   * @private\n   */\n  function rev32_(n) {\n    return (Zlib.BitStream.ReverseTable[n & 0xFF] << 24) |\n      (Zlib.BitStream.ReverseTable[n >>> 8 & 0xFF] << 16) |\n      (Zlib.BitStream.ReverseTable[n >>> 16 & 0xFF] << 8) |\n      Zlib.BitStream.ReverseTable[n >>> 24 & 0xFF];\n  }\n\n  if (reverse && n > 1) {\n    number = n > 8 ?\n      rev32_(number) >> (32 - n) :\n      Zlib.BitStream.ReverseTable[number] >> (8 - n);\n  }\n\n  // Byte 境界を超えないとき\n  if (n + bitindex < 8) {\n    current = (current << n) | number;\n    bitindex += n;\n  // Byte 境界を超えるとき\n  } else {\n    for (i = 0; i < n; ++i) {\n      current = (current << 1) | ((number >> n - i - 1) & 1);\n\n      // next byte\n      if (++bitindex === 8) {\n        bitindex = 0;\n        buffer[index++] = Zlib.BitStream.ReverseTable[current];\n        current = 0;\n\n        // expand\n        if (index === buffer.length) {\n          buffer = this.expandBuffer();\n        }\n      }\n    }\n  }\n  buffer[index] = current;\n\n  this.buffer = buffer;\n  this.bitindex = bitindex;\n  this.index = index;\n};\n\n\n/**\n * ストリームの終端処理を行う\n * @return {!(Array|Uint8Array)} 終端処理後のバッファを byte array で返す.\n */\nZlib.BitStream.prototype.finish = function() {\n  var buffer = this.buffer;\n  var index = this.index;\n\n  /** @type {!(Array|Uint8Array)} output buffer. */\n  var output;\n\n  // bitindex が 0 の時は余分に index が進んでいる状態\n  if (this.bitindex > 0) {\n    buffer[index] <<= 8 - this.bitindex;\n    buffer[index] = Zlib.BitStream.ReverseTable[buffer[index]];\n    index++;\n  }\n\n  // array truncation\n  if (USE_TYPEDARRAY) {\n    output = buffer.subarray(0, index);\n  } else {\n    buffer.length = index;\n    output = buffer;\n  }\n\n  return output;\n};\n\n/**\n * 0-255 のビット順を反転したテーブル\n * @const\n * @type {!(Uint8Array|Array.<number>)}\n */\nZlib.BitStream.ReverseTable = (function(table) {\n  return table;\n})((function() {\n  /** @type {!(Array|Uint8Array)} reverse table. */\n  var table = new (USE_TYPEDARRAY ? Uint8Array : Array)(256);\n  /** @type {number} loop counter. */\n  var i;\n\n  // generate\n  for (i = 0; i < 256; ++i) {\n    table[i] = (function(n) {\n      var r = n;\n      var s = 7;\n\n      for (n >>>= 1; n; n >>>= 1) {\n        r <<= 1;\n        r |= n & 1;\n        --s;\n      }\n\n      return (r << s & 0xff) >>> 0;\n    })(i);\n  }\n\n  return table;\n})());\n\n\n// end of scope\n});\n\n/* vim:set expandtab ts=2 sw=2 tw=80: */\n","/**\n * @fileoverview CRC32 実装.\n */\ngoog.provide('Zlib.CRC32');\n\ngoog.require('USE_TYPEDARRAY');\n\n/** @define {boolean} */\nvar ZLIB_CRC32_COMPACT = false;\n\ngoog.scope(function() {\n\n/**\n * CRC32 ハッシュ値を取得\n * @param {!(Array.<number>|Uint8Array)} data data byte array.\n * @param {number=} pos data position.\n * @param {number=} length data length.\n * @return {number} CRC32.\n */\nZlib.CRC32.calc = function(data, pos, length) {\n  return Zlib.CRC32.update(data, 0, pos, length);\n};\n\n/**\n * CRC32ハッシュ値を更新\n * @param {!(Array.<number>|Uint8Array)} data data byte array.\n * @param {number} crc CRC32.\n * @param {number=} pos data position.\n * @param {number=} length data length.\n * @return {number} CRC32.\n */\nZlib.CRC32.update = function(data, crc, pos, length) {\n  var table = Zlib.CRC32.Table;\n  var i = (typeof pos === 'number') ? pos : (pos = 0);\n  var il = (typeof length === 'number') ? length : data.length;\n\n  crc ^= 0xffffffff;\n\n  // loop unrolling for performance\n  for (i = il & 7; i--; ++pos) {\n    crc = (crc >>> 8) ^ table[(crc ^ data[pos]) & 0xff];\n  }\n  for (i = il >> 3; i--; pos += 8) {\n    crc = (crc >>> 8) ^ table[(crc ^ data[pos    ]) & 0xff];\n    crc = (crc >>> 8) ^ table[(crc ^ data[pos + 1]) & 0xff];\n    crc = (crc >>> 8) ^ table[(crc ^ data[pos + 2]) & 0xff];\n    crc = (crc >>> 8) ^ table[(crc ^ data[pos + 3]) & 0xff];\n    crc = (crc >>> 8) ^ table[(crc ^ data[pos + 4]) & 0xff];\n    crc = (crc >>> 8) ^ table[(crc ^ data[pos + 5]) & 0xff];\n    crc = (crc >>> 8) ^ table[(crc ^ data[pos + 6]) & 0xff];\n    crc = (crc >>> 8) ^ table[(crc ^ data[pos + 7]) & 0xff];\n  }\n\n  return (crc ^ 0xffffffff) >>> 0;\n};\n\n/**\n * @param {number} num\n * @param {number} crc\n * @returns {number}\n */\nZlib.CRC32.single = function(num, crc) {\n  return (Zlib.CRC32.Table[(num ^ crc) & 0xff] ^ (num >>> 8)) >>> 0;\n};\n\n/**\n * @type {Array.<number>}\n * @const\n * @private\n */\nZlib.CRC32.Table_ = [\n  0x00000000, 0x77073096, 0xee0e612c, 0x990951ba, 0x076dc419, 0x706af48f,\n  0xe963a535, 0x9e6495a3, 0x0edb8832, 0x79dcb8a4, 0xe0d5e91e, 0x97d2d988,\n  0x09b64c2b, 0x7eb17cbd, 0xe7b82d07, 0x90bf1d91, 0x1db71064, 0x6ab020f2,\n  0xf3b97148, 0x84be41de, 0x1adad47d, 0x6ddde4eb, 0xf4d4b551, 0x83d385c7,\n  0x136c9856, 0x646ba8c0, 0xfd62f97a, 0x8a65c9ec, 0x14015c4f, 0x63066cd9,\n  0xfa0f3d63, 0x8d080df5, 0x3b6e20c8, 0x4c69105e, 0xd56041e4, 0xa2677172,\n  0x3c03e4d1, 0x4b04d447, 0xd20d85fd, 0xa50ab56b, 0x35b5a8fa, 0x42b2986c,\n  0xdbbbc9d6, 0xacbcf940, 0x32d86ce3, 0x45df5c75, 0xdcd60dcf, 0xabd13d59,\n  0x26d930ac, 0x51de003a, 0xc8d75180, 0xbfd06116, 0x21b4f4b5, 0x56b3c423,\n  0xcfba9599, 0xb8bda50f, 0x2802b89e, 0x5f058808, 0xc60cd9b2, 0xb10be924,\n  0x2f6f7c87, 0x58684c11, 0xc1611dab, 0xb6662d3d, 0x76dc4190, 0x01db7106,\n  0x98d220bc, 0xefd5102a, 0x71b18589, 0x06b6b51f, 0x9fbfe4a5, 0xe8b8d433,\n  0x7807c9a2, 0x0f00f934, 0x9609a88e, 0xe10e9818, 0x7f6a0dbb, 0x086d3d2d,\n  0x91646c97, 0xe6635c01, 0x6b6b51f4, 0x1c6c6162, 0x856530d8, 0xf262004e,\n  0x6c0695ed, 0x1b01a57b, 0x8208f4c1, 0xf50fc457, 0x65b0d9c6, 0x12b7e950,\n  0x8bbeb8ea, 0xfcb9887c, 0x62dd1ddf, 0x15da2d49, 0x8cd37cf3, 0xfbd44c65,\n  0x4db26158, 0x3ab551ce, 0xa3bc0074, 0xd4bb30e2, 0x4adfa541, 0x3dd895d7,\n  0xa4d1c46d, 0xd3d6f4fb, 0x4369e96a, 0x346ed9fc, 0xad678846, 0xda60b8d0,\n  0x44042d73, 0x33031de5, 0xaa0a4c5f, 0xdd0d7cc9, 0x5005713c, 0x270241aa,\n  0xbe0b1010, 0xc90c2086, 0x5768b525, 0x206f85b3, 0xb966d409, 0xce61e49f,\n  0x5edef90e, 0x29d9c998, 0xb0d09822, 0xc7d7a8b4, 0x59b33d17, 0x2eb40d81,\n  0xb7bd5c3b, 0xc0ba6cad, 0xedb88320, 0x9abfb3b6, 0x03b6e20c, 0x74b1d29a,\n  0xead54739, 0x9dd277af, 0x04db2615, 0x73dc1683, 0xe3630b12, 0x94643b84,\n  0x0d6d6a3e, 0x7a6a5aa8, 0xe40ecf0b, 0x9309ff9d, 0x0a00ae27, 0x7d079eb1,\n  0xf00f9344, 0x8708a3d2, 0x1e01f268, 0x6906c2fe, 0xf762575d, 0x806567cb,\n  0x196c3671, 0x6e6b06e7, 0xfed41b76, 0x89d32be0, 0x10da7a5a, 0x67dd4acc,\n  0xf9b9df6f, 0x8ebeeff9, 0x17b7be43, 0x60b08ed5, 0xd6d6a3e8, 0xa1d1937e,\n  0x38d8c2c4, 0x4fdff252, 0xd1bb67f1, 0xa6bc5767, 0x3fb506dd, 0x48b2364b,\n  0xd80d2bda, 0xaf0a1b4c, 0x36034af6, 0x41047a60, 0xdf60efc3, 0xa867df55,\n  0x316e8eef, 0x4669be79, 0xcb61b38c, 0xbc66831a, 0x256fd2a0, 0x5268e236,\n  0xcc0c7795, 0xbb0b4703, 0x220216b9, 0x5505262f, 0xc5ba3bbe, 0xb2bd0b28,\n  0x2bb45a92, 0x5cb36a04, 0xc2d7ffa7, 0xb5d0cf31, 0x2cd99e8b, 0x5bdeae1d,\n  0x9b64c2b0, 0xec63f226, 0x756aa39c, 0x026d930a, 0x9c0906a9, 0xeb0e363f,\n  0x72076785, 0x05005713, 0x95bf4a82, 0xe2b87a14, 0x7bb12bae, 0x0cb61b38,\n  0x92d28e9b, 0xe5d5be0d, 0x7cdcefb7, 0x0bdbdf21, 0x86d3d2d4, 0xf1d4e242,\n  0x68ddb3f8, 0x1fda836e, 0x81be16cd, 0xf6b9265b, 0x6fb077e1, 0x18b74777,\n  0x88085ae6, 0xff0f6a70, 0x66063bca, 0x11010b5c, 0x8f659eff, 0xf862ae69,\n  0x616bffd3, 0x166ccf45, 0xa00ae278, 0xd70dd2ee, 0x4e048354, 0x3903b3c2,\n  0xa7672661, 0xd06016f7, 0x4969474d, 0x3e6e77db, 0xaed16a4a, 0xd9d65adc,\n  0x40df0b66, 0x37d83bf0, 0xa9bcae53, 0xdebb9ec5, 0x47b2cf7f, 0x30b5ffe9,\n  0xbdbdf21c, 0xcabac28a, 0x53b39330, 0x24b4a3a6, 0xbad03605, 0xcdd70693,\n  0x54de5729, 0x23d967bf, 0xb3667a2e, 0xc4614ab8, 0x5d681b02, 0x2a6f2b94,\n  0xb40bbe37, 0xc30c8ea1, 0x5a05df1b, 0x2d02ef8d\n];\n\n/**\n * @type {!(Array.<number>|Uint32Array)} CRC-32 Table.\n * @const\n */\nZlib.CRC32.Table = ZLIB_CRC32_COMPACT ? (function() {\n  /** @type {!(Array.<number>|Uint32Array)} */\n  var table = new (USE_TYPEDARRAY ? Uint32Array : Array)(256);\n  /** @type {number} */\n  var c;\n  /** @type {number} */\n  var i;\n  /** @type {number} */\n  var j;\n\n  for (i = 0; i < 256; ++i) {\n    c = i;\n    for (j = 0; j < 8; ++j) {\n      c = (c & 1) ? (0xedB88320 ^ (c >>> 1)) : (c >>> 1);\n    }\n    table[i] = c >>> 0;\n  }\n\n  return table;\n})() : USE_TYPEDARRAY ? new Uint32Array(Zlib.CRC32.Table_) : Zlib.CRC32.Table_;\n\n});\n","goog.provide('Zlib.GunzipMember');\n\ngoog.scope(function() {\n\n/**\n * @constructor\n */\nZlib.GunzipMember = function() {\n  /** @type {number} signature first byte. */\n  this.id1;\n  /** @type {number} signature second byte. */\n  this.id2;\n  /** @type {number} compression method. */\n  this.cm;\n  /** @type {number} flags. */\n  this.flg;\n  /** @type {Date} modification time. */\n  this.mtime;\n  /** @type {number} extra flags. */\n  this.xfl;\n  /** @type {number} operating system number. */\n  this.os;\n  /** @type {number} CRC-16 value for FHCRC flag. */\n  this.crc16;\n  /** @type {number} extra length. */\n  this.xlen;\n  /** @type {number} CRC-32 value for verification. */\n  this.crc32;\n  /** @type {number} input size modulo 32 value. */\n  this.isize;\n  /** @type {string} filename. */\n  this.name;\n  /** @type {string} comment. */\n  this.comment;\n  /** @type {!(Uint8Array|Array.<number>)} */\n  this.data;\n};\n\nZlib.GunzipMember.prototype.getName = function() {\n  return this.name;\n};\n\nZlib.GunzipMember.prototype.getData = function() {\n  return this.data;\n};\n\nZlib.GunzipMember.prototype.getMtime = function() {\n  return this.mtime;\n}\n\n});","/**\n * @fileoverview Heap Sort 実装. ハフマン符号化で使用する.\n */\n\ngoog.provide('Zlib.Heap');\n\ngoog.require('USE_TYPEDARRAY');\n\ngoog.scope(function() {\n\n/**\n * カスタムハフマン符号で使用するヒープ実装\n * @param {number} length ヒープサイズ.\n * @constructor\n */\nZlib.Heap = function(length) {\n  this.buffer = new (USE_TYPEDARRAY ? Uint16Array : Array)(length * 2);\n  this.length = 0;\n};\n\n/**\n * 親ノードの index 取得\n * @param {number} index 子ノードの index.\n * @return {number} 親ノードの index.\n *\n */\nZlib.Heap.prototype.getParent = function(index) {\n  return ((index - 2) / 4 | 0) * 2;\n};\n\n/**\n * 子ノードの index 取得\n * @param {number} index 親ノードの index.\n * @return {number} 子ノードの index.\n */\nZlib.Heap.prototype.getChild = function(index) {\n  return 2 * index + 2;\n};\n\n/**\n * Heap に値を追加する\n * @param {number} index キー index.\n * @param {number} value 値.\n * @return {number} 現在のヒープ長.\n */\nZlib.Heap.prototype.push = function(index, value) {\n  var current, parent,\n      heap = this.buffer,\n      swap;\n\n  current = this.length;\n  heap[this.length++] = value;\n  heap[this.length++] = index;\n\n  // ルートノードにたどり着くまで入れ替えを試みる\n  while (current > 0) {\n    parent = this.getParent(current);\n\n    // 親ノードと比較して親の方が小さければ入れ替える\n    if (heap[current] > heap[parent]) {\n      swap = heap[current];\n      heap[current] = heap[parent];\n      heap[parent] = swap;\n\n      swap = heap[current + 1];\n      heap[current + 1] = heap[parent + 1];\n      heap[parent + 1] = swap;\n\n      current = parent;\n    // 入れ替えが必要なくなったらそこで抜ける\n    } else {\n      break;\n    }\n  }\n\n  return this.length;\n};\n\n/**\n * Heapから一番大きい値を返す\n * @return {{index: number, value: number, length: number}} {index: キーindex,\n *     value: 値, length: ヒープ長} の Object.\n */\nZlib.Heap.prototype.pop = function() {\n  var index, value,\n      heap = this.buffer, swap,\n      current, parent;\n\n  value = heap[0];\n  index = heap[1];\n\n  // 後ろから値を取る\n  this.length -= 2;\n  heap[0] = heap[this.length];\n  heap[1] = heap[this.length + 1];\n\n  parent = 0;\n  // ルートノードから下がっていく\n  while (true) {\n    current = this.getChild(parent);\n\n    // 範囲チェック\n    if (current >= this.length) {\n      break;\n    }\n\n    // 隣のノードと比較して、隣の方が値が大きければ隣を現在ノードとして選択\n    if (current + 2 < this.length && heap[current + 2] > heap[current]) {\n      current += 2;\n    }\n\n    // 親ノードと比較して親の方が小さい場合は入れ替える\n    if (heap[current] > heap[parent]) {\n      swap = heap[parent];\n      heap[parent] = heap[current];\n      heap[current] = swap;\n\n      swap = heap[parent + 1];\n      heap[parent + 1] = heap[current + 1];\n      heap[current + 1] = swap;\n    } else {\n      break;\n    }\n\n    parent = current;\n  }\n\n  return {index: index, value: value, length: this.length};\n};\n\n\n// end of scope\n});\n\n/* vim:set expandtab ts=2 sw=2 tw=80: */\n","goog.provide('Zlib.Huffman');\n\ngoog.require('USE_TYPEDARRAY');\n\ngoog.scope(function() {\n\n/**\n * build huffman table from length list.\n * @param {!(Array.<number>|Uint8Array)} lengths length list.\n * @return {!Array} huffman table.\n */\nZlib.Huffman.buildHuffmanTable = function(lengths) {\n  /** @type {number} length list size. */\n  var listSize = lengths.length;\n  /** @type {number} max code length for table size. */\n  var maxCodeLength = 0;\n  /** @type {number} min code length for table size. */\n  var minCodeLength = Number.POSITIVE_INFINITY;\n  /** @type {number} table size. */\n  var size;\n  /** @type {!(Array|Uint8Array)} huffman code table. */\n  var table;\n  /** @type {number} bit length. */\n  var bitLength;\n  /** @type {number} huffman code. */\n  var code;\n  /**\n   * サイズが 2^maxlength 個のテーブルを埋めるためのスキップ長.\n   * @type {number} skip length for table filling.\n   */\n  var skip;\n  /** @type {number} reversed code. */\n  var reversed;\n  /** @type {number} reverse temp. */\n  var rtemp;\n  /** @type {number} loop counter. */\n  var i;\n  /** @type {number} loop limit. */\n  var il;\n  /** @type {number} loop counter. */\n  var j;\n  /** @type {number} table value. */\n  var value;\n\n  // Math.max は遅いので最長の値は for-loop で取得する\n  for (i = 0, il = listSize; i < il; ++i) {\n    if (lengths[i] > maxCodeLength) {\n      maxCodeLength = lengths[i];\n    }\n    if (lengths[i] < minCodeLength) {\n      minCodeLength = lengths[i];\n    }\n  }\n\n  size = 1 << maxCodeLength;\n  table = new (USE_TYPEDARRAY ? Uint32Array : Array)(size);\n\n  // ビット長の短い順からハフマン符号を割り当てる\n  for (bitLength = 1, code = 0, skip = 2; bitLength <= maxCodeLength;) {\n    for (i = 0; i < listSize; ++i) {\n      if (lengths[i] === bitLength) {\n        // ビットオーダーが逆になるためビット長分並びを反転する\n        for (reversed = 0, rtemp = code, j = 0; j < bitLength; ++j) {\n          reversed = (reversed << 1) | (rtemp & 1);\n          rtemp >>= 1;\n        }\n\n        // 最大ビット長をもとにテーブルを作るため、\n        // 最大ビット長以外では 0 / 1 どちらでも良い箇所ができる\n        // そのどちらでも良い場所は同じ値で埋めることで\n        // 本来のビット長以上のビット数取得しても問題が起こらないようにする\n        value = (bitLength << 16) | i;\n        for (j = reversed; j < size; j += skip) {\n          table[j] = value;\n        }\n\n        ++code;\n      }\n    }\n\n    // 次のビット長へ\n    ++bitLength;\n    code <<= 1;\n    skip <<= 1;\n  }\n\n  return [table, maxCodeLength, minCodeLength];\n};\n\n\n// end of scope\n});\n\n/* vim:set expandtab ts=2 sw=2 tw=80: */\n","/**\n * @fileoverview Deflate (RFC1951) 符号化アルゴリズム実装.\n */\n\ngoog.provide('Zlib.RawDeflate');\n\ngoog.require('USE_TYPEDARRAY');\ngoog.require('Zlib.BitStream');\ngoog.require('Zlib.Heap');\n\ngoog.scope(function() {\n\n/**\n * Raw Deflate 実装\n *\n * @constructor\n * @param {!(Array.<number>|Uint8Array)} input 符号化する対象のバッファ.\n * @param {Object=} opt_params option parameters.\n *\n * typed array が使用可能なとき、outputBuffer が Array は自動的に Uint8Array に\n * 変換されます.\n * 別のオブジェクトになるため出力バッファを参照している変数などは\n * 更新する必要があります.\n */\nZlib.RawDeflate = function(input, opt_params) {\n  /** @type {Zlib.RawDeflate.CompressionType} */\n  this.compressionType = Zlib.RawDeflate.CompressionType.DYNAMIC;\n  /** @type {number} */\n  this.lazy = 0;\n  /** @type {!(Array.<number>|Uint32Array)} */\n  this.freqsLitLen;\n  /** @type {!(Array.<number>|Uint32Array)} */\n  this.freqsDist;\n  /** @type {!(Array.<number>|Uint8Array)} */\n  this.input =\n    (USE_TYPEDARRAY && input instanceof Array) ? new Uint8Array(input) : input;\n  /** @type {!(Array.<number>|Uint8Array)} output output buffer. */\n  this.output;\n  /** @type {number} pos output buffer position. */\n  this.op = 0;\n\n  // option parameters\n  if (opt_params) {\n    if (opt_params['lazy']) {\n      this.lazy = opt_params['lazy'];\n    }\n    if (typeof opt_params['compressionType'] === 'number') {\n      this.compressionType = opt_params['compressionType'];\n    }\n    if (opt_params['outputBuffer']) {\n      this.output =\n        (USE_TYPEDARRAY && opt_params['outputBuffer'] instanceof Array) ?\n        new Uint8Array(opt_params['outputBuffer']) : opt_params['outputBuffer'];\n    }\n    if (typeof opt_params['outputIndex'] === 'number') {\n      this.op = opt_params['outputIndex'];\n    }\n  }\n\n  if (!this.output) {\n    this.output = new (USE_TYPEDARRAY ? Uint8Array : Array)(0x8000);\n  }\n};\n\n/**\n * @enum {number}\n */\nZlib.RawDeflate.CompressionType = {\n  NONE: 0,\n  FIXED: 1,\n  DYNAMIC: 2,\n  RESERVED: 3\n};\n\n\n/**\n * LZ77 の最小マッチ長\n * @const\n * @type {number}\n */\nZlib.RawDeflate.Lz77MinLength = 3;\n\n/**\n * LZ77 の最大マッチ長\n * @const\n * @type {number}\n */\nZlib.RawDeflate.Lz77MaxLength = 258;\n\n/**\n * LZ77 のウィンドウサイズ\n * @const\n * @type {number}\n */\nZlib.RawDeflate.WindowSize = 0x8000;\n\n/**\n * 最長の符号長\n * @const\n * @type {number}\n */\nZlib.RawDeflate.MaxCodeLength = 16;\n\n/**\n * ハフマン符号の最大数値\n * @const\n * @type {number}\n */\nZlib.RawDeflate.HUFMAX = 286;\n\n/**\n * 固定ハフマン符号の符号化テーブル\n * @const\n * @type {Array.<Array.<number, number>>}\n */\nZlib.RawDeflate.FixedHuffmanTable = (function() {\n  var table = [], i;\n\n  for (i = 0; i < 288; i++) {\n    switch (true) {\n      case (i <= 143): table.push([i       + 0x030, 8]); break;\n      case (i <= 255): table.push([i - 144 + 0x190, 9]); break;\n      case (i <= 279): table.push([i - 256 + 0x000, 7]); break;\n      case (i <= 287): table.push([i - 280 + 0x0C0, 8]); break;\n      default:\n        throw 'invalid literal: ' + i;\n    }\n  }\n\n  return table;\n})();\n\n/**\n * DEFLATE ブロックの作成\n * @return {!(Array.<number>|Uint8Array)} 圧縮済み byte array.\n */\nZlib.RawDeflate.prototype.compress = function() {\n  /** @type {!(Array.<number>|Uint8Array)} */\n  var blockArray;\n  /** @type {number} */\n  var position;\n  /** @type {number} */\n  var length;\n\n  var input = this.input;\n\n  // compression\n  switch (this.compressionType) {\n    case Zlib.RawDeflate.CompressionType.NONE:\n      // each 65535-Byte (length header: 16-bit)\n      for (position = 0, length = input.length; position < length;) {\n        blockArray = USE_TYPEDARRAY ?\n          input.subarray(position, position + 0xffff) :\n          input.slice(position, position + 0xffff);\n        position += blockArray.length;\n        this.makeNocompressBlock(blockArray, (position === length));\n      }\n      break;\n    case Zlib.RawDeflate.CompressionType.FIXED:\n      this.output = this.makeFixedHuffmanBlock(input, true);\n      this.op = this.output.length;\n      break;\n    case Zlib.RawDeflate.CompressionType.DYNAMIC:\n      this.output = this.makeDynamicHuffmanBlock(input, true);\n      this.op = this.output.length;\n      break;\n    default:\n      throw 'invalid compression type';\n  }\n\n  return this.output;\n};\n\n/**\n * 非圧縮ブロックの作成\n * @param {!(Array.<number>|Uint8Array)} blockArray ブロックデータ byte array.\n * @param {!boolean} isFinalBlock 最後のブロックならばtrue.\n * @return {!(Array.<number>|Uint8Array)} 非圧縮ブロック byte array.\n */\nZlib.RawDeflate.prototype.makeNocompressBlock =\nfunction(blockArray, isFinalBlock) {\n  /** @type {number} */\n  var bfinal;\n  /** @type {Zlib.RawDeflate.CompressionType} */\n  var btype;\n  /** @type {number} */\n  var len;\n  /** @type {number} */\n  var nlen;\n  /** @type {number} */\n  var i;\n  /** @type {number} */\n  var il;\n\n  var output = this.output;\n  var op = this.op;\n\n  // expand buffer\n  if (USE_TYPEDARRAY) {\n    output = new Uint8Array(this.output.buffer);\n    while (output.length <= op + blockArray.length + 5) {\n      output = new Uint8Array(output.length << 1);\n    }\n    output.set(this.output);\n  }\n\n  // header\n  bfinal = isFinalBlock ? 1 : 0;\n  btype = Zlib.RawDeflate.CompressionType.NONE;\n  output[op++] = (bfinal) | (btype << 1);\n\n  // length\n  len = blockArray.length;\n  nlen = (~len + 0x10000) & 0xffff;\n  output[op++] =          len & 0xff;\n  output[op++] =  (len >>> 8) & 0xff;\n  output[op++] =         nlen & 0xff;\n  output[op++] = (nlen >>> 8) & 0xff;\n\n  // copy buffer\n  if (USE_TYPEDARRAY) {\n     output.set(blockArray, op);\n     op += blockArray.length;\n     output = output.subarray(0, op);\n  } else {\n    for (i = 0, il = blockArray.length; i < il; ++i) {\n      output[op++] = blockArray[i];\n    }\n    output.length = op;\n  }\n\n  this.op = op;\n  this.output = output;\n\n  return output;\n};\n\n/**\n * 固定ハフマンブロックの作成\n * @param {!(Array.<number>|Uint8Array)} blockArray ブロックデータ byte array.\n * @param {!boolean} isFinalBlock 最後のブロックならばtrue.\n * @return {!(Array.<number>|Uint8Array)} 固定ハフマン符号化ブロック byte array.\n */\nZlib.RawDeflate.prototype.makeFixedHuffmanBlock =\nfunction(blockArray, isFinalBlock) {\n  /** @type {Zlib.BitStream} */\n  var stream = new Zlib.BitStream(USE_TYPEDARRAY ?\n    new Uint8Array(this.output.buffer) : this.output, this.op);\n  /** @type {number} */\n  var bfinal;\n  /** @type {Zlib.RawDeflate.CompressionType} */\n  var btype;\n  /** @type {!(Array.<number>|Uint16Array)} */\n  var data;\n\n  // header\n  bfinal = isFinalBlock ? 1 : 0;\n  btype = Zlib.RawDeflate.CompressionType.FIXED;\n\n  stream.writeBits(bfinal, 1, true);\n  stream.writeBits(btype, 2, true);\n\n  data = this.lz77(blockArray);\n  this.fixedHuffman(data, stream);\n\n  return stream.finish();\n};\n\n/**\n * 動的ハフマンブロックの作成\n * @param {!(Array.<number>|Uint8Array)} blockArray ブロックデータ byte array.\n * @param {!boolean} isFinalBlock 最後のブロックならばtrue.\n * @return {!(Array.<number>|Uint8Array)} 動的ハフマン符号ブロック byte array.\n */\nZlib.RawDeflate.prototype.makeDynamicHuffmanBlock =\nfunction(blockArray, isFinalBlock) {\n  /** @type {Zlib.BitStream} */\n  var stream = new Zlib.BitStream(USE_TYPEDARRAY ?\n    new Uint8Array(this.output.buffer) : this.output, this.op);\n  /** @type {number} */\n  var bfinal;\n  /** @type {Zlib.RawDeflate.CompressionType} */\n  var btype;\n  /** @type {!(Array.<number>|Uint16Array)} */\n  var data;\n  /** @type {number} */\n  var hlit;\n  /** @type {number} */\n  var hdist;\n  /** @type {number} */\n  var hclen;\n  /** @const @type {Array.<number>} */\n  var hclenOrder =\n        [16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15];\n  /** @type {!(Array.<number>|Uint8Array)} */\n  var litLenLengths;\n  /** @type {!(Array.<number>|Uint16Array)} */\n  var litLenCodes;\n  /** @type {!(Array.<number>|Uint8Array)} */\n  var distLengths;\n  /** @type {!(Array.<number>|Uint16Array)} */\n  var distCodes;\n  /** @type {{\n   *   codes: !(Array.<number>|Uint32Array),\n   *   freqs: !(Array.<number>|Uint8Array)\n   * }} */\n  var treeSymbols;\n  /** @type {!(Array.<number>|Uint8Array)} */\n  var treeLengths;\n  /** @type {Array} */\n  var transLengths = new Array(19);\n  /** @type {!(Array.<number>|Uint16Array)} */\n  var treeCodes;\n  /** @type {number} */\n  var code;\n  /** @type {number} */\n  var bitlen;\n  /** @type {number} */\n  var i;\n  /** @type {number} */\n  var il;\n\n  // header\n  bfinal = isFinalBlock ? 1 : 0;\n  btype = Zlib.RawDeflate.CompressionType.DYNAMIC;\n\n  stream.writeBits(bfinal, 1, true);\n  stream.writeBits(btype, 2, true);\n\n  data = this.lz77(blockArray);\n\n  // リテラル・長さ, 距離のハフマン符号と符号長の算出\n  litLenLengths = this.getLengths_(this.freqsLitLen, 15);\n  litLenCodes = this.getCodesFromLengths_(litLenLengths);\n  distLengths = this.getLengths_(this.freqsDist, 7);\n  distCodes = this.getCodesFromLengths_(distLengths);\n\n  // HLIT, HDIST の決定\n  for (hlit = 286; hlit > 257 && litLenLengths[hlit - 1] === 0; hlit--) {}\n  for (hdist = 30; hdist > 1 && distLengths[hdist - 1] === 0; hdist--) {}\n\n  // HCLEN\n  treeSymbols =\n    this.getTreeSymbols_(hlit, litLenLengths, hdist, distLengths);\n  treeLengths = this.getLengths_(treeSymbols.freqs, 7);\n  for (i = 0; i < 19; i++) {\n    transLengths[i] = treeLengths[hclenOrder[i]];\n  }\n  for (hclen = 19; hclen > 4 && transLengths[hclen - 1] === 0; hclen--) {}\n\n  treeCodes = this.getCodesFromLengths_(treeLengths);\n\n  // 出力\n  stream.writeBits(hlit - 257, 5, true);\n  stream.writeBits(hdist - 1, 5, true);\n  stream.writeBits(hclen - 4, 4, true);\n  for (i = 0; i < hclen; i++) {\n    stream.writeBits(transLengths[i], 3, true);\n  }\n\n  // ツリーの出力\n  for (i = 0, il = treeSymbols.codes.length; i < il; i++) {\n    code = treeSymbols.codes[i];\n\n    stream.writeBits(treeCodes[code], treeLengths[code], true);\n\n    // extra bits\n    if (code >= 16) {\n      i++;\n      switch (code) {\n        case 16: bitlen = 2; break;\n        case 17: bitlen = 3; break;\n        case 18: bitlen = 7; break;\n        default:\n          throw 'invalid code: ' + code;\n      }\n\n      stream.writeBits(treeSymbols.codes[i], bitlen, true);\n    }\n  }\n\n  this.dynamicHuffman(\n    data,\n    [litLenCodes, litLenLengths],\n    [distCodes, distLengths],\n    stream\n  );\n\n  return stream.finish();\n};\n\n\n/**\n * 動的ハフマン符号化(カスタムハフマンテーブル)\n * @param {!(Array.<number>|Uint16Array)} dataArray LZ77 符号化済み byte array.\n * @param {!Zlib.BitStream} stream 書き込み用ビットストリーム.\n * @return {!Zlib.BitStream} ハフマン符号化済みビットストリームオブジェクト.\n */\nZlib.RawDeflate.prototype.dynamicHuffman =\nfunction(dataArray, litLen, dist, stream) {\n  /** @type {number} */\n  var index;\n  /** @type {number} */\n  var length;\n  /** @type {number} */\n  var literal;\n  /** @type {number} */\n  var code;\n  /** @type {number} */\n  var litLenCodes;\n  /** @type {number} */\n  var litLenLengths;\n  /** @type {number} */\n  var distCodes;\n  /** @type {number} */\n  var distLengths;\n\n  litLenCodes = litLen[0];\n  litLenLengths = litLen[1];\n  distCodes = dist[0];\n  distLengths = dist[1];\n\n  // 符号を BitStream に書き込んでいく\n  for (index = 0, length = dataArray.length; index < length; ++index) {\n    literal = dataArray[index];\n\n    // literal or length\n    stream.writeBits(litLenCodes[literal], litLenLengths[literal], true);\n\n    // 長さ・距離符号\n    if (literal > 256) {\n      // length extra\n      stream.writeBits(dataArray[++index], dataArray[++index], true);\n      // distance\n      code = dataArray[++index];\n      stream.writeBits(distCodes[code], distLengths[code], true);\n      // distance extra\n      stream.writeBits(dataArray[++index], dataArray[++index], true);\n    // 終端\n    } else if (literal === 256) {\n      break;\n    }\n  }\n\n  return stream;\n};\n\n/**\n * 固定ハフマン符号化\n * @param {!(Array.<number>|Uint16Array)} dataArray LZ77 符号化済み byte array.\n * @param {!Zlib.BitStream} stream 書き込み用ビットストリーム.\n * @return {!Zlib.BitStream} ハフマン符号化済みビットストリームオブジェクト.\n */\nZlib.RawDeflate.prototype.fixedHuffman = function(dataArray, stream) {\n  /** @type {number} */\n  var index;\n  /** @type {number} */\n  var length;\n  /** @type {number} */\n  var literal;\n\n  // 符号を BitStream に書き込んでいく\n  for (index = 0, length = dataArray.length; index < length; index++) {\n    literal = dataArray[index];\n\n    // 符号の書き込み\n    Zlib.BitStream.prototype.writeBits.apply(\n      stream,\n      Zlib.RawDeflate.FixedHuffmanTable[literal]\n    );\n\n    // 長さ・距離符号\n    if (literal > 0x100) {\n      // length extra\n      stream.writeBits(dataArray[++index], dataArray[++index], true);\n      // distance\n      stream.writeBits(dataArray[++index], 5);\n      // distance extra\n      stream.writeBits(dataArray[++index], dataArray[++index], true);\n    // 終端\n    } else if (literal === 0x100) {\n      break;\n    }\n  }\n\n  return stream;\n};\n\n/**\n * マッチ情報\n * @param {!number} length マッチした長さ.\n * @param {!number} backwardDistance マッチ位置との距離.\n * @constructor\n */\nZlib.RawDeflate.Lz77Match = function(length, backwardDistance) {\n  /** @type {number} match length. */\n  this.length = length;\n  /** @type {number} backward distance. */\n  this.backwardDistance = backwardDistance;\n};\n\n/**\n * 長さ符号テーブル.\n * [コード, 拡張ビット, 拡張ビット長] の配列となっている.\n * @const\n * @type {!(Array.<number>|Uint32Array)}\n */\nZlib.RawDeflate.Lz77Match.LengthCodeTable = (function(table) {\n  return USE_TYPEDARRAY ? new Uint32Array(table) : table;\n})((function() {\n  /** @type {!Array} */\n  var table = [];\n  /** @type {number} */\n  var i;\n  /** @type {!Array.<number>} */\n  var c;\n\n  for (i = 3; i <= 258; i++) {\n    c = code(i);\n    table[i] = (c[2] << 24) | (c[1] << 16) | c[0];\n  }\n\n  /**\n   * @param {number} length lz77 length.\n   * @return {!Array.<number>} lz77 codes.\n   */\n  function code(length) {\n    switch (true) {\n      case (length === 3): return [257, length - 3, 0]; break;\n      case (length === 4): return [258, length - 4, 0]; break;\n      case (length === 5): return [259, length - 5, 0]; break;\n      case (length === 6): return [260, length - 6, 0]; break;\n      case (length === 7): return [261, length - 7, 0]; break;\n      case (length === 8): return [262, length - 8, 0]; break;\n      case (length === 9): return [263, length - 9, 0]; break;\n      case (length === 10): return [264, length - 10, 0]; break;\n      case (length <= 12): return [265, length - 11, 1]; break;\n      case (length <= 14): return [266, length - 13, 1]; break;\n      case (length <= 16): return [267, length - 15, 1]; break;\n      case (length <= 18): return [268, length - 17, 1]; break;\n      case (length <= 22): return [269, length - 19, 2]; break;\n      case (length <= 26): return [270, length - 23, 2]; break;\n      case (length <= 30): return [271, length - 27, 2]; break;\n      case (length <= 34): return [272, length - 31, 2]; break;\n      case (length <= 42): return [273, length - 35, 3]; break;\n      case (length <= 50): return [274, length - 43, 3]; break;\n      case (length <= 58): return [275, length - 51, 3]; break;\n      case (length <= 66): return [276, length - 59, 3]; break;\n      case (length <= 82): return [277, length - 67, 4]; break;\n      case (length <= 98): return [278, length - 83, 4]; break;\n      case (length <= 114): return [279, length - 99, 4]; break;\n      case (length <= 130): return [280, length - 115, 4]; break;\n      case (length <= 162): return [281, length - 131, 5]; break;\n      case (length <= 194): return [282, length - 163, 5]; break;\n      case (length <= 226): return [283, length - 195, 5]; break;\n      case (length <= 257): return [284, length - 227, 5]; break;\n      case (length === 258): return [285, length - 258, 0]; break;\n      default: throw 'invalid length: ' + length;\n    }\n  }\n\n  return table;\n})());\n\n/**\n * 距離符号テーブル\n * @param {!number} dist 距離.\n * @return {!Array.<number>} コード、拡張ビット、拡張ビット長の配列.\n * @private\n */\nZlib.RawDeflate.Lz77Match.prototype.getDistanceCode_ = function(dist) {\n  /** @type {!Array.<number>} distance code table. */\n  var r;\n\n  switch (true) {\n    case (dist === 1): r = [0, dist - 1, 0]; break;\n    case (dist === 2): r = [1, dist - 2, 0]; break;\n    case (dist === 3): r = [2, dist - 3, 0]; break;\n    case (dist === 4): r = [3, dist - 4, 0]; break;\n    case (dist <= 6): r = [4, dist - 5, 1]; break;\n    case (dist <= 8): r = [5, dist - 7, 1]; break;\n    case (dist <= 12): r = [6, dist - 9, 2]; break;\n    case (dist <= 16): r = [7, dist - 13, 2]; break;\n    case (dist <= 24): r = [8, dist - 17, 3]; break;\n    case (dist <= 32): r = [9, dist - 25, 3]; break;\n    case (dist <= 48): r = [10, dist - 33, 4]; break;\n    case (dist <= 64): r = [11, dist - 49, 4]; break;\n    case (dist <= 96): r = [12, dist - 65, 5]; break;\n    case (dist <= 128): r = [13, dist - 97, 5]; break;\n    case (dist <= 192): r = [14, dist - 129, 6]; break;\n    case (dist <= 256): r = [15, dist - 193, 6]; break;\n    case (dist <= 384): r = [16, dist - 257, 7]; break;\n    case (dist <= 512): r = [17, dist - 385, 7]; break;\n    case (dist <= 768): r = [18, dist - 513, 8]; break;\n    case (dist <= 1024): r = [19, dist - 769, 8]; break;\n    case (dist <= 1536): r = [20, dist - 1025, 9]; break;\n    case (dist <= 2048): r = [21, dist - 1537, 9]; break;\n    case (dist <= 3072): r = [22, dist - 2049, 10]; break;\n    case (dist <= 4096): r = [23, dist - 3073, 10]; break;\n    case (dist <= 6144): r = [24, dist - 4097, 11]; break;\n    case (dist <= 8192): r = [25, dist - 6145, 11]; break;\n    case (dist <= 12288): r = [26, dist - 8193, 12]; break;\n    case (dist <= 16384): r = [27, dist - 12289, 12]; break;\n    case (dist <= 24576): r = [28, dist - 16385, 13]; break;\n    case (dist <= 32768): r = [29, dist - 24577, 13]; break;\n    default: throw 'invalid distance';\n  }\n\n  return r;\n};\n\n/**\n * マッチ情報を LZ77 符号化配列で返す.\n * なお、ここでは以下の内部仕様で符号化している\n * [ CODE, EXTRA-BIT-LEN, EXTRA, CODE, EXTRA-BIT-LEN, EXTRA ]\n * @return {!Array.<number>} LZ77 符号化 byte array.\n */\nZlib.RawDeflate.Lz77Match.prototype.toLz77Array = function() {\n  /** @type {number} */\n  var length = this.length;\n  /** @type {number} */\n  var dist = this.backwardDistance;\n  /** @type {Array} */\n  var codeArray = [];\n  /** @type {number} */\n  var pos = 0;\n  /** @type {!Array.<number>} */\n  var code;\n\n  // length\n  code = Zlib.RawDeflate.Lz77Match.LengthCodeTable[length];\n  codeArray[pos++] = code & 0xffff;\n  codeArray[pos++] = (code >> 16) & 0xff;\n  codeArray[pos++] = code >> 24;\n\n  // distance\n  code = this.getDistanceCode_(dist);\n  codeArray[pos++] = code[0];\n  codeArray[pos++] = code[1];\n  codeArray[pos++] = code[2];\n\n  return codeArray;\n};\n\n/**\n * LZ77 実装\n * @param {!(Array.<number>|Uint8Array)} dataArray LZ77 符号化するバイト配列.\n * @return {!(Array.<number>|Uint16Array)} LZ77 符号化した配列.\n */\nZlib.RawDeflate.prototype.lz77 = function(dataArray) {\n  /** @type {number} input position */\n  var position;\n  /** @type {number} input length */\n  var length;\n  /** @type {number} loop counter */\n  var i;\n  /** @type {number} loop limiter */\n  var il;\n  /** @type {number} chained-hash-table key */\n  var matchKey;\n  /** @type {Object.<number, Array.<number>>} chained-hash-table */\n  var table = {};\n  /** @const @type {number} */\n  var windowSize = Zlib.RawDeflate.WindowSize;\n  /** @type {Array.<number>} match list */\n  var matchList;\n  /** @type {Zlib.RawDeflate.Lz77Match} longest match */\n  var longestMatch;\n  /** @type {Zlib.RawDeflate.Lz77Match} previous longest match */\n  var prevMatch;\n  /** @type {!(Array.<number>|Uint16Array)} lz77 buffer */\n  var lz77buf = USE_TYPEDARRAY ?\n    new Uint16Array(dataArray.length * 2) : [];\n  /** @type {number} lz77 output buffer pointer */\n  var pos = 0;\n  /** @type {number} lz77 skip length */\n  var skipLength = 0;\n  /** @type {!(Array.<number>|Uint32Array)} */\n  var freqsLitLen = new (USE_TYPEDARRAY ? Uint32Array : Array)(286);\n  /** @type {!(Array.<number>|Uint32Array)} */\n  var freqsDist = new (USE_TYPEDARRAY ? Uint32Array : Array)(30);\n  /** @type {number} */\n  var lazy = this.lazy;\n  /** @type {*} temporary variable */\n  var tmp;\n\n  // 初期化\n  if (!USE_TYPEDARRAY) {\n    for (i = 0; i <= 285;) { freqsLitLen[i++] = 0; }\n    for (i = 0; i <= 29;) { freqsDist[i++] = 0; }\n  }\n  freqsLitLen[256] = 1; // EOB の最低出現回数は 1\n\n  /**\n   * マッチデータの書き込み\n   * @param {Zlib.RawDeflate.Lz77Match} match LZ77 Match data.\n   * @param {!number} offset スキップ開始位置(相対指定).\n   * @private\n   */\n  function writeMatch(match, offset) {\n    /** @type {Array.<number>} */\n    var lz77Array = match.toLz77Array();\n    /** @type {number} */\n    var i;\n    /** @type {number} */\n    var il;\n\n    for (i = 0, il = lz77Array.length; i < il; ++i) {\n      lz77buf[pos++] = lz77Array[i];\n    }\n    freqsLitLen[lz77Array[0]]++;\n    freqsDist[lz77Array[3]]++;\n    skipLength = match.length + offset - 1;\n    prevMatch = null;\n  }\n\n  // LZ77 符号化\n  for (position = 0, length = dataArray.length; position < length; ++position) {\n    // ハッシュキーの作成\n    for (matchKey = 0, i = 0, il = Zlib.RawDeflate.Lz77MinLength; i < il; ++i) {\n      if (position + i === length) {\n        break;\n      }\n      matchKey = (matchKey << 8) | dataArray[position + i];\n    }\n\n    // テーブルが未定義だったら作成する\n    if (table[matchKey] === void 0) { table[matchKey] = []; }\n    matchList = table[matchKey];\n\n    // skip\n    if (skipLength-- > 0) {\n      matchList.push(position);\n      continue;\n    }\n\n    // マッチテーブルの更新 (最大戻り距離を超えているものを削除する)\n    while (matchList.length > 0 && position - matchList[0] > windowSize) {\n      matchList.shift();\n    }\n\n    // データ末尾でマッチしようがない場合はそのまま流しこむ\n    if (position + Zlib.RawDeflate.Lz77MinLength >= length) {\n      if (prevMatch) {\n        writeMatch(prevMatch, -1);\n      }\n\n      for (i = 0, il = length - position; i < il; ++i) {\n        tmp = dataArray[position + i];\n        lz77buf[pos++] = tmp;\n        ++freqsLitLen[tmp];\n      }\n      break;\n    }\n\n    // マッチ候補から最長のものを探す\n    if (matchList.length > 0) {\n      longestMatch = this.searchLongestMatch_(dataArray, position, matchList);\n\n      if (prevMatch) {\n        // 現在のマッチの方が前回のマッチよりも長い\n        if (prevMatch.length < longestMatch.length) {\n          // write previous literal\n          tmp = dataArray[position - 1];\n          lz77buf[pos++] = tmp;\n          ++freqsLitLen[tmp];\n\n          // write current match\n          writeMatch(longestMatch, 0);\n        } else {\n          // write previous match\n          writeMatch(prevMatch, -1);\n        }\n      } else if (longestMatch.length < lazy) {\n        prevMatch = longestMatch;\n      } else {\n        writeMatch(longestMatch, 0);\n      }\n    // 前回マッチしていて今回マッチがなかったら前回のを採用\n    } else if (prevMatch) {\n      writeMatch(prevMatch, -1);\n    } else {\n      tmp = dataArray[position];\n      lz77buf[pos++] = tmp;\n      ++freqsLitLen[tmp];\n    }\n\n    matchList.push(position); // マッチテーブルに現在の位置を保存\n  }\n\n  // 終端処理\n  lz77buf[pos++] = 256;\n  freqsLitLen[256]++;\n  this.freqsLitLen = freqsLitLen;\n  this.freqsDist = freqsDist;\n\n  return /** @type {!(Uint16Array|Array.<number>)} */ (\n    USE_TYPEDARRAY ?  lz77buf.subarray(0, pos) : lz77buf\n  );\n};\n\n/**\n * マッチした候補の中から最長一致を探す\n * @param {!Object} data plain data byte array.\n * @param {!number} position plain data byte array position.\n * @param {!Array.<number>} matchList 候補となる位置の配列.\n * @return {!Zlib.RawDeflate.Lz77Match} 最長かつ最短距離のマッチオブジェクト.\n * @private\n */\nZlib.RawDeflate.prototype.searchLongestMatch_ =\nfunction(data, position, matchList) {\n  var match,\n      currentMatch,\n      matchMax = 0, matchLength,\n      i, j, l, dl = data.length;\n\n  // 候補を後ろから 1 つずつ絞り込んでゆく\n  permatch:\n  for (i = 0, l = matchList.length; i < l; i++) {\n    match = matchList[l - i - 1];\n    matchLength = Zlib.RawDeflate.Lz77MinLength;\n\n    // 前回までの最長一致を末尾から一致検索する\n    if (matchMax > Zlib.RawDeflate.Lz77MinLength) {\n      for (j = matchMax; j > Zlib.RawDeflate.Lz77MinLength; j--) {\n        if (data[match + j - 1] !== data[position + j - 1]) {\n          continue permatch;\n        }\n      }\n      matchLength = matchMax;\n    }\n\n    // 最長一致探索\n    while (matchLength < Zlib.RawDeflate.Lz77MaxLength &&\n           position + matchLength < dl &&\n           data[match + matchLength] === data[position + matchLength]) {\n      ++matchLength;\n    }\n\n    // マッチ長が同じ場合は後方を優先\n    if (matchLength > matchMax) {\n      currentMatch = match;\n      matchMax = matchLength;\n    }\n\n    // 最長が確定したら後の処理は省略\n    if (matchLength === Zlib.RawDeflate.Lz77MaxLength) {\n      break;\n    }\n  }\n\n  return new Zlib.RawDeflate.Lz77Match(matchMax, position - currentMatch);\n};\n\n/**\n * Tree-Transmit Symbols の算出\n * reference: PuTTY Deflate implementation\n * @param {number} hlit HLIT.\n * @param {!(Array.<number>|Uint8Array)} litlenLengths リテラルと長さ符号の符号長配列.\n * @param {number} hdist HDIST.\n * @param {!(Array.<number>|Uint8Array)} distLengths 距離符号の符号長配列.\n * @return {{\n *   codes: !(Array.<number>|Uint32Array),\n *   freqs: !(Array.<number>|Uint8Array)\n * }} Tree-Transmit Symbols.\n */\nZlib.RawDeflate.prototype.getTreeSymbols_ =\nfunction(hlit, litlenLengths, hdist, distLengths) {\n  var src = new (USE_TYPEDARRAY ? Uint32Array : Array)(hlit + hdist),\n      i, j, runLength, l,\n      result = new (USE_TYPEDARRAY ? Uint32Array : Array)(286 + 30),\n      nResult,\n      rpt,\n      freqs = new (USE_TYPEDARRAY ? Uint8Array : Array)(19);\n\n  j = 0;\n  for (i = 0; i < hlit; i++) {\n    src[j++] = litlenLengths[i];\n  }\n  for (i = 0; i < hdist; i++) {\n    src[j++] = distLengths[i];\n  }\n\n  // 初期化\n  if (!USE_TYPEDARRAY) {\n    for (i = 0, l = freqs.length; i < l; ++i) {\n      freqs[i] = 0;\n    }\n  }\n\n  // 符号化\n  nResult = 0;\n  for (i = 0, l = src.length; i < l; i += j) {\n    // Run Length Encoding\n    for (j = 1; i + j < l && src[i + j] === src[i]; ++j) {}\n\n    runLength = j;\n\n    if (src[i] === 0) {\n      // 0 の繰り返しが 3 回未満ならばそのまま\n      if (runLength < 3) {\n        while (runLength-- > 0) {\n          result[nResult++] = 0;\n          freqs[0]++;\n        }\n      } else {\n        while (runLength > 0) {\n          // 繰り返しは最大 138 までなので切り詰める\n          rpt = (runLength < 138 ? runLength : 138);\n\n          if (rpt > runLength - 3 && rpt < runLength) {\n            rpt = runLength - 3;\n          }\n\n          // 3-10 回 -> 17\n          if (rpt <= 10) {\n            result[nResult++] = 17;\n            result[nResult++] = rpt - 3;\n            freqs[17]++;\n          // 11-138 回 -> 18\n          } else {\n            result[nResult++] = 18;\n            result[nResult++] = rpt - 11;\n            freqs[18]++;\n          }\n\n          runLength -= rpt;\n        }\n      }\n    } else {\n      result[nResult++] = src[i];\n      freqs[src[i]]++;\n      runLength--;\n\n      // 繰り返し回数が3回未満ならばランレングス符号は要らない\n      if (runLength < 3) {\n        while (runLength-- > 0) {\n          result[nResult++] = src[i];\n          freqs[src[i]]++;\n        }\n      // 3 回以上ならばランレングス符号化\n      } else {\n        while (runLength > 0) {\n          // runLengthを 3-6 で分割\n          rpt = (runLength < 6 ? runLength : 6);\n\n          if (rpt > runLength - 3 && rpt < runLength) {\n            rpt = runLength - 3;\n          }\n\n          result[nResult++] = 16;\n          result[nResult++] = rpt - 3;\n          freqs[16]++;\n\n          runLength -= rpt;\n        }\n      }\n    }\n  }\n\n  return {\n    codes:\n      USE_TYPEDARRAY ? result.subarray(0, nResult) : result.slice(0, nResult),\n    freqs: freqs\n  };\n};\n\n/**\n * ハフマン符号の長さを取得する\n * @param {!(Array.<number>|Uint8Array|Uint32Array)} freqs 出現カウント.\n * @param {number} limit 符号長の制限.\n * @return {!(Array.<number>|Uint8Array)} 符号長配列.\n * @private\n */\nZlib.RawDeflate.prototype.getLengths_ = function(freqs, limit) {\n  /** @type {number} */\n  var nSymbols = freqs.length;\n  /** @type {Zlib.Heap} */\n  var heap = new Zlib.Heap(2 * Zlib.RawDeflate.HUFMAX);\n  /** @type {!(Array.<number>|Uint8Array)} */\n  var length = new (USE_TYPEDARRAY ? Uint8Array : Array)(nSymbols);\n  /** @type {Array} */\n  var nodes;\n  /** @type {!(Array.<number>|Uint32Array)} */\n  var values;\n  /** @type {!(Array.<number>|Uint8Array)} */\n  var codeLength;\n  /** @type {number} */\n  var i;\n  /** @type {number} */\n  var il;\n\n  // 配列の初期化\n  if (!USE_TYPEDARRAY) {\n    for (i = 0; i < nSymbols; i++) {\n      length[i] = 0;\n    }\n  }\n\n  // ヒープの構築\n  for (i = 0; i < nSymbols; ++i) {\n    if (freqs[i] > 0) {\n      heap.push(i, freqs[i]);\n    }\n  }\n  nodes = new Array(heap.length / 2);\n  values = new (USE_TYPEDARRAY ? Uint32Array : Array)(heap.length / 2);\n\n  // 非 0 の要素が一つだけだった場合は、そのシンボルに符号長 1 を割り当てて終了\n  if (nodes.length === 1) {\n    length[heap.pop().index] = 1;\n    return length;\n  }\n\n  // Reverse Package Merge Algorithm による Canonical Huffman Code の符号長決定\n  for (i = 0, il = heap.length / 2; i < il; ++i) {\n    nodes[i] = heap.pop();\n    values[i] = nodes[i].value;\n  }\n  codeLength = this.reversePackageMerge_(values, values.length, limit);\n\n  for (i = 0, il = nodes.length; i < il; ++i) {\n    length[nodes[i].index] = codeLength[i];\n  }\n\n  return length;\n};\n\n/**\n * Reverse Package Merge Algorithm.\n * @param {!(Array.<number>|Uint32Array)} freqs sorted probability.\n * @param {number} symbols number of symbols.\n * @param {number} limit code length limit.\n * @return {!(Array.<number>|Uint8Array)} code lengths.\n */\nZlib.RawDeflate.prototype.reversePackageMerge_ = function(freqs, symbols, limit) {\n  /** @type {!(Array.<number>|Uint16Array)} */\n  var minimumCost = new (USE_TYPEDARRAY ? Uint16Array : Array)(limit);\n  /** @type {!(Array.<number>|Uint8Array)} */\n  var flag = new (USE_TYPEDARRAY ? Uint8Array : Array)(limit);\n  /** @type {!(Array.<number>|Uint8Array)} */\n  var codeLength = new (USE_TYPEDARRAY ? Uint8Array : Array)(symbols);\n  /** @type {Array} */\n  var value = new Array(limit);\n  /** @type {Array} */\n  var type  = new Array(limit);\n  /** @type {Array.<number>} */\n  var currentPosition = new Array(limit);\n  /** @type {number} */\n  var excess = (1 << limit) - symbols;\n  /** @type {number} */\n  var half = (1 << (limit - 1));\n  /** @type {number} */\n  var i;\n  /** @type {number} */\n  var j;\n  /** @type {number} */\n  var t;\n  /** @type {number} */\n  var weight;\n  /** @type {number} */\n  var next;\n\n  /**\n   * @param {number} j\n   */\n  function takePackage(j) {\n    /** @type {number} */\n    var x = type[j][currentPosition[j]];\n\n    if (x === symbols) {\n      takePackage(j+1);\n      takePackage(j+1);\n    } else {\n      --codeLength[x];\n    }\n\n    ++currentPosition[j];\n  }\n\n  minimumCost[limit-1] = symbols;\n\n  for (j = 0; j < limit; ++j) {\n    if (excess < half) {\n      flag[j] = 0;\n    } else {\n      flag[j] = 1;\n      excess -= half;\n    }\n    excess <<= 1;\n    minimumCost[limit-2-j] = (minimumCost[limit-1-j] / 2 | 0) + symbols;\n  }\n  minimumCost[0] = flag[0];\n\n  value[0] = new Array(minimumCost[0]);\n  type[0]  = new Array(minimumCost[0]);\n  for (j = 1; j < limit; ++j) {\n    if (minimumCost[j] > 2 * minimumCost[j-1] + flag[j]) {\n      minimumCost[j] = 2 * minimumCost[j-1] + flag[j];\n    }\n    value[j] = new Array(minimumCost[j]);\n    type[j]  = new Array(minimumCost[j]);\n  }\n\n  for (i = 0; i < symbols; ++i) {\n    codeLength[i] = limit;\n  }\n\n  for (t = 0; t < minimumCost[limit-1]; ++t) {\n    value[limit-1][t] = freqs[t];\n    type[limit-1][t]  = t;\n  }\n\n  for (i = 0; i < limit; ++i) {\n    currentPosition[i] = 0;\n  }\n  if (flag[limit-1] === 1) {\n    --codeLength[0];\n    ++currentPosition[limit-1];\n  }\n\n  for (j = limit-2; j >= 0; --j) {\n    i = 0;\n    weight = 0;\n    next = currentPosition[j+1];\n\n    for (t = 0; t < minimumCost[j]; t++) {\n      weight = value[j+1][next] + value[j+1][next+1];\n\n      if (weight > freqs[i]) {\n        value[j][t] = weight;\n        type[j][t] = symbols;\n        next += 2;\n      } else {\n        value[j][t] = freqs[i];\n        type[j][t] = i;\n        ++i;\n      }\n    }\n\n    currentPosition[j] = 0;\n    if (flag[j] === 1) {\n      takePackage(j);\n    }\n  }\n\n  return codeLength;\n};\n\n/**\n * 符号長配列からハフマン符号を取得する\n * reference: PuTTY Deflate implementation\n * @param {!(Array.<number>|Uint8Array)} lengths 符号長配列.\n * @return {!(Array.<number>|Uint16Array)} ハフマン符号配列.\n * @private\n */\nZlib.RawDeflate.prototype.getCodesFromLengths_ = function(lengths) {\n  var codes = new (USE_TYPEDARRAY ? Uint16Array : Array)(lengths.length),\n      count = [],\n      startCode = [],\n      code = 0, i, il, j, m;\n\n  // Count the codes of each length.\n  for (i = 0, il = lengths.length; i < il; i++) {\n    count[lengths[i]] = (count[lengths[i]] | 0) + 1;\n  }\n\n  // Determine the starting code for each length block.\n  for (i = 1, il = Zlib.RawDeflate.MaxCodeLength; i <= il; i++) {\n    startCode[i] = code;\n    code += count[i] | 0;\n    code <<= 1;\n  }\n\n  // Determine the code for each symbol. Mirrored, of course.\n  for (i = 0, il = lengths.length; i < il; i++) {\n    code = startCode[lengths[i]];\n    startCode[lengths[i]] += 1;\n    codes[i] = 0;\n\n    for (j = 0, m = lengths[i]; j < m; j++) {\n      codes[i] = (codes[i] << 1) | (code & 1);\n      code >>>= 1;\n    }\n  }\n\n  return codes;\n};\n\n// end of scope\n});\n\n/* vim:set expandtab ts=2 sw=2 tw=80: */\n","/**\n * @fileoverview GZIP (RFC1952) 実装.\n */\ngoog.provide('Zlib.Gzip');\n\ngoog.require('USE_TYPEDARRAY');\ngoog.require('Zlib.CRC32');\ngoog.require('Zlib.RawDeflate');\n\ngoog.scope(function() {\n\n/**\n * @constructor\n * @param {!(Array|Uint8Array)} input input buffer.\n * @param {Object=} opt_params option parameters.\n */\nZlib.Gzip = function(input, opt_params) {\n  /** @type {!(Array.<number>|Uint8Array)} input buffer. */\n  this.input = input;\n  /** @type {number} input buffer pointer. */\n  this.ip = 0;\n  /** @type {!(Array.<number>|Uint8Array)} output buffer. */\n  this.output;\n  /** @type {number} output buffer. */\n  this.op = 0;\n  /** @type {!Object} flags option flags. */\n  this.flags = {};\n  /** @type {!string} filename. */\n  this.filename;\n  /** @type {!string} comment. */\n  this.comment;\n  /** @type {!Object} deflate options. */\n  this.deflateOptions;\n\n  // option parameters\n  if (opt_params) {\n    if (opt_params['flags']) {\n      this.flags = opt_params['flags'];\n    }\n    if (typeof opt_params['filename'] === 'string') {\n      this.filename = opt_params['filename'];\n    }\n    if (typeof opt_params['comment'] === 'string') {\n      this.comment = opt_params['comment'];\n    }\n    if (opt_params['deflateOptions']) {\n      this.deflateOptions = opt_params['deflateOptions'];\n    }\n  }\n\n  if (!this.deflateOptions) {\n    this.deflateOptions = {};\n  }\n};\n\n/**\n * @type {number}\n * @const\n */\nZlib.Gzip.DefaultBufferSize = 0x8000;\n\n/**\n * encode gzip members.\n * @return {!(Array|Uint8Array)} gzip binary array.\n */\nZlib.Gzip.prototype.compress = function() {\n  /** @type {number} flags. */\n  var flg;\n  /** @type {number} modification time. */\n  var mtime;\n  /** @type {number} CRC-16 value for FHCRC flag. */\n  var crc16;\n  /** @type {number} CRC-32 value for verification. */\n  var crc32;\n  /** @type {!Zlib.RawDeflate} raw deflate object. */\n  var rawdeflate;\n  /** @type {number} character code */\n  var c;\n  /** @type {number} loop counter. */\n  var i;\n  /** @type {number} loop limiter. */\n  var il;\n  /** @type {!(Array|Uint8Array)} output buffer. */\n  var output =\n    new (USE_TYPEDARRAY ? Uint8Array : Array)(Zlib.Gzip.DefaultBufferSize);\n  /** @type {number} output buffer pointer. */\n  var op = 0;\n\n  var input = this.input;\n  var ip = this.ip;\n  var filename = this.filename;\n  var comment = this.comment;\n\n  // check signature\n  output[op++] = 0x1f;\n  output[op++] = 0x8b;\n\n  // check compression method\n  output[op++] = 8; /* XXX: use Zlib const */\n\n  // flags\n  flg = 0;\n  if (this.flags['fname'])    flg |= Zlib.Gzip.FlagsMask.FNAME;\n  if (this.flags['fcomment']) flg |= Zlib.Gzip.FlagsMask.FCOMMENT;\n  if (this.flags['fhcrc'])    flg |= Zlib.Gzip.FlagsMask.FHCRC;\n  // XXX: FTEXT\n  // XXX: FEXTRA\n  output[op++] = flg;\n\n  // modification time\n  mtime = (Date.now ? Date.now() : +new Date()) / 1000 | 0;\n  output[op++] = mtime        & 0xff;\n  output[op++] = mtime >>>  8 & 0xff;\n  output[op++] = mtime >>> 16 & 0xff;\n  output[op++] = mtime >>> 24 & 0xff;\n\n  // extra flags\n  output[op++] = 0;\n\n  // operating system\n  output[op++] = Zlib.Gzip.OperatingSystem.UNKNOWN;\n\n  // extra\n  /* NOP */\n\n  // fname\n  if (this.flags['fname'] !== void 0) {\n    for (i = 0, il = filename.length; i < il; ++i) {\n      c = filename.charCodeAt(i);\n      if (c > 0xff) { output[op++] = (c >>> 8) & 0xff; }\n      output[op++] = c & 0xff;\n    }\n    output[op++] = 0; // null termination\n  }\n\n  // fcomment\n  if (this.flags['comment']) {\n    for (i = 0, il = comment.length; i < il; ++i) {\n      c = comment.charCodeAt(i);\n      if (c > 0xff) { output[op++] = (c >>> 8) & 0xff; }\n      output[op++] = c & 0xff;\n    }\n    output[op++] = 0; // null termination\n  }\n\n  // fhcrc\n  if (this.flags['fhcrc']) {\n    crc16 = Zlib.CRC32.calc(output, 0, op) & 0xffff;\n    output[op++] = (crc16      ) & 0xff;\n    output[op++] = (crc16 >>> 8) & 0xff;\n  }\n\n  // add compress option\n  this.deflateOptions['outputBuffer'] = output;\n  this.deflateOptions['outputIndex'] = op;\n\n  // compress\n  rawdeflate = new Zlib.RawDeflate(input, this.deflateOptions);\n  output = rawdeflate.compress();\n  op = rawdeflate.op;\n\n  // expand buffer\n  if (USE_TYPEDARRAY) {\n    if (op + 8 > output.buffer.byteLength) {\n      this.output = new Uint8Array(op + 8);\n      this.output.set(new Uint8Array(output.buffer));\n      output = this.output;\n    } else {\n      output = new Uint8Array(output.buffer);\n    }\n  }\n\n  // crc32\n  crc32 = Zlib.CRC32.calc(input);\n  output[op++] = (crc32       ) & 0xff;\n  output[op++] = (crc32 >>>  8) & 0xff;\n  output[op++] = (crc32 >>> 16) & 0xff;\n  output[op++] = (crc32 >>> 24) & 0xff;\n\n  // input size\n  il = input.length;\n  output[op++] = (il       ) & 0xff;\n  output[op++] = (il >>>  8) & 0xff;\n  output[op++] = (il >>> 16) & 0xff;\n  output[op++] = (il >>> 24) & 0xff;\n\n  this.ip = ip;\n\n  if (USE_TYPEDARRAY && op < output.length) {\n    this.output = output = output.subarray(0, op);\n  }\n\n  return output;\n};\n\n/** @enum {number} */\nZlib.Gzip.OperatingSystem = {\n  FAT: 0,\n  AMIGA: 1,\n  VMS: 2,\n  UNIX: 3,\n  VM_CMS: 4,\n  ATARI_TOS: 5,\n  HPFS: 6,\n  MACINTOSH: 7,\n  Z_SYSTEM: 8,\n  CP_M: 9,\n  TOPS_20: 10,\n  NTFS: 11,\n  QDOS: 12,\n  ACORN_RISCOS: 13,\n  UNKNOWN: 255\n};\n\n/** @enum {number} */\nZlib.Gzip.FlagsMask = {\n  FTEXT: 0x01,\n  FHCRC: 0x02,\n  FEXTRA: 0x04,\n  FNAME: 0x08,\n  FCOMMENT: 0x10\n};\n\n});\n/* vim:set expandtab ts=2 sw=2 tw=80: */\n","goog.provide('Zlib.RawInflate');\n\ngoog.require('USE_TYPEDARRAY');\ngoog.require('Zlib.Huffman');\n\n//-----------------------------------------------------------------------------\n\n/** @define {number} buffer block size. */\nvar ZLIB_RAW_INFLATE_BUFFER_SIZE = 0x8000; // [ 0x8000 >= ZLIB_BUFFER_BLOCK_SIZE ]\n\n//-----------------------------------------------------------------------------\n\ngoog.scope(function() {\n\nvar buildHuffmanTable = Zlib.Huffman.buildHuffmanTable;\n\n/**\n * @constructor\n * @param {!(Uint8Array|Array.<number>)} input input buffer.\n * @param {Object} opt_params option parameter.\n *\n * opt_params は以下のプロパティを指定する事ができます。\n *   - index: input buffer の deflate コンテナの開始位置.\n *   - blockSize: バッファのブロックサイズ.\n *   - bufferType: Zlib.RawInflate.BufferType の値によってバッファの管理方法を指定する.\n *   - resize: 確保したバッファが実際の大きさより大きかった場合に切り詰める.\n */\nZlib.RawInflate = function(input, opt_params) {\n  /** @type {!(Array.<number>|Uint8Array)} inflated buffer */\n  this.buffer;\n  /** @type {!Array.<(Array.<number>|Uint8Array)>} */\n  this.blocks = [];\n  /** @type {number} block size. */\n  this.bufferSize = ZLIB_RAW_INFLATE_BUFFER_SIZE;\n  /** @type {!number} total output buffer pointer. */\n  this.totalpos = 0;\n  /** @type {!number} input buffer pointer. */\n  this.ip = 0;\n  /** @type {!number} bit stream reader buffer. */\n  this.bitsbuf = 0;\n  /** @type {!number} bit stream reader buffer size. */\n  this.bitsbuflen = 0;\n  /** @type {!(Array.<number>|Uint8Array)} input buffer. */\n  this.input = USE_TYPEDARRAY ? new Uint8Array(input) : input;\n  /** @type {!(Uint8Array|Array.<number>)} output buffer. */\n  this.output;\n  /** @type {!number} output buffer pointer. */\n  this.op;\n  /** @type {boolean} is final block flag. */\n  this.bfinal = false;\n  /** @type {Zlib.RawInflate.BufferType} buffer management. */\n  this.bufferType = Zlib.RawInflate.BufferType.ADAPTIVE;\n  /** @type {boolean} resize flag for memory size optimization. */\n  this.resize = false;\n\n  // option parameters\n  if (opt_params || !(opt_params = {})) {\n    if (opt_params['index']) {\n      this.ip = opt_params['index'];\n    }\n    if (opt_params['bufferSize']) {\n      this.bufferSize = opt_params['bufferSize'];\n    }\n    if (opt_params['bufferType']) {\n      this.bufferType = opt_params['bufferType'];\n    }\n    if (opt_params['resize']) {\n      this.resize = opt_params['resize'];\n    }\n  }\n\n  // initialize\n  switch (this.bufferType) {\n    case Zlib.RawInflate.BufferType.BLOCK:\n      this.op = Zlib.RawInflate.MaxBackwardLength;\n      this.output =\n        new (USE_TYPEDARRAY ? Uint8Array : Array)(\n          Zlib.RawInflate.MaxBackwardLength +\n          this.bufferSize +\n          Zlib.RawInflate.MaxCopyLength\n        );\n      break;\n    case Zlib.RawInflate.BufferType.ADAPTIVE:\n      this.op = 0;\n      this.output = new (USE_TYPEDARRAY ? Uint8Array : Array)(this.bufferSize);\n      this.expandBuffer = this.expandBufferAdaptive;\n      this.concatBuffer = this.concatBufferDynamic;\n      this.decodeHuffman = this.decodeHuffmanAdaptive;\n      break;\n    default:\n      throw new Error('invalid inflate mode');\n  }\n};\n\n/**\n * @enum {number}\n */\nZlib.RawInflate.BufferType = {\n  BLOCK: 0,\n  ADAPTIVE: 1\n};\n\n/**\n * decompress.\n * @return {!(Uint8Array|Array.<number>)} inflated buffer.\n */\nZlib.RawInflate.prototype.decompress = function() {\n  while (!this.bfinal) {\n    this.parseBlock();\n  }\n\n  return this.concatBuffer();\n};\n\n/**\n * @const\n * @type {number} max backward length for LZ77.\n */\nZlib.RawInflate.MaxBackwardLength = 32768;\n\n/**\n * @const\n * @type {number} max copy length for LZ77.\n */\nZlib.RawInflate.MaxCopyLength = 258;\n\n/**\n * huffman order\n * @const\n * @type {!(Array.<number>|Uint8Array)}\n */\nZlib.RawInflate.Order = (function(table) {\n  return USE_TYPEDARRAY ? new Uint16Array(table) : table;\n})([16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15]);\n\n/**\n * huffman length code table.\n * @const\n * @type {!(Array.<number>|Uint16Array)}\n */\nZlib.RawInflate.LengthCodeTable = (function(table) {\n  return USE_TYPEDARRAY ? new Uint16Array(table) : table;\n})([\n  0x0003, 0x0004, 0x0005, 0x0006, 0x0007, 0x0008, 0x0009, 0x000a, 0x000b,\n  0x000d, 0x000f, 0x0011, 0x0013, 0x0017, 0x001b, 0x001f, 0x0023, 0x002b,\n  0x0033, 0x003b, 0x0043, 0x0053, 0x0063, 0x0073, 0x0083, 0x00a3, 0x00c3,\n  0x00e3, 0x0102, 0x0102, 0x0102\n]);\n\n/**\n * huffman length extra-bits table.\n * @const\n * @type {!(Array.<number>|Uint8Array)}\n */\nZlib.RawInflate.LengthExtraTable = (function(table) {\n  return USE_TYPEDARRAY ? new Uint8Array(table) : table;\n})([\n  0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 2, 2, 2, 2, 3, 3, 3, 3, 4, 4, 4, 4, 5, 5,\n  5, 5, 0, 0, 0\n]);\n\n/**\n * huffman dist code table.\n * @const\n * @type {!(Array.<number>|Uint16Array)}\n */\nZlib.RawInflate.DistCodeTable = (function(table) {\n  return USE_TYPEDARRAY ? new Uint16Array(table) : table;\n})([\n  0x0001, 0x0002, 0x0003, 0x0004, 0x0005, 0x0007, 0x0009, 0x000d, 0x0011,\n  0x0019, 0x0021, 0x0031, 0x0041, 0x0061, 0x0081, 0x00c1, 0x0101, 0x0181,\n  0x0201, 0x0301, 0x0401, 0x0601, 0x0801, 0x0c01, 0x1001, 0x1801, 0x2001,\n  0x3001, 0x4001, 0x6001\n]);\n\n/**\n * huffman dist extra-bits table.\n * @const\n * @type {!(Array.<number>|Uint8Array)}\n */\nZlib.RawInflate.DistExtraTable = (function(table) {\n  return USE_TYPEDARRAY ? new Uint8Array(table) : table;\n})([\n  0, 0, 0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11,\n  11, 12, 12, 13, 13\n]);\n\n/**\n * fixed huffman length code table\n * @const\n * @type {!Array}\n */\nZlib.RawInflate.FixedLiteralLengthTable = (function(table) {\n  return table;\n})((function() {\n  var lengths = new (USE_TYPEDARRAY ? Uint8Array : Array)(288);\n  var i, il;\n\n  for (i = 0, il = lengths.length; i < il; ++i) {\n    lengths[i] =\n      (i <= 143) ? 8 :\n      (i <= 255) ? 9 :\n      (i <= 279) ? 7 :\n      8;\n  }\n\n  return buildHuffmanTable(lengths);\n})());\n\n/**\n * fixed huffman distance code table\n * @const\n * @type {!Array}\n */\nZlib.RawInflate.FixedDistanceTable = (function(table) {\n  return table;\n})((function() {\n  var lengths = new (USE_TYPEDARRAY ? Uint8Array : Array)(30);\n  var i, il;\n\n  for (i = 0, il = lengths.length; i < il; ++i) {\n    lengths[i] = 5;\n  }\n\n  return buildHuffmanTable(lengths);\n})());\n\n/**\n * parse deflated block.\n */\nZlib.RawInflate.prototype.parseBlock = function() {\n  /** @type {number} header */\n  var hdr = this.readBits(3);\n\n  // BFINAL\n  if (hdr & 0x1) {\n    this.bfinal = true;\n  }\n\n  // BTYPE\n  hdr >>>= 1;\n  switch (hdr) {\n    // uncompressed\n    case 0:\n      this.parseUncompressedBlock();\n      break;\n    // fixed huffman\n    case 1:\n      this.parseFixedHuffmanBlock();\n      break;\n    // dynamic huffman\n    case 2:\n      this.parseDynamicHuffmanBlock();\n      break;\n    // reserved or other\n    default:\n      throw new Error('unknown BTYPE: ' + hdr);\n  }\n};\n\n/**\n * read inflate bits\n * @param {number} length bits length.\n * @return {number} read bits.\n */\nZlib.RawInflate.prototype.readBits = function(length) {\n  var bitsbuf = this.bitsbuf;\n  var bitsbuflen = this.bitsbuflen;\n  var input = this.input;\n  var ip = this.ip;\n\n  /** @type {number} */\n  var inputLength = input.length;\n  /** @type {number} input and output byte. */\n  var octet;\n\n  // not enough buffer\n  while (bitsbuflen < length) {\n    // input byte\n    if (ip >= inputLength) {\n      throw new Error('input buffer is broken');\n    }\n\n    // concat octet\n    bitsbuf |= input[ip++] << bitsbuflen;\n    bitsbuflen += 8;\n  }\n\n  // output byte\n  octet = bitsbuf & /* MASK */ ((1 << length) - 1);\n  bitsbuf >>>= length;\n  bitsbuflen -= length;\n\n  this.bitsbuf = bitsbuf;\n  this.bitsbuflen = bitsbuflen;\n  this.ip = ip;\n\n  return octet;\n};\n\n/**\n * read huffman code using table\n * @param {!(Array.<number>|Uint8Array|Uint16Array)} table huffman code table.\n * @return {number} huffman code.\n */\nZlib.RawInflate.prototype.readCodeByTable = function(table) {\n  var bitsbuf = this.bitsbuf;\n  var bitsbuflen = this.bitsbuflen;\n  var input = this.input;\n  var ip = this.ip;\n\n  /** @type {number} */\n  var inputLength = input.length;\n  /** @type {!(Array.<number>|Uint8Array)} huffman code table */\n  var codeTable = table[0];\n  /** @type {number} */\n  var maxCodeLength = table[1];\n  /** @type {number} code length & code (16bit, 16bit) */\n  var codeWithLength;\n  /** @type {number} code bits length */\n  var codeLength;\n\n  // not enough buffer\n  while (bitsbuflen < maxCodeLength) {\n    if (ip >= inputLength) {\n      break;\n    }\n    bitsbuf |= input[ip++] << bitsbuflen;\n    bitsbuflen += 8;\n  }\n\n  // read max length\n  codeWithLength = codeTable[bitsbuf & ((1 << maxCodeLength) - 1)];\n  codeLength = codeWithLength >>> 16;\n\n  if (codeLength > bitsbuflen) {\n    throw new Error('invalid code length: ' + codeLength);\n  }\n\n  this.bitsbuf = bitsbuf >> codeLength;\n  this.bitsbuflen = bitsbuflen - codeLength;\n  this.ip = ip;\n\n  return codeWithLength & 0xffff;\n};\n\n/**\n * parse uncompressed block.\n */\nZlib.RawInflate.prototype.parseUncompressedBlock = function() {\n  var input = this.input;\n  var ip = this.ip;\n  var output = this.output;\n  var op = this.op;\n\n  /** @type {number} */\n  var inputLength = input.length;\n  /** @type {number} block length */\n  var len;\n  /** @type {number} number for check block length */\n  var nlen;\n  /** @type {number} output buffer length */\n  var olength = output.length;\n  /** @type {number} copy counter */\n  var preCopy;\n\n  // skip buffered header bits\n  this.bitsbuf = 0;\n  this.bitsbuflen = 0;\n\n  // len\n  if (ip + 1 >= inputLength) {\n    throw new Error('invalid uncompressed block header: LEN');\n  }\n  len = input[ip++] | (input[ip++] << 8);\n\n  // nlen\n  if (ip + 1 >= inputLength) {\n    throw new Error('invalid uncompressed block header: NLEN');\n  }\n  nlen = input[ip++] | (input[ip++] << 8);\n\n  // check len & nlen\n  if (len === ~nlen) {\n    throw new Error('invalid uncompressed block header: length verify');\n  }\n\n  // check size\n  if (ip + len > input.length) { throw new Error('input buffer is broken'); }\n\n  // expand buffer\n  switch (this.bufferType) {\n    case Zlib.RawInflate.BufferType.BLOCK:\n      // pre copy\n      while (op + len > output.length) {\n        preCopy = olength - op;\n        len -= preCopy;\n        if (USE_TYPEDARRAY) {\n          output.set(input.subarray(ip, ip + preCopy), op);\n          op += preCopy;\n          ip += preCopy;\n        } else {\n          while (preCopy--) {\n            output[op++] = input[ip++];\n          }\n        }\n        this.op = op;\n        output = this.expandBuffer();\n        op = this.op;\n      }\n      break;\n    case Zlib.RawInflate.BufferType.ADAPTIVE:\n      while (op + len > output.length) {\n        output = this.expandBuffer({fixRatio: 2});\n      }\n      break;\n    default:\n      throw new Error('invalid inflate mode');\n  }\n\n  // copy\n  if (USE_TYPEDARRAY) {\n    output.set(input.subarray(ip, ip + len), op);\n    op += len;\n    ip += len;\n  } else {\n    while (len--) {\n      output[op++] = input[ip++];\n    }\n  }\n\n  this.ip = ip;\n  this.op = op;\n  this.output = output;\n};\n\n/**\n * parse fixed huffman block.\n */\nZlib.RawInflate.prototype.parseFixedHuffmanBlock = function() {\n  this.decodeHuffman(\n    Zlib.RawInflate.FixedLiteralLengthTable,\n    Zlib.RawInflate.FixedDistanceTable\n  );\n};\n\n/**\n * parse dynamic huffman block.\n */\nZlib.RawInflate.prototype.parseDynamicHuffmanBlock = function() {\n  /** @type {number} number of literal and length codes. */\n  var hlit = this.readBits(5) + 257;\n  /** @type {number} number of distance codes. */\n  var hdist = this.readBits(5) + 1;\n  /** @type {number} number of code lengths. */\n  var hclen = this.readBits(4) + 4;\n  /** @type {!(Uint8Array|Array.<number>)} code lengths. */\n  var codeLengths =\n    new (USE_TYPEDARRAY ? Uint8Array : Array)(Zlib.RawInflate.Order.length);\n  /** @type {!Array} code lengths table. */\n  var codeLengthsTable;\n  /** @type {!(Uint8Array|Array.<number>)} literal and length code table. */\n  var litlenTable;\n  /** @type {!(Uint8Array|Array.<number>)} distance code table. */\n  var distTable;\n  /** @type {!(Uint8Array|Array.<number>)} code length table. */\n  var lengthTable;\n  /** @type {number} */\n  var code;\n  /** @type {number} */\n  var prev;\n  /** @type {number} */\n  var repeat;\n  /** @type {number} loop counter. */\n  var i;\n  /** @type {number} loop limit. */\n  var il;\n\n  // decode code lengths\n  for (i = 0; i < hclen; ++i) {\n    codeLengths[Zlib.RawInflate.Order[i]] = this.readBits(3);\n  }\n  if (!USE_TYPEDARRAY) {\n    for (i = hclen, hclen = codeLengths.length; i < hclen; ++i) {\n      codeLengths[Zlib.RawInflate.Order[i]] = 0;\n    }\n  }\n\n  // decode length table\n  codeLengthsTable = buildHuffmanTable(codeLengths);\n  lengthTable = new (USE_TYPEDARRAY ? Uint8Array : Array)(hlit + hdist);\n  for (i = 0, il = hlit + hdist; i < il;) {\n    code = this.readCodeByTable(codeLengthsTable);\n    switch (code) {\n      case 16:\n        repeat = 3 + this.readBits(2);\n        while (repeat--) { lengthTable[i++] = prev; }\n        break;\n      case 17:\n        repeat = 3 + this.readBits(3);\n        while (repeat--) { lengthTable[i++] = 0; }\n        prev = 0;\n        break;\n      case 18:\n        repeat = 11 + this.readBits(7);\n        while (repeat--) { lengthTable[i++] = 0; }\n        prev = 0;\n        break;\n      default:\n        lengthTable[i++] = code;\n        prev = code;\n        break;\n    }\n  }\n\n  litlenTable = USE_TYPEDARRAY\n    ? buildHuffmanTable(lengthTable.subarray(0, hlit))\n    : buildHuffmanTable(lengthTable.slice(0, hlit));\n  distTable = USE_TYPEDARRAY\n    ? buildHuffmanTable(lengthTable.subarray(hlit))\n    : buildHuffmanTable(lengthTable.slice(hlit));\n\n  this.decodeHuffman(litlenTable, distTable);\n};\n\n/**\n * decode huffman code\n * @param {!(Array.<number>|Uint16Array)} litlen literal and length code table.\n * @param {!(Array.<number>|Uint8Array)} dist distination code table.\n */\nZlib.RawInflate.prototype.decodeHuffman = function(litlen, dist) {\n  var output = this.output;\n  var op = this.op;\n\n  this.currentLitlenTable = litlen;\n\n  /** @type {number} output position limit. */\n  var olength = output.length - Zlib.RawInflate.MaxCopyLength;\n  /** @type {number} huffman code. */\n  var code;\n  /** @type {number} table index. */\n  var ti;\n  /** @type {number} huffman code distination. */\n  var codeDist;\n  /** @type {number} huffman code length. */\n  var codeLength;\n\n  while ((code = this.readCodeByTable(litlen)) !== 256) {\n    // literal\n    if (code < 256) {\n      if (op >= olength) {\n        this.op = op;\n        output = this.expandBuffer();\n        op = this.op;\n      }\n      output[op++] = code;\n\n      continue;\n    }\n\n    // length code\n    ti = code - 257;\n    codeLength = Zlib.RawInflate.LengthCodeTable[ti];\n    if (Zlib.RawInflate.LengthExtraTable[ti] > 0) {\n      codeLength += this.readBits(Zlib.RawInflate.LengthExtraTable[ti]);\n    }\n\n    // dist code\n    code = this.readCodeByTable(dist);\n    codeDist = Zlib.RawInflate.DistCodeTable[code];\n    if (Zlib.RawInflate.DistExtraTable[code] > 0) {\n      codeDist += this.readBits(Zlib.RawInflate.DistExtraTable[code]);\n    }\n\n    // lz77 decode\n    if (op >= olength) {\n      this.op = op;\n      output = this.expandBuffer();\n      op = this.op;\n    }\n    while (codeLength--) {\n      output[op] = output[(op++) - codeDist];\n    }\n  }\n\n  while (this.bitsbuflen >= 8) {\n    this.bitsbuflen -= 8;\n    this.ip--;\n  }\n  this.op = op;\n};\n\n/**\n * decode huffman code (adaptive)\n * @param {!(Array.<number>|Uint16Array)} litlen literal and length code table.\n * @param {!(Array.<number>|Uint8Array)} dist distination code table.\n */\nZlib.RawInflate.prototype.decodeHuffmanAdaptive = function(litlen, dist) {\n  var output = this.output;\n  var op = this.op;\n\n  this.currentLitlenTable = litlen;\n\n  /** @type {number} output position limit. */\n  var olength = output.length;\n  /** @type {number} huffman code. */\n  var code;\n  /** @type {number} table index. */\n  var ti;\n  /** @type {number} huffman code distination. */\n  var codeDist;\n  /** @type {number} huffman code length. */\n  var codeLength;\n\n  while ((code = this.readCodeByTable(litlen)) !== 256) {\n    // literal\n    if (code < 256) {\n      if (op >= olength) {\n        output = this.expandBuffer();\n        olength = output.length;\n      }\n      output[op++] = code;\n\n      continue;\n    }\n\n    // length code\n    ti = code - 257;\n    codeLength = Zlib.RawInflate.LengthCodeTable[ti];\n    if (Zlib.RawInflate.LengthExtraTable[ti] > 0) {\n      codeLength += this.readBits(Zlib.RawInflate.LengthExtraTable[ti]);\n    }\n\n    // dist code\n    code = this.readCodeByTable(dist);\n    codeDist = Zlib.RawInflate.DistCodeTable[code];\n    if (Zlib.RawInflate.DistExtraTable[code] > 0) {\n      codeDist += this.readBits(Zlib.RawInflate.DistExtraTable[code]);\n    }\n\n    // lz77 decode\n    if (op + codeLength > olength) {\n      output = this.expandBuffer();\n      olength = output.length;\n    }\n    while (codeLength--) {\n      output[op] = output[(op++) - codeDist];\n    }\n  }\n\n  while (this.bitsbuflen >= 8) {\n    this.bitsbuflen -= 8;\n    this.ip--;\n  }\n  this.op = op;\n};\n\n/**\n * expand output buffer.\n * @param {Object=} opt_param option parameters.\n * @return {!(Array.<number>|Uint8Array)} output buffer.\n */\nZlib.RawInflate.prototype.expandBuffer = function(opt_param) {\n  /** @type {!(Array.<number>|Uint8Array)} store buffer. */\n  var buffer =\n    new (USE_TYPEDARRAY ? Uint8Array : Array)(\n        this.op - Zlib.RawInflate.MaxBackwardLength\n    );\n  /** @type {number} backward base point */\n  var backward = this.op - Zlib.RawInflate.MaxBackwardLength;\n  /** @type {number} copy index. */\n  var i;\n  /** @type {number} copy limit */\n  var il;\n\n  var output = this.output;\n\n  // copy to output buffer\n  if (USE_TYPEDARRAY) {\n    buffer.set(output.subarray(Zlib.RawInflate.MaxBackwardLength, buffer.length));\n  } else {\n    for (i = 0, il = buffer.length; i < il; ++i) {\n      buffer[i] = output[i + Zlib.RawInflate.MaxBackwardLength];\n    }\n  }\n\n  this.blocks.push(buffer);\n  this.totalpos += buffer.length;\n\n  // copy to backward buffer\n  if (USE_TYPEDARRAY) {\n    output.set(\n      output.subarray(backward, backward + Zlib.RawInflate.MaxBackwardLength)\n    );\n  } else {\n    for (i = 0; i < Zlib.RawInflate.MaxBackwardLength; ++i) {\n      output[i] = output[backward + i];\n    }\n  }\n\n  this.op = Zlib.RawInflate.MaxBackwardLength;\n\n  return output;\n};\n\n/**\n * expand output buffer. (adaptive)\n * @param {Object=} opt_param option parameters.\n * @return {!(Array.<number>|Uint8Array)} output buffer pointer.\n */\nZlib.RawInflate.prototype.expandBufferAdaptive = function(opt_param) {\n  /** @type {!(Array.<number>|Uint8Array)} store buffer. */\n  var buffer;\n  /** @type {number} expantion ratio. */\n  var ratio = (this.input.length / this.ip + 1) | 0;\n  /** @type {number} maximum number of huffman code. */\n  var maxHuffCode;\n  /** @type {number} new output buffer size. */\n  var newSize;\n  /** @type {number} max inflate size. */\n  var maxInflateSize;\n\n  var input = this.input;\n  var output = this.output;\n\n  if (opt_param) {\n    if (typeof opt_param.fixRatio === 'number') {\n      ratio = opt_param.fixRatio;\n    }\n    if (typeof opt_param.addRatio === 'number') {\n      ratio += opt_param.addRatio;\n    }\n  }\n\n  // calculate new buffer size\n  if (ratio < 2) {\n    maxHuffCode =\n      (input.length - this.ip) / this.currentLitlenTable[2];\n    maxInflateSize = (maxHuffCode / 2 * 258) | 0;\n    newSize = maxInflateSize < output.length ?\n      output.length + maxInflateSize :\n      output.length << 1;\n  } else {\n    newSize = output.length * ratio;\n  }\n\n  // buffer expantion\n  if (USE_TYPEDARRAY) {\n    buffer = new Uint8Array(newSize);\n    buffer.set(output);\n  } else {\n    buffer = output;\n  }\n\n  this.output = buffer;\n\n  return this.output;\n};\n\n/**\n * concat output buffer.\n * @return {!(Array.<number>|Uint8Array)} output buffer.\n */\nZlib.RawInflate.prototype.concatBuffer = function() {\n  /** @type {number} buffer pointer. */\n  var pos = 0;\n  /** @type {number} buffer pointer. */\n  var limit = this.totalpos + (this.op - Zlib.RawInflate.MaxBackwardLength);\n  /** @type {!(Array.<number>|Uint8Array)} output block array. */\n  var output = this.output;\n  /** @type {!Array} blocks array. */\n  var blocks = this.blocks;\n  /** @type {!(Array.<number>|Uint8Array)} output block array. */\n  var block;\n  /** @type {!(Array.<number>|Uint8Array)} output buffer. */\n  var buffer = new (USE_TYPEDARRAY ? Uint8Array : Array)(limit);\n  /** @type {number} loop counter. */\n  var i;\n  /** @type {number} loop limiter. */\n  var il;\n  /** @type {number} loop counter. */\n  var j;\n  /** @type {number} loop limiter. */\n  var jl;\n\n  // single buffer\n  if (blocks.length === 0) {\n    return USE_TYPEDARRAY ?\n      this.output.subarray(Zlib.RawInflate.MaxBackwardLength, this.op) :\n      this.output.slice(Zlib.RawInflate.MaxBackwardLength, this.op);\n  }\n\n  // copy to buffer\n  for (i = 0, il = blocks.length; i < il; ++i) {\n    block = blocks[i];\n    for (j = 0, jl = block.length; j < jl; ++j) {\n      buffer[pos++] = block[j];\n    }\n  }\n\n  // current buffer\n  for (i = Zlib.RawInflate.MaxBackwardLength, il = this.op; i < il; ++i) {\n    buffer[pos++] = output[i];\n  }\n\n  this.blocks = [];\n  this.buffer = buffer;\n\n  return this.buffer;\n};\n\n/**\n * concat output buffer. (dynamic)\n * @return {!(Array.<number>|Uint8Array)} output buffer.\n */\nZlib.RawInflate.prototype.concatBufferDynamic = function() {\n  /** @type {Array.<number>|Uint8Array} output buffer. */\n  var buffer;\n  var op = this.op;\n\n  if (USE_TYPEDARRAY) {\n    if (this.resize) {\n      buffer = new Uint8Array(op);\n      buffer.set(this.output.subarray(0, op));\n    } else {\n      buffer = this.output.subarray(0, op);\n    }\n  } else {\n    if (this.output.length > op) {\n      this.output.length = op;\n    }\n    buffer = this.output;\n  }\n\n  this.buffer = buffer;\n\n  return this.buffer;\n};\n\n// end of scope\n});\n\n/* vim:set expandtab ts=2 sw=2 tw=80: */\n","/**\n * @fileoverview GZIP (RFC1952) 展開コンテナ実装.\n */\ngoog.provide('Zlib.Gunzip');\n\ngoog.require('USE_TYPEDARRAY');\ngoog.require('Zlib.CRC32');\ngoog.require('Zlib.Gzip');\ngoog.require('Zlib.RawInflate');\ngoog.require('Zlib.GunzipMember');\n\ngoog.scope(function() {\n\n/**\n * @constructor\n * @param {!(Array|Uint8Array)} input input buffer.\n * @param {Object=} opt_params option parameters.\n */\nZlib.Gunzip = function(input, opt_params) {\n  /** @type {!(Array.<number>|Uint8Array)} input buffer. */\n  this.input = input;\n  /** @type {number} input buffer pointer. */\n  this.ip = 0;\n  /** @type {Array.<Zlib.GunzipMember>} */\n  this.member = [];\n  /** @type {boolean} */\n  this.decompressed = false;\n};\n\n/**\n * @return {Array.<Zlib.GunzipMember>}\n */\nZlib.Gunzip.prototype.getMembers = function() {\n  if (!this.decompressed) {\n    this.decompress();\n  }\n\n  return this.member.slice();\n};\n\n/**\n * inflate gzip data.\n * @return {!(Array.<number>|Uint8Array)} inflated buffer.\n */\nZlib.Gunzip.prototype.decompress = function() {\n  /** @type {number} input length. */\n  var il = this.input.length;\n\n  while (this.ip < il) {\n    this.decodeMember();\n  }\n\n  this.decompressed = true;\n\n  return this.concatMember();\n};\n\n/**\n * decode gzip member.\n */\nZlib.Gunzip.prototype.decodeMember = function() {\n  /** @type {Zlib.GunzipMember} */\n  var member = new Zlib.GunzipMember();\n  /** @type {number} */\n  var isize;\n  /** @type {Zlib.RawInflate} RawInflate implementation. */\n  var rawinflate;\n  /** @type {!(Array.<number>|Uint8Array)} inflated data. */\n  var inflated;\n  /** @type {number} inflate size */\n  var inflen;\n  /** @type {number} character code */\n  var c;\n  /** @type {number} character index in string. */\n  var ci;\n  /** @type {Array.<string>} character array. */\n  var str;\n  /** @type {number} modification time. */\n  var mtime;\n  /** @type {number} */\n  var crc32;\n\n  var input = this.input;\n  var ip = this.ip;\n\n  member.id1 = input[ip++];\n  member.id2 = input[ip++];\n\n  // check signature\n  if (member.id1 !== 0x1f || member.id2 !== 0x8b) {\n    throw new Error('invalid file signature:' + member.id1 + ',' + member.id2);\n  }\n\n  // check compression method\n  member.cm = input[ip++];\n  switch (member.cm) {\n    case 8: /* XXX: use Zlib const */\n      break;\n    default:\n      throw new Error('unknown compression method: ' + member.cm);\n  }\n\n  // flags\n  member.flg = input[ip++];\n\n  // modification time\n  mtime = (input[ip++])       |\n          (input[ip++] << 8)  |\n          (input[ip++] << 16) |\n          (input[ip++] << 24);\n  member.mtime = new Date(mtime * 1000);\n\n  // extra flags\n  member.xfl = input[ip++];\n\n  // operating system\n  member.os = input[ip++];\n\n  // extra\n  if ((member.flg & Zlib.Gzip.FlagsMask.FEXTRA) > 0) {\n    member.xlen = input[ip++] | (input[ip++] << 8);\n    ip = this.decodeSubField(ip, member.xlen);\n  }\n\n  // fname\n  if ((member.flg & Zlib.Gzip.FlagsMask.FNAME) > 0) {\n    for(str = [], ci = 0; (c = input[ip++]) > 0;) {\n      str[ci++] = String.fromCharCode(c);\n    }\n    member.name = str.join('');\n  }\n\n  // fcomment\n  if ((member.flg & Zlib.Gzip.FlagsMask.FCOMMENT) > 0) {\n    for(str = [], ci = 0; (c = input[ip++]) > 0;) {\n      str[ci++] = String.fromCharCode(c);\n    }\n    member.comment = str.join('');\n  }\n\n  // fhcrc\n  if ((member.flg & Zlib.Gzip.FlagsMask.FHCRC) > 0) {\n    member.crc16 = Zlib.CRC32.calc(input, 0, ip) & 0xffff;\n    if (member.crc16 !== (input[ip++] | (input[ip++] << 8))) {\n      throw new Error('invalid header crc16');\n    }\n  }\n\n  // isize を事前に取得すると展開後のサイズが分かるため、\n  // inflate処理のバッファサイズが事前に分かり、高速になる\n  isize = (input[input.length - 4])       | (input[input.length - 3] << 8) |\n          (input[input.length - 2] << 16) | (input[input.length - 1] << 24);\n\n  // isize の妥当性チェック\n  // ハフマン符号では最小 2-bit のため、最大で 1/4 になる\n  // LZ77 符号では 長さと距離 2-Byte で最大 258-Byte を表現できるため、\n  // 1/128 になるとする\n  // ここから入力バッファの残りが isize の 512 倍以上だったら\n  // サイズ指定のバッファ確保は行わない事とする\n  if (input.length - ip - /* CRC-32 */4 - /* ISIZE */4 < isize * 512) {\n    inflen = isize;\n  }\n\n  // compressed block\n  rawinflate = new Zlib.RawInflate(input, {'index': ip, 'bufferSize': inflen});\n  member.data = inflated = rawinflate.decompress();\n  ip = rawinflate.ip;\n\n  // crc32\n  member.crc32 = crc32 =\n    ((input[ip++])       | (input[ip++] << 8) |\n     (input[ip++] << 16) | (input[ip++] << 24)) >>> 0;\n  if (Zlib.CRC32.calc(inflated) !== crc32) {\n    throw new Error('invalid CRC-32 checksum: 0x' +\n        Zlib.CRC32.calc(inflated).toString(16) + ' / 0x' + crc32.toString(16));\n  }\n\n  // input size\n  member.isize = isize =\n    ((input[ip++])       | (input[ip++] << 8) |\n     (input[ip++] << 16) | (input[ip++] << 24)) >>> 0;\n  if ((inflated.length & 0xffffffff) !== isize) {\n    throw new Error('invalid input size: ' +\n        (inflated.length & 0xffffffff) + ' / ' + isize);\n  }\n\n  this.member.push(member);\n  this.ip = ip;\n};\n\n/**\n * サブフィールドのデコード\n * XXX: 現在は何もせずスキップする\n */\nZlib.Gunzip.prototype.decodeSubField = function(ip, length) {\n  return ip + length;\n};\n\n/**\n * @return {!(Array.<number>|Uint8Array)}\n */\nZlib.Gunzip.prototype.concatMember = function() {\n  /** @type {Array.<Zlib.GunzipMember>} */\n  var member = this.member;\n  /** @type {number} */\n  var i;\n  /** @type {number} */\n  var il;\n  /** @type {number} */\n  var p = 0;\n  /** @type {number} */\n  var size = 0;\n  /** @type {!(Array.<number>|Uint8Array)} */\n  var buffer;\n\n  for (i = 0, il = member.length; i < il; ++i) {\n    size += member[i].data.length;\n  }\n\n  if (USE_TYPEDARRAY) {\n    buffer = new Uint8Array(size);\n    for (i = 0; i < il; ++i) {\n      buffer.set(member[i].data, p);\n      p += member[i].data.length;\n    }\n  } else {\n    buffer = [];\n    for (i = 0; i < il; ++i) {\n      buffer[i] = member[i].data;\n    }\n    buffer = Array.prototype.concat.apply([], buffer);\n  }\n\n  return buffer;\n};\n\n});\n/* vim:set expandtab ts=2 sw=2 tw=80: */\n","/**\n * @fileoverview Adler32 checksum 実装.\n */\ngoog.provide('Zlib.Adler32');\n\ngoog.require('USE_TYPEDARRAY');\ngoog.require('Zlib.Util');\n\ngoog.scope(function() {\n\n/**\n * Adler32 ハッシュ値の作成\n * @param {!(Array|Uint8Array|string)} array 算出に使用する byte array.\n * @return {number} Adler32 ハッシュ値.\n */\nZlib.Adler32 = function(array) {\n  if (typeof(array) === 'string') {\n    array = Zlib.Util.stringToByteArray(array);\n  }\n  return Zlib.Adler32.update(1, array);\n};\n\n/**\n * Adler32 ハッシュ値の更新\n * @param {number} adler 現在のハッシュ値.\n * @param {!(Array|Uint8Array)} array 更新に使用する byte array.\n * @return {number} Adler32 ハッシュ値.\n */\nZlib.Adler32.update = function(adler, array) {\n  /** @type {number} */\n  var s1 = adler & 0xffff;\n  /** @type {number} */\n  var s2 = (adler >>> 16) & 0xffff;\n  /** @type {number} array length */\n  var len = array.length;\n  /** @type {number} loop length (don't overflow) */\n  var tlen;\n  /** @type {number} array index */\n  var i = 0;\n\n  while (len > 0) {\n    tlen = len > Zlib.Adler32.OptimizationParameter ?\n      Zlib.Adler32.OptimizationParameter : len;\n    len -= tlen;\n    do {\n      s1 += array[i++];\n      s2 += s1;\n    } while (--tlen);\n\n    s1 %= 65521;\n    s2 %= 65521;\n  }\n\n  return ((s2 << 16) | s1) >>> 0;\n};\n\n/**\n * Adler32 最適化パラメータ\n * 現状では 1024 程度が最適.\n * @see http://jsperf.com/adler-32-simple-vs-optimized/3\n * @define {number}\n */\nZlib.Adler32.OptimizationParameter = 1024;\n\n// end of scope\n});\n\n/* vim:set expandtab ts=2 sw=2 tw=80: */\n","/**\n * @fileoverview 雑多な関数群をまとめたモジュール実装.\n */\ngoog.provide('Zlib.Util');\n\ngoog.scope(function() {\n\n/**\n * Byte String から Byte Array に変換.\n * @param {!string} str byte string.\n * @return {!Array.<number>} byte array.\n */\nZlib.Util.stringToByteArray = function(str) {\n  /** @type {!Array.<(string|number)>} */\n  var tmp = str.split('');\n  /** @type {number} */\n  var i;\n  /** @type {number} */\n  var il;\n\n  for (i = 0, il = tmp.length; i < il; i++) {\n    tmp[i] = (tmp[i].charCodeAt(0) & 0xff) >>> 0;\n  }\n\n  return tmp;\n};\n\n// end of scope\n});\n\n/* vim:set expandtab ts=2 sw=2 tw=80: */\n","goog.provide('Zlib.Inflate');\n\ngoog.require('USE_TYPEDARRAY');\ngoog.require('Zlib.Adler32');\ngoog.require('Zlib.RawInflate');\n\ngoog.scope(function() {\n\n/**\n * @constructor\n * @param {!(Uint8Array|Array)} input deflated buffer.\n * @param {Object=} opt_params option parameters.\n *\n * opt_params は以下のプロパティを指定する事ができます。\n *   - index: input buffer の deflate コンテナの開始位置.\n *   - blockSize: バッファのブロックサイズ.\n *   - verify: 伸張が終わった後 adler-32 checksum の検証を行うか.\n *   - bufferType: Zlib.Inflate.BufferType の値によってバッファの管理方法を指定する.\n *       Zlib.Inflate.BufferType は Zlib.RawInflate.BufferType のエイリアス.\n */\nZlib.Inflate = function(input, opt_params) {\n  /** @type {number} */\n  var bufferSize;\n  /** @type {Zlib.Inflate.BufferType} */\n  var bufferType;\n  /** @type {number} */\n  var cmf;\n  /** @type {number} */\n  var flg;\n\n  /** @type {!(Uint8Array|Array)} */\n  this.input = input;\n  /** @type {number} */\n  this.ip = 0;\n  /** @type {Zlib.RawInflate} */\n  this.rawinflate;\n  /** @type {(boolean|undefined)} verify flag. */\n  this.verify;\n\n  // option parameters\n  if (opt_params || !(opt_params = {})) {\n    if (opt_params['index']) {\n      this.ip = opt_params['index'];\n    }\n    if (opt_params['verify']) {\n      this.verify = opt_params['verify'];\n    }\n  }\n\n  // Compression Method and Flags\n  cmf = input[this.ip++];\n  flg = input[this.ip++];\n\n  // compression method\n  switch (cmf & 0x0f) {\n    case Zlib.CompressionMethod.DEFLATE:\n      this.method = Zlib.CompressionMethod.DEFLATE;\n      break;\n    default:\n      throw new Error('unsupported compression method');\n  }\n\n  // fcheck\n  if (((cmf << 8) + flg) % 31 !== 0) {\n    throw new Error('invalid fcheck flag:' + ((cmf << 8) + flg) % 31);\n  }\n\n  // fdict (not supported)\n  if (flg & 0x20) {\n    throw new Error('fdict flag is not supported');\n  }\n\n  // RawInflate\n  this.rawinflate = new Zlib.RawInflate(input, {\n    'index': this.ip,\n    'bufferSize': opt_params['bufferSize'],\n    'bufferType': opt_params['bufferType'],\n    'resize': opt_params['resize']\n  });\n}\n\n/**\n * @enum {number}\n */\nZlib.Inflate.BufferType = Zlib.RawInflate.BufferType;\n\n/**\n * decompress.\n * @return {!(Uint8Array|Array)} inflated buffer.\n */\nZlib.Inflate.prototype.decompress = function() {\n  /** @type {!(Array|Uint8Array)} input buffer. */\n  var input = this.input;\n  /** @type {!(Uint8Array|Array)} inflated buffer. */\n  var buffer;\n  /** @type {number} adler-32 checksum */\n  var adler32;\n\n  buffer = this.rawinflate.decompress();\n  this.ip = this.rawinflate.ip;\n\n  // verify adler-32\n  if (this.verify) {\n    adler32 = (\n      input[this.ip++] << 24 | input[this.ip++] << 16 |\n      input[this.ip++] << 8 | input[this.ip++]\n    ) >>> 0;\n\n    if (adler32 !== Zlib.Adler32(buffer)) {\n      throw new Error('invalid adler-32 checksum');\n    }\n  }\n\n  return buffer;\n};\n\n// end of scope\n});\n\n/* vim:set expandtab ts=2 sw=2 tw=80: */\n","/**\n * @fileoverview Zlib namespace. Zlib の仕様に準拠した圧縮は Zlib.Deflate で実装\n * されている. これは Inflate との共存を考慮している為.\n */\n\ngoog.provide('Zlib');\n\n//-----------------------------------------------------------------------------\n\ngoog.scope(function() {\n\n/**\n * Compression Method\n * @enum {number}\n */\nZlib.CompressionMethod = {\n  DEFLATE: 8,\n  RESERVED: 15\n};\n\n// end of scope\n});\n\n/* vim:set expandtab ts=2 sw=2 tw=80: */\n","/**\n * @fileoverview Deflate (RFC1951) 実装.\n * Deflateアルゴリズム本体は Zlib.RawDeflate で実装されている.\n */\ngoog.provide('Zlib.Deflate');\n\ngoog.require('USE_TYPEDARRAY');\ngoog.require('Zlib');\ngoog.require('Zlib.Adler32');\ngoog.require('Zlib.RawDeflate');\n\ngoog.scope(function() {\n\n/**\n * Zlib Deflate\n * @constructor\n * @param {!(Array|Uint8Array)} input 符号化する対象の byte array.\n * @param {Object=} opt_params option parameters.\n */\nZlib.Deflate = function(input, opt_params) {\n  /** @type {!(Array|Uint8Array)} */\n  this.input = input;\n  /** @type {!(Array|Uint8Array)} */\n  this.output =\n    new (USE_TYPEDARRAY ? Uint8Array : Array)(Zlib.Deflate.DefaultBufferSize);\n  /** @type {Zlib.Deflate.CompressionType} */\n  this.compressionType = Zlib.Deflate.CompressionType.DYNAMIC;\n  /** @type {Zlib.RawDeflate} */\n  this.rawDeflate;\n  /** @type {Object} */\n  var rawDeflateOption = {};\n  /** @type {string} */\n  var prop;\n\n  // option parameters\n  if (opt_params || !(opt_params = {})) {\n    if (typeof opt_params['compressionType'] === 'number') {\n      this.compressionType = opt_params['compressionType'];\n    }\n  }\n\n  // copy options\n  for (prop in opt_params) {\n    rawDeflateOption[prop] = opt_params[prop];\n  }\n\n  // set raw-deflate output buffer\n  rawDeflateOption['outputBuffer'] = this.output;\n\n  this.rawDeflate = new Zlib.RawDeflate(this.input, rawDeflateOption);\n};\n\n/**\n * @const\n * @type {number} デフォルトバッファサイズ.\n */\nZlib.Deflate.DefaultBufferSize = 0x8000;\n\n/**\n * @enum {number}\n */\nZlib.Deflate.CompressionType = Zlib.RawDeflate.CompressionType;\n\n/**\n * 直接圧縮に掛ける.\n * @param {!(Array|Uint8Array)} input target buffer.\n * @param {Object=} opt_params option parameters.\n * @return {!(Array|Uint8Array)} compressed data byte array.\n */\nZlib.Deflate.compress = function(input, opt_params) {\n  return (new Zlib.Deflate(input, opt_params)).compress();\n};\n\n/**\n * Deflate Compression.\n * @return {!(Array|Uint8Array)} compressed data byte array.\n */\nZlib.Deflate.prototype.compress = function() {\n  /** @type {Zlib.CompressionMethod} */\n  var cm;\n  /** @type {number} */\n  var cinfo;\n  /** @type {number} */\n  var cmf;\n  /** @type {number} */\n  var flg;\n  /** @type {number} */\n  var fcheck;\n  /** @type {number} */\n  var fdict;\n  /** @type {number} */\n  var flevel;\n  /** @type {number} */\n  var clevel;\n  /** @type {number} */\n  var adler;\n  /** @type {boolean} */\n  var error = false;\n  /** @type {!(Array|Uint8Array)} */\n  var output;\n  /** @type {number} */\n  var pos = 0;\n\n  output = this.output;\n\n  // Compression Method and Flags\n  cm = Zlib.CompressionMethod.DEFLATE;\n  switch (cm) {\n    case Zlib.CompressionMethod.DEFLATE:\n      cinfo = Math.LOG2E * Math.log(Zlib.RawDeflate.WindowSize) - 8;\n      break;\n    default:\n      throw new Error('invalid compression method');\n  }\n  cmf = (cinfo << 4) | cm;\n  output[pos++] = cmf;\n\n  // Flags\n  fdict = 0;\n  switch (cm) {\n    case Zlib.CompressionMethod.DEFLATE:\n      switch (this.compressionType) {\n        case Zlib.Deflate.CompressionType.NONE: flevel = 0; break;\n        case Zlib.Deflate.CompressionType.FIXED: flevel = 1; break;\n        case Zlib.Deflate.CompressionType.DYNAMIC: flevel = 2; break;\n        default: throw new Error('unsupported compression type');\n      }\n      break;\n    default:\n      throw new Error('invalid compression method');\n  }\n  flg = (flevel << 6) | (fdict << 5);\n  fcheck = 31 - (cmf * 256 + flg) % 31;\n  flg |= fcheck;\n  output[pos++] = flg;\n\n  // Adler-32 checksum\n  adler = Zlib.Adler32(this.input);\n\n  this.rawDeflate.op = pos;\n  output = this.rawDeflate.compress();\n  pos = output.length;\n\n  if (USE_TYPEDARRAY) {\n    // subarray 分を元にもどす\n    output = new Uint8Array(output.buffer);\n    // expand buffer\n    if (output.length <= pos + 4) {\n      this.output = new Uint8Array(output.length + 4);\n      this.output.set(output);\n      output = this.output;\n    }\n    output = output.subarray(0, pos + 4);\n  }\n\n  // adler32\n  output[pos++] = (adler >> 24) & 0xff;\n  output[pos++] = (adler >> 16) & 0xff;\n  output[pos++] = (adler >>  8) & 0xff;\n  output[pos++] = (adler      ) & 0xff;\n\n  return output;\n};\n\n// end of scope\n});\n\n/* vim:set expandtab ts=2 sw=2 tw=80: */\n","/**\n * zlib.js wrapper for node.js\n */\ngoog.require('Zlib.Inflate');\ngoog.require('Zlib.Deflate');\ngoog.require('Zlib.Gunzip');\n\n//-----------------------------------------------------------------------------\n// exports methods\n//-----------------------------------------------------------------------------\nexports['deflate'] = deflate;\nexports['deflateSync'] = deflateSync;\nexports['inflate'] = inflate;\nexports['inflateSync'] = inflateSync;\nexports['gzip'] = gzip;\nexports['gzipSync'] = gzipSync;\nexports['gunzip'] = gunzip;\nexports['gunzipSync'] = gunzipSync;\n\n\n/**\n * deflate async.\n * @param {!(Buffer|Array.<number>|Uint8Array)} buffer plain data buffer.\n * @param {function(Error, !(Buffer|Array.<number>|Uint8Array))} callback\n *     error calllback function.\n * @param {Object=} opt_params option parameters.\n */\nfunction deflate(buffer, callback, opt_params) {\n  process.nextTick(function(){\n    /** @type {Error} error */\n    var error;\n    /** @type {!(Buffer|Array.<number>|Uint8Array)} deflated buffer. */\n    var deflated;\n\n    try {\n      deflated = deflateSync(buffer, opt_params);\n    } catch(e){\n      error = e;\n    }\n\n    callback(error, deflated);\n  });\n}\n\n\n/**\n * deflate sync.\n * @param {!(Buffer|Array.<number>|Uint8Array)} buffer plain data buffer.\n * @param {Object=} opt_params option parameters.\n * @return {!(Buffer|Array.<number>|Uint8Array)} deflated buffer.\n */\nfunction deflateSync(buffer, opt_params) {\n  /** @type {Zlib.Deflate} deflate encoder. */\n  var deflate = new Zlib.Deflate(\n    /** @type {!(Array.<number>|Uint8Array)} */(buffer)\n  );\n  /** @type {!(Array.<number>|Uint8Array)} deflated buffer. */\n  var deflated;\n\n  deflated = deflate.compress();\n\n  if (!opt_params) {\n    opt_params = {};\n  }\n\n  return opt_params.noBuffer ? deflated : toBuffer(deflated);\n}\n\n\n/**\n * inflate async.\n * @param {!(Array.<number>|Uint8Array)} buffer deflated buffer.\n * @param {function(Error, !(Buffer|Array.<number>|Uint8Array))} callback\n *     error calllback function.\n * @param {Object=} opt_params option parameters.\n */\nfunction inflate(buffer, callback, opt_params) {\n  process.nextTick(function(){\n    /** @type {Error} error */\n    var error;\n    /** @type {!(Buffer|Array.<number>|Uint8Array)} inflated plain buffer. */\n    var inflated;\n\n    try {\n      inflated = inflateSync(buffer, opt_params);\n    } catch(e){\n      error = e;\n    }\n\n    callback(error, inflated);\n  });\n};\n\n\n/**\n * inflate sync.\n * @param {!(Array.<number>|Uint8Array)} buffer deflated buffer.\n * @param {Object=} opt_params option parameters.\n * @return {!(Buffer|Array.<number>|Uint8Array)} inflated plain buffer.\n */\nfunction inflateSync(buffer, opt_params) {\n  /** @type {Zlib.Inflate} deflate decoder. */\n  var inflate;\n  /** @type {!(Buffer|Array.<number>|Uint8Array)} inflated plain buffer. */\n  var inflated;\n\n  buffer.subarray = buffer.slice;\n  inflate = new Zlib.Inflate(buffer);\n  inflated = inflate.decompress();\n\n  if (!opt_params) {\n    opt_params = {};\n  }\n\n  return opt_params['noBuffer'] ? inflated : toBuffer(inflated);\n}\n\n/**\n * gunzip async.\n * @param {!(Array.<number>|Uint8Array)} buffer inflated buffer.\n * @param {function(Error, !(Buffer|Array.<number>|Uint8Array))} callback\n *     error calllback function.\n * @param {Object=} opt_params option parameters.\n */\nfunction gzip(buffer, callback, opt_params) {\n  process.nextTick(function(){\n    /** @type {Error} error */\n    var error;\n    /** @type {!(Buffer|Array.<number>|Uint8Array)} deflated buffer. */\n    var deflated;\n\n    try {\n      deflated = gzipSync(buffer, opt_params);\n    } catch(e){\n      error = e;\n    }\n\n    callback(error, deflated);\n  });\n}\n\n/**\n * deflate sync.\n * @param {!(Array.<number>|Uint8Array)} buffer inflated buffer.\n * @param {Object=} opt_params option parameters.\n * @return {!(Buffer|Array.<number>|Uint8Array)} deflated buffer.\n */\nfunction gzipSync(buffer, opt_params) {\n  /** @type {Zlib.Gzip} deflate compressor. */\n  var deflate;\n  /** @type {!(Buffer|Array.<number>|Uint8Array)} deflated buffer. */\n  var deflated;\n\n  buffer.subarray = buffer.slice;\n  deflate = new Zlib.Gzip(buffer);\n  deflated = deflate.compress();\n\n  if (!opt_params) {\n    opt_params = {};\n  }\n\n  return opt_params.noBuffer ? deflated : toBuffer(deflated);\n}\n\n/**\n * gunzip async.\n * @param {!(Array.<number>|Uint8Array)} buffer deflated buffer.\n * @param {function(Error, !(Buffer|Array.<number>|Uint8Array))} callback\n *     error calllback function.\n * @param {Object=} opt_params option parameters.\n */\nfunction gunzip(buffer, callback, opt_params) {\n  process.nextTick(function(){\n    /** @type {Error} error */\n    var error;\n    /** @type {!(Buffer|Array.<number>|Uint8Array)} inflated plain buffer. */\n    var inflated;\n\n    try {\n      inflated = gunzipSync(buffer, opt_params);\n    } catch(e){\n      error = e;\n    }\n\n    callback(error, inflated);\n  });\n}\n\n/**\n * inflate sync.\n * @param {!(Array.<number>|Uint8Array)} buffer deflated buffer.\n * @param {Object=} opt_params option parameters.\n * @return {!(Buffer|Array.<number>|Uint8Array)} inflated plain buffer.\n */\nfunction gunzipSync(buffer, opt_params) {\n  /** @type {Zlib.Gunzip} deflate decompressor. */\n  var inflate;\n  /** @type {!(Buffer|Array.<number>|Uint8Array)} inflated plain buffer. */\n  var inflated;\n\n  buffer.subarray = buffer.slice;\n  inflate = new Zlib.Gunzip(buffer);\n  inflated = inflate.decompress();\n\n  if (!opt_params) {\n    opt_params = {};\n  }\n\n  return opt_params.noBuffer ? inflated : toBuffer(inflated);\n}\n\n\n/**\n * convert to Buffer.\n * @param {!(Array.<number>|Uint8Array)} array arraylike object.\n * @return {!Buffer} Buffer object.\n */\nfunction toBuffer(array) {\n  var buffer = new Buffer(array.length);\n  var i;\n  var il;\n\n  // TODO: loop unrolling for performance\n  for (i = 0, il = array.length; i < il; ++i) {\n    buffer[i] = array[i];\n  }\n\n  return buffer;\n}\n\n"]}