aicommit2 2.2.12 → 2.2.14
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.
- package/README.md +1 -2
- package/dist/cli.mjs +96 -117
- package/package.json +3 -2
package/README.md
CHANGED
|
@@ -517,7 +517,7 @@ aicommit2 config set codeReviewPromptPath="/path/to/user/prompt.txt"
|
|
|
517
517
|
| **Groq** | ✓ | ✓ | ✓ | ✓ |
|
|
518
518
|
| **Perplexity** | ✓ | ✓ | ✓ | ✓ |
|
|
519
519
|
| **DeepSeek** | ✓ | ✓ | ✓ | ✓ |
|
|
520
|
-
| **Ollama** |
|
|
520
|
+
| **Ollama** | ✓ | ✓ | | ✓ |
|
|
521
521
|
| **OpenAI API-Compatible** | ✓ | ✓ | ✓ | ✓ |
|
|
522
522
|
|
|
523
523
|
> All AI support the following options in General Settings.
|
|
@@ -895,7 +895,6 @@ aicommit2 config set OLLAMA.numCtx=4096
|
|
|
895
895
|
Ollama does not support the following options in General Settings.
|
|
896
896
|
|
|
897
897
|
- maxTokens
|
|
898
|
-
- timeout
|
|
899
898
|
|
|
900
899
|
### OpenAI API-Compatible Services
|
|
901
900
|
|
package/dist/cli.mjs
CHANGED
|
@@ -1,52 +1,32 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import st from"tty";import{createRequire as gn}from"module";import{Buffer as Cn}from"node:buffer";import ne from"node:path";import cr,{ChildProcess as yn}from"node:child_process";import z from"node:process";import En from"child_process";import k from"path";import T from"fs";import{fileURLToPath as lr}from"node:url";import Fn,{constants as Dr}from"node:os";import mr from"assert";import dr from"events";import{createWriteStream as wn,createReadStream as vn}from"node:fs";import bn from"buffer";import it from"stream";import pr from"util";import{debuglog as $n}from"node:util";import Pe from"inquirer";import at from"ora";import C from"chalk";import{of as O,concatMap as A,from as v,map as b,catchError as $,mergeMap as Be,BehaviorSubject as fr,ReplaySubject as An,lastValueFrom as hr,filter as gr,toArray as Cr,Subject as yr}from"rxjs";import Pn from"@anthropic-ai/sdk";import{fromPromise as P}from"rxjs/internal/observable/innerFrom";import ut from"os";import{xxh64 as Bn}from"@pacote/xxhash";import xn from"axios";import{CohereClient as Mn,CohereTimeoutError as Sn}from"cohere-ai";import xe from"openai";import{GoogleGenerativeAI as Rn,HarmCategory as Me,HarmBlockThreshold as Se}from"@google/generative-ai";import Er from"groq-sdk";import On from"node-fetch";import{Ollama as In}from"ollama";import M from"fs/promises";import kn from"http";import Ln from"https";import Tn from"net";import Nn from"tls";import _n,{fileURLToPath as jn,pathToFileURL as Gn}from"url";import Re from"readline";import Hn from"figlet";import Un from"inquirer-reactive-list-prompt";import{rm as qn}from"node:fs/promises";import zn from"chokidar";import{takeUntil as Wn}from"rxjs/operators";const Kn="known-flag",Jn="unknown-flag",Vn="argument",{stringify:de}=JSON,Yn=/\B([A-Z])/g,Xn=t=>t.replace(Yn,"-$1").toLowerCase(),{hasOwnProperty:Zn}=Object.prototype,pe=(t,e)=>Zn.call(t,e),Qn=t=>Array.isArray(t),Fr=t=>typeof t=="function"?[t,!1]:Qn(t)?[t[0],!0]:Fr(t.type),es=(t,e)=>t===Boolean?e!=="false":e,ts=(t,e)=>typeof e=="boolean"?e:t===Number&&e===""?Number.NaN:t(e),rs=/[\s.:=]/,os=t=>{const e=`Flag name ${de(t)}`;if(t.length===0)throw new Error(`${e} cannot be empty`);if(t.length===1)throw new Error(`${e} must be longer than a character`);const r=t.match(rs);if(r)throw new Error(`${e} cannot contain ${de(r?.[0])}`)},ns=t=>{const e={},r=(o,n)=>{if(pe(e,o))throw new Error(`Duplicate flags named ${de(o)}`);e[o]=n};for(const o in t){if(!pe(t,o))continue;os(o);const n=t[o],s=[[],...Fr(n),n];r(o,s);const i=Xn(o);if(o!==i&&r(i,s),"alias"in n&&typeof n.alias=="string"){const{alias:u}=n,a=`Flag alias ${de(u)} for flag ${de(o)}`;if(u.length===0)throw new Error(`${a} cannot be empty`);if(u.length>1)throw new Error(`${a} must be a single character`);r(u,s)}}return e},ss=(t,e)=>{const r={};for(const o in t){if(!pe(t,o))continue;const[n,,s,i]=e[o];if(n.length===0&&"default"in i){let{default:u}=i;typeof u=="function"&&(u=u()),r[o]=u}else r[o]=s?n:n.pop()}return r},Oe="--",is=/[.:=]/,as=/^-{1,2}\w/,us=t=>{if(!as.test(t))return;const e=!t.startsWith(Oe);let r=t.slice(e?1:2),o;const n=r.match(is);if(n){const{index:s}=n;o=r.slice(s+1),r=r.slice(0,s)}return[r,o,e]},cs=(t,{onFlag:e,onArgument:r})=>{let o;const n=(s,i)=>{if(typeof o!="function")return!0;o(s,i),o=void 0};for(let s=0;s<t.length;s+=1){const i=t[s];if(i===Oe){n();const a=t.slice(s+1);r?.(a,[s],!0);break}const u=us(i);if(u){if(n(),!e)continue;const[a,l,m]=u;if(m)for(let c=0;c<a.length;c+=1){n();const D=c===a.length-1;o=e(a[c],D?l:void 0,[s,c+1,D])}else o=e(a,l,[s])}else n(i,[s])&&r?.([i],[s])}n()},ls=(t,e)=>{for(const[r,o,n]of e.reverse()){if(o){const s=t[r];let i=s.slice(0,o);if(n||(i+=s.slice(o+1)),i!=="-"){t[r]=i;continue}}t.splice(r,1)}},Ds=(t,e=process.argv.slice(2),{ignore:r}={})=>{const o=[],n=ns(t),s={},i=[];return i[Oe]=[],cs(e,{onFlag(u,a,l){const m=pe(n,u);if(!r?.(m?Kn:Jn,u,a)){if(m){const[c,D]=n[u],d=es(D,a),f=(h,g)=>{o.push(l),g&&o.push(g),c.push(ts(D,h||""))};return d===void 0?f:f(d)}pe(s,u)||(s[u]=[]),s[u].push(a===void 0?!0:a),o.push(l)}},onArgument(u,a,l){r?.(Vn,e[a[0]])||(i.push(...u),l?(i[Oe]=u,e.splice(a[0])):o.push(a))}}),ls(e,o),{flags:ss(t,n),unknownFlags:s,_:i}};var ms=Object.create,Ie=Object.defineProperty,ds=Object.defineProperties,ps=Object.getOwnPropertyDescriptor,fs=Object.getOwnPropertyDescriptors,hs=Object.getOwnPropertyNames,wr=Object.getOwnPropertySymbols,gs=Object.getPrototypeOf,vr=Object.prototype.hasOwnProperty,Cs=Object.prototype.propertyIsEnumerable,br=(t,e,r)=>e in t?Ie(t,e,{enumerable:!0,configurable:!0,writable:!0,value:r}):t[e]=r,ke=(t,e)=>{for(var r in e||(e={}))vr.call(e,r)&&br(t,r,e[r]);if(wr)for(var r of wr(e))Cs.call(e,r)&&br(t,r,e[r]);return t},ct=(t,e)=>ds(t,fs(e)),ys=t=>Ie(t,"__esModule",{value:!0}),Es=(t,e)=>()=>(t&&(e=t(t=0)),e),Fs=(t,e)=>()=>(e||t((e={exports:{}}).exports,e),e.exports),ws=(t,e,r,o)=>{if(e&&typeof e=="object"||typeof e=="function")for(let n of hs(e))!vr.call(t,n)&&(r||n!=="default")&&Ie(t,n,{get:()=>e[n],enumerable:!(o=ps(e,n))||o.enumerable});return t},vs=(t,e)=>ws(ys(Ie(t!=null?ms(gs(t)):{},"default",!e&&t&&t.__esModule?{get:()=>t.default,enumerable:!0}:{value:t,enumerable:!0})),t),N=Es(()=>{}),bs=Fs((t,e)=>{N(),e.exports=function(){return/\uD83C\uDFF4\uDB40\uDC67\uDB40\uDC62(?:\uDB40\uDC77\uDB40\uDC6C\uDB40\uDC73|\uDB40\uDC73\uDB40\uDC63\uDB40\uDC74|\uDB40\uDC65\uDB40\uDC6E\uDB40\uDC67)\uDB40\uDC7F|(?:\uD83E\uDDD1\uD83C\uDFFF\u200D\u2764\uFE0F\u200D(?:\uD83D\uDC8B\u200D)?\uD83E\uDDD1|\uD83D\uDC69\uD83C\uDFFF\u200D\uD83E\uDD1D\u200D(?:\uD83D[\uDC68\uDC69]))(?:\uD83C[\uDFFB-\uDFFE])|(?:\uD83E\uDDD1\uD83C\uDFFE\u200D\u2764\uFE0F\u200D(?:\uD83D\uDC8B\u200D)?\uD83E\uDDD1|\uD83D\uDC69\uD83C\uDFFE\u200D\uD83E\uDD1D\u200D(?:\uD83D[\uDC68\uDC69]))(?:\uD83C[\uDFFB-\uDFFD\uDFFF])|(?:\uD83E\uDDD1\uD83C\uDFFD\u200D\u2764\uFE0F\u200D(?:\uD83D\uDC8B\u200D)?\uD83E\uDDD1|\uD83D\uDC69\uD83C\uDFFD\u200D\uD83E\uDD1D\u200D(?:\uD83D[\uDC68\uDC69]))(?:\uD83C[\uDFFB\uDFFC\uDFFE\uDFFF])|(?:\uD83E\uDDD1\uD83C\uDFFC\u200D\u2764\uFE0F\u200D(?:\uD83D\uDC8B\u200D)?\uD83E\uDDD1|\uD83D\uDC69\uD83C\uDFFC\u200D\uD83E\uDD1D\u200D(?:\uD83D[\uDC68\uDC69]))(?:\uD83C[\uDFFB\uDFFD-\uDFFF])|(?:\uD83E\uDDD1\uD83C\uDFFB\u200D\u2764\uFE0F\u200D(?:\uD83D\uDC8B\u200D)?\uD83E\uDDD1|\uD83D\uDC69\uD83C\uDFFB\u200D\uD83E\uDD1D\u200D(?:\uD83D[\uDC68\uDC69]))(?:\uD83C[\uDFFC-\uDFFF])|\uD83D\uDC68(?:\uD83C\uDFFB(?:\u200D(?:\u2764\uFE0F\u200D(?:\uD83D\uDC8B\u200D\uD83D\uDC68(?:\uD83C[\uDFFB-\uDFFF])|\uD83D\uDC68(?:\uD83C[\uDFFB-\uDFFF]))|\uD83E\uDD1D\u200D\uD83D\uDC68(?:\uD83C[\uDFFC-\uDFFF])|[\u2695\u2696\u2708]\uFE0F|\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD]))?|(?:\uD83C[\uDFFC-\uDFFF])\u200D\u2764\uFE0F\u200D(?:\uD83D\uDC8B\u200D\uD83D\uDC68(?:\uD83C[\uDFFB-\uDFFF])|\uD83D\uDC68(?:\uD83C[\uDFFB-\uDFFF]))|\u200D(?:\u2764\uFE0F\u200D(?:\uD83D\uDC8B\u200D)?\uD83D\uDC68|(?:\uD83D[\uDC68\uDC69])\u200D(?:\uD83D\uDC66\u200D\uD83D\uDC66|\uD83D\uDC67\u200D(?:\uD83D[\uDC66\uDC67]))|\uD83D\uDC66\u200D\uD83D\uDC66|\uD83D\uDC67\u200D(?:\uD83D[\uDC66\uDC67])|\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFF\u200D(?:\uD83E\uDD1D\u200D\uD83D\uDC68(?:\uD83C[\uDFFB-\uDFFE])|\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFE\u200D(?:\uD83E\uDD1D\u200D\uD83D\uDC68(?:\uD83C[\uDFFB-\uDFFD\uDFFF])|\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFD\u200D(?:\uD83E\uDD1D\u200D\uD83D\uDC68(?:\uD83C[\uDFFB\uDFFC\uDFFE\uDFFF])|\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFC\u200D(?:\uD83E\uDD1D\u200D\uD83D\uDC68(?:\uD83C[\uDFFB\uDFFD-\uDFFF])|\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|(?:\uD83C\uDFFF\u200D[\u2695\u2696\u2708]|\uD83C\uDFFE\u200D[\u2695\u2696\u2708]|\uD83C\uDFFD\u200D[\u2695\u2696\u2708]|\uD83C\uDFFC\u200D[\u2695\u2696\u2708]|\u200D[\u2695\u2696\u2708])\uFE0F|\u200D(?:(?:\uD83D[\uDC68\uDC69])\u200D(?:\uD83D[\uDC66\uDC67])|\uD83D[\uDC66\uDC67])|\uD83C\uDFFF|\uD83C\uDFFE|\uD83C\uDFFD|\uD83C\uDFFC)?|(?:\uD83D\uDC69(?:\uD83C\uDFFB\u200D\u2764\uFE0F\u200D(?:\uD83D\uDC8B\u200D(?:\uD83D[\uDC68\uDC69])|\uD83D[\uDC68\uDC69])|(?:\uD83C[\uDFFC-\uDFFF])\u200D\u2764\uFE0F\u200D(?:\uD83D\uDC8B\u200D(?:\uD83D[\uDC68\uDC69])|\uD83D[\uDC68\uDC69]))|\uD83E\uDDD1(?:\uD83C[\uDFFB-\uDFFF])\u200D\uD83E\uDD1D\u200D\uD83E\uDDD1)(?:\uD83C[\uDFFB-\uDFFF])|\uD83D\uDC69\u200D\uD83D\uDC69\u200D(?:\uD83D\uDC66\u200D\uD83D\uDC66|\uD83D\uDC67\u200D(?:\uD83D[\uDC66\uDC67]))|\uD83D\uDC69(?:\u200D(?:\u2764\uFE0F\u200D(?:\uD83D\uDC8B\u200D(?:\uD83D[\uDC68\uDC69])|\uD83D[\uDC68\uDC69])|\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFF\u200D(?:\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFE\u200D(?:\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFD\u200D(?:\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFC\u200D(?:\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFB\u200D(?:\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD]))|\uD83E\uDDD1(?:\u200D(?:\uD83E\uDD1D\u200D\uD83E\uDDD1|\uD83C[\uDF3E\uDF73\uDF7C\uDF84\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFF\u200D(?:\uD83C[\uDF3E\uDF73\uDF7C\uDF84\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFE\u200D(?:\uD83C[\uDF3E\uDF73\uDF7C\uDF84\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFD\u200D(?:\uD83C[\uDF3E\uDF73\uDF7C\uDF84\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFC\u200D(?:\uD83C[\uDF3E\uDF73\uDF7C\uDF84\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFB\u200D(?:\uD83C[\uDF3E\uDF73\uDF7C\uDF84\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD]))|\uD83D\uDC69\u200D\uD83D\uDC66\u200D\uD83D\uDC66|\uD83D\uDC69\u200D\uD83D\uDC69\u200D(?:\uD83D[\uDC66\uDC67])|\uD83D\uDC69\u200D\uD83D\uDC67\u200D(?:\uD83D[\uDC66\uDC67])|(?:\uD83D\uDC41\uFE0F\u200D\uD83D\uDDE8|\uD83E\uDDD1(?:\uD83C\uDFFF\u200D[\u2695\u2696\u2708]|\uD83C\uDFFE\u200D[\u2695\u2696\u2708]|\uD83C\uDFFD\u200D[\u2695\u2696\u2708]|\uD83C\uDFFC\u200D[\u2695\u2696\u2708]|\uD83C\uDFFB\u200D[\u2695\u2696\u2708]|\u200D[\u2695\u2696\u2708])|\uD83D\uDC69(?:\uD83C\uDFFF\u200D[\u2695\u2696\u2708]|\uD83C\uDFFE\u200D[\u2695\u2696\u2708]|\uD83C\uDFFD\u200D[\u2695\u2696\u2708]|\uD83C\uDFFC\u200D[\u2695\u2696\u2708]|\uD83C\uDFFB\u200D[\u2695\u2696\u2708]|\u200D[\u2695\u2696\u2708])|\uD83D\uDE36\u200D\uD83C\uDF2B|\uD83C\uDFF3\uFE0F\u200D\u26A7|\uD83D\uDC3B\u200D\u2744|(?:(?:\uD83C[\uDFC3\uDFC4\uDFCA]|\uD83D[\uDC6E\uDC70\uDC71\uDC73\uDC77\uDC81\uDC82\uDC86\uDC87\uDE45-\uDE47\uDE4B\uDE4D\uDE4E\uDEA3\uDEB4-\uDEB6]|\uD83E[\uDD26\uDD35\uDD37-\uDD39\uDD3D\uDD3E\uDDB8\uDDB9\uDDCD-\uDDCF\uDDD4\uDDD6-\uDDDD])(?:\uD83C[\uDFFB-\uDFFF])|\uD83D\uDC6F|\uD83E[\uDD3C\uDDDE\uDDDF])\u200D[\u2640\u2642]|(?:\u26F9|\uD83C[\uDFCB\uDFCC]|\uD83D\uDD75)(?:\uFE0F|\uD83C[\uDFFB-\uDFFF])\u200D[\u2640\u2642]|\uD83C\uDFF4\u200D\u2620|(?:\uD83C[\uDFC3\uDFC4\uDFCA]|\uD83D[\uDC6E\uDC70\uDC71\uDC73\uDC77\uDC81\uDC82\uDC86\uDC87\uDE45-\uDE47\uDE4B\uDE4D\uDE4E\uDEA3\uDEB4-\uDEB6]|\uD83E[\uDD26\uDD35\uDD37-\uDD39\uDD3D\uDD3E\uDDB8\uDDB9\uDDCD-\uDDCF\uDDD4\uDDD6-\uDDDD])\u200D[\u2640\u2642]|[\xA9\xAE\u203C\u2049\u2122\u2139\u2194-\u2199\u21A9\u21AA\u2328\u23CF\u23ED-\u23EF\u23F1\u23F2\u23F8-\u23FA\u24C2\u25AA\u25AB\u25B6\u25C0\u25FB\u25FC\u2600-\u2604\u260E\u2611\u2618\u2620\u2622\u2623\u2626\u262A\u262E\u262F\u2638-\u263A\u2640\u2642\u265F\u2660\u2663\u2665\u2666\u2668\u267B\u267E\u2692\u2694-\u2697\u2699\u269B\u269C\u26A0\u26A7\u26B0\u26B1\u26C8\u26CF\u26D1\u26D3\u26E9\u26F0\u26F1\u26F4\u26F7\u26F8\u2702\u2708\u2709\u270F\u2712\u2714\u2716\u271D\u2721\u2733\u2734\u2744\u2747\u2763\u27A1\u2934\u2935\u2B05-\u2B07\u3030\u303D\u3297\u3299]|\uD83C[\uDD70\uDD71\uDD7E\uDD7F\uDE02\uDE37\uDF21\uDF24-\uDF2C\uDF36\uDF7D\uDF96\uDF97\uDF99-\uDF9B\uDF9E\uDF9F\uDFCD\uDFCE\uDFD4-\uDFDF\uDFF5\uDFF7]|\uD83D[\uDC3F\uDCFD\uDD49\uDD4A\uDD6F\uDD70\uDD73\uDD76-\uDD79\uDD87\uDD8A-\uDD8D\uDDA5\uDDA8\uDDB1\uDDB2\uDDBC\uDDC2-\uDDC4\uDDD1-\uDDD3\uDDDC-\uDDDE\uDDE1\uDDE3\uDDE8\uDDEF\uDDF3\uDDFA\uDECB\uDECD-\uDECF\uDEE0-\uDEE5\uDEE9\uDEF0\uDEF3])\uFE0F|\uD83C\uDFF3\uFE0F\u200D\uD83C\uDF08|\uD83D\uDC69\u200D\uD83D\uDC67|\uD83D\uDC69\u200D\uD83D\uDC66|\uD83D\uDE35\u200D\uD83D\uDCAB|\uD83D\uDE2E\u200D\uD83D\uDCA8|\uD83D\uDC15\u200D\uD83E\uDDBA|\uD83E\uDDD1(?:\uD83C\uDFFF|\uD83C\uDFFE|\uD83C\uDFFD|\uD83C\uDFFC|\uD83C\uDFFB)?|\uD83D\uDC69(?:\uD83C\uDFFF|\uD83C\uDFFE|\uD83C\uDFFD|\uD83C\uDFFC|\uD83C\uDFFB)?|\uD83C\uDDFD\uD83C\uDDF0|\uD83C\uDDF6\uD83C\uDDE6|\uD83C\uDDF4\uD83C\uDDF2|\uD83D\uDC08\u200D\u2B1B|\u2764\uFE0F\u200D(?:\uD83D\uDD25|\uD83E\uDE79)|\uD83D\uDC41\uFE0F|\uD83C\uDFF3\uFE0F|\uD83C\uDDFF(?:\uD83C[\uDDE6\uDDF2\uDDFC])|\uD83C\uDDFE(?:\uD83C[\uDDEA\uDDF9])|\uD83C\uDDFC(?:\uD83C[\uDDEB\uDDF8])|\uD83C\uDDFB(?:\uD83C[\uDDE6\uDDE8\uDDEA\uDDEC\uDDEE\uDDF3\uDDFA])|\uD83C\uDDFA(?:\uD83C[\uDDE6\uDDEC\uDDF2\uDDF3\uDDF8\uDDFE\uDDFF])|\uD83C\uDDF9(?:\uD83C[\uDDE6\uDDE8\uDDE9\uDDEB-\uDDED\uDDEF-\uDDF4\uDDF7\uDDF9\uDDFB\uDDFC\uDDFF])|\uD83C\uDDF8(?:\uD83C[\uDDE6-\uDDEA\uDDEC-\uDDF4\uDDF7-\uDDF9\uDDFB\uDDFD-\uDDFF])|\uD83C\uDDF7(?:\uD83C[\uDDEA\uDDF4\uDDF8\uDDFA\uDDFC])|\uD83C\uDDF5(?:\uD83C[\uDDE6\uDDEA-\uDDED\uDDF0-\uDDF3\uDDF7-\uDDF9\uDDFC\uDDFE])|\uD83C\uDDF3(?:\uD83C[\uDDE6\uDDE8\uDDEA-\uDDEC\uDDEE\uDDF1\uDDF4\uDDF5\uDDF7\uDDFA\uDDFF])|\uD83C\uDDF2(?:\uD83C[\uDDE6\uDDE8-\uDDED\uDDF0-\uDDFF])|\uD83C\uDDF1(?:\uD83C[\uDDE6-\uDDE8\uDDEE\uDDF0\uDDF7-\uDDFB\uDDFE])|\uD83C\uDDF0(?:\uD83C[\uDDEA\uDDEC-\uDDEE\uDDF2\uDDF3\uDDF5\uDDF7\uDDFC\uDDFE\uDDFF])|\uD83C\uDDEF(?:\uD83C[\uDDEA\uDDF2\uDDF4\uDDF5])|\uD83C\uDDEE(?:\uD83C[\uDDE8-\uDDEA\uDDF1-\uDDF4\uDDF6-\uDDF9])|\uD83C\uDDED(?:\uD83C[\uDDF0\uDDF2\uDDF3\uDDF7\uDDF9\uDDFA])|\uD83C\uDDEC(?:\uD83C[\uDDE6\uDDE7\uDDE9-\uDDEE\uDDF1-\uDDF3\uDDF5-\uDDFA\uDDFC\uDDFE])|\uD83C\uDDEB(?:\uD83C[\uDDEE-\uDDF0\uDDF2\uDDF4\uDDF7])|\uD83C\uDDEA(?:\uD83C[\uDDE6\uDDE8\uDDEA\uDDEC\uDDED\uDDF7-\uDDFA])|\uD83C\uDDE9(?:\uD83C[\uDDEA\uDDEC\uDDEF\uDDF0\uDDF2\uDDF4\uDDFF])|\uD83C\uDDE8(?:\uD83C[\uDDE6\uDDE8\uDDE9\uDDEB-\uDDEE\uDDF0-\uDDF5\uDDF7\uDDFA-\uDDFF])|\uD83C\uDDE7(?:\uD83C[\uDDE6\uDDE7\uDDE9-\uDDEF\uDDF1-\uDDF4\uDDF6-\uDDF9\uDDFB\uDDFC\uDDFE\uDDFF])|\uD83C\uDDE6(?:\uD83C[\uDDE8-\uDDEC\uDDEE\uDDF1\uDDF2\uDDF4\uDDF6-\uDDFA\uDDFC\uDDFD\uDDFF])|[#\*0-9]\uFE0F\u20E3|\u2764\uFE0F|(?:\uD83C[\uDFC3\uDFC4\uDFCA]|\uD83D[\uDC6E\uDC70\uDC71\uDC73\uDC77\uDC81\uDC82\uDC86\uDC87\uDE45-\uDE47\uDE4B\uDE4D\uDE4E\uDEA3\uDEB4-\uDEB6]|\uD83E[\uDD26\uDD35\uDD37-\uDD39\uDD3D\uDD3E\uDDB8\uDDB9\uDDCD-\uDDCF\uDDD4\uDDD6-\uDDDD])(?:\uD83C[\uDFFB-\uDFFF])|(?:\u26F9|\uD83C[\uDFCB\uDFCC]|\uD83D\uDD75)(?:\uFE0F|\uD83C[\uDFFB-\uDFFF])|\uD83C\uDFF4|(?:[\u270A\u270B]|\uD83C[\uDF85\uDFC2\uDFC7]|\uD83D[\uDC42\uDC43\uDC46-\uDC50\uDC66\uDC67\uDC6B-\uDC6D\uDC72\uDC74-\uDC76\uDC78\uDC7C\uDC83\uDC85\uDC8F\uDC91\uDCAA\uDD7A\uDD95\uDD96\uDE4C\uDE4F\uDEC0\uDECC]|\uD83E[\uDD0C\uDD0F\uDD18-\uDD1C\uDD1E\uDD1F\uDD30-\uDD34\uDD36\uDD77\uDDB5\uDDB6\uDDBB\uDDD2\uDDD3\uDDD5])(?:\uD83C[\uDFFB-\uDFFF])|(?:[\u261D\u270C\u270D]|\uD83D[\uDD74\uDD90])(?:\uFE0F|\uD83C[\uDFFB-\uDFFF])|[\u270A\u270B]|\uD83C[\uDF85\uDFC2\uDFC7]|\uD83D[\uDC08\uDC15\uDC3B\uDC42\uDC43\uDC46-\uDC50\uDC66\uDC67\uDC6B-\uDC6D\uDC72\uDC74-\uDC76\uDC78\uDC7C\uDC83\uDC85\uDC8F\uDC91\uDCAA\uDD7A\uDD95\uDD96\uDE2E\uDE35\uDE36\uDE4C\uDE4F\uDEC0\uDECC]|\uD83E[\uDD0C\uDD0F\uDD18-\uDD1C\uDD1E\uDD1F\uDD30-\uDD34\uDD36\uDD77\uDDB5\uDDB6\uDDBB\uDDD2\uDDD3\uDDD5]|\uD83C[\uDFC3\uDFC4\uDFCA]|\uD83D[\uDC6E\uDC70\uDC71\uDC73\uDC77\uDC81\uDC82\uDC86\uDC87\uDE45-\uDE47\uDE4B\uDE4D\uDE4E\uDEA3\uDEB4-\uDEB6]|\uD83E[\uDD26\uDD35\uDD37-\uDD39\uDD3D\uDD3E\uDDB8\uDDB9\uDDCD-\uDDCF\uDDD4\uDDD6-\uDDDD]|\uD83D\uDC6F|\uD83E[\uDD3C\uDDDE\uDDDF]|[\u231A\u231B\u23E9-\u23EC\u23F0\u23F3\u25FD\u25FE\u2614\u2615\u2648-\u2653\u267F\u2693\u26A1\u26AA\u26AB\u26BD\u26BE\u26C4\u26C5\u26CE\u26D4\u26EA\u26F2\u26F3\u26F5\u26FA\u26FD\u2705\u2728\u274C\u274E\u2753-\u2755\u2757\u2795-\u2797\u27B0\u27BF\u2B1B\u2B1C\u2B50\u2B55]|\uD83C[\uDC04\uDCCF\uDD8E\uDD91-\uDD9A\uDE01\uDE1A\uDE2F\uDE32-\uDE36\uDE38-\uDE3A\uDE50\uDE51\uDF00-\uDF20\uDF2D-\uDF35\uDF37-\uDF7C\uDF7E-\uDF84\uDF86-\uDF93\uDFA0-\uDFC1\uDFC5\uDFC6\uDFC8\uDFC9\uDFCF-\uDFD3\uDFE0-\uDFF0\uDFF8-\uDFFF]|\uD83D[\uDC00-\uDC07\uDC09-\uDC14\uDC16-\uDC3A\uDC3C-\uDC3E\uDC40\uDC44\uDC45\uDC51-\uDC65\uDC6A\uDC79-\uDC7B\uDC7D-\uDC80\uDC84\uDC88-\uDC8E\uDC90\uDC92-\uDCA9\uDCAB-\uDCFC\uDCFF-\uDD3D\uDD4B-\uDD4E\uDD50-\uDD67\uDDA4\uDDFB-\uDE2D\uDE2F-\uDE34\uDE37-\uDE44\uDE48-\uDE4A\uDE80-\uDEA2\uDEA4-\uDEB3\uDEB7-\uDEBF\uDEC1-\uDEC5\uDED0-\uDED2\uDED5-\uDED7\uDEEB\uDEEC\uDEF4-\uDEFC\uDFE0-\uDFEB]|\uD83E[\uDD0D\uDD0E\uDD10-\uDD17\uDD1D\uDD20-\uDD25\uDD27-\uDD2F\uDD3A\uDD3F-\uDD45\uDD47-\uDD76\uDD78\uDD7A-\uDDB4\uDDB7\uDDBA\uDDBC-\uDDCB\uDDD0\uDDE0-\uDDFF\uDE70-\uDE74\uDE78-\uDE7A\uDE80-\uDE86\uDE90-\uDEA8\uDEB0-\uDEB6\uDEC0-\uDEC2\uDED0-\uDED6]|(?:[\u231A\u231B\u23E9-\u23EC\u23F0\u23F3\u25FD\u25FE\u2614\u2615\u2648-\u2653\u267F\u2693\u26A1\u26AA\u26AB\u26BD\u26BE\u26C4\u26C5\u26CE\u26D4\u26EA\u26F2\u26F3\u26F5\u26FA\u26FD\u2705\u270A\u270B\u2728\u274C\u274E\u2753-\u2755\u2757\u2795-\u2797\u27B0\u27BF\u2B1B\u2B1C\u2B50\u2B55]|\uD83C[\uDC04\uDCCF\uDD8E\uDD91-\uDD9A\uDDE6-\uDDFF\uDE01\uDE1A\uDE2F\uDE32-\uDE36\uDE38-\uDE3A\uDE50\uDE51\uDF00-\uDF20\uDF2D-\uDF35\uDF37-\uDF7C\uDF7E-\uDF93\uDFA0-\uDFCA\uDFCF-\uDFD3\uDFE0-\uDFF0\uDFF4\uDFF8-\uDFFF]|\uD83D[\uDC00-\uDC3E\uDC40\uDC42-\uDCFC\uDCFF-\uDD3D\uDD4B-\uDD4E\uDD50-\uDD67\uDD7A\uDD95\uDD96\uDDA4\uDDFB-\uDE4F\uDE80-\uDEC5\uDECC\uDED0-\uDED2\uDED5-\uDED7\uDEEB\uDEEC\uDEF4-\uDEFC\uDFE0-\uDFEB]|\uD83E[\uDD0C-\uDD3A\uDD3C-\uDD45\uDD47-\uDD78\uDD7A-\uDDCB\uDDCD-\uDDFF\uDE70-\uDE74\uDE78-\uDE7A\uDE80-\uDE86\uDE90-\uDEA8\uDEB0-\uDEB6\uDEC0-\uDEC2\uDED0-\uDED6])|(?:[#\*0-9\xA9\xAE\u203C\u2049\u2122\u2139\u2194-\u2199\u21A9\u21AA\u231A\u231B\u2328\u23CF\u23E9-\u23F3\u23F8-\u23FA\u24C2\u25AA\u25AB\u25B6\u25C0\u25FB-\u25FE\u2600-\u2604\u260E\u2611\u2614\u2615\u2618\u261D\u2620\u2622\u2623\u2626\u262A\u262E\u262F\u2638-\u263A\u2640\u2642\u2648-\u2653\u265F\u2660\u2663\u2665\u2666\u2668\u267B\u267E\u267F\u2692-\u2697\u2699\u269B\u269C\u26A0\u26A1\u26A7\u26AA\u26AB\u26B0\u26B1\u26BD\u26BE\u26C4\u26C5\u26C8\u26CE\u26CF\u26D1\u26D3\u26D4\u26E9\u26EA\u26F0-\u26F5\u26F7-\u26FA\u26FD\u2702\u2705\u2708-\u270D\u270F\u2712\u2714\u2716\u271D\u2721\u2728\u2733\u2734\u2744\u2747\u274C\u274E\u2753-\u2755\u2757\u2763\u2764\u2795-\u2797\u27A1\u27B0\u27BF\u2934\u2935\u2B05-\u2B07\u2B1B\u2B1C\u2B50\u2B55\u3030\u303D\u3297\u3299]|\uD83C[\uDC04\uDCCF\uDD70\uDD71\uDD7E\uDD7F\uDD8E\uDD91-\uDD9A\uDDE6-\uDDFF\uDE01\uDE02\uDE1A\uDE2F\uDE32-\uDE3A\uDE50\uDE51\uDF00-\uDF21\uDF24-\uDF93\uDF96\uDF97\uDF99-\uDF9B\uDF9E-\uDFF0\uDFF3-\uDFF5\uDFF7-\uDFFF]|\uD83D[\uDC00-\uDCFD\uDCFF-\uDD3D\uDD49-\uDD4E\uDD50-\uDD67\uDD6F\uDD70\uDD73-\uDD7A\uDD87\uDD8A-\uDD8D\uDD90\uDD95\uDD96\uDDA4\uDDA5\uDDA8\uDDB1\uDDB2\uDDBC\uDDC2-\uDDC4\uDDD1-\uDDD3\uDDDC-\uDDDE\uDDE1\uDDE3\uDDE8\uDDEF\uDDF3\uDDFA-\uDE4F\uDE80-\uDEC5\uDECB-\uDED2\uDED5-\uDED7\uDEE0-\uDEE5\uDEE9\uDEEB\uDEEC\uDEF0\uDEF3-\uDEFC\uDFE0-\uDFEB]|\uD83E[\uDD0C-\uDD3A\uDD3C-\uDD45\uDD47-\uDD78\uDD7A-\uDDCB\uDDCD-\uDDFF\uDE70-\uDE74\uDE78-\uDE7A\uDE80-\uDE86\uDE90-\uDEA8\uDEB0-\uDEB6\uDEC0-\uDEC2\uDED0-\uDED6])\uFE0F|(?:[\u261D\u26F9\u270A-\u270D]|\uD83C[\uDF85\uDFC2-\uDFC4\uDFC7\uDFCA-\uDFCC]|\uD83D[\uDC42\uDC43\uDC46-\uDC50\uDC66-\uDC78\uDC7C\uDC81-\uDC83\uDC85-\uDC87\uDC8F\uDC91\uDCAA\uDD74\uDD75\uDD7A\uDD90\uDD95\uDD96\uDE45-\uDE47\uDE4B-\uDE4F\uDEA3\uDEB4-\uDEB6\uDEC0\uDECC]|\uD83E[\uDD0C\uDD0F\uDD18-\uDD1F\uDD26\uDD30-\uDD39\uDD3C-\uDD3E\uDD77\uDDB5\uDDB6\uDDB8\uDDB9\uDDBB\uDDCD-\uDDCF\uDDD1-\uDDDD])/g}});N(),N(),N();var $s=t=>{var e,r,o;let n=(e=process.stdout.columns)!=null?e:Number.POSITIVE_INFINITY;return typeof t=="function"&&(t=t(n)),t||(t={}),Array.isArray(t)?{columns:t,stdoutColumns:n}:{columns:(r=t.columns)!=null?r:[],stdoutColumns:(o=t.stdoutColumns)!=null?o:n}};N(),N(),N(),N(),N();function As({onlyFirst:t=!1}={}){let e=["[\\u001B\\u009B][[\\]()#;?]*(?:(?:(?:(?:;[-a-zA-Z\\d\\/#&.:=?%@~_]+)*|[a-zA-Z\\d]+(?:;[-a-zA-Z\\d\\/#&.:=?%@~_]*)*)?\\u0007)","(?:(?:\\d{1,4}(?:;\\d{0,4})*)?[\\dA-PR-TZcf-ntqry=><~]))"].join("|");return new RegExp(e,t?void 0:"g")}function $r(t){if(typeof t!="string")throw new TypeError(`Expected a \`string\`, got \`${typeof t}\``);return t.replace(As(),"")}N();function Ps(t){return Number.isInteger(t)?t>=4352&&(t<=4447||t===9001||t===9002||11904<=t&&t<=12871&&t!==12351||12880<=t&&t<=19903||19968<=t&&t<=42182||43360<=t&&t<=43388||44032<=t&&t<=55203||63744<=t&&t<=64255||65040<=t&&t<=65049||65072<=t&&t<=65131||65281<=t&&t<=65376||65504<=t&&t<=65510||110592<=t&&t<=110593||127488<=t&&t<=127569||131072<=t&&t<=262141):!1}var Bs=vs(bs(),1);function ee(t){if(typeof t!="string"||t.length===0||(t=$r(t),t.length===0))return 0;t=t.replace((0,Bs.default)()," ");let e=0;for(let r=0;r<t.length;r++){let o=t.codePointAt(r);o<=31||o>=127&&o<=159||o>=768&&o<=879||(o>65535&&r++,e+=Ps(o)?2:1)}return e}var Ar=t=>Math.max(...t.split(`
|
|
3
|
-
`).map(ee)),xs=t=>{let e=[];for(let r of t){let{length:o}=r,n=o-e.length;for(let s=0;s<n;s+=1)e.push(0);for(let s=0;s<o;s+=1){let i=Ar(r[s]);i>e[s]&&(e[s]=i)}}return e};N();var Pr=/^\d+%$/,Br={width:"auto",align:"left",contentWidth:0,paddingLeft:0,paddingRight:0,paddingTop:0,paddingBottom:0,horizontalPadding:0,paddingLeftString:"",paddingRightString:""},Ms=(t,e)=>{var r;let o=[];for(let n=0;n<t.length;n+=1){let s=(r=e[n])!=null?r:"auto";if(typeof s=="number"||s==="auto"||s==="content-width"||typeof s=="string"&&Pr.test(s)){o.push(ct(ke({},Br),{width:s,contentWidth:t[n]}));continue}if(s&&typeof s=="object"){let i=ct(ke(ke({},Br),s),{contentWidth:t[n]});i.horizontalPadding=i.paddingLeft+i.paddingRight,o.push(i);continue}throw new Error(`Invalid column width: ${JSON.stringify(s)}`)}return o};function Ss(t,e){for(let r of t){let{width:o}=r;if(o==="content-width"&&(r.width=r.contentWidth),o==="auto"){let a=Math.min(20,r.contentWidth);r.width=a,r.autoOverflow=r.contentWidth-a}if(typeof o=="string"&&Pr.test(o)){let a=Number.parseFloat(o.slice(0,-1))/100;r.width=Math.floor(e*a)-(r.paddingLeft+r.paddingRight)}let{horizontalPadding:n}=r,s=1,i=s+n;if(i>=e){let a=i-e,l=Math.ceil(r.paddingLeft/n*a),m=a-l;r.paddingLeft-=l,r.paddingRight-=m,r.horizontalPadding=r.paddingLeft+r.paddingRight}r.paddingLeftString=r.paddingLeft?" ".repeat(r.paddingLeft):"",r.paddingRightString=r.paddingRight?" ".repeat(r.paddingRight):"";let u=e-r.horizontalPadding;r.width=Math.max(Math.min(r.width,u),s)}}var xr=()=>Object.assign([],{columns:0});function Rs(t,e){let r=[xr()],[o]=r;for(let n of t){let s=n.width+n.horizontalPadding;o.columns+s>e&&(o=xr(),r.push(o)),o.push(n),o.columns+=s}for(let n of r){let s=n.reduce((D,d)=>D+d.width+d.horizontalPadding,0),i=e-s;if(i===0)continue;let u=n.filter(D=>"autoOverflow"in D),a=u.filter(D=>D.autoOverflow>0),l=a.reduce((D,d)=>D+d.autoOverflow,0),m=Math.min(l,i);for(let D of a){let d=Math.floor(D.autoOverflow/l*m);D.width+=d,i-=d}let c=Math.floor(i/u.length);for(let D=0;D<u.length;D+=1){let d=u[D];D===u.length-1?d.width+=i:d.width+=c,i-=c}}return r}function Os(t,e,r){let o=Ms(r,e);return Ss(o,t),Rs(o,t)}N(),N(),N();var lt=10,Mr=(t=0)=>e=>`\x1B[${e+t}m`,Sr=(t=0)=>e=>`\x1B[${38+t};5;${e}m`,Rr=(t=0)=>(e,r,o)=>`\x1B[${38+t};2;${e};${r};${o}m`;function Is(){let t=new Map,e={modifier:{reset:[0,0],bold:[1,22],dim:[2,22],italic:[3,23],underline:[4,24],overline:[53,55],inverse:[7,27],hidden:[8,28],strikethrough:[9,29]},color:{black:[30,39],red:[31,39],green:[32,39],yellow:[33,39],blue:[34,39],magenta:[35,39],cyan:[36,39],white:[37,39],blackBright:[90,39],redBright:[91,39],greenBright:[92,39],yellowBright:[93,39],blueBright:[94,39],magentaBright:[95,39],cyanBright:[96,39],whiteBright:[97,39]},bgColor:{bgBlack:[40,49],bgRed:[41,49],bgGreen:[42,49],bgYellow:[43,49],bgBlue:[44,49],bgMagenta:[45,49],bgCyan:[46,49],bgWhite:[47,49],bgBlackBright:[100,49],bgRedBright:[101,49],bgGreenBright:[102,49],bgYellowBright:[103,49],bgBlueBright:[104,49],bgMagentaBright:[105,49],bgCyanBright:[106,49],bgWhiteBright:[107,49]}};e.color.gray=e.color.blackBright,e.bgColor.bgGray=e.bgColor.bgBlackBright,e.color.grey=e.color.blackBright,e.bgColor.bgGrey=e.bgColor.bgBlackBright;for(let[r,o]of Object.entries(e)){for(let[n,s]of Object.entries(o))e[n]={open:`\x1B[${s[0]}m`,close:`\x1B[${s[1]}m`},o[n]=e[n],t.set(s[0],s[1]);Object.defineProperty(e,r,{value:o,enumerable:!1})}return Object.defineProperty(e,"codes",{value:t,enumerable:!1}),e.color.close="\x1B[39m",e.bgColor.close="\x1B[49m",e.color.ansi=Mr(),e.color.ansi256=Sr(),e.color.ansi16m=Rr(),e.bgColor.ansi=Mr(lt),e.bgColor.ansi256=Sr(lt),e.bgColor.ansi16m=Rr(lt),Object.defineProperties(e,{rgbToAnsi256:{value:(r,o,n)=>r===o&&o===n?r<8?16:r>248?231:Math.round((r-8)/247*24)+232:16+36*Math.round(r/255*5)+6*Math.round(o/255*5)+Math.round(n/255*5),enumerable:!1},hexToRgb:{value:r=>{let o=/(?<colorString>[a-f\d]{6}|[a-f\d]{3})/i.exec(r.toString(16));if(!o)return[0,0,0];let{colorString:n}=o.groups;n.length===3&&(n=n.split("").map(i=>i+i).join(""));let s=Number.parseInt(n,16);return[s>>16&255,s>>8&255,s&255]},enumerable:!1},hexToAnsi256:{value:r=>e.rgbToAnsi256(...e.hexToRgb(r)),enumerable:!1},ansi256ToAnsi:{value:r=>{if(r<8)return 30+r;if(r<16)return 90+(r-8);let o,n,s;if(r>=232)o=((r-232)*10+8)/255,n=o,s=o;else{r-=16;let a=r%36;o=Math.floor(r/36)/5,n=Math.floor(a/6)/5,s=a%6/5}let i=Math.max(o,n,s)*2;if(i===0)return 30;let u=30+(Math.round(s)<<2|Math.round(n)<<1|Math.round(o));return i===2&&(u+=60),u},enumerable:!1},rgbToAnsi:{value:(r,o,n)=>e.ansi256ToAnsi(e.rgbToAnsi256(r,o,n)),enumerable:!1},hexToAnsi:{value:r=>e.ansi256ToAnsi(e.hexToAnsi256(r)),enumerable:!1}}),e}var ks=Is(),Ls=ks,Le=new Set(["\x1B","\x9B"]),Ts=39,Dt="\x07",Or="[",Ns="]",Ir="m",mt=`${Ns}8;;`,kr=t=>`${Le.values().next().value}${Or}${t}${Ir}`,Lr=t=>`${Le.values().next().value}${mt}${t}${Dt}`,_s=t=>t.split(" ").map(e=>ee(e)),dt=(t,e,r)=>{let o=[...e],n=!1,s=!1,i=ee($r(t[t.length-1]));for(let[u,a]of o.entries()){let l=ee(a);if(i+l<=r?t[t.length-1]+=a:(t.push(a),i=0),Le.has(a)&&(n=!0,s=o.slice(u+1).join("").startsWith(mt)),n){s?a===Dt&&(n=!1,s=!1):a===Ir&&(n=!1);continue}i+=l,i===r&&u<o.length-1&&(t.push(""),i=0)}!i&&t[t.length-1].length>0&&t.length>1&&(t[t.length-2]+=t.pop())},js=t=>{let e=t.split(" "),r=e.length;for(;r>0&&!(ee(e[r-1])>0);)r--;return r===e.length?t:e.slice(0,r).join(" ")+e.slice(r).join("")},Gs=(t,e,r={})=>{if(r.trim!==!1&&t.trim()==="")return"";let o="",n,s,i=_s(t),u=[""];for(let[l,m]of t.split(" ").entries()){r.trim!==!1&&(u[u.length-1]=u[u.length-1].trimStart());let c=ee(u[u.length-1]);if(l!==0&&(c>=e&&(r.wordWrap===!1||r.trim===!1)&&(u.push(""),c=0),(c>0||r.trim===!1)&&(u[u.length-1]+=" ",c++)),r.hard&&i[l]>e){let D=e-c,d=1+Math.floor((i[l]-D-1)/e);Math.floor((i[l]-1)/e)<d&&u.push(""),dt(u,m,e);continue}if(c+i[l]>e&&c>0&&i[l]>0){if(r.wordWrap===!1&&c<e){dt(u,m,e);continue}u.push("")}if(c+i[l]>e&&r.wordWrap===!1){dt(u,m,e);continue}u[u.length-1]+=m}r.trim!==!1&&(u=u.map(l=>js(l)));let a=[...u.join(`
|
|
4
|
-
`)];for(let[l,m]of a.entries()){if(o+=m,Le.has(m)){let{groups:D}=new RegExp(`(?:\\${Or}(?<code>\\d+)m|\\${mt}(?<uri>.*)${Dt})`).exec(a.slice(l).join(""))||{groups:{}};if(D.code!==void 0){let d=Number.parseFloat(D.code);n=d===Ts?void 0:d}else D.uri!==void 0&&(s=D.uri.length===0?void 0:D.uri)}let c=Ls.codes.get(Number(n));a[l+1]===`
|
|
5
|
-
`?(s&&(o+=Lr("")),n&&c&&(o+=kr(c))):m===`
|
|
6
|
-
`&&(n&&c&&(o+=kr(n)),s&&(o+=Lr(s)))}return o};function Hs(t,e,r){return String(t).normalize().replace(/\r\n/g,`
|
|
7
|
-
`).split(`
|
|
8
|
-
`).map(o=>Gs(o,e,r)).join(`
|
|
9
|
-
`)}var Tr=t=>Array.from({length:t}).fill("");function Us(t,e){let r=[],o=0;for(let n of t){let s=0,i=n.map(a=>{var l;let m=(l=e[o])!=null?l:"";o+=1,a.preprocess&&(m=a.preprocess(m)),Ar(m)>a.width&&(m=Hs(m,a.width,{hard:!0}));let c=m.split(`
|
|
10
|
-
`);if(a.postprocess){let{postprocess:D}=a;c=c.map((d,f)=>D.call(a,d,f))}return a.paddingTop&&c.unshift(...Tr(a.paddingTop)),a.paddingBottom&&c.push(...Tr(a.paddingBottom)),c.length>s&&(s=c.length),ct(ke({},a),{lines:c})}),u=[];for(let a=0;a<s;a+=1){let l=i.map(m=>{var c;let D=(c=m.lines[a])!=null?c:"",d=Number.isFinite(m.width)?" ".repeat(m.width-ee(D)):"",f=m.paddingLeftString;return m.align==="right"&&(f+=d),f+=D,m.align==="left"&&(f+=d),f+m.paddingRightString}).join("");u.push(l)}r.push(u.join(`
|
|
11
|
-
`))}return r.join(`
|
|
12
|
-
`)}function qs(t,e){if(!t||t.length===0)return"";let r=xs(t),o=r.length;if(o===0)return"";let{stdoutColumns:n,columns:s}=$s(e);if(s.length>o)throw new Error(`${s.length} columns defined, but only ${o} columns found`);let i=Os(n,s,r);return t.map(u=>Us(i,u)).join(`
|
|
13
|
-
`)}N();var zs=["<",">","=",">=","<="];function Ws(t){if(!zs.includes(t))throw new TypeError(`Invalid breakpoint operator: ${t}`)}function Ks(t){let e=Object.keys(t).map(r=>{let[o,n]=r.split(" ");Ws(o);let s=Number.parseInt(n,10);if(Number.isNaN(s))throw new TypeError(`Invalid breakpoint value: ${n}`);let i=t[r];return{operator:o,breakpoint:s,value:i}}).sort((r,o)=>o.breakpoint-r.breakpoint);return r=>{var o;return(o=e.find(({operator:n,breakpoint:s})=>n==="="&&r===s||n===">"&&r>s||n==="<"&&r<s||n===">="&&r>=s||n==="<="&&r<=s))==null?void 0:o.value}}const Js=t=>t.replace(/[\W_]([a-z\d])?/gi,(e,r)=>r?r.toUpperCase():""),Vs=t=>t.replace(/\B([A-Z])/g,"-$1").toLowerCase(),Ys={"> 80":[{width:"content-width",paddingLeft:2,paddingRight:8},{width:"auto"}],"> 40":[{width:"auto",paddingLeft:2,paddingRight:8,preprocess:t=>t.trim()},{width:"100%",paddingLeft:2,paddingBottom:1}],"> 0":{stdoutColumns:1e3,columns:[{width:"content-width",paddingLeft:2,paddingRight:8},{width:"content-width"}]}};function Xs(t){let e=!1;return{type:"table",data:{tableData:Object.keys(t).sort((r,o)=>r.localeCompare(o)).map(r=>{const o=t[r],n="alias"in o;return n&&(e=!0),{name:r,flag:o,flagFormatted:`--${Vs(r)}`,aliasesEnabled:e,aliasFormatted:n?`-${o.alias}`:void 0}}).map(r=>(r.aliasesEnabled=e,[{type:"flagName",data:r},{type:"flagDescription",data:r}])),tableBreakpoints:Ys}}}const Nr=t=>!t||(t.version??(t.help?t.help.version:void 0)),_r=t=>{const e="parent"in t&&t.parent?.name;return(e?`${e} `:"")+t.name};function Zs(t){const e=[];t.name&&e.push(_r(t));const r=Nr(t)??("parent"in t&&Nr(t.parent));if(r&&e.push(`v${r}`),e.length!==0)return{id:"name",type:"text",data:`${e.join(" ")}
|
|
14
|
-
`}}function Qs(t){const{help:e}=t;if(!(!e||!e.description))return{id:"description",type:"text",data:`${e.description}
|
|
15
|
-
`}}function ei(t){const e=t.help||{};if("usage"in e)return e.usage?{id:"usage",type:"section",data:{title:"Usage:",body:Array.isArray(e.usage)?e.usage.join(`
|
|
16
|
-
`):e.usage}}:void 0;if(t.name){const r=[],o=[_r(t)];if(t.flags&&Object.keys(t.flags).length>0&&o.push("[flags...]"),t.parameters&&t.parameters.length>0){const{parameters:n}=t,s=n.indexOf("--"),i=s>-1&&n.slice(s+1).some(u=>u.startsWith("<"));o.push(n.map(u=>u!=="--"?u:i?"--":"[--]").join(" "))}if(o.length>1&&r.push(o.join(" ")),"commands"in t&&t.commands?.length&&r.push(`${t.name} <command>`),r.length>0)return{id:"usage",type:"section",data:{title:"Usage:",body:r.join(`
|
|
17
|
-
`)}}}}function ti(t){return!("commands"in t)||!t.commands?.length?void 0:{id:"commands",type:"section",data:{title:"Commands:",body:{type:"table",data:{tableData:t.commands.map(e=>[e.options.name,e.options.help?e.options.help.description:""]),tableOptions:[{width:"content-width",paddingLeft:2,paddingRight:8}]}},indentBody:0}}}function ri(t){if(!(!t.flags||Object.keys(t.flags).length===0))return{id:"flags",type:"section",data:{title:"Flags:",body:Xs(t.flags),indentBody:0}}}function oi(t){const{help:e}=t;if(!e||!e.examples||e.examples.length===0)return;let{examples:r}=e;if(Array.isArray(r)&&(r=r.join(`
|
|
18
|
-
`)),r)return{id:"examples",type:"section",data:{title:"Examples:",body:r}}}function ni(t){if(!("alias"in t)||!t.alias)return;const{alias:e}=t;return{id:"aliases",type:"section",data:{title:"Aliases:",body:Array.isArray(e)?e.join(", "):e}}}const si=t=>[Zs,Qs,ei,ti,ri,oi,ni].map(e=>e(t)).filter(Boolean),ii=st.WriteStream.prototype.hasColors();class ai{text(e){return e}bold(e){return ii?`\x1B[1m${e}\x1B[22m`:e.toLocaleUpperCase()}indentText({text:e,spaces:r}){return e.replace(/^/gm," ".repeat(r))}heading(e){return this.bold(e)}section({title:e,body:r,indentBody:o=2}){return`${(e?`${this.heading(e)}
|
|
19
|
-
`:"")+(r?this.indentText({text:this.render(r),spaces:o}):"")}
|
|
20
|
-
`}table({tableData:e,tableOptions:r,tableBreakpoints:o}){return qs(e.map(n=>n.map(s=>this.render(s))),o?Ks(o):r)}flagParameter(e){return e===Boolean?"":e===String?"<string>":e===Number?"<number>":Array.isArray(e)?this.flagParameter(e[0]):"<value>"}flagOperator(e){return" "}flagName(e){const{flag:r,flagFormatted:o,aliasesEnabled:n,aliasFormatted:s}=e;let i="";if(s?i+=`${s}, `:n&&(i+=" "),i+=o,"placeholder"in r&&typeof r.placeholder=="string")i+=`${this.flagOperator(e)}${r.placeholder}`;else{const u=this.flagParameter("type"in r?r.type:r);u&&(i+=`${this.flagOperator(e)}${u}`)}return i}flagDefault(e){return JSON.stringify(e)}flagDescription({flag:e}){let r="description"in e?e.description??"":"";if("default"in e){let{default:o}=e;typeof o=="function"&&(o=o()),o&&(r+=` (default: ${this.flagDefault(o)})`)}return r}render(e){if(typeof e=="string")return e;if(Array.isArray(e))return e.map(r=>this.render(r)).join(`
|
|
21
|
-
`);if("type"in e&&this[e.type]){const r=this[e.type];if(typeof r=="function")return r.call(this,e.data)}throw new Error(`Invalid node type: ${JSON.stringify(e)}`)}}const pt=t=>t.length>0&&!t.includes(" "),{stringify:W}=JSON,ui=/[|\\{}()[\]^$+*?.]/;function ft(t){const e=[];let r,o;for(const n of t){if(o)throw new Error(`Invalid parameter: Spread parameter ${W(o)} must be last`);const s=n[0],i=n[n.length-1];let u;if(s==="<"&&i===">"&&(u=!0,r))throw new Error(`Invalid parameter: Required parameter ${W(n)} cannot come after optional parameter ${W(r)}`);if(s==="["&&i==="]"&&(u=!1,r=n),u===void 0)throw new Error(`Invalid parameter: ${W(n)}. Must be wrapped in <> (required parameter) or [] (optional parameter)`);let a=n.slice(1,-1);const l=a.slice(-3)==="...";l&&(o=n,a=a.slice(0,-3));const m=a.match(ui);if(m)throw new Error(`Invalid parameter: ${W(n)}. Invalid character found ${W(m[0])}`);e.push({name:a,required:u,spread:l})}return e}function ht(t,e,r,o){for(let n=0;n<e.length;n+=1){const{name:s,required:i,spread:u}=e[n],a=Js(s);if(a in t)throw new Error(`Invalid parameter: ${W(s)} is used more than once.`);const l=u?r.slice(n):r[n];if(u&&(n=e.length),i&&(!l||u&&l.length===0))return console.error(`Error: Missing required parameter ${W(s)}
|
|
22
|
-
`),o(),process.exit(1);t[a]=l}}function ci(t){return t===void 0||t!==!1}function jr(t,e,r,o){const n={...e.flags},s=e.version;s&&(n.version={type:Boolean,description:"Show version"});const{help:i}=e,u=ci(i);u&&!("help"in n)&&(n.help={type:Boolean,alias:"h",description:"Show help"});const a=Ds(n,o,{ignore:e.ignoreArgv}),l=()=>{console.log(e.version)};if(s&&a.flags.version===!0)return l(),process.exit(0);const m=new ai,c=u&&i?.render?i.render:f=>m.render(f),D=f=>{const h=si({...e,...f?{help:f}:{},flags:n});console.log(c(h,m))};if(u&&a.flags.help===!0)return D(),process.exit(0);if(e.parameters){let{parameters:f}=e,h=a._;const g=f.indexOf("--"),E=f.slice(g+1),w=Object.create(null);if(g>-1&&E.length>0){f=f.slice(0,g);const S=a._["--"];h=h.slice(0,-S.length||void 0),ht(w,ft(f),h,D),ht(w,ft(E),S,D)}else ht(w,ft(f),h,D);Object.assign(a._,w)}const d={...a,showVersion:l,showHelp:D};return typeof r=="function"&&r(d),{command:t,...d}}function li(t,e){const r=new Map;for(const o of e){const n=[o.options.name],{alias:s}=o.options;s&&(Array.isArray(s)?n.push(...s):n.push(s));for(const i of n){if(r.has(i))throw new Error(`Duplicate command name found: ${W(i)}`);r.set(i,o)}}return r.get(t)}function Di(t,e,r=process.argv.slice(2)){if(!t)throw new Error("Options is required");if("name"in t&&(!t.name||!pt(t.name)))throw new Error(`Invalid script name: ${W(t.name)}`);const o=r[0];if(t.commands&&o&&pt(o)){const n=li(o,t.commands);if(n)return jr(n.options.name,{...n.options,parent:t},n.callback,r.slice(1))}return jr(void 0,t,e,r)}function gt(t,e){if(!t)throw new Error("Command options are required");const{name:r}=t;if(r===void 0)throw new Error("Command name is required");if(!pt(r))throw new Error(`Invalid command name ${JSON.stringify(r)}. Command names must be one word.`);return{options:t,callback:e}}var mi=gn(import.meta.url),R=typeof globalThis<"u"?globalThis:typeof window<"u"?window:typeof global<"u"?global:typeof self<"u"?self:{};function se(t){return t&&t.__esModule&&Object.prototype.hasOwnProperty.call(t,"default")?t.default:t}var ie={exports:{}},Ct,Gr;function di(){if(Gr)return Ct;Gr=1,Ct=o,o.sync=n;var t=T;function e(s,i){var u=i.pathExt!==void 0?i.pathExt:process.env.PATHEXT;if(!u||(u=u.split(";"),u.indexOf("")!==-1))return!0;for(var a=0;a<u.length;a++){var l=u[a].toLowerCase();if(l&&s.substr(-l.length).toLowerCase()===l)return!0}return!1}function r(s,i,u){return!s.isSymbolicLink()&&!s.isFile()?!1:e(i,u)}function o(s,i,u){t.stat(s,function(a,l){u(a,a?!1:r(l,s,i))})}function n(s,i){return r(t.statSync(s),s,i)}return Ct}var yt,Hr;function pi(){if(Hr)return yt;Hr=1,yt=e,e.sync=r;var t=T;function e(s,i,u){t.stat(s,function(a,l){u(a,a?!1:o(l,i))})}function r(s,i){return o(t.statSync(s),i)}function o(s,i){return s.isFile()&&n(s,i)}function n(s,i){var u=s.mode,a=s.uid,l=s.gid,m=i.uid!==void 0?i.uid:process.getuid&&process.getuid(),c=i.gid!==void 0?i.gid:process.getgid&&process.getgid(),D=parseInt("100",8),d=parseInt("010",8),f=parseInt("001",8),h=D|d,g=u&f||u&d&&l===c||u&D&&a===m||u&h&&m===0;return g}return yt}var Te;process.platform==="win32"||R.TESTING_WINDOWS?Te=di():Te=pi();var fi=Et;Et.sync=hi;function Et(t,e,r){if(typeof e=="function"&&(r=e,e={}),!r){if(typeof Promise!="function")throw new TypeError("callback not provided");return new Promise(function(o,n){Et(t,e||{},function(s,i){s?n(s):o(i)})})}Te(t,e||{},function(o,n){o&&(o.code==="EACCES"||e&&e.ignoreErrors)&&(o=null,n=!1),r(o,n)})}function hi(t,e){try{return Te.sync(t,e||{})}catch(r){if(e&&e.ignoreErrors||r.code==="EACCES")return!1;throw r}}const ae=process.platform==="win32"||process.env.OSTYPE==="cygwin"||process.env.OSTYPE==="msys",Ur=k,gi=ae?";":":",qr=fi,zr=t=>Object.assign(new Error(`not found: ${t}`),{code:"ENOENT"}),Wr=(t,e)=>{const r=e.colon||gi,o=t.match(/\//)||ae&&t.match(/\\/)?[""]:[...ae?[process.cwd()]:[],...(e.path||process.env.PATH||"").split(r)],n=ae?e.pathExt||process.env.PATHEXT||".EXE;.CMD;.BAT;.COM":"",s=ae?n.split(r):[""];return ae&&t.indexOf(".")!==-1&&s[0]!==""&&s.unshift(""),{pathEnv:o,pathExt:s,pathExtExe:n}},Kr=(t,e,r)=>{typeof e=="function"&&(r=e,e={}),e||(e={});const{pathEnv:o,pathExt:n,pathExtExe:s}=Wr(t,e),i=[],u=l=>new Promise((m,c)=>{if(l===o.length)return e.all&&i.length?m(i):c(zr(t));const D=o[l],d=/^".*"$/.test(D)?D.slice(1,-1):D,f=Ur.join(d,t),h=!d&&/^\.[\\\/]/.test(t)?t.slice(0,2)+f:f;m(a(h,l,0))}),a=(l,m,c)=>new Promise((D,d)=>{if(c===n.length)return D(u(m+1));const f=n[c];qr(l+f,{pathExt:s},(h,g)=>{if(!h&&g)if(e.all)i.push(l+f);else return D(l+f);return D(a(l,m,c+1))})});return r?u(0).then(l=>r(null,l),r):u(0)},Ci=(t,e)=>{e=e||{};const{pathEnv:r,pathExt:o,pathExtExe:n}=Wr(t,e),s=[];for(let i=0;i<r.length;i++){const u=r[i],a=/^".*"$/.test(u)?u.slice(1,-1):u,l=Ur.join(a,t),m=!a&&/^\.[\\\/]/.test(t)?t.slice(0,2)+l:l;for(let c=0;c<o.length;c++){const D=m+o[c];try{if(qr.sync(D,{pathExt:n}))if(e.all)s.push(D);else return D}catch{}}}if(e.all&&s.length)return s;if(e.nothrow)return null;throw zr(t)};var yi=Kr;Kr.sync=Ci;var Ft={exports:{}};const Jr=(t={})=>{const e=t.env||process.env;return(t.platform||process.platform)!=="win32"?"PATH":Object.keys(e).reverse().find(o=>o.toUpperCase()==="PATH")||"Path"};Ft.exports=Jr,Ft.exports.default=Jr;var Ei=Ft.exports;const Vr=k,Fi=yi,wi=Ei;function Yr(t,e){const r=t.options.env||process.env,o=process.cwd(),n=t.options.cwd!=null,s=n&&process.chdir!==void 0&&!process.chdir.disabled;if(s)try{process.chdir(t.options.cwd)}catch{}let i;try{i=Fi.sync(t.command,{path:r[wi({env:r})],pathExt:e?Vr.delimiter:void 0})}catch{}finally{s&&process.chdir(o)}return i&&(i=Vr.resolve(n?t.options.cwd:"",i)),i}function vi(t){return Yr(t)||Yr(t,!0)}var bi=vi,wt={};const vt=/([()\][%!^"`<>&|;, *?])/g;function $i(t){return t=t.replace(vt,"^$1"),t}function Ai(t,e){return t=`${t}`,t=t.replace(/(?=(\\+?)?)\1"/g,'$1$1\\"'),t=t.replace(/(?=(\\+?)?)\1$/,"$1$1"),t=`"${t}"`,t=t.replace(vt,"^$1"),e&&(t=t.replace(vt,"^$1")),t}wt.command=$i,wt.argument=Ai;var Pi=/^#!(.*)/;const Bi=Pi;var xi=(t="")=>{const e=t.match(Bi);if(!e)return null;const[r,o]=e[0].replace(/#! ?/,"").split(" "),n=r.split("/").pop();return n==="env"?o:o?`${n} ${o}`:n};const bt=T,Mi=xi;function Si(t){const r=Buffer.alloc(150);let o;try{o=bt.openSync(t,"r"),bt.readSync(o,r,0,150,0),bt.closeSync(o)}catch{}return Mi(r.toString())}var Ri=Si;const Oi=k,Xr=bi,Zr=wt,Ii=Ri,ki=process.platform==="win32",Li=/\.(?:com|exe)$/i,Ti=/node_modules[\\/].bin[\\/][^\\/]+\.cmd$/i;function Ni(t){t.file=Xr(t);const e=t.file&&Ii(t.file);return e?(t.args.unshift(t.file),t.command=e,Xr(t)):t.file}function _i(t){if(!ki)return t;const e=Ni(t),r=!Li.test(e);if(t.options.forceShell||r){const o=Ti.test(e);t.command=Oi.normalize(t.command),t.command=Zr.command(t.command),t.args=t.args.map(s=>Zr.argument(s,o));const n=[t.command].concat(t.args).join(" ");t.args=["/d","/s","/c",`"${n}"`],t.command=process.env.comspec||"cmd.exe",t.options.windowsVerbatimArguments=!0}return t}function ji(t,e,r){e&&!Array.isArray(e)&&(r=e,e=null),e=e?e.slice(0):[],r=Object.assign({},r);const o={command:t,args:e,options:r,file:void 0,original:{command:t,args:e}};return r.shell?o:_i(o)}var Gi=ji;const $t=process.platform==="win32";function At(t,e){return Object.assign(new Error(`${e} ${t.command} ENOENT`),{code:"ENOENT",errno:"ENOENT",syscall:`${e} ${t.command}`,path:t.command,spawnargs:t.args})}function Hi(t,e){if(!$t)return;const r=t.emit;t.emit=function(o,n){if(o==="exit"){const s=Qr(n,e);if(s)return r.call(t,"error",s)}return r.apply(t,arguments)}}function Qr(t,e){return $t&&t===1&&!e.file?At(e.original,"spawn"):null}function Ui(t,e){return $t&&t===1&&!e.file?At(e.original,"spawnSync"):null}var qi={hookChildProcess:Hi,verifyENOENT:Qr,verifyENOENTSync:Ui,notFoundError:At};const eo=En,Pt=Gi,Bt=qi;function to(t,e,r){const o=Pt(t,e,r),n=eo.spawn(o.command,o.args,o.options);return Bt.hookChildProcess(n,o),n}function zi(t,e,r){const o=Pt(t,e,r),n=eo.spawnSync(o.command,o.args,o.options);return n.error=n.error||Bt.verifyENOENTSync(n.status,o),n}ie.exports=to,ie.exports.spawn=to,ie.exports.sync=zi,ie.exports._parse=Pt,ie.exports._enoent=Bt;var Wi=ie.exports,Ki=se(Wi);function Ji(t){const e=typeof t=="string"?`
|
|
2
|
+
import{command as Q,cli as Os}from"cleye";import{createRequire as Ls}from"module";import{Buffer as Ts}from"node:buffer";import re from"node:path";import zt,{ChildProcess as Ns}from"node:child_process";import q from"node:process";import Fs from"child_process";import T from"path";import _ from"fs";import{fileURLToPath as Kt}from"node:url";import _s,{constants as Wt}from"node:os";import Yt from"assert";import Vt from"events";import{createWriteStream as Ds,createReadStream as Gs}from"node:fs";import js from"buffer";import Xe from"stream";import Jt from"util";import{debuglog as Bs}from"node:util";import Ce from"inquirer";import Qe from"ora";import w from"chalk";import{of as O,concatMap as A,from as $,map as E,catchError as x,mergeMap as Ee,BehaviorSubject as Xt,ReplaySubject as Hs,lastValueFrom as Qt,filter as Zt,toArray as er,Subject as tr}from"rxjs";import Us from"@anthropic-ai/sdk";import{fromPromise as M}from"rxjs/internal/observable/innerFrom";import Ze from"os";import{xxh64 as qs}from"@pacote/xxhash";import zs from"axios";import{CohereClient as Ks,CohereTimeoutError as Ws}from"cohere-ai";import xe from"openai";import{GoogleGenerativeAI as Ys,HarmCategory as Ae,HarmBlockThreshold as Me}from"@google/generative-ai";import rr from"groq-sdk";import{Ollama as Vs}from"ollama";import{fetch as Js,Agent as Xs}from"undici";import I from"fs/promises";import Qs from"http";import Zs from"https";import eo from"net";import to from"tls";import ro,{fileURLToPath as so,pathToFileURL as oo}from"url";import sr from"tty";import Se from"readline";import no from"figlet";import io from"inquirer-reactive-list-prompt";import{rm as ao}from"node:fs/promises";import co from"chokidar";import{takeUntil as lo}from"rxjs/operators";var mo=Ls(import.meta.url),k=typeof globalThis<"u"?globalThis:typeof window<"u"?window:typeof global<"u"?global:typeof self<"u"?self:{};function se(t){return t&&t.__esModule&&Object.prototype.hasOwnProperty.call(t,"default")?t.default:t}var oe={exports:{}},et,or;function uo(){if(or)return et;or=1,et=r,r.sync=o;var t=_;function e(n,i){var l=i.pathExt!==void 0?i.pathExt:process.env.PATHEXT;if(!l||(l=l.split(";"),l.indexOf("")!==-1))return!0;for(var c=0;c<l.length;c++){var m=l[c].toLowerCase();if(m&&n.substr(-m.length).toLowerCase()===m)return!0}return!1}function s(n,i,l){return!n.isSymbolicLink()&&!n.isFile()?!1:e(i,l)}function r(n,i,l){t.stat(n,function(c,m){l(c,c?!1:s(m,n,i))})}function o(n,i){return s(t.statSync(n),n,i)}return et}var tt,nr;function po(){if(nr)return tt;nr=1,tt=e,e.sync=s;var t=_;function e(n,i,l){t.stat(n,function(c,m){l(c,c?!1:r(m,i))})}function s(n,i){return r(t.statSync(n),i)}function r(n,i){return n.isFile()&&o(n,i)}function o(n,i){var l=n.mode,c=n.uid,m=n.gid,p=i.uid!==void 0?i.uid:process.getuid&&process.getuid(),a=i.gid!==void 0?i.gid:process.getgid&&process.getgid(),d=parseInt("100",8),f=parseInt("010",8),h=parseInt("001",8),g=d|f,y=l&h||l&f&&m===a||l&d&&c===p||l&g&&p===0;return y}return tt}var Re;process.platform==="win32"||k.TESTING_WINDOWS?Re=uo():Re=po();var fo=rt;rt.sync=ho;function rt(t,e,s){if(typeof e=="function"&&(s=e,e={}),!s){if(typeof Promise!="function")throw new TypeError("callback not provided");return new Promise(function(r,o){rt(t,e||{},function(n,i){n?o(n):r(i)})})}Re(t,e||{},function(r,o){r&&(r.code==="EACCES"||e&&e.ignoreErrors)&&(r=null,o=!1),s(r,o)})}function ho(t,e){try{return Re.sync(t,e||{})}catch(s){if(e&&e.ignoreErrors||s.code==="EACCES")return!1;throw s}}const ne=process.platform==="win32"||process.env.OSTYPE==="cygwin"||process.env.OSTYPE==="msys",ir=T,go=ne?";":":",ar=fo,cr=t=>Object.assign(new Error(`not found: ${t}`),{code:"ENOENT"}),lr=(t,e)=>{const s=e.colon||go,r=t.match(/\//)||ne&&t.match(/\\/)?[""]:[...ne?[process.cwd()]:[],...(e.path||process.env.PATH||"").split(s)],o=ne?e.pathExt||process.env.PATHEXT||".EXE;.CMD;.BAT;.COM":"",n=ne?o.split(s):[""];return ne&&t.indexOf(".")!==-1&&n[0]!==""&&n.unshift(""),{pathEnv:r,pathExt:n,pathExtExe:o}},mr=(t,e,s)=>{typeof e=="function"&&(s=e,e={}),e||(e={});const{pathEnv:r,pathExt:o,pathExtExe:n}=lr(t,e),i=[],l=m=>new Promise((p,a)=>{if(m===r.length)return e.all&&i.length?p(i):a(cr(t));const d=r[m],f=/^".*"$/.test(d)?d.slice(1,-1):d,h=ir.join(f,t),g=!f&&/^\.[\\\/]/.test(t)?t.slice(0,2)+h:h;p(c(g,m,0))}),c=(m,p,a)=>new Promise((d,f)=>{if(a===o.length)return d(l(p+1));const h=o[a];ar(m+h,{pathExt:n},(g,y)=>{if(!g&&y)if(e.all)i.push(m+h);else return d(m+h);return d(c(m,p,a+1))})});return s?l(0).then(m=>s(null,m),s):l(0)},yo=(t,e)=>{e=e||{};const{pathEnv:s,pathExt:r,pathExtExe:o}=lr(t,e),n=[];for(let i=0;i<s.length;i++){const l=s[i],c=/^".*"$/.test(l)?l.slice(1,-1):l,m=ir.join(c,t),p=!c&&/^\.[\\\/]/.test(t)?t.slice(0,2)+m:m;for(let a=0;a<r.length;a++){const d=p+r[a];try{if(ar.sync(d,{pathExt:o}))if(e.all)n.push(d);else return d}catch{}}}if(e.all&&n.length)return n;if(e.nothrow)return null;throw cr(t)};var wo=mr;mr.sync=yo;var st={exports:{}};const ur=(t={})=>{const e=t.env||process.env;return(t.platform||process.platform)!=="win32"?"PATH":Object.keys(e).reverse().find(r=>r.toUpperCase()==="PATH")||"Path"};st.exports=ur,st.exports.default=ur;var vo=st.exports;const dr=T,bo=wo,Po=vo;function pr(t,e){const s=t.options.env||process.env,r=process.cwd(),o=t.options.cwd!=null,n=o&&process.chdir!==void 0&&!process.chdir.disabled;if(n)try{process.chdir(t.options.cwd)}catch{}let i;try{i=bo.sync(t.command,{path:s[Po({env:s})],pathExt:e?dr.delimiter:void 0})}catch{}finally{n&&process.chdir(r)}return i&&(i=dr.resolve(o?t.options.cwd:"",i)),i}function $o(t){return pr(t)||pr(t,!0)}var Co=$o,ot={};const nt=/([()\][%!^"`<>&|;, *?])/g;function Eo(t){return t=t.replace(nt,"^$1"),t}function xo(t,e){return t=`${t}`,t=t.replace(/(?=(\\+?)?)\1"/g,'$1$1\\"'),t=t.replace(/(?=(\\+?)?)\1$/,"$1$1"),t=`"${t}"`,t=t.replace(nt,"^$1"),e&&(t=t.replace(nt,"^$1")),t}ot.command=Eo,ot.argument=xo;var Ao=/^#!(.*)/;const Mo=Ao;var So=(t="")=>{const e=t.match(Mo);if(!e)return null;const[s,r]=e[0].replace(/#! ?/,"").split(" "),o=s.split("/").pop();return o==="env"?r:r?`${o} ${r}`:o};const it=_,Ro=So;function Io(t){const s=Buffer.alloc(150);let r;try{r=it.openSync(t,"r"),it.readSync(r,s,0,150,0),it.closeSync(r)}catch{}return Ro(s.toString())}var ko=Io;const Oo=T,fr=Co,hr=ot,Lo=ko,To=process.platform==="win32",No=/\.(?:com|exe)$/i,Fo=/node_modules[\\/].bin[\\/][^\\/]+\.cmd$/i;function _o(t){t.file=fr(t);const e=t.file&&Lo(t.file);return e?(t.args.unshift(t.file),t.command=e,fr(t)):t.file}function Do(t){if(!To)return t;const e=_o(t),s=!No.test(e);if(t.options.forceShell||s){const r=Fo.test(e);t.command=Oo.normalize(t.command),t.command=hr.command(t.command),t.args=t.args.map(n=>hr.argument(n,r));const o=[t.command].concat(t.args).join(" ");t.args=["/d","/s","/c",`"${o}"`],t.command=process.env.comspec||"cmd.exe",t.options.windowsVerbatimArguments=!0}return t}function Go(t,e,s){e&&!Array.isArray(e)&&(s=e,e=null),e=e?e.slice(0):[],s=Object.assign({},s);const r={command:t,args:e,options:s,file:void 0,original:{command:t,args:e}};return s.shell?r:Do(r)}var jo=Go;const at=process.platform==="win32";function ct(t,e){return Object.assign(new Error(`${e} ${t.command} ENOENT`),{code:"ENOENT",errno:"ENOENT",syscall:`${e} ${t.command}`,path:t.command,spawnargs:t.args})}function Bo(t,e){if(!at)return;const s=t.emit;t.emit=function(r,o){if(r==="exit"){const n=gr(o,e);if(n)return s.call(t,"error",n)}return s.apply(t,arguments)}}function gr(t,e){return at&&t===1&&!e.file?ct(e.original,"spawn"):null}function Ho(t,e){return at&&t===1&&!e.file?ct(e.original,"spawnSync"):null}var Uo={hookChildProcess:Bo,verifyENOENT:gr,verifyENOENTSync:Ho,notFoundError:ct};const yr=Fs,lt=jo,mt=Uo;function wr(t,e,s){const r=lt(t,e,s),o=yr.spawn(r.command,r.args,r.options);return mt.hookChildProcess(o,r),o}function qo(t,e,s){const r=lt(t,e,s),o=yr.spawnSync(r.command,r.args,r.options);return o.error=o.error||mt.verifyENOENTSync(o.status,r),o}oe.exports=wr,oe.exports.spawn=wr,oe.exports.sync=qo,oe.exports._parse=lt,oe.exports._enoent=mt;var zo=oe.exports,Ko=se(zo);function Wo(t){const e=typeof t=="string"?`
|
|
23
3
|
`:`
|
|
24
|
-
`.charCodeAt(),
|
|
25
|
-
${e}`,
|
|
26
|
-
${
|
|
27
|
-
`);return
|
|
28
|
-
`)},
|
|
4
|
+
`.charCodeAt(),s=typeof t=="string"?"\r":"\r".charCodeAt();return t[t.length-1]===e&&(t=t.slice(0,-1)),t[t.length-1]===s&&(t=t.slice(0,-1)),t}function vr(t={}){const{env:e=process.env,platform:s=process.platform}=t;return s!=="win32"?"PATH":Object.keys(e).reverse().find(r=>r.toUpperCase()==="PATH")||"Path"}const Yo=({cwd:t=q.cwd(),path:e=q.env[vr()],preferLocal:s=!0,execPath:r=q.execPath,addExecPath:o=!0}={})=>{const n=t instanceof URL?Kt(t):t,i=re.resolve(n),l=[];return s&&Vo(l,i),o&&Jo(l,r,i),[...l,e].join(re.delimiter)},Vo=(t,e)=>{let s;for(;s!==e;)t.push(re.join(e,"node_modules/.bin")),s=e,e=re.resolve(e,"..")},Jo=(t,e,s)=>{const r=e instanceof URL?Kt(e):e;t.push(re.resolve(s,r,".."))},Xo=({env:t=q.env,...e}={})=>{t={...t};const s=vr({env:t});return e.path=t[s],t[s]=Yo(e),t},Qo=(t,e,s,r)=>{if(s==="length"||s==="prototype"||s==="arguments"||s==="caller")return;const o=Object.getOwnPropertyDescriptor(t,s),n=Object.getOwnPropertyDescriptor(e,s);!Zo(o,n)&&r||Object.defineProperty(t,s,n)},Zo=function(t,e){return t===void 0||t.configurable||t.writable===e.writable&&t.enumerable===e.enumerable&&t.configurable===e.configurable&&(t.writable||t.value===e.value)},en=(t,e)=>{const s=Object.getPrototypeOf(e);s!==Object.getPrototypeOf(t)&&Object.setPrototypeOf(t,s)},tn=(t,e)=>`/* Wrapped ${t}*/
|
|
5
|
+
${e}`,rn=Object.getOwnPropertyDescriptor(Function.prototype,"toString"),sn=Object.getOwnPropertyDescriptor(Function.prototype.toString,"name"),on=(t,e,s)=>{const r=s===""?"":`with ${s.trim()}() `,o=tn.bind(null,r,e.toString());Object.defineProperty(o,"name",sn),Object.defineProperty(t,"toString",{...rn,value:o})};function nn(t,e,{ignoreNonConfigurable:s=!1}={}){const{name:r}=t;for(const o of Reflect.ownKeys(e))Qo(t,e,o,s);return en(t,e),on(t,e,r),t}const Ie=new WeakMap,br=(t,e={})=>{if(typeof t!="function")throw new TypeError("Expected a function");let s,r=0;const o=t.displayName||t.name||"<anonymous>",n=function(...i){if(Ie.set(n,++r),r===1)s=t.apply(this,i),t=null;else if(e.throw===!0)throw new Error(`Function \`${o}\` can only be called once`);return s};return nn(n,t),Ie.set(n,r),n};br.callCount=t=>{if(!Ie.has(t))throw new Error(`The given function \`${t.name}\` is not wrapped by the \`onetime\` package`);return Ie.get(t)};const an=()=>{const t=$r-Pr+1;return Array.from({length:t},cn)},cn=(t,e)=>({name:`SIGRT${e+1}`,number:Pr+e,action:"terminate",description:"Application-specific signal (realtime)",standard:"posix"}),Pr=34,$r=64,ln=[{name:"SIGHUP",number:1,action:"terminate",description:"Terminal closed",standard:"posix"},{name:"SIGINT",number:2,action:"terminate",description:"User interruption with CTRL-C",standard:"ansi"},{name:"SIGQUIT",number:3,action:"core",description:"User interruption with CTRL-\\",standard:"posix"},{name:"SIGILL",number:4,action:"core",description:"Invalid machine instruction",standard:"ansi"},{name:"SIGTRAP",number:5,action:"core",description:"Debugger breakpoint",standard:"posix"},{name:"SIGABRT",number:6,action:"core",description:"Aborted",standard:"ansi"},{name:"SIGIOT",number:6,action:"core",description:"Aborted",standard:"bsd"},{name:"SIGBUS",number:7,action:"core",description:"Bus error due to misaligned, non-existing address or paging error",standard:"bsd"},{name:"SIGEMT",number:7,action:"terminate",description:"Command should be emulated but is not implemented",standard:"other"},{name:"SIGFPE",number:8,action:"core",description:"Floating point arithmetic error",standard:"ansi"},{name:"SIGKILL",number:9,action:"terminate",description:"Forced termination",standard:"posix",forced:!0},{name:"SIGUSR1",number:10,action:"terminate",description:"Application-specific signal",standard:"posix"},{name:"SIGSEGV",number:11,action:"core",description:"Segmentation fault",standard:"ansi"},{name:"SIGUSR2",number:12,action:"terminate",description:"Application-specific signal",standard:"posix"},{name:"SIGPIPE",number:13,action:"terminate",description:"Broken pipe or socket",standard:"posix"},{name:"SIGALRM",number:14,action:"terminate",description:"Timeout or timer",standard:"posix"},{name:"SIGTERM",number:15,action:"terminate",description:"Termination",standard:"ansi"},{name:"SIGSTKFLT",number:16,action:"terminate",description:"Stack is empty or overflowed",standard:"other"},{name:"SIGCHLD",number:17,action:"ignore",description:"Child process terminated, paused or unpaused",standard:"posix"},{name:"SIGCLD",number:17,action:"ignore",description:"Child process terminated, paused or unpaused",standard:"other"},{name:"SIGCONT",number:18,action:"unpause",description:"Unpaused",standard:"posix",forced:!0},{name:"SIGSTOP",number:19,action:"pause",description:"Paused",standard:"posix",forced:!0},{name:"SIGTSTP",number:20,action:"pause",description:'Paused using CTRL-Z or "suspend"',standard:"posix"},{name:"SIGTTIN",number:21,action:"pause",description:"Background process cannot read terminal input",standard:"posix"},{name:"SIGBREAK",number:21,action:"terminate",description:"User interruption with CTRL-BREAK",standard:"other"},{name:"SIGTTOU",number:22,action:"pause",description:"Background process cannot write to terminal output",standard:"posix"},{name:"SIGURG",number:23,action:"ignore",description:"Socket received out-of-band data",standard:"bsd"},{name:"SIGXCPU",number:24,action:"core",description:"Process timed out",standard:"bsd"},{name:"SIGXFSZ",number:25,action:"core",description:"File too big",standard:"bsd"},{name:"SIGVTALRM",number:26,action:"terminate",description:"Timeout or timer",standard:"bsd"},{name:"SIGPROF",number:27,action:"terminate",description:"Timeout or timer",standard:"bsd"},{name:"SIGWINCH",number:28,action:"ignore",description:"Terminal window size changed",standard:"bsd"},{name:"SIGIO",number:29,action:"terminate",description:"I/O is available",standard:"other"},{name:"SIGPOLL",number:29,action:"terminate",description:"Watched event",standard:"other"},{name:"SIGINFO",number:29,action:"ignore",description:"Request for process information",standard:"other"},{name:"SIGPWR",number:30,action:"terminate",description:"Device running out of power",standard:"systemv"},{name:"SIGSYS",number:31,action:"core",description:"Invalid system call",standard:"other"},{name:"SIGUNUSED",number:31,action:"terminate",description:"Invalid system call",standard:"other"}],Cr=()=>{const t=an();return[...ln,...t].map(mn)},mn=({name:t,number:e,description:s,action:r,forced:o=!1,standard:n})=>{const{signals:{[t]:i}}=Wt,l=i!==void 0;return{name:t,number:l?i:e,description:s,supported:l,action:r,forced:o,standard:n}},un=()=>{const t=Cr();return Object.fromEntries(t.map(dn))},dn=({name:t,number:e,description:s,supported:r,action:o,forced:n,standard:i})=>[t,{name:t,number:e,description:s,supported:r,action:o,forced:n,standard:i}],pn=un(),fn=()=>{const t=Cr(),e=$r+1,s=Array.from({length:e},(r,o)=>hn(o,t));return Object.assign({},...s)},hn=(t,e)=>{const s=gn(t,e);if(s===void 0)return{};const{name:r,description:o,supported:n,action:i,forced:l,standard:c}=s;return{[t]:{name:r,number:t,description:o,supported:n,action:i,forced:l,standard:c}}},gn=(t,e)=>{const s=e.find(({name:r})=>Wt.signals[r]===t);return s!==void 0?s:e.find(r=>r.number===t)};fn();const yn=({timedOut:t,timeout:e,errorCode:s,signal:r,signalDescription:o,exitCode:n,isCanceled:i})=>t?`timed out after ${e} milliseconds`:i?"was canceled":s!==void 0?`failed with ${s}`:r!==void 0?`was killed with ${r} (${o})`:n!==void 0?`failed with exit code ${n}`:"failed",Er=({stdout:t,stderr:e,all:s,error:r,signal:o,exitCode:n,command:i,escapedCommand:l,timedOut:c,isCanceled:m,killed:p,parsed:{options:{timeout:a,cwd:d=q.cwd()}}})=>{n=n===null?void 0:n,o=o===null?void 0:o;const f=o===void 0?void 0:pn[o].description,h=r&&r.code,y=`Command ${yn({timedOut:c,timeout:a,errorCode:h,signal:o,signalDescription:f,exitCode:n,isCanceled:m})}: ${i}`,b=Object.prototype.toString.call(r)==="[object Error]",C=b?`${y}
|
|
6
|
+
${r.message}`:y,F=[C,e,t].filter(Boolean).join(`
|
|
7
|
+
`);return b?(r.originalMessage=r.message,r.message=F):r=new Error(F),r.shortMessage=C,r.command=i,r.escapedCommand=l,r.exitCode=n,r.signal=o,r.signalDescription=f,r.stdout=t,r.stderr=e,r.cwd=d,s!==void 0&&(r.all=s),"bufferedData"in r&&delete r.bufferedData,r.failed=!0,r.timedOut=!!c,r.isCanceled=m,r.killed=p&&!c,r},ke=["stdin","stdout","stderr"],wn=t=>ke.some(e=>t[e]!==void 0),vn=t=>{if(!t)return;const{stdio:e}=t;if(e===void 0)return ke.map(r=>t[r]);if(wn(t))throw new Error(`It's not possible to provide \`stdio\` in combination with one of ${ke.map(r=>`\`${r}\``).join(", ")}`);if(typeof e=="string")return e;if(!Array.isArray(e))throw new TypeError(`Expected \`stdio\` to be of type \`string\` or \`Array\`, got \`${typeof e}\``);const s=Math.max(e.length,ke.length);return Array.from({length:s},(r,o)=>e[o])};var ie={exports:{}},Oe={exports:{}};Oe.exports;var xr;function bn(){return xr||(xr=1,function(t){t.exports=["SIGABRT","SIGALRM","SIGHUP","SIGINT","SIGTERM"],process.platform!=="win32"&&t.exports.push("SIGVTALRM","SIGXCPU","SIGXFSZ","SIGUSR2","SIGTRAP","SIGSYS","SIGQUIT","SIGIOT"),process.platform==="linux"&&t.exports.push("SIGIO","SIGPOLL","SIGPWR","SIGSTKFLT","SIGUNUSED")}(Oe)),Oe.exports}var S=k.process;const Z=function(t){return t&&typeof t=="object"&&typeof t.removeListener=="function"&&typeof t.emit=="function"&&typeof t.reallyExit=="function"&&typeof t.listeners=="function"&&typeof t.kill=="function"&&typeof t.pid=="number"&&typeof t.on=="function"};if(!Z(S))ie.exports=function(){return function(){}};else{var Pn=Yt,ue=bn(),$n=/^win/i.test(S.platform),Le=Vt;typeof Le!="function"&&(Le=Le.EventEmitter);var L;S.__signal_exit_emitter__?L=S.__signal_exit_emitter__:(L=S.__signal_exit_emitter__=new Le,L.count=0,L.emitted={}),L.infinite||(L.setMaxListeners(1/0),L.infinite=!0),ie.exports=function(t,e){if(!Z(k.process))return function(){};Pn.equal(typeof t,"function","a callback must be provided for exit handler"),de===!1&&Ar();var s="exit";e&&e.alwaysLast&&(s="afterexit");var r=function(){L.removeListener(s,t),L.listeners("exit").length===0&&L.listeners("afterexit").length===0&&ut()};return L.on(s,t),r};var ut=function(){!de||!Z(k.process)||(de=!1,ue.forEach(function(e){try{S.removeListener(e,dt[e])}catch{}}),S.emit=pt,S.reallyExit=Mr,L.count-=1)};ie.exports.unload=ut;var ae=function(e,s,r){L.emitted[e]||(L.emitted[e]=!0,L.emit(e,s,r))},dt={};ue.forEach(function(t){dt[t]=function(){if(Z(k.process)){var s=S.listeners(t);s.length===L.count&&(ut(),ae("exit",null,t),ae("afterexit",null,t),$n&&t==="SIGHUP"&&(t="SIGINT"),S.kill(S.pid,t))}}}),ie.exports.signals=function(){return ue};var de=!1,Ar=function(){de||!Z(k.process)||(de=!0,L.count+=1,ue=ue.filter(function(e){try{return S.on(e,dt[e]),!0}catch{return!1}}),S.emit=En,S.reallyExit=Cn)};ie.exports.load=Ar;var Mr=S.reallyExit,Cn=function(e){Z(k.process)&&(S.exitCode=e||0,ae("exit",S.exitCode,null),ae("afterexit",S.exitCode,null),Mr.call(S,S.exitCode))},pt=S.emit,En=function(e,s){if(e==="exit"&&Z(k.process)){s!==void 0&&(S.exitCode=s);var r=pt.apply(this,arguments);return ae("exit",S.exitCode,null),ae("afterexit",S.exitCode,null),r}else return pt.apply(this,arguments)}}var xn=ie.exports,An=se(xn);const Mn=1e3*5,Sn=(t,e="SIGTERM",s={})=>{const r=t(e);return Rn(t,e,s,r),r},Rn=(t,e,s,r)=>{if(!In(e,s,r))return;const o=On(s),n=setTimeout(()=>{t("SIGKILL")},o);n.unref&&n.unref()},In=(t,{forceKillAfterTimeout:e},s)=>kn(t)&&e!==!1&&s,kn=t=>t===_s.constants.signals.SIGTERM||typeof t=="string"&&t.toUpperCase()==="SIGTERM",On=({forceKillAfterTimeout:t=!0})=>{if(t===!0)return Mn;if(!Number.isFinite(t)||t<0)throw new TypeError(`Expected the \`forceKillAfterTimeout\` option to be a non-negative integer, got \`${t}\` (${typeof t})`);return t},Ln=(t,e)=>{t.kill()&&(e.isCanceled=!0)},Tn=(t,e,s)=>{t.kill(e),s(Object.assign(new Error("Timed out"),{timedOut:!0,signal:e}))},Nn=(t,{timeout:e,killSignal:s="SIGTERM"},r)=>{if(e===0||e===void 0)return r;let o;const n=new Promise((l,c)=>{o=setTimeout(()=>{Tn(t,s,c)},e)}),i=r.finally(()=>{clearTimeout(o)});return Promise.race([n,i])},Fn=({timeout:t})=>{if(t!==void 0&&(!Number.isFinite(t)||t<0))throw new TypeError(`Expected the \`timeout\` option to be a non-negative integer, got \`${t}\` (${typeof t})`)},_n=async(t,{cleanup:e,detached:s},r)=>{if(!e||s)return r;const o=An(()=>{t.kill()});return r.finally(()=>{o()})};function Sr(t){return t!==null&&typeof t=="object"&&typeof t.pipe=="function"}function Rr(t){return Sr(t)&&t.writable!==!1&&typeof t._write=="function"&&typeof t._writableState=="object"}const Dn=t=>t instanceof Ns&&typeof t.then=="function",ft=(t,e,s)=>{if(typeof s=="string")return t[e].pipe(Ds(s)),t;if(Rr(s))return t[e].pipe(s),t;if(!Dn(s))throw new TypeError("The second argument must be a string, a stream or an Execa child process.");if(!Rr(s.stdin))throw new TypeError("The target child process's stdin must be available.");return t[e].pipe(s.stdin),s},Gn=t=>{t.stdout!==null&&(t.pipeStdout=ft.bind(void 0,t,"stdout")),t.stderr!==null&&(t.pipeStderr=ft.bind(void 0,t,"stderr")),t.all!==void 0&&(t.pipeAll=ft.bind(void 0,t,"all"))};var pe={exports:{}};const{PassThrough:jn}=Xe;var Bn=t=>{t={...t};const{array:e}=t;let{encoding:s}=t;const r=s==="buffer";let o=!1;e?o=!(s||r):s=s||"utf8",r&&(s=null);const n=new jn({objectMode:o});s&&n.setEncoding(s);let i=0;const l=[];return n.on("data",c=>{l.push(c),o?i=l.length:i+=c.length}),n.getBufferedValue=()=>e?l:r?Buffer.concat(l,i):l.join(""),n.getBufferedLength=()=>i,n};const{constants:Hn}=js,Un=Xe,{promisify:qn}=Jt,zn=Bn,Kn=qn(Un.pipeline);class Ir extends Error{constructor(){super("maxBuffer exceeded"),this.name="MaxBufferError"}}async function ht(t,e){if(!t)throw new Error("Expected a stream");e={maxBuffer:1/0,...e};const{maxBuffer:s}=e,r=zn(e);return await new Promise((o,n)=>{const i=l=>{l&&r.getBufferedLength()<=Hn.MAX_LENGTH&&(l.bufferedData=r.getBufferedValue()),n(l)};(async()=>{try{await Kn(t,r),o()}catch(l){i(l)}})(),r.on("data",()=>{r.getBufferedLength()>s&&i(new Ir)})}),r.getBufferedValue()}pe.exports=ht,pe.exports.buffer=(t,e)=>ht(t,{...e,encoding:"buffer"}),pe.exports.array=(t,e)=>ht(t,{...e,array:!0}),pe.exports.MaxBufferError=Ir;var Wn=pe.exports,kr=se(Wn);const{PassThrough:Yn}=Xe;var Vn=function(){var t=[],e=new Yn({objectMode:!0});return e.setMaxListeners(0),e.add=s,e.isEmpty=r,e.on("unpipe",o),Array.prototype.slice.call(arguments).forEach(s),e;function s(n){return Array.isArray(n)?(n.forEach(s),this):(t.push(n),n.once("end",o.bind(null,n)),n.once("error",e.emit.bind(e,"error")),n.pipe(e,{end:!1}),this)}function r(){return t.length==0}function o(n){t=t.filter(function(i){return i!==n}),!t.length&&e.readable&&e.end()}},Jn=se(Vn);const Xn=t=>{if(t!==void 0)throw new TypeError("The `input` and `inputFile` options cannot be both set.")},Qn=({input:t,inputFile:e})=>typeof e!="string"?t:(Xn(t),Gs(e)),Zn=(t,e)=>{const s=Qn(e);s!==void 0&&(Sr(s)?s.pipe(t.stdin):t.stdin.end(s))},ei=(t,{all:e})=>{if(!e||!t.stdout&&!t.stderr)return;const s=Jn();return t.stdout&&s.add(t.stdout),t.stderr&&s.add(t.stderr),s},gt=async(t,e)=>{if(!(!t||e===void 0)){t.destroy();try{return await e}catch(s){return s.bufferedData}}},yt=(t,{encoding:e,buffer:s,maxBuffer:r})=>{if(!(!t||!s))return e?kr(t,{encoding:e,maxBuffer:r}):kr.buffer(t,{maxBuffer:r})},ti=async({stdout:t,stderr:e,all:s},{encoding:r,buffer:o,maxBuffer:n},i)=>{const l=yt(t,{encoding:r,buffer:o,maxBuffer:n}),c=yt(e,{encoding:r,buffer:o,maxBuffer:n}),m=yt(s,{encoding:r,buffer:o,maxBuffer:n*2});try{return await Promise.all([i,l,c,m])}catch(p){return Promise.all([{error:p,signal:p.signal,timedOut:p.timedOut},gt(t,l),gt(e,c),gt(s,m)])}},ri=(async()=>{})().constructor.prototype,si=["then","catch","finally"].map(t=>[t,Reflect.getOwnPropertyDescriptor(ri,t)]),Or=(t,e)=>{for(const[s,r]of si){const o=typeof e=="function"?(...n)=>Reflect.apply(r.value,e(),n):r.value.bind(e);Reflect.defineProperty(t,s,{...r,value:o})}},oi=t=>new Promise((e,s)=>{t.on("exit",(r,o)=>{e({exitCode:r,signal:o})}),t.on("error",r=>{s(r)}),t.stdin&&t.stdin.on("error",r=>{s(r)})}),Lr=(t,e=[])=>Array.isArray(e)?[t,...e]:[t],ni=/^[\w.-]+$/,ii=/"/g,ai=t=>typeof t!="string"||ni.test(t)?t:`"${t.replace(ii,'\\"')}"`,ci=(t,e)=>Lr(t,e).join(" "),li=(t,e)=>Lr(t,e).map(s=>ai(s)).join(" "),mi=Bs("execa").enabled,Te=(t,e)=>String(t).padStart(e,"0"),ui=()=>{const t=new Date;return`${Te(t.getHours(),2)}:${Te(t.getMinutes(),2)}:${Te(t.getSeconds(),2)}.${Te(t.getMilliseconds(),3)}`},di=(t,{verbose:e})=>{e&&q.stderr.write(`[${ui()}] ${t}
|
|
8
|
+
`)},pi=1e3*1e3*100,fi=({env:t,extendEnv:e,preferLocal:s,localDir:r,execPath:o})=>{const n=e?{...q.env,...t}:t;return s?Xo({env:n,cwd:r,execPath:o}):n},hi=(t,e,s={})=>{const r=Ko._parse(t,e,s);return t=r.command,e=r.args,s=r.options,s={maxBuffer:pi,buffer:!0,stripFinalNewline:!0,extendEnv:!0,preferLocal:!1,localDir:s.cwd||q.cwd(),execPath:q.execPath,encoding:"utf8",reject:!0,cleanup:!0,all:!1,windowsHide:!0,verbose:mi,...s},s.env=fi(s),s.stdio=vn(s),q.platform==="win32"&&re.basename(t,".exe")==="cmd"&&e.unshift("/q"),{file:t,args:e,options:s,parsed:r}},wt=(t,e,s)=>typeof e!="string"&&!Ts.isBuffer(e)?s===void 0?void 0:"":t.stripFinalNewline?Wo(e):e;function ee(t,e,s){const r=hi(t,e,s),o=ci(t,e),n=li(t,e);di(n,r.options),Fn(r.options);let i;try{i=zt.spawn(r.file,r.args,r.options)}catch(f){const h=new zt.ChildProcess,g=Promise.reject(Er({error:f,stdout:"",stderr:"",all:"",command:o,escapedCommand:n,parsed:r,timedOut:!1,isCanceled:!1,killed:!1}));return Or(h,g),h}const l=oi(i),c=Nn(i,r.options,l),m=_n(i,r.options,c),p={isCanceled:!1};i.kill=Sn.bind(null,i.kill.bind(i)),i.cancel=Ln.bind(null,i,p);const d=br(async()=>{const[{error:f,exitCode:h,signal:g,timedOut:y},b,C,F]=await ti(i,r.options,m),K=wt(r.options,b),W=wt(r.options,C),me=wt(r.options,F);if(f||h!==0||g!==null){const Y=Er({error:f,exitCode:h,signal:g,stdout:K,stderr:W,all:me,command:o,escapedCommand:n,parsed:r,timedOut:y,isCanceled:p.isCanceled||(r.options.signal?r.options.signal.aborted:!1),killed:i.killed});if(!r.options.reject)return Y;throw Y}return{command:o,escapedCommand:n,exitCode:0,stdout:K,stderr:W,all:me,failed:!1,timedOut:!1,isCanceled:!1,killed:!1}});return Zn(i,r.options),i.all=ei(i,r.options),Gn(i),Or(i,d),i}class R{static create(e,s){return new e(s)}}const Ne=t=>t&&`${t[0].toUpperCase()}${t.slice(1)}`,Fe=(t,e)=>{const s=Math.ceil(t),r=Math.floor(e);return Math.floor(Math.random()*(r-s+1))+s},gi=(t,e)=>t.disabled&&!e.disabled?1:!t.disabled&&e.disabled?-1:0,_e=t=>t.reduce((e,s)=>Array.isArray(s)?e.concat(_e(s)):e.concat(s),[]),Tr=(t,e=5)=>t.replace(/[\n\r]/g,"").split(" ").slice(0,e).join(" "),yi=t=>{let e=0;for(let s=0;s<t.length;s++){const r=t.charCodeAt(s);e=(e<<5)-e+r,e=e&e}return Math.abs(e)},wi=t=>{const e=t%360,s=65+t%15,r=45+t%10;return`hsl(${e}, ${s}%, ${r}%)`},vi=t=>{const[e,s,r]=t.match(/\d+/g).map((a,d)=>d===0?Number(a):Number(a)/100),o=(1-Math.abs(2*r-1))*s,n=o*(1-Math.abs(e/60%2-1)),i=r-o/2;let l,c,m;e<60?[l,c,m]=[o,n,0]:e<120?[l,c,m]=[n,o,0]:e<180?[l,c,m]=[0,o,n]:e<240?[l,c,m]=[0,n,o]:e<300?[l,c,m]=[n,0,o]:[l,c,m]=[o,0,n];const p=a=>{const d=Math.round((a+i)*255).toString(16);return d.length===1?"0"+d:d};return`#${p(l)}${p(c)}${p(m)}`},bi=t=>{const e=yi(t),s=wi(e);return{primary:vi(s),secondary:"#FFFFFF"}};class j{constructor(e){this.handleError$=s=>{let r="An error occurred";return s.message&&(r=s.message),O({name:`${this.errorPrefix} ${r}`,value:r,isError:!0,disabled:!0})},this.serviceName="AI",this.errorPrefix="ERROR",this.colors={primary:""}}parseMessage(e,s,r){try{let o;const n=m=>m.replace(/[\u0000-\u001F\u007F-\u009F]/g,"").replace(/\\(?!["\\/bfnrtu])/g,"\\\\"),i=/\[\s*\{[\s\S]*?\}\s*\]/,l=e.match(i);if(l)try{const m=JSON.parse(n(l[0]));o=Array.isArray(m)?m:[m]}catch{return[]}else{const m=/\{[\s\S]*?\}/,p=e.match(m);if(!p)return[];try{o=[JSON.parse(n(p[0]))]}catch{return[]}}return!o.length||!o.every(m=>typeof m.subject=="string")?[]:o.map(m=>this.extractMessageAsType(m,s)).map(m=>({title:`${m.subject}`,value:`${m.subject}${m.body?`
|
|
29
9
|
|
|
30
|
-
${
|
|
10
|
+
${m.body}`:""}${m.footer?`
|
|
31
11
|
|
|
32
|
-
${
|
|
12
|
+
${m.footer}`:""}`})).slice(0,r)}catch{return[]}}extractMessageAsType(e,s){switch(s){case"conventional":const r=/(\w+)(?:\(.*?\))?:\s*(.*)/,o=e.subject.match(r),n=o?o[0]:e.subject;return{...e,subject:this.normalizeCommitMessage(n)};case"gitmoji":const i=/:\w*:\s*(.*)/,l=e.subject.match(i);return{...e,subject:l?l[0].toLowerCase():e.subject};default:return e}}normalizeCommitMessage(e){const s=/^(\w+)(\(.*?\))?:\s(.*)$/,r=e.match(s);if(r){const[,o,n,i]=r,l=o.toLowerCase(),c=i.charAt(0).toLowerCase()+i.slice(1);e=`${l}${n||""}: ${c}`}return e}sanitizeResponse(e){if(typeof e=="string")try{return[{title:`${Tr(e)}...`,value:e}]}catch{return[]}return e.map(s=>{try{return{title:`${Tr(s)}...`,value:s}}catch{return{title:"",value:""}}})}}var Nr="2.2.14",Pi="A Reactive CLI that generates git commit messages with various AI";class v extends Error{}const vt=" ",te=t=>{t instanceof Error&&(t instanceof v||(t.stack&&console.error(w.dim(t.stack.split(`
|
|
33
13
|
`).slice(1).join(`
|
|
34
14
|
`))),console.error(`
|
|
35
|
-
${
|
|
36
|
-
${
|
|
37
|
-
${
|
|
38
|
-
${
|
|
39
|
-
${e}`;if(
|
|
40
|
-
${
|
|
15
|
+
${vt}${w.dim(`aicommit2 v${Nr}`)}`),console.error(`
|
|
16
|
+
${vt}Please open a Bug report with the information above:`),console.error(`${vt}https://github.com/tak-bro/aicommit2/issues/new/choose`)))},Fr=T.join(Ze.homedir(),".aicommit2_log"),$i=new Date,B=(t,e,s,r,o)=>{const n=`[${t}]`,i=Ci($i,e,o),l=`${Fr}/${i}`,c=`- System Prompt
|
|
17
|
+
${s}`,m=`- Response
|
|
18
|
+
${r}`,p=`[Git Diff]
|
|
19
|
+
${e}`;if(_.existsSync(l)){const a=_.readFileSync(l,"utf-8");_r(l,`${n}
|
|
20
|
+
${m}
|
|
41
21
|
|
|
42
|
-
${
|
|
22
|
+
${c}
|
|
43
23
|
|
|
44
|
-
${
|
|
45
|
-
${
|
|
24
|
+
${a}`);return}_r(l,`${n}
|
|
25
|
+
${m}
|
|
46
26
|
|
|
47
|
-
${
|
|
27
|
+
${c}
|
|
48
28
|
|
|
49
|
-
${
|
|
29
|
+
${p}`)},Ci=(t,e,s)=>{const{year:r,month:o,day:n,hours:i,minutes:l,seconds:c}=Ei(t),p=qs(0).update(e).digest("hex");return s==="review"?`aic2_review_${r}-${o}-${n}_${i}-${l}-${c}_${p}.log`:`aic2_${r}-${o}-${n}_${i}-${l}-${c}_${p}.log`},_r=(t,e="")=>{_.mkdirSync(T.dirname(t),{recursive:!0}),_.writeFileSync(t,e,"utf-8")},Ei=t=>{const e=t.getFullYear().toString(),s=(t.getMonth()+1).toString().padStart(2,"0"),r=t.getDate().toString().padStart(2,"0"),o=t.getHours().toString().padStart(2,"0"),n=t.getMinutes().toString().padStart(2,"0"),i=t.getSeconds().toString().padStart(2,"0");return{year:e,month:s,day:r,hours:o,minutes:n,seconds:i}},G={locale:"en",maxLength:50,type:"conventional",generate:1,systemPrompt:"",systemPromptPath:"",codeReviewPromptPath:""},xi={"":"<commit message>",conventional:`<type>(<optional scope>): <description>
|
|
50
30
|
|
|
51
31
|
[optional body]
|
|
52
32
|
|
|
@@ -54,118 +34,117 @@ ${m}`)},vu=(t,e,r)=>{const{year:o,month:n,day:s,hours:i,minutes:u,seconds:a}=bu(
|
|
|
54
34
|
|
|
55
35
|
[optional body]
|
|
56
36
|
|
|
57
|
-
[optional footer(s)]`},
|
|
37
|
+
[optional footer(s)]`},Ai={"":"",gitmoji:`
|
|
58
38
|
${Object.entries({":sparkles:":"Introduce new features.",":bug:":"Fix a bug.",":memo:":"Add or update documentation.",":art:":"Improve structure / format of the code.",":zap:":"Improve performance.",":fire:":"Remove code or files.",":ambulance:":"Critical hotfix.",":white_check_mark:":"Add, update, or pass tests.",":lock:":"Fix security or privacy issues.",":rocket:":"Deploy stuff.",":lipstick:":"Add or update the UI and style files.",":tada:":"Begin a project.",":recycle:":"Refactor code.",":wrench:":"Add or update configuration files.",":bulb:":"Add or update comments in source code.",":twisted_rightwards_arrows:":"Merge branches."}).map(([t,e])=>` - ${t}: ${e}`).join(`
|
|
59
39
|
`)}`,conventional:`
|
|
60
40
|
${Object.entries({docs:"Documentation only changes",style:"Changes that do not affect the meaning of the code (white-space, formatting, missing semi-colons, etc)",refactor:"A code change that neither fixes a bug nor adds a feature",perf:"A code change that improves performance",test:"Adding missing tests or correcting existing tests",build:"Changes that affect the build system or external dependencies",ci:"Changes to CI configuration files, scripts",chore:"Other changes that don't modify src or test files",revert:"Reverts a previous commit",feat:"A new feature",fix:"A bug fix"}).map(([t,e])=>` - ${t}: ${e}`).join(`
|
|
61
|
-
`)}`},
|
|
62
|
-
`)},
|
|
41
|
+
`)}`},Dr=(t,e)=>t.replace(/{(\w+)}/g,(s,r)=>e[r]?.toString()||G[r]?.toString()),Gr=t=>{const{type:e,maxLength:s,generate:r,locale:o}=t;return[`You are a helpful assistant specializing in writing clear and informative Git commit messages using the ${e} style`,`Based on the given code changes or context, generate exactly ${r} ${e} Git commit message${r!==1?"s":""} based on the following guidelines.`,`1. Message Language: ${o}`,`2. Format: follow the ${e} Commits format:`,`${xi[e]}`,`3. Types: use one of the following types:${Ai[e]}`,"4. Guidelines for writing commit messages:"," - Be specific about what changes were made",' - Use imperative mood ("add feature" not "added feature")',` - Keep subject line under ${s} characters`," - Do not end the subject line with a period"," - Use the body to explain what and why vs. how","5. Focus on:"," - What problem this commit solves"," - Why this change was necessary"," - Any important technical details","6. Exclude anything unnecessary such as translation or implementation details."].filter(Boolean).join(`
|
|
42
|
+
`)},De=(t,e)=>{const s=r=>r==="conventional"?`${Array(e).fill(null).map((o,n)=>`
|
|
63
43
|
{
|
|
64
44
|
"subject": "fix(auth): fix bug in user authentication process",
|
|
65
45
|
"body": "- Update login function to handle edge cases\\n- Add additional error logging for debugging",
|
|
66
46
|
"footer": ""
|
|
67
|
-
}`).join(",")}`:`${Array(e).fill(null).map((n
|
|
47
|
+
}`).join(",")}`:`${Array(e).fill(null).map((o,n)=>`
|
|
68
48
|
{
|
|
69
49
|
"subject": ":sparkles: Add real-time chat feature",
|
|
70
50
|
"body": "- Implement WebSocket connection\\n- Add message encryption\\n- Include typing indicators",
|
|
71
51
|
"footer": ""
|
|
72
52
|
}`).join(",")}`;return[`
|
|
73
53
|
Lastly, Provide your response as a JSON array containing exactly ${e} object${e!==1?"s":""}, each with the following keys:`,`- "subject": The main commit message using the ${t} style. It should be a concise summary of the changes.`,'- "body": An optional detailed explanation of the changes. If not needed, use an empty string.','- "footer": An optional footer for metadata like BREAKING CHANGES. If not needed, use an empty string.',`The array must always contain ${e} element${e!==1?"s":""}, no more and no less.`,`Example response format:
|
|
74
|
-
[${
|
|
54
|
+
[${s(t)}
|
|
75
55
|
]`,`Ensure you generate exactly ${e} commit message${e!==1?"s":""}, even if it requires creating slightly varied versions for similar changes.`,"The response should be valid JSON that can be parsed without errors."].filter(Boolean).join(`
|
|
76
|
-
`)},
|
|
77
|
-
${
|
|
78
|
-
${
|
|
79
|
-
${
|
|
80
|
-
${
|
|
56
|
+
`)},H=t=>{const{systemPrompt:e,systemPromptPath:s,type:r,generate:o}=t;if(e)return`${e}
|
|
57
|
+
${De(r,o)}`;if(!s)return`${Gr(t)}
|
|
58
|
+
${De(r,o)}`;try{const n=_.readFileSync(T.resolve(s),"utf-8");return`${Dr(n,t)}
|
|
59
|
+
${De(r,o)}`}catch{return`${Gr(t)}
|
|
60
|
+
${De(r,o)}`}},U=t=>{const{codeReviewPromptPath:e,locale:s}=t,r=`I'll give you the output of the "git diff" command as an input. Please review the following code and provide your feedback in Markdown format. Focus on:
|
|
81
61
|
|
|
82
|
-
1. Language: ${
|
|
62
|
+
1. Language: ${s}
|
|
83
63
|
2. Code quality and best practices
|
|
84
64
|
3. Potential bugs or errors
|
|
85
65
|
4. Performance improvements
|
|
86
66
|
5. Readability and maintainability
|
|
87
67
|
|
|
88
|
-
Please structure your response with appropriate Markdown headings, code blocks, and bullet points.`;if(!e)return o;try{const n=T.readFileSync(k.resolve(e),"utf-8");return`${wo(n,t)}`}catch{return o}},bo=async t=>{if(t.systemPromptPath)try{T.readFileSync(k.resolve(t.systemPromptPath),"utf-8")}catch{throw new y(`Error reading system prompt file: ${t.systemPromptPath}`)}if(t.codeReview&&t.codeReviewPromptPath)try{T.readFileSync(k.resolve(t.codeReviewPromptPath),"utf-8")}catch{throw new y(`Error reading code review prompt file: ${t.codeReviewPromptPath}`)}},Pu=10*60*1e3;class $o extends G{constructor(e){super(e),this.params=e,this.handleError$=r=>{const o=r.error?.error?.message?.replace(/(\r\n|\n|\r)/gm,"")||"An error occurred";return O({name:`${this.errorPrefix} ${o}`,value:o,isError:!0,disabled:!0})},this.colors={primary:"#AE5630",secondary:"#fff"},this.serviceName=C.bgHex(this.colors.primary).hex(this.colors.secondary).bold("[Anthropic]"),this.errorPrefix=C.red.bold("[Anthropic]"),this.anthropic=new Pn({apiKey:this.params.config.key,...this.params.config.timeout>Pu&&{timeout:this.params.config.timeout}})}generateCommitMessage$(){return P(this.generateMessage("commit")).pipe(A(e=>v(e)),b(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:this.params.config.includeBody?e.value:e.title,description:this.params.config.includeBody?e.value:"",isError:!1})),$(this.handleError$))}generateCodeReview$(){return P(this.generateMessage("review")).pipe(A(e=>v(e)),b(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:e.value,description:e.value,isError:!1})),$(this.handleError$))}async generateMessage(e){try{const r=this.params.stagedDiff.diff,{systemPrompt:o,systemPromptPath:n,codeReviewPromptPath:s,logging:i,temperature:u,locale:a,generate:l,type:m,maxLength:c,maxTokens:D,topP:d,model:f}=this.params.config,h={...j,locale:a,maxLength:c,type:m,generate:l,systemPrompt:o,systemPromptPath:n,codeReviewPromptPath:s},g=e==="review"?q(h):U(h),E={max_tokens:D,temperature:u,system:g,messages:[{role:"user",content:`Here is the diff: ${r}`}],top_p:d,model:f},S=(await this.anthropic.messages.create(E)).content.map(({text:J})=>J).join("");return i&&H("Anthropic",r,g,S,e),e==="review"?this.sanitizeResponse(S):this.parseMessage(S,m,l)}catch(r){const o=r;throw o.code==="ENOTFOUND"?new y(`Error connecting to ${o.hostname} (${o.syscall})`):o}}}class Ce{constructor(e={}){if(!e.method)throw new Error("method should be defined!");if(!e.baseURL)throw new Error("baseURL should be defined!");this.config={...e},this.axiosInstance=xn.create(this.config)}setHeaders(e){return this.config.headers=e,this}setParams(e){return this.config.params=e,this}setBody(e){return this.config.data=e,this}addBody(e){return this.config.data={...this.config.data,...e},this}setMethod(e){return this.config.method=e,this}async execute(){try{return await this.axiosInstance.request(this.config)}catch(e){throw e}}}class Ao extends G{constructor(e){super(e),this.params=e,this.host="https://codestral.mistral.ai",this.apiKey="",this.handleError$=r=>{const o=r.message?.replace(/(\r\n|\n|\r)/gm,"")||"An error occurred";return O({name:`${this.errorPrefix} ${o}`,value:o,isError:!0,disabled:!0})},this.colors={primary:"#e28c58",secondary:"#fff"},this.serviceName=C.bgHex(this.colors.primary).hex(this.colors.secondary).bold("[Codestral]"),this.errorPrefix=C.red.bold("[Codestral]"),this.apiKey=this.params.config.key}generateCommitMessage$(){return P(this.generateMessage("commit")).pipe(A(e=>v(e)),b(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:this.params.config.includeBody?e.value:e.title,description:this.params.config.includeBody?e.value:"",isError:!1})),$(this.handleError$))}generateCodeReview$(){return P(this.generateMessage("review")).pipe(A(e=>v(e)),b(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:e.value,description:e.value,isError:!1})),$(this.handleError$))}async generateMessage(e){try{const r=this.params.stagedDiff.diff,{systemPrompt:o,systemPromptPath:n,codeReviewPromptPath:s,logging:i,locale:u,generate:a,type:l,maxLength:m}=this.params.config,c={...j,locale:u,maxLength:m,type:l,generate:a,systemPrompt:o,systemPromptPath:n,codeReviewPromptPath:s},D=e==="review"?q(c):U(c);this.checkAvailableModels();const d=await this.createChatCompletions(D,e);return i&&H("Codestral",r,D,d,e),e==="review"?this.sanitizeResponse(d):this.parseMessage(d,l,a)}catch(r){const o=r;throw o.code==="ENOTFOUND"?new y(`Error connecting to ${o.hostname} (${o.syscall})`):o}}checkAvailableModels(){if(["codestral-latest","codestral-2501"].includes(this.params.config.model))return!0;throw new Error("Invalid model type of Codestral AI")}async createChatCompletions(e,r){const o=new Ce({method:"POST",baseURL:`${this.host}/v1/chat/completions`,timeout:this.params.config.timeout}).setHeaders({Authorization:`Bearer ${this.apiKey}`,"content-type":"application/json"}).setBody({model:this.params.config.model,messages:[{role:"system",content:e},{role:"user",content:`Here is the diff: ${this.params.stagedDiff.diff}`}],temperature:this.params.config.temperature,top_p:this.params.config.topP,max_tokens:this.params.config.maxTokens,stream:!1,safe_prompt:!1,random_seed:qe(10,1e3)});r==="commit"&&o.addBody({response_format:{type:"json_object"}});const s=(await o.execute()).data;if(!s.choices||s.choices.length===0||!s.choices[0].message?.content)throw new Error("No Content on response. Please open a Bug report");return s.choices[0].message.content}}const Bu=2*60*1e3;class Po extends G{constructor(e){super(e),this.params=e,this.handleError$=r=>{const o=/"message":\s*"([^"]*)"/,n=r.message.match(o);let s=r?.body?.message;n&&n[1]&&(s=n[1]);const i=`${r.statusCode} ${s}`;return O({name:`${this.errorPrefix} ${i}`,value:s,isError:!0,disabled:!0})},this.colors={primary:"#D18EE2",secondary:"#fff"},this.serviceName=C.bgHex(this.colors.primary).hex(this.colors.secondary).bold("[Cohere]"),this.errorPrefix=C.red.bold("[Cohere]"),this.cohere=new Mn({token:this.params.config.key})}generateCommitMessage$(){return P(this.generateMessage("commit")).pipe(A(e=>v(e)),b(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:this.params.config.includeBody?e.value:e.title,description:this.params.config.includeBody?e.value:"",isError:!1})),$(this.handleError$))}generateCodeReview$(){return P(this.generateMessage("review")).pipe(A(e=>v(e)),b(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:e.value,description:e.value,isError:!1})),$(this.handleError$))}async generateMessage(e){try{const r=this.params.stagedDiff.diff,{systemPrompt:o,systemPromptPath:n,codeReviewPromptPath:s,logging:i,temperature:u,locale:a,generate:l,type:m,maxLength:c,maxTokens:D}=this.params.config,d={...j,locale:a,maxLength:c,type:m,generate:l,systemPrompt:o,systemPromptPath:n,codeReviewPromptPath:s},f=e==="review"?q(d):U(d),h=await this.cohere.chat({chatHistory:f?[{role:"SYSTEM",message:f}]:[],message:`Here is the diff: ${r}`,connectors:[{id:"web-search"}],maxTokens:D,temperature:u,model:this.params.config.model,seed:qe(10,1e3),p:this.params.config.topP},{...this.params.config.timeout>Bu&&{timeoutInSeconds:Math.floor(this.params.config.timeout/1e3)}});return i&&H("Cohere",r,f,h.text,e),e==="review"?this.sanitizeResponse(h.text):this.parseMessage(h.text,m,l)}catch(r){const o=r;throw o instanceof Sn?new y("Request timed out error!"):o}}}class Bo extends G{constructor(e){super(e),this.params=e,this.host="https://api.deepseek.com",this.handleError$=r=>{const o=r.message?.replace(/(\r\n|\n|\r)/gm,"")||"An error occurred";return O({name:`${this.errorPrefix} ${o}`,value:o,isError:!0,disabled:!0})},this.colors={primary:"#53a3f9",secondary:"#fff"},this.serviceName=C.bgHex(this.colors.primary).hex(this.colors.secondary).bold("[DeepSeek]"),this.errorPrefix=C.red.bold("[DeepSeek]"),this.deepSeek=new xe({baseURL:this.host,apiKey:this.params.config.key})}generateCommitMessage$(){return P(this.generateMessage("commit")).pipe(A(e=>v(e)),b(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:this.params.config.includeBody?e.value:e.title,description:this.params.config.includeBody?e.value:"",isError:!1})),$(this.handleError$))}generateCodeReview$(){return P(this.generateMessage("review")).pipe(A(e=>v(e)),b(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:e.value,description:e.value,isError:!1})),$(this.handleError$))}async generateMessage(e){try{const r=this.params.stagedDiff.diff,{systemPrompt:o,systemPromptPath:n,codeReviewPromptPath:s,logging:i,locale:u,generate:a,type:l,maxLength:m}=this.params.config,c={...j,locale:u,maxLength:m,type:l,generate:a,systemPrompt:o,systemPromptPath:n,codeReviewPromptPath:s},D=e==="review"?q(c):U(c);this.checkAvailableModels();const d=await this.createChatCompletions(D);return i&&H("DeepSeek",r,D,d,e),e==="review"?this.sanitizeResponse(d):this.parseMessage(d,l,a)}catch(r){const o=r;throw o.code==="ENOTFOUND"?new y(`Error connecting to ${o.hostname} (${o.syscall})`):o}}checkAvailableModels(){if(["deepseek-reasoner","deepseek-chat"].includes(this.params.config.model))return!0;throw new Error("Invalid model type of DeepSeek")}async createChatCompletions(e){return(await this.deepSeek.chat.completions.create({messages:[{role:"system",content:e},{role:"user",content:`Here is the diff: ${this.params.stagedDiff.diff}`}],model:this.params.config.model,max_tokens:this.params.config.maxTokens,top_p:this.params.config.topP,temperature:this.params.config.temperature},{timeout:this.params.config.timeout})).choices[0].message.content||""}}class xo extends G{constructor(e){super(e),this.params=e,this.handleError$=r=>{const o=r.message||r.toString(),n=/(\[.*?\]\s*[^[]*)/g,s=[...o.matchAll(n)],i=[];s.forEach(a=>i.push(a[1]));const u=i[1]||"An error occurred";return O({name:`${this.errorPrefix} ${u}`,value:u,isError:!0,disabled:!0})},this.colors={primary:"#0077FF",secondary:"#fff"},this.serviceName=C.bgHex(this.colors.primary).hex(this.colors.secondary).bold("[Gemini]"),this.errorPrefix=C.red.bold("[Gemini]"),this.genAI=new Rn(this.params.config.key)}generateCommitMessage$(){return P(this.generateMessage("commit")).pipe(A(e=>v(e)),b(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:this.params.config.includeBody?e.value:e.title,description:this.params.config.includeBody?e.value:"",isError:!1})),$(this.handleError$))}generateCodeReview$(){return P(this.generateMessage("review")).pipe(A(e=>v(e)),b(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:e.value,description:e.value,isError:!1})),$(this.handleError$))}async generateMessage(e){try{const r=this.params.stagedDiff.diff,{systemPrompt:o,systemPromptPath:n,logging:s,locale:i,codeReviewPromptPath:u,generate:a,type:l,maxLength:m}=this.params.config,c=this.params.config.maxTokens,D={...j,locale:i,maxLength:m,type:l,generate:a,systemPrompt:o,systemPromptPath:n,codeReviewPromptPath:u},d=e==="review"?q(D):U(D),f={maxOutputTokens:c,temperature:this.params.config.temperature,topP:this.params.config.topP},w=(await this.genAI.getGenerativeModel({model:this.params.config.model,systemInstruction:d,generationConfig:f,safetySettings:[{category:Me.HARM_CATEGORY_HATE_SPEECH,threshold:Se.BLOCK_LOW_AND_ABOVE},{category:Me.HARM_CATEGORY_SEXUALLY_EXPLICIT,threshold:Se.BLOCK_LOW_AND_ABOVE},{category:Me.HARM_CATEGORY_HARASSMENT,threshold:Se.BLOCK_LOW_AND_ABOVE},{category:Me.HARM_CATEGORY_DANGEROUS_CONTENT,threshold:Se.BLOCK_LOW_AND_ABOVE}]}).generateContent(`Here is the diff: ${r}`)).response.text();return s&&H("Gemini",r,d,w,e),e==="review"?this.sanitizeResponse(w):this.parseMessage(w,l,a)}catch(r){const o=r;throw o.code==="ENOTFOUND"?new y(`Error connecting to ${o.hostname} (${o.syscall})`):o}}}class Mo extends G{constructor(e){super(e),this.params=e,this.handleError$=r=>{let o="N/A",n="An error occurred";r instanceof Er.APIError&&(o=`${r.status}`,n=r.name);const s=`${o} ${n}`;return O({name:`${this.errorPrefix} ${s}`,value:n,isError:!0,disabled:!0})},this.colors={primary:"#f55036",secondary:"#fff"},this.serviceName=C.bgHex(this.colors.primary).hex(this.colors.secondary).bold("[Groq]"),this.errorPrefix=C.red.bold("[Groq]"),this.groq=new Er({apiKey:this.params.config.key})}generateCommitMessage$(){return P(this.generateMessage("commit")).pipe(A(e=>v(e)),b(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:this.params.config.includeBody?e.value:e.title,description:this.params.config.includeBody?e.value:"",isError:!1})),$(this.handleError$))}generateCodeReview$(){return P(this.generateMessage("review")).pipe(A(e=>v(e)),b(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:e.value,description:e.value,isError:!1})),$(this.handleError$))}async generateMessage(e){try{const r=this.params.stagedDiff.diff,{systemPrompt:o,systemPromptPath:n,codeReviewPromptPath:s,logging:i,locale:u,temperature:a,generate:l,type:m,maxLength:c}=this.params.config,D=this.params.config.maxTokens,d={...j,locale:u,maxLength:c,type:m,generate:l,systemPrompt:o,systemPromptPath:n,codeReviewPromptPath:s},f=e==="review"?q(d):U(d),g=(await this.groq.chat.completions.create({messages:[{role:"system",content:f},{role:"user",content:`Here is the diff: ${r}`}],model:this.params.config.model,max_tokens:D,top_p:this.params.config.topP,temperature:a},{timeout:this.params.config.timeout})).choices[0].message.content||"";return i&&H("Groq",r,f,g,e),e==="review"?this.sanitizeResponse(g):this.parseMessage(g,m,l)}catch(r){throw r}}}class So extends G{constructor(e){super(e),this.params=e,this.headers={accept:"*/*","accept-language":"en-US,en;q=0.9","sec-ch-ua":'"Chromium";v="116", "Not)A;Brand";v="24", "Google Chrome";v="116"',"sec-ch-ua-mobile":"?0","sec-ch-ua-platform":'"Windows"',"sec-fetch-dest":"empty","sec-fetch-mode":"cors","sec-fetch-site":"same-origin",origin:"https://huggingface.co","Referrer-Policy":"strict-origin-when-cross-origin"},this.models=[],this.currentModelId=null,this.currentConversation=void 0,this.currentConversionID=void 0,this.cookie="",this.colors={primary:"#FED21F",secondary:"#000"},this.serviceName=C.bgHex(this.colors.primary).hex(this.colors.secondary).bold("[HuggingFace]"),this.errorPrefix=C.red.bold("[HuggingFace]"),this.cookie=this.params.config.cookie}generateCommitMessage$(){return P(this.generateMessage("commit")).pipe(A(e=>v(e)),b(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:this.params.config.includeBody?e.value:e.title,description:this.params.config.includeBody?e.value:"",isError:!1})),$(this.handleError$))}generateCodeReview$(){return P(this.generateMessage("review")).pipe(A(e=>v(e)),b(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:e.value,description:e.value,isError:!1})),$(this.handleError$))}async generateMessage(e){try{await this.intialize();const r=this.params.stagedDiff.diff,{systemPrompt:o,systemPromptPath:n,codeReviewPromptPath:s,logging:i,locale:u,generate:a,type:l,maxLength:m}=this.params.config,c={...j,locale:u,maxLength:m,type:l,generate:a,systemPrompt:o,systemPromptPath:n,codeReviewPromptPath:s},D=e==="review"?q(c):U(c),d=await this.getNewChat(D),h=await(await this.sendMessage(`Here is the diff: ${r}`,d.id)).completeResponsePromise();return await this.deleteConversation(d.id),i&&H("HuggingFace",r,D,h,e),e==="review"?this.sanitizeResponse(h):this.parseMessage(h,l,a)}catch(r){const o=r;throw o.code==="ENOTFOUND"?new y(`Error connecting to ${o.hostname} (${o.syscall})`):o}}async intialize(){const e=await this.getRemoteLlms(),r=e.find(o=>o.name?.toLowerCase()===this.params.config.model.toLowerCase());if(r){this.currentModel=r,this.currentModelId=r.id;return}this.currentModel=e[0],this.currentModelId=e[0].id}async getRemoteLlms(){const e=await fetch("https://huggingface.co/chat/__data.json",{headers:{...this.headers,cookie:this.cookie},body:null,method:"GET"});if(e.status!==200)throw new Error(`Failed to get remote LLMs with status code: ${e.status}`);const o=(await e.json()).nodes[0].data,n=o[o[0].models],s=[],i=u=>u===-1?null:o[u];for(const u of n){const a=o[u];if(o[a.unlisted])continue;const l={id:i(a.id),name:i(a.name),displayName:i(a.displayName),preprompt:i(a.preprompt),promptExamples:[],websiteUrl:i(a.websiteUrl),description:i(a.description),datasetName:i(a.datasetName),datasetUrl:i(a.datasetUrl),modelUrl:i(a.modelUrl),parameters:{}},m=i(a.promptExamples);if(m!==null){const d=m.map(f=>i(f));l.promptExamples=d.map(f=>({title:o[f.title],prompt:o[f.prompt]}))}const c=i(a.parameters),D={};for(const[d,f]of Object.entries(c)){if(f===-1){D[d]=null;continue}if(Array.isArray(o[f])){D[d]=o[f].map(h=>o[h]);continue}D[d]=o[f]}l.parameters=D,s.push(l)}return this.models=s,s}async getNewChat(e){const r={model:this.currentModelId,preprompt:e};let o=0;for(;o<5;){const n=await fetch("https://huggingface.co/chat/conversation",{headers:{...this.headers,"content-type":"application/json",cookie:this.cookie,Referer:"https://huggingface.co/chat/"},body:JSON.stringify(r),method:"POST"}),{conversationId:s}=await n.json();if(s){this.currentConversionID=s;break}else o++}if(!this.currentConversionID)throw new Error("Failed to create new conversion");return await this.getConversationHistory(this.currentConversionID)}async getConversationHistory(e){if(!e)throw new Error("conversationId is required for getConversationHistory");const r=await fetch("https://huggingface.co/chat/conversation/"+e+"/__data.json",{headers:{...this.headers,cookie:this.cookie,Referer:"https://huggingface.co/chat/"},body:null,method:"GET"});if(r.status!=200)throw new Error("Unable get conversation details "+r);{const o=await r.json();return this.metadataParser(o,e)}}metadataParser(e,r){const o={id:"",model:"",systemPrompt:"",title:"",history:[]},n=e.nodes[1].data,s=n[n[0].model],i=n[n[0].preprompt],u=n[n[0].title],a=n[n[0].messages],l=[];for(const m of a){const c=n[m],D=new Date(n[c.createdAt][1]).getTime()/1e3,d=new Date(n[c.updatedAt][1]).getTime()/1e3;l.push({id:n[c.id],role:n[c.from],content:n[c.content],createdAt:D,updatedAt:d})}return o.id=r,o.model=s,o.systemPrompt=i,o.title=u,o.history=l,this.currentConversation=o,o}async sendMessage(e,r){if(e==="")throw new Error("the prompt can not be empty.");if(!r&&!this.currentConversionID?await this.getNewChat():r?(this.currentConversionID=r,await this.getConversationHistory(r)):this.currentConversionID&&await this.getConversationHistory(this.currentConversionID),!this.currentConversation)throw new Error("Failed to create new conversion");const o={inputs:e,id:this.currentConversation.history[this.currentConversation.history.length-1].id,is_retry:!1,is_continue:!1,web_search:!1,tools:[]},n=new FormData;n.append("data",JSON.stringify(o));const s=await fetch("https://huggingface.co/chat/conversation/"+this.currentConversionID,{headers:{...this.headers,cookie:this.cookie,Referer:"https://huggingface.co/chat/conversation/"+this.currentConversionID},body:n,method:"POST"});function i(D){try{const d=D.split(`
|
|
89
|
-
`),
|
|
68
|
+
Please structure your response with appropriate Markdown headings, code blocks, and bullet points.`;if(!e)return r;try{const o=_.readFileSync(T.resolve(e),"utf-8");return`${Dr(o,t)}`}catch{return r}},jr=async t=>{if(t.systemPromptPath)try{_.readFileSync(T.resolve(t.systemPromptPath),"utf-8")}catch{throw new v(`Error reading system prompt file: ${t.systemPromptPath}`)}if(t.codeReview&&t.codeReviewPromptPath)try{_.readFileSync(T.resolve(t.codeReviewPromptPath),"utf-8")}catch{throw new v(`Error reading code review prompt file: ${t.codeReviewPromptPath}`)}},Mi=10*60*1e3;class Br extends j{constructor(e){super(e),this.params=e,this.handleError$=s=>{const r=s.error?.error?.message?.replace(/(\r\n|\n|\r)/gm,"")||"An error occurred";return O({name:`${this.errorPrefix} ${r}`,value:r,isError:!0,disabled:!0})},this.colors={primary:"#AE5630",secondary:"#fff"},this.serviceName=w.bgHex(this.colors.primary).hex(this.colors.secondary).bold("[Anthropic]"),this.errorPrefix=w.red.bold("[Anthropic]"),this.anthropic=new Us({apiKey:this.params.config.key,...this.params.config.timeout>Mi&&{timeout:this.params.config.timeout}})}generateCommitMessage$(){return M(this.generateMessage("commit")).pipe(A(e=>$(e)),E(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:this.params.config.includeBody?e.value:e.title,description:this.params.config.includeBody?e.value:"",isError:!1})),x(this.handleError$))}generateCodeReview$(){return M(this.generateMessage("review")).pipe(A(e=>$(e)),E(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:e.value,description:e.value,isError:!1})),x(this.handleError$))}async generateMessage(e){try{const s=this.params.stagedDiff.diff,{systemPrompt:r,systemPromptPath:o,codeReviewPromptPath:n,logging:i,temperature:l,locale:c,generate:m,type:p,maxLength:a,maxTokens:d,topP:f,model:h}=this.params.config,g={...G,locale:c,maxLength:a,type:p,generate:m,systemPrompt:r,systemPromptPath:o,codeReviewPromptPath:n},y=e==="review"?U(g):H(g),b={max_tokens:d,temperature:l,system:y,messages:[{role:"user",content:`Here is the diff: ${s}`}],top_p:f,model:h},F=(await this.anthropic.messages.create(b)).content.map(({text:K})=>K).join("");return i&&B("Anthropic",s,y,F,e),e==="review"?this.sanitizeResponse(F):this.parseMessage(F,p,m)}catch(s){const r=s;throw r.code==="ENOTFOUND"?new v(`Error connecting to ${r.hostname} (${r.syscall})`):r}}}class fe{constructor(e={}){if(!e.method)throw new Error("method should be defined!");if(!e.baseURL)throw new Error("baseURL should be defined!");this.config={...e},this.axiosInstance=zs.create(this.config)}setHeaders(e){return this.config.headers=e,this}setParams(e){return this.config.params=e,this}setBody(e){return this.config.data=e,this}addBody(e){return this.config.data={...this.config.data,...e},this}setMethod(e){return this.config.method=e,this}async execute(){try{return await this.axiosInstance.request(this.config)}catch(e){throw e}}}class Hr extends j{constructor(e){super(e),this.params=e,this.host="https://codestral.mistral.ai",this.apiKey="",this.handleError$=s=>{const r=s.message?.replace(/(\r\n|\n|\r)/gm,"")||"An error occurred";return O({name:`${this.errorPrefix} ${r}`,value:r,isError:!0,disabled:!0})},this.colors={primary:"#e28c58",secondary:"#fff"},this.serviceName=w.bgHex(this.colors.primary).hex(this.colors.secondary).bold("[Codestral]"),this.errorPrefix=w.red.bold("[Codestral]"),this.apiKey=this.params.config.key}generateCommitMessage$(){return M(this.generateMessage("commit")).pipe(A(e=>$(e)),E(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:this.params.config.includeBody?e.value:e.title,description:this.params.config.includeBody?e.value:"",isError:!1})),x(this.handleError$))}generateCodeReview$(){return M(this.generateMessage("review")).pipe(A(e=>$(e)),E(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:e.value,description:e.value,isError:!1})),x(this.handleError$))}async generateMessage(e){try{const s=this.params.stagedDiff.diff,{systemPrompt:r,systemPromptPath:o,codeReviewPromptPath:n,logging:i,locale:l,generate:c,type:m,maxLength:p}=this.params.config,a={...G,locale:l,maxLength:p,type:m,generate:c,systemPrompt:r,systemPromptPath:o,codeReviewPromptPath:n},d=e==="review"?U(a):H(a);this.checkAvailableModels();const f=await this.createChatCompletions(d,e);return i&&B("Codestral",s,d,f,e),e==="review"?this.sanitizeResponse(f):this.parseMessage(f,m,c)}catch(s){const r=s;throw r.code==="ENOTFOUND"?new v(`Error connecting to ${r.hostname} (${r.syscall})`):r}}checkAvailableModels(){if(["codestral-latest","codestral-2501"].includes(this.params.config.model))return!0;throw new Error("Invalid model type of Codestral AI")}async createChatCompletions(e,s){const r=new fe({method:"POST",baseURL:`${this.host}/v1/chat/completions`,timeout:this.params.config.timeout}).setHeaders({Authorization:`Bearer ${this.apiKey}`,"content-type":"application/json"}).setBody({model:this.params.config.model,messages:[{role:"system",content:e},{role:"user",content:`Here is the diff: ${this.params.stagedDiff.diff}`}],temperature:this.params.config.temperature,top_p:this.params.config.topP,max_tokens:this.params.config.maxTokens,stream:!1,safe_prompt:!1,random_seed:Fe(10,1e3)});s==="commit"&&r.addBody({response_format:{type:"json_object"}});const n=(await r.execute()).data;if(!n.choices||n.choices.length===0||!n.choices[0].message?.content)throw new Error("No Content on response. Please open a Bug report");return n.choices[0].message.content}}const Si=2*60*1e3;class Ur extends j{constructor(e){super(e),this.params=e,this.handleError$=s=>{const r=/"message":\s*"([^"]*)"/,o=s.message.match(r);let n=s?.body?.message;o&&o[1]&&(n=o[1]);const i=`${s.statusCode} ${n}`;return O({name:`${this.errorPrefix} ${i}`,value:n,isError:!0,disabled:!0})},this.colors={primary:"#D18EE2",secondary:"#fff"},this.serviceName=w.bgHex(this.colors.primary).hex(this.colors.secondary).bold("[Cohere]"),this.errorPrefix=w.red.bold("[Cohere]"),this.cohere=new Ks({token:this.params.config.key})}generateCommitMessage$(){return M(this.generateMessage("commit")).pipe(A(e=>$(e)),E(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:this.params.config.includeBody?e.value:e.title,description:this.params.config.includeBody?e.value:"",isError:!1})),x(this.handleError$))}generateCodeReview$(){return M(this.generateMessage("review")).pipe(A(e=>$(e)),E(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:e.value,description:e.value,isError:!1})),x(this.handleError$))}async generateMessage(e){try{const s=this.params.stagedDiff.diff,{systemPrompt:r,systemPromptPath:o,codeReviewPromptPath:n,logging:i,temperature:l,locale:c,generate:m,type:p,maxLength:a,maxTokens:d}=this.params.config,f={...G,locale:c,maxLength:a,type:p,generate:m,systemPrompt:r,systemPromptPath:o,codeReviewPromptPath:n},h=e==="review"?U(f):H(f),g=await this.cohere.chat({chatHistory:h?[{role:"SYSTEM",message:h}]:[],message:`Here is the diff: ${s}`,connectors:[{id:"web-search"}],maxTokens:d,temperature:l,model:this.params.config.model,seed:Fe(10,1e3),p:this.params.config.topP},{...this.params.config.timeout>Si&&{timeoutInSeconds:Math.floor(this.params.config.timeout/1e3)}});return i&&B("Cohere",s,h,g.text,e),e==="review"?this.sanitizeResponse(g.text):this.parseMessage(g.text,p,m)}catch(s){const r=s;throw r instanceof Ws?new v("Request timed out error!"):r}}}class qr extends j{constructor(e){super(e),this.params=e,this.host="https://api.deepseek.com",this.handleError$=s=>{const r=s.message?.replace(/(\r\n|\n|\r)/gm,"")||"An error occurred";return O({name:`${this.errorPrefix} ${r}`,value:r,isError:!0,disabled:!0})},this.colors={primary:"#53a3f9",secondary:"#fff"},this.serviceName=w.bgHex(this.colors.primary).hex(this.colors.secondary).bold("[DeepSeek]"),this.errorPrefix=w.red.bold("[DeepSeek]"),this.deepSeek=new xe({baseURL:this.host,apiKey:this.params.config.key})}generateCommitMessage$(){return M(this.generateMessage("commit")).pipe(A(e=>$(e)),E(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:this.params.config.includeBody?e.value:e.title,description:this.params.config.includeBody?e.value:"",isError:!1})),x(this.handleError$))}generateCodeReview$(){return M(this.generateMessage("review")).pipe(A(e=>$(e)),E(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:e.value,description:e.value,isError:!1})),x(this.handleError$))}async generateMessage(e){try{const s=this.params.stagedDiff.diff,{systemPrompt:r,systemPromptPath:o,codeReviewPromptPath:n,logging:i,locale:l,generate:c,type:m,maxLength:p}=this.params.config,a={...G,locale:l,maxLength:p,type:m,generate:c,systemPrompt:r,systemPromptPath:o,codeReviewPromptPath:n},d=e==="review"?U(a):H(a);this.checkAvailableModels();const f=await this.createChatCompletions(d);return i&&B("DeepSeek",s,d,f,e),e==="review"?this.sanitizeResponse(f):this.parseMessage(f,m,c)}catch(s){const r=s;throw r.code==="ENOTFOUND"?new v(`Error connecting to ${r.hostname} (${r.syscall})`):r}}checkAvailableModels(){if(["deepseek-reasoner","deepseek-chat"].includes(this.params.config.model))return!0;throw new Error("Invalid model type of DeepSeek")}async createChatCompletions(e){return(await this.deepSeek.chat.completions.create({messages:[{role:"system",content:e},{role:"user",content:`Here is the diff: ${this.params.stagedDiff.diff}`}],model:this.params.config.model,max_tokens:this.params.config.maxTokens,top_p:this.params.config.topP,temperature:this.params.config.temperature},{timeout:this.params.config.timeout})).choices[0].message.content||""}}class zr extends j{constructor(e){super(e),this.params=e,this.handleError$=s=>{const r=s.message||s.toString(),o=/(\[.*?\]\s*[^[]*)/g,n=[...r.matchAll(o)],i=[];n.forEach(c=>i.push(c[1]));const l=i[1]||"An error occurred";return O({name:`${this.errorPrefix} ${l}`,value:l,isError:!0,disabled:!0})},this.colors={primary:"#0077FF",secondary:"#fff"},this.serviceName=w.bgHex(this.colors.primary).hex(this.colors.secondary).bold("[Gemini]"),this.errorPrefix=w.red.bold("[Gemini]"),this.genAI=new Ys(this.params.config.key)}generateCommitMessage$(){return M(this.generateMessage("commit")).pipe(A(e=>$(e)),E(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:this.params.config.includeBody?e.value:e.title,description:this.params.config.includeBody?e.value:"",isError:!1})),x(this.handleError$))}generateCodeReview$(){return M(this.generateMessage("review")).pipe(A(e=>$(e)),E(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:e.value,description:e.value,isError:!1})),x(this.handleError$))}async generateMessage(e){try{const s=this.params.stagedDiff.diff,{systemPrompt:r,systemPromptPath:o,logging:n,locale:i,codeReviewPromptPath:l,generate:c,type:m,maxLength:p}=this.params.config,a=this.params.config.maxTokens,d={...G,locale:i,maxLength:p,type:m,generate:c,systemPrompt:r,systemPromptPath:o,codeReviewPromptPath:l},f=e==="review"?U(d):H(d),h={maxOutputTokens:a,temperature:this.params.config.temperature,topP:this.params.config.topP},C=(await this.genAI.getGenerativeModel({model:this.params.config.model,systemInstruction:f,generationConfig:h,safetySettings:[{category:Ae.HARM_CATEGORY_HATE_SPEECH,threshold:Me.BLOCK_LOW_AND_ABOVE},{category:Ae.HARM_CATEGORY_SEXUALLY_EXPLICIT,threshold:Me.BLOCK_LOW_AND_ABOVE},{category:Ae.HARM_CATEGORY_HARASSMENT,threshold:Me.BLOCK_LOW_AND_ABOVE},{category:Ae.HARM_CATEGORY_DANGEROUS_CONTENT,threshold:Me.BLOCK_LOW_AND_ABOVE}]}).generateContent(`Here is the diff: ${s}`)).response.text();return n&&B("Gemini",s,f,C,e),e==="review"?this.sanitizeResponse(C):this.parseMessage(C,m,c)}catch(s){const r=s;throw r.code==="ENOTFOUND"?new v(`Error connecting to ${r.hostname} (${r.syscall})`):r}}}class Kr extends j{constructor(e){super(e),this.params=e,this.handleError$=s=>{let r="N/A",o="An error occurred";s instanceof rr.APIError&&(r=`${s.status}`,o=s.name);const n=`${r} ${o}`;return O({name:`${this.errorPrefix} ${n}`,value:o,isError:!0,disabled:!0})},this.colors={primary:"#f55036",secondary:"#fff"},this.serviceName=w.bgHex(this.colors.primary).hex(this.colors.secondary).bold("[Groq]"),this.errorPrefix=w.red.bold("[Groq]"),this.groq=new rr({apiKey:this.params.config.key})}generateCommitMessage$(){return M(this.generateMessage("commit")).pipe(A(e=>$(e)),E(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:this.params.config.includeBody?e.value:e.title,description:this.params.config.includeBody?e.value:"",isError:!1})),x(this.handleError$))}generateCodeReview$(){return M(this.generateMessage("review")).pipe(A(e=>$(e)),E(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:e.value,description:e.value,isError:!1})),x(this.handleError$))}async generateMessage(e){try{const s=this.params.stagedDiff.diff,{systemPrompt:r,systemPromptPath:o,codeReviewPromptPath:n,logging:i,locale:l,temperature:c,generate:m,type:p,maxLength:a}=this.params.config,d=this.params.config.maxTokens,f={...G,locale:l,maxLength:a,type:p,generate:m,systemPrompt:r,systemPromptPath:o,codeReviewPromptPath:n},h=e==="review"?U(f):H(f),y=(await this.groq.chat.completions.create({messages:[{role:"system",content:h},{role:"user",content:`Here is the diff: ${s}`}],model:this.params.config.model,max_tokens:d,top_p:this.params.config.topP,temperature:c},{timeout:this.params.config.timeout})).choices[0].message.content||"";return i&&B("Groq",s,h,y,e),e==="review"?this.sanitizeResponse(y):this.parseMessage(y,p,m)}catch(s){throw s}}}class Wr extends j{constructor(e){super(e),this.params=e,this.headers={accept:"*/*","accept-language":"en-US,en;q=0.9","sec-ch-ua":'"Chromium";v="116", "Not)A;Brand";v="24", "Google Chrome";v="116"',"sec-ch-ua-mobile":"?0","sec-ch-ua-platform":'"Windows"',"sec-fetch-dest":"empty","sec-fetch-mode":"cors","sec-fetch-site":"same-origin",origin:"https://huggingface.co","Referrer-Policy":"strict-origin-when-cross-origin"},this.models=[],this.currentModelId=null,this.currentConversation=void 0,this.currentConversionID=void 0,this.cookie="",this.colors={primary:"#FED21F",secondary:"#000"},this.serviceName=w.bgHex(this.colors.primary).hex(this.colors.secondary).bold("[HuggingFace]"),this.errorPrefix=w.red.bold("[HuggingFace]"),this.cookie=this.params.config.cookie}generateCommitMessage$(){return M(this.generateMessage("commit")).pipe(A(e=>$(e)),E(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:this.params.config.includeBody?e.value:e.title,description:this.params.config.includeBody?e.value:"",isError:!1})),x(this.handleError$))}generateCodeReview$(){return M(this.generateMessage("review")).pipe(A(e=>$(e)),E(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:e.value,description:e.value,isError:!1})),x(this.handleError$))}async generateMessage(e){try{await this.intialize();const s=this.params.stagedDiff.diff,{systemPrompt:r,systemPromptPath:o,codeReviewPromptPath:n,logging:i,locale:l,generate:c,type:m,maxLength:p}=this.params.config,a={...G,locale:l,maxLength:p,type:m,generate:c,systemPrompt:r,systemPromptPath:o,codeReviewPromptPath:n},d=e==="review"?U(a):H(a),f=await this.getNewChat(d),g=await(await this.sendMessage(`Here is the diff: ${s}`,f.id)).completeResponsePromise();return await this.deleteConversation(f.id),i&&B("HuggingFace",s,d,g,e),e==="review"?this.sanitizeResponse(g):this.parseMessage(g,m,c)}catch(s){const r=s;throw r.code==="ENOTFOUND"?new v(`Error connecting to ${r.hostname} (${r.syscall})`):r}}async intialize(){const e=await this.getRemoteLlms(),s=e.find(r=>r.name?.toLowerCase()===this.params.config.model.toLowerCase());if(s){this.currentModel=s,this.currentModelId=s.id;return}this.currentModel=e[0],this.currentModelId=e[0].id}async getRemoteLlms(){const e=await fetch("https://huggingface.co/chat/__data.json",{headers:{...this.headers,cookie:this.cookie},body:null,method:"GET"});if(e.status!==200)throw new Error(`Failed to get remote LLMs with status code: ${e.status}`);const r=(await e.json()).nodes[0].data,o=r[r[0].models],n=[],i=l=>l===-1?null:r[l];for(const l of o){const c=r[l];if(r[c.unlisted])continue;const m={id:i(c.id),name:i(c.name),displayName:i(c.displayName),preprompt:i(c.preprompt),promptExamples:[],websiteUrl:i(c.websiteUrl),description:i(c.description),datasetName:i(c.datasetName),datasetUrl:i(c.datasetUrl),modelUrl:i(c.modelUrl),parameters:{}},p=i(c.promptExamples);if(p!==null){const f=p.map(h=>i(h));m.promptExamples=f.map(h=>({title:r[h.title],prompt:r[h.prompt]}))}const a=i(c.parameters),d={};for(const[f,h]of Object.entries(a)){if(h===-1){d[f]=null;continue}if(Array.isArray(r[h])){d[f]=r[h].map(g=>r[g]);continue}d[f]=r[h]}m.parameters=d,n.push(m)}return this.models=n,n}async getNewChat(e){const s={model:this.currentModelId,preprompt:e};let r=0;for(;r<5;){const o=await fetch("https://huggingface.co/chat/conversation",{headers:{...this.headers,"content-type":"application/json",cookie:this.cookie,Referer:"https://huggingface.co/chat/"},body:JSON.stringify(s),method:"POST"}),{conversationId:n}=await o.json();if(n){this.currentConversionID=n;break}else r++}if(!this.currentConversionID)throw new Error("Failed to create new conversion");return await this.getConversationHistory(this.currentConversionID)}async getConversationHistory(e){if(!e)throw new Error("conversationId is required for getConversationHistory");const s=await fetch("https://huggingface.co/chat/conversation/"+e+"/__data.json",{headers:{...this.headers,cookie:this.cookie,Referer:"https://huggingface.co/chat/"},body:null,method:"GET"});if(s.status!=200)throw new Error("Unable get conversation details "+s);{const r=await s.json();return this.metadataParser(r,e)}}metadataParser(e,s){const r={id:"",model:"",systemPrompt:"",title:"",history:[]},o=e.nodes[1].data,n=o[o[0].model],i=o[o[0].preprompt],l=o[o[0].title],c=o[o[0].messages],m=[];for(const p of c){const a=o[p],d=new Date(o[a.createdAt][1]).getTime()/1e3,f=new Date(o[a.updatedAt][1]).getTime()/1e3;m.push({id:o[a.id],role:o[a.from],content:o[a.content],createdAt:d,updatedAt:f})}return r.id=s,r.model=n,r.systemPrompt=i,r.title=l,r.history=m,this.currentConversation=r,r}async sendMessage(e,s){if(e==="")throw new Error("the prompt can not be empty.");if(!s&&!this.currentConversionID?await this.getNewChat():s?(this.currentConversionID=s,await this.getConversationHistory(s)):this.currentConversionID&&await this.getConversationHistory(this.currentConversionID),!this.currentConversation)throw new Error("Failed to create new conversion");const r={inputs:e,id:this.currentConversation.history[this.currentConversation.history.length-1].id,is_retry:!1,is_continue:!1,web_search:!1,tools:[]},o=new FormData;o.append("data",JSON.stringify(r));const n=await fetch("https://huggingface.co/chat/conversation/"+this.currentConversionID,{headers:{...this.headers,cookie:this.cookie,Referer:"https://huggingface.co/chat/conversation/"+this.currentConversionID},body:o,method:"POST"});function i(d){try{const f=d.split(`
|
|
69
|
+
`),h=[];for(const g of f)g.trim()&&h.push(JSON.parse(g));return h}catch{return[{}]}}const l=new TextDecoder;let c="";const m=new TransformStream({async transform(d,f){const h=l.decode(d);try{const g=i(h);for(const y of g)y.type==="finalAnswer"?(c=y?.text||"",f.terminate()):y.type==="stream"&&f.enqueue(y?.token||"")}catch{throw new Error("Error during parsing response")}}}),p=n.body?.pipeThrough(m);async function a(){return new Promise(async(d,f)=>{try{if(!p)f("ModifiedStream undefined");else{const h=p.getReader();for(;;){const{done:g,value:y}=await h.read();if(g){d(c);break}}}}catch(h){f(h)}})}return{id:this.currentConversionID,stream:p,completeResponsePromise:a}}async deleteConversation(e){return(await fetch(`https://huggingface.co/chat/conversation/${e}`,{headers:{...this.headers,cookie:this.cookie,Referer:"https://huggingface.co/chat/"},body:null,method:"DELETE"})).json()}}class Yr extends j{constructor(e){super(e),this.params=e,this.host="https://api.mistral.ai",this.apiKey="",this.handleError$=s=>{const r=s.message?.replace(/(\r\n|\n|\r)/gm,"")||"An error occurred";return O({name:`${this.errorPrefix} ${r}`,value:r,isError:!0,disabled:!0})},this.colors={primary:"#ff7000",secondary:"#fff"},this.serviceName=w.bgHex(this.colors.primary).hex(this.colors.secondary).bold("[MistralAI]"),this.errorPrefix=w.red.bold("[MistralAI]"),this.apiKey=this.params.config.key}generateCommitMessage$(){return M(this.generateMessage("commit")).pipe(A(e=>$(e)),E(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:this.params.config.includeBody?e.value:e.title,description:this.params.config.includeBody?e.value:"",isError:!1})),x(this.handleError$))}generateCodeReview$(){return M(this.generateMessage("review")).pipe(A(e=>$(e)),E(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:e.value,description:e.value,isError:!1})),x(this.handleError$))}async generateMessage(e){try{const s=this.params.stagedDiff.diff,{systemPrompt:r,systemPromptPath:o,codeReviewPromptPath:n,logging:i,locale:l,generate:c,type:m,maxLength:p}=this.params.config,a={...G,locale:l,maxLength:p,type:m,generate:c,systemPrompt:r,systemPromptPath:o,codeReviewPromptPath:n},d=e==="review"?U(a):H(a);await this.checkAvailableModels();const f=await this.createChatCompletions(d,`Here is the diff: ${s}`);return i&&B("MistralAI",s,d,f,e),e==="review"?this.sanitizeResponse(f):this.parseMessage(f,m,c)}catch(s){const r=s;throw r.code==="ENOTFOUND"?new v(`Error connecting to ${r.hostname} (${r.syscall})`):r}}async checkAvailableModels(){if((await this.getAvailableModels()).includes(this.params.config.model))return!0;throw new Error(`Invalid model type of Mistral AI: ${this.params.config.model}`)}async getAvailableModels(){return(await new fe({method:"GET",baseURL:`${this.host}/v1/models`,timeout:this.params.config.timeout}).setHeaders({Authorization:`Bearer ${this.apiKey}`,"content-type":"application/json"}).execute()).data.data.filter(s=>s.object==="model").map(s=>s.id)}async createChatCompletions(e,s){const o=(await new fe({method:"POST",baseURL:`${this.host}/v1/chat/completions`,timeout:this.params.config.timeout}).setHeaders({Authorization:`Bearer ${this.apiKey}`,"content-type":"application/json"}).setBody({model:this.params.config.model,messages:[{role:"system",content:e},{role:"user",content:s}],temperature:this.params.config.temperature,top_p:this.params.config.topP,max_tokens:this.params.config.maxTokens,stream:!1,safe_prompt:!1,random_seed:Fe(10,1e3)}).execute()).data;if(!o.choices||o.choices.length===0||!o.choices[0].message?.content)throw new Error("No Content on response. Please open a Bug report");return o.choices[0].message.content}}const{hasOwnProperty:bt}=Object.prototype,Ge=typeof process<"u"&&process.platform==="win32"?`\r
|
|
90
70
|
`:`
|
|
91
|
-
`,_t=(t,e)=>{const r=[];let o="";typeof e=="string"?e={section:e,whitespace:!1}:(e=e||Object.create(null),e.whitespace=e.whitespace===!0);const n=e.whitespace?" = ":"=";for(const s of Object.keys(t)){const i=t[s];if(i&&Array.isArray(i))for(const u of i)o+=le(s+"[]")+n+le(u)+Ke;else i&&typeof i=="object"?r.push(s):o+=le(s)+n+le(i)+Ke}e.section&&o.length&&(o="["+le(e.section)+"]"+Ke+o);for(const s of r){const i=Oo(s).join("\\."),u=(e.section?e.section+".":"")+i,{whitespace:a}=e,l=_t(t[s],{section:u,whitespace:a});o.length&&l.length&&(o+=Ke),o+=l}return o},Oo=t=>t.replace(/\1/g,"LITERAL\\1LITERAL").replace(/\\\./g,"").split(/\./).map(e=>e.replace(/\1/g,"\\.").replace(/\2LITERAL\\1LITERAL\2/g,"")),Io=t=>{const e=Object.create(null);let r=e,o=null;const n=/^\[([^\]]*)\]$|^([^=]+)(=(.*))?$/i,s=t.split(/[\r\n]+/g);for(const u of s){if(!u||u.match(/^\s*[;#]/))continue;const a=u.match(n);if(!a)continue;if(a[1]!==void 0){if(o=Je(a[1]),o==="__proto__"){r=Object.create(null);continue}r=e[o]=e[o]||Object.create(null);continue}const l=Je(a[2]),m=l.length>2&&l.slice(-2)==="[]",c=m?l.slice(0,-2):l;if(c==="__proto__")continue;const D=a[3]?Je(a[4]):!0,d=D==="true"||D==="false"||D==="null"?JSON.parse(D):D;m&&(Nt.call(r,c)?Array.isArray(r[c])||(r[c]=[r[c]]):r[c]=[]),Array.isArray(r[c])?r[c].push(d):r[c]=d}const i=[];for(const u of Object.keys(e)){if(!Nt.call(e,u)||typeof e[u]!="object"||Array.isArray(e[u]))continue;const a=Oo(u);r=e;const l=a.pop(),m=l.replace(/\\\./g,".");for(const c of a)c!=="__proto__"&&((!Nt.call(r,c)||typeof r[c]!="object")&&(r[c]=Object.create(null)),r=r[c]);r===e&&m===l||(r[m]=e[u],i.push(u))}for(const u of i)delete e[u];return e},ko=t=>t.startsWith('"')&&t.endsWith('"')||t.startsWith("'")&&t.endsWith("'"),le=t=>typeof t!="string"||t.match(/[=\r\n]/)||t.match(/^\[/)||t.length>1&&ko(t)||t!==t.trim()?JSON.stringify(t):t.split(";").join("\\;").split("#").join("\\#"),Je=(t,e)=>{if(t=(t||"").trim(),ko(t)){t.charAt(0)==="'"&&(t=t.slice(1,-1));try{t=JSON.parse(t)}catch{}}else{let r=!1,o="";for(let n=0,s=t.length;n<s;n++){const i=t.charAt(n);if(r)"\\;#".indexOf(i)!==-1?o+=i:o+="\\"+i,r=!1;else{if(";#".indexOf(i)!==-1)break;i==="\\"?r=!0:o+=i}}return r&&(o+="\\"),o.trim()}return t};var xu={parse:Io,decode:Io,stringify:_t,encode:_t,safe:le,unsafe:Je},jt=se(xu);const Lo=t=>M.lstat(t).then(()=>!0,()=>!1),Mu=["","conventional","gitmoji"],Gt="http://localhost:11434",{hasOwnProperty:Su}=Object.prototype,Ve=(t,e)=>Su.call(t,e),X=["OPENAI","OLLAMA","HUGGINGFACE","GEMINI","ANTHROPIC","MISTRAL","CODESTRAL","COHERE","GROQ","PERPLEXITY","DEEPSEEK"],Ru=t=>{const e=Object.keys(t),r=new Set([...X,...e.filter(o=>/^[A-Z][A-Z0-9_]*$/.test(o))]);return Array.from(r)},F=(t,e,r)=>{if(!e)throw new y(`Invalid config property ${t}: ${r}`)},p={systemPrompt(t){return t||""},systemPromptPath(t){return t||""},codeReviewPromptPath(t){return t||""},timeout(t){if(!t)return 1e4;F("timeout",/^\d+$/.test(t),"Must be an integer");const e=Number(t);return F("timeout",e>=500,"Must be greater than 500ms"),e},temperature(t){if(!t)return .7;F("temperature",/^(2|\d)(\.\d{1,2})?$/.test(t),"Must be decimal between 0 and 2");const e=Number(t);return F("temperature",e>0,"Must be greater than 0"),F("temperature",e<=2,"Must be less than or equal to 2"),e},maxTokens(t){return t?(F("maxTokens",/^\d+$/.test(t),"Must be an integer"),Number(t)):1024},logging(t){return typeof t=="boolean"?t:t==null?!0:(F("logging",/^(?:true|false)$/.test(t),"Must be a boolean(true or false)"),t==="true")},locale(t){return t?(F("locale",t,"Cannot be empty"),F("locale",/^[a-z-]+$/i.test(t),"Must be a valid locale (letters and dashes/underscores). You can consult the list of codes in: https://wikipedia.org/wiki/List_of_ISO_639-1_codes"),t):"en"},generate(t){if(!t)return 1;F("generate",/^\d+$/.test(t),"Must be an integer");const e=Number(t);return F("generate",e>0,"Must be greater than 0"),F("generate",e<=5,"Must be less or equal to 5"),e},type(t){return t?(F("type",Mu.includes(t),"Invalid commit type"),t):"conventional"},maxLength(t){if(!t)return 50;F("maxLength",/^\d+$/.test(t),"Must be an integer");const e=Number(t);return F("maxLength",e>=20,"Must be greater than 20 characters"),e},includeBody(t){return typeof t=="boolean"?t:t==null?!1:(F("includeBody",/^(?:true|false)$/.test(t),"Must be a boolean(true or false)"),t==="true")},exclude:t=>t?(typeof t=="string"?t?.split(","):t).map(r=>r.trim()).filter(r=>!!r&&r.length>0):[],topP:t=>{if(!t)return .9;F("topP",/^(1|\d)(\.\d{1,2})?$/.test(t),"Must be decimal between 0 and 1");const e=Number(t);return F("topP",e>0,"Must be greater than 0"),F("topP",e<=1,"Must be less than or equal to 1"),e},codeReview(t){return typeof t=="boolean"?t:t==null?!1:(F("codeReview",/^(?:true|false)$/.test(t),"Must be a boolean(true or false)"),t==="true")},disabled(t){return typeof t=="boolean"?t:t==null?!1:(F("disabled",/^(?:true|false)$/.test(t),"Must be a boolean(true or false)"),t==="true")},watchMode(t){return typeof t=="boolean"?t:t==null?!1:(F("watchMode",/^(?:true|false)$/.test(t),"Must be a boolean(true or false)"),t==="true")}},ye={OPENAI:{key:t=>t||"",model:t=>t||"gpt-4o-mini",url:t=>t?(F("OPENAI.url",/^https?:\/\//.test(t),"Must be a valid URL"),t):"https://api.openai.com",path:t=>t||"/v1/chat/completions",proxy:t=>t||"",topP:p.topP,systemPrompt:p.systemPrompt,systemPromptPath:p.systemPromptPath,codeReviewPromptPath:p.codeReviewPromptPath,timeout:p.timeout,temperature:p.temperature,maxTokens:p.maxTokens,logging:p.logging,locale:p.locale,generate:p.generate,type:p.type,maxLength:p.maxLength,includeBody:p.includeBody,codeReview:p.codeReview,disabled:p.disabled,watchMode:p.watchMode},HUGGINGFACE:{cookie:t=>t||"",model:t=>t?(F("HUGGINGFACE.model",["CohereForAI/c4ai-command-r-plus","meta-llama/Meta-Llama-3-70B-Instruct","HuggingFaceH4/zephyr-orpo-141b-A35b-v0.1","mistralai/Mixtral-8x7B-Instruct-v0.1","NousResearch/Nous-Hermes-2-Mixtral-8x7B-DPO","01-ai/Yi-1.5-34B-Chat","mistralai/Mistral-7B-Instruct-v0.2","microsoft/Phi-3-mini-4k-instruct"].includes(t),"Invalid model type of HuggingFace chat"),t):"CohereForAI/c4ai-command-r-plus",systemPrompt:p.systemPrompt,systemPromptPath:p.systemPromptPath,codeReviewPromptPath:p.codeReviewPromptPath,logging:p.logging,locale:p.locale,generate:p.generate,type:p.type,maxLength:p.maxLength,includeBody:p.includeBody,codeReview:p.codeReview,disabled:p.disabled,watchMode:p.watchMode},GEMINI:{key:t=>t||"",model:t=>!t||t.length===0?"gemini-2.0-flash":(F("GEMINI.model",["gemini-2.0-flash","gemini-2.0-flash-lite","gemini-2.0-pro-exp-02-05","gemini-2.0-flash-thinking-exp-01-21","gemini-2.0-flash-exp","gemini-1.5-flash","gemini-1.5-flash-8b","gemini-1.5-pro"].includes(t),"Invalid model type of Gemini"),t),systemPrompt:p.systemPrompt,systemPromptPath:p.systemPromptPath,codeReviewPromptPath:p.codeReviewPromptPath,temperature:p.temperature,maxTokens:p.maxTokens,logging:p.logging,locale:p.locale,generate:p.generate,type:p.type,maxLength:p.maxLength,includeBody:p.includeBody,topP:p.topP,codeReview:p.codeReview,disabled:p.disabled,watchMode:p.watchMode},ANTHROPIC:{key:t=>t||"",model:t=>!t||t.length===0?"claude-3-5-haiku-20241022":(F("ANTHROPIC.model",["claude-3-7-sonnet-20250219","claude-3-5-sonnet-20241022","claude-3-5-haiku-20241022","claude-3-opus-20240229","claude-3-sonnet-20240229","claude-3-haiku-20240307"].includes(t),"Invalid model type of Anthropic"),t),systemPrompt:p.systemPrompt,systemPromptPath:p.systemPromptPath,codeReviewPromptPath:p.codeReviewPromptPath,temperature:p.temperature,maxTokens:p.maxTokens,logging:p.logging,locale:p.locale,generate:p.generate,type:p.type,maxLength:p.maxLength,includeBody:p.includeBody,topP:p.topP,codeReview:p.codeReview,disabled:p.disabled,watchMode:p.watchMode},MISTRAL:{key:t=>t||"",model:t=>!t||t.length===0?"pixtral-12b-2409":(F("MISTRAL.model",["codestral-latest","mistral-large-latest","pixtral-large-latest","ministral-8b-latest","mistral-small-latest","mistral-embed","mistral-moderation-latest"].includes(t),"Invalid model type of Mistral AI"),t),systemPrompt:p.systemPrompt,systemPromptPath:p.systemPromptPath,codeReviewPromptPath:p.codeReviewPromptPath,timeout:p.timeout,temperature:p.temperature,maxTokens:p.maxTokens,logging:p.logging,locale:p.locale,generate:p.generate,type:p.type,maxLength:p.maxLength,includeBody:p.includeBody,topP:p.topP,codeReview:p.codeReview,disabled:p.disabled,watchMode:p.watchMode},CODESTRAL:{key:t=>t||"",model:t=>!t||t.length===0?"codestral-latest":(F("CODESTRAL.model",["codestral-latest","codestral-2501"].includes(t),"Invalid model type of Codestral"),t),topP:p.topP,systemPrompt:p.systemPrompt,systemPromptPath:p.systemPromptPath,codeReviewPromptPath:p.codeReviewPromptPath,timeout:p.timeout,temperature:p.temperature,maxTokens:p.maxTokens,logging:p.logging,locale:p.locale,generate:p.generate,type:p.type,maxLength:p.maxLength,includeBody:p.includeBody,codeReview:p.codeReview,disabled:p.disabled,watchMode:p.watchMode},OLLAMA:{model:t=>t?(typeof t=="string"?t?.split(","):t).map(r=>r.trim()).filter(r=>!!r&&r.length>0):[],host:t=>t?(F("OLLAMA.host",/^https?:\/\//.test(t),"Must be a valid URL"),t):Gt,timeout:t=>{if(!t)return 1e5;F("OLLAMA.timeout",/^\d+$/.test(t),"Must be an integer");const e=Number(t);return F("OLLAMA.timeout",e>=500,"Must be greater than 500ms"),e},auth:t=>t||"",key:t=>t||"",numCtx:t=>{if(!t)return 2048;F("OLLAMA.numCtx",/^\d+$/.test(t),"Must be an integer");const e=Number(t);return F("OLLAMA.numCtx",e>=2048,"Must be greater than 2048"),e},systemPrompt:p.systemPrompt,systemPromptPath:p.systemPromptPath,codeReviewPromptPath:p.codeReviewPromptPath,temperature:p.temperature,logging:p.logging,locale:p.locale,generate:p.generate,type:p.type,maxLength:p.maxLength,includeBody:p.includeBody,topP:p.topP,codeReview:p.codeReview,disabled:p.disabled,watchMode:p.watchMode},COHERE:{key:t=>t||"",model:t=>!t||t.length===0?"command":(F("COHERE.model",["command-r7b-12-2024","command-r-plus-08-2024","command-r-plus-04-2024","command-r-plus","command-r-08-2024","command-r-03-2024","command-r","command","command-nightly","command-light","command-light-nightly","c4ai-aya-expanse-8b","c4ai-aya-expanse-32b"].includes(t),"Invalid model type of Cohere"),t),systemPrompt:p.systemPrompt,systemPromptPath:p.systemPromptPath,codeReviewPromptPath:p.codeReviewPromptPath,temperature:p.temperature,maxTokens:p.maxTokens,logging:p.logging,locale:p.locale,generate:p.generate,type:p.type,maxLength:p.maxLength,includeBody:p.includeBody,topP:p.topP,codeReview:p.codeReview,disabled:p.disabled,watchMode:p.watchMode},GROQ:{key:t=>t||"",model:t=>!t||t.length===0?"deepseek-r1-distill-llama-70b":(F("GROQ.model",["qwen-2.5-32b","qwen-2.5-coder-32b","deepseek-r1-distill-qwen-32b","deepseek-r1-distill-llama-70b","gemma2-9b-it","llama-3.3-70b-versatile","llama-3.1-8b-instant","llama-guard-3-8b","llama3-70b-8192","llama3-8b-8192","mixtral-8x7b-32768","distil-whisper-large-v3-en","whisper-large-v3","whisper-large-v3-turbo","llama-3.3-70b-specdec","llama-3.2-1b-preview","llama-3.2-3b-preview","llama-3.2-11b-vision-preview","llama-3.2-90b-vision-preview"].includes(t),"Invalid model type of Groq"),t),systemPrompt:p.systemPrompt,systemPromptPath:p.systemPromptPath,codeReviewPromptPath:p.codeReviewPromptPath,timeout:p.timeout,temperature:p.temperature,maxTokens:p.maxTokens,logging:p.logging,locale:p.locale,generate:p.generate,type:p.type,maxLength:p.maxLength,includeBody:p.includeBody,topP:p.topP,codeReview:p.codeReview,disabled:p.disabled,watchMode:p.watchMode},PERPLEXITY:{key:t=>t||"",model:t=>!t||t.length===0?"sonar":(F("PERPLEXITY.model",["sonar-pro","sonar","llama-3.1-sonar-small-128k-online","llama-3.1-sonar-large-128k-online","llama-3.1-sonar-huge-128k-online"].includes(t),"Invalid model type of Perplexity"),t),topP:p.topP,systemPrompt:p.systemPrompt,systemPromptPath:p.systemPromptPath,codeReviewPromptPath:p.codeReviewPromptPath,timeout:p.timeout,temperature:p.temperature,maxTokens:p.maxTokens,logging:p.logging,locale:p.locale,generate:p.generate,type:p.type,maxLength:p.maxLength,includeBody:p.includeBody,codeReview:p.codeReview,disabled:p.disabled,watchMode:p.watchMode},DEEPSEEK:{key:t=>t||"",model:t=>!t||t.length===0?"deepseek-chat":(console.log(t),F("DEEPSEEK.model",["deepseek-reasoner","deepseek-chat"].includes(t),"Invalid model type of DeepSeek"),t),topP:p.topP,systemPrompt:p.systemPrompt,systemPromptPath:p.systemPromptPath,codeReviewPromptPath:p.codeReviewPromptPath,timeout:p.timeout,temperature:p.temperature,maxTokens:p.maxTokens,logging:p.logging,locale:p.locale,generate:p.generate,type:p.type,maxLength:p.maxLength,includeBody:p.includeBody,codeReview:p.codeReview,disabled:p.disabled,watchMode:p.watchMode}},Ye=k.join(ut.homedir(),".aicommit2"),Ou=(t=[])=>{const e={};for(const r of t)if(r.startsWith("--")){const[o,n]=r.slice(2).split("="),[s,i]=o.split(".");s&&i&&s in ye?(e[s]||(e[s]={}),e[s][i]=n):e[o]=n}return e},To=async()=>await Lo(Ye)?await M.readFile(Ye,"utf8"):"",Ht=async()=>{const t=await To();if(!t)return Object.create(null);let e=jt.parse(t);return Ve(e,"OLLAMA")&&Ve(e.OLLAMA,"model")&&(e={...e,OLLAMA:{...e.OLLAMA,model:typeof e.OLLAMA.model=="string"?[e.OLLAMA.model]:e.OLLAMA.model}}),Ve(e,"exclude")&&(e={...e,exclude:typeof e.exclude=="string"?[e.exclude]:e.exclude}),e},Ee=async(t,e=[])=>{const r=await Ht(),o=Ou(e),n={...t,...o},s={},i=Ru(r),u={},a=X.map(m=>({service:m,envKey:`${m}_API_KEY`}));for(const{service:m,envKey:c}of a){const D=process.env[c];D&&(u[m]={key:D})}const l=(m,c)=>{const D=n[`${m}.${c}`]??n[m]?.[c],d=u[m]?.[c],f=r[m]?.[c],h=n[c]??r[c];return D!==void 0?D:d!==void 0?d:f!==void 0?f:h};for(const[m,c]of Object.entries(p)){const D=n[m]??r[m];s[m]=c(D)}for(const m of i){s[m]={};const c=ye[m]||Xe(m);for(const[D,d]of Object.entries(c)){const f=l(m,D);s[m][D]=d(f)}}return s},Iu=async t=>{const e=await Ht();for(const[r,o]of t){const[n,s]=r.split(".");if(!s){const a=p[r];if(!a)throw new y(`Invalid config property: ${r}`);e[r]=a(o);continue}if(e[n]||(e[n]={}),X.includes(n)){const a=ye[n][s];if(!a)throw new y(`Invalid config property: ${r}`);e[n][s]=a(o);continue}if(!/^[A-Z][A-Z0-9_]*$/.test(n))throw new y(`Invalid service name: ${n}. Service names must be uppercase letters, numbers, and underscores.`);const u=Xe(n);if(!u[s])throw new y(`Invalid config property for custom service: ${r}`);try{e[n][s]=u[s](o)}catch(a){throw a instanceof y?a:new y(`Invalid value for ${r}: ${a.message}`)}}await M.writeFile(Ye,jt.stringify(e),"utf8")},ku=async t=>{const e=await Ht();for(const[r,o]of t){const[n,s]=r.split("."),i=e[n];if(n==="OLLAMA"&&s==="model"){i||(e[n]={});const a=e[n][s]||[];e[n][s]=ze([...a,o]);continue}if(i&&i.compatible===!0){i||(e[n]={});const a=Xe(n);if(!a[s])throw new y(`Invalid config property: ${r}`);try{e[n][s]=a[s](o)}catch(l){throw l instanceof y?l:new y(`Invalid value for ${r}: ${l.message}`)}continue}if(n in ye){i||(e[n]={});const a=ye[n][s];if(!a)throw new y(`Invalid config property: ${r}`);e[n][s]=a(o)}else{const a=Xe(n);if(!a[s])throw new y(`Invalid config property: ${r}`);e[n]||(e[n]={}),e[n][s]=a[s](o)}}await M.writeFile(Ye,jt.stringify(e),"utf8")},Lu=async()=>{const t=await To();console.log(t)},Xe=t=>({compatible:e=>typeof e=="boolean"?e:e==null?!1:(F("compatible",/^(?:true|false)$/.test(e),"Must be a boolean(true or false)"),e==="true"),stream:e=>typeof e=="boolean"?e:e==null?!1:(F("stream",/^(?:true|false)$/.test(e),"Must be a boolean(true or false)"),e==="true"),url:e=>e?(F(`${t}.url`,/^https?:\/\//.test(e),"Must be a valid URL"),e):"",path:e=>e||"",key:e=>e||"",model:e=>e||"",systemPrompt:p.systemPrompt,systemPromptPath:p.systemPromptPath,codeReviewPromptPath:p.codeReviewPromptPath,timeout:p.timeout,temperature:p.temperature,maxTokens:p.maxTokens,logging:p.logging,locale:p.locale,generate:p.generate,type:p.type,maxLength:p.maxLength,includeBody:p.includeBody,topP:p.topP,codeReview:p.codeReview,disabled:p.disabled,watchMode:p.watchMode});class No extends G{constructor(e){super(e),this.params=e,this.host=Gt,this.model="",this.key="",this.auth="",this.handleError$=r=>{if(r.response&&r.response.data?.error)return O({name:`${this.errorPrefix} ${r.response.data?.error}`,value:r.response.data?.error,isError:!0,disabled:!0});const o=r.message?.replace(/(\r\n|\n|\r)/gm,"")||"An error occurred";return O({name:`${this.errorPrefix} ${o}`,value:o,isError:!0,disabled:!0})},this.colors={primary:"#FFF",secondary:"#000"},this.model=this.params.keyName,this.serviceName=C.bgHex(this.colors.primary).hex(this.colors.secondary).bold(`[${Ue(this.model)}]`),this.errorPrefix=C.red.bold(`[${Ue(this.model)}]`),this.host=this.params.config.host||Gt,this.auth=this.params.config.auth||"Bearer",this.key=this.params.config.key||"",this.ollama=new In({host:this.host,fetch:On,...this.key&&{headers:{Authorization:`${this.auth} ${this.key}`}}})}generateCommitMessage$(){return P(this.generateMessage("commit")).pipe(A(e=>v(e)),b(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:this.params.config.includeBody?e.value:e.title,description:this.params.config.includeBody?e.value:"",isError:!1})),$(this.handleError$))}generateCodeReview$(){return P(this.generateMessage("review")).pipe(A(e=>v(e)),b(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:e.value,description:e.value,isError:!1})),$(this.handleError$))}async generateMessage(e){try{const r=this.params.stagedDiff.diff,{systemPrompt:o,systemPromptPath:n,codeReviewPromptPath:s,logging:i,locale:u,generate:a,type:l,maxLength:m}=this.params.config,c={...j,locale:u,maxLength:m,type:l,generate:a,systemPrompt:o,systemPromptPath:n,codeReviewPromptPath:s},D=e==="review"?q(c):U(c);await this.checkIsAvailableOllama();const d=await this.createChatCompletions(D,`Here is the diff: ${r}`);return i&&H(`Ollama_${this.model}`,r,D,d,e),e==="review"?this.sanitizeResponse(d):this.parseMessage(d,l,a)}catch(r){const o=r;throw o.code==="ENOTFOUND"?new y(`Error connecting to ${o.hostname} (${o.syscall})`):o}}async checkIsAvailableOllama(){try{const e=new Ce({method:"GET",baseURL:`${this.host}`,timeout:this.params.config.timeout});return this.key&&e.setHeaders({Authorization:`${this.auth} ${this.key}`}),(await e.execute()).data}catch(e){throw e.code==="ECONNREFUSED"?new y(`Error connecting to ${this.host}. Please run Ollama or check host`):e}}async createChatCompletions(e,r){return(await this.ollama.chat({model:this.model,messages:[{role:"system",content:e},{role:"user",content:r}],stream:!1,keep_alive:this.params.config.timeout,options:{num_ctx:this.params.config.numCtx,temperature:this.params.config.temperature,top_p:this.params.config.topP,seed:qe(10,1e3)}})).message.content}}class _o extends G{constructor(e){super(e),this.params=e,this.handleError$=o=>{let n="N/A",s=o.message;o instanceof xe.APIConnectionTimeoutError?s=`Connection timeout: ${o.message}`:o instanceof xe.APIError&&(n=`${o.status}`,s=o.name);const i=`${n} ${s}`;return O({name:`${this.errorPrefix} ${i}`,value:s,isError:!0,disabled:!0})};const r=this.params.keyName||"OPENAI_COMPATIBLE";this.colors=Eu(r),this.serviceName=C.bgHex(this.colors.primary).hex(this.colors.secondary).bold(`[${Ue(r)}]`),this.errorPrefix=C.red.bold(`[${Ue(r)}]`),this.openAI=new xe({apiKey:this.params.config.key,baseURL:`${this.params.config.url}${this.params.config.path}`})}generateCommitMessage$(){return P(this.generateMessage("commit")).pipe(A(e=>v(e)),b(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:this.params.config.includeBody?e.value:e.title,description:this.params.config.includeBody?e.value:"",isError:!1})),$(this.handleError$))}generateCodeReview$(){return P(this.generateMessage("review")).pipe(A(e=>v(e)),b(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:e.value,description:e.value,isError:!1})),$(this.handleError$))}async generateMessage(e){try{const r=this.params.stagedDiff.diff,{systemPrompt:o,systemPromptPath:n,codeReviewPromptPath:s,logging:i,locale:u,temperature:a,generate:l,type:m,maxLength:c,timeout:D,stream:d=!1}=this.params.config,f=this.params.config.maxTokens,h={...j,locale:u,maxLength:c,type:m,generate:l,systemPrompt:o,systemPromptPath:n,codeReviewPromptPath:s},g=e==="review"?q(h):U(h),E=await this.openAI.chat.completions.create({messages:[{role:"system",content:g},{role:"user",content:`Here is the diff: ${r}`}],model:this.params.config.model,stream:d,max_tokens:f,top_p:this.params.config.topP,temperature:a},{timeout:D});let w="";if(d&&E){const S=E;for await(const J of S){const V=J.choices[0]?.delta?.content||"",me=J.choices[0]?.delta?.reasoning_content||"",Y=`${V}${me}`;w+=Y}}else w=E.choices[0].message.content||"";return i&&H(this.params.keyName,r,g,w,e),e==="review"?this.sanitizeResponse(w):this.parseMessage(w,m,l)}catch(r){throw console.error("generateMessage error >>>",r),r}}}var Ut={},qt={exports:{}},Fe={exports:{}},zt,jo;function Tu(){if(jo)return zt;jo=1;var t=1e3,e=t*60,r=e*60,o=r*24,n=o*7,s=o*365.25;zt=function(m,c){c=c||{};var D=typeof m;if(D==="string"&&m.length>0)return i(m);if(D==="number"&&isFinite(m))return c.long?a(m):u(m);throw new Error("val is not a non-empty string or a valid number. val="+JSON.stringify(m))};function i(m){if(m=String(m),!(m.length>100)){var c=/^(-?(?:\d+)?\.?\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(m);if(c){var D=parseFloat(c[1]),d=(c[2]||"ms").toLowerCase();switch(d){case"years":case"year":case"yrs":case"yr":case"y":return D*s;case"weeks":case"week":case"w":return D*n;case"days":case"day":case"d":return D*o;case"hours":case"hour":case"hrs":case"hr":case"h":return D*r;case"minutes":case"minute":case"mins":case"min":case"m":return D*e;case"seconds":case"second":case"secs":case"sec":case"s":return D*t;case"milliseconds":case"millisecond":case"msecs":case"msec":case"ms":return D;default:return}}}}function u(m){var c=Math.abs(m);return c>=o?Math.round(m/o)+"d":c>=r?Math.round(m/r)+"h":c>=e?Math.round(m/e)+"m":c>=t?Math.round(m/t)+"s":m+"ms"}function a(m){var c=Math.abs(m);return c>=o?l(m,c,o,"day"):c>=r?l(m,c,r,"hour"):c>=e?l(m,c,e,"minute"):c>=t?l(m,c,t,"second"):m+" ms"}function l(m,c,D,d){var f=c>=D*1.5;return Math.round(m/D)+" "+d+(f?"s":"")}return zt}var Wt,Go;function Ho(){if(Go)return Wt;Go=1;function t(e){o.debug=o,o.default=o,o.coerce=l,o.disable=u,o.enable=s,o.enabled=a,o.humanize=Tu(),o.destroy=m,Object.keys(e).forEach(c=>{o[c]=e[c]}),o.names=[],o.skips=[],o.formatters={};function r(c){let D=0;for(let d=0;d<c.length;d++)D=(D<<5)-D+c.charCodeAt(d),D|=0;return o.colors[Math.abs(D)%o.colors.length]}o.selectColor=r;function o(c){let D,d=null,f,h;function g(...E){if(!g.enabled)return;const w=g,S=Number(new Date),J=S-(D||S);w.diff=J,w.prev=D,w.curr=S,D=S,E[0]=o.coerce(E[0]),typeof E[0]!="string"&&E.unshift("%O");let V=0;E[0]=E[0].replace(/%([a-zA-Z%])/g,(Y,fn)=>{if(Y==="%%")return"%";V++;const ur=o.formatters[fn];if(typeof ur=="function"){const hn=E[V];Y=ur.call(w,hn),E.splice(V,1),V--}return Y}),o.formatArgs.call(w,E),(w.log||o.log).apply(w,E)}return g.namespace=c,g.useColors=o.useColors(),g.color=o.selectColor(c),g.extend=n,g.destroy=o.destroy,Object.defineProperty(g,"enabled",{enumerable:!0,configurable:!1,get:()=>d!==null?d:(f!==o.namespaces&&(f=o.namespaces,h=o.enabled(c)),h),set:E=>{d=E}}),typeof o.init=="function"&&o.init(g),g}function n(c,D){const d=o(this.namespace+(typeof D>"u"?":":D)+c);return d.log=this.log,d}function s(c){o.save(c),o.namespaces=c,o.names=[],o.skips=[];const D=(typeof c=="string"?c:"").trim().replace(" ",",").split(",").filter(Boolean);for(const d of D)d[0]==="-"?o.skips.push(d.slice(1)):o.names.push(d)}function i(c,D){let d=0,f=0,h=-1,g=0;for(;d<c.length;)if(f<D.length&&(D[f]===c[d]||D[f]==="*"))D[f]==="*"?(h=f,g=d,f++):(d++,f++);else if(h!==-1)f=h+1,g++,d=g;else return!1;for(;f<D.length&&D[f]==="*";)f++;return f===D.length}function u(){const c=[...o.names,...o.skips.map(D=>"-"+D)].join(",");return o.enable(""),c}function a(c){for(const D of o.skips)if(i(c,D))return!1;for(const D of o.names)if(i(c,D))return!0;return!1}function l(c){return c instanceof Error?c.stack||c.message:c}function m(){console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.")}return o.enable(o.load()),o}return Wt=t,Wt}Fe.exports;var Uo;function Nu(){return Uo||(Uo=1,function(t,e){e.formatArgs=o,e.save=n,e.load=s,e.useColors=r,e.storage=i(),e.destroy=(()=>{let a=!1;return()=>{a||(a=!0,console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`."))}})(),e.colors=["#0000CC","#0000FF","#0033CC","#0033FF","#0066CC","#0066FF","#0099CC","#0099FF","#00CC00","#00CC33","#00CC66","#00CC99","#00CCCC","#00CCFF","#3300CC","#3300FF","#3333CC","#3333FF","#3366CC","#3366FF","#3399CC","#3399FF","#33CC00","#33CC33","#33CC66","#33CC99","#33CCCC","#33CCFF","#6600CC","#6600FF","#6633CC","#6633FF","#66CC00","#66CC33","#9900CC","#9900FF","#9933CC","#9933FF","#99CC00","#99CC33","#CC0000","#CC0033","#CC0066","#CC0099","#CC00CC","#CC00FF","#CC3300","#CC3333","#CC3366","#CC3399","#CC33CC","#CC33FF","#CC6600","#CC6633","#CC9900","#CC9933","#CCCC00","#CCCC33","#FF0000","#FF0033","#FF0066","#FF0099","#FF00CC","#FF00FF","#FF3300","#FF3333","#FF3366","#FF3399","#FF33CC","#FF33FF","#FF6600","#FF6633","#FF9900","#FF9933","#FFCC00","#FFCC33"];function r(){if(typeof window<"u"&&window.process&&(window.process.type==="renderer"||window.process.__nwjs))return!0;if(typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/(edge|trident)\/(\d+)/))return!1;let a;return typeof document<"u"&&document.documentElement&&document.documentElement.style&&document.documentElement.style.WebkitAppearance||typeof window<"u"&&window.console&&(window.console.firebug||window.console.exception&&window.console.table)||typeof navigator<"u"&&navigator.userAgent&&(a=navigator.userAgent.toLowerCase().match(/firefox\/(\d+)/))&&parseInt(a[1],10)>=31||typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/applewebkit\/(\d+)/)}function o(a){if(a[0]=(this.useColors?"%c":"")+this.namespace+(this.useColors?" %c":" ")+a[0]+(this.useColors?"%c ":" ")+"+"+t.exports.humanize(this.diff),!this.useColors)return;const l="color: "+this.color;a.splice(1,0,l,"color: inherit");let m=0,c=0;a[0].replace(/%[a-zA-Z%]/g,D=>{D!=="%%"&&(m++,D==="%c"&&(c=m))}),a.splice(c,0,l)}e.log=console.debug||console.log||(()=>{});function n(a){try{a?e.storage.setItem("debug",a):e.storage.removeItem("debug")}catch{}}function s(){let a;try{a=e.storage.getItem("debug")}catch{}return!a&&typeof process<"u"&&"env"in process&&(a=process.env.DEBUG),a}function i(){try{return localStorage}catch{}}t.exports=Ho()(e);const{formatters:u}=t.exports;u.j=function(a){try{return JSON.stringify(a)}catch(l){return"[UnexpectedJSONParseError]: "+l.message}}}(Fe,Fe.exports)),Fe.exports}var we={exports:{}},Kt,qo;function _u(){return qo||(qo=1,Kt=(t,e=process.argv)=>{const r=t.startsWith("-")?"":t.length===1?"-":"--",o=e.indexOf(r+t),n=e.indexOf("--");return o!==-1&&(n===-1||o<n)}),Kt}var Jt,zo;function ju(){if(zo)return Jt;zo=1;const t=ut,e=st,r=_u(),{env:o}=process;let n;r("no-color")||r("no-colors")||r("color=false")||r("color=never")?n=0:(r("color")||r("colors")||r("color=true")||r("color=always"))&&(n=1),"FORCE_COLOR"in o&&(o.FORCE_COLOR==="true"?n=1:o.FORCE_COLOR==="false"?n=0:n=o.FORCE_COLOR.length===0?1:Math.min(parseInt(o.FORCE_COLOR,10),3));function s(a){return a===0?!1:{level:a,hasBasic:!0,has256:a>=2,has16m:a>=3}}function i(a,l){if(n===0)return 0;if(r("color=16m")||r("color=full")||r("color=truecolor"))return 3;if(r("color=256"))return 2;if(a&&!l&&n===void 0)return 0;const m=n||0;if(o.TERM==="dumb")return m;if(process.platform==="win32"){const c=t.release().split(".");return Number(c[0])>=10&&Number(c[2])>=10586?Number(c[2])>=14931?3:2:1}if("CI"in o)return["TRAVIS","CIRCLECI","APPVEYOR","GITLAB_CI","GITHUB_ACTIONS","BUILDKITE"].some(c=>c in o)||o.CI_NAME==="codeship"?1:m;if("TEAMCITY_VERSION"in o)return/^(9\.(0*[1-9]\d*)\.|\d{2,}\.)/.test(o.TEAMCITY_VERSION)?1:0;if(o.COLORTERM==="truecolor")return 3;if("TERM_PROGRAM"in o){const c=parseInt((o.TERM_PROGRAM_VERSION||"").split(".")[0],10);switch(o.TERM_PROGRAM){case"iTerm.app":return c>=3?3:2;case"Apple_Terminal":return 2}}return/-256(color)?$/i.test(o.TERM)?2:/^screen|^xterm|^vt100|^vt220|^rxvt|color|ansi|cygwin|linux/i.test(o.TERM)||"COLORTERM"in o?1:m}function u(a){const l=i(a,a&&a.isTTY);return s(l)}return Jt={supportsColor:u,stdout:s(i(!0,e.isatty(1))),stderr:s(i(!0,e.isatty(2)))},Jt}we.exports;var Wo;function Gu(){return Wo||(Wo=1,function(t,e){const r=st,o=pr;e.init=m,e.log=u,e.formatArgs=s,e.save=a,e.load=l,e.useColors=n,e.destroy=o.deprecate(()=>{},"Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`."),e.colors=[6,2,3,4,5,1];try{const D=ju();D&&(D.stderr||D).level>=2&&(e.colors=[20,21,26,27,32,33,38,39,40,41,42,43,44,45,56,57,62,63,68,69,74,75,76,77,78,79,80,81,92,93,98,99,112,113,128,129,134,135,148,149,160,161,162,163,164,165,166,167,168,169,170,171,172,173,178,179,184,185,196,197,198,199,200,201,202,203,204,205,206,207,208,209,214,215,220,221])}catch{}e.inspectOpts=Object.keys(process.env).filter(D=>/^debug_/i.test(D)).reduce((D,d)=>{const f=d.substring(6).toLowerCase().replace(/_([a-z])/g,(g,E)=>E.toUpperCase());let h=process.env[d];return/^(yes|on|true|enabled)$/i.test(h)?h=!0:/^(no|off|false|disabled)$/i.test(h)?h=!1:h==="null"?h=null:h=Number(h),D[f]=h,D},{});function n(){return"colors"in e.inspectOpts?!!e.inspectOpts.colors:r.isatty(process.stderr.fd)}function s(D){const{namespace:d,useColors:f}=this;if(f){const h=this.color,g="\x1B[3"+(h<8?h:"8;5;"+h),E=` ${g};1m${d} \x1B[0m`;D[0]=E+D[0].split(`
|
|
71
|
+
`,Pt=(t,e)=>{const s=[];let r="";typeof e=="string"?e={section:e,whitespace:!1}:(e=e||Object.create(null),e.whitespace=e.whitespace===!0);const o=e.whitespace?" = ":"=";for(const n of Object.keys(t)){const i=t[n];if(i&&Array.isArray(i))for(const l of i)r+=ce(n+"[]")+o+ce(l)+Ge;else i&&typeof i=="object"?s.push(n):r+=ce(n)+o+ce(i)+Ge}e.section&&r.length&&(r="["+ce(e.section)+"]"+Ge+r);for(const n of s){const i=Vr(n).join("\\."),l=(e.section?e.section+".":"")+i,{whitespace:c}=e,m=Pt(t[n],{section:l,whitespace:c});r.length&&m.length&&(r+=Ge),r+=m}return r},Vr=t=>t.replace(/\1/g,"LITERAL\\1LITERAL").replace(/\\\./g,"").split(/\./).map(e=>e.replace(/\1/g,"\\.").replace(/\2LITERAL\\1LITERAL\2/g,"")),Jr=t=>{const e=Object.create(null);let s=e,r=null;const o=/^\[([^\]]*)\]$|^([^=]+)(=(.*))?$/i,n=t.split(/[\r\n]+/g);for(const l of n){if(!l||l.match(/^\s*[;#]/))continue;const c=l.match(o);if(!c)continue;if(c[1]!==void 0){if(r=je(c[1]),r==="__proto__"){s=Object.create(null);continue}s=e[r]=e[r]||Object.create(null);continue}const m=je(c[2]),p=m.length>2&&m.slice(-2)==="[]",a=p?m.slice(0,-2):m;if(a==="__proto__")continue;const d=c[3]?je(c[4]):!0,f=d==="true"||d==="false"||d==="null"?JSON.parse(d):d;p&&(bt.call(s,a)?Array.isArray(s[a])||(s[a]=[s[a]]):s[a]=[]),Array.isArray(s[a])?s[a].push(f):s[a]=f}const i=[];for(const l of Object.keys(e)){if(!bt.call(e,l)||typeof e[l]!="object"||Array.isArray(e[l]))continue;const c=Vr(l);s=e;const m=c.pop(),p=m.replace(/\\\./g,".");for(const a of c)a!=="__proto__"&&((!bt.call(s,a)||typeof s[a]!="object")&&(s[a]=Object.create(null)),s=s[a]);s===e&&p===m||(s[p]=e[l],i.push(l))}for(const l of i)delete e[l];return e},Xr=t=>t.startsWith('"')&&t.endsWith('"')||t.startsWith("'")&&t.endsWith("'"),ce=t=>typeof t!="string"||t.match(/[=\r\n]/)||t.match(/^\[/)||t.length>1&&Xr(t)||t!==t.trim()?JSON.stringify(t):t.split(";").join("\\;").split("#").join("\\#"),je=(t,e)=>{if(t=(t||"").trim(),Xr(t)){t.charAt(0)==="'"&&(t=t.slice(1,-1));try{t=JSON.parse(t)}catch{}}else{let s=!1,r="";for(let o=0,n=t.length;o<n;o++){const i=t.charAt(o);if(s)"\\;#".indexOf(i)!==-1?r+=i:r+="\\"+i,s=!1;else{if(";#".indexOf(i)!==-1)break;i==="\\"?s=!0:r+=i}}return s&&(r+="\\"),r.trim()}return t};var Ri={parse:Jr,decode:Jr,stringify:Pt,encode:Pt,safe:ce,unsafe:je},$t=se(Ri);const Qr=t=>I.lstat(t).then(()=>!0,()=>!1),Ii=["","conventional","gitmoji"],Ct="http://localhost:11434",{hasOwnProperty:ki}=Object.prototype,Be=(t,e)=>ki.call(t,e),V=["OPENAI","OLLAMA","HUGGINGFACE","GEMINI","ANTHROPIC","MISTRAL","CODESTRAL","COHERE","GROQ","PERPLEXITY","DEEPSEEK"],Oi=t=>{const e=Object.keys(t),s=new Set([...V,...e.filter(r=>/^[A-Z][A-Z0-9_]*$/.test(r))]);return Array.from(s)},P=(t,e,s)=>{if(!e)throw new v(`Invalid config property ${t}: ${s}`)},u={systemPrompt(t){return t||""},systemPromptPath(t){return t||""},codeReviewPromptPath(t){return t||""},timeout(t){if(!t)return 1e4;P("timeout",/^\d+$/.test(t),"Must be an integer");const e=Number(t);return P("timeout",e>=500,"Must be greater than 500ms"),e},temperature(t){if(!t)return .7;P("temperature",/^(2|\d)(\.\d{1,2})?$/.test(t),"Must be decimal between 0 and 2");const e=Number(t);return P("temperature",e>0,"Must be greater than 0"),P("temperature",e<=2,"Must be less than or equal to 2"),e},maxTokens(t){return t?(P("maxTokens",/^\d+$/.test(t),"Must be an integer"),Number(t)):1024},logging(t){return typeof t=="boolean"?t:t==null?!0:(P("logging",/^(?:true|false)$/.test(t),"Must be a boolean(true or false)"),t==="true")},locale(t){return t?(P("locale",t,"Cannot be empty"),P("locale",/^[a-z-]+$/i.test(t),"Must be a valid locale (letters and dashes/underscores). You can consult the list of codes in: https://wikipedia.org/wiki/List_of_ISO_639-1_codes"),t):"en"},generate(t){if(!t)return 1;P("generate",/^\d+$/.test(t),"Must be an integer");const e=Number(t);return P("generate",e>0,"Must be greater than 0"),P("generate",e<=5,"Must be less or equal to 5"),e},type(t){return t?(P("type",Ii.includes(t),"Invalid commit type"),t):"conventional"},maxLength(t){if(!t)return 50;P("maxLength",/^\d+$/.test(t),"Must be an integer");const e=Number(t);return P("maxLength",e>=20,"Must be greater than 20 characters"),e},includeBody(t){return typeof t=="boolean"?t:t==null?!1:(P("includeBody",/^(?:true|false)$/.test(t),"Must be a boolean(true or false)"),t==="true")},exclude:t=>t?(typeof t=="string"?t?.split(","):t).map(s=>s.trim()).filter(s=>!!s&&s.length>0):[],topP:t=>{if(!t)return .9;P("topP",/^(1|\d)(\.\d{1,2})?$/.test(t),"Must be decimal between 0 and 1");const e=Number(t);return P("topP",e>0,"Must be greater than 0"),P("topP",e<=1,"Must be less than or equal to 1"),e},codeReview(t){return typeof t=="boolean"?t:t==null?!1:(P("codeReview",/^(?:true|false)$/.test(t),"Must be a boolean(true or false)"),t==="true")},disabled(t){return typeof t=="boolean"?t:t==null?!1:(P("disabled",/^(?:true|false)$/.test(t),"Must be a boolean(true or false)"),t==="true")},watchMode(t){return typeof t=="boolean"?t:t==null?!1:(P("watchMode",/^(?:true|false)$/.test(t),"Must be a boolean(true or false)"),t==="true")}},he={OPENAI:{key:t=>t||"",model:t=>t||"gpt-4o-mini",url:t=>t?(P("OPENAI.url",/^https?:\/\//.test(t),"Must be a valid URL"),t):"https://api.openai.com",path:t=>t||"/v1/chat/completions",proxy:t=>t||"",topP:u.topP,systemPrompt:u.systemPrompt,systemPromptPath:u.systemPromptPath,codeReviewPromptPath:u.codeReviewPromptPath,timeout:u.timeout,temperature:u.temperature,maxTokens:u.maxTokens,logging:u.logging,locale:u.locale,generate:u.generate,type:u.type,maxLength:u.maxLength,includeBody:u.includeBody,codeReview:u.codeReview,disabled:u.disabled,watchMode:u.watchMode},HUGGINGFACE:{cookie:t=>t||"",model:t=>t?(P("HUGGINGFACE.model",["CohereForAI/c4ai-command-r-plus","meta-llama/Meta-Llama-3-70B-Instruct","HuggingFaceH4/zephyr-orpo-141b-A35b-v0.1","mistralai/Mixtral-8x7B-Instruct-v0.1","NousResearch/Nous-Hermes-2-Mixtral-8x7B-DPO","01-ai/Yi-1.5-34B-Chat","mistralai/Mistral-7B-Instruct-v0.2","microsoft/Phi-3-mini-4k-instruct"].includes(t),"Invalid model type of HuggingFace chat"),t):"CohereForAI/c4ai-command-r-plus",systemPrompt:u.systemPrompt,systemPromptPath:u.systemPromptPath,codeReviewPromptPath:u.codeReviewPromptPath,logging:u.logging,locale:u.locale,generate:u.generate,type:u.type,maxLength:u.maxLength,includeBody:u.includeBody,codeReview:u.codeReview,disabled:u.disabled,watchMode:u.watchMode},GEMINI:{key:t=>t||"",model:t=>!t||t.length===0?"gemini-2.0-flash":(P("GEMINI.model",["gemini-2.0-flash","gemini-2.0-flash-lite","gemini-2.0-pro-exp-02-05","gemini-2.0-flash-thinking-exp-01-21","gemini-2.0-flash-exp","gemini-1.5-flash","gemini-1.5-flash-8b","gemini-1.5-pro"].includes(t),"Invalid model type of Gemini"),t),systemPrompt:u.systemPrompt,systemPromptPath:u.systemPromptPath,codeReviewPromptPath:u.codeReviewPromptPath,temperature:u.temperature,maxTokens:u.maxTokens,logging:u.logging,locale:u.locale,generate:u.generate,type:u.type,maxLength:u.maxLength,includeBody:u.includeBody,topP:u.topP,codeReview:u.codeReview,disabled:u.disabled,watchMode:u.watchMode},ANTHROPIC:{key:t=>t||"",model:t=>!t||t.length===0?"claude-3-5-haiku-20241022":(P("ANTHROPIC.model",["claude-3-7-sonnet-20250219","claude-3-5-sonnet-20241022","claude-3-5-haiku-20241022","claude-3-opus-20240229","claude-3-sonnet-20240229","claude-3-haiku-20240307"].includes(t),"Invalid model type of Anthropic"),t),systemPrompt:u.systemPrompt,systemPromptPath:u.systemPromptPath,codeReviewPromptPath:u.codeReviewPromptPath,temperature:u.temperature,maxTokens:u.maxTokens,logging:u.logging,locale:u.locale,generate:u.generate,type:u.type,maxLength:u.maxLength,includeBody:u.includeBody,topP:u.topP,codeReview:u.codeReview,disabled:u.disabled,watchMode:u.watchMode},MISTRAL:{key:t=>t||"",model:t=>!t||t.length===0?"pixtral-12b-2409":(P("MISTRAL.model",["codestral-latest","mistral-large-latest","pixtral-large-latest","ministral-8b-latest","mistral-small-latest","mistral-embed","mistral-moderation-latest"].includes(t),"Invalid model type of Mistral AI"),t),systemPrompt:u.systemPrompt,systemPromptPath:u.systemPromptPath,codeReviewPromptPath:u.codeReviewPromptPath,timeout:u.timeout,temperature:u.temperature,maxTokens:u.maxTokens,logging:u.logging,locale:u.locale,generate:u.generate,type:u.type,maxLength:u.maxLength,includeBody:u.includeBody,topP:u.topP,codeReview:u.codeReview,disabled:u.disabled,watchMode:u.watchMode},CODESTRAL:{key:t=>t||"",model:t=>!t||t.length===0?"codestral-latest":(P("CODESTRAL.model",["codestral-latest","codestral-2501"].includes(t),"Invalid model type of Codestral"),t),topP:u.topP,systemPrompt:u.systemPrompt,systemPromptPath:u.systemPromptPath,codeReviewPromptPath:u.codeReviewPromptPath,timeout:u.timeout,temperature:u.temperature,maxTokens:u.maxTokens,logging:u.logging,locale:u.locale,generate:u.generate,type:u.type,maxLength:u.maxLength,includeBody:u.includeBody,codeReview:u.codeReview,disabled:u.disabled,watchMode:u.watchMode},OLLAMA:{model:t=>t?(typeof t=="string"?t?.split(","):t).map(s=>s.trim()).filter(s=>!!s&&s.length>0):[],host:t=>t?(P("OLLAMA.host",/^https?:\/\//.test(t),"Must be a valid URL"),t):Ct,timeout:t=>{if(!t)return 1e5;P("OLLAMA.timeout",/^\d+$/.test(t),"Must be an integer");const e=Number(t);return P("OLLAMA.timeout",e>=500,"Must be greater than 500ms"),e},auth:t=>t||"",key:t=>t||"",numCtx:t=>{if(!t)return 2048;P("OLLAMA.numCtx",/^\d+$/.test(t),"Must be an integer");const e=Number(t);return P("OLLAMA.numCtx",e>=2048,"Must be greater than 2048"),e},systemPrompt:u.systemPrompt,systemPromptPath:u.systemPromptPath,codeReviewPromptPath:u.codeReviewPromptPath,temperature:u.temperature,logging:u.logging,locale:u.locale,generate:u.generate,type:u.type,maxLength:u.maxLength,includeBody:u.includeBody,topP:u.topP,codeReview:u.codeReview,disabled:u.disabled,watchMode:u.watchMode},COHERE:{key:t=>t||"",model:t=>!t||t.length===0?"command":(P("COHERE.model",["command-r7b-12-2024","command-r-plus-08-2024","command-r-plus-04-2024","command-r-plus","command-r-08-2024","command-r-03-2024","command-r","command","command-nightly","command-light","command-light-nightly","c4ai-aya-expanse-8b","c4ai-aya-expanse-32b"].includes(t),"Invalid model type of Cohere"),t),systemPrompt:u.systemPrompt,systemPromptPath:u.systemPromptPath,codeReviewPromptPath:u.codeReviewPromptPath,temperature:u.temperature,maxTokens:u.maxTokens,logging:u.logging,locale:u.locale,generate:u.generate,type:u.type,maxLength:u.maxLength,includeBody:u.includeBody,topP:u.topP,codeReview:u.codeReview,disabled:u.disabled,watchMode:u.watchMode},GROQ:{key:t=>t||"",model:t=>!t||t.length===0?"deepseek-r1-distill-llama-70b":(P("GROQ.model",["qwen-2.5-32b","qwen-2.5-coder-32b","deepseek-r1-distill-qwen-32b","deepseek-r1-distill-llama-70b","gemma2-9b-it","llama-3.3-70b-versatile","llama-3.1-8b-instant","llama-guard-3-8b","llama3-70b-8192","llama3-8b-8192","mixtral-8x7b-32768","distil-whisper-large-v3-en","whisper-large-v3","whisper-large-v3-turbo","llama-3.3-70b-specdec","llama-3.2-1b-preview","llama-3.2-3b-preview","llama-3.2-11b-vision-preview","llama-3.2-90b-vision-preview"].includes(t),"Invalid model type of Groq"),t),systemPrompt:u.systemPrompt,systemPromptPath:u.systemPromptPath,codeReviewPromptPath:u.codeReviewPromptPath,timeout:u.timeout,temperature:u.temperature,maxTokens:u.maxTokens,logging:u.logging,locale:u.locale,generate:u.generate,type:u.type,maxLength:u.maxLength,includeBody:u.includeBody,topP:u.topP,codeReview:u.codeReview,disabled:u.disabled,watchMode:u.watchMode},PERPLEXITY:{key:t=>t||"",model:t=>!t||t.length===0?"sonar":(P("PERPLEXITY.model",["sonar-pro","sonar","llama-3.1-sonar-small-128k-online","llama-3.1-sonar-large-128k-online","llama-3.1-sonar-huge-128k-online"].includes(t),"Invalid model type of Perplexity"),t),topP:u.topP,systemPrompt:u.systemPrompt,systemPromptPath:u.systemPromptPath,codeReviewPromptPath:u.codeReviewPromptPath,timeout:u.timeout,temperature:u.temperature,maxTokens:u.maxTokens,logging:u.logging,locale:u.locale,generate:u.generate,type:u.type,maxLength:u.maxLength,includeBody:u.includeBody,codeReview:u.codeReview,disabled:u.disabled,watchMode:u.watchMode},DEEPSEEK:{key:t=>t||"",model:t=>!t||t.length===0?"deepseek-chat":(console.log(t),P("DEEPSEEK.model",["deepseek-reasoner","deepseek-chat"].includes(t),"Invalid model type of DeepSeek"),t),topP:u.topP,systemPrompt:u.systemPrompt,systemPromptPath:u.systemPromptPath,codeReviewPromptPath:u.codeReviewPromptPath,timeout:u.timeout,temperature:u.temperature,maxTokens:u.maxTokens,logging:u.logging,locale:u.locale,generate:u.generate,type:u.type,maxLength:u.maxLength,includeBody:u.includeBody,codeReview:u.codeReview,disabled:u.disabled,watchMode:u.watchMode}},He=T.join(Ze.homedir(),".aicommit2"),Li=(t=[])=>{const e={};for(const s of t)if(s.startsWith("--")){const[r,o]=s.slice(2).split("="),[n,i]=r.split(".");n&&i&&n in he?(e[n]||(e[n]={}),e[n][i]=o):e[r]=o}return e},Zr=async()=>await Qr(He)?await I.readFile(He,"utf8"):"",Et=async()=>{const t=await Zr();if(!t)return Object.create(null);let e=$t.parse(t);return Be(e,"OLLAMA")&&Be(e.OLLAMA,"model")&&(e={...e,OLLAMA:{...e.OLLAMA,model:typeof e.OLLAMA.model=="string"?[e.OLLAMA.model]:e.OLLAMA.model}}),Be(e,"exclude")&&(e={...e,exclude:typeof e.exclude=="string"?[e.exclude]:e.exclude}),e},ge=async(t,e=[])=>{const s=await Et(),r=Li(e),o={...t,...r},n={},i=Oi(s),l={},c=V.map(p=>({service:p,envKey:`${p}_API_KEY`}));for(const{service:p,envKey:a}of c){const d=process.env[a];d&&(l[p]={key:d})}const m=(p,a)=>{const d=o[`${p}.${a}`]??o[p]?.[a],f=l[p]?.[a],h=s[p]?.[a],g=o[a]??s[a];return d!==void 0?d:f!==void 0?f:h!==void 0?h:g};for(const[p,a]of Object.entries(u)){const d=o[p]??s[p];n[p]=a(d)}for(const p of i){n[p]={};const a=he[p]||Ue(p);for(const[d,f]of Object.entries(a)){const h=m(p,d);n[p][d]=f(h)}}return n},Ti=async t=>{const e=await Et();for(const[s,r]of t){const[o,n]=s.split(".");if(!n){const c=u[s];if(!c)throw new v(`Invalid config property: ${s}`);e[s]=c(r);continue}if(e[o]||(e[o]={}),V.includes(o)){const c=he[o][n];if(!c)throw new v(`Invalid config property: ${s}`);e[o][n]=c(r);continue}if(!/^[A-Z][A-Z0-9_]*$/.test(o))throw new v(`Invalid service name: ${o}. Service names must be uppercase letters, numbers, and underscores.`);const l=Ue(o);if(!l[n])throw new v(`Invalid config property for custom service: ${s}`);try{e[o][n]=l[n](r)}catch(c){throw c instanceof v?c:new v(`Invalid value for ${s}: ${c.message}`)}}await I.writeFile(He,$t.stringify(e),"utf8")},Ni=async t=>{const e=await Et();for(const[s,r]of t){const[o,n]=s.split("."),i=e[o];if(o==="OLLAMA"&&n==="model"){i||(e[o]={});const c=e[o][n]||[];e[o][n]=_e([...c,r]);continue}if(i&&i.compatible===!0){i||(e[o]={});const c=Ue(o);if(!c[n])throw new v(`Invalid config property: ${s}`);try{e[o][n]=c[n](r)}catch(m){throw m instanceof v?m:new v(`Invalid value for ${s}: ${m.message}`)}continue}if(o in he){i||(e[o]={});const c=he[o][n];if(!c)throw new v(`Invalid config property: ${s}`);e[o][n]=c(r)}else{const c=Ue(o);if(!c[n])throw new v(`Invalid config property: ${s}`);e[o]||(e[o]={}),e[o][n]=c[n](r)}}await I.writeFile(He,$t.stringify(e),"utf8")},Fi=async()=>{const t=await Zr();console.log(t)},Ue=t=>({compatible:e=>typeof e=="boolean"?e:e==null?!1:(P("compatible",/^(?:true|false)$/.test(e),"Must be a boolean(true or false)"),e==="true"),stream:e=>typeof e=="boolean"?e:e==null?!1:(P("stream",/^(?:true|false)$/.test(e),"Must be a boolean(true or false)"),e==="true"),url:e=>e?(P(`${t}.url`,/^https?:\/\//.test(e),"Must be a valid URL"),e):"",path:e=>e||"",key:e=>e||"",model:e=>e||"",systemPrompt:u.systemPrompt,systemPromptPath:u.systemPromptPath,codeReviewPromptPath:u.codeReviewPromptPath,timeout:u.timeout,temperature:u.temperature,maxTokens:u.maxTokens,logging:u.logging,locale:u.locale,generate:u.generate,type:u.type,maxLength:u.maxLength,includeBody:u.includeBody,topP:u.topP,codeReview:u.codeReview,disabled:u.disabled,watchMode:u.watchMode});class es extends j{constructor(e){super(e),this.params=e,this.host=Ct,this.model="",this.key="",this.auth="",this.handleError$=s=>{if(s.response&&s.response.data?.error)return O({name:`${this.errorPrefix} ${s.response.data?.error}`,value:s.response.data?.error,isError:!0,disabled:!0});const r=s.message?.replace(/(\r\n|\n|\r)/gm,"")||"An error occurred";return O({name:`${this.errorPrefix} ${r}`,value:r,isError:!0,disabled:!0})},this.setupFetch=(s,r={})=>Js(s,{...r,dispatcher:new Xs({headersTimeout:this.params.config.timeout})}),this.colors={primary:"#FFF",secondary:"#000"},this.model=this.params.keyName,this.serviceName=w.bgHex(this.colors.primary).hex(this.colors.secondary).bold(`[${Ne(this.model)}]`),this.errorPrefix=w.red.bold(`[${Ne(this.model)}]`),this.host=this.params.config.host||Ct,this.auth=this.params.config.auth||"Bearer",this.key=this.params.config.key||"",this.ollama=new Vs({host:this.host,fetch:this.setupFetch,...this.key&&{headers:{Authorization:`${this.auth} ${this.key}`}}})}generateCommitMessage$(){return M(this.generateMessage("commit")).pipe(A(e=>$(e)),E(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:this.params.config.includeBody?e.value:e.title,description:this.params.config.includeBody?e.value:"",isError:!1})),x(this.handleError$))}generateCodeReview$(){return M(this.generateMessage("review")).pipe(A(e=>$(e)),E(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:e.value,description:e.value,isError:!1})),x(this.handleError$))}async generateMessage(e){try{const s=this.params.stagedDiff.diff,{systemPrompt:r,systemPromptPath:o,codeReviewPromptPath:n,logging:i,locale:l,generate:c,type:m,maxLength:p}=this.params.config,a={...G,locale:l,maxLength:p,type:m,generate:c,systemPrompt:r,systemPromptPath:o,codeReviewPromptPath:n},d=e==="review"?U(a):H(a);await this.checkIsAvailableOllama();const f=await this.createChatCompletions(d,`Here is the diff: ${s}`);return i&&B(`Ollama_${this.model}`,s,d,f,e),e==="review"?this.sanitizeResponse(f):this.parseMessage(f,m,c)}catch(s){const r=s;throw r.code==="ENOTFOUND"?new v(`Error connecting to ${r.hostname} (${r.syscall})`):r}}async checkIsAvailableOllama(){try{const e=new fe({method:"GET",baseURL:`${this.host}`,timeout:this.params.config.timeout});return this.key&&e.setHeaders({Authorization:`${this.auth} ${this.key}`}),(await e.execute()).data}catch(e){throw e.code==="ECONNREFUSED"?new v(`Error connecting to ${this.host}. Please run Ollama or check host`):e}}async createChatCompletions(e,s){const r=this.params.config.stream||!1,o=await this.ollama.chat({model:this.model,messages:[{role:"system",content:e},{role:"user",content:s}],stream:r,keep_alive:this.params.config.timeout,options:{num_ctx:this.params.config.numCtx,temperature:this.params.config.temperature,top_p:this.params.config.topP,seed:Fe(10,1e3)}});if(r){let n="";if(o)for await(const i of o)n+=i.message.content;return n}return o.message.content}}class ts extends j{constructor(e){super(e),this.params=e,this.handleError$=r=>{let o="N/A",n=r.message;r instanceof xe.APIConnectionTimeoutError?n=`Connection timeout: ${r.message}`:r instanceof xe.APIError&&(o=`${r.status}`,n=r.name);const i=`${o} ${n}`;return O({name:`${this.errorPrefix} ${i}`,value:n,isError:!0,disabled:!0})};const s=this.params.keyName||"OPENAI_COMPATIBLE";this.colors=bi(s),this.serviceName=w.bgHex(this.colors.primary).hex(this.colors.secondary).bold(`[${Ne(s)}]`),this.errorPrefix=w.red.bold(`[${Ne(s)}]`),this.openAI=new xe({apiKey:this.params.config.key,baseURL:`${this.params.config.url}${this.params.config.path}`})}generateCommitMessage$(){return M(this.generateMessage("commit")).pipe(A(e=>$(e)),E(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:this.params.config.includeBody?e.value:e.title,description:this.params.config.includeBody?e.value:"",isError:!1})),x(this.handleError$))}generateCodeReview$(){return M(this.generateMessage("review")).pipe(A(e=>$(e)),E(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:e.value,description:e.value,isError:!1})),x(this.handleError$))}async generateMessage(e){try{const s=this.params.stagedDiff.diff,{systemPrompt:r,systemPromptPath:o,codeReviewPromptPath:n,logging:i,locale:l,temperature:c,generate:m,type:p,maxLength:a,timeout:d,stream:f=!1}=this.params.config,h=this.params.config.maxTokens,g={...G,locale:l,maxLength:a,type:p,generate:m,systemPrompt:r,systemPromptPath:o,codeReviewPromptPath:n},y=e==="review"?U(g):H(g),b=await this.openAI.chat.completions.create({messages:[{role:"system",content:y},{role:"user",content:`Here is the diff: ${s}`}],model:this.params.config.model,stream:f,max_tokens:h,top_p:this.params.config.topP,temperature:c},{timeout:d});let C="";if(f&&b){const F=b;for await(const K of F){const W=K.choices[0]?.delta?.content||"",me=K.choices[0]?.delta?.reasoning_content||"",Y=`${W}${me}`;C+=Y}}else C=b.choices[0].message.content||"";return i&&B(this.params.keyName,s,y,C,e),e==="review"?this.sanitizeResponse(C):this.parseMessage(C,p,m)}catch(s){throw console.error("generateMessage error >>>",s),s}}}var xt={},At={exports:{}},ye={exports:{}},Mt,rs;function _i(){if(rs)return Mt;rs=1;var t=1e3,e=t*60,s=e*60,r=s*24,o=r*7,n=r*365.25;Mt=function(p,a){a=a||{};var d=typeof p;if(d==="string"&&p.length>0)return i(p);if(d==="number"&&isFinite(p))return a.long?c(p):l(p);throw new Error("val is not a non-empty string or a valid number. val="+JSON.stringify(p))};function i(p){if(p=String(p),!(p.length>100)){var a=/^(-?(?:\d+)?\.?\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(p);if(a){var d=parseFloat(a[1]),f=(a[2]||"ms").toLowerCase();switch(f){case"years":case"year":case"yrs":case"yr":case"y":return d*n;case"weeks":case"week":case"w":return d*o;case"days":case"day":case"d":return d*r;case"hours":case"hour":case"hrs":case"hr":case"h":return d*s;case"minutes":case"minute":case"mins":case"min":case"m":return d*e;case"seconds":case"second":case"secs":case"sec":case"s":return d*t;case"milliseconds":case"millisecond":case"msecs":case"msec":case"ms":return d;default:return}}}}function l(p){var a=Math.abs(p);return a>=r?Math.round(p/r)+"d":a>=s?Math.round(p/s)+"h":a>=e?Math.round(p/e)+"m":a>=t?Math.round(p/t)+"s":p+"ms"}function c(p){var a=Math.abs(p);return a>=r?m(p,a,r,"day"):a>=s?m(p,a,s,"hour"):a>=e?m(p,a,e,"minute"):a>=t?m(p,a,t,"second"):p+" ms"}function m(p,a,d,f){var h=a>=d*1.5;return Math.round(p/d)+" "+f+(h?"s":"")}return Mt}var St,ss;function os(){if(ss)return St;ss=1;function t(e){r.debug=r,r.default=r,r.coerce=m,r.disable=l,r.enable=n,r.enabled=c,r.humanize=_i(),r.destroy=p,Object.keys(e).forEach(a=>{r[a]=e[a]}),r.names=[],r.skips=[],r.formatters={};function s(a){let d=0;for(let f=0;f<a.length;f++)d=(d<<5)-d+a.charCodeAt(f),d|=0;return r.colors[Math.abs(d)%r.colors.length]}r.selectColor=s;function r(a){let d,f=null,h,g;function y(...b){if(!y.enabled)return;const C=y,F=Number(new Date),K=F-(d||F);C.diff=K,C.prev=d,C.curr=F,d=F,b[0]=r.coerce(b[0]),typeof b[0]!="string"&&b.unshift("%O");let W=0;b[0]=b[0].replace(/%([a-zA-Z%])/g,(Y,Is)=>{if(Y==="%%")return"%";W++;const qt=r.formatters[Is];if(typeof qt=="function"){const ks=b[W];Y=qt.call(C,ks),b.splice(W,1),W--}return Y}),r.formatArgs.call(C,b),(C.log||r.log).apply(C,b)}return y.namespace=a,y.useColors=r.useColors(),y.color=r.selectColor(a),y.extend=o,y.destroy=r.destroy,Object.defineProperty(y,"enabled",{enumerable:!0,configurable:!1,get:()=>f!==null?f:(h!==r.namespaces&&(h=r.namespaces,g=r.enabled(a)),g),set:b=>{f=b}}),typeof r.init=="function"&&r.init(y),y}function o(a,d){const f=r(this.namespace+(typeof d>"u"?":":d)+a);return f.log=this.log,f}function n(a){r.save(a),r.namespaces=a,r.names=[],r.skips=[];const d=(typeof a=="string"?a:"").trim().replace(" ",",").split(",").filter(Boolean);for(const f of d)f[0]==="-"?r.skips.push(f.slice(1)):r.names.push(f)}function i(a,d){let f=0,h=0,g=-1,y=0;for(;f<a.length;)if(h<d.length&&(d[h]===a[f]||d[h]==="*"))d[h]==="*"?(g=h,y=f,h++):(f++,h++);else if(g!==-1)h=g+1,y++,f=y;else return!1;for(;h<d.length&&d[h]==="*";)h++;return h===d.length}function l(){const a=[...r.names,...r.skips.map(d=>"-"+d)].join(",");return r.enable(""),a}function c(a){for(const d of r.skips)if(i(a,d))return!1;for(const d of r.names)if(i(a,d))return!0;return!1}function m(a){return a instanceof Error?a.stack||a.message:a}function p(){console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.")}return r.enable(r.load()),r}return St=t,St}ye.exports;var ns;function Di(){return ns||(ns=1,function(t,e){e.formatArgs=r,e.save=o,e.load=n,e.useColors=s,e.storage=i(),e.destroy=(()=>{let c=!1;return()=>{c||(c=!0,console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`."))}})(),e.colors=["#0000CC","#0000FF","#0033CC","#0033FF","#0066CC","#0066FF","#0099CC","#0099FF","#00CC00","#00CC33","#00CC66","#00CC99","#00CCCC","#00CCFF","#3300CC","#3300FF","#3333CC","#3333FF","#3366CC","#3366FF","#3399CC","#3399FF","#33CC00","#33CC33","#33CC66","#33CC99","#33CCCC","#33CCFF","#6600CC","#6600FF","#6633CC","#6633FF","#66CC00","#66CC33","#9900CC","#9900FF","#9933CC","#9933FF","#99CC00","#99CC33","#CC0000","#CC0033","#CC0066","#CC0099","#CC00CC","#CC00FF","#CC3300","#CC3333","#CC3366","#CC3399","#CC33CC","#CC33FF","#CC6600","#CC6633","#CC9900","#CC9933","#CCCC00","#CCCC33","#FF0000","#FF0033","#FF0066","#FF0099","#FF00CC","#FF00FF","#FF3300","#FF3333","#FF3366","#FF3399","#FF33CC","#FF33FF","#FF6600","#FF6633","#FF9900","#FF9933","#FFCC00","#FFCC33"];function s(){if(typeof window<"u"&&window.process&&(window.process.type==="renderer"||window.process.__nwjs))return!0;if(typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/(edge|trident)\/(\d+)/))return!1;let c;return typeof document<"u"&&document.documentElement&&document.documentElement.style&&document.documentElement.style.WebkitAppearance||typeof window<"u"&&window.console&&(window.console.firebug||window.console.exception&&window.console.table)||typeof navigator<"u"&&navigator.userAgent&&(c=navigator.userAgent.toLowerCase().match(/firefox\/(\d+)/))&&parseInt(c[1],10)>=31||typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/applewebkit\/(\d+)/)}function r(c){if(c[0]=(this.useColors?"%c":"")+this.namespace+(this.useColors?" %c":" ")+c[0]+(this.useColors?"%c ":" ")+"+"+t.exports.humanize(this.diff),!this.useColors)return;const m="color: "+this.color;c.splice(1,0,m,"color: inherit");let p=0,a=0;c[0].replace(/%[a-zA-Z%]/g,d=>{d!=="%%"&&(p++,d==="%c"&&(a=p))}),c.splice(a,0,m)}e.log=console.debug||console.log||(()=>{});function o(c){try{c?e.storage.setItem("debug",c):e.storage.removeItem("debug")}catch{}}function n(){let c;try{c=e.storage.getItem("debug")}catch{}return!c&&typeof process<"u"&&"env"in process&&(c=process.env.DEBUG),c}function i(){try{return localStorage}catch{}}t.exports=os()(e);const{formatters:l}=t.exports;l.j=function(c){try{return JSON.stringify(c)}catch(m){return"[UnexpectedJSONParseError]: "+m.message}}}(ye,ye.exports)),ye.exports}var we={exports:{}},Rt,is;function Gi(){return is||(is=1,Rt=(t,e=process.argv)=>{const s=t.startsWith("-")?"":t.length===1?"-":"--",r=e.indexOf(s+t),o=e.indexOf("--");return r!==-1&&(o===-1||r<o)}),Rt}var It,as;function ji(){if(as)return It;as=1;const t=Ze,e=sr,s=Gi(),{env:r}=process;let o;s("no-color")||s("no-colors")||s("color=false")||s("color=never")?o=0:(s("color")||s("colors")||s("color=true")||s("color=always"))&&(o=1),"FORCE_COLOR"in r&&(r.FORCE_COLOR==="true"?o=1:r.FORCE_COLOR==="false"?o=0:o=r.FORCE_COLOR.length===0?1:Math.min(parseInt(r.FORCE_COLOR,10),3));function n(c){return c===0?!1:{level:c,hasBasic:!0,has256:c>=2,has16m:c>=3}}function i(c,m){if(o===0)return 0;if(s("color=16m")||s("color=full")||s("color=truecolor"))return 3;if(s("color=256"))return 2;if(c&&!m&&o===void 0)return 0;const p=o||0;if(r.TERM==="dumb")return p;if(process.platform==="win32"){const a=t.release().split(".");return Number(a[0])>=10&&Number(a[2])>=10586?Number(a[2])>=14931?3:2:1}if("CI"in r)return["TRAVIS","CIRCLECI","APPVEYOR","GITLAB_CI","GITHUB_ACTIONS","BUILDKITE"].some(a=>a in r)||r.CI_NAME==="codeship"?1:p;if("TEAMCITY_VERSION"in r)return/^(9\.(0*[1-9]\d*)\.|\d{2,}\.)/.test(r.TEAMCITY_VERSION)?1:0;if(r.COLORTERM==="truecolor")return 3;if("TERM_PROGRAM"in r){const a=parseInt((r.TERM_PROGRAM_VERSION||"").split(".")[0],10);switch(r.TERM_PROGRAM){case"iTerm.app":return a>=3?3:2;case"Apple_Terminal":return 2}}return/-256(color)?$/i.test(r.TERM)?2:/^screen|^xterm|^vt100|^vt220|^rxvt|color|ansi|cygwin|linux/i.test(r.TERM)||"COLORTERM"in r?1:p}function l(c){const m=i(c,c&&c.isTTY);return n(m)}return It={supportsColor:l,stdout:n(i(!0,e.isatty(1))),stderr:n(i(!0,e.isatty(2)))},It}we.exports;var cs;function Bi(){return cs||(cs=1,function(t,e){const s=sr,r=Jt;e.init=p,e.log=l,e.formatArgs=n,e.save=c,e.load=m,e.useColors=o,e.destroy=r.deprecate(()=>{},"Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`."),e.colors=[6,2,3,4,5,1];try{const d=ji();d&&(d.stderr||d).level>=2&&(e.colors=[20,21,26,27,32,33,38,39,40,41,42,43,44,45,56,57,62,63,68,69,74,75,76,77,78,79,80,81,92,93,98,99,112,113,128,129,134,135,148,149,160,161,162,163,164,165,166,167,168,169,170,171,172,173,178,179,184,185,196,197,198,199,200,201,202,203,204,205,206,207,208,209,214,215,220,221])}catch{}e.inspectOpts=Object.keys(process.env).filter(d=>/^debug_/i.test(d)).reduce((d,f)=>{const h=f.substring(6).toLowerCase().replace(/_([a-z])/g,(y,b)=>b.toUpperCase());let g=process.env[f];return/^(yes|on|true|enabled)$/i.test(g)?g=!0:/^(no|off|false|disabled)$/i.test(g)?g=!1:g==="null"?g=null:g=Number(g),d[h]=g,d},{});function o(){return"colors"in e.inspectOpts?!!e.inspectOpts.colors:s.isatty(process.stderr.fd)}function n(d){const{namespace:f,useColors:h}=this;if(h){const g=this.color,y="\x1B[3"+(g<8?g:"8;5;"+g),b=` ${y};1m${f} \x1B[0m`;d[0]=b+d[0].split(`
|
|
92
72
|
`).join(`
|
|
93
|
-
`+
|
|
94
|
-
`)}function
|
|
95
|
-
`).map(
|
|
96
|
-
`).some(e=>e.indexOf("(https.js:")!==-1||e.indexOf("node:https:")!==-1)}function
|
|
73
|
+
`+b),d.push(y+"m+"+t.exports.humanize(this.diff)+"\x1B[0m")}else d[0]=i()+f+" "+d[0]}function i(){return e.inspectOpts.hideDate?"":new Date().toISOString()+" "}function l(...d){return process.stderr.write(r.formatWithOptions(e.inspectOpts,...d)+`
|
|
74
|
+
`)}function c(d){d?process.env.DEBUG=d:delete process.env.DEBUG}function m(){return process.env.DEBUG}function p(d){d.inspectOpts={};const f=Object.keys(e.inspectOpts);for(let h=0;h<f.length;h++)d.inspectOpts[f[h]]=e.inspectOpts[f[h]]}t.exports=os()(e);const{formatters:a}=t.exports;a.o=function(d){return this.inspectOpts.colors=this.useColors,r.inspect(d,this.inspectOpts).split(`
|
|
75
|
+
`).map(f=>f.trim()).join(" ")},a.O=function(d){return this.inspectOpts.colors=this.useColors,r.inspect(d,this.inspectOpts)}}(we,we.exports)),we.exports}typeof process>"u"||process.type==="renderer"||process.browser===!0||process.__nwjs?At.exports=Di():At.exports=Bi();var kt=At.exports,Ot={};Object.defineProperty(Ot,"__esModule",{value:!0});function Hi(t){return function(e,s){return new Promise((r,o)=>{t.call(this,e,s,(n,i)=>{n?o(n):r(i)})})}}Ot.default=Hi;var ls=k&&k.__importDefault||function(t){return t&&t.__esModule?t:{default:t}};const Ui=Vt,qi=ls(kt),zi=ls(Ot),ve=qi.default("agent-base");function Ki(t){return!!t&&typeof t.addRequest=="function"}function Lt(){const{stack:t}=new Error;return typeof t!="string"?!1:t.split(`
|
|
76
|
+
`).some(e=>e.indexOf("(https.js:")!==-1||e.indexOf("node:https:")!==-1)}function qe(t,e){return new qe.Agent(t,e)}(function(t){class e extends Ui.EventEmitter{constructor(r,o){super();let n=o;typeof r=="function"?this.callback=r:r&&(n=r),this.timeout=null,n&&typeof n.timeout=="number"&&(this.timeout=n.timeout),this.maxFreeSockets=1,this.maxSockets=1,this.maxTotalSockets=1/0,this.sockets={},this.freeSockets={},this.requests={},this.options={}}get defaultPort(){return typeof this.explicitDefaultPort=="number"?this.explicitDefaultPort:Lt()?443:80}set defaultPort(r){this.explicitDefaultPort=r}get protocol(){return typeof this.explicitProtocol=="string"?this.explicitProtocol:Lt()?"https:":"http:"}set protocol(r){this.explicitProtocol=r}callback(r,o,n){throw new Error('"agent-base" has no default implementation, you must subclass and override `callback()`')}addRequest(r,o){const n=Object.assign({},o);typeof n.secureEndpoint!="boolean"&&(n.secureEndpoint=Lt()),n.host==null&&(n.host="localhost"),n.port==null&&(n.port=n.secureEndpoint?443:80),n.protocol==null&&(n.protocol=n.secureEndpoint?"https:":"http:"),n.host&&n.path&&delete n.path,delete n.agent,delete n.hostname,delete n._defaultAgent,delete n.defaultPort,delete n.createConnection,r._last=!0,r.shouldKeepAlive=!1;let i=!1,l=null;const c=n.timeout||this.timeout,m=f=>{r._hadError||(r.emit("error",f),r._hadError=!0)},p=()=>{l=null,i=!0;const f=new Error(`A "socket" was not created for HTTP request before ${c}ms`);f.code="ETIMEOUT",m(f)},a=f=>{i||(l!==null&&(clearTimeout(l),l=null),m(f))},d=f=>{if(i)return;if(l!=null&&(clearTimeout(l),l=null),Ki(f)){ve("Callback returned another Agent instance %o",f.constructor.name),f.addRequest(r,n);return}if(f){f.once("free",()=>{this.freeSocket(f,n)}),r.onSocket(f);return}const h=new Error(`no Duplex stream was returned to agent-base for \`${r.method} ${r.path}\``);m(h)};if(typeof this.callback!="function"){m(new Error("`callback` is not defined"));return}this.promisifiedCallback||(this.callback.length>=3?(ve("Converting legacy callback function to promise"),this.promisifiedCallback=zi.default(this.callback)):this.promisifiedCallback=this.callback),typeof c=="number"&&c>0&&(l=setTimeout(p,c)),"port"in n&&typeof n.port!="number"&&(n.port=Number(n.port));try{ve("Resolving socket for %o request: %o",n.protocol,`${r.method} ${r.path}`),Promise.resolve(this.promisifiedCallback(r,n)).then(d,a)}catch(f){Promise.reject(f).catch(a)}}freeSocket(r,o){ve("Freeing socket %o %o",r.constructor.name,o),r.destroy()}destroy(){ve("Destroying agent %o",this.constructor.name)}}t.Agent=e,t.prototype=t.Agent.prototype})(qe||(qe={}));var Wi=qe,Tt={},Yi=k&&k.__importDefault||function(t){return t&&t.__esModule?t:{default:t}};Object.defineProperty(Tt,"__esModule",{value:!0});const Vi=Yi(kt),be=Vi.default("https-proxy-agent:parse-proxy-response");function Ji(t){return new Promise((e,s)=>{let r=0;const o=[];function n(){const a=t.read();a?p(a):t.once("readable",n)}function i(){t.removeListener("end",c),t.removeListener("error",m),t.removeListener("close",l),t.removeListener("readable",n)}function l(a){be("onclose had error %o",a)}function c(){be("onend")}function m(a){i(),be("onerror %o",a),s(a)}function p(a){o.push(a),r+=a.length;const d=Buffer.concat(o,r);if(d.indexOf(`\r
|
|
97
77
|
\r
|
|
98
|
-
`)===-1){be("have not received end of HTTP headers yet..."),
|
|
99
|
-
`)),h
|
|
100
|
-
`;
|
|
101
|
-
`;const
|
|
102
|
-
`);const{statusCode:
|
|
78
|
+
`)===-1){be("have not received end of HTTP headers yet..."),n();return}const h=d.toString("ascii",0,d.indexOf(`\r
|
|
79
|
+
`)),g=+h.split(" ")[1];be("got proxy server response: %o",h),e({statusCode:g,buffered:d})}t.on("error",m),t.on("close",l),t.on("end",c),n()})}Tt.default=Ji;var Xi=k&&k.__awaiter||function(t,e,s,r){function o(n){return n instanceof s?n:new s(function(i){i(n)})}return new(s||(s=Promise))(function(n,i){function l(p){try{m(r.next(p))}catch(a){i(a)}}function c(p){try{m(r.throw(p))}catch(a){i(a)}}function m(p){p.done?n(p.value):o(p.value).then(l,c)}m((r=r.apply(t,e||[])).next())})},le=k&&k.__importDefault||function(t){return t&&t.__esModule?t:{default:t}};Object.defineProperty(xt,"__esModule",{value:!0});const ms=le(eo),us=le(to),Qi=le(ro),Zi=le(Yt),ea=le(kt),ta=Wi,ra=le(Tt),Pe=ea.default("https-proxy-agent:agent");class sa extends ta.Agent{constructor(e){let s;if(typeof e=="string"?s=Qi.default.parse(e):s=e,!s)throw new Error("an HTTP(S) proxy server `host` and `port` must be specified!");Pe("creating new HttpsProxyAgent instance: %o",s),super(s);const r=Object.assign({},s);this.secureProxy=s.secureProxy||ia(r.protocol),r.host=r.hostname||r.host,typeof r.port=="string"&&(r.port=parseInt(r.port,10)),!r.port&&r.host&&(r.port=this.secureProxy?443:80),this.secureProxy&&!("ALPNProtocols"in r)&&(r.ALPNProtocols=["http 1.1"]),r.host&&r.path&&(delete r.path,delete r.pathname),this.proxy=r}callback(e,s){return Xi(this,void 0,void 0,function*(){const{proxy:r,secureProxy:o}=this;let n;o?(Pe("Creating `tls.Socket`: %o",r),n=us.default.connect(r)):(Pe("Creating `net.Socket`: %o",r),n=ms.default.connect(r));const i=Object.assign({},r.headers);let c=`CONNECT ${`${s.host}:${s.port}`} HTTP/1.1\r
|
|
80
|
+
`;r.auth&&(i["Proxy-Authorization"]=`Basic ${Buffer.from(r.auth).toString("base64")}`);let{host:m,port:p,secureEndpoint:a}=s;na(p,a)||(m+=`:${p}`),i.Host=m,i.Connection="close";for(const y of Object.keys(i))c+=`${y}: ${i[y]}\r
|
|
81
|
+
`;const d=ra.default(n);n.write(`${c}\r
|
|
82
|
+
`);const{statusCode:f,buffered:h}=yield d;if(f===200){if(e.once("socket",oa),s.secureEndpoint){Pe("Upgrading socket connection to TLS");const y=s.servername||s.host;return us.default.connect(Object.assign(Object.assign({},aa(s,"host","hostname","path","port")),{socket:n,servername:y}))}return n}n.destroy();const g=new ms.default.Socket({writable:!1});return g.readable=!0,e.once("socket",y=>{Pe("replaying proxy buffer for failed request"),Zi.default(y.listenerCount("data")>0),y.push(h),y.push(null)}),g})}}xt.default=sa;function oa(t){t.resume()}function na(t,e){return!!(!e&&t===80||e&&t===443)}function ia(t){return typeof t=="string"?/^https:?$/i.test(t):!1}function aa(t,...e){const s={};let r;for(r in t)e.includes(r)||(s[r]=t[r]);return s}var ca=k&&k.__importDefault||function(t){return t&&t.__esModule?t:{default:t}};const Nt=ca(xt);function Ft(t){return new Nt.default(t)}(function(t){t.HttpsProxyAgent=Nt.default,t.prototype=Nt.default.prototype})(Ft||(Ft={}));var la=Ft,ma=se(la);const ua=async(t,e,s,r,o,n,i)=>new Promise((l,c)=>{const m=JSON.stringify(r),a=(t.protocol.includes("https")?Zs:Qs).request({port:i||void 0,hostname:t.hostname,path:e,method:"POST",headers:{"Content-Type":"application/json","Content-Length":Buffer.byteLength(m),...s},timeout:o,agent:n?ma(n):void 0},d=>{const f=[];d.on("data",h=>f.push(h)),d.on("end",()=>{l({request:a,response:d,data:Buffer.concat(f).toString()})})});a.on("error",c),a.on("timeout",()=>{a.destroy(),c(new v(`Time out error: request took over ${o}ms. Try increasing the \`timeout\` config`))}),a.write(m),a.end()}),da=async(t,e,s,r,o,n)=>{const i=new URL(t),{response:l,data:c}=await ua(i,e,{Authorization:`Bearer ${s}`},r,o,n);if(!l.statusCode||l.statusCode<200||l.statusCode>299){let m=`API Error: ${l.statusCode} - ${l.statusMessage}`;throw c&&(m+=`
|
|
103
83
|
|
|
104
|
-
${
|
|
84
|
+
${c}`),l.statusCode===500&&(m+=`
|
|
105
85
|
|
|
106
|
-
Check the API status: ${t}`),new
|
|
107
|
-
`)[0];const
|
|
108
|
-
`)[0];const
|
|
109
|
-
`),diff:
|
|
110
|
-
`).filter(Boolean),diff:
|
|
86
|
+
Check the API status: ${t}`),new v(m)}return JSON.parse(c)},ds=t=>t.trim(),pa=async(t,e,s,r,o,n,i,l,c,m,p,a,d,f)=>{try{const h={model:o,messages:[{role:"system",content:p},{role:"user",content:`Here is the diff: ${n}`}],temperature:c,max_tokens:l,stream:!1,n:1,top_p:m,frequency_penalty:0,presence_penalty:0},g=await da(e,s,r,h,i,f),y=g.choices.filter(b=>b.message?.content).map(b=>ds(b.message.content)).join();return a&&B(t,n,p,y,d),g.choices.filter(b=>b.message?.content).map(b=>ds(b.message.content))}catch(h){const g=h;throw g.code==="ENOTFOUND"?new v(`Error connecting to ${g.hostname} (${g.syscall})`):g}};class ps extends j{constructor(e){super(e),this.params=e,this.handleError$=s=>{let r="An error occurred";if(s.message){r=s.message.split(`
|
|
87
|
+
`)[0];const o=this.extractJSONFromError(s.message);r+=`: ${o.error.message}`}return O({name:`${this.errorPrefix} ${r}`,value:r,isError:!0,disabled:!0})},this.colors={primary:"#74AA9C",secondary:"#FFF"},this.serviceName=w.bgHex(this.colors.primary).hex(this.colors.secondary).bold("[ChatGPT]"),this.errorPrefix=w.red.bold("[ChatGPT]")}generateCommitMessage$(){return M(this.generateMessage("commit")).pipe(A(e=>$(e)),E(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:this.params.config.includeBody?e.value:e.title,description:this.params.config.includeBody?e.value:"",isError:!1})),x(this.handleError$))}generateCodeReview$(){return M(this.generateMessage("review")).pipe(A(e=>$(e)),E(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:e.value,description:e.value,isError:!1})),x(this.handleError$))}extractJSONFromError(e){const s=/[{[]{1}([,:{}[\]0-9.\-+Eaeflnr-u \n\r\t]|".*?")+[}\]]{1}/gis,r=e.match(s);return r?Object.assign({},...r.map(o=>JSON.parse(o))):{error:{message:"Unknown error"}}}async generateMessage(e){const s=this.params.stagedDiff.diff,{systemPrompt:r,systemPromptPath:o,codeReviewPromptPath:n,temperature:i,logging:l,locale:c,generate:m,type:p,maxLength:a,proxy:d,maxTokens:f,timeout:h}=this.params.config,g={...G,locale:c,maxLength:a,type:p,generate:m,systemPrompt:r,systemPromptPath:o,codeReviewPromptPath:n},y=e==="review"?U(g):H(g),b=await pa("ChatGPT",this.params.config.url,this.params.config.path,this.params.config.key,this.params.config.model,s,h,f,i,this.params.config.topP,y,l,e,d);return _e(e==="review"?b.map(C=>this.sanitizeResponse(C)):b.map(C=>this.parseMessage(C,p,m)))}}class fs extends j{constructor(e){super(e),this.params=e,this.host="https://api.perplexity.ai",this.apiKey="",this.handleError$=s=>{let r="An error occurred";if(s.message){r=s.message.split(`
|
|
88
|
+
`)[0];const o=this.extractJSONFromError(s.message);r+=`: ${o.error.message}`}return O({name:`${this.errorPrefix} ${r}`,value:r,isError:!0,disabled:!0})},this.colors={primary:"#20808D",secondary:"#FFF"},this.serviceName=w.bgHex(this.colors.primary).hex(this.colors.secondary).bold("[Perplexity]"),this.errorPrefix=w.red.bold("[Perplexity]"),this.apiKey=this.params.config.key}generateCommitMessage$(){return M(this.generateMessage("commit")).pipe(A(e=>$(e)),E(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:this.params.config.includeBody?e.value:e.title,description:this.params.config.includeBody?e.value:"",isError:!1})),x(this.handleError$))}generateCodeReview$(){return M(this.generateMessage("review")).pipe(A(e=>$(e)),E(e=>({name:`${this.serviceName} ${e.title}`,short:e.title,value:e.value,description:e.value,isError:!1})),x(this.handleError$))}extractJSONFromError(e){const s=/[{[]{1}([,:{}[\]0-9.\-+Eaeflnr-u \n\r\t]|".*?")+[}\]]{1}/gis,r=e.match(s);return r?Object.assign({},...r.map(o=>JSON.parse(o))):{error:{message:"Unknown error"}}}async generateMessage(e){try{const s=this.params.stagedDiff.diff,{systemPrompt:r,systemPromptPath:o,codeReviewPromptPath:n,logging:i,locale:l,generate:c,type:m,maxLength:p}=this.params.config,a={...G,locale:l,maxLength:p,type:m,generate:c,systemPrompt:r,systemPromptPath:o,codeReviewPromptPath:n},d=e==="review"?U(a):H(a),f=await this.createChatCompletions(d,s);return i&&B("Perplexity",s,d,f,e),this.parseMessage(f,m,c)}catch(s){const r=s;throw r.code==="ENOTFOUND"?new v(`Error connecting to ${r.hostname} (${r.syscall})`):r}}async createChatCompletions(e,s){const o=(await new fe({method:"POST",baseURL:`${this.host}/chat/completions`,timeout:this.params.config.timeout}).setHeaders({Authorization:`Bearer ${this.apiKey}`,"content-type":"application/json"}).setBody({model:this.params.config.model,messages:[{role:"system",content:`${e}`},{role:"user",content:`Here is the diff: ${s}`}],temperature:this.params.config.temperature,top_p:this.params.config.topP,max_tokens:this.params.config.maxTokens,stream:!1}).execute()).data;if(!o.choices||o.choices.length===0||!o.choices[0].message?.content)throw new Error("No Content on response. Please open a Bug report");return o.choices[0].message.content}}class ze{constructor(e,s){this.config=e,this.stagedDiff=s}createCommitMsgRequests$(e){return $(e).pipe(Ee(s=>{const r=this.config[s];if(r.compatible)return R.create(ts,{config:{...r,url:r.url||"",path:r.path||""},stagedDiff:this.stagedDiff,keyName:s}).generateCommitMessage$();switch(s){case"OPENAI":return R.create(ps,{config:this.config.OPENAI,stagedDiff:this.stagedDiff,keyName:s}).generateCommitMessage$();case"GEMINI":return R.create(zr,{config:this.config.GEMINI,stagedDiff:this.stagedDiff,keyName:s}).generateCommitMessage$();case"ANTHROPIC":return R.create(Br,{config:this.config.ANTHROPIC,stagedDiff:this.stagedDiff,keyName:s}).generateCommitMessage$();case"HUGGINGFACE":return R.create(Wr,{config:this.config.HUGGINGFACE,stagedDiff:this.stagedDiff,keyName:s}).generateCommitMessage$();case"MISTRAL":return R.create(Yr,{config:this.config.MISTRAL,stagedDiff:this.stagedDiff,keyName:s}).generateCommitMessage$();case"CODESTRAL":return R.create(Hr,{config:this.config.CODESTRAL,stagedDiff:this.stagedDiff,keyName:s}).generateCommitMessage$();case"OLLAMA":return $(this.config.OLLAMA.model).pipe(Ee(n=>R.create(es,{config:this.config.OLLAMA,keyName:n,stagedDiff:this.stagedDiff}).generateCommitMessage$()));case"COHERE":return R.create(Ur,{config:this.config.COHERE,stagedDiff:this.stagedDiff,keyName:s}).generateCommitMessage$();case"GROQ":return R.create(Kr,{config:this.config.GROQ,stagedDiff:this.stagedDiff,keyName:s}).generateCommitMessage$();case"PERPLEXITY":return R.create(fs,{config:this.config.PERPLEXITY,stagedDiff:this.stagedDiff,keyName:s}).generateCommitMessage$();case"DEEPSEEK":return R.create(qr,{config:this.config.DEEPSEEK,stagedDiff:this.stagedDiff,keyName:s}).generateCommitMessage$();default:const o=w.red.bold(`[${s}]`);return O({name:o+" Invalid AI type",value:"Invalid AI type",isError:!0,disabled:!0})}}),x(s=>{const r=w.red.bold("[UNKNOWN]");return O({name:r+` ${s.message||""}`,value:"Unknown error",isError:!0,disabled:!0})}))}createCodeReviewRequests$(e){return $(e).pipe(Ee(s=>{const r=this.config[s];if(r.compatible)return R.create(ts,{config:{...r,url:r.url||"",path:r.path||""},stagedDiff:this.stagedDiff,keyName:s}).generateCodeReview$();switch(s){case"OPENAI":return R.create(ps,{config:this.config.OPENAI,stagedDiff:this.stagedDiff,keyName:s}).generateCodeReview$();case"GEMINI":return R.create(zr,{config:this.config.GEMINI,stagedDiff:this.stagedDiff,keyName:s}).generateCodeReview$();case"ANTHROPIC":return R.create(Br,{config:this.config.ANTHROPIC,stagedDiff:this.stagedDiff,keyName:s}).generateCodeReview$();case"HUGGINGFACE":return R.create(Wr,{config:this.config.HUGGINGFACE,stagedDiff:this.stagedDiff,keyName:s}).generateCodeReview$();case"MISTRAL":return R.create(Yr,{config:this.config.MISTRAL,stagedDiff:this.stagedDiff,keyName:s}).generateCodeReview$();case"CODESTRAL":return R.create(Hr,{config:this.config.CODESTRAL,stagedDiff:this.stagedDiff,keyName:s}).generateCodeReview$();case"OLLAMA":return $(this.config.OLLAMA.model).pipe(Ee(n=>R.create(es,{config:this.config.OLLAMA,keyName:n,stagedDiff:this.stagedDiff}).generateCodeReview$()));case"COHERE":return R.create(Ur,{config:this.config.COHERE,stagedDiff:this.stagedDiff,keyName:s}).generateCodeReview$();case"GROQ":return R.create(Kr,{config:this.config.GROQ,stagedDiff:this.stagedDiff,keyName:s}).generateCodeReview$();case"PERPLEXITY":return R.create(fs,{config:this.config.PERPLEXITY,stagedDiff:this.stagedDiff,keyName:s}).generateCodeReview$();case"DEEPSEEK":return R.create(qr,{config:this.config.DEEPSEEK,stagedDiff:this.stagedDiff,keyName:s}).generateCodeReview$();default:const o=w.red.bold(`[${s}]`);return O({name:o+" Invalid AI type",value:"Invalid AI type",isError:!0,disabled:!0})}}),x(s=>{const r=w.red.bold("[UNKNOWN]");return O({name:r+` ${s.message||""}`,value:"Unknown error",isError:!0,disabled:!0})}))}}const _t=async()=>{const{stdout:t,failed:e}=await ee("git",["rev-parse","--show-toplevel"],{reject:!1});if(e)throw new v("The current directory must be a Git repository!");return t},J=t=>`:(exclude)${t}`,Ke=["package-lock.json","pnpm-lock.yaml","*.lock","*.lockb","*.gif","*.png"].map(J),Dt=async(t,e)=>{const s=["diff","--cached","--diff-algorithm=minimal"],{stdout:r}=await ee("git",[...s,"--name-only",...Ke,...t?t.map(J):[],...e?e.map(J):[]]);if(!r)return null;const{stdout:o}=await ee("git",[...s,...Ke,...t?t.map(J):[]]);return{files:r.split(`
|
|
89
|
+
`),diff:o}},fa=t=>`Detected ${t.length.toLocaleString()} staged file${t.length>1?"s":""}`,ha=async(t,e,s)=>{const r=["diff-tree","-r","--no-commit-id","--name-only",t],{stdout:o}=await ee("git",[...r,...Ke,...e?e.map(J):[],...s?s.map(J):[]]);if(!o)return null;const{stdout:n}=await ee("git",["show",t,"--",...Ke,...e?e.map(J):[],...s?s.map(J):[]]);return{files:o.split(`
|
|
90
|
+
`).filter(Boolean),diff:n}};class X{constructor(){this.title="aicommit2"}printTitle(){console.log(no.textSync(this.title,{font:"Small"}))}showLoader(e){if(this.loader){this.loader.text=e;return}this.loader=Qe(e).start()}stopLoader(){this.loader?.stop(),this.loader=void 0}displaySpinner(e){return Qe(e).start()}stopSpinner(e){e.stop(),e.clear()}printStagedFiles(e){console.log(w.bold.green("\u2714 ")+w.bold(`${fa(e.files)}:`)),console.log(`${e.files.map(s=>` ${s}`).join(`
|
|
111
91
|
`)}
|
|
112
92
|
`)}printAnalyzed(){console.log(`
|
|
113
|
-
${
|
|
114
|
-
${
|
|
115
|
-
${
|
|
116
|
-
${
|
|
117
|
-
${
|
|
118
|
-
${
|
|
119
|
-
${
|
|
120
|
-
${
|
|
121
|
-
`)}},t=>{(async()=>{const{mode:e,keyValue:r}=t._;if(e==="get"){const o=await Ee({},[]);for(const n of r)if(Ve(o,n)){if(X.includes(n)){console.log(n,o[n]);return}console.log(`${n}=${o[n]}`)}return}if(e==="set"){await Iu(r.map(o=>{const n=o.indexOf("=");if(n===-1)throw new y("Invalid format. Use: key=value");const s=o.slice(0,n),i=o.slice(n+1);return[s,i]}));return}if(e==="add"){await ku(r.map(o=>{const n=o.indexOf("=");if(n===-1)throw new y("Invalid format. Use: key=value");const s=o.slice(0,n),i=o.slice(n+1);return[s,i]}));return}if(e==="list"){await Lu();return}throw new y(`Invalid mode: ${e}`)})().catch(e=>{new Q().printError(e.message),oe(e),process.exit(1)})});const on="prepare-commit-msg",nn=`.git/hooks/${on}`,tt=jn(new URL("cli.mjs",import.meta.url)),Fc=process.argv[1].replace(/\\/g,"/").endsWith(`/${nn}`),sn=process.platform==="win32",an=`
|
|
93
|
+
${w.bold.green("\u2714")} ${w.bold("Changes analyzed")}`)}printCommitted(){console.log(`
|
|
94
|
+
${w.bold.green("\u2714")} ${w.bold("Successfully committed!")}`)}printCopied(){console.log(`
|
|
95
|
+
${w.bold.green("\u2714")} ${w.bold("Successfully copied! Press 'Ctrl + V' to paste")}`)}printSavedCommitMessage(){console.log(`
|
|
96
|
+
${w.bold.green("\u2714")} ${w.bold("Saved commit message")}`)}printCancelledCommit(){console.log(`
|
|
97
|
+
${w.bold.yellow("\u26A0")} ${w.yellow("Commit cancelled")}`)}printError(e){console.log(`
|
|
98
|
+
${w.bold.red("\u2716")} ${w.red(`${e}`)}`)}printWarning(e){console.log(`
|
|
99
|
+
${w.bold.yellow("\u26A0")} ${w.red(`${e}`)}`)}printSetupGitEvent(e){console.log(`
|
|
100
|
+
${w.bold.green("\u2714")} ${w.bold(`Git ${e} hook has been set up`)}`)}moveCursorUp(){const e=Se.createInterface({input:process.stdin,output:process.stdout});Se.moveCursor(process.stdout,0,-1),e.close()}moveCursorDown(){const e=Se.createInterface({input:process.stdin,output:process.stdout});Se.moveCursor(process.stdout,0,2),e.close()}}const ga={isLoading:!1,startOption:{text:"AI is analyzing your changes"}},hs={isLoading:!1,startOption:{text:"AI is performing a code review"}},Gt="No commit messages were generated",gs="No code reviews were generated",jt={type:"reactiveListPrompt",name:"aicommit2Prompt",message:"Pick a commit message to use: ",emptyMessage:`\u26A0 ${Gt}`,loop:!1,descPageSize:15,showDescription:!0,pickKey:"short",isDescriptionDim:!0,stopMessage:"Changes analyzed"};class Bt{constructor(e){this.choices$=new Xt([]),this.destroyed$=new Hs(1),this.stopMessage="Changes analyzed",this.inquirerInstance=null,this.loader$=new Xt(e)}initPrompt(e=jt){return this.stopMessage=e.stopMessage,Ce.registerPrompt("reactiveListPrompt",io),this.inquirerInstance=Ce.prompt({choices$:this.choices$,loader$:this.loader$,...e}),this.inquirerInstance}startLoader(){this.loader$.next({isLoading:!0})}clearLoader(){this.inquirerInstance&&this.loader$.next({isLoading:!1,clear:!0})}refreshChoices(e){const{value:s,isError:r}=e;!e||!s||this.choices$.next([...this.currentChoices,e].sort(gi))}checkErrorOnChoices(e=!0){if(this.choices$.getValue().map(r=>r).every(r=>r?.isError||r?.disabled)){this.alertNoGeneratedMessage(),this.logEmptyCommitMessage(),e&&process.exit(1);return}this.stopLoaderOnSuccess()}completeSubject(){this.choices$.complete(),this.loader$.complete(),this.destroyed$.next(!0),this.destroyed$.complete()}closeInquirerInstance(){this.inquirerInstance&&this.inquirerInstance.ui.close()}cancel(){this.inquirerInstance?.ui?.activePrompt&&this.inquirerInstance.ui.activePrompt.abortPrompt()}alertNoGeneratedMessage(){this.loader$.next({isLoading:!1,message:Gt,stopOption:{doneFrame:"\u26A0",color:"yellow"}})}stopLoaderOnSuccess(){this.loader$.next({isLoading:!1,message:this.stopMessage})}logEmptyCommitMessage(){console.log(`${w.bold.yellow("\u26A0")} ${w.yellow(`${Gt}`)}`)}get currentChoices(){return this.choices$.getValue().map(e=>e)}}const z=new X;var ya=async(t,e,s,r,o,n,i,l,c)=>(async()=>{z.printTitle(),await _t(),r&&await ee("git",["add","--update"]);const m=await ge({locale:t?.toString(),generate:e?.toString(),commitType:o?.toString(),systemPrompt:l?.toString()},c);await jr(m);const p=z.displaySpinner("Detecting staged files"),a=await Dt(s,m.exclude);if(p.stop(),!a)throw new v("No staged changes found. Stage your changes manually, or automatically stage all changes with the `--all` flag.");z.printStagedFiles(a);const d=ys(m,"commit");if(d.length===0)throw new v("Please set at least one API key via the `aicommit2 config set` command");const f=new ze(m,a),h=ys(m,"review");h.length>0&&await wa(f,h);const g=await va(f,d);i&&(mo("copy-paste").copy(g),z.printCopied(),process.exit()),n&&(await ws(g,c),process.exit());const{confirmationPrompt:y}=await Ce.prompt([{type:"confirm",name:"confirmationPrompt",message:"Use selected message?",default:!0}]);y?await ws(g,c):z.printCancelledCommit(),process.exit()})().catch(m=>{z.printError(m.message),te(m),process.exit(1)});function ys(t,e){return Object.entries(t).map(([s,r])=>[s,r]).filter(([s,r])=>!r.disabled).filter(([s,r])=>V.includes(s)||r.compatible===!0).filter(([s,r])=>{switch(e){case"commit":return s==="OLLAMA"?!!r&&!!r.model&&r.model.length>0:s==="HUGGINGFACE"?!!r&&!!r.cookie:!!r.key&&r.key.length>0;case"review":const o=t.codeReview||r.codeReview;return s==="OLLAMA"?!!r&&!!r.model&&r.model.length>0&&o:s==="HUGGINGFACE"?!!r&&!!r.cookie&&o:!!r.key&&r.key.length>0&&o}}).map(([s])=>s)}async function wa(t,e){const s=new Bt(hs),r=s.initPrompt({...jt,name:"codeReviewPrompt",message:"Please check code reviews: ",emptyMessage:`\u26A0 ${gs}`,isDescriptionDim:!1,stopMessage:"Code review completed",descPageSize:20});s.startLoader();const o=t.createCodeReviewRequests$(e).subscribe(c=>s.refreshChoices(c),()=>{},()=>s.checkErrorOnChoices());if(!(await r).codeReviewPrompt?.value)throw new v("An error occurred! No selected code review");o.unsubscribe(),s.completeSubject(),z.moveCursorUp();const{continuePrompt:l}=await Ce.prompt([{type:"confirm",name:"continuePrompt",message:"Will you continue without changing the code?",default:!0}]);l||(z.printCancelledCommit(),process.exit())}async function va(t,e){const s=new Bt(ga),r=s.initPrompt();s.startLoader();const o=t.createCommitMsgRequests$(e).subscribe(l=>s.refreshChoices(l),()=>{},()=>s.checkErrorOnChoices()),n=await r;o.unsubscribe(),s.completeSubject(),z.moveCursorUp();const i=n.aicommit2Prompt?.value;if(!i)throw new v("An error occurred! No selected message");return i}async function ws(t,e){const s=Qe("Committing with the generated message").start();await ee("git",["commit","-m",t,...e]),s.stop(),s.clear(),z.printCommitted()}var ba=Q({name:"config",parameters:["<mode>","[key=value...]"],help:{description:"Manage configuration settings",examples:["aic2 config set <key>=<value> [<key>=<value> ...]","aic2 config get [<key> [<key> ...]]","aic2 config add <key>=<value> [<key>=<value> ...]","aic2 config list"]},commands:[Q({name:"set",parameters:["<key>=<value>","[<key>=<value> ...]"],help:{description:"Set configuration values. Multiple key-value pairs can be set at once.",examples:["aic2 config set OPENAI.key=<your key>","aic2 config set ANTHROPIC.topP=0.8 ANTHROPIC.generate=2"]}}),Q({name:"get",parameters:["[<key>","[<key> ...]]"],help:{description:"Retrieve configuration values for specified AI provider.",examples:["aic2 config get OPENAI","aic2 config get ANTHROPIC"]}}),Q({name:"add",parameters:["<key>=<value>","[<key>=<value> ...]"],help:{description:"Add new model to existing configuration. Only Ollama.model can be added.",examples:['aic2 config add OLLAMA.model="gemma2"']}}),Q({name:"list",parameters:[],help:{description:"Display all configuration keys and their values.",examples:["aic2 config list"]}})]},t=>{(async()=>{const{mode:e,keyValue:s}=t._;if(e==="get"){const r=await ge({},[]);for(const o of s)if(Be(r,o)){if(V.includes(o)){console.log(o,r[o]);return}console.log(`${o}=${r[o]}`)}return}if(e==="set"){await Ti(s.map(r=>{const o=r.indexOf("=");if(o===-1)throw new v("Invalid format. Use: key=value");const n=r.slice(0,o),i=r.slice(o+1);return[n,i]}));return}if(e==="add"){await Ni(s.map(r=>{const o=r.indexOf("=");if(o===-1)throw new v("Invalid format. Use: key=value");const n=r.slice(0,o),i=r.slice(o+1);return[n,i]}));return}if(e==="list"){await Fi();return}throw new v(`Invalid mode: ${e}`)})().catch(e=>{new X().printError(e.message),te(e),process.exit(1)})});const vs="prepare-commit-msg",bs=`.git/hooks/${vs}`,We=so(new URL("cli.mjs",import.meta.url)),Pa=process.argv[1].replace(/\\/g,"/").endsWith(`/${bs}`),Ps=process.platform==="win32",$s=`
|
|
122
101
|
#!/usr/bin/env node
|
|
123
|
-
import(${JSON.stringify(
|
|
124
|
-
`.trim();var
|
|
125
|
-
`,
|
|
126
|
-
`,
|
|
127
|
-
`,
|
|
128
|
-
`,
|
|
129
|
-
`,
|
|
130
|
-
`):(
|
|
131
|
-
`,
|
|
132
|
-
`,
|
|
133
|
-
`),
|
|
134
|
-
`),
|
|
102
|
+
import(${JSON.stringify(oo(We))})
|
|
103
|
+
`.trim();var $a=Q({name:"hook",parameters:["<install/uninstall>"],help:{description:"Install or uninstall the Git prepare-commit-msg hook",examples:["aic2 hook install","aic2 hook uninstall"]}},t=>{(async()=>{const e=await _t(),{installUninstall:s}=t._,r=T.join(e,bs),o=await Qr(r);if(s==="install"){if(o){if(await I.realpath(r).catch(()=>{})===We){console.warn("The hook is already installed");return}throw new v(`A different ${vs} hook seems to be installed. Please remove it before installing aicommit2.`)}await I.mkdir(T.dirname(r),{recursive:!0}),Ps?await I.writeFile(r,$s):(await I.symlink(We,r,"file"),await I.chmod(r,493)),console.log(`${w.green("\u2714")} Hook installed`);return}if(s==="uninstall"){if(!o){console.warn("Hook is not installed");return}if(Ps){if(await I.readFile(r,"utf8")!==$s){console.warn("Hook is not installed");return}}else if(await I.realpath(r)!==We){console.warn("Hook is not installed");return}await I.rm(r),console.log(`${w.green("\u2714")} Hook uninstalled`);return}throw new v(`Invalid mode: ${s}`)})().catch(e=>{console.error(`${w.red("\u2716")} ${e.message}`),te(e),process.exit(1)})}),Ca=Q({name:"log",parameters:["<removeAll>"],help:{description:"Manage log files generated by the application",examples:["aic2 log removeAll"]}},t=>{(async()=>{const{removeAll:e}=t._;if(e==="removeAll"){await ao(Fr,{recursive:!0,force:!0}),console.log(`${w.green("\u2714")} All Log files are removed!`);return}throw new v(`Invalid mode: ${e}`)})().catch(e=>{new X().printError(e.message),te(e),process.exit(1)})});const Ea=process.argv.slice(2).filter(t=>!t.startsWith("--pre-commit")),[Ye,Cs]=Ea;var xa=()=>(async()=>{if(!Ye)throw new v('Commit message file path is missing. This file should be called from the "pre-commit framework"');if(Cs){console.log(`Skipping aicommit2 message generation for ${Cs} commit`);return}const t=await Dt();if(!t)return;const e=new X;e.printTitle();const s=await ge({});if(s.systemPromptPath)try{await I.readFile(T.resolve(s.systemPromptPath),"utf-8")}catch{throw new v(`Error reading system prompt file: ${s.systemPromptPath}`)}const r=Object.entries(s).filter(([f])=>V.includes(f)).map(([f,h])=>[f,h]).filter(([f,h])=>!h.disabled).filter(([f,h])=>f==="OLLAMA"?!!h&&!!h.model&&h.model.length>0:f==="HUGGINGFACE"?!!h&&!!h.cookie:!!h.key&&h.key.length>0).map(([f])=>f);if(r.length===0)throw new v("Please set at least one API key via the `aicommit2 config set` command");const n=new ze(s,t);let i;try{i=await Qt(n.createCommitMsgRequests$(r).pipe(Zt(f=>!f.isError),E(f=>f.value),er()))}finally{e.printAnalyzed()}const c=await I.readFile(Ye,"utf8")!=="",m=i.length>1;let p="";c&&(p=`# \u{1F916} Generated by aicommit2 (https://github.com/tak-bro/aicommit2)
|
|
104
|
+
`,p+=`# ----------------------------------------
|
|
105
|
+
`,p+=`# How to use:
|
|
106
|
+
`,m?(p+=`# 1. Remove the "#" from your chosen message
|
|
107
|
+
`,p+=`# 2. Edit the message if needed
|
|
108
|
+
`,p+=`# 3. Save and close the editor
|
|
109
|
+
`):(p+=`# 1. The message below will be used
|
|
110
|
+
`,p+=`# 2. Edit the message if needed
|
|
111
|
+
`,p+=`# 3. Save and close the editor
|
|
112
|
+
`),p+=`# ----------------------------------------
|
|
113
|
+
`),m?(c&&(p+=`
|
|
135
114
|
# \u{1F4DD} Choose one of these messages:
|
|
136
|
-
`),
|
|
137
|
-
${i.map(
|
|
138
|
-
`)}`):(
|
|
115
|
+
`),p+=`
|
|
116
|
+
${i.map(f=>`# ${f}`).join(`
|
|
117
|
+
`)}`):(c&&(p+=`
|
|
139
118
|
# \u{1F4DD} Generated commit message:
|
|
140
|
-
`),
|
|
119
|
+
`),p+=`
|
|
141
120
|
${i[0]}
|
|
142
|
-
`);const
|
|
143
|
-
`+
|
|
144
|
-
`,
|
|
145
|
-
`,
|
|
146
|
-
`,
|
|
147
|
-
`,
|
|
148
|
-
`,
|
|
149
|
-
`):(
|
|
150
|
-
`,
|
|
151
|
-
`,
|
|
152
|
-
`),
|
|
153
|
-
`),
|
|
121
|
+
`);const a=await I.readFile(Ye,"utf8"),d=p+`
|
|
122
|
+
`+a;await I.writeFile(Ye,d),e.printSavedCommitMessage()})().catch(t=>{new X().printError(t.message),te(t),process.exit(1)});const Aa=process.argv.slice(2).filter(t=>!t.startsWith("--hook-mode")),[Ve,Es]=Aa;var Ma=()=>(async()=>{if(!Ve)throw new v('Commit message file path is missing. This file should be called from the "prepare-commit-msg" git hook or with --hook-mode flag');if(Es){console.log(`Skipping aicommit2 message generation for ${Es} commit`);return}const t=await Dt();if(!t)return;const e=new X;e.printTitle();const s=await ge({});if(s.systemPromptPath)try{await I.readFile(T.resolve(s.systemPromptPath),"utf-8")}catch{throw new v(`Error reading system prompt file: ${s.systemPromptPath}`)}const r=Object.entries(s).filter(([h])=>V.includes(h)).map(([h,g])=>[h,g]).filter(([h,g])=>!g.disabled).filter(([h,g])=>h==="OLLAMA"?!!g&&!!g.model&&g.model.length>0:h==="HUGGINGFACE"?!!g&&!!g.cookie:!!g.key&&g.key.length>0).map(([h])=>h);if(r.length===0)throw new v("Please set at least one API key via the `aicommit2 config set` command");const n=new ze(s,t),i=e.displaySpinner("The AI is analyzing your changes");let l;try{l=await Qt(n.createCommitMsgRequests$(r).pipe(Zt(h=>!h.isError),E(h=>h.value),er()))}finally{i.stop(),i.clear(),e.printAnalyzed()}const m=await I.readFile(Ve,"utf8")!=="",p=l.length>1;let a="";m&&(a=`# \u{1F916} Generated by aicommit2 (https://github.com/tak-bro/aicommit2)
|
|
123
|
+
`,a+=`# ----------------------------------------
|
|
124
|
+
`,a+=`# How to use:
|
|
125
|
+
`,p?(a+=`# 1. Remove the "#" from your chosen message
|
|
126
|
+
`,a+=`# 2. Edit the message if needed
|
|
127
|
+
`,a+=`# 3. Save and close the editor
|
|
128
|
+
`):(a+=`# 1. The message below will be used
|
|
129
|
+
`,a+=`# 2. Edit the message if needed
|
|
130
|
+
`,a+=`# 3. Save and close the editor
|
|
131
|
+
`),a+=`# ----------------------------------------
|
|
132
|
+
`),p?(m&&(a+=`
|
|
154
133
|
# \u{1F4DD} Choose one of these messages:
|
|
155
|
-
`),
|
|
156
|
-
${
|
|
157
|
-
`)}`):(
|
|
134
|
+
`),a+=`
|
|
135
|
+
${l.map(h=>`# ${h}`).join(`
|
|
136
|
+
`)}`):(m&&(a+=`
|
|
158
137
|
# \u{1F4DD} Generated commit message:
|
|
159
|
-
`),
|
|
160
|
-
${
|
|
161
|
-
`);const
|
|
162
|
-
`+
|
|
138
|
+
`),a+=`
|
|
139
|
+
${l[0]}
|
|
140
|
+
`);const d=await I.readFile(Ve,"utf8"),f=a+`
|
|
141
|
+
`+d;await I.writeFile(Ve,f),e.printSavedCommitMessage()})().catch(t=>{new X().printError(t.message),te(t),process.exit(1)});let Je=new tr;const D=new X,xs=process.cwd(),Sa=T.join(xs,".git","hooks","post-commit"),$e=T.join(xs,".git","commit-log.txt"),Ra=`#!/bin/sh
|
|
163
142
|
commit_hash=$(git rev-parse HEAD)
|
|
164
143
|
commit_message=$(git log -1 --pretty=%B)
|
|
165
|
-
echo "$commit_hash: $commit_message" >> ${
|
|
166
|
-
`;let
|
|
144
|
+
echo "$commit_hash: $commit_message" >> ${$e}
|
|
145
|
+
`;let Ht=null,N=null;const As=async(t,e,s,r,o)=>{D.printTitle(),await _t();const n=await Ia(t,e,r,o);Ta(),Oa();try{await Rs(n)}catch(i){return ka(i),As(t,e,s,r,o)}},Ia=async(t,e,s,r)=>{const o=await ge({locale:t?.toString(),generate:e?.toString(),systemPrompt:s?.toString()},r);return await jr(o),Ms(o).length===0&&(D.printError(`Please set at least one API key and watchMode via the config command:
|
|
167
146
|
aicommit2 config set [MODEL].key="YOUR_API_KEY"
|
|
168
|
-
aicommit2 config set [MODEL].watchMode="true"`),process.exit()),
|
|
147
|
+
aicommit2 config set [MODEL].watchMode="true"`),process.exit()),o},ka=async t=>{D.printError(`An error occurred: ${t.message}`),te(t),await new Promise(e=>setTimeout(e,3e3)),D.printWarning("Restarting the commit monitoring process...")},Oa=()=>{_.writeFileSync($e,"",{flag:"w"})},Ms=t=>Object.entries(t).filter(([e,s])=>V.includes(e)||s.compatible===!0).map(([e,s])=>[e,s]).filter(([e,s])=>!s.disabled).filter(([e,s])=>La(e,s,t)).map(([e])=>e),La=(t,e,s)=>{const r=s.watchMode||e.watchMode;return t==="OLLAMA"?!!e&&!!e.model&&e.model.length>0&&r:t==="HUGGINGFACE"?!!e&&!!e.cookie&&r:e.compatible?!!e.url&&!!e.key&&r:!!e.key&&e.key.length>0&&r},Ta=()=>{_.writeFileSync(Sa,Ra,{mode:493}),D.printSetupGitEvent("post-commit")},Ss=()=>{process.stdout.write("\x1Bc")},Na=async(t,e)=>{try{const s=await ha(e);if(!s){D.printWarning("No changes found in this commit");return}D.stopLoader(),D.printStagedFiles(s);const r=Ms(t);if(r.length===0){D.printError(`Please set at least one API key and watchMode via the config command:
|
|
169
148
|
aicommit2 config set [MODEL].key="YOUR_API_KEY"
|
|
170
|
-
aicommit2 config set [MODEL].watchMode="true"`),process.exit();return}await
|
|
171
|
-
`),
|
|
149
|
+
aicommit2 config set [MODEL].watchMode="true"`),process.exit();return}await Fa(t,s,r)}catch(s){D.printError(`Error processing commit ${e}: ${s.message}`)}},Fa=async(t,e,s)=>{_a();const r=new ze(t,e);N=new Bt(hs);const o=Da();N.startLoader(),Ht=Ga(r,s),await o,ja()},_a=()=>{N&&(Ht?.unsubscribe(),N.clearLoader(),N.completeSubject(),N.cancel(),N.closeInquirerInstance()),Je.next(),Je.complete(),Je=new tr},Da=()=>N.initPrompt({...jt,name:"codeReviewPrompt",message:"Please check code reviews: ",emptyMessage:`\u26A0 ${gs}`,isDescriptionDim:!1,stopMessage:"Code review completed",descPageSize:20}),Ga=(t,e)=>t.createCodeReviewRequests$(e).pipe(lo(Je)).subscribe(s=>{N?.refreshChoices(s)},()=>{},()=>{N?.checkErrorOnChoices(!1)}),ja=()=>{N&&(Ht?.unsubscribe(),N.clearLoader(),N.completeSubject(),N.cancel(),N.closeInquirerInstance(),N=null),Ss(),D.showLoader("Watching for new Git commits...")},Rs=async t=>{const e=co.watch($e,{persistent:!0});e.on("change",async()=>{try{const s=await Ba();for(const r of s)r&&await Ha(t,r)}catch(s){D.printError(`Error reading or processing commit log: ${s.message}`)}finally{Ua()}}),e.on("error",qa(t))},Ba=async()=>(await _.promises.readFile($e,"utf8")).trim().split(`
|
|
150
|
+
`),Ha=async(t,e)=>{const[s]=e.split(":");if(!s){D.printWarning("Empty commit hash detected, skipping...");return}Ss(),await Na(t,s.trim())},Ua=()=>{try{_.truncateSync($e)}catch(t){D.printError(`Error truncating log file: ${t.message}`)}},qa=t=>e=>{D.printError(`Watcher error: ${e.message}`),setTimeout(()=>Rs(t),1e3)},Ut=process.argv.slice(2);process.noDeprecation=!0,Os({name:"aicommit2",version:Nr,flags:{locale:{type:String,description:"Locale to use for the generated commit messages (default: en)",alias:"l"},generate:{type:Number,description:"Number of messages to generate (Warning: generating multiple costs more) (default: 1)",alias:"g"},exclude:{type:[String],description:"Files to exclude from AI analysis",alias:"x"},all:{type:Boolean,description:"Automatically stage changes in tracked files for the commit",alias:"a",default:!1},type:{type:String,description:"Type of commit message to generate (default: conventional)",alias:"t"},confirm:{type:Boolean,description:"Skip confirmation when committing after message generation (default: false)",alias:"y",default:!1},clipboard:{type:Boolean,description:"Copy the selected message to the clipboard",alias:"c",default:!1},prompt:{type:String,description:"Custom prompt to let users fine-tune provided prompt",alias:"p"},"watch-commit":{type:Boolean,default:!1},"hook-mode":{type:Boolean,description:"Run in git hook mode, allowing chaining with other hooks",default:!1},"pre-commit":{type:Boolean,description:"Run in pre-commit Framework, allowing chaining with other hooks",default:!1}},commands:[ba,$a,Ca],help:{description:Pi},ignoreArgv:t=>t==="unknown-flag"||t==="argument"},t=>{if(t.flags["pre-commit"]){xa();return}if(t.flags["hook-mode"]||Pa){Ma();return}if(t.flags["watch-commit"]){As(t.flags.locale,t.flags.generate,t.flags.exclude,t.flags.prompt,Ut);return}ya(t.flags.locale,t.flags.generate,t.flags.exclude,t.flags.all,t.flags.type,t.flags.confirm,t.flags.clipboard,t.flags.prompt,Ut)},Ut);
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "aicommit2",
|
|
3
|
-
"version": "2.2.
|
|
3
|
+
"version": "2.2.14",
|
|
4
4
|
"description": "A Reactive CLI that generates git commit messages with various AI",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"cli",
|
|
@@ -58,6 +58,7 @@
|
|
|
58
58
|
"axios": "^1.6.8",
|
|
59
59
|
"chalk": "^5.3.0",
|
|
60
60
|
"chokidar": "^4.0.0",
|
|
61
|
+
"cleye": "^1.3.4",
|
|
61
62
|
"cohere-ai": "^7.16.0",
|
|
62
63
|
"copy-paste": "^1.5.3",
|
|
63
64
|
"figlet": "^1.7.0",
|
|
@@ -65,12 +66,12 @@
|
|
|
65
66
|
"groq-sdk": "^0.7.0",
|
|
66
67
|
"inquirer": "9.2.8",
|
|
67
68
|
"inquirer-reactive-list-prompt": "^1.0.15",
|
|
68
|
-
"node-fetch": "^3.3.2",
|
|
69
69
|
"ollama": "^0.5.14",
|
|
70
70
|
"openai": "^4.67.3",
|
|
71
71
|
"ora": "^8.0.1",
|
|
72
72
|
"readline": "^1.3.0",
|
|
73
73
|
"rxjs": "^7.8.1",
|
|
74
|
+
"undici": "^7.5.0",
|
|
74
75
|
"uuid": "^9.0.1"
|
|
75
76
|
}
|
|
76
77
|
}
|