nex-code 0.3.33 → 0.3.34

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (2) hide show
  1. package/dist/nex-code.js +4 -8
  2. package/package.json +1 -1
package/dist/nex-code.js CHANGED
@@ -1,5 +1,5 @@
1
1
  #!/usr/bin/env node
2
- var N=(t,e)=>()=>(e||t((e={exports:{}}).exports,e),e.exports);var wn=N((Lg,El)=>{El.exports={name:"nex-code",version:"0.3.33",description:"The open-source agentic coding CLI. Free with Ollama Cloud \u2014 switch to OpenAI, Anthropic or Gemini anytime. Alternative to Claude Code & Gemini CLI.",bin:{"nex-code":"./dist/nex-code.js"},files:["dist/","README.md","LICENSE"],engines:{node:">=18.0.0"},scripts:{start:"node dist/nex-code.js",build:"esbuild bin/nex-code.js --bundle --platform=node --target=node18 --outfile=dist/nex-code.js --minify --external:axios --external:dotenv --external:playwright",test:"jest --coverage","test:watch":"jest --watch",format:"prettier --write .","install-hooks":"ln -sf ../../hooks/pre-push .git/hooks/pre-push && chmod +x .git/hooks/pre-push && ln -sf ../../hooks/post-merge .git/hooks/post-merge && chmod +x .git/hooks/post-merge && echo 'Hooks installed (pre-push, post-merge).'",prepublishOnly:"npm run build && npm test",release:"npm version patch && git push --follow-tags && npm publish"},keywords:["ai","cli","coding","agent","ollama","ollama-cloud","openai","anthropic","claude","gemini","llm","gpt","agentic","terminal","coding-assistant","claude-code-alternative","gemini-cli-alternative","open-source","free","qwen3","devstral","kimi-k2","deepseek","local-llm","mcp","model-context-protocol","multi-provider"],repository:{type:"git",url:"https://github.com/hybridpicker/nex-code.git"},bugs:{url:"https://github.com/hybridpicker/nex-code/issues"},homepage:"https://github.com/hybridpicker/nex-code#readme",license:"MIT",dependencies:{axios:"^1.7.0",dotenv:"^16.4.0"},devDependencies:{esbuild:"^0.27.3",jest:"^29.7.0"}}});var wr=N((Ig,yr)=>{var M={reset:"\x1B[0m",bold:"\x1B[1m",dim:"\x1B[2m",white:"\x1B[37m",red:"\x1B[31m",green:"\x1B[32m",yellow:"\x1B[33m",blue:"\x1B[34m",magenta:"\x1B[35m",cyan:"\x1B[36m",gray:"\x1B[90m",bgRed:"\x1B[41m",bgGreen:"\x1B[42m",brightCyan:"\x1B[96m",brightMagenta:"\x1B[95m",brightBlue:"\x1B[94m"},hr=["\u280B","\u2819","\u2839","\u2838","\u283C","\u2834","\u2826","\u2827","\u2807","\u280F"],gr=["\u273D","\u2726","\u2727","\u2726"],bs=class{constructor(e="Thinking..."){this.text=e,this.frame=0,this.interval=null,this.startTime=null}_render(){if(this._stopped)return;let e=hr[this.frame%hr.length],s="";if(this.startTime){let n=Math.floor((Date.now()-this.startTime)/1e3);if(n>=60){let o=Math.floor(n/60),r=n%60;s=` ${M.dim}${o}m ${String(r).padStart(2,"0")}s${M.reset}`}else n>=1&&(s=` ${M.dim}${n}s${M.reset}`)}process.stderr.write(`\x1B[2K\r${M.cyan}${e}${M.reset} ${M.dim}${this.text}${M.reset}${s}`),this.frame++}start(){this._stopped=!1,this.startTime=Date.now(),process.stderr.isTTY&&(process.stderr.write("\x1B[?25l"),this._render(),this.interval=setInterval(()=>this._render(),80))}update(e){this.text=e}stop(){this._stopped=!0,this.interval&&(clearInterval(this.interval),this.interval=null),process.stderr.isTTY&&process.stderr.write("\x1B[2K\r\x1B[?25h"),this.startTime=null}},$r=["\u280B","\u2819","\u2839","\u2838","\u283C","\u2834","\u2826","\u2827","\u2807","\u280F"],xs=class{constructor(e){this.labels=e,this.statuses=e.map(()=>"running"),this.frame=0,this.interval=null,this.startTime=null,this.lineCount=e.length}_formatElapsed(){if(!this.startTime)return"";let e=Math.floor((Date.now()-this.startTime)/1e3);if(e<1)return"";let s=Math.floor(e/60),n=e%60;return s>0?`${s}m ${String(n).padStart(2,"0")}s`:`${n}s`}_render(){if(this._stopped)return;let e=$r[this.frame%$r.length],s=this._formatElapsed(),n=s?` ${M.dim}${s}${M.reset}`:"",o="";for(let r=0;r<this.labels.length;r++){let i,c;switch(this.statuses[r]){case"done":i=`${M.green}\u2713${M.reset}`,c=M.dim;break;case"error":i=`${M.red}\u2717${M.reset}`,c=M.dim;break;default:i=`${M.cyan}${e}${M.reset}`,c=""}let l=r===this.labels.length-1?n:"";o+=`\x1B[2K ${i} ${c}${this.labels[r]}${M.reset}${l}
2
+ var N=(t,e)=>()=>(e||t((e={exports:{}}).exports,e),e.exports);var wn=N((Lg,El)=>{El.exports={name:"nex-code",version:"0.3.34",description:"The open-source agentic coding CLI. Free with Ollama Cloud \u2014 switch to OpenAI, Anthropic or Gemini anytime. Alternative to Claude Code & Gemini CLI.",bin:{"nex-code":"./dist/nex-code.js"},files:["dist/","README.md","LICENSE"],engines:{node:">=18.0.0"},scripts:{start:"node dist/nex-code.js",build:"esbuild bin/nex-code.js --bundle --platform=node --target=node18 --outfile=dist/nex-code.js --minify --external:axios --external:dotenv --external:playwright",test:"jest --coverage","test:watch":"jest --watch",format:"prettier --write .","install-hooks":"ln -sf ../../hooks/pre-push .git/hooks/pre-push && chmod +x .git/hooks/pre-push && ln -sf ../../hooks/post-merge .git/hooks/post-merge && chmod +x .git/hooks/post-merge && echo 'Hooks installed (pre-push, post-merge).'",prepublishOnly:"npm run build && npm test",release:"npm version patch && git push --follow-tags && npm publish"},keywords:["ai","cli","coding","agent","ollama","ollama-cloud","openai","anthropic","claude","gemini","llm","gpt","agentic","terminal","coding-assistant","claude-code-alternative","gemini-cli-alternative","open-source","free","qwen3","devstral","kimi-k2","deepseek","local-llm","mcp","model-context-protocol","multi-provider"],repository:{type:"git",url:"https://github.com/hybridpicker/nex-code.git"},bugs:{url:"https://github.com/hybridpicker/nex-code/issues"},homepage:"https://github.com/hybridpicker/nex-code#readme",license:"MIT",dependencies:{axios:"^1.7.0",dotenv:"^16.4.0"},devDependencies:{esbuild:"^0.27.3",jest:"^29.7.0"}}});var wr=N((Ig,yr)=>{var M={reset:"\x1B[0m",bold:"\x1B[1m",dim:"\x1B[2m",white:"\x1B[37m",red:"\x1B[31m",green:"\x1B[32m",yellow:"\x1B[33m",blue:"\x1B[34m",magenta:"\x1B[35m",cyan:"\x1B[36m",gray:"\x1B[90m",bgRed:"\x1B[41m",bgGreen:"\x1B[42m",brightCyan:"\x1B[96m",brightMagenta:"\x1B[95m",brightBlue:"\x1B[94m"},hr=["\u280B","\u2819","\u2839","\u2838","\u283C","\u2834","\u2826","\u2827","\u2807","\u280F"],gr=["\u273D","\u2726","\u2727","\u2726"],bs=class{constructor(e="Thinking..."){this.text=e,this.frame=0,this.interval=null,this.startTime=null}_render(){if(this._stopped)return;let e=hr[this.frame%hr.length],s="";if(this.startTime){let n=Math.floor((Date.now()-this.startTime)/1e3);if(n>=60){let o=Math.floor(n/60),r=n%60;s=` ${M.dim}${o}m ${String(r).padStart(2,"0")}s${M.reset}`}else n>=1&&(s=` ${M.dim}${n}s${M.reset}`)}process.stderr.write(`\x1B[2K\r${M.cyan}${e}${M.reset} ${M.dim}${this.text}${M.reset}${s}`),this.frame++}start(){this._stopped=!1,this.startTime=Date.now(),process.stderr.isTTY&&(process.stderr.write("\x1B[?25l"),this._render(),this.interval=setInterval(()=>this._render(),80))}update(e){this.text=e}stop(){this._stopped=!0,this.interval&&(clearInterval(this.interval),this.interval=null),process.stderr.isTTY&&process.stderr.write("\x1B[2K\r\x1B[?25h"),this.startTime=null}},$r=["\u280B","\u2819","\u2839","\u2838","\u283C","\u2834","\u2826","\u2827","\u2807","\u280F"],xs=class{constructor(e){this.labels=e,this.statuses=e.map(()=>"running"),this.frame=0,this.interval=null,this.startTime=null,this.lineCount=e.length}_formatElapsed(){if(!this.startTime)return"";let e=Math.floor((Date.now()-this.startTime)/1e3);if(e<1)return"";let s=Math.floor(e/60),n=e%60;return s>0?`${s}m ${String(n).padStart(2,"0")}s`:`${n}s`}_render(){if(this._stopped)return;let e=$r[this.frame%$r.length],s=this._formatElapsed(),n=s?` ${M.dim}${s}${M.reset}`:"",o="";for(let r=0;r<this.labels.length;r++){let i,c;switch(this.statuses[r]){case"done":i=`${M.green}\u2713${M.reset}`,c=M.dim;break;case"error":i=`${M.red}\u2717${M.reset}`,c=M.dim;break;default:i=`${M.cyan}${e}${M.reset}`,c=""}let l=r===this.labels.length-1?n:"";o+=`\x1B[2K ${i} ${c}${this.labels[r]}${M.reset}${l}
3
3
  `}this.lineCount>0&&(o+=`\x1B[${this.lineCount}A`),process.stderr.write(o),this.frame++}start(){this._stopped=!1,this.startTime=Date.now();let e="\x1B[?25l";for(let s=0;s<this.lineCount;s++)e+=`
4
4
  `;this.lineCount>0&&(e+=`\x1B[${this.lineCount}A`),process.stderr.write(e),this._render(),this.interval=setInterval(()=>this._render(),80)}update(e,s){e>=0&&e<this.statuses.length&&(this.statuses[e]=s)}stop(){this._stopped=!0,this.interval&&(clearInterval(this.interval),this.interval=null),this._renderFinal(),process.stderr.write("\x1B[?25h")}_renderFinal(){let e=this._formatElapsed(),s=e?` ${M.dim}${e}${M.reset}`:"",n="";for(let o=0;o<this.labels.length;o++){let r;switch(this.statuses[o]){case"done":r=`${M.green}\u2713${M.reset}`;break;case"error":r=`${M.red}\u2717${M.reset}`;break;default:r=`${M.yellow}\u25CB${M.reset}`}let i=o===this.labels.length-1?s:"";n+=`\x1B[2K ${r} ${M.dim}${this.labels[o]}${M.reset}${i}
5
5
  `}process.stderr.write(n)}},bn={done:"\u2714",in_progress:"\u25FC",pending:"\u25FB",failed:"\u2717"},xn={done:M.green,in_progress:M.cyan,pending:M.dim,failed:M.red},Je=null,_s=class{constructor(e,s){this.name=e,this.tasks=s.map(n=>({id:n.id,description:n.description,status:n.status||"pending"})),this.frame=0,this.interval=null,this.startTime=null,this.tokens=0,this.lineCount=1+this.tasks.length,this._paused=!1}_formatElapsed(){if(!this.startTime)return"";let e=Math.floor((Date.now()-this.startTime)/1e3);if(e<1)return"";let s=Math.floor(e/60),n=e%60;return s>0?`${s}m ${String(n).padStart(2,"0")}s`:`${n}s`}_formatTokens(){return this.tokens<=0?"":this.tokens>=1e3?`${(this.tokens/1e3).toFixed(1)}k`:String(this.tokens)}_render(){if(this._stopped)return;let e=gr[this.frame%gr.length],s=this._formatElapsed(),n=this._formatTokens(),o=[s,n?`\u2193 ${n} tokens`:""].filter(Boolean).join(" \xB7 "),r=o?` ${M.dim}(${o})${M.reset}`:"",i=`\x1B[2K${M.cyan}${e}${M.reset} ${this.name}\u2026${r}
@@ -822,16 +822,13 @@ ${a.dim}No deploy configs. Run /init to create .nex/deploy.json${a.reset}
822
822
  `),!0;console.log(`
823
823
  ${a.bold}${a.cyan}Deploy configs (${i.length}):${a.reset}`);for(let[l,u]of Object.entries(r)){let d=u.local_path||"",f=`${u.server}:${u.remote_path}`,m=u.deploy_script?` ${a.dim}\u2192 ${u.deploy_script}${a.reset}`:"";console.log(` ${a.green}${l}${a.reset} ${a.dim}${d} \u2192 ${f}${a.reset}${m}`)}return console.log(`
824
824
  ${a.dim}/deploy <name> \u2014 run a named deploy${a.reset}`),console.log(`${a.dim}/deploy <name> --dry-run \u2014 preview without syncing${a.reset}
825
- `),!0}case"/init":{let{runServerWizard:o,runDeployWizard:r,setWizardRL:i}=ol();return i(e),n[0]==="deploy"?await r():await o(),!0}case"/exit":case"/quit":console.log(`
826
- ${a.dim}Bye!${a.reset}`),process.exit(0);default:return Sg(t)||console.log(`${a.red}Unknown command: ${s}. Type /help${a.reset}`),!0}}var rr=1e3;function ir(){return qe.join(process.cwd(),".nex","repl_history")}function bl(){try{let t=ir();if(tt.existsSync(t))return tt.readFileSync(t,"utf-8").split(`
825
+ `),!0}case"/init":{let{runServerWizard:o,runDeployWizard:r,setWizardRL:i}=ol();return i(e),n[0]==="deploy"?await r():await o(),!0}case"/exit":case"/quit":process.stdout.write("\x1B[r\x1B[H\x1B[2J\x1B[3J"),process.exit(0);default:return Sg(t)||console.log(`${a.red}Unknown command: ${s}. Type /help${a.reset}`),!0}}var rr=1e3;function ir(){return qe.join(process.cwd(),".nex","repl_history")}function bl(){try{let t=ir();if(tt.existsSync(t))return tt.readFileSync(t,"utf-8").split(`
827
826
  `).filter(Boolean).slice(-rr)}catch{}return[]}function ps(t){try{let e=ir(),s=qe.dirname(e);tt.existsSync(s)||tt.mkdirSync(s,{recursive:!0}),tt.appendFileSync(e,t+`
828
827
  `)}catch{}}function Ee(){let{isPlanMode:t,getAutonomyLevel:e}=Ot(),s=[];t()&&s.push("plan");let n=e();n!=="interactive"&&s.push(n);let o=Ze(),r=et(),i=o==="ollama"?r.id:`${o}:${r.id}`;return s.push(i),`${s.length>0?`${a.dim}[${s.join(" \xB7 ")}]${a.reset} `:""}${a.bold}${a.cyan}>${a.reset} `}var ar="\x1B[200~",cr="\x1B[201~";function Rg(t){return typeof t=="string"&&t.includes(ar)}function Ag(t){return typeof t=="string"&&t.includes(cr)}function gn(t){return typeof t!="string"?t:t.split(ar).join("").split(cr).join("")}async function Og(){if(!kg("local"))return!1;try{let{exec:e}=require("child_process"),{promisify:s}=require("util");return await s(e)("curl -s --max-time 1 http://localhost:11434/api/tags"),ul("local:llama3"),!0}catch{return!1}}async function Mg(){let{setAbortSignalGetter:t,getConversationLength:e,processInput:s}=ce();t(ml);let o=sr().some(A=>A.configured),r=(async()=>{vg();let A=et(),L=Ze();return{model:A,providerName:L}})(),i=(async()=>o?!0:await Og()?(console.log(`${a.green}\u2713 Local Ollama detected \u2014 using local models${a.reset}`),console.log(`${a.dim}Tip: Set API keys for cloud providers for more model options (OPENAI_API_KEY, ANTHROPIC_API_KEY, etc.)${a.reset}
829
828
  `),!0):!1)(),c=(async()=>{if(process.env.NEX_DISABLE_UPDATE_CHECK==="1")return{hasNewVersion:!1};try{let{checkForNewVersion:A}=al();return await A()}catch{return{hasNewVersion:!1}}})(),[l,u,d]=await Promise.all([r,i,c]);!u&&!o&&(console.error(`
830
829
  ${a.red}\u2717 No provider configured and no local Ollama detected.${a.reset}
831
830
  `),process.exit(1));let f=bl(),m=wg.createInterface({input:process.stdin,output:process.stdout,prompt:Ee(),completer:gl,history:f,historySize:rr});Eg(m);let h=new Tg;h.activate(m);let p=l.providerName==="ollama"?l.model.id:`${l.providerName}:${l.model.id}`;bg(p,hs,{yolo:fl()}),d.hasNewVersion&&console.log(`${a.yellow}\u{1F4A1} New version available!${a.reset} Run ${a.cyan}npm update -g nex-code${a.reset} to upgrade from ${a.dim}${d.currentVersion}${a.reset} to ${a.green}${d.latestVersion}${a.reset}
832
- `),await dl(hs);let g=!1,y=0,$=!1,x=null;function O(){ll(),h.deactivate(),cl(),process.stdin.isTTY&&process.stdout.write("\x1B[?2004l"),process.stdout.write(`
833
- ${a.dim}Bye!${a.reset}
834
- `),process.exit(0)}process.on("SIGTERM",O),process.on("exit",()=>{ll()}),m.on("SIGINT",()=>{if(cl(),g){if(y++,y>=2){O();return}Ke&&Ke.abort();let{cancelPendingAskUser:A}=Ue();A(),console.log(`
831
+ `),await dl(hs);let g=!1,y=0,$=!1,x=null;function O(){ll(),h.deactivate(),cl(),process.stdin.isTTY&&process.stdout.write("\x1B[?2004l"),process.stdout.write("\x1B[r\x1B[H\x1B[2J\x1B[3J"),process.exit(0)}process.on("SIGTERM",O),process.on("exit",()=>{ll()}),m.on("SIGINT",()=>{if(cl(),g){if(y++,y>=2){O();return}Ke&&Ke.abort();let{cancelPendingAskUser:A}=Ue();A(),console.log(`
835
832
  ${a.yellow} Task cancelled. Press Ctrl+C again to exit.${a.reset}`),g=!1,m.setPrompt(Ee()),m.prompt();return}$?O():($=!0,process.stdout.write(`
836
833
  ${a.dim} (Press Ctrl+C again to exit)${a.reset}
837
834
  `),m.setPrompt(Ee()),m.prompt(),x&&clearTimeout(x),x=setTimeout(()=>{$=!1,x=null},2e3))}),process.on("SIGINT",()=>{process.stdin.isTTY||O()});let k=!1,v=[],C=0,S={},T=!1;function F(){let A=v.join(`
@@ -849,8 +846,7 @@ ${a.dim} (Press Ctrl+C again to exit)${a.reset}
849
846
  `).trim();if(ue=null,q){ps(q.replace(/\n/g,"\\n")),g=!0,y=0,$=!1,x&&(clearTimeout(x),x=null),Ke=new AbortController;try{await s(q)}catch(ae){if(!Ke?.signal?.aborted){let je=ae.message?.split(`
850
847
  `)[0]||"An unexpected error occurred";console.log(`${a.red}Error: ${je}${a.reset}`)}}let{getConversationLength:U}=ce();g=!1;let H=U();H>0&&process.stdout.write(`${a.gray}[${H} messages] ${a.reset}`)}m.setPrompt(Ee()),m.prompt();return}m.setPrompt(de),m.prompt();return}if(A.trim()==='"""'||A.trim().startsWith('"""')){let q=A.trim().substring(3);ue=q?[q]:[],ue._mode="triple",m.setPrompt(de),m.prompt();return}if(A.endsWith("\\")){ue=[A.slice(0,-1)],ue._mode="backslash",m.setPrompt(de),m.prompt();return}let L=A.trim();if(!L){m.setPrompt(Ee()),m.prompt();return}if(ps(L),L==="/"){pl(),m.setPrompt(Ee()),m.prompt();return}if(L.startsWith("/")){await wl(L,m),m.setPrompt(Ee()),m.prompt();return}{let q="\x1B[48;5;237m",U=process.stdout.columns||80;L.split(`
851
848
  `).forEach((ae,je)=>{let gt=je===0?"\x1B[1;36m\u203A\x1B[22;39m":" ",me=2+ae.length,ke=" ".repeat(Math.max(0,U-me));console.log(`${q}${gt} ${ae}${ke}\x1B[0m`)})}g=!0,y=0,$=!1,x&&(clearTimeout(x),x=null),Ke=new AbortController;try{await s(L)}catch(q){if(!Ke?.signal?.aborted){let U=q.message?.split(`
852
- `)[0]||"An unexpected error occurred";console.log(`${a.red}Error: ${U}${a.reset}`)}}g=!1;let{getConversationLength:se}=ce(),z=se();z>0&&process.stdout.write(`${a.gray}[${z} messages] ${a.reset}`),m.setPrompt(Ee()),m.prompt()}),m.on("close",()=>{process.stdin.isTTY&&process.stdout.write("\x1B[?2004l"),console.log(`
853
- ${a.dim}Bye!${a.reset}`),process.exit(0)})}xl.exports={startREPL:Mg,getPrompt:Ee,loadHistory:bl,appendHistory:ps,getHistoryPath:ir,HISTORY_MAX:rr,showCommandList:pl,completer:gl,completeFilePath:hl,handleSlashCommand:wl,showProviders:nr,showHelp:$l,renderBar:yl,hasPasteStart:Rg,hasPasteEnd:Ag,stripPasteSequences:gn,getAbortSignal:ml}});var Sl=require("path");require("dotenv").config({path:Sl.join(__dirname,"..",".env")});require("dotenv").config();var te=process.argv.slice(2);(te.includes("--help")||te.includes("-h"))&&(console.log(`Usage: nex-code [options]
849
+ `)[0]||"An unexpected error occurred";console.log(`${a.red}Error: ${U}${a.reset}`)}}g=!1;let{getConversationLength:se}=ce(),z=se();z>0&&process.stdout.write(`${a.gray}[${z} messages] ${a.reset}`),m.setPrompt(Ee()),m.prompt()}),m.on("close",()=>{process.stdin.isTTY&&process.stdout.write("\x1B[?2004l"),process.stdout.write("\x1B[r\x1B[H\x1B[2J\x1B[3J"),process.exit(0)})}xl.exports={startREPL:Mg,getPrompt:Ee,loadHistory:bl,appendHistory:ps,getHistoryPath:ir,HISTORY_MAX:rr,showCommandList:pl,completer:gl,completeFilePath:hl,handleSlashCommand:wl,showProviders:nr,showHelp:$l,renderBar:yl,hasPasteStart:Rg,hasPasteEnd:Ag,stripPasteSequences:gn,getAbortSignal:ml}});var Sl=require("path");require("dotenv").config({path:Sl.join(__dirname,"..",".env")});require("dotenv").config();var te=process.argv.slice(2);(te.includes("--help")||te.includes("-h"))&&(console.log(`Usage: nex-code [options]
854
850
 
855
851
  Options:
856
852
  --task <prompt> Run a single task and exit (headless mode)
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "nex-code",
3
- "version": "0.3.33",
3
+ "version": "0.3.34",
4
4
  "description": "The open-source agentic coding CLI. Free with Ollama Cloud — switch to OpenAI, Anthropic or Gemini anytime. Alternative to Claude Code & Gemini CLI.",
5
5
  "bin": {
6
6
  "nex-code": "./dist/nex-code.js"