m?m=pe:_(Math.max(Q,m)+1)}}function j(c,p){return p.lineNumber=c.lineNumber,p.columnNumber=c.columnNumber,p}function s(c,p,h,x,V,te){function Ae(G,z,d){h.attributeNames.hasOwnProperty(G)&&te.fatalError("Attribute "+G+" redefined"),h.addValue(G,z.replace(/[\t\n\r]/g," ").replace(/?\w+;/g,V),d)}for(var _,q,J=++p,F=i;;){var $=c.charAt(J);switch($){case"=":if(F===o)_=c.slice(p,J),F=n;else if(F===D)F=n;else throw new Error("attribute equal must after attrName");break;case"'":case'"':if(F===n||F===o)if(F===o&&(te.warning('attribute value must after "="'),_=c.slice(p,J)),p=J+1,J=c.indexOf($,p),J>0)q=c.slice(p,J),Ae(_,q,p-1),F=g;else throw new Error("attribute value no end '"+$+"' match");else if(F==r)q=c.slice(p,J),Ae(_,q,p),te.warning('attribute "'+_+'" missed start quot('+$+")!!"),p=J+1,F=g;else throw new Error('attribute value must after "="');break;case"/":switch(F){case i:h.setTagName(c.slice(p,J));case g:case I:case a:F=a,h.closed=!0;case r:case o:break;case D:h.closed=!0;break;default:throw new Error("attribute invalid close char('/')")}break;case"":return te.error("unexpected end of input"),F==i&&h.setTagName(c.slice(p,J)),J;case">":switch(F){case i:h.setTagName(c.slice(p,J));case g:case I:case a:break;case r:case o:q=c.slice(p,J),q.slice(-1)==="/"&&(h.closed=!0,q=q.slice(0,-1));case D:F===D&&(q=_),F==r?(te.warning('attribute "'+q+'" missed quot(")!'),Ae(_,q,p)):((!e.isHTML(x[""])||!q.match(/^(?:disabled|checked|selected)$/i))&&te.warning('attribute "'+q+'" missed value!! "'+q+'" instead!!'),Ae(q,q,p));break;case n:throw new Error("attribute value missed!!")}return J;case"":$=" ";default:if($<=" ")switch(F){case i:h.setTagName(c.slice(p,J)),F=I;break;case o:_=c.slice(p,J),F=D;break;case r:var q=c.slice(p,J);te.warning('attribute "'+q+'" missed quot(")!!'),Ae(_,q,p);case g:F=I;break}else switch(F){case D:h.tagName,(!e.isHTML(x[""])||!_.match(/^(?:disabled|checked|selected)$/i))&&te.warning('attribute "'+_+'" missed value!! "'+_+'" instead2!!'),Ae(_,_,p),p=J,F=o;break;case g:te.warning('attribute space is required"'+_+'"!!');case I:F=o,p=J;break;case n:F=r,p=J;break;case a:throw new Error("elements closed character '/' and '>' must be connected to")}}J++}}function T(c,p,h){for(var x=c.tagName,V=null,$=c.length;$--;){var te=c[$],Ae=te.qName,_=te.value,G=Ae.indexOf(":");if(G>0)var q=te.prefix=Ae.slice(0,G),J=Ae.slice(G+1),F=q==="xmlns"&&J;else J=Ae,q=null,F=Ae==="xmlns"&&"";te.localName=J,F!==!1&&(V==null&&(V={},v(h,h={})),h[F]=V[F]=_,te.uri=e.XMLNS,p.startPrefixMapping(F,_))}for(var $=c.length;$--;){te=c[$];var q=te.prefix;q&&(q==="xml"&&(te.uri=e.XML),q!=="xmlns"&&(te.uri=h[q||""]))}var G=x.indexOf(":");G>0?(q=c.prefix=x.slice(0,G),J=c.localName=x.slice(G+1)):(q=null,J=c.localName=x);var z=c.uri=h[q||""];if(p.startElement(z,J,x,c),c.closed){if(p.endElement(z,J,x),V)for(q in V)Object.prototype.hasOwnProperty.call(V,q)&&p.endPrefixMapping(q)}else return c.currentNSMap=h,c.localNSMap=V,!0}function E(c,p,h,x,V){if(/^(?:script|textarea)$/i.test(h)){var te=c.indexOf(""+h+">",p),Ae=c.substring(p+1,te);if(/[&<]/.test(Ae))return/^script$/i.test(h)?(V.characters(Ae,0,Ae.length),te):(Ae=Ae.replace(/?\w+;/g,x),V.characters(Ae,0,Ae.length),te)}return p+1}function U(c,p,h,x){var V=x[h];return V==null&&(V=c.lastIndexOf(""+h+">"),V",p+4);return te>p?(h.comment(c,p+4,te-p-4),te+3):(x.error("Unclosed comment"),-1)}else return-1;default:if(c.substr(p+3,6)=="CDATA["){var te=c.indexOf("]]>",p+9);return h.startCDATA(),h.characters(c,p+9,te-p-9),h.endCDATA(),te+3}var Ae=K(c,p),_=Ae.length;if(_>1&&/!doctype/i.test(Ae[0][0])){var q=Ae[1][0],J=!1,F=!1;_>3&&(/^public$/i.test(Ae[2][0])?(J=Ae[3][0],F=_>4&&Ae[4][0]):/^system$/i.test(Ae[2][0])&&(F=Ae[3][0]));var $=Ae[_-1];return h.startDTD(q,J,F),h.endDTD(),$.index+$[0].length}}return-1}function f(c,p,h){var x=c.indexOf("?>",p);if(x){var V=c.substring(p,x).match(/^<\?(\S*)\s*([\s\S]*?)\s*$/);return V?(V[0].length,h.processingInstruction(V[1],V[2]),x+2):-1}return-1}function P(){this.attributeNames={}}P.prototype={setTagName:function(c){if(!A.test(c))throw new Error("invalid tagName:"+c);this.tagName=c},addValue:function(c,p,h){if(!A.test(c))throw new Error("invalid attribute:"+c);this.attributeNames[c]=this.length,this[this.length++]={qName:c,value:p,offset:h}},length:0,getLocalName:function(c){return this[c].localName},getLocator:function(c){return this[c].locator},getQName:function(c){return this[c].qName},getURI:function(c){return this[c].uri},getValue:function(c){return this[c].value}};function K(c,p){var h,x=[],V=/'[^']+'|"[^"]+"|[^\s<>\/=]+=?|(\/?\s*>|<)/g;for(V.lastIndex=p,V.exec(c);h=V.exec(c);)if(x.push(h),h[1])return x}return JA.XMLReader=N,JA.ParseError=C,JA}var Hr;function Cl(){if(Hr)return ZM;Hr=1;var e=pi(),t=Mw(),M=al(),A=wl(),i=t.DOMImplementation,o=e.NAMESPACE,D=A.ParseError,n=A.XMLReader;function r(s){return s.replace(/\r[\n\u0085]/g,`
+`).replace(/[\r\u0085\u2028]/g,`
+`)}function g(s){this.options=s||{locator:{}}}g.prototype.parseFromString=function(s,T){var E=this.options,U=new n,v=E.domBuilder||new a,L=E.errorHandler,f=E.locator,P=E.xmlns||{},K=/\/x?html?$/.test(T),c=K?M.HTML_ENTITIES:M.XML_ENTITIES;f&&v.setDocumentLocator(f),U.errorHandler=I(L,v,f),U.domBuilder=E.domBuilder||v,K&&(P[""]=o.HTML),P.xml=P.xml||o.XML;var p=E.normalizeLineEndings||r;return s&&typeof s=="string"?U.parse(p(s),P,c):U.errorHandler.error("invalid doc source"),v.doc};function I(s,T,E){if(!s){if(T instanceof a)return T;s=T}var U={},v=s instanceof Function;E=E||{};function L(f){var P=s[f];!P&&v&&(P=s.length==2?function(K){s(f,K)}:s),U[f]=P&&function(K){P("[xmldom "+f+"] "+K+N(E))}||function(){}}return L("warning"),L("error"),L("fatalError"),U}function a(){this.cdata=!1}function C(s,T){T.lineNumber=s.lineNumber,T.columnNumber=s.columnNumber}a.prototype={startDocument:function(){this.doc=new i().createDocument(null,null,null),this.locator&&(this.doc.documentURI=this.locator.systemId)},startElement:function(s,T,E,U){var v=this.doc,L=v.createElementNS(s,E||T),f=U.length;j(this,L),this.currentElement=L,this.locator&&C(this.locator,L);for(var P=0;P=T+E||T?new java.lang.String(s,T,E)+"":s}"endDTD,startEntity,endEntity,attributeDecl,elementDecl,externalEntityDecl,internalEntityDecl,resolveEntity,getExternalSubset,notationDecl,unparsedEntityDecl".replace(/\w+/g,function(s){a.prototype[s]=function(){return null}});function j(s,T){s.currentElement?s.currentElement.appendChild(T):s.doc.appendChild(T)}return ZM.__DOMHandler=a,ZM.normalizeLineEndings=r,ZM.DOMParser=g,ZM}var qr;function ul(){if(qr)return VM;qr=1;var e=Mw();return VM.DOMImplementation=e.DOMImplementation,VM.XMLSerializer=e.XMLSerializer,VM.DOMParser=Cl().DOMParser,VM}var RM={},Xr;function sl(){if(Xr)return RM;Xr=1,Object.defineProperty(RM,"__esModule",{value:!0}),RM.parseJson=void 0;function e(t){try{var M=JSON.parse(t);return M}catch{return null}}return RM.parseJson=e,RM}var FM={},_r;function Nl(){if(_r)return FM;_r=1,Object.defineProperty(FM,"__esModule",{value:!0}),FM.bufferFrom=void 0;function e(t){var M=encodeURIComponent(t),A=M.replace(/%([0-9A-F]{2})/g,function(o,D){return String.fromCharCode("0x"+D)}),i=new Uint8Array(A.length);return Array.prototype.forEach.call(A,function(o,D){i[D]=o.charCodeAt(0)}),i}return FM.bufferFrom=e,FM}var WM={},HM={},$r;function Aw(){if($r)return HM;$r=1,Object.defineProperty(HM,"__esModule",{value:!0}),HM.EventPolyfill=void 0;var e=function(){function t(M,A){this.AT_TARGET=0,this.BUBBLING_PHASE=0,this.CAPTURING_PHASE=0,this.NONE=0,this.type="",this.srcElement=null,this.currentTarget=null,this.eventPhase=0,this.isTrusted=!0,this.composed=!1,this.cancelable=!0,this.defaultPrevented=!1,this.bubbles=!0,this.lengthComputable=!0,this.loaded=0,this.total=0,this.cancelBubble=!1,this.returnValue=!0,this.type=M,this.target=(A==null?void 0:A.target)||null,this.currentTarget=(A==null?void 0:A.currentTarget)||null,this.timeStamp=Date.now()}return t.prototype.composedPath=function(){return[]},t.prototype.initEvent=function(M,A,i){this.type=M,this.bubbles=!!A,this.cancelable=!!i},t.prototype.preventDefault=function(){this.defaultPrevented=!0},t.prototype.stopPropagation=function(){},t.prototype.stopImmediatePropagation=function(){},t}();return HM.EventPolyfill=e,HM}var qM={},eg;function cl(){if(eg)return qM;eg=1;var e=H&&H.__extends||function(){var A=function(i,o){return A=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(D,n){D.__proto__=n}||function(D,n){for(var r in n)Object.prototype.hasOwnProperty.call(n,r)&&(D[r]=n[r])},A(i,o)};return function(i,o){if(typeof o!="function"&&o!==null)throw new TypeError("Class extends value "+String(o)+" is not a constructor or null");A(i,o);function D(){this.constructor=i}i.prototype=o===null?Object.create(o):(D.prototype=o.prototype,new D)}}();Object.defineProperty(qM,"__esModule",{value:!0}),qM.ProgressEventPolyfill=void 0;var t=Aw(),M=function(A){e(i,A);function i(o,D){var n=A.call(this,o)||this;return n.lengthComputable=(D==null?void 0:D.lengthComputable)||!1,n.composed=(D==null?void 0:D.composed)||!1,n.loaded=(D==null?void 0:D.loaded)||0,n.total=(D==null?void 0:D.total)||0,n}return i}(t.EventPolyfill);return qM.ProgressEventPolyfill=M,qM}var tg;function ll(){if(tg)return WM;tg=1,Object.defineProperty(WM,"__esModule",{value:!0}),WM.createEvent=void 0;var e=Aw(),t=cl(),M=typeof ProgressEvent<"u";function A(i,o,D){var n=["error","progress","loadstart","loadend","load","timeout","abort"],r=M?ProgressEvent:t.ProgressEventPolyfill,g=n.includes(o)?new r(o,{lengthComputable:!0,loaded:(D==null?void 0:D.loaded)||0,total:(D==null?void 0:D.total)||0}):new e.EventPolyfill(o,{target:i,currentTarget:i});return g}return WM.createEvent=A,WM}var Mg;function jl(){if(Mg)return GM;Mg=1;var e=H&&H.__awaiter||function(j,s,T,E){function U(v){return v instanceof T?v:new T(function(L){L(v)})}return new(T||(T=Promise))(function(v,L){function f(c){try{K(E.next(c))}catch(p){L(p)}}function P(c){try{K(E.throw(c))}catch(p){L(p)}}function K(c){c.done?v(c.value):U(c.value).then(f,P)}K((E=E.apply(j,s||[])).next())})},t=H&&H.__generator||function(j,s){var T={label:0,sent:function(){if(v[0]&1)throw v[1];return v[1]},trys:[],ops:[]},E,U,v,L;return L={next:f(0),throw:f(1),return:f(2)},typeof Symbol=="function"&&(L[Symbol.iterator]=function(){return this}),L;function f(K){return function(c){return P([K,c])}}function P(K){if(E)throw new TypeError("Generator is already executing.");for(;T;)try{if(E=1,U&&(v=K[0]&2?U.return:K[0]?U.throw||((v=U.return)&&v.call(U),0):U.next)&&!(v=v.call(U,K[1])).done)return v;switch(U=0,v&&(K=[K[0]&2,v.value]),K[0]){case 0:case 1:v=K;break;case 4:return T.label++,{value:K[1],done:!1};case 5:T.label++,U=K[1],K=[0];continue;case 7:K=T.ops.pop(),T.trys.pop();continue;default:if(v=T.trys,!(v=v.length>0&&v[v.length-1])&&(K[0]===6||K[0]===2)){T=0;continue}if(K[0]===3&&(!v||K[1]>v[0]&&K[1]=j.length&&(j=void 0),{value:j&&j[E++],done:!j}}};throw new TypeError(s?"Object is not iterable.":"Symbol.iterator is not defined.")},A=H&&H.__read||function(j,s){var T=typeof Symbol=="function"&&j[Symbol.iterator];if(!T)return j;var E=T.call(j),U,v=[],L;try{for(;(s===void 0||s-- >0)&&!(U=E.next()).done;)v.push(U.value)}catch(f){L={error:f}}finally{try{U&&!U.done&&(T=E.return)&&T.call(E)}finally{if(L)throw L.error}}return v};Object.defineProperty(GM,"__esModule",{value:!0}),GM.createXMLHttpRequestOverride=void 0;var i=Pt,o=it,D=ul(),n=sl(),r=tw(),g=Nl(),I=ll(),a=nM,C=gt,N=EM,b=function(j){var s,T=j.XMLHttpRequest,E=j.emitter,U=j.log;return s=function(){function v(){this._events=[],this.log=U,this.UNSENT=0,this.OPENED=1,this.HEADERS_RECEIVED=2,this.LOADING=3,this.DONE=4,this.onreadystatechange=null,this.onabort=null,this.onerror=null,this.onload=null,this.onloadend=null,this.onloadstart=null,this.onprogress=null,this.ontimeout=null,this.url="",this.method="GET",this.readyState=this.UNSENT,this.withCredentials=!1,this.status=200,this.statusText="OK",this.response="",this.responseType="text",this.responseText="",this.responseXML=null,this.responseURL="",this.upload={},this.timeout=0,this._requestHeaders=new o.Headers,this._responseHeaders=new o.Headers}return v.prototype.setReadyState=function(L){L!==this.readyState&&(this.log("readyState change %d -> %d",this.readyState,L),this.readyState=L,L!==this.UNSENT&&(this.log("triggering readystate change..."),this.trigger("readystatechange")))},v.prototype.trigger=function(L,f){var P,K;this.log('trigger "%s" (%d)',L,this.readyState),this.log('resolve listener for event "%s"',L);var c=this["on"+L];c==null||c.call(this,I.createEvent(this,L,f));try{for(var p=M(this._events),h=p.next();!h.done;h=p.next()){var x=h.value;x.name===L&&(U('calling mock event listener "%s" (%d)',L,this.readyState),x.listener.call(this,I.createEvent(this,L,f)))}}catch(V){P={error:V}}finally{try{h&&!h.done&&(K=p.return)&&K.call(p)}finally{if(P)throw P.error}}return this},v.prototype.reset=function(){this.log("reset"),this.setReadyState(this.UNSENT),this.status=200,this.statusText="OK",this.response=null,this.responseText=null,this.responseXML=null,this._requestHeaders=new o.Headers,this._responseHeaders=new o.Headers},v.prototype.open=function(L,f,P,K,c){return P===void 0&&(P=!0),e(this,void 0,void 0,function(){return t(this,function(p){return this.log=this.log.extend("request "+L+" "+f),this.log("open",{method:L,url:f,async:P,user:K,password:c}),this.reset(),this.setReadyState(this.OPENED),typeof f>"u"?(this.url=L,this.method="GET"):(this.url=f,this.method=L,this.async=P,this.user=K,this.password=c),[2]})})},v.prototype.send=function(L){var f=this;this.log("send %s %s",this.method,this.url);var P;typeof L=="string"?P=C.encodeBuffer(L):P=L||new ArrayBuffer(0);var K;try{K=new URL(this.url)}catch{K=new URL(this.url,window.location.href)}this.log("request headers",this._requestHeaders);var c=new a.IsomorphicRequest(K,{body:P,method:this.method,headers:this._requestHeaders,credentials:this.withCredentials?"include":"omit"}),p=new N.InteractiveIsomorphicRequest(c);this.log('emitting the "request" event for %d listener(s)...',E.listenerCount("request")),E.emit("request",p),this.log("awaiting mocked response..."),Promise.resolve(i.until(function(){return e(f,void 0,void 0,function(){var h,x;return t(this,function(V){switch(V.label){case 0:return[4,E.untilIdle("request",function(te){var Ae=A(te.args,1),_=Ae[0];return _.id===p.id})];case 1:return V.sent(),this.log("all request listeners have been resolved!"),[4,p.respondWith.invoked()];case 2:return h=A.apply(void 0,[V.sent(),1]),x=h[0],this.log("event.respondWith called with:",x),[2,x]}})})})).then(function(h){var x,V,te=A(h,2),Ae=te[0],_=te[1];if(Ae){f.log("middleware function threw an exception!",Ae),f.trigger("error"),f.abort();return}if(_){if(f.log("received mocked response",_),f.trigger("loadstart"),f.status=(x=_.status)!==null&&x!==void 0?x:200,f.statusText=_.statusText||"OK",f._responseHeaders=_.headers?o.objectToHeaders(_.headers):new o.Headers,f.log("set response status",f.status,f.statusText),f.log("set response headers",f._responseHeaders),f.setReadyState(f.HEADERS_RECEIVED),f.log("response type",f.responseType),f.response=f.getResponseBody(_.body),f.responseURL=f.url,f.responseText=_.body||"",f.responseXML=f.getResponseXML(),f.log("set response body",f.response),_.body&&f.response){f.setReadyState(f.LOADING);var q=g.bufferFrom(_.body);f.trigger("progress",{loaded:q.length,total:q.length})}f.setReadyState(f.DONE),f.trigger("load"),f.trigger("loadend"),E.emit("response",c,r.toIsoResponse(_))}else{f.log("no mocked response received!");var J=new T;f.log("opening an original request %s %s",f.method,f.url),J.open(f.method,f.url,(V=f.async)!==null&&V!==void 0?V:!0,f.user,f.password),J.addEventListener("load",function(){f.log('original "onload"'),f.status=J.status,f.statusText=J.statusText,f.responseURL=J.responseURL,f.responseType=J.responseType,f.response=J.response,f.responseText=J.responseText,f.responseXML=J.responseXML,f.log("set mock request readyState to DONE"),f.setReadyState(f.DONE),f.log("received original response",f.status,f.statusText),f.log("original response body:",f.response);var F=J.getAllResponseHeaders();f.log(`original response headers:
+`,F),f._responseHeaders=o.stringToHeaders(F),f.log("original response headers (normalized)",f._responseHeaders),f.log("original response finished"),E.emit("response",c,{status:J.status,statusText:J.statusText,headers:f._responseHeaders,body:J.response})}),f.propagateCallbacks(J),f.propagateListeners(J),f.propagateHeaders(J,f._requestHeaders),f.async&&(J.timeout=f.timeout),f.log("send",L),J.send(L)}})},v.prototype.abort=function(){this.log("abort"),this.readyState>this.UNSENT&&this.readyState-1&&A.splice(o,1),[]}_wrapOnceListener(A,i){const o=(...D)=>{this.removeListener(A,o),i.apply(this,D)};return o}setMaxListeners(A){return this.maxListeners=A,this}getMaxListeners(){return this.maxListeners}eventNames(){return Array.from(this.events.keys())}emit(A,...i){const o=this._getListeners(A);return o.forEach(D=>{D.apply(this,i)}),o.length>0}addListener(A,i){this._emitInternalEvent("newListener",A,i);const o=this._getListeners(A).concat(i);if(this.events.set(A,o),this.maxListeners>0&&this.listenerCount(A)>this.maxListeners&&!this.hasWarnedAboutPotentialMemoryLeak){this.hasWarnedAboutPotentialMemoryLeak=!0;const D=new e.MemoryLeakError(this,A,this.listenerCount(A));console.warn(D)}return this}on(A,i){return this.addListener(A,i)}once(A,i){return this.addListener(A,this._wrapOnceListener(A,i))}prependListener(A,i){const o=this._getListeners(A);if(o.length>0){const D=[i].concat(o);this.events.set(A,D)}else this.events.set(A,o.concat(i));return this}prependOnceListener(A,i){return this.prependListener(A,this._wrapOnceListener(A,i))}removeListener(A,i){const o=this._getListeners(A);return o.length>0&&(this._removeListener(o,i),this.events.set(A,o),this._emitInternalEvent("removeListener",A,i)),this}off(A,i){return this.removeListener(A,i)}removeAllListeners(A){return A?this.events.delete(A):this.events.clear(),this}listeners(A){return Array.from(this._getListeners(A))}listenerCount(A){return this._getListeners(A).length}rawListeners(A){return this.listeners(A)}};return XM.Emitter=t,t.defaultMaxListeners=10,XM}var Dg;function yl(){return Dg||(Dg=1,function(e){var t=H&&H.__createBinding||(Object.create?function(A,i,o,D){D===void 0&&(D=o);var n=Object.getOwnPropertyDescriptor(i,o);(!n||("get"in n?!i.__esModule:n.writable||n.configurable))&&(n={enumerable:!0,get:function(){return i[o]}}),Object.defineProperty(A,D,n)}:function(A,i,o,D){D===void 0&&(D=o),A[D]=i[o]}),M=H&&H.__exportStar||function(A,i){for(var o in A)o!=="default"&&!Object.prototype.hasOwnProperty.call(i,o)&&t(i,A,o)};Object.defineProperty(e,"__esModule",{value:!0}),M(Tl(),e),M(iw(),e)}(Lo)),Lo}var dl=Object.create,Qi=Object.defineProperty,ml=Object.getOwnPropertyDescriptor,bl=Object.getOwnPropertyNames,fl=Object.getPrototypeOf,Ul=Object.prototype.hasOwnProperty,Dw=(e,t)=>{for(var M in t)Qi(e,M,{get:t[M],enumerable:!0})},nw=(e,t,M,A)=>{if(t&&typeof t=="object"||typeof t=="function")for(let i of bl(t))!Ul.call(e,i)&&i!==M&&Qi(e,i,{get:()=>t[i],enumerable:!(A=ml(t,i))||A.enumerable});return e},UA=(e,t,M)=>(M=e!=null?dl(fl(e)):{},nw(!e||!e.__esModule?Qi(M,"default",{value:e,enumerable:!0}):M,e)),pl=e=>nw(Qi({},"__esModule",{value:!0}),e),rw={};Dw(rw,{GraphQLHandler:()=>zi,MockedRequest:()=>pA,RESTMethods:()=>Kw,RequestHandler:()=>an,RestHandler:()=>wn,SetupApi:()=>xw,SetupWorkerApi:()=>Pw,cleanUrl:()=>gn,compose:()=>Ew,context:()=>gw,createResponseComposition:()=>_o,defaultContext:()=>Ei,defaultResponse:()=>zw,graphql:()=>Cv,graphqlContext:()=>kw,handleRequest:()=>Cn,matchRequestUrl:()=>In,response:()=>Lw,rest:()=>Iv,restContext:()=>Ow,setupWorker:()=>gv});var ge=pl(rw),gw={};Dw(gw,{body:()=>ww,cookie:()=>Dn,data:()=>Cw,delay:()=>sw,errors:()=>Nw,extensions:()=>uw,fetch:()=>cw,json:()=>kM,set:()=>aw,status:()=>Iw,text:()=>lw,xml:()=>jw});var Ql={100:"Continue",101:"Switching Protocols",102:"Processing",103:"Early Hints",200:"OK",201:"Created",202:"Accepted",203:"Non-Authoritative Information",204:"No Content",205:"Reset Content",206:"Partial Content",207:"Multi-Status",208:"Already Reported",226:"IM Used",300:"Multiple Choices",301:"Moved Permanently",302:"Found",303:"See Other",304:"Not Modified",305:"Use Proxy",307:"Temporary Redirect",308:"Permanent Redirect",400:"Bad Request",401:"Unauthorized",402:"Payment Required",403:"Forbidden",404:"Not Found",405:"Method Not Allowed",406:"Not Acceptable",407:"Proxy Authentication Required",408:"Request Timeout",409:"Conflict",410:"Gone",411:"Length Required",412:"Precondition Failed",413:"Payload Too Large",414:"URI Too Long",415:"Unsupported Media Type",416:"Range Not Satisfiable",417:"Expectation Failed",418:"I'm a Teapot",421:"Misdirected Request",422:"Unprocessable Entity",423:"Locked",424:"Failed Dependency",425:"Too Early",426:"Upgrade Required",428:"Precondition Required",429:"Too Many Requests",431:"Request Header Fields Too Large",451:"Unavailable For Legal Reasons",500:"Internal Server Error",501:"Not Implemented",502:"Bad Gateway",503:"Service Unavailable",504:"Gateway Timeout",505:"HTTP Version Not Supported",506:"Variant Also Negotiates",507:"Insufficient Storage",508:"Loop Detected",509:"Bandwidth Limit Exceeded",510:"Not Extended",511:"Network Authentication Required"},Iw=(e,t)=>M=>(M.status=e,M.statusText=t||Ql[String(e)],M),El=it;function aw(...e){return t=>{const[M,A]=e;return typeof M=="string"?t.headers.append(M,A):(0,El.objectToHeaders)(M).forEach((o,D)=>{t.headers.append(D,o)}),t}}var zl=UA(uA),Dn=(e,t,M)=>A=>{const i=zl.serialize(e,t,M);return A.headers.append("Set-Cookie",i),typeof document<"u"&&(document.cookie=i),A},ww=e=>t=>(t.body=e,t);function Yt(e){try{return JSON.parse(e)}catch{return}}function ng(e){return e!=null&&typeof e=="object"&&!Array.isArray(e)}function SM(e,t){return Object.entries(t).reduce((M,[A,i])=>{const o=M[A];return Array.isArray(o)&&Array.isArray(i)?(M[A]=o.concat(i),M):ng(o)&&ng(i)?(M[A]=SM(o,i),M):(M[A]=i,M)},Object.assign({},e))}var kM=e=>t=>(t.headers.set("Content-Type","application/json"),t.body=JSON.stringify(e),t),Cw=e=>t=>{const M=Yt(t.body)||{},A=SM(M,{data:e});return kM(A)(t)},uw=e=>t=>{const M=Yt(t.body)||{},A=SM(M,{extensions:e});return kM(A)(t)},Ll=oD,Ko=2147483647,rg=100,Kl=400,Ol=5,gg=()=>(0,Ll.isNodeProcess)()?Ol:Math.floor(Math.random()*(Kl-rg)+rg),sw=e=>t=>{let M;if(typeof e=="string")switch(e){case"infinite":{M=Ko;break}case"real":{M=gg();break}default:throw new Error(`Failed to delay a response: unknown delay mode "${e}". Please make sure you provide one of the supported modes ("real", "infinite") or a number to "ctx.delay".`)}else if(typeof e>"u")M=gg();else{if(e>Ko)throw new Error(`Failed to delay a response: provided delay duration (${e}) exceeds the maximum allowed duration for "setTimeout" (${Ko}). This will cause the response to be returned immediately. Please use a number within the allowed range to delay the response by exact duration, or consider the "infinite" delay mode to delay the response indefinitely.`);M=e}return t.delay=M,t},Nw=e=>t=>{if(e==null)return t;const M=Yt(t.body)||{},A=SM(M,{errors:e});return kM(A)(t)},Sl=oD,kl=it,Ig=(0,Sl.isNodeProcess)()?(e,t)=>Promise.resolve().then(()=>UA(qC())).then(({default:M})=>M(e,t)):globalThis.fetch,ag=e=>{const t=new kl.Headers(e.headers);return t.set("x-msw-bypass","true"),{...e,headers:t.all()}},Bl=e=>{const{body:t,method:M}=e,A={...e,body:void 0};return["GET","HEAD"].includes(M)||(typeof t=="object"||typeof t=="number"||typeof t=="boolean"?A.body=JSON.stringify(t):A.body=t),A},cw=(e,t={})=>{if(typeof e=="string")return Ig(e,ag(t));const M=Bl(e),A=ag(M);return Ig(e.url.href,A)},lw=e=>t=>(t.headers.set("Content-Type","text/plain"),t.body=e,t),jw=e=>t=>(t.headers.set("Content-Type","text/xml"),t.body=e,t),hl=pt,Yl=pt,xl="[MSW]";function nn(e,...t){const M=(0,Yl.format)(e,...t);return`${xl} ${M}`}function Pl(e,...t){console.warn(nn(e,...t))}function Jl(e,...t){console.error(nn(e,...t))}var je={formatMessage:nn,warn:Pl,error:Jl};function Gl(){(0,hl.invariant)(typeof URL<"u",je.formatMessage(`Global "URL" class is not defined. This likely means that you're running MSW in an environment that doesn't support all Node.js standard API (e.g. React Native). If that's the case, please use an appropriate polyfill for the "URL" class, like "react-native-url-polyfill".`))}var Vl=pt,Zl=oD,Rl=Pt,Fl=Pt;function Oo(e,t,M){return[e.active,e.installing,e.waiting].filter(D=>D!=null).find(D=>M(D.scriptURL,t))||null}function Wl(e){return new URL(e,location.href).href}var Hl=async(e,t={},M)=>{const A=Wl(e),i=await navigator.serviceWorker.getRegistrations().then(r=>r.filter(g=>Oo(g,A,M)));!navigator.serviceWorker.controller&&i.length>0&&location.reload();const[o]=i;if(o)return o.update().then(()=>[Oo(o,A,M),o]);const[D,n]=await(0,Fl.until)(async()=>{const r=await navigator.serviceWorker.register(e,t);return[Oo(r,A,M),r]});if(D){if(D.message.includes("(404)")){const g=new URL((t==null?void 0:t.scope)||"/",location.href);throw new Error(je.formatMessage(`Failed to register a Service Worker for scope ('${g.href}') with script ('${A}'): Service Worker script does not exist at the given path.
+
+Did you forget to run "npx msw init "?
+
+Learn more about creating the Service Worker script: https://mswjs.io/docs/cli/init`))}throw new Error(je.formatMessage(`Failed to register the Service Worker:
+
+%s`,D.message))}return n};function vw(e={}){if(e.quiet)return;const t=e.message||"Mocking enabled.";console.groupCollapsed(`%c${je.formatMessage(t)}`,"color:orangered;font-weight:bold;"),console.log("%cDocumentation: %chttps://mswjs.io/docs","font-weight:bold","font-weight:normal"),console.log("Found an issue? https://github.com/mswjs/msw/issues"),e.workerUrl&&console.log("Worker script URL:",e.workerUrl),e.workerScope&&console.log("Worker scope:",e.workerScope),console.groupEnd()}async function ql(e,t){var M,A;if(e.workerChannel.send("MOCK_ACTIVATE"),await e.events.once("MOCKING_ENABLED"),e.isMockingEnabled){je.warn('Found a redundant "worker.start()" call. Note that starting the worker while mocking is already enabled will have no effect. Consider removing this "worker.start()" call.');return}e.isMockingEnabled=!0,vw({quiet:t.quiet,workerScope:(M=e.registration)==null?void 0:M.scope,workerUrl:(A=e.worker)==null?void 0:A.scriptURL})}var Xl=class{constructor(e){this.port=e}postMessage(e,...t){const[M,A]=t;this.port.postMessage({type:e,data:M},{transfer:A})}},Tw=class extends Error{constructor(e){super(e),this.name="NetworkError"}},_l=ni,$l=it,ej=UA(uA),wg=sD,tj=ni,Mj=gt,Aj=it,ij=UA(uA);function Cg(){return ij.parse(document.cookie)}function oj(e){if(typeof document>"u"||typeof location>"u")return{};switch(e.credentials){case"same-origin":return location.origin===e.url.origin?Cg():{};case"include":return Cg();default:return{}}}var Dj=it;function nj(e){var t,M;const A=(0,Dj.stringToHeaders)(e),i=A.get("content-type")||"text/plain",o=A.get("content-disposition");if(!o)throw new Error('"Content-Disposition" header is required.');const D=o.split(";").reduce((g,I)=>{const[a,...C]=I.trim().split("=");return g[a]=C.join("="),g},{}),n=(t=D.name)==null?void 0:t.slice(1,-1),r=(M=D.filename)==null?void 0:M.slice(1,-1);return{name:n,filename:r,contentType:i}}function rj(e,t){const M=t==null?void 0:t.get("content-type");if(!M)return;const[,...A]=M.split(/; */),i=A.filter(r=>r.startsWith("boundary=")).map(r=>r.replace(/^boundary=/,""))[0];if(!i)return;const o=new RegExp(`--+${i}`),D=e.split(o).filter(r=>r.startsWith(`\r
+`)&&r.endsWith(`\r
+`)).map(r=>r.trimStart().replace(/\r\n$/,""));if(!D.length)return;const n={};try{for(const r of D){const[g,...I]=r.split(`\r
+\r
+`),a=I.join(`\r
+\r
+`),{contentType:C,filename:N,name:b}=nj(g),j=N===void 0?a:new File([a],N,{type:C}),s=n[b];s===void 0?n[b]=j:Array.isArray(s)?n[b]=[...s,j]:n[b]=[s,j]}return n}catch{return}}function yw(e,t){var M;if(!e)return e;const A=((M=t==null?void 0:t.get("content-type"))==null?void 0:M.toLowerCase())||"";return A.startsWith("multipart/form-data")&&typeof e!="object"?rj(e.toString(),t)||e:A.includes("json")&&typeof e!="object"&&Yt(e.toString())||e}function rn(e,t){return e.toLowerCase()===t.toLowerCase()}var pA=class extends tj.IsomorphicRequest{constructor(e,t={}){super(e,t),t.id&&(this.id=t.id),this.cache=t.cache||"default",this.destination=t.destination||"",this.integrity=t.integrity||"",this.keepalive=t.keepalive||!1,this.mode=t.mode||"cors",this.priority=t.priority||"auto",this.redirect=t.redirect||"follow",this.referrer=t.referrer||"",this.referrerPolicy=t.referrerPolicy||"no-referrer",this.cookies=t.cookies||this.getCookies()}get body(){const e=(0,Mj.decodeBuffer)(this._body),t=yw(e,this.headers);if(!(rn(this.method,"GET")&&t===""))return t}passthrough(){return{status:101,statusText:"Continue",headers:new Aj.Headers,body:null,passthrough:!0,once:!1}}getCookies(){var e;const t=this.headers.get("cookie"),M=t?ej.parse(t):{};wg.store.hydrate();const A=Array.from((e=wg.store.get({...this,url:this.url.href}))==null?void 0:e.entries()).reduce((D,[n,{value:r}])=>Object.assign(D,{[n.trim()]:r}),{}),o={...oj(this),...A};for(const[D,n]of Object.entries(o))this.headers.append("cookie",`${D}=${n}`);return{...o,...M}}};function gj(e){const t=new URL(e.url),M=new $l.Headers(e.headers);return new pA(t,{...e,body:(0,_l.encodeBuffer)(e.body||""),headers:M})}var Ij=Pt,aj=async(e,t,M)=>{const A=t.filter(o=>o.test(e,M));if(A.length===0)return{handler:void 0,response:void 0};const i=await A.reduce(async(o,D)=>{const n=await o;if(n!=null&&n.response)return o;const r=await D.run(e,M);return r===null||r.handler.shouldSkip?null:r.response?(r.response.once&&D.markAsSkipped(!0),r):{request:r.request,handler:r.handler,response:void 0,parsedResult:r.parsedResult}},Promise.resolve(null));return i?{handler:i.handler,publicRequest:i.request,parsedRequest:i.parsedResult,response:i.response}:{handler:void 0,response:void 0}},dw=UA(us()),wj=tl,QA=e=>e.referrer.startsWith(e.url.origin)?e.url.pathname:new URL(e.url.pathname,`${e.url.protocol}//${e.url.host}`).href;function mw(e){var t;const M=e.definitions.find(A=>A.kind==="OperationDefinition");return{operationType:M==null?void 0:M.operation,operationName:(t=M==null?void 0:M.name)==null?void 0:t.value}}function Cj(e){try{const t=(0,wj.parse)(e);return mw(t)}catch(t){return t}}function uj(e,t,M){const A={variables:e};for(const[i,o]of Object.entries(t)){if(!(i in M))throw new Error(`Given files do not have a key '${i}' .`);for(const D of o){const[n,...r]=D.split(".").reverse(),g=r.reverse();let I=A;for(const a of g){if(!(a in I))throw new Error(`Property '${g}' is not in operations.`);I=I[a]}I[n]=M[i]}}return A.variables}function sj(e){var t,M;switch(e.method){case"GET":{const A=e.url.searchParams.get("query"),i=e.url.searchParams.get("variables")||"";return{query:A,variables:Yt(i)}}case"POST":{if((t=e.body)!=null&&t.query){const{query:A,variables:i}=e.body;return{query:A,variables:i}}if((M=e.body)!=null&&M.operations){const{operations:A,map:i,...o}=e.body,D=Yt(A)||{};if(!D.query)return null;const n=Yt(i||"")||{},r=D.variables?uj(D.variables,n,o):{};return{query:D.query,variables:r}}}default:return null}}function bw(e){const t=sj(e);if(!t||!t.query)return;const{query:M,variables:A}=t,i=Cj(M);if(i instanceof Error){const o=QA(e);throw new Error(je.formatMessage(`Failed to intercept a GraphQL request to "%s %s": cannot parse query. See the error message from the parser below.
+
+%s`,e.method,o,i.message))}return{operationType:i.operationType,operationName:i.operationName,variables:A}}function fw(e){return e<300?"#69AB32":e<400?"#F0BB4B":"#E95F5D"}function Uw(){const e=new Date;return[e.getHours(),e.getMinutes(),e.getSeconds()].map(String).map(t=>t.slice(0,2)).map(t=>t.padStart(2,"0")).join(":")}function pw(e){return{...e,body:e.body,headers:e.headers.all()}}var Nj=it;function Qw(e){const t=(0,Nj.objectToHeaders)(e.headers),M=yw(e.body,t);return{...e,body:M}}var cj=gl,lj=cA,jj=/[\?|#].*$/g;function vj(e){return new URL(`/${e}`,"http://localhost").searchParams}function gn(e){return e.replace(jj,"")}function Tj(e){return/^([a-z][a-z\d\+\-\.]*:)?\/\//i.test(e)}function yj(e,t){if(Tj(e)||e.startsWith("*"))return e;const M=t||typeof document<"u"&&document.baseURI;return M?decodeURI(new URL(encodeURI(e),M).href):e}function dj(e,t){if(e instanceof RegExp)return e;const M=yj(e,t);return gn(M)}function mj(e){return e.replace(/([:a-zA-Z_-]*)(\*{1,2})+/g,(t,M,A)=>{const i="(.*)";return M?M.startsWith(":")?`${M}${A}`:`${M}${i}`:i}).replace(/([^\/])(:)(?=\d+)/,"$1\\$2").replace(/^([^\/]+)(:)(?=\/\/)/,"$1\\$2")}function In(e,t,M){const A=dj(t,M),i=typeof A=="string"?mj(A):A,o=(0,lj.getCleanUrl)(e),D=(0,cj.match)(i,{decode:decodeURIComponent})(o),n=D&&D.params||{};return{matches:D!==!1,params:n}}var bj=it;function Ew(...e){return(...t)=>e.reduceRight((M,A)=>M instanceof Promise?Promise.resolve(M).then(A):A(M),t[0])}var zw={status:200,statusText:"OK",body:null,delay:0,once:!1,passthrough:!1},fj=[];function _o(e,t=fj){return async(...M)=>{const A=Object.assign({},zw,{headers:new bj.Headers({"x-powered-by":"msw"})},e),i=[...t,...M].filter(Boolean);return i.length>0?Ew(...i)(A):A}}var Lw=Object.assign(_o(),{once:_o({once:!0}),networkError(e){throw new Tw(e)}}),Uj=/[\/\\]msw[\/\\]src[\/\\](.+)/,pj=/(node_modules)?[\/\\]lib[\/\\](umd|esm|iief|cjs)[\/\\]|^[^\/\\]*$/;function Qj(e){const t=e.stack;if(!t)return;const A=t.split(`
+`).slice(1).find(o=>!(Uj.test(o)||pj.test(o)));return A?A.replace(/\s*at [^()]*\(([^)]+)\)/,"$1").replace(/^@/,""):void 0}function Ej(e){return e?typeof e[Symbol.iterator]=="function":!1}var Ei={status:Iw,set:aw,delay:sw,fetch:cw},an=class{constructor(e){this.shouldSkip=!1,this.ctx=e.ctx||Ei,this.resolver=e.resolver;const t=Qj(new Error);this.info={...e.info,callFrame:t}}parse(e,t){return null}test(e,t){return this.predicate(e,this.parse(e,t),t)}getPublicRequest(e,t){return e}markAsSkipped(e=!0){this.shouldSkip=e}async run(e,t){if(this.shouldSkip)return null;const M=this.parse(e,t);if(!this.predicate(e,M,t))return null;const i=this.getPublicRequest(e,M),D=await this.wrapResolver(this.resolver)(i,Lw,this.ctx);return this.createExecutionResult(M,i,D)}wrapResolver(e){return async(t,M,A)=>{const i=this.resolverGenerator||await e(t,M,A);if(Ej(i)){const{value:o,done:D}=i[Symbol.iterator]().next(),n=await o;return!n&&D?this.resolverGeneratorResult:(this.resolverGenerator||(this.resolverGenerator=i),this.resolverGeneratorResult=n,n)}return i}}createExecutionResult(e,t,M){return{handler:this,parsedResult:e||null,request:t,response:M||null}}},Kw=(e=>(e.HEAD="HEAD",e.GET="GET",e.POST="POST",e.PUT="PUT",e.PATCH="PATCH",e.OPTIONS="OPTIONS",e.DELETE="DELETE",e))(Kw||{}),Ow={...Ei,cookie:Dn,body:ww,text:lw,json:kM,xml:jw},zj=class extends pA{constructor(e,t){super(e.url,{...e,body:e._body}),this.params=t,this.id=e.id}},wn=class extends an{constructor(e,t,M){super({info:{header:`${e} ${t}`,path:t,method:e},ctx:Ow,resolver:M}),this.checkRedundantQueryParameters()}checkRedundantQueryParameters(){const{method:e,path:t}=this.info;if(t instanceof RegExp||gn(t)===t)return;vj(t).forEach((i,o)=>{}),je.warn(`Found a redundant usage of query parameters in the request handler URL for "${e} ${t}". Please match against a path instead and access query parameters in the response resolver function using "req.url.searchParams".`)}parse(e,t){return In(e.url,this.info.path,t==null?void 0:t.baseUrl)}getPublicRequest(e,t){return new zj(e,t.params||{})}predicate(e,t){return(this.info.method instanceof RegExp?this.info.method.test(e.method):rn(this.info.method,e.method))&&t.matches}log(e,t){const M=QA(e),A=pw(e),i=Qw(t),o=fw(t.status);console.groupCollapsed(je.formatMessage("%s %s %s (%c%s%c)"),Uw(),e.method,M,`color:${o}`,`${t.status} ${t.statusText}`,"color:inherit"),console.log("Request",A),console.log("Handler:",this),console.log("Response",i),console.groupEnd()}},GA=pt,Lj=(e,t)=>M=>{Kj(e);const A=Yt(M.body)||{},i=SM(A,{[e]:t});return kM(i)(M)};function Kj(e){(0,GA.invariant)(e.trim()!=="",je.formatMessage("Failed to set a custom field on a GraphQL response: field name cannot be empty.")),(0,GA.invariant)(e!=="data",je.formatMessage('Failed to set a custom "%s" field on a mocked GraphQL response: forbidden field name. Did you mean to call "ctx.data()" instead?',e)),(0,GA.invariant)(e!=="errors",je.formatMessage('Failed to set a custom "%s" field on a mocked GraphQL response: forbidden field name. Did you mean to call "ctx.errors()" instead?',e)),(0,GA.invariant)(e!=="extensions",je.formatMessage('Failed to set a custom "%s" field on a mocked GraphQL response: forbidden field name. Did you mean to call "ctx.extensions()" instead?',e))}function Sw(e,t){try{return e()}catch(M){t==null||t(M)}}var kw={...Ei,data:Cw,extensions:uw,errors:Nw,cookie:Dn,field:Lj};function Oj(e){return e==null?!1:typeof e=="object"&&"kind"in e&&"definitions"in e}var Sj=class extends pA{constructor(e,t,M){super(e.url,{...e,body:e._body}),this.variables=t,this.operationName=M}},zi=class extends an{constructor(e,t,M,A){let i=t;if(Oj(t)){const D=mw(t);if(D.operationType!==e)throw new Error(`Failed to create a GraphQL handler: provided a DocumentNode with a mismatched operation type (expected "${e}", but got "${D.operationType}").`);if(!D.operationName)throw new Error("Failed to create a GraphQL handler: provided a DocumentNode with no operation name.");i=D.operationName}const o=e==="all"?`${e} (origin: ${M.toString()})`:`${e} ${i} (origin: ${M.toString()})`;super({info:{header:o,operationType:e,operationName:i},ctx:kw,resolver:A}),this.endpoint=M}parse(e){return Sw(()=>bw(e),t=>console.error(t.message))}getPublicRequest(e,t){var M,A;return new Sj(e,(M=t==null?void 0:t.variables)!=null?M:{},(A=t==null?void 0:t.operationName)!=null?A:"")}predicate(e,t){if(!t)return!1;if(!t.operationName&&this.info.operationType!=="all"){const o=QA(e);return je.warn(`Failed to intercept a GraphQL request at "${e.method} ${o}": anonymous GraphQL operations are not supported.
+
+Consider naming this operation or using "graphql.operation()" request handler to intercept GraphQL requests regardless of their operation name/type. Read more: https://mswjs.io/docs/api/graphql/operation `),!1}const M=In(e.url,this.endpoint),A=this.info.operationType==="all"||t.operationType===this.info.operationType,i=this.info.operationName instanceof RegExp?this.info.operationName.test(t.operationName||""):t.operationName===this.info.operationName;return M.matches&&A&&i}log(e,t,M){const A=pw(e),i=Qw(t),o=fw(t.status),D=M!=null&&M.operationName?`${M==null?void 0:M.operationType} ${M==null?void 0:M.operationName}`:`anonymous ${M==null?void 0:M.operationType}`;console.groupCollapsed(je.formatMessage("%s %s (%c%s%c)"),Uw(),`${D}`,`color:${o}`,`${t.status} ${t.statusText}`,"color:inherit"),console.log("Request:",A),console.log("Handler:",this),console.log("Response:",i),console.groupEnd()}},kj=3,Bj=4,Bw=.5;function hj(e){return e.reduce((t,M)=>(M instanceof wn&&t.rest.push(M),M instanceof zi&&t.graphql.push(M),t),{rest:[],graphql:[]})}function Yj(){return(e,t)=>{const{path:M,method:A}=t.info;if(M instanceof RegExp||A instanceof RegExp)return 1/0;const o=rn(e.method,A)?Bw:0,D=QA(e);return(0,dw.default)(D,M)-o}}function xj(e){return(t,M)=>{if(typeof e.operationName>"u")return 1/0;const{operationType:A,operationName:i}=M.info;if(typeof i!="string")return 1/0;const D=e.operationType===A?Bw:0;return(0,dw.default)(e.operationName,i)-D}}function Pj(e,t,M){return t.reduce((i,o)=>{const D=M(e,o);return i.concat([[D,o]])},[]).sort(([i],[o])=>i-o).filter(([i])=>i<=kj).slice(0,Bj).map(([,i])=>i)}function Jj(e){return e.length>1?`Did you mean to request one of the following resources instead?
+
+${e.map(t=>` • ${t.info.header}`).join(`
+`)}`:`Did you mean to request "${e[0].info.header}" instead?`}function Gj(e,t,M="warn"){const A=Sw(()=>bw(e));function i(){const n=hj(t),r=A?n.graphql:n.rest,g=Pj(e,r,A?xj(A):Yj());return g.length>0?Jj(g):""}function o(){const n=QA(e),r=A?`${A.operationType} ${A.operationName} (${e.method} ${n})`:`${e.method} ${n}`,g=i();return["captured a request without a matching request handler:",` • ${r}`,g,`If you still wish to intercept this unhandled request, please create a request handler for it.
+Read more: https://mswjs.io/docs/getting-started/mocks`].filter(Boolean).join(`
+
+`)}function D(n){const r=o();switch(n){case"error":throw je.error("Error: %s",r),new Error(je.formatMessage('Cannot bypass a request when using the "error" strategy for the "onUnhandledRequest" option.'));case"warn":{je.warn("Warning: %s",r);break}case"bypass":break;default:throw new Error(je.formatMessage('Failed to react to an unhandled request: unknown strategy "%s". Please provide one of the supported strategies ("bypass", "warn", "error") or a custom callback function as the value of the "onUnhandledRequest" option.',n))}}if(typeof M=="function"){M(e,{warning:D.bind(null,"warn"),error:D.bind(null,"error")});return}D(M)}var ug=sD;function Vj(e,t){ug.store.add({...e,url:e.url.toString()},t),ug.store.persist()}async function Cn(e,t,M,A,i){var o,D,n,r,g,I;if(A.emit("request:start",e),e.headers.get("x-msw-bypass")==="true"){A.emit("request:end",e),(o=i==null?void 0:i.onPassthroughResponse)==null||o.call(i,e);return}const[a,C]=await(0,Ij.until)(()=>aj(e,t,i==null?void 0:i.resolutionContext));if(a)throw A.emit("unhandledException",a,e),a;const{handler:N,response:b}=C;if(!N){Gj(e,t,M.onUnhandledRequest),A.emit("request:unhandled",e),A.emit("request:end",e),(D=i==null?void 0:i.onPassthroughResponse)==null||D.call(i,e);return}if(!b){je.warn(`Expected response resolver to return a mocked response Object, but got %s. The original response is going to be used instead.
+
+ • %s
+ %s`,b,N.info.header,N.info.callFrame),A.emit("request:end",e),(n=i==null?void 0:i.onPassthroughResponse)==null||n.call(i,e);return}if(b.passthrough){A.emit("request:end",e),(r=i==null?void 0:i.onPassthroughResponse)==null||r.call(i,e);return}Vj(e,b),A.emit("request:match",e);const j=C,s=((g=i==null?void 0:i.transformResponse)==null?void 0:g.call(i,b))||b;return(I=i==null?void 0:i.onMockedResponse)==null||I.call(i,s,j),A.emit("request:end",e),s}var sg=it;async function hw(e){return{status:e.status,statusText:e.statusText,headers:(0,sg.flattenHeadersObject)((0,sg.headersToObject)(e.headers)),body:await e.clone().text()}}var Zj=(e,t)=>async(M,A)=>{var i;const o=new Xl(M.ports[0]),D=gj(A.payload);try{await Cn(D,e.requestHandlers,t,e.emitter,{transformResponse:Rj,onPassthroughResponse(){o.postMessage("NOT_FOUND")},async onMockedResponse(n,{handler:r,publicRequest:g,parsedRequest:I}){if(n.body instanceof ReadableStream)throw new Error(je.formatMessage('Failed to construct a mocked response with a "ReadableStream" body: mocked streams are not supported. Follow https://github.com/mswjs/msw/issues/1336 for more details.'));const a=new Response(n.body,n),C=a.clone(),N=await a.arrayBuffer(),b=n.body==null?null:N;o.postMessage("MOCK_RESPONSE",{...n,body:b},[N]),t.quiet||e.emitter.once("response:mocked",async()=>{r.log(g,await hw(C),I)})}})}catch(n){if(n instanceof Tw){o.postMessage("NETWORK_ERROR",{name:n.name,message:n.message});return}n instanceof Error&&(je.error(`Uncaught exception in the request handler for "%s %s":
+
+%s
+
+This exception has been gracefully handled as a 500 response, however, it's strongly recommended to resolve this error, as it indicates a mistake in your code. If you wish to mock an error response, please see this guide: https://mswjs.io/docs/recipes/mocking-error-responses`,D.method,D.url,(i=n.stack)!=null?i:n),o.postMessage("MOCK_RESPONSE",{status:500,statusText:"Request Handler Error",headers:{"Content-Type":"application/json"},body:JSON.stringify({name:n.name,message:n.message,stack:n.stack})}))}};function Rj(e){return{status:e.status,statusText:e.statusText,headers:e.headers.all(),body:e.body,delay:e.delay}}async function Fj(e,t){e.workerChannel.send("INTEGRITY_CHECK_REQUEST");const{payload:M}=await e.events.once("INTEGRITY_CHECK_RESPONSE");if(M!=="3d6b9f06410d179a7f7404d4bf4c3c70")throw new Error(`Currently active Service Worker (${M}) is behind the latest published one (3d6b9f06410d179a7f7404d4bf4c3c70).`);return t}var Ng=Pt;function Wj(e){const t=window.XMLHttpRequest.prototype.send;window.XMLHttpRequest.prototype.send=function(...A){(0,Ng.until)(()=>e).then(()=>{window.XMLHttpRequest.prototype.send=t,this.send(...A)})};const M=window.fetch;window.fetch=async(...A)=>(await(0,Ng.until)(()=>e),window.fetch=M,window.fetch(...A))}function Hj(e){return(t,M)=>{var A;const{payload:i}=M;if((A=i.type)!=null&&A.includes("opaque"))return;const o=new Response(i.body||null,i);o.headers.get("x-powered-by")==="msw"?e.emitter.emit("response:mocked",o,i.requestId):e.emitter.emit("response:bypass",o,i.requestId)}}function qj(e,t){!(t!=null&&t.quiet)&&!location.href.startsWith(e.scope)&&je.warn(`Cannot intercept requests on this page because it's outside of the worker's scope ("${e.scope}"). If you wish to mock API requests on this page, you must resolve this scope issue.
+
+- (Recommended) Register the worker at the root level ("/") of your application.
+- Set the "Service-Worker-Allowed" response header to allow out-of-scope workers.`)}var Xj=e=>function(M,A){const o=(async()=>{e.events.removeAllListeners(),e.workerChannel.on("REQUEST",Zj(e,M)),e.workerChannel.on("RESPONSE",Hj(e));const D=await Hl(M.serviceWorker.url,M.serviceWorker.options,M.findWorker),[n,r]=D;if(!n){const I=A!=null&&A.findWorker?je.formatMessage(`Failed to locate the Service Worker registration using a custom "findWorker" predicate.
+
+Please ensure that the custom predicate properly locates the Service Worker registration at "%s".
+More details: https://mswjs.io/docs/api/setup-worker/start#findworker
+`,M.serviceWorker.url):je.formatMessage(`Failed to locate the Service Worker registration.
+
+This most likely means that the worker script URL "%s" cannot resolve against the actual public hostname (%s). This may happen if your application runs behind a proxy, or has a dynamic hostname.
+
+Please consider using a custom "serviceWorker.url" option to point to the actual worker script location, or a custom "findWorker" option to resolve the Service Worker registration manually. More details: https://mswjs.io/docs/api/setup-worker/start`,M.serviceWorker.url,location.host);throw new Error(I)}e.worker=n,e.registration=r,e.events.addListener(window,"beforeunload",()=>{n.state!=="redundant"&&e.workerChannel.send("CLIENT_CLOSED"),window.clearInterval(e.keepAliveInterval)});const[g]=await(0,Rl.until)(()=>Fj(e,n));return g&&je.error(`Detected outdated Service Worker: ${g.message}
+
+The mocking is still enabled, but it's highly recommended that you update your Service Worker by running:
+
+$ npx msw init
+
+This is necessary to ensure that the Service Worker is in sync with the library to guarantee its stability.
+If this message still persists after updating, please report an issue: https://github.com/open-draft/msw/issues `),e.keepAliveInterval=window.setInterval(()=>e.workerChannel.send("KEEPALIVE_REQUEST"),5e3),qj(r,e.startOptions),r})().then(async D=>{const n=D.installing||D.waiting;return n&&await new Promise(r=>{n.addEventListener("statechange",()=>{if(n.state==="activated")return r()})}),await ql(e,M).catch(r=>{throw new Error(`Failed to enable mocking: ${r==null?void 0:r.message}`)}),D});return M.waitUntilReady&&Wj(o),o};function Yw(e={}){e.quiet||console.log(`%c${je.formatMessage("Mocking disabled.")}`,"color:orangered;font-weight:bold;")}var _j=e=>function(){var M;if(!e.isMockingEnabled){je.warn('Found a redundant "worker.stop()" call. Note that stopping the worker while mocking already stopped has no effect. Consider removing this "worker.stop()" call.');return}e.workerChannel.send("MOCK_DEACTIVATE"),e.isMockingEnabled=!1,window.clearInterval(e.keepAliveInterval),Yw({quiet:(M=e.startOptions)==null?void 0:M.quiet})},$j={serviceWorker:{url:"/mockServiceWorker.js",options:null},quiet:!1,waitUntilReady:!0,onUnhandledRequest:"warn",findWorker(e,t){return e===t}},ev=ni,tv=Il(),Mv=vl();function Av(e){return new Response(e.body,{status:e.status,statusText:e.statusText,headers:e.headers})}function iv(e,t){const M=new ev.BatchInterceptor({name:"fallback",interceptors:[new tv.FetchInterceptor,new Mv.XMLHttpRequestInterceptor]});return M.on("request",async A=>{const i=new pA(A.url,{...A,body:await A.arrayBuffer()}),o=await Cn(i,e.requestHandlers,t,e.emitter,{transformResponse(D){return{status:D.status,statusText:D.statusText,headers:D.headers.all(),body:D.body,delay:D.delay}},onMockedResponse(D,{handler:n,publicRequest:r,parsedRequest:g}){t.quiet||e.emitter.once("response:mocked",async I=>{n.log(r,await hw(I),g)})}});o&&A.respondWith(o)}),M.on("response",(A,i)=>{if(!A.id)return;const o=Av(i);i.headers.get("x-powered-by")==="msw"?e.emitter.emit("response:mocked",o,A.id):e.emitter.emit("response:bypass",o,A.id)}),M.apply(),M}function ov(e){return async function(M){e.fallbackInterceptor=iv(e,M),vw({message:"Mocking enabled (fallback mode).",quiet:M.quiet})}}function Dv(e){return function(){var M,A;(M=e.fallbackInterceptor)==null||M.dispose(),Yw({quiet:(A=e.startOptions)==null?void 0:A.quiet})}}var nv=pt,cg=yl();function rv(e,t){const M=e.emit;M._isPiped||(e.emit=function(A,...i){return t.emit(A,...i),M.call(this,A,...i)},e.emit._isPiped=!0)}function lg(e){const t=[...e];return Object.freeze(t),t}var xw=class{constructor(...e){this.validateHandlers(...e),this.initialHandlers=lg(e),this.currentHandlers=[...e],this.emitter=new cg.Emitter,this.publicEmitter=new cg.Emitter,rv(this.emitter,this.publicEmitter),this.events=this.createLifeCycleEvents()}validateHandlers(...e){for(const t of e)(0,nv.invariant)(!Array.isArray(t),je.formatMessage('Failed to construct "%s" given an Array of request handlers. Make sure you spread the request handlers when calling the respective setup function.'),this.constructor.name)}dispose(){this.emitter.removeAllListeners(),this.publicEmitter.removeAllListeners()}use(...e){this.currentHandlers.unshift(...e)}restoreHandlers(){this.currentHandlers.forEach(e=>{e.markAsSkipped(!1)})}resetHandlers(...e){this.currentHandlers=e.length>0?[...e]:[...this.initialHandlers]}listHandlers(){return lg(this.currentHandlers)}createLifeCycleEvents(){return{on:(...e)=>this.publicEmitter.on(...e),removeListener:(...e)=>this.publicEmitter.removeListener(...e),removeAllListeners:(...e)=>this.publicEmitter.removeAllListeners(...e)}}},Pw=class extends xw{constructor(...e){super(...e),this.startHandler=null,this.stopHandler=null,(0,Vl.invariant)(!(0,Zl.isNodeProcess)(),je.formatMessage("Failed to execute `setupWorker` in a non-browser environment. Consider using `setupServer` for Node.js environment instead.")),this.listeners=[],this.context=this.createWorkerContext()}createWorkerContext(){const e={isMockingEnabled:!1,startOptions:null,worker:null,registration:null,requestHandlers:this.currentHandlers,emitter:this.emitter,workerChannel:{on:(t,M)=>{this.context.events.addListener(navigator.serviceWorker,"message",A=>{if(A.source!==this.context.worker)return;const i=A.data;i&&i.type===t&&M(A,i)})},send:t=>{var M;(M=this.context.worker)==null||M.postMessage(t)}},events:{addListener:(t,M,A)=>(t.addEventListener(M,A),this.listeners.push({eventType:M,target:t,callback:A}),()=>{t.removeEventListener(M,A)}),removeAllListeners:()=>{for(const{target:t,eventType:M,callback:A}of this.listeners)t.removeEventListener(M,A);this.listeners=[]},once:t=>{const M=[];return new Promise((A,i)=>{const o=D=>{try{const n=D.data;n.type===t&&A(n)}catch(n){i(n)}};M.push(this.context.events.addListener(navigator.serviceWorker,"message",o),this.context.events.addListener(navigator.serviceWorker,"messageerror",i))}).finally(()=>{M.forEach(A=>A())})}},useFallbackMode:!("serviceWorker"in navigator)||location.protocol==="file:"};return Object.defineProperties(e,{requestHandlers:{get:()=>this.currentHandlers}}),this.startHandler=e.useFallbackMode?ov(e):Xj(e),this.stopHandler=e.useFallbackMode?Dv(e):_j(e),e}async start(e={}){return this.context.startOptions=SM($j,e),await this.startHandler(this.context.startOptions,e)}printHandlers(){this.listHandlers().forEach(t=>{const{header:M,callFrame:A}=t.info,i=t.info.hasOwnProperty("operationType")?"[graphql]":"[rest]";console.groupCollapsed(`${i} ${M}`),A&&console.log(`Declaration: ${A}`),console.log("Handler:",t),console.groupEnd()})}stop(){super.dispose(),this.context.events.removeAllListeners(),this.context.emitter.removeAllListeners(),this.stopHandler()}};function gv(...e){return new Pw(...e)}function zt(e){return(t,M)=>new wn(e,t,M)}var Iv={all:zt(/.+/),head:zt("HEAD"),get:zt("GET"),post:zt("POST"),put:zt("PUT"),delete:zt("DELETE"),patch:zt("PATCH"),options:zt("OPTIONS")};function ii(e,t){return(M,A)=>new zi(e,M,t,A)}function Jw(e){return t=>new zi("all",new RegExp(".*"),e,t)}var av={operation:Jw("*"),query:ii("query","*"),mutation:ii("mutation","*")};function wv(e){return{operation:Jw(e),query:ii("query",e),mutation:ii("mutation",e)}}var Cv={...av,link:wv};Gl();var at=(e=>(e.OPPRETTET="OPPRETTET",e.STATUS_ENDRET="STATUS_ENDRET",e.DETALJER_ENDRET="DETALJER_ENDRET",e.AVTALT="AVTALT",e.AVTALT_DATO_ENDRET="AVTALT_DATO_ENDRET",e.BLE_HISTORISK="BLE_HISTORISK",e.FORHAANDSORIENTERING_LEST="FORHAANDSORIENTERING_LEST",e.KASSERT="KASSERT",e))(at||{}),Gw=(e=>(e.ETIKETT_ENDRET="ETIKETT_ENDRET",e))(Gw||{}),un=(e=>(e.MOTE_TID_OG_STED_ENDRET="MOTE_TID_OG_STED_ENDRET",e.REFERAT_OPPRETTET="REFERAT_OPPRETTET",e.REFERAT_ENDRET="REFERAT_ENDRET",e.REFERAT_PUBLISERT="REFERAT_PUBLISERT",e))(un||{}),wA=(e=>(e.SOKNADSSTATUS_ENDRET="SOKNADSSTATUS_ENDRET",e.IKKE_FATT_JOBBEN="IKKE_FATT_JOBBEN",e.FATT_JOBBEN="FATT_JOBBEN",e.DEL_CV_SVART="DEL_CV_SVART",e))(wA||{});let jg=1003,vg=4500;const tM=({tittel:e,status:t,avtalt:M,beskrivelse:A,eksternAktivitet:i})=>(jg+=1e3,vg+=1e3,{id:`${jg}`,versjon:`${vg}`,tittel:e,beskrivelse:A,type:cM.EKSTERN_AKTIVITET_TYPE,status:t,fraDato:"2020-08-21T08:00:00+02:00",tilDato:"2025-11-30T12:15:00+02:00",opprettetDato:"2018-08-21T11:55:14.044+02:00",endretDato:"2018-08-21T11:57:57.636+02:00",endretAv:"z990207",historisk:!1,avsluttetKommentar:void 0,avtalt:M,endretAvType:"NAV",transaksjonsType:at.OPPRETTET,etikett:void 0,forhaandsorientering:void 0,eksternAktivitet:i,oppfolgingsperiodeId:"a2aa22a2-2aa2-4e02-8cc2-d44ef605fa33"}),uv=Zw()?[Ne({...tM({tittel:"Nå kan han lukte gull, derfor ror vi inn mot land",status:ye.PLANLAGT,avtalt:!0,beskrivelse:"Denne aktiviteten har blitt overført fra Arena og ligger nå i veilarbaktivitet",eksternAktivitet:{type:Xt.ARENA_TILTAK_TYPE,oppgave:void 0,handlinger:void 0,detaljer:[{label:"Deltakelse",verdi:"95.6%"},{label:"Antall dager per uke",verdi:"5"}],etiketter:[{kode:"SOKT_INN"},{kode:"AVSLAG"}]}}),fraDato:void 0,tilDato:void 0}),Ne({...tM({tittel:"testestestest",status:ye.PLANLAGT,avtalt:!1,beskrivelse:"Denne aktiviteten har blitt overført fra Arena og ligger nå i veilarbaktivitet",eksternAktivitet:{type:Xt.ARENA_TILTAK_TYPE,oppgave:{ekstern:{tekst:"Evaluer deltakelsen",knapptekst:"Gi din evaluering",url:"http://localhost:8080/ekstern",subtekst:"Du har vært hos muligheter i 5 måneder"},intern:{tekst:"Evaluer deltakelsen",knapptekst:"Gi din evaluering",url:"http://localhost:8080/ekstern",subtekst:"Du har vært hos muligheter i 5 måneder"}},handlinger:void 0,detaljer:[{label:"Deltakelse",verdi:"95.6%"},{label:"Antall dager per uke",verdi:"5"}],etiketter:[{kode:"SOKT_INN"}]}}),fraDato:dt(new Date,2).toISOString(),tilDato:MD(new Date,8).toISOString()}),Ne({...tM({tittel:"Saltrød og Høneby",status:ye.GJENNOMFOERT,avtalt:!1,beskrivelse:"Beskrivelse asdasdasdsasd",eksternAktivitet:{type:Xt.MIDL_LONNSTILSKUDD_TYPE,oppgave:void 0,handlinger:void 0,detaljer:void 0,etiketter:void 0}})}),Ne({...tM({tittel:"Arbeidstrening hos Biggen Blues og Bensin",status:ye.PLANLAGT,avtalt:!0,beskrivelse:"Pumpeoperatør",eksternAktivitet:{type:Xt.VARIG_LONNSTILSKUDD_TYPE,oppgave:void 0,handlinger:void 0,detaljer:[{label:"Arbeidsgiver",verdi:"Biggen Blues og Bensin"},{label:"Stillingsprosent",verdi:"100%"}],etiketter:void 0}})}),Ne({...tM({tittel:"Oppfølging hos Biggen",status:ye.PLANLAGT,avtalt:!0,beskrivelse:"",eksternAktivitet:{type:Xt.INDOPPFAG,oppgave:void 0,handlinger:void 0,detaljer:[{label:"Arrangør",verdi:"Biggen Oppfølging"},{label:"Oppfølging",verdi:"ukentlig"}],etiketter:void 0}})}),Ne({...tM({tittel:"Tilrettelags arbeid hos Biggen",status:ye.PLANLAGT,avtalt:!0,beskrivelse:"",eksternAktivitet:{type:Xt.VASV,oppgave:void 0,handlinger:[{tekst:"Biggens hjemmeside",subtekst:"",url:"https://www.nav.no/",lenkeType:"FELLES"}],detaljer:[{label:"Arrangør",verdi:"Biggen verna avdeling"},{label:"Stillingsprosent",verdi:"5%"}],etiketter:void 0}}),forhaandsorientering:{type:"SEND_FORHAANDSORIENTERING",tekst:"Det er viktig at du gjennomfører denne aktiviteten med Nav. Gjør du ikke det, kan det medføre at stønaden du mottar fra Nav bortfaller for en periode eller stanses. Hvis du ikke kan gjennomføre aktiviteten, ber vi deg ta kontakt med veilederen din så snart som mulig."}}),Ne({...tM({tittel:"Saltrød og Høneby - med oppgave",status:ye.GJENNOMFOERT,avtalt:!0,beskrivelse:"Lorem ipsum dolor sit amet, consectetur adipiscing elit. Fusce blandit sollicitudin odio, nec eleifend nibh pulvinar ac. Donec sed sem.",eksternAktivitet:{type:Xt.MIDL_LONNSTILSKUDD_TYPE,oppgave:{ekstern:{tekst:"Du må godkjenne avtalen",subtekst:"Lorem ipsum dolor sit amet, consectetur adipiscing elit. Vestibulum sit amet justo sit amet turpis eleifend bibendum nec ac ipsum. Mauris et hendrerit justo. Nulla varius tristique magna at pellentesque.",url:"https://www.nav.no/",knapptekst:"Lorem ipsum"},intern:void 0},handlinger:[{tekst:"Gå til avtalen",subtekst:"Avtale undertekst blah blah",url:"https://www.nav.no/",lenkeType:"FELLES"},{tekst:"Denne handlingen kan kun veiledere se",subtekst:void 0,url:"https://www.nav.no/",lenkeType:"INTERN"}],detaljer:[{label:"Abc",verdi:"def"},{label:"Ghi",verdi:"jkl"}],etiketter:void 0}})})]:[];let Tg=12e3,yg=6e6;const VA=({tittel:e})=>(yg+=1e3,Tg+=10,{id:`${Tg}`,versjon:`${yg}`,tittel:`${e}`,beskrivelse:"Ærlig arbeid",lenke:"www.nav.no",type:"STILLING",status:"PLANLAGT",fraDato:"2018-01-24T12:00:00+01:00",tilDato:"2030-01-24T12:00:00+01:00",opprettetDato:"2018-01-31T10:46:51.622+01:00",endretDato:"2018-09-30T10:46:51.622+01:00",endretAv:"z990207",historisk:!1,avtalt:!1,endretAvType:"NAV",transaksjonsType:"OPPRETTET",erReferatPublisert:!1});let dg=1e3,mg=5e6;const TM=e=>e+"-01-31T10:46:25.801+01:00",sv={navn:"Odd Fellow",tittel:"Daglig leder",mobil:"99999999"},Nv={navn:"Harry Potter",tittel:"Nav-ansatt",mobil:"+47 99009900"},cv={navn:"Sykfest Strutle",tittel:"Nav-ansatt",mobil:null},Lt=({tittel:e,arstall:t})=>{const M=t?new Date(TM(t)):void 0,A=new Date(TM(2020)),i=t?new Date(TM(t)):void 0;return i==null||i.setFullYear(i.getFullYear()+2),mg+=1e3,dg+=1e3,{avsluttetKommentar:"",avtalt:!1,beskrivelse:"",etikett:void 0,forhaandsorientering:void 0,tilDato:"",versjon:`${mg}`,id:`${dg}`,tittel:e,type:cM.STILLING_FRA_NAV_TYPE,status:ye.GJENNOMFOERT,fraDato:M==null?void 0:M.toISOString(),opprettetDato:A.toISOString(),endretDato:i==null?void 0:i.toISOString(),endretAv:"z990207",historisk:!1,endretAvType:"NAV",transaksjonsType:at.STATUS_ENDRET,stillingFraNavData:{...Kt,soknadsstatus:lM.VENTER},oppfolgingsperiodeId:"a2aa22a2-2aa2-4e02-8cc2-d44ef605fa33"}},AA={kanDeles:!0,endretTidspunkt:new Date,endretAv:"V123",endretAvType:"BRUKER"},Kt={cvKanDelesData:void 0,arbeidsgiver:"Havsalt AS Havsalt AS Havsalt AS Havsalt AS",arbeidssted:"Kristiansand",kontaktpersonData:sv,soknadsstatus:lM.VENTER,soknadsfrist:"Snarest",stillingsId:"1231",bestillingsId:"12312",detaljer:void 0,svarfrist:"2022-10-19T14:33:28.518Z",livslopsstatus:oC.HAR_VARSLET},lv={tekst:"Det er viktig at du gjennomfører denne aktiviteten med Nav. Gjør du ikke det, kan det medføre at stønaden du mottar fra Nav bortfaller for en periode eller stanses. Hvis du ikke kan gjennomføre aktiviteten, ber vi deg ta kontakt med veilederen din så snart som mulig.",type:"SEND_FORHAANDSORIENTERING",lestDato:null},jv={tekst:"Det er viktig at du gjennomfører denne aktiviteten med Nav. Gjør du ikke det, kan det medføre at stønaden du mottar fra Nav bortfaller for en periode eller stanses. Hvis du ikke kan gjennomføre aktiviteten, ber vi deg ta kontakt med veilederen din så snart som mulig.",type:"SEND_FORHAANDSORIENTERING",lestDato:"2021-05-30T10:46:40.459+00:00"};let bg=1002,fg=1002;function So({tittel:e}){return bg+=1e3,fg+=1e3,{id:`${bg}`,versjon:`${fg}`,tittel:e,referat:`Dette er et referat
+
+Med flere avsnitt.
+Og linjeskift. https://www.nav.no asdasdasdads 123 https://www.google.com`,avtalt:!1,endretAv:"1602677081175",endretDato:"2020-10-14T12:04:41.175Z",erReferatPublisert:!0,fraDato:"2020-10-14T12:04:33.649Z",historisk:!1,kanal:ho.TELEFON,endretAvType:"NAV",opprettetDato:"2020-10-14T12:04:41.175Z",status:ye.GJENNOMFOERT,transaksjonsType:at.OPPRETTET,type:cM.SAMTALEREFERAT_TYPE}}let Ug=1001,pg=9001;function Qg({tittel:e}){return Ug+=1e3,pg+=1e3,{id:`${Ug}`,versjon:`${pg}`,tittel:e,beskrivelse:"Nav forventer at du søker omtrent 20 stillinger i denne perioden. Det er viktig at du søker på de jobbene du mener du er kvalifisert for. Det er også viktig å søke på mange stillinger, det øker sjansene dine til å finne en jobb. Legg til hver stilling du søker i aktiviteten «En jobb jeg vil søke på».",lenke:null,type:"SOKEAVTALE",status:"GJENNOMFORES",fraDato:"2023-01-21T08:00:00+02:00",tilDato:"2023-08-21T12:15:00+02:00",opprettetDato:"2018-08-21T11:55:14.044+02:00",endretDato:"2018-08-21T11:57:57.636+02:00",endretAv:"z990207",historisk:!1,avsluttetKommentar:null,avtalt:!0,endretAvType:"NAV",transaksjonsType:"OPPRETTET",etikett:null,kontaktperson:null,arbeidsgiver:null,arbeidssted:null,stillingsTittel:null,hensikt:null,oppfolging:null,antallStillingerSokes:null,antallStillingerIUken:5,avtaleOppfolging:null,jobbStatus:null,ansettelsesforhold:null,arbeidstid:null,behandlingType:null,behandlingSted:null,effekt:null,behandlingOppfolging:null,kanal:null,erReferatPublisert:!1,forhaandsorientering:null}}const Vw=oi(),pM=Vw?"BRUKER":"NAV",vv=[Ne({...VA({tittel:"Kaptein sabeltann"}),beskrivelse:"Vi reiste fra karibien og ankret opp i natt",arbeidsgiver:"Den sorte dame AS",kontaktperson:"Sabeltann sin mor",arbeidssted:"Karibien"}),Ne({...VA({tittel:"Langemann"}),beskrivelse:"Ute på åpent hav, er jeg kjent som sabeltanns skygge",status:ye.GJENNOMFOERT,etikett:DC.SOKNAD_SENDT,kontaktperson:"Sabeltann",arbeidsgiver:"Kaptein Sabeltann",arbeidssted:"Den sorte dame"}),Ne({...VA({tittel:"Grusomme Gabriel"}),beskrivelse:"Skal skjules bak nedtrekksmeny for eldre aktiviteter",arbeidssted:"De syv hav",arbeidsgiver:"Uendret i lang tid",status:ye.FULLFOERT,fraDato:dt(new Date,120).toISOString(),tilDato:void 0,endretDato:dt(new Date,100).toISOString()}),Ne({...VA({tittel:"Ana Baroma"}),beskrivelse:"Skal ikke skjules bak nedtrekksmeny for eldre aktiviteter",arbeidssted:"Øya Gral",arbeidsgiver:"Endret nylig",status:ye.FULLFOERT,fraDato:dt(new Date,120).toISOString(),tilDato:void 0,endretDato:dt(new Date,1).toISOString()}),Ne({id:"5",versjon:"2410",tittel:"Kassert av Nav",beskrivelse:"Kassert av Nav",lenke:"www.nav.no",type:"EGEN",status:ye.AVBRUTT,fraDato:"2020-01-01T12:00:00+01:00",tilDato:"2020-12-01T12:00:00+01:00",opprettetDato:"2018-02-26T15:51:44.197+01:00",endretDato:"2018-02-26T15:51:44.85+01:00",endretAv:"Z123456",avtalt:!0,endretAvType:"NAV",transaksjonsType:"KASSERT",hensikt:"Kassert av Nav",oppfolging:"Kassert av Nav",erReferatPublisert:!1,oppfolgingsperiodeId:"a2aa22a2-2aa2-4e02-8cc2-d44ef605fa33"}),Ne({id:"6871",versjon:"9389",tittel:"Beste møtet ever",beskrivelse:"Vi ønsker å snakke med deg om aktiviteter du har gjennomført og videre oppfølging.",lenke:null,type:"MOTE",status:ye.PLANLAGT,fraDato:"2030-08-21T08:00:00+02:00",tilDato:"2030-08-21T12:15:00+02:00",opprettetDato:"2018-08-21T11:55:14.044+02:00",endretDato:"2018-08-21T11:57:57.636+02:00",endretAv:"z990207",historisk:!1,avsluttetKommentar:null,avtalt:!1,endretAvType:"NAV",transaksjonsType:"OPPRETTET",etikett:null,kontaktperson:null,arbeidsgiver:null,arbeidssted:null,stillingsTittel:null,hensikt:null,oppfolging:null,antallStillingerSokes:null,avtaleOppfolging:null,jobbStatus:null,ansettelsesforhold:null,arbeidstid:null,behandlingType:null,behandlingSted:null,effekt:null,behandlingOppfolging:null,kanal:ho.TELEFON,adresse:"Ditt nærmeste Nav kontor",erReferatPublisert:!1,oppfolgingsperiodeId:"a2aa22a2-2aa2-4e02-8cc2-d44ef605fa33"}),Ne({id:"10",versjon:"200",tittel:"Gamelt Beste møtet ever",beskrivelse:"Vi ønsker å snakke med deg om aktiviteter du har gjennomført og videre oppfølging.",lenke:null,type:"MOTE",status:ye.PLANLAGT,fraDato:"2017-02-16T00:00:00+01:00",tilDato:"2017-02-16T00:00:00+02:00",opprettetDato:"2017-02-16T00:00:00+01:00",endretDato:"2017-02-16T00:00:00+01:00",endretAv:"z990207",historisk:!0,avsluttetKommentar:null,avtalt:!0,endretAvType:"NAV",transaksjonsType:"BLE_HISTORISK",etikett:null,kontaktperson:null,arbeidsgiver:null,arbeidssted:null,stillingsTittel:null,hensikt:null,oppfolging:null,antallStillingerSokes:null,avtaleOppfolging:null,jobbStatus:null,ansettelsesforhold:null,arbeidstid:null,behandlingType:null,behandlingSted:null,effekt:null,behandlingOppfolging:null,kanal:ho.TELEFON,erReferatPublisert:!1,oppfolgingsperiodeId:"a1aa11a1-1aa1-4e02-8cc2-d44ef605fa33"}),Ne({...Qg({tittel:"Denne har en ulest forhåndsorientering"}),forhaandsorientering:lv}),Ne({...Qg({tittel:"Gi aldri opp! Kjemp hvis du kan."}),beskrivelse:`Du er unik. Vi vet at det finnes en arbeidsgiver der ute som ser etter akkurat deg. Plutselig klaffer det, det vet jeg. Har du sett denne lenken? Det er Rick Astley.
+https://www.youtube.com/watch?v=xvFZjo5PgG0`}),Ne({...So({tittel:"Denne har en lest forhåndsorientering"}),forhaandsorientering:jv}),Ne({...So({tittel:"Inneholder et langt referat med lenke"}),erReferatPublisert:!1,referat:`Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.
+
+Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur.
+Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum. Se også https://www.nav.no/`}),Ne({...So({tittel:"Et rykte sprer seg raskt som en brann"}),referat:`Nå kommer Sabeltann: https://www.britannica.com/animal/Smilodon
+Her er litt mer informasjon om hva dette innebærer for deg: https://no.wikipedia.org/wiki/Sj%C3%B8r%C3%B8veri`}),Ne({...Lt({tittel:"Servitør",arstall:2017}),arbeidsgiver:"Historisk"}),Ne({...Lt({tittel:"Servitør (ikke svart)"}),arbeidsgiver:"Har ikke svart ennå",status:ye.PLANLAGT,opprettetDato:dt(new Date,3).toISOString(),endretDato:dt(new Date,3).toISOString(),historisk:!1,transaksjonsType:"OPPRETTET",stillingFraNavData:{...Kt,svarfrist:MD(new Date,3).toISOString(),kontaktpersonData:Nv}}),Ne({...Lt({tittel:"Servitør"}),arbeidsgiver:"Har ikke svart innen fristen",status:ye.AVBRUTT,opprettetDato:TM(2020),endretDato:TM(2018),historisk:!1,transaksjonsType:"OPPRETTET",stillingFraNavData:{...Kt,svarfrist:TM(2021),kontaktpersonData:cv}}),Ne({...Lt({tittel:"Servitør",arstall:2020}),stillingFraNavData:{...Kt,cvKanDelesData:AA,arbeidsgiver:"Har Svart Innen Fristen AS"}}),Ne({...Lt({tittel:"Assisterende skipskokk",arstall:2020}),stillingFraNavData:{...Kt,cvKanDelesData:AA,soknadsstatus:lM.VENTER}}),Ne({...Lt({tittel:"Greve av Gral",arstall:2023}),status:ye.FULLFOERT,transaksjonsType:wA.IKKE_FATT_JOBBEN,stillingFraNavData:{...Kt,cvKanDelesData:AA,soknadsstatus:lM.IKKE_FATT_JOBBEN,detaljer:"KANDIDATLISTE_LUKKET_NOEN_ANDRE_FIKK_JOBBEN"}}),Ne({...Lt({tittel:"Hertug av Hirtzenhaus",arstall:2021}),status:ye.FULLFOERT,transaksjonsType:wA.FATT_JOBBEN,stillingFraNavData:{...Kt,cvKanDelesData:AA,soknadsstatus:lM.FATT_JOBBEN,detaljer:void 0}}),Ne({id:"91495701",versjon:"1",tittel:"Medisinsk behandling",beskrivelse:`CaCO3 løses i vann ved oppkok og avkjøles til 25˚C.
+Løsningen appliseres til tøystykker og legges rundt bruddstedet. Beinet holdes i ro til gipsen har stivnet. Dette burde ta en dag, men det er lurt å ta forbehold om at det kan gå flere dager. CaCO3 løses i vann ved oppkok og avkjøles til 25˚C.
+Løsningen appliseres til tøystykker og legges rundt bruddstedet. Beinet holdes i ro til gipsen har stivnet. Dette burde ta en dag, men det er lurt å ta forbehold om at det kan gå flere dager.`,lenke:null,type:"BEHANDLING",status:ye.PLANLAGT,fraDato:"2022-09-13T14:13:49.000+02:00",tilDato:"2022-09-14T14:13:58.000+02:00",opprettetDato:"2022-09-13T12:16:08.593Z",endretDato:"2022-09-13T12:16:08.593Z",endretAv:"BRUKER",historisk:!1,avsluttetKommentar:null,avtalt:!0,endretAvType:"BRUKER",transaksjonsType:"OPPRETTET",etikett:null,kontaktperson:null,arbeidsgiver:null,arbeidssted:null,stillingsTittel:null,hensikt:null,oppfolging:null,antallStillingerSokes:null,antallStillingerIUken:null,avtaleOppfolging:null,jobbStatus:null,ansettelsesforhold:null,arbeidstid:null,behandlingType:"Bandasje",behandlingSted:"Skyehuset",effekt:"Legge gips på bruddstedet",behandlingOppfolging:null,adresse:null,forberedelser:null,kanal:null,referat:null,erReferatPublisert:!1,forhaandsorientering:null,stillingFraNavData:null,oppfolgingsperiodeId:"a2aa22a2-2aa2-4e02-8cc2-d44ef605fa33"})],Tv=kg()?vv:[],yv=Rw()?[{id:"141438",versjon:"199743",tittel:"Se mulighetene i arbeidsmarkedet",beskrivelse:"Hvilke jobber kan du ta og hvilke bransjer kan du jobbe i? Er jobbene der du bor eller andre steder i landet? Velg geografisk område og bransje og se om jobbene finnes. Hvis du mener denne aktiviteten ikke passer for deg, kan du sette den til avbrutt.",lenke:"https://mia-q.nav.no",type:cM.EGEN_AKTIVITET_TYPE,status:ye.BRUKER_ER_INTRESSERT,fraDato:"2019-06-13T10:00:36.255+02:00",tilDato:"2019-09-13T10:00:36.255+02:00",opprettetDato:"2019-06-13T10:00:36.333+02:00",endretDato:"2019-06-13T10:00:36.632+02:00",endretAv:"srvveilarbdirigent",historisk:!1,avsluttetKommentar:void 0,avtalt:!1,endretAvType:"NAV",transaksjonsType:at.OPPRETTET,etikett:void 0,hensikt:"Bli bedre kjent med arbeidsmarkedet",oppfolging:void 0,oppfolgingsperiodeId:"a2aa22a2-2aa2-4e02-8cc2-d44ef605fa33"},{id:"141439",versjon:"199744",tittel:"Oppdater CV-en og jobbprofilen",beskrivelse:"Når du registrerer CV-en og jobbprofilen din, kan vi følge deg opp på en god måte. Du gjør deg synlig for arbeidsgivere som leter etter nye medarbeidere. Nav samarbeider med mange arbeidsgivere og bemanningsbransjen.",lenke:"https://arbeidsplassen-q.nav.no/minside",type:cM.EGEN_AKTIVITET_TYPE,status:ye.GJENNOMFOERT,fraDato:"2021-06-13T10:00:36.699+02:00",tilDato:"2021-06-21T10:00:36.699+02:00",opprettetDato:"2019-06-13T10:00:36.722+02:00",endretDato:"2019-06-13T10:00:36.742+02:00",endretAv:"srvveilarbdirigent",historisk:!1,avsluttetKommentar:void 0,avtalt:!1,endretAvType:"NAV",transaksjonsType:at.OPPRETTET,etikett:void 0,hensikt:"Bli synlig for arbeidsgivere",oppfolging:void 0,oppfolgingsperiodeId:"a2aa22a2-2aa2-4e02-8cc2-d44ef605fa33"},{id:"141440",versjon:"199745",tittel:"Jobbsøkertips",beskrivelse:"Svar på noen spørsmål om hvordan du søker på jobber. Få råd og tips til søknaden, CV-en, intervjuet og hvordan du finner jobbene.",lenke:"https://jobbsokerkompetanse-q.nav.no/",type:cM.EGEN_AKTIVITET_TYPE,status:ye.BRUKER_ER_INTRESSERT,fraDato:"2019-06-13T10:00:36.785+02:00",tilDato:"2019-06-27T10:00:36.785+02:00",opprettetDato:"2019-06-13T10:00:36.81+02:00",endretDato:"2019-06-13T10:00:36.988+02:00",endretAv:"srvveilarbdirigent",historisk:!1,avsluttetKommentar:void 0,avtalt:!1,endretAvType:"NAV",transaksjonsType:at.OPPRETTET,etikett:void 0,hensikt:"Få råd og tips når du søker jobber",oppfolging:void 0,oppfolgingsperiodeId:"a2aa22a2-2aa2-4e02-8cc2-d44ef605fa33"}]:[],dv=kg()?[Ne({...Lt({tittel:"Servitør har svart",arstall:2020}),status:ye.PLANLAGT,transaksjonsType:"DEL_CV_SVART",stillingFraNavData:{...Kt,cvKanDelesData:AA}})]:[],Zt=Tv.concat(yv).concat(uv);function Ce(e){return e||null}function mv(e){return e||new Date().toISOString()}function ko(e){return e||!1}function Eg(e){return e?parseInt(e):null}function Ne(e){const t=e;return{id:Ce(t.id),versjon:Ce(t.versjon),tittel:Ce(t.tittel),beskrivelse:Ce(t.beskrivelse),lenke:Ce(t.lenke),type:Ce(t.type),status:Ce(t.status),fraDato:Ce(t.fraDato),tilDato:Ce(t.tilDato),opprettetDato:Ce(t.opprettetDato),endretDato:Ce(t.endretDato),endretAv:mv(t.endretAv),historisk:ko(t.historisk),avsluttetKommentar:Ce(t.avsluttetKommentar),avtalt:ko(t.avtalt),endretAvType:Ce(t.endretAvType),transaksjonsType:Ce(t.transaksjonsType),etikett:Ce(t.etikett),kontaktperson:Ce(t.kontaktperson),arbeidsgiver:Ce(t.arbeidsgiver),arbeidssted:Ce(t.arbeidssted),stillingsTittel:Ce(t.stillingsTittel),hensikt:Ce(t.hensikt),oppfolging:Ce(t.oppfolging),antallStillingerSokes:Eg(t.antallStillingerSokes),antallStillingerIUken:Eg(t.antallStillingerIUken),avtaleOppfolging:Ce(t.avtaleOppfolging),jobbStatus:Ce(t.jobbStatus),ansettelsesforhold:Ce(t.ansettelsesforhold),arbeidstid:Ce(t.arbeidstid),behandlingType:Ce(t.behandlingType),behandlingSted:Ce(t.behandlingSted),effekt:Ce(t.effekt),behandlingOppfolging:Ce(t.behandlingOppfolging),adresse:Ce(t.adresse),forberedelser:Ce(t.forberedelser),kanal:Ce(t.kanal),referat:Ce(t.referat),erReferatPublisert:ko(t.erReferatPublisert),forhaandsorientering:Ce(t.forhaandsorientering),stillingFraNavData:Ce(t.stillingFraNavData),eksternAktivitet:Ce(t.eksternAktivitet),oppfolgingsperiodeId:t.oppfolgingsperiodeId||"a1aa11a1-1aa1-4e02-8cc2-d44ef605fa33"}}const bv=e=>{const t=e.params.aktivitetId;return Zt.find(M=>M.id===t)},fv=e=>{const t=e.params.aktivitetId;return sn.filter(M=>M.id===t)},Uv=async e=>{const t=await e.json(),M=Ne({id:Bo(),opprettetDato:new Date,endretAvType:pM,endretDato:new Date().toISOString(),endretAv:pM,versjon:"1",erLestAvBruker:Vw,transaksjonsType:"OPPRETTET",oppfolgingsperiodeId:"a2aa22a2-2aa2-4e02-8cc2-d44ef605fa33",...t});Zt.push(M);const A=Ne(M);return sn.push(A),M};function Qt(e,t){const M=Zt.find(i=>i.id===e),A={...M,...pv({...t,versjon:M.versjon})};return sn.push(A),Object.assign(M,A),A}function pv(e){return{...e,versjon:String(parseInt(e.versjon)+1),endretDato:new Date().toISOString(),endretAv:pM,endretAvType:pM}}const Qv=async e=>{const t=e.params.aktivitetId,A={...await e.json(),transaksjonsType:at.DETALJER_ENDRET};return Qt(t,A)},Ev=async e=>{const t=e.params.aktivitetId,A={...await e.json(),transaksjonsType:at.STATUS_ENDRET};return Qt(t,A)},zv=async e=>{const t=e.params.aktivitetId,A={...await e.json(),transaksjonsType:Gw.ETIKETT_ENDRET};return Qt(t,A)},Lv=async e=>{const t=e.url.searchParams.get("aktivitetId"),A={...await e.json(),avtalt:!0,transaksjonsType:at.AVTALT};return Qt(t,A)},Kv=async e=>{const t=e.url.searchParams.get("aktivitetId"),M=await e.json(),A=Zt.find(o=>o.id===t),i={...A,status:M.kanDeles?ye.GJENNOMFOERT:ye.AVBRUTT,transaksjonsType:wA.DEL_CV_SVART,stillingFraNavData:{...A.stillingFraNavData,cvKanDelesData:{kanDeles:M.kanDeles,endretTidspunkt:new Date,avtaltDato:M.avtaltDato,endretAv:pM?"843029483":"z123",endretAvType:pM},soknadsstatus:M.kanDeles?lM.VENTER:void 0}};return Qt(t,i)},Ov=async e=>{const t=e.url.searchParams.get("aktivitetId"),M=await e.json(),i={stillingFraNavData:{...Zt.find(o=>o.id===t).stillingFraNavData,soknadsstatus:M.soknadsstatus},transaksjonsType:wA.SOKNADSSTATUS_ENDRET};return Qt(t,i)},Sv=async e=>{const t=await e.json(),{aktivitetId:M}=t,A=Zt.find(o=>o.id===M),i={...A,forhaandsorientering:{...A.forhaandsorientering,lestDato:new Date().toISOString()},transaksjonsType:at.FORHAANDSORIENTERING_LEST};return Qt(M,i)},kv=e=>{const t=e.params.aktivitetId,M={erReferatPublisert:!0,transaksjonsType:un.REFERAT_PUBLISERT};return Qt(t,M)},Bv=async e=>{const t=e.params.aktivitetId,A={...await e.json(),transaksjonsType:un.REFERAT_ENDRET};return Qt(t,A)},$o={aktiviteter:Zt},sn=Zt.concat(dv).map(e=>Ne(e)),hv=[{id:"ARENATA11",status:"GJENNOMFORES",type:"TILTAKSAKTIVITET",tittel:"Klatrekurs i seil",beskrivelse:"Sjørøvere trenger å kunne klatre i seil",fraDato:dt(new Date,2).toISOString(),tilDato:MD(new Date,8).toISOString(),opprettetDato:"2018-09-02T00:00:00+02:00",avtalt:!0,deltakelseProsent:95.6,tiltaksnavn:"Trening123",tiltakLokaltNavn:"NAV OSLO",arrangoer:"Pelle",bedriftsnummer:"123456789",antallDagerPerUke:5,statusSistEndret:"2017-07-02T00:00:00+02:00",etikett:null,oppfolgingsperiodeId:null,moeteplanListe:null},{id:"ARENATA12",status:"GJENNOMFORES",type:"TILTAKSAKTIVITET",tittel:"Ny arenaaktivitet",beskrivelse:"Sjørøvere trenger å kunne klatre i seil",fraDato:"2022-03-02T00:00:00+02:00",tilDato:"2025-12-31T00:00:00+01:00",opprettetDato:"2021-09-02T00:00:00+02:00",avtalt:!0,deltakelseProsent:95.6,tiltaksnavn:"Trening123",tiltakLokaltNavn:"NAV OSLO",arrangoer:"Pelle",bedriftsnummer:"123456789",antallDagerPerUke:5,statusSistEndret:"2017-07-02T00:00:00+02:00",etikett:null,oppfolgingsperiodeId:"a2aa22a2-2aa2-4e02-8cc2-d44ef605fa33",moeteplanListe:null},{id:"ARENATA22",status:"AVBRUTT",type:"TILTAKSAKTIVITET",tittel:"Seiling",beskrivelse:"Sjårøvere trenger å kunne seile",fraDato:"2017-02-16T00:00:00+01:00",tilDato:"2017-06-30T00:00:00+02:00",opprettetDato:"2017-06-30T00:00:00+02:00",avtalt:!0,deltakelseProsent:30,tiltaksnavn:"Trening123",tiltakLokaltNavn:"NAV OSLO",arrangoer:"Pelle",bedriftsnummer:"123456789",antallDagerPerUke:1.5,statusSistEndret:"2017-06-30T00:00:00+02:00",etikett:null,oppfolgingsperiodeId:null,moeteplanListe:null},{id:"ARENATA33",status:"GJENNOMFORES",type:"TILTAKSAKTIVITET",tittel:"Seiling på hav",beskrivelse:"Sjårøvere trenger å kunne seile på hav",fraDato:"2017-02-16T00:00:00+01:00",tilDato:"2025-12-31T00:00:00+01:00",opprettetDato:"2018-09-02T00:00:00+02:00",avtalt:!0,deltakelseProsent:30,tiltaksnavn:"Trening123",tiltakLokaltNavn:"NAV OSLO",arrangoer:"Pelle",bedriftsnummer:"123456789",antallDagerPerUke:1.5,statusSistEndret:"2017-06-30T00:00:00+02:00",etikett:null,oppfolgingsperiodeId:"a2aa22a2-2aa2-4e02-8cc2-d44ef605fa33",moeteplanListe:null,forhaandsorientering:{tekst:"Det er viktig at du gjennomfører denne aktiviteten med Nav. Gjør du ikke det, kan det medføre at stønaden du mottar fra Nav bortfaller for en periode eller stanses. Hvis du ikke kan gjennomføre aktiviteten, ber vi deg ta kontakt med veilederen din så snart som mulig.",type:"SEND_FORHAANDSORIENTERING"}},{id:"ARENAGA120719688",status:"FULLFORT",type:"GRUPPEAKTIVITET",tittel:"Informasjonsmøte om arbeidsavklaringspenger",beskrivelse:"test",fraDato:"2018-02-22T13:00:00+01:00",tilDato:"2018-02-22T00:00:00+01:00",opprettetDato:"2018-02-22T13:00:00+01:00",avtalt:!0,etikett:null,oppfolgingsperiodeId:null,deltakelseProsent:null,tiltaksnavn:null,tiltakLokaltNavn:null,arrangoer:null,bedriftsnummer:null,antallDagerPerUke:null,statusSistEndret:null,moeteplanListe:[{startDato:"2018-02-22T13:00:00+01:00",sluttDato:"2018-02-22T14:00:00+01:00",sted:"Nav Frogner, Sommerrogata 1 (v/Solli Plass), 0255 Oslo"},{startDato:"2018-02-22T13:00:00+01:00",sluttDato:"2018-02-22T00:00:00+01:00",sted:"Nav Frogner, Sommerrogata 1 (v/Solli Plass), 0255 Oslo"}]},{id:"ARENATA5316644",status:"GJENNOMFORES",type:"TILTAKSAKTIVITET",tittel:"AMO-kurs: Endringsarbeid med fokus på kompetanseheving for deltagelse i arbeidslivet",beskrivelse:null,fraDato:"2016-08-28T22:00:00.000+00:00",tilDato:"2016-09-11T22:00:00.000+00:00",opprettetDato:"2016-09-11T22:00:00.000+00:00",avtalt:!0,forhaandsorientering:null,etikett:null,oppfolgingsperiodeId:null,deltakelseProsent:100,tiltaksnavn:"Arbeidsmarkedsopplæring (AMO)",tiltakLokaltNavn:"Endringsarbeid med fokus på kompetanseheving for deltagelse i arbeidslivet",arrangoer:"PODIUM AS",bedriftsnummer:"916068670",antallDagerPerUke:null,statusSistEndret:"2016-09-11T22:00:00.000+00:00",moeteplanListe:null},{id:"ARENATA3930143",status:"GJENNOMFORES",type:"TILTAKSAKTIVITET",tittel:"Jobbklubb",beskrivelse:"Karriereveiledning høyere utdanning i Oslo for Akershus",fraDato:"2011-08-21T22:00:00.000+00:00",tilDato:"2011-09-15T22:00:00.000+00:00",opprettetDato:"2011-08-31T22:00:00.000+00:00",avtalt:!0,forhaandsorientering:null,etikett:"IKKEM",oppfolgingsperiodeId:"a2aa22a2-2aa2-4e02-8cc2-d44ef605fa33",deltakelseProsent:100,tiltaksnavn:"Jobbklubb",tiltakLokaltNavn:"Karriereveiledning høyere utdanning i Oslo for Akershus",arrangoer:"Joblearn AS",bedriftsnummer:"981669649",antallDagerPerUke:null,statusSistEndret:"2011-08-31T22:00:00.000+00:00",moeteplanListe:null},{id:"ARENATA3852010",status:"GJENNOMFORES",type:"TILTAKSAKTIVITET",tittel:"Jobbklubb",beskrivelse:"Karriereveiledning (Jobbklubb) i Oslo for Akershus",fraDato:"2011-03-13T23:00:00.000+00:00",tilDato:null,opprettetDato:"2011-04-07T22:00:00.000+00:00",avtalt:!0,forhaandsorientering:null,etikett:null,oppfolgingsperiodeId:"a2aa22a2-2aa2-4e02-8cc2-d44ef605fa33",deltakelseProsent:100,tiltaksnavn:"Jobbklubb",tiltakLokaltNavn:"Karriereveiledning (Jobbklubb) i Oslo for Akershus",arrangoer:"Joblearn AS",bedriftsnummer:"981669649",antallDagerPerUke:null,statusSistEndret:"2011-04-07T22:00:00.000+00:00",moeteplanListe:null},{id:"ARENATA3820997",status:"FULLFORT",type:"TILTAKSAKTIVITET",tittel:"Jobbklubb",beskrivelse:"Karriereveiledning (Jobbklubb) høyere utdanning Asker/Bærum",fraDato:"2011-02-13T23:00:00.000+00:00",tilDato:"2011-03-10T23:00:00.000+00:00",opprettetDato:"2011-03-13T23:00:00.000+00:00",avtalt:!0,forhaandsorientering:null,etikett:null,oppfolgingsperiodeId:"a2aa22a2-2aa2-4e02-8cc2-d44ef605fa33",deltakelseProsent:100,tiltaksnavn:"Jobbklubb",tiltakLokaltNavn:"Karriereveiledning (Jobbklubb) høyere utdanning Asker/Bærum",arrangoer:"Joblearn AS",bedriftsnummer:"981669649",antallDagerPerUke:null,statusSistEndret:"2011-03-13T23:00:00.000+00:00",moeteplanListe:null},{id:"ARENATA3471197",status:"AVBRUTT",type:"TILTAKSAKTIVITET",tittel:"Jobbklubb",beskrivelse:"Jobbklubb Asker/Bærum (Akershus)",fraDato:"2020-05-31T10:46:51.622+01:00",tilDato:"2020-06-31T10:46:51.622+01:00",opprettetDato:"2020-05-31T10:46:51.622+01:00",avtalt:!0,forhaandsorientering:null,etikett:"NEITAKK",oppfolgingsperiodeId:"a2aa22a2-2aa2-4e02-8cc2-d44ef605fa33",deltakelseProsent:100,tiltaksnavn:"Jobbklubb",tiltakLokaltNavn:"Jobbklubb Asker/Bærum (Akershus)",arrangoer:"Joblearn AS",bedriftsnummer:"981669649",antallDagerPerUke:null,statusSistEndret:"2020-05-31T10:46:51.622+01:00",moeteplanListe:null},{id:"ARENATA1357086",status:"FULLFORT",type:"TILTAKSAKTIVITET",tittel:"Jobbklubb",beskrivelse:"Jobbklubb Bærum/ Asker",fraDato:"2008-03-04T23:00:00.000+00:00",tilDato:"2008-04-03T22:00:00.000+00:00",opprettetDato:"2008-04-04T22:00:00.000+00:00",avtalt:!0,forhaandsorientering:null,etikett:null,oppfolgingsperiodeId:"a2aa22a2-2aa2-4e02-8cc2-d44ef605fa33",deltakelseProsent:100,tiltaksnavn:"Jobbklubb",tiltakLokaltNavn:"Jobbklubb Bærum/ Asker",arrangoer:"Joblearn AS",bedriftsnummer:"981669649",antallDagerPerUke:null,statusSistEndret:"2008-04-04T22:00:00.000+00:00",moeteplanListe:null},{id:"ARENATA1337317",status:"AVBRUTT",type:"TILTAKSAKTIVITET",tittel:"AMO-kurs: Bussertifikat - Kl. D (Akershus)",beskrivelse:null,fraDato:"2021-05-31T10:46:51.622+01:00",tilDato:"2021-07-31T10:46:51.622+01:00",opprettetDato:"2020-05-31T10:46:51.622+01:00",avtalt:!0,forhaandsorientering:null,etikett:nC.AVSLAG,oppfolgingsperiodeId:"a2aa22a2-2aa2-4e02-8cc2-d44ef605fa33",deltakelseProsent:100,tiltaksnavn:"Arbeidsmarkedsopplæring (AMO)",tiltakLokaltNavn:"Bussertifikat - Kl. D (Akershus)",arrangoer:"WRIGHT TRAFIKKSKOLE AS",bedriftsnummer:"973410997",antallDagerPerUke:null,statusSistEndret:"2021-07-31T10:46:51.622+01:00",moeteplanListe:null},{id:"ARENATA4046316",status:"AVBRUTT",type:"TILTAKSAKTIVITET",tittel:"AMO-kurs: Arbeidsforberedende kurs avklaring og motivasjon Asker/Bærum",beskrivelse:null,fraDato:null,tilDato:"2011-11-27T23:00:00.000+00:00",opprettetDato:"2012-06-25T22:00:00.000+00:00",avtalt:!0,forhaandsorientering:null,etikett:"IKKAKTUELL",oppfolgingsperiodeId:"a2aa22a2-2aa2-4e02-8cc2-d44ef605fa33",deltakelseProsent:100,tiltaksnavn:"Arbeidsmarkedsopplæring (AMO)",tiltakLokaltNavn:"Arbeidsforberedende kurs avklaring og motivasjon Asker/Bærum",arrangoer:"Joblearn AS",bedriftsnummer:"981669649",antallDagerPerUke:null,statusSistEndret:"2012-06-25T22:00:00.000+00:00",moeteplanListe:null}],Nn=Fw()?hv:[],Yv=async e=>{const t=e.url.searchParams.get("arenaaktivitetId"),M=await e.json(),A=Nn.find(i=>i.id===t);return A.forhaandsorientering={type:M.type,tekst:M.tekst},A},xv=e=>{const t=e.url.searchParams.get("aktivitetId"),M=Nn.find(A=>A.id===t);return M.forhaandsorientering={...M.forhaandsorientering,lestDato:new Date().toISOString()},M},Pv={expirationTime:Yg(new Date,10).toISOString(),loggedIn:!0,remainingSeconds:99999,securityLevel:"Level4"},eD=[{id:"1",aktivitetId:"1",overskrift:"NOT USED",sisteTekst:"Hei. Hva er status her? Har du finnet Kaptain Sabeltann?",sisteDato:"2018-01-28T12:48:56.097+01:00",opprettetDato:"2018-02-27T12:48:56.081+01:00",historisk:!1,lest:!Pe(),venterPaSvar:!1,ferdigBehandlet:!1,lestAvBrukerTidspunkt:null,erLestAvBruker:!1,henvendelser:[{id:"1",dialogId:"1",avsender:"VEILEDER",avsenderId:"Z123456",sendt:"2018-02-27T12:48:56.097+01:00",lest:!Pe(),tekst:"Hei. Hva er status her? Har du finnet Kaptain Sabeltann?"},{id:"2",dialogId:"1",avsender:"BRUKER",avsenderId:"0102030405",sendt:"2018-02-28T12:48:56.097+01:00",lest:!Pe(),tekst:"Hei. Leter enda på sjøen :)"}],egenskaper:[]},{id:"3",aktivitetId:"141439",overskrift:"NOT USED",sisteTekst:"Det er viktig at du gjennomfører denne aktiviteten med Nav. Gjør du ikke det, kan det medføre at stønaden du mottar fra Nav bortfaller for en periode eller stanses. Hvis du ikke kan gjennomføre aktiviteten, ber vi deg ta kontakt med veilederen din så snart som mulig.",sisteDato:"2018-11-21T13:13:20.685+01:00",opprettetDato:"2018-11-21T13:13:20.663+01:00",historisk:!1,lest:!Pe(),venterPaSvar:!1,ferdigBehandlet:!0,lestAvBrukerTidspunkt:null,erLestAvBruker:!1,henvendelser:[{id:"4",dialogId:"141439",avsender:"VEILEDER",avsenderId:"Z990286",sendt:"2018-11-21T13:13:20.685+01:00",lest:!Pe(),tekst:"Det er viktig at du gjennomfører denne aktiviteten med Nav. Gjør du ikke det, kan det medføre at stønaden du mottar fra Nav bortfaller for en periode eller stanses. Hvis du ikke kan gjennomføre aktiviteten, ber vi deg ta kontakt med veilederen din så snart som mulig."}],egenskaper:["PARAGRAF8"]},{id:"2",aktivitetId:null,overskrift:"Du har fått et varsel fra Nav",sisteTekst:`Jeg har ikke hørt noe fra deg i det siste. Har du forlist?
+`,sisteDato:"2018-02-01T11:52:20.615+01:00",opprettetDato:"2018-02-01T11:52:20.535+01:00",historisk:!1,lest:!Pe(),venterPaSvar:!0,ferdigBehandlet:!0,lestAvBrukerTidspunkt:null,erLestAvBruker:!1,henvendelser:[{id:"3",dialogId:"2",avsender:"VEILEDER",avsenderId:"Z123456",sendt:"2018-02-01T11:52:20.615+01:00",lest:!Pe(),tekst:`Jeg har ikke hørt noe fra deg i det siste. Har du forlist?
+`}],egenskaper:["ESKALERINGSVARSEL"]},{id:"4",aktivitetId:null,overskrift:"Automatiske dialoger",sisteTekst:`Hei!
+Du er registrert som arbeidssøker og Nav trenger å bli kjent med ditt behov for hjelp fra oss, slik at vi kan gi deg riktig veiledning.
+Hva mener du? Klik her og vurder hva du selv tenker https://behovsvurdering.nav.no
+`,sisteDato:"2018-01-28T12:48:56.097+01:00",opprettetDato:"2018-02-27T12:48:56.081+01:00",historisk:!1,lest:!Pe(),venterPaSvar:!1,ferdigBehandlet:!0,lestAvBrukerTidspunkt:"2018-02-27T12:48:57.097+01:00",erLestAvBruker:!0,henvendelser:[{id:"4",dialogId:"4",avsender:"VEILEDER",avsenderId:null,sendt:"2018-02-27T12:48:56.097+01:00",lest:!Pe(),tekst:`Hei!
+Du er registrert som arbeidssøker og Nav trenger å bli kjent med ditt behov for hjelp fra oss, slik at vi kan gi deg riktig veiledning.
+Hva mener du? Klik her og vurder hva du selv tenker https://behovsvurdering.nav.no
+`},{id:"5",dialogId:"4",avsender:"VEILEDER",avsenderId:null,sendt:"2018-02-28T12:48:56.097+01:00",lest:!Pe(),tekst:`Hei!
+Du har svart at du har utfordringer som hindrer deg i å søke eller være i jobb. Vi vil veilede deg videre og trenger derfor å vite litt mer.
+Du kan velge om du vil fortelle om situasjonen din
+- i et møte med veilederen din på Nav-kontoret
+- i en telefonsamtale
+- her i dialogen
+Skriv svaret ditt i feltet over. Hvis du velger "her i dialogen", kan du fortelle mer allerede nå.
+`},{id:"6",dialogId:"4",avsender:"VEILEDER",avsenderId:null,sendt:"2018-02-28T12:48:56.097+01:00",lest:!Pe(),tekst:`Hei!
+Du har svart at du trenger mer veiledning nå som retten til sykepenger nærmer seg slutten. Vi vil veilede deg videre og trenger derfor å vite litt mer.
+Du kan velge om du vil fortelle om situasjonen din
+- i et møte med veilederen din på Nav-kontoret
+- i en telefonsamtale
+- her i dialogen
+Skriv svaret ditt i feltet over. Hvis du velger "her i dialogen", kan du fortelle mer allerede nå.
+`}],egenskaper:[]},{id:"2",aktivitetId:"10",overskrift:"Du har fått et varsel fra Nav",sisteTekst:`Jeg har ikke hørt noe fra deg i det siste. Har du forlist?
+`,sisteDato:"2017-02-17T12:52:20.615+01:00",opprettetDato:"2017-02-17T11:52:20.535+01:00",historisk:!1,lest:!Pe(),venterPaSvar:!0,ferdigBehandlet:!0,lestAvBrukerTidspunkt:null,erLestAvBruker:!1,henvendelser:[{id:"3",dialogId:"2",avsender:"VEILEDER",avsenderId:"Z123456",sendt:"2017-02-17T11:52:20.535+01:00",lest:!Pe(),tekst:`Jeg har ikke hørt noe fra deg i det siste. Har du forlist?
+`},{id:"3",dialogId:"2",avsender:"VEILEDER",avsenderId:"Z123456",sendt:"2017-02-17T11:52:20.535+01:00",lest:!Pe(),tekst:`Fortsat ikke hørt noe. Har du forlist?
+`}],egenskaper:[]}],Jv=async e=>{const t=await e.json(),M=t.dialogId===void 0?Bo():`${t.dialogId}`,A={id:Bo(),dialogId:M,avsender:oi()?"BRUKER":"VEILEDER",avsenderId:"Z123456",overskrift:t.overskrift,tekst:t.tekst,lest:!Pe(),sendt:new Date},i=eD.filter(o=>t.dialogId!==void 0&&o.id===M);if(i.length===1){const o=i[0];return o.sisteTekst=t.tekst,o.sisteDato=A.sendt,o.henvendelser.push(A),o}else{const o={id:A.dialogId,ferdigBehandlet:!t.ikkeFerdigbehandlet,venterPaSvar:!!t.venterPaSvar,aktivitetId:t.aktivitetId===void 0?null:t.aktivitetId,overskrift:t.overskrift,sisteTekst:t.tekst,sisteDato:new Date,opprettetDato:new Date,historisk:!1,lest:!Pe(),lestAvBrukerTidspunkt:null,erLestAvBruker:!1,henvendelser:[A],egenskaper:t.egenskaper===void 0?[]:t.egenskaper};return eD.push(o),o}},zg=Ww()?{id:"1234",tilhorendeDialogId:"1",opprettetAv:"z12344",opprettetDato:"2022-01-28T12:48:56.097+01:00",opprettetBegrunnelse:"Derfor! Eskaler!"}:null,Gv={},Lg=[{tidspunkt:"2018-08-30T09:46:10.971+01:00",ressurs:"aktivitetsplan",verdi:null},{tidspunkt:"2018-08-31T11:46:10.971+01:00",ressurs:"informasjon",verdi:"v1"}];let AM=[{mal:"Jeg vil bli stor og sterk",endretAv:"BRUKER",dato:"2017-12-31T09:46:10.971+01:00"},{mal:"Jeg vil bli sjørøver",endretAv:"BRUKER",dato:new Date().toISOString()}];const Vv={dato:void 0,endretAv:"VEILEDER",mal:void 0};AM=Hw()?[]:AM;function Zv(){return AM}function Rv(){return AM.length===0?Vv:AM[AM.length-1]}async function Fv(e){const M={mal:(await e.json()).maalInnhold.maal,endretAv:oi()?"BRUKER":"VEILEDER",dato:new Date().toISOString()};return AM.push(M),M}const Wv=[{hensikt:"Bli synlig for arbeidsgivere",fraDato:"2018-04-24T14:20:36.716Z",type:"EGEN",tittel:"Du må registrere CV-en din på nav.no",tilDato:"2018-05-02T14:20:36.716Z",lenke:"https://tjenester.nav.no/sbl/nav_security_check?goto=/sbl/arbeid/endreCv",beskrivelse:"Som arbeidssøker er det viktig at du er synlig for flest mulige arbeidsgivere. Det blir du ved å registrere CV-en din på nav.no, Nav samarbeider med bemannings- og rekrutteringsbransjen. Det er også nødvendig for Nav å ha CV-din for å kunne følge deg opp på en god måte.",status:"BRUKER_ER_INTERESSERT"},{hensikt:"Bli synlig for arbeidsgivere",fraDato:"2018-04-24T14:20:36.718Z",oppfolging:"",type:"EGEN",tittel:"Du må registrere jobbønskene dine på nav.no",tilDato:"2018-05-02T14:20:36.718Z",lenke:"https://tjenester.nav.no/sbl/nav_security_check?goto=/sbl/arbeid/endrePreferanser",beskrivelse:"Jobbønskene dine gir match når arbeidsgivere og veiledere i Nav leter etter kandidater i CV-basen vår. Du får også et automatisk abonnement på ledige stillinger",status:"BRUKER_ER_INTERESSERT"},{hensikt:"Få råd og tips når du søker jobber",fraDato:"2018-04-24T14:20:36.718Z",oppfolging:"",type:"EGEN",tittel:"Hvordan søker du jobber?",tilDato:"2018-05-08T14:20:36.718Z",lenke:"https://tjenester.nav.no/jobbsokerkompetanse/",beskrivelse:"Svar på noen spørsmål om hvordan du søker på jobber. Få råd og tips til søknaden, CV-en, intervjuet og hvordan du finner jobbene.",status:"BRUKER_ER_INTERESSERT"}],Hv=async e=>{const t=await e.json(),{type:M}=t;return M==="EGEN"?Wv:[]},qv={id:"1234567890",erVeileder:!1,erBruker:!0},Xv={id:"Z123456",erVeileder:!0,erBruker:!1},_v=oi(),$v=()=>_v?qv:Xv,eT=[{uuid:"a1aa11a1-1aa1-4e02-8cc2-d44ef605fa33",aktorId:"1234567988888",veileder:null,startDato:"2017-01-30T10:46:10.971+01:00",sluttDato:"2017-12-31T10:46:10.971+01:00",begrunnelse:null,kvpPerioder:[{opprettetDato:"2017-01-30T10:46:10.971+01:00",avsluttetDato:"2017-06-01T10:46:10.971+01:00"},{opprettetDato:"2017-06-30T10:46:10.971+01:00",avsluttetDato:"2017-12-01T10:46:10.971+01:00"}]},{uuid:"a2aa22a2-2aa2-4e02-8cc2-d44ef605fa33",aktorId:"1234567988888",veileder:null,startDato:"2018-01-31T10:46:10.971+01:00",sluttDato:null,begrunnelse:null}],tD={fnr:qw,aktorId:"1234567988888",veilederId:null,reservasjonKRR:Xw(),manuell:_w(),underOppfolging:!$w(),underKvp:!1,kanStarteOppfolging:!1,oppfolgingsPerioder:eC()?[]:eT,harSkriveTilgang:!0,kanReaktiveres:!1,servicegruppe:"IVURD",inaktiveringsdato:"2018-08-31T10:46:10.971+01:00"},tT=e=>({...tD,fnr:e.url.searchParams.get("fnr")??void 0});function MT(){return tD.manuell=!1,tD}const AT=()=>({fornavn:"Bruce",mellomnavn:"Batty",etternavn:"Wayne",forkortetNavn:"Bruce Batty Wayne",fodselsnummer:"10108000398",fodselsdato:"1974-09-16",dodsdato:null,barn:[{fornavn:"Bruce",mellomnavn:null,etternavn:"Banner",forkortetNavn:"Bruce Banner",fodselsnummer:"10108000391",fodselsdato:"2016-04-17",dodsdato:null,harSammeBosted:!1,gradering:"FORTROLIG",erEgenAnsatt:!1,harVeilederTilgang:!1,kjonn:"M"},{fornavn:"Harry",mellomnavn:null,etternavn:"Bosch",forkortetNavn:"Harry Bosch",fodselsnummer:"10108000392",fodselsdato:"2014-05-24",dodsdato:null,harSammeBosted:!0,gradering:"UGRADERT",erEgenAnsatt:!1,harVeilederTilgang:!1,kjonn:"M"},{fornavn:"Satoshi",mellomnavn:null,etternavn:"Nakamoto",forkortetNavn:"Satoshi Nakamoto",fodselsnummer:"10108000398",fodselsdato:"2005-10-04",dodsdato:null,harSammeBosted:!1,erEgenAnsatt:!1,harVeilederTilgang:!0,gradering:"STRENGT_FORTROLIG",kjonn:"K"}],kontonummer:"12345678911",geografiskEnhet:{enhetsnummer:"0106",navn:"Nav Fredrikstad"},telefon:[{prioritet:"1",telefonNr:"+4746333333",registrertDato:"10.07.2008",master:"Freg"},{prioritet:"2",telefonNr:"80022222",registrertDato:"10.04.2010",master:"KRR"},{prioritet:"3",telefonNr:"44222444",registrertDato:null,master:"PDL"}],epost:{epostAdresse:"tester.scrambling@registre.no",epostSistOppdatert:"10.04.2010",master:"KRR"},statsborgerskap:"NORGE",sivilstand:{sivilstand:"Gift",fraDato:"2012-08-20"},partner:{fornavn:"fornavn",mellomnavn:null,etternavn:"etternavn",forkortetNavn:"fornavn etternavn",fodselsnummer:"12108000391",fodselsdato:"1980-12-10",dodsdato:null,harSammeBosted:!0,erEgenAnsatt:!0,harVeilederTilgang:!1,gradering:"UGRADERT",kjonn:"M"},bostedsadresse:{coAdressenavn:"CoAdresseNavn",vegadresse:{matrikkelId:null,postnummer:"0000",husnummer:"21",husbokstav:"A",kommunenummer:"1111",adressenavn:"Arendalsegate",tilleggsnavn:"Arendal",poststed:"Posted",kommune:"Kommune"},matrikkeladresse:{matrikkelId:null,bruksenhetsnummer:"H0101",tilleggsnavn:"Ja",kommunenummer:"8008",postnummer:"1337",poststed:"Sandvika",kommune:"Blærum"},utenlandskAdresse:{adressenavnNummer:"AdressenavnNummer?",bygningEtasjeLeilighet:"H4290",postboksNummerNavn:"42",postkode:"1337",bySted:"Shanghai",regionDistriktOmraade:"Shanghai",landkode:"CN"},ukjentBosted:{bostedskommune:"Vinje",kommune:"Kommune"}},oppholdsadresse:null,kontaktadresser:[{type:"Utland",coAdressenavn:null,vegadresse:null,postboksadresse:null,postadresseIFrittFormat:null,utenlandskAdresse:null,utenlandskAdresseIFrittFormat:{adresselinje1:"C/O adresse2 Test",adresselinje2:"Adresselinje 2",adresselinje3:"Adresselinje 3",byEllerStedsnavn:"Stedsnavn",postkode:"1234",landkode:"Landkode"}}],kjonn:"K",malform:"se"}),iT=()=>({navn:"Navn Navnesen",adresse:{type:"NORSKPOSTADRESSE",adresselinje1:"Adresselinje 1",adresselinje2:"Adresselinje 2",postnummer:"0000",poststed:"Sted",landkode:"NO",land:"Norge"}}),oT={ident:"Z123456",navn:"Ruben, Røde",fornavn:"Røde",etternavn:"Ruben"},DT="ecf5e2dc-8177-4ea7-86da-d1e3c4cbc83c",nT="2023-12-03T10:15:30+01:00",rT="JVBERi0xLjQKJfbk/N8KMSAwIG9iago8PAovVHlwZSAvQ2F0YWxvZwovVmVyc2lvbiAvMS43Ci9QYWdlcyAyIDAgUgovTWV0YWRhdGEgMyAwIFIKL01hcmtJbmZvIDQgMCBSCi9MYW5nIChubykKL1ZpZXdlclByZWZlcmVuY2VzIDUgMCBSCi9PdXRwdXRJbnRlbnRzIFs2IDAgUl0KL1N0cnVjdFRyZWVSb290IDcgMCBSCj4+CmVuZG9iago4IDAgb2JqCjw8Ci9DcmVhdGlvbkRhdGUgKEQ6MjAyNDAyMTIxMzM1NTYrMDAnMDAnKQovUHJvZHVjZXIgKG9wZW5odG1sdG9wZGYuY29tKQovZGVzY3JpcHRpb24gKEFrdGl2aXRldHNwbGFuIG9nIGRpYWxvZykKL0F1dGhvciAob3JraXZhci1wZGZnZW4pCi9TdWJqZWN0IChBa3Rpdml0ZXRzcGxhbikKL1RpdGxlIChBa3Rpdml0ZXRzcGxhbikKPj4KZW5kb2JqCjIgMCBvYmoKPDwKL1R5cGUgL1BhZ2VzCi9LaWRzIFs5IDAgUiAxMCAwIFIgMTEgMCBSIDEyIDAgUiAxMyAwIFIgMTQgMCBSIDE1IDAgUiAxNiAwIFIgMTcgMCBSIDE4IDAgUgoxOSAwIFJdCi9Db3VudCAxMQo+PgplbmRvYmoKMyAwIG9iago8PAovTGVuZ3RoIDUzMDEKL1R5cGUgL01ldGFkYXRhCi9TdWJ0eXBlIC9YTUwKPj4Kc3RyZWFtDQo8P3hwYWNrZXQgYmVnaW49Iu+7vyIgaWQ9Ilc1TTBNcENlaGlIenJlU3pOVGN6a2M5ZCI/Pjx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iPgogIDxyZGY6UkRGIHhtbG5zOnJkZj0iaHR0cDovL3d3dy53My5vcmcvMTk5OS8wMi8yMi1yZGYtc3ludGF4LW5zIyI+CiAgICA8cmRmOkRlc2NyaXB0aW9uIHhtbG5zOnBkZmFpZD0iaHR0cDovL3d3dy5haWltLm9yZy9wZGZhL25zL2lkLyIgcmRmOmFib3V0PSIiPgogICAgICA8cGRmYWlkOmNvbmZvcm1hbmNlPkE8L3BkZmFpZDpjb25mb3JtYW5jZT4KICAgICAgPHBkZmFpZDpwYXJ0PjI8L3BkZmFpZDpwYXJ0PgogICAgPC9yZGY6RGVzY3JpcHRpb24+CiAgICA8cmRmOkRlc2NyaXB0aW9uIHhtbG5zOnBkZj0iaHR0cDovL25zLmFkb2JlLmNvbS9wZGYvMS4zLyIgcmRmOmFib3V0PSIiPgogICAgICA8cGRmOlBERlZlcnNpb24+MS43PC9wZGY6UERGVmVyc2lvbj4KICAgICAgPHBkZjpQcm9kdWNlcj5vcGVuaHRtbHRvcGRmLmNvbTwvcGRmOlByb2R1Y2VyPgogICAgPC9yZGY6RGVzY3JpcHRpb24+CiAgICA8cmRmOkRlc2NyaXB0aW9uIHhtbG5zOnhtcD0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wLyIgcmRmOmFib3V0PSIiPgogICAgICA8eG1wOkNyZWF0ZURhdGU+MjAyNC0wMi0xMlQxMzozNTo1NiswMDowMDwveG1wOkNyZWF0ZURhdGU+CiAgICA8L3JkZjpEZXNjcmlwdGlvbj4KICAgIDxyZGY6RGVzY3JpcHRpb24geG1sbnM6ZGM9Imh0dHA6Ly9wdXJsLm9yZy9kYy9lbGVtZW50cy8xLjEvIiByZGY6YWJvdXQ9IiI+CiAgICAgIDxkYzpmb3JtYXQ+YXBwbGljYXRpb24vcGRmPC9kYzpmb3JtYXQ+CiAgICAgIDxkYzpjcmVhdG9yPgogICAgICAgIDxyZGY6U2VxPgogICAgICAgICAgPHJkZjpsaT5vcmtpdmFyLXBkZmdlbjwvcmRmOmxpPgogICAgICAgIDwvcmRmOlNlcT4KICAgICAgPC9kYzpjcmVhdG9yPgogICAgICA8ZGM6dGl0bGU+CiAgICAgICAgPHJkZjpBbHQ+CiAgICAgICAgICA8cmRmOmxpIHhtbDpsYW5nPSJ4LWRlZmF1bHQiPkFrdGl2aXRldHNwbGFuPC9yZGY6bGk+CiAgICAgICAgPC9yZGY6QWx0PgogICAgICA8L2RjOnRpdGxlPgogICAgICA8ZGM6ZGVzY3JpcHRpb24+CiAgICAgICAgPHJkZjpBbHQ+CiAgICAgICAgICA8cmRmOmxpIHhtbDpsYW5nPSJ4LWRlZmF1bHQiPkFrdGl2aXRldHNwbGFuPC9yZGY6bGk+CiAgICAgICAgPC9yZGY6QWx0PgogICAgICA8L2RjOmRlc2NyaXB0aW9uPgogICAgPC9yZGY6RGVzY3JpcHRpb24+CiAgICA8cmRmOkRlc2NyaXB0aW9uIHhtbG5zOnBkZmFFeHRlbnNpb249Imh0dHA6Ly93d3cuYWlpbS5vcmcvcGRmYS9ucy9leHRlbnNpb24vIiB4bWxuczpwZGZhUHJvcGVydHk9Imh0dHA6Ly93d3cuYWlpbS5vcmcvcGRmYS9ucy9wcm9wZXJ0eSMiIHhtbG5zOnBkZmFTY2hlbWE9Imh0dHA6Ly93d3cuYWlpbS5vcmcvcGRmYS9ucy9zY2hlbWEjIiB4bWxuczpwZGZ1YWlkPSJodHRwOi8vd3d3LmFpaW0ub3JnL3BkZnVhL25zL2lkLyIgcmRmOmFib3V0PSIiPgogICAgICA8cGRmYUV4dGVuc2lvbjpzY2hlbWFzPgogICAgICAgIDxyZGY6QmFnPgogICAgICAgICAgPHJkZjpsaSByZGY6cGFyc2VUeXBlPSJSZXNvdXJjZSI+CiAgICAgICAgICAgIDxwZGZhU2NoZW1hOnNjaGVtYT5BZG9iZSBQREYgU2NoZW1hPC9wZGZhU2NoZW1hOnNjaGVtYT4KICAgICAgICAgICAgPHBkZmFTY2hlbWE6bmFtZXNwYWNlVVJJPmh0dHA6Ly9ucy5hZG9iZS5jb20vcGRmLzEuMy88L3BkZmFTY2hlbWE6bmFtZXNwYWNlVVJJPgogICAgICAgICAgICA8cGRmYVNjaGVtYTpwcmVmaXg+cGRmPC9wZGZhU2NoZW1hOnByZWZpeD4KICAgICAgICAgICAgPHBkZmFTY2hlbWE6cHJvcGVydHk+CiAgICAgICAgICAgICAgPHJkZjpTZXE+CiAgICAgICAgICAgICAgICA8cmRmOmxpIHJkZjpwYXJzZVR5cGU9IlJlc291cmNlIj4KICAgICAgICAgICAgICAgICAgPHBkZmFQcm9wZXJ0eTpuYW1lPlBERlZlcnNpb248L3BkZmFQcm9wZXJ0eTpuYW1lPgogICAgICAgICAgICAgICAgICA8cGRmYVByb3BlcnR5OnZhbHVlVHlwZT5UZXh0PC9wZGZhUHJvcGVydHk6dmFsdWVUeXBlPgogICAgICAgICAgICAgICAgICA8cGRmYVByb3BlcnR5OmNhdGVnb3J5PmludGVybmFsPC9wZGZhUHJvcGVydHk6Y2F0ZWdvcnk+CiAgICAgICAgICAgICAgICAgIDxwZGZhUHJvcGVydHk6ZGVzY3JpcHRpb24+VGhlIFBERiBmaWxlIHZlcnNpb24uPC9wZGZhUHJvcGVydHk6ZGVzY3JpcHRpb24+CiAgICAgICAgICAgICAgICA8L3JkZjpsaT4KICAgICAgICAgICAgICAgIDxyZGY6bGkgcmRmOnBhcnNlVHlwZT0iUmVzb3VyY2UiPgogICAgICAgICAgICAgICAgICA8cGRmYVByb3BlcnR5Om5hbWU+S2V5d29yZHM8L3BkZmFQcm9wZXJ0eTpuYW1lPgogICAgICAgICAgICAgICAgICA8cGRmYVByb3BlcnR5OnZhbHVlVHlwZT5UZXh0PC9wZGZhUHJvcGVydHk6dmFsdWVUeXBlPgogICAgICAgICAgICAgICAgICA8cGRmYVByb3BlcnR5OmNhdGVnb3J5PmV4dGVybmFsPC9wZGZhUHJvcGVydHk6Y2F0ZWdvcnk+CiAgICAgICAgICAgICAgICAgIDxwZGZhUHJvcGVydHk6ZGVzY3JpcHRpb24+S2V5d29yZHMuPC9wZGZhUHJvcGVydHk6ZGVzY3JpcHRpb24+CiAgICAgICAgICAgICAgICA8L3JkZjpsaT4KICAgICAgICAgICAgICAgIDxyZGY6bGkgcmRmOnBhcnNlVHlwZT0iUmVzb3VyY2UiPgogICAgICAgICAgICAgICAgICA8cGRmYVByb3BlcnR5Om5hbWU+UHJvZHVjZXI8L3BkZmFQcm9wZXJ0eTpuYW1lPgogICAgICAgICAgICAgICAgICA8cGRmYVByb3BlcnR5OnZhbHVlVHlwZT5BZ2VudE5hbWU8L3BkZmFQcm9wZXJ0eTp2YWx1ZVR5cGU+CiAgICAgICAgICAgICAgICAgIDxwZGZhUHJvcGVydHk6Y2F0ZWdvcnk+aW50ZXJuYWw8L3BkZmFQcm9wZXJ0eTpjYXRlZ29yeT4KICAgICAgICAgICAgICAgICAgPHBkZmFQcm9wZXJ0eTpkZXNjcmlwdGlvbj5UaGUgbmFtZSBvZiB0aGUgdG9vbCB0aGF0IGNyZWF0ZWQgdGhlIFBERiBkb2N1bWVudC48L3BkZmFQcm9wZXJ0eTpkZXNjcmlwdGlvbj4KICAgICAgICAgICAgICAgIDwvcmRmOmxpPgogICAgICAgICAgICAgIDwvcmRmOlNlcT4KICAgICAgICAgICAgPC9wZGZhU2NoZW1hOnByb3BlcnR5PgogICAgICAgICAgPC9yZGY6bGk+CiAgICAgICAgICA8cmRmOmxpIHJkZjpwYXJzZVR5cGU9IlJlc291cmNlIj4KICAgICAgICAgICAgPHBkZmFTY2hlbWE6c2NoZW1hPlBERi9BIElEIFNjaGVtYTwvcGRmYVNjaGVtYTpzY2hlbWE+CiAgICAgICAgICAgIDxwZGZhU2NoZW1hOm5hbWVzcGFjZVVSST5odHRwOi8vd3d3LmFpaW0ub3JnL3BkZmEvbnMvaWQvPC9wZGZhU2NoZW1hOm5hbWVzcGFjZVVSST4KICAgICAgICAgICAgPHBkZmFTY2hlbWE6cHJlZml4PnBkZmFpZDwvcGRmYVNjaGVtYTpwcmVmaXg+CiAgICAgICAgICAgIDxwZGZhU2NoZW1hOnByb3BlcnR5PgogICAgICAgICAgICAgIDxyZGY6U2VxPgogICAgICAgICAgICAgICAgPHJkZjpsaSByZGY6cGFyc2VUeXBlPSJSZXNvdXJjZSI+CiAgICAgICAgICAgICAgICAgIDxwZGZhUHJvcGVydHk6bmFtZT5wYXJ0PC9wZGZhUHJvcGVydHk6bmFtZT4KICAgICAgICAgICAgICAgICAgPHBkZmFQcm9wZXJ0eTp2YWx1ZVR5cGU+SW50ZWdlcjwvcGRmYVByb3BlcnR5OnZhbHVlVHlwZT4KICAgICAgICAgICAgICAgICAgPHBkZmFQcm9wZXJ0eTpjYXRlZ29yeT5pbnRlcm5hbDwvcGRmYVByb3BlcnR5OmNhdGVnb3J5PgogICAgICAgICAgICAgICAgICA8cGRmYVByb3BlcnR5OmRlc2NyaXB0aW9uPlBhcnQgb2YgUERGL0Egc3RhbmRhcmQ8L3BkZmFQcm9wZXJ0eTpkZXNjcmlwdGlvbj4KICAgICAgICAgICAgICAgIDwvcmRmOmxpPgogICAgICAgICAgICAgICAgPHJkZjpsaSByZGY6cGFyc2VUeXBlPSJSZXNvdXJjZSI+CiAgICAgICAgICAgICAgICAgIDxwZGZhUHJvcGVydHk6bmFtZT5jb25mb3JtYW5jZTwvcGRmYVByb3BlcnR5Om5hbWU+CiAgICAgICAgICAgICAgICAgIDxwZGZhUHJvcGVydHk6dmFsdWVUeXBlPlRleHQ8L3BkZmFQcm9wZXJ0eTp2YWx1ZVR5cGU+CiAgICAgICAgICAgICAgICAgIDxwZGZhUHJvcGVydHk6Y2F0ZWdvcnk+aW50ZXJuYWw8L3BkZmFQcm9wZXJ0eTpjYXRlZ29yeT4KICAgICAgICAgICAgICAgICAgPHBkZmFQcm9wZXJ0eTpkZXNjcmlwdGlvbj5Db25mb3JtYW5jZSBsZXZlbCBvZiBQREYvQSBzdGFuZGFyZDwvcGRmYVByb3BlcnR5OmRlc2NyaXB0aW9uPgogICAgICAgICAgICAgICAgPC9yZGY6bGk+CiAgICAgICAgICAgICAgPC9yZGY6U2VxPgogICAgICAgICAgICA8L3BkZmFTY2hlbWE6cHJvcGVydHk+CiAgICAgICAgICA8L3JkZjpsaT4KICAgICAgICAgIDxyZGY6bGkgcmRmOnBhcnNlVHlwZT0iUmVzb3VyY2UiPgogICAgICAgICAgICA8cGRmYVNjaGVtYTpzY2hlbWE+UERGL1VBIFVuaXZlcnNhbCBBY2Nlc3NpYmlsaXR5IFNjaGVtYTwvcGRmYVNjaGVtYTpzY2hlbWE+CiAgICAgICAgICAgIDxwZGZhU2NoZW1hOm5hbWVzcGFjZVVSST5odHRwOi8vd3d3LmFpaW0ub3JnL3BkZnVhL25zL2lkLzwvcGRmYVNjaGVtYTpuYW1lc3BhY2VVUkk+CiAgICAgICAgICAgIDxwZGZhU2NoZW1hOnByZWZpeD5wZGZ1YWlkPC9wZGZhU2NoZW1hOnByZWZpeD4KICAgICAgICAgICAgPHBkZmFTY2hlbWE6cHJvcGVydHk+CiAgICAgICAgICAgICAgPHJkZjpTZXE+CiAgICAgICAgICAgICAgICA8cmRmOmxpIHJkZjpwYXJzZVR5cGU9IlJlc291cmNlIj4KICAgICAgICAgICAgICAgICAgPHBkZmFQcm9wZXJ0eTpuYW1lPnBhcnQ8L3BkZmFQcm9wZXJ0eTpuYW1lPgogICAgICAgICAgICAgICAgICA8cGRmYVByb3BlcnR5OnZhbHVlVHlwZT5JbnRlZ2VyPC9wZGZhUHJvcGVydHk6dmFsdWVUeXBlPgogICAgICAgICAgICAgICAgICA8cGRmYVByb3BlcnR5OmNhdGVnb3J5PmludGVybmFsPC9wZGZhUHJvcGVydHk6Y2F0ZWdvcnk+CiAgICAgICAgICAgICAgICAgIDxwZGZhUHJvcGVydHk6ZGVzY3JpcHRpb24+SW5kaWNhdGVzLCB3aGljaCBwYXJ0IG9mIElTTyAxNDI4OSBzdGFuZGFyZCBpcyBmb2xsb3dlZDwvcGRmYVByb3BlcnR5OmRlc2NyaXB0aW9uPgogICAgICAgICAgICAgICAgPC9yZGY6bGk+CiAgICAgICAgICAgICAgPC9yZGY6U2VxPgogICAgICAgICAgICA8L3BkZmFTY2hlbWE6cHJvcGVydHk+CiAgICAgICAgICA8L3JkZjpsaT4KICAgICAgICA8L3JkZjpCYWc+CiAgICAgIDwvcGRmYUV4dGVuc2lvbjpzY2hlbWFzPgogICAgICA8cGRmdWFpZDpwYXJ0PjE8L3BkZnVhaWQ6cGFydD4KICAgIDwvcmRmOkRlc2NyaXB0aW9uPgogIDwvcmRmOlJERj4KPC94OnhtcG1ldGE+PD94cGFja2V0IGVuZD0idyI/PgoNCmVuZHN0cmVhbQplbmRvYmoKNCAwIG9iago8PAovTWFya2VkIHRydWUKPj4KZW5kb2JqCjUgMCBvYmoKPDwKL0Rpc3BsYXlEb2NUaXRsZSB0cnVlCj4+CmVuZG9iago2IDAgb2JqCjw8Ci9UeXBlIC9PdXRwdXRJbnRlbnQKL1MgL0dUU19QREZBMQovRGVzdE91dHB1dFByb2ZpbGUgMjAgMCBSCi9JbmZvIChzUkdCIElFQzYxOTY2LTIuMSkKL091dHB1dENvbmRpdGlvbiAoc1JHQiBJRUM2MTk2Ni0yLjEpCi9PdXRwdXRDb25kaXRpb25JZGVudGlmaWVyIChzUkdCIElFQzYxOTY2LTIuMSkKL1JlZ2lzdHJ5TmFtZSAoaHR0cDovL3d3dy5jb2xvci5vcmcpCj4+CmVuZG9iago3IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RUcmVlUm9vdAovUm9sZU1hcCAyMSAwIFIKL0sgMjIgMCBSCi9QYXJlbnRUcmVlTmV4dEtleSAxMQovUGFyZW50VHJlZSAyMyAwIFIKPj4KZW5kb2JqCjkgMCBvYmoKPDwKL1R5cGUgL1BhZ2UKL01lZGlhQm94IFswLjAgMC4wIDU5NS4yNzUgODQxLjg3NV0KL1BhcmVudCAyIDAgUgovQ29udGVudHMgMjQgMCBSCi9SZXNvdXJjZXMgMjUgMCBSCi9TdHJ1Y3RQYXJlbnRzIDAKL1RhYnMgL1MKPj4KZW5kb2JqCjEwIDAgb2JqCjw8Ci9UeXBlIC9QYWdlCi9NZWRpYUJveCBbMC4wIDAuMCA1OTUuMjc1IDg0MS44NzVdCi9QYXJlbnQgMiAwIFIKL0NvbnRlbnRzIDI2IDAgUgovUmVzb3VyY2VzIDI3IDAgUgovU3RydWN0UGFyZW50cyAxCi9UYWJzIC9TCj4+CmVuZG9iagoxMSAwIG9iago8PAovVHlwZSAvUGFnZQovTWVkaWFCb3ggWzAuMCAwLjAgNTk1LjI3NSA4NDEuODc1XQovUGFyZW50IDIgMCBSCi9Db250ZW50cyAyOCAwIFIKL1Jlc291cmNlcyAyOSAwIFIKL1N0cnVjdFBhcmVudHMgMgovVGFicyAvUwo+PgplbmRvYmoKMTIgMCBvYmoKPDwKL1R5cGUgL1BhZ2UKL01lZGlhQm94IFswLjAgMC4wIDU5NS4yNzUgODQxLjg3NV0KL1BhcmVudCAyIDAgUgovQ29udGVudHMgMzAgMCBSCi9SZXNvdXJjZXMgMzEgMCBSCi9TdHJ1Y3RQYXJlbnRzIDMKL1RhYnMgL1MKPj4KZW5kb2JqCjEzIDAgb2JqCjw8Ci9UeXBlIC9QYWdlCi9NZWRpYUJveCBbMC4wIDAuMCA1OTUuMjc1IDg0MS44NzVdCi9QYXJlbnQgMiAwIFIKL0NvbnRlbnRzIDMyIDAgUgovUmVzb3VyY2VzIDMzIDAgUgovU3RydWN0UGFyZW50cyA0Ci9UYWJzIC9TCj4+CmVuZG9iagoxNCAwIG9iago8PAovVHlwZSAvUGFnZQovTWVkaWFCb3ggWzAuMCAwLjAgNTk1LjI3NSA4NDEuODc1XQovUGFyZW50IDIgMCBSCi9Db250ZW50cyAzNCAwIFIKL1Jlc291cmNlcyAzNSAwIFIKL1N0cnVjdFBhcmVudHMgNQovVGFicyAvUwo+PgplbmRvYmoKMTUgMCBv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L0JpYkVudHJ5Ci9DaGFydCAvRmlndXJlCj4+CmVuZG9iagoyMiAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRG9jdW1lbnQKL0xhbmcgKG5vKQovUCA3IDAgUgovSyA0NiAwIFIKPj4KZW5kb2JqCjIzIDAgb2JqCjw8Ci9OdW1zIFswIFs0NyAwIFIgNDggMCBSIDQ5IDAgUiA0OSAwIFIgNTAgMCBSIDUxIDAgUiA1MiAwIFIgNTMgMCBSIDU0IDAgUiA1NCAwIFIKNTUgMCBSIDU1IDAgUiA1NiAwIFIgNTcgMCBSIDU4IDAgUiA1OSAwIFIgNjAgMCBSIDYxIDAgUiA2MiAwIFIgNjMgMCBSCjY0IDAgUiA2NSAwIFIgNjYgMCBSIDY3IDAgUiA2OCAwIFIgNjkgMCBSIDcwIDAgUiA3MSAwIFIgNzIgMCBSIDczIDAgUgo3NCAwIFJdCiAxIFs3NSAwIFIgNzYgMCBSIDc3IDAgUiA3OCAwIFIgNzkgMCBSIDgwIDAgUiA4MSAwIFIgODIgMCBSIDgzIDAgUiA4NCAwIFIKODUgMCBSIDg2IDAgUiA4NyAwIFIgODggMCBSIDg5IDAgUiA5MCAwIFIgOTAgMCBSIDkxIDAgUiA5MiAwIFIgOTMgMCBSCjk0IDAgUiA5NSAwIFIgOTYgMCBSIDkzIDAgUiA5MyAwIFIgOTMgMCBSIDkzIDAgUiA5MyAwIFIgOTMgMCBSIDkzIDAgUgo5MyAwIFIgOTMgMCBSIDkzIDAgUiA5MyAwIFIgOTMgMCBSIDkzIDAgUiA5MyAwIFIgOTMgMCBSIDkzIDAgUl0KIDIgWzkzIDAgUiA5MyAwIFIgOTMgMCBSIDkzIDAgUiA5MyAwIFIgOTMgMCBSIDkzIDAgUiA5MyAwIFIgOTMgMCBSIDkzIDAgUgo5MyAwIFIgOTMgMCBSIDkzIDAgUiA5MyAwIFIgOTMgMCBSIDk3IDAgUiA5OCAwIFIgOTkgMCBSIDEwMCAwIFIgMTAxIDAgUgoxMDIgMCBSIDEwMyAwIFIgMTA0IDAgUiAxMDUgMCBSIDEwNiAwIFIgMTA3IDAgUiAxMDggMCBSIDEwOSAwIFIgMTEwIDAgUiAxMTEgMCBSCjExMiAwIFIgMTEzIDAgUiAxMTQgMCBSIDExNSAwIFIgMTE2IDAgUiAxMTcgMCBSIDExOCAwIFIgMTE5IDAgUiAxMjAgMCBSIDEyMSAwIFIKMTIyIDAgUl0KIDMgWzEyMyAwIFIgMTI0IDAgUiAxMjUgMCBSIDEyNiAwIFIgMTI3IDAgUiAxMjggMCBSIDEyOSAwIFIgMTMwIDAgUiAxMzEgMCBSIDEzMiAwIFIKMTMzIDAgUiAxMzQgMCBSIDEzNSAwIFIgMTM2IDAgUiAxMzcgMCBSIDEzOCAwIFIgMTM5IDAgUiAxNDAgMCBSIDE0MSAwIFIgMTQyIDAgUgoxNDMgMCBSIDE0NCAwIFIgMTQ1IDAgUiAxNDYgMCBSIDE0NyAwIFIgMTQ4IDAgUiAxNDkgMCBSIDE1MCAwIFIgMTUxIDAgUiAxNTIgMCBSCjE1MyAwIFIgMTU0IDAgUiAxNTUgMCBSIDE1NiAwIFIgMTU3IDAgUl0KIDQgWzE1OCAwIFIgMTU5IDAgUiAxNjAgMCBSIDE2MSAwIFIgMTYyIDAgUiAxNjMgMCBSIDE2NCAwIFIgMTY1IDAgUiAxNjYgMCBSIDE2NyAwIFIKMTY4IDAgUiAxNjkgMCBSIDE3MCAwIFIgMTcxIDAgUiAxNzIgMCBSIDE3MiAwIFIgMTczIDAgUiAxNzQgMCBSIDE3NSAwIFIgMTc2IDAgUgoxNzcgMCBSIDE3OCAwIFIgMTc5IDAgUiAxODAgMCBSIDE4MSAwIFIgMTgyIDAgUiAxODMgMCBSIDE4NCAwIFIgMTg1IDAgUiAxODYgMCBSCjE4NyAwIFIgMTg4IDAgUiAxODkgMCBSIDE5MCAwIFIgMTkxIDAgUl0KNSBbMTkyIDAgUiAxOTMgMCBSIDE5NCAwIFIgMTk1IDAgUiAxOTYgMCBSIDE5NyAwIFIgMTk4IDAgUiAxOTkgMCBSIDIwMCAwIFIgMjAxIDAgUgoyMDIgMCBSIDIwMyAwIFIgMjA0IDAgUiAyMDUgMCBSIDIwNiAwIFIgMjA3IDAgUiAyMDggMCBSIDIwOSAwIFIgMjA5IDAgUiAyMTAgMCBSCjIxMSAwIFIgMjEyIDAgUiAyMTMgMCBSIDIxNCAwIFIgMjE1IDAgUiAyMTYgMCBSIDIxNyAwIFIgMjE4IDAgUiAyMTkgMCBSIDIyMCAwIFIKMjIxIDAgUl0KIDYgWzIyMiAwIFIgMjIzIDAgUiAyMjQgMCBSIDIyNSAwIFIgMjI2IDAgUiAyMjcgMCBSIDIyOCAwIFIgMjI5IDAgUiAyMzAgMCBSIDIzMSAwIFIKMjMyIDAgUiAyMzMgMCBSIDIzNCAwIFIgMjM1IDAgUiAyMzYgMCBSIDIzNyAwIFIgMjM4IDAgUiAyMzkgMCBSIDI0MCAwIFIgMjQxIDAgUgoyNDIgMCBSIDI0MyAwIFIgMjQ0IDAgUiAyNDUgMCBSIDI0NiAwIFIgMjQ3IDAgUiAyNDggMCBSIDI0OSAwIFIgMjUwIDAgUiAyNTEgMCBSXQogNyBbMjUyIDAgUiAyNTMgMCBSIDI1NCAwIFIgMjU1IDAgUiAyNTYgMCBSIDI1NyAwIFIgMjU4IDAgUiAyNTkgMCBSIDI2MCAwIFIgMjYxIDAgUgoyNjIgMCBSIDI2MyAwIFIgMjY0IDAgUiAyNjUgMCBSIDI2NiAwIFIgMjY3IDAgUiAyNjggMCBSIDI2OSAwIFIgMjcwIDAgUiAyNzAgMCBSCjI3MSAwIFIgMjcyIDAgUiAyNzMgMCBSIDI3NCAwIFIgMjc1IDAgUiAyNzYgMCBSIDI3NyAwIFIgMjc4IDAgUiAyNzkgMCBSIDI4MCAwIFIKMjgxIDAgUl0KIDggWzI4MiAwIFIgMjgzIDAgUiAyODQgMCBSIDI4NCAwIFIgMjg1IDAgUiAyODYgMCBSIDI4NyAwIFIgMjg4IDAgUiAyODkgMCBSIDI5MCAwIFIKMjkxIDAgUiAyOTIgMCBSIDI5MyAwIFIgMjk0IDAgUiAyOTUgMCBSIDI5NiAwIFIgMjk3IDAgUiAyOTcgMCBSIDI5OCAwIFIgMjk5IDAgUgozMDAgMCBSIDMwMSAwIFIgMzAyIDAgUiAzMDMgMCBSIDMwNCAwIFIgMzA1IDAgUiAzMDYgMCBSIDMwNyAwIFIgMzA4IDAgUiAzMDkgMCBSCjMxMCAwIFIgMzExIDAgUiAzMTIgMCBSIDMxMyAwIFIgMzE0IDAgUiAzMTUgMCBSXQogOSBbMzE2IDAgUiAzMTcgMCBSIDMxOCAwIFIgMzE5IDAgUiAzMjAgMCBSIDMyMSAwIFIgMzIyIDAgUiAzMjMgMCBSIDMyNCAwIFIgMzI1IDAgUgozMjYgMCBSIDMyNyAwIFIgMzI4IDAgUiAzMjkgMCBSIDMzMCAwIFIgMzMxIDAgUiAzMzIg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IDAgUgovUGcgOSAwIFIKL0sgWzM4NyAwIFIgNDkgMCBSIDUwIDAgUiAzODggMCBSIDc0IDAgUiAzODkgMCBSIDI4MSAwIFIgMzkwIDAgUiAzOTEgMCBSIDMxNCAwIFIKMzkyIDAgUiAzOTMgMCBSXQo+PgplbmRvYmoKNDcgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCAzOTQgMCBSCi9QZyA5IDAgUgovSyAwCj4+CmVuZG9iago0OCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDM5NSAwIFIKL1BnIDkgMCBSCi9LIDEKPj4KZW5kb2JqCjQ5IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9QCi9QIDQ2IDAgUgovUGcgOSAwIFIKL0sgWzIgM10KPj4KZW5kb2JqCjUwIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9IMwovUCA0NiAwIFIKL1BnIDkgMCBSCi9LIDQKPj4KZW5kb2JqCjUxIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgMzk2IDAgUgovUGcgOSAwIFIKL0sgNQo+PgplbmRvYmoKNTIgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0gyCi9QIDM5NiAwIFIKL1BnIDkgMCBSCi9LIDYKPj4KZW5kb2JqCjUzIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDM5NyAwIFIKL1BnIDkgMCBSCi9LIFs1NCAwIFIgN10KPj4KZW5kb2JqCjU0IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDUzIDAgUgovUGcgOSAwIFIKL0sgWzggOV0KPj4KZW5kb2JqCjU1IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDM5OCAwIFIKL1BnIDkgMCBSCi9LIFszOTkgMCBSIDEwIDQwMCAwIFIgMTFdCj4+CmVuZG9iago1NiAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDM5OSAwIFIKL1BnIDkgMCBSCi9LIDEyCj4+CmVuZG9iago1NyAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDM5OSAwIFIKL1BnIDkgMCBSCi9LIDEzCj4+CmVuZG9iago1OCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQwMCAwIFIKL1BnIDkgMCBSCi9LIDE0Cj4+CmVuZG9iago1OSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQwMCAwIFIKL1BnIDkgMCBSCi9LIDE1Cj4+CmVuZG9iago2MCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQwMSAwIFIKL1BnIDkgMCBSCi9LIDE2Cj4+CmVuZG9iago2MSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQwMSAwIFIKL1BnIDkgMCBSCi9LIDE3Cj4+CmVuZG9iago2MiAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQwMiAwIFIKL1BnIDkgMCBSCi9LIDE4Cj4+CmVuZG9iago2MyAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQwMiAwIFIKL1BnIDkgMCBSCi9LIDE5Cj4+CmVuZG9iago2NCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQwMyAwIFIKL1BnIDkgMCBSCi9LIDIwCj4+CmVuZG9iago2NSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQwMyAwIFIKL1BnIDkgMCBSCi9LIDIxCj4+CmVuZG9iago2NiAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvSDQKL1AgNDA0IDAgUgovUGcgOSAwIFIKL0sgMjIKPj4KZW5kb2JqCjY3IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNDA1IDAgUgovUGcgOSAwIFIKL0sgMjMKPj4KZW5kb2JqCjY4IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNDA1IDAgUgovUGcgOSAwIFIKL0sgMjQKPj4KZW5kb2JqCjY5IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNDA2IDAgUgovUGcgOSAwIFIKL0sgMjUKPj4KZW5kb2JqCjcwIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDQwNyAwIFIKL1BnIDkgMCBSCi9LIFsyNiA0MDggMCBSXQo+PgplbmRvYmoKNzEgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgNDA4IDAgUgovUGcgOSAwIFIKL0sgMjcKPj4KZW5kb2JqCjcyIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDQwNyAwIFIKL1BnIDkgMCBSCi9LIFs0MDkgMCBSIDI4XQo+PgplbmRvYmoKNzMgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA0MTAgMCBSCi9QZyA5IDAgUgovSyAyOQo+PgplbmRvYmoKNzQgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0ZpZ3VyZQovUCA0NiAwIFIKL1BnIDkgMCBSCi9BbHQgKCkKL0EgNDExIDAgUgovSyAzMAo+PgplbmRvYmoKNzUgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgNDEyIDAgUgovUGcgMTAgMCBSCi9LIFswIDQxMyAwIFJdCj4+CmVuZG9iago3NiAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCA0MTMgMCBSCi9QZyAxMCAwIFIKL0sgMQo+PgplbmRvYmoKNzcgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgNDEyIDAgUgovUGcgMTAgMCBSCi9LIFs0MTQgMCBSIDJdCj4+CmVuZG9iago3OCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQxNSAwIFIKL1BnIDEwIDAgUgovSyAzCj4+CmVuZG9iago3OSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQxNSAwIFIKL1BnIDEwIDAgUgovSyA0Cj4+CmVuZG9iago4MCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQxNiAwIFIKL1BnIDEwIDAgUgovSyA1Cj4+CmVuZG9iago4MSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCA0MTcgMCBSCi9QZyAxMCAwIFIKL0sgWzYgNDE4IDAgUl0KPj4KZW5kb2JqCjgyIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDQxOCAwIFIKL1BnIDEwIDAgUgovSyA3Cj4+CmVuZG9iago4MyAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCA0MTcgMCBSCi9QZyAxMCAwIFIKL0sgWzQxOSAwIFIgOF0KPj4KZW5kb2JqCjg0IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNDIwIDAgUgovUGcgMTAgMCBSCi9LIDkKPj4KZW5kb2JqCjg1IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNDIwIDAgUgovUGcgMTAgMCBSCi9LIDEwCj4+CmVuZG9iago4NiAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQyMSAwIFIKL1BnIDEwIDAgUgovSyAxMQo+PgplbmRvYmoKODcgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA0MjIgMCBSCi9QZyAxMCAwIFIKL0sgMTIKPj4KZW5kb2JqCjg4IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNDIyIDAgUgovUGcgMTAgMCBSCi9LIDEzCj4+CmVuZG9iago4OSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQyMyAwIFIKL1BnIDEwIDAgUgovSyAxNAo+PgplbmRvYmoKOTAgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA0MjMgMCBSCi9QZyAxMCAwIFIKL0sgWzE1IDE2IDkxIDAgUl0KPj4KZW5kb2JqCjkxIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDkwIDAgUgovUGcgMTAgMCBSCi9LIDE3Cj4+CmVuZG9iago5MiAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQyNCAwIFIKL1BnIDEwIDAgUgovSyAxOAo+PgplbmRvYmoKOTMgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA0MjQgMCBSCi9QZyAxMCAwIFIKL0sgWzE5IDk0IDAgUiA5NiAwIFIgMjMgMjQgMjUgMjYgMjcgMjggMjkKMzAgMzEgMzIgMzMgMzQgMzUgMzYgMzcgMzggNDI1IDAgUgo0MjYgMCBSIDQyNyAwIFIgNDI4IDAgUiA0MjkgMCBSIDQzMCAwIFIgNDMxIDAgUiA0MzIgMCBSIDQzMyAwIFIgNDM0IDAgUiA0MzUgMCBSCjQzNiAwIFIgNDM3IDAgUiA0MzggMCBSIDQzOSAwIFIgOTcgMCBSIDk5IDAgUiAxMDEgMCBSIDEwMyAwIFIgMTA0IDAgUl0KPj4KZW5kb2JqCjk0IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDkzIDAgUgovUGcgMTAgMCBSCi9LIFsyMCA0NDAgMCBSXQo+PgplbmRvYmoKOTUgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgNDQwIDAgUgovUGcgMTAgMCBSCi9LIDIxCj4+CmVuZG9iago5NiAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCA5MyAwIFIKL1BnIDEwIDAgUgovSyBbNDQxIDAgUiAyMl0KPj4KZW5kb2JqCjk3IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDkzIDAgUgovUGcgMTEgMCBSCi9LIFsxNSA0NDIgMCBSXQo+PgplbmRvYmoKOTggMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgNDQyIDAgUgovUGcgMTEgMCBSCi9LIDE2Cj4+CmVuZG9iago5OSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCA5MyAwIFIKL1BnIDExIDAgUgovSyBbNDQzIDAgUiAxNyA0NDQgMCBSXQo+PgplbmRvYmoKMTAwIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDQ0NCAwIFIKL1BnIDExIDAgUgovSyAxOAo+PgplbmRvYmoKMTAxIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDkzIDAgUgovUGcgMTEgMCBSCi9LIFs0NDUgMCBSIDE5IDQ0NiAwIFJdCj4+CmVuZG9iagoxMDIgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgNDQ2IDAgUgovUGcgMTEgMCBSCi9LIDIwCj4+CmVuZG9iagoxMDMgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgOTMgMCBSCi9QZyAxMSAwIFIKL0sgWzQ0NyAwIFIgMjFdCj4+CmVuZG9iagoxMDQgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgOTMgMCBSCi9QZyAxMSAwIFIKL0sgMjIKPj4KZW5kb2JqCjEwNSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQ0OCAwIFIKL1BnIDExIDAgUgovSyAyMwo+PgplbmRvYmoKMTA2IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDQ0OSAwIFIKL1BnIDExIDAgUgovSyBbMjQgNDUwIDAgUl0KPj4KZW5kb2JqCjEwNyAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCA0NTAgMCBSCi9QZyAxMSAwIFIKL0sgMjUKPj4KZW5kb2JqCjEwOCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCA0NDkgMCBSCi9QZyAxMSAwIFIKL0sgWzQ1MSAwIFIgMjZdCj4+CmVuZG9iagoxMDkgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA0NTIgMCBSCi9QZyAxMSAwIFIKL0sgMjcKPj4KZW5kb2JqCjExMCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQ1MiAwIFIKL1BnIDExIDAgUgovSyAyOAo+PgplbmRvYmoKMTExIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNDUzIDAgUgovUGcgMTEgMCBSCi9LIDI5Cj4+CmVuZG9iagoxMTIgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA0NTMgMCBSCi9QZyAxMSAwIFIKL0sgMzAKPj4KZW5kb2JqCjExMyAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQ1NCAwIFIKL1BnIDExIDAgUgovSyAzMQo+PgplbmRvYmoKMTE0IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNDU0IDAgUgovUGcgMTEgMCBSCi9LIDMyCj4+CmVuZG9iagoxMTUgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA0NTUgMCBSCi9QZyAxMSAwIFIKL0sgMzMKPj4KZW5kb2JqCjExNiAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQ1NSAwIFIKL1BnIDExIDAgUgovSyAzNAo+PgplbmRvYmoKMTE3IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNDU2IDAgUgovUGcgMTEgMCBSCi9LIDM1Cj4+CmVuZG9iagoxMTggMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA0NTYgMCBSCi9QZyAxMSAwIFIKL0sgMzYKPj4KZW5kb2JqCjExOSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQ1NyAwIFIKL1BnIDExIDAgUgovSyAzNwo+PgplbmRvYmoKMTIwIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDQ1OCAwIFIKL1BnIDExIDAgUgovSyBbMzggNDU5IDAgUl0KPj4KZW5kb2JqCjEyMSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCA0NTkgMCBSCi9QZyAxMSAwIFIKL0sgMzkKPj4KZW5kb2JqCjEyMiAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCA0NTggMCBSCi9QZyAxMSAwIFIKL0sgWzQ2MCAwIFIgNDBdCj4+CmVuZG9iagoxMjMgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA0NjEgMCBSCi9QZyAxMiAwIFIKL0sgMAo+PgplbmRvYmoKMTI0IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDQ2MiAwIFIKL1BnIDEyIDAgUgovSyBbMSA0NjMgMCBSXQo+PgplbmRvYmoKMTI1IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDQ2MyAwIFIKL1BnIDEyIDAgUgovSyAyCj4+CmVuZG9iagoxMjYgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgNDYyIDAgUgovUGcgMTIgMCBSCi9LIFs0NjQgMCBSIDNdCj4+CmVuZG9iagoxMjcgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA0NjUgMCBSCi9QZyAxMiAwIFIKL0sgNAo+PgplbmRvYmoKMTI4IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDQ2NiAwIFIKL1BnIDEyIDAgUgovSyBbNSA0NjcgMCBSXQo+PgplbmRvYmoKMTI5IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDQ2NyAwIFIKL1BnIDEyIDAgUgovSyA2Cj4+CmVuZG9iagoxMzAgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgNDY2IDAgUgovUGcgMTIgMCBSCi9LIFs0NjggMCBSIDddCj4+CmVuZG9iagoxMzEgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA0NjkgMCBSCi9QZyAxMiAwIFIKL0sgOAo+PgplbmRvYmoKMTMyIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDQ3MCAwIFIKL1BnIDEyIDAgUgovSyBbOSA0NzEgMCBSXQo+PgplbmRvYmoKMTMzIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDQ3MSAwIFIKL1BnIDEyIDAgUgovSyAxMAo+PgplbmRvYmoKMTM0IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDQ3MCAwIFIKL1BnIDEyIDAgUgovSyBbNDcyIDAgUiAxMV0KPj4KZW5kb2JqCjEzNSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQ3MyAwIFIKL1BnIDEyIDAgUgovSyAxMgo+PgplbmRvYmoKMTM2IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNDczIDAgUgovUGcgMTIgMCBSCi9LIDEzCj4+CmVuZG9iagoxMzcgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA0NzQgMCBSCi9QZyAxMiAwIFIKL0sgMTQKPj4KZW5kb2JqCjEzOCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQ3NSAwIFIKL1BnIDEyIDAgUgovSyAxNQo+PgplbmRvYmoKMTM5IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNDc1IDAgUgovUGcgMTIgMCBSCi9LIFsxNiAxNDAgMCBSXQo+PgplbmRvYmoKMTQwIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDEzOSAwIFIKL1BnIDEyIDAgUgovSyAxNwo+PgplbmRvYmoKMTQxIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNDc2IDAgUgovUGcgMTIgMCBSCi9LIDE4Cj4+CmVuZG9iagoxNDIgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgNDc3IDAgUgovUGcgMTIgMCBSCi9LIFsxOSA0NzggMCBSXQo+PgplbmRvYmoKMTQzIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDQ3OCAwIFIKL1BnIDEyIDAgUgovSyAyMAo+PgplbmRvYmoKMTQ0IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDQ3NyAwIFIKL1BnIDEyIDAgUgovSyBbNDc5IDAgUiAyMV0KPj4KZW5kb2JqCjE0NSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQ4MCAwIFIKL1BnIDEyIDAgUgovSyAyMgo+PgplbmRvYmoKMTQ2IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDQ4MSAwIFIKL1BnIDEyIDAgUgovSyBbMjMgNDgyIDAgUl0KPj4KZW5kb2JqCjE0NyAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCA0ODIgMCBSCi9QZyAxMiAwIFIKL0sgMjQKPj4KZW5kb2JqCjE0OCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCA0ODEgMCBSCi9QZyAxMiAwIFIKL0sgWzQ4MyAwIFIgMjVdCj4+CmVuZG9iagoxNDkgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA0ODQgMCBSCi9QZyAxMiAwIFIKL0sgMjYKPj4KZW5kb2JqCjE1MCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCA0ODUgMCBSCi9QZyAxMiAwIFIKL0sgWzI3IDQ4NiAwIFJdCj4+CmVuZG9iagoxNTEgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgNDg2IDAgUgovUGcgMTIgMCBSCi9LIDI4Cj4+CmVuZG9iagoxNTIgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgNDg1IDAgUgovUGcgMTIgMCBSCi9LIFs0ODcgMCBSIDI5XQo+PgplbmRvYmoKMTUzIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNDg4IDAgUgovUGcgMTIgMCBSCi9LIDMwCj4+CmVuZG9iagoxNTQgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgNDg5IDAgUgovUGcgMTIgMCBSCi9LIFszMSA0OTAgMCBSXQo+PgplbmRvYmoKMTU1IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDQ5MCAwIFIKL1BnIDEyIDAgUgovSyAzMgo+PgplbmRvYmoKMTU2IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDQ4OSAwIFIKL1BnIDEyIDAgUgovSyBbNDkxIDAgUiAzM10KPj4KZW5kb2JqCjE1NyAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQ5MiAwIFIKL1BnIDEyIDAgUgovSyAzNAo+PgplbmRvYmoKMTU4IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDQ5MyAwIFIKL1BnIDEzIDAgUgovSyBbMCA0OTQgMCBSXQo+PgplbmRvYmoKMTU5IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDQ5NCAwIFIKL1BnIDEzIDAgUgovSyAxCj4+CmVuZG9iagoxNjAgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgNDkzIDAgUgovUGcgMTMgMCBSCi9LIFs0OTUgMCBSIDJdCj4+CmVuZG9iagoxNjEgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA0OTYgMCBSCi9QZyAxMyAwIFIKL0sgMwo+PgplbmRvYmoKMTYyIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNDk2IDAgUgovUGcgMTMgMCBSCi9LIDQKPj4KZW5kb2JqCjE2MyAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQ5NyAwIFIKL1BnIDEzIDAgUgovSyA1Cj4+CmVuZG9iagoxNjQgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgNDk4IDAgUgovUGcgMTMgMCBSCi9LIFs2IDQ5OSAwIFJdCj4+CmVuZG9iagoxNjUgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgNDk5IDAgUgovUGcgMTMgMCBSCi9LIDcKPj4KZW5kb2JqCjE2NiAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCA0OTggMCBSCi9QZyAxMyAwIFIKL0sgWzUwMCAwIFIgOF0KPj4KZW5kb2JqCjE2NyAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDUwMSAwIFIKL1BnIDEzIDAgUgovSyA5Cj4+CmVuZG9iagoxNjggMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgNTAyIDAgUgovUGcgMTMgMCBSCi9LIFsxMCA1MDMgMCBSXQo+PgplbmRvYmoKMTY5IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDUwMyAwIFIKL1BnIDEzIDAgUgovSyAxMQo+PgplbmRvYmoKMTcwIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDUwMiAwIFIKL1BnIDEzIDAgUgovSyBbNTA0IDAgUiAxMl0KPj4KZW5kb2JqCjE3MSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDUwNSAwIFIKL1BnIDEzIDAgUgovSyAxMwo+PgplbmRvYmoKMTcyIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTA1IDAgUgovUGcgMTMgMCBSCi9LIFsxNCAxNV0KPj4KZW5kb2JqCjE3MyAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDUwNiAwIFIKL1BnIDEzIDAgUgovSyAxNgo+PgplbmRvYmoKMTc0IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTA2IDAgUgovUGcgMTMgMCBSCi9LIFsxNyAxNzUgMCBSXQo+PgplbmRvYmoKMTc1IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDE3NCAwIFIKL1BnIDEzIDAgUgovSyAxOAo+PgplbmRvYmoKMTc2IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTA3IDAgUgovUGcgMTMgMCBSCi9LIDE5Cj4+CmVuZG9iagoxNzcgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1MDcgMCBSCi9QZyAxMyAwIFIKL0sgWzIwIDE3OCAwIFJdCj4+CmVuZG9iagoxNzggMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgMTc3IDAgUgovUGcgMTMgMCBSCi9LIDIxCj4+CmVuZG9iagoxNzkgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1MDggMCBSCi9QZyAxMyAwIFIKL0sgMjIKPj4KZW5kb2JqCjE4MCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCA1MDkgMCBSCi9QZyAxMyAwIFIKL0sgWzIzIDUxMCAwIFJdCj4+CmVuZG9iagoxODEgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgNTEwIDAgUgovUGcgMTMgMCBSCi9LIDI0Cj4+CmVuZG9iagoxODIgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgNTA5IDAgUgovUGcgMTMgMCBSCi9LIFs1MTEgMCBSIDI1XQo+PgplbmRvYmoKMTgzIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTEyIDAgUgovUGcgMTMgMCBSCi9LIDI2Cj4+CmVuZG9iagoxODQgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgNTEzIDAgUgovUGcgMTMgMCBSCi9LIFsyNyA1MTQgMCBSXQo+PgplbmRvYmoKMTg1IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDUxNCAwIFIKL1BnIDEzIDAgUgovSyAyOAo+PgplbmRvYmoKMTg2IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDUxMyAwIFIKL1BnIDEzIDAgUgovSyBbNTE1IDAgUiAyOV0KPj4KZW5kb2JqCjE4NyAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDUxNiAwIFIKL1BnIDEzIDAgUgovSyAzMAo+PgplbmRvYmoKMTg4IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDUxNyAwIFIKL1BnIDEzIDAgUgovSyBbMzEgNTE4IDAgUl0KPj4KZW5kb2JqCjE4OSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCA1MTggMCBSCi9QZyAxMyAwIFIKL0sgMzIKPj4KZW5kb2JqCjE5MCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCA1MTcgMCBSCi9QZyAxMyAwIFIKL0sgWzUxOSAwIFIgMzNdCj4+CmVuZG9iagoxOTEgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1MjAgMCBSCi9QZyAxMyAwIFIKL0sgMzQKPj4KZW5kb2JqCjE5MiAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCA1MjEgMCBSCi9QZyAxNCAwIFIKL0sgWzAgNTIyIDAgUl0KPj4KZW5kb2JqCjE5MyAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCA1MjIgMCBSCi9QZyAxNCAwIFIKL0sgMQo+PgplbmRvYmoKMTk0IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDUyMSAwIFIKL1BnIDE0IDAgUgovSyBbNTIzIDAgUiAyXQo+PgplbmRvYmoKMTk1IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTI0IDAgUgovUGcgMTQgMCBSCi9LIDMKPj4KZW5kb2JqCjE5NiAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCA1MjUgMCBSCi9QZyAxNCAwIFIKL0sgWzQgNTI2IDAgUl0KPj4KZW5kb2JqCjE5NyAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCA1MjYgMCBSCi9QZyAxNCAwIFIKL0sgNQo+PgplbmRvYmoKMTk4IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDUyNSAwIFIKL1BnIDE0IDAgUgovSyBbNTI3IDAgUiA2XQo+PgplbmRvYmoKMTk5IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTI4IDAgUgovUGcgMTQgMCBSCi9LIDcKPj4KZW5kb2JqCjIwMCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCA1MjkgMCBSCi9QZyAxNCAwIFIKL0sgWzggNTMwIDAgUl0KPj4KZW5kb2JqCjIwMSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCA1MzAgMCBSCi9QZyAxNCAwIFIKL0sgOQo+PgplbmRvYmoKMjAyIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDUyOSAwIFIKL1BnIDE0IDAgUgovSyBbNTMxIDAgUiAxMF0KPj4KZW5kb2JqCjIwMyAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDUzMiAwIFIKL1BnIDE0IDAgUgovSyAxMQo+PgplbmRvYmoKMjA0IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDUzMyAwIFIKL1BnIDE0IDAgUgovSyBbMTIgNTM0IDAgUl0KPj4KZW5kb2JqCjIwNSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCA1MzQgMCBSCi9QZyAxNCAwIFIKL0sgMTMKPj4KZW5kb2JqCjIwNiAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCA1MzMgMCBSCi9QZyAxNCAwIFIKL0sgWzUzNSAwIFIgMTRdCj4+CmVuZG9iagoyMDcgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1MzYgMCBSCi9QZyAxNCAwIFIKL0sgMTUKPj4KZW5kb2JqCjIwOCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvSDIKL1AgNTM2IDAgUgovUGcgMTQgMCBSCi9LIDE2Cj4+CmVuZG9iagoyMDkgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgNTM3IDAgUgovUGcgMTQgMCBSCi9LIFs1MzggMCBSIDE3IDUzOSAwIFIgMThdCj4+CmVuZG9iagoyMTAgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1MzggMCBSCi9QZyAxNCAwIFIKL0sgMTkKPj4KZW5kb2JqCjIxMSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDUzOCAwIFIKL1BnIDE0IDAgUgovSyAyMAo+PgplbmRvYmoKMjEyIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTM5IDAgUgovUGcgMTQgMCBSCi9LIDIxCj4+CmVuZG9iagoyMTMgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1MzkgMCBSCi9QZyAxNCAwIFIKL0sgMjIKPj4KZW5kb2JqCjIxNCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDU0MCAwIFIKL1BnIDE0IDAgUgovSyAyMwo+PgplbmRvYmoKMjE1IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTQwIDAgUgovUGcgMTQgMCBSCi9LIDI0Cj4+CmVuZG9iagoyMTYgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1NDEgMCBSCi9QZyAxNCAwIFIKL0sgMjUKPj4KZW5kb2JqCjIxNyAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDU0MiAwIFIKL1BnIDE0IDAgUgovSyAyNgo+PgplbmRvYmoKMjE4IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTQzIDAgUgovUGcgMTQgMCBSCi9LIDI3Cj4+CmVuZG9iagoyMTkgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0g0Ci9QIDU0NCAwIFIKL1BnIDE0IDAgUgovSyAyOAo+PgplbmRvYmoKMjIwIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTQ1IDAgUgovUGcgMTQgMCBSCi9LIDI5Cj4+CmVuZG9iagoyMjEgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1NDUgMCBSCi9QZyAxNCAwIFIKL0sgMzAKPj4KZW5kb2JqCjIyMiAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDU0NiAwIFIKL1BnIDE0IDAgUgovSyA1NDcgMCBSCj4+CmVuZG9iagoyMjMgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1NDYgMCBSCi9QZyAxNSAwIFIKL0sgMQo+PgplbmRvYmoKMjI0IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTQ4IDAgUgovUGcgMTUgMCBSCi9LIDIKPj4KZW5kb2JqCjIyNSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDU0OCAwIFIKL1BnIDE1IDAgUgovSyAzCj4+CmVuZG9iagoyMjYgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1NDkgMCBSCi9QZyAxNSAwIFIKL0sgNAo+PgplbmRvYmoKMjI3IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTQ5IDAgUgovUGcgMTUgMCBSCi9LIDUKPj4KZW5kb2JqCjIyOCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDU1MCAwIFIKL1BnIDE1IDAgUgovSyA2Cj4+CmVuZG9iagoyMjkgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1NTAgMCBSCi9QZyAxNSAwIFIKL0sgNwo+PgplbmRvYmoKMjMwIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTUxIDAgUgovUGcgMTUgMCBSCi9LIDgKPj4KZW5kb2JqCjIzMSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDU1MSAwIFIKL1BnIDE1IDAgUgovSyA5Cj4+CmVuZG9iagoyMzIgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1NTIgMCBSCi9QZyAxNSAwIFIKL0sgMTAKPj4KZW5kb2JqCjIzMyAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDU1MiAwIFIKL1BnIDE1IDAgUgovSyAxMQo+PgplbmRvYmoKMjM0IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTUzIDAgUgovUGcgMTUgMCBSCi9LIDEyCj4+CmVuZG9iagoyMzUgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1NTMgMCBSCi9QZyAxNSAwIFIKL0sgMTMKPj4KZW5kb2JqCjIzNiAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDU1NCAwIFIKL1BnIDE1IDAgUgovSyAxNAo+PgplbmRvYmoKMjM3IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTU0IDAgUgovUGcgMTUgMCBSCi9LIDE1Cj4+CmVuZG9iagoyMzggMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1NTUgMCBSCi9QZyAxNSAwIFIKL0sgMTYKPj4KZW5kb2JqCjIzOSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDU1NSAwIFIKL1BnIDE1IDAgUgovSyAxNwo+PgplbmRvYmoKMjQwIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTU2IDAgUgovUGcgMTUgMCBSCi9LIDE4Cj4+CmVuZG9iagoyNDEgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1NTYgMCBSCi9QZyAxNSAwIFIKL0sgMTkKPj4KZW5kb2JqCjI0MiAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDU1NyAwIFIKL1BnIDE1IDAgUgovSyAyMAo+PgplbmRvYmoKMjQzIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTU3IDAgUgovUGcgMTUgMCBSCi9LIDIxCj4+CmVuZG9iagoyNDQgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1NTggMCBSCi9QZyAxNSAwIFIKL0sgMjIKPj4KZW5kb2JqCjI0NSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDU1OCAwIFIKL1BnIDE1IDAgUgovSyAyMwo+PgplbmRvYmoKMjQ2IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTU5IDAgUgovUGcgMTUgMCBSCi9LIDI0Cj4+CmVuZG9iagoyNDcgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1NTkgMCBSCi9QZyAxNSAwIFIKL0sgMjUKPj4KZW5kb2JqCjI0OCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDU2MCAwIFIKL1BnIDE1IDAgUgovSyAyNgo+PgplbmRvYmoKMjQ5IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTYwIDAgUgovUGcgMTUgMCBSCi9LIDI3Cj4+CmVuZG9iagoyNTAgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1NjEgMCBSCi9QZyAxNSAwIFIKL0sgMjgKPj4KZW5kb2JqCjI1MSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDU2MSAwIFIKL1BnIDE1IDAgUgovSyAyOQo+PgplbmRvYmoKMjUyIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTYyIDAgUgovUGcgMTUgMCBSCi9LIDU2MyAwIFIKPj4KZW5kb2JqCjI1MyAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCA1NjQgMCBSCi9QZyAxNiAwIFIKL0sgWzEgNTY1IDAgUl0KPj4KZW5kb2JqCjI1NCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCA1NjUgMCBSCi9QZyAxNiAwIFIKL0sgMgo+PgplbmRvYmoKMjU1IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDU2NCAwIFIKL1BnIDE2IDAgUgovSyBbNTY2IDAgUiAzXQo+PgplbmRvYmoKMjU2IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTY3IDAgUgovUGcgMTYgMCBSCi9LIDQKPj4KZW5kb2JqCjI1NyAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDU2NyAwIFIKL1BnIDE2IDAgUgovSyA1Cj4+CmVuZG9iagoyNTggMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1NjggMCBSCi9QZyAxNiAwIFIKL0sgNgo+PgplbmRvYmoKMjU5IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTY4IDAgUgovUGcgMTYgMCBSCi9LIDcKPj4KZW5kb2JqCjI2MCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDU2OSAwIFIKL1BnIDE2IDAgUgovSyA4Cj4+CmVuZG9iagoyNjEgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1NjkgMCBSCi9QZyAxNiAwIFIKL0sgOQo+PgplbmRvYmoKMjYyIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTcwIDAgUgovUGcgMTYgMCBSCi9LIDEwCj4+CmVuZG9iagoyNjMgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1NzAgMCBSCi9QZyAxNiAwIFIKL0sgMTEKPj4KZW5kb2JqCjI2NCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDU3MSAwIFIKL1BnIDE2IDAgUgovSyAxMgo+PgplbmRvYmoKMjY1IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTcxIDAgUgovUGcgMTYgMCBSCi9LIFsxMyAyNjYgMCBSXQo+PgplbmRvYmoKMjY2IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDI2NSAwIFIKL1BnIDE2IDAgUgovSyAxNAo+PgplbmRvYmoKMjY3IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTcyIDAgUgovUGcgMTYgMCBSCi9LIDE1Cj4+CmVuZG9iagoyNjggMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1NzIgMCBSCi9QZyAxNiAwIFIKL0sgMTYKPj4KZW5kb2JqCjI2OSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDU3MyAwIFIKL1BnIDE2IDAgUgovSyAxNwo+PgplbmRvYmoKMjcwIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTczIDAgUgovUGcgMTYgMCBSCi9LIFsxOCAxOV0KPj4KZW5kb2JqCjI3MSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDU3NCAwIFIKL1BnIDE2IDAgUgovSyAyMAo+PgplbmRvYmoKMjcyIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTc0IDAgUgovUGcgMTYgMCBSCi9LIDIxCj4+CmVuZG9iagoyNzMgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1NzUgMCBSCi9QZyAxNiAwIFIKL0sgMjIKPj4KZW5kb2JqCjI3NCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCA1NzYgMCBSCi9QZyAxNiAwIFIKL0sgWzIzIDU3NyAwIFJdCj4+CmVuZG9iagoyNzUgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgNTc3IDAgUgovUGcgMTYgMCBSCi9LIDI0Cj4+CmVuZG9iagoyNzYgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgNTc2IDAgUgovUGcgMTYgMCBSCi9LIFs1NzggMCBSIDI1XQo+PgplbmRvYmoKMjc3IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTc5IDAgUgovUGcgMTYgMCBSCi9LIDI2Cj4+CmVuZG9iagoyNzggMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1NzkgMCBSCi9QZyAxNiAwIFIKL0sgMjcKPj4KZW5kb2JqCjI3OSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDU4MCAwIFIKL1BnIDE2IDAgUgovSyAyOAo+PgplbmRvYmoKMjgwIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTgwIDAgUgovUGcgMTYgMCBSCi9LIDI5Cj4+CmVuZG9iagoyODEgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0gzCi9QIDQ2IDAgUgovUGcgMTYgMCBSCi9LIDMwCj4+CmVuZG9iagoyODIgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1ODEgMCBSCi9QZyAxNyAwIFIKL0sgMAo+PgplbmRvYmoKMjgzIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9IMgovUCA1ODEgMCBSCi9QZyAxNyAwIFIKL0sgMQo+PgplbmRvYmoKMjg0IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDU4MiAwIFIKL1BnIDE3IDAgUgovSyBbNTgzIDAgUiAyIDU4NCAwIFIgM10KPj4KZW5kb2JqCjI4NSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDU4MyAwIFIKL1BnIDE3IDAgUgovSyA0Cj4+CmVuZG9iagoyODYgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1ODMgMCBSCi9QZyAxNyAwIFIKL0sgNQo+PgplbmRvYmoKMjg3IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTg0IDAgUgovUGcgMTcgMCBSCi9LIDYKPj4KZW5kb2JqCjI4OCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDU4NCAwIFIKL1BnIDE3IDAgUgovSyA3Cj4+CmVuZG9iagoyODkgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1ODUgMCBSCi9QZyAxNyAwIFIKL0sgOAo+PgplbmRvYmoKMjkwIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDU4NiAwIFIKL1BnIDE3IDAgUgovSyBbOSA1ODcgMCBSXQo+PgplbmRvYmoKMjkxIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDU4NyAwIFIKL1BnIDE3IDAgUgovSyAxMAo+PgplbmRvYmoKMjkyIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDU4NiAwIFIKL1BnIDE3IDAgUgovSyBbNTg4IDAgUiAxMSA1ODkgMCBSXQo+PgplbmRvYmoKMjkzIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDU4OSAwIFIKL1BnIDE3IDAgUgovSyAxMgo+PgplbmRvYmoKMjk0IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDU4NiAwIFIKL1BnIDE3IDAgUgovSyBbNTkwIDAgUiAxM10KPj4KZW5kb2JqCjI5NSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDU5MSAwIFIKL1BnIDE3IDAgUgovSyAxNAo+PgplbmRvYmoKMjk2IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9IMgovUCA1OTEgMCBSCi9QZyAxNyAwIFIKL0sgMTUKPj4KZW5kb2JqCjI5NyAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCA1OTIgMCBSCi9QZyAxNyAwIFIKL0sgWzU5MyAwIFIgMTYgNTk0IDAgUiAxN10KPj4KZW5kb2JqCjI5OCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDU5MyAwIFIKL1BnIDE3IDAgUgovSyAxOAo+PgplbmRvYmoKMjk5IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTkzIDAgUgovUGcgMTcgMCBSCi9LIDE5Cj4+CmVuZG9iagozMDAgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1OTQgMCBSCi9QZyAxNyAwIFIKL0sgMjAKPj4KZW5kb2JqCjMwMSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDU5NCAwIFIKL1BnIDE3IDAgUgovSyAyMQo+PgplbmRvYmoKMzAyIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTk1IDAgUgovUGcgMTcgMCBSCi9LIDIyCj4+CmVuZG9iagozMDMgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgNTk2IDAgUgovUGcgMTcgMCBSCi9LIFsyMyA1OTcgMCBSXQo+PgplbmRvYmoKMzA0IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDU5NyAwIFIKL1BnIDE3IDAgUgovSyAyNAo+PgplbmRvYmoKMzA1IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDU5NiAwIFIKL1BnIDE3IDAgUgovSyBbNTk4IDAgUiAyNSA1OTkgMCBSXQo+PgplbmRvYmoKMzA2IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDU5OSAwIFIKL1BnIDE3IDAgUgovSyAyNgo+PgplbmRvYmoKMzA3IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDU5NiAwIFIKL1BnIDE3IDAgUgovSyBbNjAwIDAgUiAyNyA2MDEgMCBSXQo+PgplbmRvYmoKMzA4IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDYwMSAwIFIKL1BnIDE3IDAgUgovSyAyOAo+PgplbmRvYmoKMzA5IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDU5NiAwIFIKL1BnIDE3IDAgUgovSyBbNjAyIDAgUiAyOSA2MDMgMCBSXQo+PgplbmRvYmoKMzEwIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDYwMyAwIFIKL1BnIDE3IDAgUgovSyAzMAo+PgplbmRvYmoKMzExIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDU5NiAwIFIKL1BnIDE3IDAgUgovSyBbNjA0IDAgUiAzMSA2MDUgMCBSXQo+PgplbmRvYmoKMzEyIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDYwNSAwIFIKL1BnIDE3IDAgUgovSyAzMgo+PgplbmRvYmoKMzEzIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDU5NiAwIFIKL1BnIDE3IDAgUgovSyBbNjA2IDAgUiAzM10KPj4KZW5kb2JqCjMxNCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvSDQKL1AgNDYgMCBSCi9QZyAxNyAwIFIKL0sgMzQKPj4KZW5kb2JqCjMxNSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvSDQKL1AgMzkyIDAgUgovUGcgMTcgMCBSCi9LIDM1Cj4+CmVuZG9iagozMTYgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA2MDcgMCBSCi9QZyAxOCAwIFIKL0sgMAo+PgplbmRvYmoKMzE3IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNjA3IDAgUgovUGcgMTggMCBSCi9LIDEKPj4KZW5kb2JqCjMxOCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvSDQKL1AgMzkzIDAgUgovUGcgMTggMCBSCi9LIDIKPj4KZW5kb2JqCjMxOSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDYwOCAwIFIKL1BnIDE4IDAgUgovSyAzCj4+CmVuZG9iagozMjAgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA2MDggMCBSCi9QZyAxOCAwIFIKL0sgNAo+PgplbmRvYmoKMzIxIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNjA5IDAgUgovUGcgMTggMCBSCi9LIDUKPj4KZW5kb2JqCjMyMiAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDYwOSAwIFIKL1BnIDE4IDAgUgovSyA2Cj4+CmVuZG9iagozMjMgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA2MTAgMCBSCi9QZyAxOCAwIFIKL0sgNwo+PgplbmRvYmoKMzI0IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDYxMSAwIFIKL1BnIDE4IDAgUgovSyBbOCA2MTIgMCBSXQo+PgplbmRvYmoKMzI1IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDYxMiAwIFIKL1BnIDE4IDAgUgovSyA5Cj4+CmVuZG9iagozMjYgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgNjExIDAgUgovUGcgMTggMCBSCi9LIFs2MTMgMCBSIDEwXQo+PgplbmRvYmoKMzI3IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNjE0IDAgUgovUGcgMTggMCBSCi9LIDExCj4+CmVuZG9iagozMjggMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgNjE1IDAgUgovUGcgMTggMCBSCi9LIFsxMiA2MTYgMCBSXQo+PgplbmRvYmoKMzI5IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDYxNiAwIFIKL1BnIDE4IDAgUgovSyAxMwo+PgplbmRvYmoKMzMwIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDYxNSAwIFIKL1BnIDE4IDAgUgovSyBbNjE3IDAgUiAxNF0KPj4KZW5kb2JqCjMzMSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDYxOCAwIFIKL1BnIDE4IDAgUgovSyAxNQo+PgplbmRvYmoKMzMyIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNjE4IDAgUgovUGcgMTggMCBSCi9LIFsxNiAzMzMgMCBSXQo+PgplbmRvYmoKMzMzIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDMzMiAwIFIKL1BnIDE4IDAgUgovSyAxNwo+PgplbmRvYmoKMzM0IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNjE5IDAgUgovUGcgMTggMCBSCi9LIDE4Cj4+CmVuZG9iagozMzUgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA2MTkgMCBSCi9QZyAxOCAwIFIKL0sgMTkKPj4KZW5kb2JqCjMzNiAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDYyMCAwIFIKL1BnIDE4IDAgUgovSyAyMAo+PgplbmRvYmoKMzM3IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNjIwIDAgUgovUGcgMTggMCBSCi9LIDIxCj4+CmVuZG9iagozMzggMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA2MjEgMCBSCi9QZyAxOCAwIFIKL0sgMjIKPj4KZW5kb2JqCjMzOSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDYyMSAwIFIKL1BnIDE4IDAgUgovSyAyMwo+PgplbmRvYmoKMzQwIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNjIyIDAgUgovUGcgMTggMCBSCi9LIDI0Cj4+CmVuZG9iagozNDEgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA2MjIgMCBSCi9QZyAxOCAwIFIKL0sgMjUKPj4KZW5kb2JqCjM0MiAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDYyMyAwIFIKL1BnIDE4IDAgUgovSyAyNgo+PgplbmRvYmoKMzQzIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNjIzIDAgUgovUGcgMTggMCBSCi9LIFsyNyAzNDQgMCBSXQo+PgplbmRvYmoKMzQ0IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDM0MyAwIFIKL1BnIDE4IDAgUgovSyAyOAo+PgplbmRvYmoKMzQ1IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNjI0IDAgUgovUGcgMTggMCBSCi9LIDYyNSAwIFIKPj4KZW5kb2JqCjM0NiAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCA2MjYgMCBSCi9QZyAxOSAwIFIKL0sgWzEgNjI3IDAgUl0KPj4KZW5kb2JqCjM0NyAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCA2MjcgMCBSCi9QZyAxOSAwIFIKL0sgMgo+PgplbmRvYmoKMzQ4IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDYyNiAwIFIKL1BnIDE5IDAgUgovSyBbNjI4IDAgUiAzXQo+PgplbmRvYmoKMzQ5IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNjI5IDAgUgovUGcgMTkgMCBSCi9LIDQKPj4KZW5kb2JqCjM1MCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDYyOSAwIFIKL1BnIDE5IDAgUgovSyA1Cj4+CmVuZG9iagozNTEgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA2MzAgMCBSCi9QZyAxOSAwIFIKL0sgNgo+PgplbmRvYmoKMzUyIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDYzMSAwIFIKL1BnIDE5IDAgUgovSyBbNyA2MzIgMCBSXQo+PgplbmRvYmoKMzUzIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDYzMiAwIFIKL1BnIDE5IDAgUgovSyA4Cj4+CmVuZG9iagozNTQgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgNjMxIDAgUgovUGcgMTkgMCBSCi9LIFs2MzMgMCBSIDldCj4+CmVuZG9iagozNTUgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA2MzQgMCBSCi9QZyAxOSAwIFIKL0sgMTAKPj4KZW5kb2JqCjM1NiAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCA2MzUgMCBSCi9QZyAxOSAwIFIKL0sgWzExIDYzNiAwIFJdCj4+CmVuZG9iagozNTcgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgNjM2IDAgUgovUGcgMTkgMCBSCi9LIDEyCj4+CmVuZG9iagozNTggMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgNjM1IDAgUgovUGcgMTkgMCBSCi9LIFs2MzcgMCBSIDEzXQo+PgplbmRvYmoKMzU5IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNjM4IDAgUgovUGcgMTkgMCBSCi9LIDE0Cj4+CmVuZG9iagozNjAgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA2MzggMCBSCi9QZyAxOSAwIFIKL0sgMTUKPj4KZW5kb2JqCjM2MSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDYzOSAwIFIKL1BnIDE5IDAgUgovSyAxNgo+PgplbmRvYmoKMzYyIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNjM5IDAgUgovUGcgMTkgMCBSCi9LIFsxNyAzNjMgMCBSXQo+PgplbmRvYmoKMzYzIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDM2MiAwIFIKL1BnIDE5IDAgUgovSyAxOAo+PgplbmRvYmoKMzY0IDAgb2JqCjw8Ci9Qcm9wMSA2NDAgMCBSCi9Qcm9wMiA2NDEgMCBSCi9Qcm9wMyA2NDIgMCBSCi9Qcm9wNCA2NDMgMCBSCi9Qcm9wNSA2NDQgMCBSCi9Qcm9wNiA2NDUgMCBSCi9Qcm9wNyA2NDYgMCBSCi9Qcm9wOCA2NDcgMCBSCi9Qcm9wOSA2NDggMCBSCi9Qcm9wMTAgNjQ5IDAgUgovUHJvcDExIDY1MCAwIFIKL1Byb3AxMiA2NTEgMCBSCi9Qcm9wMTMgNjUyIDAgUgovUHJvcDE0IDY1MyAwIFIKL1Byb3AxNSA2NTQgMCBSCi9Qcm9wMTYgNjU1IDAgUgovUHJvcDE3IDY1NiAwIFIKL1Byb3AxOCA2NTcgMCBSCi9Qcm9wMTkgNjU4IDAgUgovUHJvcDIwIDY1OSAwIFIKL1Byb3AyMSA2NjAgMCBSCi9Qcm9wMjIgNjYxIDAgUgovUHJvcDIzIDY2MiAwIFIKL1Byb3AyNCA2NjMgMCBSCi9Qcm9wMjUgNjY0IDAgUgovUHJvcDI2IDY2NSAwIFIKL1Byb3AyNyA2NjYgMCBSCi9Qcm9wMjggNjY3IDAgUgovUHJvcDI5IDY2OCAwIFIKL1Byb3AzMCA2NjkgMCBSCi9Qcm9wMzEgNjcwIDAgUgovUHJvcDMyIDY3MSAwIFIKL1Byb3AzMyA2NzIgMCBSCi9Qcm9wMzQgNjczIDAgUgovUHJvcDM1IDY3NCAwIFIKL1Byb3AzNiA2NzUgMCBSCi9Qcm9wMzcgNjc2IDAgUgovUHJvcDM4IDY3NyAwIFIKL1Byb3AzOSA2NzggMCBSCi9Qcm9wNDAgNjc5IDAgUgovUHJvcDQxIDY4MCAwIFIKL1Byb3A0MiA2ODEgMCBSCi9Qcm9wNDMgNjgyIDAgUgovUHJvcDQ0IDY4MyAwIFIKL1Byb3A0NSA2ODQgMCBSCi9Qcm9wNDYgNjg1IDAgUgovUHJvcDQ3IDY4NiAwIFIKL1Byb3A0OCA2ODcgMCBSCi9Qcm9wNDkgNjg4IDAgUgovUHJvcDUwIDY4OSAwIFIKL1Byb3A1MSA2OTAgMCBSCi9Qcm9wNTIgNjkxIDAgUgovUHJvcDUzIDY5MiAwIFIKL1Byb3A1NCA2OTMgMCBSCi9Qcm9wNTUgNjk0IDAgUgovUHJvcDU2IDY5NSAwIFIKL1Byb3A1NyA2OTYgMCBSCi9Qcm9wNTggNjk3IDAgUgovUHJvcDU5IDY5OCAwIFIKL1Byb3A2MCA2OTkgMCBSCi9Qcm9wNjEgNzAwIDAgUgovUHJvcDYyIDcwMSAwIFIKL1Byb3A2MyA3MDIgMCBSCi9Qcm9wNjQgNzAzIDAgUgovUHJvcDY1IDcwNCAwIFIKL1Byb3A2NiA3MDUgMCBSCi9Qcm9wNjcgNzA2IDAgUgovUHJvcDY4IDcwNyAwIFIKL1Byb3A2OSA3MDggMCBSCi9Qcm9wNzAgNzA5IDAgUgovUHJvcDcxIDcxMCAwIFIKL1Byb3A3MiA3MTEgMCBSCi9Qcm9wNzMgNzEyIDAgUgovUHJvcDc0IDcxMyAwIFIKL1Byb3A3NSA3MTQgMCBSCi9Qcm9wNzYgNzE1IDAgUgovUHJvcDc3IDcxNiAwIFIKL1Byb3A3OCA3MTcgMCBSCi9Qcm9wNzkgNzE4IDAgUgovUHJvcDgwIDcxOSAwIFIKL1Byb3A4MSA3MjAgMCBSCi9Qcm9wODIgNzIxIDAgUgovUHJvcDgzIDcyMiAwIFIKL1Byb3A4NCA3MjMgMCBSCi9Qcm9wODUgNzI0IDAgUgovUHJvcDg2IDcyNSAwIFIKL1Byb3A4NyA3MjYgMCBSCi9Qcm9wODggNzI3IDAgUgovUHJvcDg5IDcyOCAwIFIKL1Byb3A5MCA3MjkgMCBSCi9Qcm9wOTEgNzMwIDAgUgovUHJvcDkyIDczMSAwIFIKL1Byb3A5MyA3MzIgMCBSCi9Qcm9wOTQgNzMzIDAgUgovUHJvcDk1IDczNCAwIFIKL1Byb3A5NiA3MzUgMCBSCi9Qcm9wOTcgNzM2IDAgUgovUHJvcDk4IDczNyAwIFIKL1Byb3A5OSA3MzggMCBSCi9Qcm9wMTAwIDczOSAwIFIKL1Byb3AxMDEgNzQwIDAgUgovUHJvcDEwMiA3NDEgMCBSCi9Qcm9wMTAzIDc0MiAwIFIKL1Byb3AxMDQgNzQzIDAgUgovUHJvcDEwNSA3NDQgMCBSCi9Qcm9wMTA2IDc0NSAwIFIKL1Byb3AxMDcgNzQ2IDAgUgovUHJvcDEwOCA3NDcgMCBSCi9Qcm9wMTA5IDc0OCAwIFIKL1Byb3AxMTAgNzQ5IDAgUgovUHJvcDExMSA3NTAgMCBSCi9Qcm9wMTEyIDc1MSAwIFIKL1Byb3AxMTMgNzUyIDAgUgovUHJvcDExNCA3NTMgMCBSCi9Qcm9wMTE1IDc1NCAwIFIKL1Byb3AxMTYgNzU1IDAgUgovUHJvcDExNyA3NTYgMCBSCi9Qcm9wMTE4IDc1NyAwIFIKL1Byb3AxMTkgNzU4IDAgUgovUHJvcDEyMCA3NTkgMCBSCi9Qcm9wMTIxIDc2MCAwIFIKL1Byb3AxMjIgNzYxIDAgUgovUHJvcDEyMyA3NjIgMCBSCi9Qcm9wMTI0IDc2MyAwIFIKL1Byb3AxMjUgNzY0IDAgUgovUHJvcDEyNiA3NjUgMCBSCi9Qcm9wMTI3IDc2NiAwIFIKL1Byb3AxMjggNzY3IDAgUgovUHJvcDEyOSA3NjggMCBSCi9Qcm9wMTMwIDc2OSAwIFIKL1Byb3AxMzEgNzcwIDAgUgovUHJvcDEzMiA3NzEgMCBSCi9Qcm9wMTMzIDc3MiAwIFIKL1Byb3AxMzQgNzczIDAgUgovUHJvcDEzNSA3NzQgMCBSCi9Qcm9w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MTIgMCBSCi9Qcm9wMjkgODEzIDAgUgovUHJvcDMwIDgxNCAwIFIKL1Byb3AzMSA4MTUgMCBSCi9Qcm9wMzIgODE2IDAgUgovUHJvcDMzIDgxNyAwIFIKL1Byb3AzNCA4MTggMCBSCi9Qcm9wMzUgODE5IDAgUgovUHJvcDM2IDgyMCAwIFIKL1Byb3AzNyA4MjEgMCBSCi9Qcm9wMzggODIyIDAgUgovUHJvcDM5IDgyMyAwIFIKL1Byb3A0MCA4MjQgMCBSCi9Qcm9wNDEgODI1IDAgUgovUHJvcDQyIDgyNiAwIFIKL1Byb3A0MyA4MjcgMCBSCi9Qcm9wNDQgODI4IDAgUgovUHJvcDQ1IDgyOSAwIFIKL1Byb3A0NiA4MzAgMCBSCi9Qcm9wNDcgODMxIDAgUgovUHJvcDQ4IDgzMiAwIFIKL1Byb3A0OSA4MzMgMCBSCi9Qcm9wNTAgODM0IDAgUgovUHJvcDUxIDgzNSAwIFIKL1Byb3A1MiA4MzYgMCBSCi9Qcm9wNTMgODM3IDAgUgovUHJvcDU0IDgzOCAwIFIKL1Byb3A1NSA4MzkgMCBSCi9Qcm9wNTYgODQwIDAgUgovUHJvcDU3IDg0MSAwIFIKL1Byb3A1OCA4NDIgMCBSCi9Qcm9wNTkgODQzIDAgUgovUHJvcDYwIDg0NCAwIFIKL1Byb3A2MSA4NDUgMCBSCi9Qcm9wNjIgODQ2IDAgUgovUHJvcDYzIDg0NyAwIFIKL1Byb3A2NCA4NDggMCBSCi9Qcm9wNjUgODQ5IDAgUgovUHJvcDY2IDg1MCAwIFIKL1Byb3A2NyA4NTEgMCBSCi9Qcm9wNjggODUyIDAgUgovUHJvcDY5IDg1MyAwIFIKL1Byb3A3MCA4NTQgMCBSCi9Qcm9wNzEgODU1IDAgUgovUHJvcDcyIDg1NiAwIFIKL1Byb3A3MyA4NTcgMCBSCi9Qcm9wNzQgODU4IDAgUgovUHJvcDc1IDg1OSAwIFIKL1Byb3A3NiA4NjAgMCBSCi9Qcm9wNzcgODYxIDAgUgovUHJvcDc4IDg2MiAwIFIKL1Byb3A3OSA4NjMgMCBSCi9Qcm9wODAgODY0IDAgUgovUHJvcDgxIDg2NSAwIFIKL1Byb3A4MiA4NjYgMCBSCi9Qcm9wODMgODY3IDAgUgovUHJvcDg0IDg2OCAwIFIKL1Byb3A4NSA4NjkgMCBSCi9Qcm9wODYgODcwIDAgUgovUHJvcDg3IDg3MSAwIFIKL1Byb3A4OCA4NzIgMCBSCi9Qcm9wODkgODczIDAgUgovUHJvcDkwIDg3NCAwIFIKL1Byb3A5MSA4NzUgMCBSCi9Qcm9wOTIgODc2IDAgUgovUHJvcDkzIDg3NyAwIFIKL1Byb3A5NCA4NzggMCBSCi9Qcm9wOTUgODc5IDAgUgovUHJvcDk2IDg4MCAwIFIKL1Byb3A5NyA4ODEgMCBSCi9Qcm9wOTggODgyIDAgUgovUHJvcDk5IDg4MyAwIFIKL1Byb3AxMDAgODg0IDAgUgovUHJvcDEwMSA4ODUgMCBSCi9Qcm9wMTAyIDg4NiAwIFIKL1Byb3AxMDMgODg3IDAgUgovUHJvcDEwNCA4ODggMCBSCi9Qcm9wMTA1IDg4OSAwIFIKL1Byb3AxMDYgODkwIDAgUgovUHJvcDEwNyA4OTEgMCBSCi9Qcm9wMTA4IDg5MiAwIFIKL1Byb3AxMDkgODkzIDAgUgovUHJvcDExMCA4OTQgMCBSCi9Qcm9wMTExIDg5NSAwIFIKL1Byb3AxMTIgODk2IDAgUgovUHJvcDExMyA4OTcgMCBSCi9Qcm9wMTE0IDg5OCAwIFIKL1Byb3AxMTUgODk5IDAgUgovUHJvcDExNiA5MDAgMCBSCi9Qcm9wMTE3IDkwMSAwIFIKL1Byb3AxMTggOTAyIDAgUgovUHJvcDExOSA5MDMgMCBSCi9Qcm9wMTIwIDkwNCAwIFIKL1Byb3AxMjEgOTA1IDAgUgovUHJvcDEyMiA5MDYgMCBSCi9Qcm9wMTIzIDkwNyAwIFIKL1Byb3AxMjQgOTA4IDAgUgovUHJvcDEyNSA5MDkgMCBSCi9Qcm9wMTI2IDkxMCAwIFIKL1Byb3AxMjcgOTExIDAgUgovUHJvcDEyOCA5MTIgMCBSCi9Qcm9wMTI5IDkxMyAwIFIKL1Byb3AxMzAgOTE0IDAgUgovUHJvcDEzMSA5MTUgMCBSCi9Qcm9wMTMyIDkxNiAwIFIKL1Byb3AxMzMgOTE3IDAgUgovUHJvcDEzNCA5MTggMCBSCi9Qcm9wMTM1IDkxOSAwIFIKL1Byb3AxMzYgOTIwIDAgUgovUHJvcDEzNyA5MjEgMCBSCi9Qcm9wMTM4IDkyMiAwIFIKL1Byb3AxMzkgOTIzIDAgUgovUHJvcDE0MCA5MjQgMCBSCi9Qcm9wMTQxIDkyNSAwIFIKL1Byb3AxNDIgOTI2IDAgUgovUHJvcDE0MyA5MjcgMCBSCi9Qcm9wMTQ0IDkyOCAwIFIKL1Byb3AxNDUgOTI5IDAgUgovUHJvcDE0NiA5MzAgMCBSCi9Qcm9wMTQ3IDkzMSAwIFIKL1Byb3AxNDggOTMyIDAgUgovUHJvcDE0OSA5MzMgMCBSCi9Qcm9wMTUwIDkzNCAwIFIKL1Byb3AxNTEgOTM1IDAgUgovUHJvcDE1MiA5MzYgMCBSCi9Qcm9wMTUzIDkzNyAwIFIKL1Byb3AxNTQgOTM4IDAgUgovUHJvcDE1NSA5MzkgMCBSCi9Qcm9wMTU2IDk0MCAwIFIKL1Byb3AxNTcgOTQxIDAgUgovUHJvcDE1OCA5NDIgMCBSCi9Qcm9wMTU5IDk0MyAwIFIKL1Byb3AxNjAgOTQ0IDAgUgovUHJvcDE2MSA5NDUgMCBSCi9Qcm9wMTYyIDk0NiAwIFIKL1Byb3AxNjMgOTQ3IDAgUgovUHJvcDE2NCA5NDggMCBSCi9Qcm9wMTY1IDk0OSAwIFIKL1Byb3AxNjYgOTUwIDAgUgovUHJvcDE2NyA5NTEgMCBSCi9Qcm9wMTY4IDk1MiAwIFIKL1Byb3AxNjkgOTUzIDAgUgovUHJvcDE3MCA5NTQgMCBSCi9Qcm9wMTcxIDk1NSAwIFIKPj4KZW5kb2JqCjM2OCAwIG9iago8PAovRjEgNzgyIDAgUgo+PgplbmRvYmoKMzY5IDAgb2JqCjw8Ci9Qcm9wMSA5NTYgMCBSCi9Qcm9wMiA5NTcgMCBSCi9Qcm9wMyA5NTggMCBSCi9Qcm9wNCA5NTkgMCBSCi9Qcm9wNSA5NjAgMCBSCi9Qcm9wNiA5NjEgMCBSCi9Qcm9wNyA5NjIgMCBSCi9Qcm9wOCA5NjMgMCBSCi9Qcm9wOSA5NjQgMCBSCi9Qcm9wMTAgOTY1IDAgUgovUHJvcDExIDk2NiAwIFIKL1Byb3AxMiA5NjcgMCBSCi9Qcm9wMTMgOTY4IDAgUgovUHJvcDE0IDk2OSAwIFIKL1Byb3AxNSA5NzAgMCBSCi9Qcm9wMTYgOTcxIDAgUgovUHJvcDE3IDk3MiAwIFIKL1Byb3AxOCA5NzMgMCBSCi9Qcm9wMTkgOTc0IDAgUgovUHJvcDIwIDk3NSAwIFIKL1Byb3AyMSA5NzYgMCBSCi9Qcm9wMjIgOTc3IDAgUgovUHJvcDIzIDk3OCAwIFIKL1Byb3AyNCA5NzkgMCBSCi9Qcm9wMjUgOTgwIDAgUgovUHJvcDI2IDk4MSAwIFIKL1Byb3AyNyA5ODIgMCBSCi9Qcm9wMjggOTgzIDAgUgovUHJvcDI5IDk4NCAwIFIKL1Byb3AzMCA5ODUgMCBSCi9Qcm9wMzEgOTg2IDAgUgovUHJvcDMyIDk4NyAwIFIKL1Byb3AzMyA5ODggMCBSCi9Qcm9wMzQgOTg5IDAgUgovUHJvcDM1IDk5MCAwIFIKL1Byb3AzNiA5OTEgMCBSCi9Qcm9wMzcgOTkyIDAgUgovUHJvcDM4IDk5MyAwIFIKL1Byb3AzOSA5OTQgMCBSCi9Qcm9wNDAgOTk1IDAgUgovUHJvcDQxIDk5NiAwIFIKL1Byb3A0MiA5OTcgMCBSCi9Qcm9wNDMgOTk4IDAgUgovUHJvcDQ0IDk5OSAwIFIKL1Byb3A0NSAxMDAwIDAgUgovUHJvcDQ2IDEwMDEgMCBSCi9Qcm9wNDcgMTAwMiAwIFIKL1Byb3A0OCAxMDAzIDAgUgovUHJvcDQ5IDEwMDQgMCBSCi9Qcm9wNTAgMTAwNSAwIFIKL1Byb3A1MSAxMDA2IDAgUgovUHJvcDUyIDEwMDcgMCBSCi9Qcm9wNTMgMTAwOCAwIFIKL1Byb3A1NCAxMDA5IDAgUgovUHJvcDU1IDEwMTAgMCBSCi9Qcm9wNTYgMTAxMSAwIFIKL1Byb3A1NyAxMDEyIDAgUgovUHJvcDU4IDEwMTMgMCBSCi9Qcm9wNTkgMTAxNCAwIFIKL1Byb3A2MCAxMDE1IDAgUgovUHJvcDYxIDEwMTYgMCBSCi9Qcm9wNjIgMTAxNyAwIFIKL1Byb3A2MyAxMDE4IDAgUgovUHJvcDY0IDEwMTkgMCBSCi9Qcm9wNjUgMTAyMCAwIFIKL1Byb3A2NiAxMDIxIDAgUgovUHJvcDY3IDEwMjIgMCBSCi9Qcm9wNjggMTAyMyAwIFIKL1Byb3A2OSAxMDI0IDAgUgovUHJvcDcwIDEwMjUgMCBSCi9Qcm9wNzEgMTAyNiAwIFIKL1Byb3A3MiAxMDI3IDAgUgovUHJvcDczIDEwMjggMCBSCi9Qcm9wNzQgMTAyOSAwIFIKL1Byb3A3NSAxMDMwIDAgUgovUHJvcDc2IDEwMzEgMCBSCi9Qcm9wNzcgMTAzMiAwIFIKL1Byb3A3OCAxMDMzIDAgUgovUHJvcDc5IDEwMzQgMCBSCi9Qcm9wODAgMTAzNSAwIFIKL1Byb3A4MSAxMDM2IDAgUgovUHJvcDgyIDEwMzcgMCBSCi9Qcm9wODMgMTAzOCAwIFIKL1Byb3A4NCAxMDM5IDAgUgovUHJvcDg1IDEwNDAgMCBSCi9Qcm9wODYgMTA0MSAwIFIKL1Byb3A4NyAxMDQyIDAgUgovUHJvcDg4IDEwNDMgMCBSCi9Qcm9wODkgMTA0NCAwIFIKL1Byb3A5MCAxMDQ1IDAgUgovUHJvcDkxIDEwNDYgMCBSCi9Qcm9wOTIgMTA0NyAwIFIKL1Byb3A5MyAxMDQ4IDAgUgovUHJvcDk0IDEwNDkgMCBSCi9Qcm9wOTUgMTA1MCAwIFIKL1Byb3A5NiAxMDUxIDAgUgovUHJvcDk3IDEwNTIgMCBSCi9Qcm9wOTggMTA1MyAwIFIKL1Byb3A5OSAxMDU0IDAgUgovUHJvcDEwMCAxMDU1IDAgUgovUHJvcDEwMSAxMDU2IDAgUgovUHJvcDEwMiAxMDU3IDAgUgovUHJvcDEwMyAxMDU4IDAgUgovUHJvcDEwNCAxMDU5IDAgUgovUHJvcDEwNSAxMDYwIDAgUgovUHJvcDEwNiAxMDYxIDAgUgovUHJvcDEwNyAxMDYyIDAgUgovUHJvcDEwOCAxMDYzIDAgUgovUHJvcDEwOSAxMDY0IDAgUgovUHJvcDExMCAxMDY1IDAgUgovUHJvcDExMSAxMDY2IDAgUgovUHJvcDExMiAxMDY3IDAgUgovUHJvcDExMyAxMDY4IDAgUgovUHJvcDExNCAxMDY5IDAgUgovUHJvcDExNSAxMDcwIDAgUgovUHJvcDExNiAxMDcxIDAgUgovUHJvcDExNyAxMDcyIDAgUgovUHJvcDExOCAxMDczIDAgUgovUHJvcDExOSAxMDc0IDAgUgovUHJvcDEyMCAxMDc1IDAgUgovUHJvcDEyMSAxMDc2IDAgUgovUHJvcDEyMiAxMDc3IDAgUgovUHJvcDEyMyAxMDc4IDAgUgovUHJvcDEyNCAxMDc5IDAgUgovUHJvcDEyNSAxMDgwIDAgUgovUHJvcDEyNiAxMDgxIDAgUgovUHJvcDEyNyAxMDgyIDAgUgovUHJvcDEyOCAxMDgzIDAgUgovUHJvcDEyOSAxMDg0IDAgUgovUHJvcDEzMCAxMDg1IDAgUgovUHJvcDEzMSAxMDg2IDAgUgovUHJvcDEzMiAxMDg3IDAgUgovUHJvcDEzMyAxMDg4IDAgUgovUHJvcDEzNCAxMDg5IDAgUgovUHJvcDEzNSAxMDkwIDAgUgovUHJvcDEzNiAxMDkxIDAgUgovUHJvcDEzNyAxMDkyIDAgUgovUHJvcDEzOCAxMDkzIDAgUgovUHJvcDEzOSAxMDk0IDAgUgovUHJvcDE0MCAxMDk1IDAgUgovUHJvcDE0MSAxMDk2IDAgUgovUHJvcDE0MiAxMDk3IDAgUgovUHJvcDE0MyAxMDk4IDAgUgovUHJvcDE0NCAxMDk5IDAgUgovUHJvcDE0NSAxMTAwIDAgUgovUHJvcDE0NiAxMTAxIDAgUgovUHJvcDE0NyAxMTAyIDAgUgovUHJvcDE0OCAxMTAzIDAgUgovUHJvcDE0OSAxMTA0IDAgUgovUHJvcDE1MCAxMTA1IDAgUgovUHJvcDE1MSAxMTA2IDAgUgovUHJvcDE1MiAxMTA3IDAgUgovUHJvcDE1MyAxMTA4IDAgUgovUHJvcDE1NCAxMTA5IDAgUgovUHJvcDE1NSAxMTEwIDAgUgovUHJvcDE1NiAxMTExIDAgUgovUHJvcDE1NyAxMTEyIDAgUgovUHJvcDE1OCAxMTEzIDAgUgovUHJvcDE1OSAxMTE0IDAgUgovUHJvcDE2MCAxMTE1IDAgUgovUHJvcDE2MSAxMTE2IDAgUgovUHJvcDE2MiAxMTE3IDAgUgovUHJvcDE2MyAxMTE4IDAgUgovUHJvcDE2NCAxMTE5IDAgUgovUHJvcDE2NSAxMTIwIDAgUgovUHJvcDE2NiAxMTIxIDAgUgovUHJvcDE2NyAxMTIyIDAgUgovUHJvcDE2OCAxMTIzIDAgUgovUHJvcDE2OSAxMTI0IDAgUgovUHJvcDE3MCAxMTI1IDAgUgovUHJvcDE3MSAxMTI2IDAgUgovUHJvcDE3MiAxMTI3IDAgUgovUHJvcDE3MyAxMTI4IDAgUgovUHJvcDE3NCAxMTI5IDAgUgovUHJvcDE3NSAxMTMwIDAgUgovUHJvcDE3NiAxMTMxIDAgUgovUHJvcDE3NyAxMTMyIDAgUgovUHJvcDE3OCAxMTMzIDAgUgovUHJvcDE3OSAxMTM0IDAgUgovUHJvcDE4MCAxMTM1IDAgUgovUHJvcDE4MSAxMTM2IDAgUgovUHJvcDE4MiAxMTM3IDAgUgovUHJvcDE4MyAxMTM4IDAgUgovUHJvcDE4NCAxMTM5IDAgUgovUHJvcDE4NSAxMTQwIDAgUgovUHJvcDE4NiAxMTQxIDAgUgovUHJvcDE4NyAxMTQyIDAgUgovUHJvcDE4OCAxMTQzIDAgUgovUHJvcDE4OSAxMTQ0IDAgUgovUHJvcDE5MCAxMTQ1IDAgUgovUHJvcDE5MSAxMTQ2IDAgUgovUHJvcDE5MiAxMTQ3IDAgUgovUHJvcDE5MyAxMTQ4IDAgUgovUHJvcDE5NCAxMTQ5IDAgUgo+PgplbmRvYmoKMzcwIDAgb2JqCjw8Ci9GMSA3ODIgMCBSCj4+CmVuZG9iagozNzEgMCBvYmoKPDwKL1Byb3AxIDExNTAgMCBSCi9Qcm9wMiAxMTUxIDAgUgovUHJvcDMgMTE1MiAwIFIKL1Byb3A0IDExNTMgMCBSCi9Qcm9wNSAxMTU0IDAgUgovUHJvcDYgMTE1NSAwIFIKL1Byb3A3IDExNTYgMCBSCi9Qcm9wOCAxMTU3IDAgUgovUHJvcDkgMTE1OCAwIFIKL1Byb3AxMCAxMTU5IDAgUgovUHJvcDExIDExNjAgMCBSCi9Qcm9wMTIgMTE2MSAwIFIKL1Byb3AxMyAxMTYyIDAgUgovUHJvcDE0IDExNjMgMCBSCi9Qcm9wMTUgMTE2NCAwIFIKL1Byb3AxNiAxMTY1IDAgUgovUHJvcDE3IDExNjYgMCBSCi9Qcm9wMTggMTE2NyAwIFIKL1Byb3AxOSAxMTY4IDAgUgovUHJvcDIwIDExNjkgMCBSCi9Qcm9wMjEgMTE3MCAwIFIKL1Byb3AyMiAxMTcxIDAgUgovUHJvcDIzIDExNzIgMCBSCi9Qcm9wMjQgMTE3MyAwIFIKL1Byb3AyNSAxMTc0IDAgUgovUHJvcDI2IDExNzUgMCBSCi9Qcm9wMjcgMTE3NiAwIFIKL1Byb3AyOCAxMTc3IDAgUgovUHJvcDI5IDExNzggMCBSCi9Qcm9wMzAgMTE3OSAwIFIKL1Byb3AzMSAxMTgwIDAgUgovUHJvcDMyIDExODEgMCBSCi9Qcm9wMzMgMTE4MiAwIFIKL1Byb3AzNCAxMTgzIDAgUgovUHJvcDM1IDExODQgMCBSCi9Qcm9wMzYgMTE4NSAwIFIKL1Byb3AzNyAxMTg2IDAgUgovUHJvcDM4IDExODcgMCBSCi9Qcm9wMzkgMTE4OCAwIFIKL1Byb3A0MCAxMTg5IDAgUgovUHJvcDQxIDExOTAgMCBSCi9Qcm9wNDIgMTE5MSAwIFIKL1Byb3A0MyAxMTkyIDAgUgovUHJvcDQ0IDExOTMgMCBSCi9Qcm9wNDUgMTE5NCAwIFIKL1Byb3A0NiAxMTk1IDAgUgovUHJvcDQ3IDExOTYgMCBSCi9Qcm9wNDggMTE5NyAwIFIKL1Byb3A0OSAxMTk4IDAgUgovUHJvcDUwIDExOTkgMCBSCi9Qcm9wNTEgMTIwMCAwIFIKL1Byb3A1MiAxMjAxIDAgUgovUHJvcDUzIDEyMDIgMCBSCi9Qcm9wNTQgMTIwMyAwIFIKL1Byb3A1NSAxMjA0IDAgUgovUHJvcDU2IDEyMDUgMCBSCi9Qcm9wNTcgMTIwNiAwIFIKL1Byb3A1OCAxMjA3IDAgUgovUHJvcDU5IDEyMDggMCBSCi9Qcm9wNjAgMTIwOSAwIFIKL1Byb3A2MSAxMjEwIDAgUgovUHJvcDYyIDEyMTEgMCBSCi9Qcm9wNjMgMTIxMiAwIFIKL1Byb3A2NCAxMjEzIDAgUgovUHJvcDY1IDEyMTQgMCBSCi9Qcm9wNjYgMTIxNSAwIFIKL1Byb3A2NyAxMjE2IDAgUgovUHJvcDY4IDEyMTcgMCBSCi9Qcm9wNjkgMTIxOCAwIFIKL1Byb3A3MCAxMjE5IDAgUgovUHJvcDcxIDEyMjAgMCBSCi9Qcm9wNzIgMTIyMSAwIFIKL1Byb3A3MyAxMjIyIDAgUgovUHJvcDc0IDEyMjMgMCBSCi9Qcm9wNzUgMTIyNCAwIFIKL1Byb3A3NiAxMjI1IDAgUgovUHJvcDc3IDEyMjYgMCBSCi9Qcm9wNzggMTIyNyAwIFIKL1Byb3A3OSAxMjI4IDAgUgovUHJvcDgwIDEyMjkgMCBSCi9Qcm9wODEgMTIzMCAwIFIKL1Byb3A4MiAxMjMxIDAgUgovUHJvcDgzIDEyMzIgMCBSCi9Qcm9wODQgMTIzMyAwIFIKL1Byb3A4NSAxMjM0IDAgUgovUHJvcDg2IDEyMzUgMCBSCi9Qcm9wODcgMTIzNiAwIFIKL1Byb3A4OCAxMjM3IDAgUgovUHJvcDg5IDEyMzggMCBSCi9Qcm9wOTAgMTIzOSAwIFIKL1Byb3A5MSAxMjQwIDAgUgovUHJvcDkyIDEyNDEgMCBSCi9Qcm9wOTMgMTI0MiAwIFIKL1Byb3A5NCAxMjQzIDAgUgovUHJvcDk1IDEyNDQgMCBSCi9Qcm9wOTYgMTI0NSAwIFIKL1Byb3A5NyAxMjQ2IDAgUgovUHJvcDk4IDEyNDcgMCBSCi9Qcm9wOTkgMTI0OCAwIFIKL1Byb3AxMDAgMTI0OSAwIFIKL1Byb3AxMDEgMTI1MCAwIFIKL1Byb3AxMDIgMTI1MSAwIFIKL1Byb3AxMDMgMTI1MiAwIFIKL1Byb3AxMDQgMTI1MyAwIFIKL1Byb3AxMDUgMTI1NCAwIFIKL1Byb3AxMDYgMTI1NSAwIFIKL1Byb3AxMDcgMTI1NiAwIFIKL1Byb3AxMDggMTI1NyAwIFIKL1Byb3AxMDkgMTI1OCAwIFIKL1Byb3AxMTAgMTI1OSAwIFIKL1Byb3AxMTEgMTI2MCAwIFIKL1Byb3AxMTIgMTI2MSAwIFIKL1Byb3AxMTMgMTI2MiAwIFIKL1Byb3AxMTQgMTI2MyAwIFIKL1Byb3AxMTUgMTI2NCAwIFIKL1Byb3AxMTYgMTI2NSAwIFIKL1Byb3AxMTcgMTI2NiAwIFIKL1Byb3AxMTggMTI2NyAwIFIKL1Byb3AxMTkgMTI2OCAwIFIKL1Byb3AxMjAgMTI2OSAwIFIKL1Byb3AxMjEgMTI3MCAwIFIKL1Byb3AxMjIgMTI3MSAwIFIKL1Byb3AxMjMgMTI3MiAwIFIKL1Byb3AxMjQgMTI3MyAwIFIKL1Byb3AxMjUgMTI3NCAwIFIKL1Byb3AxMjYgMTI3NSAwIFIKL1Byb3AxMjcgMTI3NiAwIFIKL1Byb3AxMjggMTI3NyAwIFIKL1Byb3AxMjkgMTI3OCAwIFIKL1Byb3AxMzAgMTI3OSAwIFIKL1Byb3AxMzEgMTI4MCAwIFIKL1Byb3AxMzIgMTI4MSAwIFIKL1Byb3AxMzMgMTI4MiAwIFIKL1Byb3AxMzQgMTI4MyAwIFIKL1Byb3AxMzUgMTI4NCAwIFIKL1Byb3AxMzYgMTI4NSAwIFIKL1Byb3AxMzcgMTI4NiAwIFIKL1Byb3AxMzggMTI4NyAwIFIKL1Byb3AxMzkgMTI4OCAwIFIKL1Byb3AxNDAgMTI4OSAwIFIKL1Byb3AxNDEgMTI5MCAwIFIKL1Byb3AxNDIgMTI5MSAwIFIKL1Byb3AxNDMgMTI5MiAwIFIKL1Byb3AxNDQgMTI5MyAwIFIKL1Byb3AxNDUgMTI5NCAwIFIKL1Byb3AxNDYgMTI5NSAwIFIKL1Byb3AxNDcgMTI5NiAwIFIKL1Byb3AxNDggMTI5NyAwIFIKL1Byb3AxNDkgMTI5OCAwIFIKL1Byb3AxNTAgMTI5OSAwIFIKL1Byb3AxNTEgMTMwMCAwIFIKL1Byb3AxNTIgMTMwMSAwIFIKL1Byb3AxNTMgMTMwMiAwIFIKL1Byb3AxNTQgMTMwMyAwIFIKL1Byb3AxNTUgMTMwNCAwIFIKL1Byb3AxNTYgMTMwNSAwIFIKL1Byb3AxNTcgMTMwNiAwIFIKL1Byb3AxNTggMTMwNyAwIFIKL1Byb3AxNTkgMTMwOCAwIFIKL1Byb3AxNjAgMTMwOSAwIFIKL1Byb3AxNjEgMTMxMCAwIFIKL1Byb3AxNjIgMTMxMSAwIFIKL1Byb3AxNjMgMTMxMiAwIFIKL1Byb3AxNjQgMTMxMyAwIFIKL1Byb3AxNjUgMTMxNCAwIFIKL1Byb3AxNjYgMTMxNSAwIFIKL1Byb3AxNjcgMTMxNiAwIFIKL1Byb3AxNjggMTMxNyAwIFIKL1Byb3AxNjkgMTMxOCAwIFIKL1Byb3AxNzAgMTMxOSAwIFIKL1Byb3AxNzEgMTMyMCAwIFIKL1Byb3AxNzIgMTMyMSAwIFIKL1Byb3AxNzMgMTMyMiAwIFIKL1Byb3AxNzQgMTMyMyAwIFIKL1Byb3AxNzUgMTMyNCAwIFIKL1Byb3AxNzYgMTMyNSAwIFIKL1Byb3AxNzcgMTMyNiAwIFIKL1Byb3AxNzggMTMyNyAwIFIKL1Byb3AxNzkgMTMyOCAwIFIKL1Byb3AxODAgMTMyOSAwIFIKL1Byb3AxODEgMTMzMCAwIFIKL1Byb3AxODIgMTMzMSAwIFIKL1Byb3AxODMgMTMzMiAwIFIKL1Byb3AxODQgMTMzMyAwIFIKL1Byb3AxODUgMTMzNCAwIFIKL1Byb3AxODYgMTMzNSAwIFIKL1Byb3AxODcgMTMzNiAwIFIKL1Byb3AxODggMTMzNyAwIFIKL1Byb3AxODkgMTMzOCAwIFIKL1Byb3AxOTAgMTMzOSAwIFIKL1Byb3AxOTEgMTM0MCAwIFIKL1Byb3AxOTIgMTM0MSAwIFIKL1Byb3AxOTMgMTM0MiAwIFIKL1Byb3AxOTQgMTM0MyAwIFIKL1Byb3AxOTUgMTM0NCAwIFIKL1Byb3AxOTYgMTM0NSAwIFIKL1Byb3AxOTcgMTM0NiAwIFIKL1Byb3AxOTggMTM0NyAwIFIKL1Byb3AxOTkgMTM0OCAwIFIKL1Byb3AyMDAgMTM0OSAwIFIKL1Byb3AyMDEgMTM1MCAwIFIKPj4KZW5kb2JqCjM3MiAwIG9iago8PAovRjEgNzgyIDAgUgo+PgplbmRvYmoKMzczIDAgb2JqCjw8Ci9Qcm9wMSAxMzUxIDAgUgovUHJvcDIgMTM1MiAwIFIKL1Byb3AzIDEzNTMgMCBSCi9Qcm9wNCAxMzU0IDAgUgovUHJvcDUgMTM1NSAwIFIKL1Byb3A2IDEzNTYgMCBSCi9Qcm9wNyAxMzU3IDAgUgovUHJvcDggMTM1OCAwIFIKL1Byb3A5IDEzNTkgMCBSCi9Qcm9wMTAgMTM2MCAwIFIKL1Byb3AxMSAxMzYxIDAgUgovUHJvcDEyIDEzNjIgMCBSCi9Qcm9wMTMgMTM2MyAwIFIKL1Byb3AxNCAxMzY0IDAgUgovUHJvcDE1IDEzNjUgMCBSCi9Qcm9wMTYgMTM2NiAwIFIKL1Byb3AxNyAxMzY3IDAgUgovUHJvcDE4IDEzNjggMCBSCi9Qcm9wMTkgMTM2OSAwIFIKL1Byb3AyMCAxMzcwIDAgUgovUHJvcDIxIDEzNzEgMCBSCi9Qcm9wMjIgMTM3MiAwIFIKL1Byb3AyMyAxMzczIDAgUgovUHJvcDI0IDEzNzQgMCBSCi9Qcm9wMjUgMTM3NSAwIFIKL1Byb3AyNiAxMzc2IDAgUgovUHJvcDI3IDEzNzcgMCBSCi9Qcm9wMjggMTM3OCAwIFIKL1Byb3AyOSAxMzc5IDAgUgovUHJvcDMwIDEzODAgMCBSCi9Qcm9wMzEgMTM4MSAwIFIKL1Byb3AzMiAxMzgyIDAgUgovUHJvcDMzIDEzODMgMCBSCi9Qcm9wMzQgMTM4NCAwIFIKL1Byb3AzNSAxMzg1IDAgUgovUHJvcDM2IDEzODYgMCBSCi9Qcm9wMzcgMTM4NyAwIFIKL1Byb3AzOCAxMzg4IDAgUgovUHJvcDM5IDEzODkgMCBSCi9Qcm9wNDAgMTM5MCAwIFIKL1Byb3A0MSAxMzkxIDAgUgovUHJvcDQyIDEzOTIgMCBSCi9Qcm9wNDMgMTM5MyAwIFIKL1Byb3A0NCAxMzk0IDAgUgovUHJvcDQ1IDEzOTUgMCBSCi9Qcm9wNDYgMTM5NiAwIFIKL1Byb3A0NyAxMzk3IDAgUgovUHJvcDQ4IDEzOTggMCBSCi9Qcm9wNDkgMTM5OSAwIFIKL1Byb3A1MCAxNDAwIDAgUgovUHJvcDUxIDE0MDEgMCBSCi9Qcm9wNTIgMTQwMiAwIFIKL1Byb3A1MyAxNDAzIDAgUgovUHJvcDU0IDE0MDQgMCBSCi9Qcm9wNTUgMTQwNSAwIFIKL1Byb3A1NiAxNDA2IDAgUgovUHJvcDU3IDE0MDcgMCBSCi9Qcm9wNTggMTQwOCAwIFIKL1Byb3A1OSAxNDA5IDAgUgovUHJvcDYwIDE0MTAgMCBSCi9Qcm9wNjEgMTQxMSAwIFIKL1Byb3A2MiAxNDEyIDAgUgovUHJvcDYzIDE0MTMgMCBSCi9Qcm9wNjQgMTQxNCAwIFIKL1Byb3A2NSAxNDE1IDAgUgovUHJvcDY2IDE0MTYgMCBSCi9Qcm9wNjcgMTQxNyAwIFIKL1Byb3A2OCAxNDE4IDAgUgovUHJvcDY5IDE0MTkgMCBSCi9Qcm9wNzAgMTQyMCAwIFIKL1Byb3A3MSAxNDIxIDAgUgovUHJvcDcyIDE0MjIgMCBSCi9Qcm9wNzMgMTQyMyAwIFIKL1Byb3A3NCAxNDI0IDAgUgovUHJvcDc1IDE0MjUgMCBSCi9Qcm9wNzYgMTQyNiAwIFIKL1Byb3A3NyAxNDI3IDAgUgovUHJvcDc4IDE0MjggMCBSCi9Qcm9wNzkgMTQyOSAwIFIKL1Byb3A4MCAxNDMwIDAgUgovUHJvcDgxIDE0MzEgMCBSCi9Qcm9wODIgMTQzMiAwIFIKL1Byb3A4MyAxNDMzIDAgUgovUHJvcDg0IDE0MzQgMCBSCi9Qcm9wODUgMTQzNSAwIFIKL1Byb3A4NiAxNDM2IDAgUgovUHJvcDg3IDE0MzcgMCBSCi9Qcm9wODggMTQzOCAwIFIKL1Byb3A4OSAxNDM5IDAgUgovUHJvcDkwIDE0NDAgMCBSCi9Qcm9wOTEgMTQ0MSAwIFIKL1Byb3A5MiAxNDQyIDAgUgovUHJvcDkzIDE0NDMgMCBSCi9Qcm9wOTQgMTQ0NCAwIFIKL1Byb3A5NSAxNDQ1IDAgUgovUHJvcDk2IDE0NDYgMCBSCi9Qcm9wOTcgMTQ0NyAwIFIKL1Byb3A5OCAxNDQ4IDAgUgovUHJvcDk5IDE0NDkgMCBSCi9Qcm9wMTAwIDE0NTAgMCBSCi9Qcm9wMTAxIDE0NTEgMCBSCi9Qcm9wMTAyIDE0NTIgMCBSCi9Qcm9wMTAzIDE0NTMgMCBSCi9Qcm9wMTA0IDE0NTQgMCBSCi9Qcm9wMTA1IDE0NTUgMCBSCi9Qcm9wMTA2IDE0NTYgMCBSCi9Qcm9wMTA3IDE0NTcgMCBSCi9Qcm9wMTA4IDE0NTggMCBSCi9Qcm9wMTA5IDE0NTkgMCBSCi9Qcm9wMTEwIDE0NjAgMCBSCi9Qcm9wMTExIDE0NjEgMCBSCi9Qcm9wMTEyIDE0NjIgMCBSCi9Qcm9wMTEzIDE0NjMgMCBSCi9Qcm9wMTE0IDE0NjQgMCBSCi9Qcm9wMTE1IDE0NjUgMCBSCi9Qcm9wMTE2IDE0NjYgMCBSCi9Qcm9wMTE3IDE0NjcgMCBSCi9Qcm9wMTE4IDE0NjggMCBSCi9Qcm9wMTE5IDE0NjkgMCBSCi9Qcm9wMTIwIDE0NzAgMCBSCi9Qcm9wMTIxIDE0NzEgMCBSCi9Qcm9wMTIyIDE0NzIgMCBSCi9Qcm9wMTIzIDE0NzMgMCBSCi9Qcm9wMTI0IDE0NzQgMCBSCi9Qcm9wMTI1IDE0NzUgMCBSCi9Qcm9wMTI2IDE0NzYgMCBSCi9Qcm9wMTI3IDE0NzcgMCBSCi9Qcm9wMTI4IDE0NzggMCBSCi9Qcm9wMTI5IDE0NzkgMCBSCi9Qcm9wMTMwIDE0ODAgMCBSCi9Qcm9wMTMxIDE0ODEgMCBSCi9Qcm9wMTMyIDE0ODIgMCBSCi9Qcm9wMTMzIDE0ODMgMCBSCi9Qcm9wMTM0IDE0ODQgMCBSCi9Qcm9wMTM1IDE0ODUgMCBSCi9Qcm9wMTM2IDE0ODYgMCBSCi9Qcm9wMTM3IDE0ODcgMCBSCi9Qcm9wMTM4IDE0ODggMCBSCi9Qcm9wMTM5IDE0ODkgMCBSCi9Qcm9wMTQwIDE0OTAgMCBSCi9Qcm9wMTQxIDE0OTEgMCBSCi9Qcm9wMTQyIDE0OTIgMCBSCi9Qcm9wMTQzIDE0OTMgMCBSCi9Qcm9wMTQ0IDE0OTQgMCBSCi9Qcm9wMTQ1IDE0OTUgMCBSCi9Qcm9wMTQ2IDE0OTYgMCBSCi9Qcm9wMTQ3IDE0OTcgMCBSCi9Qcm9wMTQ4IDE0OTggMCBSCi9Qcm9wMTQ5IDE0OTkgMCBSCi9Qcm9wMTUwIDE1MDAgMCBSCi9Qcm9wMTUxIDE1MDEgMCBSCi9Qcm9wMTUyIDE1MDIgMCBSCi9Qcm9wMTUzIDE1MDMgMCBSCi9Qcm9wMTU0IDE1MDQgMCBSCi9Qcm9wMTU1IDE1MDUgMCBSCi9Qcm9wMTU2IDE1MDYgMCBSCi9Qcm9wMTU3IDE1MDcgMCBSCi9Qcm9wMTU4IDE1MDggMCBSCi9Qcm9wMTU5IDE1MDkgMCBSCi9Qcm9wMTYwIDE1MTAgMCBSCi9Qcm9wMTYxIDE1MTEgMCBSCi9Qcm9wMTYyIDE1MTIgMCBSCi9Qcm9wMTYzIDE1MTMgMCBSCi9Qcm9wMTY0IDE1MTQgMCBSCi9Qcm9wMTY1IDE1MTUgMCBSCi9Qcm9wMTY2IDE1MTYgMCBSCi9Qcm9wMTY3IDE1MTcgMCBSCi9Qcm9wMTY4IDE1MTggMCBSCi9Qcm9wMTY5IDE1MTkgMCBSCi9Qcm9wMTcwIDE1MjAgMCBSCi9Qcm9wMTcxIDE1MjEgMCBSCi9Qcm9wMTcyIDE1MjIgMCBSCi9Qcm9wMTczIDE1MjMgMCBSCi9Qcm9wMTc0IDE1MjQgMCBSCi9Qcm9wMTc1IDE1MjUgMCBSCi9Qcm9wMTc2IDE1MjYgMCBSCi9Qcm9wMTc3IDE1MjcgMCBSCi9Qcm9wMTc4IDE1MjggMCBSCi9Qcm9wMTc5IDE1MjkgMCBSCi9Qcm9wMTgwIDE1MzAgMCBSCi9Qcm9wMTgxIDE1MzEgMCBSCi9Qcm9wMTgyIDE1MzIgMCBSCi9Qcm9wMTgzIDE1MzMgMCBSCi9Qcm9wMTg0IDE1MzQgMCBSCi9Qcm9wMTg1IDE1MzUgMCBSCi9Qcm9wMTg2IDE1MzYgMCBSCi9Qcm9wMTg3IDE1MzcgMCBSCi9Qcm9wMTg4IDE1MzggMCBSCi9Qcm9wMTg5IDE1MzkgMCBSCi9Qcm9wMTkwIDE1NDAgMCBSCi9Qcm9wMTkxIDE1NDEgMCBSCi9Qcm9wMTkyIDE1NDIgMCBSCi9Qcm9wMTkzIDE1NDMgMCBSCi9Qcm9wMTk0IDE1NDQgMCBSCi9Qcm9wMTk1IDE1NDUgMCBSCi9Qcm9wMTk2IDE1NDYgMCBSCi9Qcm9wMTk3IDE1NDcgMCBSCi9Qcm9wMTk4IDE1NDggMCBSCi9Qcm9wMTk5IDE1NDkgMCBSCi9Qcm9wMjAwIDE1NTAgMCBSCj4+CmVuZG9iagozNzQgMCBvYmoKPDwKL0YxIDc4MiAwIFIKPj4KZW5kb2JqCjM3NSAwIG9iago8PAovUHJvcDEgMTU1MSAwIFIKL1Byb3AyIDE1NTIgMCBSCi9Qcm9wMyAxNTUzIDAgUgovUHJvcDQgMTU1NCAwIFIKL1Byb3A1IDE1NTUgMCBSCi9Qcm9wNiAxNTU2IDAgUgovUHJvcDcgMTU1NyAwIFIKL1Byb3A4IDE1NTggMCBSCi9Qcm9wOSAxNTU5IDAgUgovUHJvcDEwIDE1NjAgMCBSCi9Qcm9wMTEgMTU2MSAwIFIKL1Byb3AxMiAxNTYyIDAgUgovUHJvcDEzIDE1NjMgMCBSCi9Qcm9wMTQgMTU2NCAwIFIKL1Byb3AxNSAxNTY1IDAgUgovUHJvcDE2IDE1NjYgMCBSCi9Qcm9wMTcgMTU2NyAwIFIKL1Byb3AxOCAxNTY4IDAgUgovUHJvcDE5IDE1NjkgMCBSCi9Qcm9wMjAgMTU3MCAwIFIKL1Byb3AyMSAxNTcxIDAgUgovUHJvcDIyIDE1NzIgMCBSCi9Qcm9wMjMgMTU3MyAwIFIKL1Byb3AyNCAxNTc0IDAgUgovUHJvcDI1IDE1NzUgMCBSCi9Qcm9wMjYgMTU3NiAwIFIKL1Byb3AyNyAxNTc3IDAgUgovUHJvcDI4IDE1NzggMCBSCi9Qcm9wMjkgMTU3OSAwIFIKL1Byb3AzMCAxNTgwIDAgUgovUHJvcDMxIDE1ODEgMCBSCi9Qcm9wMzIgMTU4MiAwIFIKL1Byb3AzMyAxNTgzIDAgUgovUHJvcDM0IDE1ODQgMCBSCi9Qcm9wMzUgMTU4NSAwIFIKL1Byb3AzNiAxNTg2IDAgUgovUHJvcDM3IDE1ODcgMCBSCi9Qcm9wMzggMTU4OCAwIFIKL1Byb3AzOSAxNTg5IDAgUgovUHJvcDQwIDE1OTAgMCBSCi9Qcm9wNDEgMTU5MSAwIFIKL1Byb3A0MiAxNTkyIDAgUgovUHJvcDQzIDE1OTMgMCBSCi9Qcm9wNDQgMTU5NCAwIFIKL1Byb3A0NSAxNTk1IDAgUgovUHJvcDQ2IDE1OTYgMCBSCi9Qcm9wNDcgMTU5NyAwIFIKL1Byb3A0OCAxNTk4IDAgUgovUHJvcDQ5IDE1OTkgMCBSCi9Qcm9wNTAgMTYwMCAwIFIKL1Byb3A1MSAxNjAxIDAgUgovUHJvcDUyIDE2MDIgMCBSCi9Qcm9wNTMgMTYwMyAwIFIKL1Byb3A1NCAxNjA0IDAgUgovUHJvcDU1IDE2MDUgMCBSCi9Qcm9wNTYgMTYwNiAwIFIKL1Byb3A1NyAxNjA3IDAgUgovUHJvcDU4IDE2MDggMCBSCi9Qcm9wNTkgMTYwOSAwIFIKL1Byb3A2MCAxNjEwIDAgUgovUHJvcDYxIDE2MTEgMCBSCi9Qcm9wNjIgMTYxMiAwIFIKL1Byb3A2MyAxNjEzIDAgUgovUHJvcDY0IDE2MTQgMCBSCi9Qcm9wNjUgMTYxNSAwIFIKL1Byb3A2NiAxNjE2IDAgUgovUHJvcDY3IDE2MTcgMCBSCi9Qcm9wNjggMTYxOCAwIFIKL1Byb3A2OSAxNjE5IDAgUgovUHJvcDcwIDE2MjAgMCBSCi9Qcm9wNzEgMTYyMSAwIFIKL1Byb3A3MiAxNjIyIDAgUgovUHJvcDczIDE2MjMgMCBSCi9Qcm9wNzQgMTYyNCAwIFIKL1Byb3A3NSAxNjI1IDAgUgovUHJvcDc2IDE2MjYgMCBSCi9Qcm9wNzcgMTYyNyAwIFIKL1Byb3A3OCAxNjI4IDAgUgovUHJvcDc5IDE2MjkgMCBSCi9Qcm9wODAgMTYzMCAwIFIKL1Byb3A4MSAxNjMxIDAgUgovUHJvcDgyIDE2MzIgMCBSCi9Qcm9wODMgMTYzMyAwIFIKL1Byb3A4NCAxNjM0IDAgUgovUHJvcDg1IDE2MzUgMCBSCi9Qcm9wODYgMTYzNiAwIFIKL1Byb3A4NyAxNjM3IDAgUgovUHJvcDg4IDE2MzggMCBSCi9Qcm9wODkgMTYzOSAwIFIKL1Byb3A5MCAxNjQwIDAgUgovUHJvcDkxIDE2NDEgMCBSCi9Qcm9wOTIgMTY0MiAwIFIKL1Byb3A5MyAxNjQzIDAgUgovUHJvcDk0IDE2NDQgMCBSCi9Qcm9wOTUgMTY0NSAwIFIKL1Byb3A5NiAxNjQ2IDAgUgovUHJvcDk3IDE2NDcgMCBSCi9Qcm9wOTggMTY0OCAwIFIKL1Byb3A5OSAxNjQ5IDAgUgovUHJvcDEwMCAxNjUwIDAgUgovUHJvcDEwMSAxNjUxIDAgUgovUHJvcDEwMiAxNjUyIDAgUgovUHJvcDEwMyAxNjUzIDAgUgovUHJvcDEwNCAxNjU0IDAgUgovUHJvcDEwNSAxNjU1IDAgUgovUHJvcDEwNiAxNjU2IDAgUgovUHJvcDEwNyAxNjU3IDAgUgovUHJvcDEwOCAxNjU4IDAgUgovUHJvcDEwOSAxNjU5IDAgUgovUHJvcDExMCAxNjYwIDAgUgovUHJvcDExMSAxNjYxIDAgUgovUHJvcDExMiAxNjYyIDAgUgovUHJvcDExMyAxNjYzIDAgUgovUHJvcDExNCAxNjY0IDAgUgovUHJvcDExNSAxNjY1IDAgUgovUHJvcDExNiAxNjY2IDAgUgovUHJvcDExNyAxNjY3IDAgUgovUHJvcDExOCAxNjY4IDAgUgovUHJvcDExOSAxNjY5IDAgUgovUHJvcDEyMCAxNjcwIDAgUgovUHJvcDEyMSAxNjcxIDAgUgovUHJvcDEyMiAxNjcyIDAgUgovUHJvcDEyMyAxNjczIDAgUgovUHJvcDEyNCAxNjc0IDAgUgovUHJvcDEyNSAxNjc1IDAgUgovUHJvcDEyNiAxNjc2IDAgUgovUHJvcDEyNyAxNjc3IDAgUgovUHJvcDEyOCAxNjc4IDAgUgovUHJvcDEyOSAxNjc5IDAgUgovUHJvcDEzMCAxNjgwIDAgUgovUHJvcDEzMSAxNjgxIDAgUgovUHJvcDEzMiAxNjgyIDAgUgovUHJvcDEzMyAxNjgzIDAgUgovUHJvcDEzNCAxNjg0IDAgUgovUHJvcDEzNSAxNjg1IDAgUgovUHJvcDEzNiAxNjg2IDAgUgovUHJvcDEzNyAxNjg3IDAgUgovUHJvcDEzOCAxNjg4IDAgUgovUHJvcDEzOSAxNjg5IDAgUgovUHJvcDE0MCAxNjkwIDAgUgovUHJvcDE0MSAxNjkxIDAgUgovUHJvcDE0MiAxNjkyIDAgUgovUHJvcDE0MyAxNjkzIDAgUgovUHJvcDE0NCAxNjk0IDAgUgovUHJvcDE0NSAxNjk1IDAgUgovUHJvcDE0NiAxNjk2IDAgUgovUHJvcDE0NyAxNjk3IDAgUgovUHJvcDE0OCAxNjk4IDAgUgovUHJvcDE0OSAxNjk5IDAgUgovUHJvcDE1MCAxNzAwIDAgUgovUHJvcDE1MSAxNzAxIDAgUgovUHJvcDE1MiAxNzAyIDAgUgovUHJvcDE1MyAxNzAzIDAgUgovUHJvcDE1NCAxNzA0IDAgUgovUHJvcDE1NSAxNzA1IDAgUgovUHJvcDE1NiAxNzA2IDAgUgovUHJvcDE1NyAxNzA3IDAgUgovUHJvcDE1OCAxNzA4IDAgUgovUHJvcDE1OSAxNzA5IDAgUgovUHJvcDE2MCAxNzEwIDAgUgovUHJvcDE2MSAxNzExIDAgUgovUHJvcDE2MiAxNzEyIDAgUgovUHJvcDE2MyAxNzEzIDAgUgovUHJvcDE2NCAxNzE0IDAgUgovUHJvcDE2NSAxNzE1IDAgUgovUHJvcDE2NiAxNzE2IDAgUgovUHJvcDE2NyAxNzE3IDAgUgovUHJvcDE2OCAxNzE4IDAgUgo+PgplbmRvYmoKMzc2IDAgb2JqCjw8Ci9GMSA3ODIgMCBSCi9GMiA3ODMgMCBSCj4+CmVuZG9iagozNzcgMCBvYmoKPDwKL1Byb3AxIDE3MTkgMCBSCi9Qcm9wMiAxNzIwIDAgUgovUHJvcDMgMTcyMSAwIFIKL1Byb3A0IDE3MjIgMCBSCi9Qcm9wNSAxNzIzIDAgUgovUHJvcDYgMTcyNCAwIFIKL1Byb3A3IDE3MjUgMCBSCi9Qcm9wOCAxNzI2IDAgUgovUHJvcDkgMTcyNyAwIFIKL1Byb3AxMCAxNzI4IDAgUgovUHJvcDExIDE3MjkgMCBSCi9Qcm9wMTIgMTczMCAwIFIKL1Byb3AxMyAxNzMxIDAgUgovUHJvcDE0IDE3MzIgMCBSCi9Qcm9wMTUgMTczMyAwIFIKL1Byb3AxNiAxNzM0IDAgUgovUHJvcDE3IDE3MzUgMCBSCi9Qcm9wMTggMTczNiAwIFIKL1Byb3AxOSAxNzM3IDAgUgovUHJvcDIwIDE3MzggMCBSCi9Qcm9wMjEgMTczOSAwIFIKL1Byb3AyMiAxNzQwIDAgUgovUHJvcDIzIDE3NDEgMCBSCi9Qcm9wMjQgMTc0MiAwIFIKL1Byb3AyNSAxNzQzIDAgUgovUHJvcDI2IDE3NDQgMCBSCi9Qcm9wMjcgMTc0NSAwIFIKL1Byb3AyOCAxNzQ2IDAgUgovUHJvcDI5IDE3NDcgMCBSCi9Qcm9wMzAgMTc0OCAwIFIKL1Byb3AzMSAxNzQ5IDAgUgovUHJvcDMyIDE3NTAgMCBSCi9Qcm9wMzMgMTc1MSAwIFIKL1Byb3AzNCAxNzUyIDAgUgovUHJvcDM1IDE3NTMgMCBSCi9Qcm9wMzYgMTc1NCAwIFIKL1Byb3AzNyAxNzU1IDAgUgovUHJvcDM4IDE3NTYgMCBSCi9Qcm9wMzkgMTc1NyAwIFIKL1Byb3A0MCAxNzU4IDAgUgovUHJvcDQxIDE3NTkgMCBSCi9Qcm9wNDIgMTc2MCAwIFIKL1Byb3A0MyAxNzYxIDAgUgovUHJvcDQ0IDE3NjIgMCBSCi9Qcm9wNDUgMTc2MyAwIFIKL1Byb3A0NiAxNzY0IDAgUgovUHJvcDQ3IDE3NjUgMCBSCi9Qcm9wNDggMTc2NiAwIFIKL1Byb3A0OSAxNzY3IDAgUgovUHJvcDUwIDE3NjggMCBSCi9Qcm9wNTEgMTc2OSAwIFIKL1Byb3A1MiAxNzcwIDAgUgovUHJvcDUzIDE3NzEgMCBSCi9Qcm9wNTQgMTc3MiAwIFIKL1Byb3A1NSAxNzczIDAgUgovUHJvcDU2IDE3NzQgMCBSCi9Qcm9wNTcgMTc3NSAwIFIKL1Byb3A1OCAxNzc2IDAgUgovUHJvcDU5IDE3NzcgMCBSCi9Qcm9wNjAgMTc3OCAwIFIKL1Byb3A2MSAxNzc5IDAgUgovUHJvcDYyIDE3ODAgMCBSCi9Qcm9wNjMgMTc4MSAwIFIKL1Byb3A2NCAxNzgyIDAgUgovUHJvcDY1IDE3ODMgMCBSCi9Qcm9wNjYgMTc4NCAwIFIKL1Byb3A2NyAxNzg1IDAgUgovUHJvcDY4IDE3ODYgMCBSCi9Qcm9wNjkgMTc4NyAwIFIKL1Byb3A3MCAxNzg4IDAgUgovUHJvcDcxIDE3ODkgMCBSCi9Qcm9wNzIgMTc5MCAwIFIKL1Byb3A3MyAxNzkxIDAgUgovUHJvcDc0IDE3OTIgMCBSCi9Qcm9wNzUgMTc5MyAwIFIKL1Byb3A3NiAxNzk0IDAgUgovUHJvcDc3IDE3OTUgMCBSCi9Qcm9wNzggMTc5NiAwIFIKL1Byb3A3OSAxNzk3IDAgUgovUHJvcDgwIDE3OTggMCBSCi9Qcm9wODEgMTc5OSAwIFIKL1Byb3A4MiAxODAwIDAgUgovUHJvcDgzIDE4MDEgMCBSCi9Qcm9wODQgMTgwMiAwIFIKL1Byb3A4NSAxODAzIDAgUgovUHJvcDg2IDE4MDQgMCBSCi9Qcm9wODcgMTgwNSAwIFIKL1Byb3A4OCAxODA2IDAgUgovUHJvcDg5IDE4MDcgMCBSCi9Qcm9wOTAgMTgwOCAwIFIKL1Byb3A5MSAxODA5IDAgUgovUHJvcDkyIDE4MTAgMCBSCi9Qcm9wOTMgMTgxMSAwIFIKL1Byb3A5NCAxODEyIDAgUgovUHJvcDk1IDE4MTMgMCBSCi9Qcm9wOTYgMTgxNCAwIFIKL1Byb3A5NyAxODE1IDAgUgovUHJvcDk4IDE4MTYgMCBSCi9Qcm9wOTkgMTgxNyAwIFIKL1Byb3AxMDAgMTgxOCAwIFIKL1Byb3AxMDEgMTgxOSAwIFIKL1Byb3AxMDIgMTgyMCAwIFIKL1Byb3AxMDMgMTgyMSAwIFIKL1Byb3AxMDQgMTgyMiAwIFIKL1Byb3AxMDUgMTgyMyAwIFIKL1Byb3AxMDYgMTgyNCAwIFIKL1Byb3AxMDcgMTgyNSAwIFIKL1Byb3AxMDggMTgyNiAwIFIKL1Byb3AxMDkgMTgyNyAwIFIKL1Byb3AxMTAgMTgyOCAwIFIKL1Byb3AxMTEgMTgyOSAwIFIKL1Byb3AxMTIgMTgzMCAwIFIKL1Byb3AxMTMgMTgzMSAwIFIKL1Byb3AxMTQgMTgzMiAwIFIKL1Byb3AxMTUgMTgzMyAwIFIKL1Byb3AxMTYgMTgzNCAwIFIKL1Byb3AxMTcgMTgzNSAwIFIKL1Byb3AxMTggMTgzNiAwIFIKL1Byb3AxMTkgMTgzNyAwIFIKL1Byb3AxMjAgMTgzOCAwIFIKL1Byb3AxMjEgMTgzOSAwIFIKL1Byb3AxMjIgMTg0MCAwIFIKL1Byb3AxMjMgMTg0MSAwIFIKL1Byb3AxMjQgMTg0MiAwIFIKL1Byb3AxMjUgMTg0MyAwIFIKL1Byb3AxMjYgMTg0NCAwIFIKL1Byb3AxMjcgMTg0NSAwIFIKL1Byb3AxMjggMTg0NiAwIFIKL1Byb3AxMjkgMTg0NyAwIFIKL1Byb3AxMzAgMTg0OCAwIFIKL1Byb3AxMzEgMTg0OSAwIFIKL1Byb3AxMzIgMTg1MCAwIFIKL1Byb3AxMzMgMTg1MSAwIFIKL1Byb3AxMzQgMTg1MiAwIFIKL1Byb3AxMzUgMTg1MyAwIFIKL1Byb3AxMzYgMTg1NCAwIFIKL1Byb3AxMzcgMTg1NSAwIFIKL1Byb3AxMzggMTg1NiAwIFIKL1Byb3AxMzkgMTg1NyAwIFIKL1Byb3AxNDAgMTg1OCAwIFIKL1Byb3AxNDEgMTg1OSAwIFIKL1Byb3AxNDIgMTg2MCAwIFIKL1Byb3AxNDMgMTg2MSAwIFIKPj4KZW5kb2JqCjM3OCAwIG9iago8PAovRjEgNzgyIDAgUgo+PgplbmRvYmoKMzc5IDAgb2JqCjw8Ci9Qcm9wMSAxODYyIDAgUgovUHJvcDIgMTg2MyAwIFIKL1Byb3AzIDE4NjQgMCBSCi9Qcm9wNCAxODY1IDAgUgovUHJvcDUgMTg2NiAwIFIKL1Byb3A2IDE4NjcgMCBSCi9Qcm9wNyAxODY4IDAgUgovUHJvcDggMTg2OSAwIFIKL1Byb3A5IDE4NzAgMCBSCi9Qcm9wMTAgMTg3MSAwIFIKL1Byb3AxMSAxODcyIDAgUgovUHJvcDEyIDE4NzMgMCBSCi9Qcm9wMTMgMTg3NCAwIFIKL1Byb3AxNCAxODc1IDAgUgovUHJvcDE1IDE4NzYgMCBSCi9Qcm9wMTYgMTg3NyAwIFIKL1Byb3AxNyAxODc4IDAgUgovUHJvcDE4IDE4NzkgMCBSCi9Qcm9wMTkgMTg4MCAwIFIKL1Byb3AyMCAxODgxIDAgUgovUHJvcDIxIDE4ODIgMCBSCi9Qcm9wMjIgMTg4MyAwIFIKL1Byb3AyMyAxODg0IDAgUgovUHJvcDI0IDE4ODUgMCBSCi9Qcm9wMjUgMTg4NiAwIFIKL1Byb3AyNiAxODg3IDAgUgovUHJvcDI3IDE4ODggMCBSCi9Qcm9wMjggMTg4OSAwIFIKL1Byb3AyOSAxODkwIDAgUgovUHJvcDMwIDE4OTEgMCBSCi9Qcm9wMzEgMTg5MiAwIFIKL1Byb3AzMiAxODkzIDAgUgovUHJvcDMzIDE4OTQgMCBSCi9Qcm9wMzQgMTg5NSAwIFIKL1Byb3AzNSAxODk2IDAgUgovUHJvcDM2IDE4OTcgMCBSCi9Qcm9wMzcgMTg5OCAwIFIKL1Byb3AzOCAxODk5IDAgUgovUHJvcDM5IDE5MDAgMCBSCi9Qcm9wNDAgMTkwMSAwIFIKL1Byb3A0MSAxOTAyIDAgUgovUHJvcDQyIDE5MDMgMCBSCi9Qcm9wNDMgMTkwNCAwIFIKL1Byb3A0NCAxOTA1IDAgUgovUHJvcDQ1IDE5MDYgMCBSCi9Qcm9wNDYgMTkwNyAwIFIKL1Byb3A0NyAxOTA4IDAgUgovUHJvcDQ4IDE5MDkgMCBSCi9Qcm9wNDkgMTkxMCAwIFIKL1Byb3A1MCAxOTExIDAgUgovUHJvcDUxIDE5MTIgMCBSCi9Qcm9wNTIgMTkxMyAwIFIKL1Byb3A1MyAxOTE0IDAgUgovUHJvcDU0IDE5MTUgMCBSCi9Qcm9wNTUgMTkxNiAwIFIKL1Byb3A1NiAxOTE3IDAgUgovUHJvcDU3IDE5MTggMCBSCi9Qcm9wNTggMTkxOSAwIFIKL1Byb3A1OSAxOTIwIDAgUgovUHJvcDYwIDE5MjEgMCBSCi9Qcm9wNjEgMTkyMiAwIFIKL1Byb3A2MiAxOTIzIDAgUgovUHJvcDYzIDE5MjQgMCBSCi9Qcm9wNjQgMTkyNSAwIFIKL1Byb3A2NSAxOTI2IDAgUgovUHJvcDY2IDE5MjcgMCBSCi9Qcm9wNjcgMTkyOCAwIFIKL1Byb3A2OCAxOTI5IDAgUgovUHJvcDY5IDE5MzAgMCBSCi9Qcm9wNzAgMTkzMSAwIFIKL1Byb3A3MSAxOTMyIDAgUgovUHJvcDcyIDE5MzMgMCBSCi9Qcm9wNzMgMTkzNCAwIFIKL1Byb3A3NCAxOTM1IDAgUgovUHJvcDc1IDE5MzYgMCBSCi9Qcm9wNzYgMTkzNyAwIFIKL1Byb3A3NyAxOTM4IDAgUgovUHJvcDc4IDE5MzkgMCBSCi9Qcm9wNzkgMTk0MCAwIFIKL1Byb3A4MCAxOTQxIDAgUgovUHJvcDgxIDE5NDIgMCBSCi9Qcm9wODIgMTk0MyAwIFIKL1Byb3A4MyAxOTQ0IDAgUgovUHJvcDg0IDE5NDUgMCBSCi9Qcm9wODUgMTk0NiAwIFIKL1Byb3A4NiAxOTQ3IDAgUgovUHJvcDg3IDE5NDggMCBSCi9Qcm9wODggMTk0OSAwIFIKL1Byb3A4OSAxOTUwIDAgUgovUHJvcDkwIDE5NTEgMCBSCi9Qcm9wOTEgMTk1MiAwIFIKL1Byb3A5MiAxOTUzIDAgUgovUHJvcDkzIDE5NTQgMCBSCi9Qcm9wOTQgMTk1NSAwIFIKL1Byb3A5NSAxOTU2IDAgUgovUHJvcDk2IDE5NTcgMCBSCi9Qcm9wOTcgMTk1OCAwIFIKL1Byb3A5OCAxOTU5IDAgUgovUHJvcDk5IDE5NjAgMCBSCi9Qcm9wMTAwIDE5NjEgMCBSCi9Qcm9wMTAxIDE5NjIgMCBSCi9Qcm9wMTAyIDE5NjMgMCBSCi9Qcm9wMTAzIDE5NjQgMCBSCi9Qcm9wMTA0IDE5NjUgMCBSCi9Qcm9wMTA1IDE5NjYgMCBSCi9Qcm9wMTA2IDE5NjcgMCBSCi9Qcm9wMTA3IDE5NjggMCBSCi9Qcm9wMTA4IDE5NjkgMCBSCi9Qcm9wMTA5IDE5NzAgMCBSCi9Qcm9wMTEwIDE5NzEgMCBSCi9Qcm9wMTExIDE5NzIgMCBSCi9Qcm9wMTEyIDE5NzMgMCBSCi9Qcm9wMTEzIDE5NzQgMCBSCi9Qcm9wMTE0IDE5NzUgMCBSCi9Qcm9wMTE1IDE5NzYgMCBSCi9Qcm9wMTE2IDE5NzcgMCBSCi9Qcm9wMTE3IDE5NzggMCBSCi9Qcm9wMTE4IDE5NzkgMCBSCi9Qcm9wMTE5IDE5ODAgMCBSCi9Qcm9wMTIwIDE5ODEgMCBSCi9Qcm9wMTIxIDE5ODIgMCBSCi9Qcm9wMTIyIDE5ODMgMCBSCi9Qcm9wMTIzIDE5ODQgMCBSCi9Qcm9wMTI0IDE5ODUgMCBSCi9Qcm9wMTI1IDE5ODYgMCBSCi9Qcm9wMTI2IDE5ODcgMCBSCi9Qcm9wMTI3IDE5ODggMCBSCi9Qcm9wMTI4IDE5ODkgMCBSCi9Qcm9wMTI5IDE5OTAgMCBSCi9Qcm9wMTMwIDE5OTEgMCBSCi9Qcm9wMTMxIDE5OTIgMCBSCi9Qcm9wMTMyIDE5OTMgMCBSCi9Qcm9wMTMzIDE5OTQgMCBSCi9Qcm9wMTM0IDE5OTUgMCBSCi9Qcm9wMTM1IDE5OTYgMCBSCi9Qcm9wMTM2IDE5OTcgMCBSCi9Qcm9wMTM3IDE5OTggMCBSCi9Qcm9wMTM4IDE5OTkgMCBSCi9Qcm9wMTM5IDIwMDAgMCBSCi9Qcm9wMTQwIDIwMDEgMCBSCi9Qcm9wMTQxIDIwMDIgMCBSCi9Qcm9wMTQyIDIwMDMgMCBSCi9Qcm9wMTQzIDIwMDQgMCBSCi9Qcm9wMTQ0IDIwMDUgMCBSCi9Qcm9wMTQ1IDIwMDYgMCBSCi9Qcm9wMTQ2IDIwMDcgMCBSCi9Qcm9wMTQ3IDIwMDggMCBSCi9Qcm9wMTQ4IDIwMDkgMCBSCi9Qcm9wMTQ5IDIwMTAgMCBSCi9Qcm9wMTUwIDIwMTEgMCBSCi9Qcm9wMTUxIDIwMTIgMCBSCi9Qcm9wMTUyIDIwMTMgMCBSCi9Qcm9wMTUzIDIwMTQgMCBSCi9Qcm9wMTU0IDIwMTUgMCBSCj4+CmVuZG9iagozODAgMCBvYmoKPDwKL0YxIDc4MiAwIFIKL0YyIDc4MyAwIFIKPj4KZW5kb2JqCjM4MSAwIG9iago8PAovUHJvcDEgMjAxNiAwIFIKL1Byb3AyIDIwMTcgMCBSCi9Qcm9wMyAyMDE4IDAgUgovUHJvcDQgMjAxOSAwIFIKL1Byb3A1IDIwMjAgMCBSCi9Qcm9wNiAyMDIxIDAgUgovUHJvcDcgMjAyMiAwIFIKL1Byb3A4IDIwMjMgMCBSCi9Qcm9wOSAyMDI0IDAgUgovUHJvcDEwIDIwMjUgMCBSCi9Qcm9wMTEgMjAyNiAwIFIKL1Byb3AxMiAyMDI3IDAgUgovUHJvcDEzIDIwMjggMCBSCi9Qcm9wMTQgMjAyOSAwIFIKL1Byb3AxNSAyMDMwIDAgUgovUHJvcDE2IDIwMzEgMCBSCi9Qcm9wMTcgMjAzMiAwIFIKL1Byb3AxOCAyMDMzIDAgUgovUHJvcDE5IDIwMzQgMCBSCi9Qcm9wMjAgMjAzNSAwIFIKL1Byb3AyMSAyMDM2IDAgUgovUHJvcDIyIDIwMzcgMCBSCi9Qcm9wMjMgMjAzOCAwIFIKL1Byb3AyNCAyMDM5IDAgUgovUHJvcDI1IDIwNDAgMCBSCi9Qcm9wMjYgMjA0MSAwIFIKL1Byb3AyNyAyMDQyIDAgUgovUHJvcDI4IDIwNDMgMCBSCi9Qcm9wMjkgMjA0NCAwIFIKL1Byb3AzMCAyMDQ1IDAgUgovUHJvcDMxIDIwNDYgMCBSCi9Qcm9wMzIgMjA0NyAwIFIKL1Byb3AzMyAyMDQ4IDAgUgovUHJvcDM0IDIwNDkgMCBSCi9Qcm9wMzUgMjA1MCAwIFIKL1Byb3AzNiAyMDUxIDAgUgovUHJvcDM3IDIwNTIgMCBSCi9Qcm9wMzggMjA1MyAwIFIKL1Byb3AzOSAyMDU0IDAgUgovUHJvcDQwIDIwNTUgMCBSCi9Qcm9wNDEgMjA1NiAwIFIKL1Byb3A0MiAyMDU3IDAgUgovUHJvcDQzIDIwNTggMCBSCi9Qcm9wNDQgMjA1OSAwIFIKL1Byb3A0NSAyMDYwIDAgUgovUHJvcDQ2IDIwNjEgMCBSCi9Qcm9wNDcgMjA2MiAwIFIKL1Byb3A0OCAyMDYzIDAgUgovUHJvcDQ5IDIwNjQgMCBSCi9Qcm9wNTAgMjA2NSAwIFIKL1Byb3A1MSAyMDY2IDAgUgovUHJvcDUyIDIwNjcgMCBSCi9Qcm9wNTMgMjA2OCAwIFIKL1Byb3A1NCAyMDY5IDAgUgovUHJvcDU1IDIwNzAgMCBSCi9Qcm9wNTYgMjA3MSAwIFIKL1Byb3A1NyAyMDcyIDAgUgovUHJvcDU4IDIwNzMgMCBSCi9Qcm9wNTkgMjA3NCAwIFIKL1Byb3A2MCAyMDc1IDAgUgovUHJvcDYxIDIwNzYgMCBSCi9Qcm9wNjIgMjA3NyAwIFIKL1Byb3A2MyAyMDc4IDAgUgovUHJvcDY0IDIwNzkgMCBSCi9Qcm9wNjUgMjA4MCAwIFIKL1Byb3A2NiAyMDgxIDAgUgovUHJvcDY3IDIwODIgMCBSCi9Qcm9wNjggMjA4MyAwIFIKL1Byb3A2OSAyMDg0IDAgUgovUHJvcDcwIDIwODUgMCBSCi9Qcm9wNzEgMjA4NiAwIFIKL1Byb3A3MiAyMDg3IDAgUgovUHJvcDczIDIwODggMCBSCi9Qcm9wNzQgMjA4OSAwIFIKL1Byb3A3NSAyMDkwIDAgUgovUHJvcDc2IDIwOTEgMCBSCi9Qcm9wNzcgMjA5MiAwIFIKL1Byb3A3OCAyMDkzIDAgUgovUHJvcDc5IDIwOTQgMCBSCi9Qcm9wODAgMjA5NSAwIFIKL1Byb3A4MSAyMDk2IDAgUgovUHJvcDgyIDIwOTcgMCBSCi9Qcm9wODMgMjA5OCAwIFIKL1Byb3A4NCAyMDk5IDAgUgovUHJvcDg1IDIxMDAgMCBSCi9Qcm9wODYgMjEwMSAwIFIKL1Byb3A4NyAyMTAyIDAgUgovUHJvcDg4IDIxMDMgMCBSCi9Qcm9wODkgMjEwNCAwIFIKL1Byb3A5MCAyMTA1IDAgUgovUHJvcDkxIDIxMDYgMCBSCi9Qcm9wOTIgMjEwNyAwIFIKL1Byb3A5MyAyMTA4IDAgUgovUHJvcDk0IDIxMDkgMCBSCi9Qcm9wOTUgMjExMCAwIFIKL1Byb3A5NiAyMTExIDAgUgovUHJvcDk3IDIxMTIgMCBSCi9Qcm9wOTggMjExMyAwIFIKL1Byb3A5OSAyMTE0IDAgUgovUHJvcDEwMCAyMTE1IDAgUgovUHJvcDEwMSAyMTE2IDAgUgovUHJvcDEwMiAyMTE3IDAgUgovUHJvcDEwMyAyMTE4IDAgUgovUHJvcDEwNCAyMTE5IDAgUgovUHJvcDEwNSAyMTIwIDAgUgovUHJvcDEwNiAyMTIxIDAgUgovUHJvcDEwNyAyMTIyIDAgUgovUHJvcDEwOCAyMTIzIDAgUgovUHJvcDEwOSAyMTI0IDAgUgovUHJvcDExMCAyMTI1IDAgUgovUHJvcDExMSAyMTI2IDAgUgovUHJvcDExMiAyMTI3IDAgUgovUHJvcDExMyAyMTI4IDAgUgovUHJvcDExNCAyMTI5IDAgUgovUHJvcDExNSAyMTMwIDAgUgovUHJvcDExNiAyMTMxIDAgUgovUHJvcDExNyAyMTMyIDAgUgovUHJvcDExOCAyMTMzIDAgUgovUHJvcDExOSAyMTM0IDAgUgovUHJvcDEyMCAyMTM1IDAgUgovUHJvcDEyMSAyMTM2IDAgUgovUHJvcDEyMiAyMTM3IDAgUgovUHJvcDEyMyAyMTM4IDAgUgovUHJvcDEyNCAyMTM5IDAgUgovUHJvcDEyNSAyMTQwIDAgUgovUHJvcDEyNiAyMTQxIDAgUgovUHJvcDEyNyAyMTQyIDAgUgovUHJvcDEyOCAyMTQzIDAgUgovUHJvcDEyOSAyMTQ0IDAgUgovUHJvcDEzMCAyMTQ1IDAgUgovUHJvcDEzMSAyMTQ2IDAgUgovUHJvcDEzMiAyMTQ3IDAgUgovUHJvcDEzMyAyMTQ4IDAgUgovUHJvcDEzNCAyMTQ5IDAgUgovUHJvcDEzNSAyMTUwIDAgUgovUHJvcDEzNiAyMTUxIDAgUgovUHJvcDEzNyAyMTUyIDAgUgovUHJvcDEzOCAyMTUzIDAgUgovUHJvcDEzOSAyMTU0IDAgUgovUHJvcDE0MCAyMTU1IDAgUgovUHJvcDE0MSAyMTU2IDAgUgovUHJvcDE0MiAyMTU3IDAgUgovUHJvcDE0MyAyMTU4IDAgUgovUHJvcDE0NCAyMTU5IDAgUgovUHJvcDE0NSAyMTYwIDAgUgovUHJvcDE0NiAyMTYxIDAgUgovUHJvcDE0NyAyMTYyIDAgUgovUHJvcDE0OCAyMTYzIDAgUgovUHJvcDE0OSAyMTY0IDAgUgovUHJvcDE1MCAyMTY1IDAgUgovUHJvcDE1MSAyMTY2IDAgUgovUHJvcDE1MiAyMTY3IDAgUgovUHJvcDE1MyAyMTY4IDAgUgovUHJvcDE1NCAyMTY5IDAgUgovUHJvcDE1NSAyMTcwIDAgUgovUHJvcDE1NiAyMTcxIDAgUgovUHJvcDE1NyAyMTcyIDAgUgovUHJvcDE1OCAyMTczIDAgUgovUHJvcDE1OSAyMTc0IDAgUgovUHJvcDE2MCAyMTc1IDAgUgovUHJvcDE2MSAyMTc2IDAgUgovUHJvcDE2MiAyMTc3IDAgUgovUHJvcDE2MyAyMTc4IDAgUgovUHJvcDE2NCAyMTc5IDAgUgovUHJvcDE2NSAyMTgwIDAgUgovUHJvcDE2NiAyMTgxIDAgUgovUHJvcDE2NyAyMTgyIDAgUgovUHJvcDE2OCAyMTgzIDAgUgovUHJvcDE2OSAyMTg0IDAgUgovUHJvcDE3MCAyMTg1IDAgUgovUHJvcDE3MSAyMTg2IDAgUgovUHJvcDE3MiAyMTg3IDAgUgovUHJvcDE3MyAyMTg4IDAgUgovUHJvcDE3NCAyMTg5IDAgUgovUHJvcDE3NSAyMTkwIDAgUgovUHJvcDE3NiAyMTkxIDAgUgovUHJvcDE3NyAyMTkyIDAgUgovUHJvcDE3OCAyMTkzIDAgUgovUHJvcDE3OSAyMTk0IDAgUgovUHJvcDE4MCAyMTk1IDAgUgovUHJvcDE4MSAyMTk2IDAgUgovUHJvcDE4MiAyMTk3IDAgUgovUHJvcDE4MyAyMTk4IDAgUgovUHJvcDE4NCAyMTk5IDAgUgovUHJvcDE4NSAyMjAwIDAgUgovUHJvcDE4NiAyMjAxIDAgUgovUHJvcDE4NyAyMjAyIDAgUgovUHJvcDE4OCAyMjAzIDAgUgovUHJvcDE4OSAyMjA0IDAgUgovUHJvcDE5MCAyMjA1IDAgUgovUHJvcDE5MSAyMjA2IDAgUgovUHJvcDE5MiAyMjA3IDAgUgovUHJvcDE5MyAyMjA4IDAgUgovUHJvcDE5NCAyMjA5IDAgUgovUHJvcDE5NSAyMjEwIDAgUgovUHJvcDE5NiAyMjExIDAgUgo+PgplbmRvYmoKMzgyIDAgb2JqCjw8Ci9GMSA3ODIgMCBSCi9GMiA3ODMgMCBSCj4+CmVuZG9iagozODMgMCBvYmoKPDwKL1Byb3AxIDIyMTIgMCBSCi9Qcm9wMiAyMjEzIDAgUgovUHJvcDMgMjIxNCAwIFIKL1Byb3A0IDIyMTUgMCBSCi9Qcm9wNSAyMjE2IDAgUgovUHJvcDYgMjIxNyAwIFIKL1Byb3A3IDIyMTggMCBSCi9Qcm9wOCAyMjE5IDAgUgovUHJvcDkgMjIyMCAwIFIKL1Byb3AxMCAyMjIxIDAgUgovUHJvcDExIDIyMjIgMCBSCi9Qcm9wMTIgMjIyMyAwIFIKL1Byb3AxMyAyMjI0IDAgUgovUHJvcDE0IDIyMjUgMCBSCi9Qcm9wMTUgMjIyNiAwIFIKL1Byb3AxNiAyMjI3IDAgUgovUHJvcDE3IDIyMjggMCBSCi9Qcm9wMTggMjIyOSAwIFIKL1Byb3AxOSAyMjMwIDAgUgovUHJvcDIwIDIyMzEgMCBSCi9Qcm9wMjEgMjIzMiAwIFIKL1Byb3AyMiAyMjMzIDAgUgovUHJvcDIzIDIyMzQgMCBSCi9Qcm9wMjQgMjIzNSAwIFIKL1Byb3AyNSAyMjM2IDAgUgovUHJvcDI2IDIyMzcgMCBSCi9Qcm9wMjcgMjIzOCAwIFIKL1Byb3AyOCAyMjM5IDAgUgovUHJvcDI5IDIyNDAgMCBSCi9Qcm9wMzAgMjI0MSAwIFIKL1Byb3AzMSAyMjQyIDAgUgovUHJvcDMyIDIyNDMgMCBSCi9Qcm9wMzMgMjI0NCAwIFIKL1Byb3AzNCAyMjQ1IDAgUgovUHJvcDM1IDIyNDYgMCBSCi9Qcm9wMzYgMjI0NyAwIFIKL1Byb3AzNyAyMjQ4IDAgUgovUHJvcDM4IDIyNDkgMCBSCi9Qcm9wMzkgMjI1MCAwIFIKL1Byb3A0MCAyMjUxIDAgUgovUHJvcDQxIDIyNTIgMCBSCi9Qcm9wNDIgMjI1MyAwIFIKL1Byb3A0MyAyMjU0IDAgUgovUHJvcDQ0IDIyNTUgMCBSCi9Qcm9wNDUgMjI1NiAwIFIKL1Byb3A0NiAyMjU3IDAgUgovUHJvcDQ3IDIyNTggMCBSCi9Qcm9wNDggMjI1OSAwIFIKL1Byb3A0OSAyMjYwIDAgUgovUHJvcDUwIDIyNjEgMCBSCi9Qcm9wNTEgMjI2MiAwIFIKL1Byb3A1MiAyMjYzIDAgUgovUHJvcDUzIDIyNjQgMCBSCi9Qcm9wNTQgMjI2NSAwIFIKL1Byb3A1NSAyMjY2IDAgUgovUHJvcDU2IDIyNjcgMCBSCi9Qcm9wNTcgMjI2OCAwIFIKL1Byb3A1OCAyMjY5IDAgUgovUHJvcDU5IDIyNzAgMCBSCi9Qcm9wNjAgMjI3MSAwIFIKL1Byb3A2MSAyMjcyIDAgUgovUHJvcDYyIDIyNzMgMCBSCi9Qcm9wNjMgMjI3NCAwIFIKL1Byb3A2NCAyMjc1IDAgUgovUHJvcDY1IDIyNzYgMCBSCi9Qcm9wNjYgMjI3NyAwIFIKL1Byb3A2NyAyMjc4IDAgUgovUHJvcDY4IDIyNzkgMCBSCi9Qcm9wNjkgMjI4MCAwIFIKL1Byb3A3MCAyMjgxIDAgUgovUHJvcDcxIDIyODIgMCBSCi9Qcm9wNzIgMjI4MyAwIFIKL1Byb3A3MyAyMjg0IDAgUgovUHJvcDc0IDIyODUgMCBSCi9Qcm9wNzUgMjI4NiAwIFIKL1Byb3A3NiAyMjg3IDAgUgovUHJvcDc3IDIyODggMCBSCi9Qcm9wNzggMjI4OSAwIFIKL1Byb3A3OSAyMjkwIDAgUgovUHJvcDgwIDIyOTEgMCBSCi9Qcm9wODEgMjI5MiAwIFIKL1Byb3A4MiAyMjkzIDAgUgovUHJvcDgzIDIyOTQgMCBSCi9Qcm9wODQgMjI5NSAwIFIKL1Byb3A4NSAyMjk2IDAgUgovUHJvcDg2IDIyOTcgMCBSCi9Qcm9wODcgMjI5OCAwIFIKL1Byb3A4OCAyMjk5IDAgUgovUHJvcDg5IDIzMDAgMCBSCi9Qcm9wOTAgMjMwMSAwIFIKL1Byb3A5MSAyMzAyIDAgUgovUHJvcDkyIDIzMDMgMCBSCi9Qcm9wOTMgMjMwNCAwIFIKL1Byb3A5NCAyMzA1IDAgUgovUHJvcDk1IDIzMDYgMCBSCi9Qcm9wOTYgMjMwNyAwIFIKL1Byb3A5NyAyMzA4IDAgUgovUHJvcDk4IDIzMDkgMCBSCi9Qcm9wOTkgMjMxMCAwIFIKL1Byb3AxMDAgMjMxMSAwIFIKL1Byb3AxMDEgMjMxMiAwIFIKL1Byb3AxMDIgMjMxMyAwIFIKL1Byb3AxMDMgMjMxNCAwIFIKL1Byb3AxMDQgMjMxNSAwIFIKL1Byb3AxMDUgMjMxNiAwIFIKL1Byb3AxMDYgMjMxNyAwIFIKL1Byb3AxMDcgMjMxOCAwIFIKL1Byb3AxMDggMjMxOSAwIFIKL1Byb3AxMDkgMjMyMCAwIFIKL1Byb3AxMTAgMjMyMSAwIFIKL1Byb3AxMTEgMjMyMiAwIFIKL1Byb3AxMTIgMjMyMyAwIFIKL1Byb3AxMTMgMjMyNCAwIFIKL1Byb3AxMTQgMjMyNSAwIFIKL1Byb3AxMTUgMjMyNiAwIFIKL1Byb3AxMTYgMjMyNyAwIFIKL1Byb3AxMTcgMjMyOCAwIFIKL1Byb3AxMTggMjMyOSAwIFIKL1Byb3AxMTkgMjMzMCAwIFIKL1Byb3AxMjAgMjMzMSAwIFIKL1Byb3AxMjEgMjMzMiAwIFIKL1Byb3AxMjIgMjMzMyAwIFIKL1Byb3AxMjMgMjMzNCAwIFIKL1Byb3AxMjQgMjMzNSAwIFIKL1Byb3AxMjUgMjMzNiAwIFIKL1Byb3AxMjYgMjMzNyAwIFIKL1Byb3AxMjcgMjMzOCAwIFIKL1Byb3AxMjggMjMzOSAwIFIKL1Byb3AxMjkgMjM0MCAwIFIKL1Byb3AxMzAgMjM0MSAwIFIKL1Byb3AxMzEgMjM0MiAwIFIKL1Byb3AxMzIgMjM0MyAwIFIKL1Byb3AxMzMgMjM0NCAwIFIKL1Byb3AxMzQgMjM0NSAwIFIKL1Byb3AxMzUgMjM0NiAwIFIKL1Byb3AxMzYgMjM0NyAwIFIKL1Byb3AxMzcgMjM0OCAwIFIKL1Byb3AxMzggMjM0OSAwIFIKL1Byb3AxMzkgMjM1MCAwIFIKL1Byb3AxNDAgMjM1MSAwIFIKL1Byb3AxNDEgMjM1MiAwIFIKL1Byb3AxNDIgMjM1MyAwIFIKL1Byb3AxNDMgMjM1NCAwIFIKL1Byb3AxNDQgMjM1NSAwIFIKL1Byb3AxNDUgMjM1NiAwIFIKL1Byb3AxNDYgMjM1NyAwIFIKL1Byb3AxNDcgMjM1OCAwIFIKL1Byb3AxNDggMjM1OSAwIFIKL1Byb3AxNDkgMjM2MCAwIFIKL1Byb3AxNTAgMjM2MSAwIFIKL1Byb3AxNTEgMjM2MiAwIFIKL1Byb3AxNTIgMjM2MyAwIFIKL1Byb3AxNTMgMjM2NCAwIFIKL1Byb3AxNTQgMjM2NSAwIFIKPj4KZW5kb2JqCjM4NCAwIG9iago8PAovRjEgNzgyIDAgUgovRjIgNzgzIDAgUgo+PgplbmRvYmoKMzg1IDAgb2JqCjw8Ci9Qcm9wMSAyMzY2IDAgUgovUHJvcDIgMjM2NyAwIFIKL1Byb3AzIDIzNjggMCBSCi9Qcm9wNCAyMzY5IDAgUgovUHJvcDUgMjM3MCAwIFIKL1Byb3A2IDIzNzEgMCBSCi9Qcm9wNyAyMzcyIDAgUgovUHJvcDggMjM3MyAwIFIKL1Byb3A5IDIzNzQgMCBSCi9Qcm9wMTAgMjM3NSAwIFIKL1Byb3AxMSAyMzc2IDAgUgovUHJvcDEyIDIzNzcgMCBSCi9Qcm9wMTMgMjM3OCAwIFIKL1Byb3AxNCAyMzc5IDAgUgovUHJvcDE1IDIzODAgMCBSCi9Qcm9wMTYgMjM4MSAwIFIKL1Byb3AxNyAyMzgyIDAgUgovUHJvcDE4IDIzODMgMCBSCi9Qcm9wMTkgMjM4NCAwIFIKL1Byb3AyMCAyMzg1IDAgUgovUHJvcDIxIDIzODYgMCBSCi9Qcm9wMjIgMjM4NyAwIFIKL1Byb3AyMyAyMzg4IDAgUgovUHJvcDI0IDIzODkgMCBSCi9Qcm9wMjUgMjM5MCAwIFIKL1Byb3AyNiAyMzkxIDAgUgovUHJvcDI3IDIzOTIgMCBSCi9Qcm9wMjggMjM5MyAwIFIKL1Byb3AyOSAyMzk0IDAgUgovUHJvcDMwIDIzOTUgMCBSCi9Qcm9wMzEgMjM5NiAwIFIKL1Byb3AzMiAyMzk3IDAgUgovUHJvcDMzIDIzOTggMCBSCi9Qcm9wMzQgMjM5OSAwIFIKL1Byb3AzNSAyNDAwIDAgUgovUHJvcDM2IDI0MDEgMCBSCi9Qcm9wMzcgMjQwMiAwIFIKL1Byb3AzOCAyNDAzIDAgUgovUHJvcDM5IDI0MDQgMCBSCi9Qcm9wNDAgMjQwNSAwIFIKL1Byb3A0MSAyNDA2IDAgUgovUHJvcDQyIDI0MDcgMCBSCi9Qcm9wNDMgMjQwOCAwIFIKL1Byb3A0NCAyNDA5IDAgUgovUHJvcDQ1IDI0MTAgMCBSCi9Qcm9wNDYgMjQxMSAwIFIKL1Byb3A0NyAyNDEyIDAgUgovUHJvcDQ4IDI0MTMgMCBSCi9Qcm9wNDkgMjQxNCAwIFIKL1Byb3A1MCAyNDE1IDAgUgovUHJvcDUxIDI0MTYgMCBSCi9Qcm9wNTIgMjQxNyAwIFIKL1Byb3A1MyAyNDE4IDAgUgovUHJvcDU0IDI0MTkgMCBSCi9Qcm9wNTUgMjQyMCAwIFIKL1Byb3A1NiAyNDIxIDAgUgovUHJvcDU3IDI0MjIgMCBSCi9Qcm9wNTggMjQyMyAwIFIKL1Byb3A1OSAyNDI0IDAgUgovUHJvcDYwIDI0MjUgMCBSCi9Qcm9wNjEgMjQyNiAwIFIKL1Byb3A2MiAyNDI3IDAgUgovUHJvcDYzIDI0MjggMCBSCi9Qcm9wNjQgMjQyOSAwIFIKL1Byb3A2NSAyNDMwIDAgUgovUHJvcDY2IDI0MzEgMCBSCi9Qcm9wNjcgMjQzMiAwIFIKL1Byb3A2OCAyNDMzIDAgUgovUHJvcDY5IDI0MzQgMCBSCi9Qcm9wNzAgMjQzNSAwIFIKL1Byb3A3MSAyNDM2IDAgUgovUHJvcDcyIDI0MzcgMCBSCi9Qcm9wNzMgMjQzOCAwIFIKL1Byb3A3NCAyNDM5IDAgUgovUHJvcDc1IDI0NDAgMCBSCi9Qcm9wNzYgMjQ0MSAwIFIKL1Byb3A3NyAyNDQyIDAgUgovUHJvcDc4IDI0NDMgMCBSCi9Qcm9wNzkgMjQ0NCAwIFIKL1Byb3A4MCAyNDQ1IDAgUgovUHJvcDgxIDI0NDYgMCBSCi9Qcm9wODIgMjQ0NyAwIFIKL1Byb3A4MyAyNDQ4IDAgUgovUHJvcDg0IDI0NDkgMCBSCi9Qcm9wODUgMjQ1MCAwIFIKL1Byb3A4NiAyNDUxIDAgUgovUHJvcDg3IDI0NTIgMCBSCi9Qcm9wODggMjQ1MyAwIFIKL1Byb3A4OSAyNDU0IDAgUgovUHJvcDkwIDI0NTUgMCBSCi9Qcm9wOTEgMjQ1NiAwIFIKL1Byb3A5MiAyNDU3IDAgUgovUHJvcDkzIDI0NTggMCBSCi9Qcm9wOTQgMjQ1OSAwIFIKL1Byb3A5NSAyNDYwIDAgUgovUHJvcDk2IDI0NjEgMCBSCi9Qcm9wOTcgMjQ2MiAwIFIKL1Byb3A5OCAyNDYzIDAgUgovUHJvcDk5IDI0NjQgMCBSCi9Qcm9wMTAwIDI0NjUgMCBSCi9Qcm9wMTAxIDI0NjYgMCBSCi9Qcm9wMTAyIDI0NjcgMCBSCi9Qcm9wMTAzIDI0NjggMCBSCi9Qcm9wMTA0IDI0NjkgMCBSCi9Qcm9wMTA1IDI0NzAgMCBSCj4+CmVuZG9iagozODYgMCBvYmoKPDwKL0YxIDc4MiAwIFIKPj4KZW5kb2JqCjM4NyAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvVGFibGUKL1AgNDYgMCBSCi9QZyA5IDAgUgovSyBbMjQ3MSAwIFIgMjQ3MiAwIFIgMjQ3MyAwIFJdCj4+CmVuZG9iagozODggMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0wKL1AgNDYgMCBSCi9QZyA5IDAgUgovQSAyNDc0IDAgUgovSyAyNDc1IDAgUgo+PgplbmRvYmoKMzg5IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9MCi9QIDQ2IDAgUgovUGcgMTQgMCBSCi9BIDI0NzYgMCBSCi9LIDI0NzcgMCBSCj4+CmVuZG9iagozOTAgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0wKL1AgNDYgMCBSCi9QZyAxNyAwIFIKL0EgMjQ3OCAwIFIKL0sgMjQ3OSAwIFIKPj4KZW5kb2JqCjM5MSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvTAovUCA0NiAwIFIKL1BnIDE3IDAgUgovQSAyNDgwIDAgUgovSyAyNDgxIDAgUgo+PgplbmRvYmoKMzkyIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNDYgMCBSCi9QZyAxNyAwIFIKL0sgWzMxNSAwIFIgNjA3IDAgUl0KPj4KZW5kb2JqCjM5MyAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQ2IDAgUgovUGcgMTggMCBSCi9LIFszMTggMCBSIDYwOCAwIFIgNjA5IDAgUiA2MTAgMCBSIDYxNCAwIFIgNjE4IDAgUiA2MTkgMCBSIDYyMCAwIFIgNjIxIDAgUiA2MjIgMCBSCjYyMyAwIFIgNjI0IDAgUiA2MjkgMCBSIDYzMCAwIFIgNjM0IDAgUiA2MzggMCBSIDYzOSAwIFJdCj4+CmVuZG9iagozOTQgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1RSCi9QIDI0NzIgMCBSCi9QZyA5IDAgUgovSyA0NyAwIFIKPj4KZW5kb2JqCjM5NSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvVFIKL1AgMjQ3MiAwIFIKL1BnIDkgMCBSCi9LIDQ4IDAgUgo+PgplbmRvYmoKMzk2IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9MQm9keQovUCAyNDc1IDAgUgovSyBbNTEgMCBSIDUyIDAgUiAzOTcgMCBSIDI0ODIgMCBSIDQwNCAwIFJdCj4+CmVuZG9iagozOTcgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCAzOTYgMCBSCi9QZyA5IDAgUgovSyA1MyAwIFIKPj4KZW5kb2JqCjM5OCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDI0ODIgMCBSCi9QZyA5IDAgUgovSyA1NSAwIFIKPj4KZW5kb2JqCjM5OSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCA1NSAwIFIKL1BnIDkgMCBSCi9LIFs1NiAwIFIgNTcgMCBSXQo+PgplbmRvYmoKNDAwIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDU1IDAgUgovUGcgOSAwIFIKL0sgWzU4IDAgUiA1OSAwIFJdCj4+CmVuZG9iago0MDEgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCAyNDgyIDAgUgovUGcgOSAwIFIKL0sgWzYwIDAgUiA2MSAwIFJdCj4+CmVuZG9iago0MDIgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCAyNDgyIDAgUgovUGcgOSAwIFIKL0sgWzYyIDAgUiA2MyAwIFJdCj4+CmVuZG9iago0MDMgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCAyNDgyIDAgUgovUGcgOSAwIFIKL0sgWzY0IDAgUiA2NSAwIFJdCj4+CmVuZG9iago0MDQgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCAzOTYgMCBSCi9QZyA5IDAgUgovSyBbNjYgMCBSIDQwNSAwIFIgNDA2IDAgUiA0MTAgMCBSIDQxNSAwIFIgNDE2IDAgUiA0MjAgMCBSIDQyMSAwIFIgNDIyIDAgUiA0MjMgMCBSCjQyNCAwIFIgNDQ4IDAgUiA0NTIgMCBSIDQ1MyAwIFIgNDU0IDAgUiA0NTUgMCBSIDQ1NiAwIFIgNDU3IDAgUiA0NjEgMCBSIDQ2NSAwIFIKNDY5IDAgUiA0NzMgMCBSIDQ3NCAwIFIgNDc1IDAgUiA0NzYgMCBSIDQ4MCAwIFIgNDg0IDAgUiA0ODggMCBSIDQ5MiAwIFIgNDk2IDAgUgo0OTcgMCBSIDUwMSAwIFIgNTA1IDAgUiA1MDYgMCBSIDUwNyAwIFIgNTA4IDAgUiA1MTIgMCBSIDUxNiAwIFIgNTIwIDAgUiA1MjQgMCBSCjUyOCAwIFIgNTMyIDAgUl0KPj4KZW5kb2JqCjQwNSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQwNCAwIFIKL1BnIDkgMCBSCi9LIFs2NyAwIFIgNjggMCBSXQo+PgplbmRvYmoKNDA2IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNDA0IDAgUgovUGcgOSAwIFIKL0sgWzY5IDAgUiA0MDcgMCBSXQo+PgplbmRvYmoKNDA3IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNDA2IDAgUgovUGcgOSAwIFIKL0sgWzcwIDAgUiA3MiAwIFJdCj4+CmVuZG9iago0MDggMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgNzAgMCBSCi9QZyA5IDAgUgovSyA3MSAwIFIKPj4KZW5kb2JqCjQwOSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCA3MiAwIFIKL1BnIDkgMCBSCj4+CmVuZG9iago0MTAgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA0MDQgMCBSCi9QZyA5IDAgUgovSyBbNzMgMCBSIDQxMiAwIFJdCj4+CmVuZG9iago0MTEgMCBvYmoKPDwKL0JCb3ggWzQ1Mi4yNSA3MzUuMzc1IDUyNC4wMjUgNzc4LjEyNV0KL08gL0xheW91dAo+PgplbmRvYmoKNDEyIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNDEwIDAgUgovUGcgMTAgMCBSCi9LIFs3NSAwIFIgNzcgMCBSXQo+PgplbmRvYmoKNDEzIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDc1IDAgUgovUGcgMTAgMCBSCi9LIDc2IDAgUgo+PgplbmRvYmoKNDE0IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDc3IDAgUgovUGcgMTAgMCBSCj4+CmVuZG9iago0MTUgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA0MDQgMCBSCi9QZyAxMCAwIFIKL0sgWzc4IDAgUiA3OSAwIFJdCj4+CmVuZG9iago0MTYgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA0MDQgMCBSCi9QZyAxMCAwIFIKL0sgWzgwIDAgUiA0MTcgMCBSXQo+PgplbmRvYmoKNDE3IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNDE2IDAgUgovUGcgMTAgMCBSCi9LIFs4MSAwIFIgODMgMCBSXQo+PgplbmRvYmoKNDE4IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDgxIDAgUgovUGcgMTAgMCBSCi9LIDgyIDAgUgo+PgplbmRvYmoKNDE5IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDgzIDAgUgovUGcgMTAgMCBSCj4+CmVuZG9iago0MjAgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA0MDQgMCBSCi9QZyAxMCAwIFIKL0sgWzg0IDAgUiA4NSAwIFJdCj4+CmVuZG9iago0MjEgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA0MDQgMCBSCi9QZyAxMCAwIFIKL0sgODYgMCBSCj4+CmVuZG9iago0MjIgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA0MDQgMCBSCi9QZyAxMCAwIFIKL0sgWzg3IDAgUiA4OCAwIFJdCj4+CmVuZG9iago0MjMgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA0MDQgMCBSCi9QZyAxMCAwIFIKL0sgWzg5IDAgUiA5MCAwIFJdCj4+CmVuZG9iago0MjQgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA0MDQgMCBSCi9QZyAxMCAwIFIKL0sgWzkyIDAgUiA5MyAwIFJdCj4+CmVuZG9iago0MjUgMCBvYmoKPDwKL1R5cGUgL01DUgovUGcgMTEgMCBSCi9NQ0lEIDAKPj4KZW5kb2JqCjQyNiAwIG9iago8PAovVHlwZSAvTUNSCi9QZyAxMSAwIFIKL01DSUQgMQo+PgplbmRvYmoKNDI3IDAgb2JqCjw8Ci9UeXBlIC9NQ1IKL1BnIDExIDAgUgovTUNJRCAyCj4+CmVuZG9iago0MjggMCBvYmoKPDwKL1R5cGUgL01DUgovUGcgMTEgMCBSCi9NQ0lEIDMKPj4KZW5kb2JqCjQyOSAwIG9iago8PAovVHlwZSAvTUNSCi9QZyAxMSAwIFIKL01DSUQgNAo+PgplbmRvYmoKNDMwIDAgb2JqCjw8Ci9UeXBlIC9NQ1IKL1BnIDExIDAgUgovTUNJRCA1Cj4+CmVuZG9iago0MzEgMCBvYmoKPDwKL1R5cGUgL01DUgovUGcgMTEgMCBSCi9NQ0lEIDYKPj4KZW5kb2JqCjQzMiAwIG9iago8PAovVHlwZSAvTUNSCi9QZyAxMSAwIFIKL01DSUQgNwo+PgplbmRvYmoKNDMzIDAgb2JqCjw8Ci9UeXBlIC9NQ1IKL1BnIDExIDAgUgovTUNJRCA4Cj4+CmVuZG9iago0MzQgMCBvYmoKPDwKL1R5cGUgL01DUgovUGcgMTEgMCBSCi9NQ0lEIDkKPj4KZW5kb2JqCjQzNSAwIG9iago8PAovVHlwZSAvTUNSCi9QZyAxMSAwIFIKL01DSUQgMTAKPj4KZW5kb2JqCjQzNiAwIG9iago8PAovVHlwZSAvTUNSCi9QZyAxMSAwIFIKL01DSUQgMTEKPj4KZW5kb2JqCjQzNyAwIG9iago8PAovVHlwZSAvTUNSCi9QZyAxMSAwIFIKL01DSUQgMTIKPj4KZW5kb2JqCjQzOCAwIG9iago8PAovVHlwZSAvTUNSCi9QZyAxMSAwIFIKL01DSUQgMTMKPj4KZW5kb2JqCjQzOSAwIG9iago8PAovVHlwZSAvTUNSCi9QZyAxMSAwIFIKL01DSUQgMTQKPj4KZW5kb2JqCjQ0MCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCA5NCAwIFIKL1BnIDEwIDAgUgovSyA5NSAwIFIKPj4KZW5kb2JqCjQ0MSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCA5NiAwIFIKL1BnIDEwIDAgUgo+PgplbmRvYmoKNDQyIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDk3IDAgUgovUGcgMTEgMCBSCi9LIDk4IDAgUgo+PgplbmRvYmoKNDQzIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDk5IDAgUgovUGcgMTEgMCBSCj4+CmVuZG9iago0NDQgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgOTkgMCBSCi9QZyAxMSAwIFIKL0sgMTAwIDAgUgo+PgplbmRvYmoKNDQ1IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDEwMSAwIFIKL1BnIDExIDAgUgo+PgplbmRvYmoKNDQ2IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDEwMSAwIFIKL1BnIDExIDAgUgovSyAxMDIgMCBSCj4+CmVuZG9iago0NDcgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgMTAzIDAgUgovUGcgMTEgMCBSCj4+CmVuZG9iago0NDggMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA0MDQgMCBSCi9QZyAxMSAwIFIKL0sgWzEwNSAwIFIgNDQ5IDAgUl0KPj4KZW5kb2JqCjQ0OSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQ0OCAwIFIKL1BnIDExIDAgUgovSyBbMTA2IDAgUiAxMDggMCBSXQo+PgplbmRvYmoKNDUwIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDEwNiAwIFIKL1BnIDExIDAgUgovSyAxMDcgMCBSCj4+CmVuZG9iago0NTEgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgMTA4IDAgUgovUGcgMTEgMCBSCj4+CmVuZG9iago0NTIgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA0MDQgMCBSCi9QZyAxMSAwIFIKL0sgWzEwOSAwIFIgMTEwIDAgUl0KPj4KZW5kb2JqCjQ1MyAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQwNCAwIFIKL1BnIDExIDAgUgovSyBbMTExIDAgUiAxMTIgMCBSXQo+PgplbmRvYmoKNDU0IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNDA0IDAgUgovUGcgMTEgMCBSCi9LIFsxMTMgMCBSIDExNCAwIFJdCj4+CmVuZG9iago0NTUgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA0MDQgMCBSCi9QZyAxMSAwIFIKL0sgWzExNSAwIFIgMTE2IDAgUl0KPj4KZW5kb2JqCjQ1NiAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQwNCAwIFIKL1BnIDExIDAgUgovSyBbMTE3IDAgUiAxMTggMCBSXQo+PgplbmRvYmoKNDU3IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNDA0IDAgUgovUGcgMTEgMCBSCi9LIFsxMTkgMCBSIDQ1OCAwIFJdCj4+CmVuZG9iago0NTggMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA0NTcgMCBSCi9QZyAxMSAwIFIKL0sgWzEyMCAwIFIgMTIyIDAgUl0KPj4KZW5kb2JqCjQ1OSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCAxMjAgMCBSCi9QZyAxMSAwIFIKL0sgMTIxIDAgUgo+PgplbmRvYmoKNDYwIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDEyMiAwIFIKL1BnIDExIDAgUgo+PgplbmRvYmoKNDYxIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNDA0IDAgUgovUGcgMTIgMCBSCi9LIFsxMjMgMCBSIDQ2MiAwIFJdCj4+CmVuZG9iago0NjIgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA0NjEgMCBSCi9QZyAxMiAwIFIKL0sgWzEyNCAwIFIgMTI2IDAgUl0KPj4KZW5kb2JqCjQ2MyAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCAxMjQgMCBSCi9QZyAxMiAwIFIKL0sgMTI1IDAgUgo+PgplbmRvYmoKNDY0IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDEyNiAwIFIKL1BnIDEyIDAgUgo+PgplbmRvYmoKNDY1IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNDA0IDAgUgovUGcgMTIgMCBSCi9LIFsxMjcgMCBSIDQ2NiAwIFJdCj4+CmVuZG9iago0NjYgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA0NjUgMCBSCi9QZyAxMiAwIFIKL0sgWzEyOCAwIFIgMTMwIDAgUl0KPj4KZW5kb2JqCjQ2NyAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCAxMjggMCBSCi9QZyAxMiAwIFIKL0sgMTI5IDAgUgo+PgplbmRvYmoKNDY4IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDEzMCAwIFIKL1BnIDEyIDAgUgo+PgplbmRvYmoKNDY5IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNDA0IDAgUgovUGcgMTIgMCBSCi9LIFsxMzEgMCBSIDQ3MCAwIFJdCj4+CmVuZG9iago0NzAgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA0NjkgMCBSCi9QZyAxMiAwIFIKL0sgWzEzMiAwIFIgMTM0IDAgUl0KPj4KZW5kb2JqCjQ3MSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCAxMzIgMCBSCi9QZyAxMiAwIFIKL0sgMTMzIDAgUgo+PgplbmRvYmoKNDcyIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDEzNCAwIFIKL1BnIDEyIDAgUgo+PgplbmRvYmoKNDczIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNDA0IDAgUgovUGcgMTIgMCBSCi9LIFsxMzUgMCBSIDEzNiAwIFJdCj4+CmVuZG9iago0NzQgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA0MDQgMCBSCi9QZyAxMiAwIFIKL0sgMTM3IDAgUgo+PgplbmRvYmoKNDc1IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNDA0IDAgUgovUGcgMTIgMCBSCi9LIFsxMzggMCBSIDEzOSAwIFJdCj4+CmVuZG9iago0NzYgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA0MDQgMCBSCi9QZyAxMiAwIFIKL0sgWzE0MSAwIFIgNDc3IDAgUl0KPj4KZW5kb2JqCjQ3NyAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQ3NiAwIFIKL1BnIDEyIDAgUgovSyBbMTQyIDAgUiAxNDQgMCBSXQo+PgplbmRvYmoKNDc4IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDE0MiAwIFIKL1BnIDEyIDAgUgovSyAxNDMgMCBSCj4+CmVuZG9iago0NzkgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgMTQ0IDAgUgovUGcgMTIgMCBSCj4+CmVuZG9iago0ODAgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA0MDQgMCBSCi9QZyAxMiAwIFIKL0sgWzE0NSAwIFIgNDgxIDAgUl0KPj4KZW5kb2JqCjQ4MSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQ4MCAwIFIKL1BnIDEyIDAgUgovSyBbMTQ2IDAgUiAxNDggMCBSXQo+PgplbmRvYmoKNDgyIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDE0NiAwIFIKL1BnIDEyIDAgUgovSyAxNDcgMCBSCj4+CmVuZG9iago0ODMgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgMTQ4IDAgUgovUGcgMTIgMCBSCj4+CmVuZG9iago0ODQgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA0MDQgMCBSCi9QZyAxMiAwIFIKL0sgWzE0OSAwIFIgNDg1IDAgUl0KPj4KZW5kb2JqCjQ4NSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQ4NCAwIFIKL1BnIDEyIDAgUgovSyBbMTUwIDAgUiAxNTIgMCBSXQo+PgplbmRvYmoKNDg2IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDE1MCAwIFIKL1BnIDEyIDAgUgovSyAxNTEgMCBSCj4+CmVuZG9iago0ODcgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgMTUyIDAgUgovUGcgMTIgMCBSCj4+CmVuZG9iago0ODggMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA0MDQgMCBSCi9QZyAxMiAwIFIKL0sgWzE1MyAwIFIgNDg5IDAgUl0KPj4KZW5kb2JqCjQ4OSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQ4OCAwIFIKL1BnIDEyIDAgUgovSyBbMTU0IDAgUiAxNTYgMCBSXQo+PgplbmRvYmoKNDkwIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDE1NCAwIFIKL1BnIDEyIDAgUgovSyAxNTUgMCBSCj4+CmVuZG9iago0OTEgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgMTU2IDAgUgovUGcgMTIgMCBSCj4+CmVuZG9iago0OTIgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA0MDQgMCBSCi9QZyAxMiAwIFIKL0sgWzE1NyAwIFIgNDkzIDAgUl0KPj4KZW5kb2JqCjQ5MyAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQ5MiAwIFIKL1BnIDEyIDAgUgovSyBbMTU4IDAgUiAxNjAgMCBSXQo+PgplbmRvYmoKNDk0IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDE1OCAwIFIKL1BnIDEzIDAgUgovSyAxNTkgMCBSCj4+CmVuZG9iago0OTUgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgMTYwIDAgUgovUGcgMTMgMCBSCj4+CmVuZG9iago0OTYgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA0MDQgMCBSCi9QZyAxMyAwIFIKL0sgWzE2MSAwIFIgMTYyIDAgUl0KPj4KZW5kb2JqCjQ5NyAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQwNCAwIFIKL1BnIDEzIDAgUgovSyBbMTYzIDAgUiA0OTggMCBSXQo+PgplbmRvYmoKNDk4IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNDk3IDAgUgovUGcgMTMgMCBSCi9LIFsxNjQgMCBSIDE2NiAwIFJdCj4+CmVuZG9iago0OTkgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgMTY0IDAgUgovUGcgMTMgMCBSCi9LIDE2NSAwIFIKPj4KZW5kb2JqCjUwMCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCAxNjYgMCBSCi9QZyAxMyAwIFIKPj4KZW5kb2JqCjUwMSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQwNCAwIFIKL1BnIDEzIDAgUgovSyBbMTY3IDAgUiA1MDIgMCBSXQo+PgplbmRvYmoKNTAyIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTAxIDAgUgovUGcgMTMgMCBSCi9LIFsxNjggMCBSIDE3MCAwIFJdCj4+CmVuZG9iago1MDMgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgMTY4IDAgUgovUGcgMTMgMCBSCi9LIDE2OSAwIFIKPj4KZW5kb2JqCjUwNCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCAxNzAgMCBSCi9QZyAxMyAwIFIKPj4KZW5kb2JqCjUwNSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQwNCAwIFIKL1BnIDEzIDAgUgovSyBbMTcxIDAgUiAxNzIgMCBSXQo+PgplbmRvYmoKNTA2IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNDA0IDAgUgovUGcgMTMgMCBSCi9LIFsxNzMgMCBSIDE3NCAwIFJdCj4+CmVuZG9iago1MDcgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA0MDQgMCBSCi9QZyAxMyAwIFIKL0sgWzE3NiAwIFIgMTc3IDAgUl0KPj4KZW5kb2JqCjUwOCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQwNCAwIFIKL1BnIDEzIDAgUgovSyBbMTc5IDAgUiA1MDkgMCBSXQo+PgplbmRvYmoKNTA5IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTA4IDAgUgovUGcgMTMgMCBSCi9LIFsxODAgMCBSIDE4MiAwIFJdCj4+CmVuZG9iago1MTAgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgMTgwIDAgUgovUGcgMTMgMCBSCi9LIDE4MSAwIFIKPj4KZW5kb2JqCjUxMSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCAxODIgMCBSCi9QZyAxMyAwIFIKPj4KZW5kb2JqCjUxMiAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQwNCAwIFIKL1BnIDEzIDAgUgovSyBbMTgzIDAgUiA1MTMgMCBSXQo+PgplbmRvYmoKNTEzIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTEyIDAgUgovUGcgMTMgMCBSCi9LIFsxODQgMCBSIDE4NiAwIFJdCj4+CmVuZG9iago1MTQgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgMTg0IDAgUgovUGcgMTMgMCBSCi9LIDE4NSAwIFIKPj4KZW5kb2JqCjUxNSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCAxODYgMCBSCi9QZyAxMyAwIFIKPj4KZW5kb2JqCjUxNiAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQwNCAwIFIKL1BnIDEzIDAgUgovSyBbMTg3IDAgUiA1MTcgMCBSXQo+PgplbmRvYmoKNTE3IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTE2IDAgUgovUGcgMTMgMCBSCi9LIFsxODggMCBSIDE5MCAwIFJdCj4+CmVuZG9iago1MTggMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgMTg4IDAgUgovUGcgMTMgMCBSCi9LIDE4OSAwIFIKPj4KZW5kb2JqCjUxOSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCAxOTAgMCBSCi9QZyAxMyAwIFIKPj4KZW5kb2JqCjUyMCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQwNCAwIFIKL1BnIDEzIDAgUgovSyBbMTkxIDAgUiA1MjEgMCBSXQo+PgplbmRvYmoKNTIxIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTIwIDAgUgovUGcgMTQgMCBSCi9LIFsxOTIgMCBSIDE5NCAwIFJdCj4+CmVuZG9iago1MjIgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgMTkyIDAgUgovUGcgMTQgMCBSCi9LIDE5MyAwIFIKPj4KZW5kb2JqCjUyMyAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCAxOTQgMCBSCi9QZyAxNCAwIFIKPj4KZW5kb2JqCjUyNCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQwNCAwIFIKL1BnIDE0IDAgUgovSyBbMTk1IDAgUiA1MjUgMCBSXQo+PgplbmRvYmoKNTI1IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTI0IDAgUgovUGcgMTQgMCBSCi9LIFsxOTYgMCBSIDE5OCAwIFJdCj4+CmVuZG9iago1MjYgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgMTk2IDAgUgovUGcgMTQgMCBSCi9LIDE5NyAwIFIKPj4KZW5kb2JqCjUyNyAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCAxOTggMCBSCi9QZyAxNCAwIFIKPj4KZW5kb2JqCjUyOCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQwNCAwIFIKL1BnIDE0IDAgUgovSyBbMTk5IDAgUiA1MjkgMCBSXQo+PgplbmRvYmoKNTI5IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTI4IDAgUgovUGcgMTQgMCBSCi9LIFsyMDAgMCBSIDIwMiAwIFJdCj4+CmVuZG9iago1MzAgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgMjAwIDAgUgovUGcgMTQgMCBSCi9LIDIwMSAwIFIKPj4KZW5kb2JqCjUzMSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCAyMDIgMCBSCi9QZyAxNCAwIFIKPj4KZW5kb2JqCjUzMiAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDQwNCAwIFIKL1BnIDE0IDAgUgovSyBbMjAzIDAgUiA1MzMgMCBSXQo+PgplbmRvYmoKNTMzIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTMyIDAgUgovUGcgMTQgMCBSCi9LIFsyMDQgMCBSIDIwNiAwIFJdCj4+CmVuZG9iago1MzQgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgMjA0IDAgUgovUGcgMTQgMCBSCi9LIDIwNSAwIFIKPj4KZW5kb2JqCjUzNSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCAyMDYgMCBSCi9QZyAxNCAwIFIKPj4KZW5kb2JqCjUzNiAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvTEJvZHkKL1AgMjQ3NyAwIFIKL0sgWzIwNyAwIFIgMjA4IDAgUiAyNDgzIDAgUiA1NDQgMCBSXQo+PgplbmRvYmoKNTM3IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgMjQ4MyAwIFIKL1BnIDE0IDAgUgovSyAyMDkgMCBSCj4+CmVuZG9iago1MzggMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgMjA5IDAgUgovUGcgMTQgMCBSCi9LIFsyMTAgMCBSIDIxMSAwIFJdCj4+CmVuZG9iago1MzkgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgMjA5IDAgUgovUGcgMTQgMCBSCi9LIFsyMTIgMCBSIDIxMyAwIFJdCj4+CmVuZG9iago1NDAgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCAyNDgzIDAgUgovUGcgMTQgMCBSCi9LIFsyMTQgMCBSIDIxNSAwIFJdCj4+CmVuZG9iago1NDEgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCAyNDgzIDAgUgovUGcgMTQgMCBSCi9LIDIxNiAwIFIKPj4KZW5kb2JqCjU0MiAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDI0ODMgMCBSCi9QZyAxNCAwIFIKL0sgMjE3IDAgUgo+PgplbmRvYmoKNTQzIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgMjQ4MyAwIFIKL1BnIDE0IDAgUgovSyAyMTggMCBSCj4+CmVuZG9iago1NDQgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1MzYgMCBSCi9QZyAxNCAwIFIKL0sgWzIxOSAwIFIgNTQ1IDAgUiA1NDYgMCBSIDU0OCAwIFIgNTQ5IDAgUiA1NTAgMCBSIDU1MSAwIFIgNTUyIDAgUiA1NTMgMCBSIDU1NCAwIFIKNTU1IDAgUiA1NTYgMCBSIDU1NyAwIFIgNTU4IDAgUiA1NTkgMCBSIDU2MCAwIFIgNTYxIDAgUiA1NjIgMCBSIDU2NyAwIFIgNTY4IDAgUgo1NjkgMCBSIDU3MCAwIFIgNTcxIDAgUiA1NzIgMCBSIDU3MyAwIFIgNTc0IDAgUiA1NzUgMCBSIDU3OSAwIFIgNTgwIDAgUl0KPj4KZW5kb2JqCjU0NSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDU0NCAwIFIKL1BnIDE0IDAgUgovSyBbMjIwIDAgUiAyMjEgMCBSXQo+PgplbmRvYmoKNTQ2IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTQ0IDAgUgovUGcgMTQgMCBSCi9LIFsyMjIgMCBSIDIyMyAwIFJdCj4+CmVuZG9iago1NDcgMCBvYmoKPDwKL1R5cGUgL01DUgovUGcgMTUgMCBSCi9NQ0lEIDAKPj4KZW5kb2JqCjU0OCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDU0NCAwIFIKL1BnIDE1IDAgUgovSyBbMjI0IDAgUiAyMjUgMCBSXQo+PgplbmRvYmoKNTQ5IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTQ0IDAgUgovUGcgMTUgMCBSCi9LIFsyMjYgMCBSIDIyNyAwIFJdCj4+CmVuZG9iago1NTAgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1NDQgMCBSCi9QZyAxNSAwIFIKL0sgWzIyOCAwIFIgMjI5IDAgUl0KPj4KZW5kb2JqCjU1MSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDU0NCAwIFIKL1BnIDE1IDAgUgovSyBbMjMwIDAgUiAyMzEgMCBSXQo+PgplbmRvYmoKNTUyIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTQ0IDAgUgovUGcgMTUgMCBSCi9LIFsyMzIgMCBSIDIzMyAwIFJdCj4+CmVuZG9iago1NTMgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1NDQgMCBSCi9QZyAxNSAwIFIKL0sgWzIzNCAwIFIgMjM1IDAgUl0KPj4KZW5kb2JqCjU1NCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDU0NCAwIFIKL1BnIDE1IDAgUgovSyBbMjM2IDAgUiAyMzcgMCBSXQo+PgplbmRvYmoKNTU1IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTQ0IDAgUgovUGcgMTUgMCBSCi9LIFsyMzggMCBSIDIzOSAwIFJdCj4+CmVuZG9iago1NTYgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1NDQgMCBSCi9QZyAxNSAwIFIKL0sgWzI0MCAwIFIgMjQxIDAgUl0KPj4KZW5kb2JqCjU1NyAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDU0NCAwIFIKL1BnIDE1IDAgUgovSyBbMjQyIDAgUiAyNDMgMCBSXQo+PgplbmRvYmoKNTU4IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTQ0IDAgUgovUGcgMTUgMCBSCi9LIFsyNDQgMCBSIDI0NSAwIFJdCj4+CmVuZG9iago1NTkgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1NDQgMCBSCi9QZyAxNSAwIFIKL0sgWzI0NiAwIFIgMjQ3IDAgUl0KPj4KZW5kb2JqCjU2MCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDU0NCAwIFIKL1BnIDE1IDAgUgovSyBbMjQ4IDAgUiAyNDkgMCBSXQo+PgplbmRvYmoKNTYxIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTQ0IDAgUgovUGcgMTUgMCBSCi9LIFsyNTAgMCBSIDI1MSAwIFJdCj4+CmVuZG9iago1NjIgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1NDQgMCBSCi9QZyAxNSAwIFIKL0sgWzI1MiAwIFIgNTY0IDAgUl0KPj4KZW5kb2JqCjU2MyAwIG9iago8PAovVHlwZSAvTUNSCi9QZyAxNiAwIFIKL01DSUQgMAo+PgplbmRvYmoKNTY0IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTYyIDAgUgovUGcgMTYgMCBSCi9LIFsyNTMgMCBSIDI1NSAwIFJdCj4+CmVuZG9iago1NjUgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgMjUzIDAgUgovUGcgMTYgMCBSCi9LIDI1NCAwIFIKPj4KZW5kb2JqCjU2NiAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCAyNTUgMCBSCi9QZyAxNiAwIFIKPj4KZW5kb2JqCjU2NyAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDU0NCAwIFIKL1BnIDE2IDAgUgovSyBbMjU2IDAgUiAyNTcgMCBSXQo+PgplbmRvYmoKNTY4IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTQ0IDAgUgovUGcgMTYgMCBSCi9LIFsyNTggMCBSIDI1OSAwIFJdCj4+CmVuZG9iago1NjkgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1NDQgMCBSCi9QZyAxNiAwIFIKL0sgWzI2MCAwIFIgMjYxIDAgUl0KPj4KZW5kb2JqCjU3MCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDU0NCAwIFIKL1BnIDE2IDAgUgovSyBbMjYyIDAgUiAyNjMgMCBSXQo+PgplbmRvYmoKNTcxIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTQ0IDAgUgovUGcgMTYgMCBSCi9LIFsyNjQgMCBSIDI2NSAwIFJdCj4+CmVuZG9iago1NzIgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1NDQgMCBSCi9QZyAxNiAwIFIKL0sgWzI2NyAwIFIgMjY4IDAgUl0KPj4KZW5kb2JqCjU3MyAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDU0NCAwIFIKL1BnIDE2IDAgUgovSyBbMjY5IDAgUiAyNzAgMCBSXQo+PgplbmRvYmoKNTc0IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTQ0IDAgUgovUGcgMTYgMCBSCi9LIFsyNzEgMCBSIDI3MiAwIFJdCj4+CmVuZG9iago1NzUgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1NDQgMCBSCi9QZyAxNiAwIFIKL0sgWzI3MyAwIFIgNTc2IDAgUl0KPj4KZW5kb2JqCjU3NiAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDU3NSAwIFIKL1BnIDE2IDAgUgovSyBbMjc0IDAgUiAyNzYgMCBSXQo+PgplbmRvYmoKNTc3IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDI3NCAwIFIKL1BnIDE2IDAgUgovSyAyNzUgMCBSCj4+CmVuZG9iago1NzggMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgMjc2IDAgUgovUGcgMTYgMCBSCj4+CmVuZG9iago1NzkgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1NDQgMCBSCi9QZyAxNiAwIFIKL0sgWzI3NyAwIFIgMjc4IDAgUl0KPj4KZW5kb2JqCjU4MCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDU0NCAwIFIKL1BnIDE2IDAgUgovSyBbMjc5IDAgUiAyODAgMCBSXQo+PgplbmRvYmoKNTgxIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9MQm9keQovUCAyNDc5IDAgUgovSyBbMjgyIDAgUiAyODMgMCBSIDI0ODQgMCBSXQo+PgplbmRvYmoKNTgyIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgMjQ4NCAwIFIKL1BnIDE3IDAgUgovSyAyODQgMCBSCj4+CmVuZG9iago1ODMgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgMjg0IDAgUgovUGcgMTcgMCBSCi9LIFsyODUgMCBSIDI4NiAwIFJdCj4+CmVuZG9iago1ODQgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgMjg0IDAgUgovUGcgMTcgMCBSCi9LIFsyODcgMCBSIDI4OCAwIFJdCj4+CmVuZG9iago1ODUgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCAyNDg0IDAgUgovUGcgMTcgMCBSCi9LIFsyODkgMCBSIDU4NiAwIFJdCj4+CmVuZG9iago1ODYgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1ODUgMCBSCi9QZyAxNyAwIFIKL0sgWzI5MCAwIFIgMjkyIDAgUiAyOTQgMCBSXQo+PgplbmRvYmoKNTg3IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDI5MCAwIFIKL1BnIDE3IDAgUgovSyAyOTEgMCBSCj4+CmVuZG9iago1ODggMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgMjkyIDAgUgovUGcgMTcgMCBSCj4+CmVuZG9iago1ODkgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgMjkyIDAgUgovUGcgMTcgMCBSCi9LIDI5MyAwIFIKPj4KZW5kb2JqCjU5MCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCAyOTQgMCBSCi9QZyAxNyAwIFIKPj4KZW5kb2JqCjU5MSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvTEJvZHkKL1AgMjQ4MSAwIFIKL0sgWzI5NSAwIFIgMjk2IDAgUiAyNDg1IDAgUl0KPj4KZW5kb2JqCjU5MiAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDI0ODUgMCBSCi9QZyAxNyAwIFIKL0sgMjk3IDAgUgo+PgplbmRvYmoKNTkzIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDI5NyAwIFIKL1BnIDE3IDAgUgovSyBbMjk4IDAgUiAyOTkgMCBSXQo+PgplbmRvYmoKNTk0IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDI5NyAwIFIKL1BnIDE3IDAgUgovSyBbMzAwIDAgUiAzMDEgMCBSXQo+PgplbmRvYmoKNTk1IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgMjQ4NSAwIFIKL1BnIDE3IDAgUgovSyBbMzAyIDAgUiA1OTYgMCBSXQo+PgplbmRvYmoKNTk2IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNTk1IDAgUgovUGcgMTcgMCBSCi9LIFszMDMgMCBSIDMwNSAwIFIgMzA3IDAgUiAzMDkgMCBSIDMxMSAwIFIgMzEzIDAgUl0KPj4KZW5kb2JqCjU5NyAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCAzMDMgMCBSCi9QZyAxNyAwIFIKL0sgMzA0IDAgUgo+PgplbmRvYmoKNTk4IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDMwNSAwIFIKL1BnIDE3IDAgUgo+PgplbmRvYmoKNTk5IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDMwNSAwIFIKL1BnIDE3IDAgUgovSyAzMDYgMCBSCj4+CmVuZG9iago2MDAgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgMzA3IDAgUgovUGcgMTcgMCBSCj4+CmVuZG9iago2MDEgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgMzA3IDAgUgovUGcgMTcgMCBSCi9LIDMwOCAwIFIKPj4KZW5kb2JqCjYwMiAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCAzMDkgMCBSCi9QZyAxNyAwIFIKPj4KZW5kb2JqCjYwMyAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCAzMDkgMCBSCi9QZyAxNyAwIFIKL0sgMzEwIDAgUgo+PgplbmRvYmoKNjA0IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDMxMSAwIFIKL1BnIDE3IDAgUgo+PgplbmRvYmoKNjA1IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDMxMSAwIFIKL1BnIDE3IDAgUgovSyAzMTIgMCBSCj4+CmVuZG9iago2MDYgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgMzEzIDAgUgovUGcgMTcgMCBSCj4+CmVuZG9iago2MDcgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCAzOTIgMCBSCi9QZyAxOCAwIFIKL0sgWzMxNiAwIFIgMzE3IDAgUl0KPj4KZW5kb2JqCjYwOCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDM5MyAwIFIKL1BnIDE4IDAgUgovSyBbMzE5IDAgUiAzMjAgMCBSXQo+PgplbmRvYmoKNjA5IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgMzkzIDAgUgovUGcgMTggMCBSCi9LIFszMjEgMCBSIDMyMiAwIFJdCj4+CmVuZG9iago2MTAgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCAzOTMgMCBSCi9QZyAxOCAwIFIKL0sgWzMyMyAwIFIgNjExIDAgUl0KPj4KZW5kb2JqCjYxMSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDYxMCAwIFIKL1BnIDE4IDAgUgovSyBbMzI0IDAgUiAzMjYgMCBSXQo+PgplbmRvYmoKNjEyIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDMyNCAwIFIKL1BnIDE4IDAgUgovSyAzMjUgMCBSCj4+CmVuZG9iago2MTMgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgMzI2IDAgUgovUGcgMTggMCBSCj4+CmVuZG9iago2MTQgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCAzOTMgMCBSCi9QZyAxOCAwIFIKL0sgWzMyNyAwIFIgNjE1IDAgUl0KPj4KZW5kb2JqCjYxNSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDYxNCAwIFIKL1BnIDE4IDAgUgovSyBbMzI4IDAgUiAzMzAgMCBSXQo+PgplbmRvYmoKNjE2IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDMyOCAwIFIKL1BnIDE4IDAgUgovSyAzMjkgMCBSCj4+CmVuZG9iago2MTcgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgMzMwIDAgUgovUGcgMTggMCBSCj4+CmVuZG9iago2MTggMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCAzOTMgMCBSCi9QZyAxOCAwIFIKL0sgWzMzMSAwIFIgMzMyIDAgUl0KPj4KZW5kb2JqCjYxOSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDM5MyAwIFIKL1BnIDE4IDAgUgovSyBbMzM0IDAgUiAzMzUgMCBSXQo+PgplbmRvYmoKNjIwIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgMzkzIDAgUgovUGcgMTggMCBSCi9LIFszMzYgMCBSIDMzNyAwIFJdCj4+CmVuZG9iago2MjEgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCAzOTMgMCBSCi9QZyAxOCAwIFIKL0sgWzMzOCAwIFIgMzM5IDAgUl0KPj4KZW5kb2JqCjYyMiAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDM5MyAwIFIKL1BnIDE4IDAgUgovSyBbMzQwIDAgUiAzNDEgMCBSXQo+PgplbmRvYmoKNjIzIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgMzkzIDAgUgovUGcgMTggMCBSCi9LIFszNDIgMCBSIDM0MyAwIFJdCj4+CmVuZG9iago2MjQgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCAzOTMgMCBSCi9QZyAxOCAwIFIKL0sgWzM0NSAwIFIgNjI2IDAgUl0KPj4KZW5kb2JqCjYyNSAwIG9iago8PAovVHlwZSAvTUNSCi9QZyAxOSAwIFIKL01DSUQgMAo+PgplbmRvYmoKNjI2IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgNjI0IDAgUgovUGcgMTkgMCBSCi9LIFszNDYgMCBSIDM0OCAwIFJdCj4+CmVuZG9iago2MjcgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1NwYW4KL1AgMzQ2IDAgUgovUGcgMTkgMCBSCi9LIDM0NyAwIFIKPj4KZW5kb2JqCjYyOCAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCAzNDggMCBSCi9QZyAxOSAwIFIKPj4KZW5kb2JqCjYyOSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvRGl2Ci9QIDM5MyAwIFIKL1BnIDE5IDAgUgovSyBbMzQ5IDAgUiAzNTAgMCBSXQo+PgplbmRvYmoKNjMwIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgMzkzIDAgUgovUGcgMTkgMCBSCi9LIFszNTEgMCBSIDYzMSAwIFJdCj4+CmVuZG9iago2MzEgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA2MzAgMCBSCi9QZyAxOSAwIFIKL0sgWzM1MiAwIFIgMzU0IDAgUl0KPj4KZW5kb2JqCjYzMiAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCAzNTIgMCBSCi9QZyAxOSAwIFIKL0sgMzUzIDAgUgo+PgplbmRvYmoKNjMzIDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDM1NCAwIFIKL1BnIDE5IDAgUgo+PgplbmRvYmoKNjM0IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgMzkzIDAgUgovUGcgMTkgMCBSCi9LIFszNTUgMCBSIDYzNSAwIFJdCj4+CmVuZG9iago2MzUgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA2MzQgMCBSCi9QZyAxOSAwIFIKL0sgWzM1NiAwIFIgMzU4IDAgUl0KPj4KZW5kb2JqCjYzNiAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvU3BhbgovUCAzNTYgMCBSCi9QZyAxOSAwIFIKL0sgMzU3IDAgUgo+PgplbmRvYmoKNjM3IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9TcGFuCi9QIDM1OCAwIFIKL1BnIDE5IDAgUgo+PgplbmRvYmoKNjM4IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9EaXYKL1AgMzkzIDAgUgovUGcgMTkgMCBSCi9LIFszNTkgMCBSIDM2MCAwIFJdCj4+CmVuZG9iago2MzkgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCAzOTMgMCBSCi9QZyAxOSAwIFIKL0sgWzM2MSAwIFIgMzYyIDAgUl0KPj4KZW5kb2JqCjY0MCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbNzEuMjUgNTcuNzUgNTI0LjAyNSA3ODQuMTI1XQo+PgplbmRvYmoKNjQxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs3MS4yNSA1Ny43NSA1MjQuMDI1IDc4NC4xMjVdCj4+CmVuZG9iago2NDIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzc3LjI1IDU3Ljc1IDUxOC4wMjUgNzc4LjEyNV0KPj4KZW5kb2JqCjY0MyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbNzcuMjUgNzAwLjU3NSAxNzcuNDg3NSA3MzUuMzc1XQo+PgplbmRvYmoKNjQ0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs3Ny4yNSA3MDIuMDc1IDE3Ny40ODc1IDczNS4zNzVdCj4+CmVuZG9iago2NDUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzc3LjI1IDcxOC43MjUgMTc3LjQ4NzUgNzMzLjg3NV0KPj4KZW5kb2JqCjY0NiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbNzguNzUgNzE4LjcyNSAxNzUuOTg3NSA3MzMuODc1XQo+PgplbmRvYmoKNjQ3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs3Ny4yNSA3MDIuMDc1IDE3Ny40ODc1IDcxNy4yMjUwNF0KPj4KZW5kb2JqCjY0OCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbNzguNzUgNzAyLjA3NSAxNzUuOTg3NSA3MTcuMjI1MDRdCj4+CmVuZG9iago2NDkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzc3LjI1IDY1Ni44NSA1MTguMDI1IDY4Ny4xNDk5Nl0KPj4KZW5kb2JqCjY1MCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbNzcuMjUgNjA2LjkzNzUgNTE4LjAyNSA2MzYuOTM3NV0KPj4KZW5kb2JqCjY1MSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbNzcuMjUgNTcuNzUgNTE4LjAyNSA1OTMuNTEyNV0KPj4KZW5kb2JqCjY1MiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1Ny43NSA0OTkuMjc1MDIgNTc0Ljc2MjVdCj4+CmVuZG9iago2NTMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTU5Ljc2MjQ1IDQ5OS4yNzUwMiA1NzQuNzYyNDVdCj4+CmVuZG9iago2NTQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTIyLjI2MjQ1IDQ5OS4yNzUwMiA1NDYuMjYyNDVdCj4+CmVuZG9iago2NTUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDY3Ljk2MjUgNDk5LjI3NTAyIDUwOC43NjI0OF0KPj4KZW5kb2JqCjY1NiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyOTAuNTEyNSA0OTkuMjc1MDIgNDU1Ljk2MjUyXQo+PgplbmRvYmoKNjU3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQxMy45NjI1IDQ5OS4yNzUwMiA0NTUuOTYyNV0KPj4KZW5kb2JqCjY1OCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzODAuODEyNSA0OTkuMjc1MDIgNDEzLjk2MjVdCj4+CmVuZG9iago2NTkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzk1Ljk2MjUgNDk5LjI3NTAyIDQxMy45NjI1XQo+PgplbmRvYmoKNjYwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDM4MC44MTI1IDQ5OS4yNzUwMiAzOTUuOTYyNV0KPj4KZW5kb2JqCjY2MSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzMzUuNjYyNDggNDk5LjI3NTAyIDM2OC44MTI0N10KPj4KZW5kb2JqCjY2MiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzNTAuODEyNSA0OTkuMjc1MDIgMzY4LjgxMjVdCj4+CmVuZG9iago2NjMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzM1LjY2MjQ4IDQ5OS4yNzUwMiAzNTAuODEyNDddCj4+CmVuZG9iago2NjQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjkwLjUxMjUgNDk5LjI3NTAyIDMyMy42NjI1XQo+PgplbmRvYmoKNjY1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDMwNS42NjI0OCA0OTkuMjc1MDIgMzIzLjY2MjQ4XQo+PgplbmRvYmoKNjY2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI5MC41MTI1IDQ5OS4yNzUwMiAzMDUuNjYyNV0KPj4KZW5kb2JqCjY2NyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1Ny43NSA0OTkuMjc1MDIgMjc3Ljc2MjVdCj4+CmVuZG9iago2NjggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjM5Ljk2MjQ2IDQ5OS4yNzUwMiAyNjAuOTYyNDZdCj4+CmVuZG9iago2NjkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMTkxLjY2MjQ4IDQ5OS4yNzUwMiAyMjEuOTYyNDhdCj4+CmVuZG9iago2NzAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjA2LjgxMjUgNDk5LjI3NTAyIDIyMS45NjI1XQo+PgplbmRvYmoKNjcxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDE5MS42NjI0OCA0OTkuMjc1MDIgMjA2LjgxMjQ3XQo+PgplbmRvYmoKNjcyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDExMy4wNjI1IDQ5OS4yNzUwMiAxNzMuNjYyNV0KPj4KZW5kb2JqCjY3MyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxNTguNTEyNTEgNDk5LjI3NTAyIDE3My42NjI1XQo+PgplbmRvYmoKNjc0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDExMy4wNjI1IDQ5OS4yNzUwMiAxNTguNTEyNV0KPj4KZW5kb2JqCjY3NSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1Ny43NSA0OTkuMjc1MDIgOTUuMDYyNV0KPj4KZW5kb2JqCjY3NiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3OS45MTI0NzYgNDk5LjI3NTAyIDk1LjA2MjQ4XQo+PgplbmRvYmoKNjc3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs3OC43NSA3MTguNzI1IDE2NC44ODc1MSA3MzMuODc1XQo+PgplbmRvYmoKNjc4IDAgb2JqCjw8Ci9NQ0lEIDAKPj4KZW5kb2JqCjY3OSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbNzguNzUgNzE4LjcyNSAxNjQuODg3NTEgNzMzLjg3NV0KPj4KZW5kb2JqCjY4MCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbNzguNzUgNzAyLjA3NSAxNzUuOTg3NSA3MTcuMjI1MDRdCj4+CmVuZG9iago2ODEgMCBvYmoKPDwKL01DSUQgMQo+PgplbmRvYmoKNjgyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs3OC43NSA3MDIuMDc1IDE3NS45ODc1IDcxNy4yMjUwNF0KPj4KZW5kb2JqCjY4MyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbNzcuMjUgNjcyLjAgNTA3LjMwMDAyIDY4Ny4xNV0KPj4KZW5kb2JqCjY4NCAwIG9iago8PAovTUNJRCAyCj4+CmVuZG9iago2ODUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzc3LjI1IDY3Mi4wIDUwNy4zMDAwMiA2ODcuMTVdCj4+CmVuZG9iago2ODYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzc3LjI1IDY1Ni44NSAyNDAuMzM3NTEgNjcyLjBdCj4+CmVuZG9iago2ODcgMCBvYmoKPDwKL01DSUQgMwo+PgplbmRvYmoKNjg4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs3Ny4yNSA2NTYuODUgMjQwLjMzNzUxIDY3Mi4wXQo+PgplbmRvYmoKNjg5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs3Ny4yNSA2MDYuMDM3NSAyOTMuMjUgNjM3LjgzNzQ2XQo+PgplbmRvYmoKNjkwIDAgb2JqCjw8Ci9NQ0lEIDQKPj4KZW5kb2JqCjY5MSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbNzcuMjUgNjA2LjAzNzUgMjkzLjI1IDYzNy44Mzc0Nl0KPj4KZW5kb2JqCjY5MiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1NjAuNjI1IDE1OS4xODc1IDU3My44NjI1XQo+PgplbmRvYmoKNjkzIDAgb2JqCjw8Ci9NQ0lEIDUKPj4KZW5kb2JqCjY5NCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1NjAuNjI1IDE1OS4xODc1IDU3My44NjI1XQo+PgplbmRvYmoKNjk1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDUyMi4zMzc1IDI4NC4zMjUgNTQ2LjE4NzVdCj4+CmVuZG9iago2OTYgMCBvYmoKPDwKL01DSUQgNgo+PgplbmRvYmoKNjk3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDUyMi4zMzc1IDI4NC4zMjUgNTQ2LjE4NzVdCj4+CmVuZG9iago2OTggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDczLjIxMjUgMTgzLjcxMjUgNDg4LjM2MjVdCj4+CmVuZG9iago2OTkgMCBvYmoKPDwKL01DSUQgNwo+PgplbmRvYmoKNzAwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQ3My4yMTI1IDE4My43MTI1IDQ4OC4zNjI1XQo+PgplbmRvYmoKNzAxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMDEuMjUgNDczLjIxMjUgMTc4LjQ2MjUgNTAzLjUxMjQ4XQo+PgplbmRvYmoKNzAyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMDEuMjUgNDg4LjM2MjUgMTU3Ljk4NzUgNTAzLjUxMjQ4XQo+PgplbmRvYmoKNzAzIDAgb2JqCjw8Ci9NQ0lEIDgKPj4KZW5kb2JqCjcwNCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTAxLjI1IDQ4OC4zNjI1IDE1Ny45ODc1IDUwMy41MTI0OF0KPj4KZW5kb2JqCjcwNSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTAxLjI1IDQ3My4yMTI1IDEyMS43MjUgNDg4LjM2MjVdCj4+CmVuZG9iago3MDYgMCBvYmoKPDwKL01DSUQgOQo+PgplbmRvYmoKNzA3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMDEuMjUgNDczLjIxMjUgMTIxLjcyNSA0ODguMzYyNV0KPj4KZW5kb2JqCjcwOCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0NDAuODEyNSA0NjEuMzI1IDQ1NS45NjI1XQo+PgplbmRvYmoKNzA5IDAgb2JqCjw8Ci9NQ0lEIDEwCj4+CmVuZG9iago3MTAgMCBvYmoKPDwKL01DSUQgMTEKPj4KZW5kb2JqCjcxMSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0NDAuODEyNSA0NjEuMzI1IDQ1NS45NjI1XQo+PgplbmRvYmoKNzEyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQyNS45NjI1IDI3Ny40NjI1MiA0NTUuOTYyNV0KPj4KZW5kb2JqCjcxMyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0MzcuOTYyNSAyNzcuNDYyNTIgNDU1Ljk2MjVdCj4+CmVuZG9iago3MTQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDI1Ljk2MjUgMjc3LjQ2MjUyIDQzNy45NjI1XQo+PgplbmRvYmoKNzE1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQzOC4wIDE0NS41IDQ1NS44ODc1XQo+PgplbmRvYmoKNzE2IDAgb2JqCjw8Ci9NQ0lEIDEyCj4+CmVuZG9iago3MTcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDM4LjAgMTQ1LjUgNDU1Ljg4NzVdCj4+CmVuZG9iago3MTggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDIyLjgxMjUgMTg2Ljk3NSA0MzcuOTYyNV0KPj4KZW5kb2JqCjcxOSAwIG9iago8PAovTUNJRCAxMwo+PgplbmRvYmoKNzIwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQyMi44MTI1IDE4Ni45NzUgNDM3Ljk2MjVdCj4+CmVuZG9iago3MjEgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzI3OS44NjI1MiA0MjUuOTYyNSA0NjEuMzI1IDQ1NS45NjI1XQo+PgplbmRvYmoKNzIyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsyNzkuODYyNTIgNDM3Ljk2MjUgNDYxLjMyNSA0NTUuOTYyNV0KPj4KZW5kb2JqCjcyMyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMjc5Ljg2MjUyIDQyNS45NjI1IDQ2MS4zMjUgNDM3Ljk2MjVdCj4+CmVuZG9iago3MjQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzI3OS44NjI1MiA0MzguMCAzMjQuOTAwMDIgNDU1Ljg4NzVdCj4+CmVuZG9iago3MjUgMCBvYmoKPDwKL01DSUQgMTQKPj4KZW5kb2JqCjcyNiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMjc5Ljg2MjUyIDQzOC4wIDMyNC45MDAwMiA0NTUuODg3NV0KPj4KZW5kb2JqCjcyNyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMjc5Ljg2MjUyIDQyMi44MTI1IDM3MC44Mzc1MiA0MzcuOTYyNV0KPj4KZW5kb2JqCjcyOCAwIG9iago8PAovTUNJRCAxNQo+PgplbmRvYmoKNzI5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsyNzkuODYyNTIgNDIyLjgxMjUgMzcwLjgzNzUyIDQzNy45NjI1XQo+PgplbmRvYmoKNzMwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDM5Ni4wIDI1MS45NjI1MSA0MTMuODg3NV0KPj4KZW5kb2JqCjczMSAwIG9iago8PAovTUNJRCAxNgo+PgplbmRvYmoKNzMyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDM5Ni4wIDI1MS45NjI1MSA0MTMuODg3NV0KPj4KZW5kb2JqCjczMyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzODAuODEyNSAxMDIuMCAzOTUuOTYyNV0KPj4KZW5kb2JqCjczNCAwIG9iago8PAovTUNJRCAxNwo+PgplbmRvYmoKNzM1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDM4MC44MTI1IDEwMi4wIDM5NS45NjI1XQo+PgplbmRvYmoKNzM2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDM1MC44NDk5OCAyMjAuNTc1MDEgMzY4LjczNzVdCj4+CmVuZG9iago3MzcgMCBvYmoKPDwKL01DSUQgMTgKPj4KZW5kb2JqCjczOCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzNTAuODQ5OTggMjIwLjU3NTAxIDM2OC43Mzc1XQo+PgplbmRvYmoKNzM5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDMzNS42NjI0OCAxMDIuMCAzNTAuODEyNDddCj4+CmVuZG9iago3NDAgMCBvYmoKPDwKL01DSUQgMTkKPj4KZW5kb2JqCjc0MSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzMzUuNjYyNDggMTAyLjAgMzUwLjgxMjQ3XQo+PgplbmRvYmoKNzQyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDMwNS43IDE2NC4xMzc1MSAzMjMuNTg3NTJdCj4+CmVuZG9iago3NDMgMCBvYmoKPDwKL01DSUQgMjAKPj4KZW5kb2JqCjc0NCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzMDUuNyAxNjQuMTM3NTEgMzIzLjU4NzUyXQo+PgplbmRvYmoKNzQ1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI5MC41MTI1IDE1Mi43IDMwNS42NjI1XQo+PgplbmRvYmoKNzQ2IDAgb2JqCjw8Ci9NQ0lEIDIxCj4+CmVuZG9iago3NDcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjkwLjUxMjUgMTUyLjcgMzA1LjY2MjVdCj4+CmVuZG9iago3NDggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjQwLjUyNDk2IDEzOC4yMjUgMjYwLjM5OTk2XQo+PgplbmRvYmoKNzQ5IDAgb2JqCjw8Ci9NQ0lEIDIyCj4+CmVuZG9iago3NTAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjQwLjUyNDk2IDEzOC4yMjUgMjYwLjM5OTk2XQo+PgplbmRvYmoKNzUxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDIwNi44MTI1IDI4MC45NSAyMjEuOTYyNV0KPj4KZW5kb2JqCjc1MiAwIG9iago8PAovTUNJRCAyMwo+PgplbmRvYmoKNzUzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDIwNi44MTI1IDI4MC45NSAyMjEuOTYyNV0KPj4KZW5kb2JqCjc1NCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxOTEuNjYyNDggMTk2LjMxMjUgMjA2LjgxMjQ3XQo+PgplbmRvYmoKNzU1IDAgb2JqCjw8Ci9NQ0lEIDI0Cj4+CmVuZG9iago3NTYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMTkxLjY2MjQ4IDE5Ni4zMTI1IDIwNi44MTI0N10KPj4KZW5kb2JqCjc1NyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxNTguNTEyNTEgMjg3LjU4NzUyIDE3My42NjI1XQo+PgplbmRvYmoKNzU4IDAgb2JqCjw8Ci9NQ0lEIDI1Cj4+CmVuZG9iago3NTkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMTU4LjUxMjUxIDI4Ny41ODc1MiAxNzMuNjYyNV0KPj4KZW5kb2JqCjc2MCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxNDMuMzYyNDkgMTE0LjYgMTU4LjUxMjQ4XQo+PgplbmRvYmoKNzYxIDAgb2JqCjw8Ci9NQ0lEIDI2Cj4+CmVuZG9iago3NjIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMTQzLjM2MjQ5IDExNC42IDE1OC41MTI0OF0KPj4KZW5kb2JqCjc2MyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTE0LjYwMDAwNiAxNDMuMzYyNDkgMTE0LjYwMDAwNiAxNTguNTEyNDhdCj4+CmVuZG9iago3NjQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzExNC42MDAwMDYgMTQzLjM2MjQ5IDExNC42MDAwMDYgMTU4LjUxMjQ4XQo+PgplbmRvYmoKNzY1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMTQuNjAwMDA2IDE0My4zNjI0OSAxMTQuNjAwMDA2IDE1OC41MTI0OF0KPj4KZW5kb2JqCjc2NiAwIG9iago8PAovTUNJRCAyNwo+PgplbmRvYmoKNzY3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMTQuNjAwMDA2IDE0My4zNjI0OSAxMTQuNjAwMDA2IDE1OC41MTI0OF0KPj4KZW5kb2JqCjc2OCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxMTMuMDYyNSAyMjguMDM3NSAxMjguMjEyNV0KPj4KZW5kb2JqCjc2OSAwIG9iago8PAovTUNJRCAyOAo+PgplbmRvYmoKNzcwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDExMy4wNjI1IDIyOC4wMzc1IDEyOC4yMTI1XQo+PgplbmRvYmoKNzcxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDExMy4wNjI1IDk2LjAgMTI4LjIxMjVdCj4+CmVuZG9iago3NzIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMTEzLjA2MjUgOTYuMCAxMjguMjEyNV0KPj4KZW5kb2JqCjc3MyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxMTMuMDYyNSA5Ni4wIDEyOC4yMTI1XQo+PgplbmRvYmoKNzc0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDExMy4wNjI1IDk2LjAgMTI4LjIxMjVdCj4+CmVuZG9iago3NzUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMTEzLjA2MjUgOTYuMCAxMjguMjEyNV0KPj4KZW5kb2JqCjc3NiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxMTMuMDYyNSA5Ni4wIDEyOC4yMTI1XQo+PgplbmRvYmoKNzc3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDc5LjkxMjQ3NiAyODcuNTg3NTIgOTUuMDYyNDhdCj4+CmVuZG9iago3NzggMCBvYmoKPDwKL01DSUQgMjkKPj4KZW5kb2JqCjc3OSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3OS45MTI0NzYgMjg3LjU4NzUyIDk1LjA2MjQ4XQo+PgplbmRvYmoKNzgwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs0NTIuMjUgNzM1LjM3NSA1MjQuMDI1IDc3OC4xMjVdCj4+CmVuZG9iago3ODEgMCBvYmoKPDwKL01DSUQgMzAKPj4KZW5kb2JqCjc4MiAwIG9iago8PAovVHlwZSAvRm9udAovQmFzZUZvbnQgL1NvdXJjZVNhbnNQcm8tUmVndWxhcgovU3VidHlwZSAvVHlwZTAKL0VuY29kaW5nIC9JZGVudGl0eS1ICi9EZXNjZW5kYW50Rm9udHMgWzI0ODYgMCBSXQovVG9Vbmljb2RlIDI0ODcgMCBSCj4+CmVuZG9iago3ODMgMCBvYmoKPDwKL1R5cGUgL0ZvbnQKL0Jhc2VGb250IC9Tb3VyY2VTYW5zUHJvLUJvbGQKL1N1YnR5cGUgL1R5cGUwCi9FbmNvZGluZyAvSWRlbnRpdHktSAovRGVzY2VuZGFudEZvbnRzIFsyNDg4IDAgUl0KL1RvVW5pY29kZSAyNDg5IDAgUgo+PgplbmRvYmoKNzg0IDAgb2JqCjw8Ci9nczEgMjQ5MCAwIFIKPj4KZW5kb2JqCjc4NSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbNzEuMjUgNTcuNzUgNTI0LjAyNSA3ODQuMTI1XQo+PgplbmRvYmoKNzg2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs3MS4yNSA1Ny43NSA1MjQuMDI1IDc4NC4xMjVdCj4+CmVuZG9iago3ODcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzc3LjI1IDU3Ljc1IDUxOC4wMjUgNzg0LjEyNV0KPj4KZW5kb2JqCjc4OCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbNzcuMjUgNTcuNzUgNTE4LjAyNSA3ODQuMTI1XQo+PgplbmRvYmoKNzg5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU3Ljc1IDQ5OS4yNzUwMiA3ODQuMTI1XQo+PgplbmRvYmoKNzkwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU3Ljc1IDQ5OS4yNzUwMiA3ODQuMTI1XQo+PgplbmRvYmoKNzkxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDcyMy41MjUgNDk5LjI3NTAyIDc4NC4xMjVdCj4+CmVuZG9iago3OTIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzIzLjUyNSA0OTkuMjc1MDIgNzg0LjEyNV0KPj4KZW5kb2JqCjc5MyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2NzUuMjI1IDQ5OS4yNzUwMiA3MDUuNTI0OTZdCj4+CmVuZG9iago3OTQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjkwLjM3NSA0OTkuMjc1MDIgNzA1LjUyNV0KPj4KZW5kb2JqCjc5NSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2NzUuMjI1IDQ5OS4yNzUwMiA2OTAuMzc1XQo+PgplbmRvYmoKNzk2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU5Ni42MjUgNDk5LjI3NTAyIDY1Ny4yMjVdCj4+CmVuZG9iago3OTcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjQyLjA3NSA0OTkuMjc1MDIgNjU3LjIyNTA0XQo+PgplbmRvYmoKNzk4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU5Ni42MjUgNDk5LjI3NTAyIDY0Mi4wNzVdCj4+CmVuZG9iago3OTkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTQ4LjMyNDk1IDQ5OS4yNzUwMiA1NzguNjI0OTRdCj4+CmVuZG9iago4MDAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTYzLjQ3NSA0OTkuMjc1MDIgNTc4LjYyNV0KPj4KZW5kb2JqCjgwMSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1NDguMzI0OTUgNDk5LjI3NTAyIDU2My40NzVdCj4+CmVuZG9iago4MDIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTE1LjE3NSA0OTkuMjc1MDIgNTMwLjMyNV0KPj4KZW5kb2JqCjgwMyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1MTUuMTc1IDQ5OS4yNzUwMiA1MzAuMzI1XQo+PgplbmRvYmoKODA0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQ2Ni44NzUgNDk5LjI3NTAyIDQ5Ny4xNzVdCj4+CmVuZG9iago4MDUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDgyLjAyNSA0OTkuMjc1MDIgNDk3LjE3NV0KPj4KZW5kb2JqCjgwNiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0NjYuODc1IDQ5OS4yNzUwMiA0ODIuMDI1XQo+PgplbmRvYmoKODA3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDM4OC4yNzUgNDk5LjI3NTAyIDQ0OC44NzVdCj4+CmVuZG9iago4MDggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDMzLjcyNDk4IDQ5OS4yNzUwMiA0NDguODc0OTddCj4+CmVuZG9iago4MDkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzg4LjI3NSA0OTkuMjc1MDIgNDMzLjcyNV0KPj4KZW5kb2JqCjgxMCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1Ny43NSA0OTkuMjc1MDIgMzcwLjI3NV0KPj4KZW5kb2JqCjgxMSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzNTUuMTI1IDQ5OS4yNzUwMiAzNzAuMjc1XQo+PgplbmRvYmoKODEyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU3Ljc1IDQ5OS4yNzUwMiAzNTUuMTI1XQo+PgplbmRvYmoKODEzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDc2OC45NzUgMTE2LjI4NzUgNzg0LjEyNV0KPj4KZW5kb2JqCjgxNCAwIG9iago8PAovTUNJRCAwCj4+CmVuZG9iago4MTUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzY4Ljk3NSAxMTYuMjg3NSA3ODQuMTI1XQo+PgplbmRvYmoKODE2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMTYuMjg3NTA2IDc2OC45NzUgMTE2LjI4NzUwNiA3ODQuMTI1XQo+PgplbmRvYmoKODE3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMTYuMjg3NTA2IDc2OC45NzUgMTE2LjI4NzUwNiA3ODQuMTI1XQo+PgplbmRvYmoKODE4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMTYuMjg3NTA2IDc2OC45NzUgMTE2LjI4NzUwNiA3ODQuMTI1XQo+PgplbmRvYmoKODE5IDAgb2JqCjw8Ci9NQ0lEIDEKPj4KZW5kb2JqCjgyMCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTE2LjI4NzUwNiA3NjguOTc1IDExNi4yODc1MDYgNzg0LjEyNV0KPj4KZW5kb2JqCjgyMSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3MjMuNTI1IDIyOC4wMzc1IDczOC42NzUwNV0KPj4KZW5kb2JqCjgyMiAwIG9iago8PAovTUNJRCAyCj4+CmVuZG9iago4MjMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzIzLjUyNSAyMjguMDM3NSA3MzguNjc1MDVdCj4+CmVuZG9iago4MjQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzIzLjUyNSA5Ni4wIDczOC42NzUwNV0KPj4KZW5kb2JqCjgyNSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3MjMuNTI1IDk2LjAgNzM4LjY3NTA1XQo+PgplbmRvYmoKODI2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDcyMy41MjUgOTYuMCA3MzguNjc1MDVdCj4+CmVuZG9iago4MjcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzIzLjUyNSA5Ni4wIDczOC42NzUwNV0KPj4KZW5kb2JqCjgyOCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3MjMuNTI1IDk2LjAgNzM4LjY3NTA1XQo+PgplbmRvYmoKODI5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDcyMy41MjUgOTYuMCA3MzguNjc1MDVdCj4+CmVuZG9iago4MzAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjkwLjM3NSAyODAuOTUgNzA1LjUyNV0KPj4KZW5kb2JqCjgzMSAwIG9iago8PAovTUNJRCAzCj4+CmVuZG9iago4MzIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjkwLjM3NSAyODAuOTUgNzA1LjUyNV0KPj4KZW5kb2JqCjgzMyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2NzUuMjI1IDE5MC41Mzc1IDY5MC4zNzVdCj4+CmVuZG9iago4MzQgMCBvYmoKPDwKL01DSUQgNAo+PgplbmRvYmoKODM1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDY3NS4yMjUgMTkwLjUzNzUgNjkwLjM3NV0KPj4KZW5kb2JqCjgzNiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2NDIuMDc1IDI4Ny41ODc1MiA2NTcuMjI1MDRdCj4+CmVuZG9iago4MzcgMCBvYmoKPDwKL01DSUQgNQo+PgplbmRvYmoKODM4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDY0Mi4wNzUgMjg3LjU4NzUyIDY1Ny4yMjUwNF0KPj4KZW5kb2JqCjgzOSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2MjYuOTI1IDIzNC45NzUgNjQyLjA3NV0KPj4KZW5kb2JqCjg0MCAwIG9iago8PAovTUNJRCA2Cj4+CmVuZG9iago4NDEgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjI2LjkyNSAyMzQuOTc1IDY0Mi4wNzVdCj4+CmVuZG9iago4NDIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzIzNC45NzUgNjI2LjkyNSAyMzQuOTc1IDY0Mi4wNzVdCj4+CmVuZG9iago4NDMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzIzNC45NzUgNjI2LjkyNSAyMzQuOTc1IDY0Mi4wNzVdCj4+CmVuZG9iago4NDQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzIzNC45NzUgNjI2LjkyNSAyMzQuOTc1IDY0Mi4wNzVdCj4+CmVuZG9iago4NDUgMCBvYmoKPDwKL01DSUQgNwo+PgplbmRvYmoKODQ2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsyMzQuOTc1IDYyNi45MjUgMjM0Ljk3NSA2NDIuMDc1XQo+PgplbmRvYmoKODQ3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU5Ni42MjUgMjI4LjAzNzUgNjExLjc3NV0KPj4KZW5kb2JqCjg0OCAwIG9iago8PAovTUNJRCA4Cj4+CmVuZG9iago4NDkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTk2LjYyNSAyMjguMDM3NSA2MTEuNzc1XQo+PgplbmRvYmoKODUwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU5Ni42MjUgOTYuMCA2MTEuNzc1XQo+PgplbmRvYmoKODUxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU5Ni42MjUgOTYuMCA2MTEuNzc1XQo+PgplbmRvYmoKODUyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU5Ni42MjUgOTYuMCA2MTEuNzc1XQo+PgplbmRvYmoKODUzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU5Ni42MjUgOTYuMCA2MTEuNzc1XQo+PgplbmRvYmoKODU0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU5Ni42MjUgOTYuMCA2MTEuNzc1XQo+PgplbmRvYmoKODU1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU5Ni42MjUgOTYuMCA2MTEuNzc1XQo+PgplbmRvYmoKODU2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU2My40NzUgMjgwLjk1IDU3OC42MjVdCj4+CmVuZG9iago4NTcgMCBvYmoKPDwKL01DSUQgOQo+PgplbmRvYmoKODU4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU2My40NzUgMjgwLjk1IDU3OC42MjVdCj4+CmVuZG9iago4NTkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTQ4LjMyNDk1IDExNi4yNSA1NjMuNDc1XQo+PgplbmRvYmoKODYwIDAgb2JqCjw8Ci9NQ0lEIDEwCj4+CmVuZG9iago4NjEgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTQ4LjMyNDk1IDExNi4yNSA1NjMuNDc1XQo+PgplbmRvYmoKODYyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDUxNS4xNzUgMjYyLjk1IDUzMC4zMjVdCj4+CmVuZG9iago4NjMgMCBvYmoKPDwKL01DSUQgMTEKPj4KZW5kb2JqCjg2NCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1MTUuMTc1IDI2Mi45NSA1MzAuMzI1XQo+PgplbmRvYmoKODY1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQ4Mi4wMjUgMjgwLjk1IDQ5Ny4xNzVdCj4+CmVuZG9iago4NjYgMCBvYmoKPDwKL01DSUQgMTIKPj4KZW5kb2JqCjg2NyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0ODIuMDI1IDI4MC45NSA0OTcuMTc1XQo+PgplbmRvYmoKODY4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQ2Ni44NzUgMTI3LjA1IDQ4Mi4wMjVdCj4+CmVuZG9iago4NjkgMCBvYmoKPDwKL01DSUQgMTMKPj4KZW5kb2JqCjg3MCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0NjYuODc1IDEyNy4wNSA0ODIuMDI1XQo+PgplbmRvYmoKODcxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQzMy43MjQ5OCAyODAuOTUgNDQ4Ljg3NDk3XQo+PgplbmRvYmoKODcyIDAgb2JqCjw8Ci9NQ0lEIDE0Cj4+CmVuZG9iago4NzMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDMzLjcyNDk4IDI4MC45NSA0NDguODc0OTddCj4+CmVuZG9iago4NzQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDE4LjU3NDk4IDQ5OC45Mzc1IDQzMy43MjQ5OF0KPj4KZW5kb2JqCjg3NSAwIG9iago8PAovTUNJRCAxNQo+PgplbmRvYmoKODc2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQxOC41NzQ5OCA0OTguOTM3NSA0MzMuNzI0OThdCj4+CmVuZG9iago4NzcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDAzLjQyNSAyNzkuNDEyNSA0MTguNTc0OThdCj4+CmVuZG9iago4NzggMCBvYmoKPDwKL01DSUQgMTYKPj4KZW5kb2JqCjg3OSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0MDMuNDI1IDI3OS40MTI1IDQxOC41NzQ5OF0KPj4KZW5kb2JqCjg4MCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMjc5LjQxMjUgNDAzLjQyNSAyNzkuNDEyNSA0MTguNTc0OThdCj4+CmVuZG9iago4ODEgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzI3OS40MTI1IDQwMy40MjUgMjc5LjQxMjUgNDE4LjU3NDk4XQo+PgplbmRvYmoKODgyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsyNzkuNDEyNSA0MDMuNDI1IDI3OS40MTI1IDQxOC41NzQ5OF0KPj4KZW5kb2JqCjg4MyAwIG9iago8PAovTUNJRCAxNwo+PgplbmRvYmoKODg0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsyNzkuNDEyNSA0MDMuNDI1IDI3OS40MTI1IDQxOC41NzQ5OF0KPj4KZW5kb2JqCjg4NSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzNTUuMTI1IDI4MC45NSAzNzAuMjc1XQo+PgplbmRvYmoKODg2IDAgb2JqCjw8Ci9NQ0lEIDE4Cj4+CmVuZG9iago4ODcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzU1LjEyNSAyODAuOTUgMzcwLjI3NV0KPj4KZW5kb2JqCjg4OCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzMzkuOTc0OTggNDkwLjIzNzUyIDM1NS4xMjQ5N10KPj4KZW5kb2JqCjg4OSAwIG9iago8PAovTUNJRCAxOQo+PgplbmRvYmoKODkwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDMzOS45NzQ5OCA0OTAuMjM3NTIgMzU1LjEyNDk3XQo+PgplbmRvYmoKODkxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDMyNC44MjUgMjA0LjAgMzM5Ljk3NV0KPj4KZW5kb2JqCjg5MiAwIG9iago8PAovTUNJRCAyMAo+PgplbmRvYmoKODkzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDMyNC44MjUgMjA0LjAgMzM5Ljk3NV0KPj4KZW5kb2JqCjg5NCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMjA0LjAgMzI0LjgyNSAyMDQuMCAzMzkuOTc1XQo+PgplbmRvYmoKODk1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsyMDQuMCAzMjQuODI1IDIwNC4wIDMzOS45NzVdCj4+CmVuZG9iago4OTYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzIwNC4wIDMyNC44MjUgMjA0LjAgMzM5Ljk3NV0KPj4KZW5kb2JqCjg5NyAwIG9iago8PAovTUNJRCAyMQo+PgplbmRvYmoKODk4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsyMDQuMCAzMjQuODI1IDIwNC4wIDMzOS45NzVdCj4+CmVuZG9iago4OTkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzA5LjY3NSA0OTAuMjM3NTIgMzI0LjgyNDk4XQo+PgplbmRvYmoKOTAwIDAgb2JqCjw8Ci9NQ0lEIDIyCj4+CmVuZG9iago5MDEgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzA5LjY3NSA0OTAuMjM3NTIgMzI0LjgyNDk4XQo+PgplbmRvYmoKOTAyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDMwOS42NzUgOTYuMCAzMjQuODI0OThdCj4+CmVuZG9iago5MDMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzA5LjY3NSA5Ni4wIDMyNC44MjQ5OF0KPj4KZW5kb2JqCjkwNCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzMDkuNjc1IDk2LjAgMzI0LjgyNDk4XQo+PgplbmRvYmoKOTA1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDMwOS42NzUgOTYuMCAzMjQuODI0OThdCj4+CmVuZG9iago5MDYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzA5LjY3NSA5Ni4wIDMyNC44MjQ5OF0KPj4KZW5kb2JqCjkwNyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzMDkuNjc1IDk2LjAgMzI0LjgyNDk4XQo+PgplbmRvYmoKOTA4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI5NC41MjQ5NiA0ODAuOTc1IDMwOS42NzQ5Nl0KPj4KZW5kb2JqCjkwOSAwIG9iago8PAovTUNJRCAyMwo+PgplbmRvYmoKOTEwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI5NC41MjQ5NiA0ODAuOTc1IDMwOS42NzQ5Nl0KPj4KZW5kb2JqCjkxMSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyNzkuMzc1IDQ5MC44Mzc1MiAyOTQuNTI1XQo+PgplbmRvYmoKOTEyIDAgb2JqCjw8Ci9NQ0lEIDI0Cj4+CmVuZG9iago5MTMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjc5LjM3NSA0OTAuODM3NTIgMjk0LjUyNV0KPj4KZW5kb2JqCjkxNCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyNjQuMjI0OTggNDcwLjk2MjUgMjc5LjM3NDk3XQo+PgplbmRvYmoKOTE1IDAgb2JqCjw8Ci9NQ0lEIDI1Cj4+CmVuZG9iago5MTYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjY0LjIyNDk4IDQ3MC45NjI1IDI3OS4zNzQ5N10KPj4KZW5kb2JqCjkxNyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyNDkuMDc1MDEgNDc5LjU1MDAyIDI2NC4yMjVdCj4+CmVuZG9iago5MTggMCBvYmoKPDwKL01DSUQgMjYKPj4KZW5kb2JqCjkxOSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyNDkuMDc1MDEgNDc5LjU1MDAyIDI2NC4yMjVdCj4+CmVuZG9iago5MjAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjMzLjkyNDk5IDQ4Mi4yODc1IDI0OS4wNzQ5OF0KPj4KZW5kb2JqCjkyMSAwIG9iago8PAovTUNJRCAyNwo+PgplbmRvYmoKOTIyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDIzMy45MjQ5OSA0ODIuMjg3NSAyNDkuMDc0OThdCj4+CmVuZG9iago5MjMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjE4Ljc3NDk2IDQ3Ni43NzUgMjMzLjkyNDk2XQo+PgplbmRvYmoKOTI0IDAgb2JqCjw8Ci9NQ0lEIDI4Cj4+CmVuZG9iago5MjUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjE4Ljc3NDk2IDQ3Ni43NzUgMjMzLjkyNDk2XQo+PgplbmRvYmoKOTI2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDIwMy42MjUgNDg4LjMyNSAyMTguNzc1XQo+PgplbmRvYmoKOTI3IDAgb2JqCjw8Ci9NQ0lEIDI5Cj4+CmVuZG9iago5MjggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjAzLjYyNSA0ODguMzI1IDIxOC43NzVdCj4+CmVuZG9iago5MjkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMTg4LjQ3NDk4IDQ5MS43IDIwMy42MjQ5N10KPj4KZW5kb2JqCjkzMCAwIG9iago8PAovTUNJRCAzMAo+PgplbmRvYmoKOTMxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDE4OC40NzQ5OCA0OTEuNyAyMDMuNjI0OTddCj4+CmVuZG9iago5MzIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMTczLjMyNTAxIDQ5Mi4wNzUgMTg4LjQ3NV0KPj4KZW5kb2JqCjkzMyAwIG9iago8PAovTUNJRCAzMQo+PgplbmRvYmoKOTM0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDE3My4zMjUwMSA0OTIuMDc1IDE4OC40NzVdCj4+CmVuZG9iago5MzUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMTU4LjE3NDk5IDQ3Mi42NSAxNzMuMzI0OThdCj4+CmVuZG9iago5MzYgMCBvYmoKPDwKL01DSUQgMzIKPj4KZW5kb2JqCjkzNyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxNTguMTc0OTkgNDcyLjY1IDE3My4zMjQ5OF0KPj4KZW5kb2JqCjkzOCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxNDMuMDI0OTYgNDkyLjgyNSAxNTguMTc0OTZdCj4+CmVuZG9iago5MzkgMCBvYmoKPDwKL01DSUQgMzMKPj4KZW5kb2JqCjk0MCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxNDMuMDI0OTYgNDkyLjgyNSAxNTguMTc0OTZdCj4+CmVuZG9iago5NDEgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMTI3Ljg3NSA0ODMuMzAwMDIgMTQzLjAyNV0KPj4KZW5kb2JqCjk0MiAwIG9iago8PAovTUNJRCAzNAo+PgplbmRvYmoKOTQzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDEyNy44NzUgNDgzLjMwMDAyIDE0My4wMjVdCj4+CmVuZG9iago5NDQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMTEyLjcyNDk3NiA0ODcuMiAxMjcuODc0OThdCj4+CmVuZG9iago5NDUgMCBvYmoKPDwKL01DSUQgMzUKPj4KZW5kb2JqCjk0NiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxMTIuNzI0OTc2IDQ4Ny4yIDEyNy44NzQ5OF0KPj4KZW5kb2JqCjk0NyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA5Ny41NzUwMSA0OTQuODEyNSAxMTIuNzI1MDFdCj4+CmVuZG9iago5NDggMCBvYmoKPDwKL01DSUQgMzYKPj4KZW5kb2JqCjk0OSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA5Ny41NzUwMSA0OTQuODEyNSAxMTIuNzI1MDFdCj4+CmVuZG9iago5NTAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgODIuNDI0OTkgNDc2Ljc3NSA5Ny41NzQ5OV0KPj4KZW5kb2JqCjk1MSAwIG9iago8PAovTUNJRCAzNwo+PgplbmRvYmoKOTUyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDgyLjQyNDk5IDQ3Ni43NzUgOTcuNTc0OTldCj4+CmVuZG9iago5NTMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjcuMjc0OTYgNDg4LjMyNSA4Mi40MjQ5NjVdCj4+CmVuZG9iago5NTQgMCBvYmoKPDwKL01DSUQgMzgKPj4KZW5kb2JqCjk1NSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2Ny4yNzQ5NiA0ODguMzI1IDgyLjQyNDk2NV0KPj4KZW5kb2JqCjk1NiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbNzEuMjUgNTcuNzUgNTI0LjAyNSA3ODQuMTI1XQo+PgplbmRvYmoKOTU3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs3MS4yNSA1Ny43NSA1MjQuMDI1IDc4NC4xMjVdCj4+CmVuZG9iago5NTggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzc3LjI1IDU3Ljc1IDUxOC4wMjUgNzg0LjEyNV0KPj4KZW5kb2JqCjk1OSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbNzcuMjUgNTcuNzUgNTE4LjAyNSA3ODQuMTI1XQo+PgplbmRvYmoKOTYwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU3Ljc1IDQ5OS4yNzUwMiA3ODQuMTI1XQo+PgplbmRvYmoKOTYxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU3Ljc1IDQ5OS4yNzUwMiA3ODQuMTI1XQo+PgplbmRvYmoKOTYyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQ2NS45NzUgNDk5LjI3NTAyIDc4NC4xMjVdCj4+CmVuZG9iago5NjMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDY1Ljk3NSA0OTkuMjc1MDIgNzg0LjEyNV0KPj4KZW5kb2JqCjk2NCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzODcuMzc1IDQ5OS4yNzUwMiA0NDcuOTc1XQo+PgplbmRvYmoKOTY1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQzMi44MjQ5OCA0OTkuMjc1MDIgNDQ3Ljk3NDk4XQo+PgplbmRvYmoKOTY2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDM4Ny4zNzUgNDk5LjI3NTAyIDQzMi44MjVdCj4+CmVuZG9iago5NjcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzM5LjA3NDk4IDQ5OS4yNzUwMiAzNjkuMzc0OTddCj4+CmVuZG9iago5NjggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzU0LjIyNDk4IDQ5OS4yNzUwMiAzNjkuMzc0OTddCj4+CmVuZG9iago5NjkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzM5LjA3NDk4IDQ5OS4yNzUwMiAzNTQuMjI0OThdCj4+CmVuZG9iago5NzAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjkwLjc3NDk2IDQ5OS4yNzUwMiAzMjEuMDc0OTVdCj4+CmVuZG9iago5NzEgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzA1LjkyNSA0OTkuMjc1MDIgMzIxLjA3NDk4XQo+PgplbmRvYmoKOTcyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI5MC43NzQ5NiA0OTkuMjc1MDIgMzA1LjkyNDk2XQo+PgplbmRvYmoKOTczIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI0Mi40NzQ5OCA0OTkuMjc1MDIgMjcyLjc3NDk2XQo+PgplbmRvYmoKOTc0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI1Ny42MjUgNDk5LjI3NTAyIDI3Mi43NzVdCj4+CmVuZG9iago5NzUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjQyLjQ3NDk4IDQ5OS4yNzUwMiAyNTcuNjI0OTddCj4+CmVuZG9iago5NzYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMTk0LjE3NDk5IDQ5OS4yNzUwMiAyMjQuNDc0OTldCj4+CmVuZG9iago5NzcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjA5LjMyNTAxIDQ5OS4yNzUwMiAyMjQuNDc1XQo+PgplbmRvYmoKOTc4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDE5NC4xNzQ5OSA0OTkuMjc1MDIgMjA5LjMyNDk4XQo+PgplbmRvYmoKOTc5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDE0NS44NzUgNDk5LjI3NTAyIDE3Ni4xNzVdCj4+CmVuZG9iago5ODAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMTYxLjAyNDk2IDQ5OS4yNzUwMiAxNzYuMTc0OTZdCj4+CmVuZG9iago5ODEgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMTQ1Ljg3NSA0OTkuMjc1MDIgMTYxLjAyNV0KPj4KZW5kb2JqCjk4MiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2Ny4yNzQ5NiA0OTkuMjc1MDIgMTI3Ljg3NDk3XQo+PgplbmRvYmoKOTgzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDExMi43MjQ5NzYgNDk5LjI3NTAyIDEyNy44NzQ5OF0KPj4KZW5kb2JqCjk4NCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2Ny4yNzQ5NiA0OTkuMjc1MDIgMTEyLjcyNDk2XQo+PgplbmRvYmoKOTg1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDc2OC45NzUgNDkxLjcgNzg0LjEyNV0KPj4KZW5kb2JqCjk4NiAwIG9iago8PAovTUNJRCAwCj4+CmVuZG9iago5ODcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzY4Ljk3NSA0OTEuNyA3ODQuMTI1XQo+PgplbmRvYmoKOTg4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDc1My44MjUgNDkyLjA3NSA3NjguOTc1MDRdCj4+CmVuZG9iago5ODkgMCBvYmoKPDwKL01DSUQgMQo+PgplbmRvYmoKOTkwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDc1My44MjUgNDkyLjA3NSA3NjguOTc1MDRdCj4+CmVuZG9iago5OTEgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzM4LjY3NSA0NzIuNjUgNzUzLjgyNV0KPj4KZW5kb2JqCjk5MiAwIG9iago8PAovTUNJRCAyCj4+CmVuZG9iago5OTMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzM4LjY3NSA0NzIuNjUgNzUzLjgyNV0KPj4KZW5kb2JqCjk5NCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3MjMuNTI1IDQ5Mi44MjUgNzM4LjY3NTA1XQo+PgplbmRvYmoKOTk1IDAgb2JqCjw8Ci9NQ0lEIDMKPj4KZW5kb2JqCjk5NiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3MjMuNTI1IDQ5Mi44MjUgNzM4LjY3NTA1XQo+PgplbmRvYmoKOTk3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDcwOC4zNzUgNDgzLjMwMDAyIDcyMy41MjVdCj4+CmVuZG9iago5OTggMCBvYmoKPDwKL01DSUQgNAo+PgplbmRvYmoKOTk5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDcwOC4zNzUgNDgzLjMwMDAyIDcyMy41MjVdCj4+CmVuZG9iagoxMDAwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDY5My4yMjUgNDg3LjIgNzA4LjM3NV0KPj4KZW5kb2JqCjEwMDEgMCBvYmoKPDwKL01DSUQgNQo+PgplbmRvYmoKMTAwMiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2OTMuMjI1IDQ4Ny4yIDcwOC4zNzVdCj4+CmVuZG9iagoxMDAzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDY3OC4wNzUgNDk0LjgxMjUgNjkzLjIyNTA0XQo+PgplbmRvYmoKMTAwNCAwIG9iago8PAovTUNJRCA2Cj4+CmVuZG9iagoxMDA1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDY3OC4wNzUgNDk0LjgxMjUgNjkzLjIyNTA0XQo+PgplbmRvYmoKMTAwNiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2NjIuOTI1IDQ3Ni43NzUgNjc4LjA3NV0KPj4KZW5kb2JqCjEwMDcgMCBvYmoKPDwKL01DSUQgNwo+PgplbmRvYmoKMTAwOCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2NjIuOTI1IDQ3Ni43NzUgNjc4LjA3NV0KPj4KZW5kb2JqCjEwMDkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjQ3Ljc3NSA0ODguMzI1IDY2Mi45MjUwNV0KPj4KZW5kb2JqCjEwMTAgMCBvYmoKPDwKL01DSUQgOAo+PgplbmRvYmoKMTAxMSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2NDcuNzc1IDQ4OC4zMjUgNjYyLjkyNTA1XQo+PgplbmRvYmoKMTAxMiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2MzIuNjI1IDQ5MS43IDY0Ny43NzVdCj4+CmVuZG9iagoxMDEzIDAgb2JqCjw8Ci9NQ0lEIDkKPj4KZW5kb2JqCjEwMTQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjMyLjYyNSA0OTEuNyA2NDcuNzc1XQo+PgplbmRvYmoKMTAxNSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2MTcuNDc1IDQ5Mi4wNzUgNjMyLjYyNV0KPj4KZW5kb2JqCjEwMTYgMCBvYmoKPDwKL01DSUQgMTAKPj4KZW5kb2JqCjEwMTcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjE3LjQ3NSA0OTIuMDc1IDYzMi42MjVdCj4+CmVuZG9iagoxMDE4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDYwMi4zMjUgNDcyLjY1IDYxNy40NzUwNF0KPj4KZW5kb2JqCjEwMTkgMCBvYmoKPDwKL01DSUQgMTEKPj4KZW5kb2JqCjEwMjAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjAyLjMyNSA0NzIuNjUgNjE3LjQ3NTA0XQo+PgplbmRvYmoKMTAyMSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1ODcuMTc1IDQ5Mi44MjUgNjAyLjMyNV0KPj4KZW5kb2JqCjEwMjIgMCBvYmoKPDwKL01DSUQgMTIKPj4KZW5kb2JqCjEwMjMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTg3LjE3NSA0OTIuODI1IDYwMi4zMjVdCj4+CmVuZG9iagoxMDI0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU3Mi4wMjUgNDgzLjMwMDAyIDU4Ny4xNzUwNV0KPj4KZW5kb2JqCjEwMjUgMCBvYmoKPDwKL01DSUQgMTMKPj4KZW5kb2JqCjEwMjYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTcyLjAyNSA0ODMuMzAwMDIgNTg3LjE3NTA1XQo+PgplbmRvYmoKMTAyNyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1NTYuODc1IDQ4Ny4yIDU3Mi4wMjVdCj4+CmVuZG9iagoxMDI4IDAgb2JqCjw8Ci9NQ0lEIDE0Cj4+CmVuZG9iagoxMDI5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU1Ni44NzUgNDg3LjIgNTcyLjAyNV0KPj4KZW5kb2JqCjEwMzAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTQxLjcyNSAxODQuOTEyNSA1NTYuODc1XQo+PgplbmRvYmoKMTAzMSAwIG9iago8PAovTUNJRCAxNQo+PgplbmRvYmoKMTAzMiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1NDEuNzI1IDE4NC45MTI1IDU1Ni44NzVdCj4+CmVuZG9iagoxMDMzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxODQuOTEyNSA1NDEuNzI1IDE4NC45MTI1IDU1Ni44NzVdCj4+CmVuZG9iagoxMDM0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxODQuOTEyNSA1NDEuNzI1IDE4NC45MTI1IDU1Ni44NzVdCj4+CmVuZG9iagoxMDM1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxODQuOTEyNSA1NDEuNzI1IDE4NC45MTI1IDU1Ni44NzVdCj4+CmVuZG9iagoxMDM2IDAgb2JqCjw8Ci9NQ0lEIDE2Cj4+CmVuZG9iagoxMDM3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxODQuOTEyNSA1NDEuNzI1IDE4NC45MTI1IDU1Ni44NzVdCj4+CmVuZG9iagoxMDM4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDUxMS40MjUgMjE2LjExMjUgNTI2LjU3NV0KPj4KZW5kb2JqCjEwMzkgMCBvYmoKPDwKL01DSUQgMTcKPj4KZW5kb2JqCjEwNDAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTExLjQyNSAyMTYuMTEyNSA1MjYuNTc1XQo+PgplbmRvYmoKMTA0MSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1MTEuNDI1IDk2LjAgNTI2LjU3NV0KPj4KZW5kb2JqCjEwNDIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTExLjQyNSA5Ni4wIDUyNi41NzVdCj4+CmVuZG9iagoxMDQzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDUxMS40MjUgOTYuMCA1MjYuNTc1XQo+PgplbmRvYmoKMTA0NCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1MTEuNDI1IDk2LjAgNTI2LjU3NV0KPj4KZW5kb2JqCjEwNDUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTExLjQyNSA5Ni4wIDUyNi41NzVdCj4+CmVuZG9iagoxMDQ2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDUxMS40MjUgOTYuMCA1MjYuNTc1XQo+PgplbmRvYmoKMTA0NyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMjE2LjExMjUgNTExLjQyNSAyMTYuMTEyNSA1MjYuNTc1XQo+PgplbmRvYmoKMTA0OCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMjE2LjExMjUgNTExLjQyNSAyMTYuMTEyNSA1MjYuNTc1XQo+PgplbmRvYmoKMTA0OSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMjE2LjExMjUgNTExLjQyNSAyMTYuMTEyNSA1MjYuNTc1XQo+PgplbmRvYmoKMTA1MCAwIG9iago8PAovTUNJRCAxOAo+PgplbmRvYmoKMTA1MSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMjE2LjExMjUgNTExLjQyNSAyMTYuMTEyNSA1MjYuNTc1XQo+PgplbmRvYmoKMTA1MiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0ODEuMTI1IDEzMy4xNjI1IDQ5Ni4yNzVdCj4+CmVuZG9iagoxMDUzIDAgb2JqCjw8Ci9NQ0lEIDE5Cj4+CmVuZG9iagoxMDU0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQ4MS4xMjUgMTMzLjE2MjUgNDk2LjI3NV0KPj4KZW5kb2JqCjEwNTUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDgxLjEyNSA5Ni4wIDQ5Ni4yNzVdCj4+CmVuZG9iagoxMDU2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQ4MS4xMjUgOTYuMCA0OTYuMjc1XQo+PgplbmRvYmoKMTA1NyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0ODEuMTI1IDk2LjAgNDk2LjI3NV0KPj4KZW5kb2JqCjEwNTggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDgxLjEyNSA5Ni4wIDQ5Ni4yNzVdCj4+CmVuZG9iagoxMDU5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQ4MS4xMjUgOTYuMCA0OTYuMjc1XQo+PgplbmRvYmoKMTA2MCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0ODEuMTI1IDk2LjAgNDk2LjI3NV0KPj4KZW5kb2JqCjEwNjEgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzEzMy4xNjI1IDQ4MS4xMjUgMTMzLjE2MjUgNDk2LjI3NV0KPj4KZW5kb2JqCjEwNjIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzEzMy4xNjI1IDQ4MS4xMjUgMTMzLjE2MjUgNDk2LjI3NV0KPj4KZW5kb2JqCjEwNjMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzEzMy4xNjI1IDQ4MS4xMjUgMTMzLjE2MjUgNDk2LjI3NV0KPj4KZW5kb2JqCjEwNjQgMCBvYmoKPDwKL01DSUQgMjAKPj4KZW5kb2JqCjEwNjUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzEzMy4xNjI1IDQ4MS4xMjUgMTMzLjE2MjUgNDk2LjI3NV0KPj4KZW5kb2JqCjEwNjYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDY1Ljk3NSAxMTIuNzI1IDQ4MS4xMjVdCj4+CmVuZG9iagoxMDY3IDAgb2JqCjw8Ci9NQ0lEIDIxCj4+CmVuZG9iagoxMDY4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQ2NS45NzUgMTEyLjcyNSA0ODEuMTI1XQo+PgplbmRvYmoKMTA2OSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0NjUuOTc1IDk2LjAgNDgxLjEyNV0KPj4KZW5kb2JqCjEwNzAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDY1Ljk3NSA5Ni4wIDQ4MS4xMjVdCj4+CmVuZG9iagoxMDcxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQ2NS45NzUgOTYuMCA0ODEuMTI1XQo+PgplbmRvYmoKMTA3MiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0NjUuOTc1IDk2LjAgNDgxLjEyNV0KPj4KZW5kb2JqCjEwNzMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDY1Ljk3NSA5Ni4wIDQ4MS4xMjVdCj4+CmVuZG9iagoxMDc0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQ2NS45NzUgOTYuMCA0ODEuMTI1XQo+PgplbmRvYmoKMTA3NSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTEyLjcyNTAwNiA0NjUuOTc1IDExMi43MjUwMDYgNDgxLjEyNV0KPj4KZW5kb2JqCjEwNzYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzExMi43MjUwMDYgNDY1Ljk3NSAxMTIuNzI1MDA2IDQ4MS4xMjVdCj4+CmVuZG9iagoxMDc3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMTIuNzI1MDA2IDQ2NS45NzUgMTEyLjcyNTAwNiA0ODEuMTI1XQo+PgplbmRvYmoKMTA3OCAwIG9iago8PAovTUNJRCAyMgo+PgplbmRvYmoKMTA3OSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTEyLjcyNTAwNiA0NjUuOTc1IDExMi43MjUwMDYgNDgxLjEyNV0KPj4KZW5kb2JqCjEwODAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDMyLjgyNDk4IDI4Ny41ODc1MiA0NDcuOTc0OThdCj4+CmVuZG9iagoxMDgxIDAgb2JqCjw8Ci9NQ0lEIDIzCj4+CmVuZG9iagoxMDgyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQzMi44MjQ5OCAyODcuNTg3NTIgNDQ3Ljk3NDk4XQo+PgplbmRvYmoKMTA4MyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0MTcuNjc1IDExMi43NjI1IDQzMi44MjQ5OF0KPj4KZW5kb2JqCjEwODQgMCBvYmoKPDwKL01DSUQgMjQKPj4KZW5kb2JqCjEwODUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDE3LjY3NSAxMTIuNzYyNSA0MzIuODI0OThdCj4+CmVuZG9iagoxMDg2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMTIuNzYyNTA1IDQxNy42NzUgMTEyLjc2MjUwNSA0MzIuODI0OThdCj4+CmVuZG9iagoxMDg3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMTIuNzYyNTA1IDQxNy42NzUgMTEyLjc2MjUwNSA0MzIuODI0OThdCj4+CmVuZG9iagoxMDg4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMTIuNzYyNTA1IDQxNy42NzUgMTEyLjc2MjUwNSA0MzIuODI0OThdCj4+CmVuZG9iagoxMDg5IDAgb2JqCjw8Ci9NQ0lEIDI1Cj4+CmVuZG9iagoxMDkwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMTIuNzYyNTA1IDQxNy42NzUgMTEyLjc2MjUwNSA0MzIuODI0OThdCj4+CmVuZG9iagoxMDkxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDM4Ny4zNzUgMjI4LjAzNzUgNDAyLjUyNV0KPj4KZW5kb2JqCjEwOTIgMCBvYmoKPDwKL01DSUQgMjYKPj4KZW5kb2JqCjEwOTMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzg3LjM3NSAyMjguMDM3NSA0MDIuNTI1XQo+PgplbmRvYmoKMTA5NCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzODcuMzc1IDk2LjAgNDAyLjUyNV0KPj4KZW5kb2JqCjEwOTUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzg3LjM3NSA5Ni4wIDQwMi41MjVdCj4+CmVuZG9iagoxMDk2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDM4Ny4zNzUgOTYuMCA0MDIuNTI1XQo+PgplbmRvYmoKMTA5NyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzODcuMzc1IDk2LjAgNDAyLjUyNV0KPj4KZW5kb2JqCjEwOTggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzg3LjM3NSA5Ni4wIDQwMi41MjVdCj4+CmVuZG9iagoxMDk5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDM4Ny4zNzUgOTYuMCA0MDIuNTI1XQo+PgplbmRvYmoKMTEwMCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzNTQuMjI0OTggMjgwLjk1IDM2OS4zNzQ5N10KPj4KZW5kb2JqCjExMDEgMCBvYmoKPDwKL01DSUQgMjcKPj4KZW5kb2JqCjExMDIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzU0LjIyNDk4IDI4MC45NSAzNjkuMzc0OTddCj4+CmVuZG9iagoxMTAzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDMzOS4wNzQ5OCAxMTQuNiAzNTQuMjI0OThdCj4+CmVuZG9iagoxMTA0IDAgb2JqCjw8Ci9NQ0lEIDI4Cj4+CmVuZG9iagoxMTA1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDMzOS4wNzQ5OCAxMTQuNiAzNTQuMjI0OThdCj4+CmVuZG9iagoxMTA2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDMwNS45MjUgMjgwLjk1IDMyMS4wNzQ5OF0KPj4KZW5kb2JqCjExMDcgMCBvYmoKPDwKL01DSUQgMjkKPj4KZW5kb2JqCjExMDggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzA1LjkyNSAyODAuOTUgMzIxLjA3NDk4XQo+PgplbmRvYmoKMTEwOSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyOTAuNzc0OTYgMTE4LjA1IDMwNS45MjQ5Nl0KPj4KZW5kb2JqCjExMTAgMCBvYmoKPDwKL01DSUQgMzAKPj4KZW5kb2JqCjExMTEgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjkwLjc3NDk2IDExOC4wNSAzMDUuOTI0OTZdCj4+CmVuZG9iagoxMTEyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI1Ny42MjUgMjgwLjk1IDI3Mi43NzVdCj4+CmVuZG9iagoxMTEzIDAgb2JqCjw8Ci9NQ0lEIDMxCj4+CmVuZG9iagoxMTE0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI1Ny42MjUgMjgwLjk1IDI3Mi43NzVdCj4+CmVuZG9iagoxMTE1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI0Mi40NzQ5OCAxMTIuNzYyNSAyNTcuNjI0OTddCj4+CmVuZG9iagoxMTE2IDAgb2JqCjw8Ci9NQ0lEIDMyCj4+CmVuZG9iagoxMTE3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI0Mi40NzQ5OCAxMTIuNzYyNSAyNTcuNjI0OTddCj4+CmVuZG9iagoxMTE4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDIwOS4zMjUwMSAyODAuOTUgMjI0LjQ3NV0KPj4KZW5kb2JqCjExMTkgMCBvYmoKPDwKL01DSUQgMzMKPj4KZW5kb2JqCjExMjAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjA5LjMyNTAxIDI4MC45NSAyMjQuNDc1XQo+PgplbmRvYmoKMTEyMSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxOTQuMTc0OTkgMTQxLjkgMjA5LjMyNDk4XQo+PgplbmRvYmoKMTEyMiAwIG9iago8PAovTUNJRCAzNAo+PgplbmRvYmoKMTEyMyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxOTQuMTc0OTkgMTQxLjkgMjA5LjMyNDk4XQo+PgplbmRvYmoKMTEyNCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxNjEuMDI0OTYgMjgwLjk1IDE3Ni4xNzQ5Nl0KPj4KZW5kb2JqCjExMjUgMCBvYmoKPDwKL01DSUQgMzUKPj4KZW5kb2JqCjExMjYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMTYxLjAyNDk2IDI4MC45NSAxNzYuMTc0OTZdCj4+CmVuZG9iagoxMTI3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDE0NS44NzUgMTMxLjg1IDE2MS4wMjVdCj4+CmVuZG9iagoxMTI4IDAgb2JqCjw8Ci9NQ0lEIDM2Cj4+CmVuZG9iagoxMTI5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDE0NS44NzUgMTMxLjg1IDE2MS4wMjVdCj4+CmVuZG9iagoxMTMwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDExMi43MjQ5NzYgMjg3LjU4NzUyIDEyNy44NzQ5OF0KPj4KZW5kb2JqCjExMzEgMCBvYmoKPDwKL01DSUQgMzcKPj4KZW5kb2JqCjExMzIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMTEyLjcyNDk3NiAyODcuNTg3NTIgMTI3Ljg3NDk4XQo+PgplbmRvYmoKMTEzMyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA5Ny41NzUwMSAxMTIuNzYyNSAxMTIuNzI1MDFdCj4+CmVuZG9iagoxMTM0IDAgb2JqCjw8Ci9NQ0lEIDM4Cj4+CmVuZG9iagoxMTM1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDk3LjU3NTAxIDExMi43NjI1IDExMi43MjUwMV0KPj4KZW5kb2JqCjExMzYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzExMi43NjI1MDUgOTcuNTc1MDEgMTEyLjc2MjUwNSAxMTIuNzI1MDFdCj4+CmVuZG9iagoxMTM3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMTIuNzYyNTA1IDk3LjU3NTAxIDExMi43NjI1MDUgMTEyLjcyNTAxXQo+PgplbmRvYmoKMTEzOCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTEyLjc2MjUwNSA5Ny41NzUwMSAxMTIuNzYyNTA1IDExMi43MjUwMV0KPj4KZW5kb2JqCjExMzkgMCBvYmoKPDwKL01DSUQgMzkKPj4KZW5kb2JqCjExNDAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzExMi43NjI1MDUgOTcuNTc1MDEgMTEyLjc2MjUwNSAxMTIuNzI1MDFdCj4+CmVuZG9iagoxMTQxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDY3LjI3NDk2IDIyOC4wMzc1IDgyLjQyNDk2NV0KPj4KZW5kb2JqCjExNDIgMCBvYmoKPDwKL01DSUQgNDAKPj4KZW5kb2JqCjExNDMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjcuMjc0OTYgMjI4LjAzNzUgODIuNDI0OTY1XQo+PgplbmRvYmoKMTE0NCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2Ny4yNzQ5NiA5Ni4wIDgyLjQyNDk2NV0KPj4KZW5kb2JqCjExNDUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjcuMjc0OTYgOTYuMCA4Mi40MjQ5NjVdCj4+CmVuZG9iagoxMTQ2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDY3LjI3NDk2IDk2LjAgODIuNDI0OTY1XQo+PgplbmRvYmoKMTE0NyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2Ny4yNzQ5NiA5Ni4wIDgyLjQyNDk2NV0KPj4KZW5kb2JqCjExNDggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjcuMjc0OTYgOTYuMCA4Mi40MjQ5NjVdCj4+CmVuZG9iagoxMTQ5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDY3LjI3NDk2IDk2LjAgODIuNDI0OTY1XQo+PgplbmRvYmoKMTE1MCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbNzEuMjUgNTcuNzUgNTI0LjAyNSA3ODQuMTI1XQo+PgplbmRvYmoKMTE1MSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbNzEuMjUgNTcuNzUgNTI0LjAyNSA3ODQuMTI1XQo+PgplbmRvYmoKMTE1MiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbNzcuMjUgNTcuNzUgNTE4LjAyNSA3ODQuMTI1XQo+PgplbmRvYmoKMTE1MyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbNzcuMjUgNTcuNzUgNTE4LjAyNSA3ODQuMTI1XQo+PgplbmRvYmoKMTE1NCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1Ny43NSA0OTkuMjc1MDIgNzg0LjEyNV0KPj4KZW5kb2JqCjExNTUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTcuNzUgNDk5LjI3NTAyIDc4NC4xMjVdCj4+CmVuZG9iagoxMTU2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDcxNS4wNSA0OTkuMjc1MDIgNzc1LjY0OTk2XQo+PgplbmRvYmoKMTE1NyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3NjAuNSA0OTkuMjc1MDIgNzc1LjY1XQo+PgplbmRvYmoKMTE1OCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3MTUuMDUgNDk5LjI3NTAyIDc2MC41XQo+PgplbmRvYmoKMTE1OSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2MzYuNDUgNDk5LjI3NTAyIDY5Ny4wNV0KPj4KZW5kb2JqCjExNjAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjgxLjkgNDk5LjI3NTAyIDY5Ny4wNTAwNV0KPj4KZW5kb2JqCjExNjEgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjM2LjQ1IDQ5OS4yNzUwMiA2ODEuOV0KPj4KZW5kb2JqCjExNjIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTU3Ljg1IDQ5OS4yNzUwMiA2MTguNDQ5OTVdCj4+CmVuZG9iagoxMTYzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDYwMy4zIDQ5OS4yNzUwMiA2MTguNDVdCj4+CmVuZG9iagoxMTY0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU1Ny44NSA0OTkuMjc1MDIgNjAzLjNdCj4+CmVuZG9iagoxMTY1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDUwOS41NSA0OTkuMjc1MDIgNTM5Ljg1XQo+PgplbmRvYmoKMTE2NiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1MjQuNjk5OTUgNDk5LjI3NTAyIDUzOS44NV0KPj4KZW5kb2JqCjExNjcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTA5LjU1IDQ5OS4yNzUwMiA1MjQuN10KPj4KZW5kb2JqCjExNjggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDc2LjQgNDk5LjI3NTAyIDQ5MS41NV0KPj4KZW5kb2JqCjExNjkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDc2LjQgNDk5LjI3NTAyIDQ5MS41NV0KPj4KZW5kb2JqCjExNzAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDI4LjA5OTk4IDQ5OS4yNzUwMiA0NTguMzk5OTZdCj4+CmVuZG9iagoxMTcxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQ0My4yNSA0OTkuMjc1MDIgNDU4LjRdCj4+CmVuZG9iagoxMTcyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQyOC4wOTk5OCA0OTkuMjc1MDIgNDQzLjI0OTk3XQo+PgplbmRvYmoKMTE3MyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzNDkuNSA0OTkuMjc1MDIgNDEwLjFdCj4+CmVuZG9iagoxMTc0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDM5NC45NDk5OCA0OTkuMjc1MDIgNDEwLjA5OTk4XQo+PgplbmRvYmoKMTE3NSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzNDkuNSA0OTkuMjc1MDIgMzk0Ljk1XQo+PgplbmRvYmoKMTE3NiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyNzAuODk5OTYgNDk5LjI3NTAyIDMzMS40OTk5N10KPj4KZW5kb2JqCjExNzcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzE2LjM0OTk4IDQ5OS4yNzUwMiAzMzEuNDk5OTddCj4+CmVuZG9iagoxMTc4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI3MC44OTk5NiA0OTkuMjc1MDIgMzE2LjM0OTk4XQo+PgplbmRvYmoKMTE3OSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxNzcuMTQ5OTYgNDk5LjI3NTAyIDI1Mi44OTk5Nl0KPj4KZW5kb2JqCjExODAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjM3Ljc1IDQ5OS4yNzUwMiAyNTIuOV0KPj4KZW5kb2JqCjExODEgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMTc3LjE0OTk2IDQ5OS4yNzUwMiAyMzcuNzQ5OTddCj4+CmVuZG9iagoxMTgyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDk4LjU0OTk5IDQ5OS4yNzUwMiAxNTkuMTVdCj4+CmVuZG9iagoxMTgzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDE0NC4wIDQ5OS4yNzUwMiAxNTkuMTVdCj4+CmVuZG9iagoxMTg0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDk4LjU0OTk5IDQ5OS4yNzUwMiAxNDMuOTk5OThdCj4+CmVuZG9iagoxMTg1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU3Ljc1IDQ5OS4yNzUwMiA4MC41NV0KPj4KZW5kb2JqCjExODYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjUuMzk5OTYgNDk5LjI3NTAyIDgwLjU0OTk2NV0KPj4KZW5kb2JqCjExODcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTcuNzUgNDk5LjI3NTAyIDY1LjRdCj4+CmVuZG9iagoxMTg4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDc2MC41IDI4Ny41ODc1MiA3NzUuNjVdCj4+CmVuZG9iagoxMTg5IDAgb2JqCjw8Ci9NQ0lEIDAKPj4KZW5kb2JqCjExOTAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzYwLjUgMjg3LjU4NzUyIDc3NS42NV0KPj4KZW5kb2JqCjExOTEgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzQ1LjM1IDExMi43NjI1IDc2MC41XQo+PgplbmRvYmoKMTE5MiAwIG9iago8PAovTUNJRCAxCj4+CmVuZG9iagoxMTkzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDc0NS4zNSAxMTIuNzYyNSA3NjAuNV0KPj4KZW5kb2JqCjExOTQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzExMi43NjI1MDUgNzQ1LjM1IDExMi43NjI1MDUgNzYwLjVdCj4+CmVuZG9iagoxMTk1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMTIuNzYyNTA1IDc0NS4zNSAxMTIuNzYyNTA1IDc2MC41XQo+PgplbmRvYmoKMTE5NiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTEyLjc2MjUwNSA3NDUuMzUgMTEyLjc2MjUwNSA3NjAuNV0KPj4KZW5kb2JqCjExOTcgMCBvYmoKPDwKL01DSUQgMgo+PgplbmRvYmoKMTE5OCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTEyLjc2MjUwNSA3NDUuMzUgMTEyLjc2MjUwNSA3NjAuNV0KPj4KZW5kb2JqCjExOTkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzE1LjA1IDIyOC4wMzc1IDczMC4yXQo+PgplbmRvYmoKMTIwMCAwIG9iago8PAovTUNJRCAzCj4+CmVuZG9iagoxMjAxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDcxNS4wNSAyMjguMDM3NSA3MzAuMl0KPj4KZW5kb2JqCjEyMDIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzE1LjA1IDk2LjAgNzMwLjJdCj4+CmVuZG9iagoxMjAzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDcxNS4wNSA5Ni4wIDczMC4yXQo+PgplbmRvYmoKMTIwNCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3MTUuMDUgOTYuMCA3MzAuMl0KPj4KZW5kb2JqCjEyMDUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzE1LjA1IDk2LjAgNzMwLjJdCj4+CmVuZG9iagoxMjA2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDcxNS4wNSA5Ni4wIDczMC4yXQo+PgplbmRvYmoKMTIwNyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3MTUuMDUgOTYuMCA3MzAuMl0KPj4KZW5kb2JqCjEyMDggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjgxLjkgMjg3LjU4NzUyIDY5Ny4wNTAwNV0KPj4KZW5kb2JqCjEyMDkgMCBvYmoKPDwKL01DSUQgNAo+PgplbmRvYmoKMTIxMCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2ODEuOSAyODcuNTg3NTIgNjk3LjA1MDA1XQo+PgplbmRvYmoKMTIxMSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2NjYuNzUgMTUxLjk4NzUgNjgxLjldCj4+CmVuZG9iagoxMjEyIDAgb2JqCjw8Ci9NQ0lEIDUKPj4KZW5kb2JqCjEyMTMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjY2Ljc1IDE1MS45ODc1IDY4MS45XQo+PgplbmRvYmoKMTIxNCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTUxLjk4NzUgNjY2Ljc1IDE1MS45ODc1IDY4MS45XQo+PgplbmRvYmoKMTIxNSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTUxLjk4NzUgNjY2Ljc1IDE1MS45ODc1IDY4MS45XQo+PgplbmRvYmoKMTIxNiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTUxLjk4NzUgNjY2Ljc1IDE1MS45ODc1IDY4MS45XQo+PgplbmRvYmoKMTIxNyAwIG9iago8PAovTUNJRCA2Cj4+CmVuZG9iagoxMjE4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxNTEuOTg3NSA2NjYuNzUgMTUxLjk4NzUgNjgxLjldCj4+CmVuZG9iagoxMjE5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDYzNi40NSAyMjguMDM3NSA2NTEuNjAwMDRdCj4+CmVuZG9iagoxMjIwIDAgb2JqCjw8Ci9NQ0lEIDcKPj4KZW5kb2JqCjEyMjEgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjM2LjQ1IDIyOC4wMzc1IDY1MS42MDAwNF0KPj4KZW5kb2JqCjEyMjIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjM2LjQ1IDk2LjAgNjUxLjYwMDA0XQo+PgplbmRvYmoKMTIyMyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2MzYuNDUgOTYuMCA2NTEuNjAwMDRdCj4+CmVuZG9iagoxMjI0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDYzNi40NSA5Ni4wIDY1MS42MDAwNF0KPj4KZW5kb2JqCjEyMjUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjM2LjQ1IDk2LjAgNjUxLjYwMDA0XQo+PgplbmRvYmoKMTIyNiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2MzYuNDUgOTYuMCA2NTEuNjAwMDRdCj4+CmVuZG9iagoxMjI3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDYzNi40NSA5Ni4wIDY1MS42MDAwNF0KPj4KZW5kb2JqCjEyMjggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjAzLjMgMjg3LjU4NzUyIDYxOC40NV0KPj4KZW5kb2JqCjEyMjkgMCBvYmoKPDwKL01DSUQgOAo+PgplbmRvYmoKMTIzMCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2MDMuMyAyODcuNTg3NTIgNjE4LjQ1XQo+PgplbmRvYmoKMTIzMSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1ODguMTUgMTIwLjcxMjUgNjAzLjMwMDA1XQo+PgplbmRvYmoKMTIzMiAwIG9iago8PAovTUNJRCA5Cj4+CmVuZG9iagoxMjMzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU4OC4xNSAxMjAuNzEyNSA2MDMuMzAwMDVdCj4+CmVuZG9iagoxMjM0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMjAuNzEyNSA1ODguMTUgMTIwLjcxMjUgNjAzLjMwMDA1XQo+PgplbmRvYmoKMTIzNSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTIwLjcxMjUgNTg4LjE1IDEyMC43MTI1IDYwMy4zMDAwNV0KPj4KZW5kb2JqCjEyMzYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzEyMC43MTI1IDU4OC4xNSAxMjAuNzEyNSA2MDMuMzAwMDVdCj4+CmVuZG9iagoxMjM3IDAgb2JqCjw8Ci9NQ0lEIDEwCj4+CmVuZG9iagoxMjM4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMjAuNzEyNSA1ODguMTUgMTIwLjcxMjUgNjAzLjMwMDA1XQo+PgplbmRvYmoKMTIzOSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1NTcuODUgMjI4LjAzNzUgNTczLjBdCj4+CmVuZG9iagoxMjQwIDAgb2JqCjw8Ci9NQ0lEIDExCj4+CmVuZG9iagoxMjQxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU1Ny44NSAyMjguMDM3NSA1NzMuMF0KPj4KZW5kb2JqCjEyNDIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTU3Ljg1IDk2LjAgNTczLjBdCj4+CmVuZG9iagoxMjQzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU1Ny44NSA5Ni4wIDU3My4wXQo+PgplbmRvYmoKMTI0NCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1NTcuODUgOTYuMCA1NzMuMF0KPj4KZW5kb2JqCjEyNDUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTU3Ljg1IDk2LjAgNTczLjBdCj4+CmVuZG9iagoxMjQ2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU1Ny44NSA5Ni4wIDU3My4wXQo+PgplbmRvYmoKMTI0NyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1NTcuODUgOTYuMCA1NzMuMF0KPj4KZW5kb2JqCjEyNDggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTI0LjY5OTk1IDI2Mi45NSA1MzkuODVdCj4+CmVuZG9iagoxMjQ5IDAgb2JqCjw8Ci9NQ0lEIDEyCj4+CmVuZG9iagoxMjUwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDUyNC42OTk5NSAyNjIuOTUgNTM5Ljg1XQo+PgplbmRvYmoKMTI1MSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1MDkuNTUgMjk0LjM3NSA1MjQuN10KPj4KZW5kb2JqCjEyNTIgMCBvYmoKPDwKL01DSUQgMTMKPj4KZW5kb2JqCjEyNTMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTA5LjU1IDI5NC4zNzUgNTI0LjddCj4+CmVuZG9iagoxMjU0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQ3Ni40IDI2Mi45NSA0OTEuNTVdCj4+CmVuZG9iagoxMjU1IDAgb2JqCjw8Ci9NQ0lEIDE0Cj4+CmVuZG9iagoxMjU2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQ3Ni40IDI2Mi45NSA0OTEuNTVdCj4+CmVuZG9iagoxMjU3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQ0My4yNSAyODcuNTg3NTIgNDU4LjRdCj4+CmVuZG9iagoxMjU4IDAgb2JqCjw8Ci9NQ0lEIDE1Cj4+CmVuZG9iagoxMjU5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQ0My4yNSAyODcuNTg3NTIgNDU4LjRdCj4+CmVuZG9iagoxMjYwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQyOC4wOTk5OCAxMTIuNzYyNSA0NDMuMjQ5OTddCj4+CmVuZG9iagoxMjYxIDAgb2JqCjw8Ci9NQ0lEIDE2Cj4+CmVuZG9iagoxMjYyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQyOC4wOTk5OCAxMTIuNzYyNSA0NDMuMjQ5OTddCj4+CmVuZG9iagoxMjYzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMTIuNzYyNTA1IDQyOC4wOTk5OCAxMTIuNzYyNTA1IDQ0My4yNDk5N10KPj4KZW5kb2JqCjEyNjQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzExMi43NjI1MDUgNDI4LjA5OTk4IDExMi43NjI1MDUgNDQzLjI0OTk3XQo+PgplbmRvYmoKMTI2NSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTEyLjc2MjUwNSA0MjguMDk5OTggMTEyLjc2MjUwNSA0NDMuMjQ5OTddCj4+CmVuZG9iagoxMjY2IDAgb2JqCjw8Ci9NQ0lEIDE3Cj4+CmVuZG9iagoxMjY3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMTIuNzYyNTA1IDQyOC4wOTk5OCAxMTIuNzYyNTA1IDQ0My4yNDk5N10KPj4KZW5kb2JqCjEyNjggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzk0Ljk0OTk4IDI4Ny41ODc1MiA0MTAuMDk5OThdCj4+CmVuZG9iagoxMjY5IDAgb2JqCjw8Ci9NQ0lEIDE4Cj4+CmVuZG9iagoxMjcwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDM5NC45NDk5OCAyODcuNTg3NTIgNDEwLjA5OTk4XQo+PgplbmRvYmoKMTI3MSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzNzkuOCAxMTIuNzYyNSAzOTQuOTQ5OThdCj4+CmVuZG9iagoxMjcyIDAgb2JqCjw8Ci9NQ0lEIDE5Cj4+CmVuZG9iagoxMjczIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDM3OS44IDExMi43NjI1IDM5NC45NDk5OF0KPj4KZW5kb2JqCjEyNzQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzExMi43NjI1MDUgMzc5LjggMTEyLjc2MjUwNSAzOTQuOTQ5OThdCj4+CmVuZG9iagoxMjc1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMTIuNzYyNTA1IDM3OS44IDExMi43NjI1MDUgMzk0Ljk0OTk4XQo+PgplbmRvYmoKMTI3NiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTEyLjc2MjUwNSAzNzkuOCAxMTIuNzYyNTA1IDM5NC45NDk5OF0KPj4KZW5kb2JqCjEyNzcgMCBvYmoKPDwKL01DSUQgMjAKPj4KZW5kb2JqCjEyNzggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzExMi43NjI1MDUgMzc5LjggMTEyLjc2MjUwNSAzOTQuOTQ5OThdCj4+CmVuZG9iagoxMjc5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDM0OS41IDIyOC4wMzc1IDM2NC42NV0KPj4KZW5kb2JqCjEyODAgMCBvYmoKPDwKL01DSUQgMjEKPj4KZW5kb2JqCjEyODEgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzQ5LjUgMjI4LjAzNzUgMzY0LjY1XQo+PgplbmRvYmoKMTI4MiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzNDkuNSA5Ni4wIDM2NC42NV0KPj4KZW5kb2JqCjEyODMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzQ5LjUgOTYuMCAzNjQuNjVdCj4+CmVuZG9iagoxMjg0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDM0OS41IDk2LjAgMzY0LjY1XQo+PgplbmRvYmoKMTI4NSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzNDkuNSA5Ni4wIDM2NC42NV0KPj4KZW5kb2JqCjEyODYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzQ5LjUgOTYuMCAzNjQuNjVdCj4+CmVuZG9iagoxMjg3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDM0OS41IDk2LjAgMzY0LjY1XQo+PgplbmRvYmoKMTI4OCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzMTYuMzQ5OTggMjg3LjU4NzUyIDMzMS40OTk5N10KPj4KZW5kb2JqCjEyODkgMCBvYmoKPDwKL01DSUQgMjIKPj4KZW5kb2JqCjEyOTAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzE2LjM0OTk4IDI4Ny41ODc1MiAzMzEuNDk5OTddCj4+CmVuZG9iagoxMjkxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDMwMS4yIDEyNC4xNjI1IDMxNi4zNV0KPj4KZW5kb2JqCjEyOTIgMCBvYmoKPDwKL01DSUQgMjMKPj4KZW5kb2JqCjEyOTMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzAxLjIgMTI0LjE2MjUgMzE2LjM1XQo+PgplbmRvYmoKMTI5NCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTI0LjE2MjUwNiAzMDEuMiAxMjQuMTYyNTA2IDMxNi4zNV0KPj4KZW5kb2JqCjEyOTUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzEyNC4xNjI1MDYgMzAxLjIgMTI0LjE2MjUwNiAzMTYuMzVdCj4+CmVuZG9iagoxMjk2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMjQuMTYyNTA2IDMwMS4yIDEyNC4xNjI1MDYgMzE2LjM1XQo+PgplbmRvYmoKMTI5NyAwIG9iago8PAovTUNJRCAyNAo+PgplbmRvYmoKMTI5OCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTI0LjE2MjUwNiAzMDEuMiAxMjQuMTYyNTA2IDMxNi4zNV0KPj4KZW5kb2JqCjEyOTkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjcwLjg5OTk2IDIyOC4wMzc1IDI4Ni4wNDk5Nl0KPj4KZW5kb2JqCjEzMDAgMCBvYmoKPDwKL01DSUQgMjUKPj4KZW5kb2JqCjEzMDEgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjcwLjg5OTk2IDIyOC4wMzc1IDI4Ni4wNDk5Nl0KPj4KZW5kb2JqCjEzMDIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjcwLjg5OTk2IDk2LjAgMjg2LjA0OTk2XQo+PgplbmRvYmoKMTMwMyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyNzAuODk5OTYgOTYuMCAyODYuMDQ5OTZdCj4+CmVuZG9iagoxMzA0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI3MC44OTk5NiA5Ni4wIDI4Ni4wNDk5Nl0KPj4KZW5kb2JqCjEzMDUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjcwLjg5OTk2IDk2LjAgMjg2LjA0OTk2XQo+PgplbmRvYmoKMTMwNiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyNzAuODk5OTYgOTYuMCAyODYuMDQ5OTZdCj4+CmVuZG9iagoxMzA3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI3MC44OTk5NiA5Ni4wIDI4Ni4wNDk5Nl0KPj4KZW5kb2JqCjEzMDggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjM3Ljc1IDI4Ny41ODc1MiAyNTIuOV0KPj4KZW5kb2JqCjEzMDkgMCBvYmoKPDwKL01DSUQgMjYKPj4KZW5kb2JqCjEzMTAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjM3Ljc1IDI4Ny41ODc1MiAyNTIuOV0KPj4KZW5kb2JqCjEzMTEgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjIyLjU5OTk4IDE2NC4wMjUgMjM3Ljc0OTk3XQo+PgplbmRvYmoKMTMxMiAwIG9iago8PAovTUNJRCAyNwo+PgplbmRvYmoKMTMxMyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyMjIuNTk5OTggMTY0LjAyNSAyMzcuNzQ5OTddCj4+CmVuZG9iagoxMzE0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxNjQuMDI1MDEgMjIyLjU5OTk4IDE2NC4wMjUwMSAyMzcuNzQ5OTddCj4+CmVuZG9iagoxMzE1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxNjQuMDI1MDEgMjIyLjU5OTk4IDE2NC4wMjUwMSAyMzcuNzQ5OTddCj4+CmVuZG9iagoxMzE2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxNjQuMDI1MDEgMjIyLjU5OTk4IDE2NC4wMjUwMSAyMzcuNzQ5OTddCj4+CmVuZG9iagoxMzE3IDAgb2JqCjw8Ci9NQ0lEIDI4Cj4+CmVuZG9iagoxMzE4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxNjQuMDI1MDEgMjIyLjU5OTk4IDE2NC4wMjUwMSAyMzcuNzQ5OTddCj4+CmVuZG9iagoxMzE5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDE3Ny4xNDk5NiAyMjguMDM3NSAxOTIuMjk5OTZdCj4+CmVuZG9iagoxMzIwIDAgb2JqCjw8Ci9NQ0lEIDI5Cj4+CmVuZG9iagoxMzIxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDE3Ny4xNDk5NiAyMjguMDM3NSAxOTIuMjk5OTZdCj4+CmVuZG9iagoxMzIyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDE3Ny4xNDk5NiA5Ni4wIDE5Mi4yOTk5Nl0KPj4KZW5kb2JqCjEzMjMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMTc3LjE0OTk2IDk2LjAgMTkyLjI5OTk2XQo+PgplbmRvYmoKMTMyNCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxNzcuMTQ5OTYgOTYuMCAxOTIuMjk5OTZdCj4+CmVuZG9iagoxMzI1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDE3Ny4xNDk5NiA5Ni4wIDE5Mi4yOTk5Nl0KPj4KZW5kb2JqCjEzMjYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMTc3LjE0OTk2IDk2LjAgMTkyLjI5OTk2XQo+PgplbmRvYmoKMTMyNyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxNzcuMTQ5OTYgOTYuMCAxOTIuMjk5OTZdCj4+CmVuZG9iagoxMzI4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDE0NC4wIDI4Ny41ODc1MiAxNTkuMTVdCj4+CmVuZG9iagoxMzI5IDAgb2JqCjw8Ci9NQ0lEIDMwCj4+CmVuZG9iagoxMzMwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDE0NC4wIDI4Ny41ODc1MiAxNTkuMTVdCj4+CmVuZG9iagoxMzMxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDEyOC44NDk5OCAxMTIuNzYyNSAxNDMuOTk5OTddCj4+CmVuZG9iagoxMzMyIDAgb2JqCjw8Ci9NQ0lEIDMxCj4+CmVuZG9iagoxMzMzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDEyOC44NDk5OCAxMTIuNzYyNSAxNDMuOTk5OTddCj4+CmVuZG9iagoxMzM0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMTIuNzYyNTA1IDEyOC44NDk5OCAxMTIuNzYyNTA1IDE0My45OTk5N10KPj4KZW5kb2JqCjEzMzUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzExMi43NjI1MDUgMTI4Ljg0OTk4IDExMi43NjI1MDUgMTQzLjk5OTk3XQo+PgplbmRvYmoKMTMzNiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTEyLjc2MjUwNSAxMjguODQ5OTggMTEyLjc2MjUwNSAxNDMuOTk5OTddCj4+CmVuZG9iagoxMzM3IDAgb2JqCjw8Ci9NQ0lEIDMyCj4+CmVuZG9iagoxMzM4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMTIuNzYyNTA1IDEyOC44NDk5OCAxMTIuNzYyNTA1IDE0My45OTk5N10KPj4KZW5kb2JqCjEzMzkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgOTguNTQ5OTkgMjI4LjAzNzUgMTEzLjY5OTk5XQo+PgplbmRvYmoKMTM0MCAwIG9iago8PAovTUNJRCAzMwo+PgplbmRvYmoKMTM0MSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA5OC41NDk5OSAyMjguMDM3NSAxMTMuNjk5OTldCj4+CmVuZG9iagoxMzQyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDk4LjU0OTk5IDk2LjAgMTEzLjY5OTk5XQo+PgplbmRvYmoKMTM0MyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA5OC41NDk5OSA5Ni4wIDExMy42OTk5OV0KPj4KZW5kb2JqCjEzNDQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgOTguNTQ5OTkgOTYuMCAxMTMuNjk5OTldCj4+CmVuZG9iagoxMzQ1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDk4LjU0OTk5IDk2LjAgMTEzLjY5OTk5XQo+PgplbmRvYmoKMTM0NiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA5OC41NDk5OSA5Ni4wIDExMy42OTk5OV0KPj4KZW5kb2JqCjEzNDcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgOTguNTQ5OTkgOTYuMCAxMTMuNjk5OTldCj4+CmVuZG9iagoxMzQ4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDY1LjM5OTk2IDI4Ny41ODc1MiA4MC41NDk5NjVdCj4+CmVuZG9iagoxMzQ5IDAgb2JqCjw8Ci9NQ0lEIDM0Cj4+CmVuZG9iagoxMzUwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDY1LjM5OTk2IDI4Ny41ODc1MiA4MC41NDk5NjVdCj4+CmVuZG9iagoxMzUxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs3MS4yNSA1Ny43NSA1MjQuMDI1IDc4NC4xMjVdCj4+CmVuZG9iagoxMzUyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs3MS4yNSA1Ny43NSA1MjQuMDI1IDc4NC4xMjVdCj4+CmVuZG9iagoxMzUzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs3Ny4yNSA1Ny43NSA1MTguMDI1IDc4NC4xMjVdCj4+CmVuZG9iagoxMzU0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs3Ny4yNSA1Ny43NSA1MTguMDI1IDc4NC4xMjVdCj4+CmVuZG9iagoxMzU1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU3Ljc1IDQ5OS4yNzUwMiA3ODQuMTI1XQo+PgplbmRvYmoKMTM1NiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1Ny43NSA0OTkuMjc1MDIgNzg0LjEyNV0KPj4KZW5kb2JqCjEzNTcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzM4LjY3NSA0OTkuMjc1MDIgNzg0LjEyNV0KPj4KZW5kb2JqCjEzNTggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzM4LjY3NSA0OTkuMjc1MDIgNzg0LjEyNV0KPj4KZW5kb2JqCjEzNTkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjkwLjM3NSA0OTkuMjc1MDIgNzIwLjY3NV0KPj4KZW5kb2JqCjEzNjAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzA1LjUyNSA0OTkuMjc1MDIgNzIwLjY3NTA1XQo+PgplbmRvYmoKMTM2MSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2OTAuMzc1IDQ5OS4yNzUwMiA3MDUuNTI1XQo+PgplbmRvYmoKMTM2MiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2MTEuNzc1IDQ5OS4yNzUwMiA2NzIuMzc1XQo+PgplbmRvYmoKMTM2MyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2NTcuMjI1IDQ5OS4yNzUwMiA2NzIuMzc1XQo+PgplbmRvYmoKMTM2NCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2MTEuNzc1IDQ5OS4yNzUwMiA2NTcuMjI1MDRdCj4+CmVuZG9iagoxMzY1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDUxOC4wMjUgNDk5LjI3NTAyIDU5My43NzVdCj4+CmVuZG9iagoxMzY2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU3OC42MjUgNDk5LjI3NTAyIDU5My43NzVdCj4+CmVuZG9iagoxMzY3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDUxOC4wMjUgNDk5LjI3NTAyIDU3OC42MjVdCj4+CmVuZG9iagoxMzY4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQ1NC41NzQ5OCA0OTkuMjc1MDIgNTAwLjAyNV0KPj4KZW5kb2JqCjEzNjkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDg0Ljg3NSA0OTkuMjc1MDIgNTAwLjAyNV0KPj4KZW5kb2JqCjEzNzAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDU0LjU3NDk4IDQ5OS4yNzUwMiA0ODQuODc0OTddCj4+CmVuZG9iagoxMzcxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQwNi4yNzUgNDk5LjI3NTAyIDQzNi41NzQ5OF0KPj4KZW5kb2JqCjEzNzIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDIxLjQyNSA0OTkuMjc1MDIgNDM2LjU3NDk4XQo+PgplbmRvYmoKMTM3MyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0MDYuMjc1IDQ5OS4yNzUwMiA0MjEuNDI1XQo+PgplbmRvYmoKMTM3NCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzNTcuOTc0OTggNDk5LjI3NTAyIDM4OC4yNzQ5Nl0KPj4KZW5kb2JqCjEzNzUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzczLjEyNSA0OTkuMjc1MDIgMzg4LjI3NV0KPj4KZW5kb2JqCjEzNzYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzU3Ljk3NDk4IDQ5OS4yNzUwMiAzNzMuMTI0OTddCj4+CmVuZG9iagoxMzc3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI3OS4zNzUgNDk5LjI3NTAyIDMzOS45NzVdCj4+CmVuZG9iagoxMzc4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDMyNC44MjUgNDk5LjI3NTAyIDMzOS45NzVdCj4+CmVuZG9iagoxMzc5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI3OS4zNzUgNDk5LjI3NTAyIDMyNC44MjVdCj4+CmVuZG9iagoxMzgwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDIwMC43NzQ5NiA0OTkuMjc1MDIgMjYxLjM3NDk3XQo+PgplbmRvYmoKMTM4MSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyNDYuMjI0OTggNDk5LjI3NTAyIDI2MS4zNzQ5N10KPj4KZW5kb2JqCjEzODIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjAwLjc3NDk2IDQ5OS4yNzUwMiAyNDYuMjI0OTZdCj4+CmVuZG9iagoxMzgzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDEyMi4xNzQ5OSA0OTkuMjc1MDIgMTgyLjc3NV0KPj4KZW5kb2JqCjEzODQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMTY3LjYyNSA0OTkuMjc1MDIgMTgyLjc3NV0KPj4KZW5kb2JqCjEzODUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMTIyLjE3NDk5IDQ5OS4yNzUwMiAxNjcuNjI0OThdCj4+CmVuZG9iagoxMzg2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU3Ljc1IDQ5OS4yNzUwMiAxMDQuMTc1XQo+PgplbmRvYmoKMTM4NyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA4OS4wMjQ5NiA0OTkuMjc1MDIgMTA0LjE3NDk2NV0KPj4KZW5kb2JqCjEzODggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzY4Ljk3NSAxMjMuMTUgNzg0LjEyNV0KPj4KZW5kb2JqCjEzODkgMCBvYmoKPDwKL01DSUQgMAo+PgplbmRvYmoKMTM5MCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3NjguOTc1IDEyMy4xNSA3ODQuMTI1XQo+PgplbmRvYmoKMTM5MSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTIzLjE1IDc2OC45NzUgMTIzLjE1IDc4NC4xMjVdCj4+CmVuZG9iagoxMzkyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMjMuMTUgNzY4Ljk3NSAxMjMuMTUgNzg0LjEyNV0KPj4KZW5kb2JqCjEzOTMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzEyMy4xNSA3NjguOTc1IDEyMy4xNSA3ODQuMTI1XQo+PgplbmRvYmoKMTM5NCAwIG9iago8PAovTUNJRCAxCj4+CmVuZG9iagoxMzk1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMjMuMTUgNzY4Ljk3NSAxMjMuMTUgNzg0LjEyNV0KPj4KZW5kb2JqCjEzOTYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzM4LjY3NSAyMjguMDM3NSA3NTMuODI1XQo+PgplbmRvYmoKMTM5NyAwIG9iago8PAovTUNJRCAyCj4+CmVuZG9iagoxMzk4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDczOC42NzUgMjI4LjAzNzUgNzUzLjgyNV0KPj4KZW5kb2JqCjEzOTkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzM4LjY3NSA5Ni4wIDc1My44MjVdCj4+CmVuZG9iagoxNDAwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDczOC42NzUgOTYuMCA3NTMuODI1XQo+PgplbmRvYmoKMTQwMSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3MzguNjc1IDk2LjAgNzUzLjgyNV0KPj4KZW5kb2JqCjE0MDIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzM4LjY3NSA5Ni4wIDc1My44MjVdCj4+CmVuZG9iagoxNDAzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDczOC42NzUgOTYuMCA3NTMuODI1XQo+PgplbmRvYmoKMTQwNCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3MzguNjc1IDk2LjAgNzUzLjgyNV0KPj4KZW5kb2JqCjE0MDUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzA1LjUyNSAyODAuOTUgNzIwLjY3NTA1XQo+PgplbmRvYmoKMTQwNiAwIG9iago8PAovTUNJRCAzCj4+CmVuZG9iagoxNDA3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDcwNS41MjUgMjgwLjk1IDcyMC42NzUwNV0KPj4KZW5kb2JqCjE0MDggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjkwLjM3NSAxNzQuNzUgNzA1LjUyNV0KPj4KZW5kb2JqCjE0MDkgMCBvYmoKPDwKL01DSUQgNAo+PgplbmRvYmoKMTQxMCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2OTAuMzc1IDE3NC43NSA3MDUuNTI1XQo+PgplbmRvYmoKMTQxMSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2NTcuMjI1IDI4Ny41ODc1MiA2NzIuMzc1XQo+PgplbmRvYmoKMTQxMiAwIG9iago8PAovTUNJRCA1Cj4+CmVuZG9iagoxNDEzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDY1Ny4yMjUgMjg3LjU4NzUyIDY3Mi4zNzVdCj4+CmVuZG9iagoxNDE0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDY0Mi4wNzUgMTIzLjAgNjU3LjIyNTA0XQo+PgplbmRvYmoKMTQxNSAwIG9iago8PAovTUNJRCA2Cj4+CmVuZG9iagoxNDE2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDY0Mi4wNzUgMTIzLjAgNjU3LjIyNTA0XQo+PgplbmRvYmoKMTQxNyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTIzLjAgNjQyLjA3NSAxMjMuMCA2NTcuMjI1MDRdCj4+CmVuZG9iagoxNDE4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMjMuMCA2NDIuMDc1IDEyMy4wIDY1Ny4yMjUwNF0KPj4KZW5kb2JqCjE0MTkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzEyMy4wIDY0Mi4wNzUgMTIzLjAgNjU3LjIyNTA0XQo+PgplbmRvYmoKMTQyMCAwIG9iago8PAovTUNJRCA3Cj4+CmVuZG9iagoxNDIxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMjMuMCA2NDIuMDc1IDEyMy4wIDY1Ny4yMjUwNF0KPj4KZW5kb2JqCjE0MjIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjExLjc3NSAyMjguMDM3NSA2MjYuOTI1MDVdCj4+CmVuZG9iagoxNDIzIDAgb2JqCjw8Ci9NQ0lEIDgKPj4KZW5kb2JqCjE0MjQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjExLjc3NSAyMjguMDM3NSA2MjYuOTI1MDVdCj4+CmVuZG9iagoxNDI1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDYxMS43NzUgOTYuMCA2MjYuOTI1MDVdCj4+CmVuZG9iagoxNDI2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDYxMS43NzUgOTYuMCA2MjYuOTI1MDVdCj4+CmVuZG9iagoxNDI3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDYxMS43NzUgOTYuMCA2MjYuOTI1MDVdCj4+CmVuZG9iagoxNDI4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDYxMS43NzUgOTYuMCA2MjYuOTI1MDVdCj4+CmVuZG9iagoxNDI5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDYxMS43NzUgOTYuMCA2MjYuOTI1MDVdCj4+CmVuZG9iagoxNDMwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDYxMS43NzUgOTYuMCA2MjYuOTI1MDVdCj4+CmVuZG9iagoxNDMxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU3OC42MjUgMjg3LjU4NzUyIDU5My43NzVdCj4+CmVuZG9iagoxNDMyIDAgb2JqCjw8Ci9NQ0lEIDkKPj4KZW5kb2JqCjE0MzMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTc4LjYyNSAyODcuNTg3NTIgNTkzLjc3NV0KPj4KZW5kb2JqCjE0MzQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTYzLjQ3NSAxMDkuOTEyNSA1NzguNjI1XQo+PgplbmRvYmoKMTQzNSAwIG9iago8PAovTUNJRCAxMAo+PgplbmRvYmoKMTQzNiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1NjMuNDc1IDEwOS45MTI1IDU3OC42MjVdCj4+CmVuZG9iagoxNDM3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMDkuOTEyNTA2IDU2My40NzUgMTA5LjkxMjUwNiA1NzguNjI1XQo+PgplbmRvYmoKMTQzOCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTA5LjkxMjUwNiA1NjMuNDc1IDEwOS45MTI1MDYgNTc4LjYyNV0KPj4KZW5kb2JqCjE0MzkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzEwOS45MTI1MDYgNTYzLjQ3NSAxMDkuOTEyNTA2IDU3OC42MjVdCj4+CmVuZG9iagoxNDQwIDAgb2JqCjw8Ci9NQ0lEIDExCj4+CmVuZG9iagoxNDQxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMDkuOTEyNTA2IDU2My40NzUgMTA5LjkxMjUwNiA1NzguNjI1XQo+PgplbmRvYmoKMTQ0MiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1MTguMDI1IDIyOC4wMzc1IDUzMy4xNzUwNV0KPj4KZW5kb2JqCjE0NDMgMCBvYmoKPDwKL01DSUQgMTIKPj4KZW5kb2JqCjE0NDQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTE4LjAyNSAyMjguMDM3NSA1MzMuMTc1MDVdCj4+CmVuZG9iagoxNDQ1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDUxOC4wMjUgOTYuMCA1MzMuMTc1MDVdCj4+CmVuZG9iagoxNDQ2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDUxOC4wMjUgOTYuMCA1MzMuMTc1MDVdCj4+CmVuZG9iagoxNDQ3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDUxOC4wMjUgOTYuMCA1MzMuMTc1MDVdCj4+CmVuZG9iagoxNDQ4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDUxOC4wMjUgOTYuMCA1MzMuMTc1MDVdCj4+CmVuZG9iagoxNDQ5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDUxOC4wMjUgOTYuMCA1MzMuMTc1MDVdCj4+CmVuZG9iagoxNDUwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDUxOC4wMjUgOTYuMCA1MzMuMTc1MDVdCj4+CmVuZG9iagoxNDUxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQ4NC44NzUgMjgwLjk1IDUwMC4wMjVdCj4+CmVuZG9iagoxNDUyIDAgb2JqCjw8Ci9NQ0lEIDEzCj4+CmVuZG9iagoxNDUzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQ4NC44NzUgMjgwLjk1IDUwMC4wMjVdCj4+CmVuZG9iagoxNDU0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQ2OS43MjUgNDU3LjM4NzUgNDg0Ljg3NV0KPj4KZW5kb2JqCjE0NTUgMCBvYmoKPDwKL01DSUQgMTQKPj4KZW5kb2JqCjE0NTYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDY5LjcyNSA0NTcuMzg3NSA0ODQuODc1XQo+PgplbmRvYmoKMTQ1NyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0NTQuNTc0OTggMjI0LjcgNDY5LjcyNDk4XQo+PgplbmRvYmoKMTQ1OCAwIG9iago8PAovTUNJRCAxNQo+PgplbmRvYmoKMTQ1OSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0NTQuNTc0OTggMjI0LjcgNDY5LjcyNDk4XQo+PgplbmRvYmoKMTQ2MCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0MjEuNDI1IDI4MC45NSA0MzYuNTc0OThdCj4+CmVuZG9iagoxNDYxIDAgb2JqCjw8Ci9NQ0lEIDE2Cj4+CmVuZG9iagoxNDYyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQyMS40MjUgMjgwLjk1IDQzNi41NzQ5OF0KPj4KZW5kb2JqCjE0NjMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDA2LjI3NSAxNTIuNTEyNSA0MjEuNDI1XQo+PgplbmRvYmoKMTQ2NCAwIG9iago8PAovTUNJRCAxNwo+PgplbmRvYmoKMTQ2NSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0MDYuMjc1IDE1Mi41MTI1IDQyMS40MjVdCj4+CmVuZG9iagoxNDY2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxNTIuNTEyNSA0MDYuMjc1IDE1Mi41MTI1IDQyMS40MjVdCj4+CmVuZG9iagoxNDY3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxNTIuNTEyNSA0MDYuMjc1IDE1Mi41MTI1IDQyMS40MjVdCj4+CmVuZG9iagoxNDY4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxNTIuNTEyNSA0MDYuMjc1IDE1Mi41MTI1IDQyMS40MjVdCj4+CmVuZG9iagoxNDY5IDAgb2JqCjw8Ci9NQ0lEIDE4Cj4+CmVuZG9iagoxNDcwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxNTIuNTEyNSA0MDYuMjc1IDE1Mi41MTI1IDQyMS40MjVdCj4+CmVuZG9iagoxNDcxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDM3My4xMjUgMjgwLjk1IDM4OC4yNzVdCj4+CmVuZG9iagoxNDcyIDAgb2JqCjw8Ci9NQ0lEIDE5Cj4+CmVuZG9iagoxNDczIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDM3My4xMjUgMjgwLjk1IDM4OC4yNzVdCj4+CmVuZG9iagoxNDc0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDM1Ny45NzQ5OCAxMTIuNzYyNSAzNzMuMTI0OTddCj4+CmVuZG9iagoxNDc1IDAgb2JqCjw8Ci9NQ0lEIDIwCj4+CmVuZG9iagoxNDc2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDM1Ny45NzQ5OCAxMTIuNzYyNSAzNzMuMTI0OTddCj4+CmVuZG9iagoxNDc3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMTIuNzYyNTA1IDM1Ny45NzQ5OCAxMTIuNzYyNTA1IDM3My4xMjQ5N10KPj4KZW5kb2JqCjE0NzggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzExMi43NjI1MDUgMzU3Ljk3NDk4IDExMi43NjI1MDUgMzczLjEyNDk3XQo+PgplbmRvYmoKMTQ3OSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTEyLjc2MjUwNSAzNTcuOTc0OTggMTEyLjc2MjUwNSAzNzMuMTI0OTddCj4+CmVuZG9iagoxNDgwIDAgb2JqCjw8Ci9NQ0lEIDIxCj4+CmVuZG9iagoxNDgxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMTIuNzYyNTA1IDM1Ny45NzQ5OCAxMTIuNzYyNTA1IDM3My4xMjQ5N10KPj4KZW5kb2JqCjE0ODIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzI0LjgyNSAyODcuNTg3NTIgMzM5Ljk3NV0KPj4KZW5kb2JqCjE0ODMgMCBvYmoKPDwKL01DSUQgMjIKPj4KZW5kb2JqCjE0ODQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzI0LjgyNSAyODcuNTg3NTIgMzM5Ljk3NV0KPj4KZW5kb2JqCjE0ODUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjk0LjUyNDk2IDk2LjAgMzA5LjY3NDk2XQo+PgplbmRvYmoKMTQ4NiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyOTQuNTI0OTYgOTYuMCAzMDkuNjc0OTZdCj4+CmVuZG9iagoxNDg3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI5NC41MjQ5NiA5Ni4wIDMwOS42NzQ5Nl0KPj4KZW5kb2JqCjE0ODggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjk0LjUyNDk2IDk2LjAgMzA5LjY3NDk2XQo+PgplbmRvYmoKMTQ4OSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyOTQuNTI0OTYgOTYuMCAzMDkuNjc0OTZdCj4+CmVuZG9iagoxNDkwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI5NC41MjQ5NiA5Ni4wIDMwOS42NzQ5Nl0KPj4KZW5kb2JqCjE0OTEgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjk0LjUyNDk2IDExMS40NSAzMDkuNjc0OTZdCj4+CmVuZG9iagoxNDkyIDAgb2JqCjw8Ci9NQ0lEIDIzCj4+CmVuZG9iagoxNDkzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI5NC41MjQ5NiAxMTEuNDUgMzA5LjY3NDk2XQo+PgplbmRvYmoKMTQ5NCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTExLjQ1MDAwNSAyOTQuNTI0OTYgMTExLjQ1MDAwNSAzMDkuNjc0OTZdCj4+CmVuZG9iagoxNDk1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMTEuNDUwMDA1IDI5NC41MjQ5NiAxMTEuNDUwMDA1IDMwOS42NzQ5Nl0KPj4KZW5kb2JqCjE0OTYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzExMS40NTAwMDUgMjk0LjUyNDk2IDExMS40NTAwMDUgMzA5LjY3NDk2XQo+PgplbmRvYmoKMTQ5NyAwIG9iago8PAovTUNJRCAyNAo+PgplbmRvYmoKMTQ5OCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTExLjQ1MDAwNSAyOTQuNTI0OTYgMTExLjQ1MDAwNSAzMDkuNjc0OTZdCj4+CmVuZG9iagoxNDk5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI3OS4zNzUgMjI4LjAzNzUgMjk0LjUyNV0KPj4KZW5kb2JqCjE1MDAgMCBvYmoKPDwKL01DSUQgMjUKPj4KZW5kb2JqCjE1MDEgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjc5LjM3NSAyMjguMDM3NSAyOTQuNTI1XQo+PgplbmRvYmoKMTUwMiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyNzkuMzc1IDk2LjAgMjk0LjUyNV0KPj4KZW5kb2JqCjE1MDMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjc5LjM3NSA5Ni4wIDI5NC41MjVdCj4+CmVuZG9iagoxNTA0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI3OS4zNzUgOTYuMCAyOTQuNTI1XQo+PgplbmRvYmoKMTUwNSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyNzkuMzc1IDk2LjAgMjk0LjUyNV0KPj4KZW5kb2JqCjE1MDYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjc5LjM3NSA5Ni4wIDI5NC41MjVdCj4+CmVuZG9iagoxNTA3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI3OS4zNzUgOTYuMCAyOTQuNTI1XQo+PgplbmRvYmoKMTUwOCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyNDYuMjI0OTggMjg3LjU4NzUyIDI2MS4zNzQ5N10KPj4KZW5kb2JqCjE1MDkgMCBvYmoKPDwKL01DSUQgMjYKPj4KZW5kb2JqCjE1MTAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjQ2LjIyNDk4IDI4Ny41ODc1MiAyNjEuMzc0OTddCj4+CmVuZG9iagoxNTExIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDIzMS4wNzUwMSAxMDQuOTI1IDI0Ni4yMjVdCj4+CmVuZG9iagoxNTEyIDAgb2JqCjw8Ci9NQ0lEIDI3Cj4+CmVuZG9iagoxNTEzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDIzMS4wNzUwMSAxMDQuOTI1IDI0Ni4yMjVdCj4+CmVuZG9iagoxNTE0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMDQuOTI1IDIzMS4wNzUwMSAxMDQuOTI1IDI0Ni4yMjVdCj4+CmVuZG9iagoxNTE1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMDQuOTI1IDIzMS4wNzUwMSAxMDQuOTI1IDI0Ni4yMjVdCj4+CmVuZG9iagoxNTE2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMDQuOTI1IDIzMS4wNzUwMSAxMDQuOTI1IDI0Ni4yMjVdCj4+CmVuZG9iagoxNTE3IDAgb2JqCjw8Ci9NQ0lEIDI4Cj4+CmVuZG9iagoxNTE4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMDQuOTI1IDIzMS4wNzUwMSAxMDQuOTI1IDI0Ni4yMjVdCj4+CmVuZG9iagoxNTE5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDIwMC43NzQ5NiAyMjguMDM3NSAyMTUuOTI0OTZdCj4+CmVuZG9iagoxNTIwIDAgb2JqCjw8Ci9NQ0lEIDI5Cj4+CmVuZG9iagoxNTIxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDIwMC43NzQ5NiAyMjguMDM3NSAyMTUuOTI0OTZdCj4+CmVuZG9iagoxNTIyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDIwMC43NzQ5NiA5Ni4wIDIxNS45MjQ5Nl0KPj4KZW5kb2JqCjE1MjMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjAwLjc3NDk2IDk2LjAgMjE1LjkyNDk2XQo+PgplbmRvYmoKMTUyNCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyMDAuNzc0OTYgOTYuMCAyMTUuOTI0OTZdCj4+CmVuZG9iagoxNTI1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDIwMC43NzQ5NiA5Ni4wIDIxNS45MjQ5Nl0KPj4KZW5kb2JqCjE1MjYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjAwLjc3NDk2IDk2LjAgMjE1LjkyNDk2XQo+PgplbmRvYmoKMTUyNyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyMDAuNzc0OTYgOTYuMCAyMTUuOTI0OTZdCj4+CmVuZG9iagoxNTI4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDE2Ny42MjUgMjg3LjU4NzUyIDE4Mi43NzVdCj4+CmVuZG9iagoxNTI5IDAgb2JqCjw8Ci9NQ0lEIDMwCj4+CmVuZG9iagoxNTMwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDE2Ny42MjUgMjg3LjU4NzUyIDE4Mi43NzVdCj4+CmVuZG9iagoxNTMxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDE1Mi40NzQ5OCAxMjQuNDI1IDE2Ny42MjQ5N10KPj4KZW5kb2JqCjE1MzIgMCBvYmoKPDwKL01DSUQgMzEKPj4KZW5kb2JqCjE1MzMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMTUyLjQ3NDk4IDEyNC40MjUgMTY3LjYyNDk3XQo+PgplbmRvYmoKMTUzNCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTI0LjQyNSAxNTIuNDc0OTggMTI0LjQyNSAxNjcuNjI0OTddCj4+CmVuZG9iagoxNTM1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMjQuNDI1IDE1Mi40NzQ5OCAxMjQuNDI1IDE2Ny42MjQ5N10KPj4KZW5kb2JqCjE1MzYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzEyNC40MjUgMTUyLjQ3NDk4IDEyNC40MjUgMTY3LjYyNDk3XQo+PgplbmRvYmoKMTUzNyAwIG9iago8PAovTUNJRCAzMgo+PgplbmRvYmoKMTUzOCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTI0LjQyNSAxNTIuNDc0OTggMTI0LjQyNSAxNjcuNjI0OTddCj4+CmVuZG9iagoxNTM5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDEyMi4xNzQ5OSAyMjguMDM3NSAxMzcuMzI0OThdCj4+CmVuZG9iagoxNTQwIDAgb2JqCjw8Ci9NQ0lEIDMzCj4+CmVuZG9iagoxNTQxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDEyMi4xNzQ5OSAyMjguMDM3NSAxMzcuMzI0OThdCj4+CmVuZG9iagoxNTQyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDEyMi4xNzQ5OSA5Ni4wIDEzNy4zMjQ5OF0KPj4KZW5kb2JqCjE1NDMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMTIyLjE3NDk5IDk2LjAgMTM3LjMyNDk4XQo+PgplbmRvYmoKMTU0NCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxMjIuMTc0OTkgOTYuMCAxMzcuMzI0OThdCj4+CmVuZG9iagoxNTQ1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDEyMi4xNzQ5OSA5Ni4wIDEzNy4zMjQ5OF0KPj4KZW5kb2JqCjE1NDYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMTIyLjE3NDk5IDk2LjAgMTM3LjMyNDk4XQo+PgplbmRvYmoKMTU0NyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxMjIuMTc0OTkgOTYuMCAxMzcuMzI0OThdCj4+CmVuZG9iagoxNTQ4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDg5LjAyNDk2IDI4Ny41ODc1MiAxMDQuMTc0OTY1XQo+PgplbmRvYmoKMTU0OSAwIG9iago8PAovTUNJRCAzNAo+PgplbmRvYmoKMTU1MCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA4OS4wMjQ5NiAyODcuNTg3NTIgMTA0LjE3NDk2NV0KPj4KZW5kb2JqCjE1NTEgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzcxLjI1IDU3Ljc1IDUyNC4wMjUgNzg0LjEyNV0KPj4KZW5kb2JqCjE1NTIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzcxLjI1IDU3Ljc1IDUyNC4wMjUgNzg0LjEyNV0KPj4KZW5kb2JqCjE1NTMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzc3LjI1IDU3Ljc1IDUxOC4wMjUgNzg0LjEyNV0KPj4KZW5kb2JqCjE1NTQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzc3LjI1IDQ1MC45NzQ5OCA1MTguMDI1IDc4NC4xMjVdCj4+CmVuZG9iagoxNTU1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQ2OS43MjUgNDk5LjI3NTAyIDc4NC4xMjVdCj4+CmVuZG9iagoxNTU2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQ4Ny43MjUgNDk5LjI3NTAyIDc4NC4xMjVdCj4+CmVuZG9iagoxNTU3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDczOC42NzUgNDk5LjI3NTAyIDc4NC4xMjVdCj4+CmVuZG9iagoxNTU4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDczOC42NzUgNDk5LjI3NTAyIDc4NC4xMjVdCj4+CmVuZG9iagoxNTU5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDY2MC4wNzUgNDk5LjI3NTAyIDcyMC42NzVdCj4+CmVuZG9iagoxNTYwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDcwNS41MjUgNDk5LjI3NTAyIDcyMC42NzUwNV0KPj4KZW5kb2JqCjE1NjEgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjYwLjA3NSA0OTkuMjc1MDIgNzA1LjUyNV0KPj4KZW5kb2JqCjE1NjIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTgxLjQ3NSA0OTkuMjc1MDIgNjQyLjA3NDk1XQo+PgplbmRvYmoKMTU2MyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2MjYuOTI1IDQ5OS4yNzUwMiA2NDIuMDc1XQo+PgplbmRvYmoKMTU2NCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1ODEuNDc1IDQ5OS4yNzUwMiA2MjYuOTI1XQo+PgplbmRvYmoKMTU2NSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0ODcuNzI1IDQ5OS4yNzUwMiA1NjMuNDc1XQo+PgplbmRvYmoKMTU2NiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1NDguMzI0OTUgNDk5LjI3NTAyIDU2My40NzVdCj4+CmVuZG9iagoxNTY3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQ4Ny43MjUgNDk5LjI3NTAyIDU0OC4zMjVdCj4+CmVuZG9iagoxNTY4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs3Ny4yNSA1Ny43NSA1MTguMDI1IDQzNy41NTAwMl0KPj4KZW5kb2JqCjE1NjkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTcuNzUgNDk5LjI3NTAyIDQxOC44MDAwMl0KPj4KZW5kb2JqCjE1NzAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDAzLjggNDk5LjI3NTAyIDQxOC44XQo+PgplbmRvYmoKMTU3MSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzNjYuMyA0OTkuMjc1MDIgMzkwLjNdCj4+CmVuZG9iagoxNTcyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDE4Ny42NDk5NiA0OTkuMjc1MDIgMzUyLjhdCj4+CmVuZG9iagoxNTczIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDMxMC44IDQ5OS4yNzUwMiAzNTIuOF0KPj4KZW5kb2JqCjE1NzQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjc3LjY0OTk2IDQ5OS4yNzUwMiAzMTAuNzk5OTZdCj4+CmVuZG9iagoxNTc1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI5Mi44IDQ5OS4yNzUwMiAzMTAuOF0KPj4KZW5kb2JqCjE1NzYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjc3LjY0OTk2IDQ5OS4yNzUwMiAyOTIuNzk5OTZdCj4+CmVuZG9iagoxNTc3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI0Ny42NDk5NiA0OTkuMjc1MDIgMjY1LjY0OTk2XQo+PgplbmRvYmoKMTU3OCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyNDcuNjQ5OTYgNDk5LjI3NTAyIDI2NS42NDk5Nl0KPj4KZW5kb2JqCjE1NzkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjE3LjY0OTk2IDQ5OS4yNzUwMiAyMzUuNjQ5OTZdCj4+CmVuZG9iagoxNTgwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDIxNy42NDk5NiA0OTkuMjc1MDIgMjM1LjY0OTk2XQo+PgplbmRvYmoKMTU4MSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxODcuNjQ5OTYgNDk5LjI3NTAyIDIwNS42NDk5Nl0KPj4KZW5kb2JqCjE1ODIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMTg3LjY0OTk2IDQ5OS4yNzUwMiAyMDUuNjQ5OTZdCj4+CmVuZG9iagoxNTgzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU3Ljc1IDQ5OS4yNzUwMiAxNzQuOV0KPj4KZW5kb2JqCjE1ODQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMTM3LjA5OTk4IDQ5OS4yNzUwMiAxNTguMDk5OThdCj4+CmVuZG9iagoxNTg1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDg4Ljc5OTk5IDQ5OS4yNzUwMiAxMTkuMDk5OTldCj4+CmVuZG9iagoxNTg2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDEwMy45NTAwMSA0OTkuMjc1MDIgMTE5LjEwMDAxXQo+PgplbmRvYmoKMTU4NyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA4OC43OTk5OSA0OTkuMjc1MDIgMTAzLjk0OTk5XQo+PgplbmRvYmoKMTU4OCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1Ny43NSA0OTkuMjc1MDIgNzAuOF0KPj4KZW5kb2JqCjE1ODkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTcuNzUgNDk5LjI3NTAyIDcwLjhdCj4+CmVuZG9iagoxNTkwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDc2OC45NzUgMTUzLjAgNzg0LjEyNV0KPj4KZW5kb2JqCjE1OTEgMCBvYmoKPDwKL01DSUQgMAo+PgplbmRvYmoKMTU5MiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3NjguOTc1IDE1My4wIDc4NC4xMjVdCj4+CmVuZG9iagoxNTkzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxNTMuMCA3NjguOTc1IDE1My4wIDc4NC4xMjVdCj4+CmVuZG9iagoxNTk0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxNTMuMCA3NjguOTc1IDE1My4wIDc4NC4xMjVdCj4+CmVuZG9iagoxNTk1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxNTMuMCA3NjguOTc1IDE1My4wIDc4NC4xMjVdCj4+CmVuZG9iagoxNTk2IDAgb2JqCjw8Ci9NQ0lEIDEKPj4KZW5kb2JqCjE1OTcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzE1My4wIDc2OC45NzUgMTUzLjAgNzg0LjEyNV0KPj4KZW5kb2JqCjE1OTggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzM4LjY3NSAyMjguMDM3NSA3NTMuODI1XQo+PgplbmRvYmoKMTU5OSAwIG9iago8PAovTUNJRCAyCj4+CmVuZG9iagoxNjAwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDczOC42NzUgMjI4LjAzNzUgNzUzLjgyNV0KPj4KZW5kb2JqCjE2MDEgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzM4LjY3NSA5Ni4wIDc1My44MjVdCj4+CmVuZG9iagoxNjAyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDczOC42NzUgOTYuMCA3NTMuODI1XQo+PgplbmRvYmoKMTYwMyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3MzguNjc1IDk2LjAgNzUzLjgyNV0KPj4KZW5kb2JqCjE2MDQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzM4LjY3NSA5Ni4wIDc1My44MjVdCj4+CmVuZG9iagoxNjA1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDczOC42NzUgOTYuMCA3NTMuODI1XQo+PgplbmRvYmoKMTYwNiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3MzguNjc1IDk2LjAgNzUzLjgyNV0KPj4KZW5kb2JqCjE2MDcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzA1LjUyNSAyODcuNTg3NTIgNzIwLjY3NTA1XQo+PgplbmRvYmoKMTYwOCAwIG9iago8PAovTUNJRCAzCj4+CmVuZG9iagoxNjA5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDcwNS41MjUgMjg3LjU4NzUyIDcyMC42NzUwNV0KPj4KZW5kb2JqCjE2MTAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjkwLjM3NSAxMjQuNDI1IDcwNS41MjVdCj4+CmVuZG9iagoxNjExIDAgb2JqCjw8Ci9NQ0lEIDQKPj4KZW5kb2JqCjE2MTIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjkwLjM3NSAxMjQuNDI1IDcwNS41MjVdCj4+CmVuZG9iagoxNjEzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMjQuNDI1IDY5MC4zNzUgMTI0LjQyNSA3MDUuNTI1XQo+PgplbmRvYmoKMTYxNCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTI0LjQyNSA2OTAuMzc1IDEyNC40MjUgNzA1LjUyNV0KPj4KZW5kb2JqCjE2MTUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzEyNC40MjUgNjkwLjM3NSAxMjQuNDI1IDcwNS41MjVdCj4+CmVuZG9iagoxNjE2IDAgb2JqCjw8Ci9NQ0lEIDUKPj4KZW5kb2JqCjE2MTcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzEyNC40MjUgNjkwLjM3NSAxMjQuNDI1IDcwNS41MjVdCj4+CmVuZG9iagoxNjE4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDY2MC4wNzUgMjI4LjAzNzUgNjc1LjIyNTA0XQo+PgplbmRvYmoKMTYxOSAwIG9iago8PAovTUNJRCA2Cj4+CmVuZG9iagoxNjIwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDY2MC4wNzUgMjI4LjAzNzUgNjc1LjIyNTA0XQo+PgplbmRvYmoKMTYyMSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2NjAuMDc1IDk2LjAgNjc1LjIyNTA0XQo+PgplbmRvYmoKMTYyMiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2NjAuMDc1IDk2LjAgNjc1LjIyNTA0XQo+PgplbmRvYmoKMTYyMyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2NjAuMDc1IDk2LjAgNjc1LjIyNTA0XQo+PgplbmRvYmoKMTYyNCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2NjAuMDc1IDk2LjAgNjc1LjIyNTA0XQo+PgplbmRvYmoKMTYyNSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2NjAuMDc1IDk2LjAgNjc1LjIyNTA0XQo+PgplbmRvYmoKMTYyNiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2NjAuMDc1IDk2LjAgNjc1LjIyNTA0XQo+PgplbmRvYmoKMTYyNyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2MjYuOTI1IDI4Ny41ODc1MiA2NDIuMDc1XQo+PgplbmRvYmoKMTYyOCAwIG9iago8PAovTUNJRCA3Cj4+CmVuZG9iagoxNjI5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDYyNi45MjUgMjg3LjU4NzUyIDY0Mi4wNzVdCj4+CmVuZG9iagoxNjMwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDYxMS43NzUgMTM3LjIxMjUgNjI2LjkyNTA1XQo+PgplbmRvYmoKMTYzMSAwIG9iago8PAovTUNJRCA4Cj4+CmVuZG9iagoxNjMyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDYxMS43NzUgMTM3LjIxMjUgNjI2LjkyNTA1XQo+PgplbmRvYmoKMTYzMyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTM3LjIxMjUxIDYxMS43NzUgMTM3LjIxMjUxIDYyNi45MjUwNV0KPj4KZW5kb2JqCjE2MzQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzEzNy4yMTI1MSA2MTEuNzc1IDEzNy4yMTI1MSA2MjYuOTI1MDVdCj4+CmVuZG9iagoxNjM1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMzcuMjEyNTEgNjExLjc3NSAxMzcuMjEyNTEgNjI2LjkyNTA1XQo+PgplbmRvYmoKMTYzNiAwIG9iago8PAovTUNJRCA5Cj4+CmVuZG9iagoxNjM3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMzcuMjEyNTEgNjExLjc3NSAxMzcuMjEyNTEgNjI2LjkyNTA1XQo+PgplbmRvYmoKMTYzOCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1ODEuNDc1IDIyOC4wMzc1IDU5Ni42MjVdCj4+CmVuZG9iagoxNjM5IDAgb2JqCjw8Ci9NQ0lEIDEwCj4+CmVuZG9iagoxNjQwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU4MS40NzUgMjI4LjAzNzUgNTk2LjYyNV0KPj4KZW5kb2JqCjE2NDEgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTgxLjQ3NSA5Ni4wIDU5Ni42MjVdCj4+CmVuZG9iagoxNjQyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU4MS40NzUgOTYuMCA1OTYuNjI1XQo+PgplbmRvYmoKMTY0MyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1ODEuNDc1IDk2LjAgNTk2LjYyNV0KPj4KZW5kb2JqCjE2NDQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTgxLjQ3NSA5Ni4wIDU5Ni42MjVdCj4+CmVuZG9iagoxNjQ1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU4MS40NzUgOTYuMCA1OTYuNjI1XQo+PgplbmRvYmoKMTY0NiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1ODEuNDc1IDk2LjAgNTk2LjYyNV0KPj4KZW5kb2JqCjE2NDcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTQ4LjMyNDk1IDI4Ny41ODc1MiA1NjMuNDc1XQo+PgplbmRvYmoKMTY0OCAwIG9iago8PAovTUNJRCAxMQo+PgplbmRvYmoKMTY0OSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1NDguMzI0OTUgMjg3LjU4NzUyIDU2My40NzVdCj4+CmVuZG9iagoxNjUwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDUzMy4xNzUgMTEyLjc2MjUgNTQ4LjMyNV0KPj4KZW5kb2JqCjE2NTEgMCBvYmoKPDwKL01DSUQgMTIKPj4KZW5kb2JqCjE2NTIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTMzLjE3NSAxMTIuNzYyNSA1NDguMzI1XQo+PgplbmRvYmoKMTY1MyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTEyLjc2MjUwNSA1MzMuMTc1IDExMi43NjI1MDUgNTQ4LjMyNV0KPj4KZW5kb2JqCjE2NTQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzExMi43NjI1MDUgNTMzLjE3NSAxMTIuNzYyNTA1IDU0OC4zMjVdCj4+CmVuZG9iagoxNjU1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMTIuNzYyNTA1IDUzMy4xNzUgMTEyLjc2MjUwNSA1NDguMzI1XQo+PgplbmRvYmoKMTY1NiAwIG9iago8PAovTUNJRCAxMwo+PgplbmRvYmoKMTY1NyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTEyLjc2MjUwNSA1MzMuMTc1IDExMi43NjI1MDUgNTQ4LjMyNV0KPj4KZW5kb2JqCjE2NTggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDg3LjcyNSAyMjguMDM3NSA1MDIuODc1XQo+PgplbmRvYmoKMTY1OSAwIG9iago8PAovTUNJRCAxNAo+PgplbmRvYmoKMTY2MCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0ODcuNzI1IDIyOC4wMzc1IDUwMi44NzVdCj4+CmVuZG9iagoxNjYxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQ4Ny43MjUgOTYuMCA1MDIuODc1XQo+PgplbmRvYmoKMTY2MiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0ODcuNzI1IDk2LjAgNTAyLjg3NV0KPj4KZW5kb2JqCjE2NjMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDg3LjcyNSA5Ni4wIDUwMi44NzVdCj4+CmVuZG9iagoxNjY0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQ4Ny43MjUgOTYuMCA1MDIuODc1XQo+PgplbmRvYmoKMTY2NSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0ODcuNzI1IDk2LjAgNTAyLjg3NV0KPj4KZW5kb2JqCjE2NjYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDg3LjcyNSA5Ni4wIDUwMi44NzVdCj4+CmVuZG9iagoxNjY3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQwNC42NjI0OCAyMzUuOCA0MTcuODk5OTZdCj4+CmVuZG9iagoxNjY4IDAgb2JqCjw8Ci9NQ0lEIDE1Cj4+CmVuZG9iagoxNjY5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQwNC42NjI0OCAyMzUuOCA0MTcuODk5OTZdCj4+CmVuZG9iagoxNjcwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDM2Ni4zNzUgMTY2LjgzNzUgMzkwLjIyNV0KPj4KZW5kb2JqCjE2NzEgMCBvYmoKPDwKL01DSUQgMTYKPj4KZW5kb2JqCjE2NzIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzY2LjM3NSAxNjYuODM3NSAzOTAuMjI1XQo+PgplbmRvYmoKMTY3MyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzMzcuNjUgNDYxLjMyNSAzNTIuOF0KPj4KZW5kb2JqCjE2NzQgMCBvYmoKPDwKL01DSUQgMTcKPj4KZW5kb2JqCjE2NzUgMCBvYmoKPDwKL01DSUQgMTgKPj4KZW5kb2JqCjE2NzYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzM3LjY1IDQ2MS4zMjUgMzUyLjhdCj4+CmVuZG9iagoxNjc3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDMyMi44IDI3Ny40NjI1MiAzNTIuOF0KPj4KZW5kb2JqCjE2NzggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzM0LjggMjc3LjQ2MjUyIDM1Mi44XQo+PgplbmRvYmoKMTY3OSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzMjIuOCAyNzcuNDYyNTIgMzM0LjhdCj4+CmVuZG9iagoxNjgwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDMzNC44Mzc1IDE0NS41IDM1Mi43MjVdCj4+CmVuZG9iagoxNjgxIDAgb2JqCjw8Ci9NQ0lEIDE5Cj4+CmVuZG9iagoxNjgyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDMzNC44Mzc1IDE0NS41IDM1Mi43MjVdCj4+CmVuZG9iagoxNjgzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDMxOS42NDk5NiAxODYuOTc1IDMzNC43OTk5Nl0KPj4KZW5kb2JqCjE2ODQgMCBvYmoKPDwKL01DSUQgMjAKPj4KZW5kb2JqCjE2ODUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzE5LjY0OTk2IDE4Ni45NzUgMzM0Ljc5OTk2XQo+PgplbmRvYmoKMTY4NiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMjc5Ljg2MjUyIDMyMi44IDQ2MS4zMjUgMzUyLjhdCj4+CmVuZG9iagoxNjg3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsyNzkuODYyNTIgMzM0LjggNDYxLjMyNSAzNTIuOF0KPj4KZW5kb2JqCjE2ODggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzI3OS44NjI1MiAzMjIuOCA0NjEuMzI1IDMzNC44XQo+PgplbmRvYmoKMTY4OSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMjc5Ljg2MjUyIDMzNC44Mzc1IDMyNC45MDAwMiAzNTIuNzI1XQo+PgplbmRvYmoKMTY5MCAwIG9iago8PAovTUNJRCAyMQo+PgplbmRvYmoKMTY5MSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMjc5Ljg2MjUyIDMzNC44Mzc1IDMyNC45MDAwMiAzNTIuNzI1XQo+PgplbmRvYmoKMTY5MiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMjc5Ljg2MjUyIDMxOS42NDk5NiAzNzAuODM3NTIgMzM0Ljc5OTk2XQo+PgplbmRvYmoKMTY5MyAwIG9iago8PAovTUNJRCAyMgo+PgplbmRvYmoKMTY5NCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMjc5Ljg2MjUyIDMxOS42NDk5NiAzNzAuODM3NTIgMzM0Ljc5OTk2XQo+PgplbmRvYmoKMTY5NSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyOTIuODM3NDYgMjE0LjUzNzUgMzEwLjcyNDk4XQo+PgplbmRvYmoKMTY5NiAwIG9iago8PAovTUNJRCAyMwo+PgplbmRvYmoKMTY5NyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyOTIuODM3NDYgMjE0LjUzNzUgMzEwLjcyNDk4XQo+PgplbmRvYmoKMTY5OCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyNzcuNjQ5OTYgMTMzLjE2MjUgMjkyLjc5OTk2XQo+PgplbmRvYmoKMTY5OSAwIG9iago8PAovTUNJRCAyNAo+PgplbmRvYmoKMTcwMCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyNzcuNjQ5OTYgMTMzLjE2MjUgMjkyLjc5OTk2XQo+PgplbmRvYmoKMTcwMSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyNDcuNjg3NSAxODEuNDI1IDI2NS41NzVdCj4+CmVuZG9iagoxNzAyIDAgb2JqCjw8Ci9NQ0lEIDI1Cj4+CmVuZG9iagoxNzAzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI0Ny42ODc1IDE4MS40MjUgMjY1LjU3NV0KPj4KZW5kb2JqCjE3MDQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjE3LjY4NzUgMTY0LjEzNzUxIDIzNS41NzVdCj4+CmVuZG9iagoxNzA1IDAgb2JqCjw8Ci9NQ0lEIDI2Cj4+CmVuZG9iagoxNzA2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDIxNy42ODc1IDE2NC4xMzc1MSAyMzUuNTc1XQo+PgplbmRvYmoKMTcwNyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxODcuNjg3NSAxMzEuOTI1IDIwNS41NzVdCj4+CmVuZG9iagoxNzA4IDAgb2JqCjw8Ci9NQ0lEIDI3Cj4+CmVuZG9iagoxNzA5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDE4Ny42ODc1IDEzMS45MjUgMjA1LjU3NV0KPj4KZW5kb2JqCjE3MTAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMTM3LjY2MjQ4IDEzOC4yMjUgMTU3LjUzNzQ4XQo+PgplbmRvYmoKMTcxMSAwIG9iago8PAovTUNJRCAyOAo+PgplbmRvYmoKMTcxMiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxMzcuNjYyNDggMTM4LjIyNSAxNTcuNTM3NDhdCj4+CmVuZG9iagoxNzEzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDEwMy45NTAwMSAyODAuOTUgMTE5LjEwMDAxXQo+PgplbmRvYmoKMTcxNCAwIG9iago8PAovTUNJRCAyOQo+PgplbmRvYmoKMTcxNSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxMDMuOTUwMDEgMjgwLjk1IDExOS4xMDAwMV0KPj4KZW5kb2JqCjE3MTYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgODguNzk5OTkgMTE2LjkyNSAxMDMuOTQ5OTldCj4+CmVuZG9iagoxNzE3IDAgb2JqCjw8Ci9NQ0lEIDMwCj4+CmVuZG9iagoxNzE4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDg4Ljc5OTk5IDExNi45MjUgMTAzLjk0OTk5XQo+PgplbmRvYmoKMTcxOSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbNzEuMjUgNTcuNzUgNTI0LjAyNSA3ODQuMTI1XQo+PgplbmRvYmoKMTcyMCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbNzEuMjUgNTcuNzUgNTI0LjAyNSA3ODQuMTI1XQo+PgplbmRvYmoKMTcyMSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbNzcuMjUgNTcuNzUgNTE4LjAyNSA3ODQuMTI1XQo+PgplbmRvYmoKMTcyMiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbNzcuMjUgNTcuNzUgNTE4LjAyNSA3ODQuMTI1XQo+PgplbmRvYmoKMTcyMyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1Ny43NSA0OTkuMjc1MDIgNzg0LjEyNV0KPj4KZW5kb2JqCjE3MjQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTcuNzUgNDk5LjI3NTAyIDc4NC4xMjVdCj4+CmVuZG9iagoxNzI1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDc1My44MjUgNDk5LjI3NTAyIDc4NC4xMjVdCj4+CmVuZG9iagoxNzI2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDc2OC45NzUgNDk5LjI3NTAyIDc4NC4xMjVdCj4+CmVuZG9iagoxNzI3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDc1My44MjUgNDk5LjI3NTAyIDc2OC45NzUwNF0KPj4KZW5kb2JqCjE3MjggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzA1LjUyNSA0OTkuMjc1MDIgNzM1LjgyNV0KPj4KZW5kb2JqCjE3MjkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzIwLjY3NSA0OTkuMjc1MDIgNzM1LjgyNV0KPj4KZW5kb2JqCjE3MzAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzA1LjUyNSA0OTkuMjc1MDIgNzIwLjY3NTA1XQo+PgplbmRvYmoKMTczMSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2NTcuMjI1IDQ5OS4yNzUwMiA2ODcuNTI0OTZdCj4+CmVuZG9iagoxNzMyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDY3Mi4zNzUgNDk5LjI3NTAyIDY4Ny41MjVdCj4+CmVuZG9iagoxNzMzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDY1Ny4yMjUgNDk5LjI3NTAyIDY3Mi4zNzVdCj4+CmVuZG9iagoxNzM0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDYwOC45MjUgNDk5LjI3NTAyIDYzOS4yMjVdCj4+CmVuZG9iagoxNzM1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDYyNC4wNzUgNDk5LjI3NTAyIDYzOS4yMjUwNF0KPj4KZW5kb2JqCjE3MzYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjA4LjkyNSA0OTkuMjc1MDIgNjI0LjA3NV0KPj4KZW5kb2JqCjE3MzcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTYwLjYyNSA0OTkuMjc1MDIgNTkwLjkyNV0KPj4KZW5kb2JqCjE3MzggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTc1Ljc3NSA0OTkuMjc1MDIgNTkwLjkyNTA1XQo+PgplbmRvYmoKMTczOSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1NjAuNjI1IDQ5OS4yNzUwMiA1NzUuNzc1XQo+PgplbmRvYmoKMTc0MCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1MTIuMzI0OTUgNDk5LjI3NTAyIDU0Mi42MjQ5NF0KPj4KZW5kb2JqCjE3NDEgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTI3LjQ3NSA0OTkuMjc1MDIgNTQyLjYyNV0KPj4KZW5kb2JqCjE3NDIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTEyLjMyNDk1IDQ5OS4yNzUwMiA1MjcuNDc1XQo+PgplbmRvYmoKMTc0MyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0NjQuMDI1IDQ5OS4yNzUwMiA0OTQuMzI0OThdCj4+CmVuZG9iagoxNzQ0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQ3OS4xNzUgNDk5LjI3NTAyIDQ5NC4zMjQ5OF0KPj4KZW5kb2JqCjE3NDUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDY0LjAyNSA0OTkuMjc1MDIgNDc5LjE3NV0KPj4KZW5kb2JqCjE3NDYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDE1LjcyNDk4IDQ5OS4yNzUwMiA0NDYuMDI0OTZdCj4+CmVuZG9iagoxNzQ3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQzMC44NzUgNDk5LjI3NTAyIDQ0Ni4wMjVdCj4+CmVuZG9iagoxNzQ4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQxNS43MjQ5OCA0OTkuMjc1MDIgNDMwLjg3NDk3XQo+PgplbmRvYmoKMTc0OSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzNjcuNDI1IDQ5OS4yNzUwMiAzOTcuNzI0OThdCj4+CmVuZG9iagoxNzUwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDM4Mi41NzQ5OCA0OTkuMjc1MDIgMzk3LjcyNDk4XQo+PgplbmRvYmoKMTc1MSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzNjcuNDI1IDQ5OS4yNzUwMiAzODIuNTc0OThdCj4+CmVuZG9iagoxNzUyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDMxOS4xMjUgNDk5LjI3NTAyIDM0OS40MjVdCj4+CmVuZG9iagoxNzUzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDMzNC4yNzUgNDk5LjI3NTAyIDM0OS40MjVdCj4+CmVuZG9iagoxNzU0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDMxOS4xMjUgNDk5LjI3NTAyIDMzNC4yNzVdCj4+CmVuZG9iagoxNzU1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI3MC44MjUgNDk5LjI3NTAyIDMwMS4xMjVdCj4+CmVuZG9iagoxNzU2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI4NS45NzQ5OCA0OTkuMjc1MDIgMzAxLjEyNDk3XQo+PgplbmRvYmoKMTc1NyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyNzAuODI1IDQ5OS4yNzUwMiAyODUuOTc1XQo+PgplbmRvYmoKMTc1OCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyMjIuNTI0OTYgNDk5LjI3NTAyIDI1Mi44MjQ5N10KPj4KZW5kb2JqCjE3NTkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjM3LjY3NDk5IDQ5OS4yNzUwMiAyNTIuODI0OThdCj4+CmVuZG9iagoxNzYwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDIyMi41MjQ5NiA0OTkuMjc1MDIgMjM3LjY3NDk2XQo+PgplbmRvYmoKMTc2MSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxNzQuMjI0OTggNDk5LjI3NTAyIDIwNC41MjQ5OF0KPj4KZW5kb2JqCjE3NjIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMTg5LjM3NSA0OTkuMjc1MDIgMjA0LjUyNV0KPj4KZW5kb2JqCjE3NjMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMTc0LjIyNDk4IDQ5OS4yNzUwMiAxODkuMzc0OTddCj4+CmVuZG9iagoxNzY0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDEyNS45MjQ5OSA0OTkuMjc1MDIgMTU2LjIyNDk5XQo+PgplbmRvYmoKMTc2NSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxNDEuMDc1MDEgNDk5LjI3NTAyIDE1Ni4yMjVdCj4+CmVuZG9iagoxNzY2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDEyNS45MjQ5OSA0OTkuMjc1MDIgMTQxLjA3NDk4XQo+PgplbmRvYmoKMTc2NyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3Ny42MjUgNDk5LjI3NTAyIDEwNy45MjVdCj4+CmVuZG9iagoxNzY4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDkyLjc3NDk2IDQ5OS4yNzUwMiAxMDcuOTI0OTY1XQo+PgplbmRvYmoKMTc2OSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3Ny42MjUgNDk5LjI3NTAyIDkyLjc3NV0KPj4KZW5kb2JqCjE3NzAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTcuNzUgNDk5LjI3NTAyIDU5LjYyNV0KPj4KZW5kb2JqCjE3NzEgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTcuNzUgNDk5LjI3NTAyIDU5LjYyNV0KPj4KZW5kb2JqCjE3NzIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzY4Ljk3NSAyODAuOTUgNzg0LjEyNV0KPj4KZW5kb2JqCjE3NzMgMCBvYmoKPDwKL01DSUQgMAo+PgplbmRvYmoKMTc3NCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3NjguOTc1IDI4MC45NSA3ODQuMTI1XQo+PgplbmRvYmoKMTc3NSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3NTMuODI1IDEwNS45NzUgNzY4Ljk3NTA0XQo+PgplbmRvYmoKMTc3NiAwIG9iago8PAovTUNJRCAxCj4+CmVuZG9iagoxNzc3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDc1My44MjUgMTA1Ljk3NSA3NjguOTc1MDRdCj4+CmVuZG9iagoxNzc4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDcyMC42NzUgMjgwLjk1IDczNS44MjVdCj4+CmVuZG9iagoxNzc5IDAgb2JqCjw8Ci9NQ0lEIDIKPj4KZW5kb2JqCjE3ODAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzIwLjY3NSAyODAuOTUgNzM1LjgyNV0KPj4KZW5kb2JqCjE3ODEgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzA1LjUyNSAxOTkuOCA3MjAuNjc1MDVdCj4+CmVuZG9iagoxNzgyIDAgb2JqCjw8Ci9NQ0lEIDMKPj4KZW5kb2JqCjE3ODMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzA1LjUyNSAxOTkuOCA3MjAuNjc1MDVdCj4+CmVuZG9iagoxNzg0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDY3Mi4zNzUgMjgwLjk1IDY4Ny41MjVdCj4+CmVuZG9iagoxNzg1IDAgb2JqCjw8Ci9NQ0lEIDQKPj4KZW5kb2JqCjE3ODYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjcyLjM3NSAyODAuOTUgNjg3LjUyNV0KPj4KZW5kb2JqCjE3ODcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjU3LjIyNSAxNjcuMSA2NzIuMzc1XQo+PgplbmRvYmoKMTc4OCAwIG9iago8PAovTUNJRCA1Cj4+CmVuZG9iagoxNzg5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDY1Ny4yMjUgMTY3LjEgNjcyLjM3NV0KPj4KZW5kb2JqCjE3OTAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjI0LjA3NSAyODAuOTUgNjM5LjIyNTA0XQo+PgplbmRvYmoKMTc5MSAwIG9iago8PAovTUNJRCA2Cj4+CmVuZG9iagoxNzkyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDYyNC4wNzUgMjgwLjk1IDYzOS4yMjUwNF0KPj4KZW5kb2JqCjE3OTMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjA4LjkyNSAxOTAuMjM3NSA2MjQuMDc1XQo+PgplbmRvYmoKMTc5NCAwIG9iago8PAovTUNJRCA3Cj4+CmVuZG9iagoxNzk1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDYwOC45MjUgMTkwLjIzNzUgNjI0LjA3NV0KPj4KZW5kb2JqCjE3OTYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTc1Ljc3NSAyODAuOTUgNTkwLjkyNTA1XQo+PgplbmRvYmoKMTc5NyAwIG9iago8PAovTUNJRCA4Cj4+CmVuZG9iagoxNzk4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU3NS43NzUgMjgwLjk1IDU5MC45MjUwNV0KPj4KZW5kb2JqCjE3OTkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTYwLjYyNSAxMDUuNTYyNSA1NzUuNzc1XQo+PgplbmRvYmoKMTgwMCAwIG9iago8PAovTUNJRCA5Cj4+CmVuZG9iagoxODAxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU2MC42MjUgMTA1LjU2MjUgNTc1Ljc3NV0KPj4KZW5kb2JqCjE4MDIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTI3LjQ3NSAyODAuOTUgNTQyLjYyNV0KPj4KZW5kb2JqCjE4MDMgMCBvYmoKPDwKL01DSUQgMTAKPj4KZW5kb2JqCjE4MDQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTI3LjQ3NSAyODAuOTUgNTQyLjYyNV0KPj4KZW5kb2JqCjE4MDUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTEyLjMyNDk1IDEzNS45NzUgNTI3LjQ3NV0KPj4KZW5kb2JqCjE4MDYgMCBvYmoKPDwKL01DSUQgMTEKPj4KZW5kb2JqCjE4MDcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTEyLjMyNDk1IDEzNS45NzUgNTI3LjQ3NV0KPj4KZW5kb2JqCjE4MDggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDc5LjE3NSAyODAuOTUgNDk0LjMyNDk4XQo+PgplbmRvYmoKMTgwOSAwIG9iago8PAovTUNJRCAxMgo+PgplbmRvYmoKMTgxMCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0NzkuMTc1IDI4MC45NSA0OTQuMzI0OThdCj4+CmVuZG9iagoxODExIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQ2NC4wMjUgMTI4LjAyNSA0NzkuMTc1XQo+PgplbmRvYmoKMTgxMiAwIG9iago8PAovTUNJRCAxMwo+PgplbmRvYmoKMTgxMyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0NjQuMDI1IDEyOC4wMjUgNDc5LjE3NV0KPj4KZW5kb2JqCjE4MTQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDMwLjg3NSAyODAuOTUgNDQ2LjAyNV0KPj4KZW5kb2JqCjE4MTUgMCBvYmoKPDwKL01DSUQgMTQKPj4KZW5kb2JqCjE4MTYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDMwLjg3NSAyODAuOTUgNDQ2LjAyNV0KPj4KZW5kb2JqCjE4MTcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDE1LjcyNDk4IDExMC45NjI1IDQzMC44NzQ5N10KPj4KZW5kb2JqCjE4MTggMCBvYmoKPDwKL01DSUQgMTUKPj4KZW5kb2JqCjE4MTkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDE1LjcyNDk4IDExMC45NjI1IDQzMC44NzQ5N10KPj4KZW5kb2JqCjE4MjAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzgyLjU3NDk4IDI4MC45NSAzOTcuNzI0OThdCj4+CmVuZG9iagoxODIxIDAgb2JqCjw8Ci9NQ0lEIDE2Cj4+CmVuZG9iagoxODIyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDM4Mi41NzQ5OCAyODAuOTUgMzk3LjcyNDk4XQo+PgplbmRvYmoKMTgyMyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzNjcuNDI1IDExMi4wODc1IDM4Mi41NzQ5OF0KPj4KZW5kb2JqCjE4MjQgMCBvYmoKPDwKL01DSUQgMTcKPj4KZW5kb2JqCjE4MjUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzY3LjQyNSAxMTIuMDg3NSAzODIuNTc0OThdCj4+CmVuZG9iagoxODI2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDMzNC4yNzUgMjgwLjk1IDM0OS40MjVdCj4+CmVuZG9iagoxODI3IDAgb2JqCjw8Ci9NQ0lEIDE4Cj4+CmVuZG9iagoxODI4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDMzNC4yNzUgMjgwLjk1IDM0OS40MjVdCj4+CmVuZG9iagoxODI5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDMxOS4xMjUgMTM1Ljk3NSAzMzQuMjc1XQo+PgplbmRvYmoKMTgzMCAwIG9iago8PAovTUNJRCAxOQo+PgplbmRvYmoKMTgzMSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzMTkuMTI1IDEzNS45NzUgMzM0LjI3NV0KPj4KZW5kb2JqCjE4MzIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjg1Ljk3NDk4IDI4MC45NSAzMDEuMTI0OTddCj4+CmVuZG9iagoxODMzIDAgb2JqCjw8Ci9NQ0lEIDIwCj4+CmVuZG9iagoxODM0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI4NS45NzQ5OCAyODAuOTUgMzAxLjEyNDk3XQo+PgplbmRvYmoKMTgzNSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyNzAuODI1IDEzNS45NzUgMjg1Ljk3NV0KPj4KZW5kb2JqCjE4MzYgMCBvYmoKPDwKL01DSUQgMjEKPj4KZW5kb2JqCjE4MzcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjcwLjgyNSAxMzUuOTc1IDI4NS45NzVdCj4+CmVuZG9iagoxODM4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDIzNy42NzQ5OSAyODAuOTUgMjUyLjgyNDk4XQo+PgplbmRvYmoKMTgzOSAwIG9iago8PAovTUNJRCAyMgo+PgplbmRvYmoKMTg0MCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyMzcuNjc0OTkgMjgwLjk1IDI1Mi44MjQ5OF0KPj4KZW5kb2JqCjE4NDEgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjIyLjUyNDk2IDE4Ni42Mzc1MSAyMzcuNjc0OTZdCj4+CmVuZG9iagoxODQyIDAgb2JqCjw8Ci9NQ0lEIDIzCj4+CmVuZG9iagoxODQzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDIyMi41MjQ5NiAxODYuNjM3NTEgMjM3LjY3NDk2XQo+PgplbmRvYmoKMTg0NCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxODkuMzc1IDI4MC45NSAyMDQuNTI1XQo+PgplbmRvYmoKMTg0NSAwIG9iago8PAovTUNJRCAyNAo+PgplbmRvYmoKMTg0NiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxODkuMzc1IDI4MC45NSAyMDQuNTI1XQo+PgplbmRvYmoKMTg0NyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxNzQuMjI0OTggMTM1Ljk3NSAxODkuMzc0OTddCj4+CmVuZG9iagoxODQ4IDAgb2JqCjw8Ci9NQ0lEIDI1Cj4+CmVuZG9iagoxODQ5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDE3NC4yMjQ5OCAxMzUuOTc1IDE4OS4zNzQ5N10KPj4KZW5kb2JqCjE4NTAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMTQxLjA3NTAxIDI4MC45NSAxNTYuMjI1XQo+PgplbmRvYmoKMTg1MSAwIG9iago8PAovTUNJRCAyNgo+PgplbmRvYmoKMTg1MiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxNDEuMDc1MDEgMjgwLjk1IDE1Ni4yMjVdCj4+CmVuZG9iagoxODUzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDEyNS45MjQ5OSAxMzUuOTc1IDE0MS4wNzQ5OF0KPj4KZW5kb2JqCjE4NTQgMCBvYmoKPDwKL01DSUQgMjcKPj4KZW5kb2JqCjE4NTUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMTI1LjkyNDk5IDEzNS45NzUgMTQxLjA3NDk4XQo+PgplbmRvYmoKMTg1NiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA5Mi43NzQ5NiAyODAuOTUgMTA3LjkyNDk2NV0KPj4KZW5kb2JqCjE4NTcgMCBvYmoKPDwKL01DSUQgMjgKPj4KZW5kb2JqCjE4NTggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgOTIuNzc0OTYgMjgwLjk1IDEwNy45MjQ5NjVdCj4+CmVuZG9iagoxODU5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDc3LjYyNSAxMzMuMTYyNSA5Mi43NzVdCj4+CmVuZG9iagoxODYwIDAgb2JqCjw8Ci9NQ0lEIDI5Cj4+CmVuZG9iagoxODYxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDc3LjYyNSAxMzMuMTYyNSA5Mi43NzVdCj4+CmVuZG9iagoxODYyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs3MS4yNSA1Ny43NSA1MjQuMDI1IDc4NC4xMjVdCj4+CmVuZG9iagoxODYzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs3MS4yNSA1Ny43NSA1MjQuMDI1IDc4NC4xMjVdCj4+CmVuZG9iagoxODY0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs3Ny4yNSA1Ny43NSA1MTguMDI1IDc4NC4xMjVdCj4+CmVuZG9iagoxODY1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs3Ny4yNSAxMTAuMDI0OTYgNTE4LjAyNSA3ODQuMTI1XQo+PgplbmRvYmoKMTg2NiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxMjguNzc0OTYgNDk5LjI3NTAyIDc4NC4xMjVdCj4+CmVuZG9iagoxODY3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDE0Ni43NzQ5NiA0OTkuMjc1MDIgNzg0LjEyNV0KPj4KZW5kb2JqCjE4NjggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzIzLjUyNSA0OTkuMjc1MDIgNzg0LjEyNV0KPj4KZW5kb2JqCjE4NjkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzY4Ljk3NSA0OTkuMjc1MDIgNzg0LjEyNV0KPj4KZW5kb2JqCjE4NzAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzIzLjUyNSA0OTkuMjc1MDIgNzY4Ljk3NTA0XQo+PgplbmRvYmoKMTg3MSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2NzUuMjI1IDQ5OS4yNzUwMiA3MDUuNTI0OTZdCj4+CmVuZG9iagoxODcyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDY5MC4zNzUgNDk5LjI3NTAyIDcwNS41MjVdCj4+CmVuZG9iagoxODczIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDY3NS4yMjUgNDk5LjI3NTAyIDY5MC4zNzVdCj4+CmVuZG9iagoxODc0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDYyNi45MjUgNDk5LjI3NTAyIDY1Ny4yMjVdCj4+CmVuZG9iagoxODc1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDY0Mi4wNzUgNDk5LjI3NTAyIDY1Ny4yMjUwNF0KPj4KZW5kb2JqCjE4NzYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjI2LjkyNSA0OTkuMjc1MDIgNjQyLjA3NV0KPj4KZW5kb2JqCjE4NzcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTc4LjYyNSA0OTkuMjc1MDIgNjA4LjkyNV0KPj4KZW5kb2JqCjE4NzggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTkzLjc3NSA0OTkuMjc1MDIgNjA4LjkyNTA1XQo+PgplbmRvYmoKMTg3OSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1NzguNjI1IDQ5OS4yNzUwMiA1OTMuNzc1XQo+PgplbmRvYmoKMTg4MCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1MzAuMzI0OTUgNDk5LjI3NTAyIDU2MC42MjQ5NF0KPj4KZW5kb2JqCjE4ODEgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTQ1LjQ3NSA0OTkuMjc1MDIgNTYwLjYyNV0KPj4KZW5kb2JqCjE4ODIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTMwLjMyNDk1IDQ5OS4yNzUwMiA1NDUuNDc1XQo+PgplbmRvYmoKMTg4MyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0ODIuMDI1IDQ5OS4yNzUwMiA1MTIuMzI1XQo+PgplbmRvYmoKMTg4NCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0OTcuMTc1IDQ5OS4yNzUwMiA1MTIuMzI1XQo+PgplbmRvYmoKMTg4NSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0ODIuMDI1IDQ5OS4yNzUwMiA0OTcuMTc1XQo+PgplbmRvYmoKMTg4NiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0MzMuNzI0OTggNDk5LjI3NTAyIDQ2NC4wMjQ5Nl0KPj4KZW5kb2JqCjE4ODcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDQ4Ljg3NSA0OTkuMjc1MDIgNDY0LjAyNV0KPj4KZW5kb2JqCjE4ODggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDMzLjcyNDk4IDQ5OS4yNzUwMiA0NDguODc0OTddCj4+CmVuZG9iagoxODg5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDM3MC4yNzUgNDk5LjI3NTAyIDQxNS43MjVdCj4+CmVuZG9iagoxODkwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQwMC41NzQ5OCA0OTkuMjc1MDIgNDE1LjcyNDk4XQo+PgplbmRvYmoKMTg5MSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzNzAuMjc1IDQ5OS4yNzUwMiA0MDAuNTc0OThdCj4+CmVuZG9iagoxODkyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDMyMS45NzQ5OCA0OTkuMjc1MDIgMzUyLjI3NDk2XQo+PgplbmRvYmoKMTg5MyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzMzcuMTI1IDQ5OS4yNzUwMiAzNTIuMjc1XQo+PgplbmRvYmoKMTg5NCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzMjEuOTc0OTggNDk5LjI3NTAyIDMzNy4xMjQ5N10KPj4KZW5kb2JqCjE4OTUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjQzLjM3NSA0OTkuMjc1MDIgMzAzLjk3NV0KPj4KZW5kb2JqCjE4OTYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjg4LjgyNSA0OTkuMjc1MDIgMzAzLjk3NV0KPj4KZW5kb2JqCjE4OTcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjQzLjM3NSA0OTkuMjc1MDIgMjg4LjgyNV0KPj4KZW5kb2JqCjE4OTggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMTk1LjA3NTAxIDQ5OS4yNzUwMiAyMjUuMzc1MDJdCj4+CmVuZG9iagoxODk5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDIxMC4yMjQ5OCA0OTkuMjc1MDIgMjI1LjM3NDk3XQo+PgplbmRvYmoKMTkwMCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxOTUuMDc1MDEgNDk5LjI3NTAyIDIxMC4yMjVdCj4+CmVuZG9iagoxOTAxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDE0Ni43NzQ5NiA0OTkuMjc1MDIgMTc3LjA3NDk3XQo+PgplbmRvYmoKMTkwMiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxNjEuOTI0OTkgNDk5LjI3NTAyIDE3Ny4wNzQ5OF0KPj4KZW5kb2JqCjE5MDMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMTQ2Ljc3NDk2IDQ5OS4yNzUwMiAxNjEuOTI0OTZdCj4+CmVuZG9iagoxOTA0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs3Ny4yNSA2MC4xMTI0ODggNTE4LjAyNSA5MC4xMTI0OV0KPj4KZW5kb2JqCjE5MDUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzY4Ljk3NSAyODcuNTg3NTIgNzg0LjEyNV0KPj4KZW5kb2JqCjE5MDYgMCBvYmoKPDwKL01DSUQgMAo+PgplbmRvYmoKMTkwNyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3NjguOTc1IDI4Ny41ODc1MiA3ODQuMTI1XQo+PgplbmRvYmoKMTkwOCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3NTMuODI1IDIyMy42ODc1IDc2OC45NzUwNF0KPj4KZW5kb2JqCjE5MDkgMCBvYmoKPDwKL01DSUQgMQo+PgplbmRvYmoKMTkxMCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3NTMuODI1IDIyMy42ODc1IDc2OC45NzUwNF0KPj4KZW5kb2JqCjE5MTEgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzIyMy42ODc1IDc1My44MjUgMjIzLjY4NzUgNzY4Ljk3NTA0XQo+PgplbmRvYmoKMTkxMiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMjIzLjY4NzUgNzUzLjgyNSAyMjMuNjg3NSA3NjguOTc1MDRdCj4+CmVuZG9iagoxOTEzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsyMjMuNjg3NSA3NTMuODI1IDIyMy42ODc1IDc2OC45NzUwNF0KPj4KZW5kb2JqCjE5MTQgMCBvYmoKPDwKL01DSUQgMgo+PgplbmRvYmoKMTkxNSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMjIzLjY4NzUgNzUzLjgyNSAyMjMuNjg3NSA3NjguOTc1MDRdCj4+CmVuZG9iagoxOTE2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDcyMy41MjUgMjI4LjAzNzUgNzM4LjY3NTA1XQo+PgplbmRvYmoKMTkxNyAwIG9iago8PAovTUNJRCAzCj4+CmVuZG9iagoxOTE4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDcyMy41MjUgMjI4LjAzNzUgNzM4LjY3NTA1XQo+PgplbmRvYmoKMTkxOSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3MjMuNTI1IDk2LjAgNzM4LjY3NTA1XQo+PgplbmRvYmoKMTkyMCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3MjMuNTI1IDk2LjAgNzM4LjY3NTA1XQo+PgplbmRvYmoKMTkyMSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3MjMuNTI1IDk2LjAgNzM4LjY3NTA1XQo+PgplbmRvYmoKMTkyMiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3MjMuNTI1IDk2LjAgNzM4LjY3NTA1XQo+PgplbmRvYmoKMTkyMyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3MjMuNTI1IDk2LjAgNzM4LjY3NTA1XQo+PgplbmRvYmoKMTkyNCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3MjMuNTI1IDk2LjAgNzM4LjY3NTA1XQo+PgplbmRvYmoKMTkyNSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2OTAuMzc1IDI4MC45NSA3MDUuNTI1XQo+PgplbmRvYmoKMTkyNiAwIG9iago8PAovTUNJRCA0Cj4+CmVuZG9iagoxOTI3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDY5MC4zNzUgMjgwLjk1IDcwNS41MjVdCj4+CmVuZG9iagoxOTI4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDY3NS4yMjUgMTAyLjY3NSA2OTAuMzc1XQo+PgplbmRvYmoKMTkyOSAwIG9iago8PAovTUNJRCA1Cj4+CmVuZG9iagoxOTMwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDY3NS4yMjUgMTAyLjY3NSA2OTAuMzc1XQo+PgplbmRvYmoKMTkzMSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2NDIuMDc1IDI4MC45NSA2NTcuMjI1MDRdCj4+CmVuZG9iagoxOTMyIDAgb2JqCjw8Ci9NQ0lEIDYKPj4KZW5kb2JqCjE5MzMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjQyLjA3NSAyODAuOTUgNjU3LjIyNTA0XQo+PgplbmRvYmoKMTkzNCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2MjYuOTI1IDE1My4wIDY0Mi4wNzVdCj4+CmVuZG9iagoxOTM1IDAgb2JqCjw8Ci9NQ0lEIDcKPj4KZW5kb2JqCjE5MzYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjI2LjkyNSAxNTMuMCA2NDIuMDc1XQo+PgplbmRvYmoKMTkzNyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1OTMuNzc1IDI4MC45NSA2MDguOTI1MDVdCj4+CmVuZG9iagoxOTM4IDAgb2JqCjw8Ci9NQ0lEIDgKPj4KZW5kb2JqCjE5MzkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTkzLjc3NSAyODAuOTUgNjA4LjkyNTA1XQo+PgplbmRvYmoKMTk0MCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1NzguNjI1IDE3OS4yMTI1IDU5My43NzVdCj4+CmVuZG9iagoxOTQxIDAgb2JqCjw8Ci9NQ0lEIDkKPj4KZW5kb2JqCjE5NDIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTc4LjYyNSAxNzkuMjEyNSA1OTMuNzc1XQo+PgplbmRvYmoKMTk0MyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1NDUuNDc1IDI4MC45NSA1NjAuNjI1XQo+PgplbmRvYmoKMTk0NCAwIG9iago8PAovTUNJRCAxMAo+PgplbmRvYmoKMTk0NSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1NDUuNDc1IDI4MC45NSA1NjAuNjI1XQo+PgplbmRvYmoKMTk0NiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1MzAuMzI0OTUgMTM1Ljk3NSA1NDUuNDc1XQo+PgplbmRvYmoKMTk0NyAwIG9iago8PAovTUNJRCAxMQo+PgplbmRvYmoKMTk0OCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1MzAuMzI0OTUgMTM1Ljk3NSA1NDUuNDc1XQo+PgplbmRvYmoKMTk0OSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0OTcuMTc1IDI4MC45NSA1MTIuMzI1XQo+PgplbmRvYmoKMTk1MCAwIG9iago8PAovTUNJRCAxMgo+PgplbmRvYmoKMTk1MSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0OTcuMTc1IDI4MC45NSA1MTIuMzI1XQo+PgplbmRvYmoKMTk1MiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0ODIuMDI1IDEzNS45NzUgNDk3LjE3NV0KPj4KZW5kb2JqCjE5NTMgMCBvYmoKPDwKL01DSUQgMTMKPj4KZW5kb2JqCjE5NTQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDgyLjAyNSAxMzUuOTc1IDQ5Ny4xNzVdCj4+CmVuZG9iagoxOTU1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMzUuOTc1IDQ4Mi4wMjUgMTM1Ljk3NSA0OTcuMTc1XQo+PgplbmRvYmoKMTk1NiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTM1Ljk3NSA0ODIuMDI1IDEzNS45NzUgNDk3LjE3NV0KPj4KZW5kb2JqCjE5NTcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzEzNS45NzUgNDgyLjAyNSAxMzUuOTc1IDQ5Ny4xNzVdCj4+CmVuZG9iagoxOTU4IDAgb2JqCjw8Ci9NQ0lEIDE0Cj4+CmVuZG9iagoxOTU5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMzUuOTc1IDQ4Mi4wMjUgMTM1Ljk3NSA0OTcuMTc1XQo+PgplbmRvYmoKMTk2MCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0NDguODc1IDI4MC45NSA0NjQuMDI1XQo+PgplbmRvYmoKMTk2MSAwIG9iago8PAovTUNJRCAxNQo+PgplbmRvYmoKMTk2MiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0NDguODc1IDI4MC45NSA0NjQuMDI1XQo+PgplbmRvYmoKMTk2MyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0MzMuNzI0OTggMTAyLjg2MjUgNDQ4Ljg3NDk3XQo+PgplbmRvYmoKMTk2NCAwIG9iago8PAovTUNJRCAxNgo+PgplbmRvYmoKMTk2NSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0MzMuNzI0OTggMTAyLjg2MjUgNDQ4Ljg3NDk3XQo+PgplbmRvYmoKMTk2NiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0MDAuNTc0OTggMjgwLjk1IDQxNS43MjQ5OF0KPj4KZW5kb2JqCjE5NjcgMCBvYmoKPDwKL01DSUQgMTcKPj4KZW5kb2JqCjE5NjggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDAwLjU3NDk4IDI4MC45NSA0MTUuNzI0OThdCj4+CmVuZG9iagoxOTY5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDM4NS40MjUgNDYyLjIyNSA0MDAuNTc0OThdCj4+CmVuZG9iagoxOTcwIDAgb2JqCjw8Ci9NQ0lEIDE4Cj4+CmVuZG9iagoxOTcxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDM4NS40MjUgNDYyLjIyNSA0MDAuNTc0OThdCj4+CmVuZG9iagoxOTcyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDM3MC4yNzUgMzg2LjU1MDAyIDM4NS40MjVdCj4+CmVuZG9iagoxOTczIDAgb2JqCjw8Ci9NQ0lEIDE5Cj4+CmVuZG9iagoxOTc0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDM3MC4yNzUgMzg2LjU1MDAyIDM4NS40MjVdCj4+CmVuZG9iagoxOTc1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDMzNy4xMjUgMjgwLjk1IDM1Mi4yNzVdCj4+CmVuZG9iagoxOTc2IDAgb2JqCjw8Ci9NQ0lEIDIwCj4+CmVuZG9iagoxOTc3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDMzNy4xMjUgMjgwLjk1IDM1Mi4yNzVdCj4+CmVuZG9iagoxOTc4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDMyMS45NzQ5OCAxMzcuMjEyNSAzMzcuMTI0OTddCj4+CmVuZG9iagoxOTc5IDAgb2JqCjw8Ci9NQ0lEIDIxCj4+CmVuZG9iagoxOTgwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDMyMS45NzQ5OCAxMzcuMjEyNSAzMzcuMTI0OTddCj4+CmVuZG9iagoxOTgxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI4OC44MjUgMjg3LjU4NzUyIDMwMy45NzVdCj4+CmVuZG9iagoxOTgyIDAgb2JqCjw8Ci9NQ0lEIDIyCj4+CmVuZG9iagoxOTgzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI4OC44MjUgMjg3LjU4NzUyIDMwMy45NzVdCj4+CmVuZG9iagoxOTg0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI3My42NzUgMTk0LjgxMjUgMjg4LjgyNDk4XQo+PgplbmRvYmoKMTk4NSAwIG9iago8PAovTUNJRCAyMwo+PgplbmRvYmoKMTk4NiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyNzMuNjc1IDE5NC44MTI1IDI4OC44MjQ5OF0KPj4KZW5kb2JqCjE5ODcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzE5NC44MTI1IDI3My42NzUgMTk0LjgxMjUgMjg4LjgyNDk4XQo+PgplbmRvYmoKMTk4OCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTk0LjgxMjUgMjczLjY3NSAxOTQuODEyNSAyODguODI0OThdCj4+CmVuZG9iagoxOTg5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxOTQuODEyNSAyNzMuNjc1IDE5NC44MTI1IDI4OC44MjQ5OF0KPj4KZW5kb2JqCjE5OTAgMCBvYmoKPDwKL01DSUQgMjQKPj4KZW5kb2JqCjE5OTEgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzE5NC44MTI1IDI3My42NzUgMTk0LjgxMjUgMjg4LjgyNDk4XQo+PgplbmRvYmoKMTk5MiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyNDMuMzc1IDIyOC4wMzc1IDI1OC41MjVdCj4+CmVuZG9iagoxOTkzIDAgb2JqCjw8Ci9NQ0lEIDI1Cj4+CmVuZG9iagoxOTk0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI0My4zNzUgMjI4LjAzNzUgMjU4LjUyNV0KPj4KZW5kb2JqCjE5OTUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjQzLjM3NSA5Ni4wIDI1OC41MjVdCj4+CmVuZG9iagoxOTk2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI0My4zNzUgOTYuMCAyNTguNTI1XQo+PgplbmRvYmoKMTk5NyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyNDMuMzc1IDk2LjAgMjU4LjUyNV0KPj4KZW5kb2JqCjE5OTggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjQzLjM3NSA5Ni4wIDI1OC41MjVdCj4+CmVuZG9iagoxOTk5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI0My4zNzUgOTYuMCAyNTguNTI1XQo+PgplbmRvYmoKMjAwMCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyNDMuMzc1IDk2LjAgMjU4LjUyNV0KPj4KZW5kb2JqCjIwMDEgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjEwLjIyNDk4IDI4MC45NSAyMjUuMzc0OTddCj4+CmVuZG9iagoyMDAyIDAgb2JqCjw8Ci9NQ0lEIDI2Cj4+CmVuZG9iagoyMDAzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDIxMC4yMjQ5OCAyODAuOTUgMjI1LjM3NDk3XQo+PgplbmRvYmoKMjAwNCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxOTUuMDc1MDEgMjE2LjA3NTAxIDIxMC4yMjVdCj4+CmVuZG9iagoyMDA1IDAgb2JqCjw8Ci9NQ0lEIDI3Cj4+CmVuZG9iagoyMDA2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDE5NS4wNzUwMSAyMTYuMDc1MDEgMjEwLjIyNV0KPj4KZW5kb2JqCjIwMDcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMTYxLjkyNDk5IDI4MC45NSAxNzcuMDc0OThdCj4+CmVuZG9iagoyMDA4IDAgb2JqCjw8Ci9NQ0lEIDI4Cj4+CmVuZG9iagoyMDA5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDE2MS45MjQ5OSAyODAuOTUgMTc3LjA3NDk4XQo+PgplbmRvYmoKMjAxMCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxNDYuNzc0OTYgMTA3Ljg4NzUgMTYxLjkyNDk2XQo+PgplbmRvYmoKMjAxMSAwIG9iago8PAovTUNJRCAyOQo+PgplbmRvYmoKMjAxMiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxNDYuNzc0OTYgMTA3Ljg4NzUgMTYxLjkyNDk2XQo+PgplbmRvYmoKMjAxMyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbNzcuMjUgNTkuMjEyNDYzIDQxOC45MTI1IDkxLjAxMjQ3XQo+PgplbmRvYmoKMjAxNCAwIG9iago8PAovTUNJRCAzMAo+PgplbmRvYmoKMjAxNSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbNzcuMjUgNTkuMjEyNDYzIDQxOC45MTI1IDkxLjAxMjQ3XQo+PgplbmRvYmoKMjAxNiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbNzEuMjUgNTcuNzUgNTI0LjAyNSA3ODQuMTI1XQo+PgplbmRvYmoKMjAxNyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbNzEuMjUgNTcuNzUgNTI0LjAyNSA3ODQuMTI1XQo+PgplbmRvYmoKMjAxOCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbNzcuMjUgNTcuNzUgNTE4LjAyNSA3ODQuMTI1XQo+PgplbmRvYmoKMjAxOSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbNzcuMjUgNTM2Ljk2MjUgNTE4LjAyNSA3NzMuMDYyNV0KPj4KZW5kb2JqCjIwMjAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTU1LjcxMjUgNDk5LjI3NTAyIDc1NC4zMTI1XQo+PgplbmRvYmoKMjAyMSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3MzkuMzEyNSA0OTkuMjc1MDIgNzU0LjMxMjVdCj4+CmVuZG9iagoyMDIyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDcwMS44MTI1IDQ5OS4yNzUwMiA3MjUuODEyNV0KPj4KZW5kb2JqCjIwMjMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTY3LjcxMjUgNDk5LjI3NTAyIDY4OC4zMTI1XQo+PgplbmRvYmoKMjAyNCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2NDYuMzEyNSA0OTkuMjc1MDIgNjg4LjMxMjVdCj4+CmVuZG9iagoyMDI1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU2Ny43MTI1IDQ5OS4yNzUwMiA2NDYuMzEyNV0KPj4KZW5kb2JqCjIwMjYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjI4LjMxMjUgNDk5LjI3NTAyIDY0Ni4zMTI1XQo+PgplbmRvYmoKMjAyNyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1NjcuNzEyNSA0OTkuMjc1MDIgNjI4LjMxMjVdCj4+CmVuZG9iagoyMDI4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs3Ny4yNSAxODEuMzg3NTEgNTE4LjAyNSA1MjMuNTM3NV0KPj4KZW5kb2JqCjIwMjkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjAwLjEzNzUxIDQ5OS4yNzUwMiA1MDQuNzg3NV0KPj4KZW5kb2JqCjIwMzAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDg5Ljc4NzUgNDk5LjI3NTAyIDUwNC43ODc1XQo+PgplbmRvYmoKMjAzMSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0NTIuMjg3NDggNDk5LjI3NTAyIDQ3Ni4yODc0OF0KPj4KZW5kb2JqCjIwMzIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjEyLjEzNzUxIDQ5OS4yNzUwMiA0MzguNzg3NTRdCj4+CmVuZG9iagoyMDMzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDM5Ni43ODc0OCA0OTkuMjc1MDIgNDM4Ljc4NzQ4XQo+PgplbmRvYmoKMjAzNCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyMTIuMTM3NTEgNDk5LjI3NTAyIDM5Ni43ODc1NF0KPj4KZW5kb2JqCjIwMzUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzc4Ljc4NzQ4IDQ5OS4yNzUwMiAzOTYuNzg3NDhdCj4+CmVuZG9iagoyMDM2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDIxMi4xMzc1MSA0OTkuMjc1MDIgMzc4Ljc4NzU0XQo+PgplbmRvYmoKMjAzNyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbNzcuMjUgMTQzLjU4NzQ2IDUxOC4wMjUgMTY0LjU4NzQ2XQo+PgplbmRvYmoKMjAzOCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1Ny43NSA0OTkuMjc1MDIgMTA4LjAzNzUwNl0KPj4KZW5kb2JqCjIwMzkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzAuMjM3NDkgNDk5LjI3NTAyIDkxLjIzNzQ5XQo+PgplbmRvYmoKMjA0MCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3NDAuMTc1IDE4Mi4yNSA3NTMuNDEyNV0KPj4KZW5kb2JqCjIwNDEgMCBvYmoKPDwKL01DSUQgMAo+PgplbmRvYmoKMjA0MiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3NDAuMTc1IDE4Mi4yNSA3NTMuNDEyNV0KPj4KZW5kb2JqCjIwNDMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzAxLjg4NzUgMTE0LjgyNSA3MjUuNzM3NV0KPj4KZW5kb2JqCjIwNDQgMCBvYmoKPDwKL01DSUQgMQo+PgplbmRvYmoKMjA0NSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3MDEuODg3NSAxMTQuODI1IDcyNS43Mzc1XQo+PgplbmRvYmoKMjA0NiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2NzMuMTYyNSA0NjEuMzI1IDY4OC4zMTI1XQo+PgplbmRvYmoKMjA0NyAwIG9iago8PAovTUNJRCAyCj4+CmVuZG9iagoyMDQ4IDAgb2JqCjw8Ci9NQ0lEIDMKPj4KZW5kb2JqCjIwNDkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjczLjE2MjUgNDYxLjMyNSA2ODguMzEyNV0KPj4KZW5kb2JqCjIwNTAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjU4LjMxMjUgMjc3LjQ2MjUyIDY4OC4zMTI1XQo+PgplbmRvYmoKMjA1MSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2NzAuMzEyNSAyNzcuNDYyNTIgNjg4LjMxMjVdCj4+CmVuZG9iagoyMDUyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDY1OC4zMTI1IDI3Ny40NjI1MiA2NzAuMzEyNV0KPj4KZW5kb2JqCjIwNTMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjcwLjM1IDEyNC4yIDY4OC4yMzc1XQo+PgplbmRvYmoKMjA1NCAwIG9iago8PAovTUNJRCA0Cj4+CmVuZG9iagoyMDU1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDY3MC4zNSAxMjQuMiA2ODguMjM3NV0KPj4KZW5kb2JqCjIwNTYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjU1LjE2MjUgMTY4Ljk3NSA2NzAuMzEyNV0KPj4KZW5kb2JqCjIwNTcgMCBvYmoKPDwKL01DSUQgNQo+PgplbmRvYmoKMjA1OCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2NTUuMTYyNSAxNjguOTc1IDY3MC4zMTI1XQo+PgplbmRvYmoKMjA1OSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMjc5Ljg2MjUyIDY1OC4zMTI1IDQ2MS4zMjUgNjg4LjMxMjVdCj4+CmVuZG9iagoyMDYwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsyNzkuODYyNTIgNjcwLjMxMjUgNDYxLjMyNSA2ODguMzEyNV0KPj4KZW5kb2JqCjIwNjEgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzI3OS44NjI1MiA2NTguMzEyNSA0NjEuMzI1IDY3MC4zMTI1XQo+PgplbmRvYmoKMjA2MiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMjc5Ljg2MjUyIDY3MC4zNSAzMzguNTUwMDIgNjg4LjIzNzVdCj4+CmVuZG9iagoyMDYzIDAgb2JqCjw8Ci9NQ0lEIDYKPj4KZW5kb2JqCjIwNjQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzI3OS44NjI1MiA2NzAuMzUgMzM4LjU1MDAyIDY4OC4yMzc1XQo+PgplbmRvYmoKMjA2NSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMjc5Ljg2MjUyIDY1NS4xNjI1IDMzNC4wMTI1IDY3MC4zMTI1XQo+PgplbmRvYmoKMjA2NiAwIG9iago8PAovTUNJRCA3Cj4+CmVuZG9iagoyMDY3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsyNzkuODYyNTIgNjU1LjE2MjUgMzM0LjAxMjUgNjcwLjMxMjVdCj4+CmVuZG9iagoyMDY4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDYyOC4zNSAxODYuNDUwMDEgNjQ2LjIzNzVdCj4+CmVuZG9iagoyMDY5IDAgb2JqCjw8Ci9NQ0lEIDgKPj4KZW5kb2JqCjIwNzAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjI4LjM1IDE4Ni40NTAwMSA2NDYuMjM3NV0KPj4KZW5kb2JqCjIwNzEgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjEzLjE2MjUgMTE2LjM2MjUgNjI4LjMxMjVdCj4+CmVuZG9iagoyMDcyIDAgb2JqCjw8Ci9NQ0lEIDkKPj4KZW5kb2JqCjIwNzMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjEzLjE2MjUgMTE2LjM2MjUgNjI4LjMxMjVdCj4+CmVuZG9iagoyMDc0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMTYuMzYyNSA2MTMuMTYyNSAxMTYuMzYyNSA2MjguMzEyNV0KPj4KZW5kb2JqCjIwNzUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzExNi4zNjI1IDYxMy4xNjI1IDExNi4zNjI1IDYyOC4zMTI1XQo+PgplbmRvYmoKMjA3NiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTE2LjM2MjUgNjEzLjE2MjUgMTE2LjM2MjUgNjI4LjMxMjVdCj4+CmVuZG9iagoyMDc3IDAgb2JqCjw8Ci9NQ0lEIDEwCj4+CmVuZG9iagoyMDc4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMTYuMzYyNSA2MTMuMTYyNSAxMTYuMzYyNSA2MjguMzEyNV0KPj4KZW5kb2JqCjIwNzkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTgyLjg2MjUgMTI4LjkyNSA1OTguMDEyNV0KPj4KZW5kb2JqCjIwODAgMCBvYmoKPDwKL01DSUQgMTEKPj4KZW5kb2JqCjIwODEgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTgyLjg2MjUgMTI4LjkyNSA1OTguMDEyNV0KPj4KZW5kb2JqCjIwODIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTgyLjg2MjUgOTYuMCA1OTguMDEyNV0KPj4KZW5kb2JqCjIwODMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTgyLjg2MjUgOTYuMCA1OTguMDEyNV0KPj4KZW5kb2JqCjIwODQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTgyLjg2MjUgOTYuMCA1OTguMDEyNV0KPj4KZW5kb2JqCjIwODUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTgyLjg2MjUgOTYuMCA1OTguMDEyNV0KPj4KZW5kb2JqCjIwODYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTgyLjg2MjUgOTYuMCA1OTguMDEyNV0KPj4KZW5kb2JqCjIwODcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTgyLjg2MjUgOTYuMCA1OTguMDEyNV0KPj4KZW5kb2JqCjIwODggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzEyOC45MjUgNTgyLjg2MjUgMTI4LjkyNSA1OTguMDEyNV0KPj4KZW5kb2JqCjIwODkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzEyOC45MjUgNTgyLjg2MjUgMTI4LjkyNSA1OTguMDEyNV0KPj4KZW5kb2JqCjIwOTAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzEyOC45MjUgNTgyLjg2MjUgMTI4LjkyNSA1OTguMDEyNV0KPj4KZW5kb2JqCjIwOTEgMCBvYmoKPDwKL01DSUQgMTIKPj4KZW5kb2JqCjIwOTIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzEyOC45MjUgNTgyLjg2MjUgMTI4LjkyNSA1OTguMDEyNV0KPj4KZW5kb2JqCjIwOTMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTY3LjcxMjUgMjM4LjIgNTgyLjg2MjU1XQo+PgplbmRvYmoKMjA5NCAwIG9iago8PAovTUNJRCAxMwo+PgplbmRvYmoKMjA5NSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1NjcuNzEyNSAyMzguMiA1ODIuODYyNTVdCj4+CmVuZG9iagoyMDk2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU2Ny43MTI1IDk2LjAgNTgyLjg2MjU1XQo+PgplbmRvYmoKMjA5NyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1NjcuNzEyNSA5Ni4wIDU4Mi44NjI1NV0KPj4KZW5kb2JqCjIwOTggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTY3LjcxMjUgOTYuMCA1ODIuODYyNTVdCj4+CmVuZG9iagoyMDk5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU2Ny43MTI1IDk2LjAgNTgyLjg2MjU1XQo+PgplbmRvYmoKMjEwMCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1NjcuNzEyNSA5Ni4wIDU4Mi44NjI1NV0KPj4KZW5kb2JqCjIxMDEgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTY3LjcxMjUgOTYuMCA1ODIuODYyNTVdCj4+CmVuZG9iagoyMTAyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQ5MC42NSAxODIuMjUgNTAzLjg4NzQ4XQo+PgplbmRvYmoKMjEwMyAwIG9iago8PAovTUNJRCAxNAo+PgplbmRvYmoKMjEwNCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0OTAuNjUgMTgyLjI1IDUwMy44ODc0OF0KPj4KZW5kb2JqCjIxMDUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDUyLjM2MjUgMTUzLjIyNSA0NzYuMjEyNV0KPj4KZW5kb2JqCjIxMDYgMCBvYmoKPDwKL01DSUQgMTUKPj4KZW5kb2JqCjIxMDcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDUyLjM2MjUgMTUzLjIyNSA0NzYuMjEyNV0KPj4KZW5kb2JqCjIxMDggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDIzLjYzNzQ4IDQ2MS4zMjUgNDM4Ljc4NzQ4XQo+PgplbmRvYmoKMjEwOSAwIG9iago8PAovTUNJRCAxNgo+PgplbmRvYmoKMjExMCAwIG9iago8PAovTUNJRCAxNwo+PgplbmRvYmoKMjExMSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0MjMuNjM3NDggNDYxLjMyNSA0MzguNzg3NDhdCj4+CmVuZG9iagoyMTEyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQwOC43ODc0OCAyNzcuNDYyNTIgNDM4Ljc4NzQ4XQo+PgplbmRvYmoKMjExMyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0MjAuNzg3NDggMjc3LjQ2MjUyIDQzOC43ODc0OF0KPj4KZW5kb2JqCjIxMTQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDA4Ljc4NzQ4IDI3Ny40NjI1MiA0MjAuNzg3NDhdCj4+CmVuZG9iagoyMTE1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQyMC44MjQ5OCAxMjQuMiA0MzguNzEyNV0KPj4KZW5kb2JqCjIxMTYgMCBvYmoKPDwKL01DSUQgMTgKPj4KZW5kb2JqCjIxMTcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDIwLjgyNDk4IDEyNC4yIDQzOC43MTI1XQo+PgplbmRvYmoKMjExOCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0MDUuNjM3NDggMTY4Ljk3NSA0MjAuNzg3NDhdCj4+CmVuZG9iagoyMTE5IDAgb2JqCjw8Ci9NQ0lEIDE5Cj4+CmVuZG9iagoyMTIwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQwNS42Mzc0OCAxNjguOTc1IDQyMC43ODc0OF0KPj4KZW5kb2JqCjIxMjEgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzI3OS44NjI1MiA0MDguNzg3NDggNDYxLjMyNSA0MzguNzg3NDhdCj4+CmVuZG9iagoyMTIyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsyNzkuODYyNTIgNDIwLjc4NzQ4IDQ2MS4zMjUgNDM4Ljc4NzQ4XQo+PgplbmRvYmoKMjEyMyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMjc5Ljg2MjUyIDQwOC43ODc0OCA0NjEuMzI1IDQyMC43ODc0OF0KPj4KZW5kb2JqCjIxMjQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzI3OS44NjI1MiA0MjAuODI0OTggMzM4LjU1MDAyIDQzOC43MTI1XQo+PgplbmRvYmoKMjEyNSAwIG9iago8PAovTUNJRCAyMAo+PgplbmRvYmoKMjEyNiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMjc5Ljg2MjUyIDQyMC44MjQ5OCAzMzguNTUwMDIgNDM4LjcxMjVdCj4+CmVuZG9iagoyMTI3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsyNzkuODYyNTIgNDA1LjYzNzQ4IDM0MS45MjUwMiA0MjAuNzg3NDhdCj4+CmVuZG9iagoyMTI4IDAgb2JqCjw8Ci9NQ0lEIDIxCj4+CmVuZG9iagoyMTI5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsyNzkuODYyNTIgNDA1LjYzNzQ4IDM0MS45MjUwMiA0MjAuNzg3NDhdCj4+CmVuZG9iagoyMTMwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDM3OC44MjQ5OCAxODYuNDUwMDEgMzk2LjcxMjVdCj4+CmVuZG9iagoyMTMxIDAgb2JqCjw8Ci9NQ0lEIDIyCj4+CmVuZG9iagoyMTMyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDM3OC44MjQ5OCAxODYuNDUwMDEgMzk2LjcxMjVdCj4+CmVuZG9iagoyMTMzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDM2My42Mzc0OCAxMzUuNTYyNSAzNzguNzg3NDhdCj4+CmVuZG9iagoyMTM0IDAgb2JqCjw8Ci9NQ0lEIDIzCj4+CmVuZG9iagoyMTM1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDM2My42Mzc0OCAxMzUuNTYyNSAzNzguNzg3NDhdCj4+CmVuZG9iagoyMTM2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMzUuNTYyNSAzNjMuNjM3NDggMTM1LjU2MjUgMzc4Ljc4NzQ4XQo+PgplbmRvYmoKMjEzNyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTM1LjU2MjUgMzYzLjYzNzQ4IDEzNS41NjI1IDM3OC43ODc0OF0KPj4KZW5kb2JqCjIxMzggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzEzNS41NjI1IDM2My42Mzc0OCAxMzUuNTYyNSAzNzguNzg3NDhdCj4+CmVuZG9iagoyMTM5IDAgb2JqCjw8Ci9NQ0lEIDI0Cj4+CmVuZG9iagoyMTQwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMzUuNTYyNSAzNjMuNjM3NDggMTM1LjU2MjUgMzc4Ljc4NzQ4XQo+PgplbmRvYmoKMjE0MSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzMzMuMzM3NSAxMTUuNjUgMzQ4LjQ4NzVdCj4+CmVuZG9iagoyMTQyIDAgb2JqCjw8Ci9NQ0lEIDI1Cj4+CmVuZG9iagoyMTQzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDMzMy4zMzc1IDExNS42NSAzNDguNDg3NV0KPj4KZW5kb2JqCjIxNDQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzMzLjMzNzUgOTYuMCAzNDguNDg3NV0KPj4KZW5kb2JqCjIxNDUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzMzLjMzNzUgOTYuMCAzNDguNDg3NV0KPj4KZW5kb2JqCjIxNDYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzMzLjMzNzUgOTYuMCAzNDguNDg3NV0KPj4KZW5kb2JqCjIxNDcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzMzLjMzNzUgOTYuMCAzNDguNDg3NV0KPj4KZW5kb2JqCjIxNDggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzMzLjMzNzUgOTYuMCAzNDguNDg3NV0KPj4KZW5kb2JqCjIxNDkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzMzLjMzNzUgOTYuMCAzNDguNDg3NV0KPj4KZW5kb2JqCjIxNTAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzExNS42NSAzMzMuMzM3NSAxMTUuNjUgMzQ4LjQ4NzVdCj4+CmVuZG9iagoyMTUxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMTUuNjUgMzMzLjMzNzUgMTE1LjY1IDM0OC40ODc1XQo+PgplbmRvYmoKMjE1MiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTE1LjY1IDMzMy4zMzc1IDExNS42NSAzNDguNDg3NV0KPj4KZW5kb2JqCjIxNTMgMCBvYmoKPDwKL01DSUQgMjYKPj4KZW5kb2JqCjIxNTQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzExNS42NSAzMzMuMzM3NSAxMTUuNjUgMzQ4LjQ4NzVdCj4+CmVuZG9iagoyMTU1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDMwMy4wMzc0OCAxNTQuNTM3NSAzMTguMTg3NDddCj4+CmVuZG9iagoyMTU2IDAgb2JqCjw8Ci9NQ0lEIDI3Cj4+CmVuZG9iagoyMTU3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDMwMy4wMzc0OCAxNTQuNTM3NSAzMTguMTg3NDddCj4+CmVuZG9iagoyMTU4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDMwMy4wMzc0OCA5Ni4wIDMxOC4xODc0N10KPj4KZW5kb2JqCjIxNTkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzAzLjAzNzQ4IDk2LjAgMzE4LjE4NzQ3XQo+PgplbmRvYmoKMjE2MCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzMDMuMDM3NDggOTYuMCAzMTguMTg3NDddCj4+CmVuZG9iagoyMTYxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDMwMy4wMzc0OCA5Ni4wIDMxOC4xODc0N10KPj4KZW5kb2JqCjIxNjIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzAzLjAzNzQ4IDk2LjAgMzE4LjE4NzQ3XQo+PgplbmRvYmoKMjE2MyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzMDMuMDM3NDggOTYuMCAzMTguMTg3NDddCj4+CmVuZG9iagoyMTY0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxNTQuNTM3NSAzMDMuMDM3NDggMTU0LjUzNzUgMzE4LjE4NzQ3XQo+PgplbmRvYmoKMjE2NSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTU0LjUzNzUgMzAzLjAzNzQ4IDE1NC41Mzc1IDMxOC4xODc0N10KPj4KZW5kb2JqCjIxNjYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzE1NC41Mzc1IDMwMy4wMzc0OCAxNTQuNTM3NSAzMTguMTg3NDddCj4+CmVuZG9iagoyMTY3IDAgb2JqCjw8Ci9NQ0lEIDI4Cj4+CmVuZG9iagoyMTY4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxNTQuNTM3NSAzMDMuMDM3NDggMTU0LjUzNzUgMzE4LjE4NzQ3XQo+PgplbmRvYmoKMjE2OSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyNzIuNzM3NSAxNTAuMTg3NSAyODcuODg3NDhdCj4+CmVuZG9iagoyMTcwIDAgb2JqCjw8Ci9NQ0lEIDI5Cj4+CmVuZG9iagoyMTcxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI3Mi43Mzc1IDE1MC4xODc1IDI4Ny44ODc0OF0KPj4KZW5kb2JqCjIxNzIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjcyLjczNzUgOTYuMCAyODcuODg3NDhdCj4+CmVuZG9iagoyMTczIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI3Mi43Mzc1IDk2LjAgMjg3Ljg4NzQ4XQo+PgplbmRvYmoKMjE3NCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyNzIuNzM3NSA5Ni4wIDI4Ny44ODc0OF0KPj4KZW5kb2JqCjIxNzUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjcyLjczNzUgOTYuMCAyODcuODg3NDhdCj4+CmVuZG9iagoyMTc2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI3Mi43Mzc1IDk2LjAgMjg3Ljg4NzQ4XQo+PgplbmRvYmoKMjE3NyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyNzIuNzM3NSA5Ni4wIDI4Ny44ODc0OF0KPj4KZW5kb2JqCjIxNzggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzE1MC4xODc1IDI3Mi43Mzc1IDE1MC4xODc1IDI4Ny44ODc0OF0KPj4KZW5kb2JqCjIxNzkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzE1MC4xODc1IDI3Mi43Mzc1IDE1MC4xODc1IDI4Ny44ODc0OF0KPj4KZW5kb2JqCjIxODAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzE1MC4xODc1IDI3Mi43Mzc1IDE1MC4xODc1IDI4Ny44ODc0OF0KPj4KZW5kb2JqCjIxODEgMCBvYmoKPDwKL01DSUQgMzAKPj4KZW5kb2JqCjIxODIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzE1MC4xODc1IDI3Mi43Mzc1IDE1MC4xODc1IDI4Ny44ODc0OF0KPj4KZW5kb2JqCjIxODMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjQyLjQzNzUgMTI0LjQyNSAyNTcuNTg3NV0KPj4KZW5kb2JqCjIxODQgMCBvYmoKPDwKL01DSUQgMzEKPj4KZW5kb2JqCjIxODUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjQyLjQzNzUgMTI0LjQyNSAyNTcuNTg3NV0KPj4KZW5kb2JqCjIxODYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjQyLjQzNzUgOTYuMCAyNTcuNTg3NV0KPj4KZW5kb2JqCjIxODcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjQyLjQzNzUgOTYuMCAyNTcuNTg3NV0KPj4KZW5kb2JqCjIxODggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjQyLjQzNzUgOTYuMCAyNTcuNTg3NV0KPj4KZW5kb2JqCjIxODkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjQyLjQzNzUgOTYuMCAyNTcuNTg3NV0KPj4KZW5kb2JqCjIxOTAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjQyLjQzNzUgOTYuMCAyNTcuNTg3NV0KPj4KZW5kb2JqCjIxOTEgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjQyLjQzNzUgOTYuMCAyNTcuNTg3NV0KPj4KZW5kb2JqCjIxOTIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzEyNC40MjUgMjQyLjQzNzUgMTI0LjQyNSAyNTcuNTg3NV0KPj4KZW5kb2JqCjIxOTMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzEyNC40MjUgMjQyLjQzNzUgMTI0LjQyNSAyNTcuNTg3NV0KPj4KZW5kb2JqCjIxOTQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzEyNC40MjUgMjQyLjQzNzUgMTI0LjQyNSAyNTcuNTg3NV0KPj4KZW5kb2JqCjIxOTUgMCBvYmoKPDwKL01DSUQgMzIKPj4KZW5kb2JqCjIxOTYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzEyNC40MjUgMjQyLjQzNzUgMTI0LjQyNSAyNTcuNTg3NV0KPj4KZW5kb2JqCjIxOTcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjEyLjEzNzUxIDIyOC4wMzc1IDIyNy4yODc1XQo+PgplbmRvYmoKMjE5OCAwIG9iago8PAovTUNJRCAzMwo+PgplbmRvYmoKMjE5OSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyMTIuMTM3NTEgMjI4LjAzNzUgMjI3LjI4NzVdCj4+CmVuZG9iagoyMjAwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDIxMi4xMzc1MSA5Ni4wIDIyNy4yODc1XQo+PgplbmRvYmoKMjIwMSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyMTIuMTM3NTEgOTYuMCAyMjcuMjg3NV0KPj4KZW5kb2JqCjIyMDIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjEyLjEzNzUxIDk2LjAgMjI3LjI4NzVdCj4+CmVuZG9iagoyMjAzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDIxMi4xMzc1MSA5Ni4wIDIyNy4yODc1XQo+PgplbmRvYmoKMjIwNCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyMTIuMTM3NTEgOTYuMCAyMjcuMjg3NV0KPj4KZW5kb2JqCjIyMDUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjEyLjEzNzUxIDk2LjAgMjI3LjI4NzVdCj4+CmVuZG9iagoyMjA2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs3Ny4yNSAxNDQuMTQ5OTYgMTMzLjIgMTY0LjAyNDk2XQo+PgplbmRvYmoKMjIwNyAwIG9iago8PAovTUNJRCAzNAo+PgplbmRvYmoKMjIwOCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbNzcuMjUgMTQ0LjE0OTk2IDEzMy4yIDE2NC4wMjQ5Nl0KPj4KZW5kb2JqCjIyMDkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzAuNzk5OTkgMjY0LjkzNzUgOTAuNjc0OTldCj4+CmVuZG9iagoyMjEwIDAgb2JqCjw8Ci9NQ0lEIDM1Cj4+CmVuZG9iagoyMjExIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDcwLjc5OTk5IDI2NC45Mzc1IDkwLjY3NDk5XQo+PgplbmRvYmoKMjIxMiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbNzEuMjUgNTcuNzUgNTI0LjAyNSA3ODQuMTI1XQo+PgplbmRvYmoKMjIxMyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbNzEuMjUgNTcuNzUgNTI0LjAyNSA3ODQuMTI1XQo+PgplbmRvYmoKMjIxNCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbNzcuMjUgNTcuNzUgNTE4LjAyNSA3ODQuMTI1XQo+PgplbmRvYmoKMjIxNSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3MTguMDEyNSA0OTkuMjc1MDIgNzg0LjEyNV0KPj4KZW5kb2JqCjIyMTYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzE4LjAxMjUgNDk5LjI3NTAyIDc3OC42MTI1XQo+PgplbmRvYmoKMjIxNyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3NjMuNDYyNSA0OTkuMjc1MDIgNzc4LjYxMjU1XQo+PgplbmRvYmoKMjIxOCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3MTguMDEyNSA0OTkuMjc1MDIgNzYzLjQ2MjVdCj4+CmVuZG9iagoyMjE5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU3Ljc1IDQ5OS4yNzUwMiA2NjguNTEyNV0KPj4KZW5kb2JqCjIyMjAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjMwLjcxMjUgNDk5LjI3NTAyIDY1MS43MTI1XQo+PgplbmRvYmoKMjIyMSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1ODIuNDEyNSA0OTkuMjc1MDIgNjEyLjcxMjQ2XQo+PgplbmRvYmoKMjIyMiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1OTcuNTYyNSA0OTkuMjc1MDIgNjEyLjcxMjVdCj4+CmVuZG9iagoyMjIzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU4Mi40MTI1IDQ5OS4yNzUwMiA1OTcuNTYyNV0KPj4KZW5kb2JqCjIyMjQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTM0LjExMjUgNDk5LjI3NTAyIDU2NC40MTI1XQo+PgplbmRvYmoKMjIyNSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1NDkuMjYyNDUgNDk5LjI3NTAyIDU2NC40MTI1XQo+PgplbmRvYmoKMjIyNiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1MzQuMTEyNSA0OTkuMjc1MDIgNTQ5LjI2MjVdCj4+CmVuZG9iagoyMjI3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQ1NS41MTI0OCA0OTkuMjc1MDIgNTE2LjExMjVdCj4+CmVuZG9iagoyMjI4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDUwMC45NjI1IDQ5OS4yNzUwMiA1MTYuMTEyNV0KPj4KZW5kb2JqCjIyMjkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDU1LjUxMjQ4IDQ5OS4yNzUwMiA1MDAuOTYyNV0KPj4KZW5kb2JqCjIyMzAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzc2LjkxMjQ4IDQ5OS4yNzUwMiA0MzcuNTEyNDhdCj4+CmVuZG9iagoyMjMxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQyMi4zNjI1IDQ5OS4yNzUwMiA0MzcuNTEyNDhdCj4+CmVuZG9iagoyMjMyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDM3Ni45MTI0OCA0OTkuMjc1MDIgNDIyLjM2MjVdCj4+CmVuZG9iagoyMjMzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDMyOC42MTI1IDQ5OS4yNzUwMiAzNTguOTEyNDhdCj4+CmVuZG9iagoyMjM0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDM0My43NjI0OCA0OTkuMjc1MDIgMzU4LjkxMjQ4XQo+PgplbmRvYmoKMjIzNSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzMjguNjEyNSA0OTkuMjc1MDIgMzQzLjc2MjQ4XQo+PgplbmRvYmoKMjIzNiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyODAuMzEyNSA0OTkuMjc1MDIgMzEwLjYxMjVdCj4+CmVuZG9iagoyMjM3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI5NS40NjI0NiA0OTkuMjc1MDIgMzEwLjYxMjQ2XQo+PgplbmRvYmoKMjIzOCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyODAuMzEyNSA0OTkuMjc1MDIgMjk1LjQ2MjVdCj4+CmVuZG9iagoyMjM5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDIzMi4wMTI1MSA0OTkuMjc1MDIgMjYyLjMxMjVdCj4+CmVuZG9iagoyMjQwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI0Ny4xNjI0OCA0OTkuMjc1MDIgMjYyLjMxMjQ3XQo+PgplbmRvYmoKMjI0MSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyMzIuMDEyNTEgNDk5LjI3NTAyIDI0Ny4xNjI1XQo+PgplbmRvYmoKMjI0MiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxODMuNzEyNDYgNDk5LjI3NTAyIDIxNC4wMTI0N10KPj4KZW5kb2JqCjIyNDMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMTk4Ljg2MjQ5IDQ5OS4yNzUwMiAyMTQuMDEyNDhdCj4+CmVuZG9iagoyMjQ0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDE4My43MTI0NiA0OTkuMjc1MDIgMTk4Ljg2MjQ2XQo+PgplbmRvYmoKMjI0NSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxMzUuNDEyNDggNDk5LjI3NTAyIDE2NS43MTI0OF0KPj4KZW5kb2JqCjIyNDYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMTUwLjU2MjUgNDk5LjI3NTAyIDE2NS43MTI1XQo+PgplbmRvYmoKMjI0NyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxMzUuNDEyNDggNDk5LjI3NTAyIDE1MC41NjI0N10KPj4KZW5kb2JqCjIyNDggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgODcuMTEyNDkgNDk5LjI3NTAyIDExNy40MTI0OV0KPj4KZW5kb2JqCjIyNDkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMTAyLjI2MjUxIDQ5OS4yNzUwMiAxMTcuNDEyNTFdCj4+CmVuZG9iagoyMjUwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDg3LjExMjQ5IDQ5OS4yNzUwMiAxMDIuMjYyNDldCj4+CmVuZG9iagoyMjUxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU3Ljc1IDQ5OS4yNzUwMiA2OS4xMTI1XQo+PgplbmRvYmoKMjI1MiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1Ny43NSA0OTkuMjc1MDIgNjkuMTEyNV0KPj4KZW5kb2JqCjIyNTMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzYzLjQ2MjUgMjc0LjI3NTAyIDc3OC42MTI1NV0KPj4KZW5kb2JqCjIyNTQgMCBvYmoKPDwKL01DSUQgMAo+PgplbmRvYmoKMjI1NSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3NjMuNDYyNSAyNzQuMjc1MDIgNzc4LjYxMjU1XQo+PgplbmRvYmoKMjI1NiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3MTguMDEyNSA5Ni4wIDczMy4xNjI1NF0KPj4KZW5kb2JqCjIyNTcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzE4LjAxMjUgOTYuMCA3MzMuMTYyNTRdCj4+CmVuZG9iagoyMjU4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDcxOC4wMTI1IDk2LjAgNzMzLjE2MjU0XQo+PgplbmRvYmoKMjI1OSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3MTguMDEyNSA5Ni4wIDczMy4xNjI1NF0KPj4KZW5kb2JqCjIyNjAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzE4LjAxMjUgOTYuMCA3MzMuMTYyNTRdCj4+CmVuZG9iagoyMjYxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDcxOC4wMTI1IDk2LjAgNzMzLjE2MjU0XQo+PgplbmRvYmoKMjI2MiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3MTguMDEyNSAyMjguMDM3NSA3MzMuMTYyNTRdCj4+CmVuZG9iagoyMjYzIDAgb2JqCjw8Ci9NQ0lEIDEKPj4KZW5kb2JqCjIyNjQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzE4LjAxMjUgMjI4LjAzNzUgNzMzLjE2MjU0XQo+PgplbmRvYmoKMjI2NSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2MzEuMjc1IDE2MC44NzUgNjUxLjE1XQo+PgplbmRvYmoKMjI2NiAwIG9iago8PAovTUNJRCAyCj4+CmVuZG9iagoyMjY3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDYzMS4yNzUgMTYwLjg3NSA2NTEuMTVdCj4+CmVuZG9iagoyMjY4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU5Ny41NjI1IDI4MC45NSA2MTIuNzEyNV0KPj4KZW5kb2JqCjIyNjkgMCBvYmoKPDwKL01DSUQgMwo+PgplbmRvYmoKMjI3MCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1OTcuNTYyNSAyODAuOTUgNjEyLjcxMjVdCj4+CmVuZG9iagoyMjcxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU4Mi40MTI1IDEzNS45NzUgNTk3LjU2MjVdCj4+CmVuZG9iagoyMjcyIDAgb2JqCjw8Ci9NQ0lEIDQKPj4KZW5kb2JqCjIyNzMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTgyLjQxMjUgMTM1Ljk3NSA1OTcuNTYyNV0KPj4KZW5kb2JqCjIyNzQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTQ5LjI2MjQ1IDI4MC45NSA1NjQuNDEyNV0KPj4KZW5kb2JqCjIyNzUgMCBvYmoKPDwKL01DSUQgNQo+PgplbmRvYmoKMjI3NiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1NDkuMjYyNDUgMjgwLjk1IDU2NC40MTI1XQo+PgplbmRvYmoKMjI3NyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1MzQuMTEyNSAxMjMuMCA1NDkuMjYyNV0KPj4KZW5kb2JqCjIyNzggMCBvYmoKPDwKL01DSUQgNgo+PgplbmRvYmoKMjI3OSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1MzQuMTEyNSAxMjMuMCA1NDkuMjYyNV0KPj4KZW5kb2JqCjIyODAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTAwLjk2MjUgMjg3LjU4NzUyIDUxNi4xMTI1XQo+PgplbmRvYmoKMjI4MSAwIG9iago8PAovTUNJRCA3Cj4+CmVuZG9iagoyMjgyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDUwMC45NjI1IDI4Ny41ODc1MiA1MTYuMTEyNV0KPj4KZW5kb2JqCjIyODMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDg1LjgxMjUgMTQ1LjI3NSA1MDAuOTYyNV0KPj4KZW5kb2JqCjIyODQgMCBvYmoKPDwKL01DSUQgOAo+PgplbmRvYmoKMjI4NSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0ODUuODEyNSAxNDUuMjc1IDUwMC45NjI1XQo+PgplbmRvYmoKMjI4NiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTQ1LjI3NTAxIDQ4NS44MTI1IDE0NS4yNzUwMSA1MDAuOTYyNV0KPj4KZW5kb2JqCjIyODcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzE0NS4yNzUwMSA0ODUuODEyNSAxNDUuMjc1MDEgNTAwLjk2MjVdCj4+CmVuZG9iagoyMjg4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxNDUuMjc1MDEgNDg1LjgxMjUgMTQ1LjI3NTAxIDUwMC45NjI1XQo+PgplbmRvYmoKMjI4OSAwIG9iago8PAovTUNJRCA5Cj4+CmVuZG9iagoyMjkwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxNDUuMjc1MDEgNDg1LjgxMjUgMTQ1LjI3NTAxIDUwMC45NjI1XQo+PgplbmRvYmoKMjI5MSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0NTUuNTEyNDggMjI4LjAzNzUgNDcwLjY2MjQ4XQo+PgplbmRvYmoKMjI5MiAwIG9iago8PAovTUNJRCAxMAo+PgplbmRvYmoKMjI5MyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0NTUuNTEyNDggMjI4LjAzNzUgNDcwLjY2MjQ4XQo+PgplbmRvYmoKMjI5NCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0NTUuNTEyNDggOTYuMCA0NzAuNjYyNDhdCj4+CmVuZG9iagoyMjk1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQ1NS41MTI0OCA5Ni4wIDQ3MC42NjI0OF0KPj4KZW5kb2JqCjIyOTYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDU1LjUxMjQ4IDk2LjAgNDcwLjY2MjQ4XQo+PgplbmRvYmoKMjI5NyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0NTUuNTEyNDggOTYuMCA0NzAuNjYyNDhdCj4+CmVuZG9iagoyMjk4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQ1NS41MTI0OCA5Ni4wIDQ3MC42NjI0OF0KPj4KZW5kb2JqCjIyOTkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDU1LjUxMjQ4IDk2LjAgNDcwLjY2MjQ4XQo+PgplbmRvYmoKMjMwMCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0MjIuMzYyNSAyODcuNTg3NTIgNDM3LjUxMjQ4XQo+PgplbmRvYmoKMjMwMSAwIG9iago8PAovTUNJRCAxMQo+PgplbmRvYmoKMjMwMiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0MjIuMzYyNSAyODcuNTg3NTIgNDM3LjUxMjQ4XQo+PgplbmRvYmoKMjMwMyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0MDcuMjEyNSAyNjUuNTc1IDQyMi4zNjI1XQo+PgplbmRvYmoKMjMwNCAwIG9iago8PAovTUNJRCAxMgo+PgplbmRvYmoKMjMwNSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0MDcuMjEyNSAyNjUuNTc1IDQyMi4zNjI1XQo+PgplbmRvYmoKMjMwNiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMjY1LjU3NSA0MDcuMjEyNSAyNjUuNTc1IDQyMi4zNjI1XQo+PgplbmRvYmoKMjMwNyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMjY1LjU3NSA0MDcuMjEyNSAyNjUuNTc1IDQyMi4zNjI1XQo+PgplbmRvYmoKMjMwOCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMjY1LjU3NSA0MDcuMjEyNSAyNjUuNTc1IDQyMi4zNjI1XQo+PgplbmRvYmoKMjMwOSAwIG9iago8PAovTUNJRCAxMwo+PgplbmRvYmoKMjMxMCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMjY1LjU3NSA0MDcuMjEyNSAyNjUuNTc1IDQyMi4zNjI1XQo+PgplbmRvYmoKMjMxMSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzNzYuOTEyNDggMjI4LjAzNzUgMzkyLjA2MjQ3XQo+PgplbmRvYmoKMjMxMiAwIG9iago8PAovTUNJRCAxNAo+PgplbmRvYmoKMjMxMyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzNzYuOTEyNDggMjI4LjAzNzUgMzkyLjA2MjQ3XQo+PgplbmRvYmoKMjMxNCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzNzYuOTEyNDggOTYuMCAzOTIuMDYyNDddCj4+CmVuZG9iagoyMzE1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDM3Ni45MTI0OCA5Ni4wIDM5Mi4wNjI0N10KPj4KZW5kb2JqCjIzMTYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzc2LjkxMjQ4IDk2LjAgMzkyLjA2MjQ3XQo+PgplbmRvYmoKMjMxNyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzNzYuOTEyNDggOTYuMCAzOTIuMDYyNDddCj4+CmVuZG9iagoyMzE4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDM3Ni45MTI0OCA5Ni4wIDM5Mi4wNjI0N10KPj4KZW5kb2JqCjIzMTkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzc2LjkxMjQ4IDk2LjAgMzkyLjA2MjQ3XQo+PgplbmRvYmoKMjMyMCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAzNDMuNzYyNDggMjgwLjk1IDM1OC45MTI0OF0KPj4KZW5kb2JqCjIzMjEgMCBvYmoKPDwKL01DSUQgMTUKPj4KZW5kb2JqCjIzMjIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzQzLjc2MjQ4IDI4MC45NSAzNTguOTEyNDhdCj4+CmVuZG9iagoyMzIzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDMyOC42MTI1IDE5Mi4xMTI1IDM0My43NjI0OF0KPj4KZW5kb2JqCjIzMjQgMCBvYmoKPDwKL01DSUQgMTYKPj4KZW5kb2JqCjIzMjUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMzI4LjYxMjUgMTkyLjExMjUgMzQzLjc2MjQ4XQo+PgplbmRvYmoKMjMyNiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTkyLjExMjUgMzI4LjYxMjUgMTkyLjExMjUgMzQzLjc2MjQ4XQo+PgplbmRvYmoKMjMyNyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTkyLjExMjUgMzI4LjYxMjUgMTkyLjExMjUgMzQzLjc2MjQ4XQo+PgplbmRvYmoKMjMyOCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTkyLjExMjUgMzI4LjYxMjUgMTkyLjExMjUgMzQzLjc2MjQ4XQo+PgplbmRvYmoKMjMyOSAwIG9iago8PAovTUNJRCAxNwo+PgplbmRvYmoKMjMzMCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTkyLjExMjUgMzI4LjYxMjUgMTkyLjExMjUgMzQzLjc2MjQ4XQo+PgplbmRvYmoKMjMzMSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyOTUuNDYyNDYgMjgwLjk1IDMxMC42MTI0Nl0KPj4KZW5kb2JqCjIzMzIgMCBvYmoKPDwKL01DSUQgMTgKPj4KZW5kb2JqCjIzMzMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjk1LjQ2MjQ2IDI4MC45NSAzMTAuNjEyNDZdCj4+CmVuZG9iagoyMzM0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI4MC4zMTI1IDMwMC4yMjUgMjk1LjQ2MjVdCj4+CmVuZG9iagoyMzM1IDAgb2JqCjw8Ci9NQ0lEIDE5Cj4+CmVuZG9iagoyMzM2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI4MC4zMTI1IDMwMC4yMjUgMjk1LjQ2MjVdCj4+CmVuZG9iagoyMzM3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDI0Ny4xNjI0OCAyODAuOTUgMjYyLjMxMjQ3XQo+PgplbmRvYmoKMjMzOCAwIG9iago8PAovTUNJRCAyMAo+PgplbmRvYmoKMjMzOSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyNDcuMTYyNDggMjgwLjk1IDI2Mi4zMTI0N10KPj4KZW5kb2JqCjIzNDAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMjMyLjAxMjUxIDExNS42MTI1IDI0Ny4xNjI1XQo+PgplbmRvYmoKMjM0MSAwIG9iago8PAovTUNJRCAyMQo+PgplbmRvYmoKMjM0MiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAyMzIuMDEyNTEgMTE1LjYxMjUgMjQ3LjE2MjVdCj4+CmVuZG9iagoyMzQzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDE5OC44NjI0OSAyODAuOTUgMjE0LjAxMjQ4XQo+PgplbmRvYmoKMjM0NCAwIG9iago8PAovTUNJRCAyMgo+PgplbmRvYmoKMjM0NSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxOTguODYyNDkgMjgwLjk1IDIxNC4wMTI0OF0KPj4KZW5kb2JqCjIzNDYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMTgzLjcxMjQ2IDE0NS4xMjUgMTk4Ljg2MjQ2XQo+PgplbmRvYmoKMjM0NyAwIG9iago8PAovTUNJRCAyMwo+PgplbmRvYmoKMjM0OCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxODMuNzEyNDYgMTQ1LjEyNSAxOTguODYyNDZdCj4+CmVuZG9iagoyMzQ5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDE1MC41NjI1IDI4MC45NSAxNjUuNzEyNV0KPj4KZW5kb2JqCjIzNTAgMCBvYmoKPDwKL01DSUQgMjQKPj4KZW5kb2JqCjIzNTEgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMTUwLjU2MjUgMjgwLjk1IDE2NS43MTI1XQo+PgplbmRvYmoKMjM1MiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxMzUuNDEyNDggMzUwLjU1IDE1MC41NjI0N10KPj4KZW5kb2JqCjIzNTMgMCBvYmoKPDwKL01DSUQgMjUKPj4KZW5kb2JqCjIzNTQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgMTM1LjQxMjQ4IDM1MC41NSAxNTAuNTYyNDddCj4+CmVuZG9iagoyMzU1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDEwMi4yNjI1MSAyODAuOTUgMTE3LjQxMjUxXQo+PgplbmRvYmoKMjM1NiAwIG9iago8PAovTUNJRCAyNgo+PgplbmRvYmoKMjM1NyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCAxMDIuMjYyNTEgMjgwLjk1IDExNy40MTI1MV0KPj4KZW5kb2JqCjIzNTggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgODcuMTEyNDkgMjIyLjkzNzUgMTAyLjI2MjQ5XQo+PgplbmRvYmoKMjM1OSAwIG9iago8PAovTUNJRCAyNwo+PgplbmRvYmoKMjM2MCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA4Ny4xMTI0OSAyMjIuOTM3NSAxMDIuMjYyNDldCj4+CmVuZG9iagoyMzYxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsyMjIuOTM3NSA4Ny4xMTI0OSAyMjIuOTM3NSAxMDIuMjYyNDldCj4+CmVuZG9iagoyMzYyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsyMjIuOTM3NSA4Ny4xMTI0OSAyMjIuOTM3NSAxMDIuMjYyNDldCj4+CmVuZG9iagoyMzYzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsyMjIuOTM3NSA4Ny4xMTI0OSAyMjIuOTM3NSAxMDIuMjYyNDldCj4+CmVuZG9iagoyMzY0IDAgb2JqCjw8Ci9NQ0lEIDI4Cj4+CmVuZG9iagoyMzY1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsyMjIuOTM3NSA4Ny4xMTI0OSAyMjIuOTM3NSAxMDIuMjYyNDldCj4+CmVuZG9iagoyMzY2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs3MS4yNSAzNzUuNTI1IDUyNC4wMjUgNzg0LjEyNV0KPj4KZW5kb2JqCjIzNjcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzcxLjI1IDM3NS41MjUgNTI0LjAyNSA3ODQuMTI1XQo+PgplbmRvYmoKMjM2OCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbNzcuMjUgMzg3LjUyNSA1MTguMDI1IDc4NC4xMjVdCj4+CmVuZG9iagoyMzY5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQwNi4yNzUgNDk5LjI3NTAyIDc4NC4xMjVdCj4+CmVuZG9iagoyMzcwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDcyMy41MjUgNDk5LjI3NTAyIDc4NC4xMjVdCj4+CmVuZG9iagoyMzcxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDc2OC45NzUgNDk5LjI3NTAyIDc4NC4xMjVdCj4+CmVuZG9iagoyMzcyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDcyMy41MjUgNDk5LjI3NTAyIDc2OC45NzUwNF0KPj4KZW5kb2JqCjIzNzMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNjc1LjIyNSA0OTkuMjc1MDIgNzA1LjUyNDk2XQo+PgplbmRvYmoKMjM3NCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2OTAuMzc1IDQ5OS4yNzUwMiA3MDUuNTI1XQo+PgplbmRvYmoKMjM3NSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2NzUuMjI1IDQ5OS4yNzUwMiA2OTAuMzc1XQo+PgplbmRvYmoKMjM3NiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1OTYuNjI1IDQ5OS4yNzUwMiA2NTcuMjI1XQo+PgplbmRvYmoKMjM3NyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2NDIuMDc1IDQ5OS4yNzUwMiA2NTcuMjI1MDRdCj4+CmVuZG9iagoyMzc4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU5Ni42MjUgNDk5LjI3NTAyIDY0Mi4wNzVdCj4+CmVuZG9iagoyMzc5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDUxOC4wMjUgNDk5LjI3NTAyIDU3OC42MjVdCj4+CmVuZG9iagoyMzgwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU2My40NzUgNDk5LjI3NTAyIDU3OC42MjVdCj4+CmVuZG9iagoyMzgxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDUxOC4wMjUgNDk5LjI3NTAyIDU2My40NzUwNF0KPj4KZW5kb2JqCjIzODIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDY5LjcyNSA0OTkuMjc1MDIgNTAwLjAyNV0KPj4KZW5kb2JqCjIzODMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDg0Ljg3NSA0OTkuMjc1MDIgNTAwLjAyNV0KPj4KZW5kb2JqCjIzODQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDY5LjcyNSA0OTkuMjc1MDIgNDg0Ljg3NV0KPj4KZW5kb2JqCjIzODUgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDA2LjI3NSA0OTkuMjc1MDIgNDUxLjcyNV0KPj4KZW5kb2JqCjIzODYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDM2LjU3NDk4IDQ5OS4yNzUwMiA0NTEuNzI0OThdCj4+CmVuZG9iagoyMzg3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQwNi4yNzUgNDk5LjI3NTAyIDQzNi41NzQ5OF0KPj4KZW5kb2JqCjIzODggMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNzY4Ljk3NSAyODcuNTg3NTIgNzg0LjEyNV0KPj4KZW5kb2JqCjIzODkgMCBvYmoKPDwKL01DSUQgMAo+PgplbmRvYmoKMjM5MCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3NjguOTc1IDI4Ny41ODc1MiA3ODQuMTI1XQo+PgplbmRvYmoKMjM5MSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3NTMuODI1IDE5NC44MTI1IDc2OC45NzUwNF0KPj4KZW5kb2JqCjIzOTIgMCBvYmoKPDwKL01DSUQgMQo+PgplbmRvYmoKMjM5MyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3NTMuODI1IDE5NC44MTI1IDc2OC45NzUwNF0KPj4KZW5kb2JqCjIzOTQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzE5NC44MTI1IDc1My44MjUgMTk0LjgxMjUgNzY4Ljk3NTA0XQo+PgplbmRvYmoKMjM5NSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTk0LjgxMjUgNzUzLjgyNSAxOTQuODEyNSA3NjguOTc1MDRdCj4+CmVuZG9iagoyMzk2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxOTQuODEyNSA3NTMuODI1IDE5NC44MTI1IDc2OC45NzUwNF0KPj4KZW5kb2JqCjIzOTcgMCBvYmoKPDwKL01DSUQgMgo+PgplbmRvYmoKMjM5OCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTk0LjgxMjUgNzUzLjgyNSAxOTQuODEyNSA3NjguOTc1MDRdCj4+CmVuZG9iagoyMzk5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDcyMy41MjUgMjI4LjAzNzUgNzM4LjY3NTA1XQo+PgplbmRvYmoKMjQwMCAwIG9iago8PAovTUNJRCAzCj4+CmVuZG9iagoyNDAxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDcyMy41MjUgMjI4LjAzNzUgNzM4LjY3NTA1XQo+PgplbmRvYmoKMjQwMiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3MjMuNTI1IDk2LjAgNzM4LjY3NTA1XQo+PgplbmRvYmoKMjQwMyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3MjMuNTI1IDk2LjAgNzM4LjY3NTA1XQo+PgplbmRvYmoKMjQwNCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3MjMuNTI1IDk2LjAgNzM4LjY3NTA1XQo+PgplbmRvYmoKMjQwNSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3MjMuNTI1IDk2LjAgNzM4LjY3NTA1XQo+PgplbmRvYmoKMjQwNiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3MjMuNTI1IDk2LjAgNzM4LjY3NTA1XQo+PgplbmRvYmoKMjQwNyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA3MjMuNTI1IDk2LjAgNzM4LjY3NTA1XQo+PgplbmRvYmoKMjQwOCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2OTAuMzc1IDI4MC45NSA3MDUuNTI1XQo+PgplbmRvYmoKMjQwOSAwIG9iago8PAovTUNJRCA0Cj4+CmVuZG9iagoyNDEwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDY5MC4zNzUgMjgwLjk1IDcwNS41MjVdCj4+CmVuZG9iagoyNDExIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDY3NS4yMjUgMTM3LjIxMjUgNjkwLjM3NV0KPj4KZW5kb2JqCjI0MTIgMCBvYmoKPDwKL01DSUQgNQo+PgplbmRvYmoKMjQxMyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2NzUuMjI1IDEzNy4yMTI1IDY5MC4zNzVdCj4+CmVuZG9iagoyNDE0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDY0Mi4wNzUgMjg3LjU4NzUyIDY1Ny4yMjUwNF0KPj4KZW5kb2JqCjI0MTUgMCBvYmoKPDwKL01DSUQgNgo+PgplbmRvYmoKMjQxNiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2NDIuMDc1IDI4Ny41ODc1MiA2NTcuMjI1MDRdCj4+CmVuZG9iagoyNDE3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDYyNi45MjUgMTI0LjUzNzUgNjQyLjA3NV0KPj4KZW5kb2JqCjI0MTggMCBvYmoKPDwKL01DSUQgNwo+PgplbmRvYmoKMjQxOSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA2MjYuOTI1IDEyNC41Mzc1IDY0Mi4wNzVdCj4+CmVuZG9iagoyNDIwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxMjQuNTM3NTA2IDYyNi45MjUgMTI0LjUzNzUwNiA2NDIuMDc1XQo+PgplbmRvYmoKMjQyMSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTI0LjUzNzUwNiA2MjYuOTI1IDEyNC41Mzc1MDYgNjQyLjA3NV0KPj4KZW5kb2JqCjI0MjIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzEyNC41Mzc1MDYgNjI2LjkyNSAxMjQuNTM3NTA2IDY0Mi4wNzVdCj4+CmVuZG9iagoyNDIzIDAgb2JqCjw8Ci9NQ0lEIDgKPj4KZW5kb2JqCjI0MjQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzEyNC41Mzc1MDYgNjI2LjkyNSAxMjQuNTM3NTA2IDY0Mi4wNzVdCj4+CmVuZG9iagoyNDI1IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU5Ni42MjUgMjI4LjAzNzUgNjExLjc3NV0KPj4KZW5kb2JqCjI0MjYgMCBvYmoKPDwKL01DSUQgOQo+PgplbmRvYmoKMjQyNyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1OTYuNjI1IDIyOC4wMzc1IDYxMS43NzVdCj4+CmVuZG9iagoyNDI4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU5Ni42MjUgOTYuMCA2MTEuNzc1XQo+PgplbmRvYmoKMjQyOSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1OTYuNjI1IDk2LjAgNjExLjc3NV0KPj4KZW5kb2JqCjI0MzAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTk2LjYyNSA5Ni4wIDYxMS43NzVdCj4+CmVuZG9iagoyNDMxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU5Ni42MjUgOTYuMCA2MTEuNzc1XQo+PgplbmRvYmoKMjQzMiAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1OTYuNjI1IDk2LjAgNjExLjc3NV0KPj4KZW5kb2JqCjI0MzMgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTk2LjYyNSA5Ni4wIDYxMS43NzVdCj4+CmVuZG9iagoyNDM0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU2My40NzUgMjg3LjU4NzUyIDU3OC42MjVdCj4+CmVuZG9iagoyNDM1IDAgb2JqCjw8Ci9NQ0lEIDEwCj4+CmVuZG9iagoyNDM2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU2My40NzUgMjg3LjU4NzUyIDU3OC42MjVdCj4+CmVuZG9iagoyNDM3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDU0OC4zMjQ5NSAxNTIuNTEyNSA1NjMuNDc1XQo+PgplbmRvYmoKMjQzOCAwIG9iago8PAovTUNJRCAxMQo+PgplbmRvYmoKMjQzOSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1NDguMzI0OTUgMTUyLjUxMjUgNTYzLjQ3NV0KPj4KZW5kb2JqCjI0NDAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzE1Mi41MTI1IDU0OC4zMjQ5NSAxNTIuNTEyNSA1NjMuNDc1XQo+PgplbmRvYmoKMjQ0MSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTUyLjUxMjUgNTQ4LjMyNDk1IDE1Mi41MTI1IDU2My40NzVdCj4+CmVuZG9iagoyNDQyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxNTIuNTEyNSA1NDguMzI0OTUgMTUyLjUxMjUgNTYzLjQ3NV0KPj4KZW5kb2JqCjI0NDMgMCBvYmoKPDwKL01DSUQgMTIKPj4KZW5kb2JqCjI0NDQgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzE1Mi41MTI1IDU0OC4zMjQ5NSAxNTIuNTEyNSA1NjMuNDc1XQo+PgplbmRvYmoKMjQ0NSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA1MTguMDI1IDIyOC4wMzc1IDUzMy4xNzUwNV0KPj4KZW5kb2JqCjI0NDYgMCBvYmoKPDwKL01DSUQgMTMKPj4KZW5kb2JqCjI0NDcgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNTE4LjAyNSAyMjguMDM3NSA1MzMuMTc1MDVdCj4+CmVuZG9iagoyNDQ4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDUxOC4wMjUgOTYuMCA1MzMuMTc1MDVdCj4+CmVuZG9iagoyNDQ5IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDUxOC4wMjUgOTYuMCA1MzMuMTc1MDVdCj4+CmVuZG9iagoyNDUwIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDUxOC4wMjUgOTYuMCA1MzMuMTc1MDVdCj4+CmVuZG9iagoyNDUxIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDUxOC4wMjUgOTYuMCA1MzMuMTc1MDVdCj4+CmVuZG9iagoyNDUyIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDUxOC4wMjUgOTYuMCA1MzMuMTc1MDVdCj4+CmVuZG9iagoyNDUzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDUxOC4wMjUgOTYuMCA1MzMuMTc1MDVdCj4+CmVuZG9iagoyNDU0IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQ4NC44NzUgMjgwLjk1IDUwMC4wMjVdCj4+CmVuZG9iagoyNDU1IDAgb2JqCjw8Ci9NQ0lEIDE0Cj4+CmVuZG9iagoyNDU2IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQ4NC44NzUgMjgwLjk1IDUwMC4wMjVdCj4+CmVuZG9iagoyNDU3IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQ2OS43MjUgMTQ3LjkzNzUgNDg0Ljg3NV0KPj4KZW5kb2JqCjI0NTggMCBvYmoKPDwKL01DSUQgMTUKPj4KZW5kb2JqCjI0NTkgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDY5LjcyNSAxNDcuOTM3NSA0ODQuODc1XQo+PgplbmRvYmoKMjQ2MCAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0MzYuNTc0OTggMjgwLjk1IDQ1MS43MjQ5OF0KPj4KZW5kb2JqCjI0NjEgMCBvYmoKPDwKL01DSUQgMTYKPj4KZW5kb2JqCjI0NjIgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzk2LjAgNDM2LjU3NDk4IDI4MC45NSA0NTEuNzI0OThdCj4+CmVuZG9iagoyNDYzIDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFs5Ni4wIDQyMS40MjUgMTQzLjEzNzUgNDM2LjU3NDk4XQo+PgplbmRvYmoKMjQ2NCAwIG9iago8PAovTUNJRCAxNwo+PgplbmRvYmoKMjQ2NSAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbOTYuMCA0MjEuNDI1IDE0My4xMzc1IDQzNi41NzQ5OF0KPj4KZW5kb2JqCjI0NjYgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzE0My4xMzc1IDQyMS40MjUgMTQzLjEzNzUgNDM2LjU3NDk4XQo+PgplbmRvYmoKMjQ2NyAwIG9iago8PAovVHlwZSAvQmFja2dyb3VuZAovQkJveCBbMTQzLjEzNzUgNDIxLjQyNSAxNDMuMTM3NSA0MzYuNTc0OThdCj4+CmVuZG9iagoyNDY4IDAgb2JqCjw8Ci9UeXBlIC9CYWNrZ3JvdW5kCi9CQm94IFsxNDMuMTM3NSA0MjEuNDI1IDE0My4xMzc1IDQzNi41NzQ5OF0KPj4KZW5kb2JqCjI0NjkgMCBvYmoKPDwKL01DSUQgMTgKPj4KZW5kb2JqCjI0NzAgMCBvYmoKPDwKL1R5cGUgL0JhY2tncm91bmQKL0JCb3ggWzE0My4xMzc1IDQyMS40MjUgMTQzLjEzNzUgNDM2LjU3NDk4XQo+PgplbmRvYmoKMjQ3MSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvVEhlYWQKL1AgMzg3IDAgUgo+PgplbmRvYmoKMjQ3MiAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvVEJvZHkKL1AgMzg3IDAgUgovUGcgOSAwIFIKL0sgWzM5NCAwIFIgMzk1IDAgUl0KPj4KZW5kb2JqCjI0NzMgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL1RGb290Ci9QIDM4NyAwIFIKPj4KZW5kb2JqCjI0NzQgMCBvYmoKPDwKL08gL0xpc3QKL0xpc3ROdW1iZXJpbmcgL0Rpc2MKPj4KZW5kb2JqCjI0NzUgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0xJCi9QIDM4OCAwIFIKL1BnIDkgMCBSCi9LIDM5NiAwIFIKPj4KZW5kb2JqCjI0NzYgMCBvYmoKPDwKL08gL0xpc3QKL0xpc3ROdW1iZXJpbmcgL0Rpc2MKPj4KZW5kb2JqCjI0NzcgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0xJCi9QIDM4OSAwIFIKL1BnIDE0IDAgUgovSyA1MzYgMCBSCj4+CmVuZG9iagoyNDc4IDAgb2JqCjw8Ci9PIC9MaXN0Ci9MaXN0TnVtYmVyaW5nIC9EaXNjCj4+CmVuZG9iagoyNDc5IDAgb2JqCjw8Ci9UeXBlIC9TdHJ1Y3RFbGVtCi9TIC9MSQovUCAzOTAgMCBSCi9QZyAxNyAwIFIKL0sgNTgxIDAgUgo+PgplbmRvYmoKMjQ4MCAwIG9iago8PAovTyAvTGlzdAovTGlzdE51bWJlcmluZyAvRGlzYwo+PgplbmRvYmoKMjQ4MSAwIG9iago8PAovVHlwZSAvU3RydWN0RWxlbQovUyAvTEkKL1AgMzkxIDAgUgovUGcgMTcgMCBSCi9LIDU5MSAwIFIKPj4KZW5kb2JqCjI0ODIgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCAzOTYgMCBSCi9QZyA5IDAgUgovSyBbMzk4IDAgUiA0MDEgMCBSIDQwMiAwIFIgNDAzIDAgUl0KPj4KZW5kb2JqCjI0ODMgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1MzYgMCBSCi9QZyAxNCAwIFIKL0sgWzUzNyAwIFIgNTQwIDAgUiA1NDEgMCBSIDU0MiAwIFIgNTQzIDAgUl0KPj4KZW5kb2JqCjI0ODQgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1ODEgMCBSCi9QZyAxNyAwIFIKL0sgWzU4MiAwIFIgNTg1IDAgUl0KPj4KZW5kb2JqCjI0ODUgMCBvYmoKPDwKL1R5cGUgL1N0cnVjdEVsZW0KL1MgL0RpdgovUCA1OTEgMCBSCi9QZyAxNyAwIFIKL0sgWzU5MiAwIFIgNTk1IDAgUl0KPj4KZW5kb2JqCjI0ODYgMCBvYmoKPDwKL1R5cGUgL0ZvbnQKL1N1YnR5cGUgL0NJREZvbnRUeXBlMgovQmFzZUZvbnQgL1NvdXJjZVNhbnNQcm8tUmVndWxhcgovQ0lEU3lzdGVtSW5mbyAyNDkxIDAgUgovRm9udERlc2NyaXB0b3IgMjQ5MiAwIFIKL1cgWzAgWzY1MyAyMDAgNTQ0IDU4OCA1NzEgNjE1IDUyNyA0OTQgNjE3IDY1MgoyNjMgNDgwIDU3OSA0ODYgNzI3IDY0NyA2NjQgNTY2IDY2NCA1NjkKNTM0IDUzNiA2NDUgNTE1IDc4NiA1MTMgNDc2IDUzOSA1MDQgNTUzCjQ1NiA1NTUgNDk2IDI5MiA1MDQgNTQ0IDI0NiAyNDcgNDk1IDI1NQo4MjkgNTQ3IDU0Ml0KIDQzIDQ0IDU1NSA0NSBbMzQ3IDQxOSAzMzggNTQ0IDQ2NyA3MTggNDQ2IDQ2NyA0MjVdCiA1NCA3NSA1NDQKNzYgNzggODIyIDc5IFs2MDMgNTg4XQogODEgODUgNTcxIDg2IDg4CjYxNSA4OSBbNjM4XQogOTAgMTA3IDUyNyAxMDggMTE2IDYxNyAxMTcKMTE5IDY1MiAxMjAgWzY4N10KIDEyMSAxMzIgMjYzIDEzMyBbNDgwXQogMTM0CjEzNiA1NzkgMTM3IDE0MyA0ODYgMTQ0IFs0ODldCiAxNDUgMTQ3IDcyNwoxNDggMTU1IDY0NyAxNTYgMTczIDY2NCAxNzQgWzg0N10KIDE3NSAxODEKNjY0IDE4MiAxODggNTY5IDE4OSAxOTUgNTM0IDE5NiBbNjY3XQogMTk3CjIwMiA1MzYgMjAzIDIxOSA2NDUgMjIwIDIyNSA2NTkgMjI2IDIyOQo3ODYgMjMwIDIzNyA0NzYgMjM4IDI0MiA1MzkgMjQzIFs2MzggNTgzIDY1OCA2MzUgNTI2XQogMjQ4CjI2OSA1MDQgMjcwIDI3MiA3ODUgMjczIFs1NDQgNTUzXQogMjc1IDI3OSA0NTYKMjgwIFs1NzNdCiAyODEgMjgzIDU1NSAyODQgMzAxIDQ5NiAzMDIgMzA5CjUwNCAzMTAgMzE0IDU0NCAzMTUgMzI3IDI0NiAzMjggWzI0N10KIDMyOQozMzIgNDk1IDMzMyBbMjU1IDI3MCAzNjJdCiAzMzYgMzM5IDI1NSAzNDAgWzI2Ml0KIDM0MQozNDMgODI5IDM0NCAzNTEgNTQ3IDM1MiBbNzc1XQogMzUzIDM3MCA1NDIKMzcxIFs4MzldCiAzNzIgMzc4IDU0MiAzNzkgMzg1IDM0NyAzODYgMzkyCjQxOSAzOTMgWzU3Nl0KIDM5NCA0MDAgMzM4IDQwMSA0MjMgNTQ0IDQyNAo0MjcgNzE4IDQyOCA0MzUgNDY3IDQzNiA0NDAgNDI1IDQ0MSBbNTQ1IDU1NSA1NDcgMjQ3IDQ5MyA1MTJdCjQ0NyA0NDggNTU1IDQ0OSA0NTAgNDU2IDQ1MSA0NTIgNTU1IDQ1MwpbNDk2IDU1NSA1MDggNDk2IDY0OCA0NDAgNDU2IDU0NiAyNzBdCiA0NjIgNDYzIDU1OSA0NjQgWzQ5NyA0NjcgNTExIDU0N10KIDQ2OCA0NjkgNTQ0IDQ3MApbNTYyIDI3MCAzNDEgMjg0IDMwMiAyNTUgNTc3IDQxMV0KIDQ3OCA0ODAgODI5IDQ4MSA0ODIgNTQ3IDQ4MyBbNTQzIDU0MiA2OTkgNjgwXQogNDg3CjQ5MCAzNDcgNDkxIFszMzRdCiA0OTIgNDkzIDQ5NSA0OTQgWzQxOSAyNDcgMjcwIDMzOCA1NzUgNTQxIDUzMCA0NjcgNzE4IDQ2Nwo0MTUgNDI1IDQ0OSA0MjUgNDE3IDQ0M10KIDUxMAo1MTEgNDQxIDUxMiBbMjg4IDUyNSA1NzcgODIzIDgzMiA1OTQgODc5XQogNTE5IDUzMSAzNDMgNTMyIFs2NDddCiA1MzMKNTU1IDU1NSA1NTYgNTY0IDU1OSA1NjUgNTY2IDI0NiA1NjcgWzI2NSAzNjJdCjU2OSA1NzIgMjQ2IDU3MyBbMjU3IDU1NiA1NDQgNTg4IDQ5OCA1ODggNTI3IDUzOSA2NTIgNjY0CjI2MyA1NzkgNTE1IDcyNyA2NDcgNTMzIDY2NCA2NDUgNTY2IDUzOAo1MzYgNDc2IDcxOSA1MTMgNjk5IDY3OCA1NjYgNTkxIDcxNiAzMjcKMjYzIDcxMSA2MDAgNDc2IDcyMyA1NjAgNTY1IDQ4NCA1MzEgNDQ4CjQyNCA1NDEgNTIyIDI2Ml0KIDYxNyA2MTggNDk0IDYxOSBbNTYyIDQ3NCA0MzEgNTM1IDU4NiA1NDkgNTQ2IDQ2MCA1MTAgNjgwCjQ4MSA2ODkgNzAxIDQzMiA1NjAgNTIyIDY4MCA1NjAgNDQ4IDU0MV0KNjM5IDY0MCAyNjIgNjQxIFs1MzVdCiA2NDIgNjQzIDUxMCA2NDQgWzcwMSAyNjIgNTEwIDU4MCA1NzNdCjY0OSA2NTAgNTY2IDY1MSBbNzE0IDcxMCA3MDkgNzA1XQogNjU1IDY1NiA2MTMgNjU3IDY1OAo1NDQgNjU5IDY2MCA2NDUgNjYxIDY2MiA1OTEgNjYzIFs3NjQgNzYxIDc2MCA3NTZdCiA2NjcKNjY4IDc3MCA2NjkgNjcwIDcxNiA2NzEgWzg4OV0KIDY3MiA2NzMgODg1CjY3NCBbODgxXQogNjc1IDY3NiA4NDAgNjc3IDY3OCAzODEgNjc5IDY4MAozMjcgNjgxIFs1MDAgNDk3IDQ5NiA0OTJdCiA2ODUgNjg2IDQ1MSA2ODcgNjg4IDI2MyA2ODkKWzc2MSA3NDcgNzE3IDcxMSA4ODQgODg2IDg4MCA4NzYgNjg0IDY0NV0KIDY5OSA3MDAgNjAwIDcwMSBbNzY5IDc2NSA3MThdCiA3MDQgNzA1IDQ3NiA3MDYKWzc3MyA3NTkgNzI2IDcyMyA5MDAgODk2IDg5NSA4OTFdCiA3MTQgNzE1IDgxNyA3MTYgWzgwMiA4MzkgODMyIDk3Ml0KIDcyMCA3MjEgOTY4IDcyMgpbOTY0XQogNzIzIDcyNCA4NzIgNzI1IFs5MTBdCiA3MjYgNzI3IDEwMjggNzI4ClsxMTQ4IDExNDQgMTE0MyAxMTQwXQogNzMyIDczMyAxMDk4IDczNCBbOTM1IDEwMzEgMTAxOCAxMTU4IDExNTUgMTE1NCAxMTUwXQogNzQxIDc0MiAxMDc4IDc0Mwo3NTUgNTYwIDc1NiA3NjMgNDQ4IDc2NCA3NzQgNTQxIDc3NSA3OTAKMjYyIDc5MSA3OTggNTM1IDc5OSA4MDAgNTQ5IDgwMSA4MTYgNTEwCjgxNyA4MjcgNzAxIDgyOCA4MzkgNTYwIDg0MCA4NTEgNTQxIDg1Mgo4NjMgNzAxIDg2NCBbNDk0IDUzNSA0NjYgNDEzIDQ5OF0KIDg2OSA4NzMgMjQ5IDg3NCBbNTQyIDY0XQogODc2Cjg3NyA1NDIgODc4IFsyNjJdCiA4NzkgODkzIDU0MiA4OTQgWzExOSAxMTddCiA4OTYKODk3IDY0IDg5OCBbMjM3IDIzNCAyMzcgMjMwXQogOTAyIDkwMyAxODggOTA0IFs1NDQgNTgwIDU4OCA0OTggNjM4IDUyN10KIDkxMAo5MTEgODA1IDkxMiBbODAzIDU1NF0KIDkxNCA5MTUgNjU2IDkxNiA5MTcgNTgwCjkxOCBbNTc3IDYzMCA3MjcgNjUyIDY2NCA2NDUgNTY2IDU3MSA1MzYgNTE0CjczMiA1MTMgNjQyIDU5OCA4NjUgODc0IDcyMCA3OTggNTgwIDU3MQo5MDggNTgyXQogOTQwIDk0MSA1MjcgOTQyIFs2ODcgNDk4IDU3MSA1MzRdCiA5NDYgOTQ4IDI2Mwo5NDkgWzQ4MCA5MDMgOTI5IDY5NiA1ODBdCiA5NTQgOTU1IDU3NyA5NTYgWzY1NiA1MTQgNjQ1IDYxNCA2NjQgNTI5IDQ5OCA1MjEgODQ3XQogOTY1IDk2NiA4NTIKOTY3IFs1NTQgNjI4XQogOTY5IDk3MCA2MjUgOTcxIFs3MTZdCiA5NzIgOTczIDcyMAo5NzQgWzY2MSA1NzFdCiA5NzYgOTc3IDQ3NiA5NzggWzU1MSA2MDcgNTk4IDI2MyA4MDVdCiA5ODMgOTg0IDgwMwo5ODUgWzU0NCA4MjIgNTI3IDY1OCA2NTZdCiA5OTAgOTkxIDY2NCA5OTIgOTkzIDUxNCA5OTQgWzUwNCA1NDQgNTA4IDQxMSA1MzIgNDk2XQoxMDAwIDEwMDEgNjgxIDEwMDIgWzY4MiA0NTZdCiAxMDA0IDEwMDUgNTY1IDEwMDYgMTAwOAo0OTggMTAwOSBbNTMxIDYzMyA1NjIgNTQyIDU1MyA1NTUgNDU2IDQ2MCA0NjcgNzM0CjQ0NiA1NTQgNTEyIDc0OSA3NTcgNTk2IDY3NCA0OTEgNDU2IDczOAo1MTRdCiAxMDMwIDEwMzEgNDk2IDEwMzIgWzU0OCA0MTEgNDU2IDQxOV0KIDEwMzYgMTAzNwoyNDYgMTAzOCBbMjU3IDI0NyA3MzUgNzU4IDU0NF0KIDEwNDMgMTA0NSA0OTggMTA0NiBbNTY1IDQ2NyA1NTggNTc2IDU0MiA0NzcgNDE2IDQyNF0KIDEwNTQgMTA1Ngo3MTggMTA1NyBbNDU2XQogMTA1OCAxMDYwIDUzNiAxMDYxIDEwNjMgNjE0IDEwNjQKWzU3MCA0NTZdCiAxMDY2IDEwNjcgNDY3IDEwNjggWzQ4MiA1MjAgNTQ0IDY4MV0KIDEwNzIgMTA3MyA2ODIgMTA3NApbMjU1IDUwNCA3ODVdCiAxMDc3IDEwNzggNDk2IDEwNzkgWzU2NV0KIDEwODAgMTA4MSA1NDIgMTA4MgoxMDgzIDQ2NyAxMDg0IFs1MjYgODkzIDYwOV0KIDEwODcgMTA5OCA0OTcgMTA5OSBbNTM4IDM2OSA1MDEgNDk3IDUxOSA0OTcgNTI1IDQ5MV0KIDExMDcKMTEwOCA1MjUgMTEwOSAxMTEwIDUzOCAxMTExIDExMjAgNDk3IDExMjEgWzUxOCAzNjldCjExMjMgMTEyNCA0OTcgMTEyNSBbNTE4IDQ5NyA1MTggNDg5IDUxOSA1MThdCiAxMTMxIDExNDAgNDk3IDExNDEgMTE0NAoyNDkgMTE0NSBbOTQ4XQogMTE0NiAxMTQ3IDI4OSAxMTQ4IDExNDkgNDI1IDExNTAKWzI0OSA0MjVdCiAxMTUyIDExNTMgMjQ5IDExNTQgMTE1NSA0MjUgMTE1NiBbMjQ5IDQyNV0KIDExNTgKMTE1OSAyNzEgMTE2MCAxMTYxIDQyOSAxMTYyIDExNjMgMzExIDExNjQgWzQ4MCA4MDAgMTUwMCAyMjAwIDQ5NyA4MDAgMjQ5IDMwNF0KMTE3MiAxMTczIDUwMCAxMTc0IFswXQogMTE3NSAxMTgwIDMwMyAxMTgxIFszNTAgMjQxIDM1MCAyNDEgNDE4XQoxMTg2IDExODcgNDU0IDExODggWzQ5NyA1NjAgMzkwIDU0OSA4MTVdCiAxMTkzIDExOTQgNjc5IDExOTUgWzQzMl0KMTE5NiAxMTk5IDMwMyAxMjAwIDEyMDEgMzc4IDEyMDIgMTIwNSAzMDMgMTIwNgpbNzQ0IDc0MyA0MjNdCiAxMjA5IDEyMTEgNjM3IDEyMTIgWzY1MyA4NDcgNzgyIDQ5NyAyNDYgNDcwIDUyNiA1MDMgNTU1IDQ3NQo0NDMgNTQ5IDU5NCAyNjMgNDM4IDUxNCA0MzcgNjQ3IDU4NSA1ODkKNTE4IDU4OSA1MjMgNDc0IDQ2NyA1ODMgNDQ3IDY4NCA0NTMgNDE1CjQ3NV0KIDEyNDMgMTI2NCA0NzAgMTI2NQoxMjY3IDcxMiAxMjY4IFs1NDUgNTI2XQogMTI3MCAxMjc0IDUwMyAxMjc1IDEyNzcgNTU1CjEyNzggWzU3NF0KIDEyNzkgMTI5NiA0NzUgMTI5NyAxMzA1IDU0OSAxMzA2IDEzMDgKNTk0IDEzMDkgWzYzMF0KIDEzMTAgMTMyMSAyNjMgMTMyMiBbNDM4XQogMTMyMyAxMzI1CjUxNCAxMzI2IDEzMzMgNDM3IDEzMzQgMTMzNiA2NDcgMTMzNyAxMzQ0IDU4NQoxMzQ1IDEzNjAgNTg5IDEzNjEgWzczNV0KIDEzNjIgMTM3MCA1ODkgMTM3MSAxMzc3CjUyMyAxMzc4IDEzODQgNDc0IDEzODUgWzkzOCA1OTRdCiAxMzg3IDEzOTIgNDY3IDEzOTMKMTQwOSA1ODMgMTQxMCAxNDE1IDU5NyAxNDE2IDE0MTkgNjg0IDE0MjAgMTQyNwo0MTUgMTQyOCAxNDMyIDQ3NSAxNDMzIFs1NzQgNTI1IDU4MiA1NjggNTI2IDU4NSA0NzAgNTI2IDQ0OCA1MTRdCiAxNDQzIDE0NDQgNDc1IDE0NDUKWzU5NCA1ODkgMjYzIDUxNCA0NDUgNjQ3IDU4NSA0NzEgNTg5IDU4OAo1MTggNDcxIDQ2NyA0MTUgNjU1IDQ1MyA2MjUgNTkyIDI2MyA0MTUKNzMzIDg1NyA4NTUgNDcwIDUxOSA1MjYgNDQ4IDU2MiA0NzUgNjk3CjQ4Nl0KIDE0NzYgMTQ3NyA1ODUgMTQ3OCBbNTE5IDU1OCA2NDcgNTk0IDU4OSA1ODggNTE4IDUwMyA0NjcgNDQ1CjY0MCA0NTMgNTc5IDU0MSA3NzIgNzc5IDYyMiA3MjAgNTIwIDUwMgo4MDEgNTIyXQogMTUwMCAxNTAxIDQ3NSAxNTAyCls1OTcgNDQ4IDUwMSA0NzRdCiAxNTA2IDE1MDggMjYzIDE1MDkgWzQzOCA3NjUgODA4IDYxMSA1MTkgNTg1IDQ0NSA1ODEgNTQyIDU4OQo0NTYgNDQ4IDQ3MCA3NDMgNDg2IDU2NyA2MzcgNjAxIDUwM10KIDE1MjggMTUyOSA0MTUgMTUzMApbNDkxIDU0NyA1NDEgMjYzIDY5NyA0NzAgNzEyIDQ3NSA1ODIgNTg1XQogMTU0MCAxNTQxIDU4OSAxNTQyIDE1NDMgNDQ1IDE1NDQgWzUzNCA1MDUgMzU4IDQ1MyA0NTkgNDgxIDQ2NSA0ODggNDMxIDQ4OQo0ODNdCiAxNTU1CjE1NTYgMjg5IDE1NTcgMTU1OCA0MjUgMTU1OSBbMjQ5IDQyNV0KIDE1NjEgMTU2MiAyNDkKMTU2MyAxNTY0IDM5NiAxNTY1IFszMTEgNDE0IDY4N10KIDE1NjggMTU3MyAzMDMgMTU3NCAxNTgzCjM2NyAxNTg0IDE1ODUgMjM3IDE1ODYgMTU4NyAxNzcgMTU4OCAxNTk3IDM2NwoxNTk4IDE1OTkgMjM3IDE2MDAgMTYwMSAxNzcgMTYwMiAxNjExIDM2NyAxNjEyCjE2MTMgMjM3IDE2MTQgMTYxNSAxNzcgMTYxNiAxNjI1IDM2NyAxNjI2IDE2MjcKMjM3IDE2MjggMTYyOSAxNzcgMTYzMCBbMzQ1IDM3NCAzNjUgMzYzIDM5MiAzNzkgNDExIDM1MSAzMzAgNDExCjQzNCAxNzYgMzIxIDM4NyAzMjUgNDg2IDQzMSA0NDMgMzg1IDQ0MwozODldCiAxNjUxIDE2NTIgMzU2IDE2NTMKWzQzMSAzNDYgNTI2IDM0NiAzMjAgMzU4IDM0NSAzNzQgMzA2IDM3NAozMzYgMjAxIDM0MyAzNjYgMTY2IDE2OSAzMzcgMTc0IDU1OSAzNjkKMzY1XQogMTY3NCAxNjc1IDM3NCAxNjc2IFsyNDAgMjgzIDIzMiAzNzAgMzIxIDQ4NyAzMDcgMzE5IDI5MCAzMDJdCiAxNjg2IDE2ODcgMjQ5IDE2ODgKWzE1MSAzMThdCiAxNjkwIDE2OTIgMzM2IDE2OTMgWzM3NCAzNzcgMTY2IDE3NyAyMzYgMzQ4IDU2MiAzMzFdCiAxNzAxIDE3MjMgNDk3IDE3MjQKMTcyNiA4NiAxNzI3IFs4MjQgMTE5NCA3ODEgODA4IDc5NiA4MDQgODIxIDgwNF0KIDE3MzUgMTczNiA4MjEgMTczNyBbODQ2IDgwNCA4MjFdCiAx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IDE5NyAyMDIgNTU2IDIwMyAyMTkgNjY1CjIyMCAyMjUgNjgzIDIyNiAyMjkgODEzIDIzMCAyMzcgNTI1IDIzOAoyNDIgNTQxIDI0MyBbNjYwIDYxNyA2NzUgNjY2IDYwMl0KIDI0OCAyNjkgNTI3IDI3MCAyNzIgNzg2CjI3MyBbNTcxIDU3M10KIDI3NSAyNzkgNDY3IDI4MCBbNjE0XQogMjgxIDI4MyA1NzMKMjg0IDMwMSA1MTggMzAyIDMwOSA1MzQgMzEwIDMxNCA1NzEgMzE1CjMyNyAyNzYgMzI4IFsyNzhdCiAzMjkgMzMyIDU0OCAzMzMgWzI4NiAzMTkgNDUzXQogMzM2CjMzOSAyODYgMzQwIFszMDNdCiAzNDEgMzQzIDg1NyAzNDQgMzUxIDU3MgozNTIgWzg1Ml0KIDM1MyAzNzAgNTU1IDM3MSBbODIyXQogMzcyIDM3OCA1NTUKMzc5IDM4NSAzOTggMzg2IDM5MiA0NDMgMzkzIFs2MzJdCiAzOTQgNDAwCjM4MyA0MDEgNDIzIDU2OCA0MjQgNDI3IDc3NiA0MjggNDM1IDUyMQo0MzYgNDQwIDQ2MCA0NDEgWzU2MCA1NzMgNTcyIDI3OCA1NTQgNTM0XQogNDQ3IDQ0OCA1NzMgNDQ5IDQ1MAo0NjcgNDUxIDQ1MiA1NzMgNDUzIFs1MTggNTczIDUyOCA1MTggNzA3IDQ2MiA0NzYgNTY2IDMyMV0KIDQ2MiA0NjMgNTgzIDQ2NApbNTE3IDUyMyA1NjkgNTcyXQogNDY4IDQ2OSA1NzEgNDcwIFs1ODIgMzIxIDM5NSAzNjAgMzc3IDI4NiA2NDAgNDMyXQogNDc4IDQ4MCA4NTcgNDgxCjQ4MiA1NzIgNDgzIFs1NjEgNTU1IDcyNiA3MzhdCiA0ODcgNDkwIDM5OCA0OTEgWzM4MF0KIDQ5Mgo0OTMgNTMyIDQ5NCBbNDQzIDI3OCAzMjEgMzgzIDYxNyA1NTggNTUyIDUyMyA3NzYgNTIxCjQ2NiA0NjAgNTAzIDQ2MCA0NDggNTA2XQogNTEwIDUxMSA0NzYgNTEyIFszMzAgNTU2IDY1NyA5MzMgOTQzIDY4OCAxMDA0XQogNTE5CjUzMSAzOTYgNTMyIFs2NjVdCiA1MzMgNTU1IDU3MyA1NTYgNTY0IDU4Mwo1NjUgNTY2IDI3NiA1NjcgWzMxOCA0NTNdCiA1NjkgNTcyIDI3NiA1NzMgWzI5OSA2MzUgNTczIDYwNSA1MjEgNjQwIDU0OCA1NDEgNjc0IDY4NAozMDEgNjE0IDU1NiA3NjIgNjY1IDU3MSA2ODQgNjYzIDU5NiA1NDkKNTU2IDUyNSA3NjAgNTY3IDc1MiA3MTEgNjIyIDY2NyA3OTIgNDIwCjMwMSA3NzcgNzA0IDUyNSA4MDMgNTk1IDYwMCA1MzMgNTQ4IDQ3MQo0NjYgNTYyIDU0OSAzMDEgNTQ2IDU1MiA1OTQgNTIzIDQ2OSA1NTMKNjM1IDU2OSA1NzMgNDkyIDUzMiA3MzggNTI2IDc1MiA3NDYgNDQ2CjU5MiA1NDkgNzM4IDU5NSA0NzEgNTYyXQo2MzkgNjQwIDMwMSA2NDEgWzU1M10KIDY0MiA2NDMgNTMyIDY0NCBbNzQ2IDMwMSA1MzIgNjU1IDYzOV0KNjQ5IDY1MCA2MjIgNjUxIFs4MjIgODIxIDgxMiA4MTFdCiA2NTUgNjU2IDY3OSA2NTcgNjU4CjU3MyA2NTkgNjYwIDcxMSA2NjEgNjYyIDY2NyA2NjMgWzg3NCA4NzMgODY0IDg2M10KIDY2Nwo2NjggODM2IDY2OSA2NzAgNzkyIDY3MSBbOTk5IDk5OCA5OTAgOTg4XQogNjc1IDY3NiA4OTYKNjc3IDY3OCA0NjQgNjc5IDY4MCA0MjAgNjgxIFs2MjcgNjI2IDYxNyA2MTZdCiA2ODUgNjg2CjUyNCA2ODcgNjg4IDMwMSA2ODkgWzgyNyA4MDggNzkwIDc3NyA5ODQgOTk2IDk3NCA5NzMgNzU5IDczMV0KIDY5OSA3MDAgNzA0IDcwMQpbOTEwIDkwMCA3OTRdCiA3MDQgNzA1IDUyNSA3MDYgWzg1MyA4MzUgODExIDgwMyAxMDE4IDEwMTcgMTAwOCAxMDA3XQogNzE0IDcxNSA4NzcgNzE2Cls4NjcgOTQ5IDkzMyAxMTE2IDExMTUgMTEwNiAxMTA1XQogNzIzIDcyNCA5NzMgNzI1IFs5NjhdCiA3MjYgNzI3IDExMzEgNzI4ClsxMjk0IDEyOTMgMTI4NCAxMjgzXQogNzMyIDczMyAxMTkwIDczNCBbMTAwNSAxMTQ3IDExMjkgMTMxMyAxMzExIDEzMDMgMTMwMl0KIDc0MSA3NDIgMTE3MiA3NDMKNzU1IDU5NSA3NTYgNzYzIDQ3MSA3NjQgNzc0IDU2MiA3NzUgNzkwCjMwMSA3OTEgNzk4IDU1MyA3OTkgODAwIDU2OSA4MDEgODE2IDUzMgo4MTcgODI3IDc0NiA4MjggODM5IDU5NSA4NDAgODUxIDU2MiA4NTIKODYzIDc0NiA4NjQgWzU0NiA1NTMgNDkwIDQzMyA1MzZdCiA4NjkgODczIDMwMCA4NzQgWzU1NSAxMTldCiA4NzYKODc3IDU1NSA4NzggWzMwMV0KIDg3OSA4OTMgNTU1IDg5NCBbMTY0IDE2MV0KIDg5Ngo4OTcgMTE5IDg5OCBbMzI2IDMyNSAzMjYgMzE3XQogOTAyIDkwMyAyMjMgOTA0IFs1NzMgNjAwIDYwNSA1MjEgNjcwIDU0OF0KIDkxMAo5MTEgODY4IDkxMiBbODczIDU2NF0KIDkxNCA5MTUgNjc2IDkxNiA5MTcgNjIyCjkxOCBbNjE1IDY1NyA3NjIgNjc0IDY4NCA2NjMgNTk2IDU4MiA1NTYgNTU1Cjc2NCA1NjcgNjY5IDYzMCA5MTAgOTI2IDczMCA4NTMgNjAwIDU4Mgo5NTAgNjE3XQogOTQwIDk0MSA1NDggOTQyIFs3MDEgNTIxIDU4MiA1NTZdCiA5NDYgOTQ4IDMwMQo5NDkgWzUwOSA5MjAgOTMzIDcxOCA2MjJdCiA5NTQgOTU1IDYxNSA5NTYgWzY3NiA1NTUgNjYzIDYyNCA2ODQgNTc0IDUyMSA1NDYgOTA1XQogOTY1IDk2NiA5MzEKOTY3IFs1NjQgNjY3XQogOTY5IDk3MCA2NzAgOTcxIFs3NDldCiA5NzIgOTczIDc0NAo5NzQgWzY4OSA1ODJdCiA5NzYgOTc3IDUyNSA5NzggWzYwNSA2NDUgNjMwIDMwMSA4NjhdCiA5ODMgOTg0IDg3Mwo5ODUgWzU3MyA4NDUgNTQ4IDY3NSA2NzZdCiA5OTAgOTkxIDY4NCA5OTIgOTkzIDU1NSA5OTQgWzUyNyA1NjEgNTI4IDQzMiA1ODQgNTE4XQoxMDAwIDEwMDIgNzYxIDEwMDMgWzQ3Nl0KIDEwMDQgMTAwNSA1ODMgMTAwNiAxMDA4CjU0NiAxMDA5IFs1NzMgNjYwIDU4MiA1NTUgNTc0IDU3MyA0NjcgNDkyIDUyMSA3NzkKNTE0IDU5NSA1NTAgODAzIDgyOSA2MjMgNzM5IDUxNiA0NjcgNzc2CjU0NF0KIDEwMzAgMTAzMSA1MTggMTAzMiBbNTcyIDQzMiA0NjcgNDQzXQogMTAzNiAxMDM3CjI3NiAxMDM4IFsyOTkgMjc4IDc4MCA3ODggNTcxXQogMTA0MyAxMDQ1IDU0NiAxMDQ2IFs1ODMgNTIxIDU3OCA2MDAgNTU1IDUzMyA0MzMgNDU3XQogMTA1NCAxMDU2CjgwMyAxMDU3IFs0NzZdCiAxMDU4IDEwNjAgNTg4IDEwNjEgMTA2MyA2NTYgMTA2NApbNjA4IDQ2N10KIDEwNjYgMTA2NyA1MjMgMTA2OCBbNTQ4IDU3NSA1NzFdCiAxMDcxIDEwNzMgNzYxIDEwNzQKWzI4NiA1MjcgNzg2XQogMTA3NyAxMDc4IDUxOCAxMDc5IFs1ODNdCiAxMDgwIDEwODEgNTU1IDEwODIKMTA4MyA1MjEgMTA4NCBbNTQ2IDk2NyA2NjddCiAxMDg3IDEwOTggNTI4IDEwOTkgWzU4MCA0MTAgNTI2IDUyOCA1NjAgNTI4IDU2MiA1MTYgNTQ5IDU2Ml0KIDExMDkKMTExMCA1ODAgMTExMSAxMTIwIDUyOCAxMTIxIFs1NDUgNDEwIDUxOCA1MjggNTQ1IDUyOCA1NDUgNTE2IDU0NyA1NDVdCiAxMTMxIDExNDAgNTI4CjExNDEgMTE0NCAzMDAgMTE0NSBbOTc3XQogMTE0NiAxMTQ3IDM0MCAxMTQ4IDExNDkKNDYzIDExNTAgWzMwMCA1MzZdCiAxMTUyIDExNTMgMzAwIDExNTQgMTE1NSA1MzYgMTE1NgpbMzAwIDUzNl0KIDExNTggMTE1OSAyOTIgMTE2MCAxMTYxIDQ4MCAxMTYyIDExNjMgMzMyCjExNjQgWzQ4MCA4MDAgMTUwMCAyMjAwIDUyOCA4MDAgMzAwIDM0NV0KIDExNzIgMTE3MyA1MDAgMTE3NCBbMF0KIDExNzUgMTE4MCAzNDQKMTE4MSBbMzM5IDI2OCAzMzkgMjY4IDQ1N10KIDExODYgMTE4NyA1MTAgMTE4OCBbNTI4IDYzNiA0NTIgNjE0IDg3M10KIDExOTMgMTE5NCA3NTAKMTE5NSBbNDgwXQogMTE5NiAxMTk5IDM0NCAxMjAwIDEyMDEgNDM3IDEyMDIgMTIwNQozNDQgMTIwNiAxMjA3IDc1MCAxMjA4IFs0NjJdCiAxMjA5IDEyMTEgNjgyIDEyMTIKWzcxOSA5MDMgODMwIDUyOCAyNzYgNTAzIDU0NiA1MjAgNTgwIDQ5OQo0NzYgNTc2IDYyMSAzMDEgNDcwIDU1NSA0NzEgNjg1IDYwNiA2MTYKNTUxIDYxNCA1NjEgNTA0IDQ5MSA2MDcgNDkxIDcxNyA1MDkgNDY3CjQ4MV0KIDEyNDMgMTI2NCA1MDMgMTI2NSAxMjY3IDc0MSAxMjY4IFs1NzAgNTQ2XQogMTI3MAoxMjc0IDUyMCAxMjc1IDEyNzcgNTgwIDEyNzggWzYwNF0KIDEyNzkgMTI5NiA0OTkKMTI5NyAxMzA1IDU3NiAxMzA2IDEzMDggNjIxIDEzMDkgWzY2MF0KIDEzMTAgMTMyMQozMDEgMTMyMiBbNDcwXQogMTMyMyAxMzI1IDU1NSAxMzI2IDEzMzMgNDcxIDEzMzQKMTMzNiA2ODUgMTMzNyAxMzQ0IDYwNiAxMzQ1IDEzNjAgNjE2IDEzNjEgWzc2Nl0KMTM2MiAxMzcwIDYxNiAxMzcxIDEzNzcgNTYxIDEzNzggMTM4NCA1MDQgMTM4NQpbOTk4IDYzNl0KIDEzODcgMTM5MiA0OTEgMTM5MyAxNDA5IDYwNyAxNDEwIDE0MTUgNjI1CjE0MTYgMTQxOSA3MTcgMTQyMCAxNDI3IDQ2NyAxNDI4IDE0MzIgNDgxIDE0MzMKWzYwNCA1NjIgNjA0XQogMTQzNiAxNDM3IDYwMiAxNDM4IFs2MDYgNTAzIDU0NiA0NzIgNTcwIDQ5OSA0ODEgNjIxIDYxNiAzMDEKNTU1IDQ4OCA2ODUgNjA2IDUxMyA2MTYgNjE1IDU1MSA0ODYgNDkxCjQ2NyA3MDggNTA5IDY4MiA2MzMgMzAxIDQ2NyA4MDUgOTIzIDkzMgo1MDMgNTQzIDU0NiA0NzIgNjA0IDQ5OSA3NjYgNTAwXQogMTQ3NiAxNDc3IDYwNiAxNDc4Cls1NjcgNTkwIDY4NSA2MjEgNjE2IDYxNSA1NTEgNTIwIDQ5MSA0ODcKNjc3IDUwOSA2MTAgNTc2IDgyMyA4MzcgNjM5IDc3OSA1NDQgNTE2Cjg0OSA1NjFdCiAxNTAwIDE1MDEgNDk5IDE1MDIgWzYxNyA0NzIgNTE1IDUwNF0KIDE1MDYgMTUwOCAzMDEgMTUwOQpbNDcwIDc4NSA4MjEgNjM5IDU2NyA2MDYgNDg3IDYwMyA1NjUgNjE2CjUwNSA0NzIgNDk3IDgxMyA1MDAgNjEyIDY3NCA2MzYgNTIwXQogMTUyOCAxNTI5IDQ2NyAxNTMwIFs1NDcgNTkxIDU3NiAzMDEgNzY2IDUwMyA3NDEgNDk5IDYwNCA2MDZdCiAxNTQwIDE1NDEgNjE2IDE1NDIKMTU0MyA0ODcgMTU0NCBbNTk2IDU1MCA0MDAgNDgyIDQ5NSA1MjMgNDk0IDUxOSA0NjQgNTExCjUxM10KIDE1NTUgMTU1NiAzNDAgMTU1NyAxNTU4IDQ2MwoxNTU5IFszMDAgNTM2XQogMTU2MSAxNTYyIDMwMCAxNTYzIDE1NjQgNDcxIDE1NjUgWzMzMiA0MTggNjk2XQoxNTY4IDE1NzMgMzQ0IDE1NzQgMTU4MyAzNzYgMTU4NCAxNTg1IDI2OCAxNTg2CjE1ODcgMjA4IDE1ODggMTU5NyAzNzYgMTU5OCAxNTk5IDI2OCAxNjAwIDE2MDEKMjA4IDE2MDIgMTYxMSAzNzYgMTYxMiAxNjEzIDI2OCAxNjE0IDE2MTUgMjA4CjE2MTYgMTYyNSAzNzYgMTYyNiAxNjI3IDI2OCAxNjI4IDE2MjkgMjA4IDE2MzAKWzM1OSAzODUgMzczIDM4NyA0MDcgMzkwIDQyNyAzNjkgMzU0IDQzMQo0NTIgMjAzIDM0NCA0MTQgMzQ5IDUxNCA0NDYgNDYxIDQwOCA0NjEKNDE2IDM3NCAzNzYgNDQ4IDM3OCA1NDkgMzg2IDM1NiAzNjQgMzU5CjM4NSAzMTMgMzg1IDM0NiAyMzIgMzYxIDM4NCAxODggMTkwIDM3MQoxOTQgNTc3IDM4NCAzNzNdCiAxNjc0IDE2NzUgMzg1IDE2NzYgWzI3MiAyOTcgMjU5IDM4MyAzNTUgNTIzIDM0OCAzNTMgMzEyIDM0M10KIDE2ODYgMTY4NyAzMDAgMTY4OApbMTg5IDM1M10KIDE2OTAgMTY5MiAzNDYgMTY5MyBbMzg1IDM5MiAxODggMjA4IDI1MSAzNDkgNTYzIDM2NV0KIDE3MDEgMTcyMyA1MjggMTcyNAoxNzI2IDk2IDE3MjcgWzg1NyAxMjQ5IDgwOSA4NDYgODE4IDgzNyA4NDkgODM3XQogMTczNSAxNzM2IDg0OSAxNzM3IFs4OTIgODM3IDg0OV0KIDE3NDAKMTc0MSA4MzcgMTc0MiAxNzQzIDg0OSAxNzQ0IFs4MjkgODM3IDExNTUgODQ5XQogMTc0OCAxNzUxIDUyOAoxNzUyIFs1MjldCiAxNzUzIDE3NjMgNTI4IDE3NjQgWzgxNCA1OTQgNTc3IDM5MCA1ODggNjQwIDcxMSA1MzQgNzEwIDQ3MAo4MDBdCiAxNzc1IDE3NzggNjE3CjE3NzkgMTc5MCA4NzcgMTc5MSAxNzkyIDgwNyAxNzkzIFs2NDcgNTQ0IDU0OCAzMDAgNTM3XQogMTc5OCAxODAxCjMwMCAxODAyIDE4MDMgMTc2IDE4MDQgMTgwNyA1NTUgMTgwOCBbMTQ3IDMwOF0KIDE4MTAKMTgxMSAyMzYgMTgxMiBbMTQ3XQogMTgxMyAxODIxIDU1NSAxODIyIFs1NzddCiAxODIzCjE4NTIgMCAxODUzIFs0MV0KIDE4NTQgMTkzMyAwIDE5MzQgWzIwOCA1MjhdCiAxOTM2CjE5MzcgMTM5IDE5MzggWzEyNSAwIDYzNSA2MjddCl0KL0NJRFRvR0lETWFwIC9JZGVudGl0eQo+PgplbmRvYmoKMjQ4OSAwIG9iago8PAovTGVuZ3RoIDc4NDgKL0ZpbHRlciAvRmxhdGVEZWNvZGUKPj4Kc3RyZWFtDQp4nIWd26omN5KF7+sp9uXMReNUSCllgjHkSeCLOTCeeQC3a7sxjMum7L7w20/u/D5tgxmohmZR4TwoVioVEUvx5/7q+Pb89tNPv7989Z+ff/nhu9ffX3786dPHz6+//fLPzz+8vvz99R8/ffqQ4uXjTz/87r8+PPDDz9//+uGr++zv/vjt99efv/304y8fvv765av/uv/jb79//uPlX7aPv/z99V8/fPUfnz++fv7p0z9e/uV/ju/uf3/3z19//d/Xn18//f4yffjmm5ePrz9+uK/0b9//+u/f//z68tVz3t++/Xgf8NPvf/ztPuk55Dniv//49fUlOCUxnh9++fj626/f//D6+ftP/3j98PV0/++bl6/7/b9vPrx++viX//4hTRMn/v3HP89I9xnvENM3jzGef6X9gZIeYzqe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MDAwMDAwNzkyMCAwMDAwMCBuDQowMDAwMDEwNTcyIDAwMDAwIG4NCjAwMDAwMTA4MzUgMDAwMDAgbg0KMDAwMDAxMDkxOCAwMDAwMCBuDQowMDAwMDEzNzcwIDAwMDAwIG4NCjAwMDAwMTYxMzEgMDAwMDAgbg0KMDAwMDAxNjIxNyAwMDAwMCBuDQowMDAwMDE4NDMwIDAwMDAwIG4NCjAwMDAwMTg0ODYgMDAwMDAgbg0KMDAwMDAyMDU3MiAwMDAwMCBuDQowMDAwMDIwNjI4IDAwMDAwIG4NCjAwMDAwMjI1NjcgMDAwMDAgbg0KMDAwMDAyMjYyMyAwMDAwMCBuDQowMDAwMDI0NTk1IDAwMDAwIG4NCjAwMDAwMjQ2NTEgMDAwMDAgbg0KMDAwMDAyNzExMiAwMDAwMCBuDQowMDAwMDI3MTY4IDAwMDAwIG4NCjAwMDAwMjg4OTIgMDAwMDAgbg0KMDAwMDAyODk0OCAwMDAwMCBuDQowMDAwMDMwOTg3IDAwMDAwIG4NCjAwMDAwMzEwNDMgMDAwMDAgbg0KMDAwMDAzMzg0OCAwMDAwMCBuDQowMDAwMDMzOTA0IDAwMDAwIG4NCjAwMDAwMzYyMDIgMDAwMDAgbg0KMDAwMDAzNjI1OCAwMDAwMCBuDQowMDAwMDM3NzAxIDAwMDAwIG4NCjAwMDAwMzc3NTcgMDAwMDAgbg0KMDAwMDAzNzkyMyAwMDAwMCBuDQowMDAwMDM3OTk3IDAwMDAwIG4NCjAwMDAwMzgwNzEgMDAwMDAgbg0KMDAwMDAzODE0NiAwMDAwMCBuDQowMDAwMDM4MjE4IDAwMDAwIG4NCjAwMDAwMzgyOTIgMDAwMDAgbg0KMDAwMDAzODM2NSAwMDAwMCBuDQowMDAwMDM4NDQ5IDAwMDAwIG4NCjAwMDAwMzg1MjcgMDAwMDAgbg0KMDAwMDAzODYyNCAwMDAwMCBuDQowMDAwMDM4Njk5IDAwMDAwIG4NCjAwMDAwMzg3NzQgMDAwMDAgbg0KMDAwMDAzODg0OSAwMDAwMCBuDQowMDAwMDM4OTI0IDAwMDAwIG4NCjAwMDAwMzg5OTkgMDAwMDAgbg0KMDAwMDAzOTA3NCAwMDAwMCBuDQowMDAwMDM5MTQ5IDAwMDAwIG4NCjAwMDAwMzkyMjQgMDAwMDAgbg0KMDAwMDAzOTI5OSAwMDAwMCBuDQowMDAwMDM5Mzc0IDAwMDAwIG4NCjAwMDAwMzk0NDggMDAwMDAgbg0KMDAwMDAzOTUyMyAwMDAwMCBuDQowMDAwMDM5NTk4IDAwMDAwIG4NCjAwMDAwMzk2NzMgMDAwMDAgbg0KMDAwMDAzOTc1OSAwMDAwMCBuDQowMDAwMDM5ODM1IDAwMDAwIG4NCjAwMDAwMzk5MjEgMDAwMDAgbg0KMDAwMDAzOTk5NiAwMDAwMCBuDQowMDAwMDQwMDkyIDAwMDAwIG4NCjAwMDAwNDAxNzggMDAwMDAgbg0KMDAwMDA0MDI1NCAwMDAwMCBuDQowMDAwMDQwMzQwIDAwMDAwIG4NCjAwMDAwNDA0MTUgMDAwMDAgbg0KMDAwMDA0MDQ5MCAwMDAwMCBuDQowMDAwMDQwNTY1IDAwMDAwIG4NCjAwMDAwNDA2NTEgMDAwMDAgbg0KMDAwMDA0MDcyNyAwMDAwMCBuDQowMDAwMDQwODEzIDAwMDAwIG4NCjAwMDAwNDA4ODggMDAwMDAgbg0KMDAwMDA0MDk2NCAwMDAwMCBuDQowMDAwMDQxMDQwIDAwMDAwIG4NCjAwMDAwNDExMTYgMDAwMDAgbg0KMDAwMDA0MTE5MiAwMDAwMCBuDQowMDAwMDQxMjY4IDAwMDAwIG4NCjAwMDAwNDEzNTYgMDAwMDAgbg0KMDAwMDA0MTQzMiAwMDAwMCBuDQowMDAwMDQxNTA4IDAwMDAwIG4NCjAwMDAwNDE4MDYgMDAwMDAgbg0KMDAwMDA0MTg5MiAwMDAwMCBuDQowMDAwMDQxOTY5IDAwMDAwIG4NCjAwMDAwNDIwNTUgMDAwMDAgbg0KMDAwMDA0MjE0MSAwMDAwMCBuDQowMDAwMDQyMjE4IDAwMDAwIG4NCjAwMDAwNDIzMTIgMDAwMDAgbg0KMDAwMDA0MjM5MCAwMDAwMCBuDQowMDAwMDQyNDg1IDAwMDAwIG4NCjAwMDAwNDI1NjMgMDAwMDAgbg0KMDAwMDA0MjY1MCAwMDAwMCBuDQowMDAwMDQyNzI3IDAwMDAwIG4NCjAwMDAwNDI4MDQgMDAwMDAgbg0KMDAwMDA0Mjg5MiAwMDAwMCBuDQowMDAwMDQyOTcwIDAwMDAwIG4NCjAwMDAwNDMwNTggMDAwMDAgbg0KMDAwMDA0MzEzNSAwMDAwMCBuDQowMDAwMDQzMjEyIDAwMDAwIG4NCjAwMDAwNDMyODkgMDAwMDAgbg0KMDAwMDA0MzM2NiAwMDAwMCBuDQowMDAwMDQzNDQzIDAwMDAwIG4NCjAwMDAwNDM1MjAgMDAwMDAgbg0KMDAwMDA0MzU5NyAwMDAwMCBuDQowMDAwMDQzNjc0IDAwMDAwIG4NCjAwMDAwNDM3NTEgMDAwMDAgbg0KMDAwMDA0MzgyOCAwMDAwMCBuDQowMDAwMDQzOTA1IDAwMDAwIG4NCjAwMDAwNDM5OTMgMDAwMDAgbg0KMDAwMDA0NDA3MSAwMDAwMCBuDQowMDAwMDQ0MTU5IDAwMDAwIG4NCjAwMDAwNDQyMzUgMDAwMDAgbg0KMDAwMDA0NDMyMiAwMDAwMCBuDQowMDAwMDQ0Mzk5IDAwMDAwIG4NCjAwMDAwNDQ0ODYgMDAwMDAgbg0KMDAwMDA0NDU2MiAwMDAwMCBuDQowMDAwMDQ0NjQ5IDAwMDAwIG4NCjAwMDAwNDQ3MjYgMDAwMDAgbg0KMDAwMDA0NDgxMyAwMDAwMCBuDQowMDAwMDQ0ODg5IDAwMDAwIG4NCjAwMDAwNDQ5NzYgMDAwMDAgbg0KMDAwMDA0NTA1NCAwMDAwMCBuDQowMDAwMDQ1MTQyIDAwMDAwIG4NCjAwMDAwNDUyMTkgMDAwMDAgbg0KMDAwMDA0NTI5NiAwMDAwMCBuDQowMDAwMDQ1MzczIDAwMDAwIG4NCjAwMDAwNDU0NTAgMDAwMDAgbg0KMDAwMDA0NTUzNyAwMDAwMCBuDQowMDAwMDQ1NjE1IDAwMDAwIG4NCjAwMDAwNDU2OTIgMDAwMDAgbg0KMDAwMDA0NTc4MCAwMDAwMCBuDQowMDAwMDQ1ODU4IDAwMDAwIG4NCjAwMDAwNDU5NDYgMDAwMDAgbg0KMDAwMDA0NjAyMyAwMDAwMCBuDQowMDAwMDQ2MTExIDAwMDAwIG4NCjAwMDAwNDYxODkgMDAwMDAgbg0KMDAwMDA0NjI3NyAwMDAwMCBuDQowMDAwMDQ2MzU0IDAwMDAwIG4NCjAwMDAwNDY0NDIgMDAwMDAgbg0KMDAwMDA0NjUyMCAwMDAwMCBuDQowMDAwMDQ2NjA4IDAwMDAwIG4NCjAwMDAwNDY2ODUgMDAwMDAgbg0KMDAwMDA0Njc3MyAwMDAwMCBuDQowMDAwMDQ2ODUxIDAwMDAwIG4NCjAwMDAwNDY5MzkgMDAwMDAgbg0KMDAwMDA0NzAxNiAwMDAwMCBuDQowMDAwMDQ3MTAzIDAwMDAwIG4NCjAwMDAwNDcxODAgMDAwMDAgbg0KMDAwMDA0NzI2NyAwMDAwMCBuDQowMDAwMDQ3MzQzIDAwMDAwIG4NCjAwMDAwNDc0MTkgMDAwMDAgbg0KMDAwMDA0NzQ5NSAwMDAwMCBuDQowMDAwMDQ3NTgyIDAwMDAwIG4NCjAwMDAwNDc2NTkgMDAwMDAgbg0KMDAwMDA0Nzc0NiAwMDAwMCBuDQowMDAwMDQ3ODIyIDAwMDAwIG4NCjAwMDAwNDc5MTAgMDAwMDAgbg0KMDAwMDA0Nzk4OCAwMDAwMCBuDQowMDAwMDQ4MDc2IDAwMDAwIG4NCjAwMDAwNDgxNTMgMDAwMDAgbg0KMDAwMDA0ODIzNSAwMDAwMCBuDQowMDAwMDQ4MzEyIDAwMDAwIG4NCjAwMDAwNDgzOTkgMDAwMDAgbg0KMDAwMDA0ODQ3NyAwMDAwMCBuDQowMDAwMDQ4NTU0IDAwMDAwIG4NCjAwMDAwNDg2NDEgMDAwMDAgbg0KMDAwMDA0ODcxOSAwMDAwMCBuDQowMDAwMDQ4Nzk2IDAwMDAwIG4NCjAwMDAwNDg4ODQgMDAwMDAgbg0KMDAwMDA0ODk2MiAwMDAwMCBuDQowMDAwMDQ5MDUwIDAwMDAwIG4NCjAwMDAwNDkxMjcgMDAwMDAgbg0KMDAwMDA0OTIxNSAwMDAwMCBuDQowMDAwMDQ5MjkzIDAwMDAwIG4NCjAwMDAwNDkzODEgMDAwMDAgbg0KMDAwMDA0OTQ1OCAwMDAwMCBuDQowMDAwMDQ5NTQ2IDAwMDAwIG4NCjAwMDAwNDk2MjQgMDAwMDAgbg0KMDAwMDA0OTcxMiAwMDAwMCBuDQowMDAwMDQ5Nzg5IDAwMDAwIG4NCjAwMDAwNDk4NzYgMDAwMDAgbg0KMDAwMDA0OTk1MyAwMDAwMCBuDQowMDAwMDUwMDQwIDAwMDAwIG4NCjAwMDAwNTAxMTYgMDAwMDAgbg0KMDAwMDA1MDIwMyAwMDAwMCBuDQowMDAwMDUwMjgwIDAwMDAwIG4NCjAwMDAwNTAzNjcgMDAwMDAgbg0KMDAwMDA1MDQ0MyAwMDAwMCBuDQowMDAwMDUwNTMwIDAwMDAwIG4NCjAwMDAwNTA2MDcgMDAwMDAgbg0KMDAwMDA1MDY5NSAwMDAwMCBuDQowMDAwMDUwNzcyIDAwMDAwIG4NCjAwMDAwNTA4NjAgMDAwMDAgbg0KMDAwMDA1MDkzOCAwMDAwMCBuDQowMDAwMDUxMDI2IDAwMDAwIG4NCjAwMDAwNTExMDMgMDAwMDAgbg0KMDAwMDA1MTE3OSAwMDAwMCBuDQowMDAwMDUxMjc4IDAwMDAwIG4NCjAwMDAwNTEzNTUgMDAwMDAgbg0KMDAwMDA1MTQzMiAwMDAwMCBuDQowMDAwMDUxNTA5IDAwMDAwIG4NCjAwMDAwNTE1ODYgMDAwMDAgbg0KMDAwMDA1MTY2MyAwMDAwMCBuDQowMDAwMDUxNzQwIDAwMDAwIG4NCjAwMDAwNTE4MTcgMDAwMDAgbg0KMDAwMDA1MTg5NCAwMDAwMCBuDQowMDAwMDUxOTcxIDAwMDAwIG4NCjAwMDAwNTIwNDcgMDAwMDAgbg0KMDAwMDA1MjEyNCAwMDAwMCBuDQowMDAwMDUyMjAxIDAwMDAwIG4NCjAwMDAwNTIyODMgMDAwMDAgbg0KMDAwMDA1MjM1OSAwMDAwMCBuDQowMDAwMDUyNDM1IDAwMDAwIG4NCjAwMDAwNTI1MTEgMDAwMDAgbg0KMDAwMDA1MjU4NyAwMDAwMCBuDQowMDAwMDUyNjYzIDAwMDAwIG4NCjAwMDAwNTI3MzkgMDAwMDAgbg0KMDAwMDA1MjgxNSAwMDAwMCBuDQowMDAwMDUyODkxIDAwMDAwIG4NCjAwMDAwNTI5NjcgMDAwMDAgbg0KMDAwMDA1MzA0NCAwMDAwMCBuDQowMDAwMDUzMTIxIDAwMDAwIG4NCjAwMDAwNTMxOTggMDAwMDAgbg0KMDAwMDA1MzI3NSAwMDAwMCBuDQowMDAwMDUzMzUyIDAwMDAwIG4NCjAwMDAwNTM0MjkgMDAwMDAgbg0KMDAwMDA1MzUwNiAwMDAwMCBuDQowMDAwMDUzNTgzIDAwMDAwIG4NCjAwMDAwNTM2NjAgMDAwMDAgbg0KMDAwMDA1MzczNyAwMDAwMCBuDQowMDAwMDUzODE0IDAwMDAwIG4NCjAwMDAwNTM4OTEgMDAwMDAgbg0KMDAwMDA1Mzk2OCAwMDAwMCBuDQowMDAwMDU0MDQ1IDAwMDAwIG4NCjAwMDAwNTQxMjIgMDAwMDAgbg0KMDAwMDA1NDE5OSAwMDAwMCBuDQowMDAwMDU0Mjc2IDAwMDAwIG4NCjAwMDAwNTQzNTMgMDAwMDAgbg0KMDAwMDA1NDQzMCAwMDAwMCBuDQowMDAwMDU0NTA3IDAwMDAwIG4NCjAwMDAwNTQ1ODkgMDAwMDAgbg0KMDAwMDA1NDY3NiAwMDAwMCBuDQowMDAwMDU0NzUzIDAwMDAwIG4NCjAwMDAwNTQ4NDAgMDAwMDAgbg0KMDAwMDA1NDkxNiAwMDAwMCBuDQowMDAwMDU0OTkyIDAwMDAwIG4NCjAwMDAwNTUwNjggMDAwMDAgbg0KMDAwMDA1NTE0NCAwMDAwMCBuDQowMDAwMDU1MjIwIDAwMDAwIG4NCjAwMDAwNTUyOTYgMDAwMDAgbg0KMDAwMDA1NTM3MyAwMDAwMCBuDQowMDAwMDU1NDUwIDAwMDAwIG4NCjAwMDAwNTU1MjcgMDAwMDAgbg0KMDAwMDA1NTYxNCAwMDAwMCBuDQowMDAwMDU1NjkyIDAwMDAwIG4NCjAwMDAwNTU3NjkgMDAwMDAgbg0KMDAwMDA1NTg0NiAwMDAwMCBuDQowMDAwMDU1OTIzIDAwMDAwIG4NCjAwMDAwNTYwMDUgMDAwMDAgbg0KMDAwMDA1NjA4MiAwMDAwMCBuDQowMDAwMDU2MTU5IDAwMDAwIG4NCjAwMDAwNTYyMzYgMDAwMDAgbg0KMDAwMDA1NjMyNCAwMDAwMCBuDQowMDAwMDU2NDAyIDAwMDAwIG4NCjAwMDAwNTY0OTAgMDAwMDAgbg0KMDAwMDA1NjU2NyAwMDAwMCBuDQowMDAwMDU2NjQ0IDAwMDAwIG4NCjAwMDAwNTY3MjEgMDAwMDAgbg0KMDAwMDA1Njc5OCAwMDAwMCBuDQowMDAwMDU2ODczIDAwMDAwIG4NCjAwMDAwNTY5NDkgMDAwMDAgbg0KMDAwMDA1NzAyNCAwMDAwMCBuDQowMDAwMDU3MTIxIDAwMDAwIG4NCjAwMDAwNTcxOTcgMDAwMDAgbg0KMDAwMDA1NzI3MyAwMDAwMCBuDQowMDAwMDU3MzQ5IDAwMDAwIG4NCjAwMDAwNTc0MjUgMDAwMDAgbg0KMDAwMDA1NzUwMSAwMDAwMCBuDQowMDAwMDU3NTg4IDAwMDAwIG4NCjAwMDAwNTc2NjYgMDAwMDAgbg0KMDAwMDA1Nzc2MiAwMDAwMCBuDQowMDAwMDU3ODQwIDAwMDAwIG4NCjAwMDAwNTc5MjggMDAwMDAgbg0KMDAwMDA1ODAwNSAwMDAwMCBuDQowMDAwMDU4MDgxIDAwMDAwIG4NCjAwMDAwNTgxODAgMDAwMDAgbg0KMDAwMDA1ODI1NyAwMDAwMCBuDQowMDAwMDU4MzM0IDAwMDAwIG4NCjAwMDAwNTg0MTEgMDAwMDAgbg0KMDAwMDA1ODQ4OCAwMDAwMCBuDQowMDAwMDU4NTY1IDAwMDAwIG4NCjAwMDAwNTg2NTMgMDAwMDAgbg0KMDAwMDA1ODczMSAwMDAwMCBuDQowMDAwMDU4ODI3IDAwMDAwIG4NCjAwMDAwNTg5MDUgMDAwMDAgbg0KMDAwMDA1OTAwMSAwMDAwMCBuDQowMDAwMDU5MDc5IDAwMDAwIG4NCjAwMDAwNTkxNzUgMDAwMDAgbg0KMDAwMDA1OTI1MyAwMDAwMCBuDQowMDAwMDU5MzQ5IDAwMDAwIG4NCjAwMDAwNTk0MjcgMDAwMDAgbg0KMDAwMDA1OTUxNSAwMDAwMCBuDQowMDAwMDU5NTkwIDAwMDAwIG4NCjAwMDAwNTk2NjYgMDAwMDAgbg0KMDAwMDA1OTc0MiAwMDAwMCBuDQowMDAwMDU5ODE4IDAwMDAwIG4NCjAwMDAwNTk4OTMgMDAwMDAgbg0KMDAwMDA1OTk2OSAwMDAwMCBuDQowMDAwMDYwMDQ1IDAwMDAwIG4NCjAwMDAwNjAxMjEgMDAwMDAgbg0KMDAwMDA2MDE5NyAwMDAwMCBuDQowMDAwMDYwMjczIDAwMDAwIG4NCjAwMDAwNjAzNjAgMDAwMDAgbg0KMDAwMDA2MDQzNyAwMDAwMCBuDQowMDAwMDYwNTI1IDAwMDAwIG4NCjAwMDAwNjA2MDIgMDAwMDAgbg0KMDAwMDA2MDY5MCAwMDAwMCBuDQowMDAwMDYwNzY4IDAwMDAwIG4NCjAwMDAwNjA4NTYgMDAwMDAgbg0KMDAwMDA2MDkzMyAwMDAwMCBuDQowMDAwMDYxMDIwIDAwMDAwIG4NCjAwMDAwNjEwOTggMDAwMDAgbg0KMDAwMDA2MTE3NSAwMDAwMCBuDQowMDAwMDYxMjUyIDAwMDAwIG4NCjAwMDAwNjEzMjkgMDAwMDAgbg0KMDAwMDA2MTQwNiAwMDAwMCBuDQowMDAwMDYxNDgzIDAwMDAwIG4NCjAwMDAwNjE1NjAgMDAwMDAgbg0KMDAwMDA2MTYzNyAwMDAwMCBuDQowMDAwMDYxNzE0IDAwMDAwIG4NCjAwMDAwNjE3OTEgMDAwMDAgbg0KMDAwMDA2MTg3OCAwMDAwMCBuDQowMDAwMDYxOTU2IDAwMDAwIG4NCjAwMDAwNjIwMzggMDAwMDAgbg0KMDAwMDA2MjEyNSAwMDAwMCBuDQowMDAwMDYyMjAyIDAwMDAwIG4NCjAwMDAwNjIyODkgMDAwMDAgbg0KMDAwMDA2MjM2NSAwMDAwMCBuDQowMDAwMDYyNDQxIDAwMDAwIG4NCjAwMDAwNjI1MTcgMDAwMDAgbg0KMDAwMDA2MjYwNCAwMDAwMCBuDQowMDAwMDYyNjgxIDAwMDAwIG4NCjAwMDAwNjI3NjggMDAwMDAgbg0KMDAwMDA2Mjg0NSAwMDAwMCBuDQowMDAwMDYyOTMzIDAwMDAwIG4NCjAwMDAwNjMwMTEgMDAwMDAgbg0KMDAwMDA2MzA5OSAwMDAwMCBuDQowMDAwMDYzMTc2IDAwMDAwIG4NCjAwMDAwNjMyNTMgMDAwMDAgbg0KMDAwMDA2MzMzMCAwMDAwMCBuDQowMDAwMDYzNDE3IDAwMDAwIG4NCjAwMDAwNjM0OTUgMDAwMDAgbg0KMDAwMDA2NTgyNCAwMDAwMCBuDQowMDAwMDY1ODcxIDAwMDAwIG4NCjAwMDAwNjcwNTUgMDAwMDAgbg0KMDAwMDA2OTg3NyAwMDAwMCBuDQowMDAwMDY5OTEyIDAwMDAwIG4NCjAwMDAwNzMyNzUgMDAwMDAgbg0KMDAwMDA3MzMxMCAwMDAwMCBuDQowMDAwMDc2ODQzIDAwMDAwIG4NCjAwMDAwNzY4NzggMDAwMDAgbg0KMDAwMDA4MDM5MyAwMDAwMCBuDQowMDAwMDgwNDI4IDAwMDAwIG4NCjAwMDAwODMzNjcgMDAwMDAgbg0KMDAwMDA4MzQxNCAwMDAwMCBuDQowMDAwMDg1OTAzIDAwMDAwIG4NCjAwMDAwODU5MzggMDAwMDAgbg0KMDAwMDA4ODYyNSAwMDAwMCBuDQowMDAwMDg4NjcyIDAwMDAwIG4NCjAwMDAwOTIxMTUgMDAwMDAgbg0KMDAwMDA5MjE2MiAwMDAwMCBuDQowMDAwMDk0ODQ5IDAwMDAwIG4NCjAwMDAwOTQ4OTYgMDAwMDAgbg0KMDAwMDA5NjcwMSAwMDAwMCBuDQowMDAwMDk2NzM2IDAwMDAwIG4NCjAwMDAwOTY4MzkgMDAwMDAgbg0KMDAwMDA5NjkzMCAwMDAwMCBuDQowMDAwMDk3MDIyIDAwMDAwIG4NCjAwMDAwOTcxMTQgMDAwMDAgbg0KMDAwMDA5NzIwNiAwMDAwMCBuDQowMDAwMDk3Mjk3IDAwMDAwIG4NCjAwMDAwOTc1MDggMDAwMDAgbg0KMDAwMDA5NzU4OCAwMDAwMCBuDQowMDAwMDk3NjY4IDAwMDAwIG4NCjAwMDAwOTc3NzUgMDAwMDAgbg0KMDAwMDA5Nzg1NSAwMDAwMCBuDQowMDAwMDk3OTM2IDAwMDAwIG4NCjAwMDAwOTgwMjUgMDAwMDAgbg0KMDAwMDA5ODExNCAwMDAwMCBuDQowMDAwMDk4MjA0IDAwMDAwIG4NCjAwMDAwOTgyOTQgMDAwMDAgbg0KMDAwMDA5ODM4NCAwMDAwMCBuDQowMDAwMDk4Nzk0IDAwMDAwIG4NCjAwMDAwOTg4ODMgMDAwMDAgbg0KMDAwMDA5ODk3MyAwMDAwMCBuDQowMDAwMDk5MDYyIDAwMDAwIG4NCjAwMDAwOTkxNDIgMDAwMDAgbg0KMDAwMDA5OTIxMiAwMDAwMCBuDQowMDAwMDk5MzAyIDAwMDAwIG4NCjAwMDAwOTkzNzUgMDAwMDAgbg0KMDAwMDA5OTQ2NSAwMDAwMCBuDQowMDAwMDk5NTQ2IDAwMDAwIG4NCjAwMDAwOTk2MTcgMDAwMDAgbg0KMDAwMDA5OTcwNyAwMDAwMCBuDQowMDAwMDk5Nzk4IDAwMDAwIG4NCjAwMDAwOTk4ODggMDAwMDAgbg0KMDAwMDA5OTk2OSAwMDAwMCBuDQowMDAwMTAwMDQwIDAwMDAwIG4NCjAwMDAxMDAxMzAgMDAwMDAgbg0KMDAwMDEwMDIxMSAwMDAwMCBuDQowMDAwMTAwMzAxIDAwMDAwIG4NCjAwMDAxMDAzOTEgMDAwMDAgbg0KMDAwMDEwMDQ4MSAwMDAwMCBuDQowMDAwMTAwNTM0IDAwMDAwIG4NCjAwMDAxMDA1ODcgMDAwMDAgbg0KMDAwMDEwMDY0MCAwMDAwMCBuDQowMDAwMTAwNjkzIDAwMDAwIG4NCjAwMDAxMDA3NDYgMDAwMDAgbg0KMDAwMDEwMDc5OSAwMDAwMCBuDQowMDAwMTAwODUyIDAwMDAwIG4NCjAwMDAxMDA5MDUgMDAwMDAgbg0KMDAwMDEwMDk1OCAwMDAwMCBuDQowMDAwMTAxMDExIDAwMDAwIG4NCjAwMDAxMDEwNjUgMDAwMDAgbg0KMDAwMDEwMTExOSAwMDAwMCBuDQowMDAwMTAxMTczIDAwMDAwIG4NCjAwMDAxMDEyMjcgMDAwMDAgbg0KMDAwMDEwMTI4MSAwMDAwMCBuDQowMDAwMTAxMzYyIDAwMDAwIG4NCjAwMDAxMDE0MzMgMDAwMDAgbg0KMDAwMDEwMTUxNCAwMDAwMCBuDQowMDAwMTAxNTg1IDAwMDAwIG4NCjAwMDAxMDE2NjcgMDAwMDAgbg0KMDAwMDEwMTczOSAwMDAwMCBuDQowMDAwMTAxODIyIDAwMDAwIG4NCjAwMDAxMDE4OTQgMDAwMDAgbg0KMDAwMDEwMTk4NiAwMDAwMCBuDQowMDAwMTAyMDc4IDAwMDAwIG4NCjAwMDAxMDIxNjEgMDAwMDAgbg0KMDAwMDEwMjIzMyAwMDAwMCBuDQowMDAwMTAyMzI1IDAwMDAwIG4NCjAwMDAxMDI0MTcgMDAwMDAgbg0KMDAwMDEwMjUwOSAwMDAwMCBuDQowMDAwMTAyNjAxIDAwMDAwIG4NCjAwMDAxMDI2OTMgMDAwMDAgbg0KMDAwMDEwMjc4NSAwMDAwMCBuDQowMDAwMTAyODc3IDAwMDAwIG4NCjAwMDAxMDI5NjAgMDAwMDAgbg0KMDAwMDEwMzAzMiAwMDAwMCBuDQowMDAwMTAzMTI0IDAwMDAwIG4NCjAwMDAxMDMyMTYgMDAwMDAgbg0KMDAwMDEwMzI5OSAwMDAwMCBuDQowMDAwMTAzMzcxIDAwMDAwIG4NCjAwMDAxMDM0NjMgMDAwMDAgbg0KMDAwMDEwMzU1NSAwMDAwMCBuDQowMDAwMTAzNjM4IDAwMDAwIG4NCjAwMDAxMDM3MTAgMDAwMDAgbg0KMDAwMDEwMzgwMiAwMDAwMCBuDQowMDAwMTAzODk0IDAwMDAwIG4NCjAwMDAxMDM5NzcgMDAwMDAgbg0KMDAwMDEwNDA0OSAwMDAwMCBuDQowMDAwMTA0MTQxIDAwMDAwIG4NCjAwMDAxMDQyMjMgMDAwMDAgbg0KMDAwMDEwNDMxNSAwMDAwMCBuDQowMDAwMTA0NDA3IDAwMDAwIG4NCjAwMDAxMDQ0OTkgMDAwMDAgbg0KMDAwMDEwNDU4MiAwMDAwMCBuDQowMDAwMTA0NjU0IDAwMDAwIG4NCjAwMDAxMDQ3NDYgMDAwMDAgbg0KMDAwMDEwNDgzOCAwMDAwMCBuDQowMDAwMTA0OTIxIDAwMDAwIG4NCjAwMDAxMDQ5OTMgMDAwMDAgbg0KMDAwMDEwNTA4NSAwMDAwMCBuDQowMDAwMTA1MTc3IDAwMDAwIG4NCjAwMDAxMDUyNjAgMDAwMDAgbg0KMDAwMDEwNTMzMiAwMDAwMCBuDQowMDAwMTA1NDI0IDAwMDAwIG4NCjAwMDAxMDU1MTYgMDAwMDAgbg0KMDAwMDEwNTU5OSAwMDAwMCBuDQowMDAwMTA1NjcxIDAwMDAwIG4NCjAwMDAxMDU3NjMgMDAwMDAgbg0KMDAwMDEwNTg1NSAwMDAwMCBuDQowMDAwMTA1OTM4IDAwMDAwIG4NCjAwMDAxMDYwMTAgMDAwMDAgbg0KMDAwMDEwNjEwMiAwMDAwMCBuDQowMDAwMTA2MTk0IDAwMDAwIG4NCjAwMDAxMDYyODYgMDAwMDAgbg0KMDAwMDEwNjM2OSAwMDAwMCBuDQowMDAwMTA2NDQxIDAwMDAwIG4NCjAwMDAxMDY1MzMgMDAwMDAgbg0KMDAwMDEwNjYyNSAwMDAwMCBuDQowMDAwMTA2NzA4IDAwMDAwIG4NCjAwMDAxMDY3ODAgMDAwMDAgbg0KMDAwMDEwNjg3MiAwMDAwMCBuDQowMDAwMTA2OTY0IDAwMDAwIG4NCjAwMDAxMDcwNTYgMDAwMDAgbg0KMDAwMDEwNzE0OCAwMDAwMCBuDQowMDAwMTA3MjQwIDAwMDAwIG4NCjAwMDAxMDczMjMgMDAwMDAgbg0KMDAwMDEwNzM5NSAwMDAwMCBuDQowMDAwMTA3NDg3IDAwMDAwIG4NCjAwMDAxMDc1NzkgMDAwMDAgbg0KMDAwMDEwNzY2MiAwMDAwMCBuDQowMDAwMTA3NzM0IDAwMDAwIG4NCjAwMDAxMDc4MjYgMDAwMDAgbg0KMDAwMDEwNzkxOCAwMDAwMCBuDQowMDAwMTA4MDAxIDAwMDAwIG4NCjAwMDAxMDgwNzMgMDAwMDAgbg0KMDAwMDEwODE2NSAwMDAwMCBuDQowMDAwMTA4MjU3IDAwMDAwIG4NCjAwMDAxMDgzNDAgMDAwMDAgbg0KMDAwMDEwODQxMiAwMDAwMCBuDQowMDAwMTA4NTA0IDAwMDAwIG4NCjAwMDAxMDg1OTYgMDAwMDAgbg0KMDAwMDEwODY3OSAwMDAwMCBuDQowMDAwMTA4NzUxIDAwMDAwIG4NCjAwMDAxMDg4NDMgMDAwMDAgbg0KMDAwMDEwODkzNSAwMDAwMCBuDQowMDAwMTA5MDE4IDAwMDAwIG4NCjAwMDAxMDkwOTAgMDAwMDAgbg0KMDAwMDEwOTE4MiAwMDAwMCBuDQowMDAwMTA5Mjc0IDAwMDAwIG4NCjAwMDAxMDkzNTcgMDAwMDAgbg0KMDAwMDEwOTQyOSAwMDAwMCBuDQowMDAwMTA5NTMwIDAwMDAwIG4NCjAwMDAxMDk2MTMgMDAwMDAgbg0KMDAwMDEwOTcwNiAwMDAwMCBuDQowMDAwMTA5Nzk5IDAwMDAwIG4NCjAwMDAxMDk4OTIgMDAwMDAgbg0KMDAwMDEwOTk3NSAwMDAwMCBuDQowMDAwMTEwMDU4IDAwMDAwIG4NCjAwMDAxMTAxNDEgMDAwMDAgbg0KMDAwMDExMDQ0OSAwMDAwMCBuDQowMDAwMTEwNTQxIDAwMDAwIG4NCjAwMDAxMTA2MzMgMDAwMDAgbg0KMDAwMDExMDY4NiAwMDAwMCBuDQowMDAwMTEwNzc4IDAwMDAwIG4NCjAwMDAxMTA4NzAgMDAwMDAgbg0KMDAwMDExMDk2MiAwMDAwMCBuDQowMDAwMTExMDU0IDAwMDAwIG4NCjAwMDAxMTExNDYgMDAwMDAgbg0KMDAwMDExMTIzOCAwMDAwMCBuDQowMDAwMTExMzMwIDAwMDAwIG4NCjAwMDAxMTE0MjIgMDAwMDAgbg0KMDAwMDExMTUxNCAwMDAwMCBuDQowMDAwMTExNjA2IDAwMDAwIG4NCjAwMDAxMTE2OTggMDAwMDAgbg0KMDAwMDExMTc5MCAwMDAwMCBuDQowMDAwMTExODgyIDAwMDAwIG4NCjAwMDAxMTE5NzQgMDAwMDAgbg0KMDAwMDExMjA2NiAwMDAwMCBuDQowMDAwMTEyMTE5IDAwMDAwIG4NCjAwMDAxMTIyMTEgMDAwMDAgbg0KMDAwMDExMjI5NCAwMDAwMCBuDQowMDAwMTEyMzY2IDAwMDAwIG4NCjAwMDAxMTI0NTggMDAwMDAgbg0KMDAwMDExMjU1MCAwMDAwMCBuDQowMDAwMTEyNjQyIDAwMDAwIG4NCjAwMDAxMTI3MzQgMDAwMDAgbg0KMDAwMDExMjgyNiAwMDAwMCBuDQowMDAwMTEyOTE4IDAwMDAwIG4NCjAwMDAxMTMwMTAgMDAwMDAgbg0KMDAwMDExMzEwMiAwMDAwMCBuDQowMDAwMTEzMTk0IDAwMDAwIG4NCjAwMDAxMTMyODYgMDAwMDAgbg0KMDAwMDExMzM2OSAwMDAwMCBuDQowMDAwMTEzNDQxIDAwMDAwIG4NCjAwMDAxMTM1MzMgMDAwMDAgbg0KMDAwMDExMzYyNSAwMDAwMCBuDQowMDAwMTEzNzE4IDAwMDAwIG4NCjAwMDAxMTM4MDEgMDAwMDAgbg0KMDAwMDExMzg5NCAwMDAwMCBuDQowMDAwMTEzOTg3IDAwMDAwIG4NCjAwMDAxMTQwODAgMDAwMDAgbg0KMDAwMDExNDE4MCAwMDAwMCBuDQowMDAwMTE0MjYzIDAwMDAwIG4NCjAwMDAxMTQzMzUgMDAwMDAgbg0KMDAwMDExNDQxOCAwMDAwMCBuDQowMDAwMTE0NDkwIDAwMDAwIG4NCjAwMDAxMTQ1ODMgMDAwMDAgbg0KMDAwMDExNDY2NiAwMDAwMCBuDQowMDAwMTE0NzU5IDAwMDAwIG4NCjAwMDAxMTQ4NTIgMDAwMDAgbg0KMDAwMDExNDk0NSAwMDAwMCBuDQowMDAwMTE1MDY5IDAwMDAwIG4NCjAwMDAxMTUxNTIgMDAwMDAgbg0KMDAwMDExNTIyNCAwMDAwMCBuDQowMDAwMTE1MzA3IDAwMDAwIG4NCjAwMDAxMTUzNzkgMDAwMDAgbg0KMDAwMDExNTQ2MiAwMDAwMCBuDQowMDAwMTE1NTM0IDAwMDAwIG4NCjAwMDAxMTU2MTcgMDAwMDAgbg0KMDAwMDExNTY4OSAwMDAwMCBuDQowMDAwMTE1NzcyIDAwMDAwIG4NCjAwMDAxMTU4NDQgMDAwMDAgbg0KMDAwMDExNTkzNiAwMDAwMCBuDQowMDAwMTE2MDI4IDAwMDAwIG4NCjAwMDAxMTYxMjAgMDAwMDAgbg0KMDAwMDExNjIxMiAwMDAwMCBuDQowMDAwMTE2MzA0IDAwMDAwIG4NCjAwMDAxMTYzODcgMDAwMDAgbg0KMDAwMDExNjQ1OSAwMDAwMCBuDQowMDAwMTE2NTUxIDAwMDAwIG4NCjAwMDAxMTY2NDMgMDAwMDAgbg0KMDAwMDExNjcyNiAwMDAwMCBuDQowMDAwMTE2Nzk4IDAwMDAwIG4NCjAwMDAxMTY4OTAgMDAwMDAgbg0KMDAwMDExNjk4MiAwMDAwMCBuDQowMDAwMTE3MDc0IDAwMDAwIG4NCjAwMDAxMTcxNjYgMDAwMDAgbg0KMDAwMDExNzI1OCAwMDAwMCBuDQowMDAwMTE3MzUwIDAwMDAwIG4NCjAwMDAxMTc0NDIgMDAwMDAgbg0KMDAwMDExNzQ5NSAwMDAwMCBuDQowMDAwMTE3NTg3IDAwMDAwIG4NCjAwMDAxMTc2NzAgMDAwMDAgbg0KMDAwMDExNzc0MiAwMDAwMCBuDQowMDAwMTE3ODM0IDAwMDAwIG4NCjAwMDAxMTc5MjYgMDAwMDAgbg0KMDAwMDExODAxOCAwMDAwMCBuDQowMDAwMTE4MTAxIDAwMDAwIG4NCjAwMDAxMTgxNzMgMDAwMDAgbg0KMDAwMDExODI2NSAwMDAwMCBuDQowMDAwMTE4MzU3IDAwMDAwIG4NCjAwMDAxMTg0NDAgMDAwMDAgbg0KMDAwMDExODUxMiAwMDAwMCBuDQowMDAwMTE4NjA0IDAwMDAwIG4NCjAwMDAxMTg2OTYgMDAwMDAgbg0KMDAwMDExODc3MyAwMDAwMCBuDQowMDAwMTE4ODUwIDAwMDAwIG4NCjAwMDAxMTg5MjcgMDAwMDAgbg0KMDAwMDExOTAwNyAwMDAwMCBuDQowMDAwMTE5MDg3IDAwMDAwIG4NCjAwMDAxMTkxNjcgMDAwMDAgbg0KMDAwMDExOTI0NyAwMDAwMCBuDQowMDAwMTE5MzI5IDAwMDAwIG4NCjAwMDAxMTk0MTEgMDAwMDAgbg0KMDAwMDExOTQ5MSAwMDAwMCBuDQowMDAwMTE5NTcyIDAwMDAwIG4NCjAwMDAxMTk2NTAgMDAwMDAgbg0KMDAwMDExOTcyOSAwMDAwMCBuDQowMDAwMTE5ODEzIDAwMDAwIG4NCjAwMDAxMTk4OTcgMDAwMDAgbg0KMDAwMDExOTk4MCAwMDAwMCBuDQowMDAwMTIwMDYzIDAwMDAwIG4NCjAwMDAxMjAxNDUgMDAwMDAgbg0KMDAwMDEyMDIyNyAwMDAwMCBuDQowMDAwMTIwMzA5IDAwMDAwIG4NCjAwMDAxMjAzOTEgMDAwMDAgbg0KMDAwMDEyMDQ3NSAwMDAwMCBuDQowMDAwMTIwNTU3IDAwMDAwIG4NCjAwMDAxMjA2NDEgMDAwMDAgbg0KMDAwMDEyMDcyMyAwMDAwMCBuDQowMDAwMTIwODA3IDAwMDAwIG4NCjAwMDAxMjA4ODkgMDAwMDAgbg0KMDAwMDEyMDk2OCAwMDAwMCBuDQowMDAwMTIxMDUyIDAwMDAwIG4NCjAwMDAxMjExMzYgMDAwMDAgbg0KMDAwMDEyMTIxOCAwMDAwMCBuDQowMDAwMTIxMzAyIDAwMDAwIG4NCjAwMDAxMjEzODQgMDAwMDAgbg0KMDAwMDEyMTQ2NyAwMDAwMCBuDQowMDAwMTIxNTQ5IDAwMDAwIG4NCjAwMDAxMjE2MjcgMDAwMDAgbg0KMDAwMDEyMTcxMCAwMDAwMCBuDQowMDAwMTIxNzkxIDAwMDAwIG4NCjAwMDAxMjE4MjIgMDAwMDAgbg0KMDAwMDEyMTkwMyAwMDAwMCBuDQowMDAwMTIxOTg1IDAwMDAwIG4NCjAwMDAxMjIwMTYgMDAwMDAgbg0KMDAwMDEyMjA5OCAwMDAwMCBuDQowMDAwMTIyMTc2IDAwMDAwIG4NCjAwMDAxMjIyMDcgMDAwMDAgbg0KMDAwMDEyMjI4NSAwMDAwMCBuDQowMDAwMTIyMzYzIDAwMDAwIG4NCjAwMDAxMjIzOTQgMDAwMDAgbg0KMDAwMDEyMjQ3MiAwMDAwMCBuDQowMDAwMTIyNTUzIDAwMDAwIG4NCjAwMDAxMjI1ODQgMDAwMDAgbg0KMDAwMDEyMjY2NSAwMDAwMCBuDQowMDAwMTIyNzQ1IDAwMDAwIG4NCjAwMDAxMjI3NzYgMDAwMDAgbg0KMDAwMDEyMjg1NiAwMDAwMCBuDQowMDAwMTIyOTM2IDAwMDAwIG4NCjAwMDAxMjI5NjcgMDAwMDAgbg0KMDAwMDEyMzA0NyAwMDAwMCBuDQowMDAwMTIzMTI4IDAwMDAwIG4NCjAwMDAxMjMxNTkgMDAwMDAgbg0KMDAwMDEyMzI0MCAwMDAwMCBuDQowMDAwMTIzMzI0IDAwMDAwIG4NCjAwMDAxMjM0MDggMDAwMDAgbg0KMDAwMDEyMzQzOSAwMDAwMCBuDQowMDAwMTIzNTIzIDAwMDAwIG4NCjAwMDAxMjM2MDUgMDAwMDAgbg0KMDAwMDEyMzYzNiAwMDAwMCBuDQowMDAwMTIzNzE4IDAwMDAwIG4NCjAwMDAxMjM3OTggMDAwMDAgbg0KMDAwMDEyMzgzMCAwMDAwMCBuDQowMDAwMTIzODYyIDAwMDAwIG4NCjAwMDAxMjM5NDIgMDAwMDAgbg0KMDAwMDEyNDAyNCAwMDAwMCBuDQowMDAwMTI0MTA2IDAwMDAwIG4NCjAwMDAxMjQxODggMDAwMDAgbg0KMDAwMDEyNDI2MyAwMDAwMCBuDQowMDAwMTI0Mjk1IDAwMDAwIG4NCjAwMDAxMjQzNzAgMDAwMDAgbg0KMDAwMDEyNDQ1MCAwMDAwMCBuDQowMDAwMTI0NDgyIDAwMDAwIG4NCjAwMDAxMjQ1NjIgMDAwMDAgbg0KMDAwMDEyNDY0NyAwMDAwMCBuDQowMDAwMTI0NzMyIDAwMDAwIG4NCjAwMDAxMjQ4MTcgMDAwMDAgbg0KMDAwMDEyNDkwMSAwMDAwMCBuDQowMDAwMTI0OTMzIDAwMDAwIG4NCjAwMDAxMjUwMTcgMDAwMDAgbg0KMDAwMDEyNTEwNCAwMDAwMCBuDQowMDAwMTI1MTM2IDAwMDAwIG4NCjAwMDAxMjUyMjMgMDAwMDAgbg0KMDAwMDEyNTMwMiAwMDAwMCBuDQowMDAwMTI1MzM0IDAwMDAwIG4NCjAwMDAxMjU0MTMgMDAwMDAgbg0KMDAwMDEyNTQ5MSAwMDAwMCBuDQowMDAwMTI1NTIzIDAwMDAwIG4NCjAwMDAxMjU2MDEgMDAwMDAgbg0KMDAwMDEyNTY4NCAwMDAwMCBuDQowMDAwMTI1NzE2IDAwMDAwIG4NCjAwMDAxMjU3OTkgMDAwMDAgbg0KMDAwMDEyNTg3OSAwMDAwMCBuDQowMDAwMTI1OTExIDAwMDAwIG4NCjAwMDAxMjU5OTEgMDAwMDAgbg0KMDAwMDEyNjA3MSAwMDAwMCBuDQowMDAwMTI2MTAzIDAwMDAwIG4NCjAwMDAxMjYxODMgMDAwMDAgbg0KMDAwMDEyNjI2MSAwMDAwMCBuDQowMDAwMTI2MjkzIDAwMDAwIG4NCjAwMDAxMjYzNzEgMDAwMDAgbg0KMDAwMDEyNjQ1MyAwMDAwMCBuDQowMDAwMTI2NDg1IDAwMDAwIG4NCjAwMDAxMjY1NjcgMDAwMDAgbg0KMDAwMDEyNjY0NiAwMDAwMCBuDQowMDAwMTI2Njc4IDAwMDAwIG4NCjAwMDAxMjY3NTcgMDAwMDAgbg0KMDAwMDEyNjg0MCAwMDAwMCBuDQowMDAwMTI2ODcyIDAwMDAwIG4NCjAwMDAxMjY5NTUgMDAwMDAgbg0KMDAwMDEyNzAzOCAwMDAwMCBuDQowMDAwMTI3MDcwIDAwMDAwIG4NCjAwMDAxMjcxNTMgMDAwMDAgbg0KMDAwMDEyNzIzMyAwMDAwMCBuDQowMDAwMTI3MjY1IDAwMDAwIG4NCjAwMDAxMjczNDUgMDAwMDAgbg0KMDAwMDEyNzQzNiAwMDAwMCBuDQowMDAwMTI3NTI3IDAwMDAwIG4NCjAwMDAxMjc2MTggMDAwMDAgbg0KMDAwMDEyNzY1MCAwMDAwMCBuDQowMDAwMTI3NzQxIDAwMDAwIG4NCjAwMDAxMjc4MjIgMDAwMDAgbg0KMDAwMDEyNzg1NCAwMDAwMCBuDQowMDAwMTI3OTM1IDAwMDAwIG4NCjAwMDAxMjgwMTIgMDAwMDAgbg0KMDAwMDEyODA4OSAwMDAwMCBuDQowMDAwMTI4MTY2IDAwMDAwIG4NCjAwMDAxMjgyNDMgMDAwMDAgbg0KMDAwMDEyODMyMCAwMDAwMCBuDQowMDAwMTI4Mzk3IDAwMDAwIG4NCjAwMDAxMjg0ODAgMDAwMDAgbg0KMDAwMDEyODUxMiAwMDAwMCBuDQowMDAwMTI4NTk1IDAwMDAwIG4NCjAwMDAxMjg2NzUgMDAwMDAgbg0KMDAwMDEyODcwNyAwMDAwMCBuDQowMDAwMTI4ODYxIDAwMDAwIG4NCjAwMDAxMjkwMTIgMDAwMDAgbg0KMDAwMDEyOTA0OSAwMDAwMCBuDQowMDAwMTI5MTI2IDAwMDAwIG4NCjAwMDAxMjkyMDMgMDAwMDAgbg0KMDAwMDEyOTI4MCAwMDAwMCBuDQowMDAwMTI5MzU3IDAwMDAwIG4NCjAwMDAxMjk0MzUgMDAwMDAgbg0KMDAwMDEyOTUxMyAwMDAwMCBuDQowMDAwMTI5NTkzIDAwMDAwIG4NCjAwMDAxMjk2NzMgMDAwMDAgbg0KMDAwMDEyOTc1NSAwMDAwMCBuDQowMDAwMTI5ODM1IDAwMDAwIG4NCjAwMDAxMjk5MTUgMDAwMDAgbg0KMDAwMDEyOTk5NSAwMDAwMCBuDQowMDAwMTMwMDc3IDAwMDAwIG4NCjAwMDAxMzAxNTcgMDAwMDAgbg0KMDAwMDEzMDI0MSAwMDAwMCBuDQowMDAwMTMwMzIxIDAwMDAwIG4NCjAwMDAxMzA0MDMgMDAwMDAgbg0KMDAwMDEzMDQ4MyAwMDAwMCBuDQowMDAwMTMwNTYzIDAwMDAwIG4NCjAwMDAxMzA2NDMgMDAwMDAgbg0KMDAwMDEzMDcyMyAwMDAwMCBuDQowMDAwMTMwODAzIDAwMDAwIG4NCjAwMDAxMzA4ODMgMDAwMDAgbg0KMDAwMDEzMDk2NyAwMDAwMCBuDQowMDAwMTMxMDQ3IDAwMDAwIG4NCjAwMDAxMzExMjUgMDAwMDAgbg0KMDAwMDEzMTIwNSAwMDAwMCBuDQowMDAwMTMxMjgzIDAwMDAwIG4NCjAwMDAxMzEzNjIgMDAwMDAgbg0KMDAwMDEzMTM5MyAwMDAwMCBuDQowMDAwMTMxNDcyIDAwMDAwIG4NCjAwMDAxMzE1NTkgMDAwMDAgbg0KMDAwMDEzMTY0NiAwMDAwMCBuDQowMDAwMTMxNzMzIDAwMDAwIG4NCjAwMDAxMzE3NjQgMDAwMDAgbg0KMDAwMDEzMTg1MSAwMDAwMCBuDQowMDAwMTMxOTMyIDAwMDAwIG4NCjAwMDAxMzE5NjMgMDAwMDAgbg0KMDAwMDEzMjA0NCAwMDAwMCBuDQowMDAwMTMyMTIxIDAwMDAwIG4NCjAwMDAxMzIxOTggMDAwMDAgbg0KMDAwMDEzMjI3NSAwMDAwMCBuDQowMDAwMTMyMzUyIDAwMDAwIG4NCjAwMDAxMzI0MjkgMDAwMDAgbg0KMDAwMDEzMjUwNiAwMDAwMCBuDQowMDAwMTMyNTgzIDAwMDAwIG4NCjAwMDAxMzI2MTQgMDAwMDAgbg0KMDAwMDEzMjY5MSAwMDAwMCBuDQowMDAwMTMyNzcwIDAwMDAwIG4NCjAwMDAxMzI4MDEgMDAwMDAgbg0KMDAwMDEzMjg4MCAwMDAwMCBuDQowMDAwMTMyOTYyIDAwMDAwIG4NCjAwMDAxMzI5OTMgMDAwMDAgbg0KMDAwMDEzMzA3NSAwMDAwMCBuDQowMDAwMTMzMTUzIDAwMDAwIG4NCjAwMDAxMzMxODQgMDAwMDAgbg0KMDAwMDEzMzI2MiAwMDAwMCBuDQowMDAwMTMzMzQzIDAwMDAwIG4NCjAwMDAxMzM0MjQgMDAwMDAgbg0KMDAwMDEzMzUwNSAwMDAwMCBuDQowMDAwMTMzNTM2IDAwMDAwIG4NCjAwMDAxMzM2MTcgMDAwMDAgbg0KMDAwMDEzMzY5NiAwMDAwMCBuDQowMDAwMTMzNzI3IDAwMDAwIG4NCjAwMDAxMzM4MDYgMDAwMDAgbg0KMDAwMDEzMzg4MSAwMDAwMCBuDQowMDAwMTMzOTU2IDAwMDAwIG4NCjAwMDAxMzQwMzEgMDAwMDAgbg0KMDAwMDEzNDEwNiAwMDAwMCBuDQowMDAwMTM0MTgxIDAwMDAwIG4NCjAwMDAxMzQyNTYgMDAwMDAgbg0KMDAwMDEzNDMzMyAwMDAwMCBuDQowMDAwMTM0MzY0IDAwMDAwIG4NCjAwMDAxMzQ0NDEgMDAwMDAgbg0KMDAwMDEzNDUyMCAwMDAwMCBuDQowMDAwMTM0NTUyIDAwMDAwIG4NCjAwMDAxMzQ2MzEgMDAwMDAgbg0KMDAwMDEzNDcwOCAwMDAwMCBuDQowMDAwMTM0NzQwIDAwMDAwIG4NCjAwMDAxMzQ4MTcgMDAwMDAgbg0KMDAwMDEzNDg5NCAwMDAwMCBuDQowMDAwMTM0OTI2IDAwMDAwIG4NCjAwMDAxMzUwMDMgMDAwMDAgbg0KMDAwMDEzNTA4MCAwMDAwMCBuDQowMDAwMTM1MTEyIDAwMDAwIG4NCjAwMDAxMzUxODkgMDAwMDAgbg0KMDAwMDEzNTI3MCAwMDAwMCBuDQowMDAwMTM1MzAyIDAwMDAwIG4NCjAwMDAxMzUzODMgMDAwMDAgbg0KMDAwMDEzNTQ2NiAwMDAwMCBuDQowMDAwMTM1NDk4IDAwMDAwIG4NCjAwMDAxMzU1ODEgMDAwMDAgbg0KMDAwMDEzNTY2MiAwMDAwMCBuDQowMDAwMTM1Njk0IDAwMDAwIG4NCjAwMDAxMzU3NzUgMDAwMDAgbg0KMDAwMDEzNTg2MCAwMDAwMCBuDQowMDAwMTM1OTQ1IDAwMDAwIG4NCjAwMDAxMzYwMzAgMDAwMDAgbg0KMDAwMDEzNjA2MiAwMDAwMCBuDQowMDAwMTM2MTQ3IDAwMDAwIG4NCjAwMDAxMzYyMjQgMDAwMDAgbg0KMDAwMDEzNjI1NiAwMDAwMCBuDQowMDAwMTM2MzMzIDAwMDAwIG4NCjAwMDAxMzY0MTcgMDAwMDAgbg0KMDAwMDEzNjQ0OSAwMDAwMCBuDQowMDAwMTM2NTMzIDAwMDAwIG4NCjAwMDAxMzY2MDkgMDAwMDAgbg0KMDAwMDEzNjY0MSAwMDAwMCBuDQowMDAwMTM2NzE3IDAwMDAwIG4NCjAwMDAxMzY3OTQgMDAwMDAgbg0KMDAwMDEzNjg3MSAwMDAwMCBuDQowMDAwMTM2OTQ4IDAwMDAwIG4NCjAwMDAxMzY5ODAgMDAwMDAgbg0KMDAwMDEzNzA1NyAwMDAwMCBuDQowMDAwMTM3MTM5IDAwMDAwIG4NCjAwMDAxMzcxNzEgMDAwMDAgbg0KMDAwMDEzNzI1MyAwMDAwMCBuDQowMDAwMTM3MzMwIDAwMDAwIG4NCjAwMDAxMzc0MDcgMDAwMDAgbg0KMDAwMDEzNzQ4NCAwMDAwMCBuDQowMDAwMTM3NTYxIDAwMDAwIG4NCjAwMDAxMzc2MzggMDAwMDAgbg0KMDAwMDEzNzcxNSAwMDAwMCBuDQowMDAwMTM3Nzk3IDAwMDAwIG4NCjAwMDAxMzc4MjkgMDAwMDAgbg0KMDAwMDEzNzkxMSAwMDAwMCBuDQowMDAwMTM3OTkxIDAwMDAwIG4NCjAwMDAxMzgwMjMgMDAwMDAgbg0KMDAwMDEzODEwMyAwMDAwMCBuDQowMDAwMTM4MTg2IDAwMDAwIG4NCjAwMDAxMzgyMTggMDAwMDAgbg0KMDAwMDEzODMwMSAwMDAwMCBuDQowMDAwMTM4MzgzIDAwMDAwIG4NCjAwMDAxMzg0MTUgMDAwMDAgbg0KMDAwMDEzODQ5NyAwMDAwMCBuDQowMDAwMTM4NTgwIDAwMDAwIG4NCjAwMDAxMzg2MTIgMDAwMDAgbg0KMDAwMDEzODY5NSAwMDAwMCBuDQowMDAwMTM4Nzc3IDAwMDAwIG4NCjAwMDAxMzg4MDkgMDAwMDAgbg0KMDAwMDEzODg5MSAwMDAwMCBuDQowMDAwMTM4OTY5IDAwMDAwIG4NCjAwMDAxMzkwMDEgMDAwMDAgbg0KMDAwMDEzOTA3OSAwMDAwMCBuDQowMDAwMTM5MTU5IDAwMDAwIG4NCjAwMDAxMzkxOTEgMDAwMDAgbg0KMDAwMDEzOTI3MSAwMDAwMCBuDQowMDAwMTM5MzUxIDAwMDAwIG4NCjAwMDAxMzkzODMgMDAwMDAgbg0KMDAwMDEzOTQ2MyAwMDAwMCBuDQowMDAwMTM5NTQ0IDAwMDAwIG4NCjAwMDAxMzk1NzYgMDAwMDAgbg0KMDAwMDEzOTY1NyAwMDAwMCBuDQowMDAwMTM5NzM5IDAwMDAwIG4NCjAwMDAxMzk3NzEgMDAwMDAgbg0KMDAwMDEzOTg1MyAwMDAwMCBuDQowMDAwMTM5OTMzIDAwMDAwIG4NCjAwMDAxMzk5NjUgMDAwMDAgbg0KMDAwMDE0MDA0NSAwMDAwMCBuDQowMDAwMTQwMTI2IDAwMDAwIG4NCjAwMDAxNDAxNTggMDAwMDAgbg0KMDAwMDE0MDIzOSAwMDAwMCBuDQowMDAwMTQwMzIxIDAwMDAwIG4NCjAwMDAxNDAzNTMgMDAwMDAgbg0KMDAwMDE0MDQzNSAwMDAwMCBuDQowMDAwMTQwNTE1IDAwMDAwIG4NCjAwMDAxNDA1NDcgMDAwMDAgbg0KMDAwMDE0MDYyNyAwMDAwMCBuDQowMDAwMTQwNzA4IDAwMDAwIG4NCjAwMDAxNDA3NDAgMDAwMDAgbg0KMDAwMDE0MDgyMSAwMDAwMCBuDQowMDAwMTQwODk4IDAwMDAwIG4NCjAwMDAxNDA5NzUgMDAwMDAgbg0KMDAwMDE0MTA1MiAwMDAwMCBuDQowMDAwMTQxMTI5IDAwMDAwIG4NCjAwMDAxNDEyMDcgMDAwMDAgbg0KMDAwMDE0MTI4NSAwMDAwMCBuDQowMDAwMTQxMzY1IDAwMDAwIG4NCjAwMDAxNDE0NDUgMDAwMDAgbg0KMDAwMDE0MTUyNSAwMDAwMCBuDQowMDAwMTQxNjA5IDAwMDAwIG4NCjAwMDAxNDE2ODkgMDAwMDAgbg0KMDAwMDE0MTc3MyAwMDAwMCBuDQowMDAwMTQxODU3IDAwMDAwIG4NCjAwMDAxNDE5NDEgMDAwMDAgbg0KMDAwMDE0MjAyNSAwMDAwMCBuDQowMDAwMTQyMTA3IDAwMDAwIG4NCjAwMDAxNDIxOTEgMDAwMDAgbg0KMDAwMDE0MjI3NSAwMDAwMCBuDQowMDAwMTQyMzU1IDAwMDAwIG4NCjAwMDAxNDI0MzkgMDAwMDAgbg0KMDAwMDE0MjUyMyAwMDAwMCBuDQowMDAwMTQyNjA1IDAwMDAwIG4NCjAwMDAxNDI2ODkgMDAwMDAgbg0KMDAwMDE0Mjc2OSAwMDAwMCBuDQowMDAwMTQyODUzIDAwMDAwIG4NCjAwMDAxNDI5MzMgMDAwMDAgbg0KMDAwMDE0MzAxNiAwMDAwMCBuDQowMDAwMTQzMTAxIDAwMDAwIG4NCjAwMDAxNDMxODQgMDAwMDAgbg0KMDAwMDE0MzI2MCAwMDAwMCBuDQowMDAwMTQzMjkxIDAwMDAwIG4NCjAwMDAxNDMzNjcgMDAwMDAgbg0KMDAwMDE0MzQ0NyAwMDAwMCBuDQowMDAwMTQzNDc4IDAwMDAwIG4NCjAwMDAxNDM1NTggMDAwMDAgbg0KMDAwMDE0MzYzNSAwMDAwMCBuDQowMDAwMTQzNjY2IDAwMDAwIG4NCjAwMDAxNDM3NDMgMDAwMDAgbg0KMDAwMDE0MzgyMyAwMDAwMCBuDQowMDAwMTQzODU0IDAwMDAwIG4NCjAwMDAxNDM5MzQgMDAwMDAgbg0KMDAwMDE0NDAxNCAwMDAwMCBuDQowMDAwMTQ0MDQ1IDAwMDAwIG4NCjAwMDAxNDQxMjUgMDAwMDAgbg0KMDAwMDE0NDIwMiAwMDAwMCBuDQowMDAwMTQ0MjM0IDAwMDAwIG4NCjAwMDAxNDQzMTEgMDAwMDAgbg0KMDAwMDE0NDM5MyAwMDAwMCBuDQowMDAwMTQ0NDI1IDAwMDAwIG4NCjAwMDAxNDQ1MDcgMDAwMDAgbg0KMDAwMDE0NDU4NiAwMDAwMCBuDQowMDAwMTQ0NjE4IDAwMDAwIG4NCjAwMDAxNDQ2OTcgMDAwMDAgbg0KMDAwMDE0NDc3OCAwMDAwMCBuDQowMDAwMTQ0ODEwIDAwMDAwIG4NCjAwMDAxNDQ4OTEgMDAwMDAgbg0KMDAwMDE0NDk2OCAwMDAwMCBuDQowMDAwMTQ1MDAwIDAwMDAwIG4NCjAwMDAxNDUwNzcgMDAwMDAgbg0KMDAwMDE0NTE1NiAwMDAwMCBuDQowMDAwMTQ1MTg5IDAwMDAwIG4NCjAwMDAxNDUyNjggMDAwMDAgbg0KMDAwMDE0NTM0OCAwMDAwMCBuDQowMDAwMTQ1MzgxIDAwMDAwIG4NCjAwMDAxNDU0NjEgMDAwMDAgbg0KMDAwMDE0NTU0MCAwMDAwMCBuDQowMDAwMTQ1NTczIDAwMDAwIG4NCjAwMDAxNDU2NTIgMDAwMDAgbg0KMDAwMDE0NTczNSAwMDAwMCBuDQowMDAwMTQ1NzY4IDAwMDAwIG4NCjAwMDAxNDU4NTEgMDAwMDAgbg0KMDAwMDE0NTkyOCAwMDAwMCBuDQowMDAwMTQ1OTYxIDAwMDAwIG4NCjAwMDAxNDYwMzggMDAwMDAgbg0KMDAwMDE0NjExOCAwMDAwMCBuDQowMDAwMTQ2MTUxIDAwMDAwIG4NCjAwMDAxNDYyMzEgMDAwMDAgbg0KMDAwMDE0NjMxNSAwMDAwMCBuDQowMDAwMTQ2Mzk5IDAwMDAwIG4NCjAwMDAxNDY0ODMgMDAwMDAgbg0KMDAwMDE0NjUxNiAwMDAwMCBuDQowMDAwMTQ2NjAwIDAwMDAwIG4NCjAwMDAxNDY2ODAgMDAwMDAgbg0KMDAwMDE0NjcxMyAwMDAwMCBuDQowMDAwMTQ2NzkzIDAwMDAwIG4NCjAwMDAxNDY4NjkgMDAwMDAgbg0KMDAwMDE0Njk0NSAwMDAwMCBuDQowMDAwMTQ3MDIxIDAwMDAwIG4NCjAwMDAxNDcwOTcgMDAwMDAgbg0KMDAwMDE0NzE3MyAwMDAwMCBuDQowMDAwMTQ3MjQ5IDAwMDAwIG4NCjAwMDAxNDczMzMgMDAwMDAgbg0KMDAwMDE0NzQxNyAwMDAwMCBuDQowMDAwMTQ3NTAxIDAwMDAwIG4NCjAwMDAxNDc1MzQgMDAwMDAgbg0KMDAwMDE0NzYxOCAwMDAwMCBuDQowMDAwMTQ3Njk4IDAwMDAwIG4NCjAwMDAxNDc3MzEgMDAwMDAgbg0KMDAwMDE0NzgxMSAwMDAwMCBuDQowMDAwMTQ3ODg3IDAwMDAwIG4NCjAwMDAxNDc5NjMgMDAwMDAgbg0KMDAwMDE0ODAzOSAwMDAwMCBuDQowMDAwMTQ4MTE1IDAwMDAwIG4NCjAwMDAxNDgxOTEgMDAwMDAgbg0KMDAwMDE0ODI2NyAwMDAwMCBuDQowMDAwMTQ4MzUxIDAwMDAwIG4NCjAwMDAxNDg0MzUgMDAwMDAgbg0KMDAwMDE0ODUxOSAwMDAwMCBuDQowMDAwMTQ4NTUyIDAwMDAwIG4NCjAwMDAxNDg2MzYgMDAwMDAgbg0KMDAwMDE0ODcxNSAwMDAwMCBuDQowMDAwMTQ4NzQ4IDAwMDAwIG4NCjAwMDAxNDg4MjcgMDAwMDAgbg0KMDAwMDE0ODkwMyAwMDAwMCBuDQowMDAwMTQ4OTc5IDAwMDAwIG4NCjAwMDAxNDkwNTUgMDAwMDAgbg0KMDAwMDE0OTEzMSAwMDAwMCBuDQowMDAwMTQ5MjA3IDAwMDAwIG4NCjAwMDAxNDkyODMgMDAwMDAgbg0KMDAwMDE0OTM3MSAwMDAwMCBuDQowMDAwMTQ5NDU5IDAwMDAwIG4NCjAwMDAxNDk1NDcgMDAwMDAgbg0KMDAwMDE0OTU4MCAwMDAwMCBuDQowMDAwMTQ5NjY4IDAwMDAwIG4NCjAwMDAxNDk3NTMgMDAwMDAgbg0KMDAwMDE0OTc4NiAwMDAwMCBuDQowMDAwMTQ5ODcxIDAwMDAwIG4NCjAwMDAxNDk5NTMgMDAwMDAgbg0KMDAwMDE0OTk4NiAwMDAwMCBuDQowMDAwMTUwMDY4IDAwMDAwIG4NCjAwMDAxNTAxNTggMDAwMDAgbg0KMDAwMDE1MDI0OCAwMDAwMCBuDQowMDAwMTUwMzM4IDAwMDAwIG4NCjAwMDAxNTAzNzEgMDAwMDAgbg0KMDAwMDE1MDQ2MSAwMDAwMCBuDQowMDAwMTUwNTQxIDAwMDAwIG4NCjAwMDAxNTA1NzQgMDAwMDAgbg0KMDAwMDE1MDY1NCAwMDAwMCBuDQowMDAwMTUwNzMwIDAwMDAwIG4NCjAwMDAxNTA4MDYgMDAwMDAgbg0KMDAwMDE1MDg4MiAwMDAwMCBuDQowMDAwMTUwOTU4IDAwMDAwIG4NCjAwMDAxNTEwMzQgMDAwMDAgbg0KMDAwMDE1MTExMCAwMDAwMCBuDQowMDAwMTUxMTkyIDAwMDAwIG4NCjAwMDAxNTEyMjUgMDAwMDAgbg0KMDAwMDE1MTMwNyAwMDAwMCBuDQowMDAwMTUxMzg4IDAwMDAwIG4NCjAwMDAxNTE0MjEgMDAwMDAgbg0KMDAwMDE1MTUwMiAwMDAwMCBuDQowMDAwMTUxNTgyIDAwMDAwIG4NCjAwMDAxNTE2MTUgMDAwMDAgbg0KMDAwMDE1MTY5NSAwMDAwMCBuDQowMDAwMTUxNzc3IDAwMDAwIG4NCjAwMDAxNTE4MTAgMDAwMDAgbg0KMDAwMDE1MTg5MiAwMDAwMCBuDQowMDAwMTUxOTcwIDAwMDAwIG4NCjAwMDAxNTIwMDMgMDAwMDAgbg0KMDAwMDE1MjA4MSAwMDAwMCBuDQowMDAwMTUyMTY1IDAwMDAwIG4NCjAwMDAxNTIxOTggMDAwMDAgbg0KMDAwMDE1MjI4MiAwMDAwMCBuDQowMDAwMTUyMzYyIDAwMDAwIG4NCjAwMDAxNTIzOTUgMDAwMDAgbg0KMDAwMDE1MjQ3NSAwMDAwMCBuDQowMDAwMTUyNTU2IDAwMDAwIG4NCjAwMDAxNTI1ODkgMDAwMDAgbg0KMDAwMDE1MjY3MCAwMDAwMCBuDQowMDAwMTUyNzUyIDAwMDAwIG4NCjAwMDAxNTI3ODUgMDAwMDAgbg0KMDAwMDE1Mjg2NyAwMDAwMCBuDQowMDAwMTUyOTQ1IDAwMDAwIG4NCjAwMDAxNTI5NzggMDAwMDAgbg0KMDAwMDE1MzA1NiAwMDAwMCBuDQowMDAwMTUzMTQyIDAwMDAwIG4NCjAwMDAxNTMxNzUgMDAwMDAgbg0KMDAwMDE1MzI2MSAwMDAwMCBuDQowMDAwMTUzMzQ0IDAwMDAwIG4NCjAwMDAxNTMzNzcgMDAwMDAgbg0KMDAwMDE1MzQ2MCAwMDAwMCBuDQowMDAwMTUzNTUxIDAwMDAwIG4NCjAwMDAxNTM2NDIgMDAwMDAgbg0KMDAwMDE1MzczMyAwMDAwMCBuDQowMDAwMTUzNzY2IDAwMDAwIG4NCjAwMDAxNTM4NTcgMDAwMDAgbg0KMDAwMDE1Mzk0MCAwMDAwMCBuDQowMDAwMTUzOTczIDAwMDAwIG4NCjAwMDAxNTQwNTYgMDAwMDAgbg0KMDAwMDE1NDEzNSAwMDAwMCBuDQowMDAwMTU0MjE0IDAwMDAwIG4NCjAwMDAxNTQyOTMgMDAwMDAgbg0KMDAwMDE1NDM3MiAwMDAwMCBuDQowMDAwMTU0NDUxIDAwMDAwIG4NCjAwMDAxNTQ1MzAgMDAwMDAgbg0KMDAwMDE1NDYwOCAwMDAwMCBuDQowMDAwMTU0Njg2IDAwMDAwIG4NCjAwMDAxNTQ3NjQgMDAwMDAgbg0KMDAwMDE1NDg0MiAwMDAwMCBuDQowMDAwMTU0OTIxIDAwMDAwIG4NCjAwMDAxNTUwMDAgMDAwMDAgbg0KMDAwMDE1NTA4MiAwMDAwMCBuDQowMDAwMTU1MTYwIDAwMDAwIG4NCjAwMDAxNTUyMzggMDAwMDAgbg0KMDAwMDE1NTMxNyAwMDAwMCBuDQowMDAwMTU1Mzk4IDAwMDAwIG4NCjAwMDAxNTU0NzYgMDAwMDAgbg0KMDAwMDE1NTU1OCAwMDAwMCBuDQowMDAwMTU1NjM2IDAwMDAwIG4NCjAwMDAxNTU3MTQgMDAwMDAgbg0KMDAwMDE1NTc5MyAwMDAwMCBuDQowMDAwMTU1ODc1IDAwMDAwIG4NCjAwMDAxNTU5NTMgMDAwMDAgbg0KMDAwMDE1NjAzMSAwMDAwMCBuDQowMDAwMTU2MTA5IDAwMDAwIG4NCjAwMDAxNTYxOTQgMDAwMDAgbg0KMDAwMDE1NjI3MiAwMDAwMCBuDQowMDAwMTU2MzU3IDAwMDAwIG4NCjAwMDAxNTY0MzQgMDAwMDAgbg0KMDAwMDE1NjUxOSAwMDAwMCBuDQowMDAwMTU2NTk3IDAwMDAwIG4NCjAwMDAxNTY2ODIgMDAwMDAgbg0KMDAwMDE1Njc2NyAwMDAwMCBuDQowMDAwMTU2ODUyIDAwMDAwIG4NCjAwMDAxNTY5MzcgMDAwMDAgbg0KMDAwMDE1NzAxNSAwMDAwMCBuDQowMDAwMTU3MTAwIDAwMDAwIG4NCjAwMDAxNTcxODEgMDAwMDAgbg0KMDAwMDE1NzI1OSAwMDAwMCBuDQowMDAwMTU3MzQzIDAwMDAwIG4NCjAwMDAxNTc0MjAgMDAwMDAgbg0KMDAwMDE1NzUwNCAwMDAwMCBuDQowMDAwMTU3NTgwIDAwMDAwIG4NCjAwMDAxNTc2NTggMDAwMDAgbg0KMDAwMDE1NzY5MCAwMDAwMCBuDQowMDAwMTU3NzY4IDAwMDAwIG4NCjAwMDAxNTc4NDUgMDAwMDAgbg0KMDAwMDE1Nzg3NyAwMDAwMCBuDQowMDAwMTU3OTU0IDAwMDAwIG4NCjAwMDAxNTgwMzkgMDAwMDAgbg0KMDAwMDE1ODEyNCAwMDAwMCBuDQowMDAwMTU4MjA5IDAwMDAwIG4NCjAwMDAxNTgyNDEgMDAwMDAgbg0KMDAwMDE1ODMyNiAwMDAwMCBuDQowMDAwMTU4NDAzIDAwMDAwIG4NCjAwMDAxNTg0MzUgMDAwMDAgbg0KMDAwMDE1ODUxMiAwMDAwMCBuDQowMDAwMTU4NTg1IDAwMDAwIG4NCjAwMDAxNTg2NTggMDAwMDAgbg0KMDAwMDE1ODczMSAwMDAwMCBuDQowMDAwMTU4ODA0IDAwMDAwIG4NCjAwMDAxNTg4NzcgMDAwMDAgbg0KMDAwMDE1ODk1MCAwMDAwMCBuDQowMDAwMTU5MDMxIDAwMDAwIG4NCjAwMDAxNTkwNjMgMDAwMDAgbg0KMDAwMDE1OTE0NCAwMDAwMCBuDQowMDAwMTU5MjIxIDAwMDAwIG4NCjAwMDAxNTkyNTMgMDAwMDAgbg0KMDAwMDE1OTMzMCAwMDAwMCBuDQowMDAwMTU5NDExIDAwMDAwIG4NCjAwMDAxNTk0OTIgMDAwMDAgbg0KMDAwMDE1OTU3MyAwMDAwMCBuDQowMDAwMTU5NjA1IDAwMDAwIG4NCjAwMDAxNTk2ODYgMDAwMDAgbg0KMDAwMDE1OTc2NyAwMDAwMCBuDQowMDAwMTU5Nzk5IDAwMDAwIG4NCjAwMDAxNTk4ODAgMDAwMDAgbg0KMDAwMDE1OTk1NyAwMDAwMCBuDQowMDAwMTYwMDM0IDAwMDAwIG4NCjAwMDAxNjAxMTEgMDAwMDAgbg0KMDAwMDE2MDE4OCAwMDAwMCBuDQowMDAwMTYwMjY1IDAwMDAwIG4NCjAwMDAxNjAzNDIgMDAwMDAgbg0KMDAwMDE2MDQyMCAwMDAwMCBuDQowMDAwMTYwNDUyIDAwMDAwIG4NCjAwMDAxNjA1MzAgMDAwMDAgbg0KMDAwMDE2MDYxMSAwMDAwMCBuDQowMDAwMTYwNjQzIDAwMDAwIG4NCjAwMDAxNjA3MjQgMDAwMDAgbg0KMDAwMDE2MDgwOSAwMDAwMCBuDQowMDAwMTYwODk0IDAwMDAwIG4NCjAwMDAxNjA5NzkgMDAwMDAgbg0KMDAwMDE2MTAxMiAwMDAwMCBuDQowMDAwMTYxMDk3IDAwMDAwIG4NCjAwMDAxNjExNzQgMDAwMDAgbg0KMDAwMDE2MTIwNyAwMDAwMCBuDQowMDAwMTYxMjg0IDAwMDAwIG4NCjAwMDAxNjEzNTcgMDAwMDAgbg0KMDAwMDE2MTQzMCAwMDAwMCBuDQowMDAwMTYxNTAzIDAwMDAwIG4NCjAwMDAxNjE1NzYgMDAwMDAgbg0KMDAwMDE2MTY0OSAwMDAwMCBuDQowMDAwMTYxNzIyIDAwMDAwIG4NCjAwMDAxNjE4MDEgMDAwMDAgbg0KMDAwMDE2MTgzNCAwMDAwMCBuDQowMDAwMTYxOTEzIDAwMDAwIG4NCjAwMDAxNjE5ODkgMDAwMDAgbg0KMDAwMDE2MjAyMiAwMDAwMCBuDQowMDAwMTYyMDk4IDAwMDAwIG4NCjAwMDAxNjIxNzMgMDAwMDAgbg0KMDAwMDE2MjIwNiAwMDAwMCBuDQowMDAwMTYyMjgxIDAwMDAwIG4NCjAwMDAxNjIzNTkgMDAwMDAgbg0KMDAwMDE2MjM5MiAwMDAwMCBuDQowMDAwMTYyNDcwIDAwMDAwIG4NCjAwMDAxNjI1NTQgMDAwMDAgbg0KMDAwMDE2MjU4NyAwMDAwMCBuDQowMDAwMTYyNjcxIDAwMDAwIG4NCjAwMDAxNjI3NjMgMDAwMDAgbg0KMDAwMDE2Mjg1NSAwMDAwMCBuDQowMDAwMTYyOTQ3IDAwMDAwIG4NCjAwMDAxNjI5ODAgMDAwMDAgbg0KMDAwMDE2MzA3MiAwMDAwMCBuDQowMDAwMTYzMTU3IDAwMDAwIG4NCjAwMDAxNjMxOTAgMDAwMDAgbg0KMDAwMDE2MzI3NSAwMDAwMCBuDQowMDAwMTYzMzU1IDAwMDAwIG4NCjAwMDAxNjMzODggMDAwMDAgbg0KMDAwMDE2MzQ2OCAwMDAwMCBuDQowMDAwMTYzNTU2IDAwMDAwIG4NCjAwMDAxNjM2NDQgMDAwMDAgbg0KMDAwMDE2MzczMiAwMDAwMCBuDQowMDAwMTYzNzY1IDAwMDAwIG4NCjAwMDAxNjM4NTMgMDAwMDAgbg0KMDAwMDE2MzkzMCAwMDAwMCBuDQowMDAwMTYzOTYzIDAwMDAwIG4NCjAwMDAxNjQwNDAgMDAwMDAgbg0KMDAwMDE2NDExMyAwMDAwMCBuDQowMDAwMTY0MTg2IDAwMDAwIG4NCjAwMDAxNjQyNTkgMDAwMDAgbg0KMDAwMDE2NDMzMiAwMDAwMCBuDQowMDAwMTY0NDA1IDAwMDAwIG4NCjAwMDAxNjQ0NzggMDAwMDAgbg0KMDAwMDE2NDU2MyAwMDAwMCBuDQowMDAwMTY0NTk2IDAwMDAwIG4NCjAwMDAxNjQ2ODEgMDAwMDAgbg0KMDAwMDE2NDc1OCAwMDAwMCBuDQowMDAwMTY0NzkxIDAwMDAwIG4NCjAwMDAxNjQ4NjggMDAwMDAgbg0KMDAwMDE2NDk1MyAwMDAwMCBuDQowMDAwMTY1MDM4IDAwMDAwIG4NCjAwMDAxNjUxMjMgMDAwMDAgbg0KMDAwMDE2NTE1NiAwMDAwMCBuDQowMDAwMTY1MjQxIDAwMDAwIG4NCjAwMDAxNjUzMjUgMDAwMDAgbg0KMDAwMDE2NTM1OCAwMDAwMCBuDQowMDAwMTY1NDQyIDAwMDAwIG4NCjAwMDAxNjU1MjIgMDAwMDAgbg0KMDAwMDE2NTYwMiAwMDAwMCBuDQowMDAwMTY1NjgyIDAwMDAwIG4NCjAwMDAxNjU3NjIgMDAwMDAgbg0KMDAwMDE2NTg0MiAwMDAwMCBuDQowMDAwMTY1OTIyIDAwMDAwIG4NCjAwMDAxNjYwMDAgMDAwMDAgbg0KMDAwMDE2NjAzMyAwMDAwMCBuDQowMDAwMTY2MTExIDAwMDAwIG4NCjAwMDAxNjYxOTQgMDAwMDAgbg0KMDAwMDE2NjIyNyAwMDAwMCBuDQowMDAwMTY2MzEwIDAwMDAwIG4NCjAwMDAxNjY0MDAgMDAwMDAgbg0KMDAwMDE2NjQ5MCAwMDAwMCBuDQowMDAwMTY2NTgwIDAwMDAwIG4NCjAwMDAxNjY2MTMgMDAwMDAgbg0KMDAwMDE2NjcwMyAwMDAwMCBuDQowMDAwMTY2Nzg3IDAwMDAwIG4NCjAwMDAxNjY4MjAgMDAwMDAgbg0KMDAwMDE2NjkwNCAwMDAwMCBuDQowMDAwMTY2OTg0IDAwMDAwIG4NCjAwMDAxNjcwNjQgMDAwMDAgbg0KMDAwMDE2NzE0NCAwMDAwMCBuDQowMDAwMTY3MjI0IDAwMDAwIG4NCjAwMDAxNjczMDQgMDAwMDAgbg0KMDAwMDE2NzM4NCAwMDAwMCBuDQowMDAwMTY3NDYyIDAwMDAwIG4NCjAwMDAxNjc0OTUgMDAwMDAgbg0KMDAwMDE2NzU3MyAwMDAwMCBuDQowMDAwMTY3NjU3IDAwMDAwIG4NCjAwMDAxNjc2OTAgMDAwMDAgbg0KMDAwMDE2Nzc3NCAwMDAwMCBuDQowMDAwMTY3ODY2IDAwMDAwIG4NCjAwMDAxNjc5NTggMDAwMDAgbg0KMDAwMDE2ODA1MCAwMDAwMCBuDQowMDAwMTY4MDgzIDAwMDAwIG4NCjAwMDAxNjgxNzUgMDAwMDAgbg0KMDAwMDE2ODI1OCAwMDAwMCBuDQowMDAwMTY4MjkxIDAwMDAwIG4NCjAwMDAxNjgzNzQgMDAwMDAgbg0KMDAwMDE2ODQ1MyAwMDAwMCBuDQowMDAwMTY4NTMyIDAwMDAwIG4NCjAwMDAxNjg2MTEgMDAwMDAgbg0KMDAwMDE2ODY5MCAwMDAwMCBuDQowMDAwMTY4NzY5IDAwMDAwIG4NCjAwMDAxNjg4NDggMDAwMDAgbg0KMDAwMDE2ODkzMiAwMDAwMCBuDQowMDAwMTY4OTY1IDAwMDAwIG4NCjAwMDAxNjkwNDkgMDAwMDAgbg0KMDAwMDE2OTEyNyAwMDAwMCBuDQowMDAwMTY5MjA1IDAwMDAwIG4NCjAwMDAxNjkyODMgMDAwMDAgbg0KMDAwMDE2OTM2MSAwMDAwMCBuDQowMDAwMTY5NDQwIDAwMDAwIG4NCjAwMDAxNjk1MTkgMDAwMDAgbg0KMDAwMDE2OTYwMCAwMDAwMCBuDQowMDAwMTY5NjgxIDAwMDAwIG4NCjAwMDAxNjk3NjIgMDAwMDAgbg0KMDAwMDE2OTg0NSAwMDAwMCBuDQowMDAwMTY5OTI2IDAwMDAwIG4NCjAwMDAxNzAwMDcgMDAwMDAgbg0KMDAwMDE3MDA4OCAwMDAwMCBuDQowMDAwMTcwMTcxIDAwMDAwIG4NCjAwMDAxNzAyNTIgMDAwMDAgbg0KMDAwMDE3MDMzMyAwMDAwMCBuDQowMDAwMTcwNDE0IDAwMDAwIG4NCjAwMDAxNzA0OTcgMDAwMDAgbg0KMDAwMDE3MDU3OCAwMDAwMCBuDQowMDAwMTcwNjYzIDAwMDAwIG4NCjAwMDAxNzA3NDYgMDAwMDAgbg0KMDAwMDE3MDgyOSAwMDAwMCBuDQowMDAwMTcwOTEwIDAwMDAwIG4NCjAwMDAxNzA5OTUgMDAwMDAgbg0KMDAwMDE3MTA3NiAwMDAwMCBuDQowMDAwMTcxMTYxIDAwMDAwIG4NCjAwMDAxNzEyNDIgMDAwMDAgbg0KMDAwMDE3MTMyMyAwMDAwMCBuDQowMDAwMTcxNDA0IDAwMDAwIG4NCjAwMDAxNzE0ODkgMDAwMDAgbg0KMDAwMDE3MTU3NCAwMDAwMCBuDQowMDAwMTcxNjU5IDAwMDAwIG4NCjAwMDAxNzE3NDIgMDAwMDAgbg0KMDAwMDE3MTgyMyAwMDAwMCBuDQowMDAwMTcxOTA4IDAwMDAwIG4NCjAwMDAxNzE5ODcgMDAwMDAgbg0KMDAwMDE3MjA3MiAwMDAwMCBuDQowMDAwMTcyMTUwIDAwMDAwIG4NCjAwMDAxNzIxODIgMDAwMDAgbg0KMDAwMDE3MjI2MCAwMDAwMCBuDQowMDAwMTcyMzQwIDAwMDAwIG4NCjAwMDAxNzI0MjAgMDAwMDAgbg0KMDAwMDE3MjUwMCAwMDAwMCBuDQowMDAwMTcyNTMyIDAwMDAwIG4NCjAwMDAxNzI2MTIgMDAwMDAgbg0KMDAwMDE3MjY5MiAwMDAwMCBuDQowMDAwMTcyNzI0IDAwMDAwIG4NCjAwMDAxNzI4MDQgMDAwMDAgbg0KMDAwMDE3Mjg4MCAwMDAwMCBuDQowMDAwMTcyOTU2IDAwMDAwIG4NCjAwMDAxNzMwMzIgMDAwMDAgbg0KMDAwMDE3MzEwOCAwMDAwMCBuDQowMDAwMTczMTg0IDAwMDAwIG4NCjAwMDAxNzMyNjAgMDAwMDAgbg0KMDAwMDE3MzM0MCAwMDAwMCBuDQowMDAwMTczMzcyIDAwMDAwIG4NCjAwMDAxNzM0NTIgMDAwMDAgbg0KMDAwMDE3MzUzMCAwMDAwMCBuDQowMDAwMTczNTYyIDAwMDAwIG4NCjAwMDAxNzM2NDAgMDAwMDAgbg0KMDAwMDE3MzcyMSAwMDAwMCBuDQowMDAwMTczNzUzIDAwMDAwIG4NCjAwMDAxNzM4MzQgMDAwMDAgbg0KMDAwMDE3MzkxMyAwMDAwMCBuDQowMDAwMTczOTQ1IDAwMDAwIG4NCjAwMDAxNzQwMjQgMDAwMDAgbg0KMDAwMDE3NDEwNCAwMDAwMCBuDQowMDAwMTc0MTg0IDAwMDAwIG4NCjAwMDAxNzQyNjQgMDAwMDAgbg0KMDAwMDE3NDI5NiAwMDAwMCBuDQowMDAwMTc0Mzc2IDAwMDAwIG4NCjAwMDAxNzQ0NTggMDAwMDAgbg0KMDAwMDE3NDQ5MCAwMDAwMCBuDQowMDAwMTc0NTcyIDAwMDAwIG4NCjAwMDAxNzQ2NTAgMDAwMDAgbg0KMDAwMDE3NDcyOCAwMDAwMCBuDQowMDAwMTc0ODA2IDAwMDAwIG4NCjAwMDAxNzQ4ODQgMDAwMDAgbg0KMDAwMDE3NDk2MiAwMDAwMCBuDQowMDAwMTc1MDQwIDAwMDAwIG4NCjAwMDAxNzUxMjEgMDAwMDAgbg0KMDAwMDE3NTE1MyAwMDAwMCBuDQowMDAwMTc1MjM0IDAwMDAwIG4NCjAwMDAxNzUzMTQgMDAwMDAgbg0KMDAwMDE3NTM0NyAwMDAwMCBuDQowMDAwMTc1NDI3IDAwMDAwIG4NCjAwMDAxNzU1MTUgMDAwMDAgbg0KMDAwMDE3NTYwMyAwMDAwMCBuDQowMDAwMTc1NjkxIDAwMDAwIG4NCjAwMDAxNzU3MjQgMDAwMDAgbg0KMDAwMDE3NTgxMiAwMDAwMCBuDQowMDAwMTc1ODk0IDAwMDAwIG4NCjAwMDAxNzU5MjcgMDAwMDAgbg0KMDAwMDE3NjAwOSAwMDAwMCBuDQowMDAwMTc2MDg3IDAwMDAwIG4NCjAwMDAxNzYxNjUgMDAwMDAgbg0KMDAwMDE3NjI0MyAwMDAwMCBuDQowMDAwMTc2MzIxIDAwMDAwIG4NCjAwMDAxNzYzOTkgMDAwMDAgbg0KMDAwMDE3NjQ3NyAwMDAwMCBuDQowMDAwMTc2NTU1IDAwMDAwIG4NCjAwMDAxNzY1ODggMDAwMDAgbg0KMDAwMDE3NjY2NiAwMDAwMCBuDQowMDAwMTc2NzQ2IDAwMDAwIG4NCjAwMDAxNzY3NzkgMDAwMDAgbg0KMDAwMDE3Njg1OSAwMDAwMCBuDQowMDAwMTc2OTQwIDAwMDAwIG4NCjAwMDAxNzY5NzMgMDAwMDAgbg0KMDAwMDE3NzA1NCAwMDAwMCBuDQowMDAwMTc3MTM0IDAwMDAwIG4NCjAwMDAxNzcxNjcgMDAwMDAgbg0KMDAwMDE3NzI0NyAwMDAwMCBuDQowMDAwMTc3MzI3IDAwMDAwIG4NCjAwMDAxNzczNjAgMDAwMDAgbg0KMDAwMDE3NzQ0MCAwMDAwMCBuDQowMDAwMTc3NTI0IDAwMDAwIG4NCjAwMDAxNzc2MDggMDAwMDAgbg0KMDAwMDE3NzY5MiAwMDAwMCBuDQowMDAwMTc3NzI1IDAwMDAwIG4NCjAwMDAxNzc4MDkgMDAwMDAgbg0KMDAwMDE3Nzg4NyAwMDAwMCBuDQowMDAwMTc3OTIwIDAwMDAwIG4NCjAwMDAxNzc5OTggMDAwMDAgbg0KMDAwMDE3ODA4MiAwMDAwMCBuDQowMDAwMTc4MTE1IDAwMDAwIG4NCjAwMDAxNzgxOTkgMDAwMDAgbg0KMDAwMDE3ODI5MSAwMDAwMCBuDQowMDAwMTc4MzgzIDAwMDAwIG4NCjAwMDAxNzg0NzUgMDAwMDAgbg0KMDAwMDE3ODUwOCAwMDAwMCBuDQowMDAwMTc4NjAwIDAwMDAwIG4NCjAwMDAxNzg2ODEgMDAwMDAgbg0KMDAwMDE3ODcxNCAwMDAwMCBuDQowMDAwMTc4Nzk1IDAwMDAwIG4NCjAwMDAxNzg4NzUgMDAwMDAgbg0KMDAwMDE3ODk1NSAwMDAwMCBuDQowMDAwMTc5MDM1IDAwMDAwIG4NCjAwMDAxNzkxMTUgMDAwMDAgbg0KMDAwMDE3OTE5NSAwMDAwMCBuDQowMDAwMTc5Mjc1IDAwMDAwIG4NCjAwMDAxNzkzNTcgMDAwMDAgbg0KMDAwMDE3OTM5MCAwMDAwMCBuDQowMDAwMTc5NDcyIDAwMDAwIG4NCjAwMDAxNzk1NjQgMDAwMDAgbg0KMDAwMDE3OTY1NiAwMDAwMCBuDQowMDAwMTc5NzQ4IDAwMDAwIG4NCjAwMDAxNzk3ODEgMDAwMDAgbg0KMDAwMDE3OTg3MyAwMDAwMCBuDQowMDAwMTc5OTUzIDAwMDAwIG4NCjAwMDAxNzk5ODYgMDAwMDAgbg0KMDAwMDE4MDA2NiAwMDAwMCBuDQowMDAwMTgwMTQyIDAwMDAwIG4NCjAwMDAxODAyMTggMDAwMDAgbg0KMDAwMDE4MDI5NCAwMDAwMCBuDQowMDAwMTgwMzcwIDAwMDAwIG4NCjAwMDAxODA0NDYgMDAwMDAgbg0KMDAwMDE4MDUyMiAwMDAwMCBuDQowMDAwMTgwNjA3IDAwMDAwIG4NCjAwMDAxODA2NDAgMDAwMDAgbg0KMDAwMDE4MDcyNSAwMDAwMCBuDQowMDAwMTgwODA2IDAwMDAwIG4NCjAwMDAxODA4MzkgMDAwMDAgbg0KMDAwMDE4MDkyMCAwMDAwMCBuDQowMDAwMTgxMDA0IDAwMDAwIG4NCjAwMDAxODEwODggMDAwMDAgbg0KMDAwMDE4MTE3MiAwMDAwMCBuDQowMDAwMTgxMjA1IDAwMDAwIG4NCjAwMDAxODEyODkgMDAwMDAgbg0KMDAwMDE4MTM3MyAwMDAwMCBuDQowMDAwMTgxNDA2IDAwMDAwIG4NCjAwMDAxODE0OTAgMDAwMDAgbg0KMDAwMDE4MTU3MCAwMDAwMCBuDQowMDAwMTgxNjUwIDAwMDAwIG4NCjAwMDAxODE3MzAgMDAwMDAgbg0KMDAwMDE4MTgxMCAwMDAwMCBuDQowMDAwMTgxODkwIDAwMDAwIG4NCjAwMDAxODE5NzAgMDAwMDAgbg0KMDAwMDE4MjA1MSAwMDAwMCBuDQowMDAwMTgyMDg0IDAwMDAwIG4NCjAwMDAxODIxNjUgMDAwMDAgbg0KMDAwMDE4MjI0OCAwMDAwMCBuDQowMDAwMTgyMjgxIDAwMDAwIG4NCjAwMDAxODIzNjQgMDAwMDAgbg0KMDAwMDE4MjQ1MCAwMDAwMCBuDQowMDAwMTgyNTM2IDAwMDAwIG4NCjAwMDAxODI2MjIgMDAwMDAgbg0KMDAwMDE4MjY1NSAwMDAwMCBuDQowMDAwMTgyNzQxIDAwMDAwIG4NCjAwMDAxODI4MjUgMDAwMDAgbg0KMDAwMDE4Mjg1OCAwMDAwMCBuDQowMDAwMTgyOTQyIDAwMDAwIG4NCjAwMDAxODMwMjIgMDAwMDAgbg0KMDAwMDE4MzEwMiAwMDAwMCBuDQowMDAwMTgzMTgyIDAwMDAwIG4NCjAwMDAxODMyNjIgMDAwMDAgbg0KMDAwMDE4MzM0MiAwMDAwMCBuDQowMDAwMTgzNDIyIDAwMDAwIG4NCjAwMDAxODM1MDcgMDAwMDAgbg0KMDAwMDE4MzU0MCAwMDAwMCBuDQowMDAwMTgzNjI1IDAwMDAwIG4NCjAwMDAxODM3MDMgMDAwMDAgbg0KMDAwMDE4Mzc4MSAwMDAwMCBuDQowMDAwMTgzODU5IDAwMDAwIG4NCjAwMDAxODM5NDEgMDAwMDAgbg0KMDAwMDE4NDAyMiAwMDAwMCBuDQowMDAwMTg0MTAzIDAwMDAwIG4NCjAwMDAxODQxODQgMDAwMDAgbg0KMDAwMDE4NDI2NSAwMDAwMCBuDQowMDAwMTg0MzQ2IDAwMDAwIG4NCjAwMDAxODQ0MjkgMDAwMDAgbg0KMDAwMDE4NDUxMCAwMDAwMCBuDQowMDAwMTg0NTkzIDAwMDAwIG4NCjAwMDAxODQ2NzQgMDAwMDAgbg0KMDAwMDE4NDc1NSAwMDAwMCBuDQowMDAwMTg0ODM2IDAwMDAwIG4NCjAwMDAxODQ5MTkgMDAwMDAgbg0KMDAwMDE4NTAwMCAwMDAwMCBuDQowMDAwMTg1MDgwIDAwMDAwIG4NCjAwMDAxODUxNjEgMDAwMDAgbg0KMDAwMDE4NTIzOCAwMDAwMCBuDQowMDAwMTg1MzE1IDAwMDAwIG4NCjAwMDAxODUzOTYgMDAwMDAgbg0KMDAwMDE4NTQ3MyAwMDAwMCBuDQowMDAwMTg1NTU4IDAwMDAwIG4NCjAwMDAxODU2MzUgMDAwMDAgbg0KMDAwMDE4NTcyMCAwMDAwMCBuDQowMDAwMTg1ODA1IDAwMDAwIG4NCjAwMDAxODU4OTAgMDAwMDAgbg0KMDAwMDE4NTk3NSAwMDAwMCBuDQowMDAwMTg2MDYwIDAwMDAwIG4NCjAwMDAxODYxNDUgMDAwMDAgbg0KMDAwMDE4NjIzMCAwMDAwMCBuDQowMDAwMTg2MzA3IDAwMDAwIG4NCjAwMDAxODYzOTIgMDAwMDAgbg0KMDAwMDE4NjQ3NiAwMDAwMCBuDQowMDAwMTg2NTYxIDAwMDAwIG4NCjAwMDAxODY2NDUgMDAwMDAgbg0KMDAwMDE4NjcyMSAwMDAwMCBuDQowMDAwMTg2Nzk3IDAwMDAwIG4NCjAwMDAxODY4NzQgMDAwMDAgbg0KMDAwMDE4NjkwNiAwMDAwMCBuDQowMDAwMTg2OTgzIDAwMDAwIG4NCjAwMDAxODcwNjEgMDAwMDAgbg0KMDAwMDE4NzEzOSAwMDAwMCBuDQowMDAwMTg3MjE3IDAwMDAwIG4NCjAwMDAxODcyNDkgMDAwMDAgbg0KMDAwMDE4NzMyNyAwMDAwMCBuDQowMDAwMTg3NDA3IDAwMDAwIG4NCjAwMDAxODc0MzkgMDAwMDAgbg0KMDAwMDE4NzUxOSAwMDAwMCBuDQowMDAwMTg3NTk1IDAwMDAwIG4NCjAwMDAxODc2NzEgMDAwMDAgbg0KMDAwMDE4Nzc0NyAwMDAwMCBuDQowMDAwMTg3ODIzIDAwMDAwIG4NCjAwMDAxODc4OTkgMDAwMDAgbg0KMDAwMDE4Nzk3NSAwMDAwMCBuDQowMDAwMTg4MDU4IDAwMDAwIG4NCjAwMDAxODgwOTAgMDAwMDAgbg0KMDAwMDE4ODE3MyAwMDAwMCBuDQowMDAwMTg4MjUyIDAwMDAwIG4NCjAwMDAxODgyODQgMDAwMDAgbg0KMDAwMDE4ODM2MyAwMDAwMCBuDQowMDAwMTg4NDQ1IDAwMDAwIG4NCjAwMDAxODg1MjcgMDAwMDAgbg0KMDAwMDE4ODYwOSAwMDAwMCBuDQowMDAwMTg4NjQxIDAwMDAwIG4NCjAwMDAxODg3MjMgMDAwMDAgbg0KMDAwMDE4ODgwNSAwMDAwMCBuDQowMDAwMTg4ODM3IDAwMDAwIG4NCjAwMDAxODg5MTkgMDAwMDAgbg0KMDAwMDE4ODk5NyAwMDAwMCBuDQowMDAwMTg5MDc1IDAwMDAwIG4NCjAwMDAxODkxNTMgMDAwMDAgbg0KMDAwMDE4OTIzMSAwMDAwMCBuDQowMDAwMTg5MzA5IDAwMDAwIG4NCjAwMDAxODkzODcgMDAwMDAgbg0KMDAwMDE4OTQ2OCAwMDAwMCBuDQowMDAwMTg5NTAwIDAwMDAwIG4NCjAwMDAxODk1ODEgMDAwMDAgbg0KMDAwMDE4OTY2MyAwMDAwMCBuDQowMDAwMTg5Njk1IDAwMDAwIG4NCjAwMDAxODk3NzcgMDAwMDAgbg0KMDAwMDE4OTg2NSAwMDAwMCBuDQowMDAwMTg5OTUzIDAwMDAwIG4NCjAwMDAxOTAwNDEgMDAwMDAgbg0KMDAwMDE5MDA3MyAwMDAwMCBuDQowMDAwMTkwMTYxIDAwMDAwIG4NCjAwMDAxOTAyNDEgMDAwMDAgbg0KMDAwMDE5MDI3NCAwMDAwMCBuDQowMDAwMTkwMzU0IDAwMDAwIG4NCjAwMDAxOTA0MzAgMDAwMDAgbg0KMDAwMDE5MDUwNiAwMDAwMCBuDQowMDAwMTkwNTgyIDAwMDAwIG4NCjAwMDAxOTA2NTggMDAwMDAgbg0KMDAwMDE5MDczNCAwMDAwMCBuDQowMDAwMTkwODEwIDAwMDAwIG4NCjAwMDAxOTA4OTMgMDAwMDAgbg0KMDAwMDE5MDkyNiAwMDAwMCBuDQowMDAwMTkxMDA5IDAwMDAwIG4NCjAwMDAxOTEwODkgMDAwMDAgbg0KMDAwMDE5MTEyMiAwMDAwMCBuDQowMDAwMTkxMjAyIDAwMDAwIG4NCjAwMDAxOTEyOTAgMDAwMDAgbg0KMDAwMDE5MTM3OCAwMDAwMCBuDQowMDAwMTkxNDY2IDAwMDAwIG4NCjAwMDAxOTE0OTkgMDAwMDAgbg0KMDAwMDE5MTU4NyAwMDAwMCBuDQowMDAwMTkxNjY3IDAwMDAwIG4NCjAwMDAxOTE3MDAgMDAwMDAgbg0KMDAwMDE5MTc4MCAwMDAwMCBuDQowMDAwMTkxODU2IDAwMDAwIG4NCjAwMDAxOTE5MzIgMDAwMDAgbg0KMDAwMDE5MjAwOCAwMDAwMCBuDQowMDAwMTkyMDg0IDAwMDAwIG4NCjAwMDAxOTIxNjAgMDAwMDAgbg0KMDAwMDE5MjIzNiAwMDAwMCBuDQowMDAwMTkyMzE3IDAwMDAwIG4NCjAwMDAxOTIzNTAgMDAwMDAgbg0KMDAwMDE5MjQzMSAwMDAwMCBuDQowMDAwMTkyNTExIDAwMDAwIG4NCjAwMDAxOTI1NDQgMDAwMDAgbg0KMDAwMDE5MjYyNCAwMDAwMCBuDQowMDAwMTkyNzAwIDAwMDAwIG4NCjAwMDAxOTI3MzMgMDAwMDAgbg0KMDAwMDE5Mjc2NiAwMDAwMCBuDQowMDAwMTkyODQyIDAwMDAwIG4NCjAwMDAxOTI5MTkgMDAwMDAgbg0KMDAwMDE5Mjk5NiAwMDAwMCBuDQowMDAwMTkzMDczIDAwMDAwIG4NCjAwMDAxOTMxNTEgMDAwMDAgbg0KMDAwMDE5MzE4NCAwMDAwMCBuDQowMDAwMTkzMjYyIDAwMDAwIG4NCjAwMDAxOTMzNDUgMDAwMDAgbg0KMDAwMDE5MzM3OCAwMDAwMCBuDQowMDAwMTkzNDYxIDAwMDAwIG4NCjAwMDAxOTM1NDEgMDAwMDAgbg0KMDAwMDE5MzYyMSAwMDAwMCBuDQowMDAwMTkzNzAxIDAwMDAwIG4NCjAwMDAxOTM3ODggMDAwMDAgbg0KMDAwMDE5MzgyMSAwMDAwMCBuDQowMDAwMTkzOTA4IDAwMDAwIG4NCjAwMDAxOTM5OTggMDAwMDAgbg0KMDAwMDE5NDAzMSAwMDAwMCBuDQowMDAwMTk0MTIxIDAwMDAwIG4NCjAwMDAxOTQyMDUgMDAwMDAgbg0KMDAwMDE5NDIzOCAwMDAwMCBuDQowMDAwMTk0MzIyIDAwMDAwIG4NCjAwMDAxOTQ0MDYgMDAwMDAgbg0KMDAwMDE5NDQzOSAwMDAwMCBuDQowMDAwMTk0NTIzIDAwMDAwIG4NCjAwMDAxOTQ2MDMgMDAwMDAgbg0KMDAwMDE5NDYzNiAwMDAwMCBuDQowMDAwMTk0NzE2IDAwMDAwIG4NCjAwMDAxOTQ3OTggMDAwMDAgbg0KMDAwMDE5NDgzMSAwMDAwMCBuDQowMDAwMTk0OTEzIDAwMDAwIG4NCjAwMDAxOTQ5OTMgMDAwMDAgbg0KMDAwMDE5NTAyNiAwMDAwMCBuDQowMDAwMTk1MTA2IDAwMDAwIG4NCjAwMDAxOTUxODkgMDAwMDAgbg0KMDAwMDE5NTIyMiAwMDAwMCBuDQowMDAwMTk1MzA1IDAwMDAwIG4NCjAwMDAxOTUzODcgMDAwMDAgbg0KMDAwMDE5NTQyMCAwMDAwMCBuDQowMDAwMTk1NTAyIDAwMDAwIG4NCjAwMDAxOTU1ODQgMDAwMDAgbg0KMDAwMDE5NTYxNyAwMDAwMCBuDQowMDAwMTk1Njk5IDAwMDAwIG4NCjAwMDAxOTU3NzcgMDAwMDAgbg0KMDAwMDE5NTg1NSAwMDAwMCBuDQowMDAwMTk1OTMzIDAwMDAwIG4NCjAwMDAxOTYwMTEgMDAwMDAgbg0KMDAwMDE5NjA5MCAwMDAwMCBuDQowMDAwMTk2MTY5IDAwMDAwIG4NCjAwMDAxOTYyNTAgMDAwMDAgbg0KMDAwMDE5NjMzMSAwMDAwMCBuDQowMDAwMTk2NDE0IDAwMDAwIG4NCjAwMDAxOTY0OTUgMDAwMDAgbg0KMDAwMDE5NjU3NiAwMDAwMCBuDQowMDAwMTk2NjU5IDAwMDAwIG4NCjAwMDAxOTY3NDIgMDAwMDAgbg0KMDAwMDE5NjgyMyAwMDAwMCBuDQowMDAwMTk2OTA0IDAwMDAwIG4NCjAwMDAxOTY5ODUgMDAwMDAgbg0KMDAwMDE5NzA2OCAwMDAwMCBuDQowMDAwMTk3MTQ5IDAwMDAwIG4NCjAwMDAxOTcyMzAgMDAwMDAgbg0KMDAwMDE5NzMxMyAwMDAwMCBuDQowMDAwMTk3Mzk0IDAwMDAwIG4NCjAwMDAxOTc0NzkgMDAwMDAgbg0KMDAwMDE5NzU2MCAwMDAwMCBuDQowMDAwMTk3NjQzIDAwMDAwIG4NCjAwMDAxOTc3MjYgMDAwMDAgbg0KMDAwMDE5NzgwOSAwMDAwMCBuDQowMDAwMTk3ODkwIDAwMDAwIG4NCjAwMDAxOTc5NzUgMDAwMDAgbg0KMDAwMDE5ODA1NiAwMDAwMCBuDQowMDAwMTk4MTQxIDAwMDAwIG4NCjAwMDAxOTgyMjQgMDAwMDAgbg0KMDAwMDE5ODMwOSAwMDAwMCBuDQowMDAwMTk4MzkyIDAwMDAwIG4NCjAwMDAxOTg0NzMgMDAwMDAgbg0KMDAwMDE5ODU1NCAwMDAwMCBuDQowMDAwMTk4NjM1IDAwMDAwIG4NCjAwMDAxOTg3MTYgMDAwMDAgbg0KMDAwMDE5ODgwMSAwMDAwMCBuDQowMDAwMTk4ODgyIDAwMDAwIG4NCjAwMDAxOTg5NjcgMDAwMDAgbg0KMDAwMDE5OTA1MiAwMDAwMCBuDQowMDAwMTk5MTM3IDAwMDAwIG4NCjAwMDAxOTkyMjIgMDAwMDAgbg0KMDAwMDE5OTMwMyAwMDAwMCBuDQowMDAwMTk5Mzg4IDAwMDAwIG4NCjAwMDAxOTk0NzMgMDAwMDAgbg0KMDAwMDE5OTU1NiAwMDAwMCBuDQowMDAwMTk5NjQxIDAwMDAwIG4NCjAwMDAxOTk3MjEgMDAwMDAgbg0KMDAwMDE5OTgwNiAwMDAwMCBuDQowMDAwMTk5ODg1IDAwMDAwIG4NCjAwMDAxOTk5NjMgMDAwMDAgbg0KMDAwMDIwMDA0MSAwMDAwMCBuDQowMDAwMjAwMTE5IDAwMDAwIG4NCjAwMDAyMDAxNTEgMDAwMDAgbg0KMDAwMDIwMDIyOSAwMDAwMCBuDQowMDAwMjAwMzEwIDAwMDAwIG4NCjAwMDAyMDAzNDIgMDAwMDAgbg0KMDAwMDIwMDQyMyAwMDAwMCBuDQowMDAwMjAwNTAxIDAwMDAwIG4NCjAwMDAyMDA1MzMgMDAwMDAgbg0KMDAwMDIwMDYxMSAwMDAwMCBuDQowMDAwMjAwNjkwIDAwMDAwIG4NCjAwMDAyMDA3MjIgMDAwMDAgbg0KMDAwMDIwMDgwMSAwMDAwMCBuDQowMDAwMjAwODc5IDAwMDAwIG4NCjAwMDAyMDA5MTEgMDAwMDAgbg0KMDAwMDIwMDk4OSAwMDAwMCBuDQowMDAwMjAxMDY2IDAwMDAwIG4NCjAwMDAyMDEwOTggMDAwMDAgbg0KMDAwMDIwMTE3NSAwMDAwMCBuDQowMDAwMjAxMjU1IDAwMDAwIG4NCjAwMDAyMDEyODcgMDAwMDAgbg0KMDAwMDIwMTM2NyAwMDAwMCBuDQowMDAwMjAxNDQ3IDAwMDAwIG4NCjAwMDAyMDE0NzkgMDAwMDAgbg0KMDAwMDIwMTU1OSAwMDAwMCBuDQowMDAwMjAxNjM5IDAwMDAwIG4NCjAwMDAyMDE2NzEgMDAwMDAgbg0KMDAwMDIwMTc1MSAwMDAwMCBuDQowMDAwMjAxODMxIDAwMDAwIG4NCjAwMDAyMDE4NjMgMDAwMDAgbg0KMDAwMDIwMTk0MyAwMDAwMCBuDQowMDAwMjAyMDIxIDAwMDAwIG4NCjAwMDAyMDIwNTQgMDAwMDAgbg0KMDAwMDIwMjEzMiAwMDAwMCBuDQowMDAwMjAyMjEzIDAwMDAwIG4NCjAwMDAyMDIyNDYgMDAwMDAgbg0KMDAwMDIwMjMyNyAwMDAwMCBuDQowMDAwMjAyNDA3IDAwMDAwIG4NCjAwMDAyMDI0NDAgMDAwMDAgbg0KMDAwMDIwMjUyMCAwMDAwMCBuDQowMDAwMjAyNTk5IDAwMDAwIG4NCjAwMDAyMDI2MzIgMDAwMDAgbg0KMDAwMDIwMjcxMSAwMDAwMCBuDQowMDAwMjAyNzg5IDAwMDAwIG4NCjAwMDAyMDI4MjIgMDAwMDAgbg0KMDAwMDIwMjkwMCAwMDAwMCBuDQowMDAwMjAyOTg0IDAwMDAwIG4NCjAwMDAyMDMwMTcgMDAwMDAgbg0KMDAwMDIwMzEwMSAwMDAwMCBuDQowMDAwMjAzMTgzIDAwMDAwIG4NCjAwMDAyMDMyMTYgMDAwMDAgbg0KMDAwMDIwMzI5OCAwMDAwMCBuDQowMDAwMjAzMzgwIDAwMDAwIG4NCjAwMDAyMDM0MTMgMDAwMDAgbg0KMDAwMDIwMzQ5NSAwMDAwMCBuDQowMDAwMjAzNTczIDAwMDAwIG4NCjAwMDAyMDM2MDYgMDAwMDAgbg0KMDAwMDIwMzY4NCAwMDAwMCBuDQowMDAwMjAzNzYzIDAwMDAwIG4NCjAwMDAyMDM3OTYgMDAwMDAgbg0KMDAwMDIwMzg3NSAwMDAwMCBuDQowMDAwMjAzOTU3IDAwMDAwIG4NCjAwMDAyMDM5OTAgMDAwMDAgbg0KMDAwMDIwNDA3MiAwMDAwMCBuDQowMDAwMjA0MTUxIDAwMDAwIG4NCjAwMDAyMDQxODQgMDAwMDAgbg0KMDAwMDIwNDI2MyAwMDAwMCBuDQowMDAwMjA0MzQ1IDAwMDAwIG4NCjAwMDAyMDQzNzggMDAwMDAgbg0KMDAwMDIwNDQ2MCAwMDAwMCBuDQowMDAwMjA0NTQ1IDAwMDAwIG4NCjAwMDAyMDQ1NzggMDAwMDAgbg0KMDAwMDIwNDY2MyAwMDAwMCBuDQowMDAwMjA0NzQxIDAwMDAwIG4NCjAwMDAyMDQ3NzQgMDAwMDAgbg0KMDAwMDIwNDg1MiAwMDAwMCBuDQowMDAwMjA0OTM1IDAwMDAwIG4NCjAwMDAyMDQ5NjggMDAwMDAgbg0KMDAwMDIwNTA1MSAwMDAwMCBuDQowMDAwMjA1MTMxIDAwMDAwIG4NCjAwMDAyMDUxNjQgMDAwMDAgbg0KMDAwMDIwNTI0NCAwMDAwMCBuDQowMDAwMjA1MzI3IDAwMDAwIG4NCjAwMDAyMDUzNjAgMDAwMDAgbg0KMDAwMDIwNTQ0MyAwMDAwMCBuDQowMDAwMjA1NTI1IDAwMDAwIG4NCjAwMDAyMDU1NTggMDAwMDAgbg0KMDAwMDIwNTY0MCAwMDAwMCBuDQowMDAwMjA1NzE4IDAwMDAwIG4NCjAwMDAyMDU3NTEgMDAwMDAgbg0KMDAwMDIwNTgyOSAwMDAwMCBuDQowMDAwMjA1OTA3IDAwMDAwIG4NCjAwMDAyMDU5ODUgMDAwMDAgbg0KMDAwMDIwNjA2MyAwMDAwMCBuDQowMDAwMjA2MTQ1IDAwMDAwIG4NCjAwMDAyMDYyMjggMDAwMDAgbg0KMDAwMDIwNjMxMSAwMDAwMCBuDQowMDAwMjA2MzkyIDAwMDAwIG4NCjAwMDAyMDY0NzMgMDAwMDAgbg0KMDAwMDIwNjU1NiAwMDAwMCBuDQowMDAwMjA2NjM5IDAwMDAwIG4NCjAwMDAyMDY3MjAgMDAwMDAgbg0KMDAwMDIwNjgwMSAwMDAwMCBuDQowMDAwMjA2ODgyIDAwMDAwIG4NCjAwMDAyMDY5NjUgMDAwMDAgbg0KMDAwMDIwNzA0NiAwMDAwMCBuDQowMDAwMjA3MTI3IDAwMDAwIG4NCjAwMDAyMDcyMTAgMDAwMDAgbg0KMDAwMDIwNzI5MSAwMDAwMCBuDQowMDAwMjA3Mzc2IDAwMDAwIG4NCjAwMDAyMDc0NTcgMDAwMDAgbg0KMDAwMDIwNzU0MCAwMDAwMCBuDQowMDAwMjA3NjIxIDAwMDAwIG4NCjAwMDAyMDc3MDIgMDAwMDAgbg0KMDAwMDIwNzc4MyAwMDAwMCBuDQowMDAwMjA3ODY4IDAwMDAwIG4NCjAwMDAyMDc5NDkgMDAwMDAgbg0KMDAwMDIwODAzNCAwMDAwMCBuDQowMDAwMjA4MTE1IDAwMDAwIG4NCjAwMDAyMDgyMDAgMDAwMDAgbg0KMDAwMDIwODI4MyAwMDAwMCBuDQowMDAwMjA4MzY4IDAwMDAwIG4NCjAwMDAyMDg0NDkgMDAwMDAgbg0KMDAwMDIwODUzNCAwMDAwMCBuDQowMDAwMjA4NjE1IDAwMDAwIG4NCjAwMDAyMDg2OTYgMDAwMDAgbg0KMDAwMDIwODc3NyAwMDAwMCBuDQowMDAwMjA4ODYyIDAwMDAwIG4NCjAwMDAyMDg5NDcgMDAwMDAgbg0KMDAwMDIwOTAzMCAwMDAwMCBuDQowMDAwMjA5MTE1IDAwMDAwIG4NCjAwMDAyMDkyMDAgMDAwMDAgbg0KMDAwMDIwOTI4NSAwMDAwMCBuDQowMDAwMjA5MzY4IDAwMDAwIG4NCjAwMDAyMDk0NDkgMDAwMDAgbg0KMDAwMDIwOTQ4MSAwMDAwMCBuDQowMDAwMjA5NTYyIDAwMDAwIG4NCjAwMDAyMDk2NDQgMDAwMDAgbg0KMDAwMDIwOTY3NiAwMDAwMCBuDQowMDAwMjA5NzU4IDAwMDAwIG4NCjAwMDAyMDk4NDQgMDAwMDAgbg0KMDAwMDIwOTkzMCAwMDAwMCBuDQowMDAwMjEwMDE2IDAwMDAwIG4NCjAwMDAyMTAwNDggMDAwMDAgbg0KMDAwMDIxMDEzNCAwMDAwMCBuDQowMDAwMjEwMjE2IDAwMDAwIG4NCjAwMDAyMTAyNDggMDAwMDAgbg0KMDAwMDIxMDMzMCAwMDAwMCBuDQowMDAwMjEwNDA4IDAwMDAwIG4NCjAwMDAyMTA0ODYgMDAwMDAgbg0KMDAwMDIxMDU2NCAwMDAwMCBuDQowMDAwMjEwNjQyIDAwMDAwIG4NCjAwMDAyMTA3MjAgMDAwMDAgbg0KMDAwMDIxMDc5OCAwMDAwMCBuDQowMDAwMjEwODc2IDAwMDAwIG4NCjAwMDAyMTA5MDggMDAwMDAgbg0KMDAwMDIxMDk4NiAwMDAwMCBuDQowMDAwMjExMDY1IDAwMDAwIG4NCjAwMDAyMTEwOTcgMDAwMDAgbg0KMDAwMDIxMTE3NiAwMDAwMCBuDQowMDAwMjExMjU2IDAwMDAwIG4NCjAwMDAyMTEyODggMDAwMDAgbg0KMDAwMDIxMTM2OCAwMDAwMCBuDQowMDAwMjExNDQ1IDAwMDAwIG4NCjAwMDAyMTE0NzcgMDAwMDAgbg0KMDAwMDIxMTU1NCAwMDAwMCBuDQowMDAwMjExNjM0IDAwMDAwIG4NCjAwMDAyMTE2NjYgMDAwMDAgbg0KMDAwMDIxMTc0NiAwMDAwMCBuDQowMDAwMjExODI2IDAwMDAwIG4NCjAwMDAyMTE4NTggMDAwMDAgbg0KMDAwMDIxMTkzOCAwMDAwMCBuDQowMDAwMjEyMDE2IDAwMDAwIG4NCjAwMDAyMTIwNDkgMDAwMDAgbg0KMDAwMDIxMjEyNyAwMDAwMCBuDQowMDAwMjEyMjA4IDAwMDAwIG4NCjAwMDAyMTIyNDEgMDAwMDAgbg0KMDAwMDIxMjMyMiAwMDAwMCBuDQowMDAwMjEyNDAwIDAwMDAwIG4NCjAwMDAyMTI0MzMgMDAwMDAgbg0KMDAwMDIxMjUxMSAwMDAwMCBuDQowMDAwMjEyNTkwIDAwMDAwIG4NCjAwMDAyMTI2MjMgMDAwMDAgbg0KMDAwMDIxMjcwMiAwMDAwMCBuDQowMDAwMjEyNzg0IDAwMDAwIG4NCjAwMDAyMTI4NjYgMDAwMDAgbg0KMDAwMDIxMjk0OCAwMDAwMCBuDQowMDAwMjEyOTgxIDAwMDAwIG4NCjAwMDAyMTMwNjMgMDAwMDAgbg0KMDAwMDIxMzE0MSAwMDAwMCBuDQowMDAwMjEzMTc0IDAwMDAwIG4NCjAwMDAyMTMyNTIgMDAwMDAgbg0KMDAwMDIxMzMzNiAwMDAwMCBuDQowMDAwMjEzMzY5IDAwMDAwIG4NCjAwMDAyMTM0NTMgMDAwMDAgbg0KMDAwMDIxMzUzNSAwMDAwMCBuDQowMDAwMjEzNTY4IDAwMDAwIG4NCjAwMDAyMTM2NTAgMDAwMDAgbg0KMDAwMDIxMzczMSAwMDAwMCBuDQowMDAwMjEzNzY0IDAwMDAwIG4NCjAwMDAyMTM4NDUgMDAwMDAgbg0KMDAwMDIxMzkyNiAwMDAwMCBuDQowMDAwMjEzOTU5IDAwMDAwIG4NCjAwMDAyMTQwNDAgMDAwMDAgbg0KMDAwMDIxNDExOCAwMDAwMCBuDQowMDAwMjE0MTUxIDAwMDAwIG4NCjAwMDAyMTQyMjkgMDAwMDAgbg0KMDAwMDIxNDMxMyAwMDAwMCBuDQowMDAwMjE0MzQ2IDAwMDAwIG4NCjAwMDAyMTQ0MzAgMDAwMDAgbg0KMDAwMDIxNDUxMSAwMDAwMCBuDQowMDAwMjE0NTQ0IDAwMDAwIG4NCjAwMDAyMTQ2MjUgMDAwMDAgbg0KMDAwMDIxNDcwNyAwMDAwMCBuDQowMDAwMjE0NzQwIDAwMDAwIG4NCjAwMDAyMTQ4MjIgMDAwMDAgbg0KMDAwMDIxNDkwOCAwMDAwMCBuDQowMDAwMjE0OTk0IDAwMDAwIG4NCjAwMDAyMTUwODAgMDAwMDAgbg0KMDAwMDIxNTExMyAwMDAwMCBuDQowMDAwMjE1MTk5IDAwMDAwIG4NCjAwMDAyMTUyNzkgMDAwMDAgbg0KMDAwMDIxNTMxMiAwMDAwMCBuDQowMDAwMjE1MzkyIDAwMDAwIG4NCjAwMDAyMTU0NjggMDAwMDAgbg0KMDAwMDIxNTU0NCAwMDAwMCBuDQowMDAwMjE1NjIwIDAwMDAwIG4NCjAwMDAyMTU2OTYgMDAwMDAgbg0KMDAwMDIxNTc3MiAwMDAwMCBuDQowMDAwMjE1ODQ4IDAwMDAwIG4NCjAwMDAyMTU5MzAgMDAwMDAgbg0KMDAwMDIxNTk2MyAwMDAwMCBuDQowMDAwMjE2MDQ1IDAwMDAwIG4NCjAwMDAyMTYxMjggMDAwMDAgbg0KMDAwMDIxNjE2MSAwMDAwMCBuDQowMDAwMjE2MjQ0IDAwMDAwIG4NCjAwMDAyMTYzMjYgMDAwMDAgbg0KMDAwMDIxNjM1OSAwMDAwMCBuDQowMDAwMjE2NDQxIDAwMDAwIG4NCjAwMDAyMTY1MjUgMDAwMDAgbg0KMDAwMDIxNjU1OCAwMDAwMCBuDQowMDAwMjE2NjQyIDAwMDAwIG4NCjAwMDAyMTY3MjYgMDAwMDAgbg0KMDAwMDIxNjc1OSAwMDAwMCBuDQowMDAwMjE2ODQzIDAwMDAwIG4NCjAwMDAyMTY5MjEgMDAwMDAgbg0KMDAwMDIxNjk5OSAwMDAwMCBuDQowMDAwMjE3MDc3IDAwMDAwIG4NCjAwMDAyMTcxNTkgMDAwMDAgbg0KMDAwMDIxNzI0MiAwMDAwMCBuDQowMDAwMjE3MzI1IDAwMDAwIG4NCjAwMDAyMTc0MDggMDAwMDAgbg0KMDAwMDIxNzQ5MSAwMDAwMCBuDQowMDAwMjE3NTc0IDAwMDAwIG4NCjAwMDAyMTc2NTcgMDAwMDAgbg0KMDAwMDIxNzc0MCAwMDAwMCBuDQowMDAwMjE3ODIzIDAwMDAwIG4NCjAwMDAyMTc5MDYgMDAwMDAgbg0KMDAwMDIxNzk5MCAwMDAwMCBuDQowMDAwMjE4MDczIDAwMDAwIG4NCjAwMDAyMTgxNTggMDAwMDAgbg0KMDAwMDIxODI0MyAwMDAwMCBuDQowMDAwMjE4MzI4IDAwMDAwIG4NCjAwMDAyMTg0MTMgMDAwMDAgbg0KMDAwMDIxODQ5OCAwMDAwMCBuDQowMDAwMjE4NTgzIDAwMDAwIG4NCjAwMDAyMTg2NjcgMDAwMDAgbg0KMDAwMDIxODc0OSAwMDAwMCBuDQowMDAwMjE4ODMyIDAwMDAwIG4NCjAwMDAyMTg5MTEgMDAwMDAgbg0KMDAwMDIxODk0MyAwMDAwMCBuDQowMDAwMjE5MDIyIDAwMDAwIG4NCjAwMDAyMTkxMDMgMDAwMDAgbg0KMDAwMDIxOTEzNSAwMDAwMCBuDQowMDAwMjE5MjE2IDAwMDAwIG4NCjAwMDAyMTkyOTcgMDAwMDAgbg0KMDAwMDIxOTMyOSAwMDAwMCBuDQowMDAwMjE5MzYxIDAwMDAwIG4NCjAwMDAyMTk0NDIgMDAwMDAgbg0KMDAwMDIxOTUyNSAwMDAwMCBuDQowMDAwMjE5NjA4IDAwMDAwIG4NCjAwMDAyMTk2OTEgMDAwMDAgbg0KMDAwMDIxOTc2OCAwMDAwMCBuDQowMDAwMjE5ODAwIDAwMDAwIG4NCjAwMDAyMTk4NzcgMDAwMDAgbg0KMDAwMDIxOTk1OCAwMDAwMCBuDQowMDAwMjE5OTkwIDAwMDAwIG4NCjAwMDAyMjAwNzEgMDAwMDAgbg0KMDAwMDIyMDE1NyAwMDAwMCBuDQowMDAwMjIwMjQzIDAwMDAwIG4NCjAwMDAyMjAzMjkgMDAwMDAgbg0KMDAwMDIyMDQxNSAwMDAwMCBuDQowMDAwMjIwNDQ3IDAwMDAwIG4NCjAwMDAyMjA1MzMgMDAwMDAgbg0KMDAwMDIyMDYyMCAwMDAwMCBuDQowMDAwMjIwNjUyIDAwMDAwIG4NCjAwMDAyMjA3MzkgMDAwMDAgbg0KMDAwMDIyMDgyMCAwMDAwMCBuDQowMDAwMjIwODUyIDAwMDAwIG4NCjAwMDAyMjA5MzMgMDAwMDAgbg0KMDAwMDIyMTAxNSAwMDAwMCBuDQowMDAwMjIxMDQ3IDAwMDAwIG4NCjAwMDAyMjExMjkgMDAwMDAgbg0KMDAwMDIyMTIxNSAwMDAwMCBuDQowMDAwMjIxMzAxIDAwMDAwIG4NCjAwMDAyMjEzODcgMDAwMDAgbg0KMDAwMDIyMTQyMCAwMDAwMCBuDQowMDAwMjIxNTA2IDAwMDAwIG4NCjAwMDAyMjE1ODcgMDAwMDAgbg0KMDAwMDIyMTYyMCAwMDAwMCBuDQowMDAwMjIxNzAxIDAwMDAwIG4NCjAwMDAyMjE3NzkgMDAwMDAgbg0KMDAwMDIyMTg1NyAwMDAwMCBuDQowMDAwMjIxOTM1IDAwMDAwIG4NCjAwMDAyMjIwMTMgMDAwMDAgbg0KMDAwMDIyMjA5MSAwMDAwMCBuDQowMDAwMjIyMTY5IDAwMDAwIG4NCjAwMDAyMjIyNTMgMDAwMDAgbg0KMDAwMDIyMjMzNyAwMDAwMCBuDQowMDAwMjIyNDIxIDAwMDAwIG4NCjAwMDAyMjI0NTQgMDAwMDAgbg0KMDAwMDIyMjUzOCAwMDAwMCBuDQowMDAwMjIyNjE4IDAwMDAwIG4NCjAwMDAyMjI2NTEgMDAwMDAgbg0KMDAwMDIyMjczMSAwMDAwMCBuDQowMDAwMjIyODEwIDAwMDAwIG4NCjAwMDAyMjI4ODkgMDAwMDAgbg0KMDAwMDIyMjk2OCAwMDAwMCBuDQowMDAwMjIzMDQ3IDAwMDAwIG4NCjAwMDAyMjMxMjYgMDAwMDAgbg0KMDAwMDIyMzIwNSAwMDAwMCBuDQowMDAwMjIzMjg0IDAwMDAwIG4NCjAwMDAyMjMzMTcgMDAwMDAgbg0KMDAwMDIyMzM5NiAwMDAwMCBuDQowMDAwMjIzNDc3IDAwMDAwIG4NCjAwMDAyMjM1MTAgMDAwMDAgbg0KMDAwMDIyMzU5MSAwMDAwMCBuDQowMDAwMjIzNjc0IDAwMDAwIG4NCjAwMDAyMjM3MDcgMDAwMDAgbg0KMDAwMDIyMzc0MCAwMDAwMCBuDQowMDAwMjIzODIzIDAwMDAwIG4NCjAwMDAyMjM5MDggMDAwMDAgbg0KMDAwMDIyMzk5MyAwMDAwMCBuDQowMDAwMjI0MDc4IDAwMDAwIG4NCjAwMDAyMjQxNTggMDAwMDAgbg0KMDAwMDIyNDE5MSAwMDAwMCBuDQowMDAwMjI0MjcxIDAwMDAwIG4NCjAwMDAyMjQzNTQgMDAwMDAgbg0KMDAwMDIyNDM4NyAwMDAwMCBuDQowMDAwMjI0NDcwIDAwMDAwIG4NCjAwMDAyMjQ1NTggMDAwMDAgbg0KMDAwMDIyNDY0NiAwMDAwMCBuDQowMDAwMjI0NzM0IDAwMDAwIG4NCjAwMDAyMjQ4MjMgMDAwMDAgbg0KMDAwMDIyNDg1NiAwMDAwMCBuDQowMDAwMjI0OTQ1IDAwMDAwIG4NCjAwMDAyMjUwMzUgMDAwMDAgbg0KMDAwMDIyNTA2OCAwMDAwMCBuDQowMDAwMjI1MTU4IDAwMDAwIG4NCjAwMDAyMjUyNDIgMDAwMDAgbg0KMDAwMDIyNTI3NSAwMDAwMCBuDQowMDAwMjI1MzU5IDAwMDAwIG4NCjAwMDAyMjU0NDMgMDAwMDAgbg0KMDAwMDIyNTQ3NiAwMDAwMCBuDQowMDAwMjI1NTYwIDAwMDAwIG4NCjAwMDAyMjU2NDggMDAwMDAgbg0KMDAwMDIyNTczNiAwMDAwMCBuDQowMDAwMjI1ODI0IDAwMDAwIG4NCjAwMDAyMjU4NTcgMDAwMDAgbg0KMDAwMDIyNTk0NSAwMDAwMCBuDQowMDAwMjI2MDI1IDAwMDAwIG4NCjAwMDAyMjYwNTggMDAwMDAgbg0KMDAwMDIyNjEzOCAwMDAwMCBuDQowMDAwMjI2MjE2IDAwMDAwIG4NCjAwMDAyMjYyOTQgMDAwMDAgbg0KMDAwMDIyNjM3MiAwMDAwMCBuDQowMDAwMjI2NDUwIDAwMDAwIG4NCjAwMDAyMjY1MjggMDAwMDAgbg0KMDAwMDIyNjYwNiAwMDAwMCBuDQowMDAwMjI2Njg4IDAwMDAwIG4NCjAwMDAyMjY3NzAgMDAwMDAgbg0KMDAwMDIyNjg1MiAwMDAwMCBuDQowMDAwMjI2ODg1IDAwMDAwIG4NCjAwMDAyMjY5NjcgMDAwMDAgbg0KMDAwMDIyNzA1MSAwMDAwMCBuDQowMDAwMjI3MDg0IDAwMDAwIG4NCjAwMDAyMjcxNjggMDAwMDAgbg0KMDAwMDIyNzI0OCAwMDAwMCBuDQowMDAwMjI3MzI4IDAwMDAwIG4NCjAwMDAyMjc0MDggMDAwMDAgbg0KMDAwMDIyNzQ4OCAwMDAwMCBuDQowMDAwMjI3NTY4IDAwMDAwIG4NCjAwMDAyMjc2NDggMDAwMDAgbg0KMDAwMDIyNzczNiAwMDAwMCBuDQowMDAwMjI3ODI0IDAwMDAwIG4NCjAwMDAyMjc5MTIgMDAwMDAgbg0KMDAwMDIyNzk0NSAwMDAwMCBuDQowMDAwMjI4MDMzIDAwMDAwIG4NCjAwMDAyMjgxMTYgMDAwMDAgbg0KMDAwMDIyODE0OSAwMDAwMCBuDQowMDAwMjI4MjMyIDAwMDAwIG4NCjAwMDAyMjgzMTEgMDAwMDAgbg0KMDAwMDIyODM5MCAwMDAwMCBuDQowMDAwMjI4NDY5IDAwMDAwIG4NCjAwMDAyMjg1NDggMDAwMDAgbg0KMDAwMDIyODYyNyAwMDAwMCBuDQowMDAwMjI4NzA2IDAwMDAwIG4NCjAwMDAyMjg3OTMgMDAwMDAgbg0KMDAwMDIyODg4MCAwMDAwMCBuDQowMDAwMjI4OTY3IDAwMDAwIG4NCjAwMDAyMjkwMDAgMDAwMDAgbg0KMDAwMDIyOTA4NyAwMDAwMCBuDQowMDAwMjI5MTY4IDAwMDAwIG4NCjAwMDAyMjkyMDEgMDAwMDAgbg0KMDAwMDIyOTI4MiAwMDAwMCBuDQowMDAwMjI5MzYwIDAwMDAwIG4NCjAwMDAyMjk0MzggMDAwMDAgbg0KMDAwMDIyOTUxNiAwMDAwMCBuDQowMDAwMjI5NTk0IDAwMDAwIG4NCjAwMDAyMjk2NzIgMDAwMDAgbg0KMDAwMDIyOTc1MCAwMDAwMCBuDQowMDAwMjI5ODM0IDAwMDAwIG4NCjAwMDAyMjk5MTggMDAwMDAgbg0KMDAwMDIzMDAwMiAwMDAwMCBuDQowMDAwMjMwMDM1IDAwMDAwIG4NCjAwMDAyMzAxMTkgMDAwMDAgbg0KMDAwMDIzMDIwMiAwMDAwMCBuDQowMDAwMjMwMjM1IDAwMDAwIG4NCjAwMDAyMzAzMTggMDAwMDAgbg0KMDAwMDIzMDM5NyAwMDAwMCBuDQowMDAwMjMwNDc2IDAwMDAwIG4NCjAwMDAyMzA1NTUgMDAwMDAgbg0KMDAwMDIzMDYzNCAwMDAwMCBuDQowMDAwMjMwNzEzIDAwMDAwIG4NCjAwMDAyMzA3OTIgMDAwMDAgbg0KMDAwMDIzMDg3NCAwMDAwMCBuDQowMDAwMjMwOTA3IDAwMDAwIG4NCjAwMDAyMzA5ODkgMDAwMDAgbg0KMDAwMDIzMTA3MSAwMDAwMCBuDQowMDAwMjMxMTA0IDAwMDAwIG4NCjAwMDAyMzExODYgMDAwMDAgbg0KMDAwMDIzMTI2NCAwMDAwMCBuDQowMDAwMjMxMzQyIDAwMDAwIG4NCjAwMDAyMzE0MjAgMDAwMDAgbg0KMDAwMDIzMTUwMiAwMDAwMCBuDQowMDAwMjMxNTg1IDAwMDAwIG4NCjAwMDAyMzE2NjkgMDAwMDAgbg0KMDAwMDIzMTc1MiAwMDAwMCBuDQowMDAwMjMxODMyIDAwMDAwIG4NCjAwMDAyMzE5MTUgMDAwMDAgbg0KMDAwMDIzMTk5OSAwMDAwMCBuDQowMDAwMjMyMDgyIDAwMDAwIG4NCjAwMDAyMzIxNjUgMDAwMDAgbg0KMDAwMDIzMjI0OCAwMDAwMCBuDQowMDAwMjMyMzMyIDAwMDAwIG4NCjAwMDAyMzI0MTUgMDAwMDAgbg0KMDAwMDIzMjQ5OSAwMDAwMCBuDQowMDAwMjMyNTgyIDAwMDAwIG4NCjAwMDAyMzI2NjYgMDAwMDAgbg0KMDAwMDIzMjc1MSAwMDAwMCBuDQowMDAwMjMyODM1IDAwMDAwIG4NCjAwMDAyMzI5MTkgMDAwMDAgbg0KMDAwMDIzMzAwMyAwMDAwMCBuDQowMDAwMjMzMDg4IDAwMDAwIG4NCjAwMDAyMzMxNzIgMDAwMDAgbg0KMDAwMDIzMzI1NSAwMDAwMCBuDQowMDAwMjMzMzQwIDAwMDAwIG4NCjAwMDAyMzM0MjMgMDAwMDAgbg0KMDAwMDIzMzUwNyAwMDAwMCBuDQowMDAwMjMzNTkyIDAwMDAwIG4NCjAwMDAyMzM2NzYgMDAwMDAgbg0KMDAwMDIzMzc2MSAwMDAwMCBuDQowMDAwMjMzODQ2IDAwMDAwIG4NCjAwMDAyMzM5MzEgMDAwMDAgbg0KMDAwMDIzNDAxNiAwMDAwMCBuDQowMDAwMjM0MDk5IDAwMDAwIG4NCjAwMDAyMzQxODQgMDAwMDAgbg0KMDAwMDIzNDI2OCAwMDAwMCBuDQowMDAwMjM0MzUzIDAwMDAwIG4NCjAwMDAyMzQ0MzcgMDAwMDAgbg0KMDAwMDIzNDUxNiAwMDAwMCBuDQowMDAwMjM0NTk1IDAwMDAwIG4NCjAwMDAyMzQ2NzkgMDAwMDAgbg0KMDAwMDIzNDcxMSAwMDAwMCBuDQowMDAwMjM0Nzk1IDAwMDAwIG4NCjAwMDAyMzQ4NzQgMDAwMDAgbg0KMDAwMDIzNDk1MyAwMDAwMCBuDQowMDAwMjM1MDMyIDAwMDAwIG4NCjAwMDAyMzUxMTEgMDAwMDAgbg0KMDAwMDIzNTE5MCAwMDAwMCBuDQowMDAwMjM1MjY5IDAwMDAwIG4NCjAwMDAyMzUzNTIgMDAwMDAgbg0KMDAwMDIzNTM4NCAwMDAwMCBuDQowMDAwMjM1NDY3IDAwMDAwIG4NCjAwMDAyMzU1NDUgMDAwMDAgbg0KMDAwMDIzNTU3NyAwMDAwMCBuDQowMDAwMjM1NjU1IDAwMDAwIG4NCjAwMDAyMzU3MzUgMDAwMDAgbg0KMDAwMDIzNTc2NyAwMDAwMCBuDQowMDAwMjM1ODQ3IDAwMDAwIG4NCjAwMDAyMzU5MjggMDAwMDAgbg0KMDAwMDIzNTk2MCAwMDAwMCBuDQowMDAwMjM2MDQxIDAwMDAwIG4NCjAwMDAyMzYxMjIgMDAwMDAgbg0KMDAwMDIzNjE1NCAwMDAwMCBuDQowMDAwMjM2MjM1IDAwMDAwIG4NCjAwMDAyMzYzMTQgMDAwMDAgbg0KMDAwMDIzNjM0NiAwMDAwMCBuDQowMDAwMjM2NDI1IDAwMDAwIG4NCjAwMDAyMzY1MDggMDAwMDAgbg0KMDAwMDIzNjU0MCAwMDAwMCBuDQowMDAwMjM2NjIzIDAwMDAwIG4NCjAwMDAyMzY3MDQgMDAwMDAgbg0KMDAwMDIzNjczNiAwMDAwMCBuDQowMDAwMjM2ODE3IDAwMDAwIG4NCjAwMDAyMzY5MDUgMDAwMDAgbg0KMDAwMDIzNjk5MyAwMDAwMCBuDQowMDAwMjM3MDgxIDAwMDAwIG4NCjAwMDAyMzcxMTMgMDAwMDAgbg0KMDAwMDIzNzIwMSAwMDAwMCBuDQowMDAwMjM3Mjg1IDAwMDAwIG4NCjAwMDAyMzczMTggMDAwMDAgbg0KMDAwMDIzNzQwMiAwMDAwMCBuDQowMDAwMjM3NDgyIDAwMDAwIG4NCjAwMDAyMzc1NjIgMDAwMDAgbg0KMDAwMDIzNzY0MiAwMDAwMCBuDQowMDAwMjM3NzIyIDAwMDAwIG4NCjAwMDAyMzc4MDIgMDAwMDAgbg0KMDAwMDIzNzg4MiAwMDAwMCBuDQowMDAwMjM3OTY2IDAwMDAwIG4NCjAwMDAyMzc5OTkgMDAwMDAgbg0KMDAwMDIzODA4MyAwMDAwMCBuDQowMDAwMjM4MTY0IDAwMDAwIG4NCjAwMDAyMzgxOTcgMDAwMDAgbg0KMDAwMDIzODI3OCAwMDAwMCBuDQowMDAwMjM4MzYyIDAwMDAwIG4NCjAwMDAyMzg0NDYgMDAwMDAgbg0KMDAwMDIzODUzMCAwMDAwMCBuDQowMDAwMjM4NTYzIDAwMDAwIG4NCjAwMDAyMzg2NDcgMDAwMDAgbg0KMDAwMDIzODczMSAwMDAwMCBuDQowMDAwMjM4NzY0IDAwMDAwIG4NCjAwMDAyMzg4NDggMDAwMDAgbg0KMDAwMDIzODkyOCAwMDAwMCBuDQowMDAwMjM5MDA4IDAwMDAwIG4NCjAwMDAyMzkwODggMDAwMDAgbg0KMDAwMDIzOTE2OCAwMDAwMCBuDQowMDAwMjM5MjQ4IDAwMDAwIG4NCjAwMDAyMzkzMjggMDAwMDAgbg0KMDAwMDIzOTQxMCAwMDAwMCBuDQowMDAwMjM5NDQzIDAwMDAwIG4NCjAwMDAyMzk1MjUgMDAwMDAgbg0KMDAwMDIzOTYwOCAwMDAwMCBuDQowMDAwMjM5NjQxIDAwMDAwIG4NCjAwMDAyMzk3MjQgMDAwMDAgbg0KMDAwMDIzOTgxMSAwMDAwMCBuDQowMDAwMjM5ODk4IDAwMDAwIG4NCjAwMDAyMzk5ODUgMDAwMDAgbg0KMDAwMDI0MDAxOCAwMDAwMCBuDQowMDAwMjQwMTA1IDAwMDAwIG4NCjAwMDAyNDAxODcgMDAwMDAgbg0KMDAwMDI0MDIyMCAwMDAwMCBuDQowMDAwMjQwMzAyIDAwMDAwIG4NCjAwMDAyNDAzODMgMDAwMDAgbg0KMDAwMDI0MDQxNiAwMDAwMCBuDQowMDAwMjQwNDk3IDAwMDAwIG4NCjAwMDAyNDA1NzkgMDAwMDAgbg0KMDAwMDI0MDYxMiAwMDAwMCBuDQowMDAwMjQwNjk0IDAwMDAwIG4NCjAwMDAyNDA3NzcgMDAwMDAgbg0KMDAwMDI0MDgxMCAwMDAwMCBuDQowMDAwMjQwODkzIDAwMDAwIG4NCjAwMDAyNDA5NzUgMDAwMDAgbg0KMDAwMDI0MTAwOCAwMDAwMCBuDQowMDAwMjQxMDkwIDAwMDAwIG4NCjAwMDAyNDExNzMgMDAwMDAgbg0KMDAwMDI0MTIwNiAwMDAwMCBuDQowMDAwMjQxMjg5IDAwMDAwIG4NCjAwMDAyNDEzNjkgMDAwMDAgbg0KMDAwMDI0MTQwMiAwMDAwMCBuDQowMDAwMjQxNDgyIDAwMDAwIG4NCjAwMDAyNDE1NjQgMDAwMDAgbg0KMDAwMDI0MTU5NyAwMDAwMCBuDQowMDAwMjQxNjc5IDAwMDAwIG4NCjAwMDAyNDE3NjEgMDAwMDAgbg0KMDAwMDI0MTc5NCAwMDAwMCBuDQowMDAwMjQxODc2IDAwMDAwIG4NCjAwMDAyNDE5NTkgMDAwMDAgbg0KMDAwMDI0MTk5MiAwMDAwMCBuDQowMDAwMjQyMDc1IDAwMDAwIG4NCjAwMDAyNDIxNjIgMDAwMDAgbg0KMDAwMDI0MjI0OSAwMDAwMCBuDQowMDAwMjQyMzM2IDAwMDAwIG4NCjAwMDAyNDIzNjkgMDAwMDAgbg0KMDAwMDI0MjQ1NiAwMDAwMCBuDQowMDAwMjQyNTM2IDAwMDAwIG4NCjAwMDAyNDI2MTYgMDAwMDAgbg0KMDAwMDI0MjY5NiAwMDAwMCBuDQowMDAwMjQyNzc3IDAwMDAwIG4NCjAwMDAyNDI4NTggMDAwMDAgbg0KMDAwMDI0MjkzOSAwMDAwMCBuDQowMDAwMjQzMDIyIDAwMDAwIG4NCjAwMDAyNDMxMDUgMDAwMDAgbg0KMDAwMDI0MzE4NiAwMDAwMCBuDQowMDAwMjQzMjY3IDAwMDAwIG4NCjAwMDAyNDMzNDggMDAwMDAgbg0KMDAwMDI0MzQzMSAwMDAwMCBuDQowMDAwMjQzNTEyIDAwMDAwIG4NCjAwMDAyNDM1OTMgMDAwMDAgbg0KMDAwMDI0MzY3NCAwMDAwMCBuDQowMDAwMjQzNzU3IDAwMDAwIG4NCjAwMDAyNDM4MzggMDAwMDAgbg0KMDAwMDI0MzkxOSAwMDAwMCBuDQowMDAwMjQ0MDAwIDAwMDAwIG4NCjAwMDAyNDQwODEgMDAwMDAgbg0KMDAwMDI0NDE2NiAwMDAwMCBuDQowMDAwMjQ0MjQ5IDAwMDAwIG4NCjAwMDAyNDQzMzAgMDAwMDAgbg0KMDAwMDI0NDM2MiAwMDAwMCBuDQowMDAwMjQ0NDQzIDAwMDAwIG4NCjAwMDAyNDQ1MjUgMDAwMDAgbg0KMDAwMDI0NDU1NyAwMDAwMCBuDQowMDAwMjQ0NjM5IDAwMDAwIG4NCjAwMDAyNDQ3MjUgMDAwMDAgbg0KMDAwMDI0NDgxMSAwMDAwMCBuDQowMDAwMjQ0ODk3IDAwMDAwIG4NCjAwMDAyNDQ5MjkgMDAwMDAgbg0KMDAwMDI0NTAxNSAwMDAwMCBuDQowMDAwMjQ1MDk3IDAwMDAwIG4NCjAwMDAyNDUxMjkgMDAwMDAgbg0KMDAwMDI0NTIxMSAwMDAwMCBuDQowMDAwMjQ1Mjg5IDAwMDAwIG4NCjAwMDAyNDUzNjcgMDAwMDAgbg0KMDAwMDI0NTQ0NSAwMDAwMCBuDQowMDAwMjQ1NTIzIDAwMDAwIG4NCjAwMDAyNDU2MDEgMDAwMDAgbg0KMDAwMDI0NTY3OSAwMDAwMCBuDQowMDAwMjQ1NzU3IDAwMDAwIG4NCjAwMDAyNDU3ODkgMDAwMDAgbg0KMDAwMDI0NTg2NyAwMDAwMCBuDQowMDAwMjQ1OTQ3IDAwMDAwIG4NCjAwMDAyNDU5NzkgMDAwMDAgbg0KMDAwMDI0NjA1OSAwMDAwMCBuDQowMDAwMjQ2MTQyIDAwMDAwIG4NCjAwMDAyNDYxNzQgMDAwMDAgbg0KMDAwMDI0NjI1NyAwMDAwMCBuDQowMDAwMjQ2MzM3IDAwMDAwIG4NCjAwMDAyNDYzNjkgMDAwMDAgbg0KMDAwMDI0NjQ0OSAwMDAwMCBuDQowMDAwMjQ2NTM3IDAwMDAwIG4NCjAwMDAyNDY2MjUgMDAwMDAgbg0KMDAwMDI0NjcxMyAwMDAwMCBuDQowMDAwMjQ2NzQ1IDAwMDAwIG4NCjAwMDAyNDY4MzMgMDAwMDAgbg0KMDAwMDI0NjkxMyAwMDAwMCBuDQowMDAwMjQ2OTQ1IDAwMDAwIG4NCjAwMDAyNDcwMjUgMDAwMDAgbg0KMDAwMDI0NzEwMSAwMDAwMCBuDQowMDAwMjQ3MTc3IDAwMDAwIG4NCjAwMDAyNDcyNTMgMDAwMDAgbg0KMDAwMDI0NzMyOSAwMDAwMCBuDQowMDAwMjQ3NDA1IDAwMDAwIG4NCjAwMDAyNDc0ODEgMDAwMDAgbg0KMDAwMDI0NzU2MiAwMDAwMCBuDQowMDAwMjQ3NTk1IDAwMDAwIG4NCjAwMDAyNDc2NzYgMDAwMDAgbg0KMDAwMDI0Nzc1OCAwMDAwMCBuDQowMDAwMjQ3NzkxIDAwMDAwIG4NCjAwMDAyNDc4NzMgMDAwMDAgbg0KMDAwMDI0Nzk1OSAwMDAwMCBuDQowMDAwMjQ4MDQ1IDAwMDAwIG4NCjAwMDAyNDgxMzEgMDAwMDAgbg0KMDAwMDI0ODE2NCAwMDAwMCBuDQowMDAwMjQ4MjUwIDAwMDAwIG4NCjAwMDAyNDgzMzIgMDAwMDAgbg0KMDAwMDI0ODM2NSAwMDAwMCBuDQowMDAwMjQ4NDQ3IDAwMDAwIG4NCjAwMDAyNDg1MjUgMDAwMDAgbg0KMDAwMDI0ODYwMyAwMDAwMCBuDQowMDAwMjQ4NjgxIDAwMDAwIG4NCjAwMDAyNDg3NTkgMDAwMDAgbg0KMDAwMDI0ODgzNyAwMDAwMCBuDQowMDAwMjQ4OTE1IDAwMDAwIG4NCjAwMDAyNDg5OTMgMDAwMDAgbg0KMDAwMDI0OTAyNiAwMDAwMCBuDQowMDAwMjQ5MTA0IDAwMDAwIG4NCjAwMDAyNDkxODQgMDAwMDAgbg0KMDAwMDI0OTIxNyAwMDAwMCBuDQowMDAwMjQ5Mjk3IDAwMDAwIG4NCjAwMDAyNDkzNzkgMDAwMDAgbg0KMDAwMDI0OTQxMiAwMDAwMCBuDQowMDAwMjQ5NDk0IDAwMDAwIG4NCjAwMDAyNDk1NzYgMDAwMDAgbg0KMDAwMDI0OTYwOSAwMDAwMCBuDQowMDAwMjQ5NjkxIDAwMDAwIG4NCjAwMDAyNDk3NzcgMDAwMDAgbg0KMDAwMDI0OTg2MyAwMDAwMCBuDQowMDAwMjQ5OTQ5IDAwMDAwIG4NCjAwMDAyNDk5ODIgMDAwMDAgbg0KMDAwMDI1MDA2OCAwMDAwMCBuDQowMDAwMjUwMTMxIDAwMDAwIG4NCjAwMDAyNTAyMjUgMDAwMDAgbg0KMDAwMDI1MDI4OCAwMDAwMCBuDQowMDAwMjUwMzQyIDAwMDAwIG4NCjAwMDAyNTA0MjMgMDAwMDAgbg0KMDAwMDI1MDQ3NyAwMDAwMCBuDQowMDAwMjUwNTU5IDAwMDAwIG4NCjAwMDAyNTA2MTMgMDAwMDAgbg0KMDAwMDI1MDY5NSAwMDAwMCBuDQowMDAwMjUwNzQ5IDAwMDAwIG4NCjAwMDAyNTA4MzEgMDAwMDAgbg0KMDAwMDI1MDkzOSAwMDAwMCBuDQowMDAwMjUxMDU2IDAwMDAwIG4NCjAwMDAyNTExNDkgMDAwMDAgbg0KMDAwMDI1MTI0MiAwMDAwMCBuDQowMDAwMjU3ODQ1IDAwMDAwIG4NCjAwMDAyNjU3NzEgMDAwMDAgbg0KMDAwMDI3MjMyNSAwMDAwMCBuDQowMDAwMjgwMjUxIDAwMDAwIG4NCjAwMDAyODAzMDggMDAwMDAgbg0KMDAwMDI4MDM4NSAwMDAwMCBuDQowMDAwMjgwNjQzIDAwMDAwIG4NCjAwMDAyODA3MjAgMDAwMDAgbg0KMDAwMDI4MDk3OSAwMDAwMCBuDQowMDAwNDEwMDEyIDAwMDAwIG4NCnRyYWlsZXIKPDwKL1Jvb3QgMSAwIFIKL0luZm8gOCAwIFIKL0lEIFs8ODI2MkJGNzgxNkE2NzkwMUQ0RDM4Rjc0NjZBNkU4RTk+IDw4MjYyQkY3ODE2QTY3OTAxRDREMzhGNzQ2NkE2RThFOT5dCi9TaXplIDI0OTcKPj4Kc3RhcnR4cmVmCjUzNzc4OAolJUVPRgo=",gT={uuid:DT,forhaandsvisningOpprettet:nT,sistJournalført:"2024-03-13T14:11:48.478662",pdf:rT},IT={sistJournalført:"2024-03-14T14:11:48.478662"},Kg=()=>hg()&&!NM(),Og=()=>Bg()&&!NM(),$M=()=>nt()&&!NM(),aT=[ge.rest.get("/auth/info",Ze(Pv)),ge.rest.get("/veilarboppfolging/api/v3/oppfolging/me",me(Kg,$v)),ge.rest.post("/veilarboppfolging/api/v3/oppfolging/hent-status",me(Kg,tT)),ge.rest.post("/veilarboppfolging/api/v3/oppfolging/harFlereAktorIderMedOppfolging",Ze(!0)),ge.rest.post("/veilarboppfolging/api/v3/hent-maal",me(Og,Rv)),ge.rest.post("/veilarboppfolging/api/v3/maal/hent-alle",me(Og,Zv)),ge.rest.post("/veilarboppfolging/api/v3/maal",me(Bg,Fv)),ge.rest.post("/veilarboppfolging/api/:fnr/lestaktivitetsplan",(e,t,M)=>t(M.status(204))),ge.rest.post("/veilarboppfolging/api/v3/veileder/lest-aktivitetsplan",(e,t,M)=>t(M.status(204))),ge.rest.post("/veilarboppfolging/api/v3/oppfolging/settDigital",me(hg,MT)),ge.rest.get("/veilarbdialog/api/eskaleringsvarsel/gjeldende",Ze(zg)),ge.rest.get("/veilarbdialog/api/dialog/sistOppdatert",Ze({sistOppdatert:1678793406845})),ge.rest.post("/veilarbdialog/api/dialog",Ze(Jv)),ge.rest.post("/veilarbdialog/graphql",fn(MC,()=>({data:{dialoger:eD,stansVarsel:zg}}))),ge.rest.post("/veilarbaktivitet/api/logger/event",(e,t,M)=>t(M.status(200))),ge.rest.get("/veilarbaktivitet/api/aktivitet",me($M,()=>$o)),ge.rest.post("/veilarbaktivitet/graphql",fn($M,async e=>{const t=await e.json();if(t.query.includes("historikk")){const M=t.variables.aktivitetId,A=$o.aktiviteter.find(i=>i.id===M);return await new Promise(i=>{setTimeout(i,2e3)}),CT(A)}else return wT()})),ge.rest.post("/veilarbaktivitet/api/arena/tiltak",me(()=>Yi()&&!NM(),()=>Nn)),ge.rest.get("/veilarbaktivitet/api/aktivitet/kanaler",me($M,()=>["INTERNETT","OPPMOTE","TELEFON"])),ge.rest.put("/veilarbaktivitet/api/arena/forhaandsorientering",me(()=>Yi()&&!NM(),Yv)),ge.rest.put("/veilarbaktivitet/api/arena/forhaandsorientering/lest",me(()=>Yi()&&!NM(),xv)),ge.rest.get("/veilarbaktivitet/api/aktivitet/:aktivitetId",me($M,bv)),ge.rest.put("/veilarbaktivitet/api/aktivitet/:aktivitetId",me(nt,Qv)),ge.rest.post("/veilarbaktivitet/api/aktivitet/:oppfolgingsperiode/ny",me(nt,Uv)),ge.rest.get("/veilarbaktivitet/api/aktivitet/:aktivitetId/versjoner",me($M,fv)),ge.rest.put("/veilarbaktivitet/api/aktivitet/:aktivitetId/status",me(nt,Ev)),ge.rest.put("/veilarbaktivitet/api/aktivitet/:aktivitetId/etikett",me(nt,zv)),ge.rest.put("/veilarbaktivitet/api/aktivitet/:aktivitetId/referat/publiser",me(nt,kv)),ge.rest.put("/veilarbaktivitet/api/aktivitet/:aktivitetId/referat",me(nt,Bv)),ge.rest.put("/veilarbaktivitet/api/avtaltMedNav",me(nt,Lv)),ge.rest.put("/veilarbaktivitet/api/avtaltMedNav/lest",me(nt,Sv)),ge.rest.put("/veilarbaktivitet/api/stillingFraNav/kanDeleCV",me(nt,Kv)),ge.rest.put("/veilarbaktivitet/api/stillingFraNav/soknadStatus",me(nt,Ov)),ge.rest.get("/veilarbaktivitet/api/feature",Ze(Gv)),ge.rest.get("/veilarbaktivitet/api/arkivering/forhaandsvisning",me(AC,()=>gT,500)),ge.rest.post("/veilarbaktivitet/api/arkivering/journalfor",me(iC,()=>IT,2e3)),ge.rest.post("/veilarbaktivitet/api/innsynsrett",Ze({foresatteHarInnsynsrett:tC()})),ge.rest.post("/veilarblest/api/aktivitetsplan/les",Ze(Lg)),ge.rest.put("/veilarblest/api/informasjon/les",Ze(Lg)),ge.rest.post("/veilarbperson/api/v3/hent-person",Ze(AT)),ge.rest.post("/veilarbperson/api/v3/person/hent-postadresse",Ze(iT)),ge.rest.get("/veilarbveileder/api/veileder/me",Ze(oT)),ge.rest.get("/veilarboppgave/api/oppgavehistorikk",Ze([])),ge.rest.post("/veilarbmalverk/api/mal",Ze(Hv))],wT=({aktiviteter:e}={aktiviteter:$o.aktiviteter})=>({data:{perioder:Array.from(new Set(e.map(M=>M.oppfolgingsperiodeId))).map(M=>({id:M,aktiviteter:e.filter(A=>A.oppfolgingsperiodeId===M)}))}}),CT=e=>({data:{aktivitet:{...e,historikk:{endringer:[{endretAvType:"BRUKER",endretAv:"2121212121212",tidspunkt:new Date,beskrivelseForVeileder:"Bruker endret detaljer på aktiviteten",beskrivelseForBruker:"Du endret detaljer på aktiviteten"},{endretAvType:"NAV",endretAv:"R121212",tidspunkt:rC(new Date,30),beskrivelseForVeileder:'R121212 merket aktiviteten "Avtalt med Nav"',beskrivelseForBruker:'Nav merket aktiviteten "Avtalt med Nav"'},{endretAvType:"BRUKER",endretAv:"2121212121212",tidspunkt:dt(new Date,2),beskrivelseForVeileder:"Bruker flyttet aktiviteten fra Planlegger til Forslag",beskrivelseForBruker:"Du flyttet aktiviteten fra Planlegger til Forslag"}]}}}}),uT=ge.setupWorker(...aT),jT=()=>uT.start({serviceWorker:{url:"/aktivitetsplan/mockServiceWorker.js"},onUnhandledRequest:(e,t)=>{const M=["amplitude.nav.no","nav.psplugin.com"],A=[".ts",".js",".tsx",".jsx","css","svg","png",".less"];M.some(o=>e.url.host.includes(o))||A.some(o=>e.url.pathname.endsWith(o))||t.warning()}});export{jT as default};
+//# sourceMappingURL=index-CIiTfqqf.js.map
diff --git a/assets/index-CIiTfqqf.js.map b/assets/index-CIiTfqqf.js.map
new file mode 100644
index 000000000..0c88da4c0
--- /dev/null
+++ b/assets/index-CIiTfqqf.js.map
@@ -0,0 +1 @@
+{"version":3,"file":"index-CIiTfqqf.js","sources":["../../node_modules/date-fns/subMinutes.mjs","../../node_modules/headers-polyfill/lib/index.js","../../node_modules/cookie/index.js","../../node_modules/is-node-process/lib/index.js","../../node_modules/node-fetch/browser.js","../../node_modules/outvariant/lib/index.js","../../node_modules/@open-draft/until/lib/until.js","../../node_modules/@open-draft/until/lib/index.js","../../node_modules/@mswjs/interceptors/lib/glossary.js","../../node_modules/ms/index.js","../../node_modules/debug/src/common.js","../../node_modules/debug/src/browser.js","../../node_modules/events/events.js","../../node_modules/@mswjs/interceptors/node_modules/strict-event-emitter/lib/StrictEventEmitter.js","../../node_modules/@mswjs/interceptors/node_modules/strict-event-emitter/lib/index.js","../../node_modules/@mswjs/interceptors/lib/utils/nextTick.js","../../node_modules/@mswjs/interceptors/lib/utils/AsyncEventEmitter.js","../../node_modules/@mswjs/interceptors/lib/Interceptor.js","../../node_modules/@mswjs/interceptors/lib/BatchInterceptor.js","../../node_modules/has-symbols/shams.js","../../node_modules/has-tostringtag/shams.js","../../node_modules/es-errors/index.js","../../node_modules/es-errors/eval.js","../../node_modules/es-errors/range.js","../../node_modules/es-errors/ref.js","../../node_modules/es-errors/syntax.js","../../node_modules/es-errors/type.js","../../node_modules/es-errors/uri.js","../../node_modules/has-symbols/index.js","../../node_modules/has-proto/index.js","../../node_modules/function-bind/implementation.js","../../node_modules/function-bind/index.js","../../node_modules/hasown/index.js","../../node_modules/get-intrinsic/index.js","../../node_modules/es-define-property/index.js","../../node_modules/gopd/index.js","../../node_modules/define-data-property/index.js","../../node_modules/has-property-descriptors/index.js","../../node_modules/set-function-length/index.js","../../node_modules/call-bind/index.js","../../node_modules/call-bind/callBound.js","../../node_modules/is-arguments/index.js","../../node_modules/is-generator-function/index.js","../../node_modules/is-callable/index.js","../../node_modules/for-each/index.js","../../node_modules/possible-typed-array-names/index.js","../../node_modules/available-typed-arrays/index.js","../../node_modules/which-typed-array/index.js","../../node_modules/is-typed-array/index.js","../../node_modules/util/support/types.js","../../node_modules/util/support/isBufferBrowser.js","../../node_modules/inherits/inherits_browser.js","../../node_modules/util/util.js","../../node_modules/web-encoding/src/lib.js","../../node_modules/@mswjs/interceptors/lib/utils/bufferUtils.js","../../node_modules/@mswjs/interceptors/lib/utils/uuid.js","../../node_modules/@mswjs/interceptors/lib/IsomorphicRequest.js","../../node_modules/@mswjs/interceptors/lib/utils/createLazyCallback.js","../../node_modules/@mswjs/interceptors/lib/InteractiveIsomorphicRequest.js","../../node_modules/@mswjs/interceptors/lib/utils/getCleanUrl.js","../../node_modules/@mswjs/interceptors/lib/index.js","../../node_modules/set-cookie-parser/lib/set-cookie.js","../../node_modules/@mswjs/cookies/lib/store.js","../../node_modules/@mswjs/cookies/lib/index.js","../../node_modules/js-levenshtein/index.js","../../node_modules/graphql/version.mjs","../../node_modules/graphql/jsutils/devAssert.mjs","../../node_modules/graphql/jsutils/isPromise.mjs","../../node_modules/graphql/jsutils/isObjectLike.mjs","../../node_modules/graphql/jsutils/invariant.mjs","../../node_modules/graphql/language/location.mjs","../../node_modules/graphql/language/printLocation.mjs","../../node_modules/graphql/error/GraphQLError.mjs","../../node_modules/graphql/error/syntaxError.mjs","../../node_modules/graphql/language/ast.mjs","../../node_modules/graphql/language/directiveLocation.mjs","../../node_modules/graphql/language/kinds.mjs","../../node_modules/graphql/language/characterClasses.mjs","../../node_modules/graphql/language/blockString.mjs","../../node_modules/graphql/language/tokenKind.mjs","../../node_modules/graphql/language/lexer.mjs","../../node_modules/graphql/jsutils/inspect.mjs","../../node_modules/graphql/jsutils/instanceOf.mjs","../../node_modules/graphql/language/source.mjs","../../node_modules/graphql/language/parser.mjs","../../node_modules/graphql/jsutils/didYouMean.mjs","../../node_modules/graphql/jsutils/identityFunc.mjs","../../node_modules/graphql/jsutils/keyMap.mjs","../../node_modules/graphql/jsutils/keyValMap.mjs","../../node_modules/graphql/jsutils/mapValue.mjs","../../node_modules/graphql/jsutils/naturalCompare.mjs","../../node_modules/graphql/jsutils/suggestionList.mjs","../../node_modules/graphql/jsutils/toObjMap.mjs","../../node_modules/graphql/language/printString.mjs","../../node_modules/graphql/language/visitor.mjs","../../node_modules/graphql/language/printer.mjs","../../node_modules/graphql/utilities/valueFromASTUntyped.mjs","../../node_modules/graphql/type/assertName.mjs","../../node_modules/graphql/type/definition.mjs","../../node_modules/graphql/utilities/typeComparators.mjs","../../node_modules/graphql/type/scalars.mjs","../../node_modules/graphql/type/directives.mjs","../../node_modules/graphql/jsutils/isIterableObject.mjs","../../node_modules/graphql/utilities/astFromValue.mjs","../../node_modules/graphql/type/introspection.mjs","../../node_modules/graphql/type/schema.mjs","../../node_modules/graphql/type/validate.mjs","../../node_modules/graphql/utilities/typeFromAST.mjs","../../node_modules/graphql/utilities/TypeInfo.mjs","../../node_modules/graphql/language/predicates.mjs","../../node_modules/graphql/validation/rules/ExecutableDefinitionsRule.mjs","../../node_modules/graphql/validation/rules/FieldsOnCorrectTypeRule.mjs","../../node_modules/graphql/validation/rules/FragmentsOnCompositeTypesRule.mjs","../../node_modules/graphql/validation/rules/KnownArgumentNamesRule.mjs","../../node_modules/graphql/validation/rules/KnownDirectivesRule.mjs","../../node_modules/graphql/validation/rules/KnownFragmentNamesRule.mjs","../../node_modules/graphql/validation/rules/KnownTypeNamesRule.mjs","../../node_modules/graphql/validation/rules/LoneAnonymousOperationRule.mjs","../../node_modules/graphql/validation/rules/LoneSchemaDefinitionRule.mjs","../../node_modules/graphql/validation/rules/NoFragmentCyclesRule.mjs","../../node_modules/graphql/validation/rules/NoUndefinedVariablesRule.mjs","../../node_modules/graphql/validation/rules/NoUnusedFragmentsRule.mjs","../../node_modules/graphql/validation/rules/NoUnusedVariablesRule.mjs","../../node_modules/graphql/utilities/sortValueNode.mjs","../../node_modules/graphql/validation/rules/OverlappingFieldsCanBeMergedRule.mjs","../../node_modules/graphql/validation/rules/PossibleFragmentSpreadsRule.mjs","../../node_modules/graphql/validation/rules/PossibleTypeExtensionsRule.mjs","../../node_modules/graphql/validation/rules/ProvidedRequiredArgumentsRule.mjs","../../node_modules/graphql/validation/rules/ScalarLeafsRule.mjs","../../node_modules/graphql/jsutils/printPathArray.mjs","../../node_modules/graphql/jsutils/Path.mjs","../../node_modules/graphql/utilities/coerceInputValue.mjs","../../node_modules/graphql/utilities/valueFromAST.mjs","../../node_modules/graphql/execution/values.mjs","../../node_modules/graphql/execution/collectFields.mjs","../../node_modules/graphql/validation/rules/SingleFieldSubscriptionsRule.mjs","../../node_modules/graphql/jsutils/groupBy.mjs","../../node_modules/graphql/validation/rules/UniqueArgumentDefinitionNamesRule.mjs","../../node_modules/graphql/validation/rules/UniqueArgumentNamesRule.mjs","../../node_modules/graphql/validation/rules/UniqueDirectiveNamesRule.mjs","../../node_modules/graphql/validation/rules/UniqueDirectivesPerLocationRule.mjs","../../node_modules/graphql/validation/rules/UniqueEnumValueNamesRule.mjs","../../node_modules/graphql/validation/rules/UniqueFieldDefinitionNamesRule.mjs","../../node_modules/graphql/validation/rules/UniqueFragmentNamesRule.mjs","../../node_modules/graphql/validation/rules/UniqueInputFieldNamesRule.mjs","../../node_modules/graphql/validation/rules/UniqueOperationNamesRule.mjs","../../node_modules/graphql/validation/rules/UniqueOperationTypesRule.mjs","../../node_modules/graphql/validation/rules/UniqueTypeNamesRule.mjs","../../node_modules/graphql/validation/rules/UniqueVariableNamesRule.mjs","../../node_modules/graphql/validation/rules/ValuesOfCorrectTypeRule.mjs","../../node_modules/graphql/validation/rules/VariablesAreInputTypesRule.mjs","../../node_modules/graphql/validation/rules/VariablesInAllowedPositionRule.mjs","../../node_modules/graphql/validation/specifiedRules.mjs","../../node_modules/graphql/validation/ValidationContext.mjs","../../node_modules/graphql/validation/validate.mjs","../../node_modules/graphql/jsutils/memoize3.mjs","../../node_modules/graphql/jsutils/promiseForObject.mjs","../../node_modules/graphql/jsutils/promiseReduce.mjs","../../node_modules/graphql/jsutils/toError.mjs","../../node_modules/graphql/error/locatedError.mjs","../../node_modules/graphql/execution/execute.mjs","../../node_modules/graphql/graphql.mjs","../../node_modules/graphql/jsutils/isAsyncIterable.mjs","../../node_modules/graphql/execution/mapAsyncIterator.mjs","../../node_modules/graphql/execution/subscribe.mjs","../../node_modules/graphql/validation/rules/custom/NoDeprecatedCustomRule.mjs","../../node_modules/graphql/validation/rules/custom/NoSchemaIntrospectionCustomRule.mjs","../../node_modules/graphql/utilities/getIntrospectionQuery.mjs","../../node_modules/graphql/utilities/getOperationAST.mjs","../../node_modules/graphql/utilities/getOperationRootType.mjs","../../node_modules/graphql/utilities/introspectionFromSchema.mjs","../../node_modules/graphql/utilities/buildClientSchema.mjs","../../node_modules/graphql/utilities/extendSchema.mjs","../../node_modules/graphql/utilities/buildASTSchema.mjs","../../node_modules/graphql/utilities/lexicographicSortSchema.mjs","../../node_modules/graphql/utilities/printSchema.mjs","../../node_modules/graphql/utilities/concatAST.mjs","../../node_modules/graphql/utilities/separateOperations.mjs","../../node_modules/graphql/utilities/stripIgnoredCharacters.mjs","../../node_modules/graphql/utilities/assertValidName.mjs","../../node_modules/graphql/utilities/findBreakingChanges.mjs","../../node_modules/path-to-regexp/dist.es2015/index.js","../../node_modules/@mswjs/interceptors/lib/utils/toIsoResponse.js","../../node_modules/@mswjs/interceptors/lib/interceptors/fetch/index.js","../../node_modules/@xmldom/xmldom/lib/conventions.js","../../node_modules/@xmldom/xmldom/lib/dom.js","../../node_modules/@xmldom/xmldom/lib/entities.js","../../node_modules/@xmldom/xmldom/lib/sax.js","../../node_modules/@xmldom/xmldom/lib/dom-parser.js","../../node_modules/@xmldom/xmldom/lib/index.js","../../node_modules/@mswjs/interceptors/lib/utils/parseJson.js","../../node_modules/@mswjs/interceptors/lib/interceptors/XMLHttpRequest/utils/bufferFrom.js","../../node_modules/@mswjs/interceptors/lib/interceptors/XMLHttpRequest/polyfills/EventPolyfill.js","../../node_modules/@mswjs/interceptors/lib/interceptors/XMLHttpRequest/polyfills/ProgressEventPolyfill.js","../../node_modules/@mswjs/interceptors/lib/interceptors/XMLHttpRequest/utils/createEvent.js","../../node_modules/@mswjs/interceptors/lib/interceptors/XMLHttpRequest/XMLHttpRequestOverride.js","../../node_modules/@mswjs/interceptors/lib/interceptors/XMLHttpRequest/index.js","../../node_modules/strict-event-emitter/lib/MemoryLeakError.js","../../node_modules/strict-event-emitter/lib/Emitter.js","../../node_modules/strict-event-emitter/lib/index.js","../../node_modules/msw/lib/index.js","../../src/datatypes/transaksjonstyperTypes.ts","../../src/mocks/fixtures/eksternAktivitetFixtures.ts","../../src/mocks/eksterneAktiviteter.ts","../../src/mocks/fixtures/stillingFixtures.js","../../src/mocks/fixtures/stillingFraNavFixtures.ts","../../src/mocks/forhaandsorienteringFixtures.js","../../src/mocks/samtalereferatFixtures.ts","../../src/mocks/sokeAktivitetFixtures.js","../../src/mocks/aktivitet.ts","../../src/mocks/data/arena.ts","../../src/mocks/data/auth.ts","../../src/mocks/data/dialog.ts","../../src/mocks/data/eskaleringsvarsel.ts","../../src/mocks/data/feature.ts","../../src/mocks/data/lest.ts","../../src/mocks/data/mal.ts","../../src/mocks/data/malverk.ts","../../src/mocks/data/me.ts","../../src/mocks/data/oppfolging.ts","../../src/mocks/data/person.ts","../../src/mocks/data/Veileder.ts","../../src/mocks/data/journalføring.ts","../../src/mocks/handlers.ts","../../src/mocks/index.ts"],"sourcesContent":["import { addMinutes } from \"./addMinutes.mjs\";\n\n/**\n * @name subMinutes\n * @category Minute Helpers\n * @summary Subtract the specified number of minutes from the given date.\n *\n * @description\n * Subtract the specified number of minutes from the given date.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The date to be changed\n * @param amount - The amount of minutes to be subtracted.\n *\n * @returns The new date with the minutes subtracted\n *\n * @example\n * // Subtract 30 minutes from 10 July 2014 12:00:00:\n * const result = subMinutes(new Date(2014, 6, 10, 12, 0), 30)\n * //=> Thu Jul 10 2014 11:30:00\n */\nexport function subMinutes(date, amount) {\n return addMinutes(date, -amount);\n}\n\n// Fallback for modularized imports:\nexport default subMinutes;\n","function _array_like_to_array(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];\n return arr2;\n}\nfunction _array_with_holes(arr) {\n if (Array.isArray(arr)) return arr;\n}\nfunction _class_call_check(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}\nfunction _defineProperties(target, props) {\n for(var i = 0; i < props.length; i++){\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n}\nfunction _create_class(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n return Constructor;\n}\nfunction _instanceof(left, right) {\n if (right != null && typeof Symbol !== \"undefined\" && right[Symbol.hasInstance]) {\n return !!right[Symbol.hasInstance](left);\n } else {\n return left instanceof right;\n }\n}\nfunction _iterable_to_array_limit(arr, i) {\n var _i = arr == null ? null : typeof Symbol !== \"undefined\" && arr[Symbol.iterator] || arr[\"@@iterator\"];\n if (_i == null) return;\n var _arr = [];\n var _n = true;\n var _d = false;\n var _s, _e;\n try {\n for(_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true){\n _arr.push(_s.value);\n if (i && _arr.length === i) break;\n }\n } catch (err) {\n _d = true;\n _e = err;\n } finally{\n try {\n if (!_n && _i[\"return\"] != null) _i[\"return\"]();\n } finally{\n if (_d) throw _e;\n }\n }\n return _arr;\n}\nfunction _non_iterable_rest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\nfunction _sliced_to_array(arr, i) {\n return _array_with_holes(arr) || _iterable_to_array_limit(arr, i) || _unsupported_iterable_to_array(arr, i) || _non_iterable_rest();\n}\nfunction _unsupported_iterable_to_array(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return _array_like_to_array(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(n);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);\n}\nfunction _ts_generator(thisArg, body) {\n var f, y, t, g, _ = {\n label: 0,\n sent: function() {\n if (t[0] & 1) throw t[1];\n return t[1];\n },\n trys: [],\n ops: []\n };\n return g = {\n next: verb(0),\n \"throw\": verb(1),\n \"return\": verb(2)\n }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() {\n return this;\n }), g;\n function verb(n) {\n return function(v) {\n return step([\n n,\n v\n ]);\n };\n }\n function step(op) {\n if (f) throw new TypeError(\"Generator is already executing.\");\n while(_)try {\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\n if (y = 0, t) op = [\n op[0] & 2,\n t.value\n ];\n switch(op[0]){\n case 0:\n case 1:\n t = op;\n break;\n case 4:\n _.label++;\n return {\n value: op[1],\n done: false\n };\n case 5:\n _.label++;\n y = op[1];\n op = [\n 0\n ];\n continue;\n case 7:\n op = _.ops.pop();\n _.trys.pop();\n continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {\n _ = 0;\n continue;\n }\n if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {\n _.label = op[1];\n break;\n }\n if (op[0] === 6 && _.label < t[1]) {\n _.label = t[1];\n t = op;\n break;\n }\n if (t && _.label < t[2]) {\n _.label = t[2];\n _.ops.push(op);\n break;\n }\n if (t[2]) _.ops.pop();\n _.trys.pop();\n continue;\n }\n op = body.call(thisArg, _);\n } catch (e) {\n op = [\n 6,\n e\n ];\n y = 0;\n } finally{\n f = t = 0;\n }\n if (op[0] & 5) throw op[1];\n return {\n value: op[0] ? op[1] : void 0,\n done: true\n };\n }\n}\nvar __create = Object.create;\nvar __defProp = Object.defineProperty;\nvar __getOwnPropDesc = Object.getOwnPropertyDescriptor;\nvar __getOwnPropNames = Object.getOwnPropertyNames;\nvar __getProtoOf = Object.getPrototypeOf;\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\nvar __commonJS = function(cb, mod) {\n return function __require() {\n return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = {\n exports: {}\n }).exports, mod), mod.exports;\n };\n};\nvar __export = function(target, all) {\n for(var name in all)__defProp(target, name, {\n get: all[name],\n enumerable: true\n });\n};\nvar __copyProps = function(to, from, except, desc) {\n if (from && typeof from === \"object\" || typeof from === \"function\") {\n var _iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = undefined;\n try {\n var _loop = function() {\n var key = _step.value;\n if (!__hasOwnProp.call(to, key) && key !== except) __defProp(to, key, {\n get: function() {\n return from[key];\n },\n enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable\n });\n };\n for(var _iterator = __getOwnPropNames(from)[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true)_loop();\n } catch (err) {\n _didIteratorError = true;\n _iteratorError = err;\n } finally{\n try {\n if (!_iteratorNormalCompletion && _iterator.return != null) {\n _iterator.return();\n }\n } finally{\n if (_didIteratorError) {\n throw _iteratorError;\n }\n }\n }\n }\n return to;\n};\nvar __toESM = function(mod, isNodeMode, target) {\n return target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(isNodeMode || !mod || !mod.__esModule ? __defProp(target, \"default\", {\n value: mod,\n enumerable: true\n }) : target, mod);\n};\nvar __toCommonJS = function(mod) {\n return __copyProps(__defProp({}, \"__esModule\", {\n value: true\n }), mod);\n};\n// node_modules/set-cookie-parser/lib/set-cookie.js\nvar require_set_cookie = __commonJS({\n \"node_modules/set-cookie-parser/lib/set-cookie.js\": function(exports, module2) {\n \"use strict\";\n var isNonEmptyString = function isNonEmptyString(str) {\n return typeof str === \"string\" && !!str.trim();\n };\n var parseString = function parseString(setCookieValue, options) {\n var parts = setCookieValue.split(\";\").filter(isNonEmptyString);\n var nameValuePairStr = parts.shift();\n var parsed = parseNameValuePair(nameValuePairStr);\n var name = parsed.name;\n var value = parsed.value;\n options = options ? Object.assign({}, defaultParseOptions, options) : defaultParseOptions;\n try {\n value = options.decodeValues ? decodeURIComponent(value) : value;\n } catch (e) {\n console.error(\"set-cookie-parser encountered an error while decoding a cookie with value '\" + value + \"'. Set options.decodeValues to false to disable this feature.\", e);\n }\n var cookie = {\n name: name,\n value: value\n };\n parts.forEach(function(part) {\n var sides = part.split(\"=\");\n var key = sides.shift().trimLeft().toLowerCase();\n var value2 = sides.join(\"=\");\n if (key === \"expires\") {\n cookie.expires = new Date(value2);\n } else if (key === \"max-age\") {\n cookie.maxAge = parseInt(value2, 10);\n } else if (key === \"secure\") {\n cookie.secure = true;\n } else if (key === \"httponly\") {\n cookie.httpOnly = true;\n } else if (key === \"samesite\") {\n cookie.sameSite = value2;\n } else {\n cookie[key] = value2;\n }\n });\n return cookie;\n };\n var parseNameValuePair = function parseNameValuePair(nameValuePairStr) {\n var name = \"\";\n var value = \"\";\n var nameValueArr = nameValuePairStr.split(\"=\");\n if (nameValueArr.length > 1) {\n name = nameValueArr.shift();\n value = nameValueArr.join(\"=\");\n } else {\n value = nameValuePairStr;\n }\n return {\n name: name,\n value: value\n };\n };\n var parse = function parse(input, options) {\n options = options ? Object.assign({}, defaultParseOptions, options) : defaultParseOptions;\n if (!input) {\n if (!options.map) {\n return [];\n } else {\n return {};\n }\n }\n if (input.headers) {\n if (typeof input.headers.getSetCookie === \"function\") {\n input = input.headers.getSetCookie();\n } else if (input.headers[\"set-cookie\"]) {\n input = input.headers[\"set-cookie\"];\n } else {\n var sch = input.headers[Object.keys(input.headers).find(function(key) {\n return key.toLowerCase() === \"set-cookie\";\n })];\n if (!sch && input.headers.cookie && !options.silent) {\n console.warn(\"Warning: set-cookie-parser appears to have been called on a request object. It is designed to parse Set-Cookie headers from responses, not Cookie headers from requests. Set the option {silent: true} to suppress this warning.\");\n }\n input = sch;\n }\n }\n if (!Array.isArray(input)) {\n input = [\n input\n ];\n }\n options = options ? Object.assign({}, defaultParseOptions, options) : defaultParseOptions;\n if (!options.map) {\n return input.filter(isNonEmptyString).map(function(str) {\n return parseString(str, options);\n });\n } else {\n var cookies = {};\n return input.filter(isNonEmptyString).reduce(function(cookies2, str) {\n var cookie = parseString(str, options);\n cookies2[cookie.name] = cookie;\n return cookies2;\n }, cookies);\n }\n };\n var splitCookiesString2 = function splitCookiesString2(cookiesString) {\n if (Array.isArray(cookiesString)) {\n return cookiesString;\n }\n if (typeof cookiesString !== \"string\") {\n return [];\n }\n var cookiesStrings = [];\n var pos = 0;\n var start;\n var ch;\n var lastComma;\n var nextStart;\n var cookiesSeparatorFound;\n function skipWhitespace() {\n while(pos < cookiesString.length && /\\s/.test(cookiesString.charAt(pos))){\n pos += 1;\n }\n return pos < cookiesString.length;\n }\n function notSpecialChar() {\n ch = cookiesString.charAt(pos);\n return ch !== \"=\" && ch !== \";\" && ch !== \",\";\n }\n while(pos < cookiesString.length){\n start = pos;\n cookiesSeparatorFound = false;\n while(skipWhitespace()){\n ch = cookiesString.charAt(pos);\n if (ch === \",\") {\n lastComma = pos;\n pos += 1;\n skipWhitespace();\n nextStart = pos;\n while(pos < cookiesString.length && notSpecialChar()){\n pos += 1;\n }\n if (pos < cookiesString.length && cookiesString.charAt(pos) === \"=\") {\n cookiesSeparatorFound = true;\n pos = nextStart;\n cookiesStrings.push(cookiesString.substring(start, lastComma));\n start = pos;\n } else {\n pos = lastComma + 1;\n }\n } else {\n pos += 1;\n }\n }\n if (!cookiesSeparatorFound || pos >= cookiesString.length) {\n cookiesStrings.push(cookiesString.substring(start, cookiesString.length));\n }\n }\n return cookiesStrings;\n };\n var defaultParseOptions = {\n decodeValues: true,\n map: false,\n silent: false\n };\n module2.exports = parse;\n module2.exports.parse = parse;\n module2.exports.parseString = parseString;\n module2.exports.splitCookiesString = splitCookiesString2;\n }\n});\n// src/index.ts\nvar src_exports = {};\n__export(src_exports, {\n Headers: function() {\n return HeadersPolyfill;\n },\n flattenHeadersList: function() {\n return flattenHeadersList;\n },\n flattenHeadersObject: function() {\n return flattenHeadersObject;\n },\n headersToList: function() {\n return headersToList;\n },\n headersToObject: function() {\n return headersToObject;\n },\n headersToString: function() {\n return headersToString;\n },\n listToHeaders: function() {\n return listToHeaders;\n },\n objectToHeaders: function() {\n return objectToHeaders;\n },\n reduceHeadersObject: function() {\n return reduceHeadersObject;\n },\n stringToHeaders: function() {\n return stringToHeaders;\n }\n});\nmodule.exports = __toCommonJS(src_exports);\n// src/Headers.ts\nvar import_set_cookie_parser = __toESM(require_set_cookie());\n// src/utils/normalizeHeaderName.ts\nvar HEADERS_INVALID_CHARACTERS = /[^a-z0-9\\-#$%&'*+.^_`|~]/i;\nfunction normalizeHeaderName(name) {\n if (HEADERS_INVALID_CHARACTERS.test(name) || name.trim() === \"\") {\n throw new TypeError(\"Invalid character in header field name\");\n }\n return name.trim().toLowerCase();\n}\n// src/utils/normalizeHeaderValue.ts\nvar charCodesToRemove = [\n String.fromCharCode(10),\n String.fromCharCode(13),\n String.fromCharCode(9),\n String.fromCharCode(32)\n];\nvar HEADER_VALUE_REMOVE_REGEXP = new RegExp(\"(^[\".concat(charCodesToRemove.join(\"\"), \"]|$[\").concat(charCodesToRemove.join(\"\"), \"])\"), \"g\");\nfunction normalizeHeaderValue(value) {\n var nextValue = value.replace(HEADER_VALUE_REMOVE_REGEXP, \"\");\n return nextValue;\n}\n// src/utils/isValidHeaderName.ts\nfunction isValidHeaderName(value) {\n if (typeof value !== \"string\") {\n return false;\n }\n if (value.length === 0) {\n return false;\n }\n for(var i = 0; i < value.length; i++){\n var character = value.charCodeAt(i);\n if (character > 127 || !isToken(character)) {\n return false;\n }\n }\n return true;\n}\nfunction isToken(value) {\n return ![\n 127,\n 32,\n \"(\",\n \")\",\n \"<\",\n \">\",\n \"@\",\n \",\",\n \";\",\n \":\",\n \"\\\\\",\n '\"',\n \"/\",\n \"[\",\n \"]\",\n \"?\",\n \"=\",\n \"{\",\n \"}\"\n ].includes(value);\n}\n// src/utils/isValidHeaderValue.ts\nfunction isValidHeaderValue(value) {\n if (typeof value !== \"string\") {\n return false;\n }\n if (value.trim() !== value) {\n return false;\n }\n for(var i = 0; i < value.length; i++){\n var character = value.charCodeAt(i);\n if (character === 0 || character === 10 || character === 13) {\n return false;\n }\n }\n return true;\n}\n// src/Headers.ts\nvar NORMALIZED_HEADERS = Symbol(\"normalizedHeaders\");\nvar RAW_HEADER_NAMES = Symbol(\"rawHeaderNames\");\nvar HEADER_VALUE_DELIMITER = \", \";\nvar _a, _b;\nvar HeadersPolyfill = /*#__PURE__*/ function() {\n \"use strict\";\n function HeadersPolyfill1(init) {\n var _this = this;\n _class_call_check(this, HeadersPolyfill1);\n var _init;\n this[_a] = {};\n this[_b] = /* @__PURE__ */ new Map();\n if ([\n \"Headers\",\n \"HeadersPolyfill\"\n ].includes((_init = init) === null || _init === void 0 ? void 0 : _init.constructor.name) || _instanceof(init, HeadersPolyfill)) {\n var initialHeaders = init;\n initialHeaders.forEach(function(value, name) {\n _this.append(name, value);\n }, this);\n } else if (Array.isArray(init)) {\n init.forEach(function(param) {\n var _param = _sliced_to_array(param, 2), name = _param[0], value = _param[1];\n _this.append(name, Array.isArray(value) ? value.join(HEADER_VALUE_DELIMITER) : value);\n });\n } else if (init) {\n Object.getOwnPropertyNames(init).forEach(function(name) {\n var value = init[name];\n _this.append(name, Array.isArray(value) ? value.join(HEADER_VALUE_DELIMITER) : value);\n });\n }\n }\n _create_class(HeadersPolyfill1, [\n {\n key: (_a = NORMALIZED_HEADERS, _b = RAW_HEADER_NAMES, Symbol.iterator),\n value: function value() {\n return this.entries();\n }\n },\n {\n key: \"keys\",\n value: function keys() {\n var _iteratorNormalCompletion, _didIteratorError, _iteratorError, _iterator, _step, _step_value, name, err;\n return _ts_generator(this, function(_state) {\n switch(_state.label){\n case 0:\n _iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = undefined;\n _state.label = 1;\n case 1:\n _state.trys.push([\n 1,\n 6,\n 7,\n 8\n ]);\n _iterator = this.entries()[Symbol.iterator]();\n _state.label = 2;\n case 2:\n if (!!(_iteratorNormalCompletion = (_step = _iterator.next()).done)) return [\n 3,\n 5\n ];\n _step_value = _sliced_to_array(_step.value, 1), name = _step_value[0];\n return [\n 4,\n name\n ];\n case 3:\n _state.sent();\n _state.label = 4;\n case 4:\n _iteratorNormalCompletion = true;\n return [\n 3,\n 2\n ];\n case 5:\n return [\n 3,\n 8\n ];\n case 6:\n err = _state.sent();\n _didIteratorError = true;\n _iteratorError = err;\n return [\n 3,\n 8\n ];\n case 7:\n try {\n if (!_iteratorNormalCompletion && _iterator.return != null) {\n _iterator.return();\n }\n } finally{\n if (_didIteratorError) {\n throw _iteratorError;\n }\n }\n return [\n 7\n ];\n case 8:\n return [\n 2\n ];\n }\n });\n }\n },\n {\n key: \"values\",\n value: function values() {\n var _iteratorNormalCompletion, _didIteratorError, _iteratorError, _iterator, _step, _step_value, value, err;\n return _ts_generator(this, function(_state) {\n switch(_state.label){\n case 0:\n _iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = undefined;\n _state.label = 1;\n case 1:\n _state.trys.push([\n 1,\n 6,\n 7,\n 8\n ]);\n _iterator = this.entries()[Symbol.iterator]();\n _state.label = 2;\n case 2:\n if (!!(_iteratorNormalCompletion = (_step = _iterator.next()).done)) return [\n 3,\n 5\n ];\n _step_value = _sliced_to_array(_step.value, 2), value = _step_value[1];\n return [\n 4,\n value\n ];\n case 3:\n _state.sent();\n _state.label = 4;\n case 4:\n _iteratorNormalCompletion = true;\n return [\n 3,\n 2\n ];\n case 5:\n return [\n 3,\n 8\n ];\n case 6:\n err = _state.sent();\n _didIteratorError = true;\n _iteratorError = err;\n return [\n 3,\n 8\n ];\n case 7:\n try {\n if (!_iteratorNormalCompletion && _iterator.return != null) {\n _iterator.return();\n }\n } finally{\n if (_didIteratorError) {\n throw _iteratorError;\n }\n }\n return [\n 7\n ];\n case 8:\n return [\n 2\n ];\n }\n });\n }\n },\n {\n key: \"entries\",\n value: function entries() {\n var sortedKeys, _iteratorNormalCompletion, _didIteratorError, _iteratorError, _iterator, _step, name, _iteratorNormalCompletion1, _didIteratorError1, _iteratorError1, _iterator1, _step1, value, err, err;\n return _ts_generator(this, function(_state) {\n switch(_state.label){\n case 0:\n sortedKeys = Object.keys(this[NORMALIZED_HEADERS]).sort(function(a, b) {\n return a.localeCompare(b);\n });\n _iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = undefined;\n _state.label = 1;\n case 1:\n _state.trys.push([\n 1,\n 15,\n 16,\n 17\n ]);\n _iterator = sortedKeys[Symbol.iterator]();\n _state.label = 2;\n case 2:\n if (!!(_iteratorNormalCompletion = (_step = _iterator.next()).done)) return [\n 3,\n 14\n ];\n name = _step.value;\n if (!(name === \"set-cookie\")) return [\n 3,\n 11\n ];\n _iteratorNormalCompletion1 = true, _didIteratorError1 = false, _iteratorError1 = undefined;\n _state.label = 3;\n case 3:\n _state.trys.push([\n 3,\n 8,\n 9,\n 10\n ]);\n _iterator1 = this.getSetCookie()[Symbol.iterator]();\n _state.label = 4;\n case 4:\n if (!!(_iteratorNormalCompletion1 = (_step1 = _iterator1.next()).done)) return [\n 3,\n 7\n ];\n value = _step1.value;\n return [\n 4,\n [\n name,\n value\n ]\n ];\n case 5:\n _state.sent();\n _state.label = 6;\n case 6:\n _iteratorNormalCompletion1 = true;\n return [\n 3,\n 4\n ];\n case 7:\n return [\n 3,\n 10\n ];\n case 8:\n err = _state.sent();\n _didIteratorError1 = true;\n _iteratorError1 = err;\n return [\n 3,\n 10\n ];\n case 9:\n try {\n if (!_iteratorNormalCompletion1 && _iterator1.return != null) {\n _iterator1.return();\n }\n } finally{\n if (_didIteratorError1) {\n throw _iteratorError1;\n }\n }\n return [\n 7\n ];\n case 10:\n return [\n 3,\n 13\n ];\n case 11:\n return [\n 4,\n [\n name,\n this.get(name)\n ]\n ];\n case 12:\n _state.sent();\n _state.label = 13;\n case 13:\n _iteratorNormalCompletion = true;\n return [\n 3,\n 2\n ];\n case 14:\n return [\n 3,\n 17\n ];\n case 15:\n err = _state.sent();\n _didIteratorError = true;\n _iteratorError = err;\n return [\n 3,\n 17\n ];\n case 16:\n try {\n if (!_iteratorNormalCompletion && _iterator.return != null) {\n _iterator.return();\n }\n } finally{\n if (_didIteratorError) {\n throw _iteratorError;\n }\n }\n return [\n 7\n ];\n case 17:\n return [\n 2\n ];\n }\n });\n }\n },\n {\n key: \"has\",\n value: function has(name) {\n if (!isValidHeaderName(name)) {\n throw new TypeError('Invalid header name \"'.concat(name, '\"'));\n }\n return this[NORMALIZED_HEADERS].hasOwnProperty(normalizeHeaderName(name));\n }\n },\n {\n key: \"get\",\n value: function get(name) {\n if (!isValidHeaderName(name)) {\n throw TypeError('Invalid header name \"'.concat(name, '\"'));\n }\n var _this_NORMALIZED_HEADERS_normalizeHeaderName;\n return (_this_NORMALIZED_HEADERS_normalizeHeaderName = this[NORMALIZED_HEADERS][normalizeHeaderName(name)]) !== null && _this_NORMALIZED_HEADERS_normalizeHeaderName !== void 0 ? _this_NORMALIZED_HEADERS_normalizeHeaderName : null;\n }\n },\n {\n key: \"set\",\n value: function set(name, value) {\n if (!isValidHeaderName(name) || !isValidHeaderValue(value)) {\n return;\n }\n var normalizedName = normalizeHeaderName(name);\n var normalizedValue = normalizeHeaderValue(value);\n this[NORMALIZED_HEADERS][normalizedName] = normalizeHeaderValue(normalizedValue);\n this[RAW_HEADER_NAMES].set(normalizedName, name);\n }\n },\n {\n key: \"append\",\n value: function append(name, value) {\n if (!isValidHeaderName(name) || !isValidHeaderValue(value)) {\n return;\n }\n var normalizedName = normalizeHeaderName(name);\n var normalizedValue = normalizeHeaderValue(value);\n var resolvedValue = this.has(normalizedName) ? \"\".concat(this.get(normalizedName), \", \").concat(normalizedValue) : normalizedValue;\n this.set(name, resolvedValue);\n }\n },\n {\n key: \"delete\",\n value: function _delete(name) {\n if (!isValidHeaderName(name)) {\n return;\n }\n if (!this.has(name)) {\n return;\n }\n var normalizedName = normalizeHeaderName(name);\n delete this[NORMALIZED_HEADERS][normalizedName];\n this[RAW_HEADER_NAMES].delete(normalizedName);\n }\n },\n {\n key: \"all\",\n value: function all() {\n return this[NORMALIZED_HEADERS];\n }\n },\n {\n key: \"raw\",\n value: function raw() {\n var rawHeaders = {};\n var _iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = undefined;\n try {\n for(var _iterator = this.entries()[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true){\n var _step_value = _sliced_to_array(_step.value, 2), name = _step_value[0], value = _step_value[1];\n rawHeaders[this[RAW_HEADER_NAMES].get(name)] = value;\n }\n } catch (err) {\n _didIteratorError = true;\n _iteratorError = err;\n } finally{\n try {\n if (!_iteratorNormalCompletion && _iterator.return != null) {\n _iterator.return();\n }\n } finally{\n if (_didIteratorError) {\n throw _iteratorError;\n }\n }\n }\n return rawHeaders;\n }\n },\n {\n key: \"forEach\",\n value: function forEach(callback, thisArg) {\n var _iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = undefined;\n try {\n for(var _iterator = this.entries()[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true){\n var _step_value = _sliced_to_array(_step.value, 2), name = _step_value[0], value = _step_value[1];\n callback.call(thisArg, value, name, this);\n }\n } catch (err) {\n _didIteratorError = true;\n _iteratorError = err;\n } finally{\n try {\n if (!_iteratorNormalCompletion && _iterator.return != null) {\n _iterator.return();\n }\n } finally{\n if (_didIteratorError) {\n throw _iteratorError;\n }\n }\n }\n }\n },\n {\n key: \"getSetCookie\",\n value: function getSetCookie() {\n var setCookieHeader = this.get(\"set-cookie\");\n if (setCookieHeader === null) {\n return [];\n }\n if (setCookieHeader === \"\") {\n return [\n \"\"\n ];\n }\n return (0, import_set_cookie_parser.splitCookiesString)(setCookieHeader);\n }\n }\n ]);\n return HeadersPolyfill1;\n}();\n// src/transformers/headersToList.ts\nfunction headersToList(headers) {\n var headersList = [];\n headers.forEach(function(value, name) {\n var resolvedValue = value.includes(\",\") ? value.split(\",\").map(function(value2) {\n return value2.trim();\n }) : value;\n headersList.push([\n name,\n resolvedValue\n ]);\n });\n return headersList;\n}\n// src/transformers/headersToString.ts\nfunction headersToString(headers) {\n var list = headersToList(headers);\n var lines = list.map(function(param) {\n var _param = _sliced_to_array(param, 2), name = _param[0], value = _param[1];\n var values = [].concat(value);\n return \"\".concat(name, \": \").concat(values.join(\", \"));\n });\n return lines.join(\"\\r\\n\");\n}\n// src/transformers/headersToObject.ts\nvar singleValueHeaders = [\n \"user-agent\"\n];\nfunction headersToObject(headers) {\n var headersObject = {};\n headers.forEach(function(value, name) {\n var isMultiValue = !singleValueHeaders.includes(name.toLowerCase()) && value.includes(\",\");\n headersObject[name] = isMultiValue ? value.split(\",\").map(function(s) {\n return s.trim();\n }) : value;\n });\n return headersObject;\n}\n// src/transformers/stringToHeaders.ts\nfunction stringToHeaders(str) {\n var lines = str.trim().split(/[\\r\\n]+/);\n return lines.reduce(function(headers, line) {\n if (line.trim() === \"\") {\n return headers;\n }\n var parts = line.split(\": \");\n var name = parts.shift();\n var value = parts.join(\": \");\n headers.append(name, value);\n return headers;\n }, new HeadersPolyfill());\n}\n// src/transformers/listToHeaders.ts\nfunction listToHeaders(list) {\n var headers = new HeadersPolyfill();\n list.forEach(function(param) {\n var _param = _sliced_to_array(param, 2), name = _param[0], value = _param[1];\n var values = [].concat(value);\n values.forEach(function(value2) {\n headers.append(name, value2);\n });\n });\n return headers;\n}\n// src/transformers/reduceHeadersObject.ts\nfunction reduceHeadersObject(headers, reducer, initialState) {\n return Object.keys(headers).reduce(function(nextHeaders, name) {\n return reducer(nextHeaders, name, headers[name]);\n }, initialState);\n}\n// src/transformers/objectToHeaders.ts\nfunction objectToHeaders(headersObject) {\n return reduceHeadersObject(headersObject, function(headers, name, value) {\n var values = [].concat(value).filter(Boolean);\n values.forEach(function(value2) {\n headers.append(name, value2);\n });\n return headers;\n }, new HeadersPolyfill());\n}\n// src/transformers/flattenHeadersList.ts\nfunction flattenHeadersList(list) {\n return list.map(function(param) {\n var _param = _sliced_to_array(param, 2), name = _param[0], values = _param[1];\n return [\n name,\n [].concat(values).join(\", \")\n ];\n });\n}\n// src/transformers/flattenHeadersObject.ts\nfunction flattenHeadersObject(headersObject) {\n return reduceHeadersObject(headersObject, function(headers, name, value) {\n headers[name] = [].concat(value).join(\", \");\n return headers;\n }, {});\n}\n// Annotate the CommonJS export names for ESM import in node:\n0 && (module.exports = {\n Headers: Headers,\n flattenHeadersList: flattenHeadersList,\n flattenHeadersObject: flattenHeadersObject,\n headersToList: headersToList,\n headersToObject: headersToObject,\n headersToString: headersToString,\n listToHeaders: listToHeaders,\n objectToHeaders: objectToHeaders,\n reduceHeadersObject: reduceHeadersObject,\n stringToHeaders: stringToHeaders\n});\n//# sourceMappingURL=index.js.map","/*!\n * cookie\n * Copyright(c) 2012-2014 Roman Shtylman\n * Copyright(c) 2015 Douglas Christopher Wilson\n * MIT Licensed\n */\n\n'use strict';\n\n/**\n * Module exports.\n * @public\n */\n\nexports.parse = parse;\nexports.serialize = serialize;\n\n/**\n * Module variables.\n * @private\n */\n\nvar decode = decodeURIComponent;\nvar encode = encodeURIComponent;\n\n/**\n * RegExp to match field-content in RFC 7230 sec 3.2\n *\n * field-content = field-vchar [ 1*( SP / HTAB ) field-vchar ]\n * field-vchar = VCHAR / obs-text\n * obs-text = %x80-FF\n */\n\nvar fieldContentRegExp = /^[\\u0009\\u0020-\\u007e\\u0080-\\u00ff]+$/;\n\n/**\n * Parse a cookie header.\n *\n * Parse the given cookie header string into an object\n * The object has the various cookies as keys(names) => values\n *\n * @param {string} str\n * @param {object} [options]\n * @return {object}\n * @public\n */\n\nfunction parse(str, options) {\n if (typeof str !== 'string') {\n throw new TypeError('argument str must be a string');\n }\n\n var obj = {}\n var opt = options || {};\n var pairs = str.split(';')\n var dec = opt.decode || decode;\n\n for (var i = 0; i < pairs.length; i++) {\n var pair = pairs[i];\n var index = pair.indexOf('=')\n\n // skip things that don't look like key=value\n if (index < 0) {\n continue;\n }\n\n var key = pair.substring(0, index).trim()\n\n // only assign once\n if (undefined == obj[key]) {\n var val = pair.substring(index + 1, pair.length).trim()\n\n // quoted values\n if (val[0] === '\"') {\n val = val.slice(1, -1)\n }\n\n obj[key] = tryDecode(val, dec);\n }\n }\n\n return obj;\n}\n\n/**\n * Serialize data into a cookie header.\n *\n * Serialize the a name value pair into a cookie string suitable for\n * http headers. An optional options object specified cookie parameters.\n *\n * serialize('foo', 'bar', { httpOnly: true })\n * => \"foo=bar; httpOnly\"\n *\n * @param {string} name\n * @param {string} val\n * @param {object} [options]\n * @return {string}\n * @public\n */\n\nfunction serialize(name, val, options) {\n var opt = options || {};\n var enc = opt.encode || encode;\n\n if (typeof enc !== 'function') {\n throw new TypeError('option encode is invalid');\n }\n\n if (!fieldContentRegExp.test(name)) {\n throw new TypeError('argument name is invalid');\n }\n\n var value = enc(val);\n\n if (value && !fieldContentRegExp.test(value)) {\n throw new TypeError('argument val is invalid');\n }\n\n var str = name + '=' + value;\n\n if (null != opt.maxAge) {\n var maxAge = opt.maxAge - 0;\n\n if (isNaN(maxAge) || !isFinite(maxAge)) {\n throw new TypeError('option maxAge is invalid')\n }\n\n str += '; Max-Age=' + Math.floor(maxAge);\n }\n\n if (opt.domain) {\n if (!fieldContentRegExp.test(opt.domain)) {\n throw new TypeError('option domain is invalid');\n }\n\n str += '; Domain=' + opt.domain;\n }\n\n if (opt.path) {\n if (!fieldContentRegExp.test(opt.path)) {\n throw new TypeError('option path is invalid');\n }\n\n str += '; Path=' + opt.path;\n }\n\n if (opt.expires) {\n if (typeof opt.expires.toUTCString !== 'function') {\n throw new TypeError('option expires is invalid');\n }\n\n str += '; Expires=' + opt.expires.toUTCString();\n }\n\n if (opt.httpOnly) {\n str += '; HttpOnly';\n }\n\n if (opt.secure) {\n str += '; Secure';\n }\n\n if (opt.sameSite) {\n var sameSite = typeof opt.sameSite === 'string'\n ? opt.sameSite.toLowerCase() : opt.sameSite;\n\n switch (sameSite) {\n case true:\n str += '; SameSite=Strict';\n break;\n case 'lax':\n str += '; SameSite=Lax';\n break;\n case 'strict':\n str += '; SameSite=Strict';\n break;\n case 'none':\n str += '; SameSite=None';\n break;\n default:\n throw new TypeError('option sameSite is invalid');\n }\n }\n\n return str;\n}\n\n/**\n * Try decoding a string using a decoding function.\n *\n * @param {string} str\n * @param {function} decode\n * @private\n */\n\nfunction tryDecode(str, decode) {\n try {\n return decode(str);\n } catch (e) {\n return str;\n }\n}\n","var __defProp = Object.defineProperty;\nvar __getOwnPropDesc = Object.getOwnPropertyDescriptor;\nvar __getOwnPropNames = Object.getOwnPropertyNames;\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\nvar __export = (target, all) => {\n for (var name in all)\n __defProp(target, name, { get: all[name], enumerable: true });\n};\nvar __copyProps = (to, from, except, desc) => {\n if (from && typeof from === \"object\" || typeof from === \"function\") {\n for (let key of __getOwnPropNames(from))\n if (!__hasOwnProp.call(to, key) && key !== except)\n __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });\n }\n return to;\n};\nvar __toCommonJS = (mod) => __copyProps(__defProp({}, \"__esModule\", { value: true }), mod);\n\n// src/index.ts\nvar src_exports = {};\n__export(src_exports, {\n isNodeProcess: () => isNodeProcess\n});\nmodule.exports = __toCommonJS(src_exports);\nfunction isNodeProcess() {\n if (typeof navigator !== \"undefined\" && navigator.product === \"ReactNative\") {\n return true;\n }\n if (typeof process !== \"undefined\") {\n const type = process.type;\n if (type === \"renderer\" || type === \"worker\") {\n return false;\n }\n return !!(process.versions && process.versions.node);\n }\n return false;\n}\n// Annotate the CommonJS export names for ESM import in node:\n0 && (module.exports = {\n isNodeProcess\n});\n//# sourceMappingURL=index.js.map","\"use strict\";\n\n// ref: https://github.com/tc39/proposal-global\nvar getGlobal = function () {\n\t// the only reliable means to get the global object is\n\t// `Function('return this')()`\n\t// However, this causes CSP violations in Chrome apps.\n\tif (typeof self !== 'undefined') { return self; }\n\tif (typeof window !== 'undefined') { return window; }\n\tif (typeof global !== 'undefined') { return global; }\n\tthrow new Error('unable to locate global object');\n}\n\nvar globalObject = getGlobal();\n\nmodule.exports = exports = globalObject.fetch;\n\n// Needed for TypeScript and Webpack.\nif (globalObject.fetch) {\n\texports.default = globalObject.fetch.bind(globalObject);\n}\n\nexports.Headers = globalObject.Headers;\nexports.Request = globalObject.Request;\nexports.Response = globalObject.Response;\n","\"use strict\";\nvar __defProp = Object.defineProperty;\nvar __getOwnPropDesc = Object.getOwnPropertyDescriptor;\nvar __getOwnPropNames = Object.getOwnPropertyNames;\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\nvar __export = (target, all) => {\n for (var name in all)\n __defProp(target, name, { get: all[name], enumerable: true });\n};\nvar __copyProps = (to, from, except, desc) => {\n if (from && typeof from === \"object\" || typeof from === \"function\") {\n for (let key of __getOwnPropNames(from))\n if (!__hasOwnProp.call(to, key) && key !== except)\n __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });\n }\n return to;\n};\nvar __toCommonJS = (mod) => __copyProps(__defProp({}, \"__esModule\", { value: true }), mod);\n\n// src/index.ts\nvar src_exports = {};\n__export(src_exports, {\n InvariantError: () => InvariantError,\n format: () => format,\n invariant: () => invariant\n});\nmodule.exports = __toCommonJS(src_exports);\n\n// src/format.ts\nvar POSITIONALS_EXP = /(%?)(%([sdijo]))/g;\nfunction serializePositional(positional, flag) {\n switch (flag) {\n case \"s\":\n return positional;\n case \"d\":\n case \"i\":\n return Number(positional);\n case \"j\":\n return JSON.stringify(positional);\n case \"o\": {\n if (typeof positional === \"string\") {\n return positional;\n }\n const json = JSON.stringify(positional);\n if (json === \"{}\" || json === \"[]\" || /^\\[object .+?\\]$/.test(json)) {\n return positional;\n }\n return json;\n }\n }\n}\nfunction format(message, ...positionals) {\n if (positionals.length === 0) {\n return message;\n }\n let positionalIndex = 0;\n let formattedMessage = message.replace(\n POSITIONALS_EXP,\n (match, isEscaped, _, flag) => {\n const positional = positionals[positionalIndex];\n const value = serializePositional(positional, flag);\n if (!isEscaped) {\n positionalIndex++;\n return value;\n }\n return match;\n }\n );\n if (positionalIndex < positionals.length) {\n formattedMessage += ` ${positionals.slice(positionalIndex).join(\" \")}`;\n }\n formattedMessage = formattedMessage.replace(/%{2,2}/g, \"%\");\n return formattedMessage;\n}\n\n// src/invariant.ts\nvar STACK_FRAMES_TO_IGNORE = 2;\nfunction cleanErrorStack(error) {\n if (!error.stack) {\n return;\n }\n const nextStack = error.stack.split(\"\\n\");\n nextStack.splice(1, STACK_FRAMES_TO_IGNORE);\n error.stack = nextStack.join(\"\\n\");\n}\nvar InvariantError = class extends Error {\n constructor(message, ...positionals) {\n super(message);\n this.message = message;\n this.name = \"Invariant Violation\";\n this.message = format(message, ...positionals);\n cleanErrorStack(this);\n }\n};\nvar invariant = (predicate, message, ...positionals) => {\n if (!predicate) {\n throw new InvariantError(message, ...positionals);\n }\n};\ninvariant.as = (ErrorConstructor, predicate, message, ...positionals) => {\n if (!predicate) {\n const formatMessage = positionals.length === 0 ? message : format(message, ...positionals);\n let error;\n try {\n error = Reflect.construct(ErrorConstructor, [\n formatMessage\n ]);\n } catch (err) {\n error = ErrorConstructor(formatMessage);\n }\n throw error;\n }\n};\n// Annotate the CommonJS export names for ESM import in node:\n0 && (module.exports = {\n InvariantError,\n format,\n invariant\n});\n//# sourceMappingURL=index.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\n/**\n * Gracefully handles a given Promise factory.\n * @example\n * cosnt [error, data] = await until(() => asyncAction())\n */\nexports.until = async (promise) => {\n try {\n const data = await promise().catch((error) => {\n throw error;\n });\n return [null, data];\n }\n catch (error) {\n return [error, null];\n }\n};\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar until_1 = require(\"./until\");\nexports.until = until_1.until;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.IS_PATCHED_MODULE = void 0;\nexports.IS_PATCHED_MODULE = Symbol('isPatchedModule');\n//# sourceMappingURL=glossary.js.map","/**\n * Helpers.\n */\n\nvar s = 1000;\nvar m = s * 60;\nvar h = m * 60;\nvar d = h * 24;\nvar w = d * 7;\nvar y = d * 365.25;\n\n/**\n * Parse or format the given `val`.\n *\n * Options:\n *\n * - `long` verbose formatting [false]\n *\n * @param {String|Number} val\n * @param {Object} [options]\n * @throws {Error} throw an error if val is not a non-empty string or a number\n * @return {String|Number}\n * @api public\n */\n\nmodule.exports = function(val, options) {\n options = options || {};\n var type = typeof val;\n if (type === 'string' && val.length > 0) {\n return parse(val);\n } else if (type === 'number' && isFinite(val)) {\n return options.long ? fmtLong(val) : fmtShort(val);\n }\n throw new Error(\n 'val is not a non-empty string or a valid number. val=' +\n JSON.stringify(val)\n );\n};\n\n/**\n * Parse the given `str` and return milliseconds.\n *\n * @param {String} str\n * @return {Number}\n * @api private\n */\n\nfunction parse(str) {\n str = String(str);\n if (str.length > 100) {\n return;\n }\n var match = /^(-?(?:\\d+)?\\.?\\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(\n str\n );\n if (!match) {\n return;\n }\n var n = parseFloat(match[1]);\n var type = (match[2] || 'ms').toLowerCase();\n switch (type) {\n case 'years':\n case 'year':\n case 'yrs':\n case 'yr':\n case 'y':\n return n * y;\n case 'weeks':\n case 'week':\n case 'w':\n return n * w;\n case 'days':\n case 'day':\n case 'd':\n return n * d;\n case 'hours':\n case 'hour':\n case 'hrs':\n case 'hr':\n case 'h':\n return n * h;\n case 'minutes':\n case 'minute':\n case 'mins':\n case 'min':\n case 'm':\n return n * m;\n case 'seconds':\n case 'second':\n case 'secs':\n case 'sec':\n case 's':\n return n * s;\n case 'milliseconds':\n case 'millisecond':\n case 'msecs':\n case 'msec':\n case 'ms':\n return n;\n default:\n return undefined;\n }\n}\n\n/**\n * Short format for `ms`.\n *\n * @param {Number} ms\n * @return {String}\n * @api private\n */\n\nfunction fmtShort(ms) {\n var msAbs = Math.abs(ms);\n if (msAbs >= d) {\n return Math.round(ms / d) + 'd';\n }\n if (msAbs >= h) {\n return Math.round(ms / h) + 'h';\n }\n if (msAbs >= m) {\n return Math.round(ms / m) + 'm';\n }\n if (msAbs >= s) {\n return Math.round(ms / s) + 's';\n }\n return ms + 'ms';\n}\n\n/**\n * Long format for `ms`.\n *\n * @param {Number} ms\n * @return {String}\n * @api private\n */\n\nfunction fmtLong(ms) {\n var msAbs = Math.abs(ms);\n if (msAbs >= d) {\n return plural(ms, msAbs, d, 'day');\n }\n if (msAbs >= h) {\n return plural(ms, msAbs, h, 'hour');\n }\n if (msAbs >= m) {\n return plural(ms, msAbs, m, 'minute');\n }\n if (msAbs >= s) {\n return plural(ms, msAbs, s, 'second');\n }\n return ms + ' ms';\n}\n\n/**\n * Pluralization helper.\n */\n\nfunction plural(ms, msAbs, n, name) {\n var isPlural = msAbs >= n * 1.5;\n return Math.round(ms / n) + ' ' + name + (isPlural ? 's' : '');\n}\n","\n/**\n * This is the common logic for both the Node.js and web browser\n * implementations of `debug()`.\n */\n\nfunction setup(env) {\n\tcreateDebug.debug = createDebug;\n\tcreateDebug.default = createDebug;\n\tcreateDebug.coerce = coerce;\n\tcreateDebug.disable = disable;\n\tcreateDebug.enable = enable;\n\tcreateDebug.enabled = enabled;\n\tcreateDebug.humanize = require('ms');\n\tcreateDebug.destroy = destroy;\n\n\tObject.keys(env).forEach(key => {\n\t\tcreateDebug[key] = env[key];\n\t});\n\n\t/**\n\t* The currently active debug mode names, and names to skip.\n\t*/\n\n\tcreateDebug.names = [];\n\tcreateDebug.skips = [];\n\n\t/**\n\t* Map of special \"%n\" handling functions, for the debug \"format\" argument.\n\t*\n\t* Valid key names are a single, lower or upper-case letter, i.e. \"n\" and \"N\".\n\t*/\n\tcreateDebug.formatters = {};\n\n\t/**\n\t* Selects a color for a debug namespace\n\t* @param {String} namespace The namespace string for the debug instance to be colored\n\t* @return {Number|String} An ANSI color code for the given namespace\n\t* @api private\n\t*/\n\tfunction selectColor(namespace) {\n\t\tlet hash = 0;\n\n\t\tfor (let i = 0; i < namespace.length; i++) {\n\t\t\thash = ((hash << 5) - hash) + namespace.charCodeAt(i);\n\t\t\thash |= 0; // Convert to 32bit integer\n\t\t}\n\n\t\treturn createDebug.colors[Math.abs(hash) % createDebug.colors.length];\n\t}\n\tcreateDebug.selectColor = selectColor;\n\n\t/**\n\t* Create a debugger with the given `namespace`.\n\t*\n\t* @param {String} namespace\n\t* @return {Function}\n\t* @api public\n\t*/\n\tfunction createDebug(namespace) {\n\t\tlet prevTime;\n\t\tlet enableOverride = null;\n\t\tlet namespacesCache;\n\t\tlet enabledCache;\n\n\t\tfunction debug(...args) {\n\t\t\t// Disabled?\n\t\t\tif (!debug.enabled) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tconst self = debug;\n\n\t\t\t// Set `diff` timestamp\n\t\t\tconst curr = Number(new Date());\n\t\t\tconst ms = curr - (prevTime || curr);\n\t\t\tself.diff = ms;\n\t\t\tself.prev = prevTime;\n\t\t\tself.curr = curr;\n\t\t\tprevTime = curr;\n\n\t\t\targs[0] = createDebug.coerce(args[0]);\n\n\t\t\tif (typeof args[0] !== 'string') {\n\t\t\t\t// Anything else let's inspect with %O\n\t\t\t\targs.unshift('%O');\n\t\t\t}\n\n\t\t\t// Apply any `formatters` transformations\n\t\t\tlet index = 0;\n\t\t\targs[0] = args[0].replace(/%([a-zA-Z%])/g, (match, format) => {\n\t\t\t\t// If we encounter an escaped % then don't increase the array index\n\t\t\t\tif (match === '%%') {\n\t\t\t\t\treturn '%';\n\t\t\t\t}\n\t\t\t\tindex++;\n\t\t\t\tconst formatter = createDebug.formatters[format];\n\t\t\t\tif (typeof formatter === 'function') {\n\t\t\t\t\tconst val = args[index];\n\t\t\t\t\tmatch = formatter.call(self, val);\n\n\t\t\t\t\t// Now we need to remove `args[index]` since it's inlined in the `format`\n\t\t\t\t\targs.splice(index, 1);\n\t\t\t\t\tindex--;\n\t\t\t\t}\n\t\t\t\treturn match;\n\t\t\t});\n\n\t\t\t// Apply env-specific formatting (colors, etc.)\n\t\t\tcreateDebug.formatArgs.call(self, args);\n\n\t\t\tconst logFn = self.log || createDebug.log;\n\t\t\tlogFn.apply(self, args);\n\t\t}\n\n\t\tdebug.namespace = namespace;\n\t\tdebug.useColors = createDebug.useColors();\n\t\tdebug.color = createDebug.selectColor(namespace);\n\t\tdebug.extend = extend;\n\t\tdebug.destroy = createDebug.destroy; // XXX Temporary. Will be removed in the next major release.\n\n\t\tObject.defineProperty(debug, 'enabled', {\n\t\t\tenumerable: true,\n\t\t\tconfigurable: false,\n\t\t\tget: () => {\n\t\t\t\tif (enableOverride !== null) {\n\t\t\t\t\treturn enableOverride;\n\t\t\t\t}\n\t\t\t\tif (namespacesCache !== createDebug.namespaces) {\n\t\t\t\t\tnamespacesCache = createDebug.namespaces;\n\t\t\t\t\tenabledCache = createDebug.enabled(namespace);\n\t\t\t\t}\n\n\t\t\t\treturn enabledCache;\n\t\t\t},\n\t\t\tset: v => {\n\t\t\t\tenableOverride = v;\n\t\t\t}\n\t\t});\n\n\t\t// Env-specific initialization logic for debug instances\n\t\tif (typeof createDebug.init === 'function') {\n\t\t\tcreateDebug.init(debug);\n\t\t}\n\n\t\treturn debug;\n\t}\n\n\tfunction extend(namespace, delimiter) {\n\t\tconst newDebug = createDebug(this.namespace + (typeof delimiter === 'undefined' ? ':' : delimiter) + namespace);\n\t\tnewDebug.log = this.log;\n\t\treturn newDebug;\n\t}\n\n\t/**\n\t* Enables a debug mode by namespaces. This can include modes\n\t* separated by a colon and wildcards.\n\t*\n\t* @param {String} namespaces\n\t* @api public\n\t*/\n\tfunction enable(namespaces) {\n\t\tcreateDebug.save(namespaces);\n\t\tcreateDebug.namespaces = namespaces;\n\n\t\tcreateDebug.names = [];\n\t\tcreateDebug.skips = [];\n\n\t\tlet i;\n\t\tconst split = (typeof namespaces === 'string' ? namespaces : '').split(/[\\s,]+/);\n\t\tconst len = split.length;\n\n\t\tfor (i = 0; i < len; i++) {\n\t\t\tif (!split[i]) {\n\t\t\t\t// ignore empty strings\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tnamespaces = split[i].replace(/\\*/g, '.*?');\n\n\t\t\tif (namespaces[0] === '-') {\n\t\t\t\tcreateDebug.skips.push(new RegExp('^' + namespaces.slice(1) + '$'));\n\t\t\t} else {\n\t\t\t\tcreateDebug.names.push(new RegExp('^' + namespaces + '$'));\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t* Disable debug output.\n\t*\n\t* @return {String} namespaces\n\t* @api public\n\t*/\n\tfunction disable() {\n\t\tconst namespaces = [\n\t\t\t...createDebug.names.map(toNamespace),\n\t\t\t...createDebug.skips.map(toNamespace).map(namespace => '-' + namespace)\n\t\t].join(',');\n\t\tcreateDebug.enable('');\n\t\treturn namespaces;\n\t}\n\n\t/**\n\t* Returns true if the given mode name is enabled, false otherwise.\n\t*\n\t* @param {String} name\n\t* @return {Boolean}\n\t* @api public\n\t*/\n\tfunction enabled(name) {\n\t\tif (name[name.length - 1] === '*') {\n\t\t\treturn true;\n\t\t}\n\n\t\tlet i;\n\t\tlet len;\n\n\t\tfor (i = 0, len = createDebug.skips.length; i < len; i++) {\n\t\t\tif (createDebug.skips[i].test(name)) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t}\n\n\t\tfor (i = 0, len = createDebug.names.length; i < len; i++) {\n\t\t\tif (createDebug.names[i].test(name)) {\n\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\n\t\treturn false;\n\t}\n\n\t/**\n\t* Convert regexp to namespace\n\t*\n\t* @param {RegExp} regxep\n\t* @return {String} namespace\n\t* @api private\n\t*/\n\tfunction toNamespace(regexp) {\n\t\treturn regexp.toString()\n\t\t\t.substring(2, regexp.toString().length - 2)\n\t\t\t.replace(/\\.\\*\\?$/, '*');\n\t}\n\n\t/**\n\t* Coerce `val`.\n\t*\n\t* @param {Mixed} val\n\t* @return {Mixed}\n\t* @api private\n\t*/\n\tfunction coerce(val) {\n\t\tif (val instanceof Error) {\n\t\t\treturn val.stack || val.message;\n\t\t}\n\t\treturn val;\n\t}\n\n\t/**\n\t* XXX DO NOT USE. This is a temporary stub function.\n\t* XXX It WILL be removed in the next major release.\n\t*/\n\tfunction destroy() {\n\t\tconsole.warn('Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.');\n\t}\n\n\tcreateDebug.enable(createDebug.load());\n\n\treturn createDebug;\n}\n\nmodule.exports = setup;\n","/* eslint-env browser */\n\n/**\n * This is the web browser implementation of `debug()`.\n */\n\nexports.formatArgs = formatArgs;\nexports.save = save;\nexports.load = load;\nexports.useColors = useColors;\nexports.storage = localstorage();\nexports.destroy = (() => {\n\tlet warned = false;\n\n\treturn () => {\n\t\tif (!warned) {\n\t\t\twarned = true;\n\t\t\tconsole.warn('Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.');\n\t\t}\n\t};\n})();\n\n/**\n * Colors.\n */\n\nexports.colors = [\n\t'#0000CC',\n\t'#0000FF',\n\t'#0033CC',\n\t'#0033FF',\n\t'#0066CC',\n\t'#0066FF',\n\t'#0099CC',\n\t'#0099FF',\n\t'#00CC00',\n\t'#00CC33',\n\t'#00CC66',\n\t'#00CC99',\n\t'#00CCCC',\n\t'#00CCFF',\n\t'#3300CC',\n\t'#3300FF',\n\t'#3333CC',\n\t'#3333FF',\n\t'#3366CC',\n\t'#3366FF',\n\t'#3399CC',\n\t'#3399FF',\n\t'#33CC00',\n\t'#33CC33',\n\t'#33CC66',\n\t'#33CC99',\n\t'#33CCCC',\n\t'#33CCFF',\n\t'#6600CC',\n\t'#6600FF',\n\t'#6633CC',\n\t'#6633FF',\n\t'#66CC00',\n\t'#66CC33',\n\t'#9900CC',\n\t'#9900FF',\n\t'#9933CC',\n\t'#9933FF',\n\t'#99CC00',\n\t'#99CC33',\n\t'#CC0000',\n\t'#CC0033',\n\t'#CC0066',\n\t'#CC0099',\n\t'#CC00CC',\n\t'#CC00FF',\n\t'#CC3300',\n\t'#CC3333',\n\t'#CC3366',\n\t'#CC3399',\n\t'#CC33CC',\n\t'#CC33FF',\n\t'#CC6600',\n\t'#CC6633',\n\t'#CC9900',\n\t'#CC9933',\n\t'#CCCC00',\n\t'#CCCC33',\n\t'#FF0000',\n\t'#FF0033',\n\t'#FF0066',\n\t'#FF0099',\n\t'#FF00CC',\n\t'#FF00FF',\n\t'#FF3300',\n\t'#FF3333',\n\t'#FF3366',\n\t'#FF3399',\n\t'#FF33CC',\n\t'#FF33FF',\n\t'#FF6600',\n\t'#FF6633',\n\t'#FF9900',\n\t'#FF9933',\n\t'#FFCC00',\n\t'#FFCC33'\n];\n\n/**\n * Currently only WebKit-based Web Inspectors, Firefox >= v31,\n * and the Firebug extension (any Firefox version) are known\n * to support \"%c\" CSS customizations.\n *\n * TODO: add a `localStorage` variable to explicitly enable/disable colors\n */\n\n// eslint-disable-next-line complexity\nfunction useColors() {\n\t// NB: In an Electron preload script, document will be defined but not fully\n\t// initialized. Since we know we're in Chrome, we'll just detect this case\n\t// explicitly\n\tif (typeof window !== 'undefined' && window.process && (window.process.type === 'renderer' || window.process.__nwjs)) {\n\t\treturn true;\n\t}\n\n\t// Internet Explorer and Edge do not support colors.\n\tif (typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/(edge|trident)\\/(\\d+)/)) {\n\t\treturn false;\n\t}\n\n\t// Is webkit? http://stackoverflow.com/a/16459606/376773\n\t// document is undefined in react-native: https://github.com/facebook/react-native/pull/1632\n\treturn (typeof document !== 'undefined' && document.documentElement && document.documentElement.style && document.documentElement.style.WebkitAppearance) ||\n\t\t// Is firebug? http://stackoverflow.com/a/398120/376773\n\t\t(typeof window !== 'undefined' && window.console && (window.console.firebug || (window.console.exception && window.console.table))) ||\n\t\t// Is firefox >= v31?\n\t\t// https://developer.mozilla.org/en-US/docs/Tools/Web_Console#Styling_messages\n\t\t(typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/firefox\\/(\\d+)/) && parseInt(RegExp.$1, 10) >= 31) ||\n\t\t// Double check webkit in userAgent just in case we are in a worker\n\t\t(typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/applewebkit\\/(\\d+)/));\n}\n\n/**\n * Colorize log arguments if enabled.\n *\n * @api public\n */\n\nfunction formatArgs(args) {\n\targs[0] = (this.useColors ? '%c' : '') +\n\t\tthis.namespace +\n\t\t(this.useColors ? ' %c' : ' ') +\n\t\targs[0] +\n\t\t(this.useColors ? '%c ' : ' ') +\n\t\t'+' + module.exports.humanize(this.diff);\n\n\tif (!this.useColors) {\n\t\treturn;\n\t}\n\n\tconst c = 'color: ' + this.color;\n\targs.splice(1, 0, c, 'color: inherit');\n\n\t// The final \"%c\" is somewhat tricky, because there could be other\n\t// arguments passed either before or after the %c, so we need to\n\t// figure out the correct index to insert the CSS into\n\tlet index = 0;\n\tlet lastC = 0;\n\targs[0].replace(/%[a-zA-Z%]/g, match => {\n\t\tif (match === '%%') {\n\t\t\treturn;\n\t\t}\n\t\tindex++;\n\t\tif (match === '%c') {\n\t\t\t// We only are interested in the *last* %c\n\t\t\t// (the user may have provided their own)\n\t\t\tlastC = index;\n\t\t}\n\t});\n\n\targs.splice(lastC, 0, c);\n}\n\n/**\n * Invokes `console.debug()` when available.\n * No-op when `console.debug` is not a \"function\".\n * If `console.debug` is not available, falls back\n * to `console.log`.\n *\n * @api public\n */\nexports.log = console.debug || console.log || (() => {});\n\n/**\n * Save `namespaces`.\n *\n * @param {String} namespaces\n * @api private\n */\nfunction save(namespaces) {\n\ttry {\n\t\tif (namespaces) {\n\t\t\texports.storage.setItem('debug', namespaces);\n\t\t} else {\n\t\t\texports.storage.removeItem('debug');\n\t\t}\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n}\n\n/**\n * Load `namespaces`.\n *\n * @return {String} returns the previously persisted debug modes\n * @api private\n */\nfunction load() {\n\tlet r;\n\ttry {\n\t\tr = exports.storage.getItem('debug');\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n\n\t// If debug isn't set in LS, and we're in Electron, try to load $DEBUG\n\tif (!r && typeof process !== 'undefined' && 'env' in process) {\n\t\tr = process.env.DEBUG;\n\t}\n\n\treturn r;\n}\n\n/**\n * Localstorage attempts to return the localstorage.\n *\n * This is necessary because safari throws\n * when a user disables cookies/localstorage\n * and you attempt to access it.\n *\n * @return {LocalStorage}\n * @api private\n */\n\nfunction localstorage() {\n\ttry {\n\t\t// TVMLKit (Apple TV JS Runtime) does not have a window object, just localStorage in the global context\n\t\t// The Browser also has localStorage in the global context.\n\t\treturn localStorage;\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n}\n\nmodule.exports = require('./common')(exports);\n\nconst {formatters} = module.exports;\n\n/**\n * Map %j to `JSON.stringify()`, since no Web Inspectors do that by default.\n */\n\nformatters.j = function (v) {\n\ttry {\n\t\treturn JSON.stringify(v);\n\t} catch (error) {\n\t\treturn '[UnexpectedJSONParseError]: ' + error.message;\n\t}\n};\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\nvar R = typeof Reflect === 'object' ? Reflect : null\nvar ReflectApply = R && typeof R.apply === 'function'\n ? R.apply\n : function ReflectApply(target, receiver, args) {\n return Function.prototype.apply.call(target, receiver, args);\n }\n\nvar ReflectOwnKeys\nif (R && typeof R.ownKeys === 'function') {\n ReflectOwnKeys = R.ownKeys\n} else if (Object.getOwnPropertySymbols) {\n ReflectOwnKeys = function ReflectOwnKeys(target) {\n return Object.getOwnPropertyNames(target)\n .concat(Object.getOwnPropertySymbols(target));\n };\n} else {\n ReflectOwnKeys = function ReflectOwnKeys(target) {\n return Object.getOwnPropertyNames(target);\n };\n}\n\nfunction ProcessEmitWarning(warning) {\n if (console && console.warn) console.warn(warning);\n}\n\nvar NumberIsNaN = Number.isNaN || function NumberIsNaN(value) {\n return value !== value;\n}\n\nfunction EventEmitter() {\n EventEmitter.init.call(this);\n}\nmodule.exports = EventEmitter;\nmodule.exports.once = once;\n\n// Backwards-compat with node 0.10.x\nEventEmitter.EventEmitter = EventEmitter;\n\nEventEmitter.prototype._events = undefined;\nEventEmitter.prototype._eventsCount = 0;\nEventEmitter.prototype._maxListeners = undefined;\n\n// By default EventEmitters will print a warning if more than 10 listeners are\n// added to it. This is a useful default which helps finding memory leaks.\nvar defaultMaxListeners = 10;\n\nfunction checkListener(listener) {\n if (typeof listener !== 'function') {\n throw new TypeError('The \"listener\" argument must be of type Function. Received type ' + typeof listener);\n }\n}\n\nObject.defineProperty(EventEmitter, 'defaultMaxListeners', {\n enumerable: true,\n get: function() {\n return defaultMaxListeners;\n },\n set: function(arg) {\n if (typeof arg !== 'number' || arg < 0 || NumberIsNaN(arg)) {\n throw new RangeError('The value of \"defaultMaxListeners\" is out of range. It must be a non-negative number. Received ' + arg + '.');\n }\n defaultMaxListeners = arg;\n }\n});\n\nEventEmitter.init = function() {\n\n if (this._events === undefined ||\n this._events === Object.getPrototypeOf(this)._events) {\n this._events = Object.create(null);\n this._eventsCount = 0;\n }\n\n this._maxListeners = this._maxListeners || undefined;\n};\n\n// Obviously not all Emitters should be limited to 10. This function allows\n// that to be increased. Set to zero for unlimited.\nEventEmitter.prototype.setMaxListeners = function setMaxListeners(n) {\n if (typeof n !== 'number' || n < 0 || NumberIsNaN(n)) {\n throw new RangeError('The value of \"n\" is out of range. It must be a non-negative number. Received ' + n + '.');\n }\n this._maxListeners = n;\n return this;\n};\n\nfunction _getMaxListeners(that) {\n if (that._maxListeners === undefined)\n return EventEmitter.defaultMaxListeners;\n return that._maxListeners;\n}\n\nEventEmitter.prototype.getMaxListeners = function getMaxListeners() {\n return _getMaxListeners(this);\n};\n\nEventEmitter.prototype.emit = function emit(type) {\n var args = [];\n for (var i = 1; i < arguments.length; i++) args.push(arguments[i]);\n var doError = (type === 'error');\n\n var events = this._events;\n if (events !== undefined)\n doError = (doError && events.error === undefined);\n else if (!doError)\n return false;\n\n // If there is no 'error' event listener then throw.\n if (doError) {\n var er;\n if (args.length > 0)\n er = args[0];\n if (er instanceof Error) {\n // Note: The comments on the `throw` lines are intentional, they show\n // up in Node's output if this results in an unhandled exception.\n throw er; // Unhandled 'error' event\n }\n // At least give some kind of context to the user\n var err = new Error('Unhandled error.' + (er ? ' (' + er.message + ')' : ''));\n err.context = er;\n throw err; // Unhandled 'error' event\n }\n\n var handler = events[type];\n\n if (handler === undefined)\n return false;\n\n if (typeof handler === 'function') {\n ReflectApply(handler, this, args);\n } else {\n var len = handler.length;\n var listeners = arrayClone(handler, len);\n for (var i = 0; i < len; ++i)\n ReflectApply(listeners[i], this, args);\n }\n\n return true;\n};\n\nfunction _addListener(target, type, listener, prepend) {\n var m;\n var events;\n var existing;\n\n checkListener(listener);\n\n events = target._events;\n if (events === undefined) {\n events = target._events = Object.create(null);\n target._eventsCount = 0;\n } else {\n // To avoid recursion in the case that type === \"newListener\"! Before\n // adding it to the listeners, first emit \"newListener\".\n if (events.newListener !== undefined) {\n target.emit('newListener', type,\n listener.listener ? listener.listener : listener);\n\n // Re-assign `events` because a newListener handler could have caused the\n // this._events to be assigned to a new object\n events = target._events;\n }\n existing = events[type];\n }\n\n if (existing === undefined) {\n // Optimize the case of one listener. Don't need the extra array object.\n existing = events[type] = listener;\n ++target._eventsCount;\n } else {\n if (typeof existing === 'function') {\n // Adding the second element, need to change to array.\n existing = events[type] =\n prepend ? [listener, existing] : [existing, listener];\n // If we've already got an array, just append.\n } else if (prepend) {\n existing.unshift(listener);\n } else {\n existing.push(listener);\n }\n\n // Check for listener leak\n m = _getMaxListeners(target);\n if (m > 0 && existing.length > m && !existing.warned) {\n existing.warned = true;\n // No error code for this since it is a Warning\n // eslint-disable-next-line no-restricted-syntax\n var w = new Error('Possible EventEmitter memory leak detected. ' +\n existing.length + ' ' + String(type) + ' listeners ' +\n 'added. Use emitter.setMaxListeners() to ' +\n 'increase limit');\n w.name = 'MaxListenersExceededWarning';\n w.emitter = target;\n w.type = type;\n w.count = existing.length;\n ProcessEmitWarning(w);\n }\n }\n\n return target;\n}\n\nEventEmitter.prototype.addListener = function addListener(type, listener) {\n return _addListener(this, type, listener, false);\n};\n\nEventEmitter.prototype.on = EventEmitter.prototype.addListener;\n\nEventEmitter.prototype.prependListener =\n function prependListener(type, listener) {\n return _addListener(this, type, listener, true);\n };\n\nfunction onceWrapper() {\n if (!this.fired) {\n this.target.removeListener(this.type, this.wrapFn);\n this.fired = true;\n if (arguments.length === 0)\n return this.listener.call(this.target);\n return this.listener.apply(this.target, arguments);\n }\n}\n\nfunction _onceWrap(target, type, listener) {\n var state = { fired: false, wrapFn: undefined, target: target, type: type, listener: listener };\n var wrapped = onceWrapper.bind(state);\n wrapped.listener = listener;\n state.wrapFn = wrapped;\n return wrapped;\n}\n\nEventEmitter.prototype.once = function once(type, listener) {\n checkListener(listener);\n this.on(type, _onceWrap(this, type, listener));\n return this;\n};\n\nEventEmitter.prototype.prependOnceListener =\n function prependOnceListener(type, listener) {\n checkListener(listener);\n this.prependListener(type, _onceWrap(this, type, listener));\n return this;\n };\n\n// Emits a 'removeListener' event if and only if the listener was removed.\nEventEmitter.prototype.removeListener =\n function removeListener(type, listener) {\n var list, events, position, i, originalListener;\n\n checkListener(listener);\n\n events = this._events;\n if (events === undefined)\n return this;\n\n list = events[type];\n if (list === undefined)\n return this;\n\n if (list === listener || list.listener === listener) {\n if (--this._eventsCount === 0)\n this._events = Object.create(null);\n else {\n delete events[type];\n if (events.removeListener)\n this.emit('removeListener', type, list.listener || listener);\n }\n } else if (typeof list !== 'function') {\n position = -1;\n\n for (i = list.length - 1; i >= 0; i--) {\n if (list[i] === listener || list[i].listener === listener) {\n originalListener = list[i].listener;\n position = i;\n break;\n }\n }\n\n if (position < 0)\n return this;\n\n if (position === 0)\n list.shift();\n else {\n spliceOne(list, position);\n }\n\n if (list.length === 1)\n events[type] = list[0];\n\n if (events.removeListener !== undefined)\n this.emit('removeListener', type, originalListener || listener);\n }\n\n return this;\n };\n\nEventEmitter.prototype.off = EventEmitter.prototype.removeListener;\n\nEventEmitter.prototype.removeAllListeners =\n function removeAllListeners(type) {\n var listeners, events, i;\n\n events = this._events;\n if (events === undefined)\n return this;\n\n // not listening for removeListener, no need to emit\n if (events.removeListener === undefined) {\n if (arguments.length === 0) {\n this._events = Object.create(null);\n this._eventsCount = 0;\n } else if (events[type] !== undefined) {\n if (--this._eventsCount === 0)\n this._events = Object.create(null);\n else\n delete events[type];\n }\n return this;\n }\n\n // emit removeListener for all listeners on all events\n if (arguments.length === 0) {\n var keys = Object.keys(events);\n var key;\n for (i = 0; i < keys.length; ++i) {\n key = keys[i];\n if (key === 'removeListener') continue;\n this.removeAllListeners(key);\n }\n this.removeAllListeners('removeListener');\n this._events = Object.create(null);\n this._eventsCount = 0;\n return this;\n }\n\n listeners = events[type];\n\n if (typeof listeners === 'function') {\n this.removeListener(type, listeners);\n } else if (listeners !== undefined) {\n // LIFO order\n for (i = listeners.length - 1; i >= 0; i--) {\n this.removeListener(type, listeners[i]);\n }\n }\n\n return this;\n };\n\nfunction _listeners(target, type, unwrap) {\n var events = target._events;\n\n if (events === undefined)\n return [];\n\n var evlistener = events[type];\n if (evlistener === undefined)\n return [];\n\n if (typeof evlistener === 'function')\n return unwrap ? [evlistener.listener || evlistener] : [evlistener];\n\n return unwrap ?\n unwrapListeners(evlistener) : arrayClone(evlistener, evlistener.length);\n}\n\nEventEmitter.prototype.listeners = function listeners(type) {\n return _listeners(this, type, true);\n};\n\nEventEmitter.prototype.rawListeners = function rawListeners(type) {\n return _listeners(this, type, false);\n};\n\nEventEmitter.listenerCount = function(emitter, type) {\n if (typeof emitter.listenerCount === 'function') {\n return emitter.listenerCount(type);\n } else {\n return listenerCount.call(emitter, type);\n }\n};\n\nEventEmitter.prototype.listenerCount = listenerCount;\nfunction listenerCount(type) {\n var events = this._events;\n\n if (events !== undefined) {\n var evlistener = events[type];\n\n if (typeof evlistener === 'function') {\n return 1;\n } else if (evlistener !== undefined) {\n return evlistener.length;\n }\n }\n\n return 0;\n}\n\nEventEmitter.prototype.eventNames = function eventNames() {\n return this._eventsCount > 0 ? ReflectOwnKeys(this._events) : [];\n};\n\nfunction arrayClone(arr, n) {\n var copy = new Array(n);\n for (var i = 0; i < n; ++i)\n copy[i] = arr[i];\n return copy;\n}\n\nfunction spliceOne(list, index) {\n for (; index + 1 < list.length; index++)\n list[index] = list[index + 1];\n list.pop();\n}\n\nfunction unwrapListeners(arr) {\n var ret = new Array(arr.length);\n for (var i = 0; i < ret.length; ++i) {\n ret[i] = arr[i].listener || arr[i];\n }\n return ret;\n}\n\nfunction once(emitter, name) {\n return new Promise(function (resolve, reject) {\n function errorListener(err) {\n emitter.removeListener(name, resolver);\n reject(err);\n }\n\n function resolver() {\n if (typeof emitter.removeListener === 'function') {\n emitter.removeListener('error', errorListener);\n }\n resolve([].slice.call(arguments));\n };\n\n eventTargetAgnosticAddListener(emitter, name, resolver, { once: true });\n if (name !== 'error') {\n addErrorHandlerIfEventEmitter(emitter, errorListener, { once: true });\n }\n });\n}\n\nfunction addErrorHandlerIfEventEmitter(emitter, handler, flags) {\n if (typeof emitter.on === 'function') {\n eventTargetAgnosticAddListener(emitter, 'error', handler, flags);\n }\n}\n\nfunction eventTargetAgnosticAddListener(emitter, name, listener, flags) {\n if (typeof emitter.on === 'function') {\n if (flags.once) {\n emitter.once(name, listener);\n } else {\n emitter.on(name, listener);\n }\n } else if (typeof emitter.addEventListener === 'function') {\n // EventTarget does not have `error` event semantics like Node\n // EventEmitters, we do not listen for `error` events here.\n emitter.addEventListener(name, function wrapListener(arg) {\n // IE does not have builtin `{ once: true }` support so we\n // have to do it manually.\n if (flags.once) {\n emitter.removeEventListener(name, wrapListener);\n }\n listener(arg);\n });\n } else {\n throw new TypeError('The \"emitter\" argument must be of type EventEmitter. Received type ' + typeof emitter);\n }\n}\n","\"use strict\";\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __spreadArrays = (this && this.__spreadArrays) || function () {\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\n r[k] = a[j];\n return r;\n};\nexports.__esModule = true;\nexports.StrictEventEmitter = void 0;\nvar events_1 = require(\"events\");\nvar StrictEventEmitter = /** @class */ (function (_super) {\n __extends(StrictEventEmitter, _super);\n function StrictEventEmitter() {\n return _super.call(this) || this;\n }\n StrictEventEmitter.prototype.on = function (event, listener) {\n return _super.prototype.on.call(this, event.toString(), listener);\n };\n StrictEventEmitter.prototype.once = function (event, listener) {\n return _super.prototype.once.call(this, event.toString(), listener);\n };\n StrictEventEmitter.prototype.off = function (event, listener) {\n return _super.prototype.off.call(this, event.toString(), listener);\n };\n StrictEventEmitter.prototype.emit = function (event) {\n var data = [];\n for (var _i = 1; _i < arguments.length; _i++) {\n data[_i - 1] = arguments[_i];\n }\n return _super.prototype.emit.apply(this, __spreadArrays([event.toString()], data));\n };\n StrictEventEmitter.prototype.addListener = function (event, listener) {\n return _super.prototype.addListener.call(this, event.toString(), listener);\n };\n StrictEventEmitter.prototype.prependListener = function (event, listener) {\n return _super.prototype.prependListener.call(this, event.toString(), listener);\n };\n StrictEventEmitter.prototype.prependOnceListener = function (event, listener) {\n return _super.prototype.prependOnceListener.call(this, event.toString(), listener);\n };\n StrictEventEmitter.prototype.removeListener = function (event, listener) {\n return _super.prototype.removeListener.call(this, event.toString(), listener);\n };\n StrictEventEmitter.prototype.removeAllListeners = function (event) {\n if (event) {\n return _super.prototype.removeAllListeners.call(this, event.toString());\n }\n return _super.prototype.removeAllListeners.call(this);\n };\n StrictEventEmitter.prototype.eventNames = function () {\n return _super.prototype.eventNames.call(this);\n };\n StrictEventEmitter.prototype.listeners = function (event) {\n return _super.prototype.listeners.call(this, event.toString());\n };\n StrictEventEmitter.prototype.rawListeners = function (event) {\n return _super.prototype.rawListeners.call(this, event.toString());\n };\n StrictEventEmitter.prototype.listenerCount = function (event) {\n return _super.prototype.listenerCount.call(this, event.toString());\n };\n return StrictEventEmitter;\n}(events_1.EventEmitter));\nexports.StrictEventEmitter = StrictEventEmitter;\n","\"use strict\";\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __exportStar = (this && this.__exportStar) || function(m, exports) {\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);\n};\nexports.__esModule = true;\n__exportStar(require(\"./StrictEventEmitter\"), exports);\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.nextTickAsync = exports.nextTick = void 0;\nfunction nextTick(callback) {\n setTimeout(callback, 0);\n}\nexports.nextTick = nextTick;\nfunction nextTickAsync(callback) {\n return new Promise(function (resolve) {\n setTimeout(function () {\n resolve(callback());\n }, 0);\n });\n}\nexports.nextTickAsync = nextTickAsync;\n//# sourceMappingURL=nextTick.js.map","\"use strict\";\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nvar __generator = (this && this.__generator) || function (thisArg, body) {\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\n function verb(n) { return function (v) { return step([n, v]); }; }\n function step(op) {\n if (f) throw new TypeError(\"Generator is already executing.\");\n while (_) try {\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\n if (y = 0, t) op = [op[0] & 2, t.value];\n switch (op[0]) {\n case 0: case 1: t = op; break;\n case 4: _.label++; return { value: op[1], done: false };\n case 5: _.label++; y = op[1]; op = [0]; continue;\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\n if (t[2]) _.ops.pop();\n _.trys.pop(); continue;\n }\n op = body.call(thisArg, _);\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\n }\n};\nvar __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nvar __spreadArray = (this && this.__spreadArray) || function (to, from) {\n for (var i = 0, il = from.length, j = to.length; i < il; i++, j++)\n to[j] = from[i];\n return to;\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.AsyncEventEmitter = exports.AsyncEventEmitterReadyState = void 0;\nvar debug_1 = require(\"debug\");\nvar strict_event_emitter_1 = require(\"strict-event-emitter\");\nvar nextTick_1 = require(\"./nextTick\");\nvar AsyncEventEmitterReadyState;\n(function (AsyncEventEmitterReadyState) {\n AsyncEventEmitterReadyState[\"ACTIVE\"] = \"ACTIVE\";\n AsyncEventEmitterReadyState[\"DEACTIVATED\"] = \"DEACTIVATED\";\n})(AsyncEventEmitterReadyState = exports.AsyncEventEmitterReadyState || (exports.AsyncEventEmitterReadyState = {}));\nvar AsyncEventEmitter = /** @class */ (function (_super) {\n __extends(AsyncEventEmitter, _super);\n function AsyncEventEmitter() {\n var _this = _super.call(this) || this;\n _this.log = debug_1.debug('async-event-emitter');\n _this.queue = new Map();\n _this.readyState = AsyncEventEmitterReadyState.ACTIVE;\n return _this;\n }\n AsyncEventEmitter.prototype.on = function (event, listener) {\n var _this = this;\n var log = this.log.extend('on');\n log('adding \"%s\" listener...', event);\n if (this.readyState === AsyncEventEmitterReadyState.DEACTIVATED) {\n log('the emitter is destroyed, skipping!');\n return this;\n }\n return _super.prototype.on.call(this, event, (function () {\n var args = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n args[_i] = arguments[_i];\n }\n return __awaiter(_this, void 0, void 0, function () {\n var queue;\n var _this = this;\n return __generator(this, function (_a) {\n queue = this.openListenerQueue(event);\n log('awaiting the \"%s\" listener...', event);\n // Whenever a listener is called, create a new Promise\n // that resolves when that listener function completes its execution.\n queue.push({\n args: args,\n done: new Promise(function (resolve, reject) { return __awaiter(_this, void 0, void 0, function () {\n var error_1;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n _a.trys.push([0, 2, , 3]);\n // Treat listeners as potentially asynchronous functions\n // so they could be awaited.\n return [4 /*yield*/, listener.apply(void 0, __spreadArray([], __read(args)))];\n case 1:\n // Treat listeners as potentially asynchronous functions\n // so they could be awaited.\n _a.sent();\n resolve();\n log('\"%s\" listener has resolved!', event);\n return [3 /*break*/, 3];\n case 2:\n error_1 = _a.sent();\n log('\"%s\" listener has rejected!', error_1);\n reject(error_1);\n return [3 /*break*/, 3];\n case 3: return [2 /*return*/];\n }\n });\n }); }),\n });\n return [2 /*return*/];\n });\n });\n }));\n };\n AsyncEventEmitter.prototype.emit = function (event) {\n var _this = this;\n var args = [];\n for (var _i = 1; _i < arguments.length; _i++) {\n args[_i - 1] = arguments[_i];\n }\n var log = this.log.extend('emit');\n log('emitting \"%s\" event...', event);\n if (this.readyState === AsyncEventEmitterReadyState.DEACTIVATED) {\n log('the emitter is destroyed, skipping!');\n return false;\n }\n // Establish the Promise queue for this particular event.\n this.openListenerQueue(event);\n log('appending a one-time cleanup \"%s\" listener...', event);\n // Append a one-time clean up listener.\n this.once(event, (function () {\n // Clear the Promise queue for this particular event\n // in the next tick so the Promise in \"untilIdle\" has\n // time to properly resolve.\n nextTick_1.nextTick(function () {\n _this.queue.delete(event);\n log('cleaned up \"%s\" listeners queue!', event);\n });\n }));\n return _super.prototype.emit.apply(this, __spreadArray([event], __read(args)));\n };\n /**\n * Returns a promise that resolves when all the listeners for the given event\n * has been called. Awaits asynchronous listeners.\n * If the event has no listeners, resolves immediately.\n */\n AsyncEventEmitter.prototype.untilIdle = function (event, filter) {\n if (filter === void 0) { filter = function () {\n return true;\n }; }\n return __awaiter(this, void 0, void 0, function () {\n var listenersQueue;\n var _this = this;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n listenersQueue = this.queue.get(event) || [];\n return [4 /*yield*/, Promise.all(listenersQueue.filter(filter).map(function (_a) {\n var done = _a.done;\n return done;\n })).finally(function () {\n // Clear the queue one the promise settles\n // so that different events don't share the same queue.\n _this.queue.delete(event);\n })];\n case 1:\n _a.sent();\n return [2 /*return*/];\n }\n });\n });\n };\n AsyncEventEmitter.prototype.openListenerQueue = function (event) {\n var log = this.log.extend('openListenerQueue');\n log('opening \"%s\" listeners queue...', event);\n var queue = this.queue.get(event);\n if (!queue) {\n log('no queue found, creating one...');\n this.queue.set(event, []);\n return [];\n }\n log('returning an exising queue:', queue);\n return queue;\n };\n AsyncEventEmitter.prototype.removeAllListeners = function (event) {\n var log = this.log.extend('removeAllListeners');\n log('event:', event);\n if (event) {\n this.queue.delete(event);\n log('cleared the \"%s\" listeners queue!', event, this.queue.get(event));\n }\n else {\n this.queue.clear();\n log('cleared the listeners queue!', this.queue);\n }\n return _super.prototype.removeAllListeners.call(this, event);\n };\n AsyncEventEmitter.prototype.activate = function () {\n var log = this.log.extend('activate');\n this.readyState = AsyncEventEmitterReadyState.ACTIVE;\n log('set state to:', this.readyState);\n };\n /**\n * Deactivate this event emitter.\n * Deactivated emitter can no longer emit and listen to events\n * and needs to be activated again in order to do so.\n */\n AsyncEventEmitter.prototype.deactivate = function () {\n var log = this.log.extend('deactivate');\n log('removing all listeners...');\n this.removeAllListeners();\n this.readyState = AsyncEventEmitterReadyState.DEACTIVATED;\n log('set state to:', this.readyState);\n };\n return AsyncEventEmitter;\n}(strict_event_emitter_1.StrictEventEmitter));\nexports.AsyncEventEmitter = AsyncEventEmitter;\n//# sourceMappingURL=AsyncEventEmitter.js.map","\"use strict\";\nvar __values = (this && this.__values) || function(o) {\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\n if (m) return m.call(o);\n if (o && typeof o.length === \"number\") return {\n next: function () {\n if (o && i >= o.length) o = void 0;\n return { value: o && o[i++], done: !o };\n }\n };\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.Interceptor = exports.InterceptorReadyState = exports.deleteGlobalSymbol = exports.getGlobalSymbol = void 0;\nvar debug_1 = require(\"debug\");\nvar AsyncEventEmitter_1 = require(\"./utils/AsyncEventEmitter\");\nvar nextTick_1 = require(\"./utils/nextTick\");\nfunction getGlobalSymbol(symbol) {\n return (\n // @ts-ignore https://github.com/Microsoft/TypeScript/issues/24587\n globalThis[symbol] || undefined);\n}\nexports.getGlobalSymbol = getGlobalSymbol;\nfunction setGlobalSymbol(symbol, value) {\n // @ts-ignore\n globalThis[symbol] = value;\n}\nfunction deleteGlobalSymbol(symbol) {\n // @ts-ignore\n delete globalThis[symbol];\n}\nexports.deleteGlobalSymbol = deleteGlobalSymbol;\nvar InterceptorReadyState;\n(function (InterceptorReadyState) {\n InterceptorReadyState[\"IDLE\"] = \"IDLE\";\n InterceptorReadyState[\"APPLYING\"] = \"APPLYING\";\n InterceptorReadyState[\"APPLIED\"] = \"APPLIED\";\n InterceptorReadyState[\"DISPOSING\"] = \"DISPOSING\";\n InterceptorReadyState[\"DISPOSED\"] = \"DISPOSED\";\n})(InterceptorReadyState = exports.InterceptorReadyState || (exports.InterceptorReadyState = {}));\nvar Interceptor = /** @class */ (function () {\n function Interceptor(symbol) {\n this.symbol = symbol;\n this.readyState = InterceptorReadyState.IDLE;\n this.emitter = new AsyncEventEmitter_1.AsyncEventEmitter();\n this.subscriptions = [];\n this.log = debug_1.debug(symbol.description);\n // Do not limit the maximum number of listeners\n // so not to limit the maximum amount of parallel events emitted.\n this.emitter.setMaxListeners(0);\n this.log('constructing the interceptor...');\n }\n /**\n * Determine if this interceptor can be applied\n * in the current environment.\n */\n Interceptor.prototype.checkEnvironment = function () {\n return true;\n };\n /**\n * Apply this interceptor to the current process.\n * Returns an already running interceptor instance if it's present.\n */\n Interceptor.prototype.apply = function () {\n var _this = this;\n var log = this.log.extend('apply');\n log('applying the interceptor...');\n if (this.readyState === InterceptorReadyState.APPLIED) {\n log('intercepted already applied!');\n return;\n }\n var shouldApply = this.checkEnvironment();\n if (!shouldApply) {\n log('the interceptor cannot be applied in this environment!');\n return;\n }\n this.readyState = InterceptorReadyState.APPLYING;\n // Always activate the emitter when applying the interceptor.\n // This will ensure the interceptor can process events after it's\n // been disposed and re-applied again (it may be a singleton).\n this.emitter.activate();\n log('activated the emiter!', this.emitter.readyState);\n // Whenever applying a new interceptor, check if it hasn't been applied already.\n // This enables to apply the same interceptor multiple times, for example from a different\n // interceptor, only proxying events but keeping the stubs in a single place.\n var runningInstance = this.getInstance();\n if (runningInstance) {\n log('found a running instance, reusing...');\n // Proxy any listeners you set on this instance to the running instance.\n this.on = function (event, listener) {\n log('proxying the \"%s\" listener', event);\n // Add listeners to the running instance so they appear\n // at the top of the event listeners list and are executed first.\n runningInstance.emitter.addListener(event, listener);\n // Ensure that once this interceptor instance is disposed,\n // it removes all listeners it has appended to the running interceptor instance.\n _this.subscriptions.push(function () {\n runningInstance.emitter.removeListener(event, listener);\n log('removed proxied \"%s\" listener!', event);\n });\n };\n nextTick_1.nextTick(function () {\n _this.readyState = InterceptorReadyState.APPLIED;\n });\n return;\n }\n log('no running instance found, setting up a new instance...');\n // Setup the interceptor.\n this.setup();\n // Store the newly applied interceptor instance globally.\n this.setInstance();\n nextTick_1.nextTick(function () {\n _this.readyState = InterceptorReadyState.APPLIED;\n });\n };\n /**\n * Setup the module augments and stubs necessary for this interceptor.\n * This method is not run if there's a running interceptor instance\n * to prevent instantiating an interceptor multiple times.\n */\n Interceptor.prototype.setup = function () { };\n /**\n * Listen to the interceptor's public events.\n */\n Interceptor.prototype.on = function (event, listener) {\n var log = this.log.extend('on');\n if (this.readyState === InterceptorReadyState.DISPOSING ||\n this.readyState === InterceptorReadyState.DISPOSED) {\n log('cannot listen to events, already disposed!');\n return;\n }\n log('adding \"%s\" event listener:', event, listener.name);\n this.emitter.on(event, listener);\n };\n /**\n * Disposes of any side-effects this interceptor has introduced.\n */\n Interceptor.prototype.dispose = function () {\n var e_1, _a;\n var _this = this;\n var log = this.log.extend('dispose');\n if (this.readyState === InterceptorReadyState.DISPOSED) {\n log('cannot dispose, already disposed!');\n return;\n }\n log('disposing the interceptor...');\n this.readyState = InterceptorReadyState.DISPOSING;\n if (!this.getInstance()) {\n log('no interceptors running, skipping dispose...');\n return;\n }\n // Delete the global symbol as soon as possible,\n // indicating that the interceptor is no longer running.\n this.clearInstance();\n log('global symbol deleted:', getGlobalSymbol(this.symbol));\n if (this.subscriptions.length > 0) {\n log('disposing of %d subscriptions...', this.subscriptions.length);\n try {\n for (var _b = __values(this.subscriptions), _c = _b.next(); !_c.done; _c = _b.next()) {\n var dispose = _c.value;\n dispose();\n }\n }\n catch (e_1_1) { e_1 = { error: e_1_1 }; }\n finally {\n try {\n if (_c && !_c.done && (_a = _b.return)) _a.call(_b);\n }\n finally { if (e_1) throw e_1.error; }\n }\n this.subscriptions = [];\n log('disposed of all subscriptions!', this.subscriptions.length);\n }\n this.emitter.deactivate();\n log('destroyed the listener!');\n nextTick_1.nextTick(function () {\n _this.readyState = InterceptorReadyState.DISPOSED;\n });\n };\n Interceptor.prototype.getInstance = function () {\n var _a;\n var instance = getGlobalSymbol(this.symbol);\n this.log('retrieved global instance:', (_a = instance === null || instance === void 0 ? void 0 : instance.constructor) === null || _a === void 0 ? void 0 : _a.name);\n return instance;\n };\n Interceptor.prototype.setInstance = function () {\n setGlobalSymbol(this.symbol, this);\n this.log('set global instance!', this.symbol.description);\n };\n Interceptor.prototype.clearInstance = function () {\n deleteGlobalSymbol(this.symbol);\n this.log('cleared global instance!', this.symbol.description);\n };\n return Interceptor;\n}());\nexports.Interceptor = Interceptor;\n//# sourceMappingURL=Interceptor.js.map","\"use strict\";\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __values = (this && this.__values) || function(o) {\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\n if (m) return m.call(o);\n if (o && typeof o.length === \"number\") return {\n next: function () {\n if (o && i >= o.length) o = void 0;\n return { value: o && o[i++], done: !o };\n }\n };\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.BatchInterceptor = void 0;\nvar Interceptor_1 = require(\"./Interceptor\");\n/**\n * A batch interceptor that exposes a single interface\n * to apply and operate with multiple interceptors at once.\n */\nvar BatchInterceptor = /** @class */ (function (_super) {\n __extends(BatchInterceptor, _super);\n function BatchInterceptor(options) {\n var _this = this;\n BatchInterceptor.symbol = Symbol(options.name);\n _this = _super.call(this, BatchInterceptor.symbol) || this;\n _this.interceptors = options.interceptors;\n return _this;\n }\n BatchInterceptor.prototype.setup = function () {\n var e_1, _a;\n var log = this.log.extend('setup');\n log('applying all %d interceptors...', this.interceptors.length);\n var _loop_1 = function (interceptor) {\n log('applying \"%s\" interceptor...', interceptor.constructor.name);\n interceptor.apply();\n log('adding interceptor dispose subscription');\n this_1.subscriptions.push(function () { return interceptor.dispose(); });\n };\n var this_1 = this;\n try {\n for (var _b = __values(this.interceptors), _c = _b.next(); !_c.done; _c = _b.next()) {\n var interceptor = _c.value;\n _loop_1(interceptor);\n }\n }\n catch (e_1_1) { e_1 = { error: e_1_1 }; }\n finally {\n try {\n if (_c && !_c.done && (_a = _b.return)) _a.call(_b);\n }\n finally { if (e_1) throw e_1.error; }\n }\n };\n BatchInterceptor.prototype.on = function (event, listener) {\n // Instead of adding a listener to the batch interceptor,\n // propagate the listener to each of the individual interceptors.\n this.interceptors.forEach(function (interceptor) {\n interceptor.on(event, listener);\n });\n };\n return BatchInterceptor;\n}(Interceptor_1.Interceptor));\nexports.BatchInterceptor = BatchInterceptor;\n//# sourceMappingURL=BatchInterceptor.js.map","'use strict';\n\n/* eslint complexity: [2, 18], max-statements: [2, 33] */\nmodule.exports = function hasSymbols() {\n\tif (typeof Symbol !== 'function' || typeof Object.getOwnPropertySymbols !== 'function') { return false; }\n\tif (typeof Symbol.iterator === 'symbol') { return true; }\n\n\tvar obj = {};\n\tvar sym = Symbol('test');\n\tvar symObj = Object(sym);\n\tif (typeof sym === 'string') { return false; }\n\n\tif (Object.prototype.toString.call(sym) !== '[object Symbol]') { return false; }\n\tif (Object.prototype.toString.call(symObj) !== '[object Symbol]') { return false; }\n\n\t// temp disabled per https://github.com/ljharb/object.assign/issues/17\n\t// if (sym instanceof Symbol) { return false; }\n\t// temp disabled per https://github.com/WebReflection/get-own-property-symbols/issues/4\n\t// if (!(symObj instanceof Symbol)) { return false; }\n\n\t// if (typeof Symbol.prototype.toString !== 'function') { return false; }\n\t// if (String(sym) !== Symbol.prototype.toString.call(sym)) { return false; }\n\n\tvar symVal = 42;\n\tobj[sym] = symVal;\n\tfor (sym in obj) { return false; } // eslint-disable-line no-restricted-syntax, no-unreachable-loop\n\tif (typeof Object.keys === 'function' && Object.keys(obj).length !== 0) { return false; }\n\n\tif (typeof Object.getOwnPropertyNames === 'function' && Object.getOwnPropertyNames(obj).length !== 0) { return false; }\n\n\tvar syms = Object.getOwnPropertySymbols(obj);\n\tif (syms.length !== 1 || syms[0] !== sym) { return false; }\n\n\tif (!Object.prototype.propertyIsEnumerable.call(obj, sym)) { return false; }\n\n\tif (typeof Object.getOwnPropertyDescriptor === 'function') {\n\t\tvar descriptor = Object.getOwnPropertyDescriptor(obj, sym);\n\t\tif (descriptor.value !== symVal || descriptor.enumerable !== true) { return false; }\n\t}\n\n\treturn true;\n};\n","'use strict';\n\nvar hasSymbols = require('has-symbols/shams');\n\n/** @type {import('.')} */\nmodule.exports = function hasToStringTagShams() {\n\treturn hasSymbols() && !!Symbol.toStringTag;\n};\n","'use strict';\n\n/** @type {import('.')} */\nmodule.exports = Error;\n","'use strict';\n\n/** @type {import('./eval')} */\nmodule.exports = EvalError;\n","'use strict';\n\n/** @type {import('./range')} */\nmodule.exports = RangeError;\n","'use strict';\n\n/** @type {import('./ref')} */\nmodule.exports = ReferenceError;\n","'use strict';\n\n/** @type {import('./syntax')} */\nmodule.exports = SyntaxError;\n","'use strict';\n\n/** @type {import('./type')} */\nmodule.exports = TypeError;\n","'use strict';\n\n/** @type {import('./uri')} */\nmodule.exports = URIError;\n","'use strict';\n\nvar origSymbol = typeof Symbol !== 'undefined' && Symbol;\nvar hasSymbolSham = require('./shams');\n\nmodule.exports = function hasNativeSymbols() {\n\tif (typeof origSymbol !== 'function') { return false; }\n\tif (typeof Symbol !== 'function') { return false; }\n\tif (typeof origSymbol('foo') !== 'symbol') { return false; }\n\tif (typeof Symbol('bar') !== 'symbol') { return false; }\n\n\treturn hasSymbolSham();\n};\n","'use strict';\n\nvar test = {\n\t__proto__: null,\n\tfoo: {}\n};\n\nvar $Object = Object;\n\n/** @type {import('.')} */\nmodule.exports = function hasProto() {\n\t// @ts-expect-error: TS errors on an inherited property for some reason\n\treturn { __proto__: test }.foo === test.foo\n\t\t&& !(test instanceof $Object);\n};\n","'use strict';\n\n/* eslint no-invalid-this: 1 */\n\nvar ERROR_MESSAGE = 'Function.prototype.bind called on incompatible ';\nvar toStr = Object.prototype.toString;\nvar max = Math.max;\nvar funcType = '[object Function]';\n\nvar concatty = function concatty(a, b) {\n var arr = [];\n\n for (var i = 0; i < a.length; i += 1) {\n arr[i] = a[i];\n }\n for (var j = 0; j < b.length; j += 1) {\n arr[j + a.length] = b[j];\n }\n\n return arr;\n};\n\nvar slicy = function slicy(arrLike, offset) {\n var arr = [];\n for (var i = offset || 0, j = 0; i < arrLike.length; i += 1, j += 1) {\n arr[j] = arrLike[i];\n }\n return arr;\n};\n\nvar joiny = function (arr, joiner) {\n var str = '';\n for (var i = 0; i < arr.length; i += 1) {\n str += arr[i];\n if (i + 1 < arr.length) {\n str += joiner;\n }\n }\n return str;\n};\n\nmodule.exports = function bind(that) {\n var target = this;\n if (typeof target !== 'function' || toStr.apply(target) !== funcType) {\n throw new TypeError(ERROR_MESSAGE + target);\n }\n var args = slicy(arguments, 1);\n\n var bound;\n var binder = function () {\n if (this instanceof bound) {\n var result = target.apply(\n this,\n concatty(args, arguments)\n );\n if (Object(result) === result) {\n return result;\n }\n return this;\n }\n return target.apply(\n that,\n concatty(args, arguments)\n );\n\n };\n\n var boundLength = max(0, target.length - args.length);\n var boundArgs = [];\n for (var i = 0; i < boundLength; i++) {\n boundArgs[i] = '$' + i;\n }\n\n bound = Function('binder', 'return function (' + joiny(boundArgs, ',') + '){ return binder.apply(this,arguments); }')(binder);\n\n if (target.prototype) {\n var Empty = function Empty() {};\n Empty.prototype = target.prototype;\n bound.prototype = new Empty();\n Empty.prototype = null;\n }\n\n return bound;\n};\n","'use strict';\n\nvar implementation = require('./implementation');\n\nmodule.exports = Function.prototype.bind || implementation;\n","'use strict';\n\nvar call = Function.prototype.call;\nvar $hasOwn = Object.prototype.hasOwnProperty;\nvar bind = require('function-bind');\n\n/** @type {import('.')} */\nmodule.exports = bind.call(call, $hasOwn);\n","'use strict';\n\nvar undefined;\n\nvar $Error = require('es-errors');\nvar $EvalError = require('es-errors/eval');\nvar $RangeError = require('es-errors/range');\nvar $ReferenceError = require('es-errors/ref');\nvar $SyntaxError = require('es-errors/syntax');\nvar $TypeError = require('es-errors/type');\nvar $URIError = require('es-errors/uri');\n\nvar $Function = Function;\n\n// eslint-disable-next-line consistent-return\nvar getEvalledConstructor = function (expressionSyntax) {\n\ttry {\n\t\treturn $Function('\"use strict\"; return (' + expressionSyntax + ').constructor;')();\n\t} catch (e) {}\n};\n\nvar $gOPD = Object.getOwnPropertyDescriptor;\nif ($gOPD) {\n\ttry {\n\t\t$gOPD({}, '');\n\t} catch (e) {\n\t\t$gOPD = null; // this is IE 8, which has a broken gOPD\n\t}\n}\n\nvar throwTypeError = function () {\n\tthrow new $TypeError();\n};\nvar ThrowTypeError = $gOPD\n\t? (function () {\n\t\ttry {\n\t\t\t// eslint-disable-next-line no-unused-expressions, no-caller, no-restricted-properties\n\t\t\targuments.callee; // IE 8 does not throw here\n\t\t\treturn throwTypeError;\n\t\t} catch (calleeThrows) {\n\t\t\ttry {\n\t\t\t\t// IE 8 throws on Object.getOwnPropertyDescriptor(arguments, '')\n\t\t\t\treturn $gOPD(arguments, 'callee').get;\n\t\t\t} catch (gOPDthrows) {\n\t\t\t\treturn throwTypeError;\n\t\t\t}\n\t\t}\n\t}())\n\t: throwTypeError;\n\nvar hasSymbols = require('has-symbols')();\nvar hasProto = require('has-proto')();\n\nvar getProto = Object.getPrototypeOf || (\n\thasProto\n\t\t? function (x) { return x.__proto__; } // eslint-disable-line no-proto\n\t\t: null\n);\n\nvar needsEval = {};\n\nvar TypedArray = typeof Uint8Array === 'undefined' || !getProto ? undefined : getProto(Uint8Array);\n\nvar INTRINSICS = {\n\t__proto__: null,\n\t'%AggregateError%': typeof AggregateError === 'undefined' ? undefined : AggregateError,\n\t'%Array%': Array,\n\t'%ArrayBuffer%': typeof ArrayBuffer === 'undefined' ? undefined : ArrayBuffer,\n\t'%ArrayIteratorPrototype%': hasSymbols && getProto ? getProto([][Symbol.iterator]()) : undefined,\n\t'%AsyncFromSyncIteratorPrototype%': undefined,\n\t'%AsyncFunction%': needsEval,\n\t'%AsyncGenerator%': needsEval,\n\t'%AsyncGeneratorFunction%': needsEval,\n\t'%AsyncIteratorPrototype%': needsEval,\n\t'%Atomics%': typeof Atomics === 'undefined' ? undefined : Atomics,\n\t'%BigInt%': typeof BigInt === 'undefined' ? undefined : BigInt,\n\t'%BigInt64Array%': typeof BigInt64Array === 'undefined' ? undefined : BigInt64Array,\n\t'%BigUint64Array%': typeof BigUint64Array === 'undefined' ? undefined : BigUint64Array,\n\t'%Boolean%': Boolean,\n\t'%DataView%': typeof DataView === 'undefined' ? undefined : DataView,\n\t'%Date%': Date,\n\t'%decodeURI%': decodeURI,\n\t'%decodeURIComponent%': decodeURIComponent,\n\t'%encodeURI%': encodeURI,\n\t'%encodeURIComponent%': encodeURIComponent,\n\t'%Error%': $Error,\n\t'%eval%': eval, // eslint-disable-line no-eval\n\t'%EvalError%': $EvalError,\n\t'%Float32Array%': typeof Float32Array === 'undefined' ? undefined : Float32Array,\n\t'%Float64Array%': typeof Float64Array === 'undefined' ? undefined : Float64Array,\n\t'%FinalizationRegistry%': typeof FinalizationRegistry === 'undefined' ? undefined : FinalizationRegistry,\n\t'%Function%': $Function,\n\t'%GeneratorFunction%': needsEval,\n\t'%Int8Array%': typeof Int8Array === 'undefined' ? undefined : Int8Array,\n\t'%Int16Array%': typeof Int16Array === 'undefined' ? undefined : Int16Array,\n\t'%Int32Array%': typeof Int32Array === 'undefined' ? undefined : Int32Array,\n\t'%isFinite%': isFinite,\n\t'%isNaN%': isNaN,\n\t'%IteratorPrototype%': hasSymbols && getProto ? getProto(getProto([][Symbol.iterator]())) : undefined,\n\t'%JSON%': typeof JSON === 'object' ? JSON : undefined,\n\t'%Map%': typeof Map === 'undefined' ? undefined : Map,\n\t'%MapIteratorPrototype%': typeof Map === 'undefined' || !hasSymbols || !getProto ? undefined : getProto(new Map()[Symbol.iterator]()),\n\t'%Math%': Math,\n\t'%Number%': Number,\n\t'%Object%': Object,\n\t'%parseFloat%': parseFloat,\n\t'%parseInt%': parseInt,\n\t'%Promise%': typeof Promise === 'undefined' ? undefined : Promise,\n\t'%Proxy%': typeof Proxy === 'undefined' ? undefined : Proxy,\n\t'%RangeError%': $RangeError,\n\t'%ReferenceError%': $ReferenceError,\n\t'%Reflect%': typeof Reflect === 'undefined' ? undefined : Reflect,\n\t'%RegExp%': RegExp,\n\t'%Set%': typeof Set === 'undefined' ? undefined : Set,\n\t'%SetIteratorPrototype%': typeof Set === 'undefined' || !hasSymbols || !getProto ? undefined : getProto(new Set()[Symbol.iterator]()),\n\t'%SharedArrayBuffer%': typeof SharedArrayBuffer === 'undefined' ? undefined : SharedArrayBuffer,\n\t'%String%': String,\n\t'%StringIteratorPrototype%': hasSymbols && getProto ? getProto(''[Symbol.iterator]()) : undefined,\n\t'%Symbol%': hasSymbols ? Symbol : undefined,\n\t'%SyntaxError%': $SyntaxError,\n\t'%ThrowTypeError%': ThrowTypeError,\n\t'%TypedArray%': TypedArray,\n\t'%TypeError%': $TypeError,\n\t'%Uint8Array%': typeof Uint8Array === 'undefined' ? undefined : Uint8Array,\n\t'%Uint8ClampedArray%': typeof Uint8ClampedArray === 'undefined' ? undefined : Uint8ClampedArray,\n\t'%Uint16Array%': typeof Uint16Array === 'undefined' ? undefined : Uint16Array,\n\t'%Uint32Array%': typeof Uint32Array === 'undefined' ? undefined : Uint32Array,\n\t'%URIError%': $URIError,\n\t'%WeakMap%': typeof WeakMap === 'undefined' ? undefined : WeakMap,\n\t'%WeakRef%': typeof WeakRef === 'undefined' ? undefined : WeakRef,\n\t'%WeakSet%': typeof WeakSet === 'undefined' ? undefined : WeakSet\n};\n\nif (getProto) {\n\ttry {\n\t\tnull.error; // eslint-disable-line no-unused-expressions\n\t} catch (e) {\n\t\t// https://github.com/tc39/proposal-shadowrealm/pull/384#issuecomment-1364264229\n\t\tvar errorProto = getProto(getProto(e));\n\t\tINTRINSICS['%Error.prototype%'] = errorProto;\n\t}\n}\n\nvar doEval = function doEval(name) {\n\tvar value;\n\tif (name === '%AsyncFunction%') {\n\t\tvalue = getEvalledConstructor('async function () {}');\n\t} else if (name === '%GeneratorFunction%') {\n\t\tvalue = getEvalledConstructor('function* () {}');\n\t} else if (name === '%AsyncGeneratorFunction%') {\n\t\tvalue = getEvalledConstructor('async function* () {}');\n\t} else if (name === '%AsyncGenerator%') {\n\t\tvar fn = doEval('%AsyncGeneratorFunction%');\n\t\tif (fn) {\n\t\t\tvalue = fn.prototype;\n\t\t}\n\t} else if (name === '%AsyncIteratorPrototype%') {\n\t\tvar gen = doEval('%AsyncGenerator%');\n\t\tif (gen && getProto) {\n\t\t\tvalue = getProto(gen.prototype);\n\t\t}\n\t}\n\n\tINTRINSICS[name] = value;\n\n\treturn value;\n};\n\nvar LEGACY_ALIASES = {\n\t__proto__: null,\n\t'%ArrayBufferPrototype%': ['ArrayBuffer', 'prototype'],\n\t'%ArrayPrototype%': ['Array', 'prototype'],\n\t'%ArrayProto_entries%': ['Array', 'prototype', 'entries'],\n\t'%ArrayProto_forEach%': ['Array', 'prototype', 'forEach'],\n\t'%ArrayProto_keys%': ['Array', 'prototype', 'keys'],\n\t'%ArrayProto_values%': ['Array', 'prototype', 'values'],\n\t'%AsyncFunctionPrototype%': ['AsyncFunction', 'prototype'],\n\t'%AsyncGenerator%': ['AsyncGeneratorFunction', 'prototype'],\n\t'%AsyncGeneratorPrototype%': ['AsyncGeneratorFunction', 'prototype', 'prototype'],\n\t'%BooleanPrototype%': ['Boolean', 'prototype'],\n\t'%DataViewPrototype%': ['DataView', 'prototype'],\n\t'%DatePrototype%': ['Date', 'prototype'],\n\t'%ErrorPrototype%': ['Error', 'prototype'],\n\t'%EvalErrorPrototype%': ['EvalError', 'prototype'],\n\t'%Float32ArrayPrototype%': ['Float32Array', 'prototype'],\n\t'%Float64ArrayPrototype%': ['Float64Array', 'prototype'],\n\t'%FunctionPrototype%': ['Function', 'prototype'],\n\t'%Generator%': ['GeneratorFunction', 'prototype'],\n\t'%GeneratorPrototype%': ['GeneratorFunction', 'prototype', 'prototype'],\n\t'%Int8ArrayPrototype%': ['Int8Array', 'prototype'],\n\t'%Int16ArrayPrototype%': ['Int16Array', 'prototype'],\n\t'%Int32ArrayPrototype%': ['Int32Array', 'prototype'],\n\t'%JSONParse%': ['JSON', 'parse'],\n\t'%JSONStringify%': ['JSON', 'stringify'],\n\t'%MapPrototype%': ['Map', 'prototype'],\n\t'%NumberPrototype%': ['Number', 'prototype'],\n\t'%ObjectPrototype%': ['Object', 'prototype'],\n\t'%ObjProto_toString%': ['Object', 'prototype', 'toString'],\n\t'%ObjProto_valueOf%': ['Object', 'prototype', 'valueOf'],\n\t'%PromisePrototype%': ['Promise', 'prototype'],\n\t'%PromiseProto_then%': ['Promise', 'prototype', 'then'],\n\t'%Promise_all%': ['Promise', 'all'],\n\t'%Promise_reject%': ['Promise', 'reject'],\n\t'%Promise_resolve%': ['Promise', 'resolve'],\n\t'%RangeErrorPrototype%': ['RangeError', 'prototype'],\n\t'%ReferenceErrorPrototype%': ['ReferenceError', 'prototype'],\n\t'%RegExpPrototype%': ['RegExp', 'prototype'],\n\t'%SetPrototype%': ['Set', 'prototype'],\n\t'%SharedArrayBufferPrototype%': ['SharedArrayBuffer', 'prototype'],\n\t'%StringPrototype%': ['String', 'prototype'],\n\t'%SymbolPrototype%': ['Symbol', 'prototype'],\n\t'%SyntaxErrorPrototype%': ['SyntaxError', 'prototype'],\n\t'%TypedArrayPrototype%': ['TypedArray', 'prototype'],\n\t'%TypeErrorPrototype%': ['TypeError', 'prototype'],\n\t'%Uint8ArrayPrototype%': ['Uint8Array', 'prototype'],\n\t'%Uint8ClampedArrayPrototype%': ['Uint8ClampedArray', 'prototype'],\n\t'%Uint16ArrayPrototype%': ['Uint16Array', 'prototype'],\n\t'%Uint32ArrayPrototype%': ['Uint32Array', 'prototype'],\n\t'%URIErrorPrototype%': ['URIError', 'prototype'],\n\t'%WeakMapPrototype%': ['WeakMap', 'prototype'],\n\t'%WeakSetPrototype%': ['WeakSet', 'prototype']\n};\n\nvar bind = require('function-bind');\nvar hasOwn = require('hasown');\nvar $concat = bind.call(Function.call, Array.prototype.concat);\nvar $spliceApply = bind.call(Function.apply, Array.prototype.splice);\nvar $replace = bind.call(Function.call, String.prototype.replace);\nvar $strSlice = bind.call(Function.call, String.prototype.slice);\nvar $exec = bind.call(Function.call, RegExp.prototype.exec);\n\n/* adapted from https://github.com/lodash/lodash/blob/4.17.15/dist/lodash.js#L6735-L6744 */\nvar rePropName = /[^%.[\\]]+|\\[(?:(-?\\d+(?:\\.\\d+)?)|([\"'])((?:(?!\\2)[^\\\\]|\\\\.)*?)\\2)\\]|(?=(?:\\.|\\[\\])(?:\\.|\\[\\]|%$))/g;\nvar reEscapeChar = /\\\\(\\\\)?/g; /** Used to match backslashes in property paths. */\nvar stringToPath = function stringToPath(string) {\n\tvar first = $strSlice(string, 0, 1);\n\tvar last = $strSlice(string, -1);\n\tif (first === '%' && last !== '%') {\n\t\tthrow new $SyntaxError('invalid intrinsic syntax, expected closing `%`');\n\t} else if (last === '%' && first !== '%') {\n\t\tthrow new $SyntaxError('invalid intrinsic syntax, expected opening `%`');\n\t}\n\tvar result = [];\n\t$replace(string, rePropName, function (match, number, quote, subString) {\n\t\tresult[result.length] = quote ? $replace(subString, reEscapeChar, '$1') : number || match;\n\t});\n\treturn result;\n};\n/* end adaptation */\n\nvar getBaseIntrinsic = function getBaseIntrinsic(name, allowMissing) {\n\tvar intrinsicName = name;\n\tvar alias;\n\tif (hasOwn(LEGACY_ALIASES, intrinsicName)) {\n\t\talias = LEGACY_ALIASES[intrinsicName];\n\t\tintrinsicName = '%' + alias[0] + '%';\n\t}\n\n\tif (hasOwn(INTRINSICS, intrinsicName)) {\n\t\tvar value = INTRINSICS[intrinsicName];\n\t\tif (value === needsEval) {\n\t\t\tvalue = doEval(intrinsicName);\n\t\t}\n\t\tif (typeof value === 'undefined' && !allowMissing) {\n\t\t\tthrow new $TypeError('intrinsic ' + name + ' exists, but is not available. Please file an issue!');\n\t\t}\n\n\t\treturn {\n\t\t\talias: alias,\n\t\t\tname: intrinsicName,\n\t\t\tvalue: value\n\t\t};\n\t}\n\n\tthrow new $SyntaxError('intrinsic ' + name + ' does not exist!');\n};\n\nmodule.exports = function GetIntrinsic(name, allowMissing) {\n\tif (typeof name !== 'string' || name.length === 0) {\n\t\tthrow new $TypeError('intrinsic name must be a non-empty string');\n\t}\n\tif (arguments.length > 1 && typeof allowMissing !== 'boolean') {\n\t\tthrow new $TypeError('\"allowMissing\" argument must be a boolean');\n\t}\n\n\tif ($exec(/^%?[^%]*%?$/, name) === null) {\n\t\tthrow new $SyntaxError('`%` may not be present anywhere but at the beginning and end of the intrinsic name');\n\t}\n\tvar parts = stringToPath(name);\n\tvar intrinsicBaseName = parts.length > 0 ? parts[0] : '';\n\n\tvar intrinsic = getBaseIntrinsic('%' + intrinsicBaseName + '%', allowMissing);\n\tvar intrinsicRealName = intrinsic.name;\n\tvar value = intrinsic.value;\n\tvar skipFurtherCaching = false;\n\n\tvar alias = intrinsic.alias;\n\tif (alias) {\n\t\tintrinsicBaseName = alias[0];\n\t\t$spliceApply(parts, $concat([0, 1], alias));\n\t}\n\n\tfor (var i = 1, isOwn = true; i < parts.length; i += 1) {\n\t\tvar part = parts[i];\n\t\tvar first = $strSlice(part, 0, 1);\n\t\tvar last = $strSlice(part, -1);\n\t\tif (\n\t\t\t(\n\t\t\t\t(first === '\"' || first === \"'\" || first === '`')\n\t\t\t\t|| (last === '\"' || last === \"'\" || last === '`')\n\t\t\t)\n\t\t\t&& first !== last\n\t\t) {\n\t\t\tthrow new $SyntaxError('property names with quotes must have matching quotes');\n\t\t}\n\t\tif (part === 'constructor' || !isOwn) {\n\t\t\tskipFurtherCaching = true;\n\t\t}\n\n\t\tintrinsicBaseName += '.' + part;\n\t\tintrinsicRealName = '%' + intrinsicBaseName + '%';\n\n\t\tif (hasOwn(INTRINSICS, intrinsicRealName)) {\n\t\t\tvalue = INTRINSICS[intrinsicRealName];\n\t\t} else if (value != null) {\n\t\t\tif (!(part in value)) {\n\t\t\t\tif (!allowMissing) {\n\t\t\t\t\tthrow new $TypeError('base intrinsic for ' + name + ' exists, but the property is not available.');\n\t\t\t\t}\n\t\t\t\treturn void undefined;\n\t\t\t}\n\t\t\tif ($gOPD && (i + 1) >= parts.length) {\n\t\t\t\tvar desc = $gOPD(value, part);\n\t\t\t\tisOwn = !!desc;\n\n\t\t\t\t// By convention, when a data property is converted to an accessor\n\t\t\t\t// property to emulate a data property that does not suffer from\n\t\t\t\t// the override mistake, that accessor's getter is marked with\n\t\t\t\t// an `originalValue` property. Here, when we detect this, we\n\t\t\t\t// uphold the illusion by pretending to see that original data\n\t\t\t\t// property, i.e., returning the value rather than the getter\n\t\t\t\t// itself.\n\t\t\t\tif (isOwn && 'get' in desc && !('originalValue' in desc.get)) {\n\t\t\t\t\tvalue = desc.get;\n\t\t\t\t} else {\n\t\t\t\t\tvalue = value[part];\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tisOwn = hasOwn(value, part);\n\t\t\t\tvalue = value[part];\n\t\t\t}\n\n\t\t\tif (isOwn && !skipFurtherCaching) {\n\t\t\t\tINTRINSICS[intrinsicRealName] = value;\n\t\t\t}\n\t\t}\n\t}\n\treturn value;\n};\n","'use strict';\n\nvar GetIntrinsic = require('get-intrinsic');\n\n/** @type {import('.')} */\nvar $defineProperty = GetIntrinsic('%Object.defineProperty%', true) || false;\nif ($defineProperty) {\n\ttry {\n\t\t$defineProperty({}, 'a', { value: 1 });\n\t} catch (e) {\n\t\t// IE 8 has a broken defineProperty\n\t\t$defineProperty = false;\n\t}\n}\n\nmodule.exports = $defineProperty;\n","'use strict';\n\nvar GetIntrinsic = require('get-intrinsic');\n\nvar $gOPD = GetIntrinsic('%Object.getOwnPropertyDescriptor%', true);\n\nif ($gOPD) {\n\ttry {\n\t\t$gOPD([], 'length');\n\t} catch (e) {\n\t\t// IE 8 has a broken gOPD\n\t\t$gOPD = null;\n\t}\n}\n\nmodule.exports = $gOPD;\n","'use strict';\n\nvar $defineProperty = require('es-define-property');\n\nvar $SyntaxError = require('es-errors/syntax');\nvar $TypeError = require('es-errors/type');\n\nvar gopd = require('gopd');\n\n/** @type {import('.')} */\nmodule.exports = function defineDataProperty(\n\tobj,\n\tproperty,\n\tvalue\n) {\n\tif (!obj || (typeof obj !== 'object' && typeof obj !== 'function')) {\n\t\tthrow new $TypeError('`obj` must be an object or a function`');\n\t}\n\tif (typeof property !== 'string' && typeof property !== 'symbol') {\n\t\tthrow new $TypeError('`property` must be a string or a symbol`');\n\t}\n\tif (arguments.length > 3 && typeof arguments[3] !== 'boolean' && arguments[3] !== null) {\n\t\tthrow new $TypeError('`nonEnumerable`, if provided, must be a boolean or null');\n\t}\n\tif (arguments.length > 4 && typeof arguments[4] !== 'boolean' && arguments[4] !== null) {\n\t\tthrow new $TypeError('`nonWritable`, if provided, must be a boolean or null');\n\t}\n\tif (arguments.length > 5 && typeof arguments[5] !== 'boolean' && arguments[5] !== null) {\n\t\tthrow new $TypeError('`nonConfigurable`, if provided, must be a boolean or null');\n\t}\n\tif (arguments.length > 6 && typeof arguments[6] !== 'boolean') {\n\t\tthrow new $TypeError('`loose`, if provided, must be a boolean');\n\t}\n\n\tvar nonEnumerable = arguments.length > 3 ? arguments[3] : null;\n\tvar nonWritable = arguments.length > 4 ? arguments[4] : null;\n\tvar nonConfigurable = arguments.length > 5 ? arguments[5] : null;\n\tvar loose = arguments.length > 6 ? arguments[6] : false;\n\n\t/* @type {false | TypedPropertyDescriptor} */\n\tvar desc = !!gopd && gopd(obj, property);\n\n\tif ($defineProperty) {\n\t\t$defineProperty(obj, property, {\n\t\t\tconfigurable: nonConfigurable === null && desc ? desc.configurable : !nonConfigurable,\n\t\t\tenumerable: nonEnumerable === null && desc ? desc.enumerable : !nonEnumerable,\n\t\t\tvalue: value,\n\t\t\twritable: nonWritable === null && desc ? desc.writable : !nonWritable\n\t\t});\n\t} else if (loose || (!nonEnumerable && !nonWritable && !nonConfigurable)) {\n\t\t// must fall back to [[Set]], and was not explicitly asked to make non-enumerable, non-writable, or non-configurable\n\t\tobj[property] = value; // eslint-disable-line no-param-reassign\n\t} else {\n\t\tthrow new $SyntaxError('This environment does not support defining a property as non-configurable, non-writable, or non-enumerable.');\n\t}\n};\n","'use strict';\n\nvar $defineProperty = require('es-define-property');\n\nvar hasPropertyDescriptors = function hasPropertyDescriptors() {\n\treturn !!$defineProperty;\n};\n\nhasPropertyDescriptors.hasArrayLengthDefineBug = function hasArrayLengthDefineBug() {\n\t// node v0.6 has a bug where array lengths can be Set but not Defined\n\tif (!$defineProperty) {\n\t\treturn null;\n\t}\n\ttry {\n\t\treturn $defineProperty([], 'length', { value: 1 }).length !== 1;\n\t} catch (e) {\n\t\t// In Firefox 4-22, defining length on an array throws an exception.\n\t\treturn true;\n\t}\n};\n\nmodule.exports = hasPropertyDescriptors;\n","'use strict';\n\nvar GetIntrinsic = require('get-intrinsic');\nvar define = require('define-data-property');\nvar hasDescriptors = require('has-property-descriptors')();\nvar gOPD = require('gopd');\n\nvar $TypeError = require('es-errors/type');\nvar $floor = GetIntrinsic('%Math.floor%');\n\n/** @type {import('.')} */\nmodule.exports = function setFunctionLength(fn, length) {\n\tif (typeof fn !== 'function') {\n\t\tthrow new $TypeError('`fn` is not a function');\n\t}\n\tif (typeof length !== 'number' || length < 0 || length > 0xFFFFFFFF || $floor(length) !== length) {\n\t\tthrow new $TypeError('`length` must be a positive 32-bit integer');\n\t}\n\n\tvar loose = arguments.length > 2 && !!arguments[2];\n\n\tvar functionLengthIsConfigurable = true;\n\tvar functionLengthIsWritable = true;\n\tif ('length' in fn && gOPD) {\n\t\tvar desc = gOPD(fn, 'length');\n\t\tif (desc && !desc.configurable) {\n\t\t\tfunctionLengthIsConfigurable = false;\n\t\t}\n\t\tif (desc && !desc.writable) {\n\t\t\tfunctionLengthIsWritable = false;\n\t\t}\n\t}\n\n\tif (functionLengthIsConfigurable || functionLengthIsWritable || !loose) {\n\t\tif (hasDescriptors) {\n\t\t\tdefine(/** @type {Parameters[0]} */ (fn), 'length', length, true, true);\n\t\t} else {\n\t\t\tdefine(/** @type {Parameters[0]} */ (fn), 'length', length);\n\t\t}\n\t}\n\treturn fn;\n};\n","'use strict';\n\nvar bind = require('function-bind');\nvar GetIntrinsic = require('get-intrinsic');\nvar setFunctionLength = require('set-function-length');\n\nvar $TypeError = require('es-errors/type');\nvar $apply = GetIntrinsic('%Function.prototype.apply%');\nvar $call = GetIntrinsic('%Function.prototype.call%');\nvar $reflectApply = GetIntrinsic('%Reflect.apply%', true) || bind.call($call, $apply);\n\nvar $defineProperty = require('es-define-property');\nvar $max = GetIntrinsic('%Math.max%');\n\nmodule.exports = function callBind(originalFunction) {\n\tif (typeof originalFunction !== 'function') {\n\t\tthrow new $TypeError('a function is required');\n\t}\n\tvar func = $reflectApply(bind, $call, arguments);\n\treturn setFunctionLength(\n\t\tfunc,\n\t\t1 + $max(0, originalFunction.length - (arguments.length - 1)),\n\t\ttrue\n\t);\n};\n\nvar applyBind = function applyBind() {\n\treturn $reflectApply(bind, $apply, arguments);\n};\n\nif ($defineProperty) {\n\t$defineProperty(module.exports, 'apply', { value: applyBind });\n} else {\n\tmodule.exports.apply = applyBind;\n}\n","'use strict';\n\nvar GetIntrinsic = require('get-intrinsic');\n\nvar callBind = require('./');\n\nvar $indexOf = callBind(GetIntrinsic('String.prototype.indexOf'));\n\nmodule.exports = function callBoundIntrinsic(name, allowMissing) {\n\tvar intrinsic = GetIntrinsic(name, !!allowMissing);\n\tif (typeof intrinsic === 'function' && $indexOf(name, '.prototype.') > -1) {\n\t\treturn callBind(intrinsic);\n\t}\n\treturn intrinsic;\n};\n","'use strict';\n\nvar hasToStringTag = require('has-tostringtag/shams')();\nvar callBound = require('call-bind/callBound');\n\nvar $toString = callBound('Object.prototype.toString');\n\nvar isStandardArguments = function isArguments(value) {\n\tif (hasToStringTag && value && typeof value === 'object' && Symbol.toStringTag in value) {\n\t\treturn false;\n\t}\n\treturn $toString(value) === '[object Arguments]';\n};\n\nvar isLegacyArguments = function isArguments(value) {\n\tif (isStandardArguments(value)) {\n\t\treturn true;\n\t}\n\treturn value !== null &&\n\t\ttypeof value === 'object' &&\n\t\ttypeof value.length === 'number' &&\n\t\tvalue.length >= 0 &&\n\t\t$toString(value) !== '[object Array]' &&\n\t\t$toString(value.callee) === '[object Function]';\n};\n\nvar supportsStandardArguments = (function () {\n\treturn isStandardArguments(arguments);\n}());\n\nisStandardArguments.isLegacyArguments = isLegacyArguments; // for tests\n\nmodule.exports = supportsStandardArguments ? isStandardArguments : isLegacyArguments;\n","'use strict';\n\nvar toStr = Object.prototype.toString;\nvar fnToStr = Function.prototype.toString;\nvar isFnRegex = /^\\s*(?:function)?\\*/;\nvar hasToStringTag = require('has-tostringtag/shams')();\nvar getProto = Object.getPrototypeOf;\nvar getGeneratorFunc = function () { // eslint-disable-line consistent-return\n\tif (!hasToStringTag) {\n\t\treturn false;\n\t}\n\ttry {\n\t\treturn Function('return function*() {}')();\n\t} catch (e) {\n\t}\n};\nvar GeneratorFunction;\n\nmodule.exports = function isGeneratorFunction(fn) {\n\tif (typeof fn !== 'function') {\n\t\treturn false;\n\t}\n\tif (isFnRegex.test(fnToStr.call(fn))) {\n\t\treturn true;\n\t}\n\tif (!hasToStringTag) {\n\t\tvar str = toStr.call(fn);\n\t\treturn str === '[object GeneratorFunction]';\n\t}\n\tif (!getProto) {\n\t\treturn false;\n\t}\n\tif (typeof GeneratorFunction === 'undefined') {\n\t\tvar generatorFunc = getGeneratorFunc();\n\t\tGeneratorFunction = generatorFunc ? getProto(generatorFunc) : false;\n\t}\n\treturn getProto(fn) === GeneratorFunction;\n};\n","'use strict';\n\nvar fnToStr = Function.prototype.toString;\nvar reflectApply = typeof Reflect === 'object' && Reflect !== null && Reflect.apply;\nvar badArrayLike;\nvar isCallableMarker;\nif (typeof reflectApply === 'function' && typeof Object.defineProperty === 'function') {\n\ttry {\n\t\tbadArrayLike = Object.defineProperty({}, 'length', {\n\t\t\tget: function () {\n\t\t\t\tthrow isCallableMarker;\n\t\t\t}\n\t\t});\n\t\tisCallableMarker = {};\n\t\t// eslint-disable-next-line no-throw-literal\n\t\treflectApply(function () { throw 42; }, null, badArrayLike);\n\t} catch (_) {\n\t\tif (_ !== isCallableMarker) {\n\t\t\treflectApply = null;\n\t\t}\n\t}\n} else {\n\treflectApply = null;\n}\n\nvar constructorRegex = /^\\s*class\\b/;\nvar isES6ClassFn = function isES6ClassFunction(value) {\n\ttry {\n\t\tvar fnStr = fnToStr.call(value);\n\t\treturn constructorRegex.test(fnStr);\n\t} catch (e) {\n\t\treturn false; // not a function\n\t}\n};\n\nvar tryFunctionObject = function tryFunctionToStr(value) {\n\ttry {\n\t\tif (isES6ClassFn(value)) { return false; }\n\t\tfnToStr.call(value);\n\t\treturn true;\n\t} catch (e) {\n\t\treturn false;\n\t}\n};\nvar toStr = Object.prototype.toString;\nvar objectClass = '[object Object]';\nvar fnClass = '[object Function]';\nvar genClass = '[object GeneratorFunction]';\nvar ddaClass = '[object HTMLAllCollection]'; // IE 11\nvar ddaClass2 = '[object HTML document.all class]';\nvar ddaClass3 = '[object HTMLCollection]'; // IE 9-10\nvar hasToStringTag = typeof Symbol === 'function' && !!Symbol.toStringTag; // better: use `has-tostringtag`\n\nvar isIE68 = !(0 in [,]); // eslint-disable-line no-sparse-arrays, comma-spacing\n\nvar isDDA = function isDocumentDotAll() { return false; };\nif (typeof document === 'object') {\n\t// Firefox 3 canonicalizes DDA to undefined when it's not accessed directly\n\tvar all = document.all;\n\tif (toStr.call(all) === toStr.call(document.all)) {\n\t\tisDDA = function isDocumentDotAll(value) {\n\t\t\t/* globals document: false */\n\t\t\t// in IE 6-8, typeof document.all is \"object\" and it's truthy\n\t\t\tif ((isIE68 || !value) && (typeof value === 'undefined' || typeof value === 'object')) {\n\t\t\t\ttry {\n\t\t\t\t\tvar str = toStr.call(value);\n\t\t\t\t\treturn (\n\t\t\t\t\t\tstr === ddaClass\n\t\t\t\t\t\t|| str === ddaClass2\n\t\t\t\t\t\t|| str === ddaClass3 // opera 12.16\n\t\t\t\t\t\t|| str === objectClass // IE 6-8\n\t\t\t\t\t) && value('') == null; // eslint-disable-line eqeqeq\n\t\t\t\t} catch (e) { /**/ }\n\t\t\t}\n\t\t\treturn false;\n\t\t};\n\t}\n}\n\nmodule.exports = reflectApply\n\t? function isCallable(value) {\n\t\tif (isDDA(value)) { return true; }\n\t\tif (!value) { return false; }\n\t\tif (typeof value !== 'function' && typeof value !== 'object') { return false; }\n\t\ttry {\n\t\t\treflectApply(value, null, badArrayLike);\n\t\t} catch (e) {\n\t\t\tif (e !== isCallableMarker) { return false; }\n\t\t}\n\t\treturn !isES6ClassFn(value) && tryFunctionObject(value);\n\t}\n\t: function isCallable(value) {\n\t\tif (isDDA(value)) { return true; }\n\t\tif (!value) { return false; }\n\t\tif (typeof value !== 'function' && typeof value !== 'object') { return false; }\n\t\tif (hasToStringTag) { return tryFunctionObject(value); }\n\t\tif (isES6ClassFn(value)) { return false; }\n\t\tvar strClass = toStr.call(value);\n\t\tif (strClass !== fnClass && strClass !== genClass && !(/^\\[object HTML/).test(strClass)) { return false; }\n\t\treturn tryFunctionObject(value);\n\t};\n","'use strict';\n\nvar isCallable = require('is-callable');\n\nvar toStr = Object.prototype.toString;\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\n\nvar forEachArray = function forEachArray(array, iterator, receiver) {\n for (var i = 0, len = array.length; i < len; i++) {\n if (hasOwnProperty.call(array, i)) {\n if (receiver == null) {\n iterator(array[i], i, array);\n } else {\n iterator.call(receiver, array[i], i, array);\n }\n }\n }\n};\n\nvar forEachString = function forEachString(string, iterator, receiver) {\n for (var i = 0, len = string.length; i < len; i++) {\n // no such thing as a sparse string.\n if (receiver == null) {\n iterator(string.charAt(i), i, string);\n } else {\n iterator.call(receiver, string.charAt(i), i, string);\n }\n }\n};\n\nvar forEachObject = function forEachObject(object, iterator, receiver) {\n for (var k in object) {\n if (hasOwnProperty.call(object, k)) {\n if (receiver == null) {\n iterator(object[k], k, object);\n } else {\n iterator.call(receiver, object[k], k, object);\n }\n }\n }\n};\n\nvar forEach = function forEach(list, iterator, thisArg) {\n if (!isCallable(iterator)) {\n throw new TypeError('iterator must be a function');\n }\n\n var receiver;\n if (arguments.length >= 3) {\n receiver = thisArg;\n }\n\n if (toStr.call(list) === '[object Array]') {\n forEachArray(list, iterator, receiver);\n } else if (typeof list === 'string') {\n forEachString(list, iterator, receiver);\n } else {\n forEachObject(list, iterator, receiver);\n }\n};\n\nmodule.exports = forEach;\n","'use strict';\n\n/** @type {import('.')} */\nmodule.exports = [\n\t'Float32Array',\n\t'Float64Array',\n\t'Int8Array',\n\t'Int16Array',\n\t'Int32Array',\n\t'Uint8Array',\n\t'Uint8ClampedArray',\n\t'Uint16Array',\n\t'Uint32Array',\n\t'BigInt64Array',\n\t'BigUint64Array'\n];\n","'use strict';\n\nvar possibleNames = require('possible-typed-array-names');\n\nvar g = typeof globalThis === 'undefined' ? global : globalThis;\n\n/** @type {import('.')} */\nmodule.exports = function availableTypedArrays() {\n\tvar /** @type {ReturnType} */ out = [];\n\tfor (var i = 0; i < possibleNames.length; i++) {\n\t\tif (typeof g[possibleNames[i]] === 'function') {\n\t\t\t// @ts-expect-error\n\t\t\tout[out.length] = possibleNames[i];\n\t\t}\n\t}\n\treturn out;\n};\n","'use strict';\n\nvar forEach = require('for-each');\nvar availableTypedArrays = require('available-typed-arrays');\nvar callBind = require('call-bind');\nvar callBound = require('call-bind/callBound');\nvar gOPD = require('gopd');\n\n/** @type {(O: object) => string} */\nvar $toString = callBound('Object.prototype.toString');\nvar hasToStringTag = require('has-tostringtag/shams')();\n\nvar g = typeof globalThis === 'undefined' ? global : globalThis;\nvar typedArrays = availableTypedArrays();\n\nvar $slice = callBound('String.prototype.slice');\nvar getPrototypeOf = Object.getPrototypeOf; // require('getprototypeof');\n\n/** @type {(array: readonly T[], value: unknown) => number} */\nvar $indexOf = callBound('Array.prototype.indexOf', true) || function indexOf(array, value) {\n\tfor (var i = 0; i < array.length; i += 1) {\n\t\tif (array[i] === value) {\n\t\t\treturn i;\n\t\t}\n\t}\n\treturn -1;\n};\n\n/** @typedef {(receiver: import('.').TypedArray) => string | typeof Uint8Array.prototype.slice.call | typeof Uint8Array.prototype.set.call} Getter */\n/** @type {{ [k in `\\$${import('.').TypedArrayName}`]?: Getter } & { __proto__: null }} */\nvar cache = { __proto__: null };\nif (hasToStringTag && gOPD && getPrototypeOf) {\n\tforEach(typedArrays, function (typedArray) {\n\t\tvar arr = new g[typedArray]();\n\t\tif (Symbol.toStringTag in arr) {\n\t\t\tvar proto = getPrototypeOf(arr);\n\t\t\t// @ts-expect-error TS won't narrow inside a closure\n\t\t\tvar descriptor = gOPD(proto, Symbol.toStringTag);\n\t\t\tif (!descriptor) {\n\t\t\t\tvar superProto = getPrototypeOf(proto);\n\t\t\t\t// @ts-expect-error TS won't narrow inside a closure\n\t\t\t\tdescriptor = gOPD(superProto, Symbol.toStringTag);\n\t\t\t}\n\t\t\t// @ts-expect-error TODO: fix\n\t\t\tcache['$' + typedArray] = callBind(descriptor.get);\n\t\t}\n\t});\n} else {\n\tforEach(typedArrays, function (typedArray) {\n\t\tvar arr = new g[typedArray]();\n\t\tvar fn = arr.slice || arr.set;\n\t\tif (fn) {\n\t\t\t// @ts-expect-error TODO: fix\n\t\t\tcache['$' + typedArray] = callBind(fn);\n\t\t}\n\t});\n}\n\n/** @type {(value: object) => false | import('.').TypedArrayName} */\nvar tryTypedArrays = function tryAllTypedArrays(value) {\n\t/** @type {ReturnType} */ var found = false;\n\tforEach(\n\t\t// eslint-disable-next-line no-extra-parens\n\t\t/** @type {Record<`\\$${TypedArrayName}`, Getter>} */ /** @type {any} */ (cache),\n\t\t/** @type {(getter: Getter, name: `\\$${import('.').TypedArrayName}`) => void} */\n\t\tfunction (getter, typedArray) {\n\t\t\tif (!found) {\n\t\t\t\ttry {\n\t\t\t\t// @ts-expect-error TODO: fix\n\t\t\t\t\tif ('$' + getter(value) === typedArray) {\n\t\t\t\t\t\tfound = $slice(typedArray, 1);\n\t\t\t\t\t}\n\t\t\t\t} catch (e) { /**/ }\n\t\t\t}\n\t\t}\n\t);\n\treturn found;\n};\n\n/** @type {(value: object) => false | import('.').TypedArrayName} */\nvar trySlices = function tryAllSlices(value) {\n\t/** @type {ReturnType} */ var found = false;\n\tforEach(\n\t\t// eslint-disable-next-line no-extra-parens\n\t\t/** @type {Record<`\\$${TypedArrayName}`, Getter>} */ /** @type {any} */ (cache),\n\t\t/** @type {(getter: typeof cache, name: `\\$${import('.').TypedArrayName}`) => void} */ function (getter, name) {\n\t\t\tif (!found) {\n\t\t\t\ttry {\n\t\t\t\t\t// @ts-expect-error TODO: fix\n\t\t\t\t\tgetter(value);\n\t\t\t\t\tfound = $slice(name, 1);\n\t\t\t\t} catch (e) { /**/ }\n\t\t\t}\n\t\t}\n\t);\n\treturn found;\n};\n\n/** @type {import('.')} */\nmodule.exports = function whichTypedArray(value) {\n\tif (!value || typeof value !== 'object') { return false; }\n\tif (!hasToStringTag) {\n\t\t/** @type {string} */\n\t\tvar tag = $slice($toString(value), 8, -1);\n\t\tif ($indexOf(typedArrays, tag) > -1) {\n\t\t\treturn tag;\n\t\t}\n\t\tif (tag !== 'Object') {\n\t\t\treturn false;\n\t\t}\n\t\t// node < 0.6 hits here on real Typed Arrays\n\t\treturn trySlices(value);\n\t}\n\tif (!gOPD) { return null; } // unknown engine\n\treturn tryTypedArrays(value);\n};\n","'use strict';\n\nvar whichTypedArray = require('which-typed-array');\n\n/** @type {import('.')} */\nmodule.exports = function isTypedArray(value) {\n\treturn !!whichTypedArray(value);\n};\n","// Currently in sync with Node.js lib/internal/util/types.js\n// https://github.com/nodejs/node/commit/112cc7c27551254aa2b17098fb774867f05ed0d9\n\n'use strict';\n\nvar isArgumentsObject = require('is-arguments');\nvar isGeneratorFunction = require('is-generator-function');\nvar whichTypedArray = require('which-typed-array');\nvar isTypedArray = require('is-typed-array');\n\nfunction uncurryThis(f) {\n return f.call.bind(f);\n}\n\nvar BigIntSupported = typeof BigInt !== 'undefined';\nvar SymbolSupported = typeof Symbol !== 'undefined';\n\nvar ObjectToString = uncurryThis(Object.prototype.toString);\n\nvar numberValue = uncurryThis(Number.prototype.valueOf);\nvar stringValue = uncurryThis(String.prototype.valueOf);\nvar booleanValue = uncurryThis(Boolean.prototype.valueOf);\n\nif (BigIntSupported) {\n var bigIntValue = uncurryThis(BigInt.prototype.valueOf);\n}\n\nif (SymbolSupported) {\n var symbolValue = uncurryThis(Symbol.prototype.valueOf);\n}\n\nfunction checkBoxedPrimitive(value, prototypeValueOf) {\n if (typeof value !== 'object') {\n return false;\n }\n try {\n prototypeValueOf(value);\n return true;\n } catch(e) {\n return false;\n }\n}\n\nexports.isArgumentsObject = isArgumentsObject;\nexports.isGeneratorFunction = isGeneratorFunction;\nexports.isTypedArray = isTypedArray;\n\n// Taken from here and modified for better browser support\n// https://github.com/sindresorhus/p-is-promise/blob/cda35a513bda03f977ad5cde3a079d237e82d7ef/index.js\nfunction isPromise(input) {\n\treturn (\n\t\t(\n\t\t\ttypeof Promise !== 'undefined' &&\n\t\t\tinput instanceof Promise\n\t\t) ||\n\t\t(\n\t\t\tinput !== null &&\n\t\t\ttypeof input === 'object' &&\n\t\t\ttypeof input.then === 'function' &&\n\t\t\ttypeof input.catch === 'function'\n\t\t)\n\t);\n}\nexports.isPromise = isPromise;\n\nfunction isArrayBufferView(value) {\n if (typeof ArrayBuffer !== 'undefined' && ArrayBuffer.isView) {\n return ArrayBuffer.isView(value);\n }\n\n return (\n isTypedArray(value) ||\n isDataView(value)\n );\n}\nexports.isArrayBufferView = isArrayBufferView;\n\n\nfunction isUint8Array(value) {\n return whichTypedArray(value) === 'Uint8Array';\n}\nexports.isUint8Array = isUint8Array;\n\nfunction isUint8ClampedArray(value) {\n return whichTypedArray(value) === 'Uint8ClampedArray';\n}\nexports.isUint8ClampedArray = isUint8ClampedArray;\n\nfunction isUint16Array(value) {\n return whichTypedArray(value) === 'Uint16Array';\n}\nexports.isUint16Array = isUint16Array;\n\nfunction isUint32Array(value) {\n return whichTypedArray(value) === 'Uint32Array';\n}\nexports.isUint32Array = isUint32Array;\n\nfunction isInt8Array(value) {\n return whichTypedArray(value) === 'Int8Array';\n}\nexports.isInt8Array = isInt8Array;\n\nfunction isInt16Array(value) {\n return whichTypedArray(value) === 'Int16Array';\n}\nexports.isInt16Array = isInt16Array;\n\nfunction isInt32Array(value) {\n return whichTypedArray(value) === 'Int32Array';\n}\nexports.isInt32Array = isInt32Array;\n\nfunction isFloat32Array(value) {\n return whichTypedArray(value) === 'Float32Array';\n}\nexports.isFloat32Array = isFloat32Array;\n\nfunction isFloat64Array(value) {\n return whichTypedArray(value) === 'Float64Array';\n}\nexports.isFloat64Array = isFloat64Array;\n\nfunction isBigInt64Array(value) {\n return whichTypedArray(value) === 'BigInt64Array';\n}\nexports.isBigInt64Array = isBigInt64Array;\n\nfunction isBigUint64Array(value) {\n return whichTypedArray(value) === 'BigUint64Array';\n}\nexports.isBigUint64Array = isBigUint64Array;\n\nfunction isMapToString(value) {\n return ObjectToString(value) === '[object Map]';\n}\nisMapToString.working = (\n typeof Map !== 'undefined' &&\n isMapToString(new Map())\n);\n\nfunction isMap(value) {\n if (typeof Map === 'undefined') {\n return false;\n }\n\n return isMapToString.working\n ? isMapToString(value)\n : value instanceof Map;\n}\nexports.isMap = isMap;\n\nfunction isSetToString(value) {\n return ObjectToString(value) === '[object Set]';\n}\nisSetToString.working = (\n typeof Set !== 'undefined' &&\n isSetToString(new Set())\n);\nfunction isSet(value) {\n if (typeof Set === 'undefined') {\n return false;\n }\n\n return isSetToString.working\n ? isSetToString(value)\n : value instanceof Set;\n}\nexports.isSet = isSet;\n\nfunction isWeakMapToString(value) {\n return ObjectToString(value) === '[object WeakMap]';\n}\nisWeakMapToString.working = (\n typeof WeakMap !== 'undefined' &&\n isWeakMapToString(new WeakMap())\n);\nfunction isWeakMap(value) {\n if (typeof WeakMap === 'undefined') {\n return false;\n }\n\n return isWeakMapToString.working\n ? isWeakMapToString(value)\n : value instanceof WeakMap;\n}\nexports.isWeakMap = isWeakMap;\n\nfunction isWeakSetToString(value) {\n return ObjectToString(value) === '[object WeakSet]';\n}\nisWeakSetToString.working = (\n typeof WeakSet !== 'undefined' &&\n isWeakSetToString(new WeakSet())\n);\nfunction isWeakSet(value) {\n return isWeakSetToString(value);\n}\nexports.isWeakSet = isWeakSet;\n\nfunction isArrayBufferToString(value) {\n return ObjectToString(value) === '[object ArrayBuffer]';\n}\nisArrayBufferToString.working = (\n typeof ArrayBuffer !== 'undefined' &&\n isArrayBufferToString(new ArrayBuffer())\n);\nfunction isArrayBuffer(value) {\n if (typeof ArrayBuffer === 'undefined') {\n return false;\n }\n\n return isArrayBufferToString.working\n ? isArrayBufferToString(value)\n : value instanceof ArrayBuffer;\n}\nexports.isArrayBuffer = isArrayBuffer;\n\nfunction isDataViewToString(value) {\n return ObjectToString(value) === '[object DataView]';\n}\nisDataViewToString.working = (\n typeof ArrayBuffer !== 'undefined' &&\n typeof DataView !== 'undefined' &&\n isDataViewToString(new DataView(new ArrayBuffer(1), 0, 1))\n);\nfunction isDataView(value) {\n if (typeof DataView === 'undefined') {\n return false;\n }\n\n return isDataViewToString.working\n ? isDataViewToString(value)\n : value instanceof DataView;\n}\nexports.isDataView = isDataView;\n\n// Store a copy of SharedArrayBuffer in case it's deleted elsewhere\nvar SharedArrayBufferCopy = typeof SharedArrayBuffer !== 'undefined' ? SharedArrayBuffer : undefined;\nfunction isSharedArrayBufferToString(value) {\n return ObjectToString(value) === '[object SharedArrayBuffer]';\n}\nfunction isSharedArrayBuffer(value) {\n if (typeof SharedArrayBufferCopy === 'undefined') {\n return false;\n }\n\n if (typeof isSharedArrayBufferToString.working === 'undefined') {\n isSharedArrayBufferToString.working = isSharedArrayBufferToString(new SharedArrayBufferCopy());\n }\n\n return isSharedArrayBufferToString.working\n ? isSharedArrayBufferToString(value)\n : value instanceof SharedArrayBufferCopy;\n}\nexports.isSharedArrayBuffer = isSharedArrayBuffer;\n\nfunction isAsyncFunction(value) {\n return ObjectToString(value) === '[object AsyncFunction]';\n}\nexports.isAsyncFunction = isAsyncFunction;\n\nfunction isMapIterator(value) {\n return ObjectToString(value) === '[object Map Iterator]';\n}\nexports.isMapIterator = isMapIterator;\n\nfunction isSetIterator(value) {\n return ObjectToString(value) === '[object Set Iterator]';\n}\nexports.isSetIterator = isSetIterator;\n\nfunction isGeneratorObject(value) {\n return ObjectToString(value) === '[object Generator]';\n}\nexports.isGeneratorObject = isGeneratorObject;\n\nfunction isWebAssemblyCompiledModule(value) {\n return ObjectToString(value) === '[object WebAssembly.Module]';\n}\nexports.isWebAssemblyCompiledModule = isWebAssemblyCompiledModule;\n\nfunction isNumberObject(value) {\n return checkBoxedPrimitive(value, numberValue);\n}\nexports.isNumberObject = isNumberObject;\n\nfunction isStringObject(value) {\n return checkBoxedPrimitive(value, stringValue);\n}\nexports.isStringObject = isStringObject;\n\nfunction isBooleanObject(value) {\n return checkBoxedPrimitive(value, booleanValue);\n}\nexports.isBooleanObject = isBooleanObject;\n\nfunction isBigIntObject(value) {\n return BigIntSupported && checkBoxedPrimitive(value, bigIntValue);\n}\nexports.isBigIntObject = isBigIntObject;\n\nfunction isSymbolObject(value) {\n return SymbolSupported && checkBoxedPrimitive(value, symbolValue);\n}\nexports.isSymbolObject = isSymbolObject;\n\nfunction isBoxedPrimitive(value) {\n return (\n isNumberObject(value) ||\n isStringObject(value) ||\n isBooleanObject(value) ||\n isBigIntObject(value) ||\n isSymbolObject(value)\n );\n}\nexports.isBoxedPrimitive = isBoxedPrimitive;\n\nfunction isAnyArrayBuffer(value) {\n return typeof Uint8Array !== 'undefined' && (\n isArrayBuffer(value) ||\n isSharedArrayBuffer(value)\n );\n}\nexports.isAnyArrayBuffer = isAnyArrayBuffer;\n\n['isProxy', 'isExternal', 'isModuleNamespaceObject'].forEach(function(method) {\n Object.defineProperty(exports, method, {\n enumerable: false,\n value: function() {\n throw new Error(method + ' is not supported in userland');\n }\n });\n});\n","module.exports = function isBuffer(arg) {\n return arg && typeof arg === 'object'\n && typeof arg.copy === 'function'\n && typeof arg.fill === 'function'\n && typeof arg.readUInt8 === 'function';\n}","if (typeof Object.create === 'function') {\n // implementation from standard node.js 'util' module\n module.exports = function inherits(ctor, superCtor) {\n if (superCtor) {\n ctor.super_ = superCtor\n ctor.prototype = Object.create(superCtor.prototype, {\n constructor: {\n value: ctor,\n enumerable: false,\n writable: true,\n configurable: true\n }\n })\n }\n };\n} else {\n // old school shim for old browsers\n module.exports = function inherits(ctor, superCtor) {\n if (superCtor) {\n ctor.super_ = superCtor\n var TempCtor = function () {}\n TempCtor.prototype = superCtor.prototype\n ctor.prototype = new TempCtor()\n ctor.prototype.constructor = ctor\n }\n }\n}\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nvar getOwnPropertyDescriptors = Object.getOwnPropertyDescriptors ||\n function getOwnPropertyDescriptors(obj) {\n var keys = Object.keys(obj);\n var descriptors = {};\n for (var i = 0; i < keys.length; i++) {\n descriptors[keys[i]] = Object.getOwnPropertyDescriptor(obj, keys[i]);\n }\n return descriptors;\n };\n\nvar formatRegExp = /%[sdj%]/g;\nexports.format = function(f) {\n if (!isString(f)) {\n var objects = [];\n for (var i = 0; i < arguments.length; i++) {\n objects.push(inspect(arguments[i]));\n }\n return objects.join(' ');\n }\n\n var i = 1;\n var args = arguments;\n var len = args.length;\n var str = String(f).replace(formatRegExp, function(x) {\n if (x === '%%') return '%';\n if (i >= len) return x;\n switch (x) {\n case '%s': return String(args[i++]);\n case '%d': return Number(args[i++]);\n case '%j':\n try {\n return JSON.stringify(args[i++]);\n } catch (_) {\n return '[Circular]';\n }\n default:\n return x;\n }\n });\n for (var x = args[i]; i < len; x = args[++i]) {\n if (isNull(x) || !isObject(x)) {\n str += ' ' + x;\n } else {\n str += ' ' + inspect(x);\n }\n }\n return str;\n};\n\n\n// Mark that a method should not be used.\n// Returns a modified function which warns once by default.\n// If --no-deprecation is set, then it is a no-op.\nexports.deprecate = function(fn, msg) {\n if (typeof process !== 'undefined' && process.noDeprecation === true) {\n return fn;\n }\n\n // Allow for deprecating things in the process of starting up.\n if (typeof process === 'undefined') {\n return function() {\n return exports.deprecate(fn, msg).apply(this, arguments);\n };\n }\n\n var warned = false;\n function deprecated() {\n if (!warned) {\n if (process.throwDeprecation) {\n throw new Error(msg);\n } else if (process.traceDeprecation) {\n console.trace(msg);\n } else {\n console.error(msg);\n }\n warned = true;\n }\n return fn.apply(this, arguments);\n }\n\n return deprecated;\n};\n\n\nvar debugs = {};\nvar debugEnvRegex = /^$/;\n\nif (process.env.NODE_DEBUG) {\n var debugEnv = process.env.NODE_DEBUG;\n debugEnv = debugEnv.replace(/[|\\\\{}()[\\]^$+?.]/g, '\\\\$&')\n .replace(/\\*/g, '.*')\n .replace(/,/g, '$|^')\n .toUpperCase();\n debugEnvRegex = new RegExp('^' + debugEnv + '$', 'i');\n}\nexports.debuglog = function(set) {\n set = set.toUpperCase();\n if (!debugs[set]) {\n if (debugEnvRegex.test(set)) {\n var pid = process.pid;\n debugs[set] = function() {\n var msg = exports.format.apply(exports, arguments);\n console.error('%s %d: %s', set, pid, msg);\n };\n } else {\n debugs[set] = function() {};\n }\n }\n return debugs[set];\n};\n\n\n/**\n * Echos the value of a value. Trys to print the value out\n * in the best way possible given the different types.\n *\n * @param {Object} obj The object to print out.\n * @param {Object} opts Optional options object that alters the output.\n */\n/* legacy: obj, showHidden, depth, colors*/\nfunction inspect(obj, opts) {\n // default options\n var ctx = {\n seen: [],\n stylize: stylizeNoColor\n };\n // legacy...\n if (arguments.length >= 3) ctx.depth = arguments[2];\n if (arguments.length >= 4) ctx.colors = arguments[3];\n if (isBoolean(opts)) {\n // legacy...\n ctx.showHidden = opts;\n } else if (opts) {\n // got an \"options\" object\n exports._extend(ctx, opts);\n }\n // set default options\n if (isUndefined(ctx.showHidden)) ctx.showHidden = false;\n if (isUndefined(ctx.depth)) ctx.depth = 2;\n if (isUndefined(ctx.colors)) ctx.colors = false;\n if (isUndefined(ctx.customInspect)) ctx.customInspect = true;\n if (ctx.colors) ctx.stylize = stylizeWithColor;\n return formatValue(ctx, obj, ctx.depth);\n}\nexports.inspect = inspect;\n\n\n// http://en.wikipedia.org/wiki/ANSI_escape_code#graphics\ninspect.colors = {\n 'bold' : [1, 22],\n 'italic' : [3, 23],\n 'underline' : [4, 24],\n 'inverse' : [7, 27],\n 'white' : [37, 39],\n 'grey' : [90, 39],\n 'black' : [30, 39],\n 'blue' : [34, 39],\n 'cyan' : [36, 39],\n 'green' : [32, 39],\n 'magenta' : [35, 39],\n 'red' : [31, 39],\n 'yellow' : [33, 39]\n};\n\n// Don't use 'blue' not visible on cmd.exe\ninspect.styles = {\n 'special': 'cyan',\n 'number': 'yellow',\n 'boolean': 'yellow',\n 'undefined': 'grey',\n 'null': 'bold',\n 'string': 'green',\n 'date': 'magenta',\n // \"name\": intentionally not styling\n 'regexp': 'red'\n};\n\n\nfunction stylizeWithColor(str, styleType) {\n var style = inspect.styles[styleType];\n\n if (style) {\n return '\\u001b[' + inspect.colors[style][0] + 'm' + str +\n '\\u001b[' + inspect.colors[style][1] + 'm';\n } else {\n return str;\n }\n}\n\n\nfunction stylizeNoColor(str, styleType) {\n return str;\n}\n\n\nfunction arrayToHash(array) {\n var hash = {};\n\n array.forEach(function(val, idx) {\n hash[val] = true;\n });\n\n return hash;\n}\n\n\nfunction formatValue(ctx, value, recurseTimes) {\n // Provide a hook for user-specified inspect functions.\n // Check that value is an object with an inspect function on it\n if (ctx.customInspect &&\n value &&\n isFunction(value.inspect) &&\n // Filter out the util module, it's inspect function is special\n value.inspect !== exports.inspect &&\n // Also filter out any prototype objects using the circular check.\n !(value.constructor && value.constructor.prototype === value)) {\n var ret = value.inspect(recurseTimes, ctx);\n if (!isString(ret)) {\n ret = formatValue(ctx, ret, recurseTimes);\n }\n return ret;\n }\n\n // Primitive types cannot have properties\n var primitive = formatPrimitive(ctx, value);\n if (primitive) {\n return primitive;\n }\n\n // Look up the keys of the object.\n var keys = Object.keys(value);\n var visibleKeys = arrayToHash(keys);\n\n if (ctx.showHidden) {\n keys = Object.getOwnPropertyNames(value);\n }\n\n // IE doesn't make error fields non-enumerable\n // http://msdn.microsoft.com/en-us/library/ie/dww52sbt(v=vs.94).aspx\n if (isError(value)\n && (keys.indexOf('message') >= 0 || keys.indexOf('description') >= 0)) {\n return formatError(value);\n }\n\n // Some type of object without properties can be shortcutted.\n if (keys.length === 0) {\n if (isFunction(value)) {\n var name = value.name ? ': ' + value.name : '';\n return ctx.stylize('[Function' + name + ']', 'special');\n }\n if (isRegExp(value)) {\n return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp');\n }\n if (isDate(value)) {\n return ctx.stylize(Date.prototype.toString.call(value), 'date');\n }\n if (isError(value)) {\n return formatError(value);\n }\n }\n\n var base = '', array = false, braces = ['{', '}'];\n\n // Make Array say that they are Array\n if (isArray(value)) {\n array = true;\n braces = ['[', ']'];\n }\n\n // Make functions say that they are functions\n if (isFunction(value)) {\n var n = value.name ? ': ' + value.name : '';\n base = ' [Function' + n + ']';\n }\n\n // Make RegExps say that they are RegExps\n if (isRegExp(value)) {\n base = ' ' + RegExp.prototype.toString.call(value);\n }\n\n // Make dates with properties first say the date\n if (isDate(value)) {\n base = ' ' + Date.prototype.toUTCString.call(value);\n }\n\n // Make error with message first say the error\n if (isError(value)) {\n base = ' ' + formatError(value);\n }\n\n if (keys.length === 0 && (!array || value.length == 0)) {\n return braces[0] + base + braces[1];\n }\n\n if (recurseTimes < 0) {\n if (isRegExp(value)) {\n return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp');\n } else {\n return ctx.stylize('[Object]', 'special');\n }\n }\n\n ctx.seen.push(value);\n\n var output;\n if (array) {\n output = formatArray(ctx, value, recurseTimes, visibleKeys, keys);\n } else {\n output = keys.map(function(key) {\n return formatProperty(ctx, value, recurseTimes, visibleKeys, key, array);\n });\n }\n\n ctx.seen.pop();\n\n return reduceToSingleString(output, base, braces);\n}\n\n\nfunction formatPrimitive(ctx, value) {\n if (isUndefined(value))\n return ctx.stylize('undefined', 'undefined');\n if (isString(value)) {\n var simple = '\\'' + JSON.stringify(value).replace(/^\"|\"$/g, '')\n .replace(/'/g, \"\\\\'\")\n .replace(/\\\\\"/g, '\"') + '\\'';\n return ctx.stylize(simple, 'string');\n }\n if (isNumber(value))\n return ctx.stylize('' + value, 'number');\n if (isBoolean(value))\n return ctx.stylize('' + value, 'boolean');\n // For some reason typeof null is \"object\", so special case here.\n if (isNull(value))\n return ctx.stylize('null', 'null');\n}\n\n\nfunction formatError(value) {\n return '[' + Error.prototype.toString.call(value) + ']';\n}\n\n\nfunction formatArray(ctx, value, recurseTimes, visibleKeys, keys) {\n var output = [];\n for (var i = 0, l = value.length; i < l; ++i) {\n if (hasOwnProperty(value, String(i))) {\n output.push(formatProperty(ctx, value, recurseTimes, visibleKeys,\n String(i), true));\n } else {\n output.push('');\n }\n }\n keys.forEach(function(key) {\n if (!key.match(/^\\d+$/)) {\n output.push(formatProperty(ctx, value, recurseTimes, visibleKeys,\n key, true));\n }\n });\n return output;\n}\n\n\nfunction formatProperty(ctx, value, recurseTimes, visibleKeys, key, array) {\n var name, str, desc;\n desc = Object.getOwnPropertyDescriptor(value, key) || { value: value[key] };\n if (desc.get) {\n if (desc.set) {\n str = ctx.stylize('[Getter/Setter]', 'special');\n } else {\n str = ctx.stylize('[Getter]', 'special');\n }\n } else {\n if (desc.set) {\n str = ctx.stylize('[Setter]', 'special');\n }\n }\n if (!hasOwnProperty(visibleKeys, key)) {\n name = '[' + key + ']';\n }\n if (!str) {\n if (ctx.seen.indexOf(desc.value) < 0) {\n if (isNull(recurseTimes)) {\n str = formatValue(ctx, desc.value, null);\n } else {\n str = formatValue(ctx, desc.value, recurseTimes - 1);\n }\n if (str.indexOf('\\n') > -1) {\n if (array) {\n str = str.split('\\n').map(function(line) {\n return ' ' + line;\n }).join('\\n').slice(2);\n } else {\n str = '\\n' + str.split('\\n').map(function(line) {\n return ' ' + line;\n }).join('\\n');\n }\n }\n } else {\n str = ctx.stylize('[Circular]', 'special');\n }\n }\n if (isUndefined(name)) {\n if (array && key.match(/^\\d+$/)) {\n return str;\n }\n name = JSON.stringify('' + key);\n if (name.match(/^\"([a-zA-Z_][a-zA-Z_0-9]*)\"$/)) {\n name = name.slice(1, -1);\n name = ctx.stylize(name, 'name');\n } else {\n name = name.replace(/'/g, \"\\\\'\")\n .replace(/\\\\\"/g, '\"')\n .replace(/(^\"|\"$)/g, \"'\");\n name = ctx.stylize(name, 'string');\n }\n }\n\n return name + ': ' + str;\n}\n\n\nfunction reduceToSingleString(output, base, braces) {\n var numLinesEst = 0;\n var length = output.reduce(function(prev, cur) {\n numLinesEst++;\n if (cur.indexOf('\\n') >= 0) numLinesEst++;\n return prev + cur.replace(/\\u001b\\[\\d\\d?m/g, '').length + 1;\n }, 0);\n\n if (length > 60) {\n return braces[0] +\n (base === '' ? '' : base + '\\n ') +\n ' ' +\n output.join(',\\n ') +\n ' ' +\n braces[1];\n }\n\n return braces[0] + base + ' ' + output.join(', ') + ' ' + braces[1];\n}\n\n\n// NOTE: These type checking functions intentionally don't use `instanceof`\n// because it is fragile and can be easily faked with `Object.create()`.\nexports.types = require('./support/types');\n\nfunction isArray(ar) {\n return Array.isArray(ar);\n}\nexports.isArray = isArray;\n\nfunction isBoolean(arg) {\n return typeof arg === 'boolean';\n}\nexports.isBoolean = isBoolean;\n\nfunction isNull(arg) {\n return arg === null;\n}\nexports.isNull = isNull;\n\nfunction isNullOrUndefined(arg) {\n return arg == null;\n}\nexports.isNullOrUndefined = isNullOrUndefined;\n\nfunction isNumber(arg) {\n return typeof arg === 'number';\n}\nexports.isNumber = isNumber;\n\nfunction isString(arg) {\n return typeof arg === 'string';\n}\nexports.isString = isString;\n\nfunction isSymbol(arg) {\n return typeof arg === 'symbol';\n}\nexports.isSymbol = isSymbol;\n\nfunction isUndefined(arg) {\n return arg === void 0;\n}\nexports.isUndefined = isUndefined;\n\nfunction isRegExp(re) {\n return isObject(re) && objectToString(re) === '[object RegExp]';\n}\nexports.isRegExp = isRegExp;\nexports.types.isRegExp = isRegExp;\n\nfunction isObject(arg) {\n return typeof arg === 'object' && arg !== null;\n}\nexports.isObject = isObject;\n\nfunction isDate(d) {\n return isObject(d) && objectToString(d) === '[object Date]';\n}\nexports.isDate = isDate;\nexports.types.isDate = isDate;\n\nfunction isError(e) {\n return isObject(e) &&\n (objectToString(e) === '[object Error]' || e instanceof Error);\n}\nexports.isError = isError;\nexports.types.isNativeError = isError;\n\nfunction isFunction(arg) {\n return typeof arg === 'function';\n}\nexports.isFunction = isFunction;\n\nfunction isPrimitive(arg) {\n return arg === null ||\n typeof arg === 'boolean' ||\n typeof arg === 'number' ||\n typeof arg === 'string' ||\n typeof arg === 'symbol' || // ES6 symbol\n typeof arg === 'undefined';\n}\nexports.isPrimitive = isPrimitive;\n\nexports.isBuffer = require('./support/isBuffer');\n\nfunction objectToString(o) {\n return Object.prototype.toString.call(o);\n}\n\n\nfunction pad(n) {\n return n < 10 ? '0' + n.toString(10) : n.toString(10);\n}\n\n\nvar months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep',\n 'Oct', 'Nov', 'Dec'];\n\n// 26 Feb 16:19:34\nfunction timestamp() {\n var d = new Date();\n var time = [pad(d.getHours()),\n pad(d.getMinutes()),\n pad(d.getSeconds())].join(':');\n return [d.getDate(), months[d.getMonth()], time].join(' ');\n}\n\n\n// log is just a thin wrapper to console.log that prepends a timestamp\nexports.log = function() {\n console.log('%s - %s', timestamp(), exports.format.apply(exports, arguments));\n};\n\n\n/**\n * Inherit the prototype methods from one constructor into another.\n *\n * The Function.prototype.inherits from lang.js rewritten as a standalone\n * function (not on Function.prototype). NOTE: If this file is to be loaded\n * during bootstrapping this function needs to be rewritten using some native\n * functions as prototype setup using normal JavaScript does not work as\n * expected during bootstrapping (see mirror.js in r114903).\n *\n * @param {function} ctor Constructor function which needs to inherit the\n * prototype.\n * @param {function} superCtor Constructor function to inherit prototype from.\n */\nexports.inherits = require('inherits');\n\nexports._extend = function(origin, add) {\n // Don't do anything if add isn't an object\n if (!add || !isObject(add)) return origin;\n\n var keys = Object.keys(add);\n var i = keys.length;\n while (i--) {\n origin[keys[i]] = add[keys[i]];\n }\n return origin;\n};\n\nfunction hasOwnProperty(obj, prop) {\n return Object.prototype.hasOwnProperty.call(obj, prop);\n}\n\nvar kCustomPromisifiedSymbol = typeof Symbol !== 'undefined' ? Symbol('util.promisify.custom') : undefined;\n\nexports.promisify = function promisify(original) {\n if (typeof original !== 'function')\n throw new TypeError('The \"original\" argument must be of type Function');\n\n if (kCustomPromisifiedSymbol && original[kCustomPromisifiedSymbol]) {\n var fn = original[kCustomPromisifiedSymbol];\n if (typeof fn !== 'function') {\n throw new TypeError('The \"util.promisify.custom\" argument must be of type Function');\n }\n Object.defineProperty(fn, kCustomPromisifiedSymbol, {\n value: fn, enumerable: false, writable: false, configurable: true\n });\n return fn;\n }\n\n function fn() {\n var promiseResolve, promiseReject;\n var promise = new Promise(function (resolve, reject) {\n promiseResolve = resolve;\n promiseReject = reject;\n });\n\n var args = [];\n for (var i = 0; i < arguments.length; i++) {\n args.push(arguments[i]);\n }\n args.push(function (err, value) {\n if (err) {\n promiseReject(err);\n } else {\n promiseResolve(value);\n }\n });\n\n try {\n original.apply(this, args);\n } catch (err) {\n promiseReject(err);\n }\n\n return promise;\n }\n\n Object.setPrototypeOf(fn, Object.getPrototypeOf(original));\n\n if (kCustomPromisifiedSymbol) Object.defineProperty(fn, kCustomPromisifiedSymbol, {\n value: fn, enumerable: false, writable: false, configurable: true\n });\n return Object.defineProperties(\n fn,\n getOwnPropertyDescriptors(original)\n );\n}\n\nexports.promisify.custom = kCustomPromisifiedSymbol\n\nfunction callbackifyOnRejected(reason, cb) {\n // `!reason` guard inspired by bluebird (Ref: https://goo.gl/t5IS6M).\n // Because `null` is a special error value in callbacks which means \"no error\n // occurred\", we error-wrap so the callback consumer can distinguish between\n // \"the promise rejected with null\" or \"the promise fulfilled with undefined\".\n if (!reason) {\n var newReason = new Error('Promise was rejected with a falsy value');\n newReason.reason = reason;\n reason = newReason;\n }\n return cb(reason);\n}\n\nfunction callbackify(original) {\n if (typeof original !== 'function') {\n throw new TypeError('The \"original\" argument must be of type Function');\n }\n\n // We DO NOT return the promise as it gives the user a false sense that\n // the promise is actually somehow related to the callback's execution\n // and that the callback throwing will reject the promise.\n function callbackified() {\n var args = [];\n for (var i = 0; i < arguments.length; i++) {\n args.push(arguments[i]);\n }\n\n var maybeCb = args.pop();\n if (typeof maybeCb !== 'function') {\n throw new TypeError('The last argument must be of type Function');\n }\n var self = this;\n var cb = function() {\n return maybeCb.apply(self, arguments);\n };\n // In true node style we process the callback on `nextTick` with all the\n // implications (stack, `uncaughtException`, `async_hooks`)\n original.apply(this, args)\n .then(function(ret) { process.nextTick(cb.bind(null, null, ret)) },\n function(rej) { process.nextTick(callbackifyOnRejected.bind(null, rej, cb)) });\n }\n\n Object.setPrototypeOf(callbackified, Object.getPrototypeOf(original));\n Object.defineProperties(callbackified,\n getOwnPropertyDescriptors(original));\n return callbackified;\n}\nexports.callbackify = callbackify;\n","\"use strict\"\n\nexports.TextEncoder =\n typeof TextEncoder !== \"undefined\" ? TextEncoder : require(\"util\").TextEncoder\n\nexports.TextDecoder =\n typeof TextDecoder !== \"undefined\" ? TextDecoder : require(\"util\").TextDecoder\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getArrayBuffer = exports.decodeBuffer = exports.encodeBuffer = void 0;\nvar web_encoding_1 = require(\"web-encoding\");\nfunction encodeBuffer(text) {\n var encoder = new web_encoding_1.TextEncoder();\n var encoded = encoder.encode(text);\n return getArrayBuffer(encoded);\n}\nexports.encodeBuffer = encodeBuffer;\nfunction decodeBuffer(buffer, encoding) {\n var decoder = new web_encoding_1.TextDecoder(encoding);\n return decoder.decode(buffer);\n}\nexports.decodeBuffer = decodeBuffer;\nfunction getArrayBuffer(array) {\n return array.buffer.slice(array.byteOffset, array.byteOffset + array.byteLength);\n}\nexports.getArrayBuffer = getArrayBuffer;\n//# sourceMappingURL=bufferUtils.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.uuidv4 = void 0;\nfunction uuidv4() {\n return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function (c) {\n var r = (Math.random() * 16) | 0;\n var v = c == 'x' ? r : (r & 0x3) | 0x8;\n return v.toString(16);\n });\n}\nexports.uuidv4 = uuidv4;\n//# sourceMappingURL=uuid.js.map","\"use strict\";\nvar __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nvar __generator = (this && this.__generator) || function (thisArg, body) {\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\n function verb(n) { return function (v) { return step([n, v]); }; }\n function step(op) {\n if (f) throw new TypeError(\"Generator is already executing.\");\n while (_) try {\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\n if (y = 0, t) op = [op[0] & 2, t.value];\n switch (op[0]) {\n case 0: case 1: t = op; break;\n case 4: _.label++; return { value: op[1], done: false };\n case 5: _.label++; y = op[1]; op = [0]; continue;\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\n if (t[2]) _.ops.pop();\n _.trys.pop(); continue;\n }\n op = body.call(thisArg, _);\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\n }\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.IsomorphicRequest = void 0;\nvar headers_polyfill_1 = require(\"headers-polyfill\");\nvar outvariant_1 = require(\"outvariant\");\nvar bufferUtils_1 = require(\"./utils/bufferUtils\");\nvar uuid_1 = require(\"./utils/uuid\");\nvar IsomorphicRequest = /** @class */ (function () {\n function IsomorphicRequest(input, init) {\n if (init === void 0) { init = {}; }\n var defaultBody = new ArrayBuffer(0);\n this._bodyUsed = false;\n if (input instanceof IsomorphicRequest) {\n this.id = input.id;\n this.url = input.url;\n this.method = input.method;\n this.headers = input.headers;\n this.credentials = input.credentials;\n this._body = input._body || defaultBody;\n return;\n }\n this.id = uuid_1.uuidv4();\n this.url = input;\n this.method = init.method || 'GET';\n this.headers = new headers_polyfill_1.Headers(init.headers);\n this.credentials = init.credentials || 'same-origin';\n this._body = init.body || defaultBody;\n }\n Object.defineProperty(IsomorphicRequest.prototype, \"bodyUsed\", {\n get: function () {\n return this._bodyUsed;\n },\n enumerable: false,\n configurable: true\n });\n IsomorphicRequest.prototype.text = function () {\n return __awaiter(this, void 0, void 0, function () {\n return __generator(this, function (_a) {\n outvariant_1.invariant(!this.bodyUsed, 'Failed to execute \"text\" on \"IsomorphicRequest\": body buffer already read');\n this._bodyUsed = true;\n return [2 /*return*/, bufferUtils_1.decodeBuffer(this._body)];\n });\n });\n };\n IsomorphicRequest.prototype.json = function () {\n return __awaiter(this, void 0, void 0, function () {\n var text;\n return __generator(this, function (_a) {\n outvariant_1.invariant(!this.bodyUsed, 'Failed to execute \"json\" on \"IsomorphicRequest\": body buffer already read');\n this._bodyUsed = true;\n text = bufferUtils_1.decodeBuffer(this._body);\n return [2 /*return*/, JSON.parse(text)];\n });\n });\n };\n IsomorphicRequest.prototype.arrayBuffer = function () {\n return __awaiter(this, void 0, void 0, function () {\n return __generator(this, function (_a) {\n outvariant_1.invariant(!this.bodyUsed, 'Failed to execute \"arrayBuffer\" on \"IsomorphicRequest\": body buffer already read');\n this._bodyUsed = true;\n return [2 /*return*/, this._body];\n });\n });\n };\n IsomorphicRequest.prototype.clone = function () {\n return new IsomorphicRequest(this);\n };\n return IsomorphicRequest;\n}());\nexports.IsomorphicRequest = IsomorphicRequest;\n//# sourceMappingURL=IsomorphicRequest.js.map","\"use strict\";\nvar __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nvar __generator = (this && this.__generator) || function (thisArg, body) {\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\n function verb(n) { return function (v) { return step([n, v]); }; }\n function step(op) {\n if (f) throw new TypeError(\"Generator is already executing.\");\n while (_) try {\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\n if (y = 0, t) op = [op[0] & 2, t.value];\n switch (op[0]) {\n case 0: case 1: t = op; break;\n case 4: _.label++; return { value: op[1], done: false };\n case 5: _.label++; y = op[1]; op = [0]; continue;\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\n if (t[2]) _.ops.pop();\n _.trys.pop(); continue;\n }\n op = body.call(thisArg, _);\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\n }\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.createLazyCallback = void 0;\nfunction createLazyCallback(options) {\n var _this = this;\n if (options === void 0) { options = {}; }\n var calledTimes = 0;\n var autoResolveTimeout;\n var remoteResolve;\n var callPromise = new Promise(function (resolve) {\n remoteResolve = resolve;\n }).finally(function () {\n clearTimeout(autoResolveTimeout);\n });\n var fn = function () {\n var _a;\n var args = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n args[_i] = arguments[_i];\n }\n if (options.maxCalls && calledTimes >= options.maxCalls) {\n (_a = options.maxCallsCallback) === null || _a === void 0 ? void 0 : _a.call(options);\n }\n remoteResolve(args);\n calledTimes++;\n };\n fn.invoked = function () { return __awaiter(_this, void 0, void 0, function () {\n return __generator(this, function (_a) {\n // Immediately resolve the callback if it hasn't been called already.\n autoResolveTimeout = setTimeout(function () {\n remoteResolve([]);\n }, 0);\n return [2 /*return*/, callPromise];\n });\n }); };\n return fn;\n}\nexports.createLazyCallback = createLazyCallback;\n//# sourceMappingURL=createLazyCallback.js.map","\"use strict\";\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.InteractiveIsomorphicRequest = void 0;\nvar outvariant_1 = require(\"outvariant\");\nvar IsomorphicRequest_1 = require(\"./IsomorphicRequest\");\nvar createLazyCallback_1 = require(\"./utils/createLazyCallback\");\nvar InteractiveIsomorphicRequest = /** @class */ (function (_super) {\n __extends(InteractiveIsomorphicRequest, _super);\n function InteractiveIsomorphicRequest(request) {\n var _this = _super.call(this, request) || this;\n _this.respondWith = createLazyCallback_1.createLazyCallback({\n maxCalls: 1,\n maxCallsCallback: function () {\n outvariant_1.invariant(false, 'Failed to respond to \"%s %s\" request: the \"request\" event has already been responded to.', _this.method, _this.url.href);\n },\n });\n return _this;\n }\n return InteractiveIsomorphicRequest;\n}(IsomorphicRequest_1.IsomorphicRequest));\nexports.InteractiveIsomorphicRequest = InteractiveIsomorphicRequest;\n//# sourceMappingURL=InteractiveIsomorphicRequest.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getCleanUrl = void 0;\n/**\n * Removes query parameters and hashes from a given URL.\n */\nfunction getCleanUrl(url, isAbsolute) {\n if (isAbsolute === void 0) { isAbsolute = true; }\n return [isAbsolute && url.origin, url.pathname].filter(Boolean).join('');\n}\nexports.getCleanUrl = getCleanUrl;\n//# sourceMappingURL=getCleanUrl.js.map","\"use strict\";\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __exportStar = (this && this.__exportStar) || function(m, exports) {\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.decodeBuffer = exports.encodeBuffer = exports.getCleanUrl = void 0;\n__exportStar(require(\"./glossary\"), exports);\n__exportStar(require(\"./Interceptor\"), exports);\n__exportStar(require(\"./BatchInterceptor\"), exports);\n__exportStar(require(\"./IsomorphicRequest\"), exports);\n__exportStar(require(\"./InteractiveIsomorphicRequest\"), exports);\n/* Utils */\nvar getCleanUrl_1 = require(\"./utils/getCleanUrl\");\nObject.defineProperty(exports, \"getCleanUrl\", { enumerable: true, get: function () { return getCleanUrl_1.getCleanUrl; } });\nvar bufferUtils_1 = require(\"./utils/bufferUtils\");\nObject.defineProperty(exports, \"encodeBuffer\", { enumerable: true, get: function () { return bufferUtils_1.encodeBuffer; } });\nObject.defineProperty(exports, \"decodeBuffer\", { enumerable: true, get: function () { return bufferUtils_1.decodeBuffer; } });\n//# sourceMappingURL=index.js.map","\"use strict\";\n\nvar defaultParseOptions = {\n decodeValues: true,\n map: false,\n silent: false,\n};\n\nfunction isNonEmptyString(str) {\n return typeof str === \"string\" && !!str.trim();\n}\n\nfunction parseString(setCookieValue, options) {\n var parts = setCookieValue.split(\";\").filter(isNonEmptyString);\n\n var nameValuePairStr = parts.shift();\n var parsed = parseNameValuePair(nameValuePairStr);\n var name = parsed.name;\n var value = parsed.value;\n\n options = options\n ? Object.assign({}, defaultParseOptions, options)\n : defaultParseOptions;\n\n try {\n value = options.decodeValues ? decodeURIComponent(value) : value; // decode cookie value\n } catch (e) {\n console.error(\n \"set-cookie-parser encountered an error while decoding a cookie with value '\" +\n value +\n \"'. Set options.decodeValues to false to disable this feature.\",\n e\n );\n }\n\n var cookie = {\n name: name,\n value: value,\n };\n\n parts.forEach(function (part) {\n var sides = part.split(\"=\");\n var key = sides.shift().trimLeft().toLowerCase();\n var value = sides.join(\"=\");\n if (key === \"expires\") {\n cookie.expires = new Date(value);\n } else if (key === \"max-age\") {\n cookie.maxAge = parseInt(value, 10);\n } else if (key === \"secure\") {\n cookie.secure = true;\n } else if (key === \"httponly\") {\n cookie.httpOnly = true;\n } else if (key === \"samesite\") {\n cookie.sameSite = value;\n } else {\n cookie[key] = value;\n }\n });\n\n return cookie;\n}\n\nfunction parseNameValuePair(nameValuePairStr) {\n // Parses name-value-pair according to rfc6265bis draft\n\n var name = \"\";\n var value = \"\";\n var nameValueArr = nameValuePairStr.split(\"=\");\n if (nameValueArr.length > 1) {\n name = nameValueArr.shift();\n value = nameValueArr.join(\"=\"); // everything after the first =, joined by a \"=\" if there was more than one part\n } else {\n value = nameValuePairStr;\n }\n\n return { name: name, value: value };\n}\n\nfunction parse(input, options) {\n options = options\n ? Object.assign({}, defaultParseOptions, options)\n : defaultParseOptions;\n\n if (!input) {\n if (!options.map) {\n return [];\n } else {\n return {};\n }\n }\n\n if (input.headers && input.headers[\"set-cookie\"]) {\n // fast-path for node.js (which automatically normalizes header names to lower-case\n input = input.headers[\"set-cookie\"];\n } else if (input.headers) {\n // slow-path for other environments - see #25\n var sch =\n input.headers[\n Object.keys(input.headers).find(function (key) {\n return key.toLowerCase() === \"set-cookie\";\n })\n ];\n // warn if called on a request-like object with a cookie header rather than a set-cookie header - see #34, 36\n if (!sch && input.headers.cookie && !options.silent) {\n console.warn(\n \"Warning: set-cookie-parser appears to have been called on a request object. It is designed to parse Set-Cookie headers from responses, not Cookie headers from requests. Set the option {silent: true} to suppress this warning.\"\n );\n }\n input = sch;\n }\n if (!Array.isArray(input)) {\n input = [input];\n }\n\n options = options\n ? Object.assign({}, defaultParseOptions, options)\n : defaultParseOptions;\n\n if (!options.map) {\n return input.filter(isNonEmptyString).map(function (str) {\n return parseString(str, options);\n });\n } else {\n var cookies = {};\n return input.filter(isNonEmptyString).reduce(function (cookies, str) {\n var cookie = parseString(str, options);\n cookies[cookie.name] = cookie;\n return cookies;\n }, cookies);\n }\n}\n\n/*\n Set-Cookie header field-values are sometimes comma joined in one string. This splits them without choking on commas\n that are within a single set-cookie field-value, such as in the Expires portion.\n\n This is uncommon, but explicitly allowed - see https://tools.ietf.org/html/rfc2616#section-4.2\n Node.js does this for every header *except* set-cookie - see https://github.com/nodejs/node/blob/d5e363b77ebaf1caf67cd7528224b651c86815c1/lib/_http_incoming.js#L128\n React Native's fetch does this for *every* header, including set-cookie.\n\n Based on: https://github.com/google/j2objc/commit/16820fdbc8f76ca0c33472810ce0cb03d20efe25\n Credits to: https://github.com/tomball for original and https://github.com/chrusart for JavaScript implementation\n*/\nfunction splitCookiesString(cookiesString) {\n if (Array.isArray(cookiesString)) {\n return cookiesString;\n }\n if (typeof cookiesString !== \"string\") {\n return [];\n }\n\n var cookiesStrings = [];\n var pos = 0;\n var start;\n var ch;\n var lastComma;\n var nextStart;\n var cookiesSeparatorFound;\n\n function skipWhitespace() {\n while (pos < cookiesString.length && /\\s/.test(cookiesString.charAt(pos))) {\n pos += 1;\n }\n return pos < cookiesString.length;\n }\n\n function notSpecialChar() {\n ch = cookiesString.charAt(pos);\n\n return ch !== \"=\" && ch !== \";\" && ch !== \",\";\n }\n\n while (pos < cookiesString.length) {\n start = pos;\n cookiesSeparatorFound = false;\n\n while (skipWhitespace()) {\n ch = cookiesString.charAt(pos);\n if (ch === \",\") {\n // ',' is a cookie separator if we have later first '=', not ';' or ','\n lastComma = pos;\n pos += 1;\n\n skipWhitespace();\n nextStart = pos;\n\n while (pos < cookiesString.length && notSpecialChar()) {\n pos += 1;\n }\n\n // currently special character\n if (pos < cookiesString.length && cookiesString.charAt(pos) === \"=\") {\n // we found cookies separator\n cookiesSeparatorFound = true;\n // pos is inside the next cookie, so back up and return it.\n pos = nextStart;\n cookiesStrings.push(cookiesString.substring(start, lastComma));\n start = pos;\n } else {\n // in param ',' or param separator ';',\n // we continue from that comma\n pos = lastComma + 1;\n }\n } else {\n pos += 1;\n }\n }\n\n if (!cookiesSeparatorFound || pos >= cookiesString.length) {\n cookiesStrings.push(cookiesString.substring(start, cookiesString.length));\n }\n }\n\n return cookiesStrings;\n}\n\nmodule.exports = parse;\nmodule.exports.parse = parse;\nmodule.exports.parseString = parseString;\nmodule.exports.splitCookiesString = splitCookiesString;\n","\"use strict\";\nvar __rest = (this && this.__rest) || function (s, e) {\n var t = {};\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\n t[p] = s[p];\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\n t[p[i]] = s[p[i]];\n }\n return t;\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.store = exports.PERSISTENCY_KEY = void 0;\nconst set_cookie_parser_1 = require(\"set-cookie-parser\");\nexports.PERSISTENCY_KEY = 'MSW_COOKIE_STORE';\nfunction supportsLocalStorage() {\n try {\n if (localStorage == null) {\n return false;\n }\n const testKey = exports.PERSISTENCY_KEY + '_test';\n localStorage.setItem(testKey, 'test');\n localStorage.getItem(testKey);\n localStorage.removeItem(testKey);\n return true;\n }\n catch (error) {\n return false;\n }\n}\nclass CookieStore {\n constructor() {\n this.store = new Map();\n }\n /**\n * Sets the given request cookies into the store.\n * Respects the `request.credentials` policy.\n */\n add(request, response) {\n if (request.credentials === 'omit') {\n return;\n }\n const requestUrl = new URL(request.url);\n const responseCookies = response.headers.get('set-cookie');\n if (!responseCookies) {\n return;\n }\n const now = Date.now();\n const parsedResponseCookies = set_cookie_parser_1.parse(responseCookies).map((_a) => {\n var { maxAge } = _a, cookie = __rest(_a, [\"maxAge\"]);\n return (Object.assign(Object.assign({}, cookie), { expires: maxAge === undefined ? cookie.expires : new Date(now + maxAge * 1000), maxAge }));\n });\n const prevCookies = this.store.get(requestUrl.origin) || new Map();\n parsedResponseCookies.forEach((cookie) => {\n this.store.set(requestUrl.origin, prevCookies.set(cookie.name, cookie));\n });\n }\n /**\n * Returns cookies relevant to the given request\n * and its `request.credentials` policy.\n */\n get(request) {\n this.deleteExpiredCookies();\n const requestUrl = new URL(request.url);\n const originCookies = this.store.get(requestUrl.origin) || new Map();\n switch (request.credentials) {\n case 'include': {\n // Support running this method in Node.js.\n if (typeof document === 'undefined') {\n return originCookies;\n }\n const documentCookies = set_cookie_parser_1.parse(document.cookie);\n documentCookies.forEach((cookie) => {\n originCookies.set(cookie.name, cookie);\n });\n return originCookies;\n }\n case 'same-origin': {\n return originCookies;\n }\n default:\n return new Map();\n }\n }\n /**\n * Returns a collection of all stored cookies.\n */\n getAll() {\n this.deleteExpiredCookies();\n return this.store;\n }\n /**\n * Deletes all cookies associated with the given request.\n */\n deleteAll(request) {\n const requestUrl = new URL(request.url);\n this.store.delete(requestUrl.origin);\n }\n /**\n * Clears the entire cookie store.\n */\n clear() {\n this.store.clear();\n }\n /**\n * Hydrates the virtual cookie store from the `localStorage` if defined.\n */\n hydrate() {\n if (!supportsLocalStorage()) {\n return;\n }\n const persistedCookies = localStorage.getItem(exports.PERSISTENCY_KEY);\n if (!persistedCookies) {\n return;\n }\n try {\n const parsedCookies = JSON.parse(persistedCookies);\n parsedCookies.forEach(([origin, cookies]) => {\n this.store.set(origin, new Map(cookies.map((_a) => {\n var [token, _b] = _a, { expires } = _b, cookie = __rest(_b, [\"expires\"]);\n return [\n token,\n expires === undefined\n ? cookie\n : Object.assign(Object.assign({}, cookie), { expires: new Date(expires) }),\n ];\n })));\n });\n }\n catch (error) {\n console.warn(`\n[virtual-cookie] Failed to parse a stored cookie from the localStorage (key \"${exports.PERSISTENCY_KEY}\").\n\nStored value:\n${localStorage.getItem(exports.PERSISTENCY_KEY)}\n\nThrown exception:\n${error}\n\nInvalid value has been removed from localStorage to prevent subsequent failed parsing attempts.`);\n localStorage.removeItem(exports.PERSISTENCY_KEY);\n }\n }\n /**\n * Persists the current virtual cookies into the `localStorage` if defined,\n * so they are available on the next page load.\n */\n persist() {\n if (!supportsLocalStorage()) {\n return;\n }\n const serializedCookies = Array.from(this.store.entries()).map(([origin, cookies]) => {\n return [origin, Array.from(cookies.entries())];\n });\n localStorage.setItem(exports.PERSISTENCY_KEY, JSON.stringify(serializedCookies));\n }\n deleteExpiredCookies() {\n const now = Date.now();\n this.store.forEach((originCookies, origin) => {\n originCookies.forEach(({ expires, name }) => {\n if (expires !== undefined && expires.getTime() <= now) {\n originCookies.delete(name);\n }\n });\n if (originCookies.size === 0) {\n this.store.delete(origin);\n }\n });\n }\n}\nexports.store = new CookieStore();\n","\"use strict\";\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __exportStar = (this && this.__exportStar) || function(m, exports) {\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\n__exportStar(require(\"./store\"), exports);\n","'use strict';\nmodule.exports = (function()\n{\n function _min(d0, d1, d2, bx, ay)\n {\n return d0 < d1 || d2 < d1\n ? d0 > d2\n ? d2 + 1\n : d0 + 1\n : bx === ay\n ? d1\n : d1 + 1;\n }\n\n return function(a, b)\n {\n if (a === b) {\n return 0;\n }\n\n if (a.length > b.length) {\n var tmp = a;\n a = b;\n b = tmp;\n }\n\n var la = a.length;\n var lb = b.length;\n\n while (la > 0 && (a.charCodeAt(la - 1) === b.charCodeAt(lb - 1))) {\n la--;\n lb--;\n }\n\n var offset = 0;\n\n while (offset < la && (a.charCodeAt(offset) === b.charCodeAt(offset))) {\n offset++;\n }\n\n la -= offset;\n lb -= offset;\n\n if (la === 0 || lb < 3) {\n return lb;\n }\n\n var x = 0;\n var y;\n var d0;\n var d1;\n var d2;\n var d3;\n var dd;\n var dy;\n var ay;\n var bx0;\n var bx1;\n var bx2;\n var bx3;\n\n var vector = [];\n\n for (y = 0; y < la; y++) {\n vector.push(y + 1);\n vector.push(a.charCodeAt(offset + y));\n }\n\n var len = vector.length - 1;\n\n for (; x < lb - 3;) {\n bx0 = b.charCodeAt(offset + (d0 = x));\n bx1 = b.charCodeAt(offset + (d1 = x + 1));\n bx2 = b.charCodeAt(offset + (d2 = x + 2));\n bx3 = b.charCodeAt(offset + (d3 = x + 3));\n dd = (x += 4);\n for (y = 0; y < len; y += 2) {\n dy = vector[y];\n ay = vector[y + 1];\n d0 = _min(dy, d0, d1, bx0, ay);\n d1 = _min(d0, d1, d2, bx1, ay);\n d2 = _min(d1, d2, d3, bx2, ay);\n dd = _min(d2, d3, dd, bx3, ay);\n vector[y] = dd;\n d3 = d2;\n d2 = d1;\n d1 = d0;\n d0 = dy;\n }\n }\n\n for (; x < lb;) {\n bx0 = b.charCodeAt(offset + (d0 = x));\n dd = ++x;\n for (y = 0; y < len; y += 2) {\n dy = vector[y];\n vector[y] = dd = _min(dy, d0, dd, bx0, vector[y + 1]);\n d0 = dy;\n }\n }\n\n return dd;\n };\n})();\n\n","// Note: This file is autogenerated using \"resources/gen-version.js\" script and\n// automatically updated by \"npm version\" command.\n\n/**\n * A string containing the version of the GraphQL.js library\n */\nexport const version = '16.8.1';\n/**\n * An object containing the components of the GraphQL.js version string\n */\n\nexport const versionInfo = Object.freeze({\n major: 16,\n minor: 8,\n patch: 1,\n preReleaseTag: null,\n});\n","export function devAssert(condition, message) {\n const booleanCondition = Boolean(condition);\n\n if (!booleanCondition) {\n throw new Error(message);\n }\n}\n","/**\n * Returns true if the value acts like a Promise, i.e. has a \"then\" function,\n * otherwise returns false.\n */\nexport function isPromise(value) {\n return (\n typeof (value === null || value === void 0 ? void 0 : value.then) ===\n 'function'\n );\n}\n","/**\n * Return true if `value` is object-like. A value is object-like if it's not\n * `null` and has a `typeof` result of \"object\".\n */\nexport function isObjectLike(value) {\n return typeof value == 'object' && value !== null;\n}\n","export function invariant(condition, message) {\n const booleanCondition = Boolean(condition);\n\n if (!booleanCondition) {\n throw new Error(\n message != null ? message : 'Unexpected invariant triggered.',\n );\n }\n}\n","import { invariant } from '../jsutils/invariant.mjs';\nconst LineRegExp = /\\r\\n|[\\n\\r]/g;\n/**\n * Represents a location in a Source.\n */\n\n/**\n * Takes a Source and a UTF-8 character offset, and returns the corresponding\n * line and column as a SourceLocation.\n */\nexport function getLocation(source, position) {\n let lastLineStart = 0;\n let line = 1;\n\n for (const match of source.body.matchAll(LineRegExp)) {\n typeof match.index === 'number' || invariant(false);\n\n if (match.index >= position) {\n break;\n }\n\n lastLineStart = match.index + match[0].length;\n line += 1;\n }\n\n return {\n line,\n column: position + 1 - lastLineStart,\n };\n}\n","import { getLocation } from './location.mjs';\n\n/**\n * Render a helpful description of the location in the GraphQL Source document.\n */\nexport function printLocation(location) {\n return printSourceLocation(\n location.source,\n getLocation(location.source, location.start),\n );\n}\n/**\n * Render a helpful description of the location in the GraphQL Source document.\n */\n\nexport function printSourceLocation(source, sourceLocation) {\n const firstLineColumnOffset = source.locationOffset.column - 1;\n const body = ''.padStart(firstLineColumnOffset) + source.body;\n const lineIndex = sourceLocation.line - 1;\n const lineOffset = source.locationOffset.line - 1;\n const lineNum = sourceLocation.line + lineOffset;\n const columnOffset = sourceLocation.line === 1 ? firstLineColumnOffset : 0;\n const columnNum = sourceLocation.column + columnOffset;\n const locationStr = `${source.name}:${lineNum}:${columnNum}\\n`;\n const lines = body.split(/\\r\\n|[\\n\\r]/g);\n const locationLine = lines[lineIndex]; // Special case for minified documents\n\n if (locationLine.length > 120) {\n const subLineIndex = Math.floor(columnNum / 80);\n const subLineColumnNum = columnNum % 80;\n const subLines = [];\n\n for (let i = 0; i < locationLine.length; i += 80) {\n subLines.push(locationLine.slice(i, i + 80));\n }\n\n return (\n locationStr +\n printPrefixedLines([\n [`${lineNum} |`, subLines[0]],\n ...subLines.slice(1, subLineIndex + 1).map((subLine) => ['|', subLine]),\n ['|', '^'.padStart(subLineColumnNum)],\n ['|', subLines[subLineIndex + 1]],\n ])\n );\n }\n\n return (\n locationStr +\n printPrefixedLines([\n // Lines specified like this: [\"prefix\", \"string\"],\n [`${lineNum - 1} |`, lines[lineIndex - 1]],\n [`${lineNum} |`, locationLine],\n ['|', '^'.padStart(columnNum)],\n [`${lineNum + 1} |`, lines[lineIndex + 1]],\n ])\n );\n}\n\nfunction printPrefixedLines(lines) {\n const existingLines = lines.filter(([_, line]) => line !== undefined);\n const padLen = Math.max(...existingLines.map(([prefix]) => prefix.length));\n return existingLines\n .map(([prefix, line]) => prefix.padStart(padLen) + (line ? ' ' + line : ''))\n .join('\\n');\n}\n","import { isObjectLike } from '../jsutils/isObjectLike.mjs';\nimport { getLocation } from '../language/location.mjs';\nimport {\n printLocation,\n printSourceLocation,\n} from '../language/printLocation.mjs';\n\nfunction toNormalizedOptions(args) {\n const firstArg = args[0];\n\n if (firstArg == null || 'kind' in firstArg || 'length' in firstArg) {\n return {\n nodes: firstArg,\n source: args[1],\n positions: args[2],\n path: args[3],\n originalError: args[4],\n extensions: args[5],\n };\n }\n\n return firstArg;\n}\n/**\n * A GraphQLError describes an Error found during the parse, validate, or\n * execute phases of performing a GraphQL operation. In addition to a message\n * and stack trace, it also includes information about the locations in a\n * GraphQL document and/or execution result that correspond to the Error.\n */\n\nexport class GraphQLError extends Error {\n /**\n * An array of `{ line, column }` locations within the source GraphQL document\n * which correspond to this error.\n *\n * Errors during validation often contain multiple locations, for example to\n * point out two things with the same name. Errors during execution include a\n * single location, the field which produced the error.\n *\n * Enumerable, and appears in the result of JSON.stringify().\n */\n\n /**\n * An array describing the JSON-path into the execution response which\n * corresponds to this error. Only included for errors during execution.\n *\n * Enumerable, and appears in the result of JSON.stringify().\n */\n\n /**\n * An array of GraphQL AST Nodes corresponding to this error.\n */\n\n /**\n * The source GraphQL document for the first location of this error.\n *\n * Note that if this Error represents more than one node, the source may not\n * represent nodes after the first node.\n */\n\n /**\n * An array of character offsets within the source GraphQL document\n * which correspond to this error.\n */\n\n /**\n * The original error thrown from a field resolver during execution.\n */\n\n /**\n * Extension fields to add to the formatted error.\n */\n\n /**\n * @deprecated Please use the `GraphQLErrorOptions` constructor overload instead.\n */\n constructor(message, ...rawArgs) {\n var _this$nodes, _nodeLocations$, _ref;\n\n const { nodes, source, positions, path, originalError, extensions } =\n toNormalizedOptions(rawArgs);\n super(message);\n this.name = 'GraphQLError';\n this.path = path !== null && path !== void 0 ? path : undefined;\n this.originalError =\n originalError !== null && originalError !== void 0\n ? originalError\n : undefined; // Compute list of blame nodes.\n\n this.nodes = undefinedIfEmpty(\n Array.isArray(nodes) ? nodes : nodes ? [nodes] : undefined,\n );\n const nodeLocations = undefinedIfEmpty(\n (_this$nodes = this.nodes) === null || _this$nodes === void 0\n ? void 0\n : _this$nodes.map((node) => node.loc).filter((loc) => loc != null),\n ); // Compute locations in the source for the given nodes/positions.\n\n this.source =\n source !== null && source !== void 0\n ? source\n : nodeLocations === null || nodeLocations === void 0\n ? void 0\n : (_nodeLocations$ = nodeLocations[0]) === null ||\n _nodeLocations$ === void 0\n ? void 0\n : _nodeLocations$.source;\n this.positions =\n positions !== null && positions !== void 0\n ? positions\n : nodeLocations === null || nodeLocations === void 0\n ? void 0\n : nodeLocations.map((loc) => loc.start);\n this.locations =\n positions && source\n ? positions.map((pos) => getLocation(source, pos))\n : nodeLocations === null || nodeLocations === void 0\n ? void 0\n : nodeLocations.map((loc) => getLocation(loc.source, loc.start));\n const originalExtensions = isObjectLike(\n originalError === null || originalError === void 0\n ? void 0\n : originalError.extensions,\n )\n ? originalError === null || originalError === void 0\n ? void 0\n : originalError.extensions\n : undefined;\n this.extensions =\n (_ref =\n extensions !== null && extensions !== void 0\n ? extensions\n : originalExtensions) !== null && _ref !== void 0\n ? _ref\n : Object.create(null); // Only properties prescribed by the spec should be enumerable.\n // Keep the rest as non-enumerable.\n\n Object.defineProperties(this, {\n message: {\n writable: true,\n enumerable: true,\n },\n name: {\n enumerable: false,\n },\n nodes: {\n enumerable: false,\n },\n source: {\n enumerable: false,\n },\n positions: {\n enumerable: false,\n },\n originalError: {\n enumerable: false,\n },\n }); // Include (non-enumerable) stack trace.\n\n /* c8 ignore start */\n // FIXME: https://github.com/graphql/graphql-js/issues/2317\n\n if (\n originalError !== null &&\n originalError !== void 0 &&\n originalError.stack\n ) {\n Object.defineProperty(this, 'stack', {\n value: originalError.stack,\n writable: true,\n configurable: true,\n });\n } else if (Error.captureStackTrace) {\n Error.captureStackTrace(this, GraphQLError);\n } else {\n Object.defineProperty(this, 'stack', {\n value: Error().stack,\n writable: true,\n configurable: true,\n });\n }\n /* c8 ignore stop */\n }\n\n get [Symbol.toStringTag]() {\n return 'GraphQLError';\n }\n\n toString() {\n let output = this.message;\n\n if (this.nodes) {\n for (const node of this.nodes) {\n if (node.loc) {\n output += '\\n\\n' + printLocation(node.loc);\n }\n }\n } else if (this.source && this.locations) {\n for (const location of this.locations) {\n output += '\\n\\n' + printSourceLocation(this.source, location);\n }\n }\n\n return output;\n }\n\n toJSON() {\n const formattedError = {\n message: this.message,\n };\n\n if (this.locations != null) {\n formattedError.locations = this.locations;\n }\n\n if (this.path != null) {\n formattedError.path = this.path;\n }\n\n if (this.extensions != null && Object.keys(this.extensions).length > 0) {\n formattedError.extensions = this.extensions;\n }\n\n return formattedError;\n }\n}\n\nfunction undefinedIfEmpty(array) {\n return array === undefined || array.length === 0 ? undefined : array;\n}\n/**\n * See: https://spec.graphql.org/draft/#sec-Errors\n */\n\n/**\n * Prints a GraphQLError to a string, representing useful location information\n * about the error's position in the source.\n *\n * @deprecated Please use `error.toString` instead. Will be removed in v17\n */\nexport function printError(error) {\n return error.toString();\n}\n/**\n * Given a GraphQLError, format it according to the rules described by the\n * Response Format, Errors section of the GraphQL Specification.\n *\n * @deprecated Please use `error.toJSON` instead. Will be removed in v17\n */\n\nexport function formatError(error) {\n return error.toJSON();\n}\n","import { GraphQLError } from './GraphQLError.mjs';\n/**\n * Produces a GraphQLError representing a syntax error, containing useful\n * descriptive information about the syntax error's position in the source.\n */\n\nexport function syntaxError(source, position, description) {\n return new GraphQLError(`Syntax Error: ${description}`, {\n source,\n positions: [position],\n });\n}\n","/**\n * Contains a range of UTF-8 character offsets and token references that\n * identify the region of the source from which the AST derived.\n */\nexport class Location {\n /**\n * The character offset at which this Node begins.\n */\n\n /**\n * The character offset at which this Node ends.\n */\n\n /**\n * The Token at which this Node begins.\n */\n\n /**\n * The Token at which this Node ends.\n */\n\n /**\n * The Source document the AST represents.\n */\n constructor(startToken, endToken, source) {\n this.start = startToken.start;\n this.end = endToken.end;\n this.startToken = startToken;\n this.endToken = endToken;\n this.source = source;\n }\n\n get [Symbol.toStringTag]() {\n return 'Location';\n }\n\n toJSON() {\n return {\n start: this.start,\n end: this.end,\n };\n }\n}\n/**\n * Represents a range of characters represented by a lexical token\n * within a Source.\n */\n\nexport class Token {\n /**\n * The kind of Token.\n */\n\n /**\n * The character offset at which this Node begins.\n */\n\n /**\n * The character offset at which this Node ends.\n */\n\n /**\n * The 1-indexed line number on which this Token appears.\n */\n\n /**\n * The 1-indexed column number at which this Token begins.\n */\n\n /**\n * For non-punctuation tokens, represents the interpreted value of the token.\n *\n * Note: is undefined for punctuation tokens, but typed as string for\n * convenience in the parser.\n */\n\n /**\n * Tokens exist as nodes in a double-linked-list amongst all tokens\n * including ignored tokens. is always the first node and \n * the last.\n */\n constructor(kind, start, end, line, column, value) {\n this.kind = kind;\n this.start = start;\n this.end = end;\n this.line = line;\n this.column = column; // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n\n this.value = value;\n this.prev = null;\n this.next = null;\n }\n\n get [Symbol.toStringTag]() {\n return 'Token';\n }\n\n toJSON() {\n return {\n kind: this.kind,\n value: this.value,\n line: this.line,\n column: this.column,\n };\n }\n}\n/**\n * The list of all possible AST node types.\n */\n\n/**\n * @internal\n */\nexport const QueryDocumentKeys = {\n Name: [],\n Document: ['definitions'],\n OperationDefinition: [\n 'name',\n 'variableDefinitions',\n 'directives',\n 'selectionSet',\n ],\n VariableDefinition: ['variable', 'type', 'defaultValue', 'directives'],\n Variable: ['name'],\n SelectionSet: ['selections'],\n Field: ['alias', 'name', 'arguments', 'directives', 'selectionSet'],\n Argument: ['name', 'value'],\n FragmentSpread: ['name', 'directives'],\n InlineFragment: ['typeCondition', 'directives', 'selectionSet'],\n FragmentDefinition: [\n 'name', // Note: fragment variable definitions are deprecated and will removed in v17.0.0\n 'variableDefinitions',\n 'typeCondition',\n 'directives',\n 'selectionSet',\n ],\n IntValue: [],\n FloatValue: [],\n StringValue: [],\n BooleanValue: [],\n NullValue: [],\n EnumValue: [],\n ListValue: ['values'],\n ObjectValue: ['fields'],\n ObjectField: ['name', 'value'],\n Directive: ['name', 'arguments'],\n NamedType: ['name'],\n ListType: ['type'],\n NonNullType: ['type'],\n SchemaDefinition: ['description', 'directives', 'operationTypes'],\n OperationTypeDefinition: ['type'],\n ScalarTypeDefinition: ['description', 'name', 'directives'],\n ObjectTypeDefinition: [\n 'description',\n 'name',\n 'interfaces',\n 'directives',\n 'fields',\n ],\n FieldDefinition: ['description', 'name', 'arguments', 'type', 'directives'],\n InputValueDefinition: [\n 'description',\n 'name',\n 'type',\n 'defaultValue',\n 'directives',\n ],\n InterfaceTypeDefinition: [\n 'description',\n 'name',\n 'interfaces',\n 'directives',\n 'fields',\n ],\n UnionTypeDefinition: ['description', 'name', 'directives', 'types'],\n EnumTypeDefinition: ['description', 'name', 'directives', 'values'],\n EnumValueDefinition: ['description', 'name', 'directives'],\n InputObjectTypeDefinition: ['description', 'name', 'directives', 'fields'],\n DirectiveDefinition: ['description', 'name', 'arguments', 'locations'],\n SchemaExtension: ['directives', 'operationTypes'],\n ScalarTypeExtension: ['name', 'directives'],\n ObjectTypeExtension: ['name', 'interfaces', 'directives', 'fields'],\n InterfaceTypeExtension: ['name', 'interfaces', 'directives', 'fields'],\n UnionTypeExtension: ['name', 'directives', 'types'],\n EnumTypeExtension: ['name', 'directives', 'values'],\n InputObjectTypeExtension: ['name', 'directives', 'fields'],\n};\nconst kindValues = new Set(Object.keys(QueryDocumentKeys));\n/**\n * @internal\n */\n\nexport function isNode(maybeNode) {\n const maybeKind =\n maybeNode === null || maybeNode === void 0 ? void 0 : maybeNode.kind;\n return typeof maybeKind === 'string' && kindValues.has(maybeKind);\n}\n/** Name */\n\nvar OperationTypeNode;\n\n(function (OperationTypeNode) {\n OperationTypeNode['QUERY'] = 'query';\n OperationTypeNode['MUTATION'] = 'mutation';\n OperationTypeNode['SUBSCRIPTION'] = 'subscription';\n})(OperationTypeNode || (OperationTypeNode = {}));\n\nexport { OperationTypeNode };\n","/**\n * The set of allowed directive location values.\n */\nvar DirectiveLocation;\n\n(function (DirectiveLocation) {\n DirectiveLocation['QUERY'] = 'QUERY';\n DirectiveLocation['MUTATION'] = 'MUTATION';\n DirectiveLocation['SUBSCRIPTION'] = 'SUBSCRIPTION';\n DirectiveLocation['FIELD'] = 'FIELD';\n DirectiveLocation['FRAGMENT_DEFINITION'] = 'FRAGMENT_DEFINITION';\n DirectiveLocation['FRAGMENT_SPREAD'] = 'FRAGMENT_SPREAD';\n DirectiveLocation['INLINE_FRAGMENT'] = 'INLINE_FRAGMENT';\n DirectiveLocation['VARIABLE_DEFINITION'] = 'VARIABLE_DEFINITION';\n DirectiveLocation['SCHEMA'] = 'SCHEMA';\n DirectiveLocation['SCALAR'] = 'SCALAR';\n DirectiveLocation['OBJECT'] = 'OBJECT';\n DirectiveLocation['FIELD_DEFINITION'] = 'FIELD_DEFINITION';\n DirectiveLocation['ARGUMENT_DEFINITION'] = 'ARGUMENT_DEFINITION';\n DirectiveLocation['INTERFACE'] = 'INTERFACE';\n DirectiveLocation['UNION'] = 'UNION';\n DirectiveLocation['ENUM'] = 'ENUM';\n DirectiveLocation['ENUM_VALUE'] = 'ENUM_VALUE';\n DirectiveLocation['INPUT_OBJECT'] = 'INPUT_OBJECT';\n DirectiveLocation['INPUT_FIELD_DEFINITION'] = 'INPUT_FIELD_DEFINITION';\n})(DirectiveLocation || (DirectiveLocation = {}));\n\nexport { DirectiveLocation };\n/**\n * The enum type representing the directive location values.\n *\n * @deprecated Please use `DirectiveLocation`. Will be remove in v17.\n */\n","/**\n * The set of allowed kind values for AST nodes.\n */\nvar Kind;\n\n(function (Kind) {\n Kind['NAME'] = 'Name';\n Kind['DOCUMENT'] = 'Document';\n Kind['OPERATION_DEFINITION'] = 'OperationDefinition';\n Kind['VARIABLE_DEFINITION'] = 'VariableDefinition';\n Kind['SELECTION_SET'] = 'SelectionSet';\n Kind['FIELD'] = 'Field';\n Kind['ARGUMENT'] = 'Argument';\n Kind['FRAGMENT_SPREAD'] = 'FragmentSpread';\n Kind['INLINE_FRAGMENT'] = 'InlineFragment';\n Kind['FRAGMENT_DEFINITION'] = 'FragmentDefinition';\n Kind['VARIABLE'] = 'Variable';\n Kind['INT'] = 'IntValue';\n Kind['FLOAT'] = 'FloatValue';\n Kind['STRING'] = 'StringValue';\n Kind['BOOLEAN'] = 'BooleanValue';\n Kind['NULL'] = 'NullValue';\n Kind['ENUM'] = 'EnumValue';\n Kind['LIST'] = 'ListValue';\n Kind['OBJECT'] = 'ObjectValue';\n Kind['OBJECT_FIELD'] = 'ObjectField';\n Kind['DIRECTIVE'] = 'Directive';\n Kind['NAMED_TYPE'] = 'NamedType';\n Kind['LIST_TYPE'] = 'ListType';\n Kind['NON_NULL_TYPE'] = 'NonNullType';\n Kind['SCHEMA_DEFINITION'] = 'SchemaDefinition';\n Kind['OPERATION_TYPE_DEFINITION'] = 'OperationTypeDefinition';\n Kind['SCALAR_TYPE_DEFINITION'] = 'ScalarTypeDefinition';\n Kind['OBJECT_TYPE_DEFINITION'] = 'ObjectTypeDefinition';\n Kind['FIELD_DEFINITION'] = 'FieldDefinition';\n Kind['INPUT_VALUE_DEFINITION'] = 'InputValueDefinition';\n Kind['INTERFACE_TYPE_DEFINITION'] = 'InterfaceTypeDefinition';\n Kind['UNION_TYPE_DEFINITION'] = 'UnionTypeDefinition';\n Kind['ENUM_TYPE_DEFINITION'] = 'EnumTypeDefinition';\n Kind['ENUM_VALUE_DEFINITION'] = 'EnumValueDefinition';\n Kind['INPUT_OBJECT_TYPE_DEFINITION'] = 'InputObjectTypeDefinition';\n Kind['DIRECTIVE_DEFINITION'] = 'DirectiveDefinition';\n Kind['SCHEMA_EXTENSION'] = 'SchemaExtension';\n Kind['SCALAR_TYPE_EXTENSION'] = 'ScalarTypeExtension';\n Kind['OBJECT_TYPE_EXTENSION'] = 'ObjectTypeExtension';\n Kind['INTERFACE_TYPE_EXTENSION'] = 'InterfaceTypeExtension';\n Kind['UNION_TYPE_EXTENSION'] = 'UnionTypeExtension';\n Kind['ENUM_TYPE_EXTENSION'] = 'EnumTypeExtension';\n Kind['INPUT_OBJECT_TYPE_EXTENSION'] = 'InputObjectTypeExtension';\n})(Kind || (Kind = {}));\n\nexport { Kind };\n/**\n * The enum type representing the possible kind values of AST nodes.\n *\n * @deprecated Please use `Kind`. Will be remove in v17.\n */\n","/**\n * ```\n * WhiteSpace ::\n * - \"Horizontal Tab (U+0009)\"\n * - \"Space (U+0020)\"\n * ```\n * @internal\n */\nexport function isWhiteSpace(code) {\n return code === 0x0009 || code === 0x0020;\n}\n/**\n * ```\n * Digit :: one of\n * - `0` `1` `2` `3` `4` `5` `6` `7` `8` `9`\n * ```\n * @internal\n */\n\nexport function isDigit(code) {\n return code >= 0x0030 && code <= 0x0039;\n}\n/**\n * ```\n * Letter :: one of\n * - `A` `B` `C` `D` `E` `F` `G` `H` `I` `J` `K` `L` `M`\n * - `N` `O` `P` `Q` `R` `S` `T` `U` `V` `W` `X` `Y` `Z`\n * - `a` `b` `c` `d` `e` `f` `g` `h` `i` `j` `k` `l` `m`\n * - `n` `o` `p` `q` `r` `s` `t` `u` `v` `w` `x` `y` `z`\n * ```\n * @internal\n */\n\nexport function isLetter(code) {\n return (\n (code >= 0x0061 && code <= 0x007a) || // A-Z\n (code >= 0x0041 && code <= 0x005a) // a-z\n );\n}\n/**\n * ```\n * NameStart ::\n * - Letter\n * - `_`\n * ```\n * @internal\n */\n\nexport function isNameStart(code) {\n return isLetter(code) || code === 0x005f;\n}\n/**\n * ```\n * NameContinue ::\n * - Letter\n * - Digit\n * - `_`\n * ```\n * @internal\n */\n\nexport function isNameContinue(code) {\n return isLetter(code) || isDigit(code) || code === 0x005f;\n}\n","import { isWhiteSpace } from './characterClasses.mjs';\n/**\n * Produces the value of a block string from its parsed raw value, similar to\n * CoffeeScript's block string, Python's docstring trim or Ruby's strip_heredoc.\n *\n * This implements the GraphQL spec's BlockStringValue() static algorithm.\n *\n * @internal\n */\n\nexport function dedentBlockStringLines(lines) {\n var _firstNonEmptyLine2;\n\n let commonIndent = Number.MAX_SAFE_INTEGER;\n let firstNonEmptyLine = null;\n let lastNonEmptyLine = -1;\n\n for (let i = 0; i < lines.length; ++i) {\n var _firstNonEmptyLine;\n\n const line = lines[i];\n const indent = leadingWhitespace(line);\n\n if (indent === line.length) {\n continue; // skip empty lines\n }\n\n firstNonEmptyLine =\n (_firstNonEmptyLine = firstNonEmptyLine) !== null &&\n _firstNonEmptyLine !== void 0\n ? _firstNonEmptyLine\n : i;\n lastNonEmptyLine = i;\n\n if (i !== 0 && indent < commonIndent) {\n commonIndent = indent;\n }\n }\n\n return lines // Remove common indentation from all lines but first.\n .map((line, i) => (i === 0 ? line : line.slice(commonIndent))) // Remove leading and trailing blank lines.\n .slice(\n (_firstNonEmptyLine2 = firstNonEmptyLine) !== null &&\n _firstNonEmptyLine2 !== void 0\n ? _firstNonEmptyLine2\n : 0,\n lastNonEmptyLine + 1,\n );\n}\n\nfunction leadingWhitespace(str) {\n let i = 0;\n\n while (i < str.length && isWhiteSpace(str.charCodeAt(i))) {\n ++i;\n }\n\n return i;\n}\n/**\n * @internal\n */\n\nexport function isPrintableAsBlockString(value) {\n if (value === '') {\n return true; // empty string is printable\n }\n\n let isEmptyLine = true;\n let hasIndent = false;\n let hasCommonIndent = true;\n let seenNonEmptyLine = false;\n\n for (let i = 0; i < value.length; ++i) {\n switch (value.codePointAt(i)) {\n case 0x0000:\n case 0x0001:\n case 0x0002:\n case 0x0003:\n case 0x0004:\n case 0x0005:\n case 0x0006:\n case 0x0007:\n case 0x0008:\n case 0x000b:\n case 0x000c:\n case 0x000e:\n case 0x000f:\n return false;\n // Has non-printable characters\n\n case 0x000d:\n // \\r\n return false;\n // Has \\r or \\r\\n which will be replaced as \\n\n\n case 10:\n // \\n\n if (isEmptyLine && !seenNonEmptyLine) {\n return false; // Has leading new line\n }\n\n seenNonEmptyLine = true;\n isEmptyLine = true;\n hasIndent = false;\n break;\n\n case 9: // \\t\n\n case 32:\n // \n hasIndent || (hasIndent = isEmptyLine);\n break;\n\n default:\n hasCommonIndent && (hasCommonIndent = hasIndent);\n isEmptyLine = false;\n }\n }\n\n if (isEmptyLine) {\n return false; // Has trailing empty lines\n }\n\n if (hasCommonIndent && seenNonEmptyLine) {\n return false; // Has internal indent\n }\n\n return true;\n}\n/**\n * Print a block string in the indented block form by adding a leading and\n * trailing blank line. However, if a block string starts with whitespace and is\n * a single-line, adding a leading blank line would strip that whitespace.\n *\n * @internal\n */\n\nexport function printBlockString(value, options) {\n const escapedValue = value.replace(/\"\"\"/g, '\\\\\"\"\"'); // Expand a block string's raw value into independent lines.\n\n const lines = escapedValue.split(/\\r\\n|[\\n\\r]/g);\n const isSingleLine = lines.length === 1; // If common indentation is found we can fix some of those cases by adding leading new line\n\n const forceLeadingNewLine =\n lines.length > 1 &&\n lines\n .slice(1)\n .every((line) => line.length === 0 || isWhiteSpace(line.charCodeAt(0))); // Trailing triple quotes just looks confusing but doesn't force trailing new line\n\n const hasTrailingTripleQuotes = escapedValue.endsWith('\\\\\"\"\"'); // Trailing quote (single or double) or slash forces trailing new line\n\n const hasTrailingQuote = value.endsWith('\"') && !hasTrailingTripleQuotes;\n const hasTrailingSlash = value.endsWith('\\\\');\n const forceTrailingNewline = hasTrailingQuote || hasTrailingSlash;\n const printAsMultipleLines =\n !(options !== null && options !== void 0 && options.minimize) && // add leading and trailing new lines only if it improves readability\n (!isSingleLine ||\n value.length > 70 ||\n forceTrailingNewline ||\n forceLeadingNewLine ||\n hasTrailingTripleQuotes);\n let result = ''; // Format a multi-line block quote to account for leading space.\n\n const skipLeadingNewLine = isSingleLine && isWhiteSpace(value.charCodeAt(0));\n\n if ((printAsMultipleLines && !skipLeadingNewLine) || forceLeadingNewLine) {\n result += '\\n';\n }\n\n result += escapedValue;\n\n if (printAsMultipleLines || forceTrailingNewline) {\n result += '\\n';\n }\n\n return '\"\"\"' + result + '\"\"\"';\n}\n","/**\n * An exported enum describing the different kinds of tokens that the\n * lexer emits.\n */\nvar TokenKind;\n\n(function (TokenKind) {\n TokenKind['SOF'] = '';\n TokenKind['EOF'] = '';\n TokenKind['BANG'] = '!';\n TokenKind['DOLLAR'] = '$';\n TokenKind['AMP'] = '&';\n TokenKind['PAREN_L'] = '(';\n TokenKind['PAREN_R'] = ')';\n TokenKind['SPREAD'] = '...';\n TokenKind['COLON'] = ':';\n TokenKind['EQUALS'] = '=';\n TokenKind['AT'] = '@';\n TokenKind['BRACKET_L'] = '[';\n TokenKind['BRACKET_R'] = ']';\n TokenKind['BRACE_L'] = '{';\n TokenKind['PIPE'] = '|';\n TokenKind['BRACE_R'] = '}';\n TokenKind['NAME'] = 'Name';\n TokenKind['INT'] = 'Int';\n TokenKind['FLOAT'] = 'Float';\n TokenKind['STRING'] = 'String';\n TokenKind['BLOCK_STRING'] = 'BlockString';\n TokenKind['COMMENT'] = 'Comment';\n})(TokenKind || (TokenKind = {}));\n\nexport { TokenKind };\n/**\n * The enum type representing the token kinds values.\n *\n * @deprecated Please use `TokenKind`. Will be remove in v17.\n */\n","import { syntaxError } from '../error/syntaxError.mjs';\nimport { Token } from './ast.mjs';\nimport { dedentBlockStringLines } from './blockString.mjs';\nimport { isDigit, isNameContinue, isNameStart } from './characterClasses.mjs';\nimport { TokenKind } from './tokenKind.mjs';\n/**\n * Given a Source object, creates a Lexer for that source.\n * A Lexer is a stateful stream generator in that every time\n * it is advanced, it returns the next token in the Source. Assuming the\n * source lexes, the final Token emitted by the lexer will be of kind\n * EOF, after which the lexer will repeatedly return the same EOF token\n * whenever called.\n */\n\nexport class Lexer {\n /**\n * The previously focused non-ignored token.\n */\n\n /**\n * The currently focused non-ignored token.\n */\n\n /**\n * The (1-indexed) line containing the current token.\n */\n\n /**\n * The character offset at which the current line begins.\n */\n constructor(source) {\n const startOfFileToken = new Token(TokenKind.SOF, 0, 0, 0, 0);\n this.source = source;\n this.lastToken = startOfFileToken;\n this.token = startOfFileToken;\n this.line = 1;\n this.lineStart = 0;\n }\n\n get [Symbol.toStringTag]() {\n return 'Lexer';\n }\n /**\n * Advances the token stream to the next non-ignored token.\n */\n\n advance() {\n this.lastToken = this.token;\n const token = (this.token = this.lookahead());\n return token;\n }\n /**\n * Looks ahead and returns the next non-ignored token, but does not change\n * the state of Lexer.\n */\n\n lookahead() {\n let token = this.token;\n\n if (token.kind !== TokenKind.EOF) {\n do {\n if (token.next) {\n token = token.next;\n } else {\n // Read the next token and form a link in the token linked-list.\n const nextToken = readNextToken(this, token.end); // @ts-expect-error next is only mutable during parsing.\n\n token.next = nextToken; // @ts-expect-error prev is only mutable during parsing.\n\n nextToken.prev = token;\n token = nextToken;\n }\n } while (token.kind === TokenKind.COMMENT);\n }\n\n return token;\n }\n}\n/**\n * @internal\n */\n\nexport function isPunctuatorTokenKind(kind) {\n return (\n kind === TokenKind.BANG ||\n kind === TokenKind.DOLLAR ||\n kind === TokenKind.AMP ||\n kind === TokenKind.PAREN_L ||\n kind === TokenKind.PAREN_R ||\n kind === TokenKind.SPREAD ||\n kind === TokenKind.COLON ||\n kind === TokenKind.EQUALS ||\n kind === TokenKind.AT ||\n kind === TokenKind.BRACKET_L ||\n kind === TokenKind.BRACKET_R ||\n kind === TokenKind.BRACE_L ||\n kind === TokenKind.PIPE ||\n kind === TokenKind.BRACE_R\n );\n}\n/**\n * A Unicode scalar value is any Unicode code point except surrogate code\n * points. In other words, the inclusive ranges of values 0x0000 to 0xD7FF and\n * 0xE000 to 0x10FFFF.\n *\n * SourceCharacter ::\n * - \"Any Unicode scalar value\"\n */\n\nfunction isUnicodeScalarValue(code) {\n return (\n (code >= 0x0000 && code <= 0xd7ff) || (code >= 0xe000 && code <= 0x10ffff)\n );\n}\n/**\n * The GraphQL specification defines source text as a sequence of unicode scalar\n * values (which Unicode defines to exclude surrogate code points). However\n * JavaScript defines strings as a sequence of UTF-16 code units which may\n * include surrogates. A surrogate pair is a valid source character as it\n * encodes a supplementary code point (above U+FFFF), but unpaired surrogate\n * code points are not valid source characters.\n */\n\nfunction isSupplementaryCodePoint(body, location) {\n return (\n isLeadingSurrogate(body.charCodeAt(location)) &&\n isTrailingSurrogate(body.charCodeAt(location + 1))\n );\n}\n\nfunction isLeadingSurrogate(code) {\n return code >= 0xd800 && code <= 0xdbff;\n}\n\nfunction isTrailingSurrogate(code) {\n return code >= 0xdc00 && code <= 0xdfff;\n}\n/**\n * Prints the code point (or end of file reference) at a given location in a\n * source for use in error messages.\n *\n * Printable ASCII is printed quoted, while other points are printed in Unicode\n * code point form (ie. U+1234).\n */\n\nfunction printCodePointAt(lexer, location) {\n const code = lexer.source.body.codePointAt(location);\n\n if (code === undefined) {\n return TokenKind.EOF;\n } else if (code >= 0x0020 && code <= 0x007e) {\n // Printable ASCII\n const char = String.fromCodePoint(code);\n return char === '\"' ? \"'\\\"'\" : `\"${char}\"`;\n } // Unicode code point\n\n return 'U+' + code.toString(16).toUpperCase().padStart(4, '0');\n}\n/**\n * Create a token with line and column location information.\n */\n\nfunction createToken(lexer, kind, start, end, value) {\n const line = lexer.line;\n const col = 1 + start - lexer.lineStart;\n return new Token(kind, start, end, line, col, value);\n}\n/**\n * Gets the next token from the source starting at the given position.\n *\n * This skips over whitespace until it finds the next lexable token, then lexes\n * punctuators immediately or calls the appropriate helper function for more\n * complicated tokens.\n */\n\nfunction readNextToken(lexer, start) {\n const body = lexer.source.body;\n const bodyLength = body.length;\n let position = start;\n\n while (position < bodyLength) {\n const code = body.charCodeAt(position); // SourceCharacter\n\n switch (code) {\n // Ignored ::\n // - UnicodeBOM\n // - WhiteSpace\n // - LineTerminator\n // - Comment\n // - Comma\n //\n // UnicodeBOM :: \"Byte Order Mark (U+FEFF)\"\n //\n // WhiteSpace ::\n // - \"Horizontal Tab (U+0009)\"\n // - \"Space (U+0020)\"\n //\n // Comma :: ,\n case 0xfeff: // \n\n case 0x0009: // \\t\n\n case 0x0020: // \n\n case 0x002c:\n // ,\n ++position;\n continue;\n // LineTerminator ::\n // - \"New Line (U+000A)\"\n // - \"Carriage Return (U+000D)\" [lookahead != \"New Line (U+000A)\"]\n // - \"Carriage Return (U+000D)\" \"New Line (U+000A)\"\n\n case 0x000a:\n // \\n\n ++position;\n ++lexer.line;\n lexer.lineStart = position;\n continue;\n\n case 0x000d:\n // \\r\n if (body.charCodeAt(position + 1) === 0x000a) {\n position += 2;\n } else {\n ++position;\n }\n\n ++lexer.line;\n lexer.lineStart = position;\n continue;\n // Comment\n\n case 0x0023:\n // #\n return readComment(lexer, position);\n // Token ::\n // - Punctuator\n // - Name\n // - IntValue\n // - FloatValue\n // - StringValue\n //\n // Punctuator :: one of ! $ & ( ) ... : = @ [ ] { | }\n\n case 0x0021:\n // !\n return createToken(lexer, TokenKind.BANG, position, position + 1);\n\n case 0x0024:\n // $\n return createToken(lexer, TokenKind.DOLLAR, position, position + 1);\n\n case 0x0026:\n // &\n return createToken(lexer, TokenKind.AMP, position, position + 1);\n\n case 0x0028:\n // (\n return createToken(lexer, TokenKind.PAREN_L, position, position + 1);\n\n case 0x0029:\n // )\n return createToken(lexer, TokenKind.PAREN_R, position, position + 1);\n\n case 0x002e:\n // .\n if (\n body.charCodeAt(position + 1) === 0x002e &&\n body.charCodeAt(position + 2) === 0x002e\n ) {\n return createToken(lexer, TokenKind.SPREAD, position, position + 3);\n }\n\n break;\n\n case 0x003a:\n // :\n return createToken(lexer, TokenKind.COLON, position, position + 1);\n\n case 0x003d:\n // =\n return createToken(lexer, TokenKind.EQUALS, position, position + 1);\n\n case 0x0040:\n // @\n return createToken(lexer, TokenKind.AT, position, position + 1);\n\n case 0x005b:\n // [\n return createToken(lexer, TokenKind.BRACKET_L, position, position + 1);\n\n case 0x005d:\n // ]\n return createToken(lexer, TokenKind.BRACKET_R, position, position + 1);\n\n case 0x007b:\n // {\n return createToken(lexer, TokenKind.BRACE_L, position, position + 1);\n\n case 0x007c:\n // |\n return createToken(lexer, TokenKind.PIPE, position, position + 1);\n\n case 0x007d:\n // }\n return createToken(lexer, TokenKind.BRACE_R, position, position + 1);\n // StringValue\n\n case 0x0022:\n // \"\n if (\n body.charCodeAt(position + 1) === 0x0022 &&\n body.charCodeAt(position + 2) === 0x0022\n ) {\n return readBlockString(lexer, position);\n }\n\n return readString(lexer, position);\n } // IntValue | FloatValue (Digit | -)\n\n if (isDigit(code) || code === 0x002d) {\n return readNumber(lexer, position, code);\n } // Name\n\n if (isNameStart(code)) {\n return readName(lexer, position);\n }\n\n throw syntaxError(\n lexer.source,\n position,\n code === 0x0027\n ? 'Unexpected single quote character (\\'), did you mean to use a double quote (\")?'\n : isUnicodeScalarValue(code) || isSupplementaryCodePoint(body, position)\n ? `Unexpected character: ${printCodePointAt(lexer, position)}.`\n : `Invalid character: ${printCodePointAt(lexer, position)}.`,\n );\n }\n\n return createToken(lexer, TokenKind.EOF, bodyLength, bodyLength);\n}\n/**\n * Reads a comment token from the source file.\n *\n * ```\n * Comment :: # CommentChar* [lookahead != CommentChar]\n *\n * CommentChar :: SourceCharacter but not LineTerminator\n * ```\n */\n\nfunction readComment(lexer, start) {\n const body = lexer.source.body;\n const bodyLength = body.length;\n let position = start + 1;\n\n while (position < bodyLength) {\n const code = body.charCodeAt(position); // LineTerminator (\\n | \\r)\n\n if (code === 0x000a || code === 0x000d) {\n break;\n } // SourceCharacter\n\n if (isUnicodeScalarValue(code)) {\n ++position;\n } else if (isSupplementaryCodePoint(body, position)) {\n position += 2;\n } else {\n break;\n }\n }\n\n return createToken(\n lexer,\n TokenKind.COMMENT,\n start,\n position,\n body.slice(start + 1, position),\n );\n}\n/**\n * Reads a number token from the source file, either a FloatValue or an IntValue\n * depending on whether a FractionalPart or ExponentPart is encountered.\n *\n * ```\n * IntValue :: IntegerPart [lookahead != {Digit, `.`, NameStart}]\n *\n * IntegerPart ::\n * - NegativeSign? 0\n * - NegativeSign? NonZeroDigit Digit*\n *\n * NegativeSign :: -\n *\n * NonZeroDigit :: Digit but not `0`\n *\n * FloatValue ::\n * - IntegerPart FractionalPart ExponentPart [lookahead != {Digit, `.`, NameStart}]\n * - IntegerPart FractionalPart [lookahead != {Digit, `.`, NameStart}]\n * - IntegerPart ExponentPart [lookahead != {Digit, `.`, NameStart}]\n *\n * FractionalPart :: . Digit+\n *\n * ExponentPart :: ExponentIndicator Sign? Digit+\n *\n * ExponentIndicator :: one of `e` `E`\n *\n * Sign :: one of + -\n * ```\n */\n\nfunction readNumber(lexer, start, firstCode) {\n const body = lexer.source.body;\n let position = start;\n let code = firstCode;\n let isFloat = false; // NegativeSign (-)\n\n if (code === 0x002d) {\n code = body.charCodeAt(++position);\n } // Zero (0)\n\n if (code === 0x0030) {\n code = body.charCodeAt(++position);\n\n if (isDigit(code)) {\n throw syntaxError(\n lexer.source,\n position,\n `Invalid number, unexpected digit after 0: ${printCodePointAt(\n lexer,\n position,\n )}.`,\n );\n }\n } else {\n position = readDigits(lexer, position, code);\n code = body.charCodeAt(position);\n } // Full stop (.)\n\n if (code === 0x002e) {\n isFloat = true;\n code = body.charCodeAt(++position);\n position = readDigits(lexer, position, code);\n code = body.charCodeAt(position);\n } // E e\n\n if (code === 0x0045 || code === 0x0065) {\n isFloat = true;\n code = body.charCodeAt(++position); // + -\n\n if (code === 0x002b || code === 0x002d) {\n code = body.charCodeAt(++position);\n }\n\n position = readDigits(lexer, position, code);\n code = body.charCodeAt(position);\n } // Numbers cannot be followed by . or NameStart\n\n if (code === 0x002e || isNameStart(code)) {\n throw syntaxError(\n lexer.source,\n position,\n `Invalid number, expected digit but got: ${printCodePointAt(\n lexer,\n position,\n )}.`,\n );\n }\n\n return createToken(\n lexer,\n isFloat ? TokenKind.FLOAT : TokenKind.INT,\n start,\n position,\n body.slice(start, position),\n );\n}\n/**\n * Returns the new position in the source after reading one or more digits.\n */\n\nfunction readDigits(lexer, start, firstCode) {\n if (!isDigit(firstCode)) {\n throw syntaxError(\n lexer.source,\n start,\n `Invalid number, expected digit but got: ${printCodePointAt(\n lexer,\n start,\n )}.`,\n );\n }\n\n const body = lexer.source.body;\n let position = start + 1; // +1 to skip first firstCode\n\n while (isDigit(body.charCodeAt(position))) {\n ++position;\n }\n\n return position;\n}\n/**\n * Reads a single-quote string token from the source file.\n *\n * ```\n * StringValue ::\n * - `\"\"` [lookahead != `\"`]\n * - `\"` StringCharacter+ `\"`\n *\n * StringCharacter ::\n * - SourceCharacter but not `\"` or `\\` or LineTerminator\n * - `\\u` EscapedUnicode\n * - `\\` EscapedCharacter\n *\n * EscapedUnicode ::\n * - `{` HexDigit+ `}`\n * - HexDigit HexDigit HexDigit HexDigit\n *\n * EscapedCharacter :: one of `\"` `\\` `/` `b` `f` `n` `r` `t`\n * ```\n */\n\nfunction readString(lexer, start) {\n const body = lexer.source.body;\n const bodyLength = body.length;\n let position = start + 1;\n let chunkStart = position;\n let value = '';\n\n while (position < bodyLength) {\n const code = body.charCodeAt(position); // Closing Quote (\")\n\n if (code === 0x0022) {\n value += body.slice(chunkStart, position);\n return createToken(lexer, TokenKind.STRING, start, position + 1, value);\n } // Escape Sequence (\\)\n\n if (code === 0x005c) {\n value += body.slice(chunkStart, position);\n const escape =\n body.charCodeAt(position + 1) === 0x0075 // u\n ? body.charCodeAt(position + 2) === 0x007b // {\n ? readEscapedUnicodeVariableWidth(lexer, position)\n : readEscapedUnicodeFixedWidth(lexer, position)\n : readEscapedCharacter(lexer, position);\n value += escape.value;\n position += escape.size;\n chunkStart = position;\n continue;\n } // LineTerminator (\\n | \\r)\n\n if (code === 0x000a || code === 0x000d) {\n break;\n } // SourceCharacter\n\n if (isUnicodeScalarValue(code)) {\n ++position;\n } else if (isSupplementaryCodePoint(body, position)) {\n position += 2;\n } else {\n throw syntaxError(\n lexer.source,\n position,\n `Invalid character within String: ${printCodePointAt(\n lexer,\n position,\n )}.`,\n );\n }\n }\n\n throw syntaxError(lexer.source, position, 'Unterminated string.');\n} // The string value and lexed size of an escape sequence.\n\nfunction readEscapedUnicodeVariableWidth(lexer, position) {\n const body = lexer.source.body;\n let point = 0;\n let size = 3; // Cannot be larger than 12 chars (\\u{00000000}).\n\n while (size < 12) {\n const code = body.charCodeAt(position + size++); // Closing Brace (})\n\n if (code === 0x007d) {\n // Must be at least 5 chars (\\u{0}) and encode a Unicode scalar value.\n if (size < 5 || !isUnicodeScalarValue(point)) {\n break;\n }\n\n return {\n value: String.fromCodePoint(point),\n size,\n };\n } // Append this hex digit to the code point.\n\n point = (point << 4) | readHexDigit(code);\n\n if (point < 0) {\n break;\n }\n }\n\n throw syntaxError(\n lexer.source,\n position,\n `Invalid Unicode escape sequence: \"${body.slice(\n position,\n position + size,\n )}\".`,\n );\n}\n\nfunction readEscapedUnicodeFixedWidth(lexer, position) {\n const body = lexer.source.body;\n const code = read16BitHexCode(body, position + 2);\n\n if (isUnicodeScalarValue(code)) {\n return {\n value: String.fromCodePoint(code),\n size: 6,\n };\n } // GraphQL allows JSON-style surrogate pair escape sequences, but only when\n // a valid pair is formed.\n\n if (isLeadingSurrogate(code)) {\n // \\u\n if (\n body.charCodeAt(position + 6) === 0x005c &&\n body.charCodeAt(position + 7) === 0x0075\n ) {\n const trailingCode = read16BitHexCode(body, position + 8);\n\n if (isTrailingSurrogate(trailingCode)) {\n // JavaScript defines strings as a sequence of UTF-16 code units and\n // encodes Unicode code points above U+FFFF using a surrogate pair of\n // code units. Since this is a surrogate pair escape sequence, just\n // include both codes into the JavaScript string value. Had JavaScript\n // not been internally based on UTF-16, then this surrogate pair would\n // be decoded to retrieve the supplementary code point.\n return {\n value: String.fromCodePoint(code, trailingCode),\n size: 12,\n };\n }\n }\n }\n\n throw syntaxError(\n lexer.source,\n position,\n `Invalid Unicode escape sequence: \"${body.slice(position, position + 6)}\".`,\n );\n}\n/**\n * Reads four hexadecimal characters and returns the positive integer that 16bit\n * hexadecimal string represents. For example, \"000f\" will return 15, and \"dead\"\n * will return 57005.\n *\n * Returns a negative number if any char was not a valid hexadecimal digit.\n */\n\nfunction read16BitHexCode(body, position) {\n // readHexDigit() returns -1 on error. ORing a negative value with any other\n // value always produces a negative value.\n return (\n (readHexDigit(body.charCodeAt(position)) << 12) |\n (readHexDigit(body.charCodeAt(position + 1)) << 8) |\n (readHexDigit(body.charCodeAt(position + 2)) << 4) |\n readHexDigit(body.charCodeAt(position + 3))\n );\n}\n/**\n * Reads a hexadecimal character and returns its positive integer value (0-15).\n *\n * '0' becomes 0, '9' becomes 9\n * 'A' becomes 10, 'F' becomes 15\n * 'a' becomes 10, 'f' becomes 15\n *\n * Returns -1 if the provided character code was not a valid hexadecimal digit.\n *\n * HexDigit :: one of\n * - `0` `1` `2` `3` `4` `5` `6` `7` `8` `9`\n * - `A` `B` `C` `D` `E` `F`\n * - `a` `b` `c` `d` `e` `f`\n */\n\nfunction readHexDigit(code) {\n return code >= 0x0030 && code <= 0x0039 // 0-9\n ? code - 0x0030\n : code >= 0x0041 && code <= 0x0046 // A-F\n ? code - 0x0037\n : code >= 0x0061 && code <= 0x0066 // a-f\n ? code - 0x0057\n : -1;\n}\n/**\n * | Escaped Character | Code Point | Character Name |\n * | ----------------- | ---------- | ---------------------------- |\n * | `\"` | U+0022 | double quote |\n * | `\\` | U+005C | reverse solidus (back slash) |\n * | `/` | U+002F | solidus (forward slash) |\n * | `b` | U+0008 | backspace |\n * | `f` | U+000C | form feed |\n * | `n` | U+000A | line feed (new line) |\n * | `r` | U+000D | carriage return |\n * | `t` | U+0009 | horizontal tab |\n */\n\nfunction readEscapedCharacter(lexer, position) {\n const body = lexer.source.body;\n const code = body.charCodeAt(position + 1);\n\n switch (code) {\n case 0x0022:\n // \"\n return {\n value: '\\u0022',\n size: 2,\n };\n\n case 0x005c:\n // \\\n return {\n value: '\\u005c',\n size: 2,\n };\n\n case 0x002f:\n // /\n return {\n value: '\\u002f',\n size: 2,\n };\n\n case 0x0062:\n // b\n return {\n value: '\\u0008',\n size: 2,\n };\n\n case 0x0066:\n // f\n return {\n value: '\\u000c',\n size: 2,\n };\n\n case 0x006e:\n // n\n return {\n value: '\\u000a',\n size: 2,\n };\n\n case 0x0072:\n // r\n return {\n value: '\\u000d',\n size: 2,\n };\n\n case 0x0074:\n // t\n return {\n value: '\\u0009',\n size: 2,\n };\n }\n\n throw syntaxError(\n lexer.source,\n position,\n `Invalid character escape sequence: \"${body.slice(\n position,\n position + 2,\n )}\".`,\n );\n}\n/**\n * Reads a block string token from the source file.\n *\n * ```\n * StringValue ::\n * - `\"\"\"` BlockStringCharacter* `\"\"\"`\n *\n * BlockStringCharacter ::\n * - SourceCharacter but not `\"\"\"` or `\\\"\"\"`\n * - `\\\"\"\"`\n * ```\n */\n\nfunction readBlockString(lexer, start) {\n const body = lexer.source.body;\n const bodyLength = body.length;\n let lineStart = lexer.lineStart;\n let position = start + 3;\n let chunkStart = position;\n let currentLine = '';\n const blockLines = [];\n\n while (position < bodyLength) {\n const code = body.charCodeAt(position); // Closing Triple-Quote (\"\"\")\n\n if (\n code === 0x0022 &&\n body.charCodeAt(position + 1) === 0x0022 &&\n body.charCodeAt(position + 2) === 0x0022\n ) {\n currentLine += body.slice(chunkStart, position);\n blockLines.push(currentLine);\n const token = createToken(\n lexer,\n TokenKind.BLOCK_STRING,\n start,\n position + 3, // Return a string of the lines joined with U+000A.\n dedentBlockStringLines(blockLines).join('\\n'),\n );\n lexer.line += blockLines.length - 1;\n lexer.lineStart = lineStart;\n return token;\n } // Escaped Triple-Quote (\\\"\"\")\n\n if (\n code === 0x005c &&\n body.charCodeAt(position + 1) === 0x0022 &&\n body.charCodeAt(position + 2) === 0x0022 &&\n body.charCodeAt(position + 3) === 0x0022\n ) {\n currentLine += body.slice(chunkStart, position);\n chunkStart = position + 1; // skip only slash\n\n position += 4;\n continue;\n } // LineTerminator\n\n if (code === 0x000a || code === 0x000d) {\n currentLine += body.slice(chunkStart, position);\n blockLines.push(currentLine);\n\n if (code === 0x000d && body.charCodeAt(position + 1) === 0x000a) {\n position += 2;\n } else {\n ++position;\n }\n\n currentLine = '';\n chunkStart = position;\n lineStart = position;\n continue;\n } // SourceCharacter\n\n if (isUnicodeScalarValue(code)) {\n ++position;\n } else if (isSupplementaryCodePoint(body, position)) {\n position += 2;\n } else {\n throw syntaxError(\n lexer.source,\n position,\n `Invalid character within String: ${printCodePointAt(\n lexer,\n position,\n )}.`,\n );\n }\n }\n\n throw syntaxError(lexer.source, position, 'Unterminated string.');\n}\n/**\n * Reads an alphanumeric + underscore name from the source.\n *\n * ```\n * Name ::\n * - NameStart NameContinue* [lookahead != NameContinue]\n * ```\n */\n\nfunction readName(lexer, start) {\n const body = lexer.source.body;\n const bodyLength = body.length;\n let position = start + 1;\n\n while (position < bodyLength) {\n const code = body.charCodeAt(position);\n\n if (isNameContinue(code)) {\n ++position;\n } else {\n break;\n }\n }\n\n return createToken(\n lexer,\n TokenKind.NAME,\n start,\n position,\n body.slice(start, position),\n );\n}\n","const MAX_ARRAY_LENGTH = 10;\nconst MAX_RECURSIVE_DEPTH = 2;\n/**\n * Used to print values in error messages.\n */\n\nexport function inspect(value) {\n return formatValue(value, []);\n}\n\nfunction formatValue(value, seenValues) {\n switch (typeof value) {\n case 'string':\n return JSON.stringify(value);\n\n case 'function':\n return value.name ? `[function ${value.name}]` : '[function]';\n\n case 'object':\n return formatObjectValue(value, seenValues);\n\n default:\n return String(value);\n }\n}\n\nfunction formatObjectValue(value, previouslySeenValues) {\n if (value === null) {\n return 'null';\n }\n\n if (previouslySeenValues.includes(value)) {\n return '[Circular]';\n }\n\n const seenValues = [...previouslySeenValues, value];\n\n if (isJSONable(value)) {\n const jsonValue = value.toJSON(); // check for infinite recursion\n\n if (jsonValue !== value) {\n return typeof jsonValue === 'string'\n ? jsonValue\n : formatValue(jsonValue, seenValues);\n }\n } else if (Array.isArray(value)) {\n return formatArray(value, seenValues);\n }\n\n return formatObject(value, seenValues);\n}\n\nfunction isJSONable(value) {\n return typeof value.toJSON === 'function';\n}\n\nfunction formatObject(object, seenValues) {\n const entries = Object.entries(object);\n\n if (entries.length === 0) {\n return '{}';\n }\n\n if (seenValues.length > MAX_RECURSIVE_DEPTH) {\n return '[' + getObjectTag(object) + ']';\n }\n\n const properties = entries.map(\n ([key, value]) => key + ': ' + formatValue(value, seenValues),\n );\n return '{ ' + properties.join(', ') + ' }';\n}\n\nfunction formatArray(array, seenValues) {\n if (array.length === 0) {\n return '[]';\n }\n\n if (seenValues.length > MAX_RECURSIVE_DEPTH) {\n return '[Array]';\n }\n\n const len = Math.min(MAX_ARRAY_LENGTH, array.length);\n const remaining = array.length - len;\n const items = [];\n\n for (let i = 0; i < len; ++i) {\n items.push(formatValue(array[i], seenValues));\n }\n\n if (remaining === 1) {\n items.push('... 1 more item');\n } else if (remaining > 1) {\n items.push(`... ${remaining} more items`);\n }\n\n return '[' + items.join(', ') + ']';\n}\n\nfunction getObjectTag(object) {\n const tag = Object.prototype.toString\n .call(object)\n .replace(/^\\[object /, '')\n .replace(/]$/, '');\n\n if (tag === 'Object' && typeof object.constructor === 'function') {\n const name = object.constructor.name;\n\n if (typeof name === 'string' && name !== '') {\n return name;\n }\n }\n\n return tag;\n}\n","import { inspect } from './inspect.mjs';\n/**\n * A replacement for instanceof which includes an error warning when multi-realm\n * constructors are detected.\n * See: https://expressjs.com/en/advanced/best-practice-performance.html#set-node_env-to-production\n * See: https://webpack.js.org/guides/production/\n */\n\nexport const instanceOf =\n /* c8 ignore next 6 */\n // FIXME: https://github.com/graphql/graphql-js/issues/2317\n globalThis.process && globalThis.process.env.NODE_ENV === 'production'\n ? function instanceOf(value, constructor) {\n return value instanceof constructor;\n }\n : function instanceOf(value, constructor) {\n if (value instanceof constructor) {\n return true;\n }\n\n if (typeof value === 'object' && value !== null) {\n var _value$constructor;\n\n // Prefer Symbol.toStringTag since it is immune to minification.\n const className = constructor.prototype[Symbol.toStringTag];\n const valueClassName = // We still need to support constructor's name to detect conflicts with older versions of this library.\n Symbol.toStringTag in value // @ts-expect-error TS bug see, https://github.com/microsoft/TypeScript/issues/38009\n ? value[Symbol.toStringTag]\n : (_value$constructor = value.constructor) === null ||\n _value$constructor === void 0\n ? void 0\n : _value$constructor.name;\n\n if (className === valueClassName) {\n const stringifiedValue = inspect(value);\n throw new Error(`Cannot use ${className} \"${stringifiedValue}\" from another module or realm.\n\nEnsure that there is only one instance of \"graphql\" in the node_modules\ndirectory. If different versions of \"graphql\" are the dependencies of other\nrelied on modules, use \"resolutions\" to ensure only one version is installed.\n\nhttps://yarnpkg.com/en/docs/selective-version-resolutions\n\nDuplicate \"graphql\" modules cannot be used at the same time since different\nversions may have different capabilities and behavior. The data from one\nversion used in the function from another could produce confusing and\nspurious results.`);\n }\n }\n\n return false;\n };\n","import { devAssert } from '../jsutils/devAssert.mjs';\nimport { inspect } from '../jsutils/inspect.mjs';\nimport { instanceOf } from '../jsutils/instanceOf.mjs';\n\n/**\n * A representation of source input to GraphQL. The `name` and `locationOffset` parameters are\n * optional, but they are useful for clients who store GraphQL documents in source files.\n * For example, if the GraphQL input starts at line 40 in a file named `Foo.graphql`, it might\n * be useful for `name` to be `\"Foo.graphql\"` and location to be `{ line: 40, column: 1 }`.\n * The `line` and `column` properties in `locationOffset` are 1-indexed.\n */\nexport class Source {\n constructor(\n body,\n name = 'GraphQL request',\n locationOffset = {\n line: 1,\n column: 1,\n },\n ) {\n typeof body === 'string' ||\n devAssert(false, `Body must be a string. Received: ${inspect(body)}.`);\n this.body = body;\n this.name = name;\n this.locationOffset = locationOffset;\n this.locationOffset.line > 0 ||\n devAssert(\n false,\n 'line in locationOffset is 1-indexed and must be positive.',\n );\n this.locationOffset.column > 0 ||\n devAssert(\n false,\n 'column in locationOffset is 1-indexed and must be positive.',\n );\n }\n\n get [Symbol.toStringTag]() {\n return 'Source';\n }\n}\n/**\n * Test if the given value is a Source object.\n *\n * @internal\n */\n\nexport function isSource(source) {\n return instanceOf(source, Source);\n}\n","import { syntaxError } from '../error/syntaxError.mjs';\nimport { Location, OperationTypeNode } from './ast.mjs';\nimport { DirectiveLocation } from './directiveLocation.mjs';\nimport { Kind } from './kinds.mjs';\nimport { isPunctuatorTokenKind, Lexer } from './lexer.mjs';\nimport { isSource, Source } from './source.mjs';\nimport { TokenKind } from './tokenKind.mjs';\n/**\n * Configuration options to control parser behavior\n */\n\n/**\n * Given a GraphQL source, parses it into a Document.\n * Throws GraphQLError if a syntax error is encountered.\n */\nexport function parse(source, options) {\n const parser = new Parser(source, options);\n return parser.parseDocument();\n}\n/**\n * Given a string containing a GraphQL value (ex. `[42]`), parse the AST for\n * that value.\n * Throws GraphQLError if a syntax error is encountered.\n *\n * This is useful within tools that operate upon GraphQL Values directly and\n * in isolation of complete GraphQL documents.\n *\n * Consider providing the results to the utility function: valueFromAST().\n */\n\nexport function parseValue(source, options) {\n const parser = new Parser(source, options);\n parser.expectToken(TokenKind.SOF);\n const value = parser.parseValueLiteral(false);\n parser.expectToken(TokenKind.EOF);\n return value;\n}\n/**\n * Similar to parseValue(), but raises a parse error if it encounters a\n * variable. The return type will be a constant value.\n */\n\nexport function parseConstValue(source, options) {\n const parser = new Parser(source, options);\n parser.expectToken(TokenKind.SOF);\n const value = parser.parseConstValueLiteral();\n parser.expectToken(TokenKind.EOF);\n return value;\n}\n/**\n * Given a string containing a GraphQL Type (ex. `[Int!]`), parse the AST for\n * that type.\n * Throws GraphQLError if a syntax error is encountered.\n *\n * This is useful within tools that operate upon GraphQL Types directly and\n * in isolation of complete GraphQL documents.\n *\n * Consider providing the results to the utility function: typeFromAST().\n */\n\nexport function parseType(source, options) {\n const parser = new Parser(source, options);\n parser.expectToken(TokenKind.SOF);\n const type = parser.parseTypeReference();\n parser.expectToken(TokenKind.EOF);\n return type;\n}\n/**\n * This class is exported only to assist people in implementing their own parsers\n * without duplicating too much code and should be used only as last resort for cases\n * such as experimental syntax or if certain features could not be contributed upstream.\n *\n * It is still part of the internal API and is versioned, so any changes to it are never\n * considered breaking changes. If you still need to support multiple versions of the\n * library, please use the `versionInfo` variable for version detection.\n *\n * @internal\n */\n\nexport class Parser {\n constructor(source, options = {}) {\n const sourceObj = isSource(source) ? source : new Source(source);\n this._lexer = new Lexer(sourceObj);\n this._options = options;\n this._tokenCounter = 0;\n }\n /**\n * Converts a name lex token into a name parse node.\n */\n\n parseName() {\n const token = this.expectToken(TokenKind.NAME);\n return this.node(token, {\n kind: Kind.NAME,\n value: token.value,\n });\n } // Implements the parsing rules in the Document section.\n\n /**\n * Document : Definition+\n */\n\n parseDocument() {\n return this.node(this._lexer.token, {\n kind: Kind.DOCUMENT,\n definitions: this.many(\n TokenKind.SOF,\n this.parseDefinition,\n TokenKind.EOF,\n ),\n });\n }\n /**\n * Definition :\n * - ExecutableDefinition\n * - TypeSystemDefinition\n * - TypeSystemExtension\n *\n * ExecutableDefinition :\n * - OperationDefinition\n * - FragmentDefinition\n *\n * TypeSystemDefinition :\n * - SchemaDefinition\n * - TypeDefinition\n * - DirectiveDefinition\n *\n * TypeDefinition :\n * - ScalarTypeDefinition\n * - ObjectTypeDefinition\n * - InterfaceTypeDefinition\n * - UnionTypeDefinition\n * - EnumTypeDefinition\n * - InputObjectTypeDefinition\n */\n\n parseDefinition() {\n if (this.peek(TokenKind.BRACE_L)) {\n return this.parseOperationDefinition();\n } // Many definitions begin with a description and require a lookahead.\n\n const hasDescription = this.peekDescription();\n const keywordToken = hasDescription\n ? this._lexer.lookahead()\n : this._lexer.token;\n\n if (keywordToken.kind === TokenKind.NAME) {\n switch (keywordToken.value) {\n case 'schema':\n return this.parseSchemaDefinition();\n\n case 'scalar':\n return this.parseScalarTypeDefinition();\n\n case 'type':\n return this.parseObjectTypeDefinition();\n\n case 'interface':\n return this.parseInterfaceTypeDefinition();\n\n case 'union':\n return this.parseUnionTypeDefinition();\n\n case 'enum':\n return this.parseEnumTypeDefinition();\n\n case 'input':\n return this.parseInputObjectTypeDefinition();\n\n case 'directive':\n return this.parseDirectiveDefinition();\n }\n\n if (hasDescription) {\n throw syntaxError(\n this._lexer.source,\n this._lexer.token.start,\n 'Unexpected description, descriptions are supported only on type definitions.',\n );\n }\n\n switch (keywordToken.value) {\n case 'query':\n case 'mutation':\n case 'subscription':\n return this.parseOperationDefinition();\n\n case 'fragment':\n return this.parseFragmentDefinition();\n\n case 'extend':\n return this.parseTypeSystemExtension();\n }\n }\n\n throw this.unexpected(keywordToken);\n } // Implements the parsing rules in the Operations section.\n\n /**\n * OperationDefinition :\n * - SelectionSet\n * - OperationType Name? VariableDefinitions? Directives? SelectionSet\n */\n\n parseOperationDefinition() {\n const start = this._lexer.token;\n\n if (this.peek(TokenKind.BRACE_L)) {\n return this.node(start, {\n kind: Kind.OPERATION_DEFINITION,\n operation: OperationTypeNode.QUERY,\n name: undefined,\n variableDefinitions: [],\n directives: [],\n selectionSet: this.parseSelectionSet(),\n });\n }\n\n const operation = this.parseOperationType();\n let name;\n\n if (this.peek(TokenKind.NAME)) {\n name = this.parseName();\n }\n\n return this.node(start, {\n kind: Kind.OPERATION_DEFINITION,\n operation,\n name,\n variableDefinitions: this.parseVariableDefinitions(),\n directives: this.parseDirectives(false),\n selectionSet: this.parseSelectionSet(),\n });\n }\n /**\n * OperationType : one of query mutation subscription\n */\n\n parseOperationType() {\n const operationToken = this.expectToken(TokenKind.NAME);\n\n switch (operationToken.value) {\n case 'query':\n return OperationTypeNode.QUERY;\n\n case 'mutation':\n return OperationTypeNode.MUTATION;\n\n case 'subscription':\n return OperationTypeNode.SUBSCRIPTION;\n }\n\n throw this.unexpected(operationToken);\n }\n /**\n * VariableDefinitions : ( VariableDefinition+ )\n */\n\n parseVariableDefinitions() {\n return this.optionalMany(\n TokenKind.PAREN_L,\n this.parseVariableDefinition,\n TokenKind.PAREN_R,\n );\n }\n /**\n * VariableDefinition : Variable : Type DefaultValue? Directives[Const]?\n */\n\n parseVariableDefinition() {\n return this.node(this._lexer.token, {\n kind: Kind.VARIABLE_DEFINITION,\n variable: this.parseVariable(),\n type: (this.expectToken(TokenKind.COLON), this.parseTypeReference()),\n defaultValue: this.expectOptionalToken(TokenKind.EQUALS)\n ? this.parseConstValueLiteral()\n : undefined,\n directives: this.parseConstDirectives(),\n });\n }\n /**\n * Variable : $ Name\n */\n\n parseVariable() {\n const start = this._lexer.token;\n this.expectToken(TokenKind.DOLLAR);\n return this.node(start, {\n kind: Kind.VARIABLE,\n name: this.parseName(),\n });\n }\n /**\n * ```\n * SelectionSet : { Selection+ }\n * ```\n */\n\n parseSelectionSet() {\n return this.node(this._lexer.token, {\n kind: Kind.SELECTION_SET,\n selections: this.many(\n TokenKind.BRACE_L,\n this.parseSelection,\n TokenKind.BRACE_R,\n ),\n });\n }\n /**\n * Selection :\n * - Field\n * - FragmentSpread\n * - InlineFragment\n */\n\n parseSelection() {\n return this.peek(TokenKind.SPREAD)\n ? this.parseFragment()\n : this.parseField();\n }\n /**\n * Field : Alias? Name Arguments? Directives? SelectionSet?\n *\n * Alias : Name :\n */\n\n parseField() {\n const start = this._lexer.token;\n const nameOrAlias = this.parseName();\n let alias;\n let name;\n\n if (this.expectOptionalToken(TokenKind.COLON)) {\n alias = nameOrAlias;\n name = this.parseName();\n } else {\n name = nameOrAlias;\n }\n\n return this.node(start, {\n kind: Kind.FIELD,\n alias,\n name,\n arguments: this.parseArguments(false),\n directives: this.parseDirectives(false),\n selectionSet: this.peek(TokenKind.BRACE_L)\n ? this.parseSelectionSet()\n : undefined,\n });\n }\n /**\n * Arguments[Const] : ( Argument[?Const]+ )\n */\n\n parseArguments(isConst) {\n const item = isConst ? this.parseConstArgument : this.parseArgument;\n return this.optionalMany(TokenKind.PAREN_L, item, TokenKind.PAREN_R);\n }\n /**\n * Argument[Const] : Name : Value[?Const]\n */\n\n parseArgument(isConst = false) {\n const start = this._lexer.token;\n const name = this.parseName();\n this.expectToken(TokenKind.COLON);\n return this.node(start, {\n kind: Kind.ARGUMENT,\n name,\n value: this.parseValueLiteral(isConst),\n });\n }\n\n parseConstArgument() {\n return this.parseArgument(true);\n } // Implements the parsing rules in the Fragments section.\n\n /**\n * Corresponds to both FragmentSpread and InlineFragment in the spec.\n *\n * FragmentSpread : ... FragmentName Directives?\n *\n * InlineFragment : ... TypeCondition? Directives? SelectionSet\n */\n\n parseFragment() {\n const start = this._lexer.token;\n this.expectToken(TokenKind.SPREAD);\n const hasTypeCondition = this.expectOptionalKeyword('on');\n\n if (!hasTypeCondition && this.peek(TokenKind.NAME)) {\n return this.node(start, {\n kind: Kind.FRAGMENT_SPREAD,\n name: this.parseFragmentName(),\n directives: this.parseDirectives(false),\n });\n }\n\n return this.node(start, {\n kind: Kind.INLINE_FRAGMENT,\n typeCondition: hasTypeCondition ? this.parseNamedType() : undefined,\n directives: this.parseDirectives(false),\n selectionSet: this.parseSelectionSet(),\n });\n }\n /**\n * FragmentDefinition :\n * - fragment FragmentName on TypeCondition Directives? SelectionSet\n *\n * TypeCondition : NamedType\n */\n\n parseFragmentDefinition() {\n const start = this._lexer.token;\n this.expectKeyword('fragment'); // Legacy support for defining variables within fragments changes\n // the grammar of FragmentDefinition:\n // - fragment FragmentName VariableDefinitions? on TypeCondition Directives? SelectionSet\n\n if (this._options.allowLegacyFragmentVariables === true) {\n return this.node(start, {\n kind: Kind.FRAGMENT_DEFINITION,\n name: this.parseFragmentName(),\n variableDefinitions: this.parseVariableDefinitions(),\n typeCondition: (this.expectKeyword('on'), this.parseNamedType()),\n directives: this.parseDirectives(false),\n selectionSet: this.parseSelectionSet(),\n });\n }\n\n return this.node(start, {\n kind: Kind.FRAGMENT_DEFINITION,\n name: this.parseFragmentName(),\n typeCondition: (this.expectKeyword('on'), this.parseNamedType()),\n directives: this.parseDirectives(false),\n selectionSet: this.parseSelectionSet(),\n });\n }\n /**\n * FragmentName : Name but not `on`\n */\n\n parseFragmentName() {\n if (this._lexer.token.value === 'on') {\n throw this.unexpected();\n }\n\n return this.parseName();\n } // Implements the parsing rules in the Values section.\n\n /**\n * Value[Const] :\n * - [~Const] Variable\n * - IntValue\n * - FloatValue\n * - StringValue\n * - BooleanValue\n * - NullValue\n * - EnumValue\n * - ListValue[?Const]\n * - ObjectValue[?Const]\n *\n * BooleanValue : one of `true` `false`\n *\n * NullValue : `null`\n *\n * EnumValue : Name but not `true`, `false` or `null`\n */\n\n parseValueLiteral(isConst) {\n const token = this._lexer.token;\n\n switch (token.kind) {\n case TokenKind.BRACKET_L:\n return this.parseList(isConst);\n\n case TokenKind.BRACE_L:\n return this.parseObject(isConst);\n\n case TokenKind.INT:\n this.advanceLexer();\n return this.node(token, {\n kind: Kind.INT,\n value: token.value,\n });\n\n case TokenKind.FLOAT:\n this.advanceLexer();\n return this.node(token, {\n kind: Kind.FLOAT,\n value: token.value,\n });\n\n case TokenKind.STRING:\n case TokenKind.BLOCK_STRING:\n return this.parseStringLiteral();\n\n case TokenKind.NAME:\n this.advanceLexer();\n\n switch (token.value) {\n case 'true':\n return this.node(token, {\n kind: Kind.BOOLEAN,\n value: true,\n });\n\n case 'false':\n return this.node(token, {\n kind: Kind.BOOLEAN,\n value: false,\n });\n\n case 'null':\n return this.node(token, {\n kind: Kind.NULL,\n });\n\n default:\n return this.node(token, {\n kind: Kind.ENUM,\n value: token.value,\n });\n }\n\n case TokenKind.DOLLAR:\n if (isConst) {\n this.expectToken(TokenKind.DOLLAR);\n\n if (this._lexer.token.kind === TokenKind.NAME) {\n const varName = this._lexer.token.value;\n throw syntaxError(\n this._lexer.source,\n token.start,\n `Unexpected variable \"$${varName}\" in constant value.`,\n );\n } else {\n throw this.unexpected(token);\n }\n }\n\n return this.parseVariable();\n\n default:\n throw this.unexpected();\n }\n }\n\n parseConstValueLiteral() {\n return this.parseValueLiteral(true);\n }\n\n parseStringLiteral() {\n const token = this._lexer.token;\n this.advanceLexer();\n return this.node(token, {\n kind: Kind.STRING,\n value: token.value,\n block: token.kind === TokenKind.BLOCK_STRING,\n });\n }\n /**\n * ListValue[Const] :\n * - [ ]\n * - [ Value[?Const]+ ]\n */\n\n parseList(isConst) {\n const item = () => this.parseValueLiteral(isConst);\n\n return this.node(this._lexer.token, {\n kind: Kind.LIST,\n values: this.any(TokenKind.BRACKET_L, item, TokenKind.BRACKET_R),\n });\n }\n /**\n * ```\n * ObjectValue[Const] :\n * - { }\n * - { ObjectField[?Const]+ }\n * ```\n */\n\n parseObject(isConst) {\n const item = () => this.parseObjectField(isConst);\n\n return this.node(this._lexer.token, {\n kind: Kind.OBJECT,\n fields: this.any(TokenKind.BRACE_L, item, TokenKind.BRACE_R),\n });\n }\n /**\n * ObjectField[Const] : Name : Value[?Const]\n */\n\n parseObjectField(isConst) {\n const start = this._lexer.token;\n const name = this.parseName();\n this.expectToken(TokenKind.COLON);\n return this.node(start, {\n kind: Kind.OBJECT_FIELD,\n name,\n value: this.parseValueLiteral(isConst),\n });\n } // Implements the parsing rules in the Directives section.\n\n /**\n * Directives[Const] : Directive[?Const]+\n */\n\n parseDirectives(isConst) {\n const directives = [];\n\n while (this.peek(TokenKind.AT)) {\n directives.push(this.parseDirective(isConst));\n }\n\n return directives;\n }\n\n parseConstDirectives() {\n return this.parseDirectives(true);\n }\n /**\n * ```\n * Directive[Const] : @ Name Arguments[?Const]?\n * ```\n */\n\n parseDirective(isConst) {\n const start = this._lexer.token;\n this.expectToken(TokenKind.AT);\n return this.node(start, {\n kind: Kind.DIRECTIVE,\n name: this.parseName(),\n arguments: this.parseArguments(isConst),\n });\n } // Implements the parsing rules in the Types section.\n\n /**\n * Type :\n * - NamedType\n * - ListType\n * - NonNullType\n */\n\n parseTypeReference() {\n const start = this._lexer.token;\n let type;\n\n if (this.expectOptionalToken(TokenKind.BRACKET_L)) {\n const innerType = this.parseTypeReference();\n this.expectToken(TokenKind.BRACKET_R);\n type = this.node(start, {\n kind: Kind.LIST_TYPE,\n type: innerType,\n });\n } else {\n type = this.parseNamedType();\n }\n\n if (this.expectOptionalToken(TokenKind.BANG)) {\n return this.node(start, {\n kind: Kind.NON_NULL_TYPE,\n type,\n });\n }\n\n return type;\n }\n /**\n * NamedType : Name\n */\n\n parseNamedType() {\n return this.node(this._lexer.token, {\n kind: Kind.NAMED_TYPE,\n name: this.parseName(),\n });\n } // Implements the parsing rules in the Type Definition section.\n\n peekDescription() {\n return this.peek(TokenKind.STRING) || this.peek(TokenKind.BLOCK_STRING);\n }\n /**\n * Description : StringValue\n */\n\n parseDescription() {\n if (this.peekDescription()) {\n return this.parseStringLiteral();\n }\n }\n /**\n * ```\n * SchemaDefinition : Description? schema Directives[Const]? { OperationTypeDefinition+ }\n * ```\n */\n\n parseSchemaDefinition() {\n const start = this._lexer.token;\n const description = this.parseDescription();\n this.expectKeyword('schema');\n const directives = this.parseConstDirectives();\n const operationTypes = this.many(\n TokenKind.BRACE_L,\n this.parseOperationTypeDefinition,\n TokenKind.BRACE_R,\n );\n return this.node(start, {\n kind: Kind.SCHEMA_DEFINITION,\n description,\n directives,\n operationTypes,\n });\n }\n /**\n * OperationTypeDefinition : OperationType : NamedType\n */\n\n parseOperationTypeDefinition() {\n const start = this._lexer.token;\n const operation = this.parseOperationType();\n this.expectToken(TokenKind.COLON);\n const type = this.parseNamedType();\n return this.node(start, {\n kind: Kind.OPERATION_TYPE_DEFINITION,\n operation,\n type,\n });\n }\n /**\n * ScalarTypeDefinition : Description? scalar Name Directives[Const]?\n */\n\n parseScalarTypeDefinition() {\n const start = this._lexer.token;\n const description = this.parseDescription();\n this.expectKeyword('scalar');\n const name = this.parseName();\n const directives = this.parseConstDirectives();\n return this.node(start, {\n kind: Kind.SCALAR_TYPE_DEFINITION,\n description,\n name,\n directives,\n });\n }\n /**\n * ObjectTypeDefinition :\n * Description?\n * type Name ImplementsInterfaces? Directives[Const]? FieldsDefinition?\n */\n\n parseObjectTypeDefinition() {\n const start = this._lexer.token;\n const description = this.parseDescription();\n this.expectKeyword('type');\n const name = this.parseName();\n const interfaces = this.parseImplementsInterfaces();\n const directives = this.parseConstDirectives();\n const fields = this.parseFieldsDefinition();\n return this.node(start, {\n kind: Kind.OBJECT_TYPE_DEFINITION,\n description,\n name,\n interfaces,\n directives,\n fields,\n });\n }\n /**\n * ImplementsInterfaces :\n * - implements `&`? NamedType\n * - ImplementsInterfaces & NamedType\n */\n\n parseImplementsInterfaces() {\n return this.expectOptionalKeyword('implements')\n ? this.delimitedMany(TokenKind.AMP, this.parseNamedType)\n : [];\n }\n /**\n * ```\n * FieldsDefinition : { FieldDefinition+ }\n * ```\n */\n\n parseFieldsDefinition() {\n return this.optionalMany(\n TokenKind.BRACE_L,\n this.parseFieldDefinition,\n TokenKind.BRACE_R,\n );\n }\n /**\n * FieldDefinition :\n * - Description? Name ArgumentsDefinition? : Type Directives[Const]?\n */\n\n parseFieldDefinition() {\n const start = this._lexer.token;\n const description = this.parseDescription();\n const name = this.parseName();\n const args = this.parseArgumentDefs();\n this.expectToken(TokenKind.COLON);\n const type = this.parseTypeReference();\n const directives = this.parseConstDirectives();\n return this.node(start, {\n kind: Kind.FIELD_DEFINITION,\n description,\n name,\n arguments: args,\n type,\n directives,\n });\n }\n /**\n * ArgumentsDefinition : ( InputValueDefinition+ )\n */\n\n parseArgumentDefs() {\n return this.optionalMany(\n TokenKind.PAREN_L,\n this.parseInputValueDef,\n TokenKind.PAREN_R,\n );\n }\n /**\n * InputValueDefinition :\n * - Description? Name : Type DefaultValue? Directives[Const]?\n */\n\n parseInputValueDef() {\n const start = this._lexer.token;\n const description = this.parseDescription();\n const name = this.parseName();\n this.expectToken(TokenKind.COLON);\n const type = this.parseTypeReference();\n let defaultValue;\n\n if (this.expectOptionalToken(TokenKind.EQUALS)) {\n defaultValue = this.parseConstValueLiteral();\n }\n\n const directives = this.parseConstDirectives();\n return this.node(start, {\n kind: Kind.INPUT_VALUE_DEFINITION,\n description,\n name,\n type,\n defaultValue,\n directives,\n });\n }\n /**\n * InterfaceTypeDefinition :\n * - Description? interface Name Directives[Const]? FieldsDefinition?\n */\n\n parseInterfaceTypeDefinition() {\n const start = this._lexer.token;\n const description = this.parseDescription();\n this.expectKeyword('interface');\n const name = this.parseName();\n const interfaces = this.parseImplementsInterfaces();\n const directives = this.parseConstDirectives();\n const fields = this.parseFieldsDefinition();\n return this.node(start, {\n kind: Kind.INTERFACE_TYPE_DEFINITION,\n description,\n name,\n interfaces,\n directives,\n fields,\n });\n }\n /**\n * UnionTypeDefinition :\n * - Description? union Name Directives[Const]? UnionMemberTypes?\n */\n\n parseUnionTypeDefinition() {\n const start = this._lexer.token;\n const description = this.parseDescription();\n this.expectKeyword('union');\n const name = this.parseName();\n const directives = this.parseConstDirectives();\n const types = this.parseUnionMemberTypes();\n return this.node(start, {\n kind: Kind.UNION_TYPE_DEFINITION,\n description,\n name,\n directives,\n types,\n });\n }\n /**\n * UnionMemberTypes :\n * - = `|`? NamedType\n * - UnionMemberTypes | NamedType\n */\n\n parseUnionMemberTypes() {\n return this.expectOptionalToken(TokenKind.EQUALS)\n ? this.delimitedMany(TokenKind.PIPE, this.parseNamedType)\n : [];\n }\n /**\n * EnumTypeDefinition :\n * - Description? enum Name Directives[Const]? EnumValuesDefinition?\n */\n\n parseEnumTypeDefinition() {\n const start = this._lexer.token;\n const description = this.parseDescription();\n this.expectKeyword('enum');\n const name = this.parseName();\n const directives = this.parseConstDirectives();\n const values = this.parseEnumValuesDefinition();\n return this.node(start, {\n kind: Kind.ENUM_TYPE_DEFINITION,\n description,\n name,\n directives,\n values,\n });\n }\n /**\n * ```\n * EnumValuesDefinition : { EnumValueDefinition+ }\n * ```\n */\n\n parseEnumValuesDefinition() {\n return this.optionalMany(\n TokenKind.BRACE_L,\n this.parseEnumValueDefinition,\n TokenKind.BRACE_R,\n );\n }\n /**\n * EnumValueDefinition : Description? EnumValue Directives[Const]?\n */\n\n parseEnumValueDefinition() {\n const start = this._lexer.token;\n const description = this.parseDescription();\n const name = this.parseEnumValueName();\n const directives = this.parseConstDirectives();\n return this.node(start, {\n kind: Kind.ENUM_VALUE_DEFINITION,\n description,\n name,\n directives,\n });\n }\n /**\n * EnumValue : Name but not `true`, `false` or `null`\n */\n\n parseEnumValueName() {\n if (\n this._lexer.token.value === 'true' ||\n this._lexer.token.value === 'false' ||\n this._lexer.token.value === 'null'\n ) {\n throw syntaxError(\n this._lexer.source,\n this._lexer.token.start,\n `${getTokenDesc(\n this._lexer.token,\n )} is reserved and cannot be used for an enum value.`,\n );\n }\n\n return this.parseName();\n }\n /**\n * InputObjectTypeDefinition :\n * - Description? input Name Directives[Const]? InputFieldsDefinition?\n */\n\n parseInputObjectTypeDefinition() {\n const start = this._lexer.token;\n const description = this.parseDescription();\n this.expectKeyword('input');\n const name = this.parseName();\n const directives = this.parseConstDirectives();\n const fields = this.parseInputFieldsDefinition();\n return this.node(start, {\n kind: Kind.INPUT_OBJECT_TYPE_DEFINITION,\n description,\n name,\n directives,\n fields,\n });\n }\n /**\n * ```\n * InputFieldsDefinition : { InputValueDefinition+ }\n * ```\n */\n\n parseInputFieldsDefinition() {\n return this.optionalMany(\n TokenKind.BRACE_L,\n this.parseInputValueDef,\n TokenKind.BRACE_R,\n );\n }\n /**\n * TypeSystemExtension :\n * - SchemaExtension\n * - TypeExtension\n *\n * TypeExtension :\n * - ScalarTypeExtension\n * - ObjectTypeExtension\n * - InterfaceTypeExtension\n * - UnionTypeExtension\n * - EnumTypeExtension\n * - InputObjectTypeDefinition\n */\n\n parseTypeSystemExtension() {\n const keywordToken = this._lexer.lookahead();\n\n if (keywordToken.kind === TokenKind.NAME) {\n switch (keywordToken.value) {\n case 'schema':\n return this.parseSchemaExtension();\n\n case 'scalar':\n return this.parseScalarTypeExtension();\n\n case 'type':\n return this.parseObjectTypeExtension();\n\n case 'interface':\n return this.parseInterfaceTypeExtension();\n\n case 'union':\n return this.parseUnionTypeExtension();\n\n case 'enum':\n return this.parseEnumTypeExtension();\n\n case 'input':\n return this.parseInputObjectTypeExtension();\n }\n }\n\n throw this.unexpected(keywordToken);\n }\n /**\n * ```\n * SchemaExtension :\n * - extend schema Directives[Const]? { OperationTypeDefinition+ }\n * - extend schema Directives[Const]\n * ```\n */\n\n parseSchemaExtension() {\n const start = this._lexer.token;\n this.expectKeyword('extend');\n this.expectKeyword('schema');\n const directives = this.parseConstDirectives();\n const operationTypes = this.optionalMany(\n TokenKind.BRACE_L,\n this.parseOperationTypeDefinition,\n TokenKind.BRACE_R,\n );\n\n if (directives.length === 0 && operationTypes.length === 0) {\n throw this.unexpected();\n }\n\n return this.node(start, {\n kind: Kind.SCHEMA_EXTENSION,\n directives,\n operationTypes,\n });\n }\n /**\n * ScalarTypeExtension :\n * - extend scalar Name Directives[Const]\n */\n\n parseScalarTypeExtension() {\n const start = this._lexer.token;\n this.expectKeyword('extend');\n this.expectKeyword('scalar');\n const name = this.parseName();\n const directives = this.parseConstDirectives();\n\n if (directives.length === 0) {\n throw this.unexpected();\n }\n\n return this.node(start, {\n kind: Kind.SCALAR_TYPE_EXTENSION,\n name,\n directives,\n });\n }\n /**\n * ObjectTypeExtension :\n * - extend type Name ImplementsInterfaces? Directives[Const]? FieldsDefinition\n * - extend type Name ImplementsInterfaces? Directives[Const]\n * - extend type Name ImplementsInterfaces\n */\n\n parseObjectTypeExtension() {\n const start = this._lexer.token;\n this.expectKeyword('extend');\n this.expectKeyword('type');\n const name = this.parseName();\n const interfaces = this.parseImplementsInterfaces();\n const directives = this.parseConstDirectives();\n const fields = this.parseFieldsDefinition();\n\n if (\n interfaces.length === 0 &&\n directives.length === 0 &&\n fields.length === 0\n ) {\n throw this.unexpected();\n }\n\n return this.node(start, {\n kind: Kind.OBJECT_TYPE_EXTENSION,\n name,\n interfaces,\n directives,\n fields,\n });\n }\n /**\n * InterfaceTypeExtension :\n * - extend interface Name ImplementsInterfaces? Directives[Const]? FieldsDefinition\n * - extend interface Name ImplementsInterfaces? Directives[Const]\n * - extend interface Name ImplementsInterfaces\n */\n\n parseInterfaceTypeExtension() {\n const start = this._lexer.token;\n this.expectKeyword('extend');\n this.expectKeyword('interface');\n const name = this.parseName();\n const interfaces = this.parseImplementsInterfaces();\n const directives = this.parseConstDirectives();\n const fields = this.parseFieldsDefinition();\n\n if (\n interfaces.length === 0 &&\n directives.length === 0 &&\n fields.length === 0\n ) {\n throw this.unexpected();\n }\n\n return this.node(start, {\n kind: Kind.INTERFACE_TYPE_EXTENSION,\n name,\n interfaces,\n directives,\n fields,\n });\n }\n /**\n * UnionTypeExtension :\n * - extend union Name Directives[Const]? UnionMemberTypes\n * - extend union Name Directives[Const]\n */\n\n parseUnionTypeExtension() {\n const start = this._lexer.token;\n this.expectKeyword('extend');\n this.expectKeyword('union');\n const name = this.parseName();\n const directives = this.parseConstDirectives();\n const types = this.parseUnionMemberTypes();\n\n if (directives.length === 0 && types.length === 0) {\n throw this.unexpected();\n }\n\n return this.node(start, {\n kind: Kind.UNION_TYPE_EXTENSION,\n name,\n directives,\n types,\n });\n }\n /**\n * EnumTypeExtension :\n * - extend enum Name Directives[Const]? EnumValuesDefinition\n * - extend enum Name Directives[Const]\n */\n\n parseEnumTypeExtension() {\n const start = this._lexer.token;\n this.expectKeyword('extend');\n this.expectKeyword('enum');\n const name = this.parseName();\n const directives = this.parseConstDirectives();\n const values = this.parseEnumValuesDefinition();\n\n if (directives.length === 0 && values.length === 0) {\n throw this.unexpected();\n }\n\n return this.node(start, {\n kind: Kind.ENUM_TYPE_EXTENSION,\n name,\n directives,\n values,\n });\n }\n /**\n * InputObjectTypeExtension :\n * - extend input Name Directives[Const]? InputFieldsDefinition\n * - extend input Name Directives[Const]\n */\n\n parseInputObjectTypeExtension() {\n const start = this._lexer.token;\n this.expectKeyword('extend');\n this.expectKeyword('input');\n const name = this.parseName();\n const directives = this.parseConstDirectives();\n const fields = this.parseInputFieldsDefinition();\n\n if (directives.length === 0 && fields.length === 0) {\n throw this.unexpected();\n }\n\n return this.node(start, {\n kind: Kind.INPUT_OBJECT_TYPE_EXTENSION,\n name,\n directives,\n fields,\n });\n }\n /**\n * ```\n * DirectiveDefinition :\n * - Description? directive @ Name ArgumentsDefinition? `repeatable`? on DirectiveLocations\n * ```\n */\n\n parseDirectiveDefinition() {\n const start = this._lexer.token;\n const description = this.parseDescription();\n this.expectKeyword('directive');\n this.expectToken(TokenKind.AT);\n const name = this.parseName();\n const args = this.parseArgumentDefs();\n const repeatable = this.expectOptionalKeyword('repeatable');\n this.expectKeyword('on');\n const locations = this.parseDirectiveLocations();\n return this.node(start, {\n kind: Kind.DIRECTIVE_DEFINITION,\n description,\n name,\n arguments: args,\n repeatable,\n locations,\n });\n }\n /**\n * DirectiveLocations :\n * - `|`? DirectiveLocation\n * - DirectiveLocations | DirectiveLocation\n */\n\n parseDirectiveLocations() {\n return this.delimitedMany(TokenKind.PIPE, this.parseDirectiveLocation);\n }\n /*\n * DirectiveLocation :\n * - ExecutableDirectiveLocation\n * - TypeSystemDirectiveLocation\n *\n * ExecutableDirectiveLocation : one of\n * `QUERY`\n * `MUTATION`\n * `SUBSCRIPTION`\n * `FIELD`\n * `FRAGMENT_DEFINITION`\n * `FRAGMENT_SPREAD`\n * `INLINE_FRAGMENT`\n *\n * TypeSystemDirectiveLocation : one of\n * `SCHEMA`\n * `SCALAR`\n * `OBJECT`\n * `FIELD_DEFINITION`\n * `ARGUMENT_DEFINITION`\n * `INTERFACE`\n * `UNION`\n * `ENUM`\n * `ENUM_VALUE`\n * `INPUT_OBJECT`\n * `INPUT_FIELD_DEFINITION`\n */\n\n parseDirectiveLocation() {\n const start = this._lexer.token;\n const name = this.parseName();\n\n if (Object.prototype.hasOwnProperty.call(DirectiveLocation, name.value)) {\n return name;\n }\n\n throw this.unexpected(start);\n } // Core parsing utility functions\n\n /**\n * Returns a node that, if configured to do so, sets a \"loc\" field as a\n * location object, used to identify the place in the source that created a\n * given parsed object.\n */\n\n node(startToken, node) {\n if (this._options.noLocation !== true) {\n node.loc = new Location(\n startToken,\n this._lexer.lastToken,\n this._lexer.source,\n );\n }\n\n return node;\n }\n /**\n * Determines if the next token is of a given kind\n */\n\n peek(kind) {\n return this._lexer.token.kind === kind;\n }\n /**\n * If the next token is of the given kind, return that token after advancing the lexer.\n * Otherwise, do not change the parser state and throw an error.\n */\n\n expectToken(kind) {\n const token = this._lexer.token;\n\n if (token.kind === kind) {\n this.advanceLexer();\n return token;\n }\n\n throw syntaxError(\n this._lexer.source,\n token.start,\n `Expected ${getTokenKindDesc(kind)}, found ${getTokenDesc(token)}.`,\n );\n }\n /**\n * If the next token is of the given kind, return \"true\" after advancing the lexer.\n * Otherwise, do not change the parser state and return \"false\".\n */\n\n expectOptionalToken(kind) {\n const token = this._lexer.token;\n\n if (token.kind === kind) {\n this.advanceLexer();\n return true;\n }\n\n return false;\n }\n /**\n * If the next token is a given keyword, advance the lexer.\n * Otherwise, do not change the parser state and throw an error.\n */\n\n expectKeyword(value) {\n const token = this._lexer.token;\n\n if (token.kind === TokenKind.NAME && token.value === value) {\n this.advanceLexer();\n } else {\n throw syntaxError(\n this._lexer.source,\n token.start,\n `Expected \"${value}\", found ${getTokenDesc(token)}.`,\n );\n }\n }\n /**\n * If the next token is a given keyword, return \"true\" after advancing the lexer.\n * Otherwise, do not change the parser state and return \"false\".\n */\n\n expectOptionalKeyword(value) {\n const token = this._lexer.token;\n\n if (token.kind === TokenKind.NAME && token.value === value) {\n this.advanceLexer();\n return true;\n }\n\n return false;\n }\n /**\n * Helper function for creating an error when an unexpected lexed token is encountered.\n */\n\n unexpected(atToken) {\n const token =\n atToken !== null && atToken !== void 0 ? atToken : this._lexer.token;\n return syntaxError(\n this._lexer.source,\n token.start,\n `Unexpected ${getTokenDesc(token)}.`,\n );\n }\n /**\n * Returns a possibly empty list of parse nodes, determined by the parseFn.\n * This list begins with a lex token of openKind and ends with a lex token of closeKind.\n * Advances the parser to the next lex token after the closing token.\n */\n\n any(openKind, parseFn, closeKind) {\n this.expectToken(openKind);\n const nodes = [];\n\n while (!this.expectOptionalToken(closeKind)) {\n nodes.push(parseFn.call(this));\n }\n\n return nodes;\n }\n /**\n * Returns a list of parse nodes, determined by the parseFn.\n * It can be empty only if open token is missing otherwise it will always return non-empty list\n * that begins with a lex token of openKind and ends with a lex token of closeKind.\n * Advances the parser to the next lex token after the closing token.\n */\n\n optionalMany(openKind, parseFn, closeKind) {\n if (this.expectOptionalToken(openKind)) {\n const nodes = [];\n\n do {\n nodes.push(parseFn.call(this));\n } while (!this.expectOptionalToken(closeKind));\n\n return nodes;\n }\n\n return [];\n }\n /**\n * Returns a non-empty list of parse nodes, determined by the parseFn.\n * This list begins with a lex token of openKind and ends with a lex token of closeKind.\n * Advances the parser to the next lex token after the closing token.\n */\n\n many(openKind, parseFn, closeKind) {\n this.expectToken(openKind);\n const nodes = [];\n\n do {\n nodes.push(parseFn.call(this));\n } while (!this.expectOptionalToken(closeKind));\n\n return nodes;\n }\n /**\n * Returns a non-empty list of parse nodes, determined by the parseFn.\n * This list may begin with a lex token of delimiterKind followed by items separated by lex tokens of tokenKind.\n * Advances the parser to the next lex token after last item in the list.\n */\n\n delimitedMany(delimiterKind, parseFn) {\n this.expectOptionalToken(delimiterKind);\n const nodes = [];\n\n do {\n nodes.push(parseFn.call(this));\n } while (this.expectOptionalToken(delimiterKind));\n\n return nodes;\n }\n\n advanceLexer() {\n const { maxTokens } = this._options;\n\n const token = this._lexer.advance();\n\n if (maxTokens !== undefined && token.kind !== TokenKind.EOF) {\n ++this._tokenCounter;\n\n if (this._tokenCounter > maxTokens) {\n throw syntaxError(\n this._lexer.source,\n token.start,\n `Document contains more that ${maxTokens} tokens. Parsing aborted.`,\n );\n }\n }\n }\n}\n/**\n * A helper function to describe a token as a string for debugging.\n */\n\nfunction getTokenDesc(token) {\n const value = token.value;\n return getTokenKindDesc(token.kind) + (value != null ? ` \"${value}\"` : '');\n}\n/**\n * A helper function to describe a token kind as a string for debugging.\n */\n\nfunction getTokenKindDesc(kind) {\n return isPunctuatorTokenKind(kind) ? `\"${kind}\"` : kind;\n}\n","const MAX_SUGGESTIONS = 5;\n/**\n * Given [ A, B, C ] return ' Did you mean A, B, or C?'.\n */\n\nexport function didYouMean(firstArg, secondArg) {\n const [subMessage, suggestionsArg] = secondArg\n ? [firstArg, secondArg]\n : [undefined, firstArg];\n let message = ' Did you mean ';\n\n if (subMessage) {\n message += subMessage + ' ';\n }\n\n const suggestions = suggestionsArg.map((x) => `\"${x}\"`);\n\n switch (suggestions.length) {\n case 0:\n return '';\n\n case 1:\n return message + suggestions[0] + '?';\n\n case 2:\n return message + suggestions[0] + ' or ' + suggestions[1] + '?';\n }\n\n const selected = suggestions.slice(0, MAX_SUGGESTIONS);\n const lastItem = selected.pop();\n return message + selected.join(', ') + ', or ' + lastItem + '?';\n}\n","/**\n * Returns the first argument it receives.\n */\nexport function identityFunc(x) {\n return x;\n}\n","/**\n * Creates a keyed JS object from an array, given a function to produce the keys\n * for each value in the array.\n *\n * This provides a convenient lookup for the array items if the key function\n * produces unique results.\n * ```ts\n * const phoneBook = [\n * { name: 'Jon', num: '555-1234' },\n * { name: 'Jenny', num: '867-5309' }\n * ]\n *\n * const entriesByName = keyMap(\n * phoneBook,\n * entry => entry.name\n * )\n *\n * // {\n * // Jon: { name: 'Jon', num: '555-1234' },\n * // Jenny: { name: 'Jenny', num: '867-5309' }\n * // }\n *\n * const jennyEntry = entriesByName['Jenny']\n *\n * // { name: 'Jenny', num: '857-6309' }\n * ```\n */\nexport function keyMap(list, keyFn) {\n const result = Object.create(null);\n\n for (const item of list) {\n result[keyFn(item)] = item;\n }\n\n return result;\n}\n","/**\n * Creates a keyed JS object from an array, given a function to produce the keys\n * and a function to produce the values from each item in the array.\n * ```ts\n * const phoneBook = [\n * { name: 'Jon', num: '555-1234' },\n * { name: 'Jenny', num: '867-5309' }\n * ]\n *\n * // { Jon: '555-1234', Jenny: '867-5309' }\n * const phonesByName = keyValMap(\n * phoneBook,\n * entry => entry.name,\n * entry => entry.num\n * )\n * ```\n */\nexport function keyValMap(list, keyFn, valFn) {\n const result = Object.create(null);\n\n for (const item of list) {\n result[keyFn(item)] = valFn(item);\n }\n\n return result;\n}\n","/**\n * Creates an object map with the same keys as `map` and values generated by\n * running each value of `map` thru `fn`.\n */\nexport function mapValue(map, fn) {\n const result = Object.create(null);\n\n for (const key of Object.keys(map)) {\n result[key] = fn(map[key], key);\n }\n\n return result;\n}\n","/**\n * Returns a number indicating whether a reference string comes before, or after,\n * or is the same as the given string in natural sort order.\n *\n * See: https://en.wikipedia.org/wiki/Natural_sort_order\n *\n */\nexport function naturalCompare(aStr, bStr) {\n let aIndex = 0;\n let bIndex = 0;\n\n while (aIndex < aStr.length && bIndex < bStr.length) {\n let aChar = aStr.charCodeAt(aIndex);\n let bChar = bStr.charCodeAt(bIndex);\n\n if (isDigit(aChar) && isDigit(bChar)) {\n let aNum = 0;\n\n do {\n ++aIndex;\n aNum = aNum * 10 + aChar - DIGIT_0;\n aChar = aStr.charCodeAt(aIndex);\n } while (isDigit(aChar) && aNum > 0);\n\n let bNum = 0;\n\n do {\n ++bIndex;\n bNum = bNum * 10 + bChar - DIGIT_0;\n bChar = bStr.charCodeAt(bIndex);\n } while (isDigit(bChar) && bNum > 0);\n\n if (aNum < bNum) {\n return -1;\n }\n\n if (aNum > bNum) {\n return 1;\n }\n } else {\n if (aChar < bChar) {\n return -1;\n }\n\n if (aChar > bChar) {\n return 1;\n }\n\n ++aIndex;\n ++bIndex;\n }\n }\n\n return aStr.length - bStr.length;\n}\nconst DIGIT_0 = 48;\nconst DIGIT_9 = 57;\n\nfunction isDigit(code) {\n return !isNaN(code) && DIGIT_0 <= code && code <= DIGIT_9;\n}\n","import { naturalCompare } from './naturalCompare.mjs';\n/**\n * Given an invalid input string and a list of valid options, returns a filtered\n * list of valid options sorted based on their similarity with the input.\n */\n\nexport function suggestionList(input, options) {\n const optionsByDistance = Object.create(null);\n const lexicalDistance = new LexicalDistance(input);\n const threshold = Math.floor(input.length * 0.4) + 1;\n\n for (const option of options) {\n const distance = lexicalDistance.measure(option, threshold);\n\n if (distance !== undefined) {\n optionsByDistance[option] = distance;\n }\n }\n\n return Object.keys(optionsByDistance).sort((a, b) => {\n const distanceDiff = optionsByDistance[a] - optionsByDistance[b];\n return distanceDiff !== 0 ? distanceDiff : naturalCompare(a, b);\n });\n}\n/**\n * Computes the lexical distance between strings A and B.\n *\n * The \"distance\" between two strings is given by counting the minimum number\n * of edits needed to transform string A into string B. An edit can be an\n * insertion, deletion, or substitution of a single character, or a swap of two\n * adjacent characters.\n *\n * Includes a custom alteration from Damerau-Levenshtein to treat case changes\n * as a single edit which helps identify mis-cased values with an edit distance\n * of 1.\n *\n * This distance can be useful for detecting typos in input or sorting\n */\n\nclass LexicalDistance {\n constructor(input) {\n this._input = input;\n this._inputLowerCase = input.toLowerCase();\n this._inputArray = stringToArray(this._inputLowerCase);\n this._rows = [\n new Array(input.length + 1).fill(0),\n new Array(input.length + 1).fill(0),\n new Array(input.length + 1).fill(0),\n ];\n }\n\n measure(option, threshold) {\n if (this._input === option) {\n return 0;\n }\n\n const optionLowerCase = option.toLowerCase(); // Any case change counts as a single edit\n\n if (this._inputLowerCase === optionLowerCase) {\n return 1;\n }\n\n let a = stringToArray(optionLowerCase);\n let b = this._inputArray;\n\n if (a.length < b.length) {\n const tmp = a;\n a = b;\n b = tmp;\n }\n\n const aLength = a.length;\n const bLength = b.length;\n\n if (aLength - bLength > threshold) {\n return undefined;\n }\n\n const rows = this._rows;\n\n for (let j = 0; j <= bLength; j++) {\n rows[0][j] = j;\n }\n\n for (let i = 1; i <= aLength; i++) {\n const upRow = rows[(i - 1) % 3];\n const currentRow = rows[i % 3];\n let smallestCell = (currentRow[0] = i);\n\n for (let j = 1; j <= bLength; j++) {\n const cost = a[i - 1] === b[j - 1] ? 0 : 1;\n let currentCell = Math.min(\n upRow[j] + 1, // delete\n currentRow[j - 1] + 1, // insert\n upRow[j - 1] + cost, // substitute\n );\n\n if (i > 1 && j > 1 && a[i - 1] === b[j - 2] && a[i - 2] === b[j - 1]) {\n // transposition\n const doubleDiagonalCell = rows[(i - 2) % 3][j - 2];\n currentCell = Math.min(currentCell, doubleDiagonalCell + 1);\n }\n\n if (currentCell < smallestCell) {\n smallestCell = currentCell;\n }\n\n currentRow[j] = currentCell;\n } // Early exit, since distance can't go smaller than smallest element of the previous row.\n\n if (smallestCell > threshold) {\n return undefined;\n }\n }\n\n const distance = rows[aLength % 3][bLength];\n return distance <= threshold ? distance : undefined;\n }\n}\n\nfunction stringToArray(str) {\n const strLength = str.length;\n const array = new Array(strLength);\n\n for (let i = 0; i < strLength; ++i) {\n array[i] = str.charCodeAt(i);\n }\n\n return array;\n}\n","export function toObjMap(obj) {\n if (obj == null) {\n return Object.create(null);\n }\n\n if (Object.getPrototypeOf(obj) === null) {\n return obj;\n }\n\n const map = Object.create(null);\n\n for (const [key, value] of Object.entries(obj)) {\n map[key] = value;\n }\n\n return map;\n}\n","/**\n * Prints a string as a GraphQL StringValue literal. Replaces control characters\n * and excluded characters (\" U+0022 and \\\\ U+005C) with escape sequences.\n */\nexport function printString(str) {\n return `\"${str.replace(escapedRegExp, escapedReplacer)}\"`;\n} // eslint-disable-next-line no-control-regex\n\nconst escapedRegExp = /[\\x00-\\x1f\\x22\\x5c\\x7f-\\x9f]/g;\n\nfunction escapedReplacer(str) {\n return escapeSequences[str.charCodeAt(0)];\n} // prettier-ignore\n\nconst escapeSequences = [\n '\\\\u0000',\n '\\\\u0001',\n '\\\\u0002',\n '\\\\u0003',\n '\\\\u0004',\n '\\\\u0005',\n '\\\\u0006',\n '\\\\u0007',\n '\\\\b',\n '\\\\t',\n '\\\\n',\n '\\\\u000B',\n '\\\\f',\n '\\\\r',\n '\\\\u000E',\n '\\\\u000F',\n '\\\\u0010',\n '\\\\u0011',\n '\\\\u0012',\n '\\\\u0013',\n '\\\\u0014',\n '\\\\u0015',\n '\\\\u0016',\n '\\\\u0017',\n '\\\\u0018',\n '\\\\u0019',\n '\\\\u001A',\n '\\\\u001B',\n '\\\\u001C',\n '\\\\u001D',\n '\\\\u001E',\n '\\\\u001F',\n '',\n '',\n '\\\\\"',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '', // 2F\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '', // 3F\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '', // 4F\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '\\\\\\\\',\n '',\n '',\n '', // 5F\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '', // 6F\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '\\\\u007F',\n '\\\\u0080',\n '\\\\u0081',\n '\\\\u0082',\n '\\\\u0083',\n '\\\\u0084',\n '\\\\u0085',\n '\\\\u0086',\n '\\\\u0087',\n '\\\\u0088',\n '\\\\u0089',\n '\\\\u008A',\n '\\\\u008B',\n '\\\\u008C',\n '\\\\u008D',\n '\\\\u008E',\n '\\\\u008F',\n '\\\\u0090',\n '\\\\u0091',\n '\\\\u0092',\n '\\\\u0093',\n '\\\\u0094',\n '\\\\u0095',\n '\\\\u0096',\n '\\\\u0097',\n '\\\\u0098',\n '\\\\u0099',\n '\\\\u009A',\n '\\\\u009B',\n '\\\\u009C',\n '\\\\u009D',\n '\\\\u009E',\n '\\\\u009F',\n];\n","import { devAssert } from '../jsutils/devAssert.mjs';\nimport { inspect } from '../jsutils/inspect.mjs';\nimport { isNode, QueryDocumentKeys } from './ast.mjs';\nimport { Kind } from './kinds.mjs';\n/**\n * A visitor is provided to visit, it contains the collection of\n * relevant functions to be called during the visitor's traversal.\n */\n\nexport const BREAK = Object.freeze({});\n/**\n * visit() will walk through an AST using a depth-first traversal, calling\n * the visitor's enter function at each node in the traversal, and calling the\n * leave function after visiting that node and all of its child nodes.\n *\n * By returning different values from the enter and leave functions, the\n * behavior of the visitor can be altered, including skipping over a sub-tree of\n * the AST (by returning false), editing the AST by returning a value or null\n * to remove the value, or to stop the whole traversal by returning BREAK.\n *\n * When using visit() to edit an AST, the original AST will not be modified, and\n * a new version of the AST with the changes applied will be returned from the\n * visit function.\n *\n * ```ts\n * const editedAST = visit(ast, {\n * enter(node, key, parent, path, ancestors) {\n * // @return\n * // undefined: no action\n * // false: skip visiting this node\n * // visitor.BREAK: stop visiting altogether\n * // null: delete this node\n * // any value: replace this node with the returned value\n * },\n * leave(node, key, parent, path, ancestors) {\n * // @return\n * // undefined: no action\n * // false: no action\n * // visitor.BREAK: stop visiting altogether\n * // null: delete this node\n * // any value: replace this node with the returned value\n * }\n * });\n * ```\n *\n * Alternatively to providing enter() and leave() functions, a visitor can\n * instead provide functions named the same as the kinds of AST nodes, or\n * enter/leave visitors at a named key, leading to three permutations of the\n * visitor API:\n *\n * 1) Named visitors triggered when entering a node of a specific kind.\n *\n * ```ts\n * visit(ast, {\n * Kind(node) {\n * // enter the \"Kind\" node\n * }\n * })\n * ```\n *\n * 2) Named visitors that trigger upon entering and leaving a node of a specific kind.\n *\n * ```ts\n * visit(ast, {\n * Kind: {\n * enter(node) {\n * // enter the \"Kind\" node\n * }\n * leave(node) {\n * // leave the \"Kind\" node\n * }\n * }\n * })\n * ```\n *\n * 3) Generic visitors that trigger upon entering and leaving any node.\n *\n * ```ts\n * visit(ast, {\n * enter(node) {\n * // enter any node\n * },\n * leave(node) {\n * // leave any node\n * }\n * })\n * ```\n */\n\nexport function visit(root, visitor, visitorKeys = QueryDocumentKeys) {\n const enterLeaveMap = new Map();\n\n for (const kind of Object.values(Kind)) {\n enterLeaveMap.set(kind, getEnterLeaveForKind(visitor, kind));\n }\n /* eslint-disable no-undef-init */\n\n let stack = undefined;\n let inArray = Array.isArray(root);\n let keys = [root];\n let index = -1;\n let edits = [];\n let node = root;\n let key = undefined;\n let parent = undefined;\n const path = [];\n const ancestors = [];\n /* eslint-enable no-undef-init */\n\n do {\n index++;\n const isLeaving = index === keys.length;\n const isEdited = isLeaving && edits.length !== 0;\n\n if (isLeaving) {\n key = ancestors.length === 0 ? undefined : path[path.length - 1];\n node = parent;\n parent = ancestors.pop();\n\n if (isEdited) {\n if (inArray) {\n node = node.slice();\n let editOffset = 0;\n\n for (const [editKey, editValue] of edits) {\n const arrayKey = editKey - editOffset;\n\n if (editValue === null) {\n node.splice(arrayKey, 1);\n editOffset++;\n } else {\n node[arrayKey] = editValue;\n }\n }\n } else {\n node = Object.defineProperties(\n {},\n Object.getOwnPropertyDescriptors(node),\n );\n\n for (const [editKey, editValue] of edits) {\n node[editKey] = editValue;\n }\n }\n }\n\n index = stack.index;\n keys = stack.keys;\n edits = stack.edits;\n inArray = stack.inArray;\n stack = stack.prev;\n } else if (parent) {\n key = inArray ? index : keys[index];\n node = parent[key];\n\n if (node === null || node === undefined) {\n continue;\n }\n\n path.push(key);\n }\n\n let result;\n\n if (!Array.isArray(node)) {\n var _enterLeaveMap$get, _enterLeaveMap$get2;\n\n isNode(node) || devAssert(false, `Invalid AST Node: ${inspect(node)}.`);\n const visitFn = isLeaving\n ? (_enterLeaveMap$get = enterLeaveMap.get(node.kind)) === null ||\n _enterLeaveMap$get === void 0\n ? void 0\n : _enterLeaveMap$get.leave\n : (_enterLeaveMap$get2 = enterLeaveMap.get(node.kind)) === null ||\n _enterLeaveMap$get2 === void 0\n ? void 0\n : _enterLeaveMap$get2.enter;\n result =\n visitFn === null || visitFn === void 0\n ? void 0\n : visitFn.call(visitor, node, key, parent, path, ancestors);\n\n if (result === BREAK) {\n break;\n }\n\n if (result === false) {\n if (!isLeaving) {\n path.pop();\n continue;\n }\n } else if (result !== undefined) {\n edits.push([key, result]);\n\n if (!isLeaving) {\n if (isNode(result)) {\n node = result;\n } else {\n path.pop();\n continue;\n }\n }\n }\n }\n\n if (result === undefined && isEdited) {\n edits.push([key, node]);\n }\n\n if (isLeaving) {\n path.pop();\n } else {\n var _node$kind;\n\n stack = {\n inArray,\n index,\n keys,\n edits,\n prev: stack,\n };\n inArray = Array.isArray(node);\n keys = inArray\n ? node\n : (_node$kind = visitorKeys[node.kind]) !== null &&\n _node$kind !== void 0\n ? _node$kind\n : [];\n index = -1;\n edits = [];\n\n if (parent) {\n ancestors.push(parent);\n }\n\n parent = node;\n }\n } while (stack !== undefined);\n\n if (edits.length !== 0) {\n // New root\n return edits[edits.length - 1][1];\n }\n\n return root;\n}\n/**\n * Creates a new visitor instance which delegates to many visitors to run in\n * parallel. Each visitor will be visited for each node before moving on.\n *\n * If a prior visitor edits a node, no following visitors will see that node.\n */\n\nexport function visitInParallel(visitors) {\n const skipping = new Array(visitors.length).fill(null);\n const mergedVisitor = Object.create(null);\n\n for (const kind of Object.values(Kind)) {\n let hasVisitor = false;\n const enterList = new Array(visitors.length).fill(undefined);\n const leaveList = new Array(visitors.length).fill(undefined);\n\n for (let i = 0; i < visitors.length; ++i) {\n const { enter, leave } = getEnterLeaveForKind(visitors[i], kind);\n hasVisitor || (hasVisitor = enter != null || leave != null);\n enterList[i] = enter;\n leaveList[i] = leave;\n }\n\n if (!hasVisitor) {\n continue;\n }\n\n const mergedEnterLeave = {\n enter(...args) {\n const node = args[0];\n\n for (let i = 0; i < visitors.length; i++) {\n if (skipping[i] === null) {\n var _enterList$i;\n\n const result =\n (_enterList$i = enterList[i]) === null || _enterList$i === void 0\n ? void 0\n : _enterList$i.apply(visitors[i], args);\n\n if (result === false) {\n skipping[i] = node;\n } else if (result === BREAK) {\n skipping[i] = BREAK;\n } else if (result !== undefined) {\n return result;\n }\n }\n }\n },\n\n leave(...args) {\n const node = args[0];\n\n for (let i = 0; i < visitors.length; i++) {\n if (skipping[i] === null) {\n var _leaveList$i;\n\n const result =\n (_leaveList$i = leaveList[i]) === null || _leaveList$i === void 0\n ? void 0\n : _leaveList$i.apply(visitors[i], args);\n\n if (result === BREAK) {\n skipping[i] = BREAK;\n } else if (result !== undefined && result !== false) {\n return result;\n }\n } else if (skipping[i] === node) {\n skipping[i] = null;\n }\n }\n },\n };\n mergedVisitor[kind] = mergedEnterLeave;\n }\n\n return mergedVisitor;\n}\n/**\n * Given a visitor instance and a node kind, return EnterLeaveVisitor for that kind.\n */\n\nexport function getEnterLeaveForKind(visitor, kind) {\n const kindVisitor = visitor[kind];\n\n if (typeof kindVisitor === 'object') {\n // { Kind: { enter() {}, leave() {} } }\n return kindVisitor;\n } else if (typeof kindVisitor === 'function') {\n // { Kind() {} }\n return {\n enter: kindVisitor,\n leave: undefined,\n };\n } // { enter() {}, leave() {} }\n\n return {\n enter: visitor.enter,\n leave: visitor.leave,\n };\n}\n/**\n * Given a visitor instance, if it is leaving or not, and a node kind, return\n * the function the visitor runtime should call.\n *\n * @deprecated Please use `getEnterLeaveForKind` instead. Will be removed in v17\n */\n\n/* c8 ignore next 8 */\n\nexport function getVisitFn(visitor, kind, isLeaving) {\n const { enter, leave } = getEnterLeaveForKind(visitor, kind);\n return isLeaving ? leave : enter;\n}\n","import { printBlockString } from './blockString.mjs';\nimport { printString } from './printString.mjs';\nimport { visit } from './visitor.mjs';\n/**\n * Converts an AST into a string, using one set of reasonable\n * formatting rules.\n */\n\nexport function print(ast) {\n return visit(ast, printDocASTReducer);\n}\nconst MAX_LINE_LENGTH = 80;\nconst printDocASTReducer = {\n Name: {\n leave: (node) => node.value,\n },\n Variable: {\n leave: (node) => '$' + node.name,\n },\n // Document\n Document: {\n leave: (node) => join(node.definitions, '\\n\\n'),\n },\n OperationDefinition: {\n leave(node) {\n const varDefs = wrap('(', join(node.variableDefinitions, ', '), ')');\n const prefix = join(\n [\n node.operation,\n join([node.name, varDefs]),\n join(node.directives, ' '),\n ],\n ' ',\n ); // Anonymous queries with no directives or variable definitions can use\n // the query short form.\n\n return (prefix === 'query' ? '' : prefix + ' ') + node.selectionSet;\n },\n },\n VariableDefinition: {\n leave: ({ variable, type, defaultValue, directives }) =>\n variable +\n ': ' +\n type +\n wrap(' = ', defaultValue) +\n wrap(' ', join(directives, ' ')),\n },\n SelectionSet: {\n leave: ({ selections }) => block(selections),\n },\n Field: {\n leave({ alias, name, arguments: args, directives, selectionSet }) {\n const prefix = wrap('', alias, ': ') + name;\n let argsLine = prefix + wrap('(', join(args, ', '), ')');\n\n if (argsLine.length > MAX_LINE_LENGTH) {\n argsLine = prefix + wrap('(\\n', indent(join(args, '\\n')), '\\n)');\n }\n\n return join([argsLine, join(directives, ' '), selectionSet], ' ');\n },\n },\n Argument: {\n leave: ({ name, value }) => name + ': ' + value,\n },\n // Fragments\n FragmentSpread: {\n leave: ({ name, directives }) =>\n '...' + name + wrap(' ', join(directives, ' ')),\n },\n InlineFragment: {\n leave: ({ typeCondition, directives, selectionSet }) =>\n join(\n [\n '...',\n wrap('on ', typeCondition),\n join(directives, ' '),\n selectionSet,\n ],\n ' ',\n ),\n },\n FragmentDefinition: {\n leave: (\n { name, typeCondition, variableDefinitions, directives, selectionSet }, // Note: fragment variable definitions are experimental and may be changed\n ) =>\n // or removed in the future.\n `fragment ${name}${wrap('(', join(variableDefinitions, ', '), ')')} ` +\n `on ${typeCondition} ${wrap('', join(directives, ' '), ' ')}` +\n selectionSet,\n },\n // Value\n IntValue: {\n leave: ({ value }) => value,\n },\n FloatValue: {\n leave: ({ value }) => value,\n },\n StringValue: {\n leave: ({ value, block: isBlockString }) =>\n isBlockString ? printBlockString(value) : printString(value),\n },\n BooleanValue: {\n leave: ({ value }) => (value ? 'true' : 'false'),\n },\n NullValue: {\n leave: () => 'null',\n },\n EnumValue: {\n leave: ({ value }) => value,\n },\n ListValue: {\n leave: ({ values }) => '[' + join(values, ', ') + ']',\n },\n ObjectValue: {\n leave: ({ fields }) => '{' + join(fields, ', ') + '}',\n },\n ObjectField: {\n leave: ({ name, value }) => name + ': ' + value,\n },\n // Directive\n Directive: {\n leave: ({ name, arguments: args }) =>\n '@' + name + wrap('(', join(args, ', '), ')'),\n },\n // Type\n NamedType: {\n leave: ({ name }) => name,\n },\n ListType: {\n leave: ({ type }) => '[' + type + ']',\n },\n NonNullType: {\n leave: ({ type }) => type + '!',\n },\n // Type System Definitions\n SchemaDefinition: {\n leave: ({ description, directives, operationTypes }) =>\n wrap('', description, '\\n') +\n join(['schema', join(directives, ' '), block(operationTypes)], ' '),\n },\n OperationTypeDefinition: {\n leave: ({ operation, type }) => operation + ': ' + type,\n },\n ScalarTypeDefinition: {\n leave: ({ description, name, directives }) =>\n wrap('', description, '\\n') +\n join(['scalar', name, join(directives, ' ')], ' '),\n },\n ObjectTypeDefinition: {\n leave: ({ description, name, interfaces, directives, fields }) =>\n wrap('', description, '\\n') +\n join(\n [\n 'type',\n name,\n wrap('implements ', join(interfaces, ' & ')),\n join(directives, ' '),\n block(fields),\n ],\n ' ',\n ),\n },\n FieldDefinition: {\n leave: ({ description, name, arguments: args, type, directives }) =>\n wrap('', description, '\\n') +\n name +\n (hasMultilineItems(args)\n ? wrap('(\\n', indent(join(args, '\\n')), '\\n)')\n : wrap('(', join(args, ', '), ')')) +\n ': ' +\n type +\n wrap(' ', join(directives, ' ')),\n },\n InputValueDefinition: {\n leave: ({ description, name, type, defaultValue, directives }) =>\n wrap('', description, '\\n') +\n join(\n [name + ': ' + type, wrap('= ', defaultValue), join(directives, ' ')],\n ' ',\n ),\n },\n InterfaceTypeDefinition: {\n leave: ({ description, name, interfaces, directives, fields }) =>\n wrap('', description, '\\n') +\n join(\n [\n 'interface',\n name,\n wrap('implements ', join(interfaces, ' & ')),\n join(directives, ' '),\n block(fields),\n ],\n ' ',\n ),\n },\n UnionTypeDefinition: {\n leave: ({ description, name, directives, types }) =>\n wrap('', description, '\\n') +\n join(\n ['union', name, join(directives, ' '), wrap('= ', join(types, ' | '))],\n ' ',\n ),\n },\n EnumTypeDefinition: {\n leave: ({ description, name, directives, values }) =>\n wrap('', description, '\\n') +\n join(['enum', name, join(directives, ' '), block(values)], ' '),\n },\n EnumValueDefinition: {\n leave: ({ description, name, directives }) =>\n wrap('', description, '\\n') + join([name, join(directives, ' ')], ' '),\n },\n InputObjectTypeDefinition: {\n leave: ({ description, name, directives, fields }) =>\n wrap('', description, '\\n') +\n join(['input', name, join(directives, ' '), block(fields)], ' '),\n },\n DirectiveDefinition: {\n leave: ({ description, name, arguments: args, repeatable, locations }) =>\n wrap('', description, '\\n') +\n 'directive @' +\n name +\n (hasMultilineItems(args)\n ? wrap('(\\n', indent(join(args, '\\n')), '\\n)')\n : wrap('(', join(args, ', '), ')')) +\n (repeatable ? ' repeatable' : '') +\n ' on ' +\n join(locations, ' | '),\n },\n SchemaExtension: {\n leave: ({ directives, operationTypes }) =>\n join(\n ['extend schema', join(directives, ' '), block(operationTypes)],\n ' ',\n ),\n },\n ScalarTypeExtension: {\n leave: ({ name, directives }) =>\n join(['extend scalar', name, join(directives, ' ')], ' '),\n },\n ObjectTypeExtension: {\n leave: ({ name, interfaces, directives, fields }) =>\n join(\n [\n 'extend type',\n name,\n wrap('implements ', join(interfaces, ' & ')),\n join(directives, ' '),\n block(fields),\n ],\n ' ',\n ),\n },\n InterfaceTypeExtension: {\n leave: ({ name, interfaces, directives, fields }) =>\n join(\n [\n 'extend interface',\n name,\n wrap('implements ', join(interfaces, ' & ')),\n join(directives, ' '),\n block(fields),\n ],\n ' ',\n ),\n },\n UnionTypeExtension: {\n leave: ({ name, directives, types }) =>\n join(\n [\n 'extend union',\n name,\n join(directives, ' '),\n wrap('= ', join(types, ' | ')),\n ],\n ' ',\n ),\n },\n EnumTypeExtension: {\n leave: ({ name, directives, values }) =>\n join(['extend enum', name, join(directives, ' '), block(values)], ' '),\n },\n InputObjectTypeExtension: {\n leave: ({ name, directives, fields }) =>\n join(['extend input', name, join(directives, ' '), block(fields)], ' '),\n },\n};\n/**\n * Given maybeArray, print an empty string if it is null or empty, otherwise\n * print all items together separated by separator if provided\n */\n\nfunction join(maybeArray, separator = '') {\n var _maybeArray$filter$jo;\n\n return (_maybeArray$filter$jo =\n maybeArray === null || maybeArray === void 0\n ? void 0\n : maybeArray.filter((x) => x).join(separator)) !== null &&\n _maybeArray$filter$jo !== void 0\n ? _maybeArray$filter$jo\n : '';\n}\n/**\n * Given array, print each item on its own line, wrapped in an indented `{ }` block.\n */\n\nfunction block(array) {\n return wrap('{\\n', indent(join(array, '\\n')), '\\n}');\n}\n/**\n * If maybeString is not null or empty, then wrap with start and end, otherwise print an empty string.\n */\n\nfunction wrap(start, maybeString, end = '') {\n return maybeString != null && maybeString !== ''\n ? start + maybeString + end\n : '';\n}\n\nfunction indent(str) {\n return wrap(' ', str.replace(/\\n/g, '\\n '));\n}\n\nfunction hasMultilineItems(maybeArray) {\n var _maybeArray$some;\n\n // FIXME: https://github.com/graphql/graphql-js/issues/2203\n\n /* c8 ignore next */\n return (_maybeArray$some =\n maybeArray === null || maybeArray === void 0\n ? void 0\n : maybeArray.some((str) => str.includes('\\n'))) !== null &&\n _maybeArray$some !== void 0\n ? _maybeArray$some\n : false;\n}\n","import { keyValMap } from '../jsutils/keyValMap.mjs';\nimport { Kind } from '../language/kinds.mjs';\n/**\n * Produces a JavaScript value given a GraphQL Value AST.\n *\n * Unlike `valueFromAST()`, no type is provided. The resulting JavaScript value\n * will reflect the provided GraphQL value AST.\n *\n * | GraphQL Value | JavaScript Value |\n * | -------------------- | ---------------- |\n * | Input Object | Object |\n * | List | Array |\n * | Boolean | Boolean |\n * | String / Enum | String |\n * | Int / Float | Number |\n * | Null | null |\n *\n */\n\nexport function valueFromASTUntyped(valueNode, variables) {\n switch (valueNode.kind) {\n case Kind.NULL:\n return null;\n\n case Kind.INT:\n return parseInt(valueNode.value, 10);\n\n case Kind.FLOAT:\n return parseFloat(valueNode.value);\n\n case Kind.STRING:\n case Kind.ENUM:\n case Kind.BOOLEAN:\n return valueNode.value;\n\n case Kind.LIST:\n return valueNode.values.map((node) =>\n valueFromASTUntyped(node, variables),\n );\n\n case Kind.OBJECT:\n return keyValMap(\n valueNode.fields,\n (field) => field.name.value,\n (field) => valueFromASTUntyped(field.value, variables),\n );\n\n case Kind.VARIABLE:\n return variables === null || variables === void 0\n ? void 0\n : variables[valueNode.name.value];\n }\n}\n","import { devAssert } from '../jsutils/devAssert.mjs';\nimport { GraphQLError } from '../error/GraphQLError.mjs';\nimport { isNameContinue, isNameStart } from '../language/characterClasses.mjs';\n/**\n * Upholds the spec rules about naming.\n */\n\nexport function assertName(name) {\n name != null || devAssert(false, 'Must provide name.');\n typeof name === 'string' || devAssert(false, 'Expected name to be a string.');\n\n if (name.length === 0) {\n throw new GraphQLError('Expected name to be a non-empty string.');\n }\n\n for (let i = 1; i < name.length; ++i) {\n if (!isNameContinue(name.charCodeAt(i))) {\n throw new GraphQLError(\n `Names must only contain [_a-zA-Z0-9] but \"${name}\" does not.`,\n );\n }\n }\n\n if (!isNameStart(name.charCodeAt(0))) {\n throw new GraphQLError(\n `Names must start with [_a-zA-Z] but \"${name}\" does not.`,\n );\n }\n\n return name;\n}\n/**\n * Upholds the spec rules about naming enum values.\n *\n * @internal\n */\n\nexport function assertEnumValueName(name) {\n if (name === 'true' || name === 'false' || name === 'null') {\n throw new GraphQLError(`Enum values cannot be named: ${name}`);\n }\n\n return assertName(name);\n}\n","import { devAssert } from '../jsutils/devAssert.mjs';\nimport { didYouMean } from '../jsutils/didYouMean.mjs';\nimport { identityFunc } from '../jsutils/identityFunc.mjs';\nimport { inspect } from '../jsutils/inspect.mjs';\nimport { instanceOf } from '../jsutils/instanceOf.mjs';\nimport { isObjectLike } from '../jsutils/isObjectLike.mjs';\nimport { keyMap } from '../jsutils/keyMap.mjs';\nimport { keyValMap } from '../jsutils/keyValMap.mjs';\nimport { mapValue } from '../jsutils/mapValue.mjs';\nimport { suggestionList } from '../jsutils/suggestionList.mjs';\nimport { toObjMap } from '../jsutils/toObjMap.mjs';\nimport { GraphQLError } from '../error/GraphQLError.mjs';\nimport { Kind } from '../language/kinds.mjs';\nimport { print } from '../language/printer.mjs';\nimport { valueFromASTUntyped } from '../utilities/valueFromASTUntyped.mjs';\nimport { assertEnumValueName, assertName } from './assertName.mjs';\nexport function isType(type) {\n return (\n isScalarType(type) ||\n isObjectType(type) ||\n isInterfaceType(type) ||\n isUnionType(type) ||\n isEnumType(type) ||\n isInputObjectType(type) ||\n isListType(type) ||\n isNonNullType(type)\n );\n}\nexport function assertType(type) {\n if (!isType(type)) {\n throw new Error(`Expected ${inspect(type)} to be a GraphQL type.`);\n }\n\n return type;\n}\n/**\n * There are predicates for each kind of GraphQL type.\n */\n\nexport function isScalarType(type) {\n return instanceOf(type, GraphQLScalarType);\n}\nexport function assertScalarType(type) {\n if (!isScalarType(type)) {\n throw new Error(`Expected ${inspect(type)} to be a GraphQL Scalar type.`);\n }\n\n return type;\n}\nexport function isObjectType(type) {\n return instanceOf(type, GraphQLObjectType);\n}\nexport function assertObjectType(type) {\n if (!isObjectType(type)) {\n throw new Error(`Expected ${inspect(type)} to be a GraphQL Object type.`);\n }\n\n return type;\n}\nexport function isInterfaceType(type) {\n return instanceOf(type, GraphQLInterfaceType);\n}\nexport function assertInterfaceType(type) {\n if (!isInterfaceType(type)) {\n throw new Error(\n `Expected ${inspect(type)} to be a GraphQL Interface type.`,\n );\n }\n\n return type;\n}\nexport function isUnionType(type) {\n return instanceOf(type, GraphQLUnionType);\n}\nexport function assertUnionType(type) {\n if (!isUnionType(type)) {\n throw new Error(`Expected ${inspect(type)} to be a GraphQL Union type.`);\n }\n\n return type;\n}\nexport function isEnumType(type) {\n return instanceOf(type, GraphQLEnumType);\n}\nexport function assertEnumType(type) {\n if (!isEnumType(type)) {\n throw new Error(`Expected ${inspect(type)} to be a GraphQL Enum type.`);\n }\n\n return type;\n}\nexport function isInputObjectType(type) {\n return instanceOf(type, GraphQLInputObjectType);\n}\nexport function assertInputObjectType(type) {\n if (!isInputObjectType(type)) {\n throw new Error(\n `Expected ${inspect(type)} to be a GraphQL Input Object type.`,\n );\n }\n\n return type;\n}\nexport function isListType(type) {\n return instanceOf(type, GraphQLList);\n}\nexport function assertListType(type) {\n if (!isListType(type)) {\n throw new Error(`Expected ${inspect(type)} to be a GraphQL List type.`);\n }\n\n return type;\n}\nexport function isNonNullType(type) {\n return instanceOf(type, GraphQLNonNull);\n}\nexport function assertNonNullType(type) {\n if (!isNonNullType(type)) {\n throw new Error(`Expected ${inspect(type)} to be a GraphQL Non-Null type.`);\n }\n\n return type;\n}\n/**\n * These types may be used as input types for arguments and directives.\n */\n\nexport function isInputType(type) {\n return (\n isScalarType(type) ||\n isEnumType(type) ||\n isInputObjectType(type) ||\n (isWrappingType(type) && isInputType(type.ofType))\n );\n}\nexport function assertInputType(type) {\n if (!isInputType(type)) {\n throw new Error(`Expected ${inspect(type)} to be a GraphQL input type.`);\n }\n\n return type;\n}\n/**\n * These types may be used as output types as the result of fields.\n */\n\nexport function isOutputType(type) {\n return (\n isScalarType(type) ||\n isObjectType(type) ||\n isInterfaceType(type) ||\n isUnionType(type) ||\n isEnumType(type) ||\n (isWrappingType(type) && isOutputType(type.ofType))\n );\n}\nexport function assertOutputType(type) {\n if (!isOutputType(type)) {\n throw new Error(`Expected ${inspect(type)} to be a GraphQL output type.`);\n }\n\n return type;\n}\n/**\n * These types may describe types which may be leaf values.\n */\n\nexport function isLeafType(type) {\n return isScalarType(type) || isEnumType(type);\n}\nexport function assertLeafType(type) {\n if (!isLeafType(type)) {\n throw new Error(`Expected ${inspect(type)} to be a GraphQL leaf type.`);\n }\n\n return type;\n}\n/**\n * These types may describe the parent context of a selection set.\n */\n\nexport function isCompositeType(type) {\n return isObjectType(type) || isInterfaceType(type) || isUnionType(type);\n}\nexport function assertCompositeType(type) {\n if (!isCompositeType(type)) {\n throw new Error(\n `Expected ${inspect(type)} to be a GraphQL composite type.`,\n );\n }\n\n return type;\n}\n/**\n * These types may describe the parent context of a selection set.\n */\n\nexport function isAbstractType(type) {\n return isInterfaceType(type) || isUnionType(type);\n}\nexport function assertAbstractType(type) {\n if (!isAbstractType(type)) {\n throw new Error(`Expected ${inspect(type)} to be a GraphQL abstract type.`);\n }\n\n return type;\n}\n/**\n * List Type Wrapper\n *\n * A list is a wrapping type which points to another type.\n * Lists are often created within the context of defining the fields of\n * an object type.\n *\n * Example:\n *\n * ```ts\n * const PersonType = new GraphQLObjectType({\n * name: 'Person',\n * fields: () => ({\n * parents: { type: new GraphQLList(PersonType) },\n * children: { type: new GraphQLList(PersonType) },\n * })\n * })\n * ```\n */\n\nexport class GraphQLList {\n constructor(ofType) {\n isType(ofType) ||\n devAssert(false, `Expected ${inspect(ofType)} to be a GraphQL type.`);\n this.ofType = ofType;\n }\n\n get [Symbol.toStringTag]() {\n return 'GraphQLList';\n }\n\n toString() {\n return '[' + String(this.ofType) + ']';\n }\n\n toJSON() {\n return this.toString();\n }\n}\n/**\n * Non-Null Type Wrapper\n *\n * A non-null is a wrapping type which points to another type.\n * Non-null types enforce that their values are never null and can ensure\n * an error is raised if this ever occurs during a request. It is useful for\n * fields which you can make a strong guarantee on non-nullability, for example\n * usually the id field of a database row will never be null.\n *\n * Example:\n *\n * ```ts\n * const RowType = new GraphQLObjectType({\n * name: 'Row',\n * fields: () => ({\n * id: { type: new GraphQLNonNull(GraphQLString) },\n * })\n * })\n * ```\n * Note: the enforcement of non-nullability occurs within the executor.\n */\n\nexport class GraphQLNonNull {\n constructor(ofType) {\n isNullableType(ofType) ||\n devAssert(\n false,\n `Expected ${inspect(ofType)} to be a GraphQL nullable type.`,\n );\n this.ofType = ofType;\n }\n\n get [Symbol.toStringTag]() {\n return 'GraphQLNonNull';\n }\n\n toString() {\n return String(this.ofType) + '!';\n }\n\n toJSON() {\n return this.toString();\n }\n}\n/**\n * These types wrap and modify other types\n */\n\nexport function isWrappingType(type) {\n return isListType(type) || isNonNullType(type);\n}\nexport function assertWrappingType(type) {\n if (!isWrappingType(type)) {\n throw new Error(`Expected ${inspect(type)} to be a GraphQL wrapping type.`);\n }\n\n return type;\n}\n/**\n * These types can all accept null as a value.\n */\n\nexport function isNullableType(type) {\n return isType(type) && !isNonNullType(type);\n}\nexport function assertNullableType(type) {\n if (!isNullableType(type)) {\n throw new Error(`Expected ${inspect(type)} to be a GraphQL nullable type.`);\n }\n\n return type;\n}\nexport function getNullableType(type) {\n if (type) {\n return isNonNullType(type) ? type.ofType : type;\n }\n}\n/**\n * These named types do not include modifiers like List or NonNull.\n */\n\nexport function isNamedType(type) {\n return (\n isScalarType(type) ||\n isObjectType(type) ||\n isInterfaceType(type) ||\n isUnionType(type) ||\n isEnumType(type) ||\n isInputObjectType(type)\n );\n}\nexport function assertNamedType(type) {\n if (!isNamedType(type)) {\n throw new Error(`Expected ${inspect(type)} to be a GraphQL named type.`);\n }\n\n return type;\n}\nexport function getNamedType(type) {\n if (type) {\n let unwrappedType = type;\n\n while (isWrappingType(unwrappedType)) {\n unwrappedType = unwrappedType.ofType;\n }\n\n return unwrappedType;\n }\n}\n/**\n * Used while defining GraphQL types to allow for circular references in\n * otherwise immutable type definitions.\n */\n\nexport function resolveReadonlyArrayThunk(thunk) {\n return typeof thunk === 'function' ? thunk() : thunk;\n}\nexport function resolveObjMapThunk(thunk) {\n return typeof thunk === 'function' ? thunk() : thunk;\n}\n/**\n * Custom extensions\n *\n * @remarks\n * Use a unique identifier name for your extension, for example the name of\n * your library or project. Do not use a shortened identifier as this increases\n * the risk of conflicts. We recommend you add at most one extension field,\n * an object which can contain all the values you need.\n */\n\n/**\n * Scalar Type Definition\n *\n * The leaf values of any request and input values to arguments are\n * Scalars (or Enums) and are defined with a name and a series of functions\n * used to parse input from ast or variables and to ensure validity.\n *\n * If a type's serialize function returns `null` or does not return a value\n * (i.e. it returns `undefined`) then an error will be raised and a `null`\n * value will be returned in the response. It is always better to validate\n *\n * Example:\n *\n * ```ts\n * const OddType = new GraphQLScalarType({\n * name: 'Odd',\n * serialize(value) {\n * if (!Number.isFinite(value)) {\n * throw new Error(\n * `Scalar \"Odd\" cannot represent \"${value}\" since it is not a finite number.`,\n * );\n * }\n *\n * if (value % 2 === 0) {\n * throw new Error(`Scalar \"Odd\" cannot represent \"${value}\" since it is even.`);\n * }\n * return value;\n * }\n * });\n * ```\n */\nexport class GraphQLScalarType {\n constructor(config) {\n var _config$parseValue,\n _config$serialize,\n _config$parseLiteral,\n _config$extensionASTN;\n\n const parseValue =\n (_config$parseValue = config.parseValue) !== null &&\n _config$parseValue !== void 0\n ? _config$parseValue\n : identityFunc;\n this.name = assertName(config.name);\n this.description = config.description;\n this.specifiedByURL = config.specifiedByURL;\n this.serialize =\n (_config$serialize = config.serialize) !== null &&\n _config$serialize !== void 0\n ? _config$serialize\n : identityFunc;\n this.parseValue = parseValue;\n this.parseLiteral =\n (_config$parseLiteral = config.parseLiteral) !== null &&\n _config$parseLiteral !== void 0\n ? _config$parseLiteral\n : (node, variables) => parseValue(valueFromASTUntyped(node, variables));\n this.extensions = toObjMap(config.extensions);\n this.astNode = config.astNode;\n this.extensionASTNodes =\n (_config$extensionASTN = config.extensionASTNodes) !== null &&\n _config$extensionASTN !== void 0\n ? _config$extensionASTN\n : [];\n config.specifiedByURL == null ||\n typeof config.specifiedByURL === 'string' ||\n devAssert(\n false,\n `${this.name} must provide \"specifiedByURL\" as a string, ` +\n `but got: ${inspect(config.specifiedByURL)}.`,\n );\n config.serialize == null ||\n typeof config.serialize === 'function' ||\n devAssert(\n false,\n `${this.name} must provide \"serialize\" function. If this custom Scalar is also used as an input type, ensure \"parseValue\" and \"parseLiteral\" functions are also provided.`,\n );\n\n if (config.parseLiteral) {\n (typeof config.parseValue === 'function' &&\n typeof config.parseLiteral === 'function') ||\n devAssert(\n false,\n `${this.name} must provide both \"parseValue\" and \"parseLiteral\" functions.`,\n );\n }\n }\n\n get [Symbol.toStringTag]() {\n return 'GraphQLScalarType';\n }\n\n toConfig() {\n return {\n name: this.name,\n description: this.description,\n specifiedByURL: this.specifiedByURL,\n serialize: this.serialize,\n parseValue: this.parseValue,\n parseLiteral: this.parseLiteral,\n extensions: this.extensions,\n astNode: this.astNode,\n extensionASTNodes: this.extensionASTNodes,\n };\n }\n\n toString() {\n return this.name;\n }\n\n toJSON() {\n return this.toString();\n }\n}\n\n/**\n * Object Type Definition\n *\n * Almost all of the GraphQL types you define will be object types. Object types\n * have a name, but most importantly describe their fields.\n *\n * Example:\n *\n * ```ts\n * const AddressType = new GraphQLObjectType({\n * name: 'Address',\n * fields: {\n * street: { type: GraphQLString },\n * number: { type: GraphQLInt },\n * formatted: {\n * type: GraphQLString,\n * resolve(obj) {\n * return obj.number + ' ' + obj.street\n * }\n * }\n * }\n * });\n * ```\n *\n * When two types need to refer to each other, or a type needs to refer to\n * itself in a field, you can use a function expression (aka a closure or a\n * thunk) to supply the fields lazily.\n *\n * Example:\n *\n * ```ts\n * const PersonType = new GraphQLObjectType({\n * name: 'Person',\n * fields: () => ({\n * name: { type: GraphQLString },\n * bestFriend: { type: PersonType },\n * })\n * });\n * ```\n */\nexport class GraphQLObjectType {\n constructor(config) {\n var _config$extensionASTN2;\n\n this.name = assertName(config.name);\n this.description = config.description;\n this.isTypeOf = config.isTypeOf;\n this.extensions = toObjMap(config.extensions);\n this.astNode = config.astNode;\n this.extensionASTNodes =\n (_config$extensionASTN2 = config.extensionASTNodes) !== null &&\n _config$extensionASTN2 !== void 0\n ? _config$extensionASTN2\n : [];\n\n this._fields = () => defineFieldMap(config);\n\n this._interfaces = () => defineInterfaces(config);\n\n config.isTypeOf == null ||\n typeof config.isTypeOf === 'function' ||\n devAssert(\n false,\n `${this.name} must provide \"isTypeOf\" as a function, ` +\n `but got: ${inspect(config.isTypeOf)}.`,\n );\n }\n\n get [Symbol.toStringTag]() {\n return 'GraphQLObjectType';\n }\n\n getFields() {\n if (typeof this._fields === 'function') {\n this._fields = this._fields();\n }\n\n return this._fields;\n }\n\n getInterfaces() {\n if (typeof this._interfaces === 'function') {\n this._interfaces = this._interfaces();\n }\n\n return this._interfaces;\n }\n\n toConfig() {\n return {\n name: this.name,\n description: this.description,\n interfaces: this.getInterfaces(),\n fields: fieldsToFieldsConfig(this.getFields()),\n isTypeOf: this.isTypeOf,\n extensions: this.extensions,\n astNode: this.astNode,\n extensionASTNodes: this.extensionASTNodes,\n };\n }\n\n toString() {\n return this.name;\n }\n\n toJSON() {\n return this.toString();\n }\n}\n\nfunction defineInterfaces(config) {\n var _config$interfaces;\n\n const interfaces = resolveReadonlyArrayThunk(\n (_config$interfaces = config.interfaces) !== null &&\n _config$interfaces !== void 0\n ? _config$interfaces\n : [],\n );\n Array.isArray(interfaces) ||\n devAssert(\n false,\n `${config.name} interfaces must be an Array or a function which returns an Array.`,\n );\n return interfaces;\n}\n\nfunction defineFieldMap(config) {\n const fieldMap = resolveObjMapThunk(config.fields);\n isPlainObj(fieldMap) ||\n devAssert(\n false,\n `${config.name} fields must be an object with field names as keys or a function which returns such an object.`,\n );\n return mapValue(fieldMap, (fieldConfig, fieldName) => {\n var _fieldConfig$args;\n\n isPlainObj(fieldConfig) ||\n devAssert(\n false,\n `${config.name}.${fieldName} field config must be an object.`,\n );\n fieldConfig.resolve == null ||\n typeof fieldConfig.resolve === 'function' ||\n devAssert(\n false,\n `${config.name}.${fieldName} field resolver must be a function if ` +\n `provided, but got: ${inspect(fieldConfig.resolve)}.`,\n );\n const argsConfig =\n (_fieldConfig$args = fieldConfig.args) !== null &&\n _fieldConfig$args !== void 0\n ? _fieldConfig$args\n : {};\n isPlainObj(argsConfig) ||\n devAssert(\n false,\n `${config.name}.${fieldName} args must be an object with argument names as keys.`,\n );\n return {\n name: assertName(fieldName),\n description: fieldConfig.description,\n type: fieldConfig.type,\n args: defineArguments(argsConfig),\n resolve: fieldConfig.resolve,\n subscribe: fieldConfig.subscribe,\n deprecationReason: fieldConfig.deprecationReason,\n extensions: toObjMap(fieldConfig.extensions),\n astNode: fieldConfig.astNode,\n };\n });\n}\n\nexport function defineArguments(config) {\n return Object.entries(config).map(([argName, argConfig]) => ({\n name: assertName(argName),\n description: argConfig.description,\n type: argConfig.type,\n defaultValue: argConfig.defaultValue,\n deprecationReason: argConfig.deprecationReason,\n extensions: toObjMap(argConfig.extensions),\n astNode: argConfig.astNode,\n }));\n}\n\nfunction isPlainObj(obj) {\n return isObjectLike(obj) && !Array.isArray(obj);\n}\n\nfunction fieldsToFieldsConfig(fields) {\n return mapValue(fields, (field) => ({\n description: field.description,\n type: field.type,\n args: argsToArgsConfig(field.args),\n resolve: field.resolve,\n subscribe: field.subscribe,\n deprecationReason: field.deprecationReason,\n extensions: field.extensions,\n astNode: field.astNode,\n }));\n}\n/**\n * @internal\n */\n\nexport function argsToArgsConfig(args) {\n return keyValMap(\n args,\n (arg) => arg.name,\n (arg) => ({\n description: arg.description,\n type: arg.type,\n defaultValue: arg.defaultValue,\n deprecationReason: arg.deprecationReason,\n extensions: arg.extensions,\n astNode: arg.astNode,\n }),\n );\n}\nexport function isRequiredArgument(arg) {\n return isNonNullType(arg.type) && arg.defaultValue === undefined;\n}\n\n/**\n * Interface Type Definition\n *\n * When a field can return one of a heterogeneous set of types, a Interface type\n * is used to describe what types are possible, what fields are in common across\n * all types, as well as a function to determine which type is actually used\n * when the field is resolved.\n *\n * Example:\n *\n * ```ts\n * const EntityType = new GraphQLInterfaceType({\n * name: 'Entity',\n * fields: {\n * name: { type: GraphQLString }\n * }\n * });\n * ```\n */\nexport class GraphQLInterfaceType {\n constructor(config) {\n var _config$extensionASTN3;\n\n this.name = assertName(config.name);\n this.description = config.description;\n this.resolveType = config.resolveType;\n this.extensions = toObjMap(config.extensions);\n this.astNode = config.astNode;\n this.extensionASTNodes =\n (_config$extensionASTN3 = config.extensionASTNodes) !== null &&\n _config$extensionASTN3 !== void 0\n ? _config$extensionASTN3\n : [];\n this._fields = defineFieldMap.bind(undefined, config);\n this._interfaces = defineInterfaces.bind(undefined, config);\n config.resolveType == null ||\n typeof config.resolveType === 'function' ||\n devAssert(\n false,\n `${this.name} must provide \"resolveType\" as a function, ` +\n `but got: ${inspect(config.resolveType)}.`,\n );\n }\n\n get [Symbol.toStringTag]() {\n return 'GraphQLInterfaceType';\n }\n\n getFields() {\n if (typeof this._fields === 'function') {\n this._fields = this._fields();\n }\n\n return this._fields;\n }\n\n getInterfaces() {\n if (typeof this._interfaces === 'function') {\n this._interfaces = this._interfaces();\n }\n\n return this._interfaces;\n }\n\n toConfig() {\n return {\n name: this.name,\n description: this.description,\n interfaces: this.getInterfaces(),\n fields: fieldsToFieldsConfig(this.getFields()),\n resolveType: this.resolveType,\n extensions: this.extensions,\n astNode: this.astNode,\n extensionASTNodes: this.extensionASTNodes,\n };\n }\n\n toString() {\n return this.name;\n }\n\n toJSON() {\n return this.toString();\n }\n}\n\n/**\n * Union Type Definition\n *\n * When a field can return one of a heterogeneous set of types, a Union type\n * is used to describe what types are possible as well as providing a function\n * to determine which type is actually used when the field is resolved.\n *\n * Example:\n *\n * ```ts\n * const PetType = new GraphQLUnionType({\n * name: 'Pet',\n * types: [ DogType, CatType ],\n * resolveType(value) {\n * if (value instanceof Dog) {\n * return DogType;\n * }\n * if (value instanceof Cat) {\n * return CatType;\n * }\n * }\n * });\n * ```\n */\nexport class GraphQLUnionType {\n constructor(config) {\n var _config$extensionASTN4;\n\n this.name = assertName(config.name);\n this.description = config.description;\n this.resolveType = config.resolveType;\n this.extensions = toObjMap(config.extensions);\n this.astNode = config.astNode;\n this.extensionASTNodes =\n (_config$extensionASTN4 = config.extensionASTNodes) !== null &&\n _config$extensionASTN4 !== void 0\n ? _config$extensionASTN4\n : [];\n this._types = defineTypes.bind(undefined, config);\n config.resolveType == null ||\n typeof config.resolveType === 'function' ||\n devAssert(\n false,\n `${this.name} must provide \"resolveType\" as a function, ` +\n `but got: ${inspect(config.resolveType)}.`,\n );\n }\n\n get [Symbol.toStringTag]() {\n return 'GraphQLUnionType';\n }\n\n getTypes() {\n if (typeof this._types === 'function') {\n this._types = this._types();\n }\n\n return this._types;\n }\n\n toConfig() {\n return {\n name: this.name,\n description: this.description,\n types: this.getTypes(),\n resolveType: this.resolveType,\n extensions: this.extensions,\n astNode: this.astNode,\n extensionASTNodes: this.extensionASTNodes,\n };\n }\n\n toString() {\n return this.name;\n }\n\n toJSON() {\n return this.toString();\n }\n}\n\nfunction defineTypes(config) {\n const types = resolveReadonlyArrayThunk(config.types);\n Array.isArray(types) ||\n devAssert(\n false,\n `Must provide Array of types or a function which returns such an array for Union ${config.name}.`,\n );\n return types;\n}\n\n/**\n * Enum Type Definition\n *\n * Some leaf values of requests and input values are Enums. GraphQL serializes\n * Enum values as strings, however internally Enums can be represented by any\n * kind of type, often integers.\n *\n * Example:\n *\n * ```ts\n * const RGBType = new GraphQLEnumType({\n * name: 'RGB',\n * values: {\n * RED: { value: 0 },\n * GREEN: { value: 1 },\n * BLUE: { value: 2 }\n * }\n * });\n * ```\n *\n * Note: If a value is not provided in a definition, the name of the enum value\n * will be used as its internal value.\n */\nexport class GraphQLEnumType {\n /* */\n constructor(config) {\n var _config$extensionASTN5;\n\n this.name = assertName(config.name);\n this.description = config.description;\n this.extensions = toObjMap(config.extensions);\n this.astNode = config.astNode;\n this.extensionASTNodes =\n (_config$extensionASTN5 = config.extensionASTNodes) !== null &&\n _config$extensionASTN5 !== void 0\n ? _config$extensionASTN5\n : [];\n this._values = defineEnumValues(this.name, config.values);\n this._valueLookup = new Map(\n this._values.map((enumValue) => [enumValue.value, enumValue]),\n );\n this._nameLookup = keyMap(this._values, (value) => value.name);\n }\n\n get [Symbol.toStringTag]() {\n return 'GraphQLEnumType';\n }\n\n getValues() {\n return this._values;\n }\n\n getValue(name) {\n return this._nameLookup[name];\n }\n\n serialize(outputValue) {\n const enumValue = this._valueLookup.get(outputValue);\n\n if (enumValue === undefined) {\n throw new GraphQLError(\n `Enum \"${this.name}\" cannot represent value: ${inspect(outputValue)}`,\n );\n }\n\n return enumValue.name;\n }\n\n parseValue(inputValue) /* T */\n {\n if (typeof inputValue !== 'string') {\n const valueStr = inspect(inputValue);\n throw new GraphQLError(\n `Enum \"${this.name}\" cannot represent non-string value: ${valueStr}.` +\n didYouMeanEnumValue(this, valueStr),\n );\n }\n\n const enumValue = this.getValue(inputValue);\n\n if (enumValue == null) {\n throw new GraphQLError(\n `Value \"${inputValue}\" does not exist in \"${this.name}\" enum.` +\n didYouMeanEnumValue(this, inputValue),\n );\n }\n\n return enumValue.value;\n }\n\n parseLiteral(valueNode, _variables) /* T */\n {\n // Note: variables will be resolved to a value before calling this function.\n if (valueNode.kind !== Kind.ENUM) {\n const valueStr = print(valueNode);\n throw new GraphQLError(\n `Enum \"${this.name}\" cannot represent non-enum value: ${valueStr}.` +\n didYouMeanEnumValue(this, valueStr),\n {\n nodes: valueNode,\n },\n );\n }\n\n const enumValue = this.getValue(valueNode.value);\n\n if (enumValue == null) {\n const valueStr = print(valueNode);\n throw new GraphQLError(\n `Value \"${valueStr}\" does not exist in \"${this.name}\" enum.` +\n didYouMeanEnumValue(this, valueStr),\n {\n nodes: valueNode,\n },\n );\n }\n\n return enumValue.value;\n }\n\n toConfig() {\n const values = keyValMap(\n this.getValues(),\n (value) => value.name,\n (value) => ({\n description: value.description,\n value: value.value,\n deprecationReason: value.deprecationReason,\n extensions: value.extensions,\n astNode: value.astNode,\n }),\n );\n return {\n name: this.name,\n description: this.description,\n values,\n extensions: this.extensions,\n astNode: this.astNode,\n extensionASTNodes: this.extensionASTNodes,\n };\n }\n\n toString() {\n return this.name;\n }\n\n toJSON() {\n return this.toString();\n }\n}\n\nfunction didYouMeanEnumValue(enumType, unknownValueStr) {\n const allNames = enumType.getValues().map((value) => value.name);\n const suggestedValues = suggestionList(unknownValueStr, allNames);\n return didYouMean('the enum value', suggestedValues);\n}\n\nfunction defineEnumValues(typeName, valueMap) {\n isPlainObj(valueMap) ||\n devAssert(\n false,\n `${typeName} values must be an object with value names as keys.`,\n );\n return Object.entries(valueMap).map(([valueName, valueConfig]) => {\n isPlainObj(valueConfig) ||\n devAssert(\n false,\n `${typeName}.${valueName} must refer to an object with a \"value\" key ` +\n `representing an internal value but got: ${inspect(valueConfig)}.`,\n );\n return {\n name: assertEnumValueName(valueName),\n description: valueConfig.description,\n value: valueConfig.value !== undefined ? valueConfig.value : valueName,\n deprecationReason: valueConfig.deprecationReason,\n extensions: toObjMap(valueConfig.extensions),\n astNode: valueConfig.astNode,\n };\n });\n}\n\n/**\n * Input Object Type Definition\n *\n * An input object defines a structured collection of fields which may be\n * supplied to a field argument.\n *\n * Using `NonNull` will ensure that a value must be provided by the query\n *\n * Example:\n *\n * ```ts\n * const GeoPoint = new GraphQLInputObjectType({\n * name: 'GeoPoint',\n * fields: {\n * lat: { type: new GraphQLNonNull(GraphQLFloat) },\n * lon: { type: new GraphQLNonNull(GraphQLFloat) },\n * alt: { type: GraphQLFloat, defaultValue: 0 },\n * }\n * });\n * ```\n */\nexport class GraphQLInputObjectType {\n constructor(config) {\n var _config$extensionASTN6;\n\n this.name = assertName(config.name);\n this.description = config.description;\n this.extensions = toObjMap(config.extensions);\n this.astNode = config.astNode;\n this.extensionASTNodes =\n (_config$extensionASTN6 = config.extensionASTNodes) !== null &&\n _config$extensionASTN6 !== void 0\n ? _config$extensionASTN6\n : [];\n this._fields = defineInputFieldMap.bind(undefined, config);\n }\n\n get [Symbol.toStringTag]() {\n return 'GraphQLInputObjectType';\n }\n\n getFields() {\n if (typeof this._fields === 'function') {\n this._fields = this._fields();\n }\n\n return this._fields;\n }\n\n toConfig() {\n const fields = mapValue(this.getFields(), (field) => ({\n description: field.description,\n type: field.type,\n defaultValue: field.defaultValue,\n deprecationReason: field.deprecationReason,\n extensions: field.extensions,\n astNode: field.astNode,\n }));\n return {\n name: this.name,\n description: this.description,\n fields,\n extensions: this.extensions,\n astNode: this.astNode,\n extensionASTNodes: this.extensionASTNodes,\n };\n }\n\n toString() {\n return this.name;\n }\n\n toJSON() {\n return this.toString();\n }\n}\n\nfunction defineInputFieldMap(config) {\n const fieldMap = resolveObjMapThunk(config.fields);\n isPlainObj(fieldMap) ||\n devAssert(\n false,\n `${config.name} fields must be an object with field names as keys or a function which returns such an object.`,\n );\n return mapValue(fieldMap, (fieldConfig, fieldName) => {\n !('resolve' in fieldConfig) ||\n devAssert(\n false,\n `${config.name}.${fieldName} field has a resolve property, but Input Types cannot define resolvers.`,\n );\n return {\n name: assertName(fieldName),\n description: fieldConfig.description,\n type: fieldConfig.type,\n defaultValue: fieldConfig.defaultValue,\n deprecationReason: fieldConfig.deprecationReason,\n extensions: toObjMap(fieldConfig.extensions),\n astNode: fieldConfig.astNode,\n };\n });\n}\n\nexport function isRequiredInputField(field) {\n return isNonNullType(field.type) && field.defaultValue === undefined;\n}\n","import {\n isAbstractType,\n isInterfaceType,\n isListType,\n isNonNullType,\n isObjectType,\n} from '../type/definition.mjs';\n\n/**\n * Provided two types, return true if the types are equal (invariant).\n */\nexport function isEqualType(typeA, typeB) {\n // Equivalent types are equal.\n if (typeA === typeB) {\n return true;\n } // If either type is non-null, the other must also be non-null.\n\n if (isNonNullType(typeA) && isNonNullType(typeB)) {\n return isEqualType(typeA.ofType, typeB.ofType);\n } // If either type is a list, the other must also be a list.\n\n if (isListType(typeA) && isListType(typeB)) {\n return isEqualType(typeA.ofType, typeB.ofType);\n } // Otherwise the types are not equal.\n\n return false;\n}\n/**\n * Provided a type and a super type, return true if the first type is either\n * equal or a subset of the second super type (covariant).\n */\n\nexport function isTypeSubTypeOf(schema, maybeSubType, superType) {\n // Equivalent type is a valid subtype\n if (maybeSubType === superType) {\n return true;\n } // If superType is non-null, maybeSubType must also be non-null.\n\n if (isNonNullType(superType)) {\n if (isNonNullType(maybeSubType)) {\n return isTypeSubTypeOf(schema, maybeSubType.ofType, superType.ofType);\n }\n\n return false;\n }\n\n if (isNonNullType(maybeSubType)) {\n // If superType is nullable, maybeSubType may be non-null or nullable.\n return isTypeSubTypeOf(schema, maybeSubType.ofType, superType);\n } // If superType type is a list, maybeSubType type must also be a list.\n\n if (isListType(superType)) {\n if (isListType(maybeSubType)) {\n return isTypeSubTypeOf(schema, maybeSubType.ofType, superType.ofType);\n }\n\n return false;\n }\n\n if (isListType(maybeSubType)) {\n // If superType is not a list, maybeSubType must also be not a list.\n return false;\n } // If superType type is an abstract type, check if it is super type of maybeSubType.\n // Otherwise, the child type is not a valid subtype of the parent type.\n\n return (\n isAbstractType(superType) &&\n (isInterfaceType(maybeSubType) || isObjectType(maybeSubType)) &&\n schema.isSubType(superType, maybeSubType)\n );\n}\n/**\n * Provided two composite types, determine if they \"overlap\". Two composite\n * types overlap when the Sets of possible concrete types for each intersect.\n *\n * This is often used to determine if a fragment of a given type could possibly\n * be visited in a context of another type.\n *\n * This function is commutative.\n */\n\nexport function doTypesOverlap(schema, typeA, typeB) {\n // Equivalent types overlap\n if (typeA === typeB) {\n return true;\n }\n\n if (isAbstractType(typeA)) {\n if (isAbstractType(typeB)) {\n // If both types are abstract, then determine if there is any intersection\n // between possible concrete types of each.\n return schema\n .getPossibleTypes(typeA)\n .some((type) => schema.isSubType(typeB, type));\n } // Determine if the latter type is a possible concrete type of the former.\n\n return schema.isSubType(typeA, typeB);\n }\n\n if (isAbstractType(typeB)) {\n // Determine if the former type is a possible concrete type of the latter.\n return schema.isSubType(typeB, typeA);\n } // Otherwise the types do not overlap.\n\n return false;\n}\n","import { inspect } from '../jsutils/inspect.mjs';\nimport { isObjectLike } from '../jsutils/isObjectLike.mjs';\nimport { GraphQLError } from '../error/GraphQLError.mjs';\nimport { Kind } from '../language/kinds.mjs';\nimport { print } from '../language/printer.mjs';\nimport { GraphQLScalarType } from './definition.mjs';\n/**\n * Maximum possible Int value as per GraphQL Spec (32-bit signed integer).\n * n.b. This differs from JavaScript's numbers that are IEEE 754 doubles safe up-to 2^53 - 1\n * */\n\nexport const GRAPHQL_MAX_INT = 2147483647;\n/**\n * Minimum possible Int value as per GraphQL Spec (32-bit signed integer).\n * n.b. This differs from JavaScript's numbers that are IEEE 754 doubles safe starting at -(2^53 - 1)\n * */\n\nexport const GRAPHQL_MIN_INT = -2147483648;\nexport const GraphQLInt = new GraphQLScalarType({\n name: 'Int',\n description:\n 'The `Int` scalar type represents non-fractional signed whole numeric values. Int can represent values between -(2^31) and 2^31 - 1.',\n\n serialize(outputValue) {\n const coercedValue = serializeObject(outputValue);\n\n if (typeof coercedValue === 'boolean') {\n return coercedValue ? 1 : 0;\n }\n\n let num = coercedValue;\n\n if (typeof coercedValue === 'string' && coercedValue !== '') {\n num = Number(coercedValue);\n }\n\n if (typeof num !== 'number' || !Number.isInteger(num)) {\n throw new GraphQLError(\n `Int cannot represent non-integer value: ${inspect(coercedValue)}`,\n );\n }\n\n if (num > GRAPHQL_MAX_INT || num < GRAPHQL_MIN_INT) {\n throw new GraphQLError(\n 'Int cannot represent non 32-bit signed integer value: ' +\n inspect(coercedValue),\n );\n }\n\n return num;\n },\n\n parseValue(inputValue) {\n if (typeof inputValue !== 'number' || !Number.isInteger(inputValue)) {\n throw new GraphQLError(\n `Int cannot represent non-integer value: ${inspect(inputValue)}`,\n );\n }\n\n if (inputValue > GRAPHQL_MAX_INT || inputValue < GRAPHQL_MIN_INT) {\n throw new GraphQLError(\n `Int cannot represent non 32-bit signed integer value: ${inputValue}`,\n );\n }\n\n return inputValue;\n },\n\n parseLiteral(valueNode) {\n if (valueNode.kind !== Kind.INT) {\n throw new GraphQLError(\n `Int cannot represent non-integer value: ${print(valueNode)}`,\n {\n nodes: valueNode,\n },\n );\n }\n\n const num = parseInt(valueNode.value, 10);\n\n if (num > GRAPHQL_MAX_INT || num < GRAPHQL_MIN_INT) {\n throw new GraphQLError(\n `Int cannot represent non 32-bit signed integer value: ${valueNode.value}`,\n {\n nodes: valueNode,\n },\n );\n }\n\n return num;\n },\n});\nexport const GraphQLFloat = new GraphQLScalarType({\n name: 'Float',\n description:\n 'The `Float` scalar type represents signed double-precision fractional values as specified by [IEEE 754](https://en.wikipedia.org/wiki/IEEE_floating_point).',\n\n serialize(outputValue) {\n const coercedValue = serializeObject(outputValue);\n\n if (typeof coercedValue === 'boolean') {\n return coercedValue ? 1 : 0;\n }\n\n let num = coercedValue;\n\n if (typeof coercedValue === 'string' && coercedValue !== '') {\n num = Number(coercedValue);\n }\n\n if (typeof num !== 'number' || !Number.isFinite(num)) {\n throw new GraphQLError(\n `Float cannot represent non numeric value: ${inspect(coercedValue)}`,\n );\n }\n\n return num;\n },\n\n parseValue(inputValue) {\n if (typeof inputValue !== 'number' || !Number.isFinite(inputValue)) {\n throw new GraphQLError(\n `Float cannot represent non numeric value: ${inspect(inputValue)}`,\n );\n }\n\n return inputValue;\n },\n\n parseLiteral(valueNode) {\n if (valueNode.kind !== Kind.FLOAT && valueNode.kind !== Kind.INT) {\n throw new GraphQLError(\n `Float cannot represent non numeric value: ${print(valueNode)}`,\n valueNode,\n );\n }\n\n return parseFloat(valueNode.value);\n },\n});\nexport const GraphQLString = new GraphQLScalarType({\n name: 'String',\n description:\n 'The `String` scalar type represents textual data, represented as UTF-8 character sequences. The String type is most often used by GraphQL to represent free-form human-readable text.',\n\n serialize(outputValue) {\n const coercedValue = serializeObject(outputValue); // Serialize string, boolean and number values to a string, but do not\n // attempt to coerce object, function, symbol, or other types as strings.\n\n if (typeof coercedValue === 'string') {\n return coercedValue;\n }\n\n if (typeof coercedValue === 'boolean') {\n return coercedValue ? 'true' : 'false';\n }\n\n if (typeof coercedValue === 'number' && Number.isFinite(coercedValue)) {\n return coercedValue.toString();\n }\n\n throw new GraphQLError(\n `String cannot represent value: ${inspect(outputValue)}`,\n );\n },\n\n parseValue(inputValue) {\n if (typeof inputValue !== 'string') {\n throw new GraphQLError(\n `String cannot represent a non string value: ${inspect(inputValue)}`,\n );\n }\n\n return inputValue;\n },\n\n parseLiteral(valueNode) {\n if (valueNode.kind !== Kind.STRING) {\n throw new GraphQLError(\n `String cannot represent a non string value: ${print(valueNode)}`,\n {\n nodes: valueNode,\n },\n );\n }\n\n return valueNode.value;\n },\n});\nexport const GraphQLBoolean = new GraphQLScalarType({\n name: 'Boolean',\n description: 'The `Boolean` scalar type represents `true` or `false`.',\n\n serialize(outputValue) {\n const coercedValue = serializeObject(outputValue);\n\n if (typeof coercedValue === 'boolean') {\n return coercedValue;\n }\n\n if (Number.isFinite(coercedValue)) {\n return coercedValue !== 0;\n }\n\n throw new GraphQLError(\n `Boolean cannot represent a non boolean value: ${inspect(coercedValue)}`,\n );\n },\n\n parseValue(inputValue) {\n if (typeof inputValue !== 'boolean') {\n throw new GraphQLError(\n `Boolean cannot represent a non boolean value: ${inspect(inputValue)}`,\n );\n }\n\n return inputValue;\n },\n\n parseLiteral(valueNode) {\n if (valueNode.kind !== Kind.BOOLEAN) {\n throw new GraphQLError(\n `Boolean cannot represent a non boolean value: ${print(valueNode)}`,\n {\n nodes: valueNode,\n },\n );\n }\n\n return valueNode.value;\n },\n});\nexport const GraphQLID = new GraphQLScalarType({\n name: 'ID',\n description:\n 'The `ID` scalar type represents a unique identifier, often used to refetch an object or as key for a cache. The ID type appears in a JSON response as a String; however, it is not intended to be human-readable. When expected as an input type, any string (such as `\"4\"`) or integer (such as `4`) input value will be accepted as an ID.',\n\n serialize(outputValue) {\n const coercedValue = serializeObject(outputValue);\n\n if (typeof coercedValue === 'string') {\n return coercedValue;\n }\n\n if (Number.isInteger(coercedValue)) {\n return String(coercedValue);\n }\n\n throw new GraphQLError(\n `ID cannot represent value: ${inspect(outputValue)}`,\n );\n },\n\n parseValue(inputValue) {\n if (typeof inputValue === 'string') {\n return inputValue;\n }\n\n if (typeof inputValue === 'number' && Number.isInteger(inputValue)) {\n return inputValue.toString();\n }\n\n throw new GraphQLError(`ID cannot represent value: ${inspect(inputValue)}`);\n },\n\n parseLiteral(valueNode) {\n if (valueNode.kind !== Kind.STRING && valueNode.kind !== Kind.INT) {\n throw new GraphQLError(\n 'ID cannot represent a non-string and non-integer value: ' +\n print(valueNode),\n {\n nodes: valueNode,\n },\n );\n }\n\n return valueNode.value;\n },\n});\nexport const specifiedScalarTypes = Object.freeze([\n GraphQLString,\n GraphQLInt,\n GraphQLFloat,\n GraphQLBoolean,\n GraphQLID,\n]);\nexport function isSpecifiedScalarType(type) {\n return specifiedScalarTypes.some(({ name }) => type.name === name);\n} // Support serializing objects with custom valueOf() or toJSON() functions -\n// a common way to represent a complex value which can be represented as\n// a string (ex: MongoDB id objects).\n\nfunction serializeObject(outputValue) {\n if (isObjectLike(outputValue)) {\n if (typeof outputValue.valueOf === 'function') {\n const valueOfResult = outputValue.valueOf();\n\n if (!isObjectLike(valueOfResult)) {\n return valueOfResult;\n }\n }\n\n if (typeof outputValue.toJSON === 'function') {\n return outputValue.toJSON();\n }\n }\n\n return outputValue;\n}\n","import { devAssert } from '../jsutils/devAssert.mjs';\nimport { inspect } from '../jsutils/inspect.mjs';\nimport { instanceOf } from '../jsutils/instanceOf.mjs';\nimport { isObjectLike } from '../jsutils/isObjectLike.mjs';\nimport { toObjMap } from '../jsutils/toObjMap.mjs';\nimport { DirectiveLocation } from '../language/directiveLocation.mjs';\nimport { assertName } from './assertName.mjs';\nimport {\n argsToArgsConfig,\n defineArguments,\n GraphQLNonNull,\n} from './definition.mjs';\nimport { GraphQLBoolean, GraphQLString } from './scalars.mjs';\n/**\n * Test if the given value is a GraphQL directive.\n */\n\nexport function isDirective(directive) {\n return instanceOf(directive, GraphQLDirective);\n}\nexport function assertDirective(directive) {\n if (!isDirective(directive)) {\n throw new Error(\n `Expected ${inspect(directive)} to be a GraphQL directive.`,\n );\n }\n\n return directive;\n}\n/**\n * Custom extensions\n *\n * @remarks\n * Use a unique identifier name for your extension, for example the name of\n * your library or project. Do not use a shortened identifier as this increases\n * the risk of conflicts. We recommend you add at most one extension field,\n * an object which can contain all the values you need.\n */\n\n/**\n * Directives are used by the GraphQL runtime as a way of modifying execution\n * behavior. Type system creators will usually not create these directly.\n */\nexport class GraphQLDirective {\n constructor(config) {\n var _config$isRepeatable, _config$args;\n\n this.name = assertName(config.name);\n this.description = config.description;\n this.locations = config.locations;\n this.isRepeatable =\n (_config$isRepeatable = config.isRepeatable) !== null &&\n _config$isRepeatable !== void 0\n ? _config$isRepeatable\n : false;\n this.extensions = toObjMap(config.extensions);\n this.astNode = config.astNode;\n Array.isArray(config.locations) ||\n devAssert(false, `@${config.name} locations must be an Array.`);\n const args =\n (_config$args = config.args) !== null && _config$args !== void 0\n ? _config$args\n : {};\n (isObjectLike(args) && !Array.isArray(args)) ||\n devAssert(\n false,\n `@${config.name} args must be an object with argument names as keys.`,\n );\n this.args = defineArguments(args);\n }\n\n get [Symbol.toStringTag]() {\n return 'GraphQLDirective';\n }\n\n toConfig() {\n return {\n name: this.name,\n description: this.description,\n locations: this.locations,\n args: argsToArgsConfig(this.args),\n isRepeatable: this.isRepeatable,\n extensions: this.extensions,\n astNode: this.astNode,\n };\n }\n\n toString() {\n return '@' + this.name;\n }\n\n toJSON() {\n return this.toString();\n }\n}\n\n/**\n * Used to conditionally include fields or fragments.\n */\nexport const GraphQLIncludeDirective = new GraphQLDirective({\n name: 'include',\n description:\n 'Directs the executor to include this field or fragment only when the `if` argument is true.',\n locations: [\n DirectiveLocation.FIELD,\n DirectiveLocation.FRAGMENT_SPREAD,\n DirectiveLocation.INLINE_FRAGMENT,\n ],\n args: {\n if: {\n type: new GraphQLNonNull(GraphQLBoolean),\n description: 'Included when true.',\n },\n },\n});\n/**\n * Used to conditionally skip (exclude) fields or fragments.\n */\n\nexport const GraphQLSkipDirective = new GraphQLDirective({\n name: 'skip',\n description:\n 'Directs the executor to skip this field or fragment when the `if` argument is true.',\n locations: [\n DirectiveLocation.FIELD,\n DirectiveLocation.FRAGMENT_SPREAD,\n DirectiveLocation.INLINE_FRAGMENT,\n ],\n args: {\n if: {\n type: new GraphQLNonNull(GraphQLBoolean),\n description: 'Skipped when true.',\n },\n },\n});\n/**\n * Constant string used for default reason for a deprecation.\n */\n\nexport const DEFAULT_DEPRECATION_REASON = 'No longer supported';\n/**\n * Used to declare element of a GraphQL schema as deprecated.\n */\n\nexport const GraphQLDeprecatedDirective = new GraphQLDirective({\n name: 'deprecated',\n description: 'Marks an element of a GraphQL schema as no longer supported.',\n locations: [\n DirectiveLocation.FIELD_DEFINITION,\n DirectiveLocation.ARGUMENT_DEFINITION,\n DirectiveLocation.INPUT_FIELD_DEFINITION,\n DirectiveLocation.ENUM_VALUE,\n ],\n args: {\n reason: {\n type: GraphQLString,\n description:\n 'Explains why this element was deprecated, usually also including a suggestion for how to access supported similar data. Formatted using the Markdown syntax, as specified by [CommonMark](https://commonmark.org/).',\n defaultValue: DEFAULT_DEPRECATION_REASON,\n },\n },\n});\n/**\n * Used to provide a URL for specifying the behavior of custom scalar definitions.\n */\n\nexport const GraphQLSpecifiedByDirective = new GraphQLDirective({\n name: 'specifiedBy',\n description: 'Exposes a URL that specifies the behavior of this scalar.',\n locations: [DirectiveLocation.SCALAR],\n args: {\n url: {\n type: new GraphQLNonNull(GraphQLString),\n description: 'The URL that specifies the behavior of this scalar.',\n },\n },\n});\n/**\n * The full list of specified directives.\n */\n\nexport const specifiedDirectives = Object.freeze([\n GraphQLIncludeDirective,\n GraphQLSkipDirective,\n GraphQLDeprecatedDirective,\n GraphQLSpecifiedByDirective,\n]);\nexport function isSpecifiedDirective(directive) {\n return specifiedDirectives.some(({ name }) => name === directive.name);\n}\n","/**\n * Returns true if the provided object is an Object (i.e. not a string literal)\n * and implements the Iterator protocol.\n *\n * This may be used in place of [Array.isArray()][isArray] to determine if\n * an object should be iterated-over e.g. Array, Map, Set, Int8Array,\n * TypedArray, etc. but excludes string literals.\n *\n * @example\n * ```ts\n * isIterableObject([ 1, 2, 3 ]) // true\n * isIterableObject(new Map()) // true\n * isIterableObject('ABC') // false\n * isIterableObject({ key: 'value' }) // false\n * isIterableObject({ length: 1, 0: 'Alpha' }) // false\n * ```\n */\nexport function isIterableObject(maybeIterable) {\n return (\n typeof maybeIterable === 'object' &&\n typeof (maybeIterable === null || maybeIterable === void 0\n ? void 0\n : maybeIterable[Symbol.iterator]) === 'function'\n );\n}\n","import { inspect } from '../jsutils/inspect.mjs';\nimport { invariant } from '../jsutils/invariant.mjs';\nimport { isIterableObject } from '../jsutils/isIterableObject.mjs';\nimport { isObjectLike } from '../jsutils/isObjectLike.mjs';\nimport { Kind } from '../language/kinds.mjs';\nimport {\n isEnumType,\n isInputObjectType,\n isLeafType,\n isListType,\n isNonNullType,\n} from '../type/definition.mjs';\nimport { GraphQLID } from '../type/scalars.mjs';\n/**\n * Produces a GraphQL Value AST given a JavaScript object.\n * Function will match JavaScript/JSON values to GraphQL AST schema format\n * by using suggested GraphQLInputType. For example:\n *\n * astFromValue(\"value\", GraphQLString)\n *\n * A GraphQL type must be provided, which will be used to interpret different\n * JavaScript values.\n *\n * | JSON Value | GraphQL Value |\n * | ------------- | -------------------- |\n * | Object | Input Object |\n * | Array | List |\n * | Boolean | Boolean |\n * | String | String / Enum Value |\n * | Number | Int / Float |\n * | Unknown | Enum Value |\n * | null | NullValue |\n *\n */\n\nexport function astFromValue(value, type) {\n if (isNonNullType(type)) {\n const astValue = astFromValue(value, type.ofType);\n\n if (\n (astValue === null || astValue === void 0 ? void 0 : astValue.kind) ===\n Kind.NULL\n ) {\n return null;\n }\n\n return astValue;\n } // only explicit null, not undefined, NaN\n\n if (value === null) {\n return {\n kind: Kind.NULL,\n };\n } // undefined\n\n if (value === undefined) {\n return null;\n } // Convert JavaScript array to GraphQL list. If the GraphQLType is a list, but\n // the value is not an array, convert the value using the list's item type.\n\n if (isListType(type)) {\n const itemType = type.ofType;\n\n if (isIterableObject(value)) {\n const valuesNodes = [];\n\n for (const item of value) {\n const itemNode = astFromValue(item, itemType);\n\n if (itemNode != null) {\n valuesNodes.push(itemNode);\n }\n }\n\n return {\n kind: Kind.LIST,\n values: valuesNodes,\n };\n }\n\n return astFromValue(value, itemType);\n } // Populate the fields of the input object by creating ASTs from each value\n // in the JavaScript object according to the fields in the input type.\n\n if (isInputObjectType(type)) {\n if (!isObjectLike(value)) {\n return null;\n }\n\n const fieldNodes = [];\n\n for (const field of Object.values(type.getFields())) {\n const fieldValue = astFromValue(value[field.name], field.type);\n\n if (fieldValue) {\n fieldNodes.push({\n kind: Kind.OBJECT_FIELD,\n name: {\n kind: Kind.NAME,\n value: field.name,\n },\n value: fieldValue,\n });\n }\n }\n\n return {\n kind: Kind.OBJECT,\n fields: fieldNodes,\n };\n }\n\n if (isLeafType(type)) {\n // Since value is an internally represented value, it must be serialized\n // to an externally represented value before converting into an AST.\n const serialized = type.serialize(value);\n\n if (serialized == null) {\n return null;\n } // Others serialize based on their corresponding JavaScript scalar types.\n\n if (typeof serialized === 'boolean') {\n return {\n kind: Kind.BOOLEAN,\n value: serialized,\n };\n } // JavaScript numbers can be Int or Float values.\n\n if (typeof serialized === 'number' && Number.isFinite(serialized)) {\n const stringNum = String(serialized);\n return integerStringRegExp.test(stringNum)\n ? {\n kind: Kind.INT,\n value: stringNum,\n }\n : {\n kind: Kind.FLOAT,\n value: stringNum,\n };\n }\n\n if (typeof serialized === 'string') {\n // Enum types use Enum literals.\n if (isEnumType(type)) {\n return {\n kind: Kind.ENUM,\n value: serialized,\n };\n } // ID types can use Int literals.\n\n if (type === GraphQLID && integerStringRegExp.test(serialized)) {\n return {\n kind: Kind.INT,\n value: serialized,\n };\n }\n\n return {\n kind: Kind.STRING,\n value: serialized,\n };\n }\n\n throw new TypeError(`Cannot convert value to AST: ${inspect(serialized)}.`);\n }\n /* c8 ignore next 3 */\n // Not reachable, all possible types have been considered.\n\n false || invariant(false, 'Unexpected input type: ' + inspect(type));\n}\n/**\n * IntValue:\n * - NegativeSign? 0\n * - NegativeSign? NonZeroDigit ( Digit+ )?\n */\n\nconst integerStringRegExp = /^-?(?:0|[1-9][0-9]*)$/;\n","import { inspect } from '../jsutils/inspect.mjs';\nimport { invariant } from '../jsutils/invariant.mjs';\nimport { DirectiveLocation } from '../language/directiveLocation.mjs';\nimport { print } from '../language/printer.mjs';\nimport { astFromValue } from '../utilities/astFromValue.mjs';\nimport {\n GraphQLEnumType,\n GraphQLList,\n GraphQLNonNull,\n GraphQLObjectType,\n isAbstractType,\n isEnumType,\n isInputObjectType,\n isInterfaceType,\n isListType,\n isNonNullType,\n isObjectType,\n isScalarType,\n isUnionType,\n} from './definition.mjs';\nimport { GraphQLBoolean, GraphQLString } from './scalars.mjs';\nexport const __Schema = new GraphQLObjectType({\n name: '__Schema',\n description:\n 'A GraphQL Schema defines the capabilities of a GraphQL server. It exposes all available types and directives on the server, as well as the entry points for query, mutation, and subscription operations.',\n fields: () => ({\n description: {\n type: GraphQLString,\n resolve: (schema) => schema.description,\n },\n types: {\n description: 'A list of all types supported by this server.',\n type: new GraphQLNonNull(new GraphQLList(new GraphQLNonNull(__Type))),\n\n resolve(schema) {\n return Object.values(schema.getTypeMap());\n },\n },\n queryType: {\n description: 'The type that query operations will be rooted at.',\n type: new GraphQLNonNull(__Type),\n resolve: (schema) => schema.getQueryType(),\n },\n mutationType: {\n description:\n 'If this server supports mutation, the type that mutation operations will be rooted at.',\n type: __Type,\n resolve: (schema) => schema.getMutationType(),\n },\n subscriptionType: {\n description:\n 'If this server support subscription, the type that subscription operations will be rooted at.',\n type: __Type,\n resolve: (schema) => schema.getSubscriptionType(),\n },\n directives: {\n description: 'A list of all directives supported by this server.',\n type: new GraphQLNonNull(\n new GraphQLList(new GraphQLNonNull(__Directive)),\n ),\n resolve: (schema) => schema.getDirectives(),\n },\n }),\n});\nexport const __Directive = new GraphQLObjectType({\n name: '__Directive',\n description:\n \"A Directive provides a way to describe alternate runtime execution and type validation behavior in a GraphQL document.\\n\\nIn some cases, you need to provide options to alter GraphQL's execution behavior in ways field arguments will not suffice, such as conditionally including or skipping a field. Directives provide this by describing additional information to the executor.\",\n fields: () => ({\n name: {\n type: new GraphQLNonNull(GraphQLString),\n resolve: (directive) => directive.name,\n },\n description: {\n type: GraphQLString,\n resolve: (directive) => directive.description,\n },\n isRepeatable: {\n type: new GraphQLNonNull(GraphQLBoolean),\n resolve: (directive) => directive.isRepeatable,\n },\n locations: {\n type: new GraphQLNonNull(\n new GraphQLList(new GraphQLNonNull(__DirectiveLocation)),\n ),\n resolve: (directive) => directive.locations,\n },\n args: {\n type: new GraphQLNonNull(\n new GraphQLList(new GraphQLNonNull(__InputValue)),\n ),\n args: {\n includeDeprecated: {\n type: GraphQLBoolean,\n defaultValue: false,\n },\n },\n\n resolve(field, { includeDeprecated }) {\n return includeDeprecated\n ? field.args\n : field.args.filter((arg) => arg.deprecationReason == null);\n },\n },\n }),\n});\nexport const __DirectiveLocation = new GraphQLEnumType({\n name: '__DirectiveLocation',\n description:\n 'A Directive can be adjacent to many parts of the GraphQL language, a __DirectiveLocation describes one such possible adjacencies.',\n values: {\n QUERY: {\n value: DirectiveLocation.QUERY,\n description: 'Location adjacent to a query operation.',\n },\n MUTATION: {\n value: DirectiveLocation.MUTATION,\n description: 'Location adjacent to a mutation operation.',\n },\n SUBSCRIPTION: {\n value: DirectiveLocation.SUBSCRIPTION,\n description: 'Location adjacent to a subscription operation.',\n },\n FIELD: {\n value: DirectiveLocation.FIELD,\n description: 'Location adjacent to a field.',\n },\n FRAGMENT_DEFINITION: {\n value: DirectiveLocation.FRAGMENT_DEFINITION,\n description: 'Location adjacent to a fragment definition.',\n },\n FRAGMENT_SPREAD: {\n value: DirectiveLocation.FRAGMENT_SPREAD,\n description: 'Location adjacent to a fragment spread.',\n },\n INLINE_FRAGMENT: {\n value: DirectiveLocation.INLINE_FRAGMENT,\n description: 'Location adjacent to an inline fragment.',\n },\n VARIABLE_DEFINITION: {\n value: DirectiveLocation.VARIABLE_DEFINITION,\n description: 'Location adjacent to a variable definition.',\n },\n SCHEMA: {\n value: DirectiveLocation.SCHEMA,\n description: 'Location adjacent to a schema definition.',\n },\n SCALAR: {\n value: DirectiveLocation.SCALAR,\n description: 'Location adjacent to a scalar definition.',\n },\n OBJECT: {\n value: DirectiveLocation.OBJECT,\n description: 'Location adjacent to an object type definition.',\n },\n FIELD_DEFINITION: {\n value: DirectiveLocation.FIELD_DEFINITION,\n description: 'Location adjacent to a field definition.',\n },\n ARGUMENT_DEFINITION: {\n value: DirectiveLocation.ARGUMENT_DEFINITION,\n description: 'Location adjacent to an argument definition.',\n },\n INTERFACE: {\n value: DirectiveLocation.INTERFACE,\n description: 'Location adjacent to an interface definition.',\n },\n UNION: {\n value: DirectiveLocation.UNION,\n description: 'Location adjacent to a union definition.',\n },\n ENUM: {\n value: DirectiveLocation.ENUM,\n description: 'Location adjacent to an enum definition.',\n },\n ENUM_VALUE: {\n value: DirectiveLocation.ENUM_VALUE,\n description: 'Location adjacent to an enum value definition.',\n },\n INPUT_OBJECT: {\n value: DirectiveLocation.INPUT_OBJECT,\n description: 'Location adjacent to an input object type definition.',\n },\n INPUT_FIELD_DEFINITION: {\n value: DirectiveLocation.INPUT_FIELD_DEFINITION,\n description: 'Location adjacent to an input object field definition.',\n },\n },\n});\nexport const __Type = new GraphQLObjectType({\n name: '__Type',\n description:\n 'The fundamental unit of any GraphQL Schema is the type. There are many kinds of types in GraphQL as represented by the `__TypeKind` enum.\\n\\nDepending on the kind of a type, certain fields describe information about that type. Scalar types provide no information beyond a name, description and optional `specifiedByURL`, while Enum types provide their values. Object and Interface types provide the fields they describe. Abstract types, Union and Interface, provide the Object types possible at runtime. List and NonNull types compose other types.',\n fields: () => ({\n kind: {\n type: new GraphQLNonNull(__TypeKind),\n\n resolve(type) {\n if (isScalarType(type)) {\n return TypeKind.SCALAR;\n }\n\n if (isObjectType(type)) {\n return TypeKind.OBJECT;\n }\n\n if (isInterfaceType(type)) {\n return TypeKind.INTERFACE;\n }\n\n if (isUnionType(type)) {\n return TypeKind.UNION;\n }\n\n if (isEnumType(type)) {\n return TypeKind.ENUM;\n }\n\n if (isInputObjectType(type)) {\n return TypeKind.INPUT_OBJECT;\n }\n\n if (isListType(type)) {\n return TypeKind.LIST;\n }\n\n if (isNonNullType(type)) {\n return TypeKind.NON_NULL;\n }\n /* c8 ignore next 3 */\n // Not reachable, all possible types have been considered)\n\n false || invariant(false, `Unexpected type: \"${inspect(type)}\".`);\n },\n },\n name: {\n type: GraphQLString,\n resolve: (type) => ('name' in type ? type.name : undefined),\n },\n description: {\n type: GraphQLString,\n resolve: (\n type, // FIXME: add test case\n ) =>\n /* c8 ignore next */\n 'description' in type ? type.description : undefined,\n },\n specifiedByURL: {\n type: GraphQLString,\n resolve: (obj) =>\n 'specifiedByURL' in obj ? obj.specifiedByURL : undefined,\n },\n fields: {\n type: new GraphQLList(new GraphQLNonNull(__Field)),\n args: {\n includeDeprecated: {\n type: GraphQLBoolean,\n defaultValue: false,\n },\n },\n\n resolve(type, { includeDeprecated }) {\n if (isObjectType(type) || isInterfaceType(type)) {\n const fields = Object.values(type.getFields());\n return includeDeprecated\n ? fields\n : fields.filter((field) => field.deprecationReason == null);\n }\n },\n },\n interfaces: {\n type: new GraphQLList(new GraphQLNonNull(__Type)),\n\n resolve(type) {\n if (isObjectType(type) || isInterfaceType(type)) {\n return type.getInterfaces();\n }\n },\n },\n possibleTypes: {\n type: new GraphQLList(new GraphQLNonNull(__Type)),\n\n resolve(type, _args, _context, { schema }) {\n if (isAbstractType(type)) {\n return schema.getPossibleTypes(type);\n }\n },\n },\n enumValues: {\n type: new GraphQLList(new GraphQLNonNull(__EnumValue)),\n args: {\n includeDeprecated: {\n type: GraphQLBoolean,\n defaultValue: false,\n },\n },\n\n resolve(type, { includeDeprecated }) {\n if (isEnumType(type)) {\n const values = type.getValues();\n return includeDeprecated\n ? values\n : values.filter((field) => field.deprecationReason == null);\n }\n },\n },\n inputFields: {\n type: new GraphQLList(new GraphQLNonNull(__InputValue)),\n args: {\n includeDeprecated: {\n type: GraphQLBoolean,\n defaultValue: false,\n },\n },\n\n resolve(type, { includeDeprecated }) {\n if (isInputObjectType(type)) {\n const values = Object.values(type.getFields());\n return includeDeprecated\n ? values\n : values.filter((field) => field.deprecationReason == null);\n }\n },\n },\n ofType: {\n type: __Type,\n resolve: (type) => ('ofType' in type ? type.ofType : undefined),\n },\n }),\n});\nexport const __Field = new GraphQLObjectType({\n name: '__Field',\n description:\n 'Object and Interface types are described by a list of Fields, each of which has a name, potentially a list of arguments, and a return type.',\n fields: () => ({\n name: {\n type: new GraphQLNonNull(GraphQLString),\n resolve: (field) => field.name,\n },\n description: {\n type: GraphQLString,\n resolve: (field) => field.description,\n },\n args: {\n type: new GraphQLNonNull(\n new GraphQLList(new GraphQLNonNull(__InputValue)),\n ),\n args: {\n includeDeprecated: {\n type: GraphQLBoolean,\n defaultValue: false,\n },\n },\n\n resolve(field, { includeDeprecated }) {\n return includeDeprecated\n ? field.args\n : field.args.filter((arg) => arg.deprecationReason == null);\n },\n },\n type: {\n type: new GraphQLNonNull(__Type),\n resolve: (field) => field.type,\n },\n isDeprecated: {\n type: new GraphQLNonNull(GraphQLBoolean),\n resolve: (field) => field.deprecationReason != null,\n },\n deprecationReason: {\n type: GraphQLString,\n resolve: (field) => field.deprecationReason,\n },\n }),\n});\nexport const __InputValue = new GraphQLObjectType({\n name: '__InputValue',\n description:\n 'Arguments provided to Fields or Directives and the input fields of an InputObject are represented as Input Values which describe their type and optionally a default value.',\n fields: () => ({\n name: {\n type: new GraphQLNonNull(GraphQLString),\n resolve: (inputValue) => inputValue.name,\n },\n description: {\n type: GraphQLString,\n resolve: (inputValue) => inputValue.description,\n },\n type: {\n type: new GraphQLNonNull(__Type),\n resolve: (inputValue) => inputValue.type,\n },\n defaultValue: {\n type: GraphQLString,\n description:\n 'A GraphQL-formatted string representing the default value for this input value.',\n\n resolve(inputValue) {\n const { type, defaultValue } = inputValue;\n const valueAST = astFromValue(defaultValue, type);\n return valueAST ? print(valueAST) : null;\n },\n },\n isDeprecated: {\n type: new GraphQLNonNull(GraphQLBoolean),\n resolve: (field) => field.deprecationReason != null,\n },\n deprecationReason: {\n type: GraphQLString,\n resolve: (obj) => obj.deprecationReason,\n },\n }),\n});\nexport const __EnumValue = new GraphQLObjectType({\n name: '__EnumValue',\n description:\n 'One possible value for a given Enum. Enum values are unique values, not a placeholder for a string or numeric value. However an Enum value is returned in a JSON response as a string.',\n fields: () => ({\n name: {\n type: new GraphQLNonNull(GraphQLString),\n resolve: (enumValue) => enumValue.name,\n },\n description: {\n type: GraphQLString,\n resolve: (enumValue) => enumValue.description,\n },\n isDeprecated: {\n type: new GraphQLNonNull(GraphQLBoolean),\n resolve: (enumValue) => enumValue.deprecationReason != null,\n },\n deprecationReason: {\n type: GraphQLString,\n resolve: (enumValue) => enumValue.deprecationReason,\n },\n }),\n});\nvar TypeKind;\n\n(function (TypeKind) {\n TypeKind['SCALAR'] = 'SCALAR';\n TypeKind['OBJECT'] = 'OBJECT';\n TypeKind['INTERFACE'] = 'INTERFACE';\n TypeKind['UNION'] = 'UNION';\n TypeKind['ENUM'] = 'ENUM';\n TypeKind['INPUT_OBJECT'] = 'INPUT_OBJECT';\n TypeKind['LIST'] = 'LIST';\n TypeKind['NON_NULL'] = 'NON_NULL';\n})(TypeKind || (TypeKind = {}));\n\nexport { TypeKind };\nexport const __TypeKind = new GraphQLEnumType({\n name: '__TypeKind',\n description: 'An enum describing what kind of type a given `__Type` is.',\n values: {\n SCALAR: {\n value: TypeKind.SCALAR,\n description: 'Indicates this type is a scalar.',\n },\n OBJECT: {\n value: TypeKind.OBJECT,\n description:\n 'Indicates this type is an object. `fields` and `interfaces` are valid fields.',\n },\n INTERFACE: {\n value: TypeKind.INTERFACE,\n description:\n 'Indicates this type is an interface. `fields`, `interfaces`, and `possibleTypes` are valid fields.',\n },\n UNION: {\n value: TypeKind.UNION,\n description:\n 'Indicates this type is a union. `possibleTypes` is a valid field.',\n },\n ENUM: {\n value: TypeKind.ENUM,\n description:\n 'Indicates this type is an enum. `enumValues` is a valid field.',\n },\n INPUT_OBJECT: {\n value: TypeKind.INPUT_OBJECT,\n description:\n 'Indicates this type is an input object. `inputFields` is a valid field.',\n },\n LIST: {\n value: TypeKind.LIST,\n description: 'Indicates this type is a list. `ofType` is a valid field.',\n },\n NON_NULL: {\n value: TypeKind.NON_NULL,\n description:\n 'Indicates this type is a non-null. `ofType` is a valid field.',\n },\n },\n});\n/**\n * Note that these are GraphQLField and not GraphQLFieldConfig,\n * so the format for args is different.\n */\n\nexport const SchemaMetaFieldDef = {\n name: '__schema',\n type: new GraphQLNonNull(__Schema),\n description: 'Access the current type schema of this server.',\n args: [],\n resolve: (_source, _args, _context, { schema }) => schema,\n deprecationReason: undefined,\n extensions: Object.create(null),\n astNode: undefined,\n};\nexport const TypeMetaFieldDef = {\n name: '__type',\n type: __Type,\n description: 'Request the type information of a single type.',\n args: [\n {\n name: 'name',\n description: undefined,\n type: new GraphQLNonNull(GraphQLString),\n defaultValue: undefined,\n deprecationReason: undefined,\n extensions: Object.create(null),\n astNode: undefined,\n },\n ],\n resolve: (_source, { name }, _context, { schema }) => schema.getType(name),\n deprecationReason: undefined,\n extensions: Object.create(null),\n astNode: undefined,\n};\nexport const TypeNameMetaFieldDef = {\n name: '__typename',\n type: new GraphQLNonNull(GraphQLString),\n description: 'The name of the current Object type at runtime.',\n args: [],\n resolve: (_source, _args, _context, { parentType }) => parentType.name,\n deprecationReason: undefined,\n extensions: Object.create(null),\n astNode: undefined,\n};\nexport const introspectionTypes = Object.freeze([\n __Schema,\n __Directive,\n __DirectiveLocation,\n __Type,\n __Field,\n __InputValue,\n __EnumValue,\n __TypeKind,\n]);\nexport function isIntrospectionType(type) {\n return introspectionTypes.some(({ name }) => type.name === name);\n}\n","import { devAssert } from '../jsutils/devAssert.mjs';\nimport { inspect } from '../jsutils/inspect.mjs';\nimport { instanceOf } from '../jsutils/instanceOf.mjs';\nimport { isObjectLike } from '../jsutils/isObjectLike.mjs';\nimport { toObjMap } from '../jsutils/toObjMap.mjs';\nimport { OperationTypeNode } from '../language/ast.mjs';\nimport {\n getNamedType,\n isInputObjectType,\n isInterfaceType,\n isObjectType,\n isUnionType,\n} from './definition.mjs';\nimport { isDirective, specifiedDirectives } from './directives.mjs';\nimport { __Schema } from './introspection.mjs';\n/**\n * Test if the given value is a GraphQL schema.\n */\n\nexport function isSchema(schema) {\n return instanceOf(schema, GraphQLSchema);\n}\nexport function assertSchema(schema) {\n if (!isSchema(schema)) {\n throw new Error(`Expected ${inspect(schema)} to be a GraphQL schema.`);\n }\n\n return schema;\n}\n/**\n * Custom extensions\n *\n * @remarks\n * Use a unique identifier name for your extension, for example the name of\n * your library or project. Do not use a shortened identifier as this increases\n * the risk of conflicts. We recommend you add at most one extension field,\n * an object which can contain all the values you need.\n */\n\n/**\n * Schema Definition\n *\n * A Schema is created by supplying the root types of each type of operation,\n * query and mutation (optional). A schema definition is then supplied to the\n * validator and executor.\n *\n * Example:\n *\n * ```ts\n * const MyAppSchema = new GraphQLSchema({\n * query: MyAppQueryRootType,\n * mutation: MyAppMutationRootType,\n * })\n * ```\n *\n * Note: When the schema is constructed, by default only the types that are\n * reachable by traversing the root types are included, other types must be\n * explicitly referenced.\n *\n * Example:\n *\n * ```ts\n * const characterInterface = new GraphQLInterfaceType({\n * name: 'Character',\n * ...\n * });\n *\n * const humanType = new GraphQLObjectType({\n * name: 'Human',\n * interfaces: [characterInterface],\n * ...\n * });\n *\n * const droidType = new GraphQLObjectType({\n * name: 'Droid',\n * interfaces: [characterInterface],\n * ...\n * });\n *\n * const schema = new GraphQLSchema({\n * query: new GraphQLObjectType({\n * name: 'Query',\n * fields: {\n * hero: { type: characterInterface, ... },\n * }\n * }),\n * ...\n * // Since this schema references only the `Character` interface it's\n * // necessary to explicitly list the types that implement it if\n * // you want them to be included in the final schema.\n * types: [humanType, droidType],\n * })\n * ```\n *\n * Note: If an array of `directives` are provided to GraphQLSchema, that will be\n * the exact list of directives represented and allowed. If `directives` is not\n * provided then a default set of the specified directives (e.g. `@include` and\n * `@skip`) will be used. If you wish to provide *additional* directives to these\n * specified directives, you must explicitly declare them. Example:\n *\n * ```ts\n * const MyAppSchema = new GraphQLSchema({\n * ...\n * directives: specifiedDirectives.concat([ myCustomDirective ]),\n * })\n * ```\n */\nexport class GraphQLSchema {\n // Used as a cache for validateSchema().\n constructor(config) {\n var _config$extensionASTN, _config$directives;\n\n // If this schema was built from a source known to be valid, then it may be\n // marked with assumeValid to avoid an additional type system validation.\n this.__validationErrors = config.assumeValid === true ? [] : undefined; // Check for common mistakes during construction to produce early errors.\n\n isObjectLike(config) ||\n devAssert(false, 'Must provide configuration object.');\n !config.types ||\n Array.isArray(config.types) ||\n devAssert(\n false,\n `\"types\" must be Array if provided but got: ${inspect(config.types)}.`,\n );\n !config.directives ||\n Array.isArray(config.directives) ||\n devAssert(\n false,\n '\"directives\" must be Array if provided but got: ' +\n `${inspect(config.directives)}.`,\n );\n this.description = config.description;\n this.extensions = toObjMap(config.extensions);\n this.astNode = config.astNode;\n this.extensionASTNodes =\n (_config$extensionASTN = config.extensionASTNodes) !== null &&\n _config$extensionASTN !== void 0\n ? _config$extensionASTN\n : [];\n this._queryType = config.query;\n this._mutationType = config.mutation;\n this._subscriptionType = config.subscription; // Provide specified directives (e.g. @include and @skip) by default.\n\n this._directives =\n (_config$directives = config.directives) !== null &&\n _config$directives !== void 0\n ? _config$directives\n : specifiedDirectives; // To preserve order of user-provided types, we add first to add them to\n // the set of \"collected\" types, so `collectReferencedTypes` ignore them.\n\n const allReferencedTypes = new Set(config.types);\n\n if (config.types != null) {\n for (const type of config.types) {\n // When we ready to process this type, we remove it from \"collected\" types\n // and then add it together with all dependent types in the correct position.\n allReferencedTypes.delete(type);\n collectReferencedTypes(type, allReferencedTypes);\n }\n }\n\n if (this._queryType != null) {\n collectReferencedTypes(this._queryType, allReferencedTypes);\n }\n\n if (this._mutationType != null) {\n collectReferencedTypes(this._mutationType, allReferencedTypes);\n }\n\n if (this._subscriptionType != null) {\n collectReferencedTypes(this._subscriptionType, allReferencedTypes);\n }\n\n for (const directive of this._directives) {\n // Directives are not validated until validateSchema() is called.\n if (isDirective(directive)) {\n for (const arg of directive.args) {\n collectReferencedTypes(arg.type, allReferencedTypes);\n }\n }\n }\n\n collectReferencedTypes(__Schema, allReferencedTypes); // Storing the resulting map for reference by the schema.\n\n this._typeMap = Object.create(null);\n this._subTypeMap = Object.create(null); // Keep track of all implementations by interface name.\n\n this._implementationsMap = Object.create(null);\n\n for (const namedType of allReferencedTypes) {\n if (namedType == null) {\n continue;\n }\n\n const typeName = namedType.name;\n typeName ||\n devAssert(\n false,\n 'One of the provided types for building the Schema is missing a name.',\n );\n\n if (this._typeMap[typeName] !== undefined) {\n throw new Error(\n `Schema must contain uniquely named types but contains multiple types named \"${typeName}\".`,\n );\n }\n\n this._typeMap[typeName] = namedType;\n\n if (isInterfaceType(namedType)) {\n // Store implementations by interface.\n for (const iface of namedType.getInterfaces()) {\n if (isInterfaceType(iface)) {\n let implementations = this._implementationsMap[iface.name];\n\n if (implementations === undefined) {\n implementations = this._implementationsMap[iface.name] = {\n objects: [],\n interfaces: [],\n };\n }\n\n implementations.interfaces.push(namedType);\n }\n }\n } else if (isObjectType(namedType)) {\n // Store implementations by objects.\n for (const iface of namedType.getInterfaces()) {\n if (isInterfaceType(iface)) {\n let implementations = this._implementationsMap[iface.name];\n\n if (implementations === undefined) {\n implementations = this._implementationsMap[iface.name] = {\n objects: [],\n interfaces: [],\n };\n }\n\n implementations.objects.push(namedType);\n }\n }\n }\n }\n }\n\n get [Symbol.toStringTag]() {\n return 'GraphQLSchema';\n }\n\n getQueryType() {\n return this._queryType;\n }\n\n getMutationType() {\n return this._mutationType;\n }\n\n getSubscriptionType() {\n return this._subscriptionType;\n }\n\n getRootType(operation) {\n switch (operation) {\n case OperationTypeNode.QUERY:\n return this.getQueryType();\n\n case OperationTypeNode.MUTATION:\n return this.getMutationType();\n\n case OperationTypeNode.SUBSCRIPTION:\n return this.getSubscriptionType();\n }\n }\n\n getTypeMap() {\n return this._typeMap;\n }\n\n getType(name) {\n return this.getTypeMap()[name];\n }\n\n getPossibleTypes(abstractType) {\n return isUnionType(abstractType)\n ? abstractType.getTypes()\n : this.getImplementations(abstractType).objects;\n }\n\n getImplementations(interfaceType) {\n const implementations = this._implementationsMap[interfaceType.name];\n return implementations !== null && implementations !== void 0\n ? implementations\n : {\n objects: [],\n interfaces: [],\n };\n }\n\n isSubType(abstractType, maybeSubType) {\n let map = this._subTypeMap[abstractType.name];\n\n if (map === undefined) {\n map = Object.create(null);\n\n if (isUnionType(abstractType)) {\n for (const type of abstractType.getTypes()) {\n map[type.name] = true;\n }\n } else {\n const implementations = this.getImplementations(abstractType);\n\n for (const type of implementations.objects) {\n map[type.name] = true;\n }\n\n for (const type of implementations.interfaces) {\n map[type.name] = true;\n }\n }\n\n this._subTypeMap[abstractType.name] = map;\n }\n\n return map[maybeSubType.name] !== undefined;\n }\n\n getDirectives() {\n return this._directives;\n }\n\n getDirective(name) {\n return this.getDirectives().find((directive) => directive.name === name);\n }\n\n toConfig() {\n return {\n description: this.description,\n query: this.getQueryType(),\n mutation: this.getMutationType(),\n subscription: this.getSubscriptionType(),\n types: Object.values(this.getTypeMap()),\n directives: this.getDirectives(),\n extensions: this.extensions,\n astNode: this.astNode,\n extensionASTNodes: this.extensionASTNodes,\n assumeValid: this.__validationErrors !== undefined,\n };\n }\n}\n\nfunction collectReferencedTypes(type, typeSet) {\n const namedType = getNamedType(type);\n\n if (!typeSet.has(namedType)) {\n typeSet.add(namedType);\n\n if (isUnionType(namedType)) {\n for (const memberType of namedType.getTypes()) {\n collectReferencedTypes(memberType, typeSet);\n }\n } else if (isObjectType(namedType) || isInterfaceType(namedType)) {\n for (const interfaceType of namedType.getInterfaces()) {\n collectReferencedTypes(interfaceType, typeSet);\n }\n\n for (const field of Object.values(namedType.getFields())) {\n collectReferencedTypes(field.type, typeSet);\n\n for (const arg of field.args) {\n collectReferencedTypes(arg.type, typeSet);\n }\n }\n } else if (isInputObjectType(namedType)) {\n for (const field of Object.values(namedType.getFields())) {\n collectReferencedTypes(field.type, typeSet);\n }\n }\n }\n\n return typeSet;\n}\n","import { inspect } from '../jsutils/inspect.mjs';\nimport { GraphQLError } from '../error/GraphQLError.mjs';\nimport { OperationTypeNode } from '../language/ast.mjs';\nimport { isEqualType, isTypeSubTypeOf } from '../utilities/typeComparators.mjs';\nimport {\n isEnumType,\n isInputObjectType,\n isInputType,\n isInterfaceType,\n isNamedType,\n isNonNullType,\n isObjectType,\n isOutputType,\n isRequiredArgument,\n isRequiredInputField,\n isUnionType,\n} from './definition.mjs';\nimport { GraphQLDeprecatedDirective, isDirective } from './directives.mjs';\nimport { isIntrospectionType } from './introspection.mjs';\nimport { assertSchema } from './schema.mjs';\n/**\n * Implements the \"Type Validation\" sub-sections of the specification's\n * \"Type System\" section.\n *\n * Validation runs synchronously, returning an array of encountered errors, or\n * an empty array if no errors were encountered and the Schema is valid.\n */\n\nexport function validateSchema(schema) {\n // First check to ensure the provided value is in fact a GraphQLSchema.\n assertSchema(schema); // If this Schema has already been validated, return the previous results.\n\n if (schema.__validationErrors) {\n return schema.__validationErrors;\n } // Validate the schema, producing a list of errors.\n\n const context = new SchemaValidationContext(schema);\n validateRootTypes(context);\n validateDirectives(context);\n validateTypes(context); // Persist the results of validation before returning to ensure validation\n // does not run multiple times for this schema.\n\n const errors = context.getErrors();\n schema.__validationErrors = errors;\n return errors;\n}\n/**\n * Utility function which asserts a schema is valid by throwing an error if\n * it is invalid.\n */\n\nexport function assertValidSchema(schema) {\n const errors = validateSchema(schema);\n\n if (errors.length !== 0) {\n throw new Error(errors.map((error) => error.message).join('\\n\\n'));\n }\n}\n\nclass SchemaValidationContext {\n constructor(schema) {\n this._errors = [];\n this.schema = schema;\n }\n\n reportError(message, nodes) {\n const _nodes = Array.isArray(nodes) ? nodes.filter(Boolean) : nodes;\n\n this._errors.push(\n new GraphQLError(message, {\n nodes: _nodes,\n }),\n );\n }\n\n getErrors() {\n return this._errors;\n }\n}\n\nfunction validateRootTypes(context) {\n const schema = context.schema;\n const queryType = schema.getQueryType();\n\n if (!queryType) {\n context.reportError('Query root type must be provided.', schema.astNode);\n } else if (!isObjectType(queryType)) {\n var _getOperationTypeNode;\n\n context.reportError(\n `Query root type must be Object type, it cannot be ${inspect(\n queryType,\n )}.`,\n (_getOperationTypeNode = getOperationTypeNode(\n schema,\n OperationTypeNode.QUERY,\n )) !== null && _getOperationTypeNode !== void 0\n ? _getOperationTypeNode\n : queryType.astNode,\n );\n }\n\n const mutationType = schema.getMutationType();\n\n if (mutationType && !isObjectType(mutationType)) {\n var _getOperationTypeNode2;\n\n context.reportError(\n 'Mutation root type must be Object type if provided, it cannot be ' +\n `${inspect(mutationType)}.`,\n (_getOperationTypeNode2 = getOperationTypeNode(\n schema,\n OperationTypeNode.MUTATION,\n )) !== null && _getOperationTypeNode2 !== void 0\n ? _getOperationTypeNode2\n : mutationType.astNode,\n );\n }\n\n const subscriptionType = schema.getSubscriptionType();\n\n if (subscriptionType && !isObjectType(subscriptionType)) {\n var _getOperationTypeNode3;\n\n context.reportError(\n 'Subscription root type must be Object type if provided, it cannot be ' +\n `${inspect(subscriptionType)}.`,\n (_getOperationTypeNode3 = getOperationTypeNode(\n schema,\n OperationTypeNode.SUBSCRIPTION,\n )) !== null && _getOperationTypeNode3 !== void 0\n ? _getOperationTypeNode3\n : subscriptionType.astNode,\n );\n }\n}\n\nfunction getOperationTypeNode(schema, operation) {\n var _flatMap$find;\n\n return (_flatMap$find = [schema.astNode, ...schema.extensionASTNodes]\n .flatMap(\n // FIXME: https://github.com/graphql/graphql-js/issues/2203\n (schemaNode) => {\n var _schemaNode$operation;\n\n return (\n /* c8 ignore next */\n (_schemaNode$operation =\n schemaNode === null || schemaNode === void 0\n ? void 0\n : schemaNode.operationTypes) !== null &&\n _schemaNode$operation !== void 0\n ? _schemaNode$operation\n : []\n );\n },\n )\n .find((operationNode) => operationNode.operation === operation)) === null ||\n _flatMap$find === void 0\n ? void 0\n : _flatMap$find.type;\n}\n\nfunction validateDirectives(context) {\n for (const directive of context.schema.getDirectives()) {\n // Ensure all directives are in fact GraphQL directives.\n if (!isDirective(directive)) {\n context.reportError(\n `Expected directive but got: ${inspect(directive)}.`,\n directive === null || directive === void 0 ? void 0 : directive.astNode,\n );\n continue;\n } // Ensure they are named correctly.\n\n validateName(context, directive); // TODO: Ensure proper locations.\n // Ensure the arguments are valid.\n\n for (const arg of directive.args) {\n // Ensure they are named correctly.\n validateName(context, arg); // Ensure the type is an input type.\n\n if (!isInputType(arg.type)) {\n context.reportError(\n `The type of @${directive.name}(${arg.name}:) must be Input Type ` +\n `but got: ${inspect(arg.type)}.`,\n arg.astNode,\n );\n }\n\n if (isRequiredArgument(arg) && arg.deprecationReason != null) {\n var _arg$astNode;\n\n context.reportError(\n `Required argument @${directive.name}(${arg.name}:) cannot be deprecated.`,\n [\n getDeprecatedDirectiveNode(arg.astNode),\n (_arg$astNode = arg.astNode) === null || _arg$astNode === void 0\n ? void 0\n : _arg$astNode.type,\n ],\n );\n }\n }\n }\n}\n\nfunction validateName(context, node) {\n // Ensure names are valid, however introspection types opt out.\n if (node.name.startsWith('__')) {\n context.reportError(\n `Name \"${node.name}\" must not begin with \"__\", which is reserved by GraphQL introspection.`,\n node.astNode,\n );\n }\n}\n\nfunction validateTypes(context) {\n const validateInputObjectCircularRefs =\n createInputObjectCircularRefsValidator(context);\n const typeMap = context.schema.getTypeMap();\n\n for (const type of Object.values(typeMap)) {\n // Ensure all provided types are in fact GraphQL type.\n if (!isNamedType(type)) {\n context.reportError(\n `Expected GraphQL named type but got: ${inspect(type)}.`,\n type.astNode,\n );\n continue;\n } // Ensure it is named correctly (excluding introspection types).\n\n if (!isIntrospectionType(type)) {\n validateName(context, type);\n }\n\n if (isObjectType(type)) {\n // Ensure fields are valid\n validateFields(context, type); // Ensure objects implement the interfaces they claim to.\n\n validateInterfaces(context, type);\n } else if (isInterfaceType(type)) {\n // Ensure fields are valid.\n validateFields(context, type); // Ensure interfaces implement the interfaces they claim to.\n\n validateInterfaces(context, type);\n } else if (isUnionType(type)) {\n // Ensure Unions include valid member types.\n validateUnionMembers(context, type);\n } else if (isEnumType(type)) {\n // Ensure Enums have valid values.\n validateEnumValues(context, type);\n } else if (isInputObjectType(type)) {\n // Ensure Input Object fields are valid.\n validateInputFields(context, type); // Ensure Input Objects do not contain non-nullable circular references\n\n validateInputObjectCircularRefs(type);\n }\n }\n}\n\nfunction validateFields(context, type) {\n const fields = Object.values(type.getFields()); // Objects and Interfaces both must define one or more fields.\n\n if (fields.length === 0) {\n context.reportError(`Type ${type.name} must define one or more fields.`, [\n type.astNode,\n ...type.extensionASTNodes,\n ]);\n }\n\n for (const field of fields) {\n // Ensure they are named correctly.\n validateName(context, field); // Ensure the type is an output type\n\n if (!isOutputType(field.type)) {\n var _field$astNode;\n\n context.reportError(\n `The type of ${type.name}.${field.name} must be Output Type ` +\n `but got: ${inspect(field.type)}.`,\n (_field$astNode = field.astNode) === null || _field$astNode === void 0\n ? void 0\n : _field$astNode.type,\n );\n } // Ensure the arguments are valid\n\n for (const arg of field.args) {\n const argName = arg.name; // Ensure they are named correctly.\n\n validateName(context, arg); // Ensure the type is an input type\n\n if (!isInputType(arg.type)) {\n var _arg$astNode2;\n\n context.reportError(\n `The type of ${type.name}.${field.name}(${argName}:) must be Input ` +\n `Type but got: ${inspect(arg.type)}.`,\n (_arg$astNode2 = arg.astNode) === null || _arg$astNode2 === void 0\n ? void 0\n : _arg$astNode2.type,\n );\n }\n\n if (isRequiredArgument(arg) && arg.deprecationReason != null) {\n var _arg$astNode3;\n\n context.reportError(\n `Required argument ${type.name}.${field.name}(${argName}:) cannot be deprecated.`,\n [\n getDeprecatedDirectiveNode(arg.astNode),\n (_arg$astNode3 = arg.astNode) === null || _arg$astNode3 === void 0\n ? void 0\n : _arg$astNode3.type,\n ],\n );\n }\n }\n }\n}\n\nfunction validateInterfaces(context, type) {\n const ifaceTypeNames = Object.create(null);\n\n for (const iface of type.getInterfaces()) {\n if (!isInterfaceType(iface)) {\n context.reportError(\n `Type ${inspect(type)} must only implement Interface types, ` +\n `it cannot implement ${inspect(iface)}.`,\n getAllImplementsInterfaceNodes(type, iface),\n );\n continue;\n }\n\n if (type === iface) {\n context.reportError(\n `Type ${type.name} cannot implement itself because it would create a circular reference.`,\n getAllImplementsInterfaceNodes(type, iface),\n );\n continue;\n }\n\n if (ifaceTypeNames[iface.name]) {\n context.reportError(\n `Type ${type.name} can only implement ${iface.name} once.`,\n getAllImplementsInterfaceNodes(type, iface),\n );\n continue;\n }\n\n ifaceTypeNames[iface.name] = true;\n validateTypeImplementsAncestors(context, type, iface);\n validateTypeImplementsInterface(context, type, iface);\n }\n}\n\nfunction validateTypeImplementsInterface(context, type, iface) {\n const typeFieldMap = type.getFields(); // Assert each interface field is implemented.\n\n for (const ifaceField of Object.values(iface.getFields())) {\n const fieldName = ifaceField.name;\n const typeField = typeFieldMap[fieldName]; // Assert interface field exists on type.\n\n if (!typeField) {\n context.reportError(\n `Interface field ${iface.name}.${fieldName} expected but ${type.name} does not provide it.`,\n [ifaceField.astNode, type.astNode, ...type.extensionASTNodes],\n );\n continue;\n } // Assert interface field type is satisfied by type field type, by being\n // a valid subtype. (covariant)\n\n if (!isTypeSubTypeOf(context.schema, typeField.type, ifaceField.type)) {\n var _ifaceField$astNode, _typeField$astNode;\n\n context.reportError(\n `Interface field ${iface.name}.${fieldName} expects type ` +\n `${inspect(ifaceField.type)} but ${type.name}.${fieldName} ` +\n `is type ${inspect(typeField.type)}.`,\n [\n (_ifaceField$astNode = ifaceField.astNode) === null ||\n _ifaceField$astNode === void 0\n ? void 0\n : _ifaceField$astNode.type,\n (_typeField$astNode = typeField.astNode) === null ||\n _typeField$astNode === void 0\n ? void 0\n : _typeField$astNode.type,\n ],\n );\n } // Assert each interface field arg is implemented.\n\n for (const ifaceArg of ifaceField.args) {\n const argName = ifaceArg.name;\n const typeArg = typeField.args.find((arg) => arg.name === argName); // Assert interface field arg exists on object field.\n\n if (!typeArg) {\n context.reportError(\n `Interface field argument ${iface.name}.${fieldName}(${argName}:) expected but ${type.name}.${fieldName} does not provide it.`,\n [ifaceArg.astNode, typeField.astNode],\n );\n continue;\n } // Assert interface field arg type matches object field arg type.\n // (invariant)\n // TODO: change to contravariant?\n\n if (!isEqualType(ifaceArg.type, typeArg.type)) {\n var _ifaceArg$astNode, _typeArg$astNode;\n\n context.reportError(\n `Interface field argument ${iface.name}.${fieldName}(${argName}:) ` +\n `expects type ${inspect(ifaceArg.type)} but ` +\n `${type.name}.${fieldName}(${argName}:) is type ` +\n `${inspect(typeArg.type)}.`,\n [\n (_ifaceArg$astNode = ifaceArg.astNode) === null ||\n _ifaceArg$astNode === void 0\n ? void 0\n : _ifaceArg$astNode.type,\n (_typeArg$astNode = typeArg.astNode) === null ||\n _typeArg$astNode === void 0\n ? void 0\n : _typeArg$astNode.type,\n ],\n );\n } // TODO: validate default values?\n } // Assert additional arguments must not be required.\n\n for (const typeArg of typeField.args) {\n const argName = typeArg.name;\n const ifaceArg = ifaceField.args.find((arg) => arg.name === argName);\n\n if (!ifaceArg && isRequiredArgument(typeArg)) {\n context.reportError(\n `Object field ${type.name}.${fieldName} includes required argument ${argName} that is missing from the Interface field ${iface.name}.${fieldName}.`,\n [typeArg.astNode, ifaceField.astNode],\n );\n }\n }\n }\n}\n\nfunction validateTypeImplementsAncestors(context, type, iface) {\n const ifaceInterfaces = type.getInterfaces();\n\n for (const transitive of iface.getInterfaces()) {\n if (!ifaceInterfaces.includes(transitive)) {\n context.reportError(\n transitive === type\n ? `Type ${type.name} cannot implement ${iface.name} because it would create a circular reference.`\n : `Type ${type.name} must implement ${transitive.name} because it is implemented by ${iface.name}.`,\n [\n ...getAllImplementsInterfaceNodes(iface, transitive),\n ...getAllImplementsInterfaceNodes(type, iface),\n ],\n );\n }\n }\n}\n\nfunction validateUnionMembers(context, union) {\n const memberTypes = union.getTypes();\n\n if (memberTypes.length === 0) {\n context.reportError(\n `Union type ${union.name} must define one or more member types.`,\n [union.astNode, ...union.extensionASTNodes],\n );\n }\n\n const includedTypeNames = Object.create(null);\n\n for (const memberType of memberTypes) {\n if (includedTypeNames[memberType.name]) {\n context.reportError(\n `Union type ${union.name} can only include type ${memberType.name} once.`,\n getUnionMemberTypeNodes(union, memberType.name),\n );\n continue;\n }\n\n includedTypeNames[memberType.name] = true;\n\n if (!isObjectType(memberType)) {\n context.reportError(\n `Union type ${union.name} can only include Object types, ` +\n `it cannot include ${inspect(memberType)}.`,\n getUnionMemberTypeNodes(union, String(memberType)),\n );\n }\n }\n}\n\nfunction validateEnumValues(context, enumType) {\n const enumValues = enumType.getValues();\n\n if (enumValues.length === 0) {\n context.reportError(\n `Enum type ${enumType.name} must define one or more values.`,\n [enumType.astNode, ...enumType.extensionASTNodes],\n );\n }\n\n for (const enumValue of enumValues) {\n // Ensure valid name.\n validateName(context, enumValue);\n }\n}\n\nfunction validateInputFields(context, inputObj) {\n const fields = Object.values(inputObj.getFields());\n\n if (fields.length === 0) {\n context.reportError(\n `Input Object type ${inputObj.name} must define one or more fields.`,\n [inputObj.astNode, ...inputObj.extensionASTNodes],\n );\n } // Ensure the arguments are valid\n\n for (const field of fields) {\n // Ensure they are named correctly.\n validateName(context, field); // Ensure the type is an input type\n\n if (!isInputType(field.type)) {\n var _field$astNode2;\n\n context.reportError(\n `The type of ${inputObj.name}.${field.name} must be Input Type ` +\n `but got: ${inspect(field.type)}.`,\n (_field$astNode2 = field.astNode) === null || _field$astNode2 === void 0\n ? void 0\n : _field$astNode2.type,\n );\n }\n\n if (isRequiredInputField(field) && field.deprecationReason != null) {\n var _field$astNode3;\n\n context.reportError(\n `Required input field ${inputObj.name}.${field.name} cannot be deprecated.`,\n [\n getDeprecatedDirectiveNode(field.astNode),\n (_field$astNode3 = field.astNode) === null ||\n _field$astNode3 === void 0\n ? void 0\n : _field$astNode3.type,\n ],\n );\n }\n }\n}\n\nfunction createInputObjectCircularRefsValidator(context) {\n // Modified copy of algorithm from 'src/validation/rules/NoFragmentCycles.js'.\n // Tracks already visited types to maintain O(N) and to ensure that cycles\n // are not redundantly reported.\n const visitedTypes = Object.create(null); // Array of types nodes used to produce meaningful errors\n\n const fieldPath = []; // Position in the type path\n\n const fieldPathIndexByTypeName = Object.create(null);\n return detectCycleRecursive; // This does a straight-forward DFS to find cycles.\n // It does not terminate when a cycle was found but continues to explore\n // the graph to find all possible cycles.\n\n function detectCycleRecursive(inputObj) {\n if (visitedTypes[inputObj.name]) {\n return;\n }\n\n visitedTypes[inputObj.name] = true;\n fieldPathIndexByTypeName[inputObj.name] = fieldPath.length;\n const fields = Object.values(inputObj.getFields());\n\n for (const field of fields) {\n if (isNonNullType(field.type) && isInputObjectType(field.type.ofType)) {\n const fieldType = field.type.ofType;\n const cycleIndex = fieldPathIndexByTypeName[fieldType.name];\n fieldPath.push(field);\n\n if (cycleIndex === undefined) {\n detectCycleRecursive(fieldType);\n } else {\n const cyclePath = fieldPath.slice(cycleIndex);\n const pathStr = cyclePath.map((fieldObj) => fieldObj.name).join('.');\n context.reportError(\n `Cannot reference Input Object \"${fieldType.name}\" within itself through a series of non-null fields: \"${pathStr}\".`,\n cyclePath.map((fieldObj) => fieldObj.astNode),\n );\n }\n\n fieldPath.pop();\n }\n }\n\n fieldPathIndexByTypeName[inputObj.name] = undefined;\n }\n}\n\nfunction getAllImplementsInterfaceNodes(type, iface) {\n const { astNode, extensionASTNodes } = type;\n const nodes =\n astNode != null ? [astNode, ...extensionASTNodes] : extensionASTNodes; // FIXME: https://github.com/graphql/graphql-js/issues/2203\n\n return nodes\n .flatMap((typeNode) => {\n var _typeNode$interfaces;\n\n return (\n /* c8 ignore next */\n (_typeNode$interfaces = typeNode.interfaces) !== null &&\n _typeNode$interfaces !== void 0\n ? _typeNode$interfaces\n : []\n );\n })\n .filter((ifaceNode) => ifaceNode.name.value === iface.name);\n}\n\nfunction getUnionMemberTypeNodes(union, typeName) {\n const { astNode, extensionASTNodes } = union;\n const nodes =\n astNode != null ? [astNode, ...extensionASTNodes] : extensionASTNodes; // FIXME: https://github.com/graphql/graphql-js/issues/2203\n\n return nodes\n .flatMap((unionNode) => {\n var _unionNode$types;\n\n return (\n /* c8 ignore next */\n (_unionNode$types = unionNode.types) !== null &&\n _unionNode$types !== void 0\n ? _unionNode$types\n : []\n );\n })\n .filter((typeNode) => typeNode.name.value === typeName);\n}\n\nfunction getDeprecatedDirectiveNode(definitionNode) {\n var _definitionNode$direc;\n\n return definitionNode === null || definitionNode === void 0\n ? void 0\n : (_definitionNode$direc = definitionNode.directives) === null ||\n _definitionNode$direc === void 0\n ? void 0\n : _definitionNode$direc.find(\n (node) => node.name.value === GraphQLDeprecatedDirective.name,\n );\n}\n","import { Kind } from '../language/kinds.mjs';\nimport { GraphQLList, GraphQLNonNull } from '../type/definition.mjs';\nexport function typeFromAST(schema, typeNode) {\n switch (typeNode.kind) {\n case Kind.LIST_TYPE: {\n const innerType = typeFromAST(schema, typeNode.type);\n return innerType && new GraphQLList(innerType);\n }\n\n case Kind.NON_NULL_TYPE: {\n const innerType = typeFromAST(schema, typeNode.type);\n return innerType && new GraphQLNonNull(innerType);\n }\n\n case Kind.NAMED_TYPE:\n return schema.getType(typeNode.name.value);\n }\n}\n","import { isNode } from '../language/ast.mjs';\nimport { Kind } from '../language/kinds.mjs';\nimport { getEnterLeaveForKind } from '../language/visitor.mjs';\nimport {\n getNamedType,\n getNullableType,\n isCompositeType,\n isEnumType,\n isInputObjectType,\n isInputType,\n isInterfaceType,\n isListType,\n isObjectType,\n isOutputType,\n} from '../type/definition.mjs';\nimport {\n SchemaMetaFieldDef,\n TypeMetaFieldDef,\n TypeNameMetaFieldDef,\n} from '../type/introspection.mjs';\nimport { typeFromAST } from './typeFromAST.mjs';\n/**\n * TypeInfo is a utility class which, given a GraphQL schema, can keep track\n * of the current field and type definitions at any point in a GraphQL document\n * AST during a recursive descent by calling `enter(node)` and `leave(node)`.\n */\n\nexport class TypeInfo {\n constructor(\n schema,\n /**\n * Initial type may be provided in rare cases to facilitate traversals\n * beginning somewhere other than documents.\n */\n initialType,\n /** @deprecated will be removed in 17.0.0 */\n getFieldDefFn,\n ) {\n this._schema = schema;\n this._typeStack = [];\n this._parentTypeStack = [];\n this._inputTypeStack = [];\n this._fieldDefStack = [];\n this._defaultValueStack = [];\n this._directive = null;\n this._argument = null;\n this._enumValue = null;\n this._getFieldDef =\n getFieldDefFn !== null && getFieldDefFn !== void 0\n ? getFieldDefFn\n : getFieldDef;\n\n if (initialType) {\n if (isInputType(initialType)) {\n this._inputTypeStack.push(initialType);\n }\n\n if (isCompositeType(initialType)) {\n this._parentTypeStack.push(initialType);\n }\n\n if (isOutputType(initialType)) {\n this._typeStack.push(initialType);\n }\n }\n }\n\n get [Symbol.toStringTag]() {\n return 'TypeInfo';\n }\n\n getType() {\n if (this._typeStack.length > 0) {\n return this._typeStack[this._typeStack.length - 1];\n }\n }\n\n getParentType() {\n if (this._parentTypeStack.length > 0) {\n return this._parentTypeStack[this._parentTypeStack.length - 1];\n }\n }\n\n getInputType() {\n if (this._inputTypeStack.length > 0) {\n return this._inputTypeStack[this._inputTypeStack.length - 1];\n }\n }\n\n getParentInputType() {\n if (this._inputTypeStack.length > 1) {\n return this._inputTypeStack[this._inputTypeStack.length - 2];\n }\n }\n\n getFieldDef() {\n if (this._fieldDefStack.length > 0) {\n return this._fieldDefStack[this._fieldDefStack.length - 1];\n }\n }\n\n getDefaultValue() {\n if (this._defaultValueStack.length > 0) {\n return this._defaultValueStack[this._defaultValueStack.length - 1];\n }\n }\n\n getDirective() {\n return this._directive;\n }\n\n getArgument() {\n return this._argument;\n }\n\n getEnumValue() {\n return this._enumValue;\n }\n\n enter(node) {\n const schema = this._schema; // Note: many of the types below are explicitly typed as \"unknown\" to drop\n // any assumptions of a valid schema to ensure runtime types are properly\n // checked before continuing since TypeInfo is used as part of validation\n // which occurs before guarantees of schema and document validity.\n\n switch (node.kind) {\n case Kind.SELECTION_SET: {\n const namedType = getNamedType(this.getType());\n\n this._parentTypeStack.push(\n isCompositeType(namedType) ? namedType : undefined,\n );\n\n break;\n }\n\n case Kind.FIELD: {\n const parentType = this.getParentType();\n let fieldDef;\n let fieldType;\n\n if (parentType) {\n fieldDef = this._getFieldDef(schema, parentType, node);\n\n if (fieldDef) {\n fieldType = fieldDef.type;\n }\n }\n\n this._fieldDefStack.push(fieldDef);\n\n this._typeStack.push(isOutputType(fieldType) ? fieldType : undefined);\n\n break;\n }\n\n case Kind.DIRECTIVE:\n this._directive = schema.getDirective(node.name.value);\n break;\n\n case Kind.OPERATION_DEFINITION: {\n const rootType = schema.getRootType(node.operation);\n\n this._typeStack.push(isObjectType(rootType) ? rootType : undefined);\n\n break;\n }\n\n case Kind.INLINE_FRAGMENT:\n case Kind.FRAGMENT_DEFINITION: {\n const typeConditionAST = node.typeCondition;\n const outputType = typeConditionAST\n ? typeFromAST(schema, typeConditionAST)\n : getNamedType(this.getType());\n\n this._typeStack.push(isOutputType(outputType) ? outputType : undefined);\n\n break;\n }\n\n case Kind.VARIABLE_DEFINITION: {\n const inputType = typeFromAST(schema, node.type);\n\n this._inputTypeStack.push(\n isInputType(inputType) ? inputType : undefined,\n );\n\n break;\n }\n\n case Kind.ARGUMENT: {\n var _this$getDirective;\n\n let argDef;\n let argType;\n const fieldOrDirective =\n (_this$getDirective = this.getDirective()) !== null &&\n _this$getDirective !== void 0\n ? _this$getDirective\n : this.getFieldDef();\n\n if (fieldOrDirective) {\n argDef = fieldOrDirective.args.find(\n (arg) => arg.name === node.name.value,\n );\n\n if (argDef) {\n argType = argDef.type;\n }\n }\n\n this._argument = argDef;\n\n this._defaultValueStack.push(argDef ? argDef.defaultValue : undefined);\n\n this._inputTypeStack.push(isInputType(argType) ? argType : undefined);\n\n break;\n }\n\n case Kind.LIST: {\n const listType = getNullableType(this.getInputType());\n const itemType = isListType(listType) ? listType.ofType : listType; // List positions never have a default value.\n\n this._defaultValueStack.push(undefined);\n\n this._inputTypeStack.push(isInputType(itemType) ? itemType : undefined);\n\n break;\n }\n\n case Kind.OBJECT_FIELD: {\n const objectType = getNamedType(this.getInputType());\n let inputFieldType;\n let inputField;\n\n if (isInputObjectType(objectType)) {\n inputField = objectType.getFields()[node.name.value];\n\n if (inputField) {\n inputFieldType = inputField.type;\n }\n }\n\n this._defaultValueStack.push(\n inputField ? inputField.defaultValue : undefined,\n );\n\n this._inputTypeStack.push(\n isInputType(inputFieldType) ? inputFieldType : undefined,\n );\n\n break;\n }\n\n case Kind.ENUM: {\n const enumType = getNamedType(this.getInputType());\n let enumValue;\n\n if (isEnumType(enumType)) {\n enumValue = enumType.getValue(node.value);\n }\n\n this._enumValue = enumValue;\n break;\n }\n\n default: // Ignore other nodes\n }\n }\n\n leave(node) {\n switch (node.kind) {\n case Kind.SELECTION_SET:\n this._parentTypeStack.pop();\n\n break;\n\n case Kind.FIELD:\n this._fieldDefStack.pop();\n\n this._typeStack.pop();\n\n break;\n\n case Kind.DIRECTIVE:\n this._directive = null;\n break;\n\n case Kind.OPERATION_DEFINITION:\n case Kind.INLINE_FRAGMENT:\n case Kind.FRAGMENT_DEFINITION:\n this._typeStack.pop();\n\n break;\n\n case Kind.VARIABLE_DEFINITION:\n this._inputTypeStack.pop();\n\n break;\n\n case Kind.ARGUMENT:\n this._argument = null;\n\n this._defaultValueStack.pop();\n\n this._inputTypeStack.pop();\n\n break;\n\n case Kind.LIST:\n case Kind.OBJECT_FIELD:\n this._defaultValueStack.pop();\n\n this._inputTypeStack.pop();\n\n break;\n\n case Kind.ENUM:\n this._enumValue = null;\n break;\n\n default: // Ignore other nodes\n }\n }\n}\n\n/**\n * Not exactly the same as the executor's definition of getFieldDef, in this\n * statically evaluated environment we do not always have an Object type,\n * and need to handle Interface and Union types.\n */\nfunction getFieldDef(schema, parentType, fieldNode) {\n const name = fieldNode.name.value;\n\n if (\n name === SchemaMetaFieldDef.name &&\n schema.getQueryType() === parentType\n ) {\n return SchemaMetaFieldDef;\n }\n\n if (name === TypeMetaFieldDef.name && schema.getQueryType() === parentType) {\n return TypeMetaFieldDef;\n }\n\n if (name === TypeNameMetaFieldDef.name && isCompositeType(parentType)) {\n return TypeNameMetaFieldDef;\n }\n\n if (isObjectType(parentType) || isInterfaceType(parentType)) {\n return parentType.getFields()[name];\n }\n}\n/**\n * Creates a new visitor instance which maintains a provided TypeInfo instance\n * along with visiting visitor.\n */\n\nexport function visitWithTypeInfo(typeInfo, visitor) {\n return {\n enter(...args) {\n const node = args[0];\n typeInfo.enter(node);\n const fn = getEnterLeaveForKind(visitor, node.kind).enter;\n\n if (fn) {\n const result = fn.apply(visitor, args);\n\n if (result !== undefined) {\n typeInfo.leave(node);\n\n if (isNode(result)) {\n typeInfo.enter(result);\n }\n }\n\n return result;\n }\n },\n\n leave(...args) {\n const node = args[0];\n const fn = getEnterLeaveForKind(visitor, node.kind).leave;\n let result;\n\n if (fn) {\n result = fn.apply(visitor, args);\n }\n\n typeInfo.leave(node);\n return result;\n },\n };\n}\n","import { Kind } from './kinds.mjs';\nexport function isDefinitionNode(node) {\n return (\n isExecutableDefinitionNode(node) ||\n isTypeSystemDefinitionNode(node) ||\n isTypeSystemExtensionNode(node)\n );\n}\nexport function isExecutableDefinitionNode(node) {\n return (\n node.kind === Kind.OPERATION_DEFINITION ||\n node.kind === Kind.FRAGMENT_DEFINITION\n );\n}\nexport function isSelectionNode(node) {\n return (\n node.kind === Kind.FIELD ||\n node.kind === Kind.FRAGMENT_SPREAD ||\n node.kind === Kind.INLINE_FRAGMENT\n );\n}\nexport function isValueNode(node) {\n return (\n node.kind === Kind.VARIABLE ||\n node.kind === Kind.INT ||\n node.kind === Kind.FLOAT ||\n node.kind === Kind.STRING ||\n node.kind === Kind.BOOLEAN ||\n node.kind === Kind.NULL ||\n node.kind === Kind.ENUM ||\n node.kind === Kind.LIST ||\n node.kind === Kind.OBJECT\n );\n}\nexport function isConstValueNode(node) {\n return (\n isValueNode(node) &&\n (node.kind === Kind.LIST\n ? node.values.some(isConstValueNode)\n : node.kind === Kind.OBJECT\n ? node.fields.some((field) => isConstValueNode(field.value))\n : node.kind !== Kind.VARIABLE)\n );\n}\nexport function isTypeNode(node) {\n return (\n node.kind === Kind.NAMED_TYPE ||\n node.kind === Kind.LIST_TYPE ||\n node.kind === Kind.NON_NULL_TYPE\n );\n}\nexport function isTypeSystemDefinitionNode(node) {\n return (\n node.kind === Kind.SCHEMA_DEFINITION ||\n isTypeDefinitionNode(node) ||\n node.kind === Kind.DIRECTIVE_DEFINITION\n );\n}\nexport function isTypeDefinitionNode(node) {\n return (\n node.kind === Kind.SCALAR_TYPE_DEFINITION ||\n node.kind === Kind.OBJECT_TYPE_DEFINITION ||\n node.kind === Kind.INTERFACE_TYPE_DEFINITION ||\n node.kind === Kind.UNION_TYPE_DEFINITION ||\n node.kind === Kind.ENUM_TYPE_DEFINITION ||\n node.kind === Kind.INPUT_OBJECT_TYPE_DEFINITION\n );\n}\nexport function isTypeSystemExtensionNode(node) {\n return node.kind === Kind.SCHEMA_EXTENSION || isTypeExtensionNode(node);\n}\nexport function isTypeExtensionNode(node) {\n return (\n node.kind === Kind.SCALAR_TYPE_EXTENSION ||\n node.kind === Kind.OBJECT_TYPE_EXTENSION ||\n node.kind === Kind.INTERFACE_TYPE_EXTENSION ||\n node.kind === Kind.UNION_TYPE_EXTENSION ||\n node.kind === Kind.ENUM_TYPE_EXTENSION ||\n node.kind === Kind.INPUT_OBJECT_TYPE_EXTENSION\n );\n}\n","import { GraphQLError } from '../../error/GraphQLError.mjs';\nimport { Kind } from '../../language/kinds.mjs';\nimport { isExecutableDefinitionNode } from '../../language/predicates.mjs';\n\n/**\n * Executable definitions\n *\n * A GraphQL document is only valid for execution if all definitions are either\n * operation or fragment definitions.\n *\n * See https://spec.graphql.org/draft/#sec-Executable-Definitions\n */\nexport function ExecutableDefinitionsRule(context) {\n return {\n Document(node) {\n for (const definition of node.definitions) {\n if (!isExecutableDefinitionNode(definition)) {\n const defName =\n definition.kind === Kind.SCHEMA_DEFINITION ||\n definition.kind === Kind.SCHEMA_EXTENSION\n ? 'schema'\n : '\"' + definition.name.value + '\"';\n context.reportError(\n new GraphQLError(`The ${defName} definition is not executable.`, {\n nodes: definition,\n }),\n );\n }\n }\n\n return false;\n },\n };\n}\n","import { didYouMean } from '../../jsutils/didYouMean.mjs';\nimport { naturalCompare } from '../../jsutils/naturalCompare.mjs';\nimport { suggestionList } from '../../jsutils/suggestionList.mjs';\nimport { GraphQLError } from '../../error/GraphQLError.mjs';\nimport {\n isAbstractType,\n isInterfaceType,\n isObjectType,\n} from '../../type/definition.mjs';\n\n/**\n * Fields on correct type\n *\n * A GraphQL document is only valid if all fields selected are defined by the\n * parent type, or are an allowed meta field such as __typename.\n *\n * See https://spec.graphql.org/draft/#sec-Field-Selections\n */\nexport function FieldsOnCorrectTypeRule(context) {\n return {\n Field(node) {\n const type = context.getParentType();\n\n if (type) {\n const fieldDef = context.getFieldDef();\n\n if (!fieldDef) {\n // This field doesn't exist, lets look for suggestions.\n const schema = context.getSchema();\n const fieldName = node.name.value; // First determine if there are any suggested types to condition on.\n\n let suggestion = didYouMean(\n 'to use an inline fragment on',\n getSuggestedTypeNames(schema, type, fieldName),\n ); // If there are no suggested types, then perhaps this was a typo?\n\n if (suggestion === '') {\n suggestion = didYouMean(getSuggestedFieldNames(type, fieldName));\n } // Report an error, including helpful suggestions.\n\n context.reportError(\n new GraphQLError(\n `Cannot query field \"${fieldName}\" on type \"${type.name}\".` +\n suggestion,\n {\n nodes: node,\n },\n ),\n );\n }\n }\n },\n };\n}\n/**\n * Go through all of the implementations of type, as well as the interfaces that\n * they implement. If any of those types include the provided field, suggest them,\n * sorted by how often the type is referenced.\n */\n\nfunction getSuggestedTypeNames(schema, type, fieldName) {\n if (!isAbstractType(type)) {\n // Must be an Object type, which does not have possible fields.\n return [];\n }\n\n const suggestedTypes = new Set();\n const usageCount = Object.create(null);\n\n for (const possibleType of schema.getPossibleTypes(type)) {\n if (!possibleType.getFields()[fieldName]) {\n continue;\n } // This object type defines this field.\n\n suggestedTypes.add(possibleType);\n usageCount[possibleType.name] = 1;\n\n for (const possibleInterface of possibleType.getInterfaces()) {\n var _usageCount$possibleI;\n\n if (!possibleInterface.getFields()[fieldName]) {\n continue;\n } // This interface type defines this field.\n\n suggestedTypes.add(possibleInterface);\n usageCount[possibleInterface.name] =\n ((_usageCount$possibleI = usageCount[possibleInterface.name]) !==\n null && _usageCount$possibleI !== void 0\n ? _usageCount$possibleI\n : 0) + 1;\n }\n }\n\n return [...suggestedTypes]\n .sort((typeA, typeB) => {\n // Suggest both interface and object types based on how common they are.\n const usageCountDiff = usageCount[typeB.name] - usageCount[typeA.name];\n\n if (usageCountDiff !== 0) {\n return usageCountDiff;\n } // Suggest super types first followed by subtypes\n\n if (isInterfaceType(typeA) && schema.isSubType(typeA, typeB)) {\n return -1;\n }\n\n if (isInterfaceType(typeB) && schema.isSubType(typeB, typeA)) {\n return 1;\n }\n\n return naturalCompare(typeA.name, typeB.name);\n })\n .map((x) => x.name);\n}\n/**\n * For the field name provided, determine if there are any similar field names\n * that may be the result of a typo.\n */\n\nfunction getSuggestedFieldNames(type, fieldName) {\n if (isObjectType(type) || isInterfaceType(type)) {\n const possibleFieldNames = Object.keys(type.getFields());\n return suggestionList(fieldName, possibleFieldNames);\n } // Otherwise, must be a Union type, which does not define fields.\n\n return [];\n}\n","import { GraphQLError } from '../../error/GraphQLError.mjs';\nimport { print } from '../../language/printer.mjs';\nimport { isCompositeType } from '../../type/definition.mjs';\nimport { typeFromAST } from '../../utilities/typeFromAST.mjs';\n\n/**\n * Fragments on composite type\n *\n * Fragments use a type condition to determine if they apply, since fragments\n * can only be spread into a composite type (object, interface, or union), the\n * type condition must also be a composite type.\n *\n * See https://spec.graphql.org/draft/#sec-Fragments-On-Composite-Types\n */\nexport function FragmentsOnCompositeTypesRule(context) {\n return {\n InlineFragment(node) {\n const typeCondition = node.typeCondition;\n\n if (typeCondition) {\n const type = typeFromAST(context.getSchema(), typeCondition);\n\n if (type && !isCompositeType(type)) {\n const typeStr = print(typeCondition);\n context.reportError(\n new GraphQLError(\n `Fragment cannot condition on non composite type \"${typeStr}\".`,\n {\n nodes: typeCondition,\n },\n ),\n );\n }\n }\n },\n\n FragmentDefinition(node) {\n const type = typeFromAST(context.getSchema(), node.typeCondition);\n\n if (type && !isCompositeType(type)) {\n const typeStr = print(node.typeCondition);\n context.reportError(\n new GraphQLError(\n `Fragment \"${node.name.value}\" cannot condition on non composite type \"${typeStr}\".`,\n {\n nodes: node.typeCondition,\n },\n ),\n );\n }\n },\n };\n}\n","import { didYouMean } from '../../jsutils/didYouMean.mjs';\nimport { suggestionList } from '../../jsutils/suggestionList.mjs';\nimport { GraphQLError } from '../../error/GraphQLError.mjs';\nimport { Kind } from '../../language/kinds.mjs';\nimport { specifiedDirectives } from '../../type/directives.mjs';\n\n/**\n * Known argument names\n *\n * A GraphQL field is only valid if all supplied arguments are defined by\n * that field.\n *\n * See https://spec.graphql.org/draft/#sec-Argument-Names\n * See https://spec.graphql.org/draft/#sec-Directives-Are-In-Valid-Locations\n */\nexport function KnownArgumentNamesRule(context) {\n return {\n // eslint-disable-next-line new-cap\n ...KnownArgumentNamesOnDirectivesRule(context),\n\n Argument(argNode) {\n const argDef = context.getArgument();\n const fieldDef = context.getFieldDef();\n const parentType = context.getParentType();\n\n if (!argDef && fieldDef && parentType) {\n const argName = argNode.name.value;\n const knownArgsNames = fieldDef.args.map((arg) => arg.name);\n const suggestions = suggestionList(argName, knownArgsNames);\n context.reportError(\n new GraphQLError(\n `Unknown argument \"${argName}\" on field \"${parentType.name}.${fieldDef.name}\".` +\n didYouMean(suggestions),\n {\n nodes: argNode,\n },\n ),\n );\n }\n },\n };\n}\n/**\n * @internal\n */\n\nexport function KnownArgumentNamesOnDirectivesRule(context) {\n const directiveArgs = Object.create(null);\n const schema = context.getSchema();\n const definedDirectives = schema\n ? schema.getDirectives()\n : specifiedDirectives;\n\n for (const directive of definedDirectives) {\n directiveArgs[directive.name] = directive.args.map((arg) => arg.name);\n }\n\n const astDefinitions = context.getDocument().definitions;\n\n for (const def of astDefinitions) {\n if (def.kind === Kind.DIRECTIVE_DEFINITION) {\n var _def$arguments;\n\n // FIXME: https://github.com/graphql/graphql-js/issues/2203\n\n /* c8 ignore next */\n const argsNodes =\n (_def$arguments = def.arguments) !== null && _def$arguments !== void 0\n ? _def$arguments\n : [];\n directiveArgs[def.name.value] = argsNodes.map((arg) => arg.name.value);\n }\n }\n\n return {\n Directive(directiveNode) {\n const directiveName = directiveNode.name.value;\n const knownArgs = directiveArgs[directiveName];\n\n if (directiveNode.arguments && knownArgs) {\n for (const argNode of directiveNode.arguments) {\n const argName = argNode.name.value;\n\n if (!knownArgs.includes(argName)) {\n const suggestions = suggestionList(argName, knownArgs);\n context.reportError(\n new GraphQLError(\n `Unknown argument \"${argName}\" on directive \"@${directiveName}\".` +\n didYouMean(suggestions),\n {\n nodes: argNode,\n },\n ),\n );\n }\n }\n }\n\n return false;\n },\n };\n}\n","import { inspect } from '../../jsutils/inspect.mjs';\nimport { invariant } from '../../jsutils/invariant.mjs';\nimport { GraphQLError } from '../../error/GraphQLError.mjs';\nimport { OperationTypeNode } from '../../language/ast.mjs';\nimport { DirectiveLocation } from '../../language/directiveLocation.mjs';\nimport { Kind } from '../../language/kinds.mjs';\nimport { specifiedDirectives } from '../../type/directives.mjs';\n\n/**\n * Known directives\n *\n * A GraphQL document is only valid if all `@directives` are known by the\n * schema and legally positioned.\n *\n * See https://spec.graphql.org/draft/#sec-Directives-Are-Defined\n */\nexport function KnownDirectivesRule(context) {\n const locationsMap = Object.create(null);\n const schema = context.getSchema();\n const definedDirectives = schema\n ? schema.getDirectives()\n : specifiedDirectives;\n\n for (const directive of definedDirectives) {\n locationsMap[directive.name] = directive.locations;\n }\n\n const astDefinitions = context.getDocument().definitions;\n\n for (const def of astDefinitions) {\n if (def.kind === Kind.DIRECTIVE_DEFINITION) {\n locationsMap[def.name.value] = def.locations.map((name) => name.value);\n }\n }\n\n return {\n Directive(node, _key, _parent, _path, ancestors) {\n const name = node.name.value;\n const locations = locationsMap[name];\n\n if (!locations) {\n context.reportError(\n new GraphQLError(`Unknown directive \"@${name}\".`, {\n nodes: node,\n }),\n );\n return;\n }\n\n const candidateLocation = getDirectiveLocationForASTPath(ancestors);\n\n if (candidateLocation && !locations.includes(candidateLocation)) {\n context.reportError(\n new GraphQLError(\n `Directive \"@${name}\" may not be used on ${candidateLocation}.`,\n {\n nodes: node,\n },\n ),\n );\n }\n },\n };\n}\n\nfunction getDirectiveLocationForASTPath(ancestors) {\n const appliedTo = ancestors[ancestors.length - 1];\n 'kind' in appliedTo || invariant(false);\n\n switch (appliedTo.kind) {\n case Kind.OPERATION_DEFINITION:\n return getDirectiveLocationForOperation(appliedTo.operation);\n\n case Kind.FIELD:\n return DirectiveLocation.FIELD;\n\n case Kind.FRAGMENT_SPREAD:\n return DirectiveLocation.FRAGMENT_SPREAD;\n\n case Kind.INLINE_FRAGMENT:\n return DirectiveLocation.INLINE_FRAGMENT;\n\n case Kind.FRAGMENT_DEFINITION:\n return DirectiveLocation.FRAGMENT_DEFINITION;\n\n case Kind.VARIABLE_DEFINITION:\n return DirectiveLocation.VARIABLE_DEFINITION;\n\n case Kind.SCHEMA_DEFINITION:\n case Kind.SCHEMA_EXTENSION:\n return DirectiveLocation.SCHEMA;\n\n case Kind.SCALAR_TYPE_DEFINITION:\n case Kind.SCALAR_TYPE_EXTENSION:\n return DirectiveLocation.SCALAR;\n\n case Kind.OBJECT_TYPE_DEFINITION:\n case Kind.OBJECT_TYPE_EXTENSION:\n return DirectiveLocation.OBJECT;\n\n case Kind.FIELD_DEFINITION:\n return DirectiveLocation.FIELD_DEFINITION;\n\n case Kind.INTERFACE_TYPE_DEFINITION:\n case Kind.INTERFACE_TYPE_EXTENSION:\n return DirectiveLocation.INTERFACE;\n\n case Kind.UNION_TYPE_DEFINITION:\n case Kind.UNION_TYPE_EXTENSION:\n return DirectiveLocation.UNION;\n\n case Kind.ENUM_TYPE_DEFINITION:\n case Kind.ENUM_TYPE_EXTENSION:\n return DirectiveLocation.ENUM;\n\n case Kind.ENUM_VALUE_DEFINITION:\n return DirectiveLocation.ENUM_VALUE;\n\n case Kind.INPUT_OBJECT_TYPE_DEFINITION:\n case Kind.INPUT_OBJECT_TYPE_EXTENSION:\n return DirectiveLocation.INPUT_OBJECT;\n\n case Kind.INPUT_VALUE_DEFINITION: {\n const parentNode = ancestors[ancestors.length - 3];\n 'kind' in parentNode || invariant(false);\n return parentNode.kind === Kind.INPUT_OBJECT_TYPE_DEFINITION\n ? DirectiveLocation.INPUT_FIELD_DEFINITION\n : DirectiveLocation.ARGUMENT_DEFINITION;\n }\n // Not reachable, all possible types have been considered.\n\n /* c8 ignore next */\n\n default:\n false || invariant(false, 'Unexpected kind: ' + inspect(appliedTo.kind));\n }\n}\n\nfunction getDirectiveLocationForOperation(operation) {\n switch (operation) {\n case OperationTypeNode.QUERY:\n return DirectiveLocation.QUERY;\n\n case OperationTypeNode.MUTATION:\n return DirectiveLocation.MUTATION;\n\n case OperationTypeNode.SUBSCRIPTION:\n return DirectiveLocation.SUBSCRIPTION;\n }\n}\n","import { GraphQLError } from '../../error/GraphQLError.mjs';\n\n/**\n * Known fragment names\n *\n * A GraphQL document is only valid if all `...Fragment` fragment spreads refer\n * to fragments defined in the same document.\n *\n * See https://spec.graphql.org/draft/#sec-Fragment-spread-target-defined\n */\nexport function KnownFragmentNamesRule(context) {\n return {\n FragmentSpread(node) {\n const fragmentName = node.name.value;\n const fragment = context.getFragment(fragmentName);\n\n if (!fragment) {\n context.reportError(\n new GraphQLError(`Unknown fragment \"${fragmentName}\".`, {\n nodes: node.name,\n }),\n );\n }\n },\n };\n}\n","import { didYouMean } from '../../jsutils/didYouMean.mjs';\nimport { suggestionList } from '../../jsutils/suggestionList.mjs';\nimport { GraphQLError } from '../../error/GraphQLError.mjs';\nimport {\n isTypeDefinitionNode,\n isTypeSystemDefinitionNode,\n isTypeSystemExtensionNode,\n} from '../../language/predicates.mjs';\nimport { introspectionTypes } from '../../type/introspection.mjs';\nimport { specifiedScalarTypes } from '../../type/scalars.mjs';\n\n/**\n * Known type names\n *\n * A GraphQL document is only valid if referenced types (specifically\n * variable definitions and fragment conditions) are defined by the type schema.\n *\n * See https://spec.graphql.org/draft/#sec-Fragment-Spread-Type-Existence\n */\nexport function KnownTypeNamesRule(context) {\n const schema = context.getSchema();\n const existingTypesMap = schema ? schema.getTypeMap() : Object.create(null);\n const definedTypes = Object.create(null);\n\n for (const def of context.getDocument().definitions) {\n if (isTypeDefinitionNode(def)) {\n definedTypes[def.name.value] = true;\n }\n }\n\n const typeNames = [\n ...Object.keys(existingTypesMap),\n ...Object.keys(definedTypes),\n ];\n return {\n NamedType(node, _1, parent, _2, ancestors) {\n const typeName = node.name.value;\n\n if (!existingTypesMap[typeName] && !definedTypes[typeName]) {\n var _ancestors$;\n\n const definitionNode =\n (_ancestors$ = ancestors[2]) !== null && _ancestors$ !== void 0\n ? _ancestors$\n : parent;\n const isSDL = definitionNode != null && isSDLNode(definitionNode);\n\n if (isSDL && standardTypeNames.includes(typeName)) {\n return;\n }\n\n const suggestedTypes = suggestionList(\n typeName,\n isSDL ? standardTypeNames.concat(typeNames) : typeNames,\n );\n context.reportError(\n new GraphQLError(\n `Unknown type \"${typeName}\".` + didYouMean(suggestedTypes),\n {\n nodes: node,\n },\n ),\n );\n }\n },\n };\n}\nconst standardTypeNames = [...specifiedScalarTypes, ...introspectionTypes].map(\n (type) => type.name,\n);\n\nfunction isSDLNode(value) {\n return (\n 'kind' in value &&\n (isTypeSystemDefinitionNode(value) || isTypeSystemExtensionNode(value))\n );\n}\n","import { GraphQLError } from '../../error/GraphQLError.mjs';\nimport { Kind } from '../../language/kinds.mjs';\n\n/**\n * Lone anonymous operation\n *\n * A GraphQL document is only valid if when it contains an anonymous operation\n * (the query short-hand) that it contains only that one operation definition.\n *\n * See https://spec.graphql.org/draft/#sec-Lone-Anonymous-Operation\n */\nexport function LoneAnonymousOperationRule(context) {\n let operationCount = 0;\n return {\n Document(node) {\n operationCount = node.definitions.filter(\n (definition) => definition.kind === Kind.OPERATION_DEFINITION,\n ).length;\n },\n\n OperationDefinition(node) {\n if (!node.name && operationCount > 1) {\n context.reportError(\n new GraphQLError(\n 'This anonymous operation must be the only defined operation.',\n {\n nodes: node,\n },\n ),\n );\n }\n },\n };\n}\n","import { GraphQLError } from '../../error/GraphQLError.mjs';\n\n/**\n * Lone Schema definition\n *\n * A GraphQL document is only valid if it contains only one schema definition.\n */\nexport function LoneSchemaDefinitionRule(context) {\n var _ref, _ref2, _oldSchema$astNode;\n\n const oldSchema = context.getSchema();\n const alreadyDefined =\n (_ref =\n (_ref2 =\n (_oldSchema$astNode =\n oldSchema === null || oldSchema === void 0\n ? void 0\n : oldSchema.astNode) !== null && _oldSchema$astNode !== void 0\n ? _oldSchema$astNode\n : oldSchema === null || oldSchema === void 0\n ? void 0\n : oldSchema.getQueryType()) !== null && _ref2 !== void 0\n ? _ref2\n : oldSchema === null || oldSchema === void 0\n ? void 0\n : oldSchema.getMutationType()) !== null && _ref !== void 0\n ? _ref\n : oldSchema === null || oldSchema === void 0\n ? void 0\n : oldSchema.getSubscriptionType();\n let schemaDefinitionsCount = 0;\n return {\n SchemaDefinition(node) {\n if (alreadyDefined) {\n context.reportError(\n new GraphQLError(\n 'Cannot define a new schema within a schema extension.',\n {\n nodes: node,\n },\n ),\n );\n return;\n }\n\n if (schemaDefinitionsCount > 0) {\n context.reportError(\n new GraphQLError('Must provide only one schema definition.', {\n nodes: node,\n }),\n );\n }\n\n ++schemaDefinitionsCount;\n },\n };\n}\n","import { GraphQLError } from '../../error/GraphQLError.mjs';\n\n/**\n * No fragment cycles\n *\n * The graph of fragment spreads must not form any cycles including spreading itself.\n * Otherwise an operation could infinitely spread or infinitely execute on cycles in the underlying data.\n *\n * See https://spec.graphql.org/draft/#sec-Fragment-spreads-must-not-form-cycles\n */\nexport function NoFragmentCyclesRule(context) {\n // Tracks already visited fragments to maintain O(N) and to ensure that cycles\n // are not redundantly reported.\n const visitedFrags = Object.create(null); // Array of AST nodes used to produce meaningful errors\n\n const spreadPath = []; // Position in the spread path\n\n const spreadPathIndexByName = Object.create(null);\n return {\n OperationDefinition: () => false,\n\n FragmentDefinition(node) {\n detectCycleRecursive(node);\n return false;\n },\n }; // This does a straight-forward DFS to find cycles.\n // It does not terminate when a cycle was found but continues to explore\n // the graph to find all possible cycles.\n\n function detectCycleRecursive(fragment) {\n if (visitedFrags[fragment.name.value]) {\n return;\n }\n\n const fragmentName = fragment.name.value;\n visitedFrags[fragmentName] = true;\n const spreadNodes = context.getFragmentSpreads(fragment.selectionSet);\n\n if (spreadNodes.length === 0) {\n return;\n }\n\n spreadPathIndexByName[fragmentName] = spreadPath.length;\n\n for (const spreadNode of spreadNodes) {\n const spreadName = spreadNode.name.value;\n const cycleIndex = spreadPathIndexByName[spreadName];\n spreadPath.push(spreadNode);\n\n if (cycleIndex === undefined) {\n const spreadFragment = context.getFragment(spreadName);\n\n if (spreadFragment) {\n detectCycleRecursive(spreadFragment);\n }\n } else {\n const cyclePath = spreadPath.slice(cycleIndex);\n const viaPath = cyclePath\n .slice(0, -1)\n .map((s) => '\"' + s.name.value + '\"')\n .join(', ');\n context.reportError(\n new GraphQLError(\n `Cannot spread fragment \"${spreadName}\" within itself` +\n (viaPath !== '' ? ` via ${viaPath}.` : '.'),\n {\n nodes: cyclePath,\n },\n ),\n );\n }\n\n spreadPath.pop();\n }\n\n spreadPathIndexByName[fragmentName] = undefined;\n }\n}\n","import { GraphQLError } from '../../error/GraphQLError.mjs';\n\n/**\n * No undefined variables\n *\n * A GraphQL operation is only valid if all variables encountered, both directly\n * and via fragment spreads, are defined by that operation.\n *\n * See https://spec.graphql.org/draft/#sec-All-Variable-Uses-Defined\n */\nexport function NoUndefinedVariablesRule(context) {\n let variableNameDefined = Object.create(null);\n return {\n OperationDefinition: {\n enter() {\n variableNameDefined = Object.create(null);\n },\n\n leave(operation) {\n const usages = context.getRecursiveVariableUsages(operation);\n\n for (const { node } of usages) {\n const varName = node.name.value;\n\n if (variableNameDefined[varName] !== true) {\n context.reportError(\n new GraphQLError(\n operation.name\n ? `Variable \"$${varName}\" is not defined by operation \"${operation.name.value}\".`\n : `Variable \"$${varName}\" is not defined.`,\n {\n nodes: [node, operation],\n },\n ),\n );\n }\n }\n },\n },\n\n VariableDefinition(node) {\n variableNameDefined[node.variable.name.value] = true;\n },\n };\n}\n","import { GraphQLError } from '../../error/GraphQLError.mjs';\n\n/**\n * No unused fragments\n *\n * A GraphQL document is only valid if all fragment definitions are spread\n * within operations, or spread within other fragments spread within operations.\n *\n * See https://spec.graphql.org/draft/#sec-Fragments-Must-Be-Used\n */\nexport function NoUnusedFragmentsRule(context) {\n const operationDefs = [];\n const fragmentDefs = [];\n return {\n OperationDefinition(node) {\n operationDefs.push(node);\n return false;\n },\n\n FragmentDefinition(node) {\n fragmentDefs.push(node);\n return false;\n },\n\n Document: {\n leave() {\n const fragmentNameUsed = Object.create(null);\n\n for (const operation of operationDefs) {\n for (const fragment of context.getRecursivelyReferencedFragments(\n operation,\n )) {\n fragmentNameUsed[fragment.name.value] = true;\n }\n }\n\n for (const fragmentDef of fragmentDefs) {\n const fragName = fragmentDef.name.value;\n\n if (fragmentNameUsed[fragName] !== true) {\n context.reportError(\n new GraphQLError(`Fragment \"${fragName}\" is never used.`, {\n nodes: fragmentDef,\n }),\n );\n }\n }\n },\n },\n };\n}\n","import { GraphQLError } from '../../error/GraphQLError.mjs';\n\n/**\n * No unused variables\n *\n * A GraphQL operation is only valid if all variables defined by an operation\n * are used, either directly or within a spread fragment.\n *\n * See https://spec.graphql.org/draft/#sec-All-Variables-Used\n */\nexport function NoUnusedVariablesRule(context) {\n let variableDefs = [];\n return {\n OperationDefinition: {\n enter() {\n variableDefs = [];\n },\n\n leave(operation) {\n const variableNameUsed = Object.create(null);\n const usages = context.getRecursiveVariableUsages(operation);\n\n for (const { node } of usages) {\n variableNameUsed[node.name.value] = true;\n }\n\n for (const variableDef of variableDefs) {\n const variableName = variableDef.variable.name.value;\n\n if (variableNameUsed[variableName] !== true) {\n context.reportError(\n new GraphQLError(\n operation.name\n ? `Variable \"$${variableName}\" is never used in operation \"${operation.name.value}\".`\n : `Variable \"$${variableName}\" is never used.`,\n {\n nodes: variableDef,\n },\n ),\n );\n }\n }\n },\n },\n\n VariableDefinition(def) {\n variableDefs.push(def);\n },\n };\n}\n","import { naturalCompare } from '../jsutils/naturalCompare.mjs';\nimport { Kind } from '../language/kinds.mjs';\n/**\n * Sort ValueNode.\n *\n * This function returns a sorted copy of the given ValueNode.\n *\n * @internal\n */\n\nexport function sortValueNode(valueNode) {\n switch (valueNode.kind) {\n case Kind.OBJECT:\n return { ...valueNode, fields: sortFields(valueNode.fields) };\n\n case Kind.LIST:\n return { ...valueNode, values: valueNode.values.map(sortValueNode) };\n\n case Kind.INT:\n case Kind.FLOAT:\n case Kind.STRING:\n case Kind.BOOLEAN:\n case Kind.NULL:\n case Kind.ENUM:\n case Kind.VARIABLE:\n return valueNode;\n }\n}\n\nfunction sortFields(fields) {\n return fields\n .map((fieldNode) => ({\n ...fieldNode,\n value: sortValueNode(fieldNode.value),\n }))\n .sort((fieldA, fieldB) =>\n naturalCompare(fieldA.name.value, fieldB.name.value),\n );\n}\n","import { inspect } from '../../jsutils/inspect.mjs';\nimport { GraphQLError } from '../../error/GraphQLError.mjs';\nimport { Kind } from '../../language/kinds.mjs';\nimport { print } from '../../language/printer.mjs';\nimport {\n getNamedType,\n isInterfaceType,\n isLeafType,\n isListType,\n isNonNullType,\n isObjectType,\n} from '../../type/definition.mjs';\nimport { sortValueNode } from '../../utilities/sortValueNode.mjs';\nimport { typeFromAST } from '../../utilities/typeFromAST.mjs';\n\nfunction reasonMessage(reason) {\n if (Array.isArray(reason)) {\n return reason\n .map(\n ([responseName, subReason]) =>\n `subfields \"${responseName}\" conflict because ` +\n reasonMessage(subReason),\n )\n .join(' and ');\n }\n\n return reason;\n}\n/**\n * Overlapping fields can be merged\n *\n * A selection set is only valid if all fields (including spreading any\n * fragments) either correspond to distinct response names or can be merged\n * without ambiguity.\n *\n * See https://spec.graphql.org/draft/#sec-Field-Selection-Merging\n */\n\nexport function OverlappingFieldsCanBeMergedRule(context) {\n // A memoization for when two fragments are compared \"between\" each other for\n // conflicts. Two fragments may be compared many times, so memoizing this can\n // dramatically improve the performance of this validator.\n const comparedFragmentPairs = new PairSet(); // A cache for the \"field map\" and list of fragment names found in any given\n // selection set. Selection sets may be asked for this information multiple\n // times, so this improves the performance of this validator.\n\n const cachedFieldsAndFragmentNames = new Map();\n return {\n SelectionSet(selectionSet) {\n const conflicts = findConflictsWithinSelectionSet(\n context,\n cachedFieldsAndFragmentNames,\n comparedFragmentPairs,\n context.getParentType(),\n selectionSet,\n );\n\n for (const [[responseName, reason], fields1, fields2] of conflicts) {\n const reasonMsg = reasonMessage(reason);\n context.reportError(\n new GraphQLError(\n `Fields \"${responseName}\" conflict because ${reasonMsg}. Use different aliases on the fields to fetch both if this was intentional.`,\n {\n nodes: fields1.concat(fields2),\n },\n ),\n );\n }\n },\n };\n}\n\n/**\n * Algorithm:\n *\n * Conflicts occur when two fields exist in a query which will produce the same\n * response name, but represent differing values, thus creating a conflict.\n * The algorithm below finds all conflicts via making a series of comparisons\n * between fields. In order to compare as few fields as possible, this makes\n * a series of comparisons \"within\" sets of fields and \"between\" sets of fields.\n *\n * Given any selection set, a collection produces both a set of fields by\n * also including all inline fragments, as well as a list of fragments\n * referenced by fragment spreads.\n *\n * A) Each selection set represented in the document first compares \"within\" its\n * collected set of fields, finding any conflicts between every pair of\n * overlapping fields.\n * Note: This is the *only time* that a the fields \"within\" a set are compared\n * to each other. After this only fields \"between\" sets are compared.\n *\n * B) Also, if any fragment is referenced in a selection set, then a\n * comparison is made \"between\" the original set of fields and the\n * referenced fragment.\n *\n * C) Also, if multiple fragments are referenced, then comparisons\n * are made \"between\" each referenced fragment.\n *\n * D) When comparing \"between\" a set of fields and a referenced fragment, first\n * a comparison is made between each field in the original set of fields and\n * each field in the the referenced set of fields.\n *\n * E) Also, if any fragment is referenced in the referenced selection set,\n * then a comparison is made \"between\" the original set of fields and the\n * referenced fragment (recursively referring to step D).\n *\n * F) When comparing \"between\" two fragments, first a comparison is made between\n * each field in the first referenced set of fields and each field in the the\n * second referenced set of fields.\n *\n * G) Also, any fragments referenced by the first must be compared to the\n * second, and any fragments referenced by the second must be compared to the\n * first (recursively referring to step F).\n *\n * H) When comparing two fields, if both have selection sets, then a comparison\n * is made \"between\" both selection sets, first comparing the set of fields in\n * the first selection set with the set of fields in the second.\n *\n * I) Also, if any fragment is referenced in either selection set, then a\n * comparison is made \"between\" the other set of fields and the\n * referenced fragment.\n *\n * J) Also, if two fragments are referenced in both selection sets, then a\n * comparison is made \"between\" the two fragments.\n *\n */\n// Find all conflicts found \"within\" a selection set, including those found\n// via spreading in fragments. Called when visiting each SelectionSet in the\n// GraphQL Document.\nfunction findConflictsWithinSelectionSet(\n context,\n cachedFieldsAndFragmentNames,\n comparedFragmentPairs,\n parentType,\n selectionSet,\n) {\n const conflicts = [];\n const [fieldMap, fragmentNames] = getFieldsAndFragmentNames(\n context,\n cachedFieldsAndFragmentNames,\n parentType,\n selectionSet,\n ); // (A) Find find all conflicts \"within\" the fields of this selection set.\n // Note: this is the *only place* `collectConflictsWithin` is called.\n\n collectConflictsWithin(\n context,\n conflicts,\n cachedFieldsAndFragmentNames,\n comparedFragmentPairs,\n fieldMap,\n );\n\n if (fragmentNames.length !== 0) {\n // (B) Then collect conflicts between these fields and those represented by\n // each spread fragment name found.\n for (let i = 0; i < fragmentNames.length; i++) {\n collectConflictsBetweenFieldsAndFragment(\n context,\n conflicts,\n cachedFieldsAndFragmentNames,\n comparedFragmentPairs,\n false,\n fieldMap,\n fragmentNames[i],\n ); // (C) Then compare this fragment with all other fragments found in this\n // selection set to collect conflicts between fragments spread together.\n // This compares each item in the list of fragment names to every other\n // item in that same list (except for itself).\n\n for (let j = i + 1; j < fragmentNames.length; j++) {\n collectConflictsBetweenFragments(\n context,\n conflicts,\n cachedFieldsAndFragmentNames,\n comparedFragmentPairs,\n false,\n fragmentNames[i],\n fragmentNames[j],\n );\n }\n }\n }\n\n return conflicts;\n} // Collect all conflicts found between a set of fields and a fragment reference\n// including via spreading in any nested fragments.\n\nfunction collectConflictsBetweenFieldsAndFragment(\n context,\n conflicts,\n cachedFieldsAndFragmentNames,\n comparedFragmentPairs,\n areMutuallyExclusive,\n fieldMap,\n fragmentName,\n) {\n const fragment = context.getFragment(fragmentName);\n\n if (!fragment) {\n return;\n }\n\n const [fieldMap2, referencedFragmentNames] =\n getReferencedFieldsAndFragmentNames(\n context,\n cachedFieldsAndFragmentNames,\n fragment,\n ); // Do not compare a fragment's fieldMap to itself.\n\n if (fieldMap === fieldMap2) {\n return;\n } // (D) First collect any conflicts between the provided collection of fields\n // and the collection of fields represented by the given fragment.\n\n collectConflictsBetween(\n context,\n conflicts,\n cachedFieldsAndFragmentNames,\n comparedFragmentPairs,\n areMutuallyExclusive,\n fieldMap,\n fieldMap2,\n ); // (E) Then collect any conflicts between the provided collection of fields\n // and any fragment names found in the given fragment.\n\n for (const referencedFragmentName of referencedFragmentNames) {\n // Memoize so two fragments are not compared for conflicts more than once.\n if (\n comparedFragmentPairs.has(\n referencedFragmentName,\n fragmentName,\n areMutuallyExclusive,\n )\n ) {\n continue;\n }\n\n comparedFragmentPairs.add(\n referencedFragmentName,\n fragmentName,\n areMutuallyExclusive,\n );\n collectConflictsBetweenFieldsAndFragment(\n context,\n conflicts,\n cachedFieldsAndFragmentNames,\n comparedFragmentPairs,\n areMutuallyExclusive,\n fieldMap,\n referencedFragmentName,\n );\n }\n} // Collect all conflicts found between two fragments, including via spreading in\n// any nested fragments.\n\nfunction collectConflictsBetweenFragments(\n context,\n conflicts,\n cachedFieldsAndFragmentNames,\n comparedFragmentPairs,\n areMutuallyExclusive,\n fragmentName1,\n fragmentName2,\n) {\n // No need to compare a fragment to itself.\n if (fragmentName1 === fragmentName2) {\n return;\n } // Memoize so two fragments are not compared for conflicts more than once.\n\n if (\n comparedFragmentPairs.has(\n fragmentName1,\n fragmentName2,\n areMutuallyExclusive,\n )\n ) {\n return;\n }\n\n comparedFragmentPairs.add(fragmentName1, fragmentName2, areMutuallyExclusive);\n const fragment1 = context.getFragment(fragmentName1);\n const fragment2 = context.getFragment(fragmentName2);\n\n if (!fragment1 || !fragment2) {\n return;\n }\n\n const [fieldMap1, referencedFragmentNames1] =\n getReferencedFieldsAndFragmentNames(\n context,\n cachedFieldsAndFragmentNames,\n fragment1,\n );\n const [fieldMap2, referencedFragmentNames2] =\n getReferencedFieldsAndFragmentNames(\n context,\n cachedFieldsAndFragmentNames,\n fragment2,\n ); // (F) First, collect all conflicts between these two collections of fields\n // (not including any nested fragments).\n\n collectConflictsBetween(\n context,\n conflicts,\n cachedFieldsAndFragmentNames,\n comparedFragmentPairs,\n areMutuallyExclusive,\n fieldMap1,\n fieldMap2,\n ); // (G) Then collect conflicts between the first fragment and any nested\n // fragments spread in the second fragment.\n\n for (const referencedFragmentName2 of referencedFragmentNames2) {\n collectConflictsBetweenFragments(\n context,\n conflicts,\n cachedFieldsAndFragmentNames,\n comparedFragmentPairs,\n areMutuallyExclusive,\n fragmentName1,\n referencedFragmentName2,\n );\n } // (G) Then collect conflicts between the second fragment and any nested\n // fragments spread in the first fragment.\n\n for (const referencedFragmentName1 of referencedFragmentNames1) {\n collectConflictsBetweenFragments(\n context,\n conflicts,\n cachedFieldsAndFragmentNames,\n comparedFragmentPairs,\n areMutuallyExclusive,\n referencedFragmentName1,\n fragmentName2,\n );\n }\n} // Find all conflicts found between two selection sets, including those found\n// via spreading in fragments. Called when determining if conflicts exist\n// between the sub-fields of two overlapping fields.\n\nfunction findConflictsBetweenSubSelectionSets(\n context,\n cachedFieldsAndFragmentNames,\n comparedFragmentPairs,\n areMutuallyExclusive,\n parentType1,\n selectionSet1,\n parentType2,\n selectionSet2,\n) {\n const conflicts = [];\n const [fieldMap1, fragmentNames1] = getFieldsAndFragmentNames(\n context,\n cachedFieldsAndFragmentNames,\n parentType1,\n selectionSet1,\n );\n const [fieldMap2, fragmentNames2] = getFieldsAndFragmentNames(\n context,\n cachedFieldsAndFragmentNames,\n parentType2,\n selectionSet2,\n ); // (H) First, collect all conflicts between these two collections of field.\n\n collectConflictsBetween(\n context,\n conflicts,\n cachedFieldsAndFragmentNames,\n comparedFragmentPairs,\n areMutuallyExclusive,\n fieldMap1,\n fieldMap2,\n ); // (I) Then collect conflicts between the first collection of fields and\n // those referenced by each fragment name associated with the second.\n\n for (const fragmentName2 of fragmentNames2) {\n collectConflictsBetweenFieldsAndFragment(\n context,\n conflicts,\n cachedFieldsAndFragmentNames,\n comparedFragmentPairs,\n areMutuallyExclusive,\n fieldMap1,\n fragmentName2,\n );\n } // (I) Then collect conflicts between the second collection of fields and\n // those referenced by each fragment name associated with the first.\n\n for (const fragmentName1 of fragmentNames1) {\n collectConflictsBetweenFieldsAndFragment(\n context,\n conflicts,\n cachedFieldsAndFragmentNames,\n comparedFragmentPairs,\n areMutuallyExclusive,\n fieldMap2,\n fragmentName1,\n );\n } // (J) Also collect conflicts between any fragment names by the first and\n // fragment names by the second. This compares each item in the first set of\n // names to each item in the second set of names.\n\n for (const fragmentName1 of fragmentNames1) {\n for (const fragmentName2 of fragmentNames2) {\n collectConflictsBetweenFragments(\n context,\n conflicts,\n cachedFieldsAndFragmentNames,\n comparedFragmentPairs,\n areMutuallyExclusive,\n fragmentName1,\n fragmentName2,\n );\n }\n }\n\n return conflicts;\n} // Collect all Conflicts \"within\" one collection of fields.\n\nfunction collectConflictsWithin(\n context,\n conflicts,\n cachedFieldsAndFragmentNames,\n comparedFragmentPairs,\n fieldMap,\n) {\n // A field map is a keyed collection, where each key represents a response\n // name and the value at that key is a list of all fields which provide that\n // response name. For every response name, if there are multiple fields, they\n // must be compared to find a potential conflict.\n for (const [responseName, fields] of Object.entries(fieldMap)) {\n // This compares every field in the list to every other field in this list\n // (except to itself). If the list only has one item, nothing needs to\n // be compared.\n if (fields.length > 1) {\n for (let i = 0; i < fields.length; i++) {\n for (let j = i + 1; j < fields.length; j++) {\n const conflict = findConflict(\n context,\n cachedFieldsAndFragmentNames,\n comparedFragmentPairs,\n false, // within one collection is never mutually exclusive\n responseName,\n fields[i],\n fields[j],\n );\n\n if (conflict) {\n conflicts.push(conflict);\n }\n }\n }\n }\n }\n} // Collect all Conflicts between two collections of fields. This is similar to,\n// but different from the `collectConflictsWithin` function above. This check\n// assumes that `collectConflictsWithin` has already been called on each\n// provided collection of fields. This is true because this validator traverses\n// each individual selection set.\n\nfunction collectConflictsBetween(\n context,\n conflicts,\n cachedFieldsAndFragmentNames,\n comparedFragmentPairs,\n parentFieldsAreMutuallyExclusive,\n fieldMap1,\n fieldMap2,\n) {\n // A field map is a keyed collection, where each key represents a response\n // name and the value at that key is a list of all fields which provide that\n // response name. For any response name which appears in both provided field\n // maps, each field from the first field map must be compared to every field\n // in the second field map to find potential conflicts.\n for (const [responseName, fields1] of Object.entries(fieldMap1)) {\n const fields2 = fieldMap2[responseName];\n\n if (fields2) {\n for (const field1 of fields1) {\n for (const field2 of fields2) {\n const conflict = findConflict(\n context,\n cachedFieldsAndFragmentNames,\n comparedFragmentPairs,\n parentFieldsAreMutuallyExclusive,\n responseName,\n field1,\n field2,\n );\n\n if (conflict) {\n conflicts.push(conflict);\n }\n }\n }\n }\n }\n} // Determines if there is a conflict between two particular fields, including\n// comparing their sub-fields.\n\nfunction findConflict(\n context,\n cachedFieldsAndFragmentNames,\n comparedFragmentPairs,\n parentFieldsAreMutuallyExclusive,\n responseName,\n field1,\n field2,\n) {\n const [parentType1, node1, def1] = field1;\n const [parentType2, node2, def2] = field2; // If it is known that two fields could not possibly apply at the same\n // time, due to the parent types, then it is safe to permit them to diverge\n // in aliased field or arguments used as they will not present any ambiguity\n // by differing.\n // It is known that two parent types could never overlap if they are\n // different Object types. Interface or Union types might overlap - if not\n // in the current state of the schema, then perhaps in some future version,\n // thus may not safely diverge.\n\n const areMutuallyExclusive =\n parentFieldsAreMutuallyExclusive ||\n (parentType1 !== parentType2 &&\n isObjectType(parentType1) &&\n isObjectType(parentType2));\n\n if (!areMutuallyExclusive) {\n // Two aliases must refer to the same field.\n const name1 = node1.name.value;\n const name2 = node2.name.value;\n\n if (name1 !== name2) {\n return [\n [responseName, `\"${name1}\" and \"${name2}\" are different fields`],\n [node1],\n [node2],\n ];\n } // Two field calls must have the same arguments.\n\n if (!sameArguments(node1, node2)) {\n return [\n [responseName, 'they have differing arguments'],\n [node1],\n [node2],\n ];\n }\n } // The return type for each field.\n\n const type1 = def1 === null || def1 === void 0 ? void 0 : def1.type;\n const type2 = def2 === null || def2 === void 0 ? void 0 : def2.type;\n\n if (type1 && type2 && doTypesConflict(type1, type2)) {\n return [\n [\n responseName,\n `they return conflicting types \"${inspect(type1)}\" and \"${inspect(\n type2,\n )}\"`,\n ],\n [node1],\n [node2],\n ];\n } // Collect and compare sub-fields. Use the same \"visited fragment names\" list\n // for both collections so fields in a fragment reference are never\n // compared to themselves.\n\n const selectionSet1 = node1.selectionSet;\n const selectionSet2 = node2.selectionSet;\n\n if (selectionSet1 && selectionSet2) {\n const conflicts = findConflictsBetweenSubSelectionSets(\n context,\n cachedFieldsAndFragmentNames,\n comparedFragmentPairs,\n areMutuallyExclusive,\n getNamedType(type1),\n selectionSet1,\n getNamedType(type2),\n selectionSet2,\n );\n return subfieldConflicts(conflicts, responseName, node1, node2);\n }\n}\n\nfunction sameArguments(node1, node2) {\n const args1 = node1.arguments;\n const args2 = node2.arguments;\n\n if (args1 === undefined || args1.length === 0) {\n return args2 === undefined || args2.length === 0;\n }\n\n if (args2 === undefined || args2.length === 0) {\n return false;\n }\n /* c8 ignore next */\n\n if (args1.length !== args2.length) {\n /* c8 ignore next */\n return false;\n /* c8 ignore next */\n }\n\n const values2 = new Map(args2.map(({ name, value }) => [name.value, value]));\n return args1.every((arg1) => {\n const value1 = arg1.value;\n const value2 = values2.get(arg1.name.value);\n\n if (value2 === undefined) {\n return false;\n }\n\n return stringifyValue(value1) === stringifyValue(value2);\n });\n}\n\nfunction stringifyValue(value) {\n return print(sortValueNode(value));\n} // Two types conflict if both types could not apply to a value simultaneously.\n// Composite types are ignored as their individual field types will be compared\n// later recursively. However List and Non-Null types must match.\n\nfunction doTypesConflict(type1, type2) {\n if (isListType(type1)) {\n return isListType(type2)\n ? doTypesConflict(type1.ofType, type2.ofType)\n : true;\n }\n\n if (isListType(type2)) {\n return true;\n }\n\n if (isNonNullType(type1)) {\n return isNonNullType(type2)\n ? doTypesConflict(type1.ofType, type2.ofType)\n : true;\n }\n\n if (isNonNullType(type2)) {\n return true;\n }\n\n if (isLeafType(type1) || isLeafType(type2)) {\n return type1 !== type2;\n }\n\n return false;\n} // Given a selection set, return the collection of fields (a mapping of response\n// name to field nodes and definitions) as well as a list of fragment names\n// referenced via fragment spreads.\n\nfunction getFieldsAndFragmentNames(\n context,\n cachedFieldsAndFragmentNames,\n parentType,\n selectionSet,\n) {\n const cached = cachedFieldsAndFragmentNames.get(selectionSet);\n\n if (cached) {\n return cached;\n }\n\n const nodeAndDefs = Object.create(null);\n const fragmentNames = Object.create(null);\n\n _collectFieldsAndFragmentNames(\n context,\n parentType,\n selectionSet,\n nodeAndDefs,\n fragmentNames,\n );\n\n const result = [nodeAndDefs, Object.keys(fragmentNames)];\n cachedFieldsAndFragmentNames.set(selectionSet, result);\n return result;\n} // Given a reference to a fragment, return the represented collection of fields\n// as well as a list of nested fragment names referenced via fragment spreads.\n\nfunction getReferencedFieldsAndFragmentNames(\n context,\n cachedFieldsAndFragmentNames,\n fragment,\n) {\n // Short-circuit building a type from the node if possible.\n const cached = cachedFieldsAndFragmentNames.get(fragment.selectionSet);\n\n if (cached) {\n return cached;\n }\n\n const fragmentType = typeFromAST(context.getSchema(), fragment.typeCondition);\n return getFieldsAndFragmentNames(\n context,\n cachedFieldsAndFragmentNames,\n fragmentType,\n fragment.selectionSet,\n );\n}\n\nfunction _collectFieldsAndFragmentNames(\n context,\n parentType,\n selectionSet,\n nodeAndDefs,\n fragmentNames,\n) {\n for (const selection of selectionSet.selections) {\n switch (selection.kind) {\n case Kind.FIELD: {\n const fieldName = selection.name.value;\n let fieldDef;\n\n if (isObjectType(parentType) || isInterfaceType(parentType)) {\n fieldDef = parentType.getFields()[fieldName];\n }\n\n const responseName = selection.alias\n ? selection.alias.value\n : fieldName;\n\n if (!nodeAndDefs[responseName]) {\n nodeAndDefs[responseName] = [];\n }\n\n nodeAndDefs[responseName].push([parentType, selection, fieldDef]);\n break;\n }\n\n case Kind.FRAGMENT_SPREAD:\n fragmentNames[selection.name.value] = true;\n break;\n\n case Kind.INLINE_FRAGMENT: {\n const typeCondition = selection.typeCondition;\n const inlineFragmentType = typeCondition\n ? typeFromAST(context.getSchema(), typeCondition)\n : parentType;\n\n _collectFieldsAndFragmentNames(\n context,\n inlineFragmentType,\n selection.selectionSet,\n nodeAndDefs,\n fragmentNames,\n );\n\n break;\n }\n }\n }\n} // Given a series of Conflicts which occurred between two sub-fields, generate\n// a single Conflict.\n\nfunction subfieldConflicts(conflicts, responseName, node1, node2) {\n if (conflicts.length > 0) {\n return [\n [responseName, conflicts.map(([reason]) => reason)],\n [node1, ...conflicts.map(([, fields1]) => fields1).flat()],\n [node2, ...conflicts.map(([, , fields2]) => fields2).flat()],\n ];\n }\n}\n/**\n * A way to keep track of pairs of things when the ordering of the pair does not matter.\n */\n\nclass PairSet {\n constructor() {\n this._data = new Map();\n }\n\n has(a, b, areMutuallyExclusive) {\n var _this$_data$get;\n\n const [key1, key2] = a < b ? [a, b] : [b, a];\n const result =\n (_this$_data$get = this._data.get(key1)) === null ||\n _this$_data$get === void 0\n ? void 0\n : _this$_data$get.get(key2);\n\n if (result === undefined) {\n return false;\n } // areMutuallyExclusive being false is a superset of being true, hence if\n // we want to know if this PairSet \"has\" these two with no exclusivity,\n // we have to ensure it was added as such.\n\n return areMutuallyExclusive ? true : areMutuallyExclusive === result;\n }\n\n add(a, b, areMutuallyExclusive) {\n const [key1, key2] = a < b ? [a, b] : [b, a];\n\n const map = this._data.get(key1);\n\n if (map === undefined) {\n this._data.set(key1, new Map([[key2, areMutuallyExclusive]]));\n } else {\n map.set(key2, areMutuallyExclusive);\n }\n }\n}\n","import { inspect } from '../../jsutils/inspect.mjs';\nimport { GraphQLError } from '../../error/GraphQLError.mjs';\nimport { isCompositeType } from '../../type/definition.mjs';\nimport { doTypesOverlap } from '../../utilities/typeComparators.mjs';\nimport { typeFromAST } from '../../utilities/typeFromAST.mjs';\n\n/**\n * Possible fragment spread\n *\n * A fragment spread is only valid if the type condition could ever possibly\n * be true: if there is a non-empty intersection of the possible parent types,\n * and possible types which pass the type condition.\n */\nexport function PossibleFragmentSpreadsRule(context) {\n return {\n InlineFragment(node) {\n const fragType = context.getType();\n const parentType = context.getParentType();\n\n if (\n isCompositeType(fragType) &&\n isCompositeType(parentType) &&\n !doTypesOverlap(context.getSchema(), fragType, parentType)\n ) {\n const parentTypeStr = inspect(parentType);\n const fragTypeStr = inspect(fragType);\n context.reportError(\n new GraphQLError(\n `Fragment cannot be spread here as objects of type \"${parentTypeStr}\" can never be of type \"${fragTypeStr}\".`,\n {\n nodes: node,\n },\n ),\n );\n }\n },\n\n FragmentSpread(node) {\n const fragName = node.name.value;\n const fragType = getFragmentType(context, fragName);\n const parentType = context.getParentType();\n\n if (\n fragType &&\n parentType &&\n !doTypesOverlap(context.getSchema(), fragType, parentType)\n ) {\n const parentTypeStr = inspect(parentType);\n const fragTypeStr = inspect(fragType);\n context.reportError(\n new GraphQLError(\n `Fragment \"${fragName}\" cannot be spread here as objects of type \"${parentTypeStr}\" can never be of type \"${fragTypeStr}\".`,\n {\n nodes: node,\n },\n ),\n );\n }\n },\n };\n}\n\nfunction getFragmentType(context, name) {\n const frag = context.getFragment(name);\n\n if (frag) {\n const type = typeFromAST(context.getSchema(), frag.typeCondition);\n\n if (isCompositeType(type)) {\n return type;\n }\n }\n}\n","import { didYouMean } from '../../jsutils/didYouMean.mjs';\nimport { inspect } from '../../jsutils/inspect.mjs';\nimport { invariant } from '../../jsutils/invariant.mjs';\nimport { suggestionList } from '../../jsutils/suggestionList.mjs';\nimport { GraphQLError } from '../../error/GraphQLError.mjs';\nimport { Kind } from '../../language/kinds.mjs';\nimport { isTypeDefinitionNode } from '../../language/predicates.mjs';\nimport {\n isEnumType,\n isInputObjectType,\n isInterfaceType,\n isObjectType,\n isScalarType,\n isUnionType,\n} from '../../type/definition.mjs';\n\n/**\n * Possible type extension\n *\n * A type extension is only valid if the type is defined and has the same kind.\n */\nexport function PossibleTypeExtensionsRule(context) {\n const schema = context.getSchema();\n const definedTypes = Object.create(null);\n\n for (const def of context.getDocument().definitions) {\n if (isTypeDefinitionNode(def)) {\n definedTypes[def.name.value] = def;\n }\n }\n\n return {\n ScalarTypeExtension: checkExtension,\n ObjectTypeExtension: checkExtension,\n InterfaceTypeExtension: checkExtension,\n UnionTypeExtension: checkExtension,\n EnumTypeExtension: checkExtension,\n InputObjectTypeExtension: checkExtension,\n };\n\n function checkExtension(node) {\n const typeName = node.name.value;\n const defNode = definedTypes[typeName];\n const existingType =\n schema === null || schema === void 0 ? void 0 : schema.getType(typeName);\n let expectedKind;\n\n if (defNode) {\n expectedKind = defKindToExtKind[defNode.kind];\n } else if (existingType) {\n expectedKind = typeToExtKind(existingType);\n }\n\n if (expectedKind) {\n if (expectedKind !== node.kind) {\n const kindStr = extensionKindToTypeName(node.kind);\n context.reportError(\n new GraphQLError(`Cannot extend non-${kindStr} type \"${typeName}\".`, {\n nodes: defNode ? [defNode, node] : node,\n }),\n );\n }\n } else {\n const allTypeNames = Object.keys({\n ...definedTypes,\n ...(schema === null || schema === void 0\n ? void 0\n : schema.getTypeMap()),\n });\n const suggestedTypes = suggestionList(typeName, allTypeNames);\n context.reportError(\n new GraphQLError(\n `Cannot extend type \"${typeName}\" because it is not defined.` +\n didYouMean(suggestedTypes),\n {\n nodes: node.name,\n },\n ),\n );\n }\n }\n}\nconst defKindToExtKind = {\n [Kind.SCALAR_TYPE_DEFINITION]: Kind.SCALAR_TYPE_EXTENSION,\n [Kind.OBJECT_TYPE_DEFINITION]: Kind.OBJECT_TYPE_EXTENSION,\n [Kind.INTERFACE_TYPE_DEFINITION]: Kind.INTERFACE_TYPE_EXTENSION,\n [Kind.UNION_TYPE_DEFINITION]: Kind.UNION_TYPE_EXTENSION,\n [Kind.ENUM_TYPE_DEFINITION]: Kind.ENUM_TYPE_EXTENSION,\n [Kind.INPUT_OBJECT_TYPE_DEFINITION]: Kind.INPUT_OBJECT_TYPE_EXTENSION,\n};\n\nfunction typeToExtKind(type) {\n if (isScalarType(type)) {\n return Kind.SCALAR_TYPE_EXTENSION;\n }\n\n if (isObjectType(type)) {\n return Kind.OBJECT_TYPE_EXTENSION;\n }\n\n if (isInterfaceType(type)) {\n return Kind.INTERFACE_TYPE_EXTENSION;\n }\n\n if (isUnionType(type)) {\n return Kind.UNION_TYPE_EXTENSION;\n }\n\n if (isEnumType(type)) {\n return Kind.ENUM_TYPE_EXTENSION;\n }\n\n if (isInputObjectType(type)) {\n return Kind.INPUT_OBJECT_TYPE_EXTENSION;\n }\n /* c8 ignore next 3 */\n // Not reachable. All possible types have been considered\n\n false || invariant(false, 'Unexpected type: ' + inspect(type));\n}\n\nfunction extensionKindToTypeName(kind) {\n switch (kind) {\n case Kind.SCALAR_TYPE_EXTENSION:\n return 'scalar';\n\n case Kind.OBJECT_TYPE_EXTENSION:\n return 'object';\n\n case Kind.INTERFACE_TYPE_EXTENSION:\n return 'interface';\n\n case Kind.UNION_TYPE_EXTENSION:\n return 'union';\n\n case Kind.ENUM_TYPE_EXTENSION:\n return 'enum';\n\n case Kind.INPUT_OBJECT_TYPE_EXTENSION:\n return 'input object';\n // Not reachable. All possible types have been considered\n\n /* c8 ignore next */\n\n default:\n false || invariant(false, 'Unexpected kind: ' + inspect(kind));\n }\n}\n","import { inspect } from '../../jsutils/inspect.mjs';\nimport { keyMap } from '../../jsutils/keyMap.mjs';\nimport { GraphQLError } from '../../error/GraphQLError.mjs';\nimport { Kind } from '../../language/kinds.mjs';\nimport { print } from '../../language/printer.mjs';\nimport { isRequiredArgument, isType } from '../../type/definition.mjs';\nimport { specifiedDirectives } from '../../type/directives.mjs';\n\n/**\n * Provided required arguments\n *\n * A field or directive is only valid if all required (non-null without a\n * default value) field arguments have been provided.\n */\nexport function ProvidedRequiredArgumentsRule(context) {\n return {\n // eslint-disable-next-line new-cap\n ...ProvidedRequiredArgumentsOnDirectivesRule(context),\n Field: {\n // Validate on leave to allow for deeper errors to appear first.\n leave(fieldNode) {\n var _fieldNode$arguments;\n\n const fieldDef = context.getFieldDef();\n\n if (!fieldDef) {\n return false;\n }\n\n const providedArgs = new Set( // FIXME: https://github.com/graphql/graphql-js/issues/2203\n /* c8 ignore next */\n (_fieldNode$arguments = fieldNode.arguments) === null ||\n _fieldNode$arguments === void 0\n ? void 0\n : _fieldNode$arguments.map((arg) => arg.name.value),\n );\n\n for (const argDef of fieldDef.args) {\n if (!providedArgs.has(argDef.name) && isRequiredArgument(argDef)) {\n const argTypeStr = inspect(argDef.type);\n context.reportError(\n new GraphQLError(\n `Field \"${fieldDef.name}\" argument \"${argDef.name}\" of type \"${argTypeStr}\" is required, but it was not provided.`,\n {\n nodes: fieldNode,\n },\n ),\n );\n }\n }\n },\n },\n };\n}\n/**\n * @internal\n */\n\nexport function ProvidedRequiredArgumentsOnDirectivesRule(context) {\n var _schema$getDirectives;\n\n const requiredArgsMap = Object.create(null);\n const schema = context.getSchema();\n const definedDirectives =\n (_schema$getDirectives =\n schema === null || schema === void 0\n ? void 0\n : schema.getDirectives()) !== null && _schema$getDirectives !== void 0\n ? _schema$getDirectives\n : specifiedDirectives;\n\n for (const directive of definedDirectives) {\n requiredArgsMap[directive.name] = keyMap(\n directive.args.filter(isRequiredArgument),\n (arg) => arg.name,\n );\n }\n\n const astDefinitions = context.getDocument().definitions;\n\n for (const def of astDefinitions) {\n if (def.kind === Kind.DIRECTIVE_DEFINITION) {\n var _def$arguments;\n\n // FIXME: https://github.com/graphql/graphql-js/issues/2203\n\n /* c8 ignore next */\n const argNodes =\n (_def$arguments = def.arguments) !== null && _def$arguments !== void 0\n ? _def$arguments\n : [];\n requiredArgsMap[def.name.value] = keyMap(\n argNodes.filter(isRequiredArgumentNode),\n (arg) => arg.name.value,\n );\n }\n }\n\n return {\n Directive: {\n // Validate on leave to allow for deeper errors to appear first.\n leave(directiveNode) {\n const directiveName = directiveNode.name.value;\n const requiredArgs = requiredArgsMap[directiveName];\n\n if (requiredArgs) {\n var _directiveNode$argume;\n\n // FIXME: https://github.com/graphql/graphql-js/issues/2203\n\n /* c8 ignore next */\n const argNodes =\n (_directiveNode$argume = directiveNode.arguments) !== null &&\n _directiveNode$argume !== void 0\n ? _directiveNode$argume\n : [];\n const argNodeMap = new Set(argNodes.map((arg) => arg.name.value));\n\n for (const [argName, argDef] of Object.entries(requiredArgs)) {\n if (!argNodeMap.has(argName)) {\n const argType = isType(argDef.type)\n ? inspect(argDef.type)\n : print(argDef.type);\n context.reportError(\n new GraphQLError(\n `Directive \"@${directiveName}\" argument \"${argName}\" of type \"${argType}\" is required, but it was not provided.`,\n {\n nodes: directiveNode,\n },\n ),\n );\n }\n }\n }\n },\n },\n };\n}\n\nfunction isRequiredArgumentNode(arg) {\n return arg.type.kind === Kind.NON_NULL_TYPE && arg.defaultValue == null;\n}\n","import { inspect } from '../../jsutils/inspect.mjs';\nimport { GraphQLError } from '../../error/GraphQLError.mjs';\nimport { getNamedType, isLeafType } from '../../type/definition.mjs';\n\n/**\n * Scalar leafs\n *\n * A GraphQL document is valid only if all leaf fields (fields without\n * sub selections) are of scalar or enum types.\n */\nexport function ScalarLeafsRule(context) {\n return {\n Field(node) {\n const type = context.getType();\n const selectionSet = node.selectionSet;\n\n if (type) {\n if (isLeafType(getNamedType(type))) {\n if (selectionSet) {\n const fieldName = node.name.value;\n const typeStr = inspect(type);\n context.reportError(\n new GraphQLError(\n `Field \"${fieldName}\" must not have a selection since type \"${typeStr}\" has no subfields.`,\n {\n nodes: selectionSet,\n },\n ),\n );\n }\n } else if (!selectionSet) {\n const fieldName = node.name.value;\n const typeStr = inspect(type);\n context.reportError(\n new GraphQLError(\n `Field \"${fieldName}\" of type \"${typeStr}\" must have a selection of subfields. Did you mean \"${fieldName} { ... }\"?`,\n {\n nodes: node,\n },\n ),\n );\n }\n }\n },\n };\n}\n","/**\n * Build a string describing the path.\n */\nexport function printPathArray(path) {\n return path\n .map((key) =>\n typeof key === 'number' ? '[' + key.toString() + ']' : '.' + key,\n )\n .join('');\n}\n","/**\n * Given a Path and a key, return a new Path containing the new key.\n */\nexport function addPath(prev, key, typename) {\n return {\n prev,\n key,\n typename,\n };\n}\n/**\n * Given a Path, return an Array of the path keys.\n */\n\nexport function pathToArray(path) {\n const flattened = [];\n let curr = path;\n\n while (curr) {\n flattened.push(curr.key);\n curr = curr.prev;\n }\n\n return flattened.reverse();\n}\n","import { didYouMean } from '../jsutils/didYouMean.mjs';\nimport { inspect } from '../jsutils/inspect.mjs';\nimport { invariant } from '../jsutils/invariant.mjs';\nimport { isIterableObject } from '../jsutils/isIterableObject.mjs';\nimport { isObjectLike } from '../jsutils/isObjectLike.mjs';\nimport { addPath, pathToArray } from '../jsutils/Path.mjs';\nimport { printPathArray } from '../jsutils/printPathArray.mjs';\nimport { suggestionList } from '../jsutils/suggestionList.mjs';\nimport { GraphQLError } from '../error/GraphQLError.mjs';\nimport {\n isInputObjectType,\n isLeafType,\n isListType,\n isNonNullType,\n} from '../type/definition.mjs';\n\n/**\n * Coerces a JavaScript value given a GraphQL Input Type.\n */\nexport function coerceInputValue(inputValue, type, onError = defaultOnError) {\n return coerceInputValueImpl(inputValue, type, onError, undefined);\n}\n\nfunction defaultOnError(path, invalidValue, error) {\n let errorPrefix = 'Invalid value ' + inspect(invalidValue);\n\n if (path.length > 0) {\n errorPrefix += ` at \"value${printPathArray(path)}\"`;\n }\n\n error.message = errorPrefix + ': ' + error.message;\n throw error;\n}\n\nfunction coerceInputValueImpl(inputValue, type, onError, path) {\n if (isNonNullType(type)) {\n if (inputValue != null) {\n return coerceInputValueImpl(inputValue, type.ofType, onError, path);\n }\n\n onError(\n pathToArray(path),\n inputValue,\n new GraphQLError(\n `Expected non-nullable type \"${inspect(type)}\" not to be null.`,\n ),\n );\n return;\n }\n\n if (inputValue == null) {\n // Explicitly return the value null.\n return null;\n }\n\n if (isListType(type)) {\n const itemType = type.ofType;\n\n if (isIterableObject(inputValue)) {\n return Array.from(inputValue, (itemValue, index) => {\n const itemPath = addPath(path, index, undefined);\n return coerceInputValueImpl(itemValue, itemType, onError, itemPath);\n });\n } // Lists accept a non-list value as a list of one.\n\n return [coerceInputValueImpl(inputValue, itemType, onError, path)];\n }\n\n if (isInputObjectType(type)) {\n if (!isObjectLike(inputValue)) {\n onError(\n pathToArray(path),\n inputValue,\n new GraphQLError(`Expected type \"${type.name}\" to be an object.`),\n );\n return;\n }\n\n const coercedValue = {};\n const fieldDefs = type.getFields();\n\n for (const field of Object.values(fieldDefs)) {\n const fieldValue = inputValue[field.name];\n\n if (fieldValue === undefined) {\n if (field.defaultValue !== undefined) {\n coercedValue[field.name] = field.defaultValue;\n } else if (isNonNullType(field.type)) {\n const typeStr = inspect(field.type);\n onError(\n pathToArray(path),\n inputValue,\n new GraphQLError(\n `Field \"${field.name}\" of required type \"${typeStr}\" was not provided.`,\n ),\n );\n }\n\n continue;\n }\n\n coercedValue[field.name] = coerceInputValueImpl(\n fieldValue,\n field.type,\n onError,\n addPath(path, field.name, type.name),\n );\n } // Ensure every provided field is defined.\n\n for (const fieldName of Object.keys(inputValue)) {\n if (!fieldDefs[fieldName]) {\n const suggestions = suggestionList(\n fieldName,\n Object.keys(type.getFields()),\n );\n onError(\n pathToArray(path),\n inputValue,\n new GraphQLError(\n `Field \"${fieldName}\" is not defined by type \"${type.name}\".` +\n didYouMean(suggestions),\n ),\n );\n }\n }\n\n return coercedValue;\n }\n\n if (isLeafType(type)) {\n let parseResult; // Scalars and Enums determine if a input value is valid via parseValue(),\n // which can throw to indicate failure. If it throws, maintain a reference\n // to the original error.\n\n try {\n parseResult = type.parseValue(inputValue);\n } catch (error) {\n if (error instanceof GraphQLError) {\n onError(pathToArray(path), inputValue, error);\n } else {\n onError(\n pathToArray(path),\n inputValue,\n new GraphQLError(`Expected type \"${type.name}\". ` + error.message, {\n originalError: error,\n }),\n );\n }\n\n return;\n }\n\n if (parseResult === undefined) {\n onError(\n pathToArray(path),\n inputValue,\n new GraphQLError(`Expected type \"${type.name}\".`),\n );\n }\n\n return parseResult;\n }\n /* c8 ignore next 3 */\n // Not reachable, all possible types have been considered.\n\n false || invariant(false, 'Unexpected input type: ' + inspect(type));\n}\n","import { inspect } from '../jsutils/inspect.mjs';\nimport { invariant } from '../jsutils/invariant.mjs';\nimport { keyMap } from '../jsutils/keyMap.mjs';\nimport { Kind } from '../language/kinds.mjs';\nimport {\n isInputObjectType,\n isLeafType,\n isListType,\n isNonNullType,\n} from '../type/definition.mjs';\n/**\n * Produces a JavaScript value given a GraphQL Value AST.\n *\n * A GraphQL type must be provided, which will be used to interpret different\n * GraphQL Value literals.\n *\n * Returns `undefined` when the value could not be validly coerced according to\n * the provided type.\n *\n * | GraphQL Value | JSON Value |\n * | -------------------- | ------------- |\n * | Input Object | Object |\n * | List | Array |\n * | Boolean | Boolean |\n * | String | String |\n * | Int / Float | Number |\n * | Enum Value | Unknown |\n * | NullValue | null |\n *\n */\n\nexport function valueFromAST(valueNode, type, variables) {\n if (!valueNode) {\n // When there is no node, then there is also no value.\n // Importantly, this is different from returning the value null.\n return;\n }\n\n if (valueNode.kind === Kind.VARIABLE) {\n const variableName = valueNode.name.value;\n\n if (variables == null || variables[variableName] === undefined) {\n // No valid return value.\n return;\n }\n\n const variableValue = variables[variableName];\n\n if (variableValue === null && isNonNullType(type)) {\n return; // Invalid: intentionally return no value.\n } // Note: This does no further checking that this variable is correct.\n // This assumes that this query has been validated and the variable\n // usage here is of the correct type.\n\n return variableValue;\n }\n\n if (isNonNullType(type)) {\n if (valueNode.kind === Kind.NULL) {\n return; // Invalid: intentionally return no value.\n }\n\n return valueFromAST(valueNode, type.ofType, variables);\n }\n\n if (valueNode.kind === Kind.NULL) {\n // This is explicitly returning the value null.\n return null;\n }\n\n if (isListType(type)) {\n const itemType = type.ofType;\n\n if (valueNode.kind === Kind.LIST) {\n const coercedValues = [];\n\n for (const itemNode of valueNode.values) {\n if (isMissingVariable(itemNode, variables)) {\n // If an array contains a missing variable, it is either coerced to\n // null or if the item type is non-null, it considered invalid.\n if (isNonNullType(itemType)) {\n return; // Invalid: intentionally return no value.\n }\n\n coercedValues.push(null);\n } else {\n const itemValue = valueFromAST(itemNode, itemType, variables);\n\n if (itemValue === undefined) {\n return; // Invalid: intentionally return no value.\n }\n\n coercedValues.push(itemValue);\n }\n }\n\n return coercedValues;\n }\n\n const coercedValue = valueFromAST(valueNode, itemType, variables);\n\n if (coercedValue === undefined) {\n return; // Invalid: intentionally return no value.\n }\n\n return [coercedValue];\n }\n\n if (isInputObjectType(type)) {\n if (valueNode.kind !== Kind.OBJECT) {\n return; // Invalid: intentionally return no value.\n }\n\n const coercedObj = Object.create(null);\n const fieldNodes = keyMap(valueNode.fields, (field) => field.name.value);\n\n for (const field of Object.values(type.getFields())) {\n const fieldNode = fieldNodes[field.name];\n\n if (!fieldNode || isMissingVariable(fieldNode.value, variables)) {\n if (field.defaultValue !== undefined) {\n coercedObj[field.name] = field.defaultValue;\n } else if (isNonNullType(field.type)) {\n return; // Invalid: intentionally return no value.\n }\n\n continue;\n }\n\n const fieldValue = valueFromAST(fieldNode.value, field.type, variables);\n\n if (fieldValue === undefined) {\n return; // Invalid: intentionally return no value.\n }\n\n coercedObj[field.name] = fieldValue;\n }\n\n return coercedObj;\n }\n\n if (isLeafType(type)) {\n // Scalars and Enums fulfill parsing a literal value via parseLiteral().\n // Invalid values represent a failure to parse correctly, in which case\n // no value is returned.\n let result;\n\n try {\n result = type.parseLiteral(valueNode, variables);\n } catch (_error) {\n return; // Invalid: intentionally return no value.\n }\n\n if (result === undefined) {\n return; // Invalid: intentionally return no value.\n }\n\n return result;\n }\n /* c8 ignore next 3 */\n // Not reachable, all possible input types have been considered.\n\n false || invariant(false, 'Unexpected input type: ' + inspect(type));\n} // Returns true if the provided valueNode is a variable which is not defined\n// in the set of variables.\n\nfunction isMissingVariable(valueNode, variables) {\n return (\n valueNode.kind === Kind.VARIABLE &&\n (variables == null || variables[valueNode.name.value] === undefined)\n );\n}\n","import { inspect } from '../jsutils/inspect.mjs';\nimport { keyMap } from '../jsutils/keyMap.mjs';\nimport { printPathArray } from '../jsutils/printPathArray.mjs';\nimport { GraphQLError } from '../error/GraphQLError.mjs';\nimport { Kind } from '../language/kinds.mjs';\nimport { print } from '../language/printer.mjs';\nimport { isInputType, isNonNullType } from '../type/definition.mjs';\nimport { coerceInputValue } from '../utilities/coerceInputValue.mjs';\nimport { typeFromAST } from '../utilities/typeFromAST.mjs';\nimport { valueFromAST } from '../utilities/valueFromAST.mjs';\n\n/**\n * Prepares an object map of variableValues of the correct type based on the\n * provided variable definitions and arbitrary input. If the input cannot be\n * parsed to match the variable definitions, a GraphQLError will be thrown.\n *\n * Note: The returned value is a plain Object with a prototype, since it is\n * exposed to user code. Care should be taken to not pull values from the\n * Object prototype.\n */\nexport function getVariableValues(schema, varDefNodes, inputs, options) {\n const errors = [];\n const maxErrors =\n options === null || options === void 0 ? void 0 : options.maxErrors;\n\n try {\n const coerced = coerceVariableValues(\n schema,\n varDefNodes,\n inputs,\n (error) => {\n if (maxErrors != null && errors.length >= maxErrors) {\n throw new GraphQLError(\n 'Too many errors processing variables, error limit reached. Execution aborted.',\n );\n }\n\n errors.push(error);\n },\n );\n\n if (errors.length === 0) {\n return {\n coerced,\n };\n }\n } catch (error) {\n errors.push(error);\n }\n\n return {\n errors,\n };\n}\n\nfunction coerceVariableValues(schema, varDefNodes, inputs, onError) {\n const coercedValues = {};\n\n for (const varDefNode of varDefNodes) {\n const varName = varDefNode.variable.name.value;\n const varType = typeFromAST(schema, varDefNode.type);\n\n if (!isInputType(varType)) {\n // Must use input types for variables. This should be caught during\n // validation, however is checked again here for safety.\n const varTypeStr = print(varDefNode.type);\n onError(\n new GraphQLError(\n `Variable \"$${varName}\" expected value of type \"${varTypeStr}\" which cannot be used as an input type.`,\n {\n nodes: varDefNode.type,\n },\n ),\n );\n continue;\n }\n\n if (!hasOwnProperty(inputs, varName)) {\n if (varDefNode.defaultValue) {\n coercedValues[varName] = valueFromAST(varDefNode.defaultValue, varType);\n } else if (isNonNullType(varType)) {\n const varTypeStr = inspect(varType);\n onError(\n new GraphQLError(\n `Variable \"$${varName}\" of required type \"${varTypeStr}\" was not provided.`,\n {\n nodes: varDefNode,\n },\n ),\n );\n }\n\n continue;\n }\n\n const value = inputs[varName];\n\n if (value === null && isNonNullType(varType)) {\n const varTypeStr = inspect(varType);\n onError(\n new GraphQLError(\n `Variable \"$${varName}\" of non-null type \"${varTypeStr}\" must not be null.`,\n {\n nodes: varDefNode,\n },\n ),\n );\n continue;\n }\n\n coercedValues[varName] = coerceInputValue(\n value,\n varType,\n (path, invalidValue, error) => {\n let prefix =\n `Variable \"$${varName}\" got invalid value ` + inspect(invalidValue);\n\n if (path.length > 0) {\n prefix += ` at \"${varName}${printPathArray(path)}\"`;\n }\n\n onError(\n new GraphQLError(prefix + '; ' + error.message, {\n nodes: varDefNode,\n originalError: error,\n }),\n );\n },\n );\n }\n\n return coercedValues;\n}\n/**\n * Prepares an object map of argument values given a list of argument\n * definitions and list of argument AST nodes.\n *\n * Note: The returned value is a plain Object with a prototype, since it is\n * exposed to user code. Care should be taken to not pull values from the\n * Object prototype.\n */\n\nexport function getArgumentValues(def, node, variableValues) {\n var _node$arguments;\n\n const coercedValues = {}; // FIXME: https://github.com/graphql/graphql-js/issues/2203\n\n /* c8 ignore next */\n\n const argumentNodes =\n (_node$arguments = node.arguments) !== null && _node$arguments !== void 0\n ? _node$arguments\n : [];\n const argNodeMap = keyMap(argumentNodes, (arg) => arg.name.value);\n\n for (const argDef of def.args) {\n const name = argDef.name;\n const argType = argDef.type;\n const argumentNode = argNodeMap[name];\n\n if (!argumentNode) {\n if (argDef.defaultValue !== undefined) {\n coercedValues[name] = argDef.defaultValue;\n } else if (isNonNullType(argType)) {\n throw new GraphQLError(\n `Argument \"${name}\" of required type \"${inspect(argType)}\" ` +\n 'was not provided.',\n {\n nodes: node,\n },\n );\n }\n\n continue;\n }\n\n const valueNode = argumentNode.value;\n let isNull = valueNode.kind === Kind.NULL;\n\n if (valueNode.kind === Kind.VARIABLE) {\n const variableName = valueNode.name.value;\n\n if (\n variableValues == null ||\n !hasOwnProperty(variableValues, variableName)\n ) {\n if (argDef.defaultValue !== undefined) {\n coercedValues[name] = argDef.defaultValue;\n } else if (isNonNullType(argType)) {\n throw new GraphQLError(\n `Argument \"${name}\" of required type \"${inspect(argType)}\" ` +\n `was provided the variable \"$${variableName}\" which was not provided a runtime value.`,\n {\n nodes: valueNode,\n },\n );\n }\n\n continue;\n }\n\n isNull = variableValues[variableName] == null;\n }\n\n if (isNull && isNonNullType(argType)) {\n throw new GraphQLError(\n `Argument \"${name}\" of non-null type \"${inspect(argType)}\" ` +\n 'must not be null.',\n {\n nodes: valueNode,\n },\n );\n }\n\n const coercedValue = valueFromAST(valueNode, argType, variableValues);\n\n if (coercedValue === undefined) {\n // Note: ValuesOfCorrectTypeRule validation should catch this before\n // execution. This is a runtime check to ensure execution does not\n // continue with an invalid argument value.\n throw new GraphQLError(\n `Argument \"${name}\" has invalid value ${print(valueNode)}.`,\n {\n nodes: valueNode,\n },\n );\n }\n\n coercedValues[name] = coercedValue;\n }\n\n return coercedValues;\n}\n/**\n * Prepares an object map of argument values given a directive definition\n * and a AST node which may contain directives. Optionally also accepts a map\n * of variable values.\n *\n * If the directive does not exist on the node, returns undefined.\n *\n * Note: The returned value is a plain Object with a prototype, since it is\n * exposed to user code. Care should be taken to not pull values from the\n * Object prototype.\n */\n\nexport function getDirectiveValues(directiveDef, node, variableValues) {\n var _node$directives;\n\n const directiveNode =\n (_node$directives = node.directives) === null || _node$directives === void 0\n ? void 0\n : _node$directives.find(\n (directive) => directive.name.value === directiveDef.name,\n );\n\n if (directiveNode) {\n return getArgumentValues(directiveDef, directiveNode, variableValues);\n }\n}\n\nfunction hasOwnProperty(obj, prop) {\n return Object.prototype.hasOwnProperty.call(obj, prop);\n}\n","import { Kind } from '../language/kinds.mjs';\nimport { isAbstractType } from '../type/definition.mjs';\nimport {\n GraphQLIncludeDirective,\n GraphQLSkipDirective,\n} from '../type/directives.mjs';\nimport { typeFromAST } from '../utilities/typeFromAST.mjs';\nimport { getDirectiveValues } from './values.mjs';\n/**\n * Given a selectionSet, collects all of the fields and returns them.\n *\n * CollectFields requires the \"runtime type\" of an object. For a field that\n * returns an Interface or Union type, the \"runtime type\" will be the actual\n * object type returned by that field.\n *\n * @internal\n */\n\nexport function collectFields(\n schema,\n fragments,\n variableValues,\n runtimeType,\n selectionSet,\n) {\n const fields = new Map();\n collectFieldsImpl(\n schema,\n fragments,\n variableValues,\n runtimeType,\n selectionSet,\n fields,\n new Set(),\n );\n return fields;\n}\n/**\n * Given an array of field nodes, collects all of the subfields of the passed\n * in fields, and returns them at the end.\n *\n * CollectSubFields requires the \"return type\" of an object. For a field that\n * returns an Interface or Union type, the \"return type\" will be the actual\n * object type returned by that field.\n *\n * @internal\n */\n\nexport function collectSubfields(\n schema,\n fragments,\n variableValues,\n returnType,\n fieldNodes,\n) {\n const subFieldNodes = new Map();\n const visitedFragmentNames = new Set();\n\n for (const node of fieldNodes) {\n if (node.selectionSet) {\n collectFieldsImpl(\n schema,\n fragments,\n variableValues,\n returnType,\n node.selectionSet,\n subFieldNodes,\n visitedFragmentNames,\n );\n }\n }\n\n return subFieldNodes;\n}\n\nfunction collectFieldsImpl(\n schema,\n fragments,\n variableValues,\n runtimeType,\n selectionSet,\n fields,\n visitedFragmentNames,\n) {\n for (const selection of selectionSet.selections) {\n switch (selection.kind) {\n case Kind.FIELD: {\n if (!shouldIncludeNode(variableValues, selection)) {\n continue;\n }\n\n const name = getFieldEntryKey(selection);\n const fieldList = fields.get(name);\n\n if (fieldList !== undefined) {\n fieldList.push(selection);\n } else {\n fields.set(name, [selection]);\n }\n\n break;\n }\n\n case Kind.INLINE_FRAGMENT: {\n if (\n !shouldIncludeNode(variableValues, selection) ||\n !doesFragmentConditionMatch(schema, selection, runtimeType)\n ) {\n continue;\n }\n\n collectFieldsImpl(\n schema,\n fragments,\n variableValues,\n runtimeType,\n selection.selectionSet,\n fields,\n visitedFragmentNames,\n );\n break;\n }\n\n case Kind.FRAGMENT_SPREAD: {\n const fragName = selection.name.value;\n\n if (\n visitedFragmentNames.has(fragName) ||\n !shouldIncludeNode(variableValues, selection)\n ) {\n continue;\n }\n\n visitedFragmentNames.add(fragName);\n const fragment = fragments[fragName];\n\n if (\n !fragment ||\n !doesFragmentConditionMatch(schema, fragment, runtimeType)\n ) {\n continue;\n }\n\n collectFieldsImpl(\n schema,\n fragments,\n variableValues,\n runtimeType,\n fragment.selectionSet,\n fields,\n visitedFragmentNames,\n );\n break;\n }\n }\n }\n}\n/**\n * Determines if a field should be included based on the `@include` and `@skip`\n * directives, where `@skip` has higher precedence than `@include`.\n */\n\nfunction shouldIncludeNode(variableValues, node) {\n const skip = getDirectiveValues(GraphQLSkipDirective, node, variableValues);\n\n if ((skip === null || skip === void 0 ? void 0 : skip.if) === true) {\n return false;\n }\n\n const include = getDirectiveValues(\n GraphQLIncludeDirective,\n node,\n variableValues,\n );\n\n if (\n (include === null || include === void 0 ? void 0 : include.if) === false\n ) {\n return false;\n }\n\n return true;\n}\n/**\n * Determines if a fragment is applicable to the given type.\n */\n\nfunction doesFragmentConditionMatch(schema, fragment, type) {\n const typeConditionNode = fragment.typeCondition;\n\n if (!typeConditionNode) {\n return true;\n }\n\n const conditionalType = typeFromAST(schema, typeConditionNode);\n\n if (conditionalType === type) {\n return true;\n }\n\n if (isAbstractType(conditionalType)) {\n return schema.isSubType(conditionalType, type);\n }\n\n return false;\n}\n/**\n * Implements the logic to compute the key of a given field's entry\n */\n\nfunction getFieldEntryKey(node) {\n return node.alias ? node.alias.value : node.name.value;\n}\n","import { GraphQLError } from '../../error/GraphQLError.mjs';\nimport { Kind } from '../../language/kinds.mjs';\nimport { collectFields } from '../../execution/collectFields.mjs';\n\n/**\n * Subscriptions must only include a non-introspection field.\n *\n * A GraphQL subscription is valid only if it contains a single root field and\n * that root field is not an introspection field.\n *\n * See https://spec.graphql.org/draft/#sec-Single-root-field\n */\nexport function SingleFieldSubscriptionsRule(context) {\n return {\n OperationDefinition(node) {\n if (node.operation === 'subscription') {\n const schema = context.getSchema();\n const subscriptionType = schema.getSubscriptionType();\n\n if (subscriptionType) {\n const operationName = node.name ? node.name.value : null;\n const variableValues = Object.create(null);\n const document = context.getDocument();\n const fragments = Object.create(null);\n\n for (const definition of document.definitions) {\n if (definition.kind === Kind.FRAGMENT_DEFINITION) {\n fragments[definition.name.value] = definition;\n }\n }\n\n const fields = collectFields(\n schema,\n fragments,\n variableValues,\n subscriptionType,\n node.selectionSet,\n );\n\n if (fields.size > 1) {\n const fieldSelectionLists = [...fields.values()];\n const extraFieldSelectionLists = fieldSelectionLists.slice(1);\n const extraFieldSelections = extraFieldSelectionLists.flat();\n context.reportError(\n new GraphQLError(\n operationName != null\n ? `Subscription \"${operationName}\" must select only one top level field.`\n : 'Anonymous Subscription must select only one top level field.',\n {\n nodes: extraFieldSelections,\n },\n ),\n );\n }\n\n for (const fieldNodes of fields.values()) {\n const field = fieldNodes[0];\n const fieldName = field.name.value;\n\n if (fieldName.startsWith('__')) {\n context.reportError(\n new GraphQLError(\n operationName != null\n ? `Subscription \"${operationName}\" must not select an introspection top level field.`\n : 'Anonymous Subscription must not select an introspection top level field.',\n {\n nodes: fieldNodes,\n },\n ),\n );\n }\n }\n }\n }\n },\n };\n}\n","/**\n * Groups array items into a Map, given a function to produce grouping key.\n */\nexport function groupBy(list, keyFn) {\n const result = new Map();\n\n for (const item of list) {\n const key = keyFn(item);\n const group = result.get(key);\n\n if (group === undefined) {\n result.set(key, [item]);\n } else {\n group.push(item);\n }\n }\n\n return result;\n}\n","import { groupBy } from '../../jsutils/groupBy.mjs';\nimport { GraphQLError } from '../../error/GraphQLError.mjs';\n\n/**\n * Unique argument definition names\n *\n * A GraphQL Object or Interface type is only valid if all its fields have uniquely named arguments.\n * A GraphQL Directive is only valid if all its arguments are uniquely named.\n */\nexport function UniqueArgumentDefinitionNamesRule(context) {\n return {\n DirectiveDefinition(directiveNode) {\n var _directiveNode$argume;\n\n // FIXME: https://github.com/graphql/graphql-js/issues/2203\n\n /* c8 ignore next */\n const argumentNodes =\n (_directiveNode$argume = directiveNode.arguments) !== null &&\n _directiveNode$argume !== void 0\n ? _directiveNode$argume\n : [];\n return checkArgUniqueness(`@${directiveNode.name.value}`, argumentNodes);\n },\n\n InterfaceTypeDefinition: checkArgUniquenessPerField,\n InterfaceTypeExtension: checkArgUniquenessPerField,\n ObjectTypeDefinition: checkArgUniquenessPerField,\n ObjectTypeExtension: checkArgUniquenessPerField,\n };\n\n function checkArgUniquenessPerField(typeNode) {\n var _typeNode$fields;\n\n const typeName = typeNode.name.value; // FIXME: https://github.com/graphql/graphql-js/issues/2203\n\n /* c8 ignore next */\n\n const fieldNodes =\n (_typeNode$fields = typeNode.fields) !== null &&\n _typeNode$fields !== void 0\n ? _typeNode$fields\n : [];\n\n for (const fieldDef of fieldNodes) {\n var _fieldDef$arguments;\n\n const fieldName = fieldDef.name.value; // FIXME: https://github.com/graphql/graphql-js/issues/2203\n\n /* c8 ignore next */\n\n const argumentNodes =\n (_fieldDef$arguments = fieldDef.arguments) !== null &&\n _fieldDef$arguments !== void 0\n ? _fieldDef$arguments\n : [];\n checkArgUniqueness(`${typeName}.${fieldName}`, argumentNodes);\n }\n\n return false;\n }\n\n function checkArgUniqueness(parentName, argumentNodes) {\n const seenArgs = groupBy(argumentNodes, (arg) => arg.name.value);\n\n for (const [argName, argNodes] of seenArgs) {\n if (argNodes.length > 1) {\n context.reportError(\n new GraphQLError(\n `Argument \"${parentName}(${argName}:)\" can only be defined once.`,\n {\n nodes: argNodes.map((node) => node.name),\n },\n ),\n );\n }\n }\n\n return false;\n }\n}\n","import { groupBy } from '../../jsutils/groupBy.mjs';\nimport { GraphQLError } from '../../error/GraphQLError.mjs';\n\n/**\n * Unique argument names\n *\n * A GraphQL field or directive is only valid if all supplied arguments are\n * uniquely named.\n *\n * See https://spec.graphql.org/draft/#sec-Argument-Names\n */\nexport function UniqueArgumentNamesRule(context) {\n return {\n Field: checkArgUniqueness,\n Directive: checkArgUniqueness,\n };\n\n function checkArgUniqueness(parentNode) {\n var _parentNode$arguments;\n\n // FIXME: https://github.com/graphql/graphql-js/issues/2203\n\n /* c8 ignore next */\n const argumentNodes =\n (_parentNode$arguments = parentNode.arguments) !== null &&\n _parentNode$arguments !== void 0\n ? _parentNode$arguments\n : [];\n const seenArgs = groupBy(argumentNodes, (arg) => arg.name.value);\n\n for (const [argName, argNodes] of seenArgs) {\n if (argNodes.length > 1) {\n context.reportError(\n new GraphQLError(\n `There can be only one argument named \"${argName}\".`,\n {\n nodes: argNodes.map((node) => node.name),\n },\n ),\n );\n }\n }\n }\n}\n","import { GraphQLError } from '../../error/GraphQLError.mjs';\n\n/**\n * Unique directive names\n *\n * A GraphQL document is only valid if all defined directives have unique names.\n */\nexport function UniqueDirectiveNamesRule(context) {\n const knownDirectiveNames = Object.create(null);\n const schema = context.getSchema();\n return {\n DirectiveDefinition(node) {\n const directiveName = node.name.value;\n\n if (\n schema !== null &&\n schema !== void 0 &&\n schema.getDirective(directiveName)\n ) {\n context.reportError(\n new GraphQLError(\n `Directive \"@${directiveName}\" already exists in the schema. It cannot be redefined.`,\n {\n nodes: node.name,\n },\n ),\n );\n return;\n }\n\n if (knownDirectiveNames[directiveName]) {\n context.reportError(\n new GraphQLError(\n `There can be only one directive named \"@${directiveName}\".`,\n {\n nodes: [knownDirectiveNames[directiveName], node.name],\n },\n ),\n );\n } else {\n knownDirectiveNames[directiveName] = node.name;\n }\n\n return false;\n },\n };\n}\n","import { GraphQLError } from '../../error/GraphQLError.mjs';\nimport { Kind } from '../../language/kinds.mjs';\nimport {\n isTypeDefinitionNode,\n isTypeExtensionNode,\n} from '../../language/predicates.mjs';\nimport { specifiedDirectives } from '../../type/directives.mjs';\n\n/**\n * Unique directive names per location\n *\n * A GraphQL document is only valid if all non-repeatable directives at\n * a given location are uniquely named.\n *\n * See https://spec.graphql.org/draft/#sec-Directives-Are-Unique-Per-Location\n */\nexport function UniqueDirectivesPerLocationRule(context) {\n const uniqueDirectiveMap = Object.create(null);\n const schema = context.getSchema();\n const definedDirectives = schema\n ? schema.getDirectives()\n : specifiedDirectives;\n\n for (const directive of definedDirectives) {\n uniqueDirectiveMap[directive.name] = !directive.isRepeatable;\n }\n\n const astDefinitions = context.getDocument().definitions;\n\n for (const def of astDefinitions) {\n if (def.kind === Kind.DIRECTIVE_DEFINITION) {\n uniqueDirectiveMap[def.name.value] = !def.repeatable;\n }\n }\n\n const schemaDirectives = Object.create(null);\n const typeDirectivesMap = Object.create(null);\n return {\n // Many different AST nodes may contain directives. Rather than listing\n // them all, just listen for entering any node, and check to see if it\n // defines any directives.\n enter(node) {\n if (!('directives' in node) || !node.directives) {\n return;\n }\n\n let seenDirectives;\n\n if (\n node.kind === Kind.SCHEMA_DEFINITION ||\n node.kind === Kind.SCHEMA_EXTENSION\n ) {\n seenDirectives = schemaDirectives;\n } else if (isTypeDefinitionNode(node) || isTypeExtensionNode(node)) {\n const typeName = node.name.value;\n seenDirectives = typeDirectivesMap[typeName];\n\n if (seenDirectives === undefined) {\n typeDirectivesMap[typeName] = seenDirectives = Object.create(null);\n }\n } else {\n seenDirectives = Object.create(null);\n }\n\n for (const directive of node.directives) {\n const directiveName = directive.name.value;\n\n if (uniqueDirectiveMap[directiveName]) {\n if (seenDirectives[directiveName]) {\n context.reportError(\n new GraphQLError(\n `The directive \"@${directiveName}\" can only be used once at this location.`,\n {\n nodes: [seenDirectives[directiveName], directive],\n },\n ),\n );\n } else {\n seenDirectives[directiveName] = directive;\n }\n }\n }\n },\n };\n}\n","import { GraphQLError } from '../../error/GraphQLError.mjs';\nimport { isEnumType } from '../../type/definition.mjs';\n\n/**\n * Unique enum value names\n *\n * A GraphQL enum type is only valid if all its values are uniquely named.\n */\nexport function UniqueEnumValueNamesRule(context) {\n const schema = context.getSchema();\n const existingTypeMap = schema ? schema.getTypeMap() : Object.create(null);\n const knownValueNames = Object.create(null);\n return {\n EnumTypeDefinition: checkValueUniqueness,\n EnumTypeExtension: checkValueUniqueness,\n };\n\n function checkValueUniqueness(node) {\n var _node$values;\n\n const typeName = node.name.value;\n\n if (!knownValueNames[typeName]) {\n knownValueNames[typeName] = Object.create(null);\n } // FIXME: https://github.com/graphql/graphql-js/issues/2203\n\n /* c8 ignore next */\n\n const valueNodes =\n (_node$values = node.values) !== null && _node$values !== void 0\n ? _node$values\n : [];\n const valueNames = knownValueNames[typeName];\n\n for (const valueDef of valueNodes) {\n const valueName = valueDef.name.value;\n const existingType = existingTypeMap[typeName];\n\n if (isEnumType(existingType) && existingType.getValue(valueName)) {\n context.reportError(\n new GraphQLError(\n `Enum value \"${typeName}.${valueName}\" already exists in the schema. It cannot also be defined in this type extension.`,\n {\n nodes: valueDef.name,\n },\n ),\n );\n } else if (valueNames[valueName]) {\n context.reportError(\n new GraphQLError(\n `Enum value \"${typeName}.${valueName}\" can only be defined once.`,\n {\n nodes: [valueNames[valueName], valueDef.name],\n },\n ),\n );\n } else {\n valueNames[valueName] = valueDef.name;\n }\n }\n\n return false;\n }\n}\n","import { GraphQLError } from '../../error/GraphQLError.mjs';\nimport {\n isInputObjectType,\n isInterfaceType,\n isObjectType,\n} from '../../type/definition.mjs';\n\n/**\n * Unique field definition names\n *\n * A GraphQL complex type is only valid if all its fields are uniquely named.\n */\nexport function UniqueFieldDefinitionNamesRule(context) {\n const schema = context.getSchema();\n const existingTypeMap = schema ? schema.getTypeMap() : Object.create(null);\n const knownFieldNames = Object.create(null);\n return {\n InputObjectTypeDefinition: checkFieldUniqueness,\n InputObjectTypeExtension: checkFieldUniqueness,\n InterfaceTypeDefinition: checkFieldUniqueness,\n InterfaceTypeExtension: checkFieldUniqueness,\n ObjectTypeDefinition: checkFieldUniqueness,\n ObjectTypeExtension: checkFieldUniqueness,\n };\n\n function checkFieldUniqueness(node) {\n var _node$fields;\n\n const typeName = node.name.value;\n\n if (!knownFieldNames[typeName]) {\n knownFieldNames[typeName] = Object.create(null);\n } // FIXME: https://github.com/graphql/graphql-js/issues/2203\n\n /* c8 ignore next */\n\n const fieldNodes =\n (_node$fields = node.fields) !== null && _node$fields !== void 0\n ? _node$fields\n : [];\n const fieldNames = knownFieldNames[typeName];\n\n for (const fieldDef of fieldNodes) {\n const fieldName = fieldDef.name.value;\n\n if (hasField(existingTypeMap[typeName], fieldName)) {\n context.reportError(\n new GraphQLError(\n `Field \"${typeName}.${fieldName}\" already exists in the schema. It cannot also be defined in this type extension.`,\n {\n nodes: fieldDef.name,\n },\n ),\n );\n } else if (fieldNames[fieldName]) {\n context.reportError(\n new GraphQLError(\n `Field \"${typeName}.${fieldName}\" can only be defined once.`,\n {\n nodes: [fieldNames[fieldName], fieldDef.name],\n },\n ),\n );\n } else {\n fieldNames[fieldName] = fieldDef.name;\n }\n }\n\n return false;\n }\n}\n\nfunction hasField(type, fieldName) {\n if (isObjectType(type) || isInterfaceType(type) || isInputObjectType(type)) {\n return type.getFields()[fieldName] != null;\n }\n\n return false;\n}\n","import { GraphQLError } from '../../error/GraphQLError.mjs';\n\n/**\n * Unique fragment names\n *\n * A GraphQL document is only valid if all defined fragments have unique names.\n *\n * See https://spec.graphql.org/draft/#sec-Fragment-Name-Uniqueness\n */\nexport function UniqueFragmentNamesRule(context) {\n const knownFragmentNames = Object.create(null);\n return {\n OperationDefinition: () => false,\n\n FragmentDefinition(node) {\n const fragmentName = node.name.value;\n\n if (knownFragmentNames[fragmentName]) {\n context.reportError(\n new GraphQLError(\n `There can be only one fragment named \"${fragmentName}\".`,\n {\n nodes: [knownFragmentNames[fragmentName], node.name],\n },\n ),\n );\n } else {\n knownFragmentNames[fragmentName] = node.name;\n }\n\n return false;\n },\n };\n}\n","import { invariant } from '../../jsutils/invariant.mjs';\nimport { GraphQLError } from '../../error/GraphQLError.mjs';\n\n/**\n * Unique input field names\n *\n * A GraphQL input object value is only valid if all supplied fields are\n * uniquely named.\n *\n * See https://spec.graphql.org/draft/#sec-Input-Object-Field-Uniqueness\n */\nexport function UniqueInputFieldNamesRule(context) {\n const knownNameStack = [];\n let knownNames = Object.create(null);\n return {\n ObjectValue: {\n enter() {\n knownNameStack.push(knownNames);\n knownNames = Object.create(null);\n },\n\n leave() {\n const prevKnownNames = knownNameStack.pop();\n prevKnownNames || invariant(false);\n knownNames = prevKnownNames;\n },\n },\n\n ObjectField(node) {\n const fieldName = node.name.value;\n\n if (knownNames[fieldName]) {\n context.reportError(\n new GraphQLError(\n `There can be only one input field named \"${fieldName}\".`,\n {\n nodes: [knownNames[fieldName], node.name],\n },\n ),\n );\n } else {\n knownNames[fieldName] = node.name;\n }\n },\n };\n}\n","import { GraphQLError } from '../../error/GraphQLError.mjs';\n\n/**\n * Unique operation names\n *\n * A GraphQL document is only valid if all defined operations have unique names.\n *\n * See https://spec.graphql.org/draft/#sec-Operation-Name-Uniqueness\n */\nexport function UniqueOperationNamesRule(context) {\n const knownOperationNames = Object.create(null);\n return {\n OperationDefinition(node) {\n const operationName = node.name;\n\n if (operationName) {\n if (knownOperationNames[operationName.value]) {\n context.reportError(\n new GraphQLError(\n `There can be only one operation named \"${operationName.value}\".`,\n {\n nodes: [\n knownOperationNames[operationName.value],\n operationName,\n ],\n },\n ),\n );\n } else {\n knownOperationNames[operationName.value] = operationName;\n }\n }\n\n return false;\n },\n\n FragmentDefinition: () => false,\n };\n}\n","import { GraphQLError } from '../../error/GraphQLError.mjs';\n\n/**\n * Unique operation types\n *\n * A GraphQL document is only valid if it has only one type per operation.\n */\nexport function UniqueOperationTypesRule(context) {\n const schema = context.getSchema();\n const definedOperationTypes = Object.create(null);\n const existingOperationTypes = schema\n ? {\n query: schema.getQueryType(),\n mutation: schema.getMutationType(),\n subscription: schema.getSubscriptionType(),\n }\n : {};\n return {\n SchemaDefinition: checkOperationTypes,\n SchemaExtension: checkOperationTypes,\n };\n\n function checkOperationTypes(node) {\n var _node$operationTypes;\n\n // See: https://github.com/graphql/graphql-js/issues/2203\n\n /* c8 ignore next */\n const operationTypesNodes =\n (_node$operationTypes = node.operationTypes) !== null &&\n _node$operationTypes !== void 0\n ? _node$operationTypes\n : [];\n\n for (const operationType of operationTypesNodes) {\n const operation = operationType.operation;\n const alreadyDefinedOperationType = definedOperationTypes[operation];\n\n if (existingOperationTypes[operation]) {\n context.reportError(\n new GraphQLError(\n `Type for ${operation} already defined in the schema. It cannot be redefined.`,\n {\n nodes: operationType,\n },\n ),\n );\n } else if (alreadyDefinedOperationType) {\n context.reportError(\n new GraphQLError(\n `There can be only one ${operation} type in schema.`,\n {\n nodes: [alreadyDefinedOperationType, operationType],\n },\n ),\n );\n } else {\n definedOperationTypes[operation] = operationType;\n }\n }\n\n return false;\n }\n}\n","import { GraphQLError } from '../../error/GraphQLError.mjs';\n\n/**\n * Unique type names\n *\n * A GraphQL document is only valid if all defined types have unique names.\n */\nexport function UniqueTypeNamesRule(context) {\n const knownTypeNames = Object.create(null);\n const schema = context.getSchema();\n return {\n ScalarTypeDefinition: checkTypeName,\n ObjectTypeDefinition: checkTypeName,\n InterfaceTypeDefinition: checkTypeName,\n UnionTypeDefinition: checkTypeName,\n EnumTypeDefinition: checkTypeName,\n InputObjectTypeDefinition: checkTypeName,\n };\n\n function checkTypeName(node) {\n const typeName = node.name.value;\n\n if (schema !== null && schema !== void 0 && schema.getType(typeName)) {\n context.reportError(\n new GraphQLError(\n `Type \"${typeName}\" already exists in the schema. It cannot also be defined in this type definition.`,\n {\n nodes: node.name,\n },\n ),\n );\n return;\n }\n\n if (knownTypeNames[typeName]) {\n context.reportError(\n new GraphQLError(`There can be only one type named \"${typeName}\".`, {\n nodes: [knownTypeNames[typeName], node.name],\n }),\n );\n } else {\n knownTypeNames[typeName] = node.name;\n }\n\n return false;\n }\n}\n","import { groupBy } from '../../jsutils/groupBy.mjs';\nimport { GraphQLError } from '../../error/GraphQLError.mjs';\n\n/**\n * Unique variable names\n *\n * A GraphQL operation is only valid if all its variables are uniquely named.\n */\nexport function UniqueVariableNamesRule(context) {\n return {\n OperationDefinition(operationNode) {\n var _operationNode$variab;\n\n // See: https://github.com/graphql/graphql-js/issues/2203\n\n /* c8 ignore next */\n const variableDefinitions =\n (_operationNode$variab = operationNode.variableDefinitions) !== null &&\n _operationNode$variab !== void 0\n ? _operationNode$variab\n : [];\n const seenVariableDefinitions = groupBy(\n variableDefinitions,\n (node) => node.variable.name.value,\n );\n\n for (const [variableName, variableNodes] of seenVariableDefinitions) {\n if (variableNodes.length > 1) {\n context.reportError(\n new GraphQLError(\n `There can be only one variable named \"$${variableName}\".`,\n {\n nodes: variableNodes.map((node) => node.variable.name),\n },\n ),\n );\n }\n }\n },\n };\n}\n","import { didYouMean } from '../../jsutils/didYouMean.mjs';\nimport { inspect } from '../../jsutils/inspect.mjs';\nimport { keyMap } from '../../jsutils/keyMap.mjs';\nimport { suggestionList } from '../../jsutils/suggestionList.mjs';\nimport { GraphQLError } from '../../error/GraphQLError.mjs';\nimport { print } from '../../language/printer.mjs';\nimport {\n getNamedType,\n getNullableType,\n isInputObjectType,\n isLeafType,\n isListType,\n isNonNullType,\n isRequiredInputField,\n} from '../../type/definition.mjs';\n\n/**\n * Value literals of correct type\n *\n * A GraphQL document is only valid if all value literals are of the type\n * expected at their position.\n *\n * See https://spec.graphql.org/draft/#sec-Values-of-Correct-Type\n */\nexport function ValuesOfCorrectTypeRule(context) {\n return {\n ListValue(node) {\n // Note: TypeInfo will traverse into a list's item type, so look to the\n // parent input type to check if it is a list.\n const type = getNullableType(context.getParentInputType());\n\n if (!isListType(type)) {\n isValidValueNode(context, node);\n return false; // Don't traverse further.\n }\n },\n\n ObjectValue(node) {\n const type = getNamedType(context.getInputType());\n\n if (!isInputObjectType(type)) {\n isValidValueNode(context, node);\n return false; // Don't traverse further.\n } // Ensure every required field exists.\n\n const fieldNodeMap = keyMap(node.fields, (field) => field.name.value);\n\n for (const fieldDef of Object.values(type.getFields())) {\n const fieldNode = fieldNodeMap[fieldDef.name];\n\n if (!fieldNode && isRequiredInputField(fieldDef)) {\n const typeStr = inspect(fieldDef.type);\n context.reportError(\n new GraphQLError(\n `Field \"${type.name}.${fieldDef.name}\" of required type \"${typeStr}\" was not provided.`,\n {\n nodes: node,\n },\n ),\n );\n }\n }\n },\n\n ObjectField(node) {\n const parentType = getNamedType(context.getParentInputType());\n const fieldType = context.getInputType();\n\n if (!fieldType && isInputObjectType(parentType)) {\n const suggestions = suggestionList(\n node.name.value,\n Object.keys(parentType.getFields()),\n );\n context.reportError(\n new GraphQLError(\n `Field \"${node.name.value}\" is not defined by type \"${parentType.name}\".` +\n didYouMean(suggestions),\n {\n nodes: node,\n },\n ),\n );\n }\n },\n\n NullValue(node) {\n const type = context.getInputType();\n\n if (isNonNullType(type)) {\n context.reportError(\n new GraphQLError(\n `Expected value of type \"${inspect(type)}\", found ${print(node)}.`,\n {\n nodes: node,\n },\n ),\n );\n }\n },\n\n EnumValue: (node) => isValidValueNode(context, node),\n IntValue: (node) => isValidValueNode(context, node),\n FloatValue: (node) => isValidValueNode(context, node),\n StringValue: (node) => isValidValueNode(context, node),\n BooleanValue: (node) => isValidValueNode(context, node),\n };\n}\n/**\n * Any value literal may be a valid representation of a Scalar, depending on\n * that scalar type.\n */\n\nfunction isValidValueNode(context, node) {\n // Report any error at the full type expected by the location.\n const locationType = context.getInputType();\n\n if (!locationType) {\n return;\n }\n\n const type = getNamedType(locationType);\n\n if (!isLeafType(type)) {\n const typeStr = inspect(locationType);\n context.reportError(\n new GraphQLError(\n `Expected value of type \"${typeStr}\", found ${print(node)}.`,\n {\n nodes: node,\n },\n ),\n );\n return;\n } // Scalars and Enums determine if a literal value is valid via parseLiteral(),\n // which may throw or return an invalid value to indicate failure.\n\n try {\n const parseResult = type.parseLiteral(\n node,\n undefined,\n /* variables */\n );\n\n if (parseResult === undefined) {\n const typeStr = inspect(locationType);\n context.reportError(\n new GraphQLError(\n `Expected value of type \"${typeStr}\", found ${print(node)}.`,\n {\n nodes: node,\n },\n ),\n );\n }\n } catch (error) {\n const typeStr = inspect(locationType);\n\n if (error instanceof GraphQLError) {\n context.reportError(error);\n } else {\n context.reportError(\n new GraphQLError(\n `Expected value of type \"${typeStr}\", found ${print(node)}; ` +\n error.message,\n {\n nodes: node,\n originalError: error,\n },\n ),\n );\n }\n }\n}\n","import { GraphQLError } from '../../error/GraphQLError.mjs';\nimport { print } from '../../language/printer.mjs';\nimport { isInputType } from '../../type/definition.mjs';\nimport { typeFromAST } from '../../utilities/typeFromAST.mjs';\n\n/**\n * Variables are input types\n *\n * A GraphQL operation is only valid if all the variables it defines are of\n * input types (scalar, enum, or input object).\n *\n * See https://spec.graphql.org/draft/#sec-Variables-Are-Input-Types\n */\nexport function VariablesAreInputTypesRule(context) {\n return {\n VariableDefinition(node) {\n const type = typeFromAST(context.getSchema(), node.type);\n\n if (type !== undefined && !isInputType(type)) {\n const variableName = node.variable.name.value;\n const typeName = print(node.type);\n context.reportError(\n new GraphQLError(\n `Variable \"$${variableName}\" cannot be non-input type \"${typeName}\".`,\n {\n nodes: node.type,\n },\n ),\n );\n }\n },\n };\n}\n","import { inspect } from '../../jsutils/inspect.mjs';\nimport { GraphQLError } from '../../error/GraphQLError.mjs';\nimport { Kind } from '../../language/kinds.mjs';\nimport { isNonNullType } from '../../type/definition.mjs';\nimport { isTypeSubTypeOf } from '../../utilities/typeComparators.mjs';\nimport { typeFromAST } from '../../utilities/typeFromAST.mjs';\n\n/**\n * Variables in allowed position\n *\n * Variable usages must be compatible with the arguments they are passed to.\n *\n * See https://spec.graphql.org/draft/#sec-All-Variable-Usages-are-Allowed\n */\nexport function VariablesInAllowedPositionRule(context) {\n let varDefMap = Object.create(null);\n return {\n OperationDefinition: {\n enter() {\n varDefMap = Object.create(null);\n },\n\n leave(operation) {\n const usages = context.getRecursiveVariableUsages(operation);\n\n for (const { node, type, defaultValue } of usages) {\n const varName = node.name.value;\n const varDef = varDefMap[varName];\n\n if (varDef && type) {\n // A var type is allowed if it is the same or more strict (e.g. is\n // a subtype of) than the expected type. It can be more strict if\n // the variable type is non-null when the expected type is nullable.\n // If both are list types, the variable item type can be more strict\n // than the expected item type (contravariant).\n const schema = context.getSchema();\n const varType = typeFromAST(schema, varDef.type);\n\n if (\n varType &&\n !allowedVariableUsage(\n schema,\n varType,\n varDef.defaultValue,\n type,\n defaultValue,\n )\n ) {\n const varTypeStr = inspect(varType);\n const typeStr = inspect(type);\n context.reportError(\n new GraphQLError(\n `Variable \"$${varName}\" of type \"${varTypeStr}\" used in position expecting type \"${typeStr}\".`,\n {\n nodes: [varDef, node],\n },\n ),\n );\n }\n }\n }\n },\n },\n\n VariableDefinition(node) {\n varDefMap[node.variable.name.value] = node;\n },\n };\n}\n/**\n * Returns true if the variable is allowed in the location it was found,\n * which includes considering if default values exist for either the variable\n * or the location at which it is located.\n */\n\nfunction allowedVariableUsage(\n schema,\n varType,\n varDefaultValue,\n locationType,\n locationDefaultValue,\n) {\n if (isNonNullType(locationType) && !isNonNullType(varType)) {\n const hasNonNullVariableDefaultValue =\n varDefaultValue != null && varDefaultValue.kind !== Kind.NULL;\n const hasLocationDefaultValue = locationDefaultValue !== undefined;\n\n if (!hasNonNullVariableDefaultValue && !hasLocationDefaultValue) {\n return false;\n }\n\n const nullableLocationType = locationType.ofType;\n return isTypeSubTypeOf(schema, varType, nullableLocationType);\n }\n\n return isTypeSubTypeOf(schema, varType, locationType);\n}\n","// Spec Section: \"Executable Definitions\"\nimport { ExecutableDefinitionsRule } from './rules/ExecutableDefinitionsRule.mjs'; // Spec Section: \"Field Selections on Objects, Interfaces, and Unions Types\"\n\nimport { FieldsOnCorrectTypeRule } from './rules/FieldsOnCorrectTypeRule.mjs'; // Spec Section: \"Fragments on Composite Types\"\n\nimport { FragmentsOnCompositeTypesRule } from './rules/FragmentsOnCompositeTypesRule.mjs'; // Spec Section: \"Argument Names\"\n\nimport {\n KnownArgumentNamesOnDirectivesRule,\n KnownArgumentNamesRule,\n} from './rules/KnownArgumentNamesRule.mjs'; // Spec Section: \"Directives Are Defined\"\n\nimport { KnownDirectivesRule } from './rules/KnownDirectivesRule.mjs'; // Spec Section: \"Fragment spread target defined\"\n\nimport { KnownFragmentNamesRule } from './rules/KnownFragmentNamesRule.mjs'; // Spec Section: \"Fragment Spread Type Existence\"\n\nimport { KnownTypeNamesRule } from './rules/KnownTypeNamesRule.mjs'; // Spec Section: \"Lone Anonymous Operation\"\n\nimport { LoneAnonymousOperationRule } from './rules/LoneAnonymousOperationRule.mjs'; // SDL-specific validation rules\n\nimport { LoneSchemaDefinitionRule } from './rules/LoneSchemaDefinitionRule.mjs'; // Spec Section: \"Fragments must not form cycles\"\n\nimport { NoFragmentCyclesRule } from './rules/NoFragmentCyclesRule.mjs'; // Spec Section: \"All Variable Used Defined\"\n\nimport { NoUndefinedVariablesRule } from './rules/NoUndefinedVariablesRule.mjs'; // Spec Section: \"Fragments must be used\"\n\nimport { NoUnusedFragmentsRule } from './rules/NoUnusedFragmentsRule.mjs'; // Spec Section: \"All Variables Used\"\n\nimport { NoUnusedVariablesRule } from './rules/NoUnusedVariablesRule.mjs'; // Spec Section: \"Field Selection Merging\"\n\nimport { OverlappingFieldsCanBeMergedRule } from './rules/OverlappingFieldsCanBeMergedRule.mjs'; // Spec Section: \"Fragment spread is possible\"\n\nimport { PossibleFragmentSpreadsRule } from './rules/PossibleFragmentSpreadsRule.mjs';\nimport { PossibleTypeExtensionsRule } from './rules/PossibleTypeExtensionsRule.mjs'; // Spec Section: \"Argument Optionality\"\n\nimport {\n ProvidedRequiredArgumentsOnDirectivesRule,\n ProvidedRequiredArgumentsRule,\n} from './rules/ProvidedRequiredArgumentsRule.mjs'; // Spec Section: \"Leaf Field Selections\"\n\nimport { ScalarLeafsRule } from './rules/ScalarLeafsRule.mjs'; // Spec Section: \"Subscriptions with Single Root Field\"\n\nimport { SingleFieldSubscriptionsRule } from './rules/SingleFieldSubscriptionsRule.mjs';\nimport { UniqueArgumentDefinitionNamesRule } from './rules/UniqueArgumentDefinitionNamesRule.mjs'; // Spec Section: \"Argument Uniqueness\"\n\nimport { UniqueArgumentNamesRule } from './rules/UniqueArgumentNamesRule.mjs';\nimport { UniqueDirectiveNamesRule } from './rules/UniqueDirectiveNamesRule.mjs'; // Spec Section: \"Directives Are Unique Per Location\"\n\nimport { UniqueDirectivesPerLocationRule } from './rules/UniqueDirectivesPerLocationRule.mjs';\nimport { UniqueEnumValueNamesRule } from './rules/UniqueEnumValueNamesRule.mjs';\nimport { UniqueFieldDefinitionNamesRule } from './rules/UniqueFieldDefinitionNamesRule.mjs'; // Spec Section: \"Fragment Name Uniqueness\"\n\nimport { UniqueFragmentNamesRule } from './rules/UniqueFragmentNamesRule.mjs'; // Spec Section: \"Input Object Field Uniqueness\"\n\nimport { UniqueInputFieldNamesRule } from './rules/UniqueInputFieldNamesRule.mjs'; // Spec Section: \"Operation Name Uniqueness\"\n\nimport { UniqueOperationNamesRule } from './rules/UniqueOperationNamesRule.mjs';\nimport { UniqueOperationTypesRule } from './rules/UniqueOperationTypesRule.mjs';\nimport { UniqueTypeNamesRule } from './rules/UniqueTypeNamesRule.mjs'; // Spec Section: \"Variable Uniqueness\"\n\nimport { UniqueVariableNamesRule } from './rules/UniqueVariableNamesRule.mjs'; // Spec Section: \"Value Type Correctness\"\n\nimport { ValuesOfCorrectTypeRule } from './rules/ValuesOfCorrectTypeRule.mjs'; // Spec Section: \"Variables are Input Types\"\n\nimport { VariablesAreInputTypesRule } from './rules/VariablesAreInputTypesRule.mjs'; // Spec Section: \"All Variable Usages Are Allowed\"\n\nimport { VariablesInAllowedPositionRule } from './rules/VariablesInAllowedPositionRule.mjs';\n\n/**\n * This set includes all validation rules defined by the GraphQL spec.\n *\n * The order of the rules in this list has been adjusted to lead to the\n * most clear output when encountering multiple validation errors.\n */\nexport const specifiedRules = Object.freeze([\n ExecutableDefinitionsRule,\n UniqueOperationNamesRule,\n LoneAnonymousOperationRule,\n SingleFieldSubscriptionsRule,\n KnownTypeNamesRule,\n FragmentsOnCompositeTypesRule,\n VariablesAreInputTypesRule,\n ScalarLeafsRule,\n FieldsOnCorrectTypeRule,\n UniqueFragmentNamesRule,\n KnownFragmentNamesRule,\n NoUnusedFragmentsRule,\n PossibleFragmentSpreadsRule,\n NoFragmentCyclesRule,\n UniqueVariableNamesRule,\n NoUndefinedVariablesRule,\n NoUnusedVariablesRule,\n KnownDirectivesRule,\n UniqueDirectivesPerLocationRule,\n KnownArgumentNamesRule,\n UniqueArgumentNamesRule,\n ValuesOfCorrectTypeRule,\n ProvidedRequiredArgumentsRule,\n VariablesInAllowedPositionRule,\n OverlappingFieldsCanBeMergedRule,\n UniqueInputFieldNamesRule,\n]);\n/**\n * @internal\n */\n\nexport const specifiedSDLRules = Object.freeze([\n LoneSchemaDefinitionRule,\n UniqueOperationTypesRule,\n UniqueTypeNamesRule,\n UniqueEnumValueNamesRule,\n UniqueFieldDefinitionNamesRule,\n UniqueArgumentDefinitionNamesRule,\n UniqueDirectiveNamesRule,\n KnownTypeNamesRule,\n KnownDirectivesRule,\n UniqueDirectivesPerLocationRule,\n PossibleTypeExtensionsRule,\n KnownArgumentNamesOnDirectivesRule,\n UniqueArgumentNamesRule,\n UniqueInputFieldNamesRule,\n ProvidedRequiredArgumentsOnDirectivesRule,\n]);\n","import { Kind } from '../language/kinds.mjs';\nimport { visit } from '../language/visitor.mjs';\nimport { TypeInfo, visitWithTypeInfo } from '../utilities/TypeInfo.mjs';\n\n/**\n * An instance of this class is passed as the \"this\" context to all validators,\n * allowing access to commonly useful contextual information from within a\n * validation rule.\n */\nexport class ASTValidationContext {\n constructor(ast, onError) {\n this._ast = ast;\n this._fragments = undefined;\n this._fragmentSpreads = new Map();\n this._recursivelyReferencedFragments = new Map();\n this._onError = onError;\n }\n\n get [Symbol.toStringTag]() {\n return 'ASTValidationContext';\n }\n\n reportError(error) {\n this._onError(error);\n }\n\n getDocument() {\n return this._ast;\n }\n\n getFragment(name) {\n let fragments;\n\n if (this._fragments) {\n fragments = this._fragments;\n } else {\n fragments = Object.create(null);\n\n for (const defNode of this.getDocument().definitions) {\n if (defNode.kind === Kind.FRAGMENT_DEFINITION) {\n fragments[defNode.name.value] = defNode;\n }\n }\n\n this._fragments = fragments;\n }\n\n return fragments[name];\n }\n\n getFragmentSpreads(node) {\n let spreads = this._fragmentSpreads.get(node);\n\n if (!spreads) {\n spreads = [];\n const setsToVisit = [node];\n let set;\n\n while ((set = setsToVisit.pop())) {\n for (const selection of set.selections) {\n if (selection.kind === Kind.FRAGMENT_SPREAD) {\n spreads.push(selection);\n } else if (selection.selectionSet) {\n setsToVisit.push(selection.selectionSet);\n }\n }\n }\n\n this._fragmentSpreads.set(node, spreads);\n }\n\n return spreads;\n }\n\n getRecursivelyReferencedFragments(operation) {\n let fragments = this._recursivelyReferencedFragments.get(operation);\n\n if (!fragments) {\n fragments = [];\n const collectedNames = Object.create(null);\n const nodesToVisit = [operation.selectionSet];\n let node;\n\n while ((node = nodesToVisit.pop())) {\n for (const spread of this.getFragmentSpreads(node)) {\n const fragName = spread.name.value;\n\n if (collectedNames[fragName] !== true) {\n collectedNames[fragName] = true;\n const fragment = this.getFragment(fragName);\n\n if (fragment) {\n fragments.push(fragment);\n nodesToVisit.push(fragment.selectionSet);\n }\n }\n }\n }\n\n this._recursivelyReferencedFragments.set(operation, fragments);\n }\n\n return fragments;\n }\n}\nexport class SDLValidationContext extends ASTValidationContext {\n constructor(ast, schema, onError) {\n super(ast, onError);\n this._schema = schema;\n }\n\n get [Symbol.toStringTag]() {\n return 'SDLValidationContext';\n }\n\n getSchema() {\n return this._schema;\n }\n}\nexport class ValidationContext extends ASTValidationContext {\n constructor(schema, ast, typeInfo, onError) {\n super(ast, onError);\n this._schema = schema;\n this._typeInfo = typeInfo;\n this._variableUsages = new Map();\n this._recursiveVariableUsages = new Map();\n }\n\n get [Symbol.toStringTag]() {\n return 'ValidationContext';\n }\n\n getSchema() {\n return this._schema;\n }\n\n getVariableUsages(node) {\n let usages = this._variableUsages.get(node);\n\n if (!usages) {\n const newUsages = [];\n const typeInfo = new TypeInfo(this._schema);\n visit(\n node,\n visitWithTypeInfo(typeInfo, {\n VariableDefinition: () => false,\n\n Variable(variable) {\n newUsages.push({\n node: variable,\n type: typeInfo.getInputType(),\n defaultValue: typeInfo.getDefaultValue(),\n });\n },\n }),\n );\n usages = newUsages;\n\n this._variableUsages.set(node, usages);\n }\n\n return usages;\n }\n\n getRecursiveVariableUsages(operation) {\n let usages = this._recursiveVariableUsages.get(operation);\n\n if (!usages) {\n usages = this.getVariableUsages(operation);\n\n for (const frag of this.getRecursivelyReferencedFragments(operation)) {\n usages = usages.concat(this.getVariableUsages(frag));\n }\n\n this._recursiveVariableUsages.set(operation, usages);\n }\n\n return usages;\n }\n\n getType() {\n return this._typeInfo.getType();\n }\n\n getParentType() {\n return this._typeInfo.getParentType();\n }\n\n getInputType() {\n return this._typeInfo.getInputType();\n }\n\n getParentInputType() {\n return this._typeInfo.getParentInputType();\n }\n\n getFieldDef() {\n return this._typeInfo.getFieldDef();\n }\n\n getDirective() {\n return this._typeInfo.getDirective();\n }\n\n getArgument() {\n return this._typeInfo.getArgument();\n }\n\n getEnumValue() {\n return this._typeInfo.getEnumValue();\n }\n}\n","import { devAssert } from '../jsutils/devAssert.mjs';\nimport { GraphQLError } from '../error/GraphQLError.mjs';\nimport { visit, visitInParallel } from '../language/visitor.mjs';\nimport { assertValidSchema } from '../type/validate.mjs';\nimport { TypeInfo, visitWithTypeInfo } from '../utilities/TypeInfo.mjs';\nimport { specifiedRules, specifiedSDLRules } from './specifiedRules.mjs';\nimport {\n SDLValidationContext,\n ValidationContext,\n} from './ValidationContext.mjs';\n/**\n * Implements the \"Validation\" section of the spec.\n *\n * Validation runs synchronously, returning an array of encountered errors, or\n * an empty array if no errors were encountered and the document is valid.\n *\n * A list of specific validation rules may be provided. If not provided, the\n * default list of rules defined by the GraphQL specification will be used.\n *\n * Each validation rules is a function which returns a visitor\n * (see the language/visitor API). Visitor methods are expected to return\n * GraphQLErrors, or Arrays of GraphQLErrors when invalid.\n *\n * Validate will stop validation after a `maxErrors` limit has been reached.\n * Attackers can send pathologically invalid queries to induce a DoS attack,\n * so by default `maxErrors` set to 100 errors.\n *\n * Optionally a custom TypeInfo instance may be provided. If not provided, one\n * will be created from the provided schema.\n */\n\nexport function validate(\n schema,\n documentAST,\n rules = specifiedRules,\n options,\n /** @deprecated will be removed in 17.0.0 */\n typeInfo = new TypeInfo(schema),\n) {\n var _options$maxErrors;\n\n const maxErrors =\n (_options$maxErrors =\n options === null || options === void 0 ? void 0 : options.maxErrors) !==\n null && _options$maxErrors !== void 0\n ? _options$maxErrors\n : 100;\n documentAST || devAssert(false, 'Must provide document.'); // If the schema used for validation is invalid, throw an error.\n\n assertValidSchema(schema);\n const abortObj = Object.freeze({});\n const errors = [];\n const context = new ValidationContext(\n schema,\n documentAST,\n typeInfo,\n (error) => {\n if (errors.length >= maxErrors) {\n errors.push(\n new GraphQLError(\n 'Too many validation errors, error limit reached. Validation aborted.',\n ),\n ); // eslint-disable-next-line @typescript-eslint/no-throw-literal\n\n throw abortObj;\n }\n\n errors.push(error);\n },\n ); // This uses a specialized visitor which runs multiple visitors in parallel,\n // while maintaining the visitor skip and break API.\n\n const visitor = visitInParallel(rules.map((rule) => rule(context))); // Visit the whole document with each instance of all provided rules.\n\n try {\n visit(documentAST, visitWithTypeInfo(typeInfo, visitor));\n } catch (e) {\n if (e !== abortObj) {\n throw e;\n }\n }\n\n return errors;\n}\n/**\n * @internal\n */\n\nexport function validateSDL(\n documentAST,\n schemaToExtend,\n rules = specifiedSDLRules,\n) {\n const errors = [];\n const context = new SDLValidationContext(\n documentAST,\n schemaToExtend,\n (error) => {\n errors.push(error);\n },\n );\n const visitors = rules.map((rule) => rule(context));\n visit(documentAST, visitInParallel(visitors));\n return errors;\n}\n/**\n * Utility function which asserts a SDL document is valid by throwing an error\n * if it is invalid.\n *\n * @internal\n */\n\nexport function assertValidSDL(documentAST) {\n const errors = validateSDL(documentAST);\n\n if (errors.length !== 0) {\n throw new Error(errors.map((error) => error.message).join('\\n\\n'));\n }\n}\n/**\n * Utility function which asserts a SDL document is valid by throwing an error\n * if it is invalid.\n *\n * @internal\n */\n\nexport function assertValidSDLExtension(documentAST, schema) {\n const errors = validateSDL(documentAST, schema);\n\n if (errors.length !== 0) {\n throw new Error(errors.map((error) => error.message).join('\\n\\n'));\n }\n}\n","/**\n * Memoizes the provided three-argument function.\n */\nexport function memoize3(fn) {\n let cache0;\n return function memoized(a1, a2, a3) {\n if (cache0 === undefined) {\n cache0 = new WeakMap();\n }\n\n let cache1 = cache0.get(a1);\n\n if (cache1 === undefined) {\n cache1 = new WeakMap();\n cache0.set(a1, cache1);\n }\n\n let cache2 = cache1.get(a2);\n\n if (cache2 === undefined) {\n cache2 = new WeakMap();\n cache1.set(a2, cache2);\n }\n\n let fnResult = cache2.get(a3);\n\n if (fnResult === undefined) {\n fnResult = fn(a1, a2, a3);\n cache2.set(a3, fnResult);\n }\n\n return fnResult;\n };\n}\n","/**\n * This function transforms a JS object `ObjMap>` into\n * a `Promise>`\n *\n * This is akin to bluebird's `Promise.props`, but implemented only using\n * `Promise.all` so it will work with any implementation of ES6 promises.\n */\nexport function promiseForObject(object) {\n return Promise.all(Object.values(object)).then((resolvedValues) => {\n const resolvedObject = Object.create(null);\n\n for (const [i, key] of Object.keys(object).entries()) {\n resolvedObject[key] = resolvedValues[i];\n }\n\n return resolvedObject;\n });\n}\n","import { isPromise } from './isPromise.mjs';\n\n/**\n * Similar to Array.prototype.reduce(), however the reducing callback may return\n * a Promise, in which case reduction will continue after each promise resolves.\n *\n * If the callback does not return a Promise, then this function will also not\n * return a Promise.\n */\nexport function promiseReduce(values, callbackFn, initialValue) {\n let accumulator = initialValue;\n\n for (const value of values) {\n accumulator = isPromise(accumulator)\n ? accumulator.then((resolved) => callbackFn(resolved, value))\n : callbackFn(accumulator, value);\n }\n\n return accumulator;\n}\n","import { inspect } from './inspect.mjs';\n/**\n * Sometimes a non-error is thrown, wrap it as an Error instance to ensure a consistent Error interface.\n */\n\nexport function toError(thrownValue) {\n return thrownValue instanceof Error\n ? thrownValue\n : new NonErrorThrown(thrownValue);\n}\n\nclass NonErrorThrown extends Error {\n constructor(thrownValue) {\n super('Unexpected error value: ' + inspect(thrownValue));\n this.name = 'NonErrorThrown';\n this.thrownValue = thrownValue;\n }\n}\n","import { toError } from '../jsutils/toError.mjs';\nimport { GraphQLError } from './GraphQLError.mjs';\n/**\n * Given an arbitrary value, presumably thrown while attempting to execute a\n * GraphQL operation, produce a new GraphQLError aware of the location in the\n * document responsible for the original Error.\n */\n\nexport function locatedError(rawOriginalError, nodes, path) {\n var _nodes;\n\n const originalError = toError(rawOriginalError); // Note: this uses a brand-check to support GraphQL errors originating from other contexts.\n\n if (isLocatedGraphQLError(originalError)) {\n return originalError;\n }\n\n return new GraphQLError(originalError.message, {\n nodes:\n (_nodes = originalError.nodes) !== null && _nodes !== void 0\n ? _nodes\n : nodes,\n source: originalError.source,\n positions: originalError.positions,\n path,\n originalError,\n });\n}\n\nfunction isLocatedGraphQLError(error) {\n return Array.isArray(error.path);\n}\n","import { devAssert } from '../jsutils/devAssert.mjs';\nimport { inspect } from '../jsutils/inspect.mjs';\nimport { invariant } from '../jsutils/invariant.mjs';\nimport { isIterableObject } from '../jsutils/isIterableObject.mjs';\nimport { isObjectLike } from '../jsutils/isObjectLike.mjs';\nimport { isPromise } from '../jsutils/isPromise.mjs';\nimport { memoize3 } from '../jsutils/memoize3.mjs';\nimport { addPath, pathToArray } from '../jsutils/Path.mjs';\nimport { promiseForObject } from '../jsutils/promiseForObject.mjs';\nimport { promiseReduce } from '../jsutils/promiseReduce.mjs';\nimport { GraphQLError } from '../error/GraphQLError.mjs';\nimport { locatedError } from '../error/locatedError.mjs';\nimport { OperationTypeNode } from '../language/ast.mjs';\nimport { Kind } from '../language/kinds.mjs';\nimport {\n isAbstractType,\n isLeafType,\n isListType,\n isNonNullType,\n isObjectType,\n} from '../type/definition.mjs';\nimport {\n SchemaMetaFieldDef,\n TypeMetaFieldDef,\n TypeNameMetaFieldDef,\n} from '../type/introspection.mjs';\nimport { assertValidSchema } from '../type/validate.mjs';\nimport {\n collectFields,\n collectSubfields as _collectSubfields,\n} from './collectFields.mjs';\nimport { getArgumentValues, getVariableValues } from './values.mjs';\n/**\n * A memoized collection of relevant subfields with regard to the return\n * type. Memoizing ensures the subfields are not repeatedly calculated, which\n * saves overhead when resolving lists of values.\n */\n\nconst collectSubfields = memoize3((exeContext, returnType, fieldNodes) =>\n _collectSubfields(\n exeContext.schema,\n exeContext.fragments,\n exeContext.variableValues,\n returnType,\n fieldNodes,\n ),\n);\n/**\n * Terminology\n *\n * \"Definitions\" are the generic name for top-level statements in the document.\n * Examples of this include:\n * 1) Operations (such as a query)\n * 2) Fragments\n *\n * \"Operations\" are a generic name for requests in the document.\n * Examples of this include:\n * 1) query,\n * 2) mutation\n *\n * \"Selections\" are the definitions that can appear legally and at\n * single level of the query. These include:\n * 1) field references e.g `a`\n * 2) fragment \"spreads\" e.g. `...c`\n * 3) inline fragment \"spreads\" e.g. `...on Type { a }`\n */\n\n/**\n * Data that must be available at all points during query execution.\n *\n * Namely, schema of the type system that is currently executing,\n * and the fragments defined in the query document\n */\n\n/**\n * Implements the \"Executing requests\" section of the GraphQL specification.\n *\n * Returns either a synchronous ExecutionResult (if all encountered resolvers\n * are synchronous), or a Promise of an ExecutionResult that will eventually be\n * resolved and never rejected.\n *\n * If the arguments to this function do not result in a legal execution context,\n * a GraphQLError will be thrown immediately explaining the invalid input.\n */\nexport function execute(args) {\n // Temporary for v15 to v16 migration. Remove in v17\n arguments.length < 2 ||\n devAssert(\n false,\n 'graphql@16 dropped long-deprecated support for positional arguments, please pass an object instead.',\n );\n const { schema, document, variableValues, rootValue } = args; // If arguments are missing or incorrect, throw an error.\n\n assertValidExecutionArguments(schema, document, variableValues); // If a valid execution context cannot be created due to incorrect arguments,\n // a \"Response\" with only errors is returned.\n\n const exeContext = buildExecutionContext(args); // Return early errors if execution context failed.\n\n if (!('schema' in exeContext)) {\n return {\n errors: exeContext,\n };\n } // Return a Promise that will eventually resolve to the data described by\n // The \"Response\" section of the GraphQL specification.\n //\n // If errors are encountered while executing a GraphQL field, only that\n // field and its descendants will be omitted, and sibling fields will still\n // be executed. An execution which encounters errors will still result in a\n // resolved Promise.\n //\n // Errors from sub-fields of a NonNull type may propagate to the top level,\n // at which point we still log the error and null the parent field, which\n // in this case is the entire response.\n\n try {\n const { operation } = exeContext;\n const result = executeOperation(exeContext, operation, rootValue);\n\n if (isPromise(result)) {\n return result.then(\n (data) => buildResponse(data, exeContext.errors),\n (error) => {\n exeContext.errors.push(error);\n return buildResponse(null, exeContext.errors);\n },\n );\n }\n\n return buildResponse(result, exeContext.errors);\n } catch (error) {\n exeContext.errors.push(error);\n return buildResponse(null, exeContext.errors);\n }\n}\n/**\n * Also implements the \"Executing requests\" section of the GraphQL specification.\n * However, it guarantees to complete synchronously (or throw an error) assuming\n * that all field resolvers are also synchronous.\n */\n\nexport function executeSync(args) {\n const result = execute(args); // Assert that the execution was synchronous.\n\n if (isPromise(result)) {\n throw new Error('GraphQL execution failed to complete synchronously.');\n }\n\n return result;\n}\n/**\n * Given a completed execution context and data, build the `{ errors, data }`\n * response defined by the \"Response\" section of the GraphQL specification.\n */\n\nfunction buildResponse(data, errors) {\n return errors.length === 0\n ? {\n data,\n }\n : {\n errors,\n data,\n };\n}\n/**\n * Essential assertions before executing to provide developer feedback for\n * improper use of the GraphQL library.\n *\n * @internal\n */\n\nexport function assertValidExecutionArguments(\n schema,\n document,\n rawVariableValues,\n) {\n document || devAssert(false, 'Must provide document.'); // If the schema used for execution is invalid, throw an error.\n\n assertValidSchema(schema); // Variables, if provided, must be an object.\n\n rawVariableValues == null ||\n isObjectLike(rawVariableValues) ||\n devAssert(\n false,\n 'Variables must be provided as an Object where each property is a variable value. Perhaps look to see if an unparsed JSON string was provided.',\n );\n}\n/**\n * Constructs a ExecutionContext object from the arguments passed to\n * execute, which we will pass throughout the other execution methods.\n *\n * Throws a GraphQLError if a valid execution context cannot be created.\n *\n * @internal\n */\n\nexport function buildExecutionContext(args) {\n var _definition$name, _operation$variableDe;\n\n const {\n schema,\n document,\n rootValue,\n contextValue,\n variableValues: rawVariableValues,\n operationName,\n fieldResolver,\n typeResolver,\n subscribeFieldResolver,\n } = args;\n let operation;\n const fragments = Object.create(null);\n\n for (const definition of document.definitions) {\n switch (definition.kind) {\n case Kind.OPERATION_DEFINITION:\n if (operationName == null) {\n if (operation !== undefined) {\n return [\n new GraphQLError(\n 'Must provide operation name if query contains multiple operations.',\n ),\n ];\n }\n\n operation = definition;\n } else if (\n ((_definition$name = definition.name) === null ||\n _definition$name === void 0\n ? void 0\n : _definition$name.value) === operationName\n ) {\n operation = definition;\n }\n\n break;\n\n case Kind.FRAGMENT_DEFINITION:\n fragments[definition.name.value] = definition;\n break;\n\n default: // ignore non-executable definitions\n }\n }\n\n if (!operation) {\n if (operationName != null) {\n return [new GraphQLError(`Unknown operation named \"${operationName}\".`)];\n }\n\n return [new GraphQLError('Must provide an operation.')];\n } // FIXME: https://github.com/graphql/graphql-js/issues/2203\n\n /* c8 ignore next */\n\n const variableDefinitions =\n (_operation$variableDe = operation.variableDefinitions) !== null &&\n _operation$variableDe !== void 0\n ? _operation$variableDe\n : [];\n const coercedVariableValues = getVariableValues(\n schema,\n variableDefinitions,\n rawVariableValues !== null && rawVariableValues !== void 0\n ? rawVariableValues\n : {},\n {\n maxErrors: 50,\n },\n );\n\n if (coercedVariableValues.errors) {\n return coercedVariableValues.errors;\n }\n\n return {\n schema,\n fragments,\n rootValue,\n contextValue,\n operation,\n variableValues: coercedVariableValues.coerced,\n fieldResolver:\n fieldResolver !== null && fieldResolver !== void 0\n ? fieldResolver\n : defaultFieldResolver,\n typeResolver:\n typeResolver !== null && typeResolver !== void 0\n ? typeResolver\n : defaultTypeResolver,\n subscribeFieldResolver:\n subscribeFieldResolver !== null && subscribeFieldResolver !== void 0\n ? subscribeFieldResolver\n : defaultFieldResolver,\n errors: [],\n };\n}\n/**\n * Implements the \"Executing operations\" section of the spec.\n */\n\nfunction executeOperation(exeContext, operation, rootValue) {\n const rootType = exeContext.schema.getRootType(operation.operation);\n\n if (rootType == null) {\n throw new GraphQLError(\n `Schema is not configured to execute ${operation.operation} operation.`,\n {\n nodes: operation,\n },\n );\n }\n\n const rootFields = collectFields(\n exeContext.schema,\n exeContext.fragments,\n exeContext.variableValues,\n rootType,\n operation.selectionSet,\n );\n const path = undefined;\n\n switch (operation.operation) {\n case OperationTypeNode.QUERY:\n return executeFields(exeContext, rootType, rootValue, path, rootFields);\n\n case OperationTypeNode.MUTATION:\n return executeFieldsSerially(\n exeContext,\n rootType,\n rootValue,\n path,\n rootFields,\n );\n\n case OperationTypeNode.SUBSCRIPTION:\n // TODO: deprecate `subscribe` and move all logic here\n // Temporary solution until we finish merging execute and subscribe together\n return executeFields(exeContext, rootType, rootValue, path, rootFields);\n }\n}\n/**\n * Implements the \"Executing selection sets\" section of the spec\n * for fields that must be executed serially.\n */\n\nfunction executeFieldsSerially(\n exeContext,\n parentType,\n sourceValue,\n path,\n fields,\n) {\n return promiseReduce(\n fields.entries(),\n (results, [responseName, fieldNodes]) => {\n const fieldPath = addPath(path, responseName, parentType.name);\n const result = executeField(\n exeContext,\n parentType,\n sourceValue,\n fieldNodes,\n fieldPath,\n );\n\n if (result === undefined) {\n return results;\n }\n\n if (isPromise(result)) {\n return result.then((resolvedResult) => {\n results[responseName] = resolvedResult;\n return results;\n });\n }\n\n results[responseName] = result;\n return results;\n },\n Object.create(null),\n );\n}\n/**\n * Implements the \"Executing selection sets\" section of the spec\n * for fields that may be executed in parallel.\n */\n\nfunction executeFields(exeContext, parentType, sourceValue, path, fields) {\n const results = Object.create(null);\n let containsPromise = false;\n\n try {\n for (const [responseName, fieldNodes] of fields.entries()) {\n const fieldPath = addPath(path, responseName, parentType.name);\n const result = executeField(\n exeContext,\n parentType,\n sourceValue,\n fieldNodes,\n fieldPath,\n );\n\n if (result !== undefined) {\n results[responseName] = result;\n\n if (isPromise(result)) {\n containsPromise = true;\n }\n }\n }\n } catch (error) {\n if (containsPromise) {\n // Ensure that any promises returned by other fields are handled, as they may also reject.\n return promiseForObject(results).finally(() => {\n throw error;\n });\n }\n\n throw error;\n } // If there are no promises, we can just return the object\n\n if (!containsPromise) {\n return results;\n } // Otherwise, results is a map from field name to the result of resolving that\n // field, which is possibly a promise. Return a promise that will return this\n // same map, but with any promises replaced with the values they resolved to.\n\n return promiseForObject(results);\n}\n/**\n * Implements the \"Executing fields\" section of the spec\n * In particular, this function figures out the value that the field returns by\n * calling its resolve function, then calls completeValue to complete promises,\n * serialize scalars, or execute the sub-selection-set for objects.\n */\n\nfunction executeField(exeContext, parentType, source, fieldNodes, path) {\n var _fieldDef$resolve;\n\n const fieldDef = getFieldDef(exeContext.schema, parentType, fieldNodes[0]);\n\n if (!fieldDef) {\n return;\n }\n\n const returnType = fieldDef.type;\n const resolveFn =\n (_fieldDef$resolve = fieldDef.resolve) !== null &&\n _fieldDef$resolve !== void 0\n ? _fieldDef$resolve\n : exeContext.fieldResolver;\n const info = buildResolveInfo(\n exeContext,\n fieldDef,\n fieldNodes,\n parentType,\n path,\n ); // Get the resolve function, regardless of if its result is normal or abrupt (error).\n\n try {\n // Build a JS object of arguments from the field.arguments AST, using the\n // variables scope to fulfill any variable references.\n // TODO: find a way to memoize, in case this field is within a List type.\n const args = getArgumentValues(\n fieldDef,\n fieldNodes[0],\n exeContext.variableValues,\n ); // The resolve function's optional third argument is a context value that\n // is provided to every resolve function within an execution. It is commonly\n // used to represent an authenticated user, or request-specific caches.\n\n const contextValue = exeContext.contextValue;\n const result = resolveFn(source, args, contextValue, info);\n let completed;\n\n if (isPromise(result)) {\n completed = result.then((resolved) =>\n completeValue(exeContext, returnType, fieldNodes, info, path, resolved),\n );\n } else {\n completed = completeValue(\n exeContext,\n returnType,\n fieldNodes,\n info,\n path,\n result,\n );\n }\n\n if (isPromise(completed)) {\n // Note: we don't rely on a `catch` method, but we do expect \"thenable\"\n // to take a second callback for the error case.\n return completed.then(undefined, (rawError) => {\n const error = locatedError(rawError, fieldNodes, pathToArray(path));\n return handleFieldError(error, returnType, exeContext);\n });\n }\n\n return completed;\n } catch (rawError) {\n const error = locatedError(rawError, fieldNodes, pathToArray(path));\n return handleFieldError(error, returnType, exeContext);\n }\n}\n/**\n * @internal\n */\n\nexport function buildResolveInfo(\n exeContext,\n fieldDef,\n fieldNodes,\n parentType,\n path,\n) {\n // The resolve function's optional fourth argument is a collection of\n // information about the current execution state.\n return {\n fieldName: fieldDef.name,\n fieldNodes,\n returnType: fieldDef.type,\n parentType,\n path,\n schema: exeContext.schema,\n fragments: exeContext.fragments,\n rootValue: exeContext.rootValue,\n operation: exeContext.operation,\n variableValues: exeContext.variableValues,\n };\n}\n\nfunction handleFieldError(error, returnType, exeContext) {\n // If the field type is non-nullable, then it is resolved without any\n // protection from errors, however it still properly locates the error.\n if (isNonNullType(returnType)) {\n throw error;\n } // Otherwise, error protection is applied, logging the error and resolving\n // a null value for this field if one is encountered.\n\n exeContext.errors.push(error);\n return null;\n}\n/**\n * Implements the instructions for completeValue as defined in the\n * \"Value Completion\" section of the spec.\n *\n * If the field type is Non-Null, then this recursively completes the value\n * for the inner type. It throws a field error if that completion returns null,\n * as per the \"Nullability\" section of the spec.\n *\n * If the field type is a List, then this recursively completes the value\n * for the inner type on each item in the list.\n *\n * If the field type is a Scalar or Enum, ensures the completed value is a legal\n * value of the type by calling the `serialize` method of GraphQL type\n * definition.\n *\n * If the field is an abstract type, determine the runtime type of the value\n * and then complete based on that type\n *\n * Otherwise, the field type expects a sub-selection set, and will complete the\n * value by executing all sub-selections.\n */\n\nfunction completeValue(exeContext, returnType, fieldNodes, info, path, result) {\n // If result is an Error, throw a located error.\n if (result instanceof Error) {\n throw result;\n } // If field type is NonNull, complete for inner type, and throw field error\n // if result is null.\n\n if (isNonNullType(returnType)) {\n const completed = completeValue(\n exeContext,\n returnType.ofType,\n fieldNodes,\n info,\n path,\n result,\n );\n\n if (completed === null) {\n throw new Error(\n `Cannot return null for non-nullable field ${info.parentType.name}.${info.fieldName}.`,\n );\n }\n\n return completed;\n } // If result value is null or undefined then return null.\n\n if (result == null) {\n return null;\n } // If field type is List, complete each item in the list with the inner type\n\n if (isListType(returnType)) {\n return completeListValue(\n exeContext,\n returnType,\n fieldNodes,\n info,\n path,\n result,\n );\n } // If field type is a leaf type, Scalar or Enum, serialize to a valid value,\n // returning null if serialization is not possible.\n\n if (isLeafType(returnType)) {\n return completeLeafValue(returnType, result);\n } // If field type is an abstract type, Interface or Union, determine the\n // runtime Object type and complete for that type.\n\n if (isAbstractType(returnType)) {\n return completeAbstractValue(\n exeContext,\n returnType,\n fieldNodes,\n info,\n path,\n result,\n );\n } // If field type is Object, execute and complete all sub-selections.\n\n if (isObjectType(returnType)) {\n return completeObjectValue(\n exeContext,\n returnType,\n fieldNodes,\n info,\n path,\n result,\n );\n }\n /* c8 ignore next 6 */\n // Not reachable, all possible output types have been considered.\n\n false ||\n invariant(\n false,\n 'Cannot complete value of unexpected output type: ' + inspect(returnType),\n );\n}\n/**\n * Complete a list value by completing each item in the list with the\n * inner type\n */\n\nfunction completeListValue(\n exeContext,\n returnType,\n fieldNodes,\n info,\n path,\n result,\n) {\n if (!isIterableObject(result)) {\n throw new GraphQLError(\n `Expected Iterable, but did not find one for field \"${info.parentType.name}.${info.fieldName}\".`,\n );\n } // This is specified as a simple map, however we're optimizing the path\n // where the list contains no Promises by avoiding creating another Promise.\n\n const itemType = returnType.ofType;\n let containsPromise = false;\n const completedResults = Array.from(result, (item, index) => {\n // No need to modify the info object containing the path,\n // since from here on it is not ever accessed by resolver functions.\n const itemPath = addPath(path, index, undefined);\n\n try {\n let completedItem;\n\n if (isPromise(item)) {\n completedItem = item.then((resolved) =>\n completeValue(\n exeContext,\n itemType,\n fieldNodes,\n info,\n itemPath,\n resolved,\n ),\n );\n } else {\n completedItem = completeValue(\n exeContext,\n itemType,\n fieldNodes,\n info,\n itemPath,\n item,\n );\n }\n\n if (isPromise(completedItem)) {\n containsPromise = true; // Note: we don't rely on a `catch` method, but we do expect \"thenable\"\n // to take a second callback for the error case.\n\n return completedItem.then(undefined, (rawError) => {\n const error = locatedError(\n rawError,\n fieldNodes,\n pathToArray(itemPath),\n );\n return handleFieldError(error, itemType, exeContext);\n });\n }\n\n return completedItem;\n } catch (rawError) {\n const error = locatedError(rawError, fieldNodes, pathToArray(itemPath));\n return handleFieldError(error, itemType, exeContext);\n }\n });\n return containsPromise ? Promise.all(completedResults) : completedResults;\n}\n/**\n * Complete a Scalar or Enum by serializing to a valid value, returning\n * null if serialization is not possible.\n */\n\nfunction completeLeafValue(returnType, result) {\n const serializedResult = returnType.serialize(result);\n\n if (serializedResult == null) {\n throw new Error(\n `Expected \\`${inspect(returnType)}.serialize(${inspect(result)})\\` to ` +\n `return non-nullable value, returned: ${inspect(serializedResult)}`,\n );\n }\n\n return serializedResult;\n}\n/**\n * Complete a value of an abstract type by determining the runtime object type\n * of that value, then complete the value for that type.\n */\n\nfunction completeAbstractValue(\n exeContext,\n returnType,\n fieldNodes,\n info,\n path,\n result,\n) {\n var _returnType$resolveTy;\n\n const resolveTypeFn =\n (_returnType$resolveTy = returnType.resolveType) !== null &&\n _returnType$resolveTy !== void 0\n ? _returnType$resolveTy\n : exeContext.typeResolver;\n const contextValue = exeContext.contextValue;\n const runtimeType = resolveTypeFn(result, contextValue, info, returnType);\n\n if (isPromise(runtimeType)) {\n return runtimeType.then((resolvedRuntimeType) =>\n completeObjectValue(\n exeContext,\n ensureValidRuntimeType(\n resolvedRuntimeType,\n exeContext,\n returnType,\n fieldNodes,\n info,\n result,\n ),\n fieldNodes,\n info,\n path,\n result,\n ),\n );\n }\n\n return completeObjectValue(\n exeContext,\n ensureValidRuntimeType(\n runtimeType,\n exeContext,\n returnType,\n fieldNodes,\n info,\n result,\n ),\n fieldNodes,\n info,\n path,\n result,\n );\n}\n\nfunction ensureValidRuntimeType(\n runtimeTypeName,\n exeContext,\n returnType,\n fieldNodes,\n info,\n result,\n) {\n if (runtimeTypeName == null) {\n throw new GraphQLError(\n `Abstract type \"${returnType.name}\" must resolve to an Object type at runtime for field \"${info.parentType.name}.${info.fieldName}\". Either the \"${returnType.name}\" type should provide a \"resolveType\" function or each possible type should provide an \"isTypeOf\" function.`,\n fieldNodes,\n );\n } // releases before 16.0.0 supported returning `GraphQLObjectType` from `resolveType`\n // TODO: remove in 17.0.0 release\n\n if (isObjectType(runtimeTypeName)) {\n throw new GraphQLError(\n 'Support for returning GraphQLObjectType from resolveType was removed in graphql-js@16.0.0 please return type name instead.',\n );\n }\n\n if (typeof runtimeTypeName !== 'string') {\n throw new GraphQLError(\n `Abstract type \"${returnType.name}\" must resolve to an Object type at runtime for field \"${info.parentType.name}.${info.fieldName}\" with ` +\n `value ${inspect(result)}, received \"${inspect(runtimeTypeName)}\".`,\n );\n }\n\n const runtimeType = exeContext.schema.getType(runtimeTypeName);\n\n if (runtimeType == null) {\n throw new GraphQLError(\n `Abstract type \"${returnType.name}\" was resolved to a type \"${runtimeTypeName}\" that does not exist inside the schema.`,\n {\n nodes: fieldNodes,\n },\n );\n }\n\n if (!isObjectType(runtimeType)) {\n throw new GraphQLError(\n `Abstract type \"${returnType.name}\" was resolved to a non-object type \"${runtimeTypeName}\".`,\n {\n nodes: fieldNodes,\n },\n );\n }\n\n if (!exeContext.schema.isSubType(returnType, runtimeType)) {\n throw new GraphQLError(\n `Runtime Object type \"${runtimeType.name}\" is not a possible type for \"${returnType.name}\".`,\n {\n nodes: fieldNodes,\n },\n );\n }\n\n return runtimeType;\n}\n/**\n * Complete an Object value by executing all sub-selections.\n */\n\nfunction completeObjectValue(\n exeContext,\n returnType,\n fieldNodes,\n info,\n path,\n result,\n) {\n // Collect sub-fields to execute to complete this value.\n const subFieldNodes = collectSubfields(exeContext, returnType, fieldNodes); // If there is an isTypeOf predicate function, call it with the\n // current result. If isTypeOf returns false, then raise an error rather\n // than continuing execution.\n\n if (returnType.isTypeOf) {\n const isTypeOf = returnType.isTypeOf(result, exeContext.contextValue, info);\n\n if (isPromise(isTypeOf)) {\n return isTypeOf.then((resolvedIsTypeOf) => {\n if (!resolvedIsTypeOf) {\n throw invalidReturnTypeError(returnType, result, fieldNodes);\n }\n\n return executeFields(\n exeContext,\n returnType,\n result,\n path,\n subFieldNodes,\n );\n });\n }\n\n if (!isTypeOf) {\n throw invalidReturnTypeError(returnType, result, fieldNodes);\n }\n }\n\n return executeFields(exeContext, returnType, result, path, subFieldNodes);\n}\n\nfunction invalidReturnTypeError(returnType, result, fieldNodes) {\n return new GraphQLError(\n `Expected value of type \"${returnType.name}\" but got: ${inspect(result)}.`,\n {\n nodes: fieldNodes,\n },\n );\n}\n/**\n * If a resolveType function is not given, then a default resolve behavior is\n * used which attempts two strategies:\n *\n * First, See if the provided value has a `__typename` field defined, if so, use\n * that value as name of the resolved type.\n *\n * Otherwise, test each possible type for the abstract type by calling\n * isTypeOf for the object being coerced, returning the first type that matches.\n */\n\nexport const defaultTypeResolver = function (\n value,\n contextValue,\n info,\n abstractType,\n) {\n // First, look for `__typename`.\n if (isObjectLike(value) && typeof value.__typename === 'string') {\n return value.__typename;\n } // Otherwise, test each possible type.\n\n const possibleTypes = info.schema.getPossibleTypes(abstractType);\n const promisedIsTypeOfResults = [];\n\n for (let i = 0; i < possibleTypes.length; i++) {\n const type = possibleTypes[i];\n\n if (type.isTypeOf) {\n const isTypeOfResult = type.isTypeOf(value, contextValue, info);\n\n if (isPromise(isTypeOfResult)) {\n promisedIsTypeOfResults[i] = isTypeOfResult;\n } else if (isTypeOfResult) {\n return type.name;\n }\n }\n }\n\n if (promisedIsTypeOfResults.length) {\n return Promise.all(promisedIsTypeOfResults).then((isTypeOfResults) => {\n for (let i = 0; i < isTypeOfResults.length; i++) {\n if (isTypeOfResults[i]) {\n return possibleTypes[i].name;\n }\n }\n });\n }\n};\n/**\n * If a resolve function is not given, then a default resolve behavior is used\n * which takes the property of the source object of the same name as the field\n * and returns it as the result, or if it's a function, returns the result\n * of calling that function while passing along args and context value.\n */\n\nexport const defaultFieldResolver = function (\n source,\n args,\n contextValue,\n info,\n) {\n // ensure source is a value for which property access is acceptable.\n if (isObjectLike(source) || typeof source === 'function') {\n const property = source[info.fieldName];\n\n if (typeof property === 'function') {\n return source[info.fieldName](args, contextValue, info);\n }\n\n return property;\n }\n};\n/**\n * This method looks up the field on the given type definition.\n * It has special casing for the three introspection fields,\n * __schema, __type and __typename. __typename is special because\n * it can always be queried as a field, even in situations where no\n * other fields are allowed, like on a Union. __schema and __type\n * could get automatically added to the query type, but that would\n * require mutating type definitions, which would cause issues.\n *\n * @internal\n */\n\nexport function getFieldDef(schema, parentType, fieldNode) {\n const fieldName = fieldNode.name.value;\n\n if (\n fieldName === SchemaMetaFieldDef.name &&\n schema.getQueryType() === parentType\n ) {\n return SchemaMetaFieldDef;\n } else if (\n fieldName === TypeMetaFieldDef.name &&\n schema.getQueryType() === parentType\n ) {\n return TypeMetaFieldDef;\n } else if (fieldName === TypeNameMetaFieldDef.name) {\n return TypeNameMetaFieldDef;\n }\n\n return parentType.getFields()[fieldName];\n}\n","import { devAssert } from './jsutils/devAssert.mjs';\nimport { isPromise } from './jsutils/isPromise.mjs';\nimport { parse } from './language/parser.mjs';\nimport { validateSchema } from './type/validate.mjs';\nimport { validate } from './validation/validate.mjs';\nimport { execute } from './execution/execute.mjs';\n/**\n * This is the primary entry point function for fulfilling GraphQL operations\n * by parsing, validating, and executing a GraphQL document along side a\n * GraphQL schema.\n *\n * More sophisticated GraphQL servers, such as those which persist queries,\n * may wish to separate the validation and execution phases to a static time\n * tooling step, and a server runtime step.\n *\n * Accepts either an object with named arguments, or individual arguments:\n *\n * schema:\n * The GraphQL type system to use when validating and executing a query.\n * source:\n * A GraphQL language formatted string representing the requested operation.\n * rootValue:\n * The value provided as the first argument to resolver functions on the top\n * level type (e.g. the query object type).\n * contextValue:\n * The context value is provided as an argument to resolver functions after\n * field arguments. It is used to pass shared information useful at any point\n * during executing this query, for example the currently logged in user and\n * connections to databases or other services.\n * variableValues:\n * A mapping of variable name to runtime value to use for all variables\n * defined in the requestString.\n * operationName:\n * The name of the operation to use if requestString contains multiple\n * possible operations. Can be omitted if requestString contains only\n * one operation.\n * fieldResolver:\n * A resolver function to use when one is not provided by the schema.\n * If not provided, the default field resolver is used (which looks for a\n * value or method on the source value with the field's name).\n * typeResolver:\n * A type resolver function to use when none is provided by the schema.\n * If not provided, the default type resolver is used (which looks for a\n * `__typename` field or alternatively calls the `isTypeOf` method).\n */\n\nexport function graphql(args) {\n // Always return a Promise for a consistent API.\n return new Promise((resolve) => resolve(graphqlImpl(args)));\n}\n/**\n * The graphqlSync function also fulfills GraphQL operations by parsing,\n * validating, and executing a GraphQL document along side a GraphQL schema.\n * However, it guarantees to complete synchronously (or throw an error) assuming\n * that all field resolvers are also synchronous.\n */\n\nexport function graphqlSync(args) {\n const result = graphqlImpl(args); // Assert that the execution was synchronous.\n\n if (isPromise(result)) {\n throw new Error('GraphQL execution failed to complete synchronously.');\n }\n\n return result;\n}\n\nfunction graphqlImpl(args) {\n // Temporary for v15 to v16 migration. Remove in v17\n arguments.length < 2 ||\n devAssert(\n false,\n 'graphql@16 dropped long-deprecated support for positional arguments, please pass an object instead.',\n );\n const {\n schema,\n source,\n rootValue,\n contextValue,\n variableValues,\n operationName,\n fieldResolver,\n typeResolver,\n } = args; // Validate Schema\n\n const schemaValidationErrors = validateSchema(schema);\n\n if (schemaValidationErrors.length > 0) {\n return {\n errors: schemaValidationErrors,\n };\n } // Parse\n\n let document;\n\n try {\n document = parse(source);\n } catch (syntaxError) {\n return {\n errors: [syntaxError],\n };\n } // Validate\n\n const validationErrors = validate(schema, document);\n\n if (validationErrors.length > 0) {\n return {\n errors: validationErrors,\n };\n } // Execute\n\n return execute({\n schema,\n document,\n rootValue,\n contextValue,\n variableValues,\n operationName,\n fieldResolver,\n typeResolver,\n });\n}\n","/**\n * Returns true if the provided object implements the AsyncIterator protocol via\n * implementing a `Symbol.asyncIterator` method.\n */\nexport function isAsyncIterable(maybeAsyncIterable) {\n return (\n typeof (maybeAsyncIterable === null || maybeAsyncIterable === void 0\n ? void 0\n : maybeAsyncIterable[Symbol.asyncIterator]) === 'function'\n );\n}\n","/**\n * Given an AsyncIterable and a callback function, return an AsyncIterator\n * which produces values mapped via calling the callback function.\n */\nexport function mapAsyncIterator(iterable, callback) {\n const iterator = iterable[Symbol.asyncIterator]();\n\n async function mapResult(result) {\n if (result.done) {\n return result;\n }\n\n try {\n return {\n value: await callback(result.value),\n done: false,\n };\n } catch (error) {\n /* c8 ignore start */\n // FIXME: add test case\n if (typeof iterator.return === 'function') {\n try {\n await iterator.return();\n } catch (_e) {\n /* ignore error */\n }\n }\n\n throw error;\n /* c8 ignore stop */\n }\n }\n\n return {\n async next() {\n return mapResult(await iterator.next());\n },\n\n async return() {\n // If iterator.return() does not exist, then type R must be undefined.\n return typeof iterator.return === 'function'\n ? mapResult(await iterator.return())\n : {\n value: undefined,\n done: true,\n };\n },\n\n async throw(error) {\n if (typeof iterator.throw === 'function') {\n return mapResult(await iterator.throw(error));\n }\n\n throw error;\n },\n\n [Symbol.asyncIterator]() {\n return this;\n },\n };\n}\n","import { devAssert } from '../jsutils/devAssert.mjs';\nimport { inspect } from '../jsutils/inspect.mjs';\nimport { isAsyncIterable } from '../jsutils/isAsyncIterable.mjs';\nimport { addPath, pathToArray } from '../jsutils/Path.mjs';\nimport { GraphQLError } from '../error/GraphQLError.mjs';\nimport { locatedError } from '../error/locatedError.mjs';\nimport { collectFields } from './collectFields.mjs';\nimport {\n assertValidExecutionArguments,\n buildExecutionContext,\n buildResolveInfo,\n execute,\n getFieldDef,\n} from './execute.mjs';\nimport { mapAsyncIterator } from './mapAsyncIterator.mjs';\nimport { getArgumentValues } from './values.mjs';\n/**\n * Implements the \"Subscribe\" algorithm described in the GraphQL specification.\n *\n * Returns a Promise which resolves to either an AsyncIterator (if successful)\n * or an ExecutionResult (error). The promise will be rejected if the schema or\n * other arguments to this function are invalid, or if the resolved event stream\n * is not an async iterable.\n *\n * If the client-provided arguments to this function do not result in a\n * compliant subscription, a GraphQL Response (ExecutionResult) with\n * descriptive errors and no data will be returned.\n *\n * If the source stream could not be created due to faulty subscription\n * resolver logic or underlying systems, the promise will resolve to a single\n * ExecutionResult containing `errors` and no `data`.\n *\n * If the operation succeeded, the promise resolves to an AsyncIterator, which\n * yields a stream of ExecutionResults representing the response stream.\n *\n * Accepts either an object with named arguments, or individual arguments.\n */\n\nexport async function subscribe(args) {\n // Temporary for v15 to v16 migration. Remove in v17\n arguments.length < 2 ||\n devAssert(\n false,\n 'graphql@16 dropped long-deprecated support for positional arguments, please pass an object instead.',\n );\n const resultOrStream = await createSourceEventStream(args);\n\n if (!isAsyncIterable(resultOrStream)) {\n return resultOrStream;\n } // For each payload yielded from a subscription, map it over the normal\n // GraphQL `execute` function, with `payload` as the rootValue.\n // This implements the \"MapSourceToResponseEvent\" algorithm described in\n // the GraphQL specification. The `execute` function provides the\n // \"ExecuteSubscriptionEvent\" algorithm, as it is nearly identical to the\n // \"ExecuteQuery\" algorithm, for which `execute` is also used.\n\n const mapSourceToResponse = (payload) =>\n execute({ ...args, rootValue: payload }); // Map every source value to a ExecutionResult value as described above.\n\n return mapAsyncIterator(resultOrStream, mapSourceToResponse);\n}\n\nfunction toNormalizedArgs(args) {\n const firstArg = args[0];\n\n if (firstArg && 'document' in firstArg) {\n return firstArg;\n }\n\n return {\n schema: firstArg,\n // FIXME: when underlying TS bug fixed, see https://github.com/microsoft/TypeScript/issues/31613\n document: args[1],\n rootValue: args[2],\n contextValue: args[3],\n variableValues: args[4],\n operationName: args[5],\n subscribeFieldResolver: args[6],\n };\n}\n/**\n * Implements the \"CreateSourceEventStream\" algorithm described in the\n * GraphQL specification, resolving the subscription source event stream.\n *\n * Returns a Promise which resolves to either an AsyncIterable (if successful)\n * or an ExecutionResult (error). The promise will be rejected if the schema or\n * other arguments to this function are invalid, or if the resolved event stream\n * is not an async iterable.\n *\n * If the client-provided arguments to this function do not result in a\n * compliant subscription, a GraphQL Response (ExecutionResult) with\n * descriptive errors and no data will be returned.\n *\n * If the the source stream could not be created due to faulty subscription\n * resolver logic or underlying systems, the promise will resolve to a single\n * ExecutionResult containing `errors` and no `data`.\n *\n * If the operation succeeded, the promise resolves to the AsyncIterable for the\n * event stream returned by the resolver.\n *\n * A Source Event Stream represents a sequence of events, each of which triggers\n * a GraphQL execution for that event.\n *\n * This may be useful when hosting the stateful subscription service in a\n * different process or machine than the stateless GraphQL execution engine,\n * or otherwise separating these two steps. For more on this, see the\n * \"Supporting Subscriptions at Scale\" information in the GraphQL specification.\n */\n\nexport async function createSourceEventStream(...rawArgs) {\n const args = toNormalizedArgs(rawArgs);\n const { schema, document, variableValues } = args; // If arguments are missing or incorrectly typed, this is an internal\n // developer mistake which should throw an early error.\n\n assertValidExecutionArguments(schema, document, variableValues); // If a valid execution context cannot be created due to incorrect arguments,\n // a \"Response\" with only errors is returned.\n\n const exeContext = buildExecutionContext(args); // Return early errors if execution context failed.\n\n if (!('schema' in exeContext)) {\n return {\n errors: exeContext,\n };\n }\n\n try {\n const eventStream = await executeSubscription(exeContext); // Assert field returned an event stream, otherwise yield an error.\n\n if (!isAsyncIterable(eventStream)) {\n throw new Error(\n 'Subscription field must return Async Iterable. ' +\n `Received: ${inspect(eventStream)}.`,\n );\n }\n\n return eventStream;\n } catch (error) {\n // If it GraphQLError, report it as an ExecutionResult, containing only errors and no data.\n // Otherwise treat the error as a system-class error and re-throw it.\n if (error instanceof GraphQLError) {\n return {\n errors: [error],\n };\n }\n\n throw error;\n }\n}\n\nasync function executeSubscription(exeContext) {\n const { schema, fragments, operation, variableValues, rootValue } =\n exeContext;\n const rootType = schema.getSubscriptionType();\n\n if (rootType == null) {\n throw new GraphQLError(\n 'Schema is not configured to execute subscription operation.',\n {\n nodes: operation,\n },\n );\n }\n\n const rootFields = collectFields(\n schema,\n fragments,\n variableValues,\n rootType,\n operation.selectionSet,\n );\n const [responseName, fieldNodes] = [...rootFields.entries()][0];\n const fieldDef = getFieldDef(schema, rootType, fieldNodes[0]);\n\n if (!fieldDef) {\n const fieldName = fieldNodes[0].name.value;\n throw new GraphQLError(\n `The subscription field \"${fieldName}\" is not defined.`,\n {\n nodes: fieldNodes,\n },\n );\n }\n\n const path = addPath(undefined, responseName, rootType.name);\n const info = buildResolveInfo(\n exeContext,\n fieldDef,\n fieldNodes,\n rootType,\n path,\n );\n\n try {\n var _fieldDef$subscribe;\n\n // Implements the \"ResolveFieldEventStream\" algorithm from GraphQL specification.\n // It differs from \"ResolveFieldValue\" due to providing a different `resolveFn`.\n // Build a JS object of arguments from the field.arguments AST, using the\n // variables scope to fulfill any variable references.\n const args = getArgumentValues(fieldDef, fieldNodes[0], variableValues); // The resolve function's optional third argument is a context value that\n // is provided to every resolve function within an execution. It is commonly\n // used to represent an authenticated user, or request-specific caches.\n\n const contextValue = exeContext.contextValue; // Call the `subscribe()` resolver or the default resolver to produce an\n // AsyncIterable yielding raw payloads.\n\n const resolveFn =\n (_fieldDef$subscribe = fieldDef.subscribe) !== null &&\n _fieldDef$subscribe !== void 0\n ? _fieldDef$subscribe\n : exeContext.subscribeFieldResolver;\n const eventStream = await resolveFn(rootValue, args, contextValue, info);\n\n if (eventStream instanceof Error) {\n throw eventStream;\n }\n\n return eventStream;\n } catch (error) {\n throw locatedError(error, fieldNodes, pathToArray(path));\n }\n}\n","import { invariant } from '../../../jsutils/invariant.mjs';\nimport { GraphQLError } from '../../../error/GraphQLError.mjs';\nimport { getNamedType, isInputObjectType } from '../../../type/definition.mjs';\n\n/**\n * No deprecated\n *\n * A GraphQL document is only valid if all selected fields and all used enum values have not been\n * deprecated.\n *\n * Note: This rule is optional and is not part of the Validation section of the GraphQL\n * Specification. The main purpose of this rule is detection of deprecated usages and not\n * necessarily to forbid their use when querying a service.\n */\nexport function NoDeprecatedCustomRule(context) {\n return {\n Field(node) {\n const fieldDef = context.getFieldDef();\n const deprecationReason =\n fieldDef === null || fieldDef === void 0\n ? void 0\n : fieldDef.deprecationReason;\n\n if (fieldDef && deprecationReason != null) {\n const parentType = context.getParentType();\n parentType != null || invariant(false);\n context.reportError(\n new GraphQLError(\n `The field ${parentType.name}.${fieldDef.name} is deprecated. ${deprecationReason}`,\n {\n nodes: node,\n },\n ),\n );\n }\n },\n\n Argument(node) {\n const argDef = context.getArgument();\n const deprecationReason =\n argDef === null || argDef === void 0\n ? void 0\n : argDef.deprecationReason;\n\n if (argDef && deprecationReason != null) {\n const directiveDef = context.getDirective();\n\n if (directiveDef != null) {\n context.reportError(\n new GraphQLError(\n `Directive \"@${directiveDef.name}\" argument \"${argDef.name}\" is deprecated. ${deprecationReason}`,\n {\n nodes: node,\n },\n ),\n );\n } else {\n const parentType = context.getParentType();\n const fieldDef = context.getFieldDef();\n (parentType != null && fieldDef != null) || invariant(false);\n context.reportError(\n new GraphQLError(\n `Field \"${parentType.name}.${fieldDef.name}\" argument \"${argDef.name}\" is deprecated. ${deprecationReason}`,\n {\n nodes: node,\n },\n ),\n );\n }\n }\n },\n\n ObjectField(node) {\n const inputObjectDef = getNamedType(context.getParentInputType());\n\n if (isInputObjectType(inputObjectDef)) {\n const inputFieldDef = inputObjectDef.getFields()[node.name.value];\n const deprecationReason =\n inputFieldDef === null || inputFieldDef === void 0\n ? void 0\n : inputFieldDef.deprecationReason;\n\n if (deprecationReason != null) {\n context.reportError(\n new GraphQLError(\n `The input field ${inputObjectDef.name}.${inputFieldDef.name} is deprecated. ${deprecationReason}`,\n {\n nodes: node,\n },\n ),\n );\n }\n }\n },\n\n EnumValue(node) {\n const enumValueDef = context.getEnumValue();\n const deprecationReason =\n enumValueDef === null || enumValueDef === void 0\n ? void 0\n : enumValueDef.deprecationReason;\n\n if (enumValueDef && deprecationReason != null) {\n const enumTypeDef = getNamedType(context.getInputType());\n enumTypeDef != null || invariant(false);\n context.reportError(\n new GraphQLError(\n `The enum value \"${enumTypeDef.name}.${enumValueDef.name}\" is deprecated. ${deprecationReason}`,\n {\n nodes: node,\n },\n ),\n );\n }\n },\n };\n}\n","import { GraphQLError } from '../../../error/GraphQLError.mjs';\nimport { getNamedType } from '../../../type/definition.mjs';\nimport { isIntrospectionType } from '../../../type/introspection.mjs';\n\n/**\n * Prohibit introspection queries\n *\n * A GraphQL document is only valid if all fields selected are not fields that\n * return an introspection type.\n *\n * Note: This rule is optional and is not part of the Validation section of the\n * GraphQL Specification. This rule effectively disables introspection, which\n * does not reflect best practices and should only be done if absolutely necessary.\n */\nexport function NoSchemaIntrospectionCustomRule(context) {\n return {\n Field(node) {\n const type = getNamedType(context.getType());\n\n if (type && isIntrospectionType(type)) {\n context.reportError(\n new GraphQLError(\n `GraphQL introspection has been disabled, but the requested query contained the field \"${node.name.value}\".`,\n {\n nodes: node,\n },\n ),\n );\n }\n },\n };\n}\n","/**\n * Produce the GraphQL query recommended for a full schema introspection.\n * Accepts optional IntrospectionOptions.\n */\nexport function getIntrospectionQuery(options) {\n const optionsWithDefault = {\n descriptions: true,\n specifiedByUrl: false,\n directiveIsRepeatable: false,\n schemaDescription: false,\n inputValueDeprecation: false,\n ...options,\n };\n const descriptions = optionsWithDefault.descriptions ? 'description' : '';\n const specifiedByUrl = optionsWithDefault.specifiedByUrl\n ? 'specifiedByURL'\n : '';\n const directiveIsRepeatable = optionsWithDefault.directiveIsRepeatable\n ? 'isRepeatable'\n : '';\n const schemaDescription = optionsWithDefault.schemaDescription\n ? descriptions\n : '';\n\n function inputDeprecation(str) {\n return optionsWithDefault.inputValueDeprecation ? str : '';\n }\n\n return `\n query IntrospectionQuery {\n __schema {\n ${schemaDescription}\n queryType { name }\n mutationType { name }\n subscriptionType { name }\n types {\n ...FullType\n }\n directives {\n name\n ${descriptions}\n ${directiveIsRepeatable}\n locations\n args${inputDeprecation('(includeDeprecated: true)')} {\n ...InputValue\n }\n }\n }\n }\n\n fragment FullType on __Type {\n kind\n name\n ${descriptions}\n ${specifiedByUrl}\n fields(includeDeprecated: true) {\n name\n ${descriptions}\n args${inputDeprecation('(includeDeprecated: true)')} {\n ...InputValue\n }\n type {\n ...TypeRef\n }\n isDeprecated\n deprecationReason\n }\n inputFields${inputDeprecation('(includeDeprecated: true)')} {\n ...InputValue\n }\n interfaces {\n ...TypeRef\n }\n enumValues(includeDeprecated: true) {\n name\n ${descriptions}\n isDeprecated\n deprecationReason\n }\n possibleTypes {\n ...TypeRef\n }\n }\n\n fragment InputValue on __InputValue {\n name\n ${descriptions}\n type { ...TypeRef }\n defaultValue\n ${inputDeprecation('isDeprecated')}\n ${inputDeprecation('deprecationReason')}\n }\n\n fragment TypeRef on __Type {\n kind\n name\n ofType {\n kind\n name\n ofType {\n kind\n name\n ofType {\n kind\n name\n ofType {\n kind\n name\n ofType {\n kind\n name\n ofType {\n kind\n name\n ofType {\n kind\n name\n ofType {\n kind\n name\n ofType {\n kind\n name\n }\n }\n }\n }\n }\n }\n }\n }\n }\n }\n `;\n}\n","import { Kind } from '../language/kinds.mjs';\n/**\n * Returns an operation AST given a document AST and optionally an operation\n * name. If a name is not provided, an operation is only returned if only one is\n * provided in the document.\n */\n\nexport function getOperationAST(documentAST, operationName) {\n let operation = null;\n\n for (const definition of documentAST.definitions) {\n if (definition.kind === Kind.OPERATION_DEFINITION) {\n var _definition$name;\n\n if (operationName == null) {\n // If no operation name was provided, only return an Operation if there\n // is one defined in the document. Upon encountering the second, return\n // null.\n if (operation) {\n return null;\n }\n\n operation = definition;\n } else if (\n ((_definition$name = definition.name) === null ||\n _definition$name === void 0\n ? void 0\n : _definition$name.value) === operationName\n ) {\n return definition;\n }\n }\n }\n\n return operation;\n}\n","import { GraphQLError } from '../error/GraphQLError.mjs';\n\n/**\n * Extracts the root type of the operation from the schema.\n *\n * @deprecated Please use `GraphQLSchema.getRootType` instead. Will be removed in v17\n */\nexport function getOperationRootType(schema, operation) {\n if (operation.operation === 'query') {\n const queryType = schema.getQueryType();\n\n if (!queryType) {\n throw new GraphQLError(\n 'Schema does not define the required query root type.',\n {\n nodes: operation,\n },\n );\n }\n\n return queryType;\n }\n\n if (operation.operation === 'mutation') {\n const mutationType = schema.getMutationType();\n\n if (!mutationType) {\n throw new GraphQLError('Schema is not configured for mutations.', {\n nodes: operation,\n });\n }\n\n return mutationType;\n }\n\n if (operation.operation === 'subscription') {\n const subscriptionType = schema.getSubscriptionType();\n\n if (!subscriptionType) {\n throw new GraphQLError('Schema is not configured for subscriptions.', {\n nodes: operation,\n });\n }\n\n return subscriptionType;\n }\n\n throw new GraphQLError(\n 'Can only have query, mutation and subscription operations.',\n {\n nodes: operation,\n },\n );\n}\n","import { invariant } from '../jsutils/invariant.mjs';\nimport { parse } from '../language/parser.mjs';\nimport { executeSync } from '../execution/execute.mjs';\nimport { getIntrospectionQuery } from './getIntrospectionQuery.mjs';\n/**\n * Build an IntrospectionQuery from a GraphQLSchema\n *\n * IntrospectionQuery is useful for utilities that care about type and field\n * relationships, but do not need to traverse through those relationships.\n *\n * This is the inverse of buildClientSchema. The primary use case is outside\n * of the server context, for instance when doing schema comparisons.\n */\n\nexport function introspectionFromSchema(schema, options) {\n const optionsWithDefaults = {\n specifiedByUrl: true,\n directiveIsRepeatable: true,\n schemaDescription: true,\n inputValueDeprecation: true,\n ...options,\n };\n const document = parse(getIntrospectionQuery(optionsWithDefaults));\n const result = executeSync({\n schema,\n document,\n });\n (!result.errors && result.data) || invariant(false);\n return result.data;\n}\n","import { devAssert } from '../jsutils/devAssert.mjs';\nimport { inspect } from '../jsutils/inspect.mjs';\nimport { isObjectLike } from '../jsutils/isObjectLike.mjs';\nimport { keyValMap } from '../jsutils/keyValMap.mjs';\nimport { parseValue } from '../language/parser.mjs';\nimport {\n assertInterfaceType,\n assertNullableType,\n assertObjectType,\n GraphQLEnumType,\n GraphQLInputObjectType,\n GraphQLInterfaceType,\n GraphQLList,\n GraphQLNonNull,\n GraphQLObjectType,\n GraphQLScalarType,\n GraphQLUnionType,\n isInputType,\n isOutputType,\n} from '../type/definition.mjs';\nimport { GraphQLDirective } from '../type/directives.mjs';\nimport { introspectionTypes, TypeKind } from '../type/introspection.mjs';\nimport { specifiedScalarTypes } from '../type/scalars.mjs';\nimport { GraphQLSchema } from '../type/schema.mjs';\nimport { valueFromAST } from './valueFromAST.mjs';\n/**\n * Build a GraphQLSchema for use by client tools.\n *\n * Given the result of a client running the introspection query, creates and\n * returns a GraphQLSchema instance which can be then used with all graphql-js\n * tools, but cannot be used to execute a query, as introspection does not\n * represent the \"resolver\", \"parse\" or \"serialize\" functions or any other\n * server-internal mechanisms.\n *\n * This function expects a complete introspection result. Don't forget to check\n * the \"errors\" field of a server response before calling this function.\n */\n\nexport function buildClientSchema(introspection, options) {\n (isObjectLike(introspection) && isObjectLike(introspection.__schema)) ||\n devAssert(\n false,\n `Invalid or incomplete introspection result. Ensure that you are passing \"data\" property of introspection response and no \"errors\" was returned alongside: ${inspect(\n introspection,\n )}.`,\n ); // Get the schema from the introspection result.\n\n const schemaIntrospection = introspection.__schema; // Iterate through all types, getting the type definition for each.\n\n const typeMap = keyValMap(\n schemaIntrospection.types,\n (typeIntrospection) => typeIntrospection.name,\n (typeIntrospection) => buildType(typeIntrospection),\n ); // Include standard types only if they are used.\n\n for (const stdType of [...specifiedScalarTypes, ...introspectionTypes]) {\n if (typeMap[stdType.name]) {\n typeMap[stdType.name] = stdType;\n }\n } // Get the root Query, Mutation, and Subscription types.\n\n const queryType = schemaIntrospection.queryType\n ? getObjectType(schemaIntrospection.queryType)\n : null;\n const mutationType = schemaIntrospection.mutationType\n ? getObjectType(schemaIntrospection.mutationType)\n : null;\n const subscriptionType = schemaIntrospection.subscriptionType\n ? getObjectType(schemaIntrospection.subscriptionType)\n : null; // Get the directives supported by Introspection, assuming empty-set if\n // directives were not queried for.\n\n const directives = schemaIntrospection.directives\n ? schemaIntrospection.directives.map(buildDirective)\n : []; // Then produce and return a Schema with these types.\n\n return new GraphQLSchema({\n description: schemaIntrospection.description,\n query: queryType,\n mutation: mutationType,\n subscription: subscriptionType,\n types: Object.values(typeMap),\n directives,\n assumeValid:\n options === null || options === void 0 ? void 0 : options.assumeValid,\n }); // Given a type reference in introspection, return the GraphQLType instance.\n // preferring cached instances before building new instances.\n\n function getType(typeRef) {\n if (typeRef.kind === TypeKind.LIST) {\n const itemRef = typeRef.ofType;\n\n if (!itemRef) {\n throw new Error('Decorated type deeper than introspection query.');\n }\n\n return new GraphQLList(getType(itemRef));\n }\n\n if (typeRef.kind === TypeKind.NON_NULL) {\n const nullableRef = typeRef.ofType;\n\n if (!nullableRef) {\n throw new Error('Decorated type deeper than introspection query.');\n }\n\n const nullableType = getType(nullableRef);\n return new GraphQLNonNull(assertNullableType(nullableType));\n }\n\n return getNamedType(typeRef);\n }\n\n function getNamedType(typeRef) {\n const typeName = typeRef.name;\n\n if (!typeName) {\n throw new Error(`Unknown type reference: ${inspect(typeRef)}.`);\n }\n\n const type = typeMap[typeName];\n\n if (!type) {\n throw new Error(\n `Invalid or incomplete schema, unknown type: ${typeName}. Ensure that a full introspection query is used in order to build a client schema.`,\n );\n }\n\n return type;\n }\n\n function getObjectType(typeRef) {\n return assertObjectType(getNamedType(typeRef));\n }\n\n function getInterfaceType(typeRef) {\n return assertInterfaceType(getNamedType(typeRef));\n } // Given a type's introspection result, construct the correct\n // GraphQLType instance.\n\n function buildType(type) {\n // eslint-disable-next-line @typescript-eslint/prefer-optional-chain\n if (type != null && type.name != null && type.kind != null) {\n // FIXME: Properly type IntrospectionType, it's a breaking change so fix in v17\n // eslint-disable-next-line @typescript-eslint/switch-exhaustiveness-check\n switch (type.kind) {\n case TypeKind.SCALAR:\n return buildScalarDef(type);\n\n case TypeKind.OBJECT:\n return buildObjectDef(type);\n\n case TypeKind.INTERFACE:\n return buildInterfaceDef(type);\n\n case TypeKind.UNION:\n return buildUnionDef(type);\n\n case TypeKind.ENUM:\n return buildEnumDef(type);\n\n case TypeKind.INPUT_OBJECT:\n return buildInputObjectDef(type);\n }\n }\n\n const typeStr = inspect(type);\n throw new Error(\n `Invalid or incomplete introspection result. Ensure that a full introspection query is used in order to build a client schema: ${typeStr}.`,\n );\n }\n\n function buildScalarDef(scalarIntrospection) {\n return new GraphQLScalarType({\n name: scalarIntrospection.name,\n description: scalarIntrospection.description,\n specifiedByURL: scalarIntrospection.specifiedByURL,\n });\n }\n\n function buildImplementationsList(implementingIntrospection) {\n // TODO: Temporary workaround until GraphQL ecosystem will fully support\n // 'interfaces' on interface types.\n if (\n implementingIntrospection.interfaces === null &&\n implementingIntrospection.kind === TypeKind.INTERFACE\n ) {\n return [];\n }\n\n if (!implementingIntrospection.interfaces) {\n const implementingIntrospectionStr = inspect(implementingIntrospection);\n throw new Error(\n `Introspection result missing interfaces: ${implementingIntrospectionStr}.`,\n );\n }\n\n return implementingIntrospection.interfaces.map(getInterfaceType);\n }\n\n function buildObjectDef(objectIntrospection) {\n return new GraphQLObjectType({\n name: objectIntrospection.name,\n description: objectIntrospection.description,\n interfaces: () => buildImplementationsList(objectIntrospection),\n fields: () => buildFieldDefMap(objectIntrospection),\n });\n }\n\n function buildInterfaceDef(interfaceIntrospection) {\n return new GraphQLInterfaceType({\n name: interfaceIntrospection.name,\n description: interfaceIntrospection.description,\n interfaces: () => buildImplementationsList(interfaceIntrospection),\n fields: () => buildFieldDefMap(interfaceIntrospection),\n });\n }\n\n function buildUnionDef(unionIntrospection) {\n if (!unionIntrospection.possibleTypes) {\n const unionIntrospectionStr = inspect(unionIntrospection);\n throw new Error(\n `Introspection result missing possibleTypes: ${unionIntrospectionStr}.`,\n );\n }\n\n return new GraphQLUnionType({\n name: unionIntrospection.name,\n description: unionIntrospection.description,\n types: () => unionIntrospection.possibleTypes.map(getObjectType),\n });\n }\n\n function buildEnumDef(enumIntrospection) {\n if (!enumIntrospection.enumValues) {\n const enumIntrospectionStr = inspect(enumIntrospection);\n throw new Error(\n `Introspection result missing enumValues: ${enumIntrospectionStr}.`,\n );\n }\n\n return new GraphQLEnumType({\n name: enumIntrospection.name,\n description: enumIntrospection.description,\n values: keyValMap(\n enumIntrospection.enumValues,\n (valueIntrospection) => valueIntrospection.name,\n (valueIntrospection) => ({\n description: valueIntrospection.description,\n deprecationReason: valueIntrospection.deprecationReason,\n }),\n ),\n });\n }\n\n function buildInputObjectDef(inputObjectIntrospection) {\n if (!inputObjectIntrospection.inputFields) {\n const inputObjectIntrospectionStr = inspect(inputObjectIntrospection);\n throw new Error(\n `Introspection result missing inputFields: ${inputObjectIntrospectionStr}.`,\n );\n }\n\n return new GraphQLInputObjectType({\n name: inputObjectIntrospection.name,\n description: inputObjectIntrospection.description,\n fields: () => buildInputValueDefMap(inputObjectIntrospection.inputFields),\n });\n }\n\n function buildFieldDefMap(typeIntrospection) {\n if (!typeIntrospection.fields) {\n throw new Error(\n `Introspection result missing fields: ${inspect(typeIntrospection)}.`,\n );\n }\n\n return keyValMap(\n typeIntrospection.fields,\n (fieldIntrospection) => fieldIntrospection.name,\n buildField,\n );\n }\n\n function buildField(fieldIntrospection) {\n const type = getType(fieldIntrospection.type);\n\n if (!isOutputType(type)) {\n const typeStr = inspect(type);\n throw new Error(\n `Introspection must provide output type for fields, but received: ${typeStr}.`,\n );\n }\n\n if (!fieldIntrospection.args) {\n const fieldIntrospectionStr = inspect(fieldIntrospection);\n throw new Error(\n `Introspection result missing field args: ${fieldIntrospectionStr}.`,\n );\n }\n\n return {\n description: fieldIntrospection.description,\n deprecationReason: fieldIntrospection.deprecationReason,\n type,\n args: buildInputValueDefMap(fieldIntrospection.args),\n };\n }\n\n function buildInputValueDefMap(inputValueIntrospections) {\n return keyValMap(\n inputValueIntrospections,\n (inputValue) => inputValue.name,\n buildInputValue,\n );\n }\n\n function buildInputValue(inputValueIntrospection) {\n const type = getType(inputValueIntrospection.type);\n\n if (!isInputType(type)) {\n const typeStr = inspect(type);\n throw new Error(\n `Introspection must provide input type for arguments, but received: ${typeStr}.`,\n );\n }\n\n const defaultValue =\n inputValueIntrospection.defaultValue != null\n ? valueFromAST(parseValue(inputValueIntrospection.defaultValue), type)\n : undefined;\n return {\n description: inputValueIntrospection.description,\n type,\n defaultValue,\n deprecationReason: inputValueIntrospection.deprecationReason,\n };\n }\n\n function buildDirective(directiveIntrospection) {\n if (!directiveIntrospection.args) {\n const directiveIntrospectionStr = inspect(directiveIntrospection);\n throw new Error(\n `Introspection result missing directive args: ${directiveIntrospectionStr}.`,\n );\n }\n\n if (!directiveIntrospection.locations) {\n const directiveIntrospectionStr = inspect(directiveIntrospection);\n throw new Error(\n `Introspection result missing directive locations: ${directiveIntrospectionStr}.`,\n );\n }\n\n return new GraphQLDirective({\n name: directiveIntrospection.name,\n description: directiveIntrospection.description,\n isRepeatable: directiveIntrospection.isRepeatable,\n locations: directiveIntrospection.locations.slice(),\n args: buildInputValueDefMap(directiveIntrospection.args),\n });\n }\n}\n","import { devAssert } from '../jsutils/devAssert.mjs';\nimport { inspect } from '../jsutils/inspect.mjs';\nimport { invariant } from '../jsutils/invariant.mjs';\nimport { keyMap } from '../jsutils/keyMap.mjs';\nimport { mapValue } from '../jsutils/mapValue.mjs';\nimport { Kind } from '../language/kinds.mjs';\nimport {\n isTypeDefinitionNode,\n isTypeExtensionNode,\n} from '../language/predicates.mjs';\nimport {\n GraphQLEnumType,\n GraphQLInputObjectType,\n GraphQLInterfaceType,\n GraphQLList,\n GraphQLNonNull,\n GraphQLObjectType,\n GraphQLScalarType,\n GraphQLUnionType,\n isEnumType,\n isInputObjectType,\n isInterfaceType,\n isListType,\n isNonNullType,\n isObjectType,\n isScalarType,\n isUnionType,\n} from '../type/definition.mjs';\nimport {\n GraphQLDeprecatedDirective,\n GraphQLDirective,\n GraphQLSpecifiedByDirective,\n} from '../type/directives.mjs';\nimport {\n introspectionTypes,\n isIntrospectionType,\n} from '../type/introspection.mjs';\nimport {\n isSpecifiedScalarType,\n specifiedScalarTypes,\n} from '../type/scalars.mjs';\nimport { assertSchema, GraphQLSchema } from '../type/schema.mjs';\nimport { assertValidSDLExtension } from '../validation/validate.mjs';\nimport { getDirectiveValues } from '../execution/values.mjs';\nimport { valueFromAST } from './valueFromAST.mjs';\n\n/**\n * Produces a new schema given an existing schema and a document which may\n * contain GraphQL type extensions and definitions. The original schema will\n * remain unaltered.\n *\n * Because a schema represents a graph of references, a schema cannot be\n * extended without effectively making an entire copy. We do not know until it's\n * too late if subgraphs remain unchanged.\n *\n * This algorithm copies the provided schema, applying extensions while\n * producing the copy. The original schema remains unaltered.\n */\nexport function extendSchema(schema, documentAST, options) {\n assertSchema(schema);\n (documentAST != null && documentAST.kind === Kind.DOCUMENT) ||\n devAssert(false, 'Must provide valid Document AST.');\n\n if (\n (options === null || options === void 0 ? void 0 : options.assumeValid) !==\n true &&\n (options === null || options === void 0\n ? void 0\n : options.assumeValidSDL) !== true\n ) {\n assertValidSDLExtension(documentAST, schema);\n }\n\n const schemaConfig = schema.toConfig();\n const extendedConfig = extendSchemaImpl(schemaConfig, documentAST, options);\n return schemaConfig === extendedConfig\n ? schema\n : new GraphQLSchema(extendedConfig);\n}\n/**\n * @internal\n */\n\nexport function extendSchemaImpl(schemaConfig, documentAST, options) {\n var _schemaDef, _schemaDef$descriptio, _schemaDef2, _options$assumeValid;\n\n // Collect the type definitions and extensions found in the document.\n const typeDefs = [];\n const typeExtensionsMap = Object.create(null); // New directives and types are separate because a directives and types can\n // have the same name. For example, a type named \"skip\".\n\n const directiveDefs = [];\n let schemaDef; // Schema extensions are collected which may add additional operation types.\n\n const schemaExtensions = [];\n\n for (const def of documentAST.definitions) {\n if (def.kind === Kind.SCHEMA_DEFINITION) {\n schemaDef = def;\n } else if (def.kind === Kind.SCHEMA_EXTENSION) {\n schemaExtensions.push(def);\n } else if (isTypeDefinitionNode(def)) {\n typeDefs.push(def);\n } else if (isTypeExtensionNode(def)) {\n const extendedTypeName = def.name.value;\n const existingTypeExtensions = typeExtensionsMap[extendedTypeName];\n typeExtensionsMap[extendedTypeName] = existingTypeExtensions\n ? existingTypeExtensions.concat([def])\n : [def];\n } else if (def.kind === Kind.DIRECTIVE_DEFINITION) {\n directiveDefs.push(def);\n }\n } // If this document contains no new types, extensions, or directives then\n // return the same unmodified GraphQLSchema instance.\n\n if (\n Object.keys(typeExtensionsMap).length === 0 &&\n typeDefs.length === 0 &&\n directiveDefs.length === 0 &&\n schemaExtensions.length === 0 &&\n schemaDef == null\n ) {\n return schemaConfig;\n }\n\n const typeMap = Object.create(null);\n\n for (const existingType of schemaConfig.types) {\n typeMap[existingType.name] = extendNamedType(existingType);\n }\n\n for (const typeNode of typeDefs) {\n var _stdTypeMap$name;\n\n const name = typeNode.name.value;\n typeMap[name] =\n (_stdTypeMap$name = stdTypeMap[name]) !== null &&\n _stdTypeMap$name !== void 0\n ? _stdTypeMap$name\n : buildType(typeNode);\n }\n\n const operationTypes = {\n // Get the extended root operation types.\n query: schemaConfig.query && replaceNamedType(schemaConfig.query),\n mutation: schemaConfig.mutation && replaceNamedType(schemaConfig.mutation),\n subscription:\n schemaConfig.subscription && replaceNamedType(schemaConfig.subscription),\n // Then, incorporate schema definition and all schema extensions.\n ...(schemaDef && getOperationTypes([schemaDef])),\n ...getOperationTypes(schemaExtensions),\n }; // Then produce and return a Schema config with these types.\n\n return {\n description:\n (_schemaDef = schemaDef) === null || _schemaDef === void 0\n ? void 0\n : (_schemaDef$descriptio = _schemaDef.description) === null ||\n _schemaDef$descriptio === void 0\n ? void 0\n : _schemaDef$descriptio.value,\n ...operationTypes,\n types: Object.values(typeMap),\n directives: [\n ...schemaConfig.directives.map(replaceDirective),\n ...directiveDefs.map(buildDirective),\n ],\n extensions: Object.create(null),\n astNode:\n (_schemaDef2 = schemaDef) !== null && _schemaDef2 !== void 0\n ? _schemaDef2\n : schemaConfig.astNode,\n extensionASTNodes: schemaConfig.extensionASTNodes.concat(schemaExtensions),\n assumeValid:\n (_options$assumeValid =\n options === null || options === void 0\n ? void 0\n : options.assumeValid) !== null && _options$assumeValid !== void 0\n ? _options$assumeValid\n : false,\n }; // Below are functions used for producing this schema that have closed over\n // this scope and have access to the schema, cache, and newly defined types.\n\n function replaceType(type) {\n if (isListType(type)) {\n // @ts-expect-error\n return new GraphQLList(replaceType(type.ofType));\n }\n\n if (isNonNullType(type)) {\n // @ts-expect-error\n return new GraphQLNonNull(replaceType(type.ofType));\n } // @ts-expect-error FIXME\n\n return replaceNamedType(type);\n }\n\n function replaceNamedType(type) {\n // Note: While this could make early assertions to get the correctly\n // typed values, that would throw immediately while type system\n // validation with validateSchema() will produce more actionable results.\n return typeMap[type.name];\n }\n\n function replaceDirective(directive) {\n const config = directive.toConfig();\n return new GraphQLDirective({\n ...config,\n args: mapValue(config.args, extendArg),\n });\n }\n\n function extendNamedType(type) {\n if (isIntrospectionType(type) || isSpecifiedScalarType(type)) {\n // Builtin types are not extended.\n return type;\n }\n\n if (isScalarType(type)) {\n return extendScalarType(type);\n }\n\n if (isObjectType(type)) {\n return extendObjectType(type);\n }\n\n if (isInterfaceType(type)) {\n return extendInterfaceType(type);\n }\n\n if (isUnionType(type)) {\n return extendUnionType(type);\n }\n\n if (isEnumType(type)) {\n return extendEnumType(type);\n }\n\n if (isInputObjectType(type)) {\n return extendInputObjectType(type);\n }\n /* c8 ignore next 3 */\n // Not reachable, all possible type definition nodes have been considered.\n\n false || invariant(false, 'Unexpected type: ' + inspect(type));\n }\n\n function extendInputObjectType(type) {\n var _typeExtensionsMap$co;\n\n const config = type.toConfig();\n const extensions =\n (_typeExtensionsMap$co = typeExtensionsMap[config.name]) !== null &&\n _typeExtensionsMap$co !== void 0\n ? _typeExtensionsMap$co\n : [];\n return new GraphQLInputObjectType({\n ...config,\n fields: () => ({\n ...mapValue(config.fields, (field) => ({\n ...field,\n type: replaceType(field.type),\n })),\n ...buildInputFieldMap(extensions),\n }),\n extensionASTNodes: config.extensionASTNodes.concat(extensions),\n });\n }\n\n function extendEnumType(type) {\n var _typeExtensionsMap$ty;\n\n const config = type.toConfig();\n const extensions =\n (_typeExtensionsMap$ty = typeExtensionsMap[type.name]) !== null &&\n _typeExtensionsMap$ty !== void 0\n ? _typeExtensionsMap$ty\n : [];\n return new GraphQLEnumType({\n ...config,\n values: { ...config.values, ...buildEnumValueMap(extensions) },\n extensionASTNodes: config.extensionASTNodes.concat(extensions),\n });\n }\n\n function extendScalarType(type) {\n var _typeExtensionsMap$co2;\n\n const config = type.toConfig();\n const extensions =\n (_typeExtensionsMap$co2 = typeExtensionsMap[config.name]) !== null &&\n _typeExtensionsMap$co2 !== void 0\n ? _typeExtensionsMap$co2\n : [];\n let specifiedByURL = config.specifiedByURL;\n\n for (const extensionNode of extensions) {\n var _getSpecifiedByURL;\n\n specifiedByURL =\n (_getSpecifiedByURL = getSpecifiedByURL(extensionNode)) !== null &&\n _getSpecifiedByURL !== void 0\n ? _getSpecifiedByURL\n : specifiedByURL;\n }\n\n return new GraphQLScalarType({\n ...config,\n specifiedByURL,\n extensionASTNodes: config.extensionASTNodes.concat(extensions),\n });\n }\n\n function extendObjectType(type) {\n var _typeExtensionsMap$co3;\n\n const config = type.toConfig();\n const extensions =\n (_typeExtensionsMap$co3 = typeExtensionsMap[config.name]) !== null &&\n _typeExtensionsMap$co3 !== void 0\n ? _typeExtensionsMap$co3\n : [];\n return new GraphQLObjectType({\n ...config,\n interfaces: () => [\n ...type.getInterfaces().map(replaceNamedType),\n ...buildInterfaces(extensions),\n ],\n fields: () => ({\n ...mapValue(config.fields, extendField),\n ...buildFieldMap(extensions),\n }),\n extensionASTNodes: config.extensionASTNodes.concat(extensions),\n });\n }\n\n function extendInterfaceType(type) {\n var _typeExtensionsMap$co4;\n\n const config = type.toConfig();\n const extensions =\n (_typeExtensionsMap$co4 = typeExtensionsMap[config.name]) !== null &&\n _typeExtensionsMap$co4 !== void 0\n ? _typeExtensionsMap$co4\n : [];\n return new GraphQLInterfaceType({\n ...config,\n interfaces: () => [\n ...type.getInterfaces().map(replaceNamedType),\n ...buildInterfaces(extensions),\n ],\n fields: () => ({\n ...mapValue(config.fields, extendField),\n ...buildFieldMap(extensions),\n }),\n extensionASTNodes: config.extensionASTNodes.concat(extensions),\n });\n }\n\n function extendUnionType(type) {\n var _typeExtensionsMap$co5;\n\n const config = type.toConfig();\n const extensions =\n (_typeExtensionsMap$co5 = typeExtensionsMap[config.name]) !== null &&\n _typeExtensionsMap$co5 !== void 0\n ? _typeExtensionsMap$co5\n : [];\n return new GraphQLUnionType({\n ...config,\n types: () => [\n ...type.getTypes().map(replaceNamedType),\n ...buildUnionTypes(extensions),\n ],\n extensionASTNodes: config.extensionASTNodes.concat(extensions),\n });\n }\n\n function extendField(field) {\n return {\n ...field,\n type: replaceType(field.type),\n args: field.args && mapValue(field.args, extendArg),\n };\n }\n\n function extendArg(arg) {\n return { ...arg, type: replaceType(arg.type) };\n }\n\n function getOperationTypes(nodes) {\n const opTypes = {};\n\n for (const node of nodes) {\n var _node$operationTypes;\n\n // FIXME: https://github.com/graphql/graphql-js/issues/2203\n const operationTypesNodes =\n /* c8 ignore next */\n (_node$operationTypes = node.operationTypes) !== null &&\n _node$operationTypes !== void 0\n ? _node$operationTypes\n : [];\n\n for (const operationType of operationTypesNodes) {\n // Note: While this could make early assertions to get the correctly\n // typed values below, that would throw immediately while type system\n // validation with validateSchema() will produce more actionable results.\n // @ts-expect-error\n opTypes[operationType.operation] = getNamedType(operationType.type);\n }\n }\n\n return opTypes;\n }\n\n function getNamedType(node) {\n var _stdTypeMap$name2;\n\n const name = node.name.value;\n const type =\n (_stdTypeMap$name2 = stdTypeMap[name]) !== null &&\n _stdTypeMap$name2 !== void 0\n ? _stdTypeMap$name2\n : typeMap[name];\n\n if (type === undefined) {\n throw new Error(`Unknown type: \"${name}\".`);\n }\n\n return type;\n }\n\n function getWrappedType(node) {\n if (node.kind === Kind.LIST_TYPE) {\n return new GraphQLList(getWrappedType(node.type));\n }\n\n if (node.kind === Kind.NON_NULL_TYPE) {\n return new GraphQLNonNull(getWrappedType(node.type));\n }\n\n return getNamedType(node);\n }\n\n function buildDirective(node) {\n var _node$description;\n\n return new GraphQLDirective({\n name: node.name.value,\n description:\n (_node$description = node.description) === null ||\n _node$description === void 0\n ? void 0\n : _node$description.value,\n // @ts-expect-error\n locations: node.locations.map(({ value }) => value),\n isRepeatable: node.repeatable,\n args: buildArgumentMap(node.arguments),\n astNode: node,\n });\n }\n\n function buildFieldMap(nodes) {\n const fieldConfigMap = Object.create(null);\n\n for (const node of nodes) {\n var _node$fields;\n\n // FIXME: https://github.com/graphql/graphql-js/issues/2203\n const nodeFields =\n /* c8 ignore next */\n (_node$fields = node.fields) !== null && _node$fields !== void 0\n ? _node$fields\n : [];\n\n for (const field of nodeFields) {\n var _field$description;\n\n fieldConfigMap[field.name.value] = {\n // Note: While this could make assertions to get the correctly typed\n // value, that would throw immediately while type system validation\n // with validateSchema() will produce more actionable results.\n type: getWrappedType(field.type),\n description:\n (_field$description = field.description) === null ||\n _field$description === void 0\n ? void 0\n : _field$description.value,\n args: buildArgumentMap(field.arguments),\n deprecationReason: getDeprecationReason(field),\n astNode: field,\n };\n }\n }\n\n return fieldConfigMap;\n }\n\n function buildArgumentMap(args) {\n // FIXME: https://github.com/graphql/graphql-js/issues/2203\n const argsNodes =\n /* c8 ignore next */\n args !== null && args !== void 0 ? args : [];\n const argConfigMap = Object.create(null);\n\n for (const arg of argsNodes) {\n var _arg$description;\n\n // Note: While this could make assertions to get the correctly typed\n // value, that would throw immediately while type system validation\n // with validateSchema() will produce more actionable results.\n const type = getWrappedType(arg.type);\n argConfigMap[arg.name.value] = {\n type,\n description:\n (_arg$description = arg.description) === null ||\n _arg$description === void 0\n ? void 0\n : _arg$description.value,\n defaultValue: valueFromAST(arg.defaultValue, type),\n deprecationReason: getDeprecationReason(arg),\n astNode: arg,\n };\n }\n\n return argConfigMap;\n }\n\n function buildInputFieldMap(nodes) {\n const inputFieldMap = Object.create(null);\n\n for (const node of nodes) {\n var _node$fields2;\n\n // FIXME: https://github.com/graphql/graphql-js/issues/2203\n const fieldsNodes =\n /* c8 ignore next */\n (_node$fields2 = node.fields) !== null && _node$fields2 !== void 0\n ? _node$fields2\n : [];\n\n for (const field of fieldsNodes) {\n var _field$description2;\n\n // Note: While this could make assertions to get the correctly typed\n // value, that would throw immediately while type system validation\n // with validateSchema() will produce more actionable results.\n const type = getWrappedType(field.type);\n inputFieldMap[field.name.value] = {\n type,\n description:\n (_field$description2 = field.description) === null ||\n _field$description2 === void 0\n ? void 0\n : _field$description2.value,\n defaultValue: valueFromAST(field.defaultValue, type),\n deprecationReason: getDeprecationReason(field),\n astNode: field,\n };\n }\n }\n\n return inputFieldMap;\n }\n\n function buildEnumValueMap(nodes) {\n const enumValueMap = Object.create(null);\n\n for (const node of nodes) {\n var _node$values;\n\n // FIXME: https://github.com/graphql/graphql-js/issues/2203\n const valuesNodes =\n /* c8 ignore next */\n (_node$values = node.values) !== null && _node$values !== void 0\n ? _node$values\n : [];\n\n for (const value of valuesNodes) {\n var _value$description;\n\n enumValueMap[value.name.value] = {\n description:\n (_value$description = value.description) === null ||\n _value$description === void 0\n ? void 0\n : _value$description.value,\n deprecationReason: getDeprecationReason(value),\n astNode: value,\n };\n }\n }\n\n return enumValueMap;\n }\n\n function buildInterfaces(nodes) {\n // Note: While this could make assertions to get the correctly typed\n // values below, that would throw immediately while type system\n // validation with validateSchema() will produce more actionable results.\n // @ts-expect-error\n return nodes.flatMap(\n // FIXME: https://github.com/graphql/graphql-js/issues/2203\n (node) => {\n var _node$interfaces$map, _node$interfaces;\n\n return (\n /* c8 ignore next */\n (_node$interfaces$map =\n (_node$interfaces = node.interfaces) === null ||\n _node$interfaces === void 0\n ? void 0\n : _node$interfaces.map(getNamedType)) !== null &&\n _node$interfaces$map !== void 0\n ? _node$interfaces$map\n : []\n );\n },\n );\n }\n\n function buildUnionTypes(nodes) {\n // Note: While this could make assertions to get the correctly typed\n // values below, that would throw immediately while type system\n // validation with validateSchema() will produce more actionable results.\n // @ts-expect-error\n return nodes.flatMap(\n // FIXME: https://github.com/graphql/graphql-js/issues/2203\n (node) => {\n var _node$types$map, _node$types;\n\n return (\n /* c8 ignore next */\n (_node$types$map =\n (_node$types = node.types) === null || _node$types === void 0\n ? void 0\n : _node$types.map(getNamedType)) !== null &&\n _node$types$map !== void 0\n ? _node$types$map\n : []\n );\n },\n );\n }\n\n function buildType(astNode) {\n var _typeExtensionsMap$na;\n\n const name = astNode.name.value;\n const extensionASTNodes =\n (_typeExtensionsMap$na = typeExtensionsMap[name]) !== null &&\n _typeExtensionsMap$na !== void 0\n ? _typeExtensionsMap$na\n : [];\n\n switch (astNode.kind) {\n case Kind.OBJECT_TYPE_DEFINITION: {\n var _astNode$description;\n\n const allNodes = [astNode, ...extensionASTNodes];\n return new GraphQLObjectType({\n name,\n description:\n (_astNode$description = astNode.description) === null ||\n _astNode$description === void 0\n ? void 0\n : _astNode$description.value,\n interfaces: () => buildInterfaces(allNodes),\n fields: () => buildFieldMap(allNodes),\n astNode,\n extensionASTNodes,\n });\n }\n\n case Kind.INTERFACE_TYPE_DEFINITION: {\n var _astNode$description2;\n\n const allNodes = [astNode, ...extensionASTNodes];\n return new GraphQLInterfaceType({\n name,\n description:\n (_astNode$description2 = astNode.description) === null ||\n _astNode$description2 === void 0\n ? void 0\n : _astNode$description2.value,\n interfaces: () => buildInterfaces(allNodes),\n fields: () => buildFieldMap(allNodes),\n astNode,\n extensionASTNodes,\n });\n }\n\n case Kind.ENUM_TYPE_DEFINITION: {\n var _astNode$description3;\n\n const allNodes = [astNode, ...extensionASTNodes];\n return new GraphQLEnumType({\n name,\n description:\n (_astNode$description3 = astNode.description) === null ||\n _astNode$description3 === void 0\n ? void 0\n : _astNode$description3.value,\n values: buildEnumValueMap(allNodes),\n astNode,\n extensionASTNodes,\n });\n }\n\n case Kind.UNION_TYPE_DEFINITION: {\n var _astNode$description4;\n\n const allNodes = [astNode, ...extensionASTNodes];\n return new GraphQLUnionType({\n name,\n description:\n (_astNode$description4 = astNode.description) === null ||\n _astNode$description4 === void 0\n ? void 0\n : _astNode$description4.value,\n types: () => buildUnionTypes(allNodes),\n astNode,\n extensionASTNodes,\n });\n }\n\n case Kind.SCALAR_TYPE_DEFINITION: {\n var _astNode$description5;\n\n return new GraphQLScalarType({\n name,\n description:\n (_astNode$description5 = astNode.description) === null ||\n _astNode$description5 === void 0\n ? void 0\n : _astNode$description5.value,\n specifiedByURL: getSpecifiedByURL(astNode),\n astNode,\n extensionASTNodes,\n });\n }\n\n case Kind.INPUT_OBJECT_TYPE_DEFINITION: {\n var _astNode$description6;\n\n const allNodes = [astNode, ...extensionASTNodes];\n return new GraphQLInputObjectType({\n name,\n description:\n (_astNode$description6 = astNode.description) === null ||\n _astNode$description6 === void 0\n ? void 0\n : _astNode$description6.value,\n fields: () => buildInputFieldMap(allNodes),\n astNode,\n extensionASTNodes,\n });\n }\n }\n }\n}\nconst stdTypeMap = keyMap(\n [...specifiedScalarTypes, ...introspectionTypes],\n (type) => type.name,\n);\n/**\n * Given a field or enum value node, returns the string value for the\n * deprecation reason.\n */\n\nfunction getDeprecationReason(node) {\n const deprecated = getDirectiveValues(GraphQLDeprecatedDirective, node); // @ts-expect-error validated by `getDirectiveValues`\n\n return deprecated === null || deprecated === void 0\n ? void 0\n : deprecated.reason;\n}\n/**\n * Given a scalar node, returns the string value for the specifiedByURL.\n */\n\nfunction getSpecifiedByURL(node) {\n const specifiedBy = getDirectiveValues(GraphQLSpecifiedByDirective, node); // @ts-expect-error validated by `getDirectiveValues`\n\n return specifiedBy === null || specifiedBy === void 0\n ? void 0\n : specifiedBy.url;\n}\n","import { devAssert } from '../jsutils/devAssert.mjs';\nimport { Kind } from '../language/kinds.mjs';\nimport { parse } from '../language/parser.mjs';\nimport { specifiedDirectives } from '../type/directives.mjs';\nimport { GraphQLSchema } from '../type/schema.mjs';\nimport { assertValidSDL } from '../validation/validate.mjs';\nimport { extendSchemaImpl } from './extendSchema.mjs';\n\n/**\n * This takes the ast of a schema document produced by the parse function in\n * src/language/parser.js.\n *\n * If no schema definition is provided, then it will look for types named Query,\n * Mutation and Subscription.\n *\n * Given that AST it constructs a GraphQLSchema. The resulting schema\n * has no resolve methods, so execution will use default resolvers.\n */\nexport function buildASTSchema(documentAST, options) {\n (documentAST != null && documentAST.kind === Kind.DOCUMENT) ||\n devAssert(false, 'Must provide valid Document AST.');\n\n if (\n (options === null || options === void 0 ? void 0 : options.assumeValid) !==\n true &&\n (options === null || options === void 0\n ? void 0\n : options.assumeValidSDL) !== true\n ) {\n assertValidSDL(documentAST);\n }\n\n const emptySchemaConfig = {\n description: undefined,\n types: [],\n directives: [],\n extensions: Object.create(null),\n extensionASTNodes: [],\n assumeValid: false,\n };\n const config = extendSchemaImpl(emptySchemaConfig, documentAST, options);\n\n if (config.astNode == null) {\n for (const type of config.types) {\n switch (type.name) {\n // Note: While this could make early assertions to get the correctly\n // typed values below, that would throw immediately while type system\n // validation with validateSchema() will produce more actionable results.\n case 'Query':\n // @ts-expect-error validated in `validateSchema`\n config.query = type;\n break;\n\n case 'Mutation':\n // @ts-expect-error validated in `validateSchema`\n config.mutation = type;\n break;\n\n case 'Subscription':\n // @ts-expect-error validated in `validateSchema`\n config.subscription = type;\n break;\n }\n }\n }\n\n const directives = [\n ...config.directives, // If specified directives were not explicitly declared, add them.\n ...specifiedDirectives.filter((stdDirective) =>\n config.directives.every(\n (directive) => directive.name !== stdDirective.name,\n ),\n ),\n ];\n return new GraphQLSchema({ ...config, directives });\n}\n/**\n * A helper function to build a GraphQLSchema directly from a source\n * document.\n */\n\nexport function buildSchema(source, options) {\n const document = parse(source, {\n noLocation:\n options === null || options === void 0 ? void 0 : options.noLocation,\n allowLegacyFragmentVariables:\n options === null || options === void 0\n ? void 0\n : options.allowLegacyFragmentVariables,\n });\n return buildASTSchema(document, {\n assumeValidSDL:\n options === null || options === void 0 ? void 0 : options.assumeValidSDL,\n assumeValid:\n options === null || options === void 0 ? void 0 : options.assumeValid,\n });\n}\n","import { inspect } from '../jsutils/inspect.mjs';\nimport { invariant } from '../jsutils/invariant.mjs';\nimport { keyValMap } from '../jsutils/keyValMap.mjs';\nimport { naturalCompare } from '../jsutils/naturalCompare.mjs';\nimport {\n GraphQLEnumType,\n GraphQLInputObjectType,\n GraphQLInterfaceType,\n GraphQLList,\n GraphQLNonNull,\n GraphQLObjectType,\n GraphQLUnionType,\n isEnumType,\n isInputObjectType,\n isInterfaceType,\n isListType,\n isNonNullType,\n isObjectType,\n isScalarType,\n isUnionType,\n} from '../type/definition.mjs';\nimport { GraphQLDirective } from '../type/directives.mjs';\nimport { isIntrospectionType } from '../type/introspection.mjs';\nimport { GraphQLSchema } from '../type/schema.mjs';\n/**\n * Sort GraphQLSchema.\n *\n * This function returns a sorted copy of the given GraphQLSchema.\n */\n\nexport function lexicographicSortSchema(schema) {\n const schemaConfig = schema.toConfig();\n const typeMap = keyValMap(\n sortByName(schemaConfig.types),\n (type) => type.name,\n sortNamedType,\n );\n return new GraphQLSchema({\n ...schemaConfig,\n types: Object.values(typeMap),\n directives: sortByName(schemaConfig.directives).map(sortDirective),\n query: replaceMaybeType(schemaConfig.query),\n mutation: replaceMaybeType(schemaConfig.mutation),\n subscription: replaceMaybeType(schemaConfig.subscription),\n });\n\n function replaceType(type) {\n if (isListType(type)) {\n // @ts-expect-error\n return new GraphQLList(replaceType(type.ofType));\n } else if (isNonNullType(type)) {\n // @ts-expect-error\n return new GraphQLNonNull(replaceType(type.ofType));\n } // @ts-expect-error FIXME: TS Conversion\n\n return replaceNamedType(type);\n }\n\n function replaceNamedType(type) {\n return typeMap[type.name];\n }\n\n function replaceMaybeType(maybeType) {\n return maybeType && replaceNamedType(maybeType);\n }\n\n function sortDirective(directive) {\n const config = directive.toConfig();\n return new GraphQLDirective({\n ...config,\n locations: sortBy(config.locations, (x) => x),\n args: sortArgs(config.args),\n });\n }\n\n function sortArgs(args) {\n return sortObjMap(args, (arg) => ({ ...arg, type: replaceType(arg.type) }));\n }\n\n function sortFields(fieldsMap) {\n return sortObjMap(fieldsMap, (field) => ({\n ...field,\n type: replaceType(field.type),\n args: field.args && sortArgs(field.args),\n }));\n }\n\n function sortInputFields(fieldsMap) {\n return sortObjMap(fieldsMap, (field) => ({\n ...field,\n type: replaceType(field.type),\n }));\n }\n\n function sortTypes(array) {\n return sortByName(array).map(replaceNamedType);\n }\n\n function sortNamedType(type) {\n if (isScalarType(type) || isIntrospectionType(type)) {\n return type;\n }\n\n if (isObjectType(type)) {\n const config = type.toConfig();\n return new GraphQLObjectType({\n ...config,\n interfaces: () => sortTypes(config.interfaces),\n fields: () => sortFields(config.fields),\n });\n }\n\n if (isInterfaceType(type)) {\n const config = type.toConfig();\n return new GraphQLInterfaceType({\n ...config,\n interfaces: () => sortTypes(config.interfaces),\n fields: () => sortFields(config.fields),\n });\n }\n\n if (isUnionType(type)) {\n const config = type.toConfig();\n return new GraphQLUnionType({\n ...config,\n types: () => sortTypes(config.types),\n });\n }\n\n if (isEnumType(type)) {\n const config = type.toConfig();\n return new GraphQLEnumType({\n ...config,\n values: sortObjMap(config.values, (value) => value),\n });\n }\n\n if (isInputObjectType(type)) {\n const config = type.toConfig();\n return new GraphQLInputObjectType({\n ...config,\n fields: () => sortInputFields(config.fields),\n });\n }\n /* c8 ignore next 3 */\n // Not reachable, all possible types have been considered.\n\n false || invariant(false, 'Unexpected type: ' + inspect(type));\n }\n}\n\nfunction sortObjMap(map, sortValueFn) {\n const sortedMap = Object.create(null);\n\n for (const key of Object.keys(map).sort(naturalCompare)) {\n sortedMap[key] = sortValueFn(map[key]);\n }\n\n return sortedMap;\n}\n\nfunction sortByName(array) {\n return sortBy(array, (obj) => obj.name);\n}\n\nfunction sortBy(array, mapToKey) {\n return array.slice().sort((obj1, obj2) => {\n const key1 = mapToKey(obj1);\n const key2 = mapToKey(obj2);\n return naturalCompare(key1, key2);\n });\n}\n","import { inspect } from '../jsutils/inspect.mjs';\nimport { invariant } from '../jsutils/invariant.mjs';\nimport { isPrintableAsBlockString } from '../language/blockString.mjs';\nimport { Kind } from '../language/kinds.mjs';\nimport { print } from '../language/printer.mjs';\nimport {\n isEnumType,\n isInputObjectType,\n isInterfaceType,\n isObjectType,\n isScalarType,\n isUnionType,\n} from '../type/definition.mjs';\nimport {\n DEFAULT_DEPRECATION_REASON,\n isSpecifiedDirective,\n} from '../type/directives.mjs';\nimport { isIntrospectionType } from '../type/introspection.mjs';\nimport { isSpecifiedScalarType } from '../type/scalars.mjs';\nimport { astFromValue } from './astFromValue.mjs';\nexport function printSchema(schema) {\n return printFilteredSchema(\n schema,\n (n) => !isSpecifiedDirective(n),\n isDefinedType,\n );\n}\nexport function printIntrospectionSchema(schema) {\n return printFilteredSchema(schema, isSpecifiedDirective, isIntrospectionType);\n}\n\nfunction isDefinedType(type) {\n return !isSpecifiedScalarType(type) && !isIntrospectionType(type);\n}\n\nfunction printFilteredSchema(schema, directiveFilter, typeFilter) {\n const directives = schema.getDirectives().filter(directiveFilter);\n const types = Object.values(schema.getTypeMap()).filter(typeFilter);\n return [\n printSchemaDefinition(schema),\n ...directives.map((directive) => printDirective(directive)),\n ...types.map((type) => printType(type)),\n ]\n .filter(Boolean)\n .join('\\n\\n');\n}\n\nfunction printSchemaDefinition(schema) {\n if (schema.description == null && isSchemaOfCommonNames(schema)) {\n return;\n }\n\n const operationTypes = [];\n const queryType = schema.getQueryType();\n\n if (queryType) {\n operationTypes.push(` query: ${queryType.name}`);\n }\n\n const mutationType = schema.getMutationType();\n\n if (mutationType) {\n operationTypes.push(` mutation: ${mutationType.name}`);\n }\n\n const subscriptionType = schema.getSubscriptionType();\n\n if (subscriptionType) {\n operationTypes.push(` subscription: ${subscriptionType.name}`);\n }\n\n return printDescription(schema) + `schema {\\n${operationTypes.join('\\n')}\\n}`;\n}\n/**\n * GraphQL schema define root types for each type of operation. These types are\n * the same as any other type and can be named in any manner, however there is\n * a common naming convention:\n *\n * ```graphql\n * schema {\n * query: Query\n * mutation: Mutation\n * subscription: Subscription\n * }\n * ```\n *\n * When using this naming convention, the schema description can be omitted.\n */\n\nfunction isSchemaOfCommonNames(schema) {\n const queryType = schema.getQueryType();\n\n if (queryType && queryType.name !== 'Query') {\n return false;\n }\n\n const mutationType = schema.getMutationType();\n\n if (mutationType && mutationType.name !== 'Mutation') {\n return false;\n }\n\n const subscriptionType = schema.getSubscriptionType();\n\n if (subscriptionType && subscriptionType.name !== 'Subscription') {\n return false;\n }\n\n return true;\n}\n\nexport function printType(type) {\n if (isScalarType(type)) {\n return printScalar(type);\n }\n\n if (isObjectType(type)) {\n return printObject(type);\n }\n\n if (isInterfaceType(type)) {\n return printInterface(type);\n }\n\n if (isUnionType(type)) {\n return printUnion(type);\n }\n\n if (isEnumType(type)) {\n return printEnum(type);\n }\n\n if (isInputObjectType(type)) {\n return printInputObject(type);\n }\n /* c8 ignore next 3 */\n // Not reachable, all possible types have been considered.\n\n false || invariant(false, 'Unexpected type: ' + inspect(type));\n}\n\nfunction printScalar(type) {\n return (\n printDescription(type) + `scalar ${type.name}` + printSpecifiedByURL(type)\n );\n}\n\nfunction printImplementedInterfaces(type) {\n const interfaces = type.getInterfaces();\n return interfaces.length\n ? ' implements ' + interfaces.map((i) => i.name).join(' & ')\n : '';\n}\n\nfunction printObject(type) {\n return (\n printDescription(type) +\n `type ${type.name}` +\n printImplementedInterfaces(type) +\n printFields(type)\n );\n}\n\nfunction printInterface(type) {\n return (\n printDescription(type) +\n `interface ${type.name}` +\n printImplementedInterfaces(type) +\n printFields(type)\n );\n}\n\nfunction printUnion(type) {\n const types = type.getTypes();\n const possibleTypes = types.length ? ' = ' + types.join(' | ') : '';\n return printDescription(type) + 'union ' + type.name + possibleTypes;\n}\n\nfunction printEnum(type) {\n const values = type\n .getValues()\n .map(\n (value, i) =>\n printDescription(value, ' ', !i) +\n ' ' +\n value.name +\n printDeprecated(value.deprecationReason),\n );\n return printDescription(type) + `enum ${type.name}` + printBlock(values);\n}\n\nfunction printInputObject(type) {\n const fields = Object.values(type.getFields()).map(\n (f, i) => printDescription(f, ' ', !i) + ' ' + printInputValue(f),\n );\n return printDescription(type) + `input ${type.name}` + printBlock(fields);\n}\n\nfunction printFields(type) {\n const fields = Object.values(type.getFields()).map(\n (f, i) =>\n printDescription(f, ' ', !i) +\n ' ' +\n f.name +\n printArgs(f.args, ' ') +\n ': ' +\n String(f.type) +\n printDeprecated(f.deprecationReason),\n );\n return printBlock(fields);\n}\n\nfunction printBlock(items) {\n return items.length !== 0 ? ' {\\n' + items.join('\\n') + '\\n}' : '';\n}\n\nfunction printArgs(args, indentation = '') {\n if (args.length === 0) {\n return '';\n } // If every arg does not have a description, print them on one line.\n\n if (args.every((arg) => !arg.description)) {\n return '(' + args.map(printInputValue).join(', ') + ')';\n }\n\n return (\n '(\\n' +\n args\n .map(\n (arg, i) =>\n printDescription(arg, ' ' + indentation, !i) +\n ' ' +\n indentation +\n printInputValue(arg),\n )\n .join('\\n') +\n '\\n' +\n indentation +\n ')'\n );\n}\n\nfunction printInputValue(arg) {\n const defaultAST = astFromValue(arg.defaultValue, arg.type);\n let argDecl = arg.name + ': ' + String(arg.type);\n\n if (defaultAST) {\n argDecl += ` = ${print(defaultAST)}`;\n }\n\n return argDecl + printDeprecated(arg.deprecationReason);\n}\n\nfunction printDirective(directive) {\n return (\n printDescription(directive) +\n 'directive @' +\n directive.name +\n printArgs(directive.args) +\n (directive.isRepeatable ? ' repeatable' : '') +\n ' on ' +\n directive.locations.join(' | ')\n );\n}\n\nfunction printDeprecated(reason) {\n if (reason == null) {\n return '';\n }\n\n if (reason !== DEFAULT_DEPRECATION_REASON) {\n const astValue = print({\n kind: Kind.STRING,\n value: reason,\n });\n return ` @deprecated(reason: ${astValue})`;\n }\n\n return ' @deprecated';\n}\n\nfunction printSpecifiedByURL(scalar) {\n if (scalar.specifiedByURL == null) {\n return '';\n }\n\n const astValue = print({\n kind: Kind.STRING,\n value: scalar.specifiedByURL,\n });\n return ` @specifiedBy(url: ${astValue})`;\n}\n\nfunction printDescription(def, indentation = '', firstInBlock = true) {\n const { description } = def;\n\n if (description == null) {\n return '';\n }\n\n const blockString = print({\n kind: Kind.STRING,\n value: description,\n block: isPrintableAsBlockString(description),\n });\n const prefix =\n indentation && !firstInBlock ? '\\n' + indentation : indentation;\n return prefix + blockString.replace(/\\n/g, '\\n' + indentation) + '\\n';\n}\n","import { Kind } from '../language/kinds.mjs';\n/**\n * Provided a collection of ASTs, presumably each from different files,\n * concatenate the ASTs together into batched AST, useful for validating many\n * GraphQL source files which together represent one conceptual application.\n */\n\nexport function concatAST(documents) {\n const definitions = [];\n\n for (const doc of documents) {\n definitions.push(...doc.definitions);\n }\n\n return {\n kind: Kind.DOCUMENT,\n definitions,\n };\n}\n","import { Kind } from '../language/kinds.mjs';\nimport { visit } from '../language/visitor.mjs';\n/**\n * separateOperations accepts a single AST document which may contain many\n * operations and fragments and returns a collection of AST documents each of\n * which contains a single operation as well the fragment definitions it\n * refers to.\n */\n\nexport function separateOperations(documentAST) {\n const operations = [];\n const depGraph = Object.create(null); // Populate metadata and build a dependency graph.\n\n for (const definitionNode of documentAST.definitions) {\n switch (definitionNode.kind) {\n case Kind.OPERATION_DEFINITION:\n operations.push(definitionNode);\n break;\n\n case Kind.FRAGMENT_DEFINITION:\n depGraph[definitionNode.name.value] = collectDependencies(\n definitionNode.selectionSet,\n );\n break;\n\n default: // ignore non-executable definitions\n }\n } // For each operation, produce a new synthesized AST which includes only what\n // is necessary for completing that operation.\n\n const separatedDocumentASTs = Object.create(null);\n\n for (const operation of operations) {\n const dependencies = new Set();\n\n for (const fragmentName of collectDependencies(operation.selectionSet)) {\n collectTransitiveDependencies(dependencies, depGraph, fragmentName);\n } // Provides the empty string for anonymous operations.\n\n const operationName = operation.name ? operation.name.value : ''; // The list of definition nodes to be included for this operation, sorted\n // to retain the same order as the original document.\n\n separatedDocumentASTs[operationName] = {\n kind: Kind.DOCUMENT,\n definitions: documentAST.definitions.filter(\n (node) =>\n node === operation ||\n (node.kind === Kind.FRAGMENT_DEFINITION &&\n dependencies.has(node.name.value)),\n ),\n };\n }\n\n return separatedDocumentASTs;\n}\n\n// From a dependency graph, collects a list of transitive dependencies by\n// recursing through a dependency graph.\nfunction collectTransitiveDependencies(collected, depGraph, fromName) {\n if (!collected.has(fromName)) {\n collected.add(fromName);\n const immediateDeps = depGraph[fromName];\n\n if (immediateDeps !== undefined) {\n for (const toName of immediateDeps) {\n collectTransitiveDependencies(collected, depGraph, toName);\n }\n }\n }\n}\n\nfunction collectDependencies(selectionSet) {\n const dependencies = [];\n visit(selectionSet, {\n FragmentSpread(node) {\n dependencies.push(node.name.value);\n },\n });\n return dependencies;\n}\n","import { printBlockString } from '../language/blockString.mjs';\nimport { isPunctuatorTokenKind, Lexer } from '../language/lexer.mjs';\nimport { isSource, Source } from '../language/source.mjs';\nimport { TokenKind } from '../language/tokenKind.mjs';\n/**\n * Strips characters that are not significant to the validity or execution\n * of a GraphQL document:\n * - UnicodeBOM\n * - WhiteSpace\n * - LineTerminator\n * - Comment\n * - Comma\n * - BlockString indentation\n *\n * Note: It is required to have a delimiter character between neighboring\n * non-punctuator tokens and this function always uses single space as delimiter.\n *\n * It is guaranteed that both input and output documents if parsed would result\n * in the exact same AST except for nodes location.\n *\n * Warning: It is guaranteed that this function will always produce stable results.\n * However, it's not guaranteed that it will stay the same between different\n * releases due to bugfixes or changes in the GraphQL specification.\n *\n * Query example:\n *\n * ```graphql\n * query SomeQuery($foo: String!, $bar: String) {\n * someField(foo: $foo, bar: $bar) {\n * a\n * b {\n * c\n * d\n * }\n * }\n * }\n * ```\n *\n * Becomes:\n *\n * ```graphql\n * query SomeQuery($foo:String!$bar:String){someField(foo:$foo bar:$bar){a b{c d}}}\n * ```\n *\n * SDL example:\n *\n * ```graphql\n * \"\"\"\n * Type description\n * \"\"\"\n * type Foo {\n * \"\"\"\n * Field description\n * \"\"\"\n * bar: String\n * }\n * ```\n *\n * Becomes:\n *\n * ```graphql\n * \"\"\"Type description\"\"\" type Foo{\"\"\"Field description\"\"\" bar:String}\n * ```\n */\n\nexport function stripIgnoredCharacters(source) {\n const sourceObj = isSource(source) ? source : new Source(source);\n const body = sourceObj.body;\n const lexer = new Lexer(sourceObj);\n let strippedBody = '';\n let wasLastAddedTokenNonPunctuator = false;\n\n while (lexer.advance().kind !== TokenKind.EOF) {\n const currentToken = lexer.token;\n const tokenKind = currentToken.kind;\n /**\n * Every two non-punctuator tokens should have space between them.\n * Also prevent case of non-punctuator token following by spread resulting\n * in invalid token (e.g. `1...` is invalid Float token).\n */\n\n const isNonPunctuator = !isPunctuatorTokenKind(currentToken.kind);\n\n if (wasLastAddedTokenNonPunctuator) {\n if (isNonPunctuator || currentToken.kind === TokenKind.SPREAD) {\n strippedBody += ' ';\n }\n }\n\n const tokenBody = body.slice(currentToken.start, currentToken.end);\n\n if (tokenKind === TokenKind.BLOCK_STRING) {\n strippedBody += printBlockString(currentToken.value, {\n minimize: true,\n });\n } else {\n strippedBody += tokenBody;\n }\n\n wasLastAddedTokenNonPunctuator = isNonPunctuator;\n }\n\n return strippedBody;\n}\n","import { devAssert } from '../jsutils/devAssert.mjs';\nimport { GraphQLError } from '../error/GraphQLError.mjs';\nimport { assertName } from '../type/assertName.mjs';\n/* c8 ignore start */\n\n/**\n * Upholds the spec rules about naming.\n * @deprecated Please use `assertName` instead. Will be removed in v17\n */\n\nexport function assertValidName(name) {\n const error = isValidNameError(name);\n\n if (error) {\n throw error;\n }\n\n return name;\n}\n/**\n * Returns an Error if a name is invalid.\n * @deprecated Please use `assertName` instead. Will be removed in v17\n */\n\nexport function isValidNameError(name) {\n typeof name === 'string' || devAssert(false, 'Expected name to be a string.');\n\n if (name.startsWith('__')) {\n return new GraphQLError(\n `Name \"${name}\" must not begin with \"__\", which is reserved by GraphQL introspection.`,\n );\n }\n\n try {\n assertName(name);\n } catch (error) {\n return error;\n }\n}\n/* c8 ignore stop */\n","import { inspect } from '../jsutils/inspect.mjs';\nimport { invariant } from '../jsutils/invariant.mjs';\nimport { keyMap } from '../jsutils/keyMap.mjs';\nimport { print } from '../language/printer.mjs';\nimport {\n isEnumType,\n isInputObjectType,\n isInterfaceType,\n isListType,\n isNamedType,\n isNonNullType,\n isObjectType,\n isRequiredArgument,\n isRequiredInputField,\n isScalarType,\n isUnionType,\n} from '../type/definition.mjs';\nimport { isSpecifiedScalarType } from '../type/scalars.mjs';\nimport { astFromValue } from './astFromValue.mjs';\nimport { sortValueNode } from './sortValueNode.mjs';\nvar BreakingChangeType;\n\n(function (BreakingChangeType) {\n BreakingChangeType['TYPE_REMOVED'] = 'TYPE_REMOVED';\n BreakingChangeType['TYPE_CHANGED_KIND'] = 'TYPE_CHANGED_KIND';\n BreakingChangeType['TYPE_REMOVED_FROM_UNION'] = 'TYPE_REMOVED_FROM_UNION';\n BreakingChangeType['VALUE_REMOVED_FROM_ENUM'] = 'VALUE_REMOVED_FROM_ENUM';\n BreakingChangeType['REQUIRED_INPUT_FIELD_ADDED'] =\n 'REQUIRED_INPUT_FIELD_ADDED';\n BreakingChangeType['IMPLEMENTED_INTERFACE_REMOVED'] =\n 'IMPLEMENTED_INTERFACE_REMOVED';\n BreakingChangeType['FIELD_REMOVED'] = 'FIELD_REMOVED';\n BreakingChangeType['FIELD_CHANGED_KIND'] = 'FIELD_CHANGED_KIND';\n BreakingChangeType['REQUIRED_ARG_ADDED'] = 'REQUIRED_ARG_ADDED';\n BreakingChangeType['ARG_REMOVED'] = 'ARG_REMOVED';\n BreakingChangeType['ARG_CHANGED_KIND'] = 'ARG_CHANGED_KIND';\n BreakingChangeType['DIRECTIVE_REMOVED'] = 'DIRECTIVE_REMOVED';\n BreakingChangeType['DIRECTIVE_ARG_REMOVED'] = 'DIRECTIVE_ARG_REMOVED';\n BreakingChangeType['REQUIRED_DIRECTIVE_ARG_ADDED'] =\n 'REQUIRED_DIRECTIVE_ARG_ADDED';\n BreakingChangeType['DIRECTIVE_REPEATABLE_REMOVED'] =\n 'DIRECTIVE_REPEATABLE_REMOVED';\n BreakingChangeType['DIRECTIVE_LOCATION_REMOVED'] =\n 'DIRECTIVE_LOCATION_REMOVED';\n})(BreakingChangeType || (BreakingChangeType = {}));\n\nexport { BreakingChangeType };\nvar DangerousChangeType;\n\n(function (DangerousChangeType) {\n DangerousChangeType['VALUE_ADDED_TO_ENUM'] = 'VALUE_ADDED_TO_ENUM';\n DangerousChangeType['TYPE_ADDED_TO_UNION'] = 'TYPE_ADDED_TO_UNION';\n DangerousChangeType['OPTIONAL_INPUT_FIELD_ADDED'] =\n 'OPTIONAL_INPUT_FIELD_ADDED';\n DangerousChangeType['OPTIONAL_ARG_ADDED'] = 'OPTIONAL_ARG_ADDED';\n DangerousChangeType['IMPLEMENTED_INTERFACE_ADDED'] =\n 'IMPLEMENTED_INTERFACE_ADDED';\n DangerousChangeType['ARG_DEFAULT_VALUE_CHANGE'] = 'ARG_DEFAULT_VALUE_CHANGE';\n})(DangerousChangeType || (DangerousChangeType = {}));\n\nexport { DangerousChangeType };\n\n/**\n * Given two schemas, returns an Array containing descriptions of all the types\n * of breaking changes covered by the other functions down below.\n */\nexport function findBreakingChanges(oldSchema, newSchema) {\n // @ts-expect-error\n return findSchemaChanges(oldSchema, newSchema).filter(\n (change) => change.type in BreakingChangeType,\n );\n}\n/**\n * Given two schemas, returns an Array containing descriptions of all the types\n * of potentially dangerous changes covered by the other functions down below.\n */\n\nexport function findDangerousChanges(oldSchema, newSchema) {\n // @ts-expect-error\n return findSchemaChanges(oldSchema, newSchema).filter(\n (change) => change.type in DangerousChangeType,\n );\n}\n\nfunction findSchemaChanges(oldSchema, newSchema) {\n return [\n ...findTypeChanges(oldSchema, newSchema),\n ...findDirectiveChanges(oldSchema, newSchema),\n ];\n}\n\nfunction findDirectiveChanges(oldSchema, newSchema) {\n const schemaChanges = [];\n const directivesDiff = diff(\n oldSchema.getDirectives(),\n newSchema.getDirectives(),\n );\n\n for (const oldDirective of directivesDiff.removed) {\n schemaChanges.push({\n type: BreakingChangeType.DIRECTIVE_REMOVED,\n description: `${oldDirective.name} was removed.`,\n });\n }\n\n for (const [oldDirective, newDirective] of directivesDiff.persisted) {\n const argsDiff = diff(oldDirective.args, newDirective.args);\n\n for (const newArg of argsDiff.added) {\n if (isRequiredArgument(newArg)) {\n schemaChanges.push({\n type: BreakingChangeType.REQUIRED_DIRECTIVE_ARG_ADDED,\n description: `A required arg ${newArg.name} on directive ${oldDirective.name} was added.`,\n });\n }\n }\n\n for (const oldArg of argsDiff.removed) {\n schemaChanges.push({\n type: BreakingChangeType.DIRECTIVE_ARG_REMOVED,\n description: `${oldArg.name} was removed from ${oldDirective.name}.`,\n });\n }\n\n if (oldDirective.isRepeatable && !newDirective.isRepeatable) {\n schemaChanges.push({\n type: BreakingChangeType.DIRECTIVE_REPEATABLE_REMOVED,\n description: `Repeatable flag was removed from ${oldDirective.name}.`,\n });\n }\n\n for (const location of oldDirective.locations) {\n if (!newDirective.locations.includes(location)) {\n schemaChanges.push({\n type: BreakingChangeType.DIRECTIVE_LOCATION_REMOVED,\n description: `${location} was removed from ${oldDirective.name}.`,\n });\n }\n }\n }\n\n return schemaChanges;\n}\n\nfunction findTypeChanges(oldSchema, newSchema) {\n const schemaChanges = [];\n const typesDiff = diff(\n Object.values(oldSchema.getTypeMap()),\n Object.values(newSchema.getTypeMap()),\n );\n\n for (const oldType of typesDiff.removed) {\n schemaChanges.push({\n type: BreakingChangeType.TYPE_REMOVED,\n description: isSpecifiedScalarType(oldType)\n ? `Standard scalar ${oldType.name} was removed because it is not referenced anymore.`\n : `${oldType.name} was removed.`,\n });\n }\n\n for (const [oldType, newType] of typesDiff.persisted) {\n if (isEnumType(oldType) && isEnumType(newType)) {\n schemaChanges.push(...findEnumTypeChanges(oldType, newType));\n } else if (isUnionType(oldType) && isUnionType(newType)) {\n schemaChanges.push(...findUnionTypeChanges(oldType, newType));\n } else if (isInputObjectType(oldType) && isInputObjectType(newType)) {\n schemaChanges.push(...findInputObjectTypeChanges(oldType, newType));\n } else if (isObjectType(oldType) && isObjectType(newType)) {\n schemaChanges.push(\n ...findFieldChanges(oldType, newType),\n ...findImplementedInterfacesChanges(oldType, newType),\n );\n } else if (isInterfaceType(oldType) && isInterfaceType(newType)) {\n schemaChanges.push(\n ...findFieldChanges(oldType, newType),\n ...findImplementedInterfacesChanges(oldType, newType),\n );\n } else if (oldType.constructor !== newType.constructor) {\n schemaChanges.push({\n type: BreakingChangeType.TYPE_CHANGED_KIND,\n description:\n `${oldType.name} changed from ` +\n `${typeKindName(oldType)} to ${typeKindName(newType)}.`,\n });\n }\n }\n\n return schemaChanges;\n}\n\nfunction findInputObjectTypeChanges(oldType, newType) {\n const schemaChanges = [];\n const fieldsDiff = diff(\n Object.values(oldType.getFields()),\n Object.values(newType.getFields()),\n );\n\n for (const newField of fieldsDiff.added) {\n if (isRequiredInputField(newField)) {\n schemaChanges.push({\n type: BreakingChangeType.REQUIRED_INPUT_FIELD_ADDED,\n description: `A required field ${newField.name} on input type ${oldType.name} was added.`,\n });\n } else {\n schemaChanges.push({\n type: DangerousChangeType.OPTIONAL_INPUT_FIELD_ADDED,\n description: `An optional field ${newField.name} on input type ${oldType.name} was added.`,\n });\n }\n }\n\n for (const oldField of fieldsDiff.removed) {\n schemaChanges.push({\n type: BreakingChangeType.FIELD_REMOVED,\n description: `${oldType.name}.${oldField.name} was removed.`,\n });\n }\n\n for (const [oldField, newField] of fieldsDiff.persisted) {\n const isSafe = isChangeSafeForInputObjectFieldOrFieldArg(\n oldField.type,\n newField.type,\n );\n\n if (!isSafe) {\n schemaChanges.push({\n type: BreakingChangeType.FIELD_CHANGED_KIND,\n description:\n `${oldType.name}.${oldField.name} changed type from ` +\n `${String(oldField.type)} to ${String(newField.type)}.`,\n });\n }\n }\n\n return schemaChanges;\n}\n\nfunction findUnionTypeChanges(oldType, newType) {\n const schemaChanges = [];\n const possibleTypesDiff = diff(oldType.getTypes(), newType.getTypes());\n\n for (const newPossibleType of possibleTypesDiff.added) {\n schemaChanges.push({\n type: DangerousChangeType.TYPE_ADDED_TO_UNION,\n description: `${newPossibleType.name} was added to union type ${oldType.name}.`,\n });\n }\n\n for (const oldPossibleType of possibleTypesDiff.removed) {\n schemaChanges.push({\n type: BreakingChangeType.TYPE_REMOVED_FROM_UNION,\n description: `${oldPossibleType.name} was removed from union type ${oldType.name}.`,\n });\n }\n\n return schemaChanges;\n}\n\nfunction findEnumTypeChanges(oldType, newType) {\n const schemaChanges = [];\n const valuesDiff = diff(oldType.getValues(), newType.getValues());\n\n for (const newValue of valuesDiff.added) {\n schemaChanges.push({\n type: DangerousChangeType.VALUE_ADDED_TO_ENUM,\n description: `${newValue.name} was added to enum type ${oldType.name}.`,\n });\n }\n\n for (const oldValue of valuesDiff.removed) {\n schemaChanges.push({\n type: BreakingChangeType.VALUE_REMOVED_FROM_ENUM,\n description: `${oldValue.name} was removed from enum type ${oldType.name}.`,\n });\n }\n\n return schemaChanges;\n}\n\nfunction findImplementedInterfacesChanges(oldType, newType) {\n const schemaChanges = [];\n const interfacesDiff = diff(oldType.getInterfaces(), newType.getInterfaces());\n\n for (const newInterface of interfacesDiff.added) {\n schemaChanges.push({\n type: DangerousChangeType.IMPLEMENTED_INTERFACE_ADDED,\n description: `${newInterface.name} added to interfaces implemented by ${oldType.name}.`,\n });\n }\n\n for (const oldInterface of interfacesDiff.removed) {\n schemaChanges.push({\n type: BreakingChangeType.IMPLEMENTED_INTERFACE_REMOVED,\n description: `${oldType.name} no longer implements interface ${oldInterface.name}.`,\n });\n }\n\n return schemaChanges;\n}\n\nfunction findFieldChanges(oldType, newType) {\n const schemaChanges = [];\n const fieldsDiff = diff(\n Object.values(oldType.getFields()),\n Object.values(newType.getFields()),\n );\n\n for (const oldField of fieldsDiff.removed) {\n schemaChanges.push({\n type: BreakingChangeType.FIELD_REMOVED,\n description: `${oldType.name}.${oldField.name} was removed.`,\n });\n }\n\n for (const [oldField, newField] of fieldsDiff.persisted) {\n schemaChanges.push(...findArgChanges(oldType, oldField, newField));\n const isSafe = isChangeSafeForObjectOrInterfaceField(\n oldField.type,\n newField.type,\n );\n\n if (!isSafe) {\n schemaChanges.push({\n type: BreakingChangeType.FIELD_CHANGED_KIND,\n description:\n `${oldType.name}.${oldField.name} changed type from ` +\n `${String(oldField.type)} to ${String(newField.type)}.`,\n });\n }\n }\n\n return schemaChanges;\n}\n\nfunction findArgChanges(oldType, oldField, newField) {\n const schemaChanges = [];\n const argsDiff = diff(oldField.args, newField.args);\n\n for (const oldArg of argsDiff.removed) {\n schemaChanges.push({\n type: BreakingChangeType.ARG_REMOVED,\n description: `${oldType.name}.${oldField.name} arg ${oldArg.name} was removed.`,\n });\n }\n\n for (const [oldArg, newArg] of argsDiff.persisted) {\n const isSafe = isChangeSafeForInputObjectFieldOrFieldArg(\n oldArg.type,\n newArg.type,\n );\n\n if (!isSafe) {\n schemaChanges.push({\n type: BreakingChangeType.ARG_CHANGED_KIND,\n description:\n `${oldType.name}.${oldField.name} arg ${oldArg.name} has changed type from ` +\n `${String(oldArg.type)} to ${String(newArg.type)}.`,\n });\n } else if (oldArg.defaultValue !== undefined) {\n if (newArg.defaultValue === undefined) {\n schemaChanges.push({\n type: DangerousChangeType.ARG_DEFAULT_VALUE_CHANGE,\n description: `${oldType.name}.${oldField.name} arg ${oldArg.name} defaultValue was removed.`,\n });\n } else {\n // Since we looking only for client's observable changes we should\n // compare default values in the same representation as they are\n // represented inside introspection.\n const oldValueStr = stringifyValue(oldArg.defaultValue, oldArg.type);\n const newValueStr = stringifyValue(newArg.defaultValue, newArg.type);\n\n if (oldValueStr !== newValueStr) {\n schemaChanges.push({\n type: DangerousChangeType.ARG_DEFAULT_VALUE_CHANGE,\n description: `${oldType.name}.${oldField.name} arg ${oldArg.name} has changed defaultValue from ${oldValueStr} to ${newValueStr}.`,\n });\n }\n }\n }\n }\n\n for (const newArg of argsDiff.added) {\n if (isRequiredArgument(newArg)) {\n schemaChanges.push({\n type: BreakingChangeType.REQUIRED_ARG_ADDED,\n description: `A required arg ${newArg.name} on ${oldType.name}.${oldField.name} was added.`,\n });\n } else {\n schemaChanges.push({\n type: DangerousChangeType.OPTIONAL_ARG_ADDED,\n description: `An optional arg ${newArg.name} on ${oldType.name}.${oldField.name} was added.`,\n });\n }\n }\n\n return schemaChanges;\n}\n\nfunction isChangeSafeForObjectOrInterfaceField(oldType, newType) {\n if (isListType(oldType)) {\n return (\n // if they're both lists, make sure the underlying types are compatible\n (isListType(newType) &&\n isChangeSafeForObjectOrInterfaceField(\n oldType.ofType,\n newType.ofType,\n )) || // moving from nullable to non-null of the same underlying type is safe\n (isNonNullType(newType) &&\n isChangeSafeForObjectOrInterfaceField(oldType, newType.ofType))\n );\n }\n\n if (isNonNullType(oldType)) {\n // if they're both non-null, make sure the underlying types are compatible\n return (\n isNonNullType(newType) &&\n isChangeSafeForObjectOrInterfaceField(oldType.ofType, newType.ofType)\n );\n }\n\n return (\n // if they're both named types, see if their names are equivalent\n (isNamedType(newType) && oldType.name === newType.name) || // moving from nullable to non-null of the same underlying type is safe\n (isNonNullType(newType) &&\n isChangeSafeForObjectOrInterfaceField(oldType, newType.ofType))\n );\n}\n\nfunction isChangeSafeForInputObjectFieldOrFieldArg(oldType, newType) {\n if (isListType(oldType)) {\n // if they're both lists, make sure the underlying types are compatible\n return (\n isListType(newType) &&\n isChangeSafeForInputObjectFieldOrFieldArg(oldType.ofType, newType.ofType)\n );\n }\n\n if (isNonNullType(oldType)) {\n return (\n // if they're both non-null, make sure the underlying types are\n // compatible\n (isNonNullType(newType) &&\n isChangeSafeForInputObjectFieldOrFieldArg(\n oldType.ofType,\n newType.ofType,\n )) || // moving from non-null to nullable of the same underlying type is safe\n (!isNonNullType(newType) &&\n isChangeSafeForInputObjectFieldOrFieldArg(oldType.ofType, newType))\n );\n } // if they're both named types, see if their names are equivalent\n\n return isNamedType(newType) && oldType.name === newType.name;\n}\n\nfunction typeKindName(type) {\n if (isScalarType(type)) {\n return 'a Scalar type';\n }\n\n if (isObjectType(type)) {\n return 'an Object type';\n }\n\n if (isInterfaceType(type)) {\n return 'an Interface type';\n }\n\n if (isUnionType(type)) {\n return 'a Union type';\n }\n\n if (isEnumType(type)) {\n return 'an Enum type';\n }\n\n if (isInputObjectType(type)) {\n return 'an Input type';\n }\n /* c8 ignore next 3 */\n // Not reachable, all possible types have been considered.\n\n false || invariant(false, 'Unexpected type: ' + inspect(type));\n}\n\nfunction stringifyValue(value, type) {\n const ast = astFromValue(value, type);\n ast != null || invariant(false);\n return print(sortValueNode(ast));\n}\n\nfunction diff(oldArray, newArray) {\n const added = [];\n const removed = [];\n const persisted = [];\n const oldMap = keyMap(oldArray, ({ name }) => name);\n const newMap = keyMap(newArray, ({ name }) => name);\n\n for (const oldItem of oldArray) {\n const newItem = newMap[oldItem.name];\n\n if (newItem === undefined) {\n removed.push(oldItem);\n } else {\n persisted.push([oldItem, newItem]);\n }\n }\n\n for (const newItem of newArray) {\n if (oldMap[newItem.name] === undefined) {\n added.push(newItem);\n }\n }\n\n return {\n added,\n persisted,\n removed,\n };\n}\n","/**\n * Tokenize input string.\n */\nfunction lexer(str) {\n var tokens = [];\n var i = 0;\n while (i < str.length) {\n var char = str[i];\n if (char === \"*\" || char === \"+\" || char === \"?\") {\n tokens.push({ type: \"MODIFIER\", index: i, value: str[i++] });\n continue;\n }\n if (char === \"\\\\\") {\n tokens.push({ type: \"ESCAPED_CHAR\", index: i++, value: str[i++] });\n continue;\n }\n if (char === \"{\") {\n tokens.push({ type: \"OPEN\", index: i, value: str[i++] });\n continue;\n }\n if (char === \"}\") {\n tokens.push({ type: \"CLOSE\", index: i, value: str[i++] });\n continue;\n }\n if (char === \":\") {\n var name = \"\";\n var j = i + 1;\n while (j < str.length) {\n var code = str.charCodeAt(j);\n if (\n // `0-9`\n (code >= 48 && code <= 57) ||\n // `A-Z`\n (code >= 65 && code <= 90) ||\n // `a-z`\n (code >= 97 && code <= 122) ||\n // `_`\n code === 95) {\n name += str[j++];\n continue;\n }\n break;\n }\n if (!name)\n throw new TypeError(\"Missing parameter name at \".concat(i));\n tokens.push({ type: \"NAME\", index: i, value: name });\n i = j;\n continue;\n }\n if (char === \"(\") {\n var count = 1;\n var pattern = \"\";\n var j = i + 1;\n if (str[j] === \"?\") {\n throw new TypeError(\"Pattern cannot start with \\\"?\\\" at \".concat(j));\n }\n while (j < str.length) {\n if (str[j] === \"\\\\\") {\n pattern += str[j++] + str[j++];\n continue;\n }\n if (str[j] === \")\") {\n count--;\n if (count === 0) {\n j++;\n break;\n }\n }\n else if (str[j] === \"(\") {\n count++;\n if (str[j + 1] !== \"?\") {\n throw new TypeError(\"Capturing groups are not allowed at \".concat(j));\n }\n }\n pattern += str[j++];\n }\n if (count)\n throw new TypeError(\"Unbalanced pattern at \".concat(i));\n if (!pattern)\n throw new TypeError(\"Missing pattern at \".concat(i));\n tokens.push({ type: \"PATTERN\", index: i, value: pattern });\n i = j;\n continue;\n }\n tokens.push({ type: \"CHAR\", index: i, value: str[i++] });\n }\n tokens.push({ type: \"END\", index: i, value: \"\" });\n return tokens;\n}\n/**\n * Parse a string for the raw tokens.\n */\nexport function parse(str, options) {\n if (options === void 0) { options = {}; }\n var tokens = lexer(str);\n var _a = options.prefixes, prefixes = _a === void 0 ? \"./\" : _a, _b = options.delimiter, delimiter = _b === void 0 ? \"/#?\" : _b;\n var result = [];\n var key = 0;\n var i = 0;\n var path = \"\";\n var tryConsume = function (type) {\n if (i < tokens.length && tokens[i].type === type)\n return tokens[i++].value;\n };\n var mustConsume = function (type) {\n var value = tryConsume(type);\n if (value !== undefined)\n return value;\n var _a = tokens[i], nextType = _a.type, index = _a.index;\n throw new TypeError(\"Unexpected \".concat(nextType, \" at \").concat(index, \", expected \").concat(type));\n };\n var consumeText = function () {\n var result = \"\";\n var value;\n while ((value = tryConsume(\"CHAR\") || tryConsume(\"ESCAPED_CHAR\"))) {\n result += value;\n }\n return result;\n };\n var isSafe = function (value) {\n for (var _i = 0, delimiter_1 = delimiter; _i < delimiter_1.length; _i++) {\n var char = delimiter_1[_i];\n if (value.indexOf(char) > -1)\n return true;\n }\n return false;\n };\n var safePattern = function (prefix) {\n var prev = result[result.length - 1];\n var prevText = prefix || (prev && typeof prev === \"string\" ? prev : \"\");\n if (prev && !prevText) {\n throw new TypeError(\"Must have text between two parameters, missing text after \\\"\".concat(prev.name, \"\\\"\"));\n }\n if (!prevText || isSafe(prevText))\n return \"[^\".concat(escapeString(delimiter), \"]+?\");\n return \"(?:(?!\".concat(escapeString(prevText), \")[^\").concat(escapeString(delimiter), \"])+?\");\n };\n while (i < tokens.length) {\n var char = tryConsume(\"CHAR\");\n var name = tryConsume(\"NAME\");\n var pattern = tryConsume(\"PATTERN\");\n if (name || pattern) {\n var prefix = char || \"\";\n if (prefixes.indexOf(prefix) === -1) {\n path += prefix;\n prefix = \"\";\n }\n if (path) {\n result.push(path);\n path = \"\";\n }\n result.push({\n name: name || key++,\n prefix: prefix,\n suffix: \"\",\n pattern: pattern || safePattern(prefix),\n modifier: tryConsume(\"MODIFIER\") || \"\",\n });\n continue;\n }\n var value = char || tryConsume(\"ESCAPED_CHAR\");\n if (value) {\n path += value;\n continue;\n }\n if (path) {\n result.push(path);\n path = \"\";\n }\n var open = tryConsume(\"OPEN\");\n if (open) {\n var prefix = consumeText();\n var name_1 = tryConsume(\"NAME\") || \"\";\n var pattern_1 = tryConsume(\"PATTERN\") || \"\";\n var suffix = consumeText();\n mustConsume(\"CLOSE\");\n result.push({\n name: name_1 || (pattern_1 ? key++ : \"\"),\n pattern: name_1 && !pattern_1 ? safePattern(prefix) : pattern_1,\n prefix: prefix,\n suffix: suffix,\n modifier: tryConsume(\"MODIFIER\") || \"\",\n });\n continue;\n }\n mustConsume(\"END\");\n }\n return result;\n}\n/**\n * Compile a string to a template function for the path.\n */\nexport function compile(str, options) {\n return tokensToFunction(parse(str, options), options);\n}\n/**\n * Expose a method for transforming tokens into the path function.\n */\nexport function tokensToFunction(tokens, options) {\n if (options === void 0) { options = {}; }\n var reFlags = flags(options);\n var _a = options.encode, encode = _a === void 0 ? function (x) { return x; } : _a, _b = options.validate, validate = _b === void 0 ? true : _b;\n // Compile all the tokens into regexps.\n var matches = tokens.map(function (token) {\n if (typeof token === \"object\") {\n return new RegExp(\"^(?:\".concat(token.pattern, \")$\"), reFlags);\n }\n });\n return function (data) {\n var path = \"\";\n for (var i = 0; i < tokens.length; i++) {\n var token = tokens[i];\n if (typeof token === \"string\") {\n path += token;\n continue;\n }\n var value = data ? data[token.name] : undefined;\n var optional = token.modifier === \"?\" || token.modifier === \"*\";\n var repeat = token.modifier === \"*\" || token.modifier === \"+\";\n if (Array.isArray(value)) {\n if (!repeat) {\n throw new TypeError(\"Expected \\\"\".concat(token.name, \"\\\" to not repeat, but got an array\"));\n }\n if (value.length === 0) {\n if (optional)\n continue;\n throw new TypeError(\"Expected \\\"\".concat(token.name, \"\\\" to not be empty\"));\n }\n for (var j = 0; j < value.length; j++) {\n var segment = encode(value[j], token);\n if (validate && !matches[i].test(segment)) {\n throw new TypeError(\"Expected all \\\"\".concat(token.name, \"\\\" to match \\\"\").concat(token.pattern, \"\\\", but got \\\"\").concat(segment, \"\\\"\"));\n }\n path += token.prefix + segment + token.suffix;\n }\n continue;\n }\n if (typeof value === \"string\" || typeof value === \"number\") {\n var segment = encode(String(value), token);\n if (validate && !matches[i].test(segment)) {\n throw new TypeError(\"Expected \\\"\".concat(token.name, \"\\\" to match \\\"\").concat(token.pattern, \"\\\", but got \\\"\").concat(segment, \"\\\"\"));\n }\n path += token.prefix + segment + token.suffix;\n continue;\n }\n if (optional)\n continue;\n var typeOfMessage = repeat ? \"an array\" : \"a string\";\n throw new TypeError(\"Expected \\\"\".concat(token.name, \"\\\" to be \").concat(typeOfMessage));\n }\n return path;\n };\n}\n/**\n * Create path match function from `path-to-regexp` spec.\n */\nexport function match(str, options) {\n var keys = [];\n var re = pathToRegexp(str, keys, options);\n return regexpToFunction(re, keys, options);\n}\n/**\n * Create a path match function from `path-to-regexp` output.\n */\nexport function regexpToFunction(re, keys, options) {\n if (options === void 0) { options = {}; }\n var _a = options.decode, decode = _a === void 0 ? function (x) { return x; } : _a;\n return function (pathname) {\n var m = re.exec(pathname);\n if (!m)\n return false;\n var path = m[0], index = m.index;\n var params = Object.create(null);\n var _loop_1 = function (i) {\n if (m[i] === undefined)\n return \"continue\";\n var key = keys[i - 1];\n if (key.modifier === \"*\" || key.modifier === \"+\") {\n params[key.name] = m[i].split(key.prefix + key.suffix).map(function (value) {\n return decode(value, key);\n });\n }\n else {\n params[key.name] = decode(m[i], key);\n }\n };\n for (var i = 1; i < m.length; i++) {\n _loop_1(i);\n }\n return { path: path, index: index, params: params };\n };\n}\n/**\n * Escape a regular expression string.\n */\nfunction escapeString(str) {\n return str.replace(/([.+*?=^!:${}()[\\]|/\\\\])/g, \"\\\\$1\");\n}\n/**\n * Get the flags for a regexp from the options.\n */\nfunction flags(options) {\n return options && options.sensitive ? \"\" : \"i\";\n}\n/**\n * Pull out keys from a regexp.\n */\nfunction regexpToRegexp(path, keys) {\n if (!keys)\n return path;\n var groupsRegex = /\\((?:\\?<(.*?)>)?(?!\\?)/g;\n var index = 0;\n var execResult = groupsRegex.exec(path.source);\n while (execResult) {\n keys.push({\n // Use parenthesized substring match if available, index otherwise\n name: execResult[1] || index++,\n prefix: \"\",\n suffix: \"\",\n modifier: \"\",\n pattern: \"\",\n });\n execResult = groupsRegex.exec(path.source);\n }\n return path;\n}\n/**\n * Transform an array into a regexp.\n */\nfunction arrayToRegexp(paths, keys, options) {\n var parts = paths.map(function (path) { return pathToRegexp(path, keys, options).source; });\n return new RegExp(\"(?:\".concat(parts.join(\"|\"), \")\"), flags(options));\n}\n/**\n * Create a path regexp from string input.\n */\nfunction stringToRegexp(path, keys, options) {\n return tokensToRegexp(parse(path, options), keys, options);\n}\n/**\n * Expose a function for taking tokens and returning a RegExp.\n */\nexport function tokensToRegexp(tokens, keys, options) {\n if (options === void 0) { options = {}; }\n var _a = options.strict, strict = _a === void 0 ? false : _a, _b = options.start, start = _b === void 0 ? true : _b, _c = options.end, end = _c === void 0 ? true : _c, _d = options.encode, encode = _d === void 0 ? function (x) { return x; } : _d, _e = options.delimiter, delimiter = _e === void 0 ? \"/#?\" : _e, _f = options.endsWith, endsWith = _f === void 0 ? \"\" : _f;\n var endsWithRe = \"[\".concat(escapeString(endsWith), \"]|$\");\n var delimiterRe = \"[\".concat(escapeString(delimiter), \"]\");\n var route = start ? \"^\" : \"\";\n // Iterate over the tokens and create our regexp string.\n for (var _i = 0, tokens_1 = tokens; _i < tokens_1.length; _i++) {\n var token = tokens_1[_i];\n if (typeof token === \"string\") {\n route += escapeString(encode(token));\n }\n else {\n var prefix = escapeString(encode(token.prefix));\n var suffix = escapeString(encode(token.suffix));\n if (token.pattern) {\n if (keys)\n keys.push(token);\n if (prefix || suffix) {\n if (token.modifier === \"+\" || token.modifier === \"*\") {\n var mod = token.modifier === \"*\" ? \"?\" : \"\";\n route += \"(?:\".concat(prefix, \"((?:\").concat(token.pattern, \")(?:\").concat(suffix).concat(prefix, \"(?:\").concat(token.pattern, \"))*)\").concat(suffix, \")\").concat(mod);\n }\n else {\n route += \"(?:\".concat(prefix, \"(\").concat(token.pattern, \")\").concat(suffix, \")\").concat(token.modifier);\n }\n }\n else {\n if (token.modifier === \"+\" || token.modifier === \"*\") {\n throw new TypeError(\"Can not repeat \\\"\".concat(token.name, \"\\\" without a prefix and suffix\"));\n }\n route += \"(\".concat(token.pattern, \")\").concat(token.modifier);\n }\n }\n else {\n route += \"(?:\".concat(prefix).concat(suffix, \")\").concat(token.modifier);\n }\n }\n }\n if (end) {\n if (!strict)\n route += \"\".concat(delimiterRe, \"?\");\n route += !options.endsWith ? \"$\" : \"(?=\".concat(endsWithRe, \")\");\n }\n else {\n var endToken = tokens[tokens.length - 1];\n var isEndDelimited = typeof endToken === \"string\"\n ? delimiterRe.indexOf(endToken[endToken.length - 1]) > -1\n : endToken === undefined;\n if (!strict) {\n route += \"(?:\".concat(delimiterRe, \"(?=\").concat(endsWithRe, \"))?\");\n }\n if (!isEndDelimited) {\n route += \"(?=\".concat(delimiterRe, \"|\").concat(endsWithRe, \")\");\n }\n }\n return new RegExp(route, flags(options));\n}\n/**\n * Normalize the given path string, returning a regular expression.\n *\n * An empty array can be passed in for the keys, which will hold the\n * placeholder key descriptions. For example, using `/user/:id`, `keys` will\n * contain `[{ name: 'id', delimiter: '/', optional: false, repeat: false }]`.\n */\nexport function pathToRegexp(path, keys, options) {\n if (path instanceof RegExp)\n return regexpToRegexp(path, keys);\n if (Array.isArray(path))\n return arrayToRegexp(path, keys, options);\n return stringToRegexp(path, keys, options);\n}\n//# sourceMappingURL=index.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.toIsoResponse = void 0;\nvar headers_polyfill_1 = require(\"headers-polyfill\");\n/**\n * Converts a given mocked response object into an isomorphic response.\n */\nfunction toIsoResponse(response) {\n var _a;\n return {\n status: (_a = response.status) !== null && _a !== void 0 ? _a : 200,\n statusText: response.statusText || 'OK',\n headers: headers_polyfill_1.objectToHeaders(response.headers || {}),\n body: response.body,\n };\n}\nexports.toIsoResponse = toIsoResponse;\n//# sourceMappingURL=toIsoResponse.js.map","\"use strict\";\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __assign = (this && this.__assign) || function () {\n __assign = Object.assign || function(t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))\n t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\n};\nvar __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nvar __generator = (this && this.__generator) || function (thisArg, body) {\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\n function verb(n) { return function (v) { return step([n, v]); }; }\n function step(op) {\n if (f) throw new TypeError(\"Generator is already executing.\");\n while (_) try {\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\n if (y = 0, t) op = [op[0] & 2, t.value];\n switch (op[0]) {\n case 0: case 1: t = op; break;\n case 4: _.label++; return { value: op[1], done: false };\n case 5: _.label++; y = op[1]; op = [0]; continue;\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\n if (t[2]) _.ops.pop();\n _.trys.pop(); continue;\n }\n op = body.call(thisArg, _);\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\n }\n};\nvar __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.FetchInterceptor = void 0;\nvar headers_polyfill_1 = require(\"headers-polyfill\");\nvar outvariant_1 = require(\"outvariant\");\nvar until_1 = require(\"@open-draft/until\");\nvar IsomorphicRequest_1 = require(\"../../IsomorphicRequest\");\nvar glossary_1 = require(\"../../glossary\");\nvar Interceptor_1 = require(\"../../Interceptor\");\nvar toIsoResponse_1 = require(\"../../utils/toIsoResponse\");\nvar InteractiveIsomorphicRequest_1 = require(\"../../InteractiveIsomorphicRequest\");\nvar FetchInterceptor = /** @class */ (function (_super) {\n __extends(FetchInterceptor, _super);\n function FetchInterceptor() {\n return _super.call(this, FetchInterceptor.symbol) || this;\n }\n FetchInterceptor.prototype.checkEnvironment = function () {\n return (typeof globalThis !== 'undefined' &&\n typeof globalThis.fetch !== 'undefined');\n };\n FetchInterceptor.prototype.setup = function () {\n var _this = this;\n var pureFetch = globalThis.fetch;\n outvariant_1.invariant(!pureFetch[glossary_1.IS_PATCHED_MODULE], 'Failed to patch the \"fetch\" module: already patched.');\n globalThis.fetch = function (input, init) { return __awaiter(_this, void 0, void 0, function () {\n var request, url, method, body, requestUrl, isomorphicRequest, interactiveIsomorphicRequest, _a, middlewareException, mockedResponse, error, isomorphicResponse, response;\n var _this = this;\n return __generator(this, function (_b) {\n switch (_b.label) {\n case 0:\n request = new Request(input, init);\n url = typeof input === 'string' ? input : input.url;\n method = request.method;\n this.log('[%s] %s', method, url);\n return [4 /*yield*/, request.clone().arrayBuffer()];\n case 1:\n body = _b.sent();\n requestUrl = new URL(url, typeof location !== 'undefined' ? location.origin : undefined);\n isomorphicRequest = new IsomorphicRequest_1.IsomorphicRequest(requestUrl, {\n body: body,\n method: method,\n headers: new headers_polyfill_1.Headers(request.headers),\n credentials: request.credentials,\n });\n interactiveIsomorphicRequest = new InteractiveIsomorphicRequest_1.InteractiveIsomorphicRequest(isomorphicRequest);\n this.log('isomorphic request', interactiveIsomorphicRequest);\n this.log('emitting the \"request\" event for %d listener(s)...', this.emitter.listenerCount('request'));\n this.emitter.emit('request', interactiveIsomorphicRequest);\n this.log('awaiting for the mocked response...');\n return [4 /*yield*/, until_1.until(function () { return __awaiter(_this, void 0, void 0, function () {\n var _a, mockedResponse;\n return __generator(this, function (_b) {\n switch (_b.label) {\n case 0: return [4 /*yield*/, this.emitter.untilIdle('request', function (_a) {\n var _b = __read(_a.args, 1), request = _b[0];\n return request.id === interactiveIsomorphicRequest.id;\n })];\n case 1:\n _b.sent();\n this.log('all request listeners have been resolved!');\n return [4 /*yield*/, interactiveIsomorphicRequest.respondWith.invoked()];\n case 2:\n _a = __read.apply(void 0, [_b.sent(), 1]), mockedResponse = _a[0];\n this.log('event.respondWith called with:', mockedResponse);\n return [2 /*return*/, mockedResponse];\n }\n });\n }); })];\n case 2:\n _a = __read.apply(void 0, [_b.sent(), 2]), middlewareException = _a[0], mockedResponse = _a[1];\n if (middlewareException) {\n console.error(request.method + \" \" + request.url + \" net::ERR_FAILED\");\n error = Object.assign(new TypeError('Failed to fetch'), {\n cause: middlewareException,\n });\n return [2 /*return*/, Promise.reject(error)];\n }\n if (mockedResponse) {\n this.log('received mocked response:', mockedResponse);\n isomorphicResponse = toIsoResponse_1.toIsoResponse(mockedResponse);\n this.log('derived isomorphic response:', isomorphicResponse);\n this.emitter.emit('response', interactiveIsomorphicRequest, isomorphicResponse);\n response = new Response(mockedResponse.body, __assign(__assign({}, isomorphicResponse), { \n // `Response.headers` cannot be instantiated with the `Headers` polyfill.\n // Apparently, it halts if the `Headers` class contains unknown properties\n // (i.e. the internal `Headers.map`).\n headers: headers_polyfill_1.flattenHeadersObject(mockedResponse.headers || {}) }));\n // Set the \"response.url\" property to equal the intercepted request URL.\n Object.defineProperty(response, 'url', {\n writable: false,\n enumerable: true,\n configurable: false,\n value: interactiveIsomorphicRequest.url.href,\n });\n return [2 /*return*/, response];\n }\n this.log('no mocked response received!');\n return [2 /*return*/, pureFetch(request).then(function (response) { return __awaiter(_this, void 0, void 0, function () {\n var cloneResponse, _a, _b, _c;\n return __generator(this, function (_d) {\n switch (_d.label) {\n case 0:\n cloneResponse = response.clone();\n this.log('original fetch performed', cloneResponse);\n _b = (_a = this.emitter).emit;\n _c = ['response',\n interactiveIsomorphicRequest];\n return [4 /*yield*/, normalizeFetchResponse(cloneResponse)];\n case 1:\n _b.apply(_a, _c.concat([_d.sent()]));\n return [2 /*return*/, response];\n }\n });\n }); })];\n }\n });\n }); };\n Object.defineProperty(globalThis.fetch, glossary_1.IS_PATCHED_MODULE, {\n enumerable: true,\n configurable: true,\n value: true,\n });\n this.subscriptions.push(function () {\n Object.defineProperty(globalThis.fetch, glossary_1.IS_PATCHED_MODULE, {\n value: undefined,\n });\n globalThis.fetch = pureFetch;\n _this.log('restored native \"globalThis.fetch\"!', globalThis.fetch.name);\n });\n };\n FetchInterceptor.symbol = Symbol('fetch');\n return FetchInterceptor;\n}(Interceptor_1.Interceptor));\nexports.FetchInterceptor = FetchInterceptor;\nfunction normalizeFetchResponse(response) {\n return __awaiter(this, void 0, void 0, function () {\n var _a;\n return __generator(this, function (_b) {\n switch (_b.label) {\n case 0:\n _a = {\n status: response.status,\n statusText: response.statusText,\n headers: headers_polyfill_1.objectToHeaders(headers_polyfill_1.headersToObject(response.headers))\n };\n return [4 /*yield*/, response.text()];\n case 1: return [2 /*return*/, (_a.body = _b.sent(),\n _a)];\n }\n });\n });\n}\n//# sourceMappingURL=index.js.map","'use strict'\n\n/**\n * Ponyfill for `Array.prototype.find` which is only available in ES6 runtimes.\n *\n * Works with anything that has a `length` property and index access properties, including NodeList.\n *\n * @template {unknown} T\n * @param {Array | ({length:number, [number]: T})} list\n * @param {function (item: T, index: number, list:Array | ({length:number, [number]: T})):boolean} predicate\n * @param {Partial>?} ac `Array.prototype` by default,\n * \t\t\t\tallows injecting a custom implementation in tests\n * @returns {T | undefined}\n *\n * @see https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/find\n * @see https://tc39.es/ecma262/multipage/indexed-collections.html#sec-array.prototype.find\n */\nfunction find(list, predicate, ac) {\n\tif (ac === undefined) {\n\t\tac = Array.prototype;\n\t}\n\tif (list && typeof ac.find === 'function') {\n\t\treturn ac.find.call(list, predicate);\n\t}\n\tfor (var i = 0; i < list.length; i++) {\n\t\tif (Object.prototype.hasOwnProperty.call(list, i)) {\n\t\t\tvar item = list[i];\n\t\t\tif (predicate.call(undefined, item, i, list)) {\n\t\t\t\treturn item;\n\t\t\t}\n\t\t}\n\t}\n}\n\n/**\n * \"Shallow freezes\" an object to render it immutable.\n * Uses `Object.freeze` if available,\n * otherwise the immutability is only in the type.\n *\n * Is used to create \"enum like\" objects.\n *\n * @template T\n * @param {T} object the object to freeze\n * @param {Pick = Object} oc `Object` by default,\n * \t\t\t\tallows to inject custom object constructor for tests\n * @returns {Readonly}\n *\n * @see https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/freeze\n */\nfunction freeze(object, oc) {\n\tif (oc === undefined) {\n\t\toc = Object\n\t}\n\treturn oc && typeof oc.freeze === 'function' ? oc.freeze(object) : object\n}\n\n/**\n * Since we can not rely on `Object.assign` we provide a simplified version\n * that is sufficient for our needs.\n *\n * @param {Object} target\n * @param {Object | null | undefined} source\n *\n * @returns {Object} target\n * @throws TypeError if target is not an object\n *\n * @see https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/assign\n * @see https://tc39.es/ecma262/multipage/fundamental-objects.html#sec-object.assign\n */\nfunction assign(target, source) {\n\tif (target === null || typeof target !== 'object') {\n\t\tthrow new TypeError('target is not an object')\n\t}\n\tfor (var key in source) {\n\t\tif (Object.prototype.hasOwnProperty.call(source, key)) {\n\t\t\ttarget[key] = source[key]\n\t\t}\n\t}\n\treturn target\n}\n\n/**\n * All mime types that are allowed as input to `DOMParser.parseFromString`\n *\n * @see https://developer.mozilla.org/en-US/docs/Web/API/DOMParser/parseFromString#Argument02 MDN\n * @see https://html.spec.whatwg.org/multipage/dynamic-markup-insertion.html#domparsersupportedtype WHATWG HTML Spec\n * @see DOMParser.prototype.parseFromString\n */\nvar MIME_TYPE = freeze({\n\t/**\n\t * `text/html`, the only mime type that triggers treating an XML document as HTML.\n\t *\n\t * @see DOMParser.SupportedType.isHTML\n\t * @see https://www.iana.org/assignments/media-types/text/html IANA MimeType registration\n\t * @see https://en.wikipedia.org/wiki/HTML Wikipedia\n\t * @see https://developer.mozilla.org/en-US/docs/Web/API/DOMParser/parseFromString MDN\n\t * @see https://html.spec.whatwg.org/multipage/dynamic-markup-insertion.html#dom-domparser-parsefromstring WHATWG HTML Spec\n\t */\n\tHTML: 'text/html',\n\n\t/**\n\t * Helper method to check a mime type if it indicates an HTML document\n\t *\n\t * @param {string} [value]\n\t * @returns {boolean}\n\t *\n\t * @see https://www.iana.org/assignments/media-types/text/html IANA MimeType registration\n\t * @see https://en.wikipedia.org/wiki/HTML Wikipedia\n\t * @see https://developer.mozilla.org/en-US/docs/Web/API/DOMParser/parseFromString MDN\n\t * @see https://html.spec.whatwg.org/multipage/dynamic-markup-insertion.html#dom-domparser-parsefromstring \t */\n\tisHTML: function (value) {\n\t\treturn value === MIME_TYPE.HTML\n\t},\n\n\t/**\n\t * `application/xml`, the standard mime type for XML documents.\n\t *\n\t * @see https://www.iana.org/assignments/media-types/application/xml IANA MimeType registration\n\t * @see https://tools.ietf.org/html/rfc7303#section-9.1 RFC 7303\n\t * @see https://en.wikipedia.org/wiki/XML_and_MIME Wikipedia\n\t */\n\tXML_APPLICATION: 'application/xml',\n\n\t/**\n\t * `text/html`, an alias for `application/xml`.\n\t *\n\t * @see https://tools.ietf.org/html/rfc7303#section-9.2 RFC 7303\n\t * @see https://www.iana.org/assignments/media-types/text/xml IANA MimeType registration\n\t * @see https://en.wikipedia.org/wiki/XML_and_MIME Wikipedia\n\t */\n\tXML_TEXT: 'text/xml',\n\n\t/**\n\t * `application/xhtml+xml`, indicates an XML document that has the default HTML namespace,\n\t * but is parsed as an XML document.\n\t *\n\t * @see https://www.iana.org/assignments/media-types/application/xhtml+xml IANA MimeType registration\n\t * @see https://dom.spec.whatwg.org/#dom-domimplementation-createdocument WHATWG DOM Spec\n\t * @see https://en.wikipedia.org/wiki/XHTML Wikipedia\n\t */\n\tXML_XHTML_APPLICATION: 'application/xhtml+xml',\n\n\t/**\n\t * `image/svg+xml`,\n\t *\n\t * @see https://www.iana.org/assignments/media-types/image/svg+xml IANA MimeType registration\n\t * @see https://www.w3.org/TR/SVG11/ W3C SVG 1.1\n\t * @see https://en.wikipedia.org/wiki/Scalable_Vector_Graphics Wikipedia\n\t */\n\tXML_SVG_IMAGE: 'image/svg+xml',\n})\n\n/**\n * Namespaces that are used in this code base.\n *\n * @see http://www.w3.org/TR/REC-xml-names\n */\nvar NAMESPACE = freeze({\n\t/**\n\t * The XHTML namespace.\n\t *\n\t * @see http://www.w3.org/1999/xhtml\n\t */\n\tHTML: 'http://www.w3.org/1999/xhtml',\n\n\t/**\n\t * Checks if `uri` equals `NAMESPACE.HTML`.\n\t *\n\t * @param {string} [uri]\n\t *\n\t * @see NAMESPACE.HTML\n\t */\n\tisHTML: function (uri) {\n\t\treturn uri === NAMESPACE.HTML\n\t},\n\n\t/**\n\t * The SVG namespace.\n\t *\n\t * @see http://www.w3.org/2000/svg\n\t */\n\tSVG: 'http://www.w3.org/2000/svg',\n\n\t/**\n\t * The `xml:` namespace.\n\t *\n\t * @see http://www.w3.org/XML/1998/namespace\n\t */\n\tXML: 'http://www.w3.org/XML/1998/namespace',\n\n\t/**\n\t * The `xmlns:` namespace\n\t *\n\t * @see https://www.w3.org/2000/xmlns/\n\t */\n\tXMLNS: 'http://www.w3.org/2000/xmlns/',\n})\n\nexports.assign = assign;\nexports.find = find;\nexports.freeze = freeze;\nexports.MIME_TYPE = MIME_TYPE;\nexports.NAMESPACE = NAMESPACE;\n","var conventions = require(\"./conventions\");\n\nvar find = conventions.find;\nvar NAMESPACE = conventions.NAMESPACE;\n\n/**\n * A prerequisite for `[].filter`, to drop elements that are empty\n * @param {string} input\n * @returns {boolean}\n */\nfunction notEmptyString (input) {\n\treturn input !== ''\n}\n/**\n * @see https://infra.spec.whatwg.org/#split-on-ascii-whitespace\n * @see https://infra.spec.whatwg.org/#ascii-whitespace\n *\n * @param {string} input\n * @returns {string[]} (can be empty)\n */\nfunction splitOnASCIIWhitespace(input) {\n\t// U+0009 TAB, U+000A LF, U+000C FF, U+000D CR, U+0020 SPACE\n\treturn input ? input.split(/[\\t\\n\\f\\r ]+/).filter(notEmptyString) : []\n}\n\n/**\n * Adds element as a key to current if it is not already present.\n *\n * @param {Record} current\n * @param {string} element\n * @returns {Record}\n */\nfunction orderedSetReducer (current, element) {\n\tif (!current.hasOwnProperty(element)) {\n\t\tcurrent[element] = true;\n\t}\n\treturn current;\n}\n\n/**\n * @see https://infra.spec.whatwg.org/#ordered-set\n * @param {string} input\n * @returns {string[]}\n */\nfunction toOrderedSet(input) {\n\tif (!input) return [];\n\tvar list = splitOnASCIIWhitespace(input);\n\treturn Object.keys(list.reduce(orderedSetReducer, {}))\n}\n\n/**\n * Uses `list.indexOf` to implement something like `Array.prototype.includes`,\n * which we can not rely on being available.\n *\n * @param {any[]} list\n * @returns {function(any): boolean}\n */\nfunction arrayIncludes (list) {\n\treturn function(element) {\n\t\treturn list && list.indexOf(element) !== -1;\n\t}\n}\n\nfunction copy(src,dest){\n\tfor(var p in src){\n\t\tif (Object.prototype.hasOwnProperty.call(src, p)) {\n\t\t\tdest[p] = src[p];\n\t\t}\n\t}\n}\n\n/**\n^\\w+\\.prototype\\.([_\\w]+)\\s*=\\s*((?:.*\\{\\s*?[\\r\\n][\\s\\S]*?^})|\\S.*?(?=[;\\r\\n]));?\n^\\w+\\.prototype\\.([_\\w]+)\\s*=\\s*(\\S.*?(?=[;\\r\\n]));?\n */\nfunction _extends(Class,Super){\n\tvar pt = Class.prototype;\n\tif(!(pt instanceof Super)){\n\t\tfunction t(){};\n\t\tt.prototype = Super.prototype;\n\t\tt = new t();\n\t\tcopy(pt,t);\n\t\tClass.prototype = pt = t;\n\t}\n\tif(pt.constructor != Class){\n\t\tif(typeof Class != 'function'){\n\t\t\tconsole.error(\"unknown Class:\"+Class)\n\t\t}\n\t\tpt.constructor = Class\n\t}\n}\n\n// Node Types\nvar NodeType = {}\nvar ELEMENT_NODE = NodeType.ELEMENT_NODE = 1;\nvar ATTRIBUTE_NODE = NodeType.ATTRIBUTE_NODE = 2;\nvar TEXT_NODE = NodeType.TEXT_NODE = 3;\nvar CDATA_SECTION_NODE = NodeType.CDATA_SECTION_NODE = 4;\nvar ENTITY_REFERENCE_NODE = NodeType.ENTITY_REFERENCE_NODE = 5;\nvar ENTITY_NODE = NodeType.ENTITY_NODE = 6;\nvar PROCESSING_INSTRUCTION_NODE = NodeType.PROCESSING_INSTRUCTION_NODE = 7;\nvar COMMENT_NODE = NodeType.COMMENT_NODE = 8;\nvar DOCUMENT_NODE = NodeType.DOCUMENT_NODE = 9;\nvar DOCUMENT_TYPE_NODE = NodeType.DOCUMENT_TYPE_NODE = 10;\nvar DOCUMENT_FRAGMENT_NODE = NodeType.DOCUMENT_FRAGMENT_NODE = 11;\nvar NOTATION_NODE = NodeType.NOTATION_NODE = 12;\n\n// ExceptionCode\nvar ExceptionCode = {}\nvar ExceptionMessage = {};\nvar INDEX_SIZE_ERR = ExceptionCode.INDEX_SIZE_ERR = ((ExceptionMessage[1]=\"Index size error\"),1);\nvar DOMSTRING_SIZE_ERR = ExceptionCode.DOMSTRING_SIZE_ERR = ((ExceptionMessage[2]=\"DOMString size error\"),2);\nvar HIERARCHY_REQUEST_ERR = ExceptionCode.HIERARCHY_REQUEST_ERR = ((ExceptionMessage[3]=\"Hierarchy request error\"),3);\nvar WRONG_DOCUMENT_ERR = ExceptionCode.WRONG_DOCUMENT_ERR = ((ExceptionMessage[4]=\"Wrong document\"),4);\nvar INVALID_CHARACTER_ERR = ExceptionCode.INVALID_CHARACTER_ERR = ((ExceptionMessage[5]=\"Invalid character\"),5);\nvar NO_DATA_ALLOWED_ERR = ExceptionCode.NO_DATA_ALLOWED_ERR = ((ExceptionMessage[6]=\"No data allowed\"),6);\nvar NO_MODIFICATION_ALLOWED_ERR = ExceptionCode.NO_MODIFICATION_ALLOWED_ERR = ((ExceptionMessage[7]=\"No modification allowed\"),7);\nvar NOT_FOUND_ERR = ExceptionCode.NOT_FOUND_ERR = ((ExceptionMessage[8]=\"Not found\"),8);\nvar NOT_SUPPORTED_ERR = ExceptionCode.NOT_SUPPORTED_ERR = ((ExceptionMessage[9]=\"Not supported\"),9);\nvar INUSE_ATTRIBUTE_ERR = ExceptionCode.INUSE_ATTRIBUTE_ERR = ((ExceptionMessage[10]=\"Attribute in use\"),10);\n//level2\nvar INVALID_STATE_ERR \t= ExceptionCode.INVALID_STATE_ERR \t= ((ExceptionMessage[11]=\"Invalid state\"),11);\nvar SYNTAX_ERR \t= ExceptionCode.SYNTAX_ERR \t= ((ExceptionMessage[12]=\"Syntax error\"),12);\nvar INVALID_MODIFICATION_ERR \t= ExceptionCode.INVALID_MODIFICATION_ERR \t= ((ExceptionMessage[13]=\"Invalid modification\"),13);\nvar NAMESPACE_ERR \t= ExceptionCode.NAMESPACE_ERR \t= ((ExceptionMessage[14]=\"Invalid namespace\"),14);\nvar INVALID_ACCESS_ERR \t= ExceptionCode.INVALID_ACCESS_ERR \t= ((ExceptionMessage[15]=\"Invalid access\"),15);\n\n/**\n * DOM Level 2\n * Object DOMException\n * @see http://www.w3.org/TR/2000/REC-DOM-Level-2-Core-20001113/ecma-script-binding.html\n * @see http://www.w3.org/TR/REC-DOM-Level-1/ecma-script-language-binding.html\n */\nfunction DOMException(code, message) {\n\tif(message instanceof Error){\n\t\tvar error = message;\n\t}else{\n\t\terror = this;\n\t\tError.call(this, ExceptionMessage[code]);\n\t\tthis.message = ExceptionMessage[code];\n\t\tif(Error.captureStackTrace) Error.captureStackTrace(this, DOMException);\n\t}\n\terror.code = code;\n\tif(message) this.message = this.message + \": \" + message;\n\treturn error;\n};\nDOMException.prototype = Error.prototype;\ncopy(ExceptionCode,DOMException)\n\n/**\n * @see http://www.w3.org/TR/2000/REC-DOM-Level-2-Core-20001113/core.html#ID-536297177\n * The NodeList interface provides the abstraction of an ordered collection of nodes, without defining or constraining how this collection is implemented. NodeList objects in the DOM are live.\n * The items in the NodeList are accessible via an integral index, starting from 0.\n */\nfunction NodeList() {\n};\nNodeList.prototype = {\n\t/**\n\t * The number of nodes in the list. The range of valid child node indices is 0 to length-1 inclusive.\n\t * @standard level1\n\t */\n\tlength:0,\n\t/**\n\t * Returns the indexth item in the collection. If index is greater than or equal to the number of nodes in the list, this returns null.\n\t * @standard level1\n\t * @param index unsigned long\n\t * Index into the collection.\n\t * @return Node\n\t * \tThe node at the indexth position in the NodeList, or null if that is not a valid index.\n\t */\n\titem: function(index) {\n\t\treturn index >= 0 && index < this.length ? this[index] : null;\n\t},\n\ttoString:function(isHTML,nodeFilter){\n\t\tfor(var buf = [], i = 0;i=0){\n\t\tvar lastIndex = list.length-1\n\t\twhile(i0 || key == 'xmlns'){\n//\t\t\treturn null;\n//\t\t}\n\t\t//console.log()\n\t\tvar i = this.length;\n\t\twhile(i--){\n\t\t\tvar attr = this[i];\n\t\t\t//console.log(attr.nodeName,key)\n\t\t\tif(attr.nodeName == key){\n\t\t\t\treturn attr;\n\t\t\t}\n\t\t}\n\t},\n\tsetNamedItem: function(attr) {\n\t\tvar el = attr.ownerElement;\n\t\tif(el && el!=this._ownerElement){\n\t\t\tthrow new DOMException(INUSE_ATTRIBUTE_ERR);\n\t\t}\n\t\tvar oldAttr = this.getNamedItem(attr.nodeName);\n\t\t_addNamedNode(this._ownerElement,this,attr,oldAttr);\n\t\treturn oldAttr;\n\t},\n\t/* returns Node */\n\tsetNamedItemNS: function(attr) {// raises: WRONG_DOCUMENT_ERR,NO_MODIFICATION_ALLOWED_ERR,INUSE_ATTRIBUTE_ERR\n\t\tvar el = attr.ownerElement, oldAttr;\n\t\tif(el && el!=this._ownerElement){\n\t\t\tthrow new DOMException(INUSE_ATTRIBUTE_ERR);\n\t\t}\n\t\toldAttr = this.getNamedItemNS(attr.namespaceURI,attr.localName);\n\t\t_addNamedNode(this._ownerElement,this,attr,oldAttr);\n\t\treturn oldAttr;\n\t},\n\n\t/* returns Node */\n\tremoveNamedItem: function(key) {\n\t\tvar attr = this.getNamedItem(key);\n\t\t_removeNamedNode(this._ownerElement,this,attr);\n\t\treturn attr;\n\n\n\t},// raises: NOT_FOUND_ERR,NO_MODIFICATION_ALLOWED_ERR\n\n\t//for level2\n\tremoveNamedItemNS:function(namespaceURI,localName){\n\t\tvar attr = this.getNamedItemNS(namespaceURI,localName);\n\t\t_removeNamedNode(this._ownerElement,this,attr);\n\t\treturn attr;\n\t},\n\tgetNamedItemNS: function(namespaceURI, localName) {\n\t\tvar i = this.length;\n\t\twhile(i--){\n\t\t\tvar node = this[i];\n\t\t\tif(node.localName == localName && node.namespaceURI == namespaceURI){\n\t\t\t\treturn node;\n\t\t\t}\n\t\t}\n\t\treturn null;\n\t}\n};\n\n/**\n * The DOMImplementation interface represents an object providing methods\n * which are not dependent on any particular document.\n * Such an object is returned by the `Document.implementation` property.\n *\n * __The individual methods describe the differences compared to the specs.__\n *\n * @constructor\n *\n * @see https://developer.mozilla.org/en-US/docs/Web/API/DOMImplementation MDN\n * @see https://www.w3.org/TR/REC-DOM-Level-1/level-one-core.html#ID-102161490 DOM Level 1 Core (Initial)\n * @see https://www.w3.org/TR/DOM-Level-2-Core/core.html#ID-102161490 DOM Level 2 Core\n * @see https://www.w3.org/TR/DOM-Level-3-Core/core.html#ID-102161490 DOM Level 3 Core\n * @see https://dom.spec.whatwg.org/#domimplementation DOM Living Standard\n */\nfunction DOMImplementation() {\n}\n\nDOMImplementation.prototype = {\n\t/**\n\t * The DOMImplementation.hasFeature() method returns a Boolean flag indicating if a given feature is supported.\n\t * The different implementations fairly diverged in what kind of features were reported.\n\t * The latest version of the spec settled to force this method to always return true, where the functionality was accurate and in use.\n\t *\n\t * @deprecated It is deprecated and modern browsers return true in all cases.\n\t *\n\t * @param {string} feature\n\t * @param {string} [version]\n\t * @returns {boolean} always true\n\t *\n\t * @see https://developer.mozilla.org/en-US/docs/Web/API/DOMImplementation/hasFeature MDN\n\t * @see https://www.w3.org/TR/REC-DOM-Level-1/level-one-core.html#ID-5CED94D7 DOM Level 1 Core\n\t * @see https://dom.spec.whatwg.org/#dom-domimplementation-hasfeature DOM Living Standard\n\t */\n\thasFeature: function(feature, version) {\n\t\t\treturn true;\n\t},\n\t/**\n\t * Creates an XML Document object of the specified type with its document element.\n\t *\n\t * __It behaves slightly different from the description in the living standard__:\n\t * - There is no interface/class `XMLDocument`, it returns a `Document` instance.\n\t * - `contentType`, `encoding`, `mode`, `origin`, `url` fields are currently not declared.\n\t * - this implementation is not validating names or qualified names\n\t * (when parsing XML strings, the SAX parser takes care of that)\n\t *\n\t * @param {string|null} namespaceURI\n\t * @param {string} qualifiedName\n\t * @param {DocumentType=null} doctype\n\t * @returns {Document}\n\t *\n\t * @see https://developer.mozilla.org/en-US/docs/Web/API/DOMImplementation/createDocument MDN\n\t * @see https://www.w3.org/TR/DOM-Level-2-Core/core.html#Level-2-Core-DOM-createDocument DOM Level 2 Core (initial)\n\t * @see https://dom.spec.whatwg.org/#dom-domimplementation-createdocument DOM Level 2 Core\n\t *\n\t * @see https://dom.spec.whatwg.org/#validate-and-extract DOM: Validate and extract\n\t * @see https://www.w3.org/TR/xml/#NT-NameStartChar XML Spec: Names\n\t * @see https://www.w3.org/TR/xml-names/#ns-qualnames XML Namespaces: Qualified names\n\t */\n\tcreateDocument: function(namespaceURI, qualifiedName, doctype){\n\t\tvar doc = new Document();\n\t\tdoc.implementation = this;\n\t\tdoc.childNodes = new NodeList();\n\t\tdoc.doctype = doctype || null;\n\t\tif (doctype){\n\t\t\tdoc.appendChild(doctype);\n\t\t}\n\t\tif (qualifiedName){\n\t\t\tvar root = doc.createElementNS(namespaceURI, qualifiedName);\n\t\t\tdoc.appendChild(root);\n\t\t}\n\t\treturn doc;\n\t},\n\t/**\n\t * Returns a doctype, with the given `qualifiedName`, `publicId`, and `systemId`.\n\t *\n\t * __This behavior is slightly different from the in the specs__:\n\t * - this implementation is not validating names or qualified names\n\t * (when parsing XML strings, the SAX parser takes care of that)\n\t *\n\t * @param {string} qualifiedName\n\t * @param {string} [publicId]\n\t * @param {string} [systemId]\n\t * @returns {DocumentType} which can either be used with `DOMImplementation.createDocument` upon document creation\n\t * \t\t\t\t or can be put into the document via methods like `Node.insertBefore()` or `Node.replaceChild()`\n\t *\n\t * @see https://developer.mozilla.org/en-US/docs/Web/API/DOMImplementation/createDocumentType MDN\n\t * @see https://www.w3.org/TR/DOM-Level-2-Core/core.html#Level-2-Core-DOM-createDocType DOM Level 2 Core\n\t * @see https://dom.spec.whatwg.org/#dom-domimplementation-createdocumenttype DOM Living Standard\n\t *\n\t * @see https://dom.spec.whatwg.org/#validate-and-extract DOM: Validate and extract\n\t * @see https://www.w3.org/TR/xml/#NT-NameStartChar XML Spec: Names\n\t * @see https://www.w3.org/TR/xml-names/#ns-qualnames XML Namespaces: Qualified names\n\t */\n\tcreateDocumentType: function(qualifiedName, publicId, systemId){\n\t\tvar node = new DocumentType();\n\t\tnode.name = qualifiedName;\n\t\tnode.nodeName = qualifiedName;\n\t\tnode.publicId = publicId || '';\n\t\tnode.systemId = systemId || '';\n\n\t\treturn node;\n\t}\n};\n\n\n/**\n * @see http://www.w3.org/TR/2000/REC-DOM-Level-2-Core-20001113/core.html#ID-1950641247\n */\n\nfunction Node() {\n};\n\nNode.prototype = {\n\tfirstChild : null,\n\tlastChild : null,\n\tpreviousSibling : null,\n\tnextSibling : null,\n\tattributes : null,\n\tparentNode : null,\n\tchildNodes : null,\n\townerDocument : null,\n\tnodeValue : null,\n\tnamespaceURI : null,\n\tprefix : null,\n\tlocalName : null,\n\t// Modified in DOM Level 2:\n\tinsertBefore:function(newChild, refChild){//raises\n\t\treturn _insertBefore(this,newChild,refChild);\n\t},\n\treplaceChild:function(newChild, oldChild){//raises\n\t\t_insertBefore(this, newChild,oldChild, assertPreReplacementValidityInDocument);\n\t\tif(oldChild){\n\t\t\tthis.removeChild(oldChild);\n\t\t}\n\t},\n\tremoveChild:function(oldChild){\n\t\treturn _removeChild(this,oldChild);\n\t},\n\tappendChild:function(newChild){\n\t\treturn this.insertBefore(newChild,null);\n\t},\n\thasChildNodes:function(){\n\t\treturn this.firstChild != null;\n\t},\n\tcloneNode:function(deep){\n\t\treturn cloneNode(this.ownerDocument||this,this,deep);\n\t},\n\t// Modified in DOM Level 2:\n\tnormalize:function(){\n\t\tvar child = this.firstChild;\n\t\twhile(child){\n\t\t\tvar next = child.nextSibling;\n\t\t\tif(next && next.nodeType == TEXT_NODE && child.nodeType == TEXT_NODE){\n\t\t\t\tthis.removeChild(next);\n\t\t\t\tchild.appendData(next.data);\n\t\t\t}else{\n\t\t\t\tchild.normalize();\n\t\t\t\tchild = next;\n\t\t\t}\n\t\t}\n\t},\n \t// Introduced in DOM Level 2:\n\tisSupported:function(feature, version){\n\t\treturn this.ownerDocument.implementation.hasFeature(feature,version);\n\t},\n // Introduced in DOM Level 2:\n hasAttributes:function(){\n \treturn this.attributes.length>0;\n },\n\t/**\n\t * Look up the prefix associated to the given namespace URI, starting from this node.\n\t * **The default namespace declarations are ignored by this method.**\n\t * See Namespace Prefix Lookup for details on the algorithm used by this method.\n\t *\n\t * _Note: The implementation seems to be incomplete when compared to the algorithm described in the specs._\n\t *\n\t * @param {string | null} namespaceURI\n\t * @returns {string | null}\n\t * @see https://www.w3.org/TR/DOM-Level-3-Core/core.html#Node3-lookupNamespacePrefix\n\t * @see https://www.w3.org/TR/DOM-Level-3-Core/namespaces-algorithms.html#lookupNamespacePrefixAlgo\n\t * @see https://dom.spec.whatwg.org/#dom-node-lookupprefix\n\t * @see https://github.com/xmldom/xmldom/issues/322\n\t */\n lookupPrefix:function(namespaceURI){\n \tvar el = this;\n \twhile(el){\n \t\tvar map = el._nsMap;\n \t\t//console.dir(map)\n \t\tif(map){\n \t\t\tfor(var n in map){\n\t\t\t\t\t\tif (Object.prototype.hasOwnProperty.call(map, n) && map[n] === namespaceURI) {\n\t\t\t\t\t\t\treturn n;\n\t\t\t\t\t\t}\n \t\t\t}\n \t\t}\n \t\tel = el.nodeType == ATTRIBUTE_NODE?el.ownerDocument : el.parentNode;\n \t}\n \treturn null;\n },\n // Introduced in DOM Level 3:\n lookupNamespaceURI:function(prefix){\n \tvar el = this;\n \twhile(el){\n \t\tvar map = el._nsMap;\n \t\t//console.dir(map)\n \t\tif(map){\n \t\t\tif(Object.prototype.hasOwnProperty.call(map, prefix)){\n \t\t\t\treturn map[prefix] ;\n \t\t\t}\n \t\t}\n \t\tel = el.nodeType == ATTRIBUTE_NODE?el.ownerDocument : el.parentNode;\n \t}\n \treturn null;\n },\n // Introduced in DOM Level 3:\n isDefaultNamespace:function(namespaceURI){\n \tvar prefix = this.lookupPrefix(namespaceURI);\n \treturn prefix == null;\n }\n};\n\n\nfunction _xmlEncoder(c){\n\treturn c == '<' && '<' ||\n c == '>' && '>' ||\n c == '&' && '&' ||\n c == '\"' && '"' ||\n ''+c.charCodeAt()+';'\n}\n\n\ncopy(NodeType,Node);\ncopy(NodeType,Node.prototype);\n\n/**\n * @param callback return true for continue,false for break\n * @return boolean true: break visit;\n */\nfunction _visitNode(node,callback){\n\tif(callback(node)){\n\t\treturn true;\n\t}\n\tif(node = node.firstChild){\n\t\tdo{\n\t\t\tif(_visitNode(node,callback)){return true}\n }while(node=node.nextSibling)\n }\n}\n\n\n\nfunction Document(){\n\tthis.ownerDocument = this;\n}\n\nfunction _onAddAttribute(doc,el,newAttr){\n\tdoc && doc._inc++;\n\tvar ns = newAttr.namespaceURI ;\n\tif(ns === NAMESPACE.XMLNS){\n\t\t//update namespace\n\t\tel._nsMap[newAttr.prefix?newAttr.localName:''] = newAttr.value\n\t}\n}\n\nfunction _onRemoveAttribute(doc,el,newAttr,remove){\n\tdoc && doc._inc++;\n\tvar ns = newAttr.namespaceURI ;\n\tif(ns === NAMESPACE.XMLNS){\n\t\t//update namespace\n\t\tdelete el._nsMap[newAttr.prefix?newAttr.localName:'']\n\t}\n}\n\n/**\n * Updates `el.childNodes`, updating the indexed items and it's `length`.\n * Passing `newChild` means it will be appended.\n * Otherwise it's assumed that an item has been removed,\n * and `el.firstNode` and it's `.nextSibling` are used\n * to walk the current list of child nodes.\n *\n * @param {Document} doc\n * @param {Node} el\n * @param {Node} [newChild]\n * @private\n */\nfunction _onUpdateChild (doc, el, newChild) {\n\tif(doc && doc._inc){\n\t\tdoc._inc++;\n\t\t//update childNodes\n\t\tvar cs = el.childNodes;\n\t\tif (newChild) {\n\t\t\tcs[cs.length++] = newChild;\n\t\t} else {\n\t\t\tvar child = el.firstChild;\n\t\t\tvar i = 0;\n\t\t\twhile (child) {\n\t\t\t\tcs[i++] = child;\n\t\t\t\tchild = child.nextSibling;\n\t\t\t}\n\t\t\tcs.length = i;\n\t\t\tdelete cs[cs.length];\n\t\t}\n\t}\n}\n\n/**\n * Removes the connections between `parentNode` and `child`\n * and any existing `child.previousSibling` or `child.nextSibling`.\n *\n * @see https://github.com/xmldom/xmldom/issues/135\n * @see https://github.com/xmldom/xmldom/issues/145\n *\n * @param {Node} parentNode\n * @param {Node} child\n * @returns {Node} the child that was removed.\n * @private\n */\nfunction _removeChild (parentNode, child) {\n\tvar previous = child.previousSibling;\n\tvar next = child.nextSibling;\n\tif (previous) {\n\t\tprevious.nextSibling = next;\n\t} else {\n\t\tparentNode.firstChild = next;\n\t}\n\tif (next) {\n\t\tnext.previousSibling = previous;\n\t} else {\n\t\tparentNode.lastChild = previous;\n\t}\n\tchild.parentNode = null;\n\tchild.previousSibling = null;\n\tchild.nextSibling = null;\n\t_onUpdateChild(parentNode.ownerDocument, parentNode);\n\treturn child;\n}\n\n/**\n * Returns `true` if `node` can be a parent for insertion.\n * @param {Node} node\n * @returns {boolean}\n */\nfunction hasValidParentNodeType(node) {\n\treturn (\n\t\tnode &&\n\t\t(node.nodeType === Node.DOCUMENT_NODE || node.nodeType === Node.DOCUMENT_FRAGMENT_NODE || node.nodeType === Node.ELEMENT_NODE)\n\t);\n}\n\n/**\n * Returns `true` if `node` can be inserted according to it's `nodeType`.\n * @param {Node} node\n * @returns {boolean}\n */\nfunction hasInsertableNodeType(node) {\n\treturn (\n\t\tnode &&\n\t\t(isElementNode(node) ||\n\t\t\tisTextNode(node) ||\n\t\t\tisDocTypeNode(node) ||\n\t\t\tnode.nodeType === Node.DOCUMENT_FRAGMENT_NODE ||\n\t\t\tnode.nodeType === Node.COMMENT_NODE ||\n\t\t\tnode.nodeType === Node.PROCESSING_INSTRUCTION_NODE)\n\t);\n}\n\n/**\n * Returns true if `node` is a DOCTYPE node\n * @param {Node} node\n * @returns {boolean}\n */\nfunction isDocTypeNode(node) {\n\treturn node && node.nodeType === Node.DOCUMENT_TYPE_NODE;\n}\n\n/**\n * Returns true if the node is an element\n * @param {Node} node\n * @returns {boolean}\n */\nfunction isElementNode(node) {\n\treturn node && node.nodeType === Node.ELEMENT_NODE;\n}\n/**\n * Returns true if `node` is a text node\n * @param {Node} node\n * @returns {boolean}\n */\nfunction isTextNode(node) {\n\treturn node && node.nodeType === Node.TEXT_NODE;\n}\n\n/**\n * Check if en element node can be inserted before `child`, or at the end if child is falsy,\n * according to the presence and position of a doctype node on the same level.\n *\n * @param {Document} doc The document node\n * @param {Node} child the node that would become the nextSibling if the element would be inserted\n * @returns {boolean} `true` if an element can be inserted before child\n * @private\n * https://dom.spec.whatwg.org/#concept-node-ensure-pre-insertion-validity\n */\nfunction isElementInsertionPossible(doc, child) {\n\tvar parentChildNodes = doc.childNodes || [];\n\tif (find(parentChildNodes, isElementNode) || isDocTypeNode(child)) {\n\t\treturn false;\n\t}\n\tvar docTypeNode = find(parentChildNodes, isDocTypeNode);\n\treturn !(child && docTypeNode && parentChildNodes.indexOf(docTypeNode) > parentChildNodes.indexOf(child));\n}\n\n/**\n * Check if en element node can be inserted before `child`, or at the end if child is falsy,\n * according to the presence and position of a doctype node on the same level.\n *\n * @param {Node} doc The document node\n * @param {Node} child the node that would become the nextSibling if the element would be inserted\n * @returns {boolean} `true` if an element can be inserted before child\n * @private\n * https://dom.spec.whatwg.org/#concept-node-ensure-pre-insertion-validity\n */\nfunction isElementReplacementPossible(doc, child) {\n\tvar parentChildNodes = doc.childNodes || [];\n\n\tfunction hasElementChildThatIsNotChild(node) {\n\t\treturn isElementNode(node) && node !== child;\n\t}\n\n\tif (find(parentChildNodes, hasElementChildThatIsNotChild)) {\n\t\treturn false;\n\t}\n\tvar docTypeNode = find(parentChildNodes, isDocTypeNode);\n\treturn !(child && docTypeNode && parentChildNodes.indexOf(docTypeNode) > parentChildNodes.indexOf(child));\n}\n\n/**\n * @private\n * Steps 1-5 of the checks before inserting and before replacing a child are the same.\n *\n * @param {Node} parent the parent node to insert `node` into\n * @param {Node} node the node to insert\n * @param {Node=} child the node that should become the `nextSibling` of `node`\n * @returns {Node}\n * @throws DOMException for several node combinations that would create a DOM that is not well-formed.\n * @throws DOMException if `child` is provided but is not a child of `parent`.\n * @see https://dom.spec.whatwg.org/#concept-node-ensure-pre-insertion-validity\n * @see https://dom.spec.whatwg.org/#concept-node-replace\n */\nfunction assertPreInsertionValidity1to5(parent, node, child) {\n\t// 1. If `parent` is not a Document, DocumentFragment, or Element node, then throw a \"HierarchyRequestError\" DOMException.\n\tif (!hasValidParentNodeType(parent)) {\n\t\tthrow new DOMException(HIERARCHY_REQUEST_ERR, 'Unexpected parent node type ' + parent.nodeType);\n\t}\n\t// 2. If `node` is a host-including inclusive ancestor of `parent`, then throw a \"HierarchyRequestError\" DOMException.\n\t// not implemented!\n\t// 3. If `child` is non-null and its parent is not `parent`, then throw a \"NotFoundError\" DOMException.\n\tif (child && child.parentNode !== parent) {\n\t\tthrow new DOMException(NOT_FOUND_ERR, 'child not in parent');\n\t}\n\tif (\n\t\t// 4. If `node` is not a DocumentFragment, DocumentType, Element, or CharacterData node, then throw a \"HierarchyRequestError\" DOMException.\n\t\t!hasInsertableNodeType(node) ||\n\t\t// 5. If either `node` is a Text node and `parent` is a document,\n\t\t// the sax parser currently adds top level text nodes, this will be fixed in 0.9.0\n\t\t// || (node.nodeType === Node.TEXT_NODE && parent.nodeType === Node.DOCUMENT_NODE)\n\t\t// or `node` is a doctype and `parent` is not a document, then throw a \"HierarchyRequestError\" DOMException.\n\t\t(isDocTypeNode(node) && parent.nodeType !== Node.DOCUMENT_NODE)\n\t) {\n\t\tthrow new DOMException(\n\t\t\tHIERARCHY_REQUEST_ERR,\n\t\t\t'Unexpected node type ' + node.nodeType + ' for parent node type ' + parent.nodeType\n\t\t);\n\t}\n}\n\n/**\n * @private\n * Step 6 of the checks before inserting and before replacing a child are different.\n *\n * @param {Document} parent the parent node to insert `node` into\n * @param {Node} node the node to insert\n * @param {Node | undefined} child the node that should become the `nextSibling` of `node`\n * @returns {Node}\n * @throws DOMException for several node combinations that would create a DOM that is not well-formed.\n * @throws DOMException if `child` is provided but is not a child of `parent`.\n * @see https://dom.spec.whatwg.org/#concept-node-ensure-pre-insertion-validity\n * @see https://dom.spec.whatwg.org/#concept-node-replace\n */\nfunction assertPreInsertionValidityInDocument(parent, node, child) {\n\tvar parentChildNodes = parent.childNodes || [];\n\tvar nodeChildNodes = node.childNodes || [];\n\n\t// DocumentFragment\n\tif (node.nodeType === Node.DOCUMENT_FRAGMENT_NODE) {\n\t\tvar nodeChildElements = nodeChildNodes.filter(isElementNode);\n\t\t// If node has more than one element child or has a Text node child.\n\t\tif (nodeChildElements.length > 1 || find(nodeChildNodes, isTextNode)) {\n\t\t\tthrow new DOMException(HIERARCHY_REQUEST_ERR, 'More than one element or text in fragment');\n\t\t}\n\t\t// Otherwise, if `node` has one element child and either `parent` has an element child,\n\t\t// `child` is a doctype, or `child` is non-null and a doctype is following `child`.\n\t\tif (nodeChildElements.length === 1 && !isElementInsertionPossible(parent, child)) {\n\t\t\tthrow new DOMException(HIERARCHY_REQUEST_ERR, 'Element in fragment can not be inserted before doctype');\n\t\t}\n\t}\n\t// Element\n\tif (isElementNode(node)) {\n\t\t// `parent` has an element child, `child` is a doctype,\n\t\t// or `child` is non-null and a doctype is following `child`.\n\t\tif (!isElementInsertionPossible(parent, child)) {\n\t\t\tthrow new DOMException(HIERARCHY_REQUEST_ERR, 'Only one element can be added and only after doctype');\n\t\t}\n\t}\n\t// DocumentType\n\tif (isDocTypeNode(node)) {\n\t\t// `parent` has a doctype child,\n\t\tif (find(parentChildNodes, isDocTypeNode)) {\n\t\t\tthrow new DOMException(HIERARCHY_REQUEST_ERR, 'Only one doctype is allowed');\n\t\t}\n\t\tvar parentElementChild = find(parentChildNodes, isElementNode);\n\t\t// `child` is non-null and an element is preceding `child`,\n\t\tif (child && parentChildNodes.indexOf(parentElementChild) < parentChildNodes.indexOf(child)) {\n\t\t\tthrow new DOMException(HIERARCHY_REQUEST_ERR, 'Doctype can only be inserted before an element');\n\t\t}\n\t\t// or `child` is null and `parent` has an element child.\n\t\tif (!child && parentElementChild) {\n\t\t\tthrow new DOMException(HIERARCHY_REQUEST_ERR, 'Doctype can not be appended since element is present');\n\t\t}\n\t}\n}\n\n/**\n * @private\n * Step 6 of the checks before inserting and before replacing a child are different.\n *\n * @param {Document} parent the parent node to insert `node` into\n * @param {Node} node the node to insert\n * @param {Node | undefined} child the node that should become the `nextSibling` of `node`\n * @returns {Node}\n * @throws DOMException for several node combinations that would create a DOM that is not well-formed.\n * @throws DOMException if `child` is provided but is not a child of `parent`.\n * @see https://dom.spec.whatwg.org/#concept-node-ensure-pre-insertion-validity\n * @see https://dom.spec.whatwg.org/#concept-node-replace\n */\nfunction assertPreReplacementValidityInDocument(parent, node, child) {\n\tvar parentChildNodes = parent.childNodes || [];\n\tvar nodeChildNodes = node.childNodes || [];\n\n\t// DocumentFragment\n\tif (node.nodeType === Node.DOCUMENT_FRAGMENT_NODE) {\n\t\tvar nodeChildElements = nodeChildNodes.filter(isElementNode);\n\t\t// If `node` has more than one element child or has a Text node child.\n\t\tif (nodeChildElements.length > 1 || find(nodeChildNodes, isTextNode)) {\n\t\t\tthrow new DOMException(HIERARCHY_REQUEST_ERR, 'More than one element or text in fragment');\n\t\t}\n\t\t// Otherwise, if `node` has one element child and either `parent` has an element child that is not `child` or a doctype is following `child`.\n\t\tif (nodeChildElements.length === 1 && !isElementReplacementPossible(parent, child)) {\n\t\t\tthrow new DOMException(HIERARCHY_REQUEST_ERR, 'Element in fragment can not be inserted before doctype');\n\t\t}\n\t}\n\t// Element\n\tif (isElementNode(node)) {\n\t\t// `parent` has an element child that is not `child` or a doctype is following `child`.\n\t\tif (!isElementReplacementPossible(parent, child)) {\n\t\t\tthrow new DOMException(HIERARCHY_REQUEST_ERR, 'Only one element can be added and only after doctype');\n\t\t}\n\t}\n\t// DocumentType\n\tif (isDocTypeNode(node)) {\n\t\tfunction hasDoctypeChildThatIsNotChild(node) {\n\t\t\treturn isDocTypeNode(node) && node !== child;\n\t\t}\n\n\t\t// `parent` has a doctype child that is not `child`,\n\t\tif (find(parentChildNodes, hasDoctypeChildThatIsNotChild)) {\n\t\t\tthrow new DOMException(HIERARCHY_REQUEST_ERR, 'Only one doctype is allowed');\n\t\t}\n\t\tvar parentElementChild = find(parentChildNodes, isElementNode);\n\t\t// or an element is preceding `child`.\n\t\tif (child && parentChildNodes.indexOf(parentElementChild) < parentChildNodes.indexOf(child)) {\n\t\t\tthrow new DOMException(HIERARCHY_REQUEST_ERR, 'Doctype can only be inserted before an element');\n\t\t}\n\t}\n}\n\n/**\n * @private\n * @param {Node} parent the parent node to insert `node` into\n * @param {Node} node the node to insert\n * @param {Node=} child the node that should become the `nextSibling` of `node`\n * @returns {Node}\n * @throws DOMException for several node combinations that would create a DOM that is not well-formed.\n * @throws DOMException if `child` is provided but is not a child of `parent`.\n * @see https://dom.spec.whatwg.org/#concept-node-ensure-pre-insertion-validity\n */\nfunction _insertBefore(parent, node, child, _inDocumentAssertion) {\n\t// To ensure pre-insertion validity of a node into a parent before a child, run these steps:\n\tassertPreInsertionValidity1to5(parent, node, child);\n\n\t// If parent is a document, and any of the statements below, switched on the interface node implements,\n\t// are true, then throw a \"HierarchyRequestError\" DOMException.\n\tif (parent.nodeType === Node.DOCUMENT_NODE) {\n\t\t(_inDocumentAssertion || assertPreInsertionValidityInDocument)(parent, node, child);\n\t}\n\n\tvar cp = node.parentNode;\n\tif(cp){\n\t\tcp.removeChild(node);//remove and update\n\t}\n\tif(node.nodeType === DOCUMENT_FRAGMENT_NODE){\n\t\tvar newFirst = node.firstChild;\n\t\tif (newFirst == null) {\n\t\t\treturn node;\n\t\t}\n\t\tvar newLast = node.lastChild;\n\t}else{\n\t\tnewFirst = newLast = node;\n\t}\n\tvar pre = child ? child.previousSibling : parent.lastChild;\n\n\tnewFirst.previousSibling = pre;\n\tnewLast.nextSibling = child;\n\n\n\tif(pre){\n\t\tpre.nextSibling = newFirst;\n\t}else{\n\t\tparent.firstChild = newFirst;\n\t}\n\tif(child == null){\n\t\tparent.lastChild = newLast;\n\t}else{\n\t\tchild.previousSibling = newLast;\n\t}\n\tdo{\n\t\tnewFirst.parentNode = parent;\n\t}while(newFirst !== newLast && (newFirst= newFirst.nextSibling))\n\t_onUpdateChild(parent.ownerDocument||parent, parent);\n\t//console.log(parent.lastChild.nextSibling == null)\n\tif (node.nodeType == DOCUMENT_FRAGMENT_NODE) {\n\t\tnode.firstChild = node.lastChild = null;\n\t}\n\treturn node;\n}\n\n/**\n * Appends `newChild` to `parentNode`.\n * If `newChild` is already connected to a `parentNode` it is first removed from it.\n *\n * @see https://github.com/xmldom/xmldom/issues/135\n * @see https://github.com/xmldom/xmldom/issues/145\n * @param {Node} parentNode\n * @param {Node} newChild\n * @returns {Node}\n * @private\n */\nfunction _appendSingleChild (parentNode, newChild) {\n\tif (newChild.parentNode) {\n\t\tnewChild.parentNode.removeChild(newChild);\n\t}\n\tnewChild.parentNode = parentNode;\n\tnewChild.previousSibling = parentNode.lastChild;\n\tnewChild.nextSibling = null;\n\tif (newChild.previousSibling) {\n\t\tnewChild.previousSibling.nextSibling = newChild;\n\t} else {\n\t\tparentNode.firstChild = newChild;\n\t}\n\tparentNode.lastChild = newChild;\n\t_onUpdateChild(parentNode.ownerDocument, parentNode, newChild);\n\treturn newChild;\n}\n\nDocument.prototype = {\n\t//implementation : null,\n\tnodeName : '#document',\n\tnodeType : DOCUMENT_NODE,\n\t/**\n\t * The DocumentType node of the document.\n\t *\n\t * @readonly\n\t * @type DocumentType\n\t */\n\tdoctype : null,\n\tdocumentElement : null,\n\t_inc : 1,\n\n\tinsertBefore : function(newChild, refChild){//raises\n\t\tif(newChild.nodeType == DOCUMENT_FRAGMENT_NODE){\n\t\t\tvar child = newChild.firstChild;\n\t\t\twhile(child){\n\t\t\t\tvar next = child.nextSibling;\n\t\t\t\tthis.insertBefore(child,refChild);\n\t\t\t\tchild = next;\n\t\t\t}\n\t\t\treturn newChild;\n\t\t}\n\t\t_insertBefore(this, newChild, refChild);\n\t\tnewChild.ownerDocument = this;\n\t\tif (this.documentElement === null && newChild.nodeType === ELEMENT_NODE) {\n\t\t\tthis.documentElement = newChild;\n\t\t}\n\n\t\treturn newChild;\n\t},\n\tremoveChild : function(oldChild){\n\t\tif(this.documentElement == oldChild){\n\t\t\tthis.documentElement = null;\n\t\t}\n\t\treturn _removeChild(this,oldChild);\n\t},\n\treplaceChild: function (newChild, oldChild) {\n\t\t//raises\n\t\t_insertBefore(this, newChild, oldChild, assertPreReplacementValidityInDocument);\n\t\tnewChild.ownerDocument = this;\n\t\tif (oldChild) {\n\t\t\tthis.removeChild(oldChild);\n\t\t}\n\t\tif (isElementNode(newChild)) {\n\t\t\tthis.documentElement = newChild;\n\t\t}\n\t},\n\t// Introduced in DOM Level 2:\n\timportNode : function(importedNode,deep){\n\t\treturn importNode(this,importedNode,deep);\n\t},\n\t// Introduced in DOM Level 2:\n\tgetElementById :\tfunction(id){\n\t\tvar rtv = null;\n\t\t_visitNode(this.documentElement,function(node){\n\t\t\tif(node.nodeType == ELEMENT_NODE){\n\t\t\t\tif(node.getAttribute('id') == id){\n\t\t\t\t\trtv = node;\n\t\t\t\t\treturn true;\n\t\t\t\t}\n\t\t\t}\n\t\t})\n\t\treturn rtv;\n\t},\n\n\t/**\n\t * The `getElementsByClassName` method of `Document` interface returns an array-like object\n\t * of all child elements which have **all** of the given class name(s).\n\t *\n\t * Returns an empty list if `classeNames` is an empty string or only contains HTML white space characters.\n\t *\n\t *\n\t * Warning: This is a live LiveNodeList.\n\t * Changes in the DOM will reflect in the array as the changes occur.\n\t * If an element selected by this array no longer qualifies for the selector,\n\t * it will automatically be removed. Be aware of this for iteration purposes.\n\t *\n\t * @param {string} classNames is a string representing the class name(s) to match; multiple class names are separated by (ASCII-)whitespace\n\t *\n\t * @see https://developer.mozilla.org/en-US/docs/Web/API/Document/getElementsByClassName\n\t * @see https://dom.spec.whatwg.org/#concept-getelementsbyclassname\n\t */\n\tgetElementsByClassName: function(classNames) {\n\t\tvar classNamesSet = toOrderedSet(classNames)\n\t\treturn new LiveNodeList(this, function(base) {\n\t\t\tvar ls = [];\n\t\t\tif (classNamesSet.length > 0) {\n\t\t\t\t_visitNode(base.documentElement, function(node) {\n\t\t\t\t\tif(node !== base && node.nodeType === ELEMENT_NODE) {\n\t\t\t\t\t\tvar nodeClassNames = node.getAttribute('class')\n\t\t\t\t\t\t// can be null if the attribute does not exist\n\t\t\t\t\t\tif (nodeClassNames) {\n\t\t\t\t\t\t\t// before splitting and iterating just compare them for the most common case\n\t\t\t\t\t\t\tvar matches = classNames === nodeClassNames;\n\t\t\t\t\t\t\tif (!matches) {\n\t\t\t\t\t\t\t\tvar nodeClassNamesSet = toOrderedSet(nodeClassNames)\n\t\t\t\t\t\t\t\tmatches = classNamesSet.every(arrayIncludes(nodeClassNamesSet))\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tif(matches) {\n\t\t\t\t\t\t\t\tls.push(node);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t}\n\t\t\treturn ls;\n\t\t});\n\t},\n\n\t//document factory method:\n\tcreateElement :\tfunction(tagName){\n\t\tvar node = new Element();\n\t\tnode.ownerDocument = this;\n\t\tnode.nodeName = tagName;\n\t\tnode.tagName = tagName;\n\t\tnode.localName = tagName;\n\t\tnode.childNodes = new NodeList();\n\t\tvar attrs\t= node.attributes = new NamedNodeMap();\n\t\tattrs._ownerElement = node;\n\t\treturn node;\n\t},\n\tcreateDocumentFragment :\tfunction(){\n\t\tvar node = new DocumentFragment();\n\t\tnode.ownerDocument = this;\n\t\tnode.childNodes = new NodeList();\n\t\treturn node;\n\t},\n\tcreateTextNode :\tfunction(data){\n\t\tvar node = new Text();\n\t\tnode.ownerDocument = this;\n\t\tnode.appendData(data)\n\t\treturn node;\n\t},\n\tcreateComment :\tfunction(data){\n\t\tvar node = new Comment();\n\t\tnode.ownerDocument = this;\n\t\tnode.appendData(data)\n\t\treturn node;\n\t},\n\tcreateCDATASection :\tfunction(data){\n\t\tvar node = new CDATASection();\n\t\tnode.ownerDocument = this;\n\t\tnode.appendData(data)\n\t\treturn node;\n\t},\n\tcreateProcessingInstruction :\tfunction(target,data){\n\t\tvar node = new ProcessingInstruction();\n\t\tnode.ownerDocument = this;\n\t\tnode.tagName = node.nodeName = node.target = target;\n\t\tnode.nodeValue = node.data = data;\n\t\treturn node;\n\t},\n\tcreateAttribute :\tfunction(name){\n\t\tvar node = new Attr();\n\t\tnode.ownerDocument\t= this;\n\t\tnode.name = name;\n\t\tnode.nodeName\t= name;\n\t\tnode.localName = name;\n\t\tnode.specified = true;\n\t\treturn node;\n\t},\n\tcreateEntityReference :\tfunction(name){\n\t\tvar node = new EntityReference();\n\t\tnode.ownerDocument\t= this;\n\t\tnode.nodeName\t= name;\n\t\treturn node;\n\t},\n\t// Introduced in DOM Level 2:\n\tcreateElementNS :\tfunction(namespaceURI,qualifiedName){\n\t\tvar node = new Element();\n\t\tvar pl = qualifiedName.split(':');\n\t\tvar attrs\t= node.attributes = new NamedNodeMap();\n\t\tnode.childNodes = new NodeList();\n\t\tnode.ownerDocument = this;\n\t\tnode.nodeName = qualifiedName;\n\t\tnode.tagName = qualifiedName;\n\t\tnode.namespaceURI = namespaceURI;\n\t\tif(pl.length == 2){\n\t\t\tnode.prefix = pl[0];\n\t\t\tnode.localName = pl[1];\n\t\t}else{\n\t\t\t//el.prefix = null;\n\t\t\tnode.localName = qualifiedName;\n\t\t}\n\t\tattrs._ownerElement = node;\n\t\treturn node;\n\t},\n\t// Introduced in DOM Level 2:\n\tcreateAttributeNS :\tfunction(namespaceURI,qualifiedName){\n\t\tvar node = new Attr();\n\t\tvar pl = qualifiedName.split(':');\n\t\tnode.ownerDocument = this;\n\t\tnode.nodeName = qualifiedName;\n\t\tnode.name = qualifiedName;\n\t\tnode.namespaceURI = namespaceURI;\n\t\tnode.specified = true;\n\t\tif(pl.length == 2){\n\t\t\tnode.prefix = pl[0];\n\t\t\tnode.localName = pl[1];\n\t\t}else{\n\t\t\t//el.prefix = null;\n\t\t\tnode.localName = qualifiedName;\n\t\t}\n\t\treturn node;\n\t}\n};\n_extends(Document,Node);\n\n\nfunction Element() {\n\tthis._nsMap = {};\n};\nElement.prototype = {\n\tnodeType : ELEMENT_NODE,\n\thasAttribute : function(name){\n\t\treturn this.getAttributeNode(name)!=null;\n\t},\n\tgetAttribute : function(name){\n\t\tvar attr = this.getAttributeNode(name);\n\t\treturn attr && attr.value || '';\n\t},\n\tgetAttributeNode : function(name){\n\t\treturn this.attributes.getNamedItem(name);\n\t},\n\tsetAttribute : function(name, value){\n\t\tvar attr = this.ownerDocument.createAttribute(name);\n\t\tattr.value = attr.nodeValue = \"\" + value;\n\t\tthis.setAttributeNode(attr)\n\t},\n\tremoveAttribute : function(name){\n\t\tvar attr = this.getAttributeNode(name)\n\t\tattr && this.removeAttributeNode(attr);\n\t},\n\n\t//four real opeartion method\n\tappendChild:function(newChild){\n\t\tif(newChild.nodeType === DOCUMENT_FRAGMENT_NODE){\n\t\t\treturn this.insertBefore(newChild,null);\n\t\t}else{\n\t\t\treturn _appendSingleChild(this,newChild);\n\t\t}\n\t},\n\tsetAttributeNode : function(newAttr){\n\t\treturn this.attributes.setNamedItem(newAttr);\n\t},\n\tsetAttributeNodeNS : function(newAttr){\n\t\treturn this.attributes.setNamedItemNS(newAttr);\n\t},\n\tremoveAttributeNode : function(oldAttr){\n\t\t//console.log(this == oldAttr.ownerElement)\n\t\treturn this.attributes.removeNamedItem(oldAttr.nodeName);\n\t},\n\t//get real attribute name,and remove it by removeAttributeNode\n\tremoveAttributeNS : function(namespaceURI, localName){\n\t\tvar old = this.getAttributeNodeNS(namespaceURI, localName);\n\t\told && this.removeAttributeNode(old);\n\t},\n\n\thasAttributeNS : function(namespaceURI, localName){\n\t\treturn this.getAttributeNodeNS(namespaceURI, localName)!=null;\n\t},\n\tgetAttributeNS : function(namespaceURI, localName){\n\t\tvar attr = this.getAttributeNodeNS(namespaceURI, localName);\n\t\treturn attr && attr.value || '';\n\t},\n\tsetAttributeNS : function(namespaceURI, qualifiedName, value){\n\t\tvar attr = this.ownerDocument.createAttributeNS(namespaceURI, qualifiedName);\n\t\tattr.value = attr.nodeValue = \"\" + value;\n\t\tthis.setAttributeNode(attr)\n\t},\n\tgetAttributeNodeNS : function(namespaceURI, localName){\n\t\treturn this.attributes.getNamedItemNS(namespaceURI, localName);\n\t},\n\n\tgetElementsByTagName : function(tagName){\n\t\treturn new LiveNodeList(this,function(base){\n\t\t\tvar ls = [];\n\t\t\t_visitNode(base,function(node){\n\t\t\t\tif(node !== base && node.nodeType == ELEMENT_NODE && (tagName === '*' || node.tagName == tagName)){\n\t\t\t\t\tls.push(node);\n\t\t\t\t}\n\t\t\t});\n\t\t\treturn ls;\n\t\t});\n\t},\n\tgetElementsByTagNameNS : function(namespaceURI, localName){\n\t\treturn new LiveNodeList(this,function(base){\n\t\t\tvar ls = [];\n\t\t\t_visitNode(base,function(node){\n\t\t\t\tif(node !== base && node.nodeType === ELEMENT_NODE && (namespaceURI === '*' || node.namespaceURI === namespaceURI) && (localName === '*' || node.localName == localName)){\n\t\t\t\t\tls.push(node);\n\t\t\t\t}\n\t\t\t});\n\t\t\treturn ls;\n\n\t\t});\n\t}\n};\nDocument.prototype.getElementsByTagName = Element.prototype.getElementsByTagName;\nDocument.prototype.getElementsByTagNameNS = Element.prototype.getElementsByTagNameNS;\n\n\n_extends(Element,Node);\nfunction Attr() {\n};\nAttr.prototype.nodeType = ATTRIBUTE_NODE;\n_extends(Attr,Node);\n\n\nfunction CharacterData() {\n};\nCharacterData.prototype = {\n\tdata : '',\n\tsubstringData : function(offset, count) {\n\t\treturn this.data.substring(offset, offset+count);\n\t},\n\tappendData: function(text) {\n\t\ttext = this.data+text;\n\t\tthis.nodeValue = this.data = text;\n\t\tthis.length = text.length;\n\t},\n\tinsertData: function(offset,text) {\n\t\tthis.replaceData(offset,0,text);\n\n\t},\n\tappendChild:function(newChild){\n\t\tthrow new Error(ExceptionMessage[HIERARCHY_REQUEST_ERR])\n\t},\n\tdeleteData: function(offset, count) {\n\t\tthis.replaceData(offset,count,\"\");\n\t},\n\treplaceData: function(offset, count, text) {\n\t\tvar start = this.data.substring(0,offset);\n\t\tvar end = this.data.substring(offset+count);\n\t\ttext = start + text + end;\n\t\tthis.nodeValue = this.data = text;\n\t\tthis.length = text.length;\n\t}\n}\n_extends(CharacterData,Node);\nfunction Text() {\n};\nText.prototype = {\n\tnodeName : \"#text\",\n\tnodeType : TEXT_NODE,\n\tsplitText : function(offset) {\n\t\tvar text = this.data;\n\t\tvar newText = text.substring(offset);\n\t\ttext = text.substring(0, offset);\n\t\tthis.data = this.nodeValue = text;\n\t\tthis.length = text.length;\n\t\tvar newNode = this.ownerDocument.createTextNode(newText);\n\t\tif(this.parentNode){\n\t\t\tthis.parentNode.insertBefore(newNode, this.nextSibling);\n\t\t}\n\t\treturn newNode;\n\t}\n}\n_extends(Text,CharacterData);\nfunction Comment() {\n};\nComment.prototype = {\n\tnodeName : \"#comment\",\n\tnodeType : COMMENT_NODE\n}\n_extends(Comment,CharacterData);\n\nfunction CDATASection() {\n};\nCDATASection.prototype = {\n\tnodeName : \"#cdata-section\",\n\tnodeType : CDATA_SECTION_NODE\n}\n_extends(CDATASection,CharacterData);\n\n\nfunction DocumentType() {\n};\nDocumentType.prototype.nodeType = DOCUMENT_TYPE_NODE;\n_extends(DocumentType,Node);\n\nfunction Notation() {\n};\nNotation.prototype.nodeType = NOTATION_NODE;\n_extends(Notation,Node);\n\nfunction Entity() {\n};\nEntity.prototype.nodeType = ENTITY_NODE;\n_extends(Entity,Node);\n\nfunction EntityReference() {\n};\nEntityReference.prototype.nodeType = ENTITY_REFERENCE_NODE;\n_extends(EntityReference,Node);\n\nfunction DocumentFragment() {\n};\nDocumentFragment.prototype.nodeName =\t\"#document-fragment\";\nDocumentFragment.prototype.nodeType =\tDOCUMENT_FRAGMENT_NODE;\n_extends(DocumentFragment,Node);\n\n\nfunction ProcessingInstruction() {\n}\nProcessingInstruction.prototype.nodeType = PROCESSING_INSTRUCTION_NODE;\n_extends(ProcessingInstruction,Node);\nfunction XMLSerializer(){}\nXMLSerializer.prototype.serializeToString = function(node,isHtml,nodeFilter){\n\treturn nodeSerializeToString.call(node,isHtml,nodeFilter);\n}\nNode.prototype.toString = nodeSerializeToString;\nfunction nodeSerializeToString(isHtml,nodeFilter){\n\tvar buf = [];\n\tvar refNode = this.nodeType == 9 && this.documentElement || this;\n\tvar prefix = refNode.prefix;\n\tvar uri = refNode.namespaceURI;\n\n\tif(uri && prefix == null){\n\t\t//console.log(prefix)\n\t\tvar prefix = refNode.lookupPrefix(uri);\n\t\tif(prefix == null){\n\t\t\t//isHTML = true;\n\t\t\tvar visibleNamespaces=[\n\t\t\t{namespace:uri,prefix:null}\n\t\t\t//{namespace:uri,prefix:''}\n\t\t\t]\n\t\t}\n\t}\n\tserializeToString(this,buf,isHtml,nodeFilter,visibleNamespaces);\n\t//console.log('###',this.nodeType,uri,prefix,buf.join(''))\n\treturn buf.join('');\n}\n\nfunction needNamespaceDefine(node, isHTML, visibleNamespaces) {\n\tvar prefix = node.prefix || '';\n\tvar uri = node.namespaceURI;\n\t// According to [Namespaces in XML 1.0](https://www.w3.org/TR/REC-xml-names/#ns-using) ,\n\t// and more specifically https://www.w3.org/TR/REC-xml-names/#nsc-NoPrefixUndecl :\n\t// > In a namespace declaration for a prefix [...], the attribute value MUST NOT be empty.\n\t// in a similar manner [Namespaces in XML 1.1](https://www.w3.org/TR/xml-names11/#ns-using)\n\t// and more specifically https://www.w3.org/TR/xml-names11/#nsc-NSDeclared :\n\t// > [...] Furthermore, the attribute value [...] must not be an empty string.\n\t// so serializing empty namespace value like xmlns:ds=\"\" would produce an invalid XML document.\n\tif (!uri) {\n\t\treturn false;\n\t}\n\tif (prefix === \"xml\" && uri === NAMESPACE.XML || uri === NAMESPACE.XMLNS) {\n\t\treturn false;\n\t}\n\n\tvar i = visibleNamespaces.length\n\twhile (i--) {\n\t\tvar ns = visibleNamespaces[i];\n\t\t// get namespace prefix\n\t\tif (ns.prefix === prefix) {\n\t\t\treturn ns.namespace !== uri;\n\t\t}\n\t}\n\treturn true;\n}\n/**\n * Well-formed constraint: No < in Attribute Values\n * > The replacement text of any entity referred to directly or indirectly\n * > in an attribute value must not contain a <.\n * @see https://www.w3.org/TR/xml11/#CleanAttrVals\n * @see https://www.w3.org/TR/xml11/#NT-AttValue\n *\n * Literal whitespace other than space that appear in attribute values\n * are serialized as their entity references, so they will be preserved.\n * (In contrast to whitespace literals in the input which are normalized to spaces)\n * @see https://www.w3.org/TR/xml11/#AVNormalize\n * @see https://w3c.github.io/DOM-Parsing/#serializing-an-element-s-attributes\n */\nfunction addSerializedAttribute(buf, qualifiedName, value) {\n\tbuf.push(' ', qualifiedName, '=\"', value.replace(/[<>&\"\\t\\n\\r]/g, _xmlEncoder), '\"')\n}\n\nfunction serializeToString(node,buf,isHTML,nodeFilter,visibleNamespaces){\n\tif (!visibleNamespaces) {\n\t\tvisibleNamespaces = [];\n\t}\n\n\tif(nodeFilter){\n\t\tnode = nodeFilter(node);\n\t\tif(node){\n\t\t\tif(typeof node == 'string'){\n\t\t\t\tbuf.push(node);\n\t\t\t\treturn;\n\t\t\t}\n\t\t}else{\n\t\t\treturn;\n\t\t}\n\t\t//buf.sort.apply(attrs, attributeSorter);\n\t}\n\n\tswitch(node.nodeType){\n\tcase ELEMENT_NODE:\n\t\tvar attrs = node.attributes;\n\t\tvar len = attrs.length;\n\t\tvar child = node.firstChild;\n\t\tvar nodeName = node.tagName;\n\n\t\tisHTML = NAMESPACE.isHTML(node.namespaceURI) || isHTML\n\n\t\tvar prefixedNodeName = nodeName\n\t\tif (!isHTML && !node.prefix && node.namespaceURI) {\n\t\t\tvar defaultNS\n\t\t\t// lookup current default ns from `xmlns` attribute\n\t\t\tfor (var ai = 0; ai < attrs.length; ai++) {\n\t\t\t\tif (attrs.item(ai).name === 'xmlns') {\n\t\t\t\t\tdefaultNS = attrs.item(ai).value\n\t\t\t\t\tbreak\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (!defaultNS) {\n\t\t\t\t// lookup current default ns in visibleNamespaces\n\t\t\t\tfor (var nsi = visibleNamespaces.length - 1; nsi >= 0; nsi--) {\n\t\t\t\t\tvar namespace = visibleNamespaces[nsi]\n\t\t\t\t\tif (namespace.prefix === '' && namespace.namespace === node.namespaceURI) {\n\t\t\t\t\t\tdefaultNS = namespace.namespace\n\t\t\t\t\t\tbreak\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (defaultNS !== node.namespaceURI) {\n\t\t\t\tfor (var nsi = visibleNamespaces.length - 1; nsi >= 0; nsi--) {\n\t\t\t\t\tvar namespace = visibleNamespaces[nsi]\n\t\t\t\t\tif (namespace.namespace === node.namespaceURI) {\n\t\t\t\t\t\tif (namespace.prefix) {\n\t\t\t\t\t\t\tprefixedNodeName = namespace.prefix + ':' + nodeName\n\t\t\t\t\t\t}\n\t\t\t\t\t\tbreak\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tbuf.push('<', prefixedNodeName);\n\n\t\tfor(var i=0;i');\n\t\t\t//if is cdata child node\n\t\t\tif(isHTML && /^script$/i.test(nodeName)){\n\t\t\t\twhile(child){\n\t\t\t\t\tif(child.data){\n\t\t\t\t\t\tbuf.push(child.data);\n\t\t\t\t\t}else{\n\t\t\t\t\t\tserializeToString(child, buf, isHTML, nodeFilter, visibleNamespaces.slice());\n\t\t\t\t\t}\n\t\t\t\t\tchild = child.nextSibling;\n\t\t\t\t}\n\t\t\t}else\n\t\t\t{\n\t\t\t\twhile(child){\n\t\t\t\t\tserializeToString(child, buf, isHTML, nodeFilter, visibleNamespaces.slice());\n\t\t\t\t\tchild = child.nextSibling;\n\t\t\t\t}\n\t\t\t}\n\t\t\tbuf.push('',prefixedNodeName,'>');\n\t\t}else{\n\t\t\tbuf.push('/>');\n\t\t}\n\t\t// remove added visible namespaces\n\t\t//visibleNamespaces.length = startVisibleNamespaces;\n\t\treturn;\n\tcase DOCUMENT_NODE:\n\tcase DOCUMENT_FRAGMENT_NODE:\n\t\tvar child = node.firstChild;\n\t\twhile(child){\n\t\t\tserializeToString(child, buf, isHTML, nodeFilter, visibleNamespaces.slice());\n\t\t\tchild = child.nextSibling;\n\t\t}\n\t\treturn;\n\tcase ATTRIBUTE_NODE:\n\t\treturn addSerializedAttribute(buf, node.name, node.value);\n\tcase TEXT_NODE:\n\t\t/**\n\t\t * The ampersand character (&) and the left angle bracket (<) must not appear in their literal form,\n\t\t * except when used as markup delimiters, or within a comment, a processing instruction, or a CDATA section.\n\t\t * If they are needed elsewhere, they must be escaped using either numeric character references or the strings\n\t\t * `&` and `<` respectively.\n\t\t * The right angle bracket (>) may be represented using the string \" > \", and must, for compatibility,\n\t\t * be escaped using either `>` or a character reference when it appears in the string `]]>` in content,\n\t\t * when that string is not marking the end of a CDATA section.\n\t\t *\n\t\t * In the content of elements, character data is any string of characters\n\t\t * which does not contain the start-delimiter of any markup\n\t\t * and does not include the CDATA-section-close delimiter, `]]>`.\n\t\t *\n\t\t * @see https://www.w3.org/TR/xml/#NT-CharData\n\t\t * @see https://w3c.github.io/DOM-Parsing/#xml-serializing-a-text-node\n\t\t */\n\t\treturn buf.push(node.data\n\t\t\t.replace(/[<&>]/g,_xmlEncoder)\n\t\t);\n\tcase CDATA_SECTION_NODE:\n\t\treturn buf.push( '');\n\tcase COMMENT_NODE:\n\t\treturn buf.push( \"\");\n\tcase DOCUMENT_TYPE_NODE:\n\t\tvar pubid = node.publicId;\n\t\tvar sysid = node.systemId;\n\t\tbuf.push('');\n\t\t}else if(sysid && sysid!='.'){\n\t\t\tbuf.push(' SYSTEM ', sysid, '>');\n\t\t}else{\n\t\t\tvar sub = node.internalSubset;\n\t\t\tif(sub){\n\t\t\t\tbuf.push(\" [\",sub,\"]\");\n\t\t\t}\n\t\t\tbuf.push(\">\");\n\t\t}\n\t\treturn;\n\tcase PROCESSING_INSTRUCTION_NODE:\n\t\treturn buf.push( \"\",node.target,\" \",node.data,\"?>\");\n\tcase ENTITY_REFERENCE_NODE:\n\t\treturn buf.push( '&',node.nodeName,';');\n\t//case ENTITY_NODE:\n\t//case NOTATION_NODE:\n\tdefault:\n\t\tbuf.push('??',node.nodeName);\n\t}\n}\nfunction importNode(doc,node,deep){\n\tvar node2;\n\tswitch (node.nodeType) {\n\tcase ELEMENT_NODE:\n\t\tnode2 = node.cloneNode(false);\n\t\tnode2.ownerDocument = doc;\n\t\t//var attrs = node2.attributes;\n\t\t//var len = attrs.length;\n\t\t//for(var i=0;i',\n\tlt: '<',\n\tquot: '\"',\n});\n\n/**\n * A map of all entities that are detected in an HTML document.\n * They contain all entries from `XML_ENTITIES`.\n *\n * @see XML_ENTITIES\n * @see DOMParser.parseFromString\n * @see DOMImplementation.prototype.createHTMLDocument\n * @see https://html.spec.whatwg.org/#named-character-references WHATWG HTML(5) Spec\n * @see https://html.spec.whatwg.org/entities.json JSON\n * @see https://www.w3.org/TR/xml-entity-names/ W3C XML Entity Names\n * @see https://www.w3.org/TR/html4/sgml/entities.html W3C HTML4/SGML\n * @see https://en.wikipedia.org/wiki/List_of_XML_and_HTML_character_entity_references#Character_entity_references_in_HTML Wikipedia (HTML)\n * @see https://en.wikipedia.org/wiki/List_of_XML_and_HTML_character_entity_references#Entities_representing_special_characters_in_XHTML Wikpedia (XHTML)\n */\nexports.HTML_ENTITIES = freeze({\n\tAacute: '\\u00C1',\n\taacute: '\\u00E1',\n\tAbreve: '\\u0102',\n\tabreve: '\\u0103',\n\tac: '\\u223E',\n\tacd: '\\u223F',\n\tacE: '\\u223E\\u0333',\n\tAcirc: '\\u00C2',\n\tacirc: '\\u00E2',\n\tacute: '\\u00B4',\n\tAcy: '\\u0410',\n\tacy: '\\u0430',\n\tAElig: '\\u00C6',\n\taelig: '\\u00E6',\n\taf: '\\u2061',\n\tAfr: '\\uD835\\uDD04',\n\tafr: '\\uD835\\uDD1E',\n\tAgrave: '\\u00C0',\n\tagrave: '\\u00E0',\n\talefsym: '\\u2135',\n\taleph: '\\u2135',\n\tAlpha: '\\u0391',\n\talpha: '\\u03B1',\n\tAmacr: '\\u0100',\n\tamacr: '\\u0101',\n\tamalg: '\\u2A3F',\n\tAMP: '\\u0026',\n\tamp: '\\u0026',\n\tAnd: '\\u2A53',\n\tand: '\\u2227',\n\tandand: '\\u2A55',\n\tandd: '\\u2A5C',\n\tandslope: '\\u2A58',\n\tandv: '\\u2A5A',\n\tang: '\\u2220',\n\tange: '\\u29A4',\n\tangle: '\\u2220',\n\tangmsd: '\\u2221',\n\tangmsdaa: '\\u29A8',\n\tangmsdab: '\\u29A9',\n\tangmsdac: '\\u29AA',\n\tangmsdad: '\\u29AB',\n\tangmsdae: '\\u29AC',\n\tangmsdaf: '\\u29AD',\n\tangmsdag: '\\u29AE',\n\tangmsdah: '\\u29AF',\n\tangrt: '\\u221F',\n\tangrtvb: '\\u22BE',\n\tangrtvbd: '\\u299D',\n\tangsph: '\\u2222',\n\tangst: '\\u00C5',\n\tangzarr: '\\u237C',\n\tAogon: '\\u0104',\n\taogon: '\\u0105',\n\tAopf: '\\uD835\\uDD38',\n\taopf: '\\uD835\\uDD52',\n\tap: '\\u2248',\n\tapacir: '\\u2A6F',\n\tapE: '\\u2A70',\n\tape: '\\u224A',\n\tapid: '\\u224B',\n\tapos: '\\u0027',\n\tApplyFunction: '\\u2061',\n\tapprox: '\\u2248',\n\tapproxeq: '\\u224A',\n\tAring: '\\u00C5',\n\taring: '\\u00E5',\n\tAscr: '\\uD835\\uDC9C',\n\tascr: '\\uD835\\uDCB6',\n\tAssign: '\\u2254',\n\tast: '\\u002A',\n\tasymp: '\\u2248',\n\tasympeq: '\\u224D',\n\tAtilde: '\\u00C3',\n\tatilde: '\\u00E3',\n\tAuml: '\\u00C4',\n\tauml: '\\u00E4',\n\tawconint: '\\u2233',\n\tawint: '\\u2A11',\n\tbackcong: '\\u224C',\n\tbackepsilon: '\\u03F6',\n\tbackprime: '\\u2035',\n\tbacksim: '\\u223D',\n\tbacksimeq: '\\u22CD',\n\tBackslash: '\\u2216',\n\tBarv: '\\u2AE7',\n\tbarvee: '\\u22BD',\n\tBarwed: '\\u2306',\n\tbarwed: '\\u2305',\n\tbarwedge: '\\u2305',\n\tbbrk: '\\u23B5',\n\tbbrktbrk: '\\u23B6',\n\tbcong: '\\u224C',\n\tBcy: '\\u0411',\n\tbcy: '\\u0431',\n\tbdquo: '\\u201E',\n\tbecaus: '\\u2235',\n\tBecause: '\\u2235',\n\tbecause: '\\u2235',\n\tbemptyv: '\\u29B0',\n\tbepsi: '\\u03F6',\n\tbernou: '\\u212C',\n\tBernoullis: '\\u212C',\n\tBeta: '\\u0392',\n\tbeta: '\\u03B2',\n\tbeth: '\\u2136',\n\tbetween: '\\u226C',\n\tBfr: '\\uD835\\uDD05',\n\tbfr: '\\uD835\\uDD1F',\n\tbigcap: '\\u22C2',\n\tbigcirc: '\\u25EF',\n\tbigcup: '\\u22C3',\n\tbigodot: '\\u2A00',\n\tbigoplus: '\\u2A01',\n\tbigotimes: '\\u2A02',\n\tbigsqcup: '\\u2A06',\n\tbigstar: '\\u2605',\n\tbigtriangledown: '\\u25BD',\n\tbigtriangleup: '\\u25B3',\n\tbiguplus: '\\u2A04',\n\tbigvee: '\\u22C1',\n\tbigwedge: '\\u22C0',\n\tbkarow: '\\u290D',\n\tblacklozenge: '\\u29EB',\n\tblacksquare: '\\u25AA',\n\tblacktriangle: '\\u25B4',\n\tblacktriangledown: '\\u25BE',\n\tblacktriangleleft: '\\u25C2',\n\tblacktriangleright: '\\u25B8',\n\tblank: '\\u2423',\n\tblk12: '\\u2592',\n\tblk14: '\\u2591',\n\tblk34: '\\u2593',\n\tblock: '\\u2588',\n\tbne: '\\u003D\\u20E5',\n\tbnequiv: '\\u2261\\u20E5',\n\tbNot: '\\u2AED',\n\tbnot: '\\u2310',\n\tBopf: '\\uD835\\uDD39',\n\tbopf: '\\uD835\\uDD53',\n\tbot: '\\u22A5',\n\tbottom: '\\u22A5',\n\tbowtie: '\\u22C8',\n\tboxbox: '\\u29C9',\n\tboxDL: '\\u2557',\n\tboxDl: '\\u2556',\n\tboxdL: '\\u2555',\n\tboxdl: '\\u2510',\n\tboxDR: '\\u2554',\n\tboxDr: '\\u2553',\n\tboxdR: '\\u2552',\n\tboxdr: '\\u250C',\n\tboxH: '\\u2550',\n\tboxh: '\\u2500',\n\tboxHD: '\\u2566',\n\tboxHd: '\\u2564',\n\tboxhD: '\\u2565',\n\tboxhd: '\\u252C',\n\tboxHU: '\\u2569',\n\tboxHu: '\\u2567',\n\tboxhU: '\\u2568',\n\tboxhu: '\\u2534',\n\tboxminus: '\\u229F',\n\tboxplus: '\\u229E',\n\tboxtimes: '\\u22A0',\n\tboxUL: '\\u255D',\n\tboxUl: '\\u255C',\n\tboxuL: '\\u255B',\n\tboxul: '\\u2518',\n\tboxUR: '\\u255A',\n\tboxUr: '\\u2559',\n\tboxuR: '\\u2558',\n\tboxur: '\\u2514',\n\tboxV: '\\u2551',\n\tboxv: '\\u2502',\n\tboxVH: '\\u256C',\n\tboxVh: '\\u256B',\n\tboxvH: '\\u256A',\n\tboxvh: '\\u253C',\n\tboxVL: '\\u2563',\n\tboxVl: '\\u2562',\n\tboxvL: '\\u2561',\n\tboxvl: '\\u2524',\n\tboxVR: '\\u2560',\n\tboxVr: '\\u255F',\n\tboxvR: '\\u255E',\n\tboxvr: '\\u251C',\n\tbprime: '\\u2035',\n\tBreve: '\\u02D8',\n\tbreve: '\\u02D8',\n\tbrvbar: '\\u00A6',\n\tBscr: '\\u212C',\n\tbscr: '\\uD835\\uDCB7',\n\tbsemi: '\\u204F',\n\tbsim: '\\u223D',\n\tbsime: '\\u22CD',\n\tbsol: '\\u005C',\n\tbsolb: '\\u29C5',\n\tbsolhsub: '\\u27C8',\n\tbull: '\\u2022',\n\tbullet: '\\u2022',\n\tbump: '\\u224E',\n\tbumpE: '\\u2AAE',\n\tbumpe: '\\u224F',\n\tBumpeq: '\\u224E',\n\tbumpeq: '\\u224F',\n\tCacute: '\\u0106',\n\tcacute: '\\u0107',\n\tCap: '\\u22D2',\n\tcap: '\\u2229',\n\tcapand: '\\u2A44',\n\tcapbrcup: '\\u2A49',\n\tcapcap: '\\u2A4B',\n\tcapcup: '\\u2A47',\n\tcapdot: '\\u2A40',\n\tCapitalDifferentialD: '\\u2145',\n\tcaps: '\\u2229\\uFE00',\n\tcaret: '\\u2041',\n\tcaron: '\\u02C7',\n\tCayleys: '\\u212D',\n\tccaps: '\\u2A4D',\n\tCcaron: '\\u010C',\n\tccaron: '\\u010D',\n\tCcedil: '\\u00C7',\n\tccedil: '\\u00E7',\n\tCcirc: '\\u0108',\n\tccirc: '\\u0109',\n\tCconint: '\\u2230',\n\tccups: '\\u2A4C',\n\tccupssm: '\\u2A50',\n\tCdot: '\\u010A',\n\tcdot: '\\u010B',\n\tcedil: '\\u00B8',\n\tCedilla: '\\u00B8',\n\tcemptyv: '\\u29B2',\n\tcent: '\\u00A2',\n\tCenterDot: '\\u00B7',\n\tcenterdot: '\\u00B7',\n\tCfr: '\\u212D',\n\tcfr: '\\uD835\\uDD20',\n\tCHcy: '\\u0427',\n\tchcy: '\\u0447',\n\tcheck: '\\u2713',\n\tcheckmark: '\\u2713',\n\tChi: '\\u03A7',\n\tchi: '\\u03C7',\n\tcir: '\\u25CB',\n\tcirc: '\\u02C6',\n\tcirceq: '\\u2257',\n\tcirclearrowleft: '\\u21BA',\n\tcirclearrowright: '\\u21BB',\n\tcircledast: '\\u229B',\n\tcircledcirc: '\\u229A',\n\tcircleddash: '\\u229D',\n\tCircleDot: '\\u2299',\n\tcircledR: '\\u00AE',\n\tcircledS: '\\u24C8',\n\tCircleMinus: '\\u2296',\n\tCirclePlus: '\\u2295',\n\tCircleTimes: '\\u2297',\n\tcirE: '\\u29C3',\n\tcire: '\\u2257',\n\tcirfnint: '\\u2A10',\n\tcirmid: '\\u2AEF',\n\tcirscir: '\\u29C2',\n\tClockwiseContourIntegral: '\\u2232',\n\tCloseCurlyDoubleQuote: '\\u201D',\n\tCloseCurlyQuote: '\\u2019',\n\tclubs: '\\u2663',\n\tclubsuit: '\\u2663',\n\tColon: '\\u2237',\n\tcolon: '\\u003A',\n\tColone: '\\u2A74',\n\tcolone: '\\u2254',\n\tcoloneq: '\\u2254',\n\tcomma: '\\u002C',\n\tcommat: '\\u0040',\n\tcomp: '\\u2201',\n\tcompfn: '\\u2218',\n\tcomplement: '\\u2201',\n\tcomplexes: '\\u2102',\n\tcong: '\\u2245',\n\tcongdot: '\\u2A6D',\n\tCongruent: '\\u2261',\n\tConint: '\\u222F',\n\tconint: '\\u222E',\n\tContourIntegral: '\\u222E',\n\tCopf: '\\u2102',\n\tcopf: '\\uD835\\uDD54',\n\tcoprod: '\\u2210',\n\tCoproduct: '\\u2210',\n\tCOPY: '\\u00A9',\n\tcopy: '\\u00A9',\n\tcopysr: '\\u2117',\n\tCounterClockwiseContourIntegral: '\\u2233',\n\tcrarr: '\\u21B5',\n\tCross: '\\u2A2F',\n\tcross: '\\u2717',\n\tCscr: '\\uD835\\uDC9E',\n\tcscr: '\\uD835\\uDCB8',\n\tcsub: '\\u2ACF',\n\tcsube: '\\u2AD1',\n\tcsup: '\\u2AD0',\n\tcsupe: '\\u2AD2',\n\tctdot: '\\u22EF',\n\tcudarrl: '\\u2938',\n\tcudarrr: '\\u2935',\n\tcuepr: '\\u22DE',\n\tcuesc: '\\u22DF',\n\tcularr: '\\u21B6',\n\tcularrp: '\\u293D',\n\tCup: '\\u22D3',\n\tcup: '\\u222A',\n\tcupbrcap: '\\u2A48',\n\tCupCap: '\\u224D',\n\tcupcap: '\\u2A46',\n\tcupcup: '\\u2A4A',\n\tcupdot: '\\u228D',\n\tcupor: '\\u2A45',\n\tcups: '\\u222A\\uFE00',\n\tcurarr: '\\u21B7',\n\tcurarrm: '\\u293C',\n\tcurlyeqprec: '\\u22DE',\n\tcurlyeqsucc: '\\u22DF',\n\tcurlyvee: '\\u22CE',\n\tcurlywedge: '\\u22CF',\n\tcurren: '\\u00A4',\n\tcurvearrowleft: '\\u21B6',\n\tcurvearrowright: '\\u21B7',\n\tcuvee: '\\u22CE',\n\tcuwed: '\\u22CF',\n\tcwconint: '\\u2232',\n\tcwint: '\\u2231',\n\tcylcty: '\\u232D',\n\tDagger: '\\u2021',\n\tdagger: '\\u2020',\n\tdaleth: '\\u2138',\n\tDarr: '\\u21A1',\n\tdArr: '\\u21D3',\n\tdarr: '\\u2193',\n\tdash: '\\u2010',\n\tDashv: '\\u2AE4',\n\tdashv: '\\u22A3',\n\tdbkarow: '\\u290F',\n\tdblac: '\\u02DD',\n\tDcaron: '\\u010E',\n\tdcaron: '\\u010F',\n\tDcy: '\\u0414',\n\tdcy: '\\u0434',\n\tDD: '\\u2145',\n\tdd: '\\u2146',\n\tddagger: '\\u2021',\n\tddarr: '\\u21CA',\n\tDDotrahd: '\\u2911',\n\tddotseq: '\\u2A77',\n\tdeg: '\\u00B0',\n\tDel: '\\u2207',\n\tDelta: '\\u0394',\n\tdelta: '\\u03B4',\n\tdemptyv: '\\u29B1',\n\tdfisht: '\\u297F',\n\tDfr: '\\uD835\\uDD07',\n\tdfr: '\\uD835\\uDD21',\n\tdHar: '\\u2965',\n\tdharl: '\\u21C3',\n\tdharr: '\\u21C2',\n\tDiacriticalAcute: '\\u00B4',\n\tDiacriticalDot: '\\u02D9',\n\tDiacriticalDoubleAcute: '\\u02DD',\n\tDiacriticalGrave: '\\u0060',\n\tDiacriticalTilde: '\\u02DC',\n\tdiam: '\\u22C4',\n\tDiamond: '\\u22C4',\n\tdiamond: '\\u22C4',\n\tdiamondsuit: '\\u2666',\n\tdiams: '\\u2666',\n\tdie: '\\u00A8',\n\tDifferentialD: '\\u2146',\n\tdigamma: '\\u03DD',\n\tdisin: '\\u22F2',\n\tdiv: '\\u00F7',\n\tdivide: '\\u00F7',\n\tdivideontimes: '\\u22C7',\n\tdivonx: '\\u22C7',\n\tDJcy: '\\u0402',\n\tdjcy: '\\u0452',\n\tdlcorn: '\\u231E',\n\tdlcrop: '\\u230D',\n\tdollar: '\\u0024',\n\tDopf: '\\uD835\\uDD3B',\n\tdopf: '\\uD835\\uDD55',\n\tDot: '\\u00A8',\n\tdot: '\\u02D9',\n\tDotDot: '\\u20DC',\n\tdoteq: '\\u2250',\n\tdoteqdot: '\\u2251',\n\tDotEqual: '\\u2250',\n\tdotminus: '\\u2238',\n\tdotplus: '\\u2214',\n\tdotsquare: '\\u22A1',\n\tdoublebarwedge: '\\u2306',\n\tDoubleContourIntegral: '\\u222F',\n\tDoubleDot: '\\u00A8',\n\tDoubleDownArrow: '\\u21D3',\n\tDoubleLeftArrow: '\\u21D0',\n\tDoubleLeftRightArrow: '\\u21D4',\n\tDoubleLeftTee: '\\u2AE4',\n\tDoubleLongLeftArrow: '\\u27F8',\n\tDoubleLongLeftRightArrow: '\\u27FA',\n\tDoubleLongRightArrow: '\\u27F9',\n\tDoubleRightArrow: '\\u21D2',\n\tDoubleRightTee: '\\u22A8',\n\tDoubleUpArrow: '\\u21D1',\n\tDoubleUpDownArrow: '\\u21D5',\n\tDoubleVerticalBar: '\\u2225',\n\tDownArrow: '\\u2193',\n\tDownarrow: '\\u21D3',\n\tdownarrow: '\\u2193',\n\tDownArrowBar: '\\u2913',\n\tDownArrowUpArrow: '\\u21F5',\n\tDownBreve: '\\u0311',\n\tdowndownarrows: '\\u21CA',\n\tdownharpoonleft: '\\u21C3',\n\tdownharpoonright: '\\u21C2',\n\tDownLeftRightVector: '\\u2950',\n\tDownLeftTeeVector: '\\u295E',\n\tDownLeftVector: '\\u21BD',\n\tDownLeftVectorBar: '\\u2956',\n\tDownRightTeeVector: '\\u295F',\n\tDownRightVector: '\\u21C1',\n\tDownRightVectorBar: '\\u2957',\n\tDownTee: '\\u22A4',\n\tDownTeeArrow: '\\u21A7',\n\tdrbkarow: '\\u2910',\n\tdrcorn: '\\u231F',\n\tdrcrop: '\\u230C',\n\tDscr: '\\uD835\\uDC9F',\n\tdscr: '\\uD835\\uDCB9',\n\tDScy: '\\u0405',\n\tdscy: '\\u0455',\n\tdsol: '\\u29F6',\n\tDstrok: '\\u0110',\n\tdstrok: '\\u0111',\n\tdtdot: '\\u22F1',\n\tdtri: '\\u25BF',\n\tdtrif: '\\u25BE',\n\tduarr: '\\u21F5',\n\tduhar: '\\u296F',\n\tdwangle: '\\u29A6',\n\tDZcy: '\\u040F',\n\tdzcy: '\\u045F',\n\tdzigrarr: '\\u27FF',\n\tEacute: '\\u00C9',\n\teacute: '\\u00E9',\n\teaster: '\\u2A6E',\n\tEcaron: '\\u011A',\n\tecaron: '\\u011B',\n\tecir: '\\u2256',\n\tEcirc: '\\u00CA',\n\tecirc: '\\u00EA',\n\tecolon: '\\u2255',\n\tEcy: '\\u042D',\n\tecy: '\\u044D',\n\teDDot: '\\u2A77',\n\tEdot: '\\u0116',\n\teDot: '\\u2251',\n\tedot: '\\u0117',\n\tee: '\\u2147',\n\tefDot: '\\u2252',\n\tEfr: '\\uD835\\uDD08',\n\tefr: '\\uD835\\uDD22',\n\teg: '\\u2A9A',\n\tEgrave: '\\u00C8',\n\tegrave: '\\u00E8',\n\tegs: '\\u2A96',\n\tegsdot: '\\u2A98',\n\tel: '\\u2A99',\n\tElement: '\\u2208',\n\telinters: '\\u23E7',\n\tell: '\\u2113',\n\tels: '\\u2A95',\n\telsdot: '\\u2A97',\n\tEmacr: '\\u0112',\n\temacr: '\\u0113',\n\tempty: '\\u2205',\n\temptyset: '\\u2205',\n\tEmptySmallSquare: '\\u25FB',\n\temptyv: '\\u2205',\n\tEmptyVerySmallSquare: '\\u25AB',\n\temsp: '\\u2003',\n\temsp13: '\\u2004',\n\temsp14: '\\u2005',\n\tENG: '\\u014A',\n\teng: '\\u014B',\n\tensp: '\\u2002',\n\tEogon: '\\u0118',\n\teogon: '\\u0119',\n\tEopf: '\\uD835\\uDD3C',\n\teopf: '\\uD835\\uDD56',\n\tepar: '\\u22D5',\n\teparsl: '\\u29E3',\n\teplus: '\\u2A71',\n\tepsi: '\\u03B5',\n\tEpsilon: '\\u0395',\n\tepsilon: '\\u03B5',\n\tepsiv: '\\u03F5',\n\teqcirc: '\\u2256',\n\teqcolon: '\\u2255',\n\teqsim: '\\u2242',\n\teqslantgtr: '\\u2A96',\n\teqslantless: '\\u2A95',\n\tEqual: '\\u2A75',\n\tequals: '\\u003D',\n\tEqualTilde: '\\u2242',\n\tequest: '\\u225F',\n\tEquilibrium: '\\u21CC',\n\tequiv: '\\u2261',\n\tequivDD: '\\u2A78',\n\teqvparsl: '\\u29E5',\n\terarr: '\\u2971',\n\terDot: '\\u2253',\n\tEscr: '\\u2130',\n\tescr: '\\u212F',\n\tesdot: '\\u2250',\n\tEsim: '\\u2A73',\n\tesim: '\\u2242',\n\tEta: '\\u0397',\n\teta: '\\u03B7',\n\tETH: '\\u00D0',\n\teth: '\\u00F0',\n\tEuml: '\\u00CB',\n\teuml: '\\u00EB',\n\teuro: '\\u20AC',\n\texcl: '\\u0021',\n\texist: '\\u2203',\n\tExists: '\\u2203',\n\texpectation: '\\u2130',\n\tExponentialE: '\\u2147',\n\texponentiale: '\\u2147',\n\tfallingdotseq: '\\u2252',\n\tFcy: '\\u0424',\n\tfcy: '\\u0444',\n\tfemale: '\\u2640',\n\tffilig: '\\uFB03',\n\tfflig: '\\uFB00',\n\tffllig: '\\uFB04',\n\tFfr: '\\uD835\\uDD09',\n\tffr: '\\uD835\\uDD23',\n\tfilig: '\\uFB01',\n\tFilledSmallSquare: '\\u25FC',\n\tFilledVerySmallSquare: '\\u25AA',\n\tfjlig: '\\u0066\\u006A',\n\tflat: '\\u266D',\n\tfllig: '\\uFB02',\n\tfltns: '\\u25B1',\n\tfnof: '\\u0192',\n\tFopf: '\\uD835\\uDD3D',\n\tfopf: '\\uD835\\uDD57',\n\tForAll: '\\u2200',\n\tforall: '\\u2200',\n\tfork: '\\u22D4',\n\tforkv: '\\u2AD9',\n\tFouriertrf: '\\u2131',\n\tfpartint: '\\u2A0D',\n\tfrac12: '\\u00BD',\n\tfrac13: '\\u2153',\n\tfrac14: '\\u00BC',\n\tfrac15: '\\u2155',\n\tfrac16: '\\u2159',\n\tfrac18: '\\u215B',\n\tfrac23: '\\u2154',\n\tfrac25: '\\u2156',\n\tfrac34: '\\u00BE',\n\tfrac35: '\\u2157',\n\tfrac38: '\\u215C',\n\tfrac45: '\\u2158',\n\tfrac56: '\\u215A',\n\tfrac58: '\\u215D',\n\tfrac78: '\\u215E',\n\tfrasl: '\\u2044',\n\tfrown: '\\u2322',\n\tFscr: '\\u2131',\n\tfscr: '\\uD835\\uDCBB',\n\tgacute: '\\u01F5',\n\tGamma: '\\u0393',\n\tgamma: '\\u03B3',\n\tGammad: '\\u03DC',\n\tgammad: '\\u03DD',\n\tgap: '\\u2A86',\n\tGbreve: '\\u011E',\n\tgbreve: '\\u011F',\n\tGcedil: '\\u0122',\n\tGcirc: '\\u011C',\n\tgcirc: '\\u011D',\n\tGcy: '\\u0413',\n\tgcy: '\\u0433',\n\tGdot: '\\u0120',\n\tgdot: '\\u0121',\n\tgE: '\\u2267',\n\tge: '\\u2265',\n\tgEl: '\\u2A8C',\n\tgel: '\\u22DB',\n\tgeq: '\\u2265',\n\tgeqq: '\\u2267',\n\tgeqslant: '\\u2A7E',\n\tges: '\\u2A7E',\n\tgescc: '\\u2AA9',\n\tgesdot: '\\u2A80',\n\tgesdoto: '\\u2A82',\n\tgesdotol: '\\u2A84',\n\tgesl: '\\u22DB\\uFE00',\n\tgesles: '\\u2A94',\n\tGfr: '\\uD835\\uDD0A',\n\tgfr: '\\uD835\\uDD24',\n\tGg: '\\u22D9',\n\tgg: '\\u226B',\n\tggg: '\\u22D9',\n\tgimel: '\\u2137',\n\tGJcy: '\\u0403',\n\tgjcy: '\\u0453',\n\tgl: '\\u2277',\n\tgla: '\\u2AA5',\n\tglE: '\\u2A92',\n\tglj: '\\u2AA4',\n\tgnap: '\\u2A8A',\n\tgnapprox: '\\u2A8A',\n\tgnE: '\\u2269',\n\tgne: '\\u2A88',\n\tgneq: '\\u2A88',\n\tgneqq: '\\u2269',\n\tgnsim: '\\u22E7',\n\tGopf: '\\uD835\\uDD3E',\n\tgopf: '\\uD835\\uDD58',\n\tgrave: '\\u0060',\n\tGreaterEqual: '\\u2265',\n\tGreaterEqualLess: '\\u22DB',\n\tGreaterFullEqual: '\\u2267',\n\tGreaterGreater: '\\u2AA2',\n\tGreaterLess: '\\u2277',\n\tGreaterSlantEqual: '\\u2A7E',\n\tGreaterTilde: '\\u2273',\n\tGscr: '\\uD835\\uDCA2',\n\tgscr: '\\u210A',\n\tgsim: '\\u2273',\n\tgsime: '\\u2A8E',\n\tgsiml: '\\u2A90',\n\tGt: '\\u226B',\n\tGT: '\\u003E',\n\tgt: '\\u003E',\n\tgtcc: '\\u2AA7',\n\tgtcir: '\\u2A7A',\n\tgtdot: '\\u22D7',\n\tgtlPar: '\\u2995',\n\tgtquest: '\\u2A7C',\n\tgtrapprox: '\\u2A86',\n\tgtrarr: '\\u2978',\n\tgtrdot: '\\u22D7',\n\tgtreqless: '\\u22DB',\n\tgtreqqless: '\\u2A8C',\n\tgtrless: '\\u2277',\n\tgtrsim: '\\u2273',\n\tgvertneqq: '\\u2269\\uFE00',\n\tgvnE: '\\u2269\\uFE00',\n\tHacek: '\\u02C7',\n\thairsp: '\\u200A',\n\thalf: '\\u00BD',\n\thamilt: '\\u210B',\n\tHARDcy: '\\u042A',\n\thardcy: '\\u044A',\n\thArr: '\\u21D4',\n\tharr: '\\u2194',\n\tharrcir: '\\u2948',\n\tharrw: '\\u21AD',\n\tHat: '\\u005E',\n\thbar: '\\u210F',\n\tHcirc: '\\u0124',\n\thcirc: '\\u0125',\n\thearts: '\\u2665',\n\theartsuit: '\\u2665',\n\thellip: '\\u2026',\n\thercon: '\\u22B9',\n\tHfr: '\\u210C',\n\thfr: '\\uD835\\uDD25',\n\tHilbertSpace: '\\u210B',\n\thksearow: '\\u2925',\n\thkswarow: '\\u2926',\n\thoarr: '\\u21FF',\n\thomtht: '\\u223B',\n\thookleftarrow: '\\u21A9',\n\thookrightarrow: '\\u21AA',\n\tHopf: '\\u210D',\n\thopf: '\\uD835\\uDD59',\n\thorbar: '\\u2015',\n\tHorizontalLine: '\\u2500',\n\tHscr: '\\u210B',\n\thscr: '\\uD835\\uDCBD',\n\thslash: '\\u210F',\n\tHstrok: '\\u0126',\n\thstrok: '\\u0127',\n\tHumpDownHump: '\\u224E',\n\tHumpEqual: '\\u224F',\n\thybull: '\\u2043',\n\thyphen: '\\u2010',\n\tIacute: '\\u00CD',\n\tiacute: '\\u00ED',\n\tic: '\\u2063',\n\tIcirc: '\\u00CE',\n\ticirc: '\\u00EE',\n\tIcy: '\\u0418',\n\ticy: '\\u0438',\n\tIdot: '\\u0130',\n\tIEcy: '\\u0415',\n\tiecy: '\\u0435',\n\tiexcl: '\\u00A1',\n\tiff: '\\u21D4',\n\tIfr: '\\u2111',\n\tifr: '\\uD835\\uDD26',\n\tIgrave: '\\u00CC',\n\tigrave: '\\u00EC',\n\tii: '\\u2148',\n\tiiiint: '\\u2A0C',\n\tiiint: '\\u222D',\n\tiinfin: '\\u29DC',\n\tiiota: '\\u2129',\n\tIJlig: '\\u0132',\n\tijlig: '\\u0133',\n\tIm: '\\u2111',\n\tImacr: '\\u012A',\n\timacr: '\\u012B',\n\timage: '\\u2111',\n\tImaginaryI: '\\u2148',\n\timagline: '\\u2110',\n\timagpart: '\\u2111',\n\timath: '\\u0131',\n\timof: '\\u22B7',\n\timped: '\\u01B5',\n\tImplies: '\\u21D2',\n\tin: '\\u2208',\n\tincare: '\\u2105',\n\tinfin: '\\u221E',\n\tinfintie: '\\u29DD',\n\tinodot: '\\u0131',\n\tInt: '\\u222C',\n\tint: '\\u222B',\n\tintcal: '\\u22BA',\n\tintegers: '\\u2124',\n\tIntegral: '\\u222B',\n\tintercal: '\\u22BA',\n\tIntersection: '\\u22C2',\n\tintlarhk: '\\u2A17',\n\tintprod: '\\u2A3C',\n\tInvisibleComma: '\\u2063',\n\tInvisibleTimes: '\\u2062',\n\tIOcy: '\\u0401',\n\tiocy: '\\u0451',\n\tIogon: '\\u012E',\n\tiogon: '\\u012F',\n\tIopf: '\\uD835\\uDD40',\n\tiopf: '\\uD835\\uDD5A',\n\tIota: '\\u0399',\n\tiota: '\\u03B9',\n\tiprod: '\\u2A3C',\n\tiquest: '\\u00BF',\n\tIscr: '\\u2110',\n\tiscr: '\\uD835\\uDCBE',\n\tisin: '\\u2208',\n\tisindot: '\\u22F5',\n\tisinE: '\\u22F9',\n\tisins: '\\u22F4',\n\tisinsv: '\\u22F3',\n\tisinv: '\\u2208',\n\tit: '\\u2062',\n\tItilde: '\\u0128',\n\titilde: '\\u0129',\n\tIukcy: '\\u0406',\n\tiukcy: '\\u0456',\n\tIuml: '\\u00CF',\n\tiuml: '\\u00EF',\n\tJcirc: '\\u0134',\n\tjcirc: '\\u0135',\n\tJcy: '\\u0419',\n\tjcy: '\\u0439',\n\tJfr: '\\uD835\\uDD0D',\n\tjfr: '\\uD835\\uDD27',\n\tjmath: '\\u0237',\n\tJopf: '\\uD835\\uDD41',\n\tjopf: '\\uD835\\uDD5B',\n\tJscr: '\\uD835\\uDCA5',\n\tjscr: '\\uD835\\uDCBF',\n\tJsercy: '\\u0408',\n\tjsercy: '\\u0458',\n\tJukcy: '\\u0404',\n\tjukcy: '\\u0454',\n\tKappa: '\\u039A',\n\tkappa: '\\u03BA',\n\tkappav: '\\u03F0',\n\tKcedil: '\\u0136',\n\tkcedil: '\\u0137',\n\tKcy: '\\u041A',\n\tkcy: '\\u043A',\n\tKfr: '\\uD835\\uDD0E',\n\tkfr: '\\uD835\\uDD28',\n\tkgreen: '\\u0138',\n\tKHcy: '\\u0425',\n\tkhcy: '\\u0445',\n\tKJcy: '\\u040C',\n\tkjcy: '\\u045C',\n\tKopf: '\\uD835\\uDD42',\n\tkopf: '\\uD835\\uDD5C',\n\tKscr: '\\uD835\\uDCA6',\n\tkscr: '\\uD835\\uDCC0',\n\tlAarr: '\\u21DA',\n\tLacute: '\\u0139',\n\tlacute: '\\u013A',\n\tlaemptyv: '\\u29B4',\n\tlagran: '\\u2112',\n\tLambda: '\\u039B',\n\tlambda: '\\u03BB',\n\tLang: '\\u27EA',\n\tlang: '\\u27E8',\n\tlangd: '\\u2991',\n\tlangle: '\\u27E8',\n\tlap: '\\u2A85',\n\tLaplacetrf: '\\u2112',\n\tlaquo: '\\u00AB',\n\tLarr: '\\u219E',\n\tlArr: '\\u21D0',\n\tlarr: '\\u2190',\n\tlarrb: '\\u21E4',\n\tlarrbfs: '\\u291F',\n\tlarrfs: '\\u291D',\n\tlarrhk: '\\u21A9',\n\tlarrlp: '\\u21AB',\n\tlarrpl: '\\u2939',\n\tlarrsim: '\\u2973',\n\tlarrtl: '\\u21A2',\n\tlat: '\\u2AAB',\n\tlAtail: '\\u291B',\n\tlatail: '\\u2919',\n\tlate: '\\u2AAD',\n\tlates: '\\u2AAD\\uFE00',\n\tlBarr: '\\u290E',\n\tlbarr: '\\u290C',\n\tlbbrk: '\\u2772',\n\tlbrace: '\\u007B',\n\tlbrack: '\\u005B',\n\tlbrke: '\\u298B',\n\tlbrksld: '\\u298F',\n\tlbrkslu: '\\u298D',\n\tLcaron: '\\u013D',\n\tlcaron: '\\u013E',\n\tLcedil: '\\u013B',\n\tlcedil: '\\u013C',\n\tlceil: '\\u2308',\n\tlcub: '\\u007B',\n\tLcy: '\\u041B',\n\tlcy: '\\u043B',\n\tldca: '\\u2936',\n\tldquo: '\\u201C',\n\tldquor: '\\u201E',\n\tldrdhar: '\\u2967',\n\tldrushar: '\\u294B',\n\tldsh: '\\u21B2',\n\tlE: '\\u2266',\n\tle: '\\u2264',\n\tLeftAngleBracket: '\\u27E8',\n\tLeftArrow: '\\u2190',\n\tLeftarrow: '\\u21D0',\n\tleftarrow: '\\u2190',\n\tLeftArrowBar: '\\u21E4',\n\tLeftArrowRightArrow: '\\u21C6',\n\tleftarrowtail: '\\u21A2',\n\tLeftCeiling: '\\u2308',\n\tLeftDoubleBracket: '\\u27E6',\n\tLeftDownTeeVector: '\\u2961',\n\tLeftDownVector: '\\u21C3',\n\tLeftDownVectorBar: '\\u2959',\n\tLeftFloor: '\\u230A',\n\tleftharpoondown: '\\u21BD',\n\tleftharpoonup: '\\u21BC',\n\tleftleftarrows: '\\u21C7',\n\tLeftRightArrow: '\\u2194',\n\tLeftrightarrow: '\\u21D4',\n\tleftrightarrow: '\\u2194',\n\tleftrightarrows: '\\u21C6',\n\tleftrightharpoons: '\\u21CB',\n\tleftrightsquigarrow: '\\u21AD',\n\tLeftRightVector: '\\u294E',\n\tLeftTee: '\\u22A3',\n\tLeftTeeArrow: '\\u21A4',\n\tLeftTeeVector: '\\u295A',\n\tleftthreetimes: '\\u22CB',\n\tLeftTriangle: '\\u22B2',\n\tLeftTriangleBar: '\\u29CF',\n\tLeftTriangleEqual: '\\u22B4',\n\tLeftUpDownVector: '\\u2951',\n\tLeftUpTeeVector: '\\u2960',\n\tLeftUpVector: '\\u21BF',\n\tLeftUpVectorBar: '\\u2958',\n\tLeftVector: '\\u21BC',\n\tLeftVectorBar: '\\u2952',\n\tlEg: '\\u2A8B',\n\tleg: '\\u22DA',\n\tleq: '\\u2264',\n\tleqq: '\\u2266',\n\tleqslant: '\\u2A7D',\n\tles: '\\u2A7D',\n\tlescc: '\\u2AA8',\n\tlesdot: '\\u2A7F',\n\tlesdoto: '\\u2A81',\n\tlesdotor: '\\u2A83',\n\tlesg: '\\u22DA\\uFE00',\n\tlesges: '\\u2A93',\n\tlessapprox: '\\u2A85',\n\tlessdot: '\\u22D6',\n\tlesseqgtr: '\\u22DA',\n\tlesseqqgtr: '\\u2A8B',\n\tLessEqualGreater: '\\u22DA',\n\tLessFullEqual: '\\u2266',\n\tLessGreater: '\\u2276',\n\tlessgtr: '\\u2276',\n\tLessLess: '\\u2AA1',\n\tlesssim: '\\u2272',\n\tLessSlantEqual: '\\u2A7D',\n\tLessTilde: '\\u2272',\n\tlfisht: '\\u297C',\n\tlfloor: '\\u230A',\n\tLfr: '\\uD835\\uDD0F',\n\tlfr: '\\uD835\\uDD29',\n\tlg: '\\u2276',\n\tlgE: '\\u2A91',\n\tlHar: '\\u2962',\n\tlhard: '\\u21BD',\n\tlharu: '\\u21BC',\n\tlharul: '\\u296A',\n\tlhblk: '\\u2584',\n\tLJcy: '\\u0409',\n\tljcy: '\\u0459',\n\tLl: '\\u22D8',\n\tll: '\\u226A',\n\tllarr: '\\u21C7',\n\tllcorner: '\\u231E',\n\tLleftarrow: '\\u21DA',\n\tllhard: '\\u296B',\n\tlltri: '\\u25FA',\n\tLmidot: '\\u013F',\n\tlmidot: '\\u0140',\n\tlmoust: '\\u23B0',\n\tlmoustache: '\\u23B0',\n\tlnap: '\\u2A89',\n\tlnapprox: '\\u2A89',\n\tlnE: '\\u2268',\n\tlne: '\\u2A87',\n\tlneq: '\\u2A87',\n\tlneqq: '\\u2268',\n\tlnsim: '\\u22E6',\n\tloang: '\\u27EC',\n\tloarr: '\\u21FD',\n\tlobrk: '\\u27E6',\n\tLongLeftArrow: '\\u27F5',\n\tLongleftarrow: '\\u27F8',\n\tlongleftarrow: '\\u27F5',\n\tLongLeftRightArrow: '\\u27F7',\n\tLongleftrightarrow: '\\u27FA',\n\tlongleftrightarrow: '\\u27F7',\n\tlongmapsto: '\\u27FC',\n\tLongRightArrow: '\\u27F6',\n\tLongrightarrow: '\\u27F9',\n\tlongrightarrow: '\\u27F6',\n\tlooparrowleft: '\\u21AB',\n\tlooparrowright: '\\u21AC',\n\tlopar: '\\u2985',\n\tLopf: '\\uD835\\uDD43',\n\tlopf: '\\uD835\\uDD5D',\n\tloplus: '\\u2A2D',\n\tlotimes: '\\u2A34',\n\tlowast: '\\u2217',\n\tlowbar: '\\u005F',\n\tLowerLeftArrow: '\\u2199',\n\tLowerRightArrow: '\\u2198',\n\tloz: '\\u25CA',\n\tlozenge: '\\u25CA',\n\tlozf: '\\u29EB',\n\tlpar: '\\u0028',\n\tlparlt: '\\u2993',\n\tlrarr: '\\u21C6',\n\tlrcorner: '\\u231F',\n\tlrhar: '\\u21CB',\n\tlrhard: '\\u296D',\n\tlrm: '\\u200E',\n\tlrtri: '\\u22BF',\n\tlsaquo: '\\u2039',\n\tLscr: '\\u2112',\n\tlscr: '\\uD835\\uDCC1',\n\tLsh: '\\u21B0',\n\tlsh: '\\u21B0',\n\tlsim: '\\u2272',\n\tlsime: '\\u2A8D',\n\tlsimg: '\\u2A8F',\n\tlsqb: '\\u005B',\n\tlsquo: '\\u2018',\n\tlsquor: '\\u201A',\n\tLstrok: '\\u0141',\n\tlstrok: '\\u0142',\n\tLt: '\\u226A',\n\tLT: '\\u003C',\n\tlt: '\\u003C',\n\tltcc: '\\u2AA6',\n\tltcir: '\\u2A79',\n\tltdot: '\\u22D6',\n\tlthree: '\\u22CB',\n\tltimes: '\\u22C9',\n\tltlarr: '\\u2976',\n\tltquest: '\\u2A7B',\n\tltri: '\\u25C3',\n\tltrie: '\\u22B4',\n\tltrif: '\\u25C2',\n\tltrPar: '\\u2996',\n\tlurdshar: '\\u294A',\n\tluruhar: '\\u2966',\n\tlvertneqq: '\\u2268\\uFE00',\n\tlvnE: '\\u2268\\uFE00',\n\tmacr: '\\u00AF',\n\tmale: '\\u2642',\n\tmalt: '\\u2720',\n\tmaltese: '\\u2720',\n\tMap: '\\u2905',\n\tmap: '\\u21A6',\n\tmapsto: '\\u21A6',\n\tmapstodown: '\\u21A7',\n\tmapstoleft: '\\u21A4',\n\tmapstoup: '\\u21A5',\n\tmarker: '\\u25AE',\n\tmcomma: '\\u2A29',\n\tMcy: '\\u041C',\n\tmcy: '\\u043C',\n\tmdash: '\\u2014',\n\tmDDot: '\\u223A',\n\tmeasuredangle: '\\u2221',\n\tMediumSpace: '\\u205F',\n\tMellintrf: '\\u2133',\n\tMfr: '\\uD835\\uDD10',\n\tmfr: '\\uD835\\uDD2A',\n\tmho: '\\u2127',\n\tmicro: '\\u00B5',\n\tmid: '\\u2223',\n\tmidast: '\\u002A',\n\tmidcir: '\\u2AF0',\n\tmiddot: '\\u00B7',\n\tminus: '\\u2212',\n\tminusb: '\\u229F',\n\tminusd: '\\u2238',\n\tminusdu: '\\u2A2A',\n\tMinusPlus: '\\u2213',\n\tmlcp: '\\u2ADB',\n\tmldr: '\\u2026',\n\tmnplus: '\\u2213',\n\tmodels: '\\u22A7',\n\tMopf: '\\uD835\\uDD44',\n\tmopf: '\\uD835\\uDD5E',\n\tmp: '\\u2213',\n\tMscr: '\\u2133',\n\tmscr: '\\uD835\\uDCC2',\n\tmstpos: '\\u223E',\n\tMu: '\\u039C',\n\tmu: '\\u03BC',\n\tmultimap: '\\u22B8',\n\tmumap: '\\u22B8',\n\tnabla: '\\u2207',\n\tNacute: '\\u0143',\n\tnacute: '\\u0144',\n\tnang: '\\u2220\\u20D2',\n\tnap: '\\u2249',\n\tnapE: '\\u2A70\\u0338',\n\tnapid: '\\u224B\\u0338',\n\tnapos: '\\u0149',\n\tnapprox: '\\u2249',\n\tnatur: '\\u266E',\n\tnatural: '\\u266E',\n\tnaturals: '\\u2115',\n\tnbsp: '\\u00A0',\n\tnbump: '\\u224E\\u0338',\n\tnbumpe: '\\u224F\\u0338',\n\tncap: '\\u2A43',\n\tNcaron: '\\u0147',\n\tncaron: '\\u0148',\n\tNcedil: '\\u0145',\n\tncedil: '\\u0146',\n\tncong: '\\u2247',\n\tncongdot: '\\u2A6D\\u0338',\n\tncup: '\\u2A42',\n\tNcy: '\\u041D',\n\tncy: '\\u043D',\n\tndash: '\\u2013',\n\tne: '\\u2260',\n\tnearhk: '\\u2924',\n\tneArr: '\\u21D7',\n\tnearr: '\\u2197',\n\tnearrow: '\\u2197',\n\tnedot: '\\u2250\\u0338',\n\tNegativeMediumSpace: '\\u200B',\n\tNegativeThickSpace: '\\u200B',\n\tNegativeThinSpace: '\\u200B',\n\tNegativeVeryThinSpace: '\\u200B',\n\tnequiv: '\\u2262',\n\tnesear: '\\u2928',\n\tnesim: '\\u2242\\u0338',\n\tNestedGreaterGreater: '\\u226B',\n\tNestedLessLess: '\\u226A',\n\tNewLine: '\\u000A',\n\tnexist: '\\u2204',\n\tnexists: '\\u2204',\n\tNfr: '\\uD835\\uDD11',\n\tnfr: '\\uD835\\uDD2B',\n\tngE: '\\u2267\\u0338',\n\tnge: '\\u2271',\n\tngeq: '\\u2271',\n\tngeqq: '\\u2267\\u0338',\n\tngeqslant: '\\u2A7E\\u0338',\n\tnges: '\\u2A7E\\u0338',\n\tnGg: '\\u22D9\\u0338',\n\tngsim: '\\u2275',\n\tnGt: '\\u226B\\u20D2',\n\tngt: '\\u226F',\n\tngtr: '\\u226F',\n\tnGtv: '\\u226B\\u0338',\n\tnhArr: '\\u21CE',\n\tnharr: '\\u21AE',\n\tnhpar: '\\u2AF2',\n\tni: '\\u220B',\n\tnis: '\\u22FC',\n\tnisd: '\\u22FA',\n\tniv: '\\u220B',\n\tNJcy: '\\u040A',\n\tnjcy: '\\u045A',\n\tnlArr: '\\u21CD',\n\tnlarr: '\\u219A',\n\tnldr: '\\u2025',\n\tnlE: '\\u2266\\u0338',\n\tnle: '\\u2270',\n\tnLeftarrow: '\\u21CD',\n\tnleftarrow: '\\u219A',\n\tnLeftrightarrow: '\\u21CE',\n\tnleftrightarrow: '\\u21AE',\n\tnleq: '\\u2270',\n\tnleqq: '\\u2266\\u0338',\n\tnleqslant: '\\u2A7D\\u0338',\n\tnles: '\\u2A7D\\u0338',\n\tnless: '\\u226E',\n\tnLl: '\\u22D8\\u0338',\n\tnlsim: '\\u2274',\n\tnLt: '\\u226A\\u20D2',\n\tnlt: '\\u226E',\n\tnltri: '\\u22EA',\n\tnltrie: '\\u22EC',\n\tnLtv: '\\u226A\\u0338',\n\tnmid: '\\u2224',\n\tNoBreak: '\\u2060',\n\tNonBreakingSpace: '\\u00A0',\n\tNopf: '\\u2115',\n\tnopf: '\\uD835\\uDD5F',\n\tNot: '\\u2AEC',\n\tnot: '\\u00AC',\n\tNotCongruent: '\\u2262',\n\tNotCupCap: '\\u226D',\n\tNotDoubleVerticalBar: '\\u2226',\n\tNotElement: '\\u2209',\n\tNotEqual: '\\u2260',\n\tNotEqualTilde: '\\u2242\\u0338',\n\tNotExists: '\\u2204',\n\tNotGreater: '\\u226F',\n\tNotGreaterEqual: '\\u2271',\n\tNotGreaterFullEqual: '\\u2267\\u0338',\n\tNotGreaterGreater: '\\u226B\\u0338',\n\tNotGreaterLess: '\\u2279',\n\tNotGreaterSlantEqual: '\\u2A7E\\u0338',\n\tNotGreaterTilde: '\\u2275',\n\tNotHumpDownHump: '\\u224E\\u0338',\n\tNotHumpEqual: '\\u224F\\u0338',\n\tnotin: '\\u2209',\n\tnotindot: '\\u22F5\\u0338',\n\tnotinE: '\\u22F9\\u0338',\n\tnotinva: '\\u2209',\n\tnotinvb: '\\u22F7',\n\tnotinvc: '\\u22F6',\n\tNotLeftTriangle: '\\u22EA',\n\tNotLeftTriangleBar: '\\u29CF\\u0338',\n\tNotLeftTriangleEqual: '\\u22EC',\n\tNotLess: '\\u226E',\n\tNotLessEqual: '\\u2270',\n\tNotLessGreater: '\\u2278',\n\tNotLessLess: '\\u226A\\u0338',\n\tNotLessSlantEqual: '\\u2A7D\\u0338',\n\tNotLessTilde: '\\u2274',\n\tNotNestedGreaterGreater: '\\u2AA2\\u0338',\n\tNotNestedLessLess: '\\u2AA1\\u0338',\n\tnotni: '\\u220C',\n\tnotniva: '\\u220C',\n\tnotnivb: '\\u22FE',\n\tnotnivc: '\\u22FD',\n\tNotPrecedes: '\\u2280',\n\tNotPrecedesEqual: '\\u2AAF\\u0338',\n\tNotPrecedesSlantEqual: '\\u22E0',\n\tNotReverseElement: '\\u220C',\n\tNotRightTriangle: '\\u22EB',\n\tNotRightTriangleBar: '\\u29D0\\u0338',\n\tNotRightTriangleEqual: '\\u22ED',\n\tNotSquareSubset: '\\u228F\\u0338',\n\tNotSquareSubsetEqual: '\\u22E2',\n\tNotSquareSuperset: '\\u2290\\u0338',\n\tNotSquareSupersetEqual: '\\u22E3',\n\tNotSubset: '\\u2282\\u20D2',\n\tNotSubsetEqual: '\\u2288',\n\tNotSucceeds: '\\u2281',\n\tNotSucceedsEqual: '\\u2AB0\\u0338',\n\tNotSucceedsSlantEqual: '\\u22E1',\n\tNotSucceedsTilde: '\\u227F\\u0338',\n\tNotSuperset: '\\u2283\\u20D2',\n\tNotSupersetEqual: '\\u2289',\n\tNotTilde: '\\u2241',\n\tNotTildeEqual: '\\u2244',\n\tNotTildeFullEqual: '\\u2247',\n\tNotTildeTilde: '\\u2249',\n\tNotVerticalBar: '\\u2224',\n\tnpar: '\\u2226',\n\tnparallel: '\\u2226',\n\tnparsl: '\\u2AFD\\u20E5',\n\tnpart: '\\u2202\\u0338',\n\tnpolint: '\\u2A14',\n\tnpr: '\\u2280',\n\tnprcue: '\\u22E0',\n\tnpre: '\\u2AAF\\u0338',\n\tnprec: '\\u2280',\n\tnpreceq: '\\u2AAF\\u0338',\n\tnrArr: '\\u21CF',\n\tnrarr: '\\u219B',\n\tnrarrc: '\\u2933\\u0338',\n\tnrarrw: '\\u219D\\u0338',\n\tnRightarrow: '\\u21CF',\n\tnrightarrow: '\\u219B',\n\tnrtri: '\\u22EB',\n\tnrtrie: '\\u22ED',\n\tnsc: '\\u2281',\n\tnsccue: '\\u22E1',\n\tnsce: '\\u2AB0\\u0338',\n\tNscr: '\\uD835\\uDCA9',\n\tnscr: '\\uD835\\uDCC3',\n\tnshortmid: '\\u2224',\n\tnshortparallel: '\\u2226',\n\tnsim: '\\u2241',\n\tnsime: '\\u2244',\n\tnsimeq: '\\u2244',\n\tnsmid: '\\u2224',\n\tnspar: '\\u2226',\n\tnsqsube: '\\u22E2',\n\tnsqsupe: '\\u22E3',\n\tnsub: '\\u2284',\n\tnsubE: '\\u2AC5\\u0338',\n\tnsube: '\\u2288',\n\tnsubset: '\\u2282\\u20D2',\n\tnsubseteq: '\\u2288',\n\tnsubseteqq: '\\u2AC5\\u0338',\n\tnsucc: '\\u2281',\n\tnsucceq: '\\u2AB0\\u0338',\n\tnsup: '\\u2285',\n\tnsupE: '\\u2AC6\\u0338',\n\tnsupe: '\\u2289',\n\tnsupset: '\\u2283\\u20D2',\n\tnsupseteq: '\\u2289',\n\tnsupseteqq: '\\u2AC6\\u0338',\n\tntgl: '\\u2279',\n\tNtilde: '\\u00D1',\n\tntilde: '\\u00F1',\n\tntlg: '\\u2278',\n\tntriangleleft: '\\u22EA',\n\tntrianglelefteq: '\\u22EC',\n\tntriangleright: '\\u22EB',\n\tntrianglerighteq: '\\u22ED',\n\tNu: '\\u039D',\n\tnu: '\\u03BD',\n\tnum: '\\u0023',\n\tnumero: '\\u2116',\n\tnumsp: '\\u2007',\n\tnvap: '\\u224D\\u20D2',\n\tnVDash: '\\u22AF',\n\tnVdash: '\\u22AE',\n\tnvDash: '\\u22AD',\n\tnvdash: '\\u22AC',\n\tnvge: '\\u2265\\u20D2',\n\tnvgt: '\\u003E\\u20D2',\n\tnvHarr: '\\u2904',\n\tnvinfin: '\\u29DE',\n\tnvlArr: '\\u2902',\n\tnvle: '\\u2264\\u20D2',\n\tnvlt: '\\u003C\\u20D2',\n\tnvltrie: '\\u22B4\\u20D2',\n\tnvrArr: '\\u2903',\n\tnvrtrie: '\\u22B5\\u20D2',\n\tnvsim: '\\u223C\\u20D2',\n\tnwarhk: '\\u2923',\n\tnwArr: '\\u21D6',\n\tnwarr: '\\u2196',\n\tnwarrow: '\\u2196',\n\tnwnear: '\\u2927',\n\tOacute: '\\u00D3',\n\toacute: '\\u00F3',\n\toast: '\\u229B',\n\tocir: '\\u229A',\n\tOcirc: '\\u00D4',\n\tocirc: '\\u00F4',\n\tOcy: '\\u041E',\n\tocy: '\\u043E',\n\todash: '\\u229D',\n\tOdblac: '\\u0150',\n\todblac: '\\u0151',\n\todiv: '\\u2A38',\n\todot: '\\u2299',\n\todsold: '\\u29BC',\n\tOElig: '\\u0152',\n\toelig: '\\u0153',\n\tofcir: '\\u29BF',\n\tOfr: '\\uD835\\uDD12',\n\tofr: '\\uD835\\uDD2C',\n\togon: '\\u02DB',\n\tOgrave: '\\u00D2',\n\tograve: '\\u00F2',\n\togt: '\\u29C1',\n\tohbar: '\\u29B5',\n\tohm: '\\u03A9',\n\toint: '\\u222E',\n\tolarr: '\\u21BA',\n\tolcir: '\\u29BE',\n\tolcross: '\\u29BB',\n\toline: '\\u203E',\n\tolt: '\\u29C0',\n\tOmacr: '\\u014C',\n\tomacr: '\\u014D',\n\tOmega: '\\u03A9',\n\tomega: '\\u03C9',\n\tOmicron: '\\u039F',\n\tomicron: '\\u03BF',\n\tomid: '\\u29B6',\n\tominus: '\\u2296',\n\tOopf: '\\uD835\\uDD46',\n\toopf: '\\uD835\\uDD60',\n\topar: '\\u29B7',\n\tOpenCurlyDoubleQuote: '\\u201C',\n\tOpenCurlyQuote: '\\u2018',\n\toperp: '\\u29B9',\n\toplus: '\\u2295',\n\tOr: '\\u2A54',\n\tor: '\\u2228',\n\torarr: '\\u21BB',\n\tord: '\\u2A5D',\n\torder: '\\u2134',\n\torderof: '\\u2134',\n\tordf: '\\u00AA',\n\tordm: '\\u00BA',\n\torigof: '\\u22B6',\n\toror: '\\u2A56',\n\torslope: '\\u2A57',\n\torv: '\\u2A5B',\n\toS: '\\u24C8',\n\tOscr: '\\uD835\\uDCAA',\n\toscr: '\\u2134',\n\tOslash: '\\u00D8',\n\toslash: '\\u00F8',\n\tosol: '\\u2298',\n\tOtilde: '\\u00D5',\n\totilde: '\\u00F5',\n\tOtimes: '\\u2A37',\n\totimes: '\\u2297',\n\totimesas: '\\u2A36',\n\tOuml: '\\u00D6',\n\touml: '\\u00F6',\n\tovbar: '\\u233D',\n\tOverBar: '\\u203E',\n\tOverBrace: '\\u23DE',\n\tOverBracket: '\\u23B4',\n\tOverParenthesis: '\\u23DC',\n\tpar: '\\u2225',\n\tpara: '\\u00B6',\n\tparallel: '\\u2225',\n\tparsim: '\\u2AF3',\n\tparsl: '\\u2AFD',\n\tpart: '\\u2202',\n\tPartialD: '\\u2202',\n\tPcy: '\\u041F',\n\tpcy: '\\u043F',\n\tpercnt: '\\u0025',\n\tperiod: '\\u002E',\n\tpermil: '\\u2030',\n\tperp: '\\u22A5',\n\tpertenk: '\\u2031',\n\tPfr: '\\uD835\\uDD13',\n\tpfr: '\\uD835\\uDD2D',\n\tPhi: '\\u03A6',\n\tphi: '\\u03C6',\n\tphiv: '\\u03D5',\n\tphmmat: '\\u2133',\n\tphone: '\\u260E',\n\tPi: '\\u03A0',\n\tpi: '\\u03C0',\n\tpitchfork: '\\u22D4',\n\tpiv: '\\u03D6',\n\tplanck: '\\u210F',\n\tplanckh: '\\u210E',\n\tplankv: '\\u210F',\n\tplus: '\\u002B',\n\tplusacir: '\\u2A23',\n\tplusb: '\\u229E',\n\tpluscir: '\\u2A22',\n\tplusdo: '\\u2214',\n\tplusdu: '\\u2A25',\n\tpluse: '\\u2A72',\n\tPlusMinus: '\\u00B1',\n\tplusmn: '\\u00B1',\n\tplussim: '\\u2A26',\n\tplustwo: '\\u2A27',\n\tpm: '\\u00B1',\n\tPoincareplane: '\\u210C',\n\tpointint: '\\u2A15',\n\tPopf: '\\u2119',\n\tpopf: '\\uD835\\uDD61',\n\tpound: '\\u00A3',\n\tPr: '\\u2ABB',\n\tpr: '\\u227A',\n\tprap: '\\u2AB7',\n\tprcue: '\\u227C',\n\tprE: '\\u2AB3',\n\tpre: '\\u2AAF',\n\tprec: '\\u227A',\n\tprecapprox: '\\u2AB7',\n\tpreccurlyeq: '\\u227C',\n\tPrecedes: '\\u227A',\n\tPrecedesEqual: '\\u2AAF',\n\tPrecedesSlantEqual: '\\u227C',\n\tPrecedesTilde: '\\u227E',\n\tpreceq: '\\u2AAF',\n\tprecnapprox: '\\u2AB9',\n\tprecneqq: '\\u2AB5',\n\tprecnsim: '\\u22E8',\n\tprecsim: '\\u227E',\n\tPrime: '\\u2033',\n\tprime: '\\u2032',\n\tprimes: '\\u2119',\n\tprnap: '\\u2AB9',\n\tprnE: '\\u2AB5',\n\tprnsim: '\\u22E8',\n\tprod: '\\u220F',\n\tProduct: '\\u220F',\n\tprofalar: '\\u232E',\n\tprofline: '\\u2312',\n\tprofsurf: '\\u2313',\n\tprop: '\\u221D',\n\tProportion: '\\u2237',\n\tProportional: '\\u221D',\n\tpropto: '\\u221D',\n\tprsim: '\\u227E',\n\tprurel: '\\u22B0',\n\tPscr: '\\uD835\\uDCAB',\n\tpscr: '\\uD835\\uDCC5',\n\tPsi: '\\u03A8',\n\tpsi: '\\u03C8',\n\tpuncsp: '\\u2008',\n\tQfr: '\\uD835\\uDD14',\n\tqfr: '\\uD835\\uDD2E',\n\tqint: '\\u2A0C',\n\tQopf: '\\u211A',\n\tqopf: '\\uD835\\uDD62',\n\tqprime: '\\u2057',\n\tQscr: '\\uD835\\uDCAC',\n\tqscr: '\\uD835\\uDCC6',\n\tquaternions: '\\u210D',\n\tquatint: '\\u2A16',\n\tquest: '\\u003F',\n\tquesteq: '\\u225F',\n\tQUOT: '\\u0022',\n\tquot: '\\u0022',\n\trAarr: '\\u21DB',\n\trace: '\\u223D\\u0331',\n\tRacute: '\\u0154',\n\tracute: '\\u0155',\n\tradic: '\\u221A',\n\traemptyv: '\\u29B3',\n\tRang: '\\u27EB',\n\trang: '\\u27E9',\n\trangd: '\\u2992',\n\trange: '\\u29A5',\n\trangle: '\\u27E9',\n\traquo: '\\u00BB',\n\tRarr: '\\u21A0',\n\trArr: '\\u21D2',\n\trarr: '\\u2192',\n\trarrap: '\\u2975',\n\trarrb: '\\u21E5',\n\trarrbfs: '\\u2920',\n\trarrc: '\\u2933',\n\trarrfs: '\\u291E',\n\trarrhk: '\\u21AA',\n\trarrlp: '\\u21AC',\n\trarrpl: '\\u2945',\n\trarrsim: '\\u2974',\n\tRarrtl: '\\u2916',\n\trarrtl: '\\u21A3',\n\trarrw: '\\u219D',\n\trAtail: '\\u291C',\n\tratail: '\\u291A',\n\tratio: '\\u2236',\n\trationals: '\\u211A',\n\tRBarr: '\\u2910',\n\trBarr: '\\u290F',\n\trbarr: '\\u290D',\n\trbbrk: '\\u2773',\n\trbrace: '\\u007D',\n\trbrack: '\\u005D',\n\trbrke: '\\u298C',\n\trbrksld: '\\u298E',\n\trbrkslu: '\\u2990',\n\tRcaron: '\\u0158',\n\trcaron: '\\u0159',\n\tRcedil: '\\u0156',\n\trcedil: '\\u0157',\n\trceil: '\\u2309',\n\trcub: '\\u007D',\n\tRcy: '\\u0420',\n\trcy: '\\u0440',\n\trdca: '\\u2937',\n\trdldhar: '\\u2969',\n\trdquo: '\\u201D',\n\trdquor: '\\u201D',\n\trdsh: '\\u21B3',\n\tRe: '\\u211C',\n\treal: '\\u211C',\n\trealine: '\\u211B',\n\trealpart: '\\u211C',\n\treals: '\\u211D',\n\trect: '\\u25AD',\n\tREG: '\\u00AE',\n\treg: '\\u00AE',\n\tReverseElement: '\\u220B',\n\tReverseEquilibrium: '\\u21CB',\n\tReverseUpEquilibrium: '\\u296F',\n\trfisht: '\\u297D',\n\trfloor: '\\u230B',\n\tRfr: '\\u211C',\n\trfr: '\\uD835\\uDD2F',\n\trHar: '\\u2964',\n\trhard: '\\u21C1',\n\trharu: '\\u21C0',\n\trharul: '\\u296C',\n\tRho: '\\u03A1',\n\trho: '\\u03C1',\n\trhov: '\\u03F1',\n\tRightAngleBracket: '\\u27E9',\n\tRightArrow: '\\u2192',\n\tRightarrow: '\\u21D2',\n\trightarrow: '\\u2192',\n\tRightArrowBar: '\\u21E5',\n\tRightArrowLeftArrow: '\\u21C4',\n\trightarrowtail: '\\u21A3',\n\tRightCeiling: '\\u2309',\n\tRightDoubleBracket: '\\u27E7',\n\tRightDownTeeVector: '\\u295D',\n\tRightDownVector: '\\u21C2',\n\tRightDownVectorBar: '\\u2955',\n\tRightFloor: '\\u230B',\n\trightharpoondown: '\\u21C1',\n\trightharpoonup: '\\u21C0',\n\trightleftarrows: '\\u21C4',\n\trightleftharpoons: '\\u21CC',\n\trightrightarrows: '\\u21C9',\n\trightsquigarrow: '\\u219D',\n\tRightTee: '\\u22A2',\n\tRightTeeArrow: '\\u21A6',\n\tRightTeeVector: '\\u295B',\n\trightthreetimes: '\\u22CC',\n\tRightTriangle: '\\u22B3',\n\tRightTriangleBar: '\\u29D0',\n\tRightTriangleEqual: '\\u22B5',\n\tRightUpDownVector: '\\u294F',\n\tRightUpTeeVector: '\\u295C',\n\tRightUpVector: '\\u21BE',\n\tRightUpVectorBar: '\\u2954',\n\tRightVector: '\\u21C0',\n\tRightVectorBar: '\\u2953',\n\tring: '\\u02DA',\n\trisingdotseq: '\\u2253',\n\trlarr: '\\u21C4',\n\trlhar: '\\u21CC',\n\trlm: '\\u200F',\n\trmoust: '\\u23B1',\n\trmoustache: '\\u23B1',\n\trnmid: '\\u2AEE',\n\troang: '\\u27ED',\n\troarr: '\\u21FE',\n\trobrk: '\\u27E7',\n\tropar: '\\u2986',\n\tRopf: '\\u211D',\n\tropf: '\\uD835\\uDD63',\n\troplus: '\\u2A2E',\n\trotimes: '\\u2A35',\n\tRoundImplies: '\\u2970',\n\trpar: '\\u0029',\n\trpargt: '\\u2994',\n\trppolint: '\\u2A12',\n\trrarr: '\\u21C9',\n\tRrightarrow: '\\u21DB',\n\trsaquo: '\\u203A',\n\tRscr: '\\u211B',\n\trscr: '\\uD835\\uDCC7',\n\tRsh: '\\u21B1',\n\trsh: '\\u21B1',\n\trsqb: '\\u005D',\n\trsquo: '\\u2019',\n\trsquor: '\\u2019',\n\trthree: '\\u22CC',\n\trtimes: '\\u22CA',\n\trtri: '\\u25B9',\n\trtrie: '\\u22B5',\n\trtrif: '\\u25B8',\n\trtriltri: '\\u29CE',\n\tRuleDelayed: '\\u29F4',\n\truluhar: '\\u2968',\n\trx: '\\u211E',\n\tSacute: '\\u015A',\n\tsacute: '\\u015B',\n\tsbquo: '\\u201A',\n\tSc: '\\u2ABC',\n\tsc: '\\u227B',\n\tscap: '\\u2AB8',\n\tScaron: '\\u0160',\n\tscaron: '\\u0161',\n\tsccue: '\\u227D',\n\tscE: '\\u2AB4',\n\tsce: '\\u2AB0',\n\tScedil: '\\u015E',\n\tscedil: '\\u015F',\n\tScirc: '\\u015C',\n\tscirc: '\\u015D',\n\tscnap: '\\u2ABA',\n\tscnE: '\\u2AB6',\n\tscnsim: '\\u22E9',\n\tscpolint: '\\u2A13',\n\tscsim: '\\u227F',\n\tScy: '\\u0421',\n\tscy: '\\u0441',\n\tsdot: '\\u22C5',\n\tsdotb: '\\u22A1',\n\tsdote: '\\u2A66',\n\tsearhk: '\\u2925',\n\tseArr: '\\u21D8',\n\tsearr: '\\u2198',\n\tsearrow: '\\u2198',\n\tsect: '\\u00A7',\n\tsemi: '\\u003B',\n\tseswar: '\\u2929',\n\tsetminus: '\\u2216',\n\tsetmn: '\\u2216',\n\tsext: '\\u2736',\n\tSfr: '\\uD835\\uDD16',\n\tsfr: '\\uD835\\uDD30',\n\tsfrown: '\\u2322',\n\tsharp: '\\u266F',\n\tSHCHcy: '\\u0429',\n\tshchcy: '\\u0449',\n\tSHcy: '\\u0428',\n\tshcy: '\\u0448',\n\tShortDownArrow: '\\u2193',\n\tShortLeftArrow: '\\u2190',\n\tshortmid: '\\u2223',\n\tshortparallel: '\\u2225',\n\tShortRightArrow: '\\u2192',\n\tShortUpArrow: '\\u2191',\n\tshy: '\\u00AD',\n\tSigma: '\\u03A3',\n\tsigma: '\\u03C3',\n\tsigmaf: '\\u03C2',\n\tsigmav: '\\u03C2',\n\tsim: '\\u223C',\n\tsimdot: '\\u2A6A',\n\tsime: '\\u2243',\n\tsimeq: '\\u2243',\n\tsimg: '\\u2A9E',\n\tsimgE: '\\u2AA0',\n\tsiml: '\\u2A9D',\n\tsimlE: '\\u2A9F',\n\tsimne: '\\u2246',\n\tsimplus: '\\u2A24',\n\tsimrarr: '\\u2972',\n\tslarr: '\\u2190',\n\tSmallCircle: '\\u2218',\n\tsmallsetminus: '\\u2216',\n\tsmashp: '\\u2A33',\n\tsmeparsl: '\\u29E4',\n\tsmid: '\\u2223',\n\tsmile: '\\u2323',\n\tsmt: '\\u2AAA',\n\tsmte: '\\u2AAC',\n\tsmtes: '\\u2AAC\\uFE00',\n\tSOFTcy: '\\u042C',\n\tsoftcy: '\\u044C',\n\tsol: '\\u002F',\n\tsolb: '\\u29C4',\n\tsolbar: '\\u233F',\n\tSopf: '\\uD835\\uDD4A',\n\tsopf: '\\uD835\\uDD64',\n\tspades: '\\u2660',\n\tspadesuit: '\\u2660',\n\tspar: '\\u2225',\n\tsqcap: '\\u2293',\n\tsqcaps: '\\u2293\\uFE00',\n\tsqcup: '\\u2294',\n\tsqcups: '\\u2294\\uFE00',\n\tSqrt: '\\u221A',\n\tsqsub: '\\u228F',\n\tsqsube: '\\u2291',\n\tsqsubset: '\\u228F',\n\tsqsubseteq: '\\u2291',\n\tsqsup: '\\u2290',\n\tsqsupe: '\\u2292',\n\tsqsupset: '\\u2290',\n\tsqsupseteq: '\\u2292',\n\tsqu: '\\u25A1',\n\tSquare: '\\u25A1',\n\tsquare: '\\u25A1',\n\tSquareIntersection: '\\u2293',\n\tSquareSubset: '\\u228F',\n\tSquareSubsetEqual: '\\u2291',\n\tSquareSuperset: '\\u2290',\n\tSquareSupersetEqual: '\\u2292',\n\tSquareUnion: '\\u2294',\n\tsquarf: '\\u25AA',\n\tsquf: '\\u25AA',\n\tsrarr: '\\u2192',\n\tSscr: '\\uD835\\uDCAE',\n\tsscr: '\\uD835\\uDCC8',\n\tssetmn: '\\u2216',\n\tssmile: '\\u2323',\n\tsstarf: '\\u22C6',\n\tStar: '\\u22C6',\n\tstar: '\\u2606',\n\tstarf: '\\u2605',\n\tstraightepsilon: '\\u03F5',\n\tstraightphi: '\\u03D5',\n\tstrns: '\\u00AF',\n\tSub: '\\u22D0',\n\tsub: '\\u2282',\n\tsubdot: '\\u2ABD',\n\tsubE: '\\u2AC5',\n\tsube: '\\u2286',\n\tsubedot: '\\u2AC3',\n\tsubmult: '\\u2AC1',\n\tsubnE: '\\u2ACB',\n\tsubne: '\\u228A',\n\tsubplus: '\\u2ABF',\n\tsubrarr: '\\u2979',\n\tSubset: '\\u22D0',\n\tsubset: '\\u2282',\n\tsubseteq: '\\u2286',\n\tsubseteqq: '\\u2AC5',\n\tSubsetEqual: '\\u2286',\n\tsubsetneq: '\\u228A',\n\tsubsetneqq: '\\u2ACB',\n\tsubsim: '\\u2AC7',\n\tsubsub: '\\u2AD5',\n\tsubsup: '\\u2AD3',\n\tsucc: '\\u227B',\n\tsuccapprox: '\\u2AB8',\n\tsucccurlyeq: '\\u227D',\n\tSucceeds: '\\u227B',\n\tSucceedsEqual: '\\u2AB0',\n\tSucceedsSlantEqual: '\\u227D',\n\tSucceedsTilde: '\\u227F',\n\tsucceq: '\\u2AB0',\n\tsuccnapprox: '\\u2ABA',\n\tsuccneqq: '\\u2AB6',\n\tsuccnsim: '\\u22E9',\n\tsuccsim: '\\u227F',\n\tSuchThat: '\\u220B',\n\tSum: '\\u2211',\n\tsum: '\\u2211',\n\tsung: '\\u266A',\n\tSup: '\\u22D1',\n\tsup: '\\u2283',\n\tsup1: '\\u00B9',\n\tsup2: '\\u00B2',\n\tsup3: '\\u00B3',\n\tsupdot: '\\u2ABE',\n\tsupdsub: '\\u2AD8',\n\tsupE: '\\u2AC6',\n\tsupe: '\\u2287',\n\tsupedot: '\\u2AC4',\n\tSuperset: '\\u2283',\n\tSupersetEqual: '\\u2287',\n\tsuphsol: '\\u27C9',\n\tsuphsub: '\\u2AD7',\n\tsuplarr: '\\u297B',\n\tsupmult: '\\u2AC2',\n\tsupnE: '\\u2ACC',\n\tsupne: '\\u228B',\n\tsupplus: '\\u2AC0',\n\tSupset: '\\u22D1',\n\tsupset: '\\u2283',\n\tsupseteq: '\\u2287',\n\tsupseteqq: '\\u2AC6',\n\tsupsetneq: '\\u228B',\n\tsupsetneqq: '\\u2ACC',\n\tsupsim: '\\u2AC8',\n\tsupsub: '\\u2AD4',\n\tsupsup: '\\u2AD6',\n\tswarhk: '\\u2926',\n\tswArr: '\\u21D9',\n\tswarr: '\\u2199',\n\tswarrow: '\\u2199',\n\tswnwar: '\\u292A',\n\tszlig: '\\u00DF',\n\tTab: '\\u0009',\n\ttarget: '\\u2316',\n\tTau: '\\u03A4',\n\ttau: '\\u03C4',\n\ttbrk: '\\u23B4',\n\tTcaron: '\\u0164',\n\ttcaron: '\\u0165',\n\tTcedil: '\\u0162',\n\ttcedil: '\\u0163',\n\tTcy: '\\u0422',\n\ttcy: '\\u0442',\n\ttdot: '\\u20DB',\n\ttelrec: '\\u2315',\n\tTfr: '\\uD835\\uDD17',\n\ttfr: '\\uD835\\uDD31',\n\tthere4: '\\u2234',\n\tTherefore: '\\u2234',\n\ttherefore: '\\u2234',\n\tTheta: '\\u0398',\n\ttheta: '\\u03B8',\n\tthetasym: '\\u03D1',\n\tthetav: '\\u03D1',\n\tthickapprox: '\\u2248',\n\tthicksim: '\\u223C',\n\tThickSpace: '\\u205F\\u200A',\n\tthinsp: '\\u2009',\n\tThinSpace: '\\u2009',\n\tthkap: '\\u2248',\n\tthksim: '\\u223C',\n\tTHORN: '\\u00DE',\n\tthorn: '\\u00FE',\n\tTilde: '\\u223C',\n\ttilde: '\\u02DC',\n\tTildeEqual: '\\u2243',\n\tTildeFullEqual: '\\u2245',\n\tTildeTilde: '\\u2248',\n\ttimes: '\\u00D7',\n\ttimesb: '\\u22A0',\n\ttimesbar: '\\u2A31',\n\ttimesd: '\\u2A30',\n\ttint: '\\u222D',\n\ttoea: '\\u2928',\n\ttop: '\\u22A4',\n\ttopbot: '\\u2336',\n\ttopcir: '\\u2AF1',\n\tTopf: '\\uD835\\uDD4B',\n\ttopf: '\\uD835\\uDD65',\n\ttopfork: '\\u2ADA',\n\ttosa: '\\u2929',\n\ttprime: '\\u2034',\n\tTRADE: '\\u2122',\n\ttrade: '\\u2122',\n\ttriangle: '\\u25B5',\n\ttriangledown: '\\u25BF',\n\ttriangleleft: '\\u25C3',\n\ttrianglelefteq: '\\u22B4',\n\ttriangleq: '\\u225C',\n\ttriangleright: '\\u25B9',\n\ttrianglerighteq: '\\u22B5',\n\ttridot: '\\u25EC',\n\ttrie: '\\u225C',\n\ttriminus: '\\u2A3A',\n\tTripleDot: '\\u20DB',\n\ttriplus: '\\u2A39',\n\ttrisb: '\\u29CD',\n\ttritime: '\\u2A3B',\n\ttrpezium: '\\u23E2',\n\tTscr: '\\uD835\\uDCAF',\n\ttscr: '\\uD835\\uDCC9',\n\tTScy: '\\u0426',\n\ttscy: '\\u0446',\n\tTSHcy: '\\u040B',\n\ttshcy: '\\u045B',\n\tTstrok: '\\u0166',\n\ttstrok: '\\u0167',\n\ttwixt: '\\u226C',\n\ttwoheadleftarrow: '\\u219E',\n\ttwoheadrightarrow: '\\u21A0',\n\tUacute: '\\u00DA',\n\tuacute: '\\u00FA',\n\tUarr: '\\u219F',\n\tuArr: '\\u21D1',\n\tuarr: '\\u2191',\n\tUarrocir: '\\u2949',\n\tUbrcy: '\\u040E',\n\tubrcy: '\\u045E',\n\tUbreve: '\\u016C',\n\tubreve: '\\u016D',\n\tUcirc: '\\u00DB',\n\tucirc: '\\u00FB',\n\tUcy: '\\u0423',\n\tucy: '\\u0443',\n\tudarr: '\\u21C5',\n\tUdblac: '\\u0170',\n\tudblac: '\\u0171',\n\tudhar: '\\u296E',\n\tufisht: '\\u297E',\n\tUfr: '\\uD835\\uDD18',\n\tufr: '\\uD835\\uDD32',\n\tUgrave: '\\u00D9',\n\tugrave: '\\u00F9',\n\tuHar: '\\u2963',\n\tuharl: '\\u21BF',\n\tuharr: '\\u21BE',\n\tuhblk: '\\u2580',\n\tulcorn: '\\u231C',\n\tulcorner: '\\u231C',\n\tulcrop: '\\u230F',\n\tultri: '\\u25F8',\n\tUmacr: '\\u016A',\n\tumacr: '\\u016B',\n\tuml: '\\u00A8',\n\tUnderBar: '\\u005F',\n\tUnderBrace: '\\u23DF',\n\tUnderBracket: '\\u23B5',\n\tUnderParenthesis: '\\u23DD',\n\tUnion: '\\u22C3',\n\tUnionPlus: '\\u228E',\n\tUogon: '\\u0172',\n\tuogon: '\\u0173',\n\tUopf: '\\uD835\\uDD4C',\n\tuopf: '\\uD835\\uDD66',\n\tUpArrow: '\\u2191',\n\tUparrow: '\\u21D1',\n\tuparrow: '\\u2191',\n\tUpArrowBar: '\\u2912',\n\tUpArrowDownArrow: '\\u21C5',\n\tUpDownArrow: '\\u2195',\n\tUpdownarrow: '\\u21D5',\n\tupdownarrow: '\\u2195',\n\tUpEquilibrium: '\\u296E',\n\tupharpoonleft: '\\u21BF',\n\tupharpoonright: '\\u21BE',\n\tuplus: '\\u228E',\n\tUpperLeftArrow: '\\u2196',\n\tUpperRightArrow: '\\u2197',\n\tUpsi: '\\u03D2',\n\tupsi: '\\u03C5',\n\tupsih: '\\u03D2',\n\tUpsilon: '\\u03A5',\n\tupsilon: '\\u03C5',\n\tUpTee: '\\u22A5',\n\tUpTeeArrow: '\\u21A5',\n\tupuparrows: '\\u21C8',\n\turcorn: '\\u231D',\n\turcorner: '\\u231D',\n\turcrop: '\\u230E',\n\tUring: '\\u016E',\n\turing: '\\u016F',\n\turtri: '\\u25F9',\n\tUscr: '\\uD835\\uDCB0',\n\tuscr: '\\uD835\\uDCCA',\n\tutdot: '\\u22F0',\n\tUtilde: '\\u0168',\n\tutilde: '\\u0169',\n\tutri: '\\u25B5',\n\tutrif: '\\u25B4',\n\tuuarr: '\\u21C8',\n\tUuml: '\\u00DC',\n\tuuml: '\\u00FC',\n\tuwangle: '\\u29A7',\n\tvangrt: '\\u299C',\n\tvarepsilon: '\\u03F5',\n\tvarkappa: '\\u03F0',\n\tvarnothing: '\\u2205',\n\tvarphi: '\\u03D5',\n\tvarpi: '\\u03D6',\n\tvarpropto: '\\u221D',\n\tvArr: '\\u21D5',\n\tvarr: '\\u2195',\n\tvarrho: '\\u03F1',\n\tvarsigma: '\\u03C2',\n\tvarsubsetneq: '\\u228A\\uFE00',\n\tvarsubsetneqq: '\\u2ACB\\uFE00',\n\tvarsupsetneq: '\\u228B\\uFE00',\n\tvarsupsetneqq: '\\u2ACC\\uFE00',\n\tvartheta: '\\u03D1',\n\tvartriangleleft: '\\u22B2',\n\tvartriangleright: '\\u22B3',\n\tVbar: '\\u2AEB',\n\tvBar: '\\u2AE8',\n\tvBarv: '\\u2AE9',\n\tVcy: '\\u0412',\n\tvcy: '\\u0432',\n\tVDash: '\\u22AB',\n\tVdash: '\\u22A9',\n\tvDash: '\\u22A8',\n\tvdash: '\\u22A2',\n\tVdashl: '\\u2AE6',\n\tVee: '\\u22C1',\n\tvee: '\\u2228',\n\tveebar: '\\u22BB',\n\tveeeq: '\\u225A',\n\tvellip: '\\u22EE',\n\tVerbar: '\\u2016',\n\tverbar: '\\u007C',\n\tVert: '\\u2016',\n\tvert: '\\u007C',\n\tVerticalBar: '\\u2223',\n\tVerticalLine: '\\u007C',\n\tVerticalSeparator: '\\u2758',\n\tVerticalTilde: '\\u2240',\n\tVeryThinSpace: '\\u200A',\n\tVfr: '\\uD835\\uDD19',\n\tvfr: '\\uD835\\uDD33',\n\tvltri: '\\u22B2',\n\tvnsub: '\\u2282\\u20D2',\n\tvnsup: '\\u2283\\u20D2',\n\tVopf: '\\uD835\\uDD4D',\n\tvopf: '\\uD835\\uDD67',\n\tvprop: '\\u221D',\n\tvrtri: '\\u22B3',\n\tVscr: '\\uD835\\uDCB1',\n\tvscr: '\\uD835\\uDCCB',\n\tvsubnE: '\\u2ACB\\uFE00',\n\tvsubne: '\\u228A\\uFE00',\n\tvsupnE: '\\u2ACC\\uFE00',\n\tvsupne: '\\u228B\\uFE00',\n\tVvdash: '\\u22AA',\n\tvzigzag: '\\u299A',\n\tWcirc: '\\u0174',\n\twcirc: '\\u0175',\n\twedbar: '\\u2A5F',\n\tWedge: '\\u22C0',\n\twedge: '\\u2227',\n\twedgeq: '\\u2259',\n\tweierp: '\\u2118',\n\tWfr: '\\uD835\\uDD1A',\n\twfr: '\\uD835\\uDD34',\n\tWopf: '\\uD835\\uDD4E',\n\twopf: '\\uD835\\uDD68',\n\twp: '\\u2118',\n\twr: '\\u2240',\n\twreath: '\\u2240',\n\tWscr: '\\uD835\\uDCB2',\n\twscr: '\\uD835\\uDCCC',\n\txcap: '\\u22C2',\n\txcirc: '\\u25EF',\n\txcup: '\\u22C3',\n\txdtri: '\\u25BD',\n\tXfr: '\\uD835\\uDD1B',\n\txfr: '\\uD835\\uDD35',\n\txhArr: '\\u27FA',\n\txharr: '\\u27F7',\n\tXi: '\\u039E',\n\txi: '\\u03BE',\n\txlArr: '\\u27F8',\n\txlarr: '\\u27F5',\n\txmap: '\\u27FC',\n\txnis: '\\u22FB',\n\txodot: '\\u2A00',\n\tXopf: '\\uD835\\uDD4F',\n\txopf: '\\uD835\\uDD69',\n\txoplus: '\\u2A01',\n\txotime: '\\u2A02',\n\txrArr: '\\u27F9',\n\txrarr: '\\u27F6',\n\tXscr: '\\uD835\\uDCB3',\n\txscr: '\\uD835\\uDCCD',\n\txsqcup: '\\u2A06',\n\txuplus: '\\u2A04',\n\txutri: '\\u25B3',\n\txvee: '\\u22C1',\n\txwedge: '\\u22C0',\n\tYacute: '\\u00DD',\n\tyacute: '\\u00FD',\n\tYAcy: '\\u042F',\n\tyacy: '\\u044F',\n\tYcirc: '\\u0176',\n\tycirc: '\\u0177',\n\tYcy: '\\u042B',\n\tycy: '\\u044B',\n\tyen: '\\u00A5',\n\tYfr: '\\uD835\\uDD1C',\n\tyfr: '\\uD835\\uDD36',\n\tYIcy: '\\u0407',\n\tyicy: '\\u0457',\n\tYopf: '\\uD835\\uDD50',\n\tyopf: '\\uD835\\uDD6A',\n\tYscr: '\\uD835\\uDCB4',\n\tyscr: '\\uD835\\uDCCE',\n\tYUcy: '\\u042E',\n\tyucy: '\\u044E',\n\tYuml: '\\u0178',\n\tyuml: '\\u00FF',\n\tZacute: '\\u0179',\n\tzacute: '\\u017A',\n\tZcaron: '\\u017D',\n\tzcaron: '\\u017E',\n\tZcy: '\\u0417',\n\tzcy: '\\u0437',\n\tZdot: '\\u017B',\n\tzdot: '\\u017C',\n\tzeetrf: '\\u2128',\n\tZeroWidthSpace: '\\u200B',\n\tZeta: '\\u0396',\n\tzeta: '\\u03B6',\n\tZfr: '\\u2128',\n\tzfr: '\\uD835\\uDD37',\n\tZHcy: '\\u0416',\n\tzhcy: '\\u0436',\n\tzigrarr: '\\u21DD',\n\tZopf: '\\u2124',\n\tzopf: '\\uD835\\uDD6B',\n\tZscr: '\\uD835\\uDCB5',\n\tzscr: '\\uD835\\uDCCF',\n\tzwj: '\\u200D',\n\tzwnj: '\\u200C',\n});\n\n/**\n * @deprecated use `HTML_ENTITIES` instead\n * @see HTML_ENTITIES\n */\nexports.entityMap = exports.HTML_ENTITIES;\n","var NAMESPACE = require(\"./conventions\").NAMESPACE;\n\n//[4] \tNameStartChar\t ::= \t\":\" | [A-Z] | \"_\" | [a-z] | [#xC0-#xD6] | [#xD8-#xF6] | [#xF8-#x2FF] | [#x370-#x37D] | [#x37F-#x1FFF] | [#x200C-#x200D] | [#x2070-#x218F] | [#x2C00-#x2FEF] | [#x3001-#xD7FF] | [#xF900-#xFDCF] | [#xFDF0-#xFFFD] | [#x10000-#xEFFFF]\n//[4a] \tNameChar\t ::= \tNameStartChar | \"-\" | \".\" | [0-9] | #xB7 | [#x0300-#x036F] | [#x203F-#x2040]\n//[5] \tName\t ::= \tNameStartChar (NameChar)*\nvar nameStartChar = /[A-Z_a-z\\xC0-\\xD6\\xD8-\\xF6\\u00F8-\\u02FF\\u0370-\\u037D\\u037F-\\u1FFF\\u200C-\\u200D\\u2070-\\u218F\\u2C00-\\u2FEF\\u3001-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFFD]///\\u10000-\\uEFFFF\nvar nameChar = new RegExp(\"[\\\\-\\\\.0-9\"+nameStartChar.source.slice(1,-1)+\"\\\\u00B7\\\\u0300-\\\\u036F\\\\u203F-\\\\u2040]\");\nvar tagNamePattern = new RegExp('^'+nameStartChar.source+nameChar.source+'*(?:\\:'+nameStartChar.source+nameChar.source+'*)?$');\n//var tagNamePattern = /^[a-zA-Z_][\\w\\-\\.]*(?:\\:[a-zA-Z_][\\w\\-\\.]*)?$/\n//var handlers = 'resolveEntity,getExternalSubset,characters,endDocument,endElement,endPrefixMapping,ignorableWhitespace,processingInstruction,setDocumentLocator,skippedEntity,startDocument,startElement,startPrefixMapping,notationDecl,unparsedEntityDecl,error,fatalError,warning,attributeDecl,elementDecl,externalEntityDecl,internalEntityDecl,comment,endCDATA,endDTD,endEntity,startCDATA,startDTD,startEntity'.split(',')\n\n//S_TAG,\tS_ATTR,\tS_EQ,\tS_ATTR_NOQUOT_VALUE\n//S_ATTR_SPACE,\tS_ATTR_END,\tS_TAG_SPACE, S_TAG_CLOSE\nvar S_TAG = 0;//tag name offerring\nvar S_ATTR = 1;//attr name offerring\nvar S_ATTR_SPACE=2;//attr name end and space offer\nvar S_EQ = 3;//=space?\nvar S_ATTR_NOQUOT_VALUE = 4;//attr value(no quot value only)\nvar S_ATTR_END = 5;//attr value end and no space(quot end)\nvar S_TAG_SPACE = 6;//(attr value end || tag end ) && (space offer)\nvar S_TAG_CLOSE = 7;//closed el\n\n/**\n * Creates an error that will not be caught by XMLReader aka the SAX parser.\n *\n * @param {string} message\n * @param {any?} locator Optional, can provide details about the location in the source\n * @constructor\n */\nfunction ParseError(message, locator) {\n\tthis.message = message\n\tthis.locator = locator\n\tif(Error.captureStackTrace) Error.captureStackTrace(this, ParseError);\n}\nParseError.prototype = new Error();\nParseError.prototype.name = ParseError.name\n\nfunction XMLReader(){\n\n}\n\nXMLReader.prototype = {\n\tparse:function(source,defaultNSMap,entityMap){\n\t\tvar domBuilder = this.domBuilder;\n\t\tdomBuilder.startDocument();\n\t\t_copy(defaultNSMap ,defaultNSMap = {})\n\t\tparse(source,defaultNSMap,entityMap,\n\t\t\t\tdomBuilder,this.errorHandler);\n\t\tdomBuilder.endDocument();\n\t}\n}\nfunction parse(source,defaultNSMapCopy,entityMap,domBuilder,errorHandler){\n\tfunction fixedFromCharCode(code) {\n\t\t// String.prototype.fromCharCode does not supports\n\t\t// > 2 bytes unicode chars directly\n\t\tif (code > 0xffff) {\n\t\t\tcode -= 0x10000;\n\t\t\tvar surrogate1 = 0xd800 + (code >> 10)\n\t\t\t\t, surrogate2 = 0xdc00 + (code & 0x3ff);\n\n\t\t\treturn String.fromCharCode(surrogate1, surrogate2);\n\t\t} else {\n\t\t\treturn String.fromCharCode(code);\n\t\t}\n\t}\n\tfunction entityReplacer(a){\n\t\tvar k = a.slice(1,-1);\n\t\tif (Object.hasOwnProperty.call(entityMap, k)) {\n\t\t\treturn entityMap[k];\n\t\t}else if(k.charAt(0) === '#'){\n\t\t\treturn fixedFromCharCode(parseInt(k.substr(1).replace('x','0x')))\n\t\t}else{\n\t\t\terrorHandler.error('entity not found:'+a);\n\t\t\treturn a;\n\t\t}\n\t}\n\tfunction appendText(end){//has some bugs\n\t\tif(end>start){\n\t\t\tvar xt = source.substring(start,end).replace(/?\\w+;/g,entityReplacer);\n\t\t\tlocator&&position(start);\n\t\t\tdomBuilder.characters(xt,0,end-start);\n\t\t\tstart = end\n\t\t}\n\t}\n\tfunction position(p,m){\n\t\twhile(p>=lineEnd && (m = linePattern.exec(source))){\n\t\t\tlineStart = m.index;\n\t\t\tlineEnd = lineStart + m[0].length;\n\t\t\tlocator.lineNumber++;\n\t\t\t//console.log('line++:',locator,startPos,endPos)\n\t\t}\n\t\tlocator.columnNumber = p-lineStart+1;\n\t}\n\tvar lineStart = 0;\n\tvar lineEnd = 0;\n\tvar linePattern = /.*(?:\\r\\n?|\\n)|.*$/g\n\tvar locator = domBuilder.locator;\n\n\tvar parseStack = [{currentNSMap:defaultNSMapCopy}]\n\tvar closeMap = {};\n\tvar start = 0;\n\twhile(true){\n\t\ttry{\n\t\t\tvar tagStart = source.indexOf('<',start);\n\t\t\tif(tagStart<0){\n\t\t\t\tif(!source.substr(start).match(/^\\s*$/)){\n\t\t\t\t\tvar doc = domBuilder.doc;\n\t \t\t\tvar text = doc.createTextNode(source.substr(start));\n\t \t\t\tdoc.appendChild(text);\n\t \t\t\tdomBuilder.currentElement = text;\n\t\t\t\t}\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tif(tagStart>start){\n\t\t\t\tappendText(tagStart);\n\t\t\t}\n\t\t\tswitch(source.charAt(tagStart+1)){\n\t\t\tcase '/':\n\t\t\t\tvar end = source.indexOf('>',tagStart+3);\n\t\t\t\tvar tagName = source.substring(tagStart + 2, end).replace(/[ \\t\\n\\r]+$/g, '');\n\t\t\t\tvar config = parseStack.pop();\n\t\t\t\tif(end<0){\n\n\t \t\ttagName = source.substring(tagStart+2).replace(/[\\s<].*/,'');\n\t \t\terrorHandler.error(\"end tag name: \"+tagName+' is not complete:'+config.tagName);\n\t \t\tend = tagStart+1+tagName.length;\n\t \t}else if(tagName.match(/\\s)){\n\t \t\ttagName = tagName.replace(/[\\s<].*/,'');\n\t \t\terrorHandler.error(\"end tag name: \"+tagName+' maybe not complete');\n\t \t\tend = tagStart+1+tagName.length;\n\t\t\t\t}\n\t\t\t\tvar localNSMap = config.localNSMap;\n\t\t\t\tvar endMatch = config.tagName == tagName;\n\t\t\t\tvar endIgnoreCaseMach = endMatch || config.tagName&&config.tagName.toLowerCase() == tagName.toLowerCase()\n\t\t if(endIgnoreCaseMach){\n\t\t \tdomBuilder.endElement(config.uri,config.localName,tagName);\n\t\t\t\t\tif(localNSMap){\n\t\t\t\t\t\tfor (var prefix in localNSMap) {\n\t\t\t\t\t\t\tif (Object.prototype.hasOwnProperty.call(localNSMap, prefix)) {\n\t\t\t\t\t\t\t\tdomBuilder.endPrefixMapping(prefix);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tif(!endMatch){\n\t\t \terrorHandler.fatalError(\"end tag name: \"+tagName+' is not match the current start tagName:'+config.tagName ); // No known test case\n\t\t\t\t\t}\n\t\t }else{\n\t\t \tparseStack.push(config)\n\t\t }\n\n\t\t\t\tend++;\n\t\t\t\tbreak;\n\t\t\t\t// end elment\n\t\t\tcase '?':// ...?>\n\t\t\t\tlocator&&position(tagStart);\n\t\t\t\tend = parseInstruction(source,tagStart,domBuilder);\n\t\t\t\tbreak;\n\t\t\tcase '!':// start){\n\t\t\tstart = end;\n\t\t}else{\n\t\t\t//TODO: 这里有可能sax回退,有位置错误风险\n\t\t\tappendText(Math.max(tagStart,start)+1);\n\t\t}\n\t}\n}\nfunction copyLocator(f,t){\n\tt.lineNumber = f.lineNumber;\n\tt.columnNumber = f.columnNumber;\n\treturn t;\n}\n\n/**\n * @see #appendElement(source,elStartEnd,el,selfClosed,entityReplacer,domBuilder,parseStack);\n * @return end of the elementStartPart(end of elementEndPart for selfClosed el)\n */\nfunction parseElementStartPart(source,start,el,currentNSMap,entityReplacer,errorHandler){\n\n\t/**\n\t * @param {string} qname\n\t * @param {string} value\n\t * @param {number} startIndex\n\t */\n\tfunction addAttribute(qname, value, startIndex) {\n\t\tif (el.attributeNames.hasOwnProperty(qname)) {\n\t\t\terrorHandler.fatalError('Attribute ' + qname + ' redefined')\n\t\t}\n\t\tel.addValue(\n\t\t\tqname,\n\t\t\t// @see https://www.w3.org/TR/xml/#AVNormalize\n\t\t\t// since the xmldom sax parser does not \"interpret\" DTD the following is not implemented:\n\t\t\t// - recursive replacement of (DTD) entity references\n\t\t\t// - trimming and collapsing multiple spaces into a single one for attributes that are not of type CDATA\n\t\t\tvalue.replace(/[\\t\\n\\r]/g, ' ').replace(/?\\w+;/g, entityReplacer),\n\t\t\tstartIndex\n\t\t)\n\t}\n\tvar attrName;\n\tvar value;\n\tvar p = ++start;\n\tvar s = S_TAG;//status\n\twhile(true){\n\t\tvar c = source.charAt(p);\n\t\tswitch(c){\n\t\tcase '=':\n\t\t\tif(s === S_ATTR){//attrName\n\t\t\t\tattrName = source.slice(start,p);\n\t\t\t\ts = S_EQ;\n\t\t\t}else if(s === S_ATTR_SPACE){\n\t\t\t\ts = S_EQ;\n\t\t\t}else{\n\t\t\t\t//fatalError: equal must after attrName or space after attrName\n\t\t\t\tthrow new Error('attribute equal must after attrName'); // No known test case\n\t\t\t}\n\t\t\tbreak;\n\t\tcase '\\'':\n\t\tcase '\"':\n\t\t\tif(s === S_EQ || s === S_ATTR //|| s == S_ATTR_SPACE\n\t\t\t\t){//equal\n\t\t\t\tif(s === S_ATTR){\n\t\t\t\t\terrorHandler.warning('attribute value must after \"=\"')\n\t\t\t\t\tattrName = source.slice(start,p)\n\t\t\t\t}\n\t\t\t\tstart = p+1;\n\t\t\t\tp = source.indexOf(c,start)\n\t\t\t\tif(p>0){\n\t\t\t\t\tvalue = source.slice(start, p);\n\t\t\t\t\taddAttribute(attrName, value, start-1);\n\t\t\t\t\ts = S_ATTR_END;\n\t\t\t\t}else{\n\t\t\t\t\t//fatalError: no end quot match\n\t\t\t\t\tthrow new Error('attribute value no end \\''+c+'\\' match');\n\t\t\t\t}\n\t\t\t}else if(s == S_ATTR_NOQUOT_VALUE){\n\t\t\t\tvalue = source.slice(start, p);\n\t\t\t\taddAttribute(attrName, value, start);\n\t\t\t\terrorHandler.warning('attribute \"'+attrName+'\" missed start quot('+c+')!!');\n\t\t\t\tstart = p+1;\n\t\t\t\ts = S_ATTR_END\n\t\t\t}else{\n\t\t\t\t//fatalError: no equal before\n\t\t\t\tthrow new Error('attribute value must after \"=\"'); // No known test case\n\t\t\t}\n\t\t\tbreak;\n\t\tcase '/':\n\t\t\tswitch(s){\n\t\t\tcase S_TAG:\n\t\t\t\tel.setTagName(source.slice(start,p));\n\t\t\tcase S_ATTR_END:\n\t\t\tcase S_TAG_SPACE:\n\t\t\tcase S_TAG_CLOSE:\n\t\t\t\ts =S_TAG_CLOSE;\n\t\t\t\tel.closed = true;\n\t\t\tcase S_ATTR_NOQUOT_VALUE:\n\t\t\tcase S_ATTR:\n\t\t\t\tbreak;\n\t\t\t\tcase S_ATTR_SPACE:\n\t\t\t\t\tel.closed = true;\n\t\t\t\tbreak;\n\t\t\t//case S_EQ:\n\t\t\tdefault:\n\t\t\t\tthrow new Error(\"attribute invalid close char('/')\") // No known test case\n\t\t\t}\n\t\t\tbreak;\n\t\tcase ''://end document\n\t\t\terrorHandler.error('unexpected end of input');\n\t\t\tif(s == S_TAG){\n\t\t\t\tel.setTagName(source.slice(start,p));\n\t\t\t}\n\t\t\treturn p;\n\t\tcase '>':\n\t\t\tswitch(s){\n\t\t\tcase S_TAG:\n\t\t\t\tel.setTagName(source.slice(start,p));\n\t\t\tcase S_ATTR_END:\n\t\t\tcase S_TAG_SPACE:\n\t\t\tcase S_TAG_CLOSE:\n\t\t\t\tbreak;//normal\n\t\t\tcase S_ATTR_NOQUOT_VALUE://Compatible state\n\t\t\tcase S_ATTR:\n\t\t\t\tvalue = source.slice(start,p);\n\t\t\t\tif(value.slice(-1) === '/'){\n\t\t\t\t\tel.closed = true;\n\t\t\t\t\tvalue = value.slice(0,-1)\n\t\t\t\t}\n\t\t\tcase S_ATTR_SPACE:\n\t\t\t\tif(s === S_ATTR_SPACE){\n\t\t\t\t\tvalue = attrName;\n\t\t\t\t}\n\t\t\t\tif(s == S_ATTR_NOQUOT_VALUE){\n\t\t\t\t\terrorHandler.warning('attribute \"'+value+'\" missed quot(\")!');\n\t\t\t\t\taddAttribute(attrName, value, start)\n\t\t\t\t}else{\n\t\t\t\t\tif(!NAMESPACE.isHTML(currentNSMap['']) || !value.match(/^(?:disabled|checked|selected)$/i)){\n\t\t\t\t\t\terrorHandler.warning('attribute \"'+value+'\" missed value!! \"'+value+'\" instead!!')\n\t\t\t\t\t}\n\t\t\t\t\taddAttribute(value, value, start)\n\t\t\t\t}\n\t\t\t\tbreak;\n\t\t\tcase S_EQ:\n\t\t\t\tthrow new Error('attribute value missed!!');\n\t\t\t}\n//\t\t\tconsole.log(tagName,tagNamePattern,tagNamePattern.test(tagName))\n\t\t\treturn p;\n\t\t/*xml space '\\x20' | #x9 | #xD | #xA; */\n\t\tcase '\\u0080':\n\t\t\tc = ' ';\n\t\tdefault:\n\t\t\tif(c<= ' '){//space\n\t\t\t\tswitch(s){\n\t\t\t\tcase S_TAG:\n\t\t\t\t\tel.setTagName(source.slice(start,p));//tagName\n\t\t\t\t\ts = S_TAG_SPACE;\n\t\t\t\t\tbreak;\n\t\t\t\tcase S_ATTR:\n\t\t\t\t\tattrName = source.slice(start,p)\n\t\t\t\t\ts = S_ATTR_SPACE;\n\t\t\t\t\tbreak;\n\t\t\t\tcase S_ATTR_NOQUOT_VALUE:\n\t\t\t\t\tvar value = source.slice(start, p);\n\t\t\t\t\terrorHandler.warning('attribute \"'+value+'\" missed quot(\")!!');\n\t\t\t\t\taddAttribute(attrName, value, start)\n\t\t\t\tcase S_ATTR_END:\n\t\t\t\t\ts = S_TAG_SPACE;\n\t\t\t\t\tbreak;\n\t\t\t\t//case S_TAG_SPACE:\n\t\t\t\t//case S_EQ:\n\t\t\t\t//case S_ATTR_SPACE:\n\t\t\t\t//\tvoid();break;\n\t\t\t\t//case S_TAG_CLOSE:\n\t\t\t\t\t//ignore warning\n\t\t\t\t}\n\t\t\t}else{//not space\n//S_TAG,\tS_ATTR,\tS_EQ,\tS_ATTR_NOQUOT_VALUE\n//S_ATTR_SPACE,\tS_ATTR_END,\tS_TAG_SPACE, S_TAG_CLOSE\n\t\t\t\tswitch(s){\n\t\t\t\t//case S_TAG:void();break;\n\t\t\t\t//case S_ATTR:void();break;\n\t\t\t\t//case S_ATTR_NOQUOT_VALUE:void();break;\n\t\t\t\tcase S_ATTR_SPACE:\n\t\t\t\t\tvar tagName = el.tagName;\n\t\t\t\t\tif (!NAMESPACE.isHTML(currentNSMap['']) || !attrName.match(/^(?:disabled|checked|selected)$/i)) {\n\t\t\t\t\t\terrorHandler.warning('attribute \"'+attrName+'\" missed value!! \"'+attrName+'\" instead2!!')\n\t\t\t\t\t}\n\t\t\t\t\taddAttribute(attrName, attrName, start);\n\t\t\t\t\tstart = p;\n\t\t\t\t\ts = S_ATTR;\n\t\t\t\t\tbreak;\n\t\t\t\tcase S_ATTR_END:\n\t\t\t\t\terrorHandler.warning('attribute space is required\"'+attrName+'\"!!')\n\t\t\t\tcase S_TAG_SPACE:\n\t\t\t\t\ts = S_ATTR;\n\t\t\t\t\tstart = p;\n\t\t\t\t\tbreak;\n\t\t\t\tcase S_EQ:\n\t\t\t\t\ts = S_ATTR_NOQUOT_VALUE;\n\t\t\t\t\tstart = p;\n\t\t\t\t\tbreak;\n\t\t\t\tcase S_TAG_CLOSE:\n\t\t\t\t\tthrow new Error(\"elements closed character '/' and '>' must be connected to\");\n\t\t\t\t}\n\t\t\t}\n\t\t}//end outer switch\n\t\t//console.log('p++',p)\n\t\tp++;\n\t}\n}\n/**\n * @return true if has new namespace define\n */\nfunction appendElement(el,domBuilder,currentNSMap){\n\tvar tagName = el.tagName;\n\tvar localNSMap = null;\n\t//var currentNSMap = parseStack[parseStack.length-1].currentNSMap;\n\tvar i = el.length;\n\twhile(i--){\n\t\tvar a = el[i];\n\t\tvar qName = a.qName;\n\t\tvar value = a.value;\n\t\tvar nsp = qName.indexOf(':');\n\t\tif(nsp>0){\n\t\t\tvar prefix = a.prefix = qName.slice(0,nsp);\n\t\t\tvar localName = qName.slice(nsp+1);\n\t\t\tvar nsPrefix = prefix === 'xmlns' && localName\n\t\t}else{\n\t\t\tlocalName = qName;\n\t\t\tprefix = null\n\t\t\tnsPrefix = qName === 'xmlns' && ''\n\t\t}\n\t\t//can not set prefix,because prefix !== ''\n\t\ta.localName = localName ;\n\t\t//prefix == null for no ns prefix attribute\n\t\tif(nsPrefix !== false){//hack!!\n\t\t\tif(localNSMap == null){\n\t\t\t\tlocalNSMap = {}\n\t\t\t\t//console.log(currentNSMap,0)\n\t\t\t\t_copy(currentNSMap,currentNSMap={})\n\t\t\t\t//console.log(currentNSMap,1)\n\t\t\t}\n\t\t\tcurrentNSMap[nsPrefix] = localNSMap[nsPrefix] = value;\n\t\t\ta.uri = NAMESPACE.XMLNS\n\t\t\tdomBuilder.startPrefixMapping(nsPrefix, value)\n\t\t}\n\t}\n\tvar i = el.length;\n\twhile(i--){\n\t\ta = el[i];\n\t\tvar prefix = a.prefix;\n\t\tif(prefix){//no prefix attribute has no namespace\n\t\t\tif(prefix === 'xml'){\n\t\t\t\ta.uri = NAMESPACE.XML;\n\t\t\t}if(prefix !== 'xmlns'){\n\t\t\t\ta.uri = currentNSMap[prefix || '']\n\n\t\t\t\t//{console.log('###'+a.qName,domBuilder.locator.systemId+'',currentNSMap,a.uri)}\n\t\t\t}\n\t\t}\n\t}\n\tvar nsp = tagName.indexOf(':');\n\tif(nsp>0){\n\t\tprefix = el.prefix = tagName.slice(0,nsp);\n\t\tlocalName = el.localName = tagName.slice(nsp+1);\n\t}else{\n\t\tprefix = null;//important!!\n\t\tlocalName = el.localName = tagName;\n\t}\n\t//no prefix element has default namespace\n\tvar ns = el.uri = currentNSMap[prefix || ''];\n\tdomBuilder.startElement(ns,localName,tagName,el);\n\t//endPrefixMapping and startPrefixMapping have not any help for dom builder\n\t//localNSMap = null\n\tif(el.closed){\n\t\tdomBuilder.endElement(ns,localName,tagName);\n\t\tif(localNSMap){\n\t\t\tfor (prefix in localNSMap) {\n\t\t\t\tif (Object.prototype.hasOwnProperty.call(localNSMap, prefix)) {\n\t\t\t\t\tdomBuilder.endPrefixMapping(prefix);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}else{\n\t\tel.currentNSMap = currentNSMap;\n\t\tel.localNSMap = localNSMap;\n\t\t//parseStack.push(el);\n\t\treturn true;\n\t}\n}\nfunction parseHtmlSpecialContent(source,elStartEnd,tagName,entityReplacer,domBuilder){\n\tif(/^(?:script|textarea)$/i.test(tagName)){\n\t\tvar elEndStart = source.indexOf(''+tagName+'>',elStartEnd);\n\t\tvar text = source.substring(elStartEnd+1,elEndStart);\n\t\tif(/[&<]/.test(text)){\n\t\t\tif(/^script$/i.test(tagName)){\n\t\t\t\t//if(!/\\]\\]>/.test(text)){\n\t\t\t\t\t//lexHandler.startCDATA();\n\t\t\t\t\tdomBuilder.characters(text,0,text.length);\n\t\t\t\t\t//lexHandler.endCDATA();\n\t\t\t\t\treturn elEndStart;\n\t\t\t\t//}\n\t\t\t}//}else{//text area\n\t\t\t\ttext = text.replace(/?\\w+;/g,entityReplacer);\n\t\t\t\tdomBuilder.characters(text,0,text.length);\n\t\t\t\treturn elEndStart;\n\t\t\t//}\n\n\t\t}\n\t}\n\treturn elStartEnd+1;\n}\nfunction fixSelfClosed(source,elStartEnd,tagName,closeMap){\n\t//if(tagName in closeMap){\n\tvar pos = closeMap[tagName];\n\tif(pos == null){\n\t\t//console.log(tagName)\n\t\tpos = source.lastIndexOf(''+tagName+'>')\n\t\tif(pos',start+4);\n\t\t\t//append comment source.substring(4,end)//