@github/copilot 0.0.349-6 → 0.0.349-7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (2) hide show
  1. package/index.js +2 -2
  2. package/package.json +2 -2
package/index.js CHANGED
@@ -2389,7 +2389,7 @@ ${this.escapeXml(this.secretFilter.filterSecrets(l.trim()))}
2389
2389
  `)[0],J=H.match(cTn)?.[0]??"";switch(Ve._free(n),y){case nY.Syntax:throw new wme(nY.Syntax,{suffix:`${w}: '${H}'...`},w,0);case nY.NodeName:throw new wme(y,{word:J},w,J.length);case nY.FieldName:throw new wme(y,{word:J},w,J.length);case nY.CaptureName:throw new wme(y,{word:J},w,J.length);case nY.PatternStructure:throw new wme(y,{suffix:`${w}: '${H}'...`},w,0)}}let I=Ve._ts_query_string_count(r),a=Ve._ts_query_capture_count(r),s=Ve._ts_query_pattern_count(r),o=new Array(a),d=new Array(s),u=new Array(I);for(let y=0;y<a;y++){let Y=Ve._ts_query_capture_name_for_id(r,y,er),w=Ve.getValue(er,"i32");o[y]=Ve.UTF8ToString(Y,w)}for(let y=0;y<s;y++){let Y=new Array(a);for(let w=0;w<a;w++){let H=Ve._ts_query_capture_quantifier_for_id(r,y,w);Y[w]=H}d[y]=Y}for(let y=0;y<I;y++){let Y=Ve._ts_query_string_value_for_id(r,y,er),w=Ve.getValue(er,"i32");u[y]=Ve.UTF8ToString(Y,w)}let b=new Array(s),p=new Array(s),h=new Array(s),Z=new Array(s),N=new Array(s);for(let y=0;y<s;y++){let Y=Ve._ts_query_predicates_for_pattern(r,y,er),w=Ve.getValue(er,"i32");Z[y]=[],N[y]=[];let H=new Array,J=Y;for(let S=0;S<w;S++){let T=Ve.getValue(J,"i32");J+=ur;let U=Ve.getValue(J,"i32");J+=ur,zal(y,T,U,o,u,H,N,Z,b,p,h)}Object.freeze(N[y]),Object.freeze(Z[y]),Object.freeze(b[y]),Object.freeze(p[y]),Object.freeze(h[y])}Ve._free(n),this[0]=r,this.captureNames=o,this.captureQuantifiers=d,this.textPredicates=N,this.predicates=Z,this.setProperties=b,this.assertedProperties=p,this.refutedProperties=h,this.exceededMatchLimit=!1}delete(){Ve._ts_query_delete(this[0]),this[0]=0}matches(t,e={}){let l=e.startPosition??ZL,n=e.endPosition??ZL,r=e.startIndex??0,I=e.endIndex??0,a=e.matchLimit??4294967295,s=e.maxStartDepth??4294967295,o=e.timeoutMicros??0,d=e.progressCallback;if(typeof a!="number")throw new Error("Arguments must be numbers");if(this.matchLimit=a,I!==0&&r>I)throw new Error("`startIndex` cannot be greater than `endIndex`");if(n!==ZL&&(l.row>n.row||l.row===n.row&&l.column>n.column))throw new Error("`startPosition` cannot be greater than `endPosition`");d&&(Ve.currentQueryProgressCallback=d),UI(t),Ve._ts_query_matches_wasm(this[0],t.tree[0],l.row,l.column,n.row,n.column,r,I,a,s,o);let u=Ve.getValue(er,"i32"),b=Ve.getValue(er+ur,"i32"),p=Ve.getValue(er+2*ur,"i32"),h=new Array(u);this.exceededMatchLimit=!!p;let Z=0,N=b;for(let y=0;y<u;y++){let Y=Ve.getValue(N,"i32");N+=ur;let w=Ve.getValue(N,"i32");N+=ur;let H=new Array(w);if(N=aet(this,t.tree,N,Y,H),this.textPredicates[Y].every(J=>J(H))){h[Z]={pattern:Y,patternIndex:Y,captures:H};let J=this.setProperties[Y];h[Z].setProperties=J;let S=this.assertedProperties[Y];h[Z].assertedProperties=S;let T=this.refutedProperties[Y];h[Z].refutedProperties=T,Z++}}return h.length=Z,Ve._free(b),Ve.currentQueryProgressCallback=null,h}captures(t,e={}){let l=e.startPosition??ZL,n=e.endPosition??ZL,r=e.startIndex??0,I=e.endIndex??0,a=e.matchLimit??4294967295,s=e.maxStartDepth??4294967295,o=e.timeoutMicros??0,d=e.progressCallback;if(typeof a!="number")throw new Error("Arguments must be numbers");if(this.matchLimit=a,I!==0&&r>I)throw new Error("`startIndex` cannot be greater than `endIndex`");if(n!==ZL&&(l.row>n.row||l.row===n.row&&l.column>n.column))throw new Error("`startPosition` cannot be greater than `endPosition`");d&&(Ve.currentQueryProgressCallback=d),UI(t),Ve._ts_query_captures_wasm(this[0],t.tree[0],l.row,l.column,n.row,n.column,r,I,a,s,o);let u=Ve.getValue(er,"i32"),b=Ve.getValue(er+ur,"i32"),p=Ve.getValue(er+2*ur,"i32"),h=new Array;this.exceededMatchLimit=!!p;let Z=new Array,N=b;for(let y=0;y<u;y++){let Y=Ve.getValue(N,"i32");N+=ur;let w=Ve.getValue(N,"i32");N+=ur;let H=Ve.getValue(N,"i32");if(N+=ur,Z.length=w,N=aet(this,t.tree,N,Y,Z),this.textPredicates[Y].every(J=>J(Z))){let J=Z[H],S=this.setProperties[Y];J.setProperties=S;let T=this.assertedProperties[Y];J.assertedProperties=T;let U=this.refutedProperties[Y];J.refutedProperties=U,h.push(J)}}return Ve._free(b),Ve.currentQueryProgressCallback=null,h}predicatesForPattern(t){return this.predicates[t]}disableCapture(t){let e=Ve.lengthBytesUTF8(t),l=Ve._malloc(e+1);Ve.stringToUTF8(t,l,e+1),Ve._ts_query_disable_capture(this[0],l,e),Ve._free(l)}disablePattern(t){if(t>=this.predicates.length)throw new Error(`Pattern index is ${t} but the pattern count is ${this.predicates.length}`);Ve._ts_query_disable_pattern(this[0],t)}didExceedMatchLimit(){return this.exceededMatchLimit}startIndexForPattern(t){if(t>=this.predicates.length)throw new Error(`Pattern index is ${t} but the pattern count is ${this.predicates.length}`);return Ve._ts_query_start_byte_for_pattern(this[0],t)}endIndexForPattern(t){if(t>=this.predicates.length)throw new Error(`Pattern index is ${t} but the pattern count is ${this.predicates.length}`);return Ve._ts_query_end_byte_for_pattern(this[0],t)}patternCount(){return Ve._ts_query_pattern_count(this[0])}captureIndexForName(t){return this.captureNames.indexOf(t)}isPatternRooted(t){return Ve._ts_query_is_pattern_rooted(this[0],t)===1}isPatternNonLocal(t){return Ve._ts_query_is_pattern_non_local(this[0],t)===1}isPatternGuaranteedAtStep(t){return Ve._ts_query_is_pattern_guaranteed_at_step(this[0],t)===1}},uTn=/^tree_sitter_\w+$/,iet=class Pal{static{Nt(this,"Language")}0=0;types;fields;constructor(e,l){Hq(e),this[0]=l,this.types=new Array(Ve._ts_language_symbol_count(this[0]));for(let n=0,r=this.types.length;n<r;n++)Ve._ts_language_symbol_type(this[0],n)<2&&(this.types[n]=Ve.UTF8ToString(Ve._ts_language_symbol_name(this[0],n)));this.fields=new Array(Ve._ts_language_field_count(this[0])+1);for(let n=0,r=this.fields.length;n<r;n++){let I=Ve._ts_language_field_name_for_id(this[0],n);I!==0?this.fields[n]=Ve.UTF8ToString(I):this.fields[n]=null}}get name(){let e=Ve._ts_language_name(this[0]);return e===0?null:Ve.UTF8ToString(e)}get version(){return Ve._ts_language_version(this[0])}get abiVersion(){return Ve._ts_language_abi_version(this[0])}get metadata(){Ve._ts_language_metadata(this[0]);let e=Ve.getValue(er,"i32"),l=Ve.getValue(er+ur,"i32");return e===0?null:Bal(l)}get fieldCount(){return this.fields.length-1}get stateCount(){return Ve._ts_language_state_count(this[0])}fieldIdForName(e){let l=this.fields.indexOf(e);return l!==-1?l:null}fieldNameForId(e){return this.fields[e]??null}idForNodeType(e,l){let n=Ve.lengthBytesUTF8(e),r=Ve._malloc(n+1);Ve.stringToUTF8(e,r,n+1);let I=Ve._ts_language_symbol_for_name(this[0],r,n,l?1:0);return Ve._free(r),I||null}get nodeTypeCount(){return Ve._ts_language_symbol_count(this[0])}nodeTypeForId(e){let l=Ve._ts_language_symbol_name(this[0],e);return l?Ve.UTF8ToString(l):null}nodeTypeIsNamed(e){return!!Ve._ts_language_type_is_named_wasm(this[0],e)}nodeTypeIsVisible(e){return!!Ve._ts_language_type_is_visible_wasm(this[0],e)}get supertypes(){Ve._ts_language_supertypes_wasm(this[0]);let e=Ve.getValue(er,"i32"),l=Ve.getValue(er+ur,"i32"),n=new Array(e);if(e>0){let r=l;for(let I=0;I<e;I++)n[I]=Ve.getValue(r,"i16"),r+=Xal}return n}subtypes(e){Ve._ts_language_subtypes_wasm(this[0],e);let l=Ve.getValue(er,"i32"),n=Ve.getValue(er+ur,"i32"),r=new Array(l);if(l>0){let I=n;for(let a=0;a<l;a++)r[a]=Ve.getValue(I,"i16"),I+=Xal}return r}nextState(e,l){return Ve._ts_language_next_state(this[0],e,l)}lookaheadIterator(e){let l=Ve._ts_lookahead_iterator_new(this[0],e);return l?new rTn(gL,l,this):null}query(e){return console.warn("Language.query is deprecated. Use new Query(language, source) instead."),new dTn(this,e)}static async load(e){let l;e instanceof Uint8Array?l=Promise.resolve(e):globalThis.process?.versions.node?l=(await import("fs/promises")).readFile(e):l=fetch(e).then(s=>s.arrayBuffer().then(o=>{if(s.ok)return new Uint8Array(o);{let d=new TextDecoder("utf-8").decode(o);throw new Error(`Language.load failed with status ${s.status}.
2390
2390
 
2391
2391
  ${d}`)}}));let n=await Ve.loadWebAssemblyModule(await l,{loadAsync:!0}),r=Object.keys(n),I=r.find(s=>uTn.test(s)&&!s.includes("external_scanner_"));if(!I)throw console.log(`Couldn't find language function in WASM file. Symbols:
2392
- ${JSON.stringify(r,null,2)}`),new Error("Language.load failed: no language function found in WASM file");let a=n[I]();return new Pal(gL,a)}},mTn=(()=>{var _scriptName=import.meta.url;return async function(moduleArg={}){var moduleRtn,Module=moduleArg,readyPromiseResolve,readyPromiseReject,readyPromise=new Promise((t,e)=>{readyPromiseResolve=t,readyPromiseReject=e}),ENVIRONMENT_IS_WEB=typeof window=="object",ENVIRONMENT_IS_WORKER=typeof WorkerGlobalScope<"u",ENVIRONMENT_IS_NODE=typeof process=="object"&&typeof process.versions=="object"&&typeof process.versions.node=="string"&&process.type!="renderer",ENVIRONMENT_IS_SHELL=!ENVIRONMENT_IS_WEB&&!ENVIRONMENT_IS_NODE&&!ENVIRONMENT_IS_WORKER;if(ENVIRONMENT_IS_NODE){let{createRequire:t}=await import("module");var require=t(import.meta.url)}Module.currentQueryProgressCallback=null,Module.currentProgressCallback=null,Module.currentLogCallback=null,Module.currentParseCallback=null;var moduleOverrides=Object.assign({},Module),arguments_=[],thisProgram="./this.program",quit_=Nt((t,e)=>{throw e},"quit_"),scriptDirectory="";function locateFile(t){return Module.locateFile?Module.locateFile(t,scriptDirectory):scriptDirectory+t}Nt(locateFile,"locateFile");var readAsync,readBinary;if(ENVIRONMENT_IS_NODE){var fs=require("fs"),nodePath=require("path");import.meta.url.startsWith("data:")||(scriptDirectory=nodePath.dirname(require("url").fileURLToPath(import.meta.url))+"/"),readBinary=Nt(t=>{t=isFileURI(t)?new URL(t):t;var e=fs.readFileSync(t);return e},"readBinary"),readAsync=Nt(async(t,e=!0)=>{t=isFileURI(t)?new URL(t):t;var l=fs.readFileSync(t,e?void 0:"utf8");return l},"readAsync"),!Module.thisProgram&&process.argv.length>1&&(thisProgram=process.argv[1].replace(/\\/g,"/")),arguments_=process.argv.slice(2),quit_=Nt((t,e)=>{throw process.exitCode=t,e},"quit_")}else(ENVIRONMENT_IS_WEB||ENVIRONMENT_IS_WORKER)&&(ENVIRONMENT_IS_WORKER?scriptDirectory=self.location.href:typeof document<"u"&&document.currentScript&&(scriptDirectory=document.currentScript.src),_scriptName&&(scriptDirectory=_scriptName),scriptDirectory.startsWith("blob:")?scriptDirectory="":scriptDirectory=scriptDirectory.slice(0,scriptDirectory.replace(/[?#].*/,"").lastIndexOf("/")+1),ENVIRONMENT_IS_WORKER&&(readBinary=Nt(t=>{var e=new XMLHttpRequest;return e.open("GET",t,!1),e.responseType="arraybuffer",e.send(null),new Uint8Array(e.response)},"readBinary")),readAsync=Nt(async t=>{if(isFileURI(t))return new Promise((l,n)=>{var r=new XMLHttpRequest;r.open("GET",t,!0),r.responseType="arraybuffer",r.onload=()=>{if(r.status==200||r.status==0&&r.response){l(r.response);return}n(r.status)},r.onerror=n,r.send(null)});var e=await fetch(t,{credentials:"same-origin"});if(e.ok)return e.arrayBuffer();throw new Error(e.status+" : "+e.url)},"readAsync"));var out=Module.print||console.log.bind(console),err=Module.printErr||console.error.bind(console);Object.assign(Module,moduleOverrides),moduleOverrides=null,Module.arguments&&(arguments_=Module.arguments),Module.thisProgram&&(thisProgram=Module.thisProgram);var dynamicLibraries=Module.dynamicLibraries||[],wasmBinary=Module.wasmBinary,wasmMemory,ABORT=!1,EXITSTATUS;function assert(t,e){t||abort(e)}Nt(assert,"assert");var HEAP,HEAP8,HEAPU8,HEAP16,HEAPU16,HEAP32,HEAPU32,HEAPF32,HEAP64,HEAPU64,HEAPF64,HEAP_DATA_VIEW,runtimeInitialized=!1,isFileURI=Nt(t=>t.startsWith("file://"),"isFileURI");function updateMemoryViews(){var t=wasmMemory.buffer;Module.HEAP_DATA_VIEW=HEAP_DATA_VIEW=new DataView(t),Module.HEAP8=HEAP8=new Int8Array(t),Module.HEAP16=HEAP16=new Int16Array(t),Module.HEAPU8=HEAPU8=new Uint8Array(t),Module.HEAPU16=HEAPU16=new Uint16Array(t),Module.HEAP32=HEAP32=new Int32Array(t),Module.HEAPU32=HEAPU32=new Uint32Array(t),Module.HEAPF32=HEAPF32=new Float32Array(t),Module.HEAPF64=HEAPF64=new Float64Array(t),Module.HEAP64=HEAP64=new BigInt64Array(t),Module.HEAPU64=HEAPU64=new BigUint64Array(t)}if(Nt(updateMemoryViews,"updateMemoryViews"),Module.wasmMemory)wasmMemory=Module.wasmMemory;else{var INITIAL_MEMORY=Module.INITIAL_MEMORY||33554432;wasmMemory=new WebAssembly.Memory({initial:INITIAL_MEMORY/65536,maximum:32768})}updateMemoryViews();var __RELOC_FUNCS__=[];function preRun(){if(Module.preRun)for(typeof Module.preRun=="function"&&(Module.preRun=[Module.preRun]);Module.preRun.length;)addOnPreRun(Module.preRun.shift());callRuntimeCallbacks(onPreRuns)}Nt(preRun,"preRun");function initRuntime(){runtimeInitialized=!0,callRuntimeCallbacks(__RELOC_FUNCS__),wasmExports.__wasm_call_ctors(),callRuntimeCallbacks(onPostCtors)}Nt(initRuntime,"initRuntime");function preMain(){}Nt(preMain,"preMain");function postRun(){if(Module.postRun)for(typeof Module.postRun=="function"&&(Module.postRun=[Module.postRun]);Module.postRun.length;)addOnPostRun(Module.postRun.shift());callRuntimeCallbacks(onPostRuns)}Nt(postRun,"postRun");var runDependencies=0,dependenciesFulfilled=null;function getUniqueRunDependency(t){return t}Nt(getUniqueRunDependency,"getUniqueRunDependency");function addRunDependency(t){runDependencies++,Module.monitorRunDependencies?.(runDependencies)}Nt(addRunDependency,"addRunDependency");function removeRunDependency(t){if(runDependencies--,Module.monitorRunDependencies?.(runDependencies),runDependencies==0&&dependenciesFulfilled){var e=dependenciesFulfilled;dependenciesFulfilled=null,e()}}Nt(removeRunDependency,"removeRunDependency");function abort(t){Module.onAbort?.(t),t="Aborted("+t+")",err(t),ABORT=!0,t+=". Build with -sASSERTIONS for more info.";var e=new WebAssembly.RuntimeError(t);throw readyPromiseReject(e),e}Nt(abort,"abort");var wasmBinaryFile;function findWasmBinary(){return Module.locateFile?locateFile("tree-sitter.wasm"):new URL("tree-sitter.wasm",import.meta.url).href}Nt(findWasmBinary,"findWasmBinary");function getBinarySync(t){if(t==wasmBinaryFile&&wasmBinary)return new Uint8Array(wasmBinary);if(readBinary)return readBinary(t);throw"both async and sync fetching of the wasm failed"}Nt(getBinarySync,"getBinarySync");async function getWasmBinary(t){if(!wasmBinary)try{var e=await readAsync(t);return new Uint8Array(e)}catch{}return getBinarySync(t)}Nt(getWasmBinary,"getWasmBinary");async function instantiateArrayBuffer(t,e){try{var l=await getWasmBinary(t),n=await WebAssembly.instantiate(l,e);return n}catch(r){err(`failed to asynchronously prepare wasm: ${r}`),abort(r)}}Nt(instantiateArrayBuffer,"instantiateArrayBuffer");async function instantiateAsync(t,e,l){if(!t&&typeof WebAssembly.instantiateStreaming=="function"&&!isFileURI(e)&&!ENVIRONMENT_IS_NODE)try{var n=fetch(e,{credentials:"same-origin"}),r=await WebAssembly.instantiateStreaming(n,l);return r}catch(I){err(`wasm streaming compile failed: ${I}`),err("falling back to ArrayBuffer instantiation")}return instantiateArrayBuffer(e,l)}Nt(instantiateAsync,"instantiateAsync");function getWasmImports(){return{env:wasmImports,wasi_snapshot_preview1:wasmImports,"GOT.mem":new Proxy(wasmImports,GOTHandler),"GOT.func":new Proxy(wasmImports,GOTHandler)}}Nt(getWasmImports,"getWasmImports");async function createWasm(){function t(I,a){wasmExports=I.exports,wasmExports=relocateExports(wasmExports,1024);var s=getDylinkMetadata(a);return s.neededDynlibs&&(dynamicLibraries=s.neededDynlibs.concat(dynamicLibraries)),mergeLibSymbols(wasmExports,"main"),LDSO.init(),loadDylibs(),__RELOC_FUNCS__.push(wasmExports.__wasm_apply_data_relocs),removeRunDependency("wasm-instantiate"),wasmExports}Nt(t,"receiveInstance"),addRunDependency("wasm-instantiate");function e(I){return t(I.instance,I.module)}Nt(e,"receiveInstantiationResult");var l=getWasmImports();if(Module.instantiateWasm)return new Promise((I,a)=>{Module.instantiateWasm(l,(s,o)=>{t(s,o),I(s.exports)})});wasmBinaryFile??=findWasmBinary();try{var n=await instantiateAsync(wasmBinary,wasmBinaryFile,l),r=e(n);return r}catch(I){return readyPromiseReject(I),Promise.reject(I)}}Nt(createWasm,"createWasm");var ASM_CONSTS={};class ExitStatus{static{Nt(this,"ExitStatus")}name="ExitStatus";constructor(e){this.message=`Program terminated with exit(${e})`,this.status=e}}var GOT={},currentModuleWeakSymbols=new Set([]),GOTHandler={get(t,e){var l=GOT[e];return l||(l=GOT[e]=new WebAssembly.Global({value:"i32",mutable:!0})),currentModuleWeakSymbols.has(e)||(l.required=!0),l}},LE_HEAP_LOAD_F32=Nt(t=>HEAP_DATA_VIEW.getFloat32(t,!0),"LE_HEAP_LOAD_F32"),LE_HEAP_LOAD_F64=Nt(t=>HEAP_DATA_VIEW.getFloat64(t,!0),"LE_HEAP_LOAD_F64"),LE_HEAP_LOAD_I16=Nt(t=>HEAP_DATA_VIEW.getInt16(t,!0),"LE_HEAP_LOAD_I16"),LE_HEAP_LOAD_I32=Nt(t=>HEAP_DATA_VIEW.getInt32(t,!0),"LE_HEAP_LOAD_I32"),LE_HEAP_LOAD_U16=Nt(t=>HEAP_DATA_VIEW.getUint16(t,!0),"LE_HEAP_LOAD_U16"),LE_HEAP_LOAD_U32=Nt(t=>HEAP_DATA_VIEW.getUint32(t,!0),"LE_HEAP_LOAD_U32"),LE_HEAP_STORE_F32=Nt((t,e)=>HEAP_DATA_VIEW.setFloat32(t,e,!0),"LE_HEAP_STORE_F32"),LE_HEAP_STORE_F64=Nt((t,e)=>HEAP_DATA_VIEW.setFloat64(t,e,!0),"LE_HEAP_STORE_F64"),LE_HEAP_STORE_I16=Nt((t,e)=>HEAP_DATA_VIEW.setInt16(t,e,!0),"LE_HEAP_STORE_I16"),LE_HEAP_STORE_I32=Nt((t,e)=>HEAP_DATA_VIEW.setInt32(t,e,!0),"LE_HEAP_STORE_I32"),LE_HEAP_STORE_U16=Nt((t,e)=>HEAP_DATA_VIEW.setUint16(t,e,!0),"LE_HEAP_STORE_U16"),LE_HEAP_STORE_U32=Nt((t,e)=>HEAP_DATA_VIEW.setUint32(t,e,!0),"LE_HEAP_STORE_U32"),callRuntimeCallbacks=Nt(t=>{for(;t.length>0;)t.shift()(Module)},"callRuntimeCallbacks"),onPostRuns=[],addOnPostRun=Nt(t=>onPostRuns.unshift(t),"addOnPostRun"),onPreRuns=[],addOnPreRun=Nt(t=>onPreRuns.unshift(t),"addOnPreRun"),UTF8Decoder=typeof TextDecoder<"u"?new TextDecoder:void 0,UTF8ArrayToString=Nt((t,e=0,l=NaN)=>{for(var n=e+l,r=e;t[r]&&!(r>=n);)++r;if(r-e>16&&t.buffer&&UTF8Decoder)return UTF8Decoder.decode(t.subarray(e,r));for(var I="";e<r;){var a=t[e++];if(!(a&128)){I+=String.fromCharCode(a);continue}var s=t[e++]&63;if((a&224)==192){I+=String.fromCharCode((a&31)<<6|s);continue}var o=t[e++]&63;if((a&240)==224?a=(a&15)<<12|s<<6|o:a=(a&7)<<18|s<<12|o<<6|t[e++]&63,a<65536)I+=String.fromCharCode(a);else{var d=a-65536;I+=String.fromCharCode(55296|d>>10,56320|d&1023)}}return I},"UTF8ArrayToString"),getDylinkMetadata=Nt(t=>{var e=0,l=0;function n(){return t[e++]}Nt(n,"getU8");function r(){for(var We=0,ee=1;;){var M=t[e++];if(We+=(M&127)*ee,ee*=128,!(M&128))break}return We}Nt(r,"getLEB");function I(){var We=r();return e+=We,UTF8ArrayToString(t,e-We,We)}Nt(I,"getString");function a(We,ee){if(We)throw new Error(ee)}Nt(a,"failIf");var s="dylink.0";if(t instanceof WebAssembly.Module){var o=WebAssembly.Module.customSections(t,s);o.length===0&&(s="dylink",o=WebAssembly.Module.customSections(t,s)),a(o.length===0,"need dylink section"),t=new Uint8Array(o[0]),l=t.length}else{var d=new Uint32Array(new Uint8Array(t.subarray(0,24)).buffer),u=d[0]==1836278016||d[0]==6386541;a(!u,"need to see wasm magic number"),a(t[8]!==0,"need the dylink section to be first"),e=9;var b=r();l=e+b,s=I()}var p={neededDynlibs:[],tlsExports:new Set,weakImports:new Set};if(s=="dylink"){p.memorySize=r(),p.memoryAlign=r(),p.tableSize=r(),p.tableAlign=r();for(var h=r(),Z=0;Z<h;++Z){var N=I();p.neededDynlibs.push(N)}}else{a(s!=="dylink.0");for(var y=1,Y=2,w=3,H=4,J=256,S=3,T=1;e<l;){var U=n(),j=r();if(U===y)p.memorySize=r(),p.memoryAlign=r(),p.tableSize=r(),p.tableAlign=r();else if(U===Y)for(var h=r(),Z=0;Z<h;++Z)N=I(),p.neededDynlibs.push(N);else if(U===w)for(var O=r();O--;){var z=I(),se=r();se&J&&p.tlsExports.add(z)}else if(U===H)for(var O=r();O--;){var ue=I(),z=I(),se=r();(se&S)==T&&p.weakImports.add(z)}else e+=j}}return p},"getDylinkMetadata");function getValue(t,e="i8"){switch(e.endsWith("*")&&(e="*"),e){case"i1":return HEAP8[t];case"i8":return HEAP8[t];case"i16":return LE_HEAP_LOAD_I16((t>>1)*2);case"i32":return LE_HEAP_LOAD_I32((t>>2)*4);case"i64":return HEAP64[t>>3];case"float":return LE_HEAP_LOAD_F32((t>>2)*4);case"double":return LE_HEAP_LOAD_F64((t>>3)*8);case"*":return LE_HEAP_LOAD_U32((t>>2)*4);default:abort(`invalid type for getValue: ${e}`)}}Nt(getValue,"getValue");var newDSO=Nt((t,e,l)=>{var n={refcount:1/0,name:t,exports:l,global:!0};return LDSO.loadedLibsByName[t]=n,e!=null&&(LDSO.loadedLibsByHandle[e]=n),n},"newDSO"),LDSO={loadedLibsByName:{},loadedLibsByHandle:{},init(){newDSO("__main__",0,wasmImports)}},___heap_base=78224,alignMemory=Nt((t,e)=>Math.ceil(t/e)*e,"alignMemory"),getMemory=Nt(t=>{if(runtimeInitialized)return _calloc(t,1);var e=___heap_base,l=e+alignMemory(t,16);return ___heap_base=l,GOT.__heap_base.value=l,e},"getMemory"),isInternalSym=Nt(t=>["__cpp_exception","__c_longjmp","__wasm_apply_data_relocs","__dso_handle","__tls_size","__tls_align","__set_stack_limits","_emscripten_tls_init","__wasm_init_tls","__wasm_call_ctors","__start_em_asm","__stop_em_asm","__start_em_js","__stop_em_js"].includes(t)||t.startsWith("__em_js__"),"isInternalSym"),uleb128Encode=Nt((t,e)=>{t<128?e.push(t):e.push(t%128|128,t>>7)},"uleb128Encode"),sigToWasmTypes=Nt(t=>{for(var e={i:"i32",j:"i64",f:"f32",d:"f64",e:"externref",p:"i32"},l={parameters:[],results:t[0]=="v"?[]:[e[t[0]]]},n=1;n<t.length;++n)l.parameters.push(e[t[n]]);return l},"sigToWasmTypes"),generateFuncType=Nt((t,e)=>{var l=t.slice(0,1),n=t.slice(1),r={i:127,p:127,j:126,f:125,d:124,e:111};e.push(96),uleb128Encode(n.length,e);for(var I=0;I<n.length;++I)e.push(r[n[I]]);l=="v"?e.push(0):e.push(1,r[l])},"generateFuncType"),convertJsFunctionToWasm=Nt((t,e)=>{if(typeof WebAssembly.Function=="function")return new WebAssembly.Function(sigToWasmTypes(e),t);var l=[1];generateFuncType(e,l);var n=[0,97,115,109,1,0,0,0,1];uleb128Encode(l.length,n),n.push(...l),n.push(2,7,1,1,101,1,102,0,0,7,5,1,1,102,0,0);var r=new WebAssembly.Module(new Uint8Array(n)),I=new WebAssembly.Instance(r,{e:{f:t}}),a=I.exports.f;return a},"convertJsFunctionToWasm"),wasmTableMirror=[],wasmTable=new WebAssembly.Table({initial:31,element:"anyfunc"}),getWasmTableEntry=Nt(t=>{var e=wasmTableMirror[t];return e||(t>=wasmTableMirror.length&&(wasmTableMirror.length=t+1),wasmTableMirror[t]=e=wasmTable.get(t)),e},"getWasmTableEntry"),updateTableMap=Nt((t,e)=>{if(functionsInTableMap)for(var l=t;l<t+e;l++){var n=getWasmTableEntry(l);n&&functionsInTableMap.set(n,l)}},"updateTableMap"),functionsInTableMap,getFunctionAddress=Nt(t=>(functionsInTableMap||(functionsInTableMap=new WeakMap,updateTableMap(0,wasmTable.length)),functionsInTableMap.get(t)||0),"getFunctionAddress"),freeTableIndexes=[],getEmptyTableSlot=Nt(()=>{if(freeTableIndexes.length)return freeTableIndexes.pop();try{wasmTable.grow(1)}catch(t){throw t instanceof RangeError?"Unable to grow wasm table. Set ALLOW_TABLE_GROWTH.":t}return wasmTable.length-1},"getEmptyTableSlot"),setWasmTableEntry=Nt((t,e)=>{wasmTable.set(t,e),wasmTableMirror[t]=wasmTable.get(t)},"setWasmTableEntry"),addFunction=Nt((t,e)=>{var l=getFunctionAddress(t);if(l)return l;var n=getEmptyTableSlot();try{setWasmTableEntry(n,t)}catch(I){if(!(I instanceof TypeError))throw I;var r=convertJsFunctionToWasm(t,e);setWasmTableEntry(n,r)}return functionsInTableMap.set(t,n),n},"addFunction"),updateGOT=Nt((t,e)=>{for(var l in t)if(!isInternalSym(l)){var n=t[l];GOT[l]||=new WebAssembly.Global({value:"i32",mutable:!0}),(e||GOT[l].value==0)&&(typeof n=="function"?GOT[l].value=addFunction(n):typeof n=="number"?GOT[l].value=n:err(`unhandled export type for '${l}': ${typeof n}`))}},"updateGOT"),relocateExports=Nt((t,e,l)=>{var n={};for(var r in t){var I=t[r];typeof I=="object"&&(I=I.value),typeof I=="number"&&(I+=e),n[r]=I}return updateGOT(n,l),n},"relocateExports"),isSymbolDefined=Nt(t=>{var e=wasmImports[t];return!(!e||e.stub)},"isSymbolDefined"),dynCall=Nt((t,e,l=[])=>{var n=getWasmTableEntry(e)(...l);return n},"dynCall"),stackSave=Nt(()=>_emscripten_stack_get_current(),"stackSave"),stackRestore=Nt(t=>__emscripten_stack_restore(t),"stackRestore"),createInvokeFunction=Nt(t=>(e,...l)=>{var n=stackSave();try{return dynCall(t,e,l)}catch(r){if(stackRestore(n),r!==r+0)throw r;if(_setThrew(1,0),t[0]=="j")return 0n}},"createInvokeFunction"),resolveGlobalSymbol=Nt((t,e=!1)=>{var l;return isSymbolDefined(t)?l=wasmImports[t]:t.startsWith("invoke_")&&(l=wasmImports[t]=createInvokeFunction(t.split("_")[1])),{sym:l,name:t}},"resolveGlobalSymbol"),onPostCtors=[],addOnPostCtor=Nt(t=>onPostCtors.unshift(t),"addOnPostCtor"),UTF8ToString=Nt((t,e)=>t?UTF8ArrayToString(HEAPU8,t,e):"","UTF8ToString"),loadWebAssemblyModule=Nt((binary,flags,libName,localScope,handle)=>{var metadata=getDylinkMetadata(binary);currentModuleWeakSymbols=metadata.weakImports;function loadModule(){var memAlign=Math.pow(2,metadata.memoryAlign),memoryBase=metadata.memorySize?alignMemory(getMemory(metadata.memorySize+memAlign),memAlign):0,tableBase=metadata.tableSize?wasmTable.length:0;handle&&(HEAP8[handle+8]=1,LE_HEAP_STORE_U32((handle+12>>2)*4,memoryBase),LE_HEAP_STORE_I32((handle+16>>2)*4,metadata.memorySize),LE_HEAP_STORE_U32((handle+20>>2)*4,tableBase),LE_HEAP_STORE_I32((handle+24>>2)*4,metadata.tableSize)),metadata.tableSize&&wasmTable.grow(metadata.tableSize);var moduleExports;function resolveSymbol(t){var e=resolveGlobalSymbol(t).sym;return!e&&localScope&&(e=localScope[t]),e||(e=moduleExports[t]),e}Nt(resolveSymbol,"resolveSymbol");var proxyHandler={get(t,e){switch(e){case"__memory_base":return memoryBase;case"__table_base":return tableBase}if(e in wasmImports&&!wasmImports[e].stub){var l=wasmImports[e];return l}if(!(e in t)){var n;t[e]=(...r)=>(n||=resolveSymbol(e),n(...r))}return t[e]}},proxy=new Proxy({},proxyHandler),info={"GOT.mem":new Proxy({},GOTHandler),"GOT.func":new Proxy({},GOTHandler),env:proxy,wasi_snapshot_preview1:proxy};function postInstantiation(module,instance){updateTableMap(tableBase,metadata.tableSize),moduleExports=relocateExports(instance.exports,memoryBase),flags.allowUndefined||reportUndefinedSymbols();function addEmAsm(addr,body){for(var args=[],arity=0;arity<16&&body.indexOf("$"+arity)!=-1;arity++)args.push("$"+arity);args=args.join(",");var func=`(${args}) => { ${body} };`;ASM_CONSTS[start]=eval(func)}if(Nt(addEmAsm,"addEmAsm"),"__start_em_asm"in moduleExports)for(var start=moduleExports.__start_em_asm,stop=moduleExports.__stop_em_asm;start<stop;){var jsString=UTF8ToString(start);addEmAsm(start,jsString),start=HEAPU8.indexOf(0,start)+1}function addEmJs(name,cSig,body){var jsArgs=[];if(cSig=cSig.slice(1,-1),cSig!="void"){cSig=cSig.split(",");for(var i in cSig){var jsArg=cSig[i].split(" ").pop();jsArgs.push(jsArg.replace("*",""))}}var func=`(${jsArgs}) => ${body};`;moduleExports[name]=eval(func)}Nt(addEmJs,"addEmJs");for(var name in moduleExports)if(name.startsWith("__em_js__")){var start=moduleExports[name],jsString=UTF8ToString(start),parts=jsString.split("<::>");addEmJs(name.replace("__em_js__",""),parts[0],parts[1]),delete moduleExports[name]}var applyRelocs=moduleExports.__wasm_apply_data_relocs;applyRelocs&&(runtimeInitialized?applyRelocs():__RELOC_FUNCS__.push(applyRelocs));var init=moduleExports.__wasm_call_ctors;return init&&(runtimeInitialized?init():addOnPostCtor(init)),moduleExports}if(Nt(postInstantiation,"postInstantiation"),flags.loadAsync){if(binary instanceof WebAssembly.Module){var instance=new WebAssembly.Instance(binary,info);return Promise.resolve(postInstantiation(binary,instance))}return WebAssembly.instantiate(binary,info).then(t=>postInstantiation(t.module,t.instance))}var module=binary instanceof WebAssembly.Module?binary:new WebAssembly.Module(binary),instance=new WebAssembly.Instance(module,info);return postInstantiation(module,instance)}return Nt(loadModule,"loadModule"),flags.loadAsync?metadata.neededDynlibs.reduce((t,e)=>t.then(()=>loadDynamicLibrary(e,flags,localScope)),Promise.resolve()).then(loadModule):(metadata.neededDynlibs.forEach(t=>loadDynamicLibrary(t,flags,localScope)),loadModule())},"loadWebAssemblyModule"),mergeLibSymbols=Nt((t,e)=>{for(var[l,n]of Object.entries(t)){let r=Nt(a=>{isSymbolDefined(a)||(wasmImports[a]=n)},"setImport");r(l);let I="__main_argc_argv";l=="main"&&r(I),l==I&&r("main")}},"mergeLibSymbols"),asyncLoad=Nt(async t=>{var e=await readAsync(t);return new Uint8Array(e)},"asyncLoad");function loadDynamicLibrary(t,e={global:!0,nodelete:!0},l,n){var r=LDSO.loadedLibsByName[t];if(r)return e.global?r.global||(r.global=!0,mergeLibSymbols(r.exports,t)):l&&Object.assign(l,r.exports),e.nodelete&&r.refcount!==1/0&&(r.refcount=1/0),r.refcount++,n&&(LDSO.loadedLibsByHandle[n]=r),e.loadAsync?Promise.resolve(!0):!0;r=newDSO(t,n,"loading"),r.refcount=e.nodelete?1/0:1,r.global=e.global;function I(){if(n){var o=LE_HEAP_LOAD_U32((n+28>>2)*4),d=LE_HEAP_LOAD_U32((n+32>>2)*4);if(o&&d){var u=HEAP8.slice(o,o+d);return e.loadAsync?Promise.resolve(u):u}}var b=locateFile(t);if(e.loadAsync)return asyncLoad(b);if(!readBinary)throw new Error(`${b}: file not found, and synchronous loading of external files is not available`);return readBinary(b)}Nt(I,"loadLibData");function a(){return e.loadAsync?I().then(o=>loadWebAssemblyModule(o,e,t,l,n)):loadWebAssemblyModule(I(),e,t,l,n)}Nt(a,"getExports");function s(o){r.global?mergeLibSymbols(o,t):l&&Object.assign(l,o),r.exports=o}return Nt(s,"moduleLoaded"),e.loadAsync?a().then(o=>(s(o),!0)):(s(a()),!0)}Nt(loadDynamicLibrary,"loadDynamicLibrary");var reportUndefinedSymbols=Nt(()=>{for(var[t,e]of Object.entries(GOT))if(e.value==0){var l=resolveGlobalSymbol(t,!0).sym;if(!l&&!e.required)continue;if(typeof l=="function")e.value=addFunction(l,l.sig);else if(typeof l=="number")e.value=l;else throw new Error(`bad export type for '${t}': ${typeof l}`)}},"reportUndefinedSymbols"),loadDylibs=Nt(()=>{if(!dynamicLibraries.length){reportUndefinedSymbols();return}addRunDependency("loadDylibs"),dynamicLibraries.reduce((t,e)=>t.then(()=>loadDynamicLibrary(e,{loadAsync:!0,global:!0,nodelete:!0,allowUndefined:!0})),Promise.resolve()).then(()=>{reportUndefinedSymbols(),removeRunDependency("loadDylibs")})},"loadDylibs"),noExitRuntime=Module.noExitRuntime||!0;function setValue(t,e,l="i8"){switch(l.endsWith("*")&&(l="*"),l){case"i1":HEAP8[t]=e;break;case"i8":HEAP8[t]=e;break;case"i16":LE_HEAP_STORE_I16((t>>1)*2,e);break;case"i32":LE_HEAP_STORE_I32((t>>2)*4,e);break;case"i64":HEAP64[t>>3]=BigInt(e);break;case"float":LE_HEAP_STORE_F32((t>>2)*4,e);break;case"double":LE_HEAP_STORE_F64((t>>3)*8,e);break;case"*":LE_HEAP_STORE_U32((t>>2)*4,e);break;default:abort(`invalid type for setValue: ${l}`)}}Nt(setValue,"setValue");var ___memory_base=new WebAssembly.Global({value:"i32",mutable:!1},1024),___stack_pointer=new WebAssembly.Global({value:"i32",mutable:!0},78224),___table_base=new WebAssembly.Global({value:"i32",mutable:!1},1),__abort_js=Nt(()=>abort(""),"__abort_js");__abort_js.sig="v";var _emscripten_get_now=Nt(()=>performance.now(),"_emscripten_get_now");_emscripten_get_now.sig="d";var _emscripten_date_now=Nt(()=>Date.now(),"_emscripten_date_now");_emscripten_date_now.sig="d";var nowIsMonotonic=1,checkWasiClock=Nt(t=>t>=0&&t<=3,"checkWasiClock"),INT53_MAX=9007199254740992,INT53_MIN=-9007199254740992,bigintToI53Checked=Nt(t=>t<INT53_MIN||t>INT53_MAX?NaN:Number(t),"bigintToI53Checked");function _clock_time_get(t,e,l){if(e=bigintToI53Checked(e),!checkWasiClock(t))return 28;var n;if(t===0)n=_emscripten_date_now();else if(nowIsMonotonic)n=_emscripten_get_now();else return 52;var r=Math.round(n*1e3*1e3);return HEAP64[l>>3]=BigInt(r),0}Nt(_clock_time_get,"_clock_time_get"),_clock_time_get.sig="iijp";var getHeapMax=Nt(()=>2147483648,"getHeapMax"),growMemory=Nt(t=>{var e=wasmMemory.buffer,l=(t-e.byteLength+65535)/65536|0;try{return wasmMemory.grow(l),updateMemoryViews(),1}catch{}},"growMemory"),_emscripten_resize_heap=Nt(t=>{var e=HEAPU8.length;t>>>=0;var l=getHeapMax();if(t>l)return!1;for(var n=1;n<=4;n*=2){var r=e*(1+.2/n);r=Math.min(r,t+100663296);var I=Math.min(l,alignMemory(Math.max(t,r),65536)),a=growMemory(I);if(a)return!0}return!1},"_emscripten_resize_heap");_emscripten_resize_heap.sig="ip";var _fd_close=Nt(t=>52,"_fd_close");_fd_close.sig="ii";function _fd_seek(t,e,l,n){return e=bigintToI53Checked(e),70}Nt(_fd_seek,"_fd_seek"),_fd_seek.sig="iijip";var printCharBuffers=[null,[],[]],printChar=Nt((t,e)=>{var l=printCharBuffers[t];e===0||e===10?((t===1?out:err)(UTF8ArrayToString(l)),l.length=0):l.push(e)},"printChar"),flush_NO_FILESYSTEM=Nt(()=>{printCharBuffers[1].length&&printChar(1,10),printCharBuffers[2].length&&printChar(2,10)},"flush_NO_FILESYSTEM"),SYSCALLS={varargs:void 0,getStr(t){var e=UTF8ToString(t);return e}},_fd_write=Nt((t,e,l,n)=>{for(var r=0,I=0;I<l;I++){var a=LE_HEAP_LOAD_U32((e>>2)*4),s=LE_HEAP_LOAD_U32((e+4>>2)*4);e+=8;for(var o=0;o<s;o++)printChar(t,HEAPU8[a+o]);r+=s}return LE_HEAP_STORE_U32((n>>2)*4,r),0},"_fd_write");_fd_write.sig="iippp";function _tree_sitter_log_callback(t,e){if(Module.currentLogCallback){let l=UTF8ToString(e);Module.currentLogCallback(l,t!==0)}}Nt(_tree_sitter_log_callback,"_tree_sitter_log_callback");function _tree_sitter_parse_callback(t,e,l,n,r){let a=Module.currentParseCallback(e,{row:l,column:n});typeof a=="string"?(setValue(r,a.length,"i32"),stringToUTF16(a,t,10240)):setValue(r,0,"i32")}Nt(_tree_sitter_parse_callback,"_tree_sitter_parse_callback");function _tree_sitter_progress_callback(t,e){return Module.currentProgressCallback?Module.currentProgressCallback({currentOffset:t,hasError:e}):!1}Nt(_tree_sitter_progress_callback,"_tree_sitter_progress_callback");function _tree_sitter_query_progress_callback(t){return Module.currentQueryProgressCallback?Module.currentQueryProgressCallback({currentOffset:t}):!1}Nt(_tree_sitter_query_progress_callback,"_tree_sitter_query_progress_callback");var runtimeKeepaliveCounter=0,keepRuntimeAlive=Nt(()=>noExitRuntime||runtimeKeepaliveCounter>0,"keepRuntimeAlive"),_proc_exit=Nt(t=>{EXITSTATUS=t,keepRuntimeAlive()||(Module.onExit?.(t),ABORT=!0),quit_(t,new ExitStatus(t))},"_proc_exit");_proc_exit.sig="vi";var exitJS=Nt((t,e)=>{EXITSTATUS=t,_proc_exit(t)},"exitJS"),handleException=Nt(t=>{if(t instanceof ExitStatus||t=="unwind")return EXITSTATUS;quit_(1,t)},"handleException"),lengthBytesUTF8=Nt(t=>{for(var e=0,l=0;l<t.length;++l){var n=t.charCodeAt(l);n<=127?e++:n<=2047?e+=2:n>=55296&&n<=57343?(e+=4,++l):e+=3}return e},"lengthBytesUTF8"),stringToUTF8Array=Nt((t,e,l,n)=>{if(!(n>0))return 0;for(var r=l,I=l+n-1,a=0;a<t.length;++a){var s=t.charCodeAt(a);if(s>=55296&&s<=57343){var o=t.charCodeAt(++a);s=65536+((s&1023)<<10)|o&1023}if(s<=127){if(l>=I)break;e[l++]=s}else if(s<=2047){if(l+1>=I)break;e[l++]=192|s>>6,e[l++]=128|s&63}else if(s<=65535){if(l+2>=I)break;e[l++]=224|s>>12,e[l++]=128|s>>6&63,e[l++]=128|s&63}else{if(l+3>=I)break;e[l++]=240|s>>18,e[l++]=128|s>>12&63,e[l++]=128|s>>6&63,e[l++]=128|s&63}}return e[l]=0,l-r},"stringToUTF8Array"),stringToUTF8=Nt((t,e,l)=>stringToUTF8Array(t,HEAPU8,e,l),"stringToUTF8"),stackAlloc=Nt(t=>__emscripten_stack_alloc(t),"stackAlloc"),stringToUTF8OnStack=Nt(t=>{var e=lengthBytesUTF8(t)+1,l=stackAlloc(e);return stringToUTF8(t,l,e),l},"stringToUTF8OnStack"),AsciiToString=Nt(t=>{for(var e="";;){var l=HEAPU8[t++];if(!l)return e;e+=String.fromCharCode(l)}},"AsciiToString"),stringToUTF16=Nt((t,e,l)=>{if(l??=2147483647,l<2)return 0;l-=2;for(var n=e,r=l<t.length*2?l/2:t.length,I=0;I<r;++I){var a=t.charCodeAt(I);LE_HEAP_STORE_I16((e>>1)*2,a),e+=2}return LE_HEAP_STORE_I16((e>>1)*2,0),e-n},"stringToUTF16"),wasmImports={__heap_base:___heap_base,__indirect_function_table:wasmTable,__memory_base:___memory_base,__stack_pointer:___stack_pointer,__table_base:___table_base,_abort_js:__abort_js,clock_time_get:_clock_time_get,emscripten_resize_heap:_emscripten_resize_heap,fd_close:_fd_close,fd_seek:_fd_seek,fd_write:_fd_write,memory:wasmMemory,tree_sitter_log_callback:_tree_sitter_log_callback,tree_sitter_parse_callback:_tree_sitter_parse_callback,tree_sitter_progress_callback:_tree_sitter_progress_callback,tree_sitter_query_progress_callback:_tree_sitter_query_progress_callback},wasmExports=await createWasm(),___wasm_call_ctors=wasmExports.__wasm_call_ctors,_malloc=Module._malloc=wasmExports.malloc,_calloc=Module._calloc=wasmExports.calloc,_realloc=Module._realloc=wasmExports.realloc,_free=Module._free=wasmExports.free,_memcmp=Module._memcmp=wasmExports.memcmp,_ts_language_symbol_count=Module._ts_language_symbol_count=wasmExports.ts_language_symbol_count,_ts_language_state_count=Module._ts_language_state_count=wasmExports.ts_language_state_count,_ts_language_version=Module._ts_language_version=wasmExports.ts_language_version,_ts_language_abi_version=Module._ts_language_abi_version=wasmExports.ts_language_abi_version,_ts_language_metadata=Module._ts_language_metadata=wasmExports.ts_language_metadata,_ts_language_name=Module._ts_language_name=wasmExports.ts_language_name,_ts_language_field_count=Module._ts_language_field_count=wasmExports.ts_language_field_count,_ts_language_next_state=Module._ts_language_next_state=wasmExports.ts_language_next_state,_ts_language_symbol_name=Module._ts_language_symbol_name=wasmExports.ts_language_symbol_name,_ts_language_symbol_for_name=Module._ts_language_symbol_for_name=wasmExports.ts_language_symbol_for_name,_strncmp=Module._strncmp=wasmExports.strncmp,_ts_language_symbol_type=Module._ts_language_symbol_type=wasmExports.ts_language_symbol_type,_ts_language_field_name_for_id=Module._ts_language_field_name_for_id=wasmExports.ts_language_field_name_for_id,_ts_lookahead_iterator_new=Module._ts_lookahead_iterator_new=wasmExports.ts_lookahead_iterator_new,_ts_lookahead_iterator_delete=Module._ts_lookahead_iterator_delete=wasmExports.ts_lookahead_iterator_delete,_ts_lookahead_iterator_reset_state=Module._ts_lookahead_iterator_reset_state=wasmExports.ts_lookahead_iterator_reset_state,_ts_lookahead_iterator_reset=Module._ts_lookahead_iterator_reset=wasmExports.ts_lookahead_iterator_reset,_ts_lookahead_iterator_next=Module._ts_lookahead_iterator_next=wasmExports.ts_lookahead_iterator_next,_ts_lookahead_iterator_current_symbol=Module._ts_lookahead_iterator_current_symbol=wasmExports.ts_lookahead_iterator_current_symbol,_ts_parser_delete=Module._ts_parser_delete=wasmExports.ts_parser_delete,_ts_parser_reset=Module._ts_parser_reset=wasmExports.ts_parser_reset,_ts_parser_set_language=Module._ts_parser_set_language=wasmExports.ts_parser_set_language,_ts_parser_timeout_micros=Module._ts_parser_timeout_micros=wasmExports.ts_parser_timeout_micros,_ts_parser_set_timeout_micros=Module._ts_parser_set_timeout_micros=wasmExports.ts_parser_set_timeout_micros,_ts_parser_set_included_ranges=Module._ts_parser_set_included_ranges=wasmExports.ts_parser_set_included_ranges,_ts_query_new=Module._ts_query_new=wasmExports.ts_query_new,_ts_query_delete=Module._ts_query_delete=wasmExports.ts_query_delete,_iswspace=Module._iswspace=wasmExports.iswspace,_iswalnum=Module._iswalnum=wasmExports.iswalnum,_ts_query_pattern_count=Module._ts_query_pattern_count=wasmExports.ts_query_pattern_count,_ts_query_capture_count=Module._ts_query_capture_count=wasmExports.ts_query_capture_count,_ts_query_string_count=Module._ts_query_string_count=wasmExports.ts_query_string_count,_ts_query_capture_name_for_id=Module._ts_query_capture_name_for_id=wasmExports.ts_query_capture_name_for_id,_ts_query_capture_quantifier_for_id=Module._ts_query_capture_quantifier_for_id=wasmExports.ts_query_capture_quantifier_for_id,_ts_query_string_value_for_id=Module._ts_query_string_value_for_id=wasmExports.ts_query_string_value_for_id,_ts_query_predicates_for_pattern=Module._ts_query_predicates_for_pattern=wasmExports.ts_query_predicates_for_pattern,_ts_query_start_byte_for_pattern=Module._ts_query_start_byte_for_pattern=wasmExports.ts_query_start_byte_for_pattern,_ts_query_end_byte_for_pattern=Module._ts_query_end_byte_for_pattern=wasmExports.ts_query_end_byte_for_pattern,_ts_query_is_pattern_rooted=Module._ts_query_is_pattern_rooted=wasmExports.ts_query_is_pattern_rooted,_ts_query_is_pattern_non_local=Module._ts_query_is_pattern_non_local=wasmExports.ts_query_is_pattern_non_local,_ts_query_is_pattern_guaranteed_at_step=Module._ts_query_is_pattern_guaranteed_at_step=wasmExports.ts_query_is_pattern_guaranteed_at_step,_ts_query_disable_capture=Module._ts_query_disable_capture=wasmExports.ts_query_disable_capture,_ts_query_disable_pattern=Module._ts_query_disable_pattern=wasmExports.ts_query_disable_pattern,_ts_tree_copy=Module._ts_tree_copy=wasmExports.ts_tree_copy,_ts_tree_delete=Module._ts_tree_delete=wasmExports.ts_tree_delete,_ts_init=Module._ts_init=wasmExports.ts_init,_ts_parser_new_wasm=Module._ts_parser_new_wasm=wasmExports.ts_parser_new_wasm,_ts_parser_enable_logger_wasm=Module._ts_parser_enable_logger_wasm=wasmExports.ts_parser_enable_logger_wasm,_ts_parser_parse_wasm=Module._ts_parser_parse_wasm=wasmExports.ts_parser_parse_wasm,_ts_parser_included_ranges_wasm=Module._ts_parser_included_ranges_wasm=wasmExports.ts_parser_included_ranges_wasm,_ts_language_type_is_named_wasm=Module._ts_language_type_is_named_wasm=wasmExports.ts_language_type_is_named_wasm,_ts_language_type_is_visible_wasm=Module._ts_language_type_is_visible_wasm=wasmExports.ts_language_type_is_visible_wasm,_ts_language_supertypes_wasm=Module._ts_language_supertypes_wasm=wasmExports.ts_language_supertypes_wasm,_ts_language_subtypes_wasm=Module._ts_language_subtypes_wasm=wasmExports.ts_language_subtypes_wasm,_ts_tree_root_node_wasm=Module._ts_tree_root_node_wasm=wasmExports.ts_tree_root_node_wasm,_ts_tree_root_node_with_offset_wasm=Module._ts_tree_root_node_with_offset_wasm=wasmExports.ts_tree_root_node_with_offset_wasm,_ts_tree_edit_wasm=Module._ts_tree_edit_wasm=wasmExports.ts_tree_edit_wasm,_ts_tree_included_ranges_wasm=Module._ts_tree_included_ranges_wasm=wasmExports.ts_tree_included_ranges_wasm,_ts_tree_get_changed_ranges_wasm=Module._ts_tree_get_changed_ranges_wasm=wasmExports.ts_tree_get_changed_ranges_wasm,_ts_tree_cursor_new_wasm=Module._ts_tree_cursor_new_wasm=wasmExports.ts_tree_cursor_new_wasm,_ts_tree_cursor_copy_wasm=Module._ts_tree_cursor_copy_wasm=wasmExports.ts_tree_cursor_copy_wasm,_ts_tree_cursor_delete_wasm=Module._ts_tree_cursor_delete_wasm=wasmExports.ts_tree_cursor_delete_wasm,_ts_tree_cursor_reset_wasm=Module._ts_tree_cursor_reset_wasm=wasmExports.ts_tree_cursor_reset_wasm,_ts_tree_cursor_reset_to_wasm=Module._ts_tree_cursor_reset_to_wasm=wasmExports.ts_tree_cursor_reset_to_wasm,_ts_tree_cursor_goto_first_child_wasm=Module._ts_tree_cursor_goto_first_child_wasm=wasmExports.ts_tree_cursor_goto_first_child_wasm,_ts_tree_cursor_goto_last_child_wasm=Module._ts_tree_cursor_goto_last_child_wasm=wasmExports.ts_tree_cursor_goto_last_child_wasm,_ts_tree_cursor_goto_first_child_for_index_wasm=Module._ts_tree_cursor_goto_first_child_for_index_wasm=wasmExports.ts_tree_cursor_goto_first_child_for_index_wasm,_ts_tree_cursor_goto_first_child_for_position_wasm=Module._ts_tree_cursor_goto_first_child_for_position_wasm=wasmExports.ts_tree_cursor_goto_first_child_for_position_wasm,_ts_tree_cursor_goto_next_sibling_wasm=Module._ts_tree_cursor_goto_next_sibling_wasm=wasmExports.ts_tree_cursor_goto_next_sibling_wasm,_ts_tree_cursor_goto_previous_sibling_wasm=Module._ts_tree_cursor_goto_previous_sibling_wasm=wasmExports.ts_tree_cursor_goto_previous_sibling_wasm,_ts_tree_cursor_goto_descendant_wasm=Module._ts_tree_cursor_goto_descendant_wasm=wasmExports.ts_tree_cursor_goto_descendant_wasm,_ts_tree_cursor_goto_parent_wasm=Module._ts_tree_cursor_goto_parent_wasm=wasmExports.ts_tree_cursor_goto_parent_wasm,_ts_tree_cursor_current_node_type_id_wasm=Module._ts_tree_cursor_current_node_type_id_wasm=wasmExports.ts_tree_cursor_current_node_type_id_wasm,_ts_tree_cursor_current_node_state_id_wasm=Module._ts_tree_cursor_current_node_state_id_wasm=wasmExports.ts_tree_cursor_current_node_state_id_wasm,_ts_tree_cursor_current_node_is_named_wasm=Module._ts_tree_cursor_current_node_is_named_wasm=wasmExports.ts_tree_cursor_current_node_is_named_wasm,_ts_tree_cursor_current_node_is_missing_wasm=Module._ts_tree_cursor_current_node_is_missing_wasm=wasmExports.ts_tree_cursor_current_node_is_missing_wasm,_ts_tree_cursor_current_node_id_wasm=Module._ts_tree_cursor_current_node_id_wasm=wasmExports.ts_tree_cursor_current_node_id_wasm,_ts_tree_cursor_start_position_wasm=Module._ts_tree_cursor_start_position_wasm=wasmExports.ts_tree_cursor_start_position_wasm,_ts_tree_cursor_end_position_wasm=Module._ts_tree_cursor_end_position_wasm=wasmExports.ts_tree_cursor_end_position_wasm,_ts_tree_cursor_start_index_wasm=Module._ts_tree_cursor_start_index_wasm=wasmExports.ts_tree_cursor_start_index_wasm,_ts_tree_cursor_end_index_wasm=Module._ts_tree_cursor_end_index_wasm=wasmExports.ts_tree_cursor_end_index_wasm,_ts_tree_cursor_current_field_id_wasm=Module._ts_tree_cursor_current_field_id_wasm=wasmExports.ts_tree_cursor_current_field_id_wasm,_ts_tree_cursor_current_depth_wasm=Module._ts_tree_cursor_current_depth_wasm=wasmExports.ts_tree_cursor_current_depth_wasm,_ts_tree_cursor_current_descendant_index_wasm=Module._ts_tree_cursor_current_descendant_index_wasm=wasmExports.ts_tree_cursor_current_descendant_index_wasm,_ts_tree_cursor_current_node_wasm=Module._ts_tree_cursor_current_node_wasm=wasmExports.ts_tree_cursor_current_node_wasm,_ts_node_symbol_wasm=Module._ts_node_symbol_wasm=wasmExports.ts_node_symbol_wasm,_ts_node_field_name_for_child_wasm=Module._ts_node_field_name_for_child_wasm=wasmExports.ts_node_field_name_for_child_wasm,_ts_node_field_name_for_named_child_wasm=Module._ts_node_field_name_for_named_child_wasm=wasmExports.ts_node_field_name_for_named_child_wasm,_ts_node_children_by_field_id_wasm=Module._ts_node_children_by_field_id_wasm=wasmExports.ts_node_children_by_field_id_wasm,_ts_node_first_child_for_byte_wasm=Module._ts_node_first_child_for_byte_wasm=wasmExports.ts_node_first_child_for_byte_wasm,_ts_node_first_named_child_for_byte_wasm=Module._ts_node_first_named_child_for_byte_wasm=wasmExports.ts_node_first_named_child_for_byte_wasm,_ts_node_grammar_symbol_wasm=Module._ts_node_grammar_symbol_wasm=wasmExports.ts_node_grammar_symbol_wasm,_ts_node_child_count_wasm=Module._ts_node_child_count_wasm=wasmExports.ts_node_child_count_wasm,_ts_node_named_child_count_wasm=Module._ts_node_named_child_count_wasm=wasmExports.ts_node_named_child_count_wasm,_ts_node_child_wasm=Module._ts_node_child_wasm=wasmExports.ts_node_child_wasm,_ts_node_named_child_wasm=Module._ts_node_named_child_wasm=wasmExports.ts_node_named_child_wasm,_ts_node_child_by_field_id_wasm=Module._ts_node_child_by_field_id_wasm=wasmExports.ts_node_child_by_field_id_wasm,_ts_node_next_sibling_wasm=Module._ts_node_next_sibling_wasm=wasmExports.ts_node_next_sibling_wasm,_ts_node_prev_sibling_wasm=Module._ts_node_prev_sibling_wasm=wasmExports.ts_node_prev_sibling_wasm,_ts_node_next_named_sibling_wasm=Module._ts_node_next_named_sibling_wasm=wasmExports.ts_node_next_named_sibling_wasm,_ts_node_prev_named_sibling_wasm=Module._ts_node_prev_named_sibling_wasm=wasmExports.ts_node_prev_named_sibling_wasm,_ts_node_descendant_count_wasm=Module._ts_node_descendant_count_wasm=wasmExports.ts_node_descendant_count_wasm,_ts_node_parent_wasm=Module._ts_node_parent_wasm=wasmExports.ts_node_parent_wasm,_ts_node_child_with_descendant_wasm=Module._ts_node_child_with_descendant_wasm=wasmExports.ts_node_child_with_descendant_wasm,_ts_node_descendant_for_index_wasm=Module._ts_node_descendant_for_index_wasm=wasmExports.ts_node_descendant_for_index_wasm,_ts_node_named_descendant_for_index_wasm=Module._ts_node_named_descendant_for_index_wasm=wasmExports.ts_node_named_descendant_for_index_wasm,_ts_node_descendant_for_position_wasm=Module._ts_node_descendant_for_position_wasm=wasmExports.ts_node_descendant_for_position_wasm,_ts_node_named_descendant_for_position_wasm=Module._ts_node_named_descendant_for_position_wasm=wasmExports.ts_node_named_descendant_for_position_wasm,_ts_node_start_point_wasm=Module._ts_node_start_point_wasm=wasmExports.ts_node_start_point_wasm,_ts_node_end_point_wasm=Module._ts_node_end_point_wasm=wasmExports.ts_node_end_point_wasm,_ts_node_start_index_wasm=Module._ts_node_start_index_wasm=wasmExports.ts_node_start_index_wasm,_ts_node_end_index_wasm=Module._ts_node_end_index_wasm=wasmExports.ts_node_end_index_wasm,_ts_node_to_string_wasm=Module._ts_node_to_string_wasm=wasmExports.ts_node_to_string_wasm,_ts_node_children_wasm=Module._ts_node_children_wasm=wasmExports.ts_node_children_wasm,_ts_node_named_children_wasm=Module._ts_node_named_children_wasm=wasmExports.ts_node_named_children_wasm,_ts_node_descendants_of_type_wasm=Module._ts_node_descendants_of_type_wasm=wasmExports.ts_node_descendants_of_type_wasm,_ts_node_is_named_wasm=Module._ts_node_is_named_wasm=wasmExports.ts_node_is_named_wasm,_ts_node_has_changes_wasm=Module._ts_node_has_changes_wasm=wasmExports.ts_node_has_changes_wasm,_ts_node_has_error_wasm=Module._ts_node_has_error_wasm=wasmExports.ts_node_has_error_wasm,_ts_node_is_error_wasm=Module._ts_node_is_error_wasm=wasmExports.ts_node_is_error_wasm,_ts_node_is_missing_wasm=Module._ts_node_is_missing_wasm=wasmExports.ts_node_is_missing_wasm,_ts_node_is_extra_wasm=Module._ts_node_is_extra_wasm=wasmExports.ts_node_is_extra_wasm,_ts_node_parse_state_wasm=Module._ts_node_parse_state_wasm=wasmExports.ts_node_parse_state_wasm,_ts_node_next_parse_state_wasm=Module._ts_node_next_parse_state_wasm=wasmExports.ts_node_next_parse_state_wasm,_ts_query_matches_wasm=Module._ts_query_matches_wasm=wasmExports.ts_query_matches_wasm,_ts_query_captures_wasm=Module._ts_query_captures_wasm=wasmExports.ts_query_captures_wasm,_memset=Module._memset=wasmExports.memset,_memcpy=Module._memcpy=wasmExports.memcpy,_memmove=Module._memmove=wasmExports.memmove,_iswalpha=Module._iswalpha=wasmExports.iswalpha,_iswblank=Module._iswblank=wasmExports.iswblank,_iswdigit=Module._iswdigit=wasmExports.iswdigit,_iswlower=Module._iswlower=wasmExports.iswlower,_iswupper=Module._iswupper=wasmExports.iswupper,_iswxdigit=Module._iswxdigit=wasmExports.iswxdigit,_memchr=Module._memchr=wasmExports.memchr,_strlen=Module._strlen=wasmExports.strlen,_strcmp=Module._strcmp=wasmExports.strcmp,_strncat=Module._strncat=wasmExports.strncat,_strncpy=Module._strncpy=wasmExports.strncpy,_towlower=Module._towlower=wasmExports.towlower,_towupper=Module._towupper=wasmExports.towupper,_setThrew=wasmExports.setThrew,__emscripten_stack_restore=wasmExports._emscripten_stack_restore,__emscripten_stack_alloc=wasmExports._emscripten_stack_alloc,_emscripten_stack_get_current=wasmExports.emscripten_stack_get_current,___wasm_apply_data_relocs=wasmExports.__wasm_apply_data_relocs;Module.setValue=setValue,Module.getValue=getValue,Module.UTF8ToString=UTF8ToString,Module.stringToUTF8=stringToUTF8,Module.lengthBytesUTF8=lengthBytesUTF8,Module.AsciiToString=AsciiToString,Module.stringToUTF16=stringToUTF16,Module.loadWebAssemblyModule=loadWebAssemblyModule;function callMain(t=[]){var e=resolveGlobalSymbol("main").sym;if(e){t.unshift(thisProgram);var l=t.length,n=stackAlloc((l+1)*4),r=n;t.forEach(a=>{LE_HEAP_STORE_U32((r>>2)*4,stringToUTF8OnStack(a)),r+=4}),LE_HEAP_STORE_U32((r>>2)*4,0);try{var I=e(l,n);return exitJS(I,!0),I}catch(a){return handleException(a)}}}Nt(callMain,"callMain");function run(t=arguments_){if(runDependencies>0){dependenciesFulfilled=run;return}if(preRun(),runDependencies>0){dependenciesFulfilled=run;return}function e(){if(Module.calledRun=!0,!ABORT){initRuntime(),readyPromiseResolve(Module),Module.onRuntimeInitialized?.();var l=Module.noInitialRun;l||callMain(t),postRun()}}Nt(e,"doRun"),Module.setStatus?(Module.setStatus("Running..."),setTimeout(()=>{setTimeout(()=>Module.setStatus(""),1),e()},1)):e()}if(Nt(run,"run"),Module.preInit)for(typeof Module.preInit=="function"&&(Module.preInit=[Module.preInit]);Module.preInit.length>0;)Module.preInit.pop()();return run(),moduleRtn=readyPromise,moduleRtn}})(),bTn=mTn,sFe=null;async function jal(t){return sFe||(sFe=await bTn(t)),sFe}Nt(jal,"initializeBinding");function Kal(){return!!sFe}Nt(Kal,"checkModule");var er,net,ret,cet=class{static{Nt(this,"Parser")}0=0;1=0;logCallback=null;language=null;static async init(t){Lal(await jal(t)),er=Ve._ts_init(),net=Ve.getValue(er,"i32"),ret=Ve.getValue(er+ur,"i32")}constructor(){this.initialize()}initialize(){if(!Kal())throw new Error("cannot construct a Parser before calling `init()`");Ve._ts_parser_new_wasm(),this[0]=Ve.getValue(er,"i32"),this[1]=Ve.getValue(er+ur,"i32")}delete(){Ve._ts_parser_delete(this[0]),Ve._free(this[1]),this[0]=0,this[1]=0}setLanguage(t){let e;if(!t)e=0,this.language=null;else if(t.constructor===iet){e=t[0];let l=Ve._ts_language_version(e);if(l<ret||net<l)throw new Error(`Incompatible language version ${l}. Compatibility range ${ret} through ${net}.`);this.language=t}else throw new Error("Argument must be a Language");return Ve._ts_parser_set_language(this[0],e),this}parse(t,e,l){if(typeof t=="string")Ve.currentParseCallback=s=>t.slice(s);else if(typeof t=="function")Ve.currentParseCallback=t;else throw new Error("Argument must be a string or a function");l?.progressCallback?Ve.currentProgressCallback=l.progressCallback:Ve.currentProgressCallback=null,this.logCallback?(Ve.currentLogCallback=this.logCallback,Ve._ts_parser_enable_logger_wasm(this[0],1)):(Ve.currentLogCallback=null,Ve._ts_parser_enable_logger_wasm(this[0],0));let n=0,r=0;if(l?.includedRanges){n=l.includedRanges.length,r=Ve._calloc(n,Fme);let s=r;for(let o=0;o<n;o++)xal(s,l.includedRanges[o]),s+=Fme}let I=Ve._ts_parser_parse_wasm(this[0],this[1],e?e[0]:0,r,n);if(!I)return Ve.currentParseCallback=null,Ve.currentLogCallback=null,Ve.currentProgressCallback=null,null;if(!this.language)throw new Error("Parser must have a language to parse");let a=new ITn(gL,I,this.language,Ve.currentParseCallback);return Ve.currentParseCallback=null,Ve.currentLogCallback=null,Ve.currentProgressCallback=null,a}reset(){Ve._ts_parser_reset(this[0])}getIncludedRanges(){Ve._ts_parser_included_ranges_wasm(this[0]);let t=Ve.getValue(er,"i32"),e=Ve.getValue(er+ur,"i32"),l=new Array(t);if(t>0){let n=e;for(let r=0;r<t;r++)l[r]=oFe(n),n+=Fme;Ve._free(e)}return l}getTimeoutMicros(){return Ve._ts_parser_timeout_micros(this[0])}setTimeoutMicros(t){Ve._ts_parser_set_timeout_micros(this[0],0,t)}setLogger(t){if(!t)this.logCallback=null;else{if(typeof t!="function")throw new Error("Logger callback must be a function");this.logCallback=t}return this}getLogger(){return this.logCallback}};c();var qal=()=>!0;var det=new Map,uet=null;async function esl(t,e,l){t==="powershell"&&(e=e.replace(/&&/g,";"));let n=await GTn(t,e);if(!n)return{kind:"error",reason:"failed to parse script"};let r=new Set(["expansion","simple_expansion","command_substitution","process_substitution","arithmetic_expansion","variable_assignment","variable_assignments","if_statement","for_statement","c_style_for_statement","while_statement","case_statement","function_definition","subshell","compound_statement","binary_expression","unary_expression","ternary_expression","test_command","negated_command","declaration_command","unset_command","brace_expression","command_name_expr"]),I=new Set(["integer_literal","string_literal","real_literal"]),a=[n.rootNode],s=[],o=!1,d=!1;for(;a.length>0;){let u=a.pop();if(u.isNamed){if(u.type==="command"){let b=ATn(t,u,l);b!==null&&s.push({fullCommandText:u.text.trim(),commandIdentifier:b})}if(r.has(u.type)){let b=u.children.length===1?u.children[0]:null;u.type==="unary_expression"&&b&&I.has(b.type)||(d=!0)}u.type==="file_redirect"&&(o||=!NTn(u)),u.type==="redirection"&&(o||=!WTn(u));for(let b=u.children.length-1;b>=0;b--){let p=u.children[b];p&&a.push(p)}}}return{kind:"success",commands:s,hasWriteFileRedirection:o,hasPotentiallyConfusingConstructs:d}}async function GTn(t,e){uet||(uet=cet.init()),await uet;let l=await pTn(t),n=new cet;return n.setLanguage(l),n.parse(e)}function pTn(t){let e=det.get(t);if(e)return e;let l=hTn(t),n=qal()?$al.join(import.meta.dirname,l.file):$al.join("node_modules",l.package,l.file),r=iet.load(n).catch(I=>{throw det.delete(t),I});return det.set(t,r),r}function hTn(t){switch(t){case"bash":return{package:"tree-sitter-bash",file:"tree-sitter-bash.wasm"};case"powershell":return{package:"tree-sitter-powershell",file:"tree-sitter-powershell.wasm"};default:sb(t,`Unknown shell type: ${t}`)}}function ATn(t,e,l){switch(t){case"bash":return ZTn(e,l);case"powershell":return gTn(e,l);default:sb(t,`Unknown shell type: ${t}`)}}function ZTn(t,e){if(!t||t.type!=="command")throw new Error(`expected a command node, got ${t.type}`);let l=t.childForFieldName("name")??t.namedChildren.find(a=>a?.type==="command_name");if(!l)throw new Error("command node has no name or command_name child");let n=l.text,r=e?.find(a=>a.stem===n);if(!r)return n;let I=l.nextNamedSibling;for(;I&&I.type==="word";){if(!r?.flagsToIgnore?.includes(I.text))return`${n} ${I.text}`;I=I.nextNamedSibling}return n}function gTn(t,e){if(!t||t.type!=="command")throw new Error(`expected a command node, got ${t.type}`);let l=t.childForFieldName("name")??t.namedChildren.find(a=>a?.type==="command_name");if(!l){if(t.namedChildren.find(s=>s?.type==="foreach_command"))return"ForEach-Object";let a=t.namedChildren.find(s=>s?.type==="command_name_expr");if(a)return a.childCount===1&&a.firstChild?.type==="script_block_expression"?null:"<command with expression as name>";throw new Error("command node has no name, command_name, foreach_command, or command_name_expr child")}let n=l.text,r=e?.find(a=>a.stem===n);if(!r)return n;let I=l.nextNamedSibling;for(;I;){if(I.type==="command_argument_sep"){I=I.nextNamedSibling;continue}if(I.type==="command_elements"){I=I.namedChildren[0];continue}if(I.type!=="command_parameter"&&I.type!=="generic_token")break;if(!r?.flagsToIgnore?.includes(I.text))return`${n} ${I.text}`;I=I.nextNamedSibling}return n}function NTn(t){if(t.children.length===3&&["2>&1","1>&2"].includes(t.text))return!0;for(let e of t.children){if(!e||e.isNamed)continue;let l=e.text;return l==="<"||l==="<&"||l==="<&-"}return!1}function WTn(t){for(let e of t.children)if(e){if(e.type==="merging_redirection_operator")return!1;if(e.type==="file_redirection_operator")return e.text.trim().startsWith("<")}return!1}var yTn=[{stem:"git",flagsToIgnore:["--no-pager"]},{stem:"gh"},{stem:"glab"},{stem:"npm"},{stem:"npx"},{stem:"yarn"},{stem:"pnpm"},{stem:"cargo"},{stem:"go"},{stem:"composer"},{stem:"pip"},{stem:"pipenv"},{stem:"poetry"},{stem:"conda"},{stem:"mvn"},{stem:"gradle"},{stem:"gradlew"},{stem:"dotnet"},{stem:"bundle"},{stem:"swift"},{stem:"sbt"},{stem:"flutter"},{stem:"mix"},{stem:"cabal"},{stem:"stack"}];async function tsl(t,e){let l=Hal(e),n=await esl(t,e,yTn);return n.kind==="error"?{result:"failed",reason:`Command could not be assured as safe: ${n.reason}`}:n.commands.length===0?{result:"completed",commands:[{identifier:e,readOnly:!1}],possiblePaths:l,hasWriteFileRedirection:n.hasWriteFileRedirection,canOfferSessionApproval:!1}:{result:"completed",commands:n.commands.map(a=>ETn(t,a.fullCommandText,a.commandIdentifier)).reduce((a,s)=>{let o=a.find(d=>d.identifier===s.identifier);return o?o.readOnly=o.readOnly&&s.readOnly:(o={identifier:s.identifier,readOnly:s.readOnly},a.push(o)),a},[]),possiblePaths:l,hasWriteFileRedirection:n.hasWriteFileRedirection,canOfferSessionApproval:!n.hasPotentiallyConfusingConstructs}}function ETn(t,e,l){switch(l){case"cat":case"cd":case"echo":case"false":case"head":case"hostname":case"ls":case"pwd":case"timeout":case"true":case"whoami":return{identifier:l,readOnly:!0}}if(l==="git"||l.startsWith("git "))return VTn(l);if(t==="bash")switch(l){case"cal":case"df":case"du":case"env":case"free":case"groups":case"id":case"nice":case"nl":case"printenv":case"ps":case"set":case"tail":case"time":case"top":case"type":case"uname":case"unset":case"uptime":case"wc":case"whatis":case"whereis":case"which":return{identifier:l,readOnly:!0};case"date":return RTn(e);case"find":return YTn(e)}if(t==="powershell")switch(l){case"Get-Command":case"Get-Content":case"Get-Process":case"Get-ChildItem":case"Get-Location":case"Select-String":case"Select-Object":case"Test-Path":return{identifier:l,readOnly:!0}}return{identifier:l,readOnly:!1}}function RTn(t){return t.match(/\s-s/)||t.match(/\s--set\b/)?{identifier:"date",readOnly:!1}:{identifier:"date",readOnly:!0}}function YTn(t){let e=["-exec","-execdir","-ok","-okdir","-delete","-fls","-fprint","-fprint0","-fprintf"];for(let l of e)if(t.includes(l))return{identifier:"find",readOnly:!1};return{identifier:"find",readOnly:!0}}function VTn(t){return t==="git"?{identifier:t,readOnly:!0}:["git blame","git branch","git describe","git diff","git grep","git log","git ls-files","git ls-remote","git remote","git rev-parse","git shortlog","git show","git status","git tag"].includes(t)?{identifier:t,readOnly:!0}:{identifier:t,readOnly:!1}}var iFe=class t{agentKind;client;settings;logger;toolConfig;availableTools=[];callback=new bWe;executeToolsInParallel=!0;constructor(){}static async createFromOptions(e){let l=new t;return await l.initializeFromOptions(e),l}async initializeFromOptions(e){this.logger=e.logger,this.executeToolsInParallel=e.executeToolsInParallel??!0;let l=new M3;l.setProblemStatement(e.problemStatement).setInstanceId(dE(e.serviceInstanceId)).setAgentModel(dE(e.serviceAgentModel)).setCallbackUrl(dE(e.serviceCallbackUrl)).setAipSweAgentToken(dE(e.apiAipSweAgentToken)).setAnthropicApiKey(dE(e.apiAnthropicKey)).setCopilotUrl(dE(e.apiCopilotUrl)).setCopilotIntegrationId(dE(e.apiCopilotIntegrationId)).setCopilotHmacKey(dE(e.apiCopilotHmacKey)).setCopilotToken(dE(e.apiCopilotToken)).setTrajectoryOutputFile(dE(e.saveTrajectoryOutput)).setEventsLogDirectory(dE(e.saveEventLogs)).setDisableOnlineEvaluation(e.disableOnlineEvaluation).setGithubRepoName("temp-repo").setGithubRepoCommit("temp-commit").setGithubRepoReadWrite(!1);let n=l.build();F_()?(C_(),this.settings=await PVe(n)):this.settings=await PVe(n),this.callback.addSettings(this.settings),this.settings.trajectory?.outputFile&&this.callback.addCallback(new aFe(this.logger,this.settings.trajectory.outputFile)),this.settings.logs?.eventsLogDir&&this.callback.addCallback(new nFe(this.logger,this.settings.logs.eventsLogDir));let r=this.settings.service?.agent?.model,I=kj(r),a=I.agent;this.agentKind=a;let s=I.model?{model:I.model}:void 0;this.client=BYe(this.settings,this.logger,a,s);let o=!1,d=async p=>{if(o)return{kind:"denied-interactively-by-user",reason:"A previous tool call was rejected"};let h=await e.requestPermission(p);return h.kind==="denied-interactively-by-user"&&(o=!0),h};this.toolConfig={location:".",timeout:3e4,permissions:{requestRequired:!0,request:d},requireReasoning:!1,splitEditingTools:!0,toolPartialResultCallback:e.onToolPartialOutput,shellConfig:(process.platform==="win32"?VA.powerShell:VA.bash).withScriptSafetyAssessor(tsl)};let u=await Eje(this.toolConfig,this.logger),b=[];if(e.mcpHost)try{b=await e.mcpHost.getTools(this.settings,this.logger,this.toolConfig.permissions)}catch(p){this.logger.error(`Failed to get MCP tools: ${p}`)}this.availableTools=[...u,...b]}async*getCompletionWithTools(e,l,n){if(!this.client)throw new Error("CLI not properly initialized");let r={...n,executeToolsInParallel:this.executeToolsInParallel};for await(let I of this.client.getCompletionWithTools(e,l,this.availableTools,r))this.callback&&await this.handleEvent(I),yield I}getToolIntentionSummary(e,l){return this.availableTools.find(r=>r.name===e)?.summariseIntention?.(l)||null}getToolTitle(e){return this.availableTools.find(n=>n.name===e)?.title||null}getAvailableTools(){return this.availableTools}getModel(){return this.client?.model||"unknown"}getAgentKind(){return this.agentKind||"sweagent-capi"}getToolConfig(){return this.toolConfig}async shutdown(){for(let e of this.availableTools)e.shutdown&&await e.shutdown()}async handleEvent(e){if(this.callback)try{await this.callback.progress(e)}catch(l){this.logger?.error(`Error in callback: ${l}`)}}};c();var Cme={CUSTOM_AGENTS:!1,CCA_PUSH:!1,COPILOT_KITTY:!0},wTn=["CUSTOM_AGENTS"],lsl=t=>t in Cme;function nsl(t){let e={...t},l=process.env.COPILOT_CLI_ENABLED_FEATURE_FLAGS;if(l){let n=l.split(",").map(r=>r.trim().toUpperCase());for(let r of n)lsl(r)&&(e[r]=!0)}for(let n of Object.keys(t)){let r=n,I=process.env[r];I&&(I.toLowerCase()==="true"?e[r]=!0:I.toLowerCase()==="false"&&(e[r]=!1))}return e}function rsl(t,e){let l={...e};if(t.staff)for(let n of wTn)l[n]=!0;if(t.feature_flags?.enabled)for(let n of t.feature_flags.enabled){let r=n.toUpperCase();lsl(r)&&(l[r]=!0)}return l}c();import{realpathSync as cFe}from"fs";import QTn from"path";var vme=class{static async isFolderTrusted(e){try{let n=(await Lr.load())?.trusted_folders||[],r=cFe(e);return n.some(I=>{try{let a=cFe(I);return r===a||r.startsWith(a+QTn.sep)}catch{return!1}})}catch{return!1}}static async addTrustedFolder(e){try{let l=await Lr.load()||{},n=l.trusted_folders||[],r=cFe(e);n.some(a=>{try{return cFe(a)===r}catch{return!1}})||(n.push(r),l.trusted_folders=n,await Lr.write(l))}catch(l){throw new Error(`Failed to add trusted folder: ${l instanceof Error?l.message:String(l)}`)}}};c();import{Transform as FTn}from"node:stream";var CTn=Buffer.from([10]),vTn=()=>{let t,e,l,n=!1;function r(){t=Buffer.alloc(1024),l=e=0,n=!1}return r(),new FTn({decodeStrings:!0,transform(I,a,s){let o=0,d,u,b;for(;o<I.length;){u=I.indexOf(13,o),u===-1&&!n?(b=I.subarray(o).lastIndexOf(10),b=b===-1?-1:b+o):(b=I.indexOf(10,o),n=!0),d=Math.min(u===-1?I.length-1:u,b===-1?I.length-1:b),d=d===-1?I.length-1:d;let p,h=o,Z=[13,10].includes(I[d])?d:d+1;for(;(p=Z-h)>0;)if(l+p>t.length){l>0&&this.push(t.subarray(0,l));let N=t.length-l;this.push(I.subarray(h,h+N)),h+=N,r()}else{I.copy(t,l,h,Z),l+=p,e=Math.max(l,e);break}I[d]===10?(this.push(Buffer.concat([t.subarray(0,e),CTn])),r()):I[d]===13&&(l=0),o=d+1}s()},flush(I){I(null,e>0?t.subarray(0,e):null)}})},Isl=t=>{let e=vTn(),l=[];return e.on("data",n=>l.push(n)),e.write(t),e.end(),Buffer.concat(l).toString("utf-8").replaceAll("\r","")};c();var dFe=class{constructor(e,l,n){this.session=e;this.onStreamingResponseSizeChanged=l;this.promptMode=n}streamingMessageText="";streamingMessageId=null;totalResponseSizeBytes=0;onStreamingChunk(e){let n=e.chunk.choices[0]?.delta?.content||"";if(this.promptMode){process.stdout.write(n);return}this.streamingMessageText+=n;let r=fTn(e);r&&(this.totalResponseSizeBytes+=r,this.onStreamingResponseSizeChanged(this.totalResponseSizeBytes)),n&&(this.streamingMessageId||(this.streamingMessageId=Bu()),this.session.addEvent({type:"assistant.message",ephemeral:!0,data:{messageId:this.streamingMessageId,content:this.streamingMessageText}}))}endCurrentStreamingMessage(){this.streamingMessageText="";let e=this.streamingMessageId;return e?(this.streamingMessageId=null,e):null}toJSON(){return"StreamingChunkDisplay"}};function fTn(t){let e=[];t.chunk.choices.forEach(n=>{e.push(n.delta.content),n.delta.tool_calls?.forEach(r=>{r.function&&(e.push(r.function.name),e.push(r.function.arguments))})});let l=e.join("");return l?new TextEncoder().encode(l).length:0}c();function asl(t){let l=t.findLastIndex(HTn)+1,n=t.slice(l).findIndex(XTn);if(n===-1)return{staticEntries:t,dynamicEntries:[]};let r=l+n;return{staticEntries:t.slice(0,r),dynamicEntries:t.slice(r)}}function HTn(t){return t.type==="copilot"&&!t.isStreaming}function XTn(t){return t.type==="tool_call_requested"||t.type==="copilot"&&t.isStreaming===!0}c();c();c();import pT from"node:process";import{spawn as jMn}from"node:child_process";import{fileURLToPath as KMn}from"node:url";import scl from"node:path";import{format as Gtt}from"node:util";c();var kme=nt(hsl(),1);import Xme from"node:path";import eUn from"node:os";c();import _Tn from"os";import pFe from"path";var WL=_Tn.homedir(),{env:IT}=process,Asl=IT.XDG_DATA_HOME||(WL?pFe.join(WL,".local","share"):void 0),kq=IT.XDG_CONFIG_HOME||(WL?pFe.join(WL,".config"):void 0),KTa=IT.XDG_STATE_HOME||(WL?pFe.join(WL,".local","state"):void 0),qTa=IT.XDG_CACHE_HOME||(WL?pFe.join(WL,".cache"):void 0),$Ta=IT.XDG_RUNTIME_DIR||void 0,DTn=(IT.XDG_DATA_DIRS||"/usr/local/share/:/usr/share/").split(":");Asl&&DTn.unshift(Asl);var zTn=(IT.XDG_CONFIG_DIRS||"/etc/xdg").split(":");kq&&zTn.unshift(kq);c();import qTn from"node:path";c();import no from"node:fs";import{promisify as Sh}from"node:util";c();var wf=(t,e)=>function(...n){return t.apply(void 0,n).catch(e)},Ow=(t,e)=>function(...n){try{return t.apply(void 0,n)}catch(r){return e(r)}};c();import Zsl from"node:process";var gsl=Zsl.getuid?!Zsl.getuid():!1,Nsl=1e4,cN=()=>{};c();var fme={isChangeErrorOk:t=>{if(!fme.isNodeError(t))return!1;let{code:e}=t;return e==="ENOSYS"||!gsl&&(e==="EINVAL"||e==="EPERM")},isNodeError:t=>t instanceof Error,isRetriableError:t=>{if(!fme.isNodeError(t))return!1;let{code:e}=t;return e==="EMFILE"||e==="ENFILE"||e==="EAGAIN"||e==="EBUSY"||e==="EACCESS"||e==="EACCES"||e==="EACCS"||e==="EPERM"},onChangeError:t=>{if(!fme.isNodeError(t))throw t;if(!fme.isChangeErrorOk(t))throw t}},am=fme;c();c();var het=class{constructor(){this.interval=25,this.intervalId=void 0,this.limit=Nsl,this.queueActive=new Set,this.queueWaiting=new Set,this.init=()=>{this.intervalId||(this.intervalId=setInterval(this.tick,this.interval))},this.reset=()=>{this.intervalId&&(clearInterval(this.intervalId),delete this.intervalId)},this.add=e=>{this.queueWaiting.add(e),this.queueActive.size<this.limit/2?this.tick():this.init()},this.remove=e=>{this.queueWaiting.delete(e),this.queueActive.delete(e)},this.schedule=()=>new Promise(e=>{let l=()=>this.remove(n),n=()=>e(l);this.add(n)}),this.tick=()=>{if(!(this.queueActive.size>=this.limit)){if(!this.queueWaiting.size)return this.reset();for(let e of this.queueWaiting){if(this.queueActive.size>=this.limit)break;this.queueWaiting.delete(e),this.queueActive.add(e),e()}}}}},Wsl=new het;var Qf=(t,e)=>function(n){return function r(...I){return Wsl.schedule().then(a=>{let s=d=>(a(),d),o=d=>{if(a(),Date.now()>=n)throw d;if(e(d)){let u=Math.round(100*Math.random());return new Promise(p=>setTimeout(p,u)).then(()=>r.apply(void 0,I))}throw d};return t.apply(void 0,I).then(s,o)})}},Ff=(t,e)=>function(n){return function r(...I){try{return t.apply(void 0,I)}catch(a){if(Date.now()>n)throw a;if(e(a))return r.apply(void 0,I);throw a}}};var PTn={attempt:{chmod:wf(Sh(no.chmod),am.onChangeError),chown:wf(Sh(no.chown),am.onChangeError),close:wf(Sh(no.close),cN),fsync:wf(Sh(no.fsync),cN),mkdir:wf(Sh(no.mkdir),cN),realpath:wf(Sh(no.realpath),cN),stat:wf(Sh(no.stat),cN),unlink:wf(Sh(no.unlink),cN),chmodSync:Ow(no.chmodSync,am.onChangeError),chownSync:Ow(no.chownSync,am.onChangeError),closeSync:Ow(no.closeSync,cN),existsSync:Ow(no.existsSync,cN),fsyncSync:Ow(no.fsync,cN),mkdirSync:Ow(no.mkdirSync,cN),realpathSync:Ow(no.realpathSync,cN),statSync:Ow(no.statSync,cN),unlinkSync:Ow(no.unlinkSync,cN)},retry:{close:Qf(Sh(no.close),am.isRetriableError),fsync:Qf(Sh(no.fsync),am.isRetriableError),open:Qf(Sh(no.open),am.isRetriableError),readFile:Qf(Sh(no.readFile),am.isRetriableError),rename:Qf(Sh(no.rename),am.isRetriableError),stat:Qf(Sh(no.stat),am.isRetriableError),write:Qf(Sh(no.write),am.isRetriableError),writeFile:Qf(Sh(no.writeFile),am.isRetriableError),closeSync:Ff(no.closeSync,am.isRetriableError),fsyncSync:Ff(no.fsyncSync,am.isRetriableError),openSync:Ff(no.openSync,am.isRetriableError),readFileSync:Ff(no.readFileSync,am.isRetriableError),renameSync:Ff(no.renameSync,am.isRetriableError),statSync:Ff(no.statSync,am.isRetriableError),writeSync:Ff(no.writeSync,am.isRetriableError),writeFileSync:Ff(no.writeFileSync,am.isRetriableError)}},XG=PTn;c();import ysl from"node:os";import Aet from"node:process";var Esl="utf8",Zet=438,Rsl=511;var Ysl={},Vsl=ysl.userInfo().uid,wsl=ysl.userInfo().gid;var Qsl=1e3,Fsl=!!Aet.getuid,YUa=Aet.getuid?!Aet.getuid():!1,get=128;c();var Csl=t=>t instanceof Error&&"code"in t;var Net=t=>typeof t=="string",hFe=t=>t===void 0;c();c();import KTn from"node:path";c();c();import Lq from"node:process";c();import vsl from"node:process";var fsl=vsl.platform==="linux",AFe=vsl.platform==="win32";c();var Wet=["SIGABRT","SIGALRM","SIGHUP","SIGINT","SIGTERM"];AFe||Wet.push("SIGVTALRM","SIGXCPU","SIGXFSZ","SIGUSR2","SIGTRAP","SIGSYS","SIGQUIT","SIGIOT");fsl&&Wet.push("SIGIO","SIGPOLL","SIGPWR","SIGSTKFLT","SIGUNUSED");var Hsl=Wet;var yet=class{constructor(){this.callbacks=new Set,this.exited=!1,this.exit=e=>{if(!this.exited){this.exited=!0;for(let l of this.callbacks)l();e&&(AFe&&e!=="SIGINT"&&e!=="SIGTERM"&&e!=="SIGKILL"?Lq.kill(Lq.pid,"SIGTERM"):Lq.kill(Lq.pid,e))}},this.hook=()=>{Lq.once("exit",()=>this.exit());for(let e of Hsl)try{Lq.once(e,()=>this.exit(e))}catch{}},this.register=e=>(this.callbacks.add(e),()=>{this.callbacks.delete(e)}),this.hook()}},Xsl=new yet;var jTn=Xsl.register,ksl=jTn;var ey={store:{},create:t=>{let e=`000000${Math.floor(Math.random()*16777215).toString(16)}`.slice(-6),r=`.tmp-${Date.now().toString().slice(-10)}${e}`;return`${t}${r}`},get:(t,e,l=!0)=>{let n=ey.truncate(e(t));return n in ey.store?ey.get(t,e,l):(ey.store[n]=l,[n,()=>delete ey.store[n]])},purge:t=>{ey.store[t]&&(delete ey.store[t],XG.attempt.unlink(t))},purgeSync:t=>{ey.store[t]&&(delete ey.store[t],XG.attempt.unlinkSync(t))},purgeSyncAll:()=>{for(let t in ey.store)ey.purgeSync(t)},truncate:t=>{let e=KTn.basename(t);if(e.length<=get)return t;let l=/^(\.?)(.*?)((?:\.[^.]+)?(?:\.tmp-\d{10}[a-f0-9]{6})?)$/.exec(e);if(!l)return t;let n=e.length-get;return`${t.slice(0,-e.length)}${l[1]}${l[2].slice(0,-n)}${l[3]}`}};ksl(ey.purgeSyncAll);var Hme=ey;function ZFe(t,e,l=Ysl){if(Net(l))return ZFe(t,e,{encoding:l});let n=Date.now()+((l.timeout??Qsl)||-1),r=null,I=null,a=null;try{let s=XG.attempt.realpathSync(t),o=!!s;t=s||t,[I,r]=Hme.get(t,l.tmpCreate||Hme.create,l.tmpPurge!==!1);let d=Fsl&&hFe(l.chown),u=hFe(l.mode);if(o&&(d||u)){let b=XG.attempt.statSync(t);b&&(l={...l},d&&(l.chown={uid:b.uid,gid:b.gid}),u&&(l.mode=b.mode))}if(!o){let b=qTn.dirname(t);XG.attempt.mkdirSync(b,{mode:Rsl,recursive:!0})}a=XG.retry.openSync(n)(I,"w",l.mode||Zet),l.tmpCreated&&l.tmpCreated(I),Net(e)?XG.retry.writeSync(n)(a,e,0,l.encoding||Esl):hFe(e)||XG.retry.writeSync(n)(a,e,0,e.length,0),l.fsync!==!1&&(l.fsyncWait!==!1?XG.retry.fsyncSync(n)(a):XG.attempt.fsync(a)),XG.retry.closeSync(n)(a),a=null,l.chown&&(l.chown.uid!==Vsl||l.chown.gid!==wsl)&&XG.attempt.chownSync(I,l.chown.uid,l.chown.gid),l.mode&&l.mode!==Zet&&XG.attempt.chmodSync(I,l.mode);try{XG.retry.renameSync(n)(I,t)}catch(b){if(!Csl(b)||b.code!=="ENAMETOOLONG")throw b;XG.retry.renameSync(n)(I,Hme.truncate(t))}r(),I=null}finally{a&&XG.attempt.closeSync(a),I&&Hme.purge(I)}}c();var aT=t=>{let e=typeof t;return t!==null&&(e==="object"||e==="function")};var Eet=new Set(["__proto__","prototype","constructor"]),$Tn=new Set("0123456789");function gFe(t){let e=[],l="",n="start",r=!1;for(let I of t)switch(I){case"\\":{if(n==="index")throw new Error("Invalid character in an index");if(n==="indexEnd")throw new Error("Invalid character after an index");r&&(l+=I),n="property",r=!r;break}case".":{if(n==="index")throw new Error("Invalid character in an index");if(n==="indexEnd"){n="property";break}if(r){r=!1,l+=I;break}if(Eet.has(l))return[];e.push(l),l="",n="property";break}case"[":{if(n==="index")throw new Error("Invalid character in an index");if(n==="indexEnd"){n="index";break}if(r){r=!1,l+=I;break}if(n==="property"){if(Eet.has(l))return[];e.push(l),l=""}n="index";break}case"]":{if(n==="index"){e.push(Number.parseInt(l,10)),l="",n="indexEnd";break}if(n==="indexEnd")throw new Error("Invalid character after an index")}default:{if(n==="index"&&!$Tn.has(I))throw new Error("Invalid character in an index");if(n==="indexEnd")throw new Error("Invalid character after an index");n==="start"&&(n="property"),r&&(r=!1,l+="\\"),l+=I}}switch(r&&(l+="\\"),n){case"property":{if(Eet.has(l))return[];e.push(l);break}case"index":throw new Error("Index was not closed");case"start":{e.push("");break}}return e}function Ret(t,e){if(typeof e!="number"&&Array.isArray(t)){let l=Number.parseInt(e,10);return Number.isInteger(l)&&t[l]===t[e]}return!1}function Lsl(t,e){if(Ret(t,e))throw new Error("Cannot use string index")}function Jsl(t,e,l){if(!aT(t)||typeof e!="string")return l===void 0?t:l;let n=gFe(e);if(n.length===0)return l;for(let r=0;r<n.length;r++){let I=n[r];if(Ret(t,I)?t=r===n.length-1?void 0:null:t=t[I],t==null){if(r!==n.length-1)return l;break}}return t===void 0?l:t}function Yet(t,e,l){if(!aT(t)||typeof e!="string")return t;let n=t,r=gFe(e);for(let I=0;I<r.length;I++){let a=r[I];Lsl(t,a),I===r.length-1?t[a]=l:aT(t[a])||(t[a]=typeof r[I+1]=="number"?[]:{}),t=t[a]}return n}function xsl(t,e){if(!aT(t)||typeof e!="string")return!1;let l=gFe(e);for(let n=0;n<l.length;n++){let r=l[n];if(Lsl(t,r),n===l.length-1)return delete t[r],!0;if(t=t[r],!aT(t))return!1}}function Ssl(t,e){if(!aT(t)||typeof e!="string")return!1;let l=gFe(e);if(l.length===0)return!1;for(let n of l){if(!aT(t)||!(n in t)||Ret(t,n))return!1;t=t[n]}return!0}function tUn(t,e){let l=e?Xme.join(t,"config.json"):Xme.join("configstore",`${t}.json`),n=kq??kme.default.mkdtempSync(kme.default.realpathSync(eUn.tmpdir())+Xme.sep);return Xme.join(n,l)}var Bsl="You don't have access to this file.",lUn={mode:448,recursive:!0},Osl={mode:384},Lme=class{constructor(e,l,n={}){this._path=n.configPath??tUn(e,n.globalConfigPath),l&&(this.all={...l,...this.all})}get all(){try{return JSON.parse(kme.default.readFileSync(this._path,"utf8"))}catch(e){if(e.code==="ENOENT")return{};if(e.code==="EACCES"&&(e.message=`${e.message}
2392
+ ${JSON.stringify(r,null,2)}`),new Error("Language.load failed: no language function found in WASM file");let a=n[I]();return new Pal(gL,a)}},mTn=(()=>{var _scriptName=import.meta.url;return async function(moduleArg={}){var moduleRtn,Module=moduleArg,readyPromiseResolve,readyPromiseReject,readyPromise=new Promise((t,e)=>{readyPromiseResolve=t,readyPromiseReject=e}),ENVIRONMENT_IS_WEB=typeof window=="object",ENVIRONMENT_IS_WORKER=typeof WorkerGlobalScope<"u",ENVIRONMENT_IS_NODE=typeof process=="object"&&typeof process.versions=="object"&&typeof process.versions.node=="string"&&process.type!="renderer",ENVIRONMENT_IS_SHELL=!ENVIRONMENT_IS_WEB&&!ENVIRONMENT_IS_NODE&&!ENVIRONMENT_IS_WORKER;if(ENVIRONMENT_IS_NODE){let{createRequire:t}=await import("module");var require=t(import.meta.url)}Module.currentQueryProgressCallback=null,Module.currentProgressCallback=null,Module.currentLogCallback=null,Module.currentParseCallback=null;var moduleOverrides=Object.assign({},Module),arguments_=[],thisProgram="./this.program",quit_=Nt((t,e)=>{throw e},"quit_"),scriptDirectory="";function locateFile(t){return Module.locateFile?Module.locateFile(t,scriptDirectory):scriptDirectory+t}Nt(locateFile,"locateFile");var readAsync,readBinary;if(ENVIRONMENT_IS_NODE){var fs=require("fs"),nodePath=require("path");import.meta.url.startsWith("data:")||(scriptDirectory=nodePath.dirname(require("url").fileURLToPath(import.meta.url))+"/"),readBinary=Nt(t=>{t=isFileURI(t)?new URL(t):t;var e=fs.readFileSync(t);return e},"readBinary"),readAsync=Nt(async(t,e=!0)=>{t=isFileURI(t)?new URL(t):t;var l=fs.readFileSync(t,e?void 0:"utf8");return l},"readAsync"),!Module.thisProgram&&process.argv.length>1&&(thisProgram=process.argv[1].replace(/\\/g,"/")),arguments_=process.argv.slice(2),quit_=Nt((t,e)=>{throw process.exitCode=t,e},"quit_")}else(ENVIRONMENT_IS_WEB||ENVIRONMENT_IS_WORKER)&&(ENVIRONMENT_IS_WORKER?scriptDirectory=self.location.href:typeof document<"u"&&document.currentScript&&(scriptDirectory=document.currentScript.src),_scriptName&&(scriptDirectory=_scriptName),scriptDirectory.startsWith("blob:")?scriptDirectory="":scriptDirectory=scriptDirectory.slice(0,scriptDirectory.replace(/[?#].*/,"").lastIndexOf("/")+1),ENVIRONMENT_IS_WORKER&&(readBinary=Nt(t=>{var e=new XMLHttpRequest;return e.open("GET",t,!1),e.responseType="arraybuffer",e.send(null),new Uint8Array(e.response)},"readBinary")),readAsync=Nt(async t=>{if(isFileURI(t))return new Promise((l,n)=>{var r=new XMLHttpRequest;r.open("GET",t,!0),r.responseType="arraybuffer",r.onload=()=>{if(r.status==200||r.status==0&&r.response){l(r.response);return}n(r.status)},r.onerror=n,r.send(null)});var e=await fetch(t,{credentials:"same-origin"});if(e.ok)return e.arrayBuffer();throw new Error(e.status+" : "+e.url)},"readAsync"));var out=Module.print||console.log.bind(console),err=Module.printErr||console.error.bind(console);Object.assign(Module,moduleOverrides),moduleOverrides=null,Module.arguments&&(arguments_=Module.arguments),Module.thisProgram&&(thisProgram=Module.thisProgram);var dynamicLibraries=Module.dynamicLibraries||[],wasmBinary=Module.wasmBinary,wasmMemory,ABORT=!1,EXITSTATUS;function assert(t,e){t||abort(e)}Nt(assert,"assert");var HEAP,HEAP8,HEAPU8,HEAP16,HEAPU16,HEAP32,HEAPU32,HEAPF32,HEAP64,HEAPU64,HEAPF64,HEAP_DATA_VIEW,runtimeInitialized=!1,isFileURI=Nt(t=>t.startsWith("file://"),"isFileURI");function updateMemoryViews(){var t=wasmMemory.buffer;Module.HEAP_DATA_VIEW=HEAP_DATA_VIEW=new DataView(t),Module.HEAP8=HEAP8=new Int8Array(t),Module.HEAP16=HEAP16=new Int16Array(t),Module.HEAPU8=HEAPU8=new Uint8Array(t),Module.HEAPU16=HEAPU16=new Uint16Array(t),Module.HEAP32=HEAP32=new Int32Array(t),Module.HEAPU32=HEAPU32=new Uint32Array(t),Module.HEAPF32=HEAPF32=new Float32Array(t),Module.HEAPF64=HEAPF64=new Float64Array(t),Module.HEAP64=HEAP64=new BigInt64Array(t),Module.HEAPU64=HEAPU64=new BigUint64Array(t)}if(Nt(updateMemoryViews,"updateMemoryViews"),Module.wasmMemory)wasmMemory=Module.wasmMemory;else{var INITIAL_MEMORY=Module.INITIAL_MEMORY||33554432;wasmMemory=new WebAssembly.Memory({initial:INITIAL_MEMORY/65536,maximum:32768})}updateMemoryViews();var __RELOC_FUNCS__=[];function preRun(){if(Module.preRun)for(typeof Module.preRun=="function"&&(Module.preRun=[Module.preRun]);Module.preRun.length;)addOnPreRun(Module.preRun.shift());callRuntimeCallbacks(onPreRuns)}Nt(preRun,"preRun");function initRuntime(){runtimeInitialized=!0,callRuntimeCallbacks(__RELOC_FUNCS__),wasmExports.__wasm_call_ctors(),callRuntimeCallbacks(onPostCtors)}Nt(initRuntime,"initRuntime");function preMain(){}Nt(preMain,"preMain");function postRun(){if(Module.postRun)for(typeof Module.postRun=="function"&&(Module.postRun=[Module.postRun]);Module.postRun.length;)addOnPostRun(Module.postRun.shift());callRuntimeCallbacks(onPostRuns)}Nt(postRun,"postRun");var runDependencies=0,dependenciesFulfilled=null;function getUniqueRunDependency(t){return t}Nt(getUniqueRunDependency,"getUniqueRunDependency");function addRunDependency(t){runDependencies++,Module.monitorRunDependencies?.(runDependencies)}Nt(addRunDependency,"addRunDependency");function removeRunDependency(t){if(runDependencies--,Module.monitorRunDependencies?.(runDependencies),runDependencies==0&&dependenciesFulfilled){var e=dependenciesFulfilled;dependenciesFulfilled=null,e()}}Nt(removeRunDependency,"removeRunDependency");function abort(t){Module.onAbort?.(t),t="Aborted("+t+")",err(t),ABORT=!0,t+=". Build with -sASSERTIONS for more info.";var e=new WebAssembly.RuntimeError(t);throw readyPromiseReject(e),e}Nt(abort,"abort");var wasmBinaryFile;function findWasmBinary(){return Module.locateFile?locateFile("tree-sitter.wasm"):new URL("tree-sitter.wasm",import.meta.url).href}Nt(findWasmBinary,"findWasmBinary");function getBinarySync(t){if(t==wasmBinaryFile&&wasmBinary)return new Uint8Array(wasmBinary);if(readBinary)return readBinary(t);throw"both async and sync fetching of the wasm failed"}Nt(getBinarySync,"getBinarySync");async function getWasmBinary(t){if(!wasmBinary)try{var e=await readAsync(t);return new Uint8Array(e)}catch{}return getBinarySync(t)}Nt(getWasmBinary,"getWasmBinary");async function instantiateArrayBuffer(t,e){try{var l=await getWasmBinary(t),n=await WebAssembly.instantiate(l,e);return n}catch(r){err(`failed to asynchronously prepare wasm: ${r}`),abort(r)}}Nt(instantiateArrayBuffer,"instantiateArrayBuffer");async function instantiateAsync(t,e,l){if(!t&&typeof WebAssembly.instantiateStreaming=="function"&&!isFileURI(e)&&!ENVIRONMENT_IS_NODE)try{var n=fetch(e,{credentials:"same-origin"}),r=await WebAssembly.instantiateStreaming(n,l);return r}catch(I){err(`wasm streaming compile failed: ${I}`),err("falling back to ArrayBuffer instantiation")}return instantiateArrayBuffer(e,l)}Nt(instantiateAsync,"instantiateAsync");function getWasmImports(){return{env:wasmImports,wasi_snapshot_preview1:wasmImports,"GOT.mem":new Proxy(wasmImports,GOTHandler),"GOT.func":new Proxy(wasmImports,GOTHandler)}}Nt(getWasmImports,"getWasmImports");async function createWasm(){function t(I,a){wasmExports=I.exports,wasmExports=relocateExports(wasmExports,1024);var s=getDylinkMetadata(a);return s.neededDynlibs&&(dynamicLibraries=s.neededDynlibs.concat(dynamicLibraries)),mergeLibSymbols(wasmExports,"main"),LDSO.init(),loadDylibs(),__RELOC_FUNCS__.push(wasmExports.__wasm_apply_data_relocs),removeRunDependency("wasm-instantiate"),wasmExports}Nt(t,"receiveInstance"),addRunDependency("wasm-instantiate");function e(I){return t(I.instance,I.module)}Nt(e,"receiveInstantiationResult");var l=getWasmImports();if(Module.instantiateWasm)return new Promise((I,a)=>{Module.instantiateWasm(l,(s,o)=>{t(s,o),I(s.exports)})});wasmBinaryFile??=findWasmBinary();try{var n=await instantiateAsync(wasmBinary,wasmBinaryFile,l),r=e(n);return r}catch(I){return readyPromiseReject(I),Promise.reject(I)}}Nt(createWasm,"createWasm");var ASM_CONSTS={};class ExitStatus{static{Nt(this,"ExitStatus")}name="ExitStatus";constructor(e){this.message=`Program terminated with exit(${e})`,this.status=e}}var GOT={},currentModuleWeakSymbols=new Set([]),GOTHandler={get(t,e){var l=GOT[e];return l||(l=GOT[e]=new WebAssembly.Global({value:"i32",mutable:!0})),currentModuleWeakSymbols.has(e)||(l.required=!0),l}},LE_HEAP_LOAD_F32=Nt(t=>HEAP_DATA_VIEW.getFloat32(t,!0),"LE_HEAP_LOAD_F32"),LE_HEAP_LOAD_F64=Nt(t=>HEAP_DATA_VIEW.getFloat64(t,!0),"LE_HEAP_LOAD_F64"),LE_HEAP_LOAD_I16=Nt(t=>HEAP_DATA_VIEW.getInt16(t,!0),"LE_HEAP_LOAD_I16"),LE_HEAP_LOAD_I32=Nt(t=>HEAP_DATA_VIEW.getInt32(t,!0),"LE_HEAP_LOAD_I32"),LE_HEAP_LOAD_U16=Nt(t=>HEAP_DATA_VIEW.getUint16(t,!0),"LE_HEAP_LOAD_U16"),LE_HEAP_LOAD_U32=Nt(t=>HEAP_DATA_VIEW.getUint32(t,!0),"LE_HEAP_LOAD_U32"),LE_HEAP_STORE_F32=Nt((t,e)=>HEAP_DATA_VIEW.setFloat32(t,e,!0),"LE_HEAP_STORE_F32"),LE_HEAP_STORE_F64=Nt((t,e)=>HEAP_DATA_VIEW.setFloat64(t,e,!0),"LE_HEAP_STORE_F64"),LE_HEAP_STORE_I16=Nt((t,e)=>HEAP_DATA_VIEW.setInt16(t,e,!0),"LE_HEAP_STORE_I16"),LE_HEAP_STORE_I32=Nt((t,e)=>HEAP_DATA_VIEW.setInt32(t,e,!0),"LE_HEAP_STORE_I32"),LE_HEAP_STORE_U16=Nt((t,e)=>HEAP_DATA_VIEW.setUint16(t,e,!0),"LE_HEAP_STORE_U16"),LE_HEAP_STORE_U32=Nt((t,e)=>HEAP_DATA_VIEW.setUint32(t,e,!0),"LE_HEAP_STORE_U32"),callRuntimeCallbacks=Nt(t=>{for(;t.length>0;)t.shift()(Module)},"callRuntimeCallbacks"),onPostRuns=[],addOnPostRun=Nt(t=>onPostRuns.unshift(t),"addOnPostRun"),onPreRuns=[],addOnPreRun=Nt(t=>onPreRuns.unshift(t),"addOnPreRun"),UTF8Decoder=typeof TextDecoder<"u"?new TextDecoder:void 0,UTF8ArrayToString=Nt((t,e=0,l=NaN)=>{for(var n=e+l,r=e;t[r]&&!(r>=n);)++r;if(r-e>16&&t.buffer&&UTF8Decoder)return UTF8Decoder.decode(t.subarray(e,r));for(var I="";e<r;){var a=t[e++];if(!(a&128)){I+=String.fromCharCode(a);continue}var s=t[e++]&63;if((a&224)==192){I+=String.fromCharCode((a&31)<<6|s);continue}var o=t[e++]&63;if((a&240)==224?a=(a&15)<<12|s<<6|o:a=(a&7)<<18|s<<12|o<<6|t[e++]&63,a<65536)I+=String.fromCharCode(a);else{var d=a-65536;I+=String.fromCharCode(55296|d>>10,56320|d&1023)}}return I},"UTF8ArrayToString"),getDylinkMetadata=Nt(t=>{var e=0,l=0;function n(){return t[e++]}Nt(n,"getU8");function r(){for(var We=0,ee=1;;){var M=t[e++];if(We+=(M&127)*ee,ee*=128,!(M&128))break}return We}Nt(r,"getLEB");function I(){var We=r();return e+=We,UTF8ArrayToString(t,e-We,We)}Nt(I,"getString");function a(We,ee){if(We)throw new Error(ee)}Nt(a,"failIf");var s="dylink.0";if(t instanceof WebAssembly.Module){var o=WebAssembly.Module.customSections(t,s);o.length===0&&(s="dylink",o=WebAssembly.Module.customSections(t,s)),a(o.length===0,"need dylink section"),t=new Uint8Array(o[0]),l=t.length}else{var d=new Uint32Array(new Uint8Array(t.subarray(0,24)).buffer),u=d[0]==1836278016||d[0]==6386541;a(!u,"need to see wasm magic number"),a(t[8]!==0,"need the dylink section to be first"),e=9;var b=r();l=e+b,s=I()}var p={neededDynlibs:[],tlsExports:new Set,weakImports:new Set};if(s=="dylink"){p.memorySize=r(),p.memoryAlign=r(),p.tableSize=r(),p.tableAlign=r();for(var h=r(),Z=0;Z<h;++Z){var N=I();p.neededDynlibs.push(N)}}else{a(s!=="dylink.0");for(var y=1,Y=2,w=3,H=4,J=256,S=3,T=1;e<l;){var U=n(),j=r();if(U===y)p.memorySize=r(),p.memoryAlign=r(),p.tableSize=r(),p.tableAlign=r();else if(U===Y)for(var h=r(),Z=0;Z<h;++Z)N=I(),p.neededDynlibs.push(N);else if(U===w)for(var O=r();O--;){var z=I(),se=r();se&J&&p.tlsExports.add(z)}else if(U===H)for(var O=r();O--;){var ue=I(),z=I(),se=r();(se&S)==T&&p.weakImports.add(z)}else e+=j}}return p},"getDylinkMetadata");function getValue(t,e="i8"){switch(e.endsWith("*")&&(e="*"),e){case"i1":return HEAP8[t];case"i8":return HEAP8[t];case"i16":return LE_HEAP_LOAD_I16((t>>1)*2);case"i32":return LE_HEAP_LOAD_I32((t>>2)*4);case"i64":return HEAP64[t>>3];case"float":return LE_HEAP_LOAD_F32((t>>2)*4);case"double":return LE_HEAP_LOAD_F64((t>>3)*8);case"*":return LE_HEAP_LOAD_U32((t>>2)*4);default:abort(`invalid type for getValue: ${e}`)}}Nt(getValue,"getValue");var newDSO=Nt((t,e,l)=>{var n={refcount:1/0,name:t,exports:l,global:!0};return LDSO.loadedLibsByName[t]=n,e!=null&&(LDSO.loadedLibsByHandle[e]=n),n},"newDSO"),LDSO={loadedLibsByName:{},loadedLibsByHandle:{},init(){newDSO("__main__",0,wasmImports)}},___heap_base=78224,alignMemory=Nt((t,e)=>Math.ceil(t/e)*e,"alignMemory"),getMemory=Nt(t=>{if(runtimeInitialized)return _calloc(t,1);var e=___heap_base,l=e+alignMemory(t,16);return ___heap_base=l,GOT.__heap_base.value=l,e},"getMemory"),isInternalSym=Nt(t=>["__cpp_exception","__c_longjmp","__wasm_apply_data_relocs","__dso_handle","__tls_size","__tls_align","__set_stack_limits","_emscripten_tls_init","__wasm_init_tls","__wasm_call_ctors","__start_em_asm","__stop_em_asm","__start_em_js","__stop_em_js"].includes(t)||t.startsWith("__em_js__"),"isInternalSym"),uleb128Encode=Nt((t,e)=>{t<128?e.push(t):e.push(t%128|128,t>>7)},"uleb128Encode"),sigToWasmTypes=Nt(t=>{for(var e={i:"i32",j:"i64",f:"f32",d:"f64",e:"externref",p:"i32"},l={parameters:[],results:t[0]=="v"?[]:[e[t[0]]]},n=1;n<t.length;++n)l.parameters.push(e[t[n]]);return l},"sigToWasmTypes"),generateFuncType=Nt((t,e)=>{var l=t.slice(0,1),n=t.slice(1),r={i:127,p:127,j:126,f:125,d:124,e:111};e.push(96),uleb128Encode(n.length,e);for(var I=0;I<n.length;++I)e.push(r[n[I]]);l=="v"?e.push(0):e.push(1,r[l])},"generateFuncType"),convertJsFunctionToWasm=Nt((t,e)=>{if(typeof WebAssembly.Function=="function")return new WebAssembly.Function(sigToWasmTypes(e),t);var l=[1];generateFuncType(e,l);var n=[0,97,115,109,1,0,0,0,1];uleb128Encode(l.length,n),n.push(...l),n.push(2,7,1,1,101,1,102,0,0,7,5,1,1,102,0,0);var r=new WebAssembly.Module(new Uint8Array(n)),I=new WebAssembly.Instance(r,{e:{f:t}}),a=I.exports.f;return a},"convertJsFunctionToWasm"),wasmTableMirror=[],wasmTable=new WebAssembly.Table({initial:31,element:"anyfunc"}),getWasmTableEntry=Nt(t=>{var e=wasmTableMirror[t];return e||(t>=wasmTableMirror.length&&(wasmTableMirror.length=t+1),wasmTableMirror[t]=e=wasmTable.get(t)),e},"getWasmTableEntry"),updateTableMap=Nt((t,e)=>{if(functionsInTableMap)for(var l=t;l<t+e;l++){var n=getWasmTableEntry(l);n&&functionsInTableMap.set(n,l)}},"updateTableMap"),functionsInTableMap,getFunctionAddress=Nt(t=>(functionsInTableMap||(functionsInTableMap=new WeakMap,updateTableMap(0,wasmTable.length)),functionsInTableMap.get(t)||0),"getFunctionAddress"),freeTableIndexes=[],getEmptyTableSlot=Nt(()=>{if(freeTableIndexes.length)return freeTableIndexes.pop();try{wasmTable.grow(1)}catch(t){throw t instanceof RangeError?"Unable to grow wasm table. Set ALLOW_TABLE_GROWTH.":t}return wasmTable.length-1},"getEmptyTableSlot"),setWasmTableEntry=Nt((t,e)=>{wasmTable.set(t,e),wasmTableMirror[t]=wasmTable.get(t)},"setWasmTableEntry"),addFunction=Nt((t,e)=>{var l=getFunctionAddress(t);if(l)return l;var n=getEmptyTableSlot();try{setWasmTableEntry(n,t)}catch(I){if(!(I instanceof TypeError))throw I;var r=convertJsFunctionToWasm(t,e);setWasmTableEntry(n,r)}return functionsInTableMap.set(t,n),n},"addFunction"),updateGOT=Nt((t,e)=>{for(var l in t)if(!isInternalSym(l)){var n=t[l];GOT[l]||=new WebAssembly.Global({value:"i32",mutable:!0}),(e||GOT[l].value==0)&&(typeof n=="function"?GOT[l].value=addFunction(n):typeof n=="number"?GOT[l].value=n:err(`unhandled export type for '${l}': ${typeof n}`))}},"updateGOT"),relocateExports=Nt((t,e,l)=>{var n={};for(var r in t){var I=t[r];typeof I=="object"&&(I=I.value),typeof I=="number"&&(I+=e),n[r]=I}return updateGOT(n,l),n},"relocateExports"),isSymbolDefined=Nt(t=>{var e=wasmImports[t];return!(!e||e.stub)},"isSymbolDefined"),dynCall=Nt((t,e,l=[])=>{var n=getWasmTableEntry(e)(...l);return n},"dynCall"),stackSave=Nt(()=>_emscripten_stack_get_current(),"stackSave"),stackRestore=Nt(t=>__emscripten_stack_restore(t),"stackRestore"),createInvokeFunction=Nt(t=>(e,...l)=>{var n=stackSave();try{return dynCall(t,e,l)}catch(r){if(stackRestore(n),r!==r+0)throw r;if(_setThrew(1,0),t[0]=="j")return 0n}},"createInvokeFunction"),resolveGlobalSymbol=Nt((t,e=!1)=>{var l;return isSymbolDefined(t)?l=wasmImports[t]:t.startsWith("invoke_")&&(l=wasmImports[t]=createInvokeFunction(t.split("_")[1])),{sym:l,name:t}},"resolveGlobalSymbol"),onPostCtors=[],addOnPostCtor=Nt(t=>onPostCtors.unshift(t),"addOnPostCtor"),UTF8ToString=Nt((t,e)=>t?UTF8ArrayToString(HEAPU8,t,e):"","UTF8ToString"),loadWebAssemblyModule=Nt((binary,flags,libName,localScope,handle)=>{var metadata=getDylinkMetadata(binary);currentModuleWeakSymbols=metadata.weakImports;function loadModule(){var memAlign=Math.pow(2,metadata.memoryAlign),memoryBase=metadata.memorySize?alignMemory(getMemory(metadata.memorySize+memAlign),memAlign):0,tableBase=metadata.tableSize?wasmTable.length:0;handle&&(HEAP8[handle+8]=1,LE_HEAP_STORE_U32((handle+12>>2)*4,memoryBase),LE_HEAP_STORE_I32((handle+16>>2)*4,metadata.memorySize),LE_HEAP_STORE_U32((handle+20>>2)*4,tableBase),LE_HEAP_STORE_I32((handle+24>>2)*4,metadata.tableSize)),metadata.tableSize&&wasmTable.grow(metadata.tableSize);var moduleExports;function resolveSymbol(t){var e=resolveGlobalSymbol(t).sym;return!e&&localScope&&(e=localScope[t]),e||(e=moduleExports[t]),e}Nt(resolveSymbol,"resolveSymbol");var proxyHandler={get(t,e){switch(e){case"__memory_base":return memoryBase;case"__table_base":return tableBase}if(e in wasmImports&&!wasmImports[e].stub){var l=wasmImports[e];return l}if(!(e in t)){var n;t[e]=(...r)=>(n||=resolveSymbol(e),n(...r))}return t[e]}},proxy=new Proxy({},proxyHandler),info={"GOT.mem":new Proxy({},GOTHandler),"GOT.func":new Proxy({},GOTHandler),env:proxy,wasi_snapshot_preview1:proxy};function postInstantiation(module,instance){updateTableMap(tableBase,metadata.tableSize),moduleExports=relocateExports(instance.exports,memoryBase),flags.allowUndefined||reportUndefinedSymbols();function addEmAsm(addr,body){for(var args=[],arity=0;arity<16&&body.indexOf("$"+arity)!=-1;arity++)args.push("$"+arity);args=args.join(",");var func=`(${args}) => { ${body} };`;ASM_CONSTS[start]=eval(func)}if(Nt(addEmAsm,"addEmAsm"),"__start_em_asm"in moduleExports)for(var start=moduleExports.__start_em_asm,stop=moduleExports.__stop_em_asm;start<stop;){var jsString=UTF8ToString(start);addEmAsm(start,jsString),start=HEAPU8.indexOf(0,start)+1}function addEmJs(name,cSig,body){var jsArgs=[];if(cSig=cSig.slice(1,-1),cSig!="void"){cSig=cSig.split(",");for(var i in cSig){var jsArg=cSig[i].split(" ").pop();jsArgs.push(jsArg.replace("*",""))}}var func=`(${jsArgs}) => ${body};`;moduleExports[name]=eval(func)}Nt(addEmJs,"addEmJs");for(var name in moduleExports)if(name.startsWith("__em_js__")){var start=moduleExports[name],jsString=UTF8ToString(start),parts=jsString.split("<::>");addEmJs(name.replace("__em_js__",""),parts[0],parts[1]),delete moduleExports[name]}var applyRelocs=moduleExports.__wasm_apply_data_relocs;applyRelocs&&(runtimeInitialized?applyRelocs():__RELOC_FUNCS__.push(applyRelocs));var init=moduleExports.__wasm_call_ctors;return init&&(runtimeInitialized?init():addOnPostCtor(init)),moduleExports}if(Nt(postInstantiation,"postInstantiation"),flags.loadAsync){if(binary instanceof WebAssembly.Module){var instance=new WebAssembly.Instance(binary,info);return Promise.resolve(postInstantiation(binary,instance))}return WebAssembly.instantiate(binary,info).then(t=>postInstantiation(t.module,t.instance))}var module=binary instanceof WebAssembly.Module?binary:new WebAssembly.Module(binary),instance=new WebAssembly.Instance(module,info);return postInstantiation(module,instance)}return Nt(loadModule,"loadModule"),flags.loadAsync?metadata.neededDynlibs.reduce((t,e)=>t.then(()=>loadDynamicLibrary(e,flags,localScope)),Promise.resolve()).then(loadModule):(metadata.neededDynlibs.forEach(t=>loadDynamicLibrary(t,flags,localScope)),loadModule())},"loadWebAssemblyModule"),mergeLibSymbols=Nt((t,e)=>{for(var[l,n]of Object.entries(t)){let r=Nt(a=>{isSymbolDefined(a)||(wasmImports[a]=n)},"setImport");r(l);let I="__main_argc_argv";l=="main"&&r(I),l==I&&r("main")}},"mergeLibSymbols"),asyncLoad=Nt(async t=>{var e=await readAsync(t);return new Uint8Array(e)},"asyncLoad");function loadDynamicLibrary(t,e={global:!0,nodelete:!0},l,n){var r=LDSO.loadedLibsByName[t];if(r)return e.global?r.global||(r.global=!0,mergeLibSymbols(r.exports,t)):l&&Object.assign(l,r.exports),e.nodelete&&r.refcount!==1/0&&(r.refcount=1/0),r.refcount++,n&&(LDSO.loadedLibsByHandle[n]=r),e.loadAsync?Promise.resolve(!0):!0;r=newDSO(t,n,"loading"),r.refcount=e.nodelete?1/0:1,r.global=e.global;function I(){if(n){var o=LE_HEAP_LOAD_U32((n+28>>2)*4),d=LE_HEAP_LOAD_U32((n+32>>2)*4);if(o&&d){var u=HEAP8.slice(o,o+d);return e.loadAsync?Promise.resolve(u):u}}var b=locateFile(t);if(e.loadAsync)return asyncLoad(b);if(!readBinary)throw new Error(`${b}: file not found, and synchronous loading of external files is not available`);return readBinary(b)}Nt(I,"loadLibData");function a(){return e.loadAsync?I().then(o=>loadWebAssemblyModule(o,e,t,l,n)):loadWebAssemblyModule(I(),e,t,l,n)}Nt(a,"getExports");function s(o){r.global?mergeLibSymbols(o,t):l&&Object.assign(l,o),r.exports=o}return Nt(s,"moduleLoaded"),e.loadAsync?a().then(o=>(s(o),!0)):(s(a()),!0)}Nt(loadDynamicLibrary,"loadDynamicLibrary");var reportUndefinedSymbols=Nt(()=>{for(var[t,e]of Object.entries(GOT))if(e.value==0){var l=resolveGlobalSymbol(t,!0).sym;if(!l&&!e.required)continue;if(typeof l=="function")e.value=addFunction(l,l.sig);else if(typeof l=="number")e.value=l;else throw new Error(`bad export type for '${t}': ${typeof l}`)}},"reportUndefinedSymbols"),loadDylibs=Nt(()=>{if(!dynamicLibraries.length){reportUndefinedSymbols();return}addRunDependency("loadDylibs"),dynamicLibraries.reduce((t,e)=>t.then(()=>loadDynamicLibrary(e,{loadAsync:!0,global:!0,nodelete:!0,allowUndefined:!0})),Promise.resolve()).then(()=>{reportUndefinedSymbols(),removeRunDependency("loadDylibs")})},"loadDylibs"),noExitRuntime=Module.noExitRuntime||!0;function setValue(t,e,l="i8"){switch(l.endsWith("*")&&(l="*"),l){case"i1":HEAP8[t]=e;break;case"i8":HEAP8[t]=e;break;case"i16":LE_HEAP_STORE_I16((t>>1)*2,e);break;case"i32":LE_HEAP_STORE_I32((t>>2)*4,e);break;case"i64":HEAP64[t>>3]=BigInt(e);break;case"float":LE_HEAP_STORE_F32((t>>2)*4,e);break;case"double":LE_HEAP_STORE_F64((t>>3)*8,e);break;case"*":LE_HEAP_STORE_U32((t>>2)*4,e);break;default:abort(`invalid type for setValue: ${l}`)}}Nt(setValue,"setValue");var ___memory_base=new WebAssembly.Global({value:"i32",mutable:!1},1024),___stack_pointer=new WebAssembly.Global({value:"i32",mutable:!0},78224),___table_base=new WebAssembly.Global({value:"i32",mutable:!1},1),__abort_js=Nt(()=>abort(""),"__abort_js");__abort_js.sig="v";var _emscripten_get_now=Nt(()=>performance.now(),"_emscripten_get_now");_emscripten_get_now.sig="d";var _emscripten_date_now=Nt(()=>Date.now(),"_emscripten_date_now");_emscripten_date_now.sig="d";var nowIsMonotonic=1,checkWasiClock=Nt(t=>t>=0&&t<=3,"checkWasiClock"),INT53_MAX=9007199254740992,INT53_MIN=-9007199254740992,bigintToI53Checked=Nt(t=>t<INT53_MIN||t>INT53_MAX?NaN:Number(t),"bigintToI53Checked");function _clock_time_get(t,e,l){if(e=bigintToI53Checked(e),!checkWasiClock(t))return 28;var n;if(t===0)n=_emscripten_date_now();else if(nowIsMonotonic)n=_emscripten_get_now();else return 52;var r=Math.round(n*1e3*1e3);return HEAP64[l>>3]=BigInt(r),0}Nt(_clock_time_get,"_clock_time_get"),_clock_time_get.sig="iijp";var getHeapMax=Nt(()=>2147483648,"getHeapMax"),growMemory=Nt(t=>{var e=wasmMemory.buffer,l=(t-e.byteLength+65535)/65536|0;try{return wasmMemory.grow(l),updateMemoryViews(),1}catch{}},"growMemory"),_emscripten_resize_heap=Nt(t=>{var e=HEAPU8.length;t>>>=0;var l=getHeapMax();if(t>l)return!1;for(var n=1;n<=4;n*=2){var r=e*(1+.2/n);r=Math.min(r,t+100663296);var I=Math.min(l,alignMemory(Math.max(t,r),65536)),a=growMemory(I);if(a)return!0}return!1},"_emscripten_resize_heap");_emscripten_resize_heap.sig="ip";var _fd_close=Nt(t=>52,"_fd_close");_fd_close.sig="ii";function _fd_seek(t,e,l,n){return e=bigintToI53Checked(e),70}Nt(_fd_seek,"_fd_seek"),_fd_seek.sig="iijip";var printCharBuffers=[null,[],[]],printChar=Nt((t,e)=>{var l=printCharBuffers[t];e===0||e===10?((t===1?out:err)(UTF8ArrayToString(l)),l.length=0):l.push(e)},"printChar"),flush_NO_FILESYSTEM=Nt(()=>{printCharBuffers[1].length&&printChar(1,10),printCharBuffers[2].length&&printChar(2,10)},"flush_NO_FILESYSTEM"),SYSCALLS={varargs:void 0,getStr(t){var e=UTF8ToString(t);return e}},_fd_write=Nt((t,e,l,n)=>{for(var r=0,I=0;I<l;I++){var a=LE_HEAP_LOAD_U32((e>>2)*4),s=LE_HEAP_LOAD_U32((e+4>>2)*4);e+=8;for(var o=0;o<s;o++)printChar(t,HEAPU8[a+o]);r+=s}return LE_HEAP_STORE_U32((n>>2)*4,r),0},"_fd_write");_fd_write.sig="iippp";function _tree_sitter_log_callback(t,e){if(Module.currentLogCallback){let l=UTF8ToString(e);Module.currentLogCallback(l,t!==0)}}Nt(_tree_sitter_log_callback,"_tree_sitter_log_callback");function _tree_sitter_parse_callback(t,e,l,n,r){let a=Module.currentParseCallback(e,{row:l,column:n});typeof a=="string"?(setValue(r,a.length,"i32"),stringToUTF16(a,t,10240)):setValue(r,0,"i32")}Nt(_tree_sitter_parse_callback,"_tree_sitter_parse_callback");function _tree_sitter_progress_callback(t,e){return Module.currentProgressCallback?Module.currentProgressCallback({currentOffset:t,hasError:e}):!1}Nt(_tree_sitter_progress_callback,"_tree_sitter_progress_callback");function _tree_sitter_query_progress_callback(t){return Module.currentQueryProgressCallback?Module.currentQueryProgressCallback({currentOffset:t}):!1}Nt(_tree_sitter_query_progress_callback,"_tree_sitter_query_progress_callback");var runtimeKeepaliveCounter=0,keepRuntimeAlive=Nt(()=>noExitRuntime||runtimeKeepaliveCounter>0,"keepRuntimeAlive"),_proc_exit=Nt(t=>{EXITSTATUS=t,keepRuntimeAlive()||(Module.onExit?.(t),ABORT=!0),quit_(t,new ExitStatus(t))},"_proc_exit");_proc_exit.sig="vi";var exitJS=Nt((t,e)=>{EXITSTATUS=t,_proc_exit(t)},"exitJS"),handleException=Nt(t=>{if(t instanceof ExitStatus||t=="unwind")return EXITSTATUS;quit_(1,t)},"handleException"),lengthBytesUTF8=Nt(t=>{for(var e=0,l=0;l<t.length;++l){var n=t.charCodeAt(l);n<=127?e++:n<=2047?e+=2:n>=55296&&n<=57343?(e+=4,++l):e+=3}return e},"lengthBytesUTF8"),stringToUTF8Array=Nt((t,e,l,n)=>{if(!(n>0))return 0;for(var r=l,I=l+n-1,a=0;a<t.length;++a){var s=t.charCodeAt(a);if(s>=55296&&s<=57343){var o=t.charCodeAt(++a);s=65536+((s&1023)<<10)|o&1023}if(s<=127){if(l>=I)break;e[l++]=s}else if(s<=2047){if(l+1>=I)break;e[l++]=192|s>>6,e[l++]=128|s&63}else if(s<=65535){if(l+2>=I)break;e[l++]=224|s>>12,e[l++]=128|s>>6&63,e[l++]=128|s&63}else{if(l+3>=I)break;e[l++]=240|s>>18,e[l++]=128|s>>12&63,e[l++]=128|s>>6&63,e[l++]=128|s&63}}return e[l]=0,l-r},"stringToUTF8Array"),stringToUTF8=Nt((t,e,l)=>stringToUTF8Array(t,HEAPU8,e,l),"stringToUTF8"),stackAlloc=Nt(t=>__emscripten_stack_alloc(t),"stackAlloc"),stringToUTF8OnStack=Nt(t=>{var e=lengthBytesUTF8(t)+1,l=stackAlloc(e);return stringToUTF8(t,l,e),l},"stringToUTF8OnStack"),AsciiToString=Nt(t=>{for(var e="";;){var l=HEAPU8[t++];if(!l)return e;e+=String.fromCharCode(l)}},"AsciiToString"),stringToUTF16=Nt((t,e,l)=>{if(l??=2147483647,l<2)return 0;l-=2;for(var n=e,r=l<t.length*2?l/2:t.length,I=0;I<r;++I){var a=t.charCodeAt(I);LE_HEAP_STORE_I16((e>>1)*2,a),e+=2}return LE_HEAP_STORE_I16((e>>1)*2,0),e-n},"stringToUTF16"),wasmImports={__heap_base:___heap_base,__indirect_function_table:wasmTable,__memory_base:___memory_base,__stack_pointer:___stack_pointer,__table_base:___table_base,_abort_js:__abort_js,clock_time_get:_clock_time_get,emscripten_resize_heap:_emscripten_resize_heap,fd_close:_fd_close,fd_seek:_fd_seek,fd_write:_fd_write,memory:wasmMemory,tree_sitter_log_callback:_tree_sitter_log_callback,tree_sitter_parse_callback:_tree_sitter_parse_callback,tree_sitter_progress_callback:_tree_sitter_progress_callback,tree_sitter_query_progress_callback:_tree_sitter_query_progress_callback},wasmExports=await createWasm(),___wasm_call_ctors=wasmExports.__wasm_call_ctors,_malloc=Module._malloc=wasmExports.malloc,_calloc=Module._calloc=wasmExports.calloc,_realloc=Module._realloc=wasmExports.realloc,_free=Module._free=wasmExports.free,_memcmp=Module._memcmp=wasmExports.memcmp,_ts_language_symbol_count=Module._ts_language_symbol_count=wasmExports.ts_language_symbol_count,_ts_language_state_count=Module._ts_language_state_count=wasmExports.ts_language_state_count,_ts_language_version=Module._ts_language_version=wasmExports.ts_language_version,_ts_language_abi_version=Module._ts_language_abi_version=wasmExports.ts_language_abi_version,_ts_language_metadata=Module._ts_language_metadata=wasmExports.ts_language_metadata,_ts_language_name=Module._ts_language_name=wasmExports.ts_language_name,_ts_language_field_count=Module._ts_language_field_count=wasmExports.ts_language_field_count,_ts_language_next_state=Module._ts_language_next_state=wasmExports.ts_language_next_state,_ts_language_symbol_name=Module._ts_language_symbol_name=wasmExports.ts_language_symbol_name,_ts_language_symbol_for_name=Module._ts_language_symbol_for_name=wasmExports.ts_language_symbol_for_name,_strncmp=Module._strncmp=wasmExports.strncmp,_ts_language_symbol_type=Module._ts_language_symbol_type=wasmExports.ts_language_symbol_type,_ts_language_field_name_for_id=Module._ts_language_field_name_for_id=wasmExports.ts_language_field_name_for_id,_ts_lookahead_iterator_new=Module._ts_lookahead_iterator_new=wasmExports.ts_lookahead_iterator_new,_ts_lookahead_iterator_delete=Module._ts_lookahead_iterator_delete=wasmExports.ts_lookahead_iterator_delete,_ts_lookahead_iterator_reset_state=Module._ts_lookahead_iterator_reset_state=wasmExports.ts_lookahead_iterator_reset_state,_ts_lookahead_iterator_reset=Module._ts_lookahead_iterator_reset=wasmExports.ts_lookahead_iterator_reset,_ts_lookahead_iterator_next=Module._ts_lookahead_iterator_next=wasmExports.ts_lookahead_iterator_next,_ts_lookahead_iterator_current_symbol=Module._ts_lookahead_iterator_current_symbol=wasmExports.ts_lookahead_iterator_current_symbol,_ts_parser_delete=Module._ts_parser_delete=wasmExports.ts_parser_delete,_ts_parser_reset=Module._ts_parser_reset=wasmExports.ts_parser_reset,_ts_parser_set_language=Module._ts_parser_set_language=wasmExports.ts_parser_set_language,_ts_parser_timeout_micros=Module._ts_parser_timeout_micros=wasmExports.ts_parser_timeout_micros,_ts_parser_set_timeout_micros=Module._ts_parser_set_timeout_micros=wasmExports.ts_parser_set_timeout_micros,_ts_parser_set_included_ranges=Module._ts_parser_set_included_ranges=wasmExports.ts_parser_set_included_ranges,_ts_query_new=Module._ts_query_new=wasmExports.ts_query_new,_ts_query_delete=Module._ts_query_delete=wasmExports.ts_query_delete,_iswspace=Module._iswspace=wasmExports.iswspace,_iswalnum=Module._iswalnum=wasmExports.iswalnum,_ts_query_pattern_count=Module._ts_query_pattern_count=wasmExports.ts_query_pattern_count,_ts_query_capture_count=Module._ts_query_capture_count=wasmExports.ts_query_capture_count,_ts_query_string_count=Module._ts_query_string_count=wasmExports.ts_query_string_count,_ts_query_capture_name_for_id=Module._ts_query_capture_name_for_id=wasmExports.ts_query_capture_name_for_id,_ts_query_capture_quantifier_for_id=Module._ts_query_capture_quantifier_for_id=wasmExports.ts_query_capture_quantifier_for_id,_ts_query_string_value_for_id=Module._ts_query_string_value_for_id=wasmExports.ts_query_string_value_for_id,_ts_query_predicates_for_pattern=Module._ts_query_predicates_for_pattern=wasmExports.ts_query_predicates_for_pattern,_ts_query_start_byte_for_pattern=Module._ts_query_start_byte_for_pattern=wasmExports.ts_query_start_byte_for_pattern,_ts_query_end_byte_for_pattern=Module._ts_query_end_byte_for_pattern=wasmExports.ts_query_end_byte_for_pattern,_ts_query_is_pattern_rooted=Module._ts_query_is_pattern_rooted=wasmExports.ts_query_is_pattern_rooted,_ts_query_is_pattern_non_local=Module._ts_query_is_pattern_non_local=wasmExports.ts_query_is_pattern_non_local,_ts_query_is_pattern_guaranteed_at_step=Module._ts_query_is_pattern_guaranteed_at_step=wasmExports.ts_query_is_pattern_guaranteed_at_step,_ts_query_disable_capture=Module._ts_query_disable_capture=wasmExports.ts_query_disable_capture,_ts_query_disable_pattern=Module._ts_query_disable_pattern=wasmExports.ts_query_disable_pattern,_ts_tree_copy=Module._ts_tree_copy=wasmExports.ts_tree_copy,_ts_tree_delete=Module._ts_tree_delete=wasmExports.ts_tree_delete,_ts_init=Module._ts_init=wasmExports.ts_init,_ts_parser_new_wasm=Module._ts_parser_new_wasm=wasmExports.ts_parser_new_wasm,_ts_parser_enable_logger_wasm=Module._ts_parser_enable_logger_wasm=wasmExports.ts_parser_enable_logger_wasm,_ts_parser_parse_wasm=Module._ts_parser_parse_wasm=wasmExports.ts_parser_parse_wasm,_ts_parser_included_ranges_wasm=Module._ts_parser_included_ranges_wasm=wasmExports.ts_parser_included_ranges_wasm,_ts_language_type_is_named_wasm=Module._ts_language_type_is_named_wasm=wasmExports.ts_language_type_is_named_wasm,_ts_language_type_is_visible_wasm=Module._ts_language_type_is_visible_wasm=wasmExports.ts_language_type_is_visible_wasm,_ts_language_supertypes_wasm=Module._ts_language_supertypes_wasm=wasmExports.ts_language_supertypes_wasm,_ts_language_subtypes_wasm=Module._ts_language_subtypes_wasm=wasmExports.ts_language_subtypes_wasm,_ts_tree_root_node_wasm=Module._ts_tree_root_node_wasm=wasmExports.ts_tree_root_node_wasm,_ts_tree_root_node_with_offset_wasm=Module._ts_tree_root_node_with_offset_wasm=wasmExports.ts_tree_root_node_with_offset_wasm,_ts_tree_edit_wasm=Module._ts_tree_edit_wasm=wasmExports.ts_tree_edit_wasm,_ts_tree_included_ranges_wasm=Module._ts_tree_included_ranges_wasm=wasmExports.ts_tree_included_ranges_wasm,_ts_tree_get_changed_ranges_wasm=Module._ts_tree_get_changed_ranges_wasm=wasmExports.ts_tree_get_changed_ranges_wasm,_ts_tree_cursor_new_wasm=Module._ts_tree_cursor_new_wasm=wasmExports.ts_tree_cursor_new_wasm,_ts_tree_cursor_copy_wasm=Module._ts_tree_cursor_copy_wasm=wasmExports.ts_tree_cursor_copy_wasm,_ts_tree_cursor_delete_wasm=Module._ts_tree_cursor_delete_wasm=wasmExports.ts_tree_cursor_delete_wasm,_ts_tree_cursor_reset_wasm=Module._ts_tree_cursor_reset_wasm=wasmExports.ts_tree_cursor_reset_wasm,_ts_tree_cursor_reset_to_wasm=Module._ts_tree_cursor_reset_to_wasm=wasmExports.ts_tree_cursor_reset_to_wasm,_ts_tree_cursor_goto_first_child_wasm=Module._ts_tree_cursor_goto_first_child_wasm=wasmExports.ts_tree_cursor_goto_first_child_wasm,_ts_tree_cursor_goto_last_child_wasm=Module._ts_tree_cursor_goto_last_child_wasm=wasmExports.ts_tree_cursor_goto_last_child_wasm,_ts_tree_cursor_goto_first_child_for_index_wasm=Module._ts_tree_cursor_goto_first_child_for_index_wasm=wasmExports.ts_tree_cursor_goto_first_child_for_index_wasm,_ts_tree_cursor_goto_first_child_for_position_wasm=Module._ts_tree_cursor_goto_first_child_for_position_wasm=wasmExports.ts_tree_cursor_goto_first_child_for_position_wasm,_ts_tree_cursor_goto_next_sibling_wasm=Module._ts_tree_cursor_goto_next_sibling_wasm=wasmExports.ts_tree_cursor_goto_next_sibling_wasm,_ts_tree_cursor_goto_previous_sibling_wasm=Module._ts_tree_cursor_goto_previous_sibling_wasm=wasmExports.ts_tree_cursor_goto_previous_sibling_wasm,_ts_tree_cursor_goto_descendant_wasm=Module._ts_tree_cursor_goto_descendant_wasm=wasmExports.ts_tree_cursor_goto_descendant_wasm,_ts_tree_cursor_goto_parent_wasm=Module._ts_tree_cursor_goto_parent_wasm=wasmExports.ts_tree_cursor_goto_parent_wasm,_ts_tree_cursor_current_node_type_id_wasm=Module._ts_tree_cursor_current_node_type_id_wasm=wasmExports.ts_tree_cursor_current_node_type_id_wasm,_ts_tree_cursor_current_node_state_id_wasm=Module._ts_tree_cursor_current_node_state_id_wasm=wasmExports.ts_tree_cursor_current_node_state_id_wasm,_ts_tree_cursor_current_node_is_named_wasm=Module._ts_tree_cursor_current_node_is_named_wasm=wasmExports.ts_tree_cursor_current_node_is_named_wasm,_ts_tree_cursor_current_node_is_missing_wasm=Module._ts_tree_cursor_current_node_is_missing_wasm=wasmExports.ts_tree_cursor_current_node_is_missing_wasm,_ts_tree_cursor_current_node_id_wasm=Module._ts_tree_cursor_current_node_id_wasm=wasmExports.ts_tree_cursor_current_node_id_wasm,_ts_tree_cursor_start_position_wasm=Module._ts_tree_cursor_start_position_wasm=wasmExports.ts_tree_cursor_start_position_wasm,_ts_tree_cursor_end_position_wasm=Module._ts_tree_cursor_end_position_wasm=wasmExports.ts_tree_cursor_end_position_wasm,_ts_tree_cursor_start_index_wasm=Module._ts_tree_cursor_start_index_wasm=wasmExports.ts_tree_cursor_start_index_wasm,_ts_tree_cursor_end_index_wasm=Module._ts_tree_cursor_end_index_wasm=wasmExports.ts_tree_cursor_end_index_wasm,_ts_tree_cursor_current_field_id_wasm=Module._ts_tree_cursor_current_field_id_wasm=wasmExports.ts_tree_cursor_current_field_id_wasm,_ts_tree_cursor_current_depth_wasm=Module._ts_tree_cursor_current_depth_wasm=wasmExports.ts_tree_cursor_current_depth_wasm,_ts_tree_cursor_current_descendant_index_wasm=Module._ts_tree_cursor_current_descendant_index_wasm=wasmExports.ts_tree_cursor_current_descendant_index_wasm,_ts_tree_cursor_current_node_wasm=Module._ts_tree_cursor_current_node_wasm=wasmExports.ts_tree_cursor_current_node_wasm,_ts_node_symbol_wasm=Module._ts_node_symbol_wasm=wasmExports.ts_node_symbol_wasm,_ts_node_field_name_for_child_wasm=Module._ts_node_field_name_for_child_wasm=wasmExports.ts_node_field_name_for_child_wasm,_ts_node_field_name_for_named_child_wasm=Module._ts_node_field_name_for_named_child_wasm=wasmExports.ts_node_field_name_for_named_child_wasm,_ts_node_children_by_field_id_wasm=Module._ts_node_children_by_field_id_wasm=wasmExports.ts_node_children_by_field_id_wasm,_ts_node_first_child_for_byte_wasm=Module._ts_node_first_child_for_byte_wasm=wasmExports.ts_node_first_child_for_byte_wasm,_ts_node_first_named_child_for_byte_wasm=Module._ts_node_first_named_child_for_byte_wasm=wasmExports.ts_node_first_named_child_for_byte_wasm,_ts_node_grammar_symbol_wasm=Module._ts_node_grammar_symbol_wasm=wasmExports.ts_node_grammar_symbol_wasm,_ts_node_child_count_wasm=Module._ts_node_child_count_wasm=wasmExports.ts_node_child_count_wasm,_ts_node_named_child_count_wasm=Module._ts_node_named_child_count_wasm=wasmExports.ts_node_named_child_count_wasm,_ts_node_child_wasm=Module._ts_node_child_wasm=wasmExports.ts_node_child_wasm,_ts_node_named_child_wasm=Module._ts_node_named_child_wasm=wasmExports.ts_node_named_child_wasm,_ts_node_child_by_field_id_wasm=Module._ts_node_child_by_field_id_wasm=wasmExports.ts_node_child_by_field_id_wasm,_ts_node_next_sibling_wasm=Module._ts_node_next_sibling_wasm=wasmExports.ts_node_next_sibling_wasm,_ts_node_prev_sibling_wasm=Module._ts_node_prev_sibling_wasm=wasmExports.ts_node_prev_sibling_wasm,_ts_node_next_named_sibling_wasm=Module._ts_node_next_named_sibling_wasm=wasmExports.ts_node_next_named_sibling_wasm,_ts_node_prev_named_sibling_wasm=Module._ts_node_prev_named_sibling_wasm=wasmExports.ts_node_prev_named_sibling_wasm,_ts_node_descendant_count_wasm=Module._ts_node_descendant_count_wasm=wasmExports.ts_node_descendant_count_wasm,_ts_node_parent_wasm=Module._ts_node_parent_wasm=wasmExports.ts_node_parent_wasm,_ts_node_child_with_descendant_wasm=Module._ts_node_child_with_descendant_wasm=wasmExports.ts_node_child_with_descendant_wasm,_ts_node_descendant_for_index_wasm=Module._ts_node_descendant_for_index_wasm=wasmExports.ts_node_descendant_for_index_wasm,_ts_node_named_descendant_for_index_wasm=Module._ts_node_named_descendant_for_index_wasm=wasmExports.ts_node_named_descendant_for_index_wasm,_ts_node_descendant_for_position_wasm=Module._ts_node_descendant_for_position_wasm=wasmExports.ts_node_descendant_for_position_wasm,_ts_node_named_descendant_for_position_wasm=Module._ts_node_named_descendant_for_position_wasm=wasmExports.ts_node_named_descendant_for_position_wasm,_ts_node_start_point_wasm=Module._ts_node_start_point_wasm=wasmExports.ts_node_start_point_wasm,_ts_node_end_point_wasm=Module._ts_node_end_point_wasm=wasmExports.ts_node_end_point_wasm,_ts_node_start_index_wasm=Module._ts_node_start_index_wasm=wasmExports.ts_node_start_index_wasm,_ts_node_end_index_wasm=Module._ts_node_end_index_wasm=wasmExports.ts_node_end_index_wasm,_ts_node_to_string_wasm=Module._ts_node_to_string_wasm=wasmExports.ts_node_to_string_wasm,_ts_node_children_wasm=Module._ts_node_children_wasm=wasmExports.ts_node_children_wasm,_ts_node_named_children_wasm=Module._ts_node_named_children_wasm=wasmExports.ts_node_named_children_wasm,_ts_node_descendants_of_type_wasm=Module._ts_node_descendants_of_type_wasm=wasmExports.ts_node_descendants_of_type_wasm,_ts_node_is_named_wasm=Module._ts_node_is_named_wasm=wasmExports.ts_node_is_named_wasm,_ts_node_has_changes_wasm=Module._ts_node_has_changes_wasm=wasmExports.ts_node_has_changes_wasm,_ts_node_has_error_wasm=Module._ts_node_has_error_wasm=wasmExports.ts_node_has_error_wasm,_ts_node_is_error_wasm=Module._ts_node_is_error_wasm=wasmExports.ts_node_is_error_wasm,_ts_node_is_missing_wasm=Module._ts_node_is_missing_wasm=wasmExports.ts_node_is_missing_wasm,_ts_node_is_extra_wasm=Module._ts_node_is_extra_wasm=wasmExports.ts_node_is_extra_wasm,_ts_node_parse_state_wasm=Module._ts_node_parse_state_wasm=wasmExports.ts_node_parse_state_wasm,_ts_node_next_parse_state_wasm=Module._ts_node_next_parse_state_wasm=wasmExports.ts_node_next_parse_state_wasm,_ts_query_matches_wasm=Module._ts_query_matches_wasm=wasmExports.ts_query_matches_wasm,_ts_query_captures_wasm=Module._ts_query_captures_wasm=wasmExports.ts_query_captures_wasm,_memset=Module._memset=wasmExports.memset,_memcpy=Module._memcpy=wasmExports.memcpy,_memmove=Module._memmove=wasmExports.memmove,_iswalpha=Module._iswalpha=wasmExports.iswalpha,_iswblank=Module._iswblank=wasmExports.iswblank,_iswdigit=Module._iswdigit=wasmExports.iswdigit,_iswlower=Module._iswlower=wasmExports.iswlower,_iswupper=Module._iswupper=wasmExports.iswupper,_iswxdigit=Module._iswxdigit=wasmExports.iswxdigit,_memchr=Module._memchr=wasmExports.memchr,_strlen=Module._strlen=wasmExports.strlen,_strcmp=Module._strcmp=wasmExports.strcmp,_strncat=Module._strncat=wasmExports.strncat,_strncpy=Module._strncpy=wasmExports.strncpy,_towlower=Module._towlower=wasmExports.towlower,_towupper=Module._towupper=wasmExports.towupper,_setThrew=wasmExports.setThrew,__emscripten_stack_restore=wasmExports._emscripten_stack_restore,__emscripten_stack_alloc=wasmExports._emscripten_stack_alloc,_emscripten_stack_get_current=wasmExports.emscripten_stack_get_current,___wasm_apply_data_relocs=wasmExports.__wasm_apply_data_relocs;Module.setValue=setValue,Module.getValue=getValue,Module.UTF8ToString=UTF8ToString,Module.stringToUTF8=stringToUTF8,Module.lengthBytesUTF8=lengthBytesUTF8,Module.AsciiToString=AsciiToString,Module.stringToUTF16=stringToUTF16,Module.loadWebAssemblyModule=loadWebAssemblyModule;function callMain(t=[]){var e=resolveGlobalSymbol("main").sym;if(e){t.unshift(thisProgram);var l=t.length,n=stackAlloc((l+1)*4),r=n;t.forEach(a=>{LE_HEAP_STORE_U32((r>>2)*4,stringToUTF8OnStack(a)),r+=4}),LE_HEAP_STORE_U32((r>>2)*4,0);try{var I=e(l,n);return exitJS(I,!0),I}catch(a){return handleException(a)}}}Nt(callMain,"callMain");function run(t=arguments_){if(runDependencies>0){dependenciesFulfilled=run;return}if(preRun(),runDependencies>0){dependenciesFulfilled=run;return}function e(){if(Module.calledRun=!0,!ABORT){initRuntime(),readyPromiseResolve(Module),Module.onRuntimeInitialized?.();var l=Module.noInitialRun;l||callMain(t),postRun()}}Nt(e,"doRun"),Module.setStatus?(Module.setStatus("Running..."),setTimeout(()=>{setTimeout(()=>Module.setStatus(""),1),e()},1)):e()}if(Nt(run,"run"),Module.preInit)for(typeof Module.preInit=="function"&&(Module.preInit=[Module.preInit]);Module.preInit.length>0;)Module.preInit.pop()();return run(),moduleRtn=readyPromise,moduleRtn}})(),bTn=mTn,sFe=null;async function jal(t){return sFe||(sFe=await bTn(t)),sFe}Nt(jal,"initializeBinding");function Kal(){return!!sFe}Nt(Kal,"checkModule");var er,net,ret,cet=class{static{Nt(this,"Parser")}0=0;1=0;logCallback=null;language=null;static async init(t){Lal(await jal(t)),er=Ve._ts_init(),net=Ve.getValue(er,"i32"),ret=Ve.getValue(er+ur,"i32")}constructor(){this.initialize()}initialize(){if(!Kal())throw new Error("cannot construct a Parser before calling `init()`");Ve._ts_parser_new_wasm(),this[0]=Ve.getValue(er,"i32"),this[1]=Ve.getValue(er+ur,"i32")}delete(){Ve._ts_parser_delete(this[0]),Ve._free(this[1]),this[0]=0,this[1]=0}setLanguage(t){let e;if(!t)e=0,this.language=null;else if(t.constructor===iet){e=t[0];let l=Ve._ts_language_version(e);if(l<ret||net<l)throw new Error(`Incompatible language version ${l}. Compatibility range ${ret} through ${net}.`);this.language=t}else throw new Error("Argument must be a Language");return Ve._ts_parser_set_language(this[0],e),this}parse(t,e,l){if(typeof t=="string")Ve.currentParseCallback=s=>t.slice(s);else if(typeof t=="function")Ve.currentParseCallback=t;else throw new Error("Argument must be a string or a function");l?.progressCallback?Ve.currentProgressCallback=l.progressCallback:Ve.currentProgressCallback=null,this.logCallback?(Ve.currentLogCallback=this.logCallback,Ve._ts_parser_enable_logger_wasm(this[0],1)):(Ve.currentLogCallback=null,Ve._ts_parser_enable_logger_wasm(this[0],0));let n=0,r=0;if(l?.includedRanges){n=l.includedRanges.length,r=Ve._calloc(n,Fme);let s=r;for(let o=0;o<n;o++)xal(s,l.includedRanges[o]),s+=Fme}let I=Ve._ts_parser_parse_wasm(this[0],this[1],e?e[0]:0,r,n);if(!I)return Ve.currentParseCallback=null,Ve.currentLogCallback=null,Ve.currentProgressCallback=null,null;if(!this.language)throw new Error("Parser must have a language to parse");let a=new ITn(gL,I,this.language,Ve.currentParseCallback);return Ve.currentParseCallback=null,Ve.currentLogCallback=null,Ve.currentProgressCallback=null,a}reset(){Ve._ts_parser_reset(this[0])}getIncludedRanges(){Ve._ts_parser_included_ranges_wasm(this[0]);let t=Ve.getValue(er,"i32"),e=Ve.getValue(er+ur,"i32"),l=new Array(t);if(t>0){let n=e;for(let r=0;r<t;r++)l[r]=oFe(n),n+=Fme;Ve._free(e)}return l}getTimeoutMicros(){return Ve._ts_parser_timeout_micros(this[0])}setTimeoutMicros(t){Ve._ts_parser_set_timeout_micros(this[0],0,t)}setLogger(t){if(!t)this.logCallback=null;else{if(typeof t!="function")throw new Error("Logger callback must be a function");this.logCallback=t}return this}getLogger(){return this.logCallback}};c();var qal=()=>!0;var det=new Map,uet=null;async function esl(t,e,l){t==="powershell"&&(e=e.replace(/&&/g,";"));let n=await GTn(t,e);if(!n)return{kind:"error",reason:"failed to parse script"};let r=new Set(["expansion","simple_expansion","command_substitution","process_substitution","arithmetic_expansion","variable_assignment","variable_assignments","if_statement","for_statement","c_style_for_statement","while_statement","case_statement","function_definition","subshell","compound_statement","binary_expression","unary_expression","ternary_expression","test_command","negated_command","declaration_command","unset_command","brace_expression","command_name_expr"]),I=new Set(["integer_literal","string_literal","real_literal"]),a=[n.rootNode],s=[],o=!1,d=!1;for(;a.length>0;){let u=a.pop();if(u.isNamed){if(u.type==="command"){let b=ATn(t,u,l);b!==null&&s.push({fullCommandText:u.text.trim(),commandIdentifier:b})}if(r.has(u.type)){let b=u.children.length===1?u.children[0]:null;u.type==="unary_expression"&&b&&I.has(b.type)||(d=!0)}u.type==="file_redirect"&&(o||=!NTn(u)),u.type==="redirection"&&(o||=!WTn(u));for(let b=u.children.length-1;b>=0;b--){let p=u.children[b];p&&a.push(p)}}}return{kind:"success",commands:s,hasWriteFileRedirection:o,hasPotentiallyConfusingConstructs:d}}async function GTn(t,e){uet||(uet=cet.init()),await uet;let l=await pTn(t),n=new cet;return n.setLanguage(l),n.parse(e)}function pTn(t){let e=det.get(t);if(e)return e;let l=hTn(t),n=qal()?$al.join(import.meta.dirname,l.file):$al.join("node_modules",l.package,l.file),r=iet.load(n).catch(I=>{throw det.delete(t),I});return det.set(t,r),r}function hTn(t){switch(t){case"bash":return{package:"tree-sitter-bash",file:"tree-sitter-bash.wasm"};case"powershell":return{package:"tree-sitter-powershell",file:"tree-sitter-powershell.wasm"};default:sb(t,`Unknown shell type: ${t}`)}}function ATn(t,e,l){switch(t){case"bash":return ZTn(e,l);case"powershell":return gTn(e,l);default:sb(t,`Unknown shell type: ${t}`)}}function ZTn(t,e){if(!t||t.type!=="command")throw new Error(`expected a command node, got ${t.type}`);let l=t.childForFieldName("name")??t.namedChildren.find(a=>a?.type==="command_name");if(!l)throw new Error("command node has no name or command_name child");let n=l.text,r=e?.find(a=>a.stem===n);if(!r)return n;let I=l.nextNamedSibling;for(;I&&I.type==="word";){if(!r?.flagsToIgnore?.includes(I.text))return`${n} ${I.text}`;I=I.nextNamedSibling}return n}function gTn(t,e){if(!t||t.type!=="command")throw new Error(`expected a command node, got ${t.type}`);let l=t.childForFieldName("name")??t.namedChildren.find(a=>a?.type==="command_name");if(!l){if(t.namedChildren.find(s=>s?.type==="foreach_command"))return"ForEach-Object";let a=t.namedChildren.find(s=>s?.type==="command_name_expr");if(a)return a.childCount===1&&a.firstChild?.type==="script_block_expression"?null:"<command with expression as name>";throw new Error("command node has no name, command_name, foreach_command, or command_name_expr child")}let n=l.text,r=e?.find(a=>a.stem===n);if(!r)return n;let I=l.nextNamedSibling;for(;I;){if(I.type==="command_argument_sep"){I=I.nextNamedSibling;continue}if(I.type==="command_elements"){I=I.namedChildren[0];continue}if(I.type!=="command_parameter"&&I.type!=="generic_token")break;if(!r?.flagsToIgnore?.includes(I.text))return`${n} ${I.text}`;I=I.nextNamedSibling}return n}function NTn(t){if(t.children.length===3&&["2>&1","1>&2"].includes(t.text))return!0;for(let e of t.children){if(!e||e.isNamed)continue;let l=e.text;return l==="<"||l==="<&"||l==="<&-"}return!1}function WTn(t){for(let e of t.children)if(e){if(e.type==="merging_redirection_operator")return!1;if(e.type==="file_redirection_operator")return e.text.trim().startsWith("<")}return!1}var yTn=[{stem:"git",flagsToIgnore:["--no-pager"]},{stem:"gh"},{stem:"glab"},{stem:"npm"},{stem:"npx"},{stem:"yarn"},{stem:"pnpm"},{stem:"cargo"},{stem:"go"},{stem:"composer"},{stem:"pip"},{stem:"pipenv"},{stem:"poetry"},{stem:"conda"},{stem:"mvn"},{stem:"gradle"},{stem:"gradlew"},{stem:"dotnet"},{stem:"bundle"},{stem:"swift"},{stem:"sbt"},{stem:"flutter"},{stem:"mix"},{stem:"cabal"},{stem:"stack"}];async function tsl(t,e){let l=Hal(e),n=await esl(t,e,yTn);return n.kind==="error"?{result:"failed",reason:`Command could not be assured as safe: ${n.reason}`}:n.commands.length===0?{result:"completed",commands:[{identifier:e,readOnly:!1}],possiblePaths:l,hasWriteFileRedirection:n.hasWriteFileRedirection,canOfferSessionApproval:!1}:{result:"completed",commands:n.commands.map(a=>ETn(t,a.fullCommandText,a.commandIdentifier)).reduce((a,s)=>{let o=a.find(d=>d.identifier===s.identifier);return o?o.readOnly=o.readOnly&&s.readOnly:(o={identifier:s.identifier,readOnly:s.readOnly},a.push(o)),a},[]),possiblePaths:l,hasWriteFileRedirection:n.hasWriteFileRedirection,canOfferSessionApproval:!n.hasPotentiallyConfusingConstructs}}function ETn(t,e,l){switch(l){case"cat":case"cd":case"echo":case"false":case"head":case"hostname":case"ls":case"pwd":case"timeout":case"true":case"whoami":return{identifier:l,readOnly:!0}}if(l==="git"||l.startsWith("git "))return VTn(l);if(t==="bash")switch(l){case"cal":case"df":case"du":case"env":case"free":case"groups":case"id":case"nice":case"nl":case"printenv":case"ps":case"set":case"tail":case"time":case"top":case"type":case"uname":case"unset":case"uptime":case"wc":case"whatis":case"whereis":case"which":return{identifier:l,readOnly:!0};case"date":return RTn(e);case"find":return YTn(e)}if(t==="powershell")switch(l){case"Get-Command":case"Get-Content":case"Get-Process":case"Get-ChildItem":case"Get-Location":case"Select-String":case"Select-Object":case"Test-Path":return{identifier:l,readOnly:!0}}return{identifier:l,readOnly:!1}}function RTn(t){return t.match(/\s-s/)||t.match(/\s--set\b/)?{identifier:"date",readOnly:!1}:{identifier:"date",readOnly:!0}}function YTn(t){let e=["-exec","-execdir","-ok","-okdir","-delete","-fls","-fprint","-fprint0","-fprintf"];for(let l of e)if(t.includes(l))return{identifier:"find",readOnly:!1};return{identifier:"find",readOnly:!0}}function VTn(t){return t==="git"?{identifier:t,readOnly:!0}:["git blame","git branch","git describe","git diff","git grep","git log","git ls-files","git ls-remote","git remote","git rev-parse","git shortlog","git show","git status","git tag"].includes(t)?{identifier:t,readOnly:!0}:{identifier:t,readOnly:!1}}var iFe=class t{agentKind;client;settings;logger;toolConfig;availableTools=[];callback=new bWe;executeToolsInParallel=!0;constructor(){}static async createFromOptions(e){let l=new t;return await l.initializeFromOptions(e),l}async initializeFromOptions(e){this.logger=e.logger,this.executeToolsInParallel=e.executeToolsInParallel??!0;let l=new M3;l.setProblemStatement(e.problemStatement).setInstanceId(dE(e.serviceInstanceId)).setAgentModel(dE(e.serviceAgentModel)).setCallbackUrl(dE(e.serviceCallbackUrl)).setAipSweAgentToken(dE(e.apiAipSweAgentToken)).setAnthropicApiKey(dE(e.apiAnthropicKey)).setCopilotUrl(dE(e.apiCopilotUrl)).setCopilotIntegrationId(dE(e.apiCopilotIntegrationId)).setCopilotHmacKey(dE(e.apiCopilotHmacKey)).setCopilotToken(dE(e.apiCopilotToken)).setTrajectoryOutputFile(dE(e.saveTrajectoryOutput)).setEventsLogDirectory(dE(e.saveEventLogs)).setDisableOnlineEvaluation(e.disableOnlineEvaluation).setGithubRepoName("temp-repo").setGithubRepoCommit("temp-commit").setGithubRepoReadWrite(!1);let n=l.build();F_()?(C_(),this.settings=await PVe(n)):this.settings=await PVe(n),this.callback.addSettings(this.settings),this.settings.trajectory?.outputFile&&this.callback.addCallback(new aFe(this.logger,this.settings.trajectory.outputFile)),this.settings.logs?.eventsLogDir&&this.callback.addCallback(new nFe(this.logger,this.settings.logs.eventsLogDir));let r=this.settings.service?.agent?.model,I=kj(r),a=I.agent;this.agentKind=a;let s=I.model?{model:I.model}:void 0;this.client=BYe(this.settings,this.logger,a,s);let o=!1,d=async p=>{if(o)return{kind:"denied-interactively-by-user",reason:"A previous tool call was rejected"};let h=await e.requestPermission(p);return h.kind==="denied-interactively-by-user"&&(o=!0),h};this.toolConfig={location:".",timeout:3e4,permissions:{requestRequired:!0,request:d},requireReasoning:!1,splitEditingTools:!0,toolPartialResultCallback:e.onToolPartialOutput,shellConfig:(process.platform==="win32"?VA.powerShell:VA.bash).withScriptSafetyAssessor(tsl)};let u=await Eje(this.toolConfig,this.logger),b=[];if(e.mcpHost)try{b=await e.mcpHost.getTools(this.settings,this.logger,this.toolConfig.permissions)}catch(p){this.logger.error(`Failed to get MCP tools: ${p}`)}this.availableTools=[...u,...b]}async*getCompletionWithTools(e,l,n){if(!this.client)throw new Error("CLI not properly initialized");let r={...n,executeToolsInParallel:this.executeToolsInParallel};for await(let I of this.client.getCompletionWithTools(e,l,this.availableTools,r))this.callback&&await this.handleEvent(I),yield I}getToolIntentionSummary(e,l){return this.availableTools.find(r=>r.name===e)?.summariseIntention?.(l)||null}getToolTitle(e){return this.availableTools.find(n=>n.name===e)?.title||null}getAvailableTools(){return this.availableTools}getModel(){return this.client?.model||"unknown"}getAgentKind(){return this.agentKind||"sweagent-capi"}getToolConfig(){return this.toolConfig}async shutdown(){for(let e of this.availableTools)e.shutdown&&await e.shutdown()}async handleEvent(e){if(this.callback)try{await this.callback.progress(e)}catch(l){this.logger?.error(`Error in callback: ${l}`)}}};c();var Cme={CUSTOM_AGENTS:!1,CCA_PUSH:!1,COPILOT_KITTY:!0},wTn=["CUSTOM_AGENTS"],lsl=t=>t in Cme;function nsl(t){let e={...t},l=process.env.COPILOT_CLI_ENABLED_FEATURE_FLAGS;if(l){let n=l.split(",").map(r=>r.trim().toUpperCase());for(let r of n)lsl(r)&&(e[r]=!0)}for(let n of Object.keys(t)){let r=n,I=process.env[r];I&&(I.toLowerCase()==="true"?e[r]=!0:I.toLowerCase()==="false"&&(e[r]=!1))}return e}function rsl(t,e){let l={...e};if(t.staff)for(let n of wTn)l[n]=!0;if(t.feature_flags?.enabled)for(let n of t.feature_flags.enabled){let r=n.toUpperCase();lsl(r)&&(l[r]=!0)}return l}c();import{realpathSync as cFe}from"fs";import QTn from"path";var vme=class{static async isFolderTrusted(e){try{let n=(await Lr.load())?.trusted_folders||[],r=cFe(e);return n.some(I=>{try{let a=cFe(I);return r===a||r.startsWith(a+QTn.sep)}catch{return!1}})}catch{return!1}}static async addTrustedFolder(e){try{let l=await Lr.load()||{},n=l.trusted_folders||[],r=cFe(e);n.some(a=>{try{return cFe(a)===r}catch{return!1}})||(n.push(r),l.trusted_folders=n,await Lr.write(l))}catch(l){throw new Error(`Failed to add trusted folder: ${l instanceof Error?l.message:String(l)}`)}}};c();import{Transform as FTn}from"node:stream";var CTn=Buffer.from([10]),vTn=()=>{let t,e,l,n=!1;function r(){t=Buffer.alloc(1024),l=e=0,n=!1}return r(),new FTn({decodeStrings:!0,transform(I,a,s){let o=0,d,u,b;for(;o<I.length;){u=I.indexOf(13,o),u===-1&&!n?(b=I.subarray(o).lastIndexOf(10),b=b===-1?-1:b+o):(b=I.indexOf(10,o),n=!0),d=Math.min(u===-1?I.length-1:u,b===-1?I.length-1:b),d=d===-1?I.length-1:d;let p,h=o,Z=[13,10].includes(I[d])?d:d+1;for(;(p=Z-h)>0;)if(l+p>t.length){l>0&&this.push(t.subarray(0,l));let N=t.length-l;this.push(I.subarray(h,h+N)),h+=N,r()}else{I.copy(t,l,h,Z),l+=p,e=Math.max(l,e);break}I[d]===10?(this.push(Buffer.concat([t.subarray(0,e),CTn])),r()):I[d]===13&&(l=0),o=d+1}s()},flush(I){I(null,e>0?t.subarray(0,e):null)}})},Isl=t=>{let e=vTn(),l=[];return e.on("data",n=>l.push(n)),e.write(t),e.end(),Buffer.concat(l).toString("utf-8").replaceAll("\r","")};c();var dFe=class{constructor(e,l,n,r){this.session=e;this.onStreamingResponseSizeChanged=l;this.promptMode=n;this.logger=r}streamingMessageText="";streamingMessageId=null;totalResponseSizeBytes=0;onStreamingChunk(e){this.logger.debug("StreamingChunkDisplay received chunk.");let n=e.chunk.choices[0]?.delta?.content||"";if(this.promptMode){process.stdout.write(n);return}this.streamingMessageText+=n;let r=fTn(e);r&&(this.totalResponseSizeBytes+=r,this.onStreamingResponseSizeChanged(this.totalResponseSizeBytes)),n&&(this.streamingMessageId||(this.streamingMessageId=Bu()),this.session.addEvent({type:"assistant.message",ephemeral:!0,data:{messageId:this.streamingMessageId,content:this.streamingMessageText}}))}endCurrentStreamingMessage(){this.streamingMessageText="";let e=this.streamingMessageId;return e?(this.streamingMessageId=null,e):null}toJSON(){return"StreamingChunkDisplay"}};function fTn(t){let e=[];t.chunk.choices.forEach(n=>{e.push(n.delta.content),n.delta.tool_calls?.forEach(r=>{r.function&&(e.push(r.function.name),e.push(r.function.arguments))})});let l=e.join("");return l?new TextEncoder().encode(l).length:0}c();function asl(t){let l=t.findLastIndex(HTn)+1,n=t.slice(l).findIndex(XTn);if(n===-1)return{staticEntries:t,dynamicEntries:[]};let r=l+n;return{staticEntries:t.slice(0,r),dynamicEntries:t.slice(r)}}function HTn(t){return t.type==="copilot"&&!t.isStreaming}function XTn(t){return t.type==="tool_call_requested"||t.type==="copilot"&&t.isStreaming===!0}c();c();c();import pT from"node:process";import{spawn as jMn}from"node:child_process";import{fileURLToPath as KMn}from"node:url";import scl from"node:path";import{format as Gtt}from"node:util";c();var kme=nt(hsl(),1);import Xme from"node:path";import eUn from"node:os";c();import _Tn from"os";import pFe from"path";var WL=_Tn.homedir(),{env:IT}=process,Asl=IT.XDG_DATA_HOME||(WL?pFe.join(WL,".local","share"):void 0),kq=IT.XDG_CONFIG_HOME||(WL?pFe.join(WL,".config"):void 0),KTa=IT.XDG_STATE_HOME||(WL?pFe.join(WL,".local","state"):void 0),qTa=IT.XDG_CACHE_HOME||(WL?pFe.join(WL,".cache"):void 0),$Ta=IT.XDG_RUNTIME_DIR||void 0,DTn=(IT.XDG_DATA_DIRS||"/usr/local/share/:/usr/share/").split(":");Asl&&DTn.unshift(Asl);var zTn=(IT.XDG_CONFIG_DIRS||"/etc/xdg").split(":");kq&&zTn.unshift(kq);c();import qTn from"node:path";c();import no from"node:fs";import{promisify as Sh}from"node:util";c();var wf=(t,e)=>function(...n){return t.apply(void 0,n).catch(e)},Ow=(t,e)=>function(...n){try{return t.apply(void 0,n)}catch(r){return e(r)}};c();import Zsl from"node:process";var gsl=Zsl.getuid?!Zsl.getuid():!1,Nsl=1e4,cN=()=>{};c();var fme={isChangeErrorOk:t=>{if(!fme.isNodeError(t))return!1;let{code:e}=t;return e==="ENOSYS"||!gsl&&(e==="EINVAL"||e==="EPERM")},isNodeError:t=>t instanceof Error,isRetriableError:t=>{if(!fme.isNodeError(t))return!1;let{code:e}=t;return e==="EMFILE"||e==="ENFILE"||e==="EAGAIN"||e==="EBUSY"||e==="EACCESS"||e==="EACCES"||e==="EACCS"||e==="EPERM"},onChangeError:t=>{if(!fme.isNodeError(t))throw t;if(!fme.isChangeErrorOk(t))throw t}},am=fme;c();c();var het=class{constructor(){this.interval=25,this.intervalId=void 0,this.limit=Nsl,this.queueActive=new Set,this.queueWaiting=new Set,this.init=()=>{this.intervalId||(this.intervalId=setInterval(this.tick,this.interval))},this.reset=()=>{this.intervalId&&(clearInterval(this.intervalId),delete this.intervalId)},this.add=e=>{this.queueWaiting.add(e),this.queueActive.size<this.limit/2?this.tick():this.init()},this.remove=e=>{this.queueWaiting.delete(e),this.queueActive.delete(e)},this.schedule=()=>new Promise(e=>{let l=()=>this.remove(n),n=()=>e(l);this.add(n)}),this.tick=()=>{if(!(this.queueActive.size>=this.limit)){if(!this.queueWaiting.size)return this.reset();for(let e of this.queueWaiting){if(this.queueActive.size>=this.limit)break;this.queueWaiting.delete(e),this.queueActive.add(e),e()}}}}},Wsl=new het;var Qf=(t,e)=>function(n){return function r(...I){return Wsl.schedule().then(a=>{let s=d=>(a(),d),o=d=>{if(a(),Date.now()>=n)throw d;if(e(d)){let u=Math.round(100*Math.random());return new Promise(p=>setTimeout(p,u)).then(()=>r.apply(void 0,I))}throw d};return t.apply(void 0,I).then(s,o)})}},Ff=(t,e)=>function(n){return function r(...I){try{return t.apply(void 0,I)}catch(a){if(Date.now()>n)throw a;if(e(a))return r.apply(void 0,I);throw a}}};var PTn={attempt:{chmod:wf(Sh(no.chmod),am.onChangeError),chown:wf(Sh(no.chown),am.onChangeError),close:wf(Sh(no.close),cN),fsync:wf(Sh(no.fsync),cN),mkdir:wf(Sh(no.mkdir),cN),realpath:wf(Sh(no.realpath),cN),stat:wf(Sh(no.stat),cN),unlink:wf(Sh(no.unlink),cN),chmodSync:Ow(no.chmodSync,am.onChangeError),chownSync:Ow(no.chownSync,am.onChangeError),closeSync:Ow(no.closeSync,cN),existsSync:Ow(no.existsSync,cN),fsyncSync:Ow(no.fsync,cN),mkdirSync:Ow(no.mkdirSync,cN),realpathSync:Ow(no.realpathSync,cN),statSync:Ow(no.statSync,cN),unlinkSync:Ow(no.unlinkSync,cN)},retry:{close:Qf(Sh(no.close),am.isRetriableError),fsync:Qf(Sh(no.fsync),am.isRetriableError),open:Qf(Sh(no.open),am.isRetriableError),readFile:Qf(Sh(no.readFile),am.isRetriableError),rename:Qf(Sh(no.rename),am.isRetriableError),stat:Qf(Sh(no.stat),am.isRetriableError),write:Qf(Sh(no.write),am.isRetriableError),writeFile:Qf(Sh(no.writeFile),am.isRetriableError),closeSync:Ff(no.closeSync,am.isRetriableError),fsyncSync:Ff(no.fsyncSync,am.isRetriableError),openSync:Ff(no.openSync,am.isRetriableError),readFileSync:Ff(no.readFileSync,am.isRetriableError),renameSync:Ff(no.renameSync,am.isRetriableError),statSync:Ff(no.statSync,am.isRetriableError),writeSync:Ff(no.writeSync,am.isRetriableError),writeFileSync:Ff(no.writeFileSync,am.isRetriableError)}},XG=PTn;c();import ysl from"node:os";import Aet from"node:process";var Esl="utf8",Zet=438,Rsl=511;var Ysl={},Vsl=ysl.userInfo().uid,wsl=ysl.userInfo().gid;var Qsl=1e3,Fsl=!!Aet.getuid,YUa=Aet.getuid?!Aet.getuid():!1,get=128;c();var Csl=t=>t instanceof Error&&"code"in t;var Net=t=>typeof t=="string",hFe=t=>t===void 0;c();c();import KTn from"node:path";c();c();import Lq from"node:process";c();import vsl from"node:process";var fsl=vsl.platform==="linux",AFe=vsl.platform==="win32";c();var Wet=["SIGABRT","SIGALRM","SIGHUP","SIGINT","SIGTERM"];AFe||Wet.push("SIGVTALRM","SIGXCPU","SIGXFSZ","SIGUSR2","SIGTRAP","SIGSYS","SIGQUIT","SIGIOT");fsl&&Wet.push("SIGIO","SIGPOLL","SIGPWR","SIGSTKFLT","SIGUNUSED");var Hsl=Wet;var yet=class{constructor(){this.callbacks=new Set,this.exited=!1,this.exit=e=>{if(!this.exited){this.exited=!0;for(let l of this.callbacks)l();e&&(AFe&&e!=="SIGINT"&&e!=="SIGTERM"&&e!=="SIGKILL"?Lq.kill(Lq.pid,"SIGTERM"):Lq.kill(Lq.pid,e))}},this.hook=()=>{Lq.once("exit",()=>this.exit());for(let e of Hsl)try{Lq.once(e,()=>this.exit(e))}catch{}},this.register=e=>(this.callbacks.add(e),()=>{this.callbacks.delete(e)}),this.hook()}},Xsl=new yet;var jTn=Xsl.register,ksl=jTn;var ey={store:{},create:t=>{let e=`000000${Math.floor(Math.random()*16777215).toString(16)}`.slice(-6),r=`.tmp-${Date.now().toString().slice(-10)}${e}`;return`${t}${r}`},get:(t,e,l=!0)=>{let n=ey.truncate(e(t));return n in ey.store?ey.get(t,e,l):(ey.store[n]=l,[n,()=>delete ey.store[n]])},purge:t=>{ey.store[t]&&(delete ey.store[t],XG.attempt.unlink(t))},purgeSync:t=>{ey.store[t]&&(delete ey.store[t],XG.attempt.unlinkSync(t))},purgeSyncAll:()=>{for(let t in ey.store)ey.purgeSync(t)},truncate:t=>{let e=KTn.basename(t);if(e.length<=get)return t;let l=/^(\.?)(.*?)((?:\.[^.]+)?(?:\.tmp-\d{10}[a-f0-9]{6})?)$/.exec(e);if(!l)return t;let n=e.length-get;return`${t.slice(0,-e.length)}${l[1]}${l[2].slice(0,-n)}${l[3]}`}};ksl(ey.purgeSyncAll);var Hme=ey;function ZFe(t,e,l=Ysl){if(Net(l))return ZFe(t,e,{encoding:l});let n=Date.now()+((l.timeout??Qsl)||-1),r=null,I=null,a=null;try{let s=XG.attempt.realpathSync(t),o=!!s;t=s||t,[I,r]=Hme.get(t,l.tmpCreate||Hme.create,l.tmpPurge!==!1);let d=Fsl&&hFe(l.chown),u=hFe(l.mode);if(o&&(d||u)){let b=XG.attempt.statSync(t);b&&(l={...l},d&&(l.chown={uid:b.uid,gid:b.gid}),u&&(l.mode=b.mode))}if(!o){let b=qTn.dirname(t);XG.attempt.mkdirSync(b,{mode:Rsl,recursive:!0})}a=XG.retry.openSync(n)(I,"w",l.mode||Zet),l.tmpCreated&&l.tmpCreated(I),Net(e)?XG.retry.writeSync(n)(a,e,0,l.encoding||Esl):hFe(e)||XG.retry.writeSync(n)(a,e,0,e.length,0),l.fsync!==!1&&(l.fsyncWait!==!1?XG.retry.fsyncSync(n)(a):XG.attempt.fsync(a)),XG.retry.closeSync(n)(a),a=null,l.chown&&(l.chown.uid!==Vsl||l.chown.gid!==wsl)&&XG.attempt.chownSync(I,l.chown.uid,l.chown.gid),l.mode&&l.mode!==Zet&&XG.attempt.chmodSync(I,l.mode);try{XG.retry.renameSync(n)(I,t)}catch(b){if(!Csl(b)||b.code!=="ENAMETOOLONG")throw b;XG.retry.renameSync(n)(I,Hme.truncate(t))}r(),I=null}finally{a&&XG.attempt.closeSync(a),I&&Hme.purge(I)}}c();var aT=t=>{let e=typeof t;return t!==null&&(e==="object"||e==="function")};var Eet=new Set(["__proto__","prototype","constructor"]),$Tn=new Set("0123456789");function gFe(t){let e=[],l="",n="start",r=!1;for(let I of t)switch(I){case"\\":{if(n==="index")throw new Error("Invalid character in an index");if(n==="indexEnd")throw new Error("Invalid character after an index");r&&(l+=I),n="property",r=!r;break}case".":{if(n==="index")throw new Error("Invalid character in an index");if(n==="indexEnd"){n="property";break}if(r){r=!1,l+=I;break}if(Eet.has(l))return[];e.push(l),l="",n="property";break}case"[":{if(n==="index")throw new Error("Invalid character in an index");if(n==="indexEnd"){n="index";break}if(r){r=!1,l+=I;break}if(n==="property"){if(Eet.has(l))return[];e.push(l),l=""}n="index";break}case"]":{if(n==="index"){e.push(Number.parseInt(l,10)),l="",n="indexEnd";break}if(n==="indexEnd")throw new Error("Invalid character after an index")}default:{if(n==="index"&&!$Tn.has(I))throw new Error("Invalid character in an index");if(n==="indexEnd")throw new Error("Invalid character after an index");n==="start"&&(n="property"),r&&(r=!1,l+="\\"),l+=I}}switch(r&&(l+="\\"),n){case"property":{if(Eet.has(l))return[];e.push(l);break}case"index":throw new Error("Index was not closed");case"start":{e.push("");break}}return e}function Ret(t,e){if(typeof e!="number"&&Array.isArray(t)){let l=Number.parseInt(e,10);return Number.isInteger(l)&&t[l]===t[e]}return!1}function Lsl(t,e){if(Ret(t,e))throw new Error("Cannot use string index")}function Jsl(t,e,l){if(!aT(t)||typeof e!="string")return l===void 0?t:l;let n=gFe(e);if(n.length===0)return l;for(let r=0;r<n.length;r++){let I=n[r];if(Ret(t,I)?t=r===n.length-1?void 0:null:t=t[I],t==null){if(r!==n.length-1)return l;break}}return t===void 0?l:t}function Yet(t,e,l){if(!aT(t)||typeof e!="string")return t;let n=t,r=gFe(e);for(let I=0;I<r.length;I++){let a=r[I];Lsl(t,a),I===r.length-1?t[a]=l:aT(t[a])||(t[a]=typeof r[I+1]=="number"?[]:{}),t=t[a]}return n}function xsl(t,e){if(!aT(t)||typeof e!="string")return!1;let l=gFe(e);for(let n=0;n<l.length;n++){let r=l[n];if(Lsl(t,r),n===l.length-1)return delete t[r],!0;if(t=t[r],!aT(t))return!1}}function Ssl(t,e){if(!aT(t)||typeof e!="string")return!1;let l=gFe(e);if(l.length===0)return!1;for(let n of l){if(!aT(t)||!(n in t)||Ret(t,n))return!1;t=t[n]}return!0}function tUn(t,e){let l=e?Xme.join(t,"config.json"):Xme.join("configstore",`${t}.json`),n=kq??kme.default.mkdtempSync(kme.default.realpathSync(eUn.tmpdir())+Xme.sep);return Xme.join(n,l)}var Bsl="You don't have access to this file.",lUn={mode:448,recursive:!0},Osl={mode:384},Lme=class{constructor(e,l,n={}){this._path=n.configPath??tUn(e,n.globalConfigPath),l&&(this.all={...l,...this.all})}get all(){try{return JSON.parse(kme.default.readFileSync(this._path,"utf8"))}catch(e){if(e.code==="ENOENT")return{};if(e.code==="EACCES"&&(e.message=`${e.message}
2393
2393
  ${Bsl}
2394
2394
  `),e.name==="SyntaxError")return ZFe(this._path,"",Osl),{};throw e}}set all(e){try{kme.default.mkdirSync(Xme.dirname(this._path),lUn),ZFe(this._path,JSON.stringify(e,void 0," "),Osl)}catch(l){throw l.code==="EACCES"&&(l.message=`${l.message}
2395
2395
  ${Bsl}
@@ -2413,7 +2413,7 @@ Run `+Jl.cyan("{updateCommand}")+" to update",I=e.message||r;e.boxenOptions??={p
2413
2413
  Length provided: ${this.length}. Number of dictionaries provided: ${this.dictionaries.length}`);let e=this.seed;return this.dictionaries.slice(0,this.length).reduce((l,n)=>{let r;e?(r=(a=>{if(typeof a=="string"){let s=a.split("").map(d=>d.charCodeAt(0)).reduce((d,u)=>d+u,1),o=Math.floor(Number(s));return hul(o)}return hul(a)})(e),e=4294967296*r):r=Math.random();let I=n[Math.floor(r*n.length)]||"";if(this.style==="lowerCase")I=I.toLowerCase();else if(this.style==="capital"){let[a,...s]=I.split("");I=a.toUpperCase()+s.join("")}else this.style==="upperCase"&&(I=I.toUpperCase());return l?`${l}${this.separator}${I}`:`${I}`},"")}},Aul={separator:"_",dictionaries:[]},Zul=t=>{let e=[...t&&t.dictionaries||Aul.dictionaries],l={...Aul,...t,length:t&&t.length||e.length,dictionaries:e};if(!t||!t.dictionaries||!t.dictionaries.length)throw new Error('A "dictionaries" array must be provided. This is a breaking change introduced starting from Unique Name Generator v4. Read more about the breaking change here: https://github.com/andreasonny83/unique-names-generator#migration-guide');return new $tt(l).generate()},gul=["able","above","absent","absolute","abstract","abundant","academic","acceptable","accepted","accessible","accurate","accused","active","actual","acute","added","additional","adequate","adjacent","administrative","adorable","advanced","adverse","advisory","aesthetic","afraid","aggregate","aggressive","agreeable","agreed","agricultural","alert","alive","alleged","allied","alone","alright","alternative","amateur","amazing","ambitious","amused","ancient","angry","annoyed","annual","anonymous","anxious","appalling","apparent","applicable","appropriate","arbitrary","architectural","armed","arrogant","artificial","artistic","ashamed","asleep","assistant","associated","atomic","attractive","automatic","autonomous","available","average","awake","aware","awful","awkward","back","bad","balanced","bare","basic","beautiful","beneficial","better","bewildered","big","binding","biological","bitter","bizarre","blank","blonde","blushing","boiling","bold","bored","boring","bottom","brainy","brave","breakable","breezy","brief","bright","brilliant","broad","broken","bumpy","burning","busy","calm","capable","careful","casual","causal","cautious","central","certain","changing","characteristic","charming","cheap","cheerful","chemical","chief","chilly","chosen","chronic","chubby","circular","civic","civil","classic","classical","clean","clear","clever","clinical","close","closed","cloudy","clumsy","coastal","cognitive","coherent","cold","collective","colorful","colossal","coloured","colourful","combined","comfortable","commercial","common","compact","comparable","comparative","compatible","competent","competitive","complete","complex","complicated","comprehensive","compulsory","conceptual","concerned","concrete","condemned","confident","confidential","confused","conscious","conservation","considerable","consistent","constant","constitutional","contemporary","content","continental","continued","continuing","continuous","controlled","controversial","convenient","conventional","convinced","convincing","cooing","cool","cooperative","corporate","correct","corresponding","costly","courageous","creative","creepy","criminal","critical","crooked","crowded","crucial","crude","cruel","cuddly","cultural","curious","curly","current","curved","cute","daily","damaged","damp","dangerous","dark","dead","deafening","dear","decent","decisive","deep","defeated","defensive","defiant","definite","deliberate","delicate","delicious","delighted","delightful","democratic","dependent","depressed","desirable","desperate","detailed","determined","developed","developing","devoted","different","difficult","digital","diplomatic","direct","dirty","disappointed","disastrous","disciplinary","disgusted","distant","distinct","distinctive","distinguished","disturbed","disturbing","diverse","divine","dizzy","domestic","dominant","double","doubtful","drab","dramatic","dreadful","driving","dry","dual","due","dull","dusty","dutch","dying","dynamic","eager","early","eastern","easy","economic","educational","eerie","effective","efficient","elaborate","elated","elderly","eldest","electoral","electric","electrical","electronic","elegant","eligible","embarrassed","embarrassing","emotional","empirical","empty","enchanting","encouraging","endless","energetic","enormous","enthusiastic","entire","entitled","envious","environmental","equal","equivalent","essential","established","estimated","ethical","eventual","everyday","evident","evil","evolutionary","exact","excellent","exceptional","excess","excessive","excited","exciting","exclusive","existing","exotic","expected","expensive","experienced","experimental","explicit","extended","extensive","external","extra","extraordinary","extreme","exuberant","faint","fair","faithful","familiar","famous","fancy","fantastic","far","fascinating","fashionable","fast","fatal","favourable","favourite","federal","fellow","few","fierce","final","financial","fine","firm","fiscal","fit","fixed","flaky","flat","flexible","fluffy","fluttering","flying","following","fond","foolish","foreign","formal","formidable","forthcoming","fortunate","forward","fragile","frail","frantic","free","frequent","fresh","friendly","frightened","front","frozen","full","fun","functional","fundamental","funny","furious","future","fuzzy","gastric","general","generous","genetic","gentle","genuine","geographical","giant","gigantic","given","glad","glamorous","gleaming","global","glorious","golden","good","gorgeous","gothic","governing","graceful","gradual","grand","grateful","greasy","great","grieving","grim","gross","grotesque","growing","grubby","grumpy","guilty","handsome","happy","hard","harsh","head","healthy","heavy","helpful","helpless","hidden","high","hilarious","hissing","historic","historical","hollow","holy","homely","hon","honest","horizontal","horrible","hostile","hot","huge","human","hungry","hurt","hushed","husky","icy","ideal","identical","ideological","ill","illegal","imaginative","immediate","immense","implicit","important","impossible","impressed","impressive","improved","inadequate","inc","inclined","increased","increasing","incredible","independent","indirect","individual","industrial","inevitable","influential","informal","inherent","initial","injured","inland","inner","innocent","innovative","inquisitive","instant","institutional","insufficient","intact","integral","integrated","intellectual","intelligent","intense","intensive","interested","interesting","interim","interior","intermediate","internal","international","invisible","involved","irrelevant","isolated","itchy","jealous","jittery","joint","jolly","joyous","judicial","juicy","junior","just","keen","key","kind","known","labour","large","late","latin","lazy","leading","left","legal","legislative","legitimate","lengthy","lesser","level","lexical","liable","light","like","likely","limited","linear","linguistic","liquid","literary","little","live","lively","living","local","logical","lonely","long","loose","lost","loud","lovely","low","loyal","ltd","lucky","mad","magic","magnetic","magnificent","main","major","mammoth","managerial","managing","manual","many","marginal","marine","marked","married","marvellous","mass","massive","mathematical","mature","maximum","mean","meaningful","mechanical","medical","medieval","melodic","melted","mental","mere","metropolitan","mid","middle","mighty","mild","military","miniature","minimal","minimum","ministerial","minor","miserable","misleading","missing","misty","mixed","moaning","mobile","moderate","modern","modest","molecular","monetary","monthly","moral","motionless","muddy","multiple","mushy","musical","mutual","mysterious","naked","narrow","nasty","national","natural","naughty","naval","near","nearby","neat","necessary","negative","neighbouring","nervous","net","neutral","new","nice","noble","noisy","normal","northern","nosy","notable","novel","nuclear","numerous","nursing","nutritious","nutty","obedient","objective","obliged","obnoxious","obvious","occasional","occupational","odd","official","ok","okay","old","only","open","operational","opposite","optimistic","ordinary","organic","organisational","original","orthodox","other","outdoor","outer","outrageous","outside","outstanding","overall","overseas","overwhelming","painful","pale","panicky","parallel","parental","parliamentary","partial","particular","passing","passive","past","patient","payable","peaceful","peculiar","perfect","permanent","persistent","personal","petite","philosophical","physical","plain","planned","plastic","pleasant","pleased","poised","polite","poor","popular","positive","possible","potential","powerful","practical","precious","precise","preferred","pregnant","preliminary","premier","prepared","present","presidential","pretty","previous","prickly","primary","prime","principal","printed","prior","private","probable","productive","professional","profitable","profound","progressive","prominent","promising","proper","proposed","prospective","protective","proud","provincial","psychiatric","psychological","public","puny","pure","purring","puzzled","quaint","qualified","quarrelsome","querulous","quick","quickest","quiet","quintessential","quixotic","racial","radical","rainy","random","rapid","rare","raspy","rational","ratty","raw","ready","real","realistic","rear","reasonable","recent","reduced","redundant","regional","registered","regular","regulatory","related","relative","relaxed","relevant","reliable","relieved","religious","reluctant","remaining","remarkable","remote","renewed","representative","repulsive","required","resident","residential","resonant","respectable","respective","responsible","resulting","retail","retired","revolutionary","rich","ridiculous","right","rigid","ripe","rising","rival","roasted","robust","rolling","romantic","rotten","rough","round","royal","rubber","rude","ruling","running","rural","sacred","sad","safe","salty","satisfactory","satisfied","scared","scary","scattered","scientific","scornful","scrawny","screeching","secondary","secret","secure","select","selected","selective","selfish","semantic","senior","sensible","sensitive","separate","serious","severe","shaggy","shaky","shallow","shared","sharp","sheer","shiny","shivering","shocked","short","shrill","shy","sick","significant","silent","silky","silly","similar","simple","single","skilled","skinny","sleepy","slight","slim","slimy","slippery","slow","small","smart","smiling","smoggy","smooth","social","soft","solar","sole","solid","sophisticated","sore","sorry","sound","sour","southern","spare","sparkling","spatial","special","specific","specified","spectacular","spicy","spiritual","splendid","spontaneous","sporting","spotless","spotty","square","squealing","stable","stale","standard","static","statistical","statutory","steady","steep","sticky","stiff","still","stingy","stormy","straight","straightforward","strange","strategic","strict","striking","striped","strong","structural","stuck","subjective","subsequent","substantial","subtle","successful","successive","sudden","sufficient","suitable","sunny","super","superb","superior","supporting","supposed","supreme","sure","surprised","surprising","surrounding","surviving","suspicious","sweet","swift","symbolic","sympathetic","systematic","tall","tame","tart","tasteless","tasty","technical","technological","teenage","temporary","tender","tense","terrible","territorial","testy","then","theoretical","thick","thin","thorough","thoughtful","thoughtless","thundering","tight","tiny","tired","top","total","tough","toxic","traditional","tragic","tremendous","tricky","tropical","troubled","typical","ugliest","ugly","ultimate","unable","unacceptable","unaware","uncertain","unchanged","uncomfortable","unconscious","underground","underlying","unemployed","uneven","unexpected","unfair","unfortunate","unhappy","uniform","uninterested","unique","united","universal","unknown","unlikely","unnecessary","unpleasant","unsightly","unusual","unwilling","upper","upset","uptight","urban","urgent","used","useful","useless","usual","vague","valid","valuable","variable","varied","various","varying","vast","verbal","vertical","very","vicarious","vicious","victorious","violent","visible","visiting","visual","vital","vitreous","vivacious","vivid","vocal","vocational","voiceless","voluminous","voluntary","vulnerable","wandering","warm","wasteful","watery","weak","wealthy","weary","wee","weekly","weird","welcome","well","western","wet","whispering","whole","wicked","wide","widespread","wild","wilful","willing","willowy","wily","wise","wispy","wittering","witty","wonderful","wooden","working","worldwide","worried","worrying","worthwhile","worthy","written","wrong","xenacious","xenial","xenogeneic","xeric","xerothermic","yabbering","yammering","yappiest","yappy","yawning","yearling","yearning","yeasty","yelling","yelping","yielding","yodelling","young","youngest","youthful","ytterbic","yucky","yummy","zany","zealous","zeroth","zestful","zesty","zippy","zonal","zoophagous","zygomorphic","zygotic"],Nul=["aardvark","aardwolf","albatross","alligator","alpaca","amphibian","anaconda","angelfish","anglerfish","ant","anteater","antelope","antlion","ape","aphid","armadillo","asp","baboon","badger","bandicoot","barnacle","barracuda","basilisk","bass","bat","bear","beaver","bedbug","bee","beetle","bird","bison","blackbird","boa","boar","bobcat","bobolink","bonobo","bovid","bug","butterfly","buzzard","camel","canid","canidae","capybara","cardinal","caribou","carp","cat","caterpillar","catfish","catshark","cattle","centipede","cephalopod","chameleon","cheetah","chickadee","chicken","chimpanzee","chinchilla","chipmunk","cicada","clam","clownfish","cobra","cockroach","cod","condor","constrictor","coral","cougar","cow","coyote","crab","crane","crawdad","crayfish","cricket","crocodile","crow","cuckoo","damselfly","deer","dingo","dinosaur","dog","dolphin","donkey","dormouse","dove","dragon","dragonfly","duck","eagle","earthworm","earwig","echidna","eel","egret","elephant","elk","emu","ermine","falcon","felidae","ferret","finch","firefly","fish","flamingo","flea","fly","flyingfish","fowl","fox","frog","galliform","gamefowl","gayal","gazelle","gecko","gerbil","gibbon","giraffe","goat","goldfish","goose","gopher","gorilla","grasshopper","grouse","guan","guanaco","guineafowl","gull","guppy","haddock","halibut","hamster","hare","harrier","hawk","hedgehog","heron","herring","hippopotamus","hookworm","hornet","horse","hoverfly","hummingbird","hyena","iguana","impala","jackal","jaguar","jay","jellyfish","junglefowl","kangaroo","kingfisher","kite","kiwi","koala","koi","krill","ladybug","lamprey","landfowl","lark","leech","lemming","lemur","leopard","leopon","limpet","lion","lizard","llama","lobster","locust","loon","louse","lungfish","lynx","macaw","mackerel","magpie","mammal","manatee","mandrill","marlin","marmoset","marmot","marsupial","marten","mastodon","meadowlark","meerkat","mink","minnow","mite","mockingbird","mole","mollusk","mongoose","monkey","moose","mosquito","moth","mouse","mule","muskox","narwhal","newt","nightingale","ocelot","octopus","opossum","orangutan","orca","ostrich","otter","owl","ox","panda","panther","parakeet","parrot","parrotfish","partridge","peacock","peafowl","pelican","penguin","perch","pheasant","pig","pigeon","pike","pinniped","piranha","planarian","platypus","pony","porcupine","porpoise","possum","prawn","primate","ptarmigan","puffin","puma","python","quail","quelea","quokka","rabbit","raccoon","rat","rattlesnake","raven","reindeer","reptile","rhinoceros","roadrunner","rodent","rook","rooster","roundworm","sailfish","salamander","salmon","sawfish","scallop","scorpion","seahorse","shark","sheep","shrew","shrimp","silkworm","silverfish","skink","skunk","sloth","slug","smelt","snail","snake","snipe","sole","sparrow","spider","spoonbill","squid","squirrel","starfish","stingray","stoat","stork","sturgeon","swallow","swan","swift","swordfish","swordtail","tahr","takin","tapir","tarantula","tarsier","termite","tern","thrush","tick","tiger","tiglon","toad","tortoise","toucan","trout","tuna","turkey","turtle","tyrannosaurus","unicorn","urial","vicuna","viper","vole","vulture","wallaby","walrus","warbler","wasp","weasel","whale","whippet","whitefish","wildcat","wildebeest","wildfowl","wolf","wolverine","wombat","woodpecker","worm","wren","xerinae","yak","zebra"];import{execFile as IPn}from"node:child_process";import{promisify as aPn}from"node:util";function t7(t){let[e,l]=t.split("/");if(!e||!l)throw new Error(`Invalid repository format: ${t}. Expected format: owner/repo`);return{owner:e,repo:l}}var uN=aPn(IPn);async function Wul(t){try{let{stdout:e}=await uN("git",["status","--porcelain"],{cwd:t,encoding:"utf8",timeout:5e3,maxBuffer:1048576}),l=e.split(`
2414
2414
  `).filter(a=>a.length>0),n=0,r=0,I=0;for(let a of l){if(a.length<2)continue;let s=a[0],o=a[1];s==="?"&&o==="?"?I++:(s!==" "&&s!=="?"&&n++,o!==" "&&o!=="?"&&r++)}return{staged:n,unstaged:r,untracked:I,hasChanges:l.length>0}}catch{return{staged:0,unstaged:0,untracked:0,hasChanges:!1}}}async function yul(){return"Checkpoint from Copilot CLI for coding agent session"}async function Eul(t){let{stdout:e}=await uN("git",["rev-parse","--abbrev-ref","HEAD"],{cwd:t,encoding:"utf8",timeout:5e3});return e.trim()}async function Rul(t){try{return await Eul(t)==="HEAD"}catch{return!1}}async function sPn(t){try{let{stdout:e}=await uN("git",["rev-parse","--abbrev-ref","HEAD"],{cwd:t,encoding:"utf8",timeout:5e3}),l=e.trim();if(!l||l==="HEAD")return"origin";let{stdout:n}=await uN("git",["config",`branch.${l}.remote`],{cwd:t,encoding:"utf8",timeout:5e3});return n.trim()||"origin"}catch{return"origin"}}async function oPn(t){let e=await sPn(t);try{let{stdout:l}=await uN("git",["symbolic-ref",`refs/remotes/${e}/HEAD`],{cwd:t,encoding:"utf8",timeout:5e3}),n=l.match(new RegExp(`refs/remotes/${e}/(.+)`));if(n)return n[1].trim()}catch{}try{return await uN("git",["rev-parse","--verify",`refs/remotes/${e}/main`],{cwd:t,encoding:"utf8",timeout:5e3}),"main"}catch{}try{return await uN("git",["rev-parse","--verify",`refs/remotes/${e}/master`],{cwd:t,encoding:"utf8",timeout:5e3}),"master"}catch{return"main"}}async function iPn(t,e){try{return await uN("git",["rev-parse","--verify",`refs/heads/${e}`],{cwd:t,encoding:"utf8",timeout:5e3}),!0}catch{return!1}}async function cPn(t,e){let n=["adjectives","animals"],I=[];for(let a of n)a.toLowerCase()==="adjectives"&&I.push(gul),a.toLowerCase()==="animals"&&I.push(Nul);if(I.length===0)return`${e}/session${Date.now()}`;for(let a=0;a<5;a++){let s=`${e}/${Zul({dictionaries:I,length:I.length,separator:"-"})}`;if(!await iPn(t,s))return s}return`${e}/session${Date.now()}`}async function dPn(t){return cPn(t,"copilot")}async function elt(t){try{let[e,l,n,r]=await Promise.all([Eul(t),aCe(t),oPn(t),dPn(t)]);if(!l)throw new Error("Could not determine GitHub repository from git remotes");return{repository:`${l.owner}/${l.name}`,baseBranch:n,headBranch:e,asyncBranch:r}}catch(e){throw new Error(`Failed to get repository info: ${e instanceof Error?e.message:String(e)}`)}}async function Yul(t,e){try{await uN("git",["add","--all"],{cwd:t,encoding:"utf8",timeout:1e4,maxBuffer:10*1024*1024});let{stdout:l}=await uN("git",["commit","-m",e],{cwd:t,encoding:"utf8",timeout:1e4,maxBuffer:10*1024*1024}),n,r=l.match(/\[[\w/-]+ ([a-f0-9]+)\]/);if(!r||!r[1]){let{stdout:I}=await uN("git",["rev-parse","--short","HEAD"],{cwd:t,encoding:"utf8",timeout:5e3});n=I.trim()}else n=r[1];return{commitHash:n,commitMessage:e}}catch(l){let n=l instanceof Error?l.message:String(l);throw n.includes("pre-commit")?new Error(`Pre-commit hook prevented the commit: ${n}`):n.includes("commit-msg")?new Error(`Commit-msg hook rejected the commit: ${n}`):n.includes("nothing to commit")||n.includes("no changes added")?new Error(`No changes to commit (possibly filtered by hooks): ${n}`):new Error(`Failed to commit changes: ${n}`)}}async function Vul(t,e=process.cwd()){try{await uN("git",["checkout",t],{cwd:e,encoding:"utf8",timeout:5e3,maxBuffer:10*1024*1024})}catch(l){let n=l instanceof Error?l.message:String(l);throw new Error(`Failed to switch to branch '${t}': ${n}`)}}async function wul(t){let{cwd:e,asyncBranch:l}=t;try{await uN("git",["checkout","-b",l],{cwd:e,encoding:"utf8",timeout:1e4,maxBuffer:10*1024*1024}),await uN("git",["push","-u","origin",l],{cwd:e,encoding:"utf8",timeout:3e4,maxBuffer:10*1024*1024})}catch(n){let r=n instanceof Error?n.message:String(n);throw r.includes("branch")&&r.includes("already exists")?new Error(`Branch '${l}' already exists: ${r}`):r.includes("Could not read from remote repository")?new Error(`Failed to push branch - repository access issue: ${r}`):r.includes("Permission denied")||r.includes("403")?new Error(`Failed to push branch - permission denied: ${r}`):r.includes("remote rejected")?new Error(`Remote rejected the push: ${r}`):new Error(`Failed to create and push branch '${l}': ${r}`)}}c();var l7=class extends Error{constructor(l,n,r){super(n);this.status=l;this.message=n;this.responseBody=r;this.name="HttpApiError"}};async function Gbe(t){let e=await jW(t);if(!e)throw new Error("Failed to get authentication token");return e}async function uPn(t){let e=t.statusText||`HTTP ${t.status}`,l;try{l=await t.json(),typeof l=="object"&&l&&"message"in l&&(e=l.message)}catch{try{let n=await t.text();n&&(l=n)}catch{}}return{message:e,body:l}}async function WT(t,e,l){let{message:n,body:r}=await uPn(t),I;switch(t.status){case 400:I=`Bad request: ${n}`;break;case 401:I=`Unauthorized: ${n}`;break;case 402:I=e==="job"?"No remaining quota for premium requests":`Payment required: ${n}`;break;case 403:e==="job"||e==="agent"?I=`Coding Agent not enabled: ${n}`:I=`Forbidden: ${n}`;break;case 404:e==="job"&&l?.jobId?I=`Job not found: ${l.jobId}`:e==="session"&&l?.sessionId?I=`Session not found: ${l.sessionId}`:e==="repository"&&l?.repository?I=`Repository not found: ${l.repository}`:e==="pr"&&l?.prNumber?I=`Pull request not found: #${l.prNumber}`:I=`Not found: ${n}`;break;case 409:e==="pr"||e==="job"?I="PR already exists for these branches":I=`Conflict: ${n}`;break;case 422:e==="job"||e==="pr"?I="Branch protection or other rule prevents operation":I=`Unprocessable entity: ${n}`;break;case 500:I=`Internal server error: ${n}`;break;case 502:I=`Bad gateway: ${n}`;break;case 503:I=`Service unavailable: ${n}`;break;default:I=e?`Failed to ${e.replace(/_/g," ")}: ${n}`:n}throw new l7(t.status,I,r)}async function vL(t,e,l,n,r="API"){let I=await Gbe(e),a=Bce(),s={Authorization:`Bearer ${I}`,Accept:"application/json","User-Agent":`copilot-cli/${a}`};return n?.headers&&Object.assign(s,n.headers),lC(t,{...n,headers:s},l,r)}async function Qul(t,e,l){let{owner:n,repo:r}=t7(t),I=ww(e),a=gO(I),s=new URL(`/repos/${n}/${r}`,a),o=await vL(s,e,l,{method:"GET",headers:{Accept:"application/vnd.github.v3+json"}},"GitHub Repository API");return o.ok||await WT(o,"repository",{repository:t}),!0}async function Ful(t,e){return!0}c();async function Cul(t,e,l,n,r,I){let{owner:a,repo:s}=t7(t),{problemStatement:o}=ial(e,n),d=await Gbe(r),u=ww(r),b=await c0(u,d),p=new URL(`/agents/swe/v1/jobs/${a}/${s}`,b),Z=await vL(p,r,I,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({problem_statement:o,pull_request:{head_ref:l,body_suffix:"Created from Copilot CLI via the copilot push command."},event_type:"cli_push_command"})},"Copilot Job API");Z.ok||await WT(Z,"job",{repository:t});let N=await Z.json();return{jobId:N.job_id,sessionId:N.session_id,actor:{id:N.actor.id,login:N.actor.login},createdAt:new Date(N.created_at),updatedAt:new Date(N.updated_at)}}async function vul(t){let{repository:e,jobId:l,authInfo:n,logger:r}=t,{owner:I,repo:a}=t7(e),s=await Gbe(n),o=ww(n),d=await c0(o,s),u=new URL(`/agents/swe/v1/jobs/${I}/${a}/${l}`,d),b=await vL(u,n,r,{method:"GET"},"Copilot Job Status API");b.ok||await WT(b,"job",{jobId:l});let p=await b.json(),h;return p.pull_request?.number&&(h=`${o}/${e}/pull/${p.pull_request.number}`),{jobId:p.job_id,sessionId:p.session_id,problemStatement:p.problem_statement,status:p.status,result:p.result,actor:{id:p.actor.id,login:p.actor.login},createdAt:new Date(p.created_at),updatedAt:new Date(p.updated_at),pullRequest:p.pull_request?{id:p.pull_request.id,number:p.pull_request.number,url:h}:void 0,workflowRun:p.workflow_run?{id:p.workflow_run.id}:void 0,error:p.error?{message:p.error.message,responseStatusCode:p.error.response_status_code,service:p.error.service}:void 0}}async function tlt(t){let{sessionId:e,authInfo:l,logger:n,integrationId:r}=t,I=await Gbe(l),a=ww(l),s=await c0(a,I),o=new URL(`/agents/sessions/${e}`,s),d=await vL(o,l,n,{method:"GET",headers:{"Copilot-Integration-Id":r}},"Copilot Session API");d.ok||await WT(d,"session",{sessionId:e});let u=await d.json(),b=u.state;return{sessionId:u.id,state:b,createdAt:u.created_at?new Date(u.created_at):new Date,updatedAt:u.last_updated_at?new Date(u.last_updated_at):new Date,resourceGlobalId:u.resource_global_id}}async function pCe(t){let{repository:e,prNumber:l,authInfo:n,logger:r,includeFiles:I=!1,maxFiles:a=100}=t,{owner:s,repo:o}=t7(e),d=ww(n),u=gO(d),b=new URL(`/repos/${s}/${o}/pulls/${l}`,u),p=await vL(b,n,r,{method:"GET",headers:{Accept:"application/vnd.github.v3+json"}},"GitHub PR API");p.ok||await WT(p,"pr",{prNumber:l.toString()});let h=await p.json(),Z={title:h.title,draft:h.draft,createdAt:new Date(h.created_at),changedFiles:h.changed_files,totalAdditions:h.additions,totalDeletions:h.deletions};if(I){let N=new URL(`/repos/${s}/${o}/pulls/${l}/files`,u);N.searchParams.set("per_page",Math.min(a,100).toString()),N.searchParams.set("page","1");let y=await vL(N,n,r,{method:"GET",headers:{Accept:"application/vnd.github.v3+json"}},"GitHub PR Files API");if(y.ok){let Y=await y.json();Z.files=Y.slice(0,a).map(w=>({filename:w.filename,status:w.status,additions:w.additions,deletions:w.deletions}))}}return Z}var hCe=class{state=null;onStateChangeCallback=null;onSessionCompleteCallback=null;timeoutId=null;pollingIntervalId=null;initialAuthInfo;authInfo;logger;integrationId;constructor(e,l,n){this.initialAuthInfo=e,this.logger=l,this.integrationId=n}startPush(e,l,n=""){if(!this.initialAuthInfo)throw new Error("Not authenticated. Please login first.");this.authInfo=this.initialAuthInfo,this.logger.startGroup("Remote Push Started"),this.logger.info(`Prompt: "${e.substring(0,100)}${e.length>100?"...":""}"`),this.logger.info(`CLI Session ID: ${l}`),n&&this.logger.info(`Problem Context: "${n.substring(0,100)}${n.length>100?"...":""}"`),this.logger.endGroup(),this.state={stage:"uncommitted_changes_check",prompt:e,problemContext:n,cliSessionId:l,isLoading:!0},this.notifyStateChange(),this.checkUncommittedChanges()}advanceStage(){if(!this.state)return;let e=this.state.stage;switch(this.state.stage){case"uncommitted_changes_check":this.logger.info(`--- Stage transition: ${e} \u2192 ConfirmPush ---`),this.state={...this.state,stage:"confirm_push",isLoading:!0},this.notifyStateChange(),this.loadPushConfirmationData();break;case"confirm_push":this.logger.info(`--- Stage transition: ${e} \u2192 PushProcessing ---`),this.state={...this.state,stage:"push_processing",processingStartTime:new Date},this.notifyStateChange(),this.executePushOperations();break;case"push_processing":this.logger.info(`--- Stage transition: ${e} \u2192 PushTracking ---`),this.state={...this.state,stage:"push_tracking"},this.notifyStateChange(),this.startJobTracking();break;case"push_tracking":this.logger.info(`--- Stage transition: ${e} \u2192 Complete ---`),this.completePushOperation();break}}cancelPush(){let e=this.state?.stage;this.logger.info(`Remote push cancelled${e?` (was in stage: ${e})`:""}`),this.timeoutId&&(clearTimeout(this.timeoutId),this.timeoutId=null),this.clearPollingInterval(),this.state=null,this.notifyStateChange()}setOnStateChangeCallback(e){this.onStateChangeCallback=e,this.notifyStateChange()}onSessionComplete(e){this.onSessionCompleteCallback=e}getCurrentState(){return this.state}isActive(){return this.state!==null}async checkUncommittedChanges(){if(!this.state)return;let e=Date.now();this.logger.info("STAGE 1: UncommittedChangesCheck - Starting validation checks");try{let l=await If(process.cwd());if(!l.found)throw new Error("Not a git repository");let n=await elt(process.cwd());this.logger.info(`Repository: ${n.repository}`),this.logger.info(`Base branch: ${n.baseBranch}, Head branch: ${n.headBranch}`),this.logger.info(`Async branch: ${n.asyncBranch}`),this.logger.info("Running parallel validation checks (detached HEAD, repo access, Copilot enabled)...");let[r,I,a]=await Promise.allSettled([Rul(process.cwd()),Qul(n.repository,this.authInfo,this.logger),Ful(n.repository,this.authInfo)]),s=[];if(r.status==="fulfilled"&&r.value===!0?s.push("Repository is in detached HEAD state. Please checkout a branch before pushing."):r.status==="rejected"&&s.push(`Failed to check HEAD state: ${r.reason}`),I.status==="fulfilled"&&I.value===!1?s.push(`Repository not found or you don't have access: ${n.repository}`):I.status==="rejected"&&s.push(I.reason?.message||"Failed to check repository access"),a.status==="rejected"&&s.push(a.reason?.message||"Failed to check Copilot status"),s.length>0){let b=s.length===1?s[0]:`Multiple errors:
2415
2415
  \u2022 ${s.join(`
2416
- \u2022 `)}`;throw new Error(b)}let o=await Wul(process.cwd());o.hasChanges?this.logger.info(`Uncommitted changes detected: ${o.staged} staged, ${o.unstaged} unstaged, ${o.untracked} untracked`):this.logger.info("No uncommitted changes detected");let d=o.hasChanges?await yul():void 0;d&&this.logger.info(`Generated checkpoint commit message: "${d}"`),this.state={...this.state,isLoading:!1,isGitRepository:l.found,hasUncommittedChanges:o.hasChanges,fileCount:o.hasChanges?{staged:o.staged,unstaged:o.unstaged,untracked:o.untracked}:void 0,commitMessage:d,repository:n.repository,baseBranch:n.baseBranch,headBranch:n.headBranch,asyncBranch:n.asyncBranch},this.notifyStateChange();let u=Date.now()-e;this.logger.info(`STAGE 1: UncommittedChangesCheck completed in ${u}ms`),o.hasChanges||(this.logger.info("Auto-advancing to ConfirmPush stage (no uncommitted changes)"),this.state={...this.state,stage:"confirm_push",isLoading:!1,isGitRepository:l.found,hasUncommittedChanges:!1},this.notifyStateChange(),await this.loadPushConfirmationData())}catch(l){this.setError(l,"Failed during uncommitted changes check")}}async loadPushConfirmationData(){if(!this.state)return;let e=Date.now();this.logger.info("STAGE 2: ConfirmPush - Loading confirmation data");try{if(this.state.repository)this.logger.info("Repository info already available from previous stage"),this.state={...this.state,isLoading:!1};else{this.logger.info("Repository info not found, fetching...");let n=await elt(process.cwd());this.state={...this.state,isLoading:!1,repository:n.repository,baseBranch:n.baseBranch,headBranch:n.headBranch,asyncBranch:n.asyncBranch},this.logger.info(`Loaded repository info: ${n.repository}`)}this.notifyStateChange();let l=Date.now()-e;this.logger.info(`STAGE 2: ConfirmPush completed in ${l}ms - Waiting for user confirmation`)}catch(l){this.setError(l,"Failed to load push confirmation data")}}async executePushOperations(){if(!this.state)return;let e=Date.now();this.logger.info("STAGE 3: PushProcessing - Executing push operations");try{let l=this.buildOperationsList();this.state={...this.state,operations:l},this.notifyStateChange(),this.logger.info(`Operations to execute: ${l.map(n=>n.id).join(" \u2192 ")}`);for(let n of l){if(!this.state)break;let r=Date.now();this.logger.info(`Operation [${n.id}] - Starting...`),this.updateOperationStatus(n.id,"running");try{switch(n.id){case"commit":{let a=await Yul(process.cwd(),this.state.commitMessage);this.state={...this.state,commitHash:a.commitHash},this.logger.info(`Operation [${n.id}] - Commit created: ${a.commitHash}`);break}case"create-branch":{this.logger.info(`Operation [${n.id}] - Creating branch: ${this.state.asyncBranch}`),await wul({cwd:process.cwd(),repository:this.state.repository,headBranch:this.state.headBranch,baseBranch:this.state.baseBranch,asyncBranch:this.state.asyncBranch}),this.logger.info(`Operation [${n.id}] - Branch created and pushed: ${this.state.asyncBranch}`),await Vul(this.state.headBranch),this.logger.info(`Operation [${n.id}] - Switched back to: ${this.state.headBranch}`);break}case"start-job":{this.logger.info(`Operation [${n.id}] - Creating job for repository: ${this.state.repository}`);let a=await Cul(this.state.repository,this.state.prompt,this.state.asyncBranch,this.state.problemContext||"",this.authInfo,this.logger);if(!a.jobId||!a.sessionId)throw new Error(`Job creation returned incomplete data: jobId=${a.jobId}, sessionId=${a.sessionId}`);this.state={...this.state,jobId:a.jobId,sessionId:a.sessionId,jobCreatedBy:a.actor.login,jobCreatedAt:a.createdAt},this.logger.info(`Operation [${n.id}] - Job created: ID=${a.jobId}, Session=${a.sessionId}, CreatedBy=${a.actor.login}`);break}case"check-job":{if(!this.state.jobId)throw new Error("No job ID available to check status");let a=1e3,s=9e4,o=Date.now(),d=!1,u=0;for(this.logger.info(`Operation [${n.id}] - Polling for PR details (max ${s}ms)...`);!d&&Date.now()-o<s;){u++;let b=await vul({repository:this.state.repository,jobId:this.state.jobId,authInfo:this.authInfo,logger:this.logger});this.state={...this.state,jobStatus:b.status,jobResult:b.result,prNumber:b.pullRequest?.number,prUrl:b.pullRequest?.url},b.pullRequest?.number?(this.logger.info(`Operation [${n.id}] - PR details received: #${b.pullRequest.number} (after ${u} polls, ${Date.now()-o}ms)`),d=!0):await new Promise(p=>setTimeout(p,a))}if(!d)throw new CO(`Timed out waiting for pull request information after ${s}ms`,"check-job",this.state.prUrl);break}case"wait-for-session":{if(!this.state.sessionId)throw new Error("No session ID available to check status");let a=1e3,s=9e4,o=Date.now(),d=!1,u=!1,b=!1,p=0;for(this.logger.info(`Operation [${n.id}] - Waiting for session to start (max ${s}ms)...`);!d&&Date.now()-o<s;){p++;let h=await tlt({sessionId:this.state.sessionId,authInfo:this.authInfo,logger:this.logger,integrationId:this.integrationId});if(h.resourceGlobalId&&!this.state.jobUrl){let Z=ww(this.authInfo);this.state={...this.state,jobUrl:`${Z}/copilot/tasks/pull/${h.resourceGlobalId}?session_id=${this.state.sessionId}`},b=!0,this.logger.info(`Operation [${n.id}] - Job URL constructed: ${this.state.jobUrl}`)}if(this.state.prNumber&&!u){let Z=await pCe({repository:this.state.repository,prNumber:this.state.prNumber,authInfo:this.authInfo,logger:this.logger,includeFiles:!1});this.state={...this.state,prTitle:Z.title,prDraft:Z.draft,prCreatedAt:Z.createdAt},u=!0,this.logger.info(`Operation [${n.id}] - PR details fetched: "${Z.title}"`)}h.state==="in_progress"?(this.logger.info(`Operation [${n.id}] - Session transitioned to in_progress (after ${p} polls, ${Date.now()-o}ms)`),d=!0):h.state==="completed"||h.state==="failed"||h.state==="cancelled"||h.state==="timed_out"?(this.logger.info(`Operation [${n.id}] - Session ended with state: ${h.state} (after ${p} polls, ${Date.now()-o}ms)`),d=!0):(h.state==="waiting_for_user"||h.state==="idle")&&(this.logger.info(`Operation [${n.id}] - Session in intermediate state: ${h.state} (after ${p} polls, ${Date.now()-o}ms)`),d=!0),(!d||!u||!b)&&await new Promise(Z=>setTimeout(Z,a))}if(!d||!u||!b){let h=[];throw d||h.push("session transition"),u||h.push("PR details"),b||h.push("job URL"),new CO(`Timed out after ${s}ms waiting for: ${h.join(", ")}`,"wait-for-session",this.state.prUrl)}break}}this.updateOperationStatus(n.id,"done");let I=Date.now()-r;this.logger.info(`Operation [${n.id}] - Completed in ${I}ms`)}catch(I){this.updateOperationStatus(n.id,"error",I.message);let a=Date.now()-r;this.logger.error(`Operation [${n.id}] - Failed after ${a}ms: ${I.message}`),await new Promise(s=>setTimeout(s,3e3)),this.setError(I,`Operation '${n.id}' failed`);return}}if(this.allOperationsComplete()){let n=Date.now()-e;this.logger.info(`STAGE 3: PushProcessing completed in ${n}ms - All operations successful`),setTimeout(()=>this.advanceStage(),2e3)}}catch(l){this.setError(l,"Failed to execute push operations")}}async startJobTracking(){if(!this.state||!this.state.sessionId){this.logger.error("Cannot start job tracking: missing state or sessionId"),this.cancelPush();return}this.logger.info("STAGE 4: PushTracking - Starting job tracking"),this.logger.info(`Tracking session: ${this.state.sessionId}`),this.state.prNumber&&this.logger.info(`Tracking PR: #${this.state.prNumber}`);let e=1e3,l=null,n=async()=>{if(!this.state||!this.state.sessionId){this.clearPollingInterval();return}try{let r=await tlt({sessionId:this.state.sessionId,authInfo:this.authInfo,logger:this.logger,integrationId:this.integrationId}),I=this.state.sessionState;if(this.state={...this.state,sessionState:r.state},I!==r.state&&this.logger.info(`Session state changed: ${I||"unknown"} \u2192 ${r.state}`),!this.state.jobUrl&&r.resourceGlobalId){let s=ww(this.authInfo);this.state.jobUrl=`${s}/copilot/tasks/pull/${r.resourceGlobalId}?session_id=${this.state.sessionId}`,this.logger.info(`Constructed job URL from polling: ${this.state.jobUrl}`)}if(this.state.prNumber)try{let s=await pCe({repository:this.state.repository,prNumber:this.state.prNumber,authInfo:this.authInfo,logger:this.logger,includeFiles:!1}),o=s.changedFiles!==this.state.prChangedFiles||s.totalAdditions!==this.state.prTotalAdditions||s.totalDeletions!==this.state.prTotalDeletions;if(this.state={...this.state,prTitle:s.title,prDraft:s.draft,prCreatedAt:s.createdAt,prChangedFiles:s.changedFiles,prTotalAdditions:s.totalAdditions,prTotalDeletions:s.totalDeletions},o||!this.state.prFiles){let d=await pCe({repository:this.state.repository,prNumber:this.state.prNumber,authInfo:this.authInfo,logger:this.logger,includeFiles:!0,maxFiles:10});this.state={...this.state,prFiles:d.files},this.logger.info(`PR files updated: ${s.changedFiles} files${s.changedFiles>10?" (showing first 10)":""}, +${s.totalAdditions} -${s.totalDeletions}`)}}catch(s){this.logError("Failed to fetch PR details",s,"warning")}if(this.notifyStateChange(),r.state==="completed"||r.state==="failed"||r.state==="cancelled"||r.state==="timed_out"){this.logger.info(`STAGE 4: PushTracking - Session ended with terminal state: ${r.state}`),this.clearPollingInterval(),setTimeout(()=>this.completePushOperation(),3e3);return}let a=1e3;if(r.state==="waiting_for_user"||r.state==="idle"){l===null&&(l=Date.now());let s=Date.now()-l,o=300*1e3,d=Math.floor(s/o);a=Math.min(5e3+d*5e3,3e4)}else l=null;if(a!==e){let s=e;e=a,this.clearPollingInterval(),this.pollingIntervalId=setInterval(()=>void n(),e),this.logger.info(`Polling interval adjusted: ${s}ms \u2192 ${e}ms (state: ${r.state})`)}}catch(r){this.clearPollingInterval(),this.setError(r,"Error polling session status")}};this.pollingIntervalId=setInterval(()=>void n(),e),n()}completePushOperation(){this.clearPollingInterval(),this.logger.info("STAGE 5: Complete - Push operation completed"),this.state&&(this.logger.startGroup("Push Operation Summary"),this.state.jobId&&this.logger.info(`Job ID: ${this.state.jobId}`),this.state.sessionId&&this.logger.info(`Session ID: ${this.state.sessionId}`),this.state.prNumber&&this.logger.info(`PR #${this.state.prNumber}: ${this.state.prUrl||"N/A"}`),this.state.commitHash&&this.logger.info(`Commit: ${this.state.commitHash}`),this.state.asyncBranch&&this.logger.info(`Branch: ${this.state.asyncBranch}`),this.state.sessionState&&this.logger.info(`Final session state: ${this.state.sessionState}`),this.logger.endGroup()),this.timeoutId&&clearTimeout(this.timeoutId),this.timeoutId=setTimeout(()=>{this.timeoutId=null,this.logger.info("Remote push workflow finished - Cleaning up"),this.onSessionCompleteCallback?this.onSessionCompleteCallback():(this.state=null,this.notifyStateChange())},3e3)}buildOperationsList(){if(!this.state)return[];let e=[];return this.state.hasUncommittedChanges&&e.push({id:"commit",status:"pending"}),e.push({id:"create-branch",status:"pending"},{id:"start-job",status:"pending"},{id:"check-job",status:"pending"},{id:"wait-for-session",status:"pending"}),e}updateOperationStatus(e,l,n){if(!this.state||!this.state.operations)return;let r=this.state.operations.map(I=>I.id===e?{...I,status:l,...n?{error:n}:{}}:I);this.state={...this.state,operations:r},this.notifyStateChange()}allOperationsComplete(){return!this.state||!this.state.operations?!0:this.state.operations.every(e=>e.status==="done"||e.status==="error")}setError(e,l){this.state&&(this.logError(l||"Operation failed",e,"error"),this.state={...this.state,error:e,isLoading:!1},this.notifyStateChange())}notifyStateChange(){this.onStateChangeCallback?.(this.state)}clearPollingInterval(){this.pollingIntervalId&&(clearInterval(this.pollingIntervalId),this.pollingIntervalId=null)}logError(e,l,n="error"){if(l instanceof l7){let r=l.responseBody?` | Response: ${JSON.stringify(l.responseBody)}`:"",I=`${e} - API error - Status: ${l.status} | Message: ${l.message}${r}`;n==="error"?this.logger.error(I):this.logger.warning(I)}else{let r=`${e}: ${l instanceof Error?l.message:String(l)}`;n==="error"?this.logger.error(r):this.logger.warning(r)}}};c();var n7=class{turnStartTimes=new Map;turnModelCallTimes=new Map;turnToolExecutionTimes=new Map;turnToolCallCounts=new Map;startTurn(e,l){this.turnStartTimes.set(e,l),this.turnModelCallTimes.set(e,{}),this.turnToolExecutionTimes.set(e,0),this.turnToolCallCounts.set(e,0)}recordModelCall(e,l){let n=this.turnModelCallTimes.get(e)||{};n.duration=l,this.turnModelCallTimes.set(e,n)}recordToolExecution(e,l){let n=this.turnToolExecutionTimes.get(e)||0;this.turnToolExecutionTimes.set(e,n+l);let r=this.turnToolCallCounts.get(e)||0;this.turnToolCallCounts.set(e,r+1)}finishTurn(e,l){let n=this.turnStartTimes.get(e);if(n===void 0)return this.cleanup(e),null;let r=l-n,I=this.turnModelCallTimes.get(e)||{},a=this.turnToolExecutionTimes.get(e)||0,s=this.turnToolCallCounts.get(e)||0,o=I.duration||0,d={totalDurationMs:r,llmDurationMs:o,toolExecutionMs:a,toolCallCount:s,totalDurationSeconds:(r/1e3).toFixed(2),llmDurationSeconds:(o/1e3).toFixed(2),toolExecutionSeconds:(a/1e3).toFixed(2)};return this.cleanup(e),d}cleanup(e){this.turnStartTimes.delete(e),this.turnModelCallTimes.delete(e),this.turnToolExecutionTimes.delete(e),this.turnToolCallCounts.delete(e)}static formatTimingBreakdown(e){return`LLM: ${e.llmDurationSeconds}s | Tools: ${e.toolExecutionSeconds}s (${e.toolCallCount} calls) | Total: ${e.totalDurationSeconds}s`}};c();var mPn="You are not licensed to use Copilot.",bPn="You are not authorized to use this Copilot feature, it requires an enterprise or organization policy to be enabled.",GPn="The provided personal access token (PAT) does not have Copilot Requests permission. Please generate a new Fine-Grained Access Token with Copilot Requests permission (not a Classic token), or log in using /login";function llt(t){return t.includes("not licensed to use Copilot")?{kind:"not-licensed",message:mPn}:t.includes("not authorized to use this Copilot feature")?{kind:"not-authorized",message:bPn}:t.includes("Personal Access Token does not have Copilot Requests")?{kind:"not-authorized",message:GPn}:null}c();import{promises as pPn}from"fs";import nlt from"path";function hPn(t){let e=[],l=/(?<![a-zA-Z0-9])(@[^\s@]+)/g,n;for(;(n=l.exec(t))!==null;)e.push({displayText:n[1],startIndex:n.index,endIndex:n.index+n[0].length});return e}async function APn(t){try{let e=await pPn.stat(t);return e.isDirectory()?"directory":e.isFile()?lse(nlt.basename(t))?"image":"file":null}catch{return null}}async function ZPn(t,e=new Map,l=process.cwd()){let n=hPn(t),r=[];for(let I of n){let a=e.get(I.startIndex);if(a?.startIndex===I.startIndex)r.push(a);else{let s=I.displayText.slice(1).replace(/[.,;:!?]+$/,""),o=nlt.isAbsolute(s)?s:nlt.resolve(l,s),d=await APn(o);if(d===null)continue;r.push({displayText:I.displayText,fullPath:o,type:d,startIndex:I.startIndex})}}return r}async function ful(t,e=new Map,l=process.cwd(),n){let r=await ZPn(t,e,l);return n.debug(`Detected mentions: ${r.map(I=>`${I.displayText} (${I.type})`).join(", ")}`),r.map(I=>({type:I.type==="image"?"file":I.type,path:I.fullPath,displayName:I.displayText,mentionIndex:I.startIndex}))}c();var ACe=nt(qt(),1);c();import{EventEmitter as slt}from"node:events";var rlt=class extends slt{get columns(){return 100}frames=[];_lastFrame;write=e=>{this.frames.push(e),this._lastFrame=e};lastFrame=()=>this._lastFrame},Ilt=class extends slt{frames=[];_lastFrame;write=e=>{this.frames.push(e),this._lastFrame=e};lastFrame=()=>this._lastFrame},alt=class extends slt{isTTY=!0;data=null;constructor(e={}){super(),this.isTTY=e.isTTY??!0}write=e=>{this.data=e,this.emit("readable"),this.emit("data",e)};setEncoding(){}setRawMode(){}resume(){}pause(){}ref(){}unref(){}read=()=>{let{data:e}=this;return this.data=null,e}},gPn=[],Hul=t=>{let e=new rlt,l=new Ilt,n=new alt,r=oee(t,{stdout:e,stderr:l,stdin:n,debug:!0,exitOnCtrlC:!1,patchConsole:!1});return gPn.push(r),{rerender:r.rerender,unmount:r.unmount,cleanup:r.cleanup,stdout:e,stderr:l,stdin:n,frames:e.frames,lastFrame:e.lastFrame}};function Xul(t,e=!1){let l=ACe.default.createElement(WQe,{logger:new Hc,children:ACe.default.createElement(YQe,{mode:"non-interactive",children:ACe.default.createElement(Yme,{entry:t,expand:e})})}),{lastFrame:n}=Hul(l),r=n();return r?r.trim():""}var kul=1,olt=!1;function yPn(t){olt=t}var zw=!1,ZCe=[],Oh=null,yT=!1;async function Lul(){if(zw||ZCe.length===0)return;zw=!0;let{integrationId:t,messageContent:e,permissionService:l,authInfo:n,resolve:r,reject:I,completePendingToolCall:a,setQuotaSnapshots:s,setContextWindowMetrics:o,setStreamingResponseSize:d,session:u,logger:b,pathManager:p,cliModel:h,enableStreaming:Z,trajectoryOutputFile:N,mcpHost:y,showLlmTiming:Y,timingTracker:w,noCustomInstructions:H,setAvailableTools:J,customAgentPrompt:S,modelList:T,disableParallelToolsExecution:U}=ZCe.shift();try{let j=await RPn(t,e,l,n,a,s,o,d,u,b,p,h,Z,N,y,Y,w,H,J,S,T,U);r(j)}catch(j){j&&typeof j=="object"&&"name"in j&&j.name==="AbortError"||j&&typeof j=="object"&&"message"in j&&typeof j.message=="string"&&j.message.includes("Operation was cancelled")?r("Operation cancelled"):I(j)}finally{zw=!1,ZCe.length>0&&setTimeout(()=>void Lul(),100)}}var EPn=TAt(c0);async function RPn(t,e,l,n,r,I,a,s,o,d,u,b,p,h,Z,N,y,Y,w,H,J,S){Oh=new AbortController,WPn(0,Oh.signal),s(0);try{let T=await Lr.load()||{},U=await jW(n),j=T.copilot_url;!j&&U&&n.type!=="hmac"&&(j=await EPn(n.host,U)),es.env.GITHUB_COPILOT_CLI_MODE="true";let O={problemStatement:e,logger:d,saveTrajectoryOutput:h||void 0,apiCopilotIntegrationId:t,apiCopilotHmacKey:n.type==="hmac"?n.hmac:void 0,apiCopilotUrl:j,apiCopilotToken:U,serviceInstanceId:o.sessionId,mcpHost:Z,saveEventLogs:es.env.COPILOT_EVENTS_LOG_DIRECTORY},z=IL()&&es.env.COPILOT_AGENT_MODEL?es.env.COPILOT_AGENT_MODEL:`sweagent-capi:${b}`,se={...O,pathManager:u,serviceAgentModel:z,requestPermission:l.request,onToolPartialOutput:(ue,We)=>{o.addEvent({type:"tool.execution_partial_result",ephemeral:!0,data:{toolCallId:ue,partialOutput:We}})},showEvents:!0,showSessionLog:!1,useSessionLogOnly:!1,abortSignal:Oh.signal,executeToolsInParallel:!S};try{let ue=await iFe.createFromOptions(se);w&&w(ue.getAvailableTools());let We=await If(es.cwd());We.found&&!Y&&await eTe(We.gitRoot,!0,es.cwd());let ee=ue.getAgentKind(),M=ue.getModel(),be=Yje()[ee]?.[M]??Rje(),ae=ue.getToolConfig?.call(ue)??{},Re=be.supports||{},Ge=await ZTe(We.found?We.gitRoot:"",Bce(),es.cwd(),{},Re,ae,ue.getAvailableTools(),void 0,Y),ve=new dFe(o,s,olt),Ae=await o.getChatContextMessages(),Ee=Ae.findLastIndex(dl=>dl.role==="user"),Ie=Ae[Ee];typeof Ie.content=="string"?Ie={...Ie,content:_ye({customAgentPrompt:H,problemStatement:Ie.content,capabilities:Re})}:Ie={...Ie,content:Ie.content.map(dl=>dl.type==="text"?{...dl,text:_ye({customAgentPrompt:H,problemStatement:dl.text,capabilities:Re})}:dl)};let Me=new PS(Ie,d),Je=new jK(d),$t=ue.getCompletionWithTools(Ge,Ae.map((dl,Ke)=>Ke===Ee?Ie:dl),{stream:p,failIfInitialInputsTooLong:!1,processors:{preRequest:[Me,new jye,Je],onRequestError:[Me],onStreamingChunk:[ve]},executeToolsInParallel:!S,abortSignal:Oh.signal});for await(let dl of $t){if(Oh?.signal.aborted){let Ke=new Error("Operation was cancelled");throw Ke.name="AbortError",Ke}await vBt(dl,{onImageProcessingEvent:Ke=>{},onImageRemovalEvent:Ke=>{},onMessage:Ke=>{if(B9(Ke)){let Lt=ve.endCurrentStreamingMessage(),st=typeof Ke.message.content=="string"?Ke.message.content:null,Bt=Pce(Ke)?Ke.message.tool_calls.map(zt=>({toolCallId:zt.id,name:zt.function.name,arguments:W9(zt.function.arguments)})):[];o.addEvent({type:"assistant.message",data:{messageId:Lt??Bu(),content:st||"",toolRequests:Bt}});for(let zt of Bt)o.addEvent({type:"tool.execution_start",data:{toolCallId:zt.toolCallId,toolName:zt.name,arguments:zt.arguments}})}else(Ke.message.role==="system"||Ke.message.role==="developer")&&o.addEvent({type:"system.message",data:{role:Ke.message.role,content:typeof Ke.message.content=="string"?Ke.message.content:JSON.stringify(Ke.message.content),name:"name"in Ke.message?Ke.message.name:void 0}})},onResponse:Ke=>{},onModelCallFailure:Ke=>{if(llt(Ke.modelCall?.error||""))return;let st=Ke.modelCall?.error||"Unknown error occurred";Ke.modelCall.request_id&&(st+=` (Request ID: ${Ke.modelCall.request_id})`),o.addEvent({type:"session.error",data:{errorType:"model_call",message:`Model call failed: ${st}`}})},onModelCallSuccess:async Ke=>{I(Ke.quotaSnapshots||{});let Lt=Ke.responseChunk.model||await o.getSelectedModel(),st=Ke.modelCallDurationMs||0,Bt=Ke.responseUsage,zt=Lt?L8(Lt,J):1;o.addEvent({type:"assistant.usage",ephemeral:!0,data:{model:Lt||"unknown",tokensUsed:Bt?.total_tokens||0,cost:zt,duration:st,initiator:Ke.modelCall?.initiator}}),N&&y&&y.recordModelCall(Ke.turn,Ke.modelCallDurationMs)},onToolExecution:Ke=>{r({callId:Ke.toolCallId,resultType:Ke.toolResult.resultType,log:(Ke.toolResult.resultType==="failure"?Ke.toolResult.error:void 0)||Ke.toolResult.sessionLog||Ke.toolResult.textResultForLlm}),N&&y&&y.recordToolExecution(Ke.turn,Ke.durationMs)},onTruncationEvent:Ke=>{a(Lt=>{let st=Math.max(Lt.totalTokens,Ke.truncateResult.preTruncationTokensInMessages);return{...Lt,totalTokens:st,postTruncationTokens:Ke.truncateResult.postTruncationTokensInMessages,tokenLimit:Ke.truncateResult.tokenLimit,messagesRemoved:Ke.truncateResult.messagesRemovedDuringTruncation,tokensRemoved:Ke.truncateResult.tokensRemovedDuringTruncation}})},onTurnEvent:Ke=>{if(Ke.kind==="turn_started")N&&y&&y.startTurn(Ke.turn,Ke.timestampMs);else if(Ke.kind==="turn_ended"&&N&&y){let Lt=y.finishTurn(Ke.turn,Ke.timestampMs);if(Lt){let st=n7.formatTimingBreakdown(Lt);olt?es.stdout.write(`
2416
+ \u2022 `)}`;throw new Error(b)}let o=await Wul(process.cwd());o.hasChanges?this.logger.info(`Uncommitted changes detected: ${o.staged} staged, ${o.unstaged} unstaged, ${o.untracked} untracked`):this.logger.info("No uncommitted changes detected");let d=o.hasChanges?await yul():void 0;d&&this.logger.info(`Generated checkpoint commit message: "${d}"`),this.state={...this.state,isLoading:!1,isGitRepository:l.found,hasUncommittedChanges:o.hasChanges,fileCount:o.hasChanges?{staged:o.staged,unstaged:o.unstaged,untracked:o.untracked}:void 0,commitMessage:d,repository:n.repository,baseBranch:n.baseBranch,headBranch:n.headBranch,asyncBranch:n.asyncBranch},this.notifyStateChange();let u=Date.now()-e;this.logger.info(`STAGE 1: UncommittedChangesCheck completed in ${u}ms`),o.hasChanges||(this.logger.info("Auto-advancing to ConfirmPush stage (no uncommitted changes)"),this.state={...this.state,stage:"confirm_push",isLoading:!1,isGitRepository:l.found,hasUncommittedChanges:!1},this.notifyStateChange(),await this.loadPushConfirmationData())}catch(l){this.setError(l,"Failed during uncommitted changes check")}}async loadPushConfirmationData(){if(!this.state)return;let e=Date.now();this.logger.info("STAGE 2: ConfirmPush - Loading confirmation data");try{if(this.state.repository)this.logger.info("Repository info already available from previous stage"),this.state={...this.state,isLoading:!1};else{this.logger.info("Repository info not found, fetching...");let n=await elt(process.cwd());this.state={...this.state,isLoading:!1,repository:n.repository,baseBranch:n.baseBranch,headBranch:n.headBranch,asyncBranch:n.asyncBranch},this.logger.info(`Loaded repository info: ${n.repository}`)}this.notifyStateChange();let l=Date.now()-e;this.logger.info(`STAGE 2: ConfirmPush completed in ${l}ms - Waiting for user confirmation`)}catch(l){this.setError(l,"Failed to load push confirmation data")}}async executePushOperations(){if(!this.state)return;let e=Date.now();this.logger.info("STAGE 3: PushProcessing - Executing push operations");try{let l=this.buildOperationsList();this.state={...this.state,operations:l},this.notifyStateChange(),this.logger.info(`Operations to execute: ${l.map(n=>n.id).join(" \u2192 ")}`);for(let n of l){if(!this.state)break;let r=Date.now();this.logger.info(`Operation [${n.id}] - Starting...`),this.updateOperationStatus(n.id,"running");try{switch(n.id){case"commit":{let a=await Yul(process.cwd(),this.state.commitMessage);this.state={...this.state,commitHash:a.commitHash},this.logger.info(`Operation [${n.id}] - Commit created: ${a.commitHash}`);break}case"create-branch":{this.logger.info(`Operation [${n.id}] - Creating branch: ${this.state.asyncBranch}`),await wul({cwd:process.cwd(),repository:this.state.repository,headBranch:this.state.headBranch,baseBranch:this.state.baseBranch,asyncBranch:this.state.asyncBranch}),this.logger.info(`Operation [${n.id}] - Branch created and pushed: ${this.state.asyncBranch}`),await Vul(this.state.headBranch),this.logger.info(`Operation [${n.id}] - Switched back to: ${this.state.headBranch}`);break}case"start-job":{this.logger.info(`Operation [${n.id}] - Creating job for repository: ${this.state.repository}`);let a=await Cul(this.state.repository,this.state.prompt,this.state.asyncBranch,this.state.problemContext||"",this.authInfo,this.logger);if(!a.jobId||!a.sessionId)throw new Error(`Job creation returned incomplete data: jobId=${a.jobId}, sessionId=${a.sessionId}`);this.state={...this.state,jobId:a.jobId,sessionId:a.sessionId,jobCreatedBy:a.actor.login,jobCreatedAt:a.createdAt},this.logger.info(`Operation [${n.id}] - Job created: ID=${a.jobId}, Session=${a.sessionId}, CreatedBy=${a.actor.login}`);break}case"check-job":{if(!this.state.jobId)throw new Error("No job ID available to check status");let a=1e3,s=9e4,o=Date.now(),d=!1,u=0;for(this.logger.info(`Operation [${n.id}] - Polling for PR details (max ${s}ms)...`);!d&&Date.now()-o<s;){u++;let b=await vul({repository:this.state.repository,jobId:this.state.jobId,authInfo:this.authInfo,logger:this.logger});this.state={...this.state,jobStatus:b.status,jobResult:b.result,prNumber:b.pullRequest?.number,prUrl:b.pullRequest?.url},b.pullRequest?.number?(this.logger.info(`Operation [${n.id}] - PR details received: #${b.pullRequest.number} (after ${u} polls, ${Date.now()-o}ms)`),d=!0):await new Promise(p=>setTimeout(p,a))}if(!d)throw new CO(`Timed out waiting for pull request information after ${s}ms`,"check-job",this.state.prUrl);break}case"wait-for-session":{if(!this.state.sessionId)throw new Error("No session ID available to check status");let a=1e3,s=9e4,o=Date.now(),d=!1,u=!1,b=!1,p=0;for(this.logger.info(`Operation [${n.id}] - Waiting for session to start (max ${s}ms)...`);!d&&Date.now()-o<s;){p++;let h=await tlt({sessionId:this.state.sessionId,authInfo:this.authInfo,logger:this.logger,integrationId:this.integrationId});if(h.resourceGlobalId&&!this.state.jobUrl){let Z=ww(this.authInfo);this.state={...this.state,jobUrl:`${Z}/copilot/tasks/pull/${h.resourceGlobalId}?session_id=${this.state.sessionId}`},b=!0,this.logger.info(`Operation [${n.id}] - Job URL constructed: ${this.state.jobUrl}`)}if(this.state.prNumber&&!u){let Z=await pCe({repository:this.state.repository,prNumber:this.state.prNumber,authInfo:this.authInfo,logger:this.logger,includeFiles:!1});this.state={...this.state,prTitle:Z.title,prDraft:Z.draft,prCreatedAt:Z.createdAt},u=!0,this.logger.info(`Operation [${n.id}] - PR details fetched: "${Z.title}"`)}h.state==="in_progress"?(this.logger.info(`Operation [${n.id}] - Session transitioned to in_progress (after ${p} polls, ${Date.now()-o}ms)`),d=!0):h.state==="completed"||h.state==="failed"||h.state==="cancelled"||h.state==="timed_out"?(this.logger.info(`Operation [${n.id}] - Session ended with state: ${h.state} (after ${p} polls, ${Date.now()-o}ms)`),d=!0):(h.state==="waiting_for_user"||h.state==="idle")&&(this.logger.info(`Operation [${n.id}] - Session in intermediate state: ${h.state} (after ${p} polls, ${Date.now()-o}ms)`),d=!0),(!d||!u||!b)&&await new Promise(Z=>setTimeout(Z,a))}if(!d||!u||!b){let h=[];throw d||h.push("session transition"),u||h.push("PR details"),b||h.push("job URL"),new CO(`Timed out after ${s}ms waiting for: ${h.join(", ")}`,"wait-for-session",this.state.prUrl)}break}}this.updateOperationStatus(n.id,"done");let I=Date.now()-r;this.logger.info(`Operation [${n.id}] - Completed in ${I}ms`)}catch(I){this.updateOperationStatus(n.id,"error",I.message);let a=Date.now()-r;this.logger.error(`Operation [${n.id}] - Failed after ${a}ms: ${I.message}`),await new Promise(s=>setTimeout(s,3e3)),this.setError(I,`Operation '${n.id}' failed`);return}}if(this.allOperationsComplete()){let n=Date.now()-e;this.logger.info(`STAGE 3: PushProcessing completed in ${n}ms - All operations successful`),setTimeout(()=>this.advanceStage(),2e3)}}catch(l){this.setError(l,"Failed to execute push operations")}}async startJobTracking(){if(!this.state||!this.state.sessionId){this.logger.error("Cannot start job tracking: missing state or sessionId"),this.cancelPush();return}this.logger.info("STAGE 4: PushTracking - Starting job tracking"),this.logger.info(`Tracking session: ${this.state.sessionId}`),this.state.prNumber&&this.logger.info(`Tracking PR: #${this.state.prNumber}`);let e=1e3,l=null,n=async()=>{if(!this.state||!this.state.sessionId){this.clearPollingInterval();return}try{let r=await tlt({sessionId:this.state.sessionId,authInfo:this.authInfo,logger:this.logger,integrationId:this.integrationId}),I=this.state.sessionState;if(this.state={...this.state,sessionState:r.state},I!==r.state&&this.logger.info(`Session state changed: ${I||"unknown"} \u2192 ${r.state}`),!this.state.jobUrl&&r.resourceGlobalId){let s=ww(this.authInfo);this.state.jobUrl=`${s}/copilot/tasks/pull/${r.resourceGlobalId}?session_id=${this.state.sessionId}`,this.logger.info(`Constructed job URL from polling: ${this.state.jobUrl}`)}if(this.state.prNumber)try{let s=await pCe({repository:this.state.repository,prNumber:this.state.prNumber,authInfo:this.authInfo,logger:this.logger,includeFiles:!1}),o=s.changedFiles!==this.state.prChangedFiles||s.totalAdditions!==this.state.prTotalAdditions||s.totalDeletions!==this.state.prTotalDeletions;if(this.state={...this.state,prTitle:s.title,prDraft:s.draft,prCreatedAt:s.createdAt,prChangedFiles:s.changedFiles,prTotalAdditions:s.totalAdditions,prTotalDeletions:s.totalDeletions},o||!this.state.prFiles){let d=await pCe({repository:this.state.repository,prNumber:this.state.prNumber,authInfo:this.authInfo,logger:this.logger,includeFiles:!0,maxFiles:10});this.state={...this.state,prFiles:d.files},this.logger.info(`PR files updated: ${s.changedFiles} files${s.changedFiles>10?" (showing first 10)":""}, +${s.totalAdditions} -${s.totalDeletions}`)}}catch(s){this.logError("Failed to fetch PR details",s,"warning")}if(this.notifyStateChange(),r.state==="completed"||r.state==="failed"||r.state==="cancelled"||r.state==="timed_out"){this.logger.info(`STAGE 4: PushTracking - Session ended with terminal state: ${r.state}`),this.clearPollingInterval(),setTimeout(()=>this.completePushOperation(),3e3);return}let a=1e3;if(r.state==="waiting_for_user"||r.state==="idle"){l===null&&(l=Date.now());let s=Date.now()-l,o=300*1e3,d=Math.floor(s/o);a=Math.min(5e3+d*5e3,3e4)}else l=null;if(a!==e){let s=e;e=a,this.clearPollingInterval(),this.pollingIntervalId=setInterval(()=>void n(),e),this.logger.info(`Polling interval adjusted: ${s}ms \u2192 ${e}ms (state: ${r.state})`)}}catch(r){this.clearPollingInterval(),this.setError(r,"Error polling session status")}};this.pollingIntervalId=setInterval(()=>void n(),e),n()}completePushOperation(){this.clearPollingInterval(),this.logger.info("STAGE 5: Complete - Push operation completed"),this.state&&(this.logger.startGroup("Push Operation Summary"),this.state.jobId&&this.logger.info(`Job ID: ${this.state.jobId}`),this.state.sessionId&&this.logger.info(`Session ID: ${this.state.sessionId}`),this.state.prNumber&&this.logger.info(`PR #${this.state.prNumber}: ${this.state.prUrl||"N/A"}`),this.state.commitHash&&this.logger.info(`Commit: ${this.state.commitHash}`),this.state.asyncBranch&&this.logger.info(`Branch: ${this.state.asyncBranch}`),this.state.sessionState&&this.logger.info(`Final session state: ${this.state.sessionState}`),this.logger.endGroup()),this.timeoutId&&clearTimeout(this.timeoutId),this.timeoutId=setTimeout(()=>{this.timeoutId=null,this.logger.info("Remote push workflow finished - Cleaning up"),this.onSessionCompleteCallback?this.onSessionCompleteCallback():(this.state=null,this.notifyStateChange())},3e3)}buildOperationsList(){if(!this.state)return[];let e=[];return this.state.hasUncommittedChanges&&e.push({id:"commit",status:"pending"}),e.push({id:"create-branch",status:"pending"},{id:"start-job",status:"pending"},{id:"check-job",status:"pending"},{id:"wait-for-session",status:"pending"}),e}updateOperationStatus(e,l,n){if(!this.state||!this.state.operations)return;let r=this.state.operations.map(I=>I.id===e?{...I,status:l,...n?{error:n}:{}}:I);this.state={...this.state,operations:r},this.notifyStateChange()}allOperationsComplete(){return!this.state||!this.state.operations?!0:this.state.operations.every(e=>e.status==="done"||e.status==="error")}setError(e,l){this.state&&(this.logError(l||"Operation failed",e,"error"),this.state={...this.state,error:e,isLoading:!1},this.notifyStateChange())}notifyStateChange(){this.onStateChangeCallback?.(this.state)}clearPollingInterval(){this.pollingIntervalId&&(clearInterval(this.pollingIntervalId),this.pollingIntervalId=null)}logError(e,l,n="error"){if(l instanceof l7){let r=l.responseBody?` | Response: ${JSON.stringify(l.responseBody)}`:"",I=`${e} - API error - Status: ${l.status} | Message: ${l.message}${r}`;n==="error"?this.logger.error(I):this.logger.warning(I)}else{let r=`${e}: ${l instanceof Error?l.message:String(l)}`;n==="error"?this.logger.error(r):this.logger.warning(r)}}};c();var n7=class{turnStartTimes=new Map;turnModelCallTimes=new Map;turnToolExecutionTimes=new Map;turnToolCallCounts=new Map;startTurn(e,l){this.turnStartTimes.set(e,l),this.turnModelCallTimes.set(e,{}),this.turnToolExecutionTimes.set(e,0),this.turnToolCallCounts.set(e,0)}recordModelCall(e,l){let n=this.turnModelCallTimes.get(e)||{};n.duration=l,this.turnModelCallTimes.set(e,n)}recordToolExecution(e,l){let n=this.turnToolExecutionTimes.get(e)||0;this.turnToolExecutionTimes.set(e,n+l);let r=this.turnToolCallCounts.get(e)||0;this.turnToolCallCounts.set(e,r+1)}finishTurn(e,l){let n=this.turnStartTimes.get(e);if(n===void 0)return this.cleanup(e),null;let r=l-n,I=this.turnModelCallTimes.get(e)||{},a=this.turnToolExecutionTimes.get(e)||0,s=this.turnToolCallCounts.get(e)||0,o=I.duration||0,d={totalDurationMs:r,llmDurationMs:o,toolExecutionMs:a,toolCallCount:s,totalDurationSeconds:(r/1e3).toFixed(2),llmDurationSeconds:(o/1e3).toFixed(2),toolExecutionSeconds:(a/1e3).toFixed(2)};return this.cleanup(e),d}cleanup(e){this.turnStartTimes.delete(e),this.turnModelCallTimes.delete(e),this.turnToolExecutionTimes.delete(e),this.turnToolCallCounts.delete(e)}static formatTimingBreakdown(e){return`LLM: ${e.llmDurationSeconds}s | Tools: ${e.toolExecutionSeconds}s (${e.toolCallCount} calls) | Total: ${e.totalDurationSeconds}s`}};c();var mPn="You are not licensed to use Copilot.",bPn="You are not authorized to use this Copilot feature, it requires an enterprise or organization policy to be enabled.",GPn="The provided personal access token (PAT) does not have Copilot Requests permission. Please generate a new Fine-Grained Access Token with Copilot Requests permission (not a Classic token), or log in using /login";function llt(t){return t.includes("not licensed to use Copilot")?{kind:"not-licensed",message:mPn}:t.includes("not authorized to use this Copilot feature")?{kind:"not-authorized",message:bPn}:t.includes("Personal Access Token does not have Copilot Requests")?{kind:"not-authorized",message:GPn}:null}c();import{promises as pPn}from"fs";import nlt from"path";function hPn(t){let e=[],l=/(?<![a-zA-Z0-9])(@[^\s@]+)/g,n;for(;(n=l.exec(t))!==null;)e.push({displayText:n[1],startIndex:n.index,endIndex:n.index+n[0].length});return e}async function APn(t){try{let e=await pPn.stat(t);return e.isDirectory()?"directory":e.isFile()?lse(nlt.basename(t))?"image":"file":null}catch{return null}}async function ZPn(t,e=new Map,l=process.cwd()){let n=hPn(t),r=[];for(let I of n){let a=e.get(I.startIndex);if(a?.startIndex===I.startIndex)r.push(a);else{let s=I.displayText.slice(1).replace(/[.,;:!?]+$/,""),o=nlt.isAbsolute(s)?s:nlt.resolve(l,s),d=await APn(o);if(d===null)continue;r.push({displayText:I.displayText,fullPath:o,type:d,startIndex:I.startIndex})}}return r}async function ful(t,e=new Map,l=process.cwd(),n){let r=await ZPn(t,e,l);return n.debug(`Detected mentions: ${r.map(I=>`${I.displayText} (${I.type})`).join(", ")}`),r.map(I=>({type:I.type==="image"?"file":I.type,path:I.fullPath,displayName:I.displayText,mentionIndex:I.startIndex}))}c();var ACe=nt(qt(),1);c();import{EventEmitter as slt}from"node:events";var rlt=class extends slt{get columns(){return 100}frames=[];_lastFrame;write=e=>{this.frames.push(e),this._lastFrame=e};lastFrame=()=>this._lastFrame},Ilt=class extends slt{frames=[];_lastFrame;write=e=>{this.frames.push(e),this._lastFrame=e};lastFrame=()=>this._lastFrame},alt=class extends slt{isTTY=!0;data=null;constructor(e={}){super(),this.isTTY=e.isTTY??!0}write=e=>{this.data=e,this.emit("readable"),this.emit("data",e)};setEncoding(){}setRawMode(){}resume(){}pause(){}ref(){}unref(){}read=()=>{let{data:e}=this;return this.data=null,e}},gPn=[],Hul=t=>{let e=new rlt,l=new Ilt,n=new alt,r=oee(t,{stdout:e,stderr:l,stdin:n,debug:!0,exitOnCtrlC:!1,patchConsole:!1});return gPn.push(r),{rerender:r.rerender,unmount:r.unmount,cleanup:r.cleanup,stdout:e,stderr:l,stdin:n,frames:e.frames,lastFrame:e.lastFrame}};function Xul(t,e=!1){let l=ACe.default.createElement(WQe,{logger:new Hc,children:ACe.default.createElement(YQe,{mode:"non-interactive",children:ACe.default.createElement(Yme,{entry:t,expand:e})})}),{lastFrame:n}=Hul(l),r=n();return r?r.trim():""}var kul=1,olt=!1;function yPn(t){olt=t}var zw=!1,ZCe=[],Oh=null,yT=!1;async function Lul(){if(zw||ZCe.length===0)return;zw=!0;let{integrationId:t,messageContent:e,permissionService:l,authInfo:n,resolve:r,reject:I,completePendingToolCall:a,setQuotaSnapshots:s,setContextWindowMetrics:o,setStreamingResponseSize:d,session:u,logger:b,pathManager:p,cliModel:h,enableStreaming:Z,trajectoryOutputFile:N,mcpHost:y,showLlmTiming:Y,timingTracker:w,noCustomInstructions:H,setAvailableTools:J,customAgentPrompt:S,modelList:T,disableParallelToolsExecution:U}=ZCe.shift();try{let j=await RPn(t,e,l,n,a,s,o,d,u,b,p,h,Z,N,y,Y,w,H,J,S,T,U);r(j)}catch(j){j&&typeof j=="object"&&"name"in j&&j.name==="AbortError"||j&&typeof j=="object"&&"message"in j&&typeof j.message=="string"&&j.message.includes("Operation was cancelled")?r("Operation cancelled"):I(j)}finally{zw=!1,ZCe.length>0&&setTimeout(()=>void Lul(),100)}}var EPn=TAt(c0);async function RPn(t,e,l,n,r,I,a,s,o,d,u,b,p,h,Z,N,y,Y,w,H,J,S){Oh=new AbortController,WPn(0,Oh.signal),s(0);try{let T=await Lr.load()||{},U=await jW(n),j=T.copilot_url;!j&&U&&n.type!=="hmac"&&(j=await EPn(n.host,U)),es.env.GITHUB_COPILOT_CLI_MODE="true";let O={problemStatement:e,logger:d,saveTrajectoryOutput:h||void 0,apiCopilotIntegrationId:t,apiCopilotHmacKey:n.type==="hmac"?n.hmac:void 0,apiCopilotUrl:j,apiCopilotToken:U,serviceInstanceId:o.sessionId,mcpHost:Z,saveEventLogs:es.env.COPILOT_EVENTS_LOG_DIRECTORY},z=IL()&&es.env.COPILOT_AGENT_MODEL?es.env.COPILOT_AGENT_MODEL:`sweagent-capi:${b}`,se={...O,pathManager:u,serviceAgentModel:z,requestPermission:l.request,onToolPartialOutput:(ue,We)=>{o.addEvent({type:"tool.execution_partial_result",ephemeral:!0,data:{toolCallId:ue,partialOutput:We}})},showEvents:!0,showSessionLog:!1,useSessionLogOnly:!1,abortSignal:Oh.signal,executeToolsInParallel:!S};try{let ue=await iFe.createFromOptions(se);w&&w(ue.getAvailableTools());let We=await If(es.cwd());We.found&&!Y&&await eTe(We.gitRoot,!0,es.cwd());let ee=ue.getAgentKind(),M=ue.getModel(),be=Yje()[ee]?.[M]??Rje(),ae=ue.getToolConfig?.call(ue)??{},Re=be.supports||{},Ge=await ZTe(We.found?We.gitRoot:"",Bce(),es.cwd(),{},Re,ae,ue.getAvailableTools(),void 0,Y),ve=new dFe(o,s,olt,d),Ae=await o.getChatContextMessages(),Ee=Ae.findLastIndex(dl=>dl.role==="user"),Ie=Ae[Ee];typeof Ie.content=="string"?Ie={...Ie,content:_ye({customAgentPrompt:H,problemStatement:Ie.content,capabilities:Re})}:Ie={...Ie,content:Ie.content.map(dl=>dl.type==="text"?{...dl,text:_ye({customAgentPrompt:H,problemStatement:dl.text,capabilities:Re})}:dl)};let Me=new PS(Ie,d),Je=new jK(d),$t=ue.getCompletionWithTools(Ge,Ae.map((dl,Ke)=>Ke===Ee?Ie:dl),{stream:p,failIfInitialInputsTooLong:!1,processors:{preRequest:[Me,new jye,Je],onRequestError:[Me],onStreamingChunk:[ve]},executeToolsInParallel:!S,abortSignal:Oh.signal});for await(let dl of $t){if(Oh?.signal.aborted){let Ke=new Error("Operation was cancelled");throw Ke.name="AbortError",Ke}await vBt(dl,{onImageProcessingEvent:Ke=>{},onImageRemovalEvent:Ke=>{},onMessage:Ke=>{if(B9(Ke)){let Lt=ve.endCurrentStreamingMessage(),st=typeof Ke.message.content=="string"?Ke.message.content:null,Bt=Pce(Ke)?Ke.message.tool_calls.map(zt=>({toolCallId:zt.id,name:zt.function.name,arguments:W9(zt.function.arguments)})):[];o.addEvent({type:"assistant.message",data:{messageId:Lt??Bu(),content:st||"",toolRequests:Bt}});for(let zt of Bt)o.addEvent({type:"tool.execution_start",data:{toolCallId:zt.toolCallId,toolName:zt.name,arguments:zt.arguments}})}else(Ke.message.role==="system"||Ke.message.role==="developer")&&o.addEvent({type:"system.message",data:{role:Ke.message.role,content:typeof Ke.message.content=="string"?Ke.message.content:JSON.stringify(Ke.message.content),name:"name"in Ke.message?Ke.message.name:void 0}})},onResponse:Ke=>{},onModelCallFailure:Ke=>{if(llt(Ke.modelCall?.error||""))return;let st=Ke.modelCall?.error||"Unknown error occurred";Ke.modelCall.request_id&&(st+=` (Request ID: ${Ke.modelCall.request_id})`),o.addEvent({type:"session.error",data:{errorType:"model_call",message:`Model call failed: ${st}`}})},onModelCallSuccess:async Ke=>{I(Ke.quotaSnapshots||{});let Lt=Ke.responseChunk.model||await o.getSelectedModel(),st=Ke.modelCallDurationMs||0,Bt=Ke.responseUsage,zt=Lt?L8(Lt,J):1;o.addEvent({type:"assistant.usage",ephemeral:!0,data:{model:Lt||"unknown",tokensUsed:Bt?.total_tokens||0,cost:zt,duration:st,initiator:Ke.modelCall?.initiator}}),N&&y&&y.recordModelCall(Ke.turn,Ke.modelCallDurationMs)},onToolExecution:Ke=>{r({callId:Ke.toolCallId,resultType:Ke.toolResult.resultType,log:(Ke.toolResult.resultType==="failure"?Ke.toolResult.error:void 0)||Ke.toolResult.sessionLog||Ke.toolResult.textResultForLlm}),N&&y&&y.recordToolExecution(Ke.turn,Ke.durationMs)},onTruncationEvent:Ke=>{a(Lt=>{let st=Math.max(Lt.totalTokens,Ke.truncateResult.preTruncationTokensInMessages);return{...Lt,totalTokens:st,postTruncationTokens:Ke.truncateResult.postTruncationTokensInMessages,tokenLimit:Ke.truncateResult.tokenLimit,messagesRemoved:Ke.truncateResult.messagesRemovedDuringTruncation,tokensRemoved:Ke.truncateResult.tokensRemovedDuringTruncation}})},onTurnEvent:Ke=>{if(Ke.kind==="turn_started")N&&y&&y.startTurn(Ke.turn,Ke.timestampMs);else if(Ke.kind==="turn_ended"&&N&&y){let Lt=y.finishTurn(Ke.turn,Ke.timestampMs);if(Lt){let st=n7.formatTimingBreakdown(Lt);olt?es.stdout.write(`
2417
2417
  \u{1F552} ${st}
2418
2418
 
2419
2419
  `):o.addEvent({type:"session.info",ephemeral:!0,data:{infoType:"timing",message:st}})}}}})}return await ue.shutdown(),"Command completed successfully"}catch(ue){let We=ue&&typeof ue=="object"&&"name"in ue&&ue.name==="AbortError",ee=ue&&typeof ue=="object"&&"message"in ue&&typeof ue.message=="string"&&ue.message.includes("Operation was cancelled");throw!We&&!ee&&(ue instanceof Error?d.debug(`Command threw error: ${ue.message}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@github/copilot",
3
3
  "description": "GitHub Copilot CLI brings the power of Copilot coding agent directly to your terminal.",
4
- "version": "0.0.349-6",
4
+ "version": "0.0.349-7",
5
5
  "type": "module",
6
6
  "repository": {
7
7
  "type": "git",
@@ -35,7 +35,7 @@
35
35
  "worker/**/*"
36
36
  ],
37
37
  "buildMetadata": {
38
- "gitCommit": "d6a5f03"
38
+ "gitCommit": "608635d"
39
39
  },
40
40
  "dependencies": {
41
41
  "sharp": "^0.34.3"