@iamharshil/aix-cli 1.1.4 → 1.1.6

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/dist/bin/aix.js CHANGED
@@ -1,8 +1,8 @@
1
1
  #!/usr/bin/env node
2
- var J=Object.defineProperty;var Q=(t=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(t,{get:(o,e)=>(typeof require<"u"?require:o)[e]}):t)(function(t){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+t+'" is not supported')});var A=(t,o)=>()=>(t&&(o=t(t=0)),o);var k=(t,o)=>{for(var e in o)J(t,e,{get:o[e],enumerable:!0})};var N={};k(N,{ConfigService:()=>w,configService:()=>m});import X from"conf";var w,m,h=A(()=>{"use strict";w=class{store;constructor(){this.store=new X({projectName:"aix",defaults:{lmStudioUrl:"http://localhost",lmStudioPort:1234,defaultTimeout:3e4,autoStartServer:!1},clearInvalidConfig:!0})}get(o){return this.store.get(o)}set(o,e){this.store.set(o,e)}setModel(o){this.store.set("model",o)}getLastUsedModel(){return this.store.get("model")}getLMStudioUrl(){let o=this.store.get("lmStudioUrl"),e=this.store.get("lmStudioPort");return`${o}:${e}`}reset(){this.store.clear()}},m=new w});var _={};k(_,{LMStudioService:()=>y,lmStudioService:()=>g});import{execa as M}from"execa";import D from"ora";import T from"chalk";var F,y,g,v=A(()=>{"use strict";h();F=[1234,1235,1236,1237],y=class{baseUrl;constructor(){this.baseUrl=m.getLMStudioUrl()}getApiUrl(o){return`${this.baseUrl}${o}`}async checkStatus(){try{return(await fetch(this.getApiUrl("/api/status"),{method:"GET",signal:AbortSignal.timeout(3e3)})).ok}catch{return!1}}async getAvailableModels(){let o=["/api/models","/api/v1/models","/api/lsMODEL/list","/api/ls-model/list"];for(let e of o)try{let r=await fetch(this.getApiUrl(e),{method:"GET",signal:AbortSignal.timeout(1e4)});if(!r.ok)continue;let n=await r.json();if(Array.isArray(n)){let d=n.map(i=>{let s=i,c=String(s.id||s.model||s.model_id||""),a=String(s.name||s.id||s.model||"");return{id:String(c),name:String(a),size:Number(s.size||s.file_size||s.size_bytes||0),quantization:String(s.quantization||s.q||"")}}).filter(i=>i.id&&i.name);if(d.length>0)return d}if(n.models&&Array.isArray(n.models))return n.models.map(d=>{let i=d;return{id:String(i.id||i.model||i.model_id||""),name:String(i.name||i.id||i.model||""),size:Number(i.size||i.file_size||0),quantization:String(i.quantization||"")}});if(n.data&&Array.isArray(n.data))return n.data}catch{continue}return[]}async getStatus(){if(!await this.checkStatus())return{running:!1,port:m.get("lmStudioPort"),models:[]};try{let e=await fetch(this.getApiUrl("/api/status"),{method:"GET",signal:AbortSignal.timeout(1e4)});if(!e.ok)return{running:!1,port:m.get("lmStudioPort"),models:[]};let r=await e.json();return{running:!0,port:m.get("lmStudioPort"),models:r.models??[],activeModel:r.active_model}}catch{return{running:!1,port:m.get("lmStudioPort"),models:[]}}}async loadModel(o,e){let r=e??D({text:`Loading model: ${T.cyan(o)}`,color:"cyan"}).start();try{let n=await fetch(this.getApiUrl("/api/model/load"),{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({model:o}),signal:AbortSignal.timeout(3e5)});if(!n.ok)throw new Error(`Failed to load model: ${n.statusText}`);return r.succeed(`Model ${T.green(o)} loaded successfully`),m.setModel(o),{loadSpinner:r}}catch(n){throw r.fail(`Failed to load model: ${n instanceof Error?n.message:"Unknown error"}`),n}}async startServer(o){let e=o??D({text:"Starting LM Studio server...",color:"cyan"}).start();try{let r=process.platform==="darwin",n=process.platform==="linux",d=process.platform==="win32",i;if(r){let s=["/Applications/LM Studio.app",`${process.env.HOME}/Applications/LM Studio.app`];for(let c of s)try{let{existsSync:a}=await import("fs");if(a(c)){i=`open "${c}" --args --server`;break}}catch{}if(i?.startsWith("open")){await M("open",[s.find(c=>{try{let{existsSync:a}=Q("fs");return a(c)}catch{return!1}})||"/Applications/LM Studio.app","--args","--server"],{detached:!0,stdio:"ignore"}),e.succeed("LM Studio server started"),await this.waitForServer(6e4);return}}else n?i=await this.findLinuxBinary():d&&(i=await this.findWindowsExecutable());if(!i)throw e.fail("LM Studio not found. Please install it from https://lmstudio.ai"),new Error("LM Studio not installed");await M(i,["--server"],{detached:!0,stdio:"ignore",env:{...process.env,LM_STUDIO_SERVER_PORT:String(m.get("lmStudioPort"))}}),e.succeed("LM Studio server started"),await this.waitForServer(6e4)}catch(r){throw e.fail(`Failed to start LM Studio: ${r instanceof Error?r.message:"Unknown error"}`),r}}async findLinuxBinary(){let o=["/usr/bin/lm-studio","/usr/local/bin/lm-studio",`${process.env.HOME}/.local/bin/lm-studio`];for(let e of o)try{return await M("test",["-x",e]),e}catch{continue}}async findWindowsExecutable(){let o=process.env.LOCALAPPDATA,e=process.env.PROGRAMFILES,r=[o?`${o}\\Programs\\LM Studio\\lm-studio.exe`:"",e?`${e}\\LM Studio\\lm-studio.exe`:""].filter(Boolean);for(let n of r)try{return await M("cmd",["/c","if exist",`"${n}"`,"echo","yes"]),n}catch{continue}}async waitForServer(o=6e4){let e=Date.now();for(;Date.now()-e<o;){if(await this.checkStatus())return!0;await this.sleep(2e3)}return!1}sleep(o){return new Promise(e=>setTimeout(e,o))}async findAvailablePort(){for(let o of F)try{if((await fetch(`http://localhost:${o}/api/status`,{method:"GET",signal:AbortSignal.timeout(1e3)})).ok)return o}catch{return m.set("lmStudioPort",o),o}return F[0]??1234}},g=new y});var K={};k(K,{ClaudeService:()=>C,claudeService:()=>U});import{execa as O}from"execa";import Z from"chalk";var C,U,R=A(()=>{"use strict";C=class{async isClaudeCodeInstalled(){try{return await O("claude",["--version"],{stdio:"ignore"}),!0}catch{return!1}}async run(o){let{model:e,args:r=[],verbose:n=!1}=o,d=this.extractProvider(e),i=this.extractModelName(e);if(!d||!i)throw new Error(`Invalid model format: ${e}. Expected format: provider/model-name`);let s=`${d}/${i}`,c=["--model",s,...r];n&&console.log(Z.dim(`
2
+ var J=Object.defineProperty;var Q=(t=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(t,{get:(o,e)=>(typeof require<"u"?require:o)[e]}):t)(function(t){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+t+'" is not supported')});var A=(t,o)=>()=>(t&&(o=t(t=0)),o);var k=(t,o)=>{for(var e in o)J(t,e,{get:o[e],enumerable:!0})};var N={};k(N,{ConfigService:()=>w,configService:()=>m});import X from"conf";var w,m,h=A(()=>{"use strict";w=class{store;constructor(){this.store=new X({projectName:"aix",defaults:{lmStudioUrl:"http://localhost",lmStudioPort:1234,defaultTimeout:3e4,autoStartServer:!1},clearInvalidConfig:!0})}get(o){return this.store.get(o)}set(o,e){this.store.set(o,e)}setModel(o){this.store.set("model",o)}getLastUsedModel(){return this.store.get("model")}getLMStudioUrl(){let o=this.store.get("lmStudioUrl"),e=this.store.get("lmStudioPort");return`${o}:${e}`}reset(){this.store.clear()}},m=new w});var j={};k(j,{LMStudioService:()=>y,lmStudioService:()=>p});import{execa as M}from"execa";import T from"ora";import D from"chalk";var F,y,p,v=A(()=>{"use strict";h();F=[1234,1235,1236,1237],y=class{baseUrl;constructor(){this.baseUrl=m.getLMStudioUrl()}getApiUrl(o){return`${this.baseUrl}${o}`}async checkStatus(){try{return(await fetch(this.getApiUrl("/api/status"),{method:"GET",signal:AbortSignal.timeout(3e3)})).ok}catch{return!1}}async getAvailableModels(){let o=["/api/v1/models","/api/models","/v1/models","/api/ls-model/list"];for(let e of o)try{let r=await fetch(this.getApiUrl(e),{method:"GET",signal:AbortSignal.timeout(1e4)});if(!r.ok)continue;let n=await r.json(),l=[];return Array.isArray(n)?l=n:n.models&&Array.isArray(n.models)?l=n.models:n.data&&Array.isArray(n.data)&&(l=n.data),l.map(d=>{let i=d;return{id:String(i.key||i.id||i.model||""),name:String(i.display_name||i.name||i.id||i.model||""),size:Number(i.size_bytes||i.size||i.file_size||0),quantization:String(i.quantization?typeof i.quantization=="object"?i.quantization.name:i.quantization:"")}}).filter(d=>d.id&&d.name)}catch{continue}return[]}async getStatus(){if(!await this.checkStatus())return{running:!1,port:m.get("lmStudioPort"),models:[]};try{let e=await fetch(this.getApiUrl("/api/status"),{method:"GET",signal:AbortSignal.timeout(1e4)});if(!e.ok)return{running:!1,port:m.get("lmStudioPort"),models:[]};let r=await e.json();return{running:!0,port:m.get("lmStudioPort"),models:r.models??[],activeModel:r.active_model}}catch{return{running:!1,port:m.get("lmStudioPort"),models:[]}}}async loadModel(o,e){let r=e??T({text:`Loading model: ${D.cyan(o)}`,color:"cyan"}).start();try{let n=await fetch(this.getApiUrl("/api/model/load"),{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({model:o}),signal:AbortSignal.timeout(3e5)});if(!n.ok)throw new Error(`Failed to load model: ${n.statusText}`);return r.succeed(`Model ${D.green(o)} loaded successfully`),m.setModel(o),{loadSpinner:r}}catch(n){throw r.fail(`Failed to load model: ${n instanceof Error?n.message:"Unknown error"}`),n}}async startServer(o){let e=o??T({text:"Starting LM Studio server...",color:"cyan"}).start();try{let r=process.platform==="darwin",n=process.platform==="linux",l=process.platform==="win32",d;if(r){let i=["/Applications/LM Studio.app",`${process.env.HOME}/Applications/LM Studio.app`];for(let c of i)try{let{existsSync:s}=await import("fs");if(s(c)){d=`open "${c}" --args --server`;break}}catch{}if(d?.startsWith("open")){await M("open",[i.find(c=>{try{let{existsSync:s}=Q("fs");return s(c)}catch{return!1}})||"/Applications/LM Studio.app","--args","--server"],{detached:!0,stdio:"ignore"}),e.succeed("LM Studio server started"),await this.waitForServer(6e4);return}}else n?d=await this.findLinuxBinary():l&&(d=await this.findWindowsExecutable());if(!d)throw e.fail("LM Studio not found. Please install it from https://lmstudio.ai"),new Error("LM Studio not installed");await M(d,["--server"],{detached:!0,stdio:"ignore",env:{...process.env,LM_STUDIO_SERVER_PORT:String(m.get("lmStudioPort"))}}),e.succeed("LM Studio server started"),await this.waitForServer(6e4)}catch(r){throw e.fail(`Failed to start LM Studio: ${r instanceof Error?r.message:"Unknown error"}`),r}}async findLinuxBinary(){let o=["/usr/bin/lm-studio","/usr/local/bin/lm-studio",`${process.env.HOME}/.local/bin/lm-studio`];for(let e of o)try{return await M("test",["-x",e]),e}catch{continue}}async findWindowsExecutable(){let o=process.env.LOCALAPPDATA,e=process.env.PROGRAMFILES,r=[o?`${o}\\Programs\\LM Studio\\lm-studio.exe`:"",e?`${e}\\LM Studio\\lm-studio.exe`:""].filter(Boolean);for(let n of r)try{return await M("cmd",["/c","if exist",`"${n}"`,"echo","yes"]),n}catch{continue}}async waitForServer(o=6e4){let e=Date.now();for(;Date.now()-e<o;){if(await this.checkStatus())return!0;await this.sleep(2e3)}return!1}sleep(o){return new Promise(e=>setTimeout(e,o))}async findAvailablePort(){for(let o of F)try{if((await fetch(`http://localhost:${o}/api/status`,{method:"GET",signal:AbortSignal.timeout(1e3)})).ok)return o}catch{return m.set("lmStudioPort",o),o}return F[0]??1234}},p=new y});var K={};k(K,{ClaudeService:()=>C,claudeService:()=>O});import{execa as U}from"execa";import Z from"chalk";var C,O,R=A(()=>{"use strict";C=class{async isClaudeCodeInstalled(){try{return await U("claude",["--version"],{stdio:"ignore"}),!0}catch{return!1}}async run(o){let{model:e,args:r=[],verbose:n=!1}=o,l=this.extractProvider(e),d=this.extractModelName(e);if(!l||!d)throw new Error(`Invalid model format: ${e}. Expected format: provider/model-name`);let i=`${l}/${d}`,c=["--model",i,...r];n&&console.log(Z.dim(`
3
3
  Running: claude ${c.join(" ")}
4
- `));try{await O("claude",c,{stdio:"inherit",env:{...process.env,ANTHROPIC_MODEL:s}})}catch(a){if(a instanceof Error&&"exitCode"in a){let P=a.exitCode;process.exit(P??1)}throw a}}extractProvider(o){return o.split("/")[0]}extractModelName(o){let e=o.split("/");if(!(e.length<2))return e.slice(1).join("/")}async getVersion(){try{return(await O("claude",["--version"])).stdout}catch{return}}},U=new C});import{Command as oo}from"commander";import u from"chalk";v();h();import q from"ora";import f from"chalk";import B from"inquirer";async function x(t,o){let e=t.map(d=>({name:`${d.name} (${d.id})`,value:d,short:d.name})),r=o?e.findIndex(d=>d.value.id===o):0;return(await B.prompt([{type:"list",name:"model",message:"Select a model to load:",choices:e,default:Math.max(0,r),pageSize:Math.min(t.length,15)}])).model}async function $(t,o=!0){return(await B.prompt([{type:"confirm",name:"confirm",message:t,default:o}])).confirm}import j from"chalk";function b(t){if(t===0)return"0 B";let o=1024,e=["B","KB","MB","GB","TB"],r=Math.floor(Math.log(t)/Math.log(o));return`${parseFloat((t/Math.pow(o,r)).toFixed(2))} ${e[r]}`}function L(t){console.log(j.green("\u2713")+" "+t)}function Y(t){console.error(j.red("\u2717")+" "+t)}function p(t,o=1){Y(t),process.exit(o)}async function E(t={}){let o=q({text:"Checking LM Studio status...",color:"cyan"}).start(),e=await g.checkStatus();e||(o.info("LM Studio server not running"),o.stop(),await $("Would you like to start the LM Studio server?")||p("LM Studio server must be running. Start it manually or use the Server tab in LM Studio."),await g.startServer(),e=!0),o.succeed("Connected to LM Studio");let r=q({text:"Fetching available models...",color:"cyan"}).start(),n=await g.getAvailableModels();n.length===0&&(r.fail("No models found. Download some models in LM Studio first."),p("No models available")),r.succeed(`Found ${f.bold(n.length)} model${n.length===1?"":"s"}`),console.log(),console.log(f.bold("Available Models:")),console.log(f.dim("\u2500".repeat(process.stdout.columns||80))),n.forEach((a,P)=>{let H=b(a.size),V=a.loaded?f.green(" [LOADED]"):"";console.log(` ${f.dim(String(P+1).padStart(2))}. ${a.name} ${f.dim(`(${H})`)}${V}`)}),console.log();let d=m.getLastUsedModel(),i=t.model,s=i?n.find(a=>a.id===i||a.name.includes(i)):await x(n,d);s||p("No model selected"),await g.loadModel(s.id,o);let c=s.id.replace("/","--");L(f.bold(`
5
- Model ready: ${s.name}`)),console.log(),console.log("Run Claude Code with this model:"),console.log(` ${f.cyan("claude --model lmstudio/"+c)}`),console.log(),console.log(`Or use ${f.cyan("npx aix run")} to start an interactive session`)}v();R();h();import W from"ora";import G from"chalk";async function z(t={}){let o=W({text:"Checking LM Studio status...",color:"cyan"}).start(),e=await g.checkStatus();e||(o.info("LM Studio server not running"),o.stop(),await $("Would you like to start the LM Studio server?")||p("LM Studio server must be running. Start it manually or use the Server tab in LM Studio."),await g.startServer(),e=!0),o.succeed("Connected to LM Studio"),o.text="Fetching available models...";let r=await g.getAvailableModels();r.length===0&&(o.fail("No models found. Download some models in LM Studio first."),p("No models available")),o.stop();let n;if(t.model){let c=r.find(a=>a.id===t.model||a.name.toLowerCase().includes(t.model.toLowerCase()));c||p(`Model "${t.model}" not found. Available models: ${r.map(a=>a.name).join(", ")}`),n=c.id}else{let c=m.getLastUsedModel();n=(await x(r,c)).id}let d=W({text:`Loading model: ${G.cyan(n)}`,color:"cyan"}).start();await g.loadModel(n,d);let s=`lmstudio/${n.replace("/","--")}`;L(G.green(`
6
- Starting Claude Code with model: ${s}
7
- `));try{await U.run({model:s,args:t.args??[],verbose:t.verbose})}catch(c){p(`Failed to run Claude Code: ${c instanceof Error?c.message:"Unknown error"}`)}}v();import l from"chalk";async function I(){let t=await g.getStatus();console.log(),console.log(l.bold("LM Studio Status")),console.log(l.dim("\u2500".repeat(50))),console.log(` ${t.running?l.green("\u25CF"):l.red("\u25CB")} Server: ${t.running?l.green("Running"):l.red("Stopped")}`),console.log(` ${l.dim("\u25B8")} Port: ${l.cyan(String(t.port))}`),console.log(` ${l.dim("\u25B8")} URL: ${l.cyan(`http://localhost:${t.port}`)}`),t.activeModel?console.log(` ${l.dim("\u25B8")} Active Model: ${l.green(t.activeModel)}`):console.log(` ${l.dim("\u25B8")} Active Model: ${l.dim("None")}`),console.log(),console.log(l.bold("Models")),console.log(l.dim("\u2500".repeat(50))),t.models.length===0?console.log(` ${l.dim("No models available")}`):t.models.forEach((o,e)=>{let r=b(o.size),n=o.id===t.activeModel?` ${l.green("[LOADED]")}`:"";console.log(` ${l.dim(String(e+1)+".")} ${o.name}${n}`),console.log(` ${l.dim("ID:")} ${o.id}`),console.log(` ${l.dim("Size:")} ${r}`),o.quantization&&console.log(` ${l.dim("Quantization:")} ${o.quantization}`),console.log()})}var S=new oo;S.name("aix").description("AI CLI tool integrating LM Studio with Claude Code").version("1.0.0");S.command("init").description("Initialize and load a model into LM Studio").option("-m, --model <name>","Model name or ID to load").action(E);S.command("run").description("Run Claude Code with a model from LM Studio").option("-m, --model <name>","Model name or ID to use").option("-v, --verbose","Show verbose output").argument("[args...]","Additional arguments for Claude Code").action(async(t,o)=>{await z({...o,args:t})});S.command("status").description("Show LM Studio status and available models").action(I);S.command("doctor").description("Check system requirements and configuration").action(async()=>{let{lmStudioService:t}=await Promise.resolve().then(()=>(v(),_)),{claudeService:o}=await Promise.resolve().then(()=>(R(),K)),{configService:e}=await Promise.resolve().then(()=>(h(),N));console.log(),console.log(u.bold("System Check")),console.log(u.dim("\u2500".repeat(50)));let r=await t.checkStatus();console.log(` ${r?u.green("\u2713"):u.yellow("\u26A0")} LM Studio: ${r?u.green("Running"):u.yellow("Not running")}`);let n=await o.isClaudeCodeInstalled();console.log(` ${n?u.green("\u2713"):u.red("\u2717")} Claude Code: ${n?u.green("Installed"):u.red("Not installed")}`),console.log(),console.log(u.bold("Configuration")),console.log(u.dim("\u2500".repeat(50))),console.log(` ${u.dim("\u25B8")} LM Studio URL: ${u.cyan(e.getLMStudioUrl())}`),n||(console.log(),console.log(u.yellow("\u26A0 Claude Code is not installed.")),console.log(` Install it with: ${u.cyan("npm install -g @anthropic-ai/claude-code")}`)),r||(console.log(),console.log(u.yellow("\u26A0 LM Studio is not running.")),console.log(` Start the server from the LM Studio app or download from ${u.cyan("https://lmstudio.ai")}`))});S.parse();
4
+ `));try{await U("claude",c,{stdio:"inherit",env:{...process.env,ANTHROPIC_MODEL:i}})}catch(s){if(s instanceof Error&&"exitCode"in s){let P=s.exitCode;process.exit(P??1)}throw s}}extractProvider(o){return o.split("/")[0]}extractModelName(o){let e=o.split("/");if(!(e.length<2))return e.slice(1).join("/")}async getVersion(){try{return(await U("claude",["--version"])).stdout}catch{return}}},O=new C});import{Command as oo}from"commander";import u from"chalk";v();h();import q from"ora";import f from"chalk";import B from"inquirer";async function x(t,o){let e=t.map(l=>({name:`${l.name} (${l.id})`,value:l,short:l.name})),r=o?e.findIndex(l=>l.value.id===o):0;return(await B.prompt([{type:"list",name:"model",message:"Select a model to load:",choices:e,default:Math.max(0,r),pageSize:Math.min(t.length,15)}])).model}async function $(t,o=!0){return(await B.prompt([{type:"confirm",name:"confirm",message:t,default:o}])).confirm}import _ from"chalk";function b(t){if(t===0)return"0 B";let o=1024,e=["B","KB","MB","GB","TB"],r=Math.floor(Math.log(t)/Math.log(o));return`${parseFloat((t/Math.pow(o,r)).toFixed(2))} ${e[r]}`}function L(t){console.log(_.green("\u2713")+" "+t)}function Y(t){console.error(_.red("\u2717")+" "+t)}function g(t,o=1){Y(t),process.exit(o)}async function E(t={}){let o=q({text:"Checking LM Studio status...",color:"cyan"}).start(),e=await p.checkStatus();e||(o.info("LM Studio server not running"),o.stop(),await $("Would you like to start the LM Studio server?")||g("LM Studio server must be running. Start it manually or use the Server tab in LM Studio."),await p.startServer(),e=!0),o.succeed("Connected to LM Studio");let r=q({text:"Fetching available models...",color:"cyan"}).start(),n=await p.getAvailableModels();n.length===0&&(r.fail("No models found. Download some models in LM Studio first."),g("No models available")),r.succeed(`Found ${f.bold(n.length)} model${n.length===1?"":"s"}`),console.log(),console.log(f.bold("Available Models:")),console.log(f.dim("\u2500".repeat(process.stdout.columns||80))),n.forEach((s,P)=>{let H=b(s.size),V=s.loaded?f.green(" [LOADED]"):"";console.log(` ${f.dim(String(P+1).padStart(2))}. ${s.name} ${f.dim(`(${H})`)}${V}`)}),console.log();let l=m.getLastUsedModel(),d=t.model,i=d?n.find(s=>s.id===d||s.name.includes(d)):await x(n,l);i||g("No model selected"),await p.loadModel(i.id,o);let c=i.id.replace("/","--");L(f.bold(`
5
+ Model ready: ${i.name}`)),console.log(),console.log("Run Claude Code with this model:"),console.log(` ${f.cyan("claude --model lmstudio/"+c)}`),console.log(),console.log(`Or use ${f.cyan("aix-cli run")} to start an interactive session`)}v();R();h();import W from"ora";import G from"chalk";async function I(t={}){let o=W({text:"Checking LM Studio status...",color:"cyan"}).start(),e=await p.checkStatus();e||(o.info("LM Studio server not running"),o.stop(),await $("Would you like to start the LM Studio server?")||g("LM Studio server must be running. Start it manually or use the Server tab in LM Studio."),await p.startServer(),e=!0),o.succeed("Connected to LM Studio"),o.text="Fetching available models...";let r=await p.getAvailableModels();r.length===0&&(o.fail("No models found. Download some models in LM Studio first."),g("No models available")),o.stop();let n;if(t.model){let c=r.find(s=>s.id===t.model||s.name.toLowerCase().includes(t.model.toLowerCase()));c||g(`Model "${t.model}" not found. Available models: ${r.map(s=>s.name).join(", ")}`),n=c.id}else{let c=m.getLastUsedModel();n=(await x(r,c)).id}let l=W({text:`Loading model: ${G.cyan(n)}`,color:"cyan"}).start();await p.loadModel(n,l);let i=`lmstudio/${n.replace("/","--")}`;L(G.green(`
6
+ Starting Claude Code with model: ${i}
7
+ `));try{await O.run({model:i,args:t.args??[],verbose:t.verbose})}catch(c){g(`Failed to run Claude Code: ${c instanceof Error?c.message:"Unknown error"}`)}}v();import a from"chalk";async function z(){let t=await p.getStatus();console.log(),console.log(a.bold("LM Studio Status")),console.log(a.dim("\u2500".repeat(50))),console.log(` ${t.running?a.green("\u25CF"):a.red("\u25CB")} Server: ${t.running?a.green("Running"):a.red("Stopped")}`),console.log(` ${a.dim("\u25B8")} Port: ${a.cyan(String(t.port))}`),console.log(` ${a.dim("\u25B8")} URL: ${a.cyan(`http://localhost:${t.port}`)}`),t.activeModel?console.log(` ${a.dim("\u25B8")} Active Model: ${a.green(t.activeModel)}`):console.log(` ${a.dim("\u25B8")} Active Model: ${a.dim("None")}`),console.log(),console.log(a.bold("Models")),console.log(a.dim("\u2500".repeat(50))),t.models.length===0?console.log(` ${a.dim("No models available")}`):t.models.forEach((o,e)=>{let r=b(o.size),n=o.id===t.activeModel?` ${a.green("[LOADED]")}`:"";console.log(` ${a.dim(String(e+1)+".")} ${o.name}${n}`),console.log(` ${a.dim("ID:")} ${o.id}`),console.log(` ${a.dim("Size:")} ${r}`),o.quantization&&console.log(` ${a.dim("Quantization:")} ${o.quantization}`),console.log()})}var S=new oo;S.name("aix").description("AI CLI tool integrating LM Studio with Claude Code").version("1.0.0");S.command("init").description("Initialize and load a model into LM Studio").option("-m, --model <name>","Model name or ID to load").action(E);S.command("run").description("Run Claude Code with a model from LM Studio").option("-m, --model <name>","Model name or ID to use").option("-v, --verbose","Show verbose output").argument("[args...]","Additional arguments for Claude Code").action(async(t,o)=>{await I({...o,args:t})});S.command("status").description("Show LM Studio status and available models").action(z);S.command("doctor").description("Check system requirements and configuration").action(async()=>{let{lmStudioService:t}=await Promise.resolve().then(()=>(v(),j)),{claudeService:o}=await Promise.resolve().then(()=>(R(),K)),{configService:e}=await Promise.resolve().then(()=>(h(),N));console.log(),console.log(u.bold("System Check")),console.log(u.dim("\u2500".repeat(50)));let r=await t.checkStatus();console.log(` ${r?u.green("\u2713"):u.yellow("\u26A0")} LM Studio: ${r?u.green("Running"):u.yellow("Not running")}`);let n=await o.isClaudeCodeInstalled();console.log(` ${n?u.green("\u2713"):u.red("\u2717")} Claude Code: ${n?u.green("Installed"):u.red("Not installed")}`),console.log(),console.log(u.bold("Configuration")),console.log(u.dim("\u2500".repeat(50))),console.log(` ${u.dim("\u25B8")} LM Studio URL: ${u.cyan(e.getLMStudioUrl())}`),n||(console.log(),console.log(u.yellow("\u26A0 Claude Code is not installed.")),console.log(` Install it with: ${u.cyan("npm install -g @anthropic-ai/claude-code")}`)),r||(console.log(),console.log(u.yellow("\u26A0 LM Studio is not running.")),console.log(` Start the server from the LM Studio app or download from ${u.cyan("https://lmstudio.ai")}`))});S.parse();
8
8
  //# sourceMappingURL=aix.js.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../src/services/config.ts", "../../src/services/lmstudio.ts", "../../src/services/claude.ts", "../../src/index.ts", "../../src/commands/init.ts", "../../src/utils/prompt.ts", "../../src/utils/format.ts", "../../src/commands/run.ts", "../../src/commands/status.ts"],
4
- "sourcesContent": ["import Conf from 'conf';\nimport type { Config } from '../types/index.js';\n\nexport class ConfigService {\n private store: Conf<Config>;\n\n constructor() {\n this.store = new Conf<Config>({\n projectName: 'aix',\n defaults: {\n lmStudioUrl: 'http://localhost',\n lmStudioPort: 1234,\n defaultTimeout: 30000,\n autoStartServer: false,\n },\n clearInvalidConfig: true,\n });\n }\n\n get<K extends keyof Config>(key: K): Config[K] {\n return this.store.get(key) as Config[K];\n }\n\n set<K extends keyof Config>(key: K, value: Config[K]): void {\n this.store.set(key, value as Config[K]);\n }\n\n setModel(model: string): void {\n this.store.set('model', model);\n }\n\n getLastUsedModel(): string | undefined {\n return this.store.get('model');\n }\n\n getLMStudioUrl(): string {\n const host = this.store.get('lmStudioUrl');\n const port = this.store.get('lmStudioPort');\n return `${host}:${port}`;\n }\n\n reset(): void {\n this.store.clear();\n }\n}\n\nexport const configService = new ConfigService();\n", "import { execa } from 'execa';\nimport ora, { type Ora } from 'ora';\nimport chalk from 'chalk';\nimport { configService } from './config.js';\nimport type { LMStudioStatus, LMStudioModel } from '../types/index.js';\n\nconst LMSTUDIO_PORTS = [1234, 1235, 1236, 1237];\n\nexport class LMStudioService {\n private baseUrl: string;\n\n constructor() {\n this.baseUrl = configService.getLMStudioUrl();\n }\n\n private getApiUrl(path: string): string {\n return `${this.baseUrl}${path}`;\n }\n\n async checkStatus(): Promise<boolean> {\n try {\n const response = await fetch(this.getApiUrl('/api/status'), {\n method: 'GET',\n signal: AbortSignal.timeout(3000),\n });\n return response.ok;\n } catch {\n return false;\n }\n }\n\n async getAvailableModels(): Promise<LMStudioModel[]> {\n const endpoints = ['/api/models', '/api/v1/models', '/api/lsMODEL/list', '/api/ls-model/list'];\n\n for (const endpoint of endpoints) {\n try {\n const response = await fetch(this.getApiUrl(endpoint), {\n method: 'GET',\n signal: AbortSignal.timeout(10000),\n });\n\n if (!response.ok) continue;\n\n const data = (await response.json()) as Record<string, unknown>;\n\n if (Array.isArray(data)) {\n const models = data\n .map((m: unknown) => {\n const model = m as Record<string, unknown>;\n const id = String(model.id || model.model || model.model_id || '');\n const name = String(model.name || model.id || model.model || '');\n return {\n id: String(id),\n name: String(name),\n size: Number(model.size || model.file_size || model.size_bytes || 0),\n quantization: String(model.quantization || model.q || ''),\n };\n })\n .filter((m) => m.id && m.name);\n if (models.length > 0) return models;\n }\n\n if (data.models && Array.isArray(data.models)) {\n return (data.models as unknown[]).map((m: unknown) => {\n const model = m as Record<string, unknown>;\n return {\n id: String(model.id || model.model || model.model_id || ''),\n name: String(model.name || model.id || model.model || ''),\n size: Number(model.size || model.file_size || 0),\n quantization: String(model.quantization || ''),\n };\n });\n }\n\n if (data.data && Array.isArray(data.data)) {\n return data.data as LMStudioModel[];\n }\n } catch {\n continue;\n }\n }\n\n return [];\n }\n\n async getStatus(): Promise<LMStudioStatus> {\n const running = await this.checkStatus();\n\n if (!running) {\n return {\n running: false,\n port: configService.get('lmStudioPort'),\n models: [],\n };\n }\n\n try {\n const response = await fetch(this.getApiUrl('/api/status'), {\n method: 'GET',\n signal: AbortSignal.timeout(10000),\n });\n\n if (!response.ok) {\n return {\n running: false,\n port: configService.get('lmStudioPort'),\n models: [],\n };\n }\n\n const data = (await response.json()) as {\n models: LMStudioModel[];\n active_model?: string;\n };\n\n return {\n running: true,\n port: configService.get('lmStudioPort'),\n models: data.models ?? [],\n activeModel: data.active_model,\n };\n } catch {\n return {\n running: false,\n port: configService.get('lmStudioPort'),\n models: [],\n };\n }\n }\n\n async loadModel(modelId: string, spinner?: Ora): Promise<{ loadSpinner: Ora }> {\n const loadSpinner =\n spinner ??\n ora({\n text: `Loading model: ${chalk.cyan(modelId)}`,\n color: 'cyan',\n }).start();\n\n try {\n const response = await fetch(this.getApiUrl('/api/model/load'), {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify({ model: modelId }),\n signal: AbortSignal.timeout(300000),\n });\n\n if (!response.ok) {\n throw new Error(`Failed to load model: ${response.statusText}`);\n }\n\n loadSpinner.succeed(`Model ${chalk.green(modelId)} loaded successfully`);\n configService.setModel(modelId);\n\n return { loadSpinner };\n } catch (error) {\n loadSpinner.fail(\n `Failed to load model: ${error instanceof Error ? error.message : 'Unknown error'}`\n );\n throw error;\n }\n }\n\n async startServer(spinner?: Ora): Promise<void> {\n const startSpinner =\n spinner ??\n ora({\n text: 'Starting LM Studio server...',\n color: 'cyan',\n }).start();\n\n try {\n const isMac = process.platform === 'darwin';\n const isLinux = process.platform === 'linux';\n const isWindows = process.platform === 'win32';\n\n let lmStudioPath: string | undefined;\n\n if (isMac) {\n const possiblePaths = [\n '/Applications/LM Studio.app',\n `${process.env.HOME}/Applications/LM Studio.app`,\n ];\n for (const p of possiblePaths) {\n try {\n const { existsSync } = await import('fs');\n if (existsSync(p)) {\n lmStudioPath = `open \"${p}\" --args --server`;\n break;\n }\n } catch {\n // continue\n }\n }\n // Use open command for macOS apps\n if (lmStudioPath?.startsWith('open')) {\n await execa(\n 'open',\n [\n possiblePaths.find((p) => {\n try {\n const { existsSync } = require('fs');\n return existsSync(p);\n } catch {\n return false;\n }\n }) || '/Applications/LM Studio.app',\n '--args',\n '--server',\n ],\n {\n detached: true,\n stdio: 'ignore',\n }\n );\n startSpinner.succeed('LM Studio server started');\n await this.waitForServer(60000);\n return;\n }\n } else if (isLinux) {\n lmStudioPath = await this.findLinuxBinary();\n } else if (isWindows) {\n lmStudioPath = await this.findWindowsExecutable();\n }\n\n if (!lmStudioPath) {\n startSpinner.fail('LM Studio not found. Please install it from https://lmstudio.ai');\n throw new Error('LM Studio not installed');\n }\n\n await execa(lmStudioPath, ['--server'], {\n detached: true,\n stdio: 'ignore',\n env: {\n ...process.env,\n LM_STUDIO_SERVER_PORT: String(configService.get('lmStudioPort')),\n },\n });\n\n startSpinner.succeed('LM Studio server started');\n\n await this.waitForServer(60000);\n } catch (error) {\n startSpinner.fail(\n `Failed to start LM Studio: ${error instanceof Error ? error.message : 'Unknown error'}`\n );\n throw error;\n }\n }\n\n private async findLinuxBinary(): Promise<string | undefined> {\n const possiblePaths = [\n '/usr/bin/lm-studio',\n '/usr/local/bin/lm-studio',\n `${process.env.HOME}/.local/bin/lm-studio`,\n ];\n\n for (const path of possiblePaths) {\n try {\n await execa('test', ['-x', path]);\n return path;\n } catch {\n continue;\n }\n }\n\n return undefined;\n }\n\n private async findWindowsExecutable(): Promise<string | undefined> {\n const localAppData = process.env.LOCALAPPDATA;\n const programFiles = process.env.PROGRAMFILES;\n\n const possiblePaths = [\n localAppData ? `${localAppData}\\\\Programs\\\\LM Studio\\\\lm-studio.exe` : '',\n programFiles ? `${programFiles}\\\\LM Studio\\\\lm-studio.exe` : '',\n ].filter(Boolean);\n\n for (const path of possiblePaths) {\n try {\n await execa('cmd', ['/c', 'if exist', `\"${path}\"`, 'echo', 'yes']);\n return path;\n } catch {\n continue;\n }\n }\n\n return undefined;\n }\n\n async waitForServer(timeout: number = 60000): Promise<boolean> {\n const startTime = Date.now();\n\n while (Date.now() - startTime < timeout) {\n if (await this.checkStatus()) {\n return true;\n }\n await this.sleep(2000);\n }\n\n return false;\n }\n\n private sleep(ms: number): Promise<void> {\n return new Promise((resolve) => setTimeout(resolve, ms));\n }\n\n async findAvailablePort(): Promise<number> {\n for (const port of LMSTUDIO_PORTS) {\n try {\n const response = await fetch(`http://localhost:${port}/api/status`, {\n method: 'GET',\n signal: AbortSignal.timeout(1000),\n });\n if (response.ok) {\n return port;\n }\n } catch {\n configService.set('lmStudioPort', port);\n return port;\n }\n }\n\n return LMSTUDIO_PORTS[0] ?? 1234;\n }\n}\n\nexport const lmStudioService = new LMStudioService();\n", "import { execa } from 'execa';\nimport chalk from 'chalk';\n\nexport interface ClaudeOptions {\n model: string;\n args?: string[];\n verbose?: boolean;\n}\n\nexport class ClaudeService {\n async isClaudeCodeInstalled(): Promise<boolean> {\n try {\n await execa('claude', ['--version'], { stdio: 'ignore' });\n return true;\n } catch {\n return false;\n }\n }\n\n async run(options: ClaudeOptions): Promise<void> {\n const { model, args = [], verbose = false } = options;\n\n const provider = this.extractProvider(model);\n const modelName = this.extractModelName(model);\n\n if (!provider || !modelName) {\n throw new Error(`Invalid model format: ${model}. Expected format: provider/model-name`);\n }\n\n const modelArg = `${provider}/${modelName}`;\n const claudeArgs = ['--model', modelArg, ...args];\n\n if (verbose) {\n console.log(chalk.dim(`\\nRunning: claude ${claudeArgs.join(' ')}\\n`));\n }\n\n try {\n await execa('claude', claudeArgs, {\n stdio: 'inherit',\n env: {\n ...process.env,\n ANTHROPIC_MODEL: modelArg,\n },\n });\n } catch (error) {\n if (error instanceof Error && 'exitCode' in error) {\n const exitCode = (error as unknown as { exitCode: number }).exitCode;\n process.exit(exitCode ?? 1);\n }\n throw error;\n }\n }\n\n private extractProvider(model: string): string | undefined {\n const parts = model.split('/');\n return parts[0];\n }\n\n private extractModelName(model: string): string | undefined {\n const parts = model.split('/');\n if (parts.length < 2) return undefined;\n return parts.slice(1).join('/');\n }\n\n async getVersion(): Promise<string | undefined> {\n try {\n const result = await execa('claude', ['--version']);\n return result.stdout;\n } catch {\n return undefined;\n }\n }\n}\n\nexport const claudeService = new ClaudeService();\n", "#!/usr/bin/env node\n\nimport { Command } from 'commander';\nimport chalk from 'chalk';\nimport { initCommand, runCommand, statusCommand } from './commands/index.js';\n\nconst program = new Command();\n\nprogram\n .name('aix')\n .description('AI CLI tool integrating LM Studio with Claude Code')\n .version('1.0.0');\n\nprogram\n .command('init')\n .description('Initialize and load a model into LM Studio')\n .option('-m, --model <name>', 'Model name or ID to load')\n .action(initCommand);\n\nprogram\n .command('run')\n .description('Run Claude Code with a model from LM Studio')\n .option('-m, --model <name>', 'Model name or ID to use')\n .option('-v, --verbose', 'Show verbose output')\n .argument('[args...]', 'Additional arguments for Claude Code')\n .action(async (args: string[], options: Record<string, unknown>) => {\n await runCommand({\n ...options,\n args,\n });\n });\n\nprogram\n .command('status')\n .description('Show LM Studio status and available models')\n .action(statusCommand);\n\nprogram\n .command('doctor')\n .description('Check system requirements and configuration')\n .action(async () => {\n const { lmStudioService } = await import('./services/lmstudio.js');\n const { claudeService } = await import('./services/claude.js');\n const { configService } = await import('./services/config.js');\n\n console.log();\n console.log(chalk.bold('System Check'));\n console.log(chalk.dim('\u2500'.repeat(50)));\n\n const lmStudioRunning = await lmStudioService.checkStatus();\n console.log(\n ` ${lmStudioRunning ? chalk.green('\u2713') : chalk.yellow('\u26A0')} LM Studio: ${lmStudioRunning ? chalk.green('Running') : chalk.yellow('Not running')}`\n );\n\n const claudeInstalled = await claudeService.isClaudeCodeInstalled();\n console.log(\n ` ${claudeInstalled ? chalk.green('\u2713') : chalk.red('\u2717')} Claude Code: ${claudeInstalled ? chalk.green('Installed') : chalk.red('Not installed')}`\n );\n\n console.log();\n console.log(chalk.bold('Configuration'));\n console.log(chalk.dim('\u2500'.repeat(50)));\n console.log(` ${chalk.dim('\u25B8')} LM Studio URL: ${chalk.cyan(configService.getLMStudioUrl())}`);\n\n if (!claudeInstalled) {\n console.log();\n console.log(chalk.yellow('\u26A0 Claude Code is not installed.'));\n console.log(` Install it with: ${chalk.cyan('npm install -g @anthropic-ai/claude-code')}`);\n }\n\n if (!lmStudioRunning) {\n console.log();\n console.log(chalk.yellow('\u26A0 LM Studio is not running.'));\n console.log(\n ` Start the server from the LM Studio app or download from ${chalk.cyan('https://lmstudio.ai')}`\n );\n }\n });\n\nprogram.parse();\n", "import ora from 'ora';\nimport chalk from 'chalk';\nimport { lmStudioService } from '../services/lmstudio.js';\nimport { configService } from '../services/config.js';\nimport { selectModel, confirmAction } from '../utils/prompt.js';\nimport { formatBytes, success, exitWithError } from '../utils/format.js';\nimport type { InitOptions } from '../types/index.js';\n\nexport async function initCommand(options: InitOptions = {}): Promise<void> {\n const spinner = ora({\n text: 'Checking LM Studio status...',\n color: 'cyan',\n }).start();\n\n let isRunning = await lmStudioService.checkStatus();\n\n if (!isRunning) {\n spinner.info('LM Studio server not running');\n spinner.stop();\n\n const shouldStart = await confirmAction('Would you like to start the LM Studio server?');\n\n if (!shouldStart) {\n exitWithError(\n 'LM Studio server must be running. Start it manually or use the Server tab in LM Studio.'\n );\n }\n\n await lmStudioService.startServer();\n isRunning = true;\n }\n\n spinner.succeed('Connected to LM Studio');\n\n const modelsSpinner = ora({\n text: 'Fetching available models...',\n color: 'cyan',\n }).start();\n\n const models = await lmStudioService.getAvailableModels();\n\n if (models.length === 0) {\n modelsSpinner.fail('No models found. Download some models in LM Studio first.');\n exitWithError('No models available');\n }\n\n modelsSpinner.succeed(\n `Found ${chalk.bold(models.length)} model${models.length === 1 ? '' : 's'}`\n );\n\n console.log();\n console.log(chalk.bold('Available Models:'));\n console.log(chalk.dim('\u2500'.repeat(process.stdout.columns || 80)));\n\n models.forEach((model, index) => {\n const size = formatBytes(model.size);\n const loaded = model.loaded ? chalk.green(' [LOADED]') : '';\n console.log(\n ` ${chalk.dim(String(index + 1).padStart(2))}. ${model.name} ${chalk.dim(`(${size})`)}${loaded}`\n );\n });\n console.log();\n\n const lastUsedModel = configService.getLastUsedModel();\n const modelSearch = options.model;\n const selectedModel = modelSearch\n ? models.find((m) => m.id === modelSearch || m.name.includes(modelSearch))\n : await selectModel(models, lastUsedModel);\n\n if (!selectedModel) {\n exitWithError('No model selected');\n }\n\n await lmStudioService.loadModel(selectedModel.id, spinner);\n\n const modelIdentifier = selectedModel.id.replace('/', '--');\n\n success(chalk.bold(`\\nModel ready: ${selectedModel.name}`));\n console.log();\n console.log(`Run Claude Code with this model:`);\n console.log(` ${chalk.cyan('claude --model lmstudio/' + modelIdentifier)}`);\n console.log();\n console.log(`Or use ${chalk.cyan('npx aix run')} to start an interactive session`);\n}\n", "import inquirer from 'inquirer';\nimport type { LMStudioModel } from '../types/index.js';\n\nexport async function selectModel(\n models: LMStudioModel[],\n defaultModel?: string\n): Promise<LMStudioModel> {\n const choices = models.map((model) => ({\n name: `${model.name} (${model.id})`,\n value: model,\n short: model.name,\n }));\n\n const defaultIndex = defaultModel ? choices.findIndex((m) => m.value.id === defaultModel) : 0;\n\n const answers = await inquirer.prompt([\n {\n type: 'list',\n name: 'model',\n message: 'Select a model to load:',\n choices,\n default: Math.max(0, defaultIndex),\n pageSize: Math.min(models.length, 15),\n },\n ]);\n\n return answers['model'] as LMStudioModel;\n}\n\nexport async function confirmAction(\n message: string,\n defaultValue: boolean = true\n): Promise<boolean> {\n const answers = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'confirm',\n message,\n default: defaultValue,\n },\n ]);\n\n return answers['confirm'] as boolean;\n}\n\nexport async function enterPrompt(message: string, defaultValue?: string): Promise<string> {\n const answers = await inquirer.prompt([\n {\n type: 'input',\n name: 'value',\n message,\n default: defaultValue,\n validate: (input: string) => input.trim().length > 0 || 'Please enter a value',\n },\n ]);\n\n return answers['value'] as string;\n}\n", "import chalk from \"chalk\";\n\nexport function formatBytes(bytes: number): string {\n if (bytes === 0) return \"0 B\";\n\n const k = 1024;\n const sizes = [\"B\", \"KB\", \"MB\", \"GB\", \"TB\"];\n const i = Math.floor(Math.log(bytes) / Math.log(k));\n\n return `${parseFloat((bytes / Math.pow(k, i)).toFixed(2))} ${sizes[i]}`;\n}\n\nexport function formatModelName(modelId: string): string {\n return modelId\n .replace(/^.*\\//, \"\")\n .replace(/[-_]/g, \" \")\n .replace(/\\b\\w/g, (c) => c.toUpperCase());\n}\n\nexport function truncate(str: string, maxLength: number): string {\n if (str.length <= maxLength) return str;\n return str.slice(0, maxLength - 3) + \"...\";\n}\n\nexport function promptSeparator(): void {\n console.log(chalk.dim(\"\u2500\".repeat(process.stdout.columns || 80)));\n}\n\nexport function success(message: string): void {\n console.log(chalk.green(\"\u2713\") + \" \" + message);\n}\n\nexport function error(message: string): void {\n console.error(chalk.red(\"\u2717\") + \" \" + message);\n}\n\nexport function info(message: string): void {\n console.log(chalk.blue(\"\u2139\") + \" \" + message);\n}\n\nexport function warn(message: string): void {\n console.log(chalk.yellow(\"\u26A0\") + \" \" + message);\n}\n\nexport function exitWithError(message: string, code: number = 1): never {\n error(message);\n process.exit(code);\n}\n", "import ora from 'ora';\nimport chalk from 'chalk';\nimport { lmStudioService } from '../services/lmstudio.js';\nimport { claudeService } from '../services/claude.js';\nimport { configService } from '../services/config.js';\nimport { selectModel, confirmAction } from '../utils/prompt.js';\nimport { exitWithError, success } from '../utils/format.js';\n\ninterface RunOptions {\n model?: string;\n verbose?: boolean;\n args?: string[];\n}\n\nexport async function runCommand(options: RunOptions = {}): Promise<void> {\n const spinner = ora({\n text: 'Checking LM Studio status...',\n color: 'cyan',\n }).start();\n\n let isRunning = await lmStudioService.checkStatus();\n\n if (!isRunning) {\n spinner.info('LM Studio server not running');\n spinner.stop();\n\n const shouldStart = await confirmAction('Would you like to start the LM Studio server?');\n\n if (!shouldStart) {\n exitWithError(\n 'LM Studio server must be running. Start it manually or use the Server tab in LM Studio.'\n );\n }\n\n await lmStudioService.startServer();\n isRunning = true;\n }\n\n spinner.succeed('Connected to LM Studio');\n\n spinner.text = 'Fetching available models...';\n const models = await lmStudioService.getAvailableModels();\n\n if (models.length === 0) {\n spinner.fail('No models found. Download some models in LM Studio first.');\n exitWithError('No models available');\n }\n\n spinner.stop();\n\n let selectedModelId: string;\n\n if (options.model) {\n const foundModel = models.find(\n (m) => m.id === options.model || m.name.toLowerCase().includes(options.model!.toLowerCase())\n );\n\n if (!foundModel) {\n exitWithError(\n `Model \"${options.model}\" not found. Available models: ${models.map((m) => m.name).join(', ')}`\n );\n }\n\n selectedModelId = foundModel.id;\n } else {\n const lastUsedModel = configService.getLastUsedModel();\n const selectedModel = await selectModel(models, lastUsedModel);\n selectedModelId = selectedModel.id;\n }\n\n const loadSpinner = ora({\n text: `Loading model: ${chalk.cyan(selectedModelId)}`,\n color: 'cyan',\n }).start();\n\n await lmStudioService.loadModel(selectedModelId, loadSpinner);\n\n const modelIdentifier = selectedModelId.replace('/', '--');\n const fullModelName = `lmstudio/${modelIdentifier}`;\n\n success(chalk.green(`\\nStarting Claude Code with model: ${fullModelName}\\n`));\n\n try {\n await claudeService.run({\n model: fullModelName,\n args: options.args ?? [],\n verbose: options.verbose,\n });\n } catch (error) {\n exitWithError(\n `Failed to run Claude Code: ${error instanceof Error ? error.message : 'Unknown error'}`\n );\n }\n}\n", "import chalk from \"chalk\";\nimport { lmStudioService } from \"../services/lmstudio.js\";\nimport { formatBytes } from \"../utils/format.js\";\n\nexport async function statusCommand(): Promise<void> {\n const status = await lmStudioService.getStatus();\n\n console.log();\n console.log(chalk.bold(\"LM Studio Status\"));\n console.log(chalk.dim(\"\u2500\".repeat(50)));\n console.log(\n ` ${status.running ? chalk.green(\"\u25CF\") : chalk.red(\"\u25CB\")} Server: ${status.running ? chalk.green(\"Running\") : chalk.red(\"Stopped\")}`,\n );\n console.log(` ${chalk.dim(\"\u25B8\")} Port: ${chalk.cyan(String(status.port))}`);\n console.log(\n ` ${chalk.dim(\"\u25B8\")} URL: ${chalk.cyan(`http://localhost:${status.port}`)}`,\n );\n\n if (status.activeModel) {\n console.log(\n ` ${chalk.dim(\"\u25B8\")} Active Model: ${chalk.green(status.activeModel)}`,\n );\n } else {\n console.log(` ${chalk.dim(\"\u25B8\")} Active Model: ${chalk.dim(\"None\")}`);\n }\n\n console.log();\n console.log(chalk.bold(\"Models\"));\n console.log(chalk.dim(\"\u2500\".repeat(50)));\n\n if (status.models.length === 0) {\n console.log(` ${chalk.dim(\"No models available\")}`);\n } else {\n status.models.forEach((model, index) => {\n const size = formatBytes(model.size);\n const loaded =\n model.id === status.activeModel ? ` ${chalk.green(\"[LOADED]\")}` : \"\";\n console.log(\n ` ${chalk.dim(String(index + 1) + \".\")} ${model.name}${loaded}`,\n );\n console.log(` ${chalk.dim(\"ID:\")} ${model.id}`);\n console.log(` ${chalk.dim(\"Size:\")} ${size}`);\n if (model.quantization) {\n console.log(` ${chalk.dim(\"Quantization:\")} ${model.quantization}`);\n }\n console.log();\n });\n }\n}\n"],
5
- "mappings": "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",
6
- "names": ["config_exports", "__export", "ConfigService", "configService", "Conf", "init_config", "__esmMin", "key", "value", "model", "host", "port", "lmstudio_exports", "__export", "LMStudioService", "lmStudioService", "execa", "ora", "chalk", "LMSTUDIO_PORTS", "init_lmstudio", "__esmMin", "init_config", "configService", "path", "endpoints", "endpoint", "response", "data", "models", "m", "model", "id", "name", "modelId", "spinner", "loadSpinner", "error", "startSpinner", "isMac", "isLinux", "isWindows", "lmStudioPath", "possiblePaths", "p", "existsSync", "localAppData", "programFiles", "timeout", "startTime", "ms", "resolve", "port", "claude_exports", "__export", "ClaudeService", "claudeService", "execa", "chalk", "init_claude", "__esmMin", "options", "model", "args", "verbose", "provider", "modelName", "modelArg", "claudeArgs", "error", "exitCode", "parts", "Command", "chalk", "init_lmstudio", "init_config", "ora", "chalk", "inquirer", "selectModel", "models", "defaultModel", "choices", "model", "defaultIndex", "m", "confirmAction", "message", "defaultValue", "chalk", "formatBytes", "bytes", "k", "sizes", "i", "success", "message", "chalk", "error", "exitWithError", "message", "code", "error", "initCommand", "options", "spinner", "ora", "isRunning", "lmStudioService", "confirmAction", "exitWithError", "modelsSpinner", "models", "chalk", "model", "index", "size", "formatBytes", "loaded", "lastUsedModel", "configService", "modelSearch", "selectedModel", "m", "selectModel", "modelIdentifier", "success", "init_lmstudio", "init_claude", "init_config", "ora", "chalk", "runCommand", "options", "spinner", "ora", "isRunning", "lmStudioService", "confirmAction", "exitWithError", "models", "selectedModelId", "foundModel", "m", "lastUsedModel", "configService", "selectModel", "loadSpinner", "chalk", "fullModelName", "success", "claudeService", "error", "init_lmstudio", "chalk", "statusCommand", "status", "lmStudioService", "chalk", "model", "index", "size", "formatBytes", "loaded", "program", "Command", "initCommand", "args", "options", "runCommand", "statusCommand", "lmStudioService", "claudeService", "configService", "chalk", "lmStudioRunning", "claudeInstalled"]
4
+ "sourcesContent": ["import Conf from 'conf';\nimport type { Config } from '../types/index.js';\n\nexport class ConfigService {\n private store: Conf<Config>;\n\n constructor() {\n this.store = new Conf<Config>({\n projectName: 'aix',\n defaults: {\n lmStudioUrl: 'http://localhost',\n lmStudioPort: 1234,\n defaultTimeout: 30000,\n autoStartServer: false,\n },\n clearInvalidConfig: true,\n });\n }\n\n get<K extends keyof Config>(key: K): Config[K] {\n return this.store.get(key) as Config[K];\n }\n\n set<K extends keyof Config>(key: K, value: Config[K]): void {\n this.store.set(key, value as Config[K]);\n }\n\n setModel(model: string): void {\n this.store.set('model', model);\n }\n\n getLastUsedModel(): string | undefined {\n return this.store.get('model');\n }\n\n getLMStudioUrl(): string {\n const host = this.store.get('lmStudioUrl');\n const port = this.store.get('lmStudioPort');\n return `${host}:${port}`;\n }\n\n reset(): void {\n this.store.clear();\n }\n}\n\nexport const configService = new ConfigService();\n", "import { execa } from 'execa';\nimport ora, { type Ora } from 'ora';\nimport chalk from 'chalk';\nimport { configService } from './config.js';\nimport type { LMStudioStatus, LMStudioModel } from '../types/index.js';\n\nconst LMSTUDIO_PORTS = [1234, 1235, 1236, 1237];\n\nexport class LMStudioService {\n private baseUrl: string;\n\n constructor() {\n this.baseUrl = configService.getLMStudioUrl();\n }\n\n private getApiUrl(path: string): string {\n return `${this.baseUrl}${path}`;\n }\n\n async checkStatus(): Promise<boolean> {\n try {\n const response = await fetch(this.getApiUrl('/api/status'), {\n method: 'GET',\n signal: AbortSignal.timeout(3000),\n });\n return response.ok;\n } catch {\n return false;\n }\n }\n\n async getAvailableModels(): Promise<LMStudioModel[]> {\n const endpoints = ['/api/v1/models', '/api/models', '/v1/models', '/api/ls-model/list'];\n\n for (const endpoint of endpoints) {\n try {\n const response = await fetch(this.getApiUrl(endpoint), {\n method: 'GET',\n signal: AbortSignal.timeout(10000),\n });\n\n if (!response.ok) continue;\n\n const json = (await response.json()) as Record<string, unknown>;\n\n let models: unknown[] = [];\n\n // Try different response formats\n if (Array.isArray(json)) {\n models = json;\n } else if (json.models && Array.isArray(json.models)) {\n models = json.models;\n } else if (json.data && Array.isArray(json.data)) {\n models = json.data;\n }\n\n return (models as Record<string, unknown>[])\n .map((m) => {\n const model = m as Record<string, unknown>;\n return {\n id: String(model.key || model.id || model.model || ''),\n name: String(model.display_name || model.name || model.id || model.model || ''),\n size: Number(model.size_bytes || model.size || model.file_size || 0),\n quantization: String(\n model.quantization\n ? typeof model.quantization === 'object'\n ? (model.quantization as Record<string, unknown>).name\n : model.quantization\n : ''\n ),\n };\n })\n .filter((m) => m.id && m.name);\n } catch {\n continue;\n }\n }\n\n return [];\n }\n\n async getStatus(): Promise<LMStudioStatus> {\n const running = await this.checkStatus();\n\n if (!running) {\n return {\n running: false,\n port: configService.get('lmStudioPort'),\n models: [],\n };\n }\n\n try {\n const response = await fetch(this.getApiUrl('/api/status'), {\n method: 'GET',\n signal: AbortSignal.timeout(10000),\n });\n\n if (!response.ok) {\n return {\n running: false,\n port: configService.get('lmStudioPort'),\n models: [],\n };\n }\n\n const data = (await response.json()) as {\n models: LMStudioModel[];\n active_model?: string;\n };\n\n return {\n running: true,\n port: configService.get('lmStudioPort'),\n models: data.models ?? [],\n activeModel: data.active_model,\n };\n } catch {\n return {\n running: false,\n port: configService.get('lmStudioPort'),\n models: [],\n };\n }\n }\n\n async loadModel(modelId: string, spinner?: Ora): Promise<{ loadSpinner: Ora }> {\n const loadSpinner =\n spinner ??\n ora({\n text: `Loading model: ${chalk.cyan(modelId)}`,\n color: 'cyan',\n }).start();\n\n try {\n const response = await fetch(this.getApiUrl('/api/model/load'), {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify({ model: modelId }),\n signal: AbortSignal.timeout(300000),\n });\n\n if (!response.ok) {\n throw new Error(`Failed to load model: ${response.statusText}`);\n }\n\n loadSpinner.succeed(`Model ${chalk.green(modelId)} loaded successfully`);\n configService.setModel(modelId);\n\n return { loadSpinner };\n } catch (error) {\n loadSpinner.fail(\n `Failed to load model: ${error instanceof Error ? error.message : 'Unknown error'}`\n );\n throw error;\n }\n }\n\n async startServer(spinner?: Ora): Promise<void> {\n const startSpinner =\n spinner ??\n ora({\n text: 'Starting LM Studio server...',\n color: 'cyan',\n }).start();\n\n try {\n const isMac = process.platform === 'darwin';\n const isLinux = process.platform === 'linux';\n const isWindows = process.platform === 'win32';\n\n let lmStudioPath: string | undefined;\n\n if (isMac) {\n const possiblePaths = [\n '/Applications/LM Studio.app',\n `${process.env.HOME}/Applications/LM Studio.app`,\n ];\n for (const p of possiblePaths) {\n try {\n const { existsSync } = await import('fs');\n if (existsSync(p)) {\n lmStudioPath = `open \"${p}\" --args --server`;\n break;\n }\n } catch {\n // continue\n }\n }\n // Use open command for macOS apps\n if (lmStudioPath?.startsWith('open')) {\n await execa(\n 'open',\n [\n possiblePaths.find((p) => {\n try {\n const { existsSync } = require('fs');\n return existsSync(p);\n } catch {\n return false;\n }\n }) || '/Applications/LM Studio.app',\n '--args',\n '--server',\n ],\n {\n detached: true,\n stdio: 'ignore',\n }\n );\n startSpinner.succeed('LM Studio server started');\n await this.waitForServer(60000);\n return;\n }\n } else if (isLinux) {\n lmStudioPath = await this.findLinuxBinary();\n } else if (isWindows) {\n lmStudioPath = await this.findWindowsExecutable();\n }\n\n if (!lmStudioPath) {\n startSpinner.fail('LM Studio not found. Please install it from https://lmstudio.ai');\n throw new Error('LM Studio not installed');\n }\n\n await execa(lmStudioPath, ['--server'], {\n detached: true,\n stdio: 'ignore',\n env: {\n ...process.env,\n LM_STUDIO_SERVER_PORT: String(configService.get('lmStudioPort')),\n },\n });\n\n startSpinner.succeed('LM Studio server started');\n\n await this.waitForServer(60000);\n } catch (error) {\n startSpinner.fail(\n `Failed to start LM Studio: ${error instanceof Error ? error.message : 'Unknown error'}`\n );\n throw error;\n }\n }\n\n private async findLinuxBinary(): Promise<string | undefined> {\n const possiblePaths = [\n '/usr/bin/lm-studio',\n '/usr/local/bin/lm-studio',\n `${process.env.HOME}/.local/bin/lm-studio`,\n ];\n\n for (const path of possiblePaths) {\n try {\n await execa('test', ['-x', path]);\n return path;\n } catch {\n continue;\n }\n }\n\n return undefined;\n }\n\n private async findWindowsExecutable(): Promise<string | undefined> {\n const localAppData = process.env.LOCALAPPDATA;\n const programFiles = process.env.PROGRAMFILES;\n\n const possiblePaths = [\n localAppData ? `${localAppData}\\\\Programs\\\\LM Studio\\\\lm-studio.exe` : '',\n programFiles ? `${programFiles}\\\\LM Studio\\\\lm-studio.exe` : '',\n ].filter(Boolean);\n\n for (const path of possiblePaths) {\n try {\n await execa('cmd', ['/c', 'if exist', `\"${path}\"`, 'echo', 'yes']);\n return path;\n } catch {\n continue;\n }\n }\n\n return undefined;\n }\n\n async waitForServer(timeout: number = 60000): Promise<boolean> {\n const startTime = Date.now();\n\n while (Date.now() - startTime < timeout) {\n if (await this.checkStatus()) {\n return true;\n }\n await this.sleep(2000);\n }\n\n return false;\n }\n\n private sleep(ms: number): Promise<void> {\n return new Promise((resolve) => setTimeout(resolve, ms));\n }\n\n async findAvailablePort(): Promise<number> {\n for (const port of LMSTUDIO_PORTS) {\n try {\n const response = await fetch(`http://localhost:${port}/api/status`, {\n method: 'GET',\n signal: AbortSignal.timeout(1000),\n });\n if (response.ok) {\n return port;\n }\n } catch {\n configService.set('lmStudioPort', port);\n return port;\n }\n }\n\n return LMSTUDIO_PORTS[0] ?? 1234;\n }\n}\n\nexport const lmStudioService = new LMStudioService();\n", "import { execa } from 'execa';\nimport chalk from 'chalk';\n\nexport interface ClaudeOptions {\n model: string;\n args?: string[];\n verbose?: boolean;\n}\n\nexport class ClaudeService {\n async isClaudeCodeInstalled(): Promise<boolean> {\n try {\n await execa('claude', ['--version'], { stdio: 'ignore' });\n return true;\n } catch {\n return false;\n }\n }\n\n async run(options: ClaudeOptions): Promise<void> {\n const { model, args = [], verbose = false } = options;\n\n const provider = this.extractProvider(model);\n const modelName = this.extractModelName(model);\n\n if (!provider || !modelName) {\n throw new Error(`Invalid model format: ${model}. Expected format: provider/model-name`);\n }\n\n const modelArg = `${provider}/${modelName}`;\n const claudeArgs = ['--model', modelArg, ...args];\n\n if (verbose) {\n console.log(chalk.dim(`\\nRunning: claude ${claudeArgs.join(' ')}\\n`));\n }\n\n try {\n await execa('claude', claudeArgs, {\n stdio: 'inherit',\n env: {\n ...process.env,\n ANTHROPIC_MODEL: modelArg,\n },\n });\n } catch (error) {\n if (error instanceof Error && 'exitCode' in error) {\n const exitCode = (error as unknown as { exitCode: number }).exitCode;\n process.exit(exitCode ?? 1);\n }\n throw error;\n }\n }\n\n private extractProvider(model: string): string | undefined {\n const parts = model.split('/');\n return parts[0];\n }\n\n private extractModelName(model: string): string | undefined {\n const parts = model.split('/');\n if (parts.length < 2) return undefined;\n return parts.slice(1).join('/');\n }\n\n async getVersion(): Promise<string | undefined> {\n try {\n const result = await execa('claude', ['--version']);\n return result.stdout;\n } catch {\n return undefined;\n }\n }\n}\n\nexport const claudeService = new ClaudeService();\n", "#!/usr/bin/env node\n\nimport { Command } from 'commander';\nimport chalk from 'chalk';\nimport { initCommand, runCommand, statusCommand } from './commands/index.js';\n\nconst program = new Command();\n\nprogram\n .name('aix')\n .description('AI CLI tool integrating LM Studio with Claude Code')\n .version('1.0.0');\n\nprogram\n .command('init')\n .description('Initialize and load a model into LM Studio')\n .option('-m, --model <name>', 'Model name or ID to load')\n .action(initCommand);\n\nprogram\n .command('run')\n .description('Run Claude Code with a model from LM Studio')\n .option('-m, --model <name>', 'Model name or ID to use')\n .option('-v, --verbose', 'Show verbose output')\n .argument('[args...]', 'Additional arguments for Claude Code')\n .action(async (args: string[], options: Record<string, unknown>) => {\n await runCommand({\n ...options,\n args,\n });\n });\n\nprogram\n .command('status')\n .description('Show LM Studio status and available models')\n .action(statusCommand);\n\nprogram\n .command('doctor')\n .description('Check system requirements and configuration')\n .action(async () => {\n const { lmStudioService } = await import('./services/lmstudio.js');\n const { claudeService } = await import('./services/claude.js');\n const { configService } = await import('./services/config.js');\n\n console.log();\n console.log(chalk.bold('System Check'));\n console.log(chalk.dim('\u2500'.repeat(50)));\n\n const lmStudioRunning = await lmStudioService.checkStatus();\n console.log(\n ` ${lmStudioRunning ? chalk.green('\u2713') : chalk.yellow('\u26A0')} LM Studio: ${lmStudioRunning ? chalk.green('Running') : chalk.yellow('Not running')}`\n );\n\n const claudeInstalled = await claudeService.isClaudeCodeInstalled();\n console.log(\n ` ${claudeInstalled ? chalk.green('\u2713') : chalk.red('\u2717')} Claude Code: ${claudeInstalled ? chalk.green('Installed') : chalk.red('Not installed')}`\n );\n\n console.log();\n console.log(chalk.bold('Configuration'));\n console.log(chalk.dim('\u2500'.repeat(50)));\n console.log(` ${chalk.dim('\u25B8')} LM Studio URL: ${chalk.cyan(configService.getLMStudioUrl())}`);\n\n if (!claudeInstalled) {\n console.log();\n console.log(chalk.yellow('\u26A0 Claude Code is not installed.'));\n console.log(` Install it with: ${chalk.cyan('npm install -g @anthropic-ai/claude-code')}`);\n }\n\n if (!lmStudioRunning) {\n console.log();\n console.log(chalk.yellow('\u26A0 LM Studio is not running.'));\n console.log(\n ` Start the server from the LM Studio app or download from ${chalk.cyan('https://lmstudio.ai')}`\n );\n }\n });\n\nprogram.parse();\n", "import ora from 'ora';\nimport chalk from 'chalk';\nimport { lmStudioService } from '../services/lmstudio.js';\nimport { configService } from '../services/config.js';\nimport { selectModel, confirmAction } from '../utils/prompt.js';\nimport { formatBytes, success, exitWithError } from '../utils/format.js';\nimport type { InitOptions } from '../types/index.js';\n\nexport async function initCommand(options: InitOptions = {}): Promise<void> {\n const spinner = ora({\n text: 'Checking LM Studio status...',\n color: 'cyan',\n }).start();\n\n let isRunning = await lmStudioService.checkStatus();\n\n if (!isRunning) {\n spinner.info('LM Studio server not running');\n spinner.stop();\n\n const shouldStart = await confirmAction('Would you like to start the LM Studio server?');\n\n if (!shouldStart) {\n exitWithError(\n 'LM Studio server must be running. Start it manually or use the Server tab in LM Studio.'\n );\n }\n\n await lmStudioService.startServer();\n isRunning = true;\n }\n\n spinner.succeed('Connected to LM Studio');\n\n const modelsSpinner = ora({\n text: 'Fetching available models...',\n color: 'cyan',\n }).start();\n\n const models = await lmStudioService.getAvailableModels();\n\n if (models.length === 0) {\n modelsSpinner.fail('No models found. Download some models in LM Studio first.');\n exitWithError('No models available');\n }\n\n modelsSpinner.succeed(\n `Found ${chalk.bold(models.length)} model${models.length === 1 ? '' : 's'}`\n );\n\n console.log();\n console.log(chalk.bold('Available Models:'));\n console.log(chalk.dim('\u2500'.repeat(process.stdout.columns || 80)));\n\n models.forEach((model, index) => {\n const size = formatBytes(model.size);\n const loaded = model.loaded ? chalk.green(' [LOADED]') : '';\n console.log(\n ` ${chalk.dim(String(index + 1).padStart(2))}. ${model.name} ${chalk.dim(`(${size})`)}${loaded}`\n );\n });\n console.log();\n\n const lastUsedModel = configService.getLastUsedModel();\n const modelSearch = options.model;\n const selectedModel = modelSearch\n ? models.find((m) => m.id === modelSearch || m.name.includes(modelSearch))\n : await selectModel(models, lastUsedModel);\n\n if (!selectedModel) {\n exitWithError('No model selected');\n }\n\n await lmStudioService.loadModel(selectedModel.id, spinner);\n\n const modelIdentifier = selectedModel.id.replace('/', '--');\n\n success(chalk.bold(`\\nModel ready: ${selectedModel.name}`));\n console.log();\n console.log(`Run Claude Code with this model:`);\n console.log(` ${chalk.cyan('claude --model lmstudio/' + modelIdentifier)}`);\n console.log();\n console.log(`Or use ${chalk.cyan('aix-cli run')} to start an interactive session`);\n}\n", "import inquirer from 'inquirer';\nimport type { LMStudioModel } from '../types/index.js';\n\nexport async function selectModel(\n models: LMStudioModel[],\n defaultModel?: string\n): Promise<LMStudioModel> {\n const choices = models.map((model) => ({\n name: `${model.name} (${model.id})`,\n value: model,\n short: model.name,\n }));\n\n const defaultIndex = defaultModel ? choices.findIndex((m) => m.value.id === defaultModel) : 0;\n\n const answers = await inquirer.prompt([\n {\n type: 'list',\n name: 'model',\n message: 'Select a model to load:',\n choices,\n default: Math.max(0, defaultIndex),\n pageSize: Math.min(models.length, 15),\n },\n ]);\n\n return answers['model'] as LMStudioModel;\n}\n\nexport async function confirmAction(\n message: string,\n defaultValue: boolean = true\n): Promise<boolean> {\n const answers = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'confirm',\n message,\n default: defaultValue,\n },\n ]);\n\n return answers['confirm'] as boolean;\n}\n\nexport async function enterPrompt(message: string, defaultValue?: string): Promise<string> {\n const answers = await inquirer.prompt([\n {\n type: 'input',\n name: 'value',\n message,\n default: defaultValue,\n validate: (input: string) => input.trim().length > 0 || 'Please enter a value',\n },\n ]);\n\n return answers['value'] as string;\n}\n", "import chalk from \"chalk\";\n\nexport function formatBytes(bytes: number): string {\n if (bytes === 0) return \"0 B\";\n\n const k = 1024;\n const sizes = [\"B\", \"KB\", \"MB\", \"GB\", \"TB\"];\n const i = Math.floor(Math.log(bytes) / Math.log(k));\n\n return `${parseFloat((bytes / Math.pow(k, i)).toFixed(2))} ${sizes[i]}`;\n}\n\nexport function formatModelName(modelId: string): string {\n return modelId\n .replace(/^.*\\//, \"\")\n .replace(/[-_]/g, \" \")\n .replace(/\\b\\w/g, (c) => c.toUpperCase());\n}\n\nexport function truncate(str: string, maxLength: number): string {\n if (str.length <= maxLength) return str;\n return str.slice(0, maxLength - 3) + \"...\";\n}\n\nexport function promptSeparator(): void {\n console.log(chalk.dim(\"\u2500\".repeat(process.stdout.columns || 80)));\n}\n\nexport function success(message: string): void {\n console.log(chalk.green(\"\u2713\") + \" \" + message);\n}\n\nexport function error(message: string): void {\n console.error(chalk.red(\"\u2717\") + \" \" + message);\n}\n\nexport function info(message: string): void {\n console.log(chalk.blue(\"\u2139\") + \" \" + message);\n}\n\nexport function warn(message: string): void {\n console.log(chalk.yellow(\"\u26A0\") + \" \" + message);\n}\n\nexport function exitWithError(message: string, code: number = 1): never {\n error(message);\n process.exit(code);\n}\n", "import ora from 'ora';\nimport chalk from 'chalk';\nimport { lmStudioService } from '../services/lmstudio.js';\nimport { claudeService } from '../services/claude.js';\nimport { configService } from '../services/config.js';\nimport { selectModel, confirmAction } from '../utils/prompt.js';\nimport { exitWithError, success } from '../utils/format.js';\n\ninterface RunOptions {\n model?: string;\n verbose?: boolean;\n args?: string[];\n}\n\nexport async function runCommand(options: RunOptions = {}): Promise<void> {\n const spinner = ora({\n text: 'Checking LM Studio status...',\n color: 'cyan',\n }).start();\n\n let isRunning = await lmStudioService.checkStatus();\n\n if (!isRunning) {\n spinner.info('LM Studio server not running');\n spinner.stop();\n\n const shouldStart = await confirmAction('Would you like to start the LM Studio server?');\n\n if (!shouldStart) {\n exitWithError(\n 'LM Studio server must be running. Start it manually or use the Server tab in LM Studio.'\n );\n }\n\n await lmStudioService.startServer();\n isRunning = true;\n }\n\n spinner.succeed('Connected to LM Studio');\n\n spinner.text = 'Fetching available models...';\n const models = await lmStudioService.getAvailableModels();\n\n if (models.length === 0) {\n spinner.fail('No models found. Download some models in LM Studio first.');\n exitWithError('No models available');\n }\n\n spinner.stop();\n\n let selectedModelId: string;\n\n if (options.model) {\n const foundModel = models.find(\n (m) => m.id === options.model || m.name.toLowerCase().includes(options.model!.toLowerCase())\n );\n\n if (!foundModel) {\n exitWithError(\n `Model \"${options.model}\" not found. Available models: ${models.map((m) => m.name).join(', ')}`\n );\n }\n\n selectedModelId = foundModel.id;\n } else {\n const lastUsedModel = configService.getLastUsedModel();\n const selectedModel = await selectModel(models, lastUsedModel);\n selectedModelId = selectedModel.id;\n }\n\n const loadSpinner = ora({\n text: `Loading model: ${chalk.cyan(selectedModelId)}`,\n color: 'cyan',\n }).start();\n\n await lmStudioService.loadModel(selectedModelId, loadSpinner);\n\n const modelIdentifier = selectedModelId.replace('/', '--');\n const fullModelName = `lmstudio/${modelIdentifier}`;\n\n success(chalk.green(`\\nStarting Claude Code with model: ${fullModelName}\\n`));\n\n try {\n await claudeService.run({\n model: fullModelName,\n args: options.args ?? [],\n verbose: options.verbose,\n });\n } catch (error) {\n exitWithError(\n `Failed to run Claude Code: ${error instanceof Error ? error.message : 'Unknown error'}`\n );\n }\n}\n", "import chalk from \"chalk\";\nimport { lmStudioService } from \"../services/lmstudio.js\";\nimport { formatBytes } from \"../utils/format.js\";\n\nexport async function statusCommand(): Promise<void> {\n const status = await lmStudioService.getStatus();\n\n console.log();\n console.log(chalk.bold(\"LM Studio Status\"));\n console.log(chalk.dim(\"\u2500\".repeat(50)));\n console.log(\n ` ${status.running ? chalk.green(\"\u25CF\") : chalk.red(\"\u25CB\")} Server: ${status.running ? chalk.green(\"Running\") : chalk.red(\"Stopped\")}`,\n );\n console.log(` ${chalk.dim(\"\u25B8\")} Port: ${chalk.cyan(String(status.port))}`);\n console.log(\n ` ${chalk.dim(\"\u25B8\")} URL: ${chalk.cyan(`http://localhost:${status.port}`)}`,\n );\n\n if (status.activeModel) {\n console.log(\n ` ${chalk.dim(\"\u25B8\")} Active Model: ${chalk.green(status.activeModel)}`,\n );\n } else {\n console.log(` ${chalk.dim(\"\u25B8\")} Active Model: ${chalk.dim(\"None\")}`);\n }\n\n console.log();\n console.log(chalk.bold(\"Models\"));\n console.log(chalk.dim(\"\u2500\".repeat(50)));\n\n if (status.models.length === 0) {\n console.log(` ${chalk.dim(\"No models available\")}`);\n } else {\n status.models.forEach((model, index) => {\n const size = formatBytes(model.size);\n const loaded =\n model.id === status.activeModel ? ` ${chalk.green(\"[LOADED]\")}` : \"\";\n console.log(\n ` ${chalk.dim(String(index + 1) + \".\")} ${model.name}${loaded}`,\n );\n console.log(` ${chalk.dim(\"ID:\")} ${model.id}`);\n console.log(` ${chalk.dim(\"Size:\")} ${size}`);\n if (model.quantization) {\n console.log(` ${chalk.dim(\"Quantization:\")} ${model.quantization}`);\n }\n console.log();\n });\n }\n}\n"],
5
+ "mappings": "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",
6
+ "names": ["config_exports", "__export", "ConfigService", "configService", "Conf", "init_config", "__esmMin", "key", "value", "model", "host", "port", "lmstudio_exports", "__export", "LMStudioService", "lmStudioService", "execa", "ora", "chalk", "LMSTUDIO_PORTS", "init_lmstudio", "__esmMin", "init_config", "configService", "path", "endpoints", "endpoint", "response", "json", "models", "m", "model", "data", "modelId", "spinner", "loadSpinner", "error", "startSpinner", "isMac", "isLinux", "isWindows", "lmStudioPath", "possiblePaths", "p", "existsSync", "localAppData", "programFiles", "timeout", "startTime", "ms", "resolve", "port", "claude_exports", "__export", "ClaudeService", "claudeService", "execa", "chalk", "init_claude", "__esmMin", "options", "model", "args", "verbose", "provider", "modelName", "modelArg", "claudeArgs", "error", "exitCode", "parts", "Command", "chalk", "init_lmstudio", "init_config", "ora", "chalk", "inquirer", "selectModel", "models", "defaultModel", "choices", "model", "defaultIndex", "m", "confirmAction", "message", "defaultValue", "chalk", "formatBytes", "bytes", "k", "sizes", "i", "success", "message", "chalk", "error", "exitWithError", "message", "code", "error", "initCommand", "options", "spinner", "ora", "isRunning", "lmStudioService", "confirmAction", "exitWithError", "modelsSpinner", "models", "chalk", "model", "index", "size", "formatBytes", "loaded", "lastUsedModel", "configService", "modelSearch", "selectedModel", "m", "selectModel", "modelIdentifier", "success", "init_lmstudio", "init_claude", "init_config", "ora", "chalk", "runCommand", "options", "spinner", "ora", "isRunning", "lmStudioService", "confirmAction", "exitWithError", "models", "selectedModelId", "foundModel", "m", "lastUsedModel", "configService", "selectModel", "loadSpinner", "chalk", "fullModelName", "success", "claudeService", "error", "init_lmstudio", "chalk", "statusCommand", "status", "lmStudioService", "chalk", "model", "index", "size", "formatBytes", "loaded", "program", "Command", "initCommand", "args", "options", "runCommand", "statusCommand", "lmStudioService", "claudeService", "configService", "chalk", "lmStudioRunning", "claudeInstalled"]
7
7
  }
@@ -1 +1 @@
1
- {"version":3,"file":"lmstudio.d.ts","sourceRoot":"","sources":["../../src/services/lmstudio.ts"],"names":[],"mappings":"AACA,OAAY,EAAE,KAAK,GAAG,EAAE,MAAM,KAAK,CAAC;AAGpC,OAAO,KAAK,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAIvE,qBAAa,eAAe;IAC1B,OAAO,CAAC,OAAO,CAAS;;IAMxB,OAAO,CAAC,SAAS;IAIX,WAAW,IAAI,OAAO,CAAC,OAAO,CAAC;IAY/B,kBAAkB,IAAI,OAAO,CAAC,aAAa,EAAE,CAAC;IAsD9C,SAAS,IAAI,OAAO,CAAC,cAAc,CAAC;IA6CpC,SAAS,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,OAAO,CAAC;QAAE,WAAW,EAAE,GAAG,CAAA;KAAE,CAAC;IAkCxE,WAAW,CAAC,OAAO,CAAC,EAAE,GAAG,GAAG,OAAO,CAAC,IAAI,CAAC;YAuFjC,eAAe;YAmBf,qBAAqB;IAqB7B,aAAa,CAAC,OAAO,GAAE,MAAc,GAAG,OAAO,CAAC,OAAO,CAAC;IAa9D,OAAO,CAAC,KAAK;IAIP,iBAAiB,IAAI,OAAO,CAAC,MAAM,CAAC;CAkB3C;AAED,eAAO,MAAM,eAAe,iBAAwB,CAAC"}
1
+ {"version":3,"file":"lmstudio.d.ts","sourceRoot":"","sources":["../../src/services/lmstudio.ts"],"names":[],"mappings":"AACA,OAAY,EAAE,KAAK,GAAG,EAAE,MAAM,KAAK,CAAC;AAGpC,OAAO,KAAK,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAIvE,qBAAa,eAAe;IAC1B,OAAO,CAAC,OAAO,CAAS;;IAMxB,OAAO,CAAC,SAAS;IAIX,WAAW,IAAI,OAAO,CAAC,OAAO,CAAC;IAY/B,kBAAkB,IAAI,OAAO,CAAC,aAAa,EAAE,CAAC;IAkD9C,SAAS,IAAI,OAAO,CAAC,cAAc,CAAC;IA6CpC,SAAS,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,OAAO,CAAC;QAAE,WAAW,EAAE,GAAG,CAAA;KAAE,CAAC;IAkCxE,WAAW,CAAC,OAAO,CAAC,EAAE,GAAG,GAAG,OAAO,CAAC,IAAI,CAAC;YAuFjC,eAAe;YAmBf,qBAAqB;IAqB7B,aAAa,CAAC,OAAO,GAAE,MAAc,GAAG,OAAO,CAAC,OAAO,CAAC;IAa9D,OAAO,CAAC,KAAK;IAIP,iBAAiB,IAAI,OAAO,CAAC,MAAM,CAAC;CAkB3C;AAED,eAAO,MAAM,eAAe,iBAAwB,CAAC"}
package/dist/src/index.js CHANGED
@@ -1,8 +1,8 @@
1
1
  #!/usr/bin/env node
2
- var J=Object.defineProperty;var Q=(t=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(t,{get:(o,e)=>(typeof require<"u"?require:o)[e]}):t)(function(t){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+t+'" is not supported')});var A=(t,o)=>()=>(t&&(o=t(t=0)),o);var k=(t,o)=>{for(var e in o)J(t,e,{get:o[e],enumerable:!0})};var N={};k(N,{ConfigService:()=>w,configService:()=>m});import X from"conf";var w,m,h=A(()=>{"use strict";w=class{store;constructor(){this.store=new X({projectName:"aix",defaults:{lmStudioUrl:"http://localhost",lmStudioPort:1234,defaultTimeout:3e4,autoStartServer:!1},clearInvalidConfig:!0})}get(o){return this.store.get(o)}set(o,e){this.store.set(o,e)}setModel(o){this.store.set("model",o)}getLastUsedModel(){return this.store.get("model")}getLMStudioUrl(){let o=this.store.get("lmStudioUrl"),e=this.store.get("lmStudioPort");return`${o}:${e}`}reset(){this.store.clear()}},m=new w});var _={};k(_,{LMStudioService:()=>y,lmStudioService:()=>g});import{execa as M}from"execa";import D from"ora";import T from"chalk";var F,y,g,v=A(()=>{"use strict";h();F=[1234,1235,1236,1237],y=class{baseUrl;constructor(){this.baseUrl=m.getLMStudioUrl()}getApiUrl(o){return`${this.baseUrl}${o}`}async checkStatus(){try{return(await fetch(this.getApiUrl("/api/status"),{method:"GET",signal:AbortSignal.timeout(3e3)})).ok}catch{return!1}}async getAvailableModels(){let o=["/api/models","/api/v1/models","/api/lsMODEL/list","/api/ls-model/list"];for(let e of o)try{let r=await fetch(this.getApiUrl(e),{method:"GET",signal:AbortSignal.timeout(1e4)});if(!r.ok)continue;let n=await r.json();if(Array.isArray(n)){let d=n.map(i=>{let s=i,c=String(s.id||s.model||s.model_id||""),a=String(s.name||s.id||s.model||"");return{id:String(c),name:String(a),size:Number(s.size||s.file_size||s.size_bytes||0),quantization:String(s.quantization||s.q||"")}}).filter(i=>i.id&&i.name);if(d.length>0)return d}if(n.models&&Array.isArray(n.models))return n.models.map(d=>{let i=d;return{id:String(i.id||i.model||i.model_id||""),name:String(i.name||i.id||i.model||""),size:Number(i.size||i.file_size||0),quantization:String(i.quantization||"")}});if(n.data&&Array.isArray(n.data))return n.data}catch{continue}return[]}async getStatus(){if(!await this.checkStatus())return{running:!1,port:m.get("lmStudioPort"),models:[]};try{let e=await fetch(this.getApiUrl("/api/status"),{method:"GET",signal:AbortSignal.timeout(1e4)});if(!e.ok)return{running:!1,port:m.get("lmStudioPort"),models:[]};let r=await e.json();return{running:!0,port:m.get("lmStudioPort"),models:r.models??[],activeModel:r.active_model}}catch{return{running:!1,port:m.get("lmStudioPort"),models:[]}}}async loadModel(o,e){let r=e??D({text:`Loading model: ${T.cyan(o)}`,color:"cyan"}).start();try{let n=await fetch(this.getApiUrl("/api/model/load"),{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({model:o}),signal:AbortSignal.timeout(3e5)});if(!n.ok)throw new Error(`Failed to load model: ${n.statusText}`);return r.succeed(`Model ${T.green(o)} loaded successfully`),m.setModel(o),{loadSpinner:r}}catch(n){throw r.fail(`Failed to load model: ${n instanceof Error?n.message:"Unknown error"}`),n}}async startServer(o){let e=o??D({text:"Starting LM Studio server...",color:"cyan"}).start();try{let r=process.platform==="darwin",n=process.platform==="linux",d=process.platform==="win32",i;if(r){let s=["/Applications/LM Studio.app",`${process.env.HOME}/Applications/LM Studio.app`];for(let c of s)try{let{existsSync:a}=await import("fs");if(a(c)){i=`open "${c}" --args --server`;break}}catch{}if(i?.startsWith("open")){await M("open",[s.find(c=>{try{let{existsSync:a}=Q("fs");return a(c)}catch{return!1}})||"/Applications/LM Studio.app","--args","--server"],{detached:!0,stdio:"ignore"}),e.succeed("LM Studio server started"),await this.waitForServer(6e4);return}}else n?i=await this.findLinuxBinary():d&&(i=await this.findWindowsExecutable());if(!i)throw e.fail("LM Studio not found. Please install it from https://lmstudio.ai"),new Error("LM Studio not installed");await M(i,["--server"],{detached:!0,stdio:"ignore",env:{...process.env,LM_STUDIO_SERVER_PORT:String(m.get("lmStudioPort"))}}),e.succeed("LM Studio server started"),await this.waitForServer(6e4)}catch(r){throw e.fail(`Failed to start LM Studio: ${r instanceof Error?r.message:"Unknown error"}`),r}}async findLinuxBinary(){let o=["/usr/bin/lm-studio","/usr/local/bin/lm-studio",`${process.env.HOME}/.local/bin/lm-studio`];for(let e of o)try{return await M("test",["-x",e]),e}catch{continue}}async findWindowsExecutable(){let o=process.env.LOCALAPPDATA,e=process.env.PROGRAMFILES,r=[o?`${o}\\Programs\\LM Studio\\lm-studio.exe`:"",e?`${e}\\LM Studio\\lm-studio.exe`:""].filter(Boolean);for(let n of r)try{return await M("cmd",["/c","if exist",`"${n}"`,"echo","yes"]),n}catch{continue}}async waitForServer(o=6e4){let e=Date.now();for(;Date.now()-e<o;){if(await this.checkStatus())return!0;await this.sleep(2e3)}return!1}sleep(o){return new Promise(e=>setTimeout(e,o))}async findAvailablePort(){for(let o of F)try{if((await fetch(`http://localhost:${o}/api/status`,{method:"GET",signal:AbortSignal.timeout(1e3)})).ok)return o}catch{return m.set("lmStudioPort",o),o}return F[0]??1234}},g=new y});var K={};k(K,{ClaudeService:()=>C,claudeService:()=>U});import{execa as O}from"execa";import Z from"chalk";var C,U,R=A(()=>{"use strict";C=class{async isClaudeCodeInstalled(){try{return await O("claude",["--version"],{stdio:"ignore"}),!0}catch{return!1}}async run(o){let{model:e,args:r=[],verbose:n=!1}=o,d=this.extractProvider(e),i=this.extractModelName(e);if(!d||!i)throw new Error(`Invalid model format: ${e}. Expected format: provider/model-name`);let s=`${d}/${i}`,c=["--model",s,...r];n&&console.log(Z.dim(`
2
+ var J=Object.defineProperty;var Q=(t=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(t,{get:(o,e)=>(typeof require<"u"?require:o)[e]}):t)(function(t){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+t+'" is not supported')});var A=(t,o)=>()=>(t&&(o=t(t=0)),o);var k=(t,o)=>{for(var e in o)J(t,e,{get:o[e],enumerable:!0})};var N={};k(N,{ConfigService:()=>w,configService:()=>m});import X from"conf";var w,m,h=A(()=>{"use strict";w=class{store;constructor(){this.store=new X({projectName:"aix",defaults:{lmStudioUrl:"http://localhost",lmStudioPort:1234,defaultTimeout:3e4,autoStartServer:!1},clearInvalidConfig:!0})}get(o){return this.store.get(o)}set(o,e){this.store.set(o,e)}setModel(o){this.store.set("model",o)}getLastUsedModel(){return this.store.get("model")}getLMStudioUrl(){let o=this.store.get("lmStudioUrl"),e=this.store.get("lmStudioPort");return`${o}:${e}`}reset(){this.store.clear()}},m=new w});var j={};k(j,{LMStudioService:()=>y,lmStudioService:()=>g});import{execa as M}from"execa";import T from"ora";import D from"chalk";var F,y,g,v=A(()=>{"use strict";h();F=[1234,1235,1236,1237],y=class{baseUrl;constructor(){this.baseUrl=m.getLMStudioUrl()}getApiUrl(o){return`${this.baseUrl}${o}`}async checkStatus(){try{return(await fetch(this.getApiUrl("/api/status"),{method:"GET",signal:AbortSignal.timeout(3e3)})).ok}catch{return!1}}async getAvailableModels(){let o=["/api/v1/models","/api/models","/v1/models","/api/ls-model/list"];for(let e of o)try{let r=await fetch(this.getApiUrl(e),{method:"GET",signal:AbortSignal.timeout(1e4)});if(!r.ok)continue;let n=await r.json(),l=[];return Array.isArray(n)?l=n:n.models&&Array.isArray(n.models)?l=n.models:n.data&&Array.isArray(n.data)&&(l=n.data),l.map(d=>{let i=d;return{id:String(i.key||i.id||i.model||""),name:String(i.display_name||i.name||i.id||i.model||""),size:Number(i.size_bytes||i.size||i.file_size||0),quantization:String(i.quantization?typeof i.quantization=="object"?i.quantization.name:i.quantization:"")}}).filter(d=>d.id&&d.name)}catch{continue}return[]}async getStatus(){if(!await this.checkStatus())return{running:!1,port:m.get("lmStudioPort"),models:[]};try{let e=await fetch(this.getApiUrl("/api/status"),{method:"GET",signal:AbortSignal.timeout(1e4)});if(!e.ok)return{running:!1,port:m.get("lmStudioPort"),models:[]};let r=await e.json();return{running:!0,port:m.get("lmStudioPort"),models:r.models??[],activeModel:r.active_model}}catch{return{running:!1,port:m.get("lmStudioPort"),models:[]}}}async loadModel(o,e){let r=e??T({text:`Loading model: ${D.cyan(o)}`,color:"cyan"}).start();try{let n=await fetch(this.getApiUrl("/api/model/load"),{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({model:o}),signal:AbortSignal.timeout(3e5)});if(!n.ok)throw new Error(`Failed to load model: ${n.statusText}`);return r.succeed(`Model ${D.green(o)} loaded successfully`),m.setModel(o),{loadSpinner:r}}catch(n){throw r.fail(`Failed to load model: ${n instanceof Error?n.message:"Unknown error"}`),n}}async startServer(o){let e=o??T({text:"Starting LM Studio server...",color:"cyan"}).start();try{let r=process.platform==="darwin",n=process.platform==="linux",l=process.platform==="win32",d;if(r){let i=["/Applications/LM Studio.app",`${process.env.HOME}/Applications/LM Studio.app`];for(let c of i)try{let{existsSync:s}=await import("fs");if(s(c)){d=`open "${c}" --args --server`;break}}catch{}if(d?.startsWith("open")){await M("open",[i.find(c=>{try{let{existsSync:s}=Q("fs");return s(c)}catch{return!1}})||"/Applications/LM Studio.app","--args","--server"],{detached:!0,stdio:"ignore"}),e.succeed("LM Studio server started"),await this.waitForServer(6e4);return}}else n?d=await this.findLinuxBinary():l&&(d=await this.findWindowsExecutable());if(!d)throw e.fail("LM Studio not found. Please install it from https://lmstudio.ai"),new Error("LM Studio not installed");await M(d,["--server"],{detached:!0,stdio:"ignore",env:{...process.env,LM_STUDIO_SERVER_PORT:String(m.get("lmStudioPort"))}}),e.succeed("LM Studio server started"),await this.waitForServer(6e4)}catch(r){throw e.fail(`Failed to start LM Studio: ${r instanceof Error?r.message:"Unknown error"}`),r}}async findLinuxBinary(){let o=["/usr/bin/lm-studio","/usr/local/bin/lm-studio",`${process.env.HOME}/.local/bin/lm-studio`];for(let e of o)try{return await M("test",["-x",e]),e}catch{continue}}async findWindowsExecutable(){let o=process.env.LOCALAPPDATA,e=process.env.PROGRAMFILES,r=[o?`${o}\\Programs\\LM Studio\\lm-studio.exe`:"",e?`${e}\\LM Studio\\lm-studio.exe`:""].filter(Boolean);for(let n of r)try{return await M("cmd",["/c","if exist",`"${n}"`,"echo","yes"]),n}catch{continue}}async waitForServer(o=6e4){let e=Date.now();for(;Date.now()-e<o;){if(await this.checkStatus())return!0;await this.sleep(2e3)}return!1}sleep(o){return new Promise(e=>setTimeout(e,o))}async findAvailablePort(){for(let o of F)try{if((await fetch(`http://localhost:${o}/api/status`,{method:"GET",signal:AbortSignal.timeout(1e3)})).ok)return o}catch{return m.set("lmStudioPort",o),o}return F[0]??1234}},g=new y});var K={};k(K,{ClaudeService:()=>C,claudeService:()=>O});import{execa as U}from"execa";import Z from"chalk";var C,O,R=A(()=>{"use strict";C=class{async isClaudeCodeInstalled(){try{return await U("claude",["--version"],{stdio:"ignore"}),!0}catch{return!1}}async run(o){let{model:e,args:r=[],verbose:n=!1}=o,l=this.extractProvider(e),d=this.extractModelName(e);if(!l||!d)throw new Error(`Invalid model format: ${e}. Expected format: provider/model-name`);let i=`${l}/${d}`,c=["--model",i,...r];n&&console.log(Z.dim(`
3
3
  Running: claude ${c.join(" ")}
4
- `));try{await O("claude",c,{stdio:"inherit",env:{...process.env,ANTHROPIC_MODEL:s}})}catch(a){if(a instanceof Error&&"exitCode"in a){let P=a.exitCode;process.exit(P??1)}throw a}}extractProvider(o){return o.split("/")[0]}extractModelName(o){let e=o.split("/");if(!(e.length<2))return e.slice(1).join("/")}async getVersion(){try{return(await O("claude",["--version"])).stdout}catch{return}}},U=new C});import{Command as oo}from"commander";import u from"chalk";v();h();import q from"ora";import f from"chalk";import B from"inquirer";async function x(t,o){let e=t.map(d=>({name:`${d.name} (${d.id})`,value:d,short:d.name})),r=o?e.findIndex(d=>d.value.id===o):0;return(await B.prompt([{type:"list",name:"model",message:"Select a model to load:",choices:e,default:Math.max(0,r),pageSize:Math.min(t.length,15)}])).model}async function $(t,o=!0){return(await B.prompt([{type:"confirm",name:"confirm",message:t,default:o}])).confirm}import j from"chalk";function b(t){if(t===0)return"0 B";let o=1024,e=["B","KB","MB","GB","TB"],r=Math.floor(Math.log(t)/Math.log(o));return`${parseFloat((t/Math.pow(o,r)).toFixed(2))} ${e[r]}`}function L(t){console.log(j.green("\u2713")+" "+t)}function Y(t){console.error(j.red("\u2717")+" "+t)}function p(t,o=1){Y(t),process.exit(o)}async function E(t={}){let o=q({text:"Checking LM Studio status...",color:"cyan"}).start(),e=await g.checkStatus();e||(o.info("LM Studio server not running"),o.stop(),await $("Would you like to start the LM Studio server?")||p("LM Studio server must be running. Start it manually or use the Server tab in LM Studio."),await g.startServer(),e=!0),o.succeed("Connected to LM Studio");let r=q({text:"Fetching available models...",color:"cyan"}).start(),n=await g.getAvailableModels();n.length===0&&(r.fail("No models found. Download some models in LM Studio first."),p("No models available")),r.succeed(`Found ${f.bold(n.length)} model${n.length===1?"":"s"}`),console.log(),console.log(f.bold("Available Models:")),console.log(f.dim("\u2500".repeat(process.stdout.columns||80))),n.forEach((a,P)=>{let H=b(a.size),V=a.loaded?f.green(" [LOADED]"):"";console.log(` ${f.dim(String(P+1).padStart(2))}. ${a.name} ${f.dim(`(${H})`)}${V}`)}),console.log();let d=m.getLastUsedModel(),i=t.model,s=i?n.find(a=>a.id===i||a.name.includes(i)):await x(n,d);s||p("No model selected"),await g.loadModel(s.id,o);let c=s.id.replace("/","--");L(f.bold(`
5
- Model ready: ${s.name}`)),console.log(),console.log("Run Claude Code with this model:"),console.log(` ${f.cyan("claude --model lmstudio/"+c)}`),console.log(),console.log(`Or use ${f.cyan("npx aix run")} to start an interactive session`)}v();R();h();import W from"ora";import G from"chalk";async function z(t={}){let o=W({text:"Checking LM Studio status...",color:"cyan"}).start(),e=await g.checkStatus();e||(o.info("LM Studio server not running"),o.stop(),await $("Would you like to start the LM Studio server?")||p("LM Studio server must be running. Start it manually or use the Server tab in LM Studio."),await g.startServer(),e=!0),o.succeed("Connected to LM Studio"),o.text="Fetching available models...";let r=await g.getAvailableModels();r.length===0&&(o.fail("No models found. Download some models in LM Studio first."),p("No models available")),o.stop();let n;if(t.model){let c=r.find(a=>a.id===t.model||a.name.toLowerCase().includes(t.model.toLowerCase()));c||p(`Model "${t.model}" not found. Available models: ${r.map(a=>a.name).join(", ")}`),n=c.id}else{let c=m.getLastUsedModel();n=(await x(r,c)).id}let d=W({text:`Loading model: ${G.cyan(n)}`,color:"cyan"}).start();await g.loadModel(n,d);let s=`lmstudio/${n.replace("/","--")}`;L(G.green(`
6
- Starting Claude Code with model: ${s}
7
- `));try{await U.run({model:s,args:t.args??[],verbose:t.verbose})}catch(c){p(`Failed to run Claude Code: ${c instanceof Error?c.message:"Unknown error"}`)}}v();import l from"chalk";async function I(){let t=await g.getStatus();console.log(),console.log(l.bold("LM Studio Status")),console.log(l.dim("\u2500".repeat(50))),console.log(` ${t.running?l.green("\u25CF"):l.red("\u25CB")} Server: ${t.running?l.green("Running"):l.red("Stopped")}`),console.log(` ${l.dim("\u25B8")} Port: ${l.cyan(String(t.port))}`),console.log(` ${l.dim("\u25B8")} URL: ${l.cyan(`http://localhost:${t.port}`)}`),t.activeModel?console.log(` ${l.dim("\u25B8")} Active Model: ${l.green(t.activeModel)}`):console.log(` ${l.dim("\u25B8")} Active Model: ${l.dim("None")}`),console.log(),console.log(l.bold("Models")),console.log(l.dim("\u2500".repeat(50))),t.models.length===0?console.log(` ${l.dim("No models available")}`):t.models.forEach((o,e)=>{let r=b(o.size),n=o.id===t.activeModel?` ${l.green("[LOADED]")}`:"";console.log(` ${l.dim(String(e+1)+".")} ${o.name}${n}`),console.log(` ${l.dim("ID:")} ${o.id}`),console.log(` ${l.dim("Size:")} ${r}`),o.quantization&&console.log(` ${l.dim("Quantization:")} ${o.quantization}`),console.log()})}var S=new oo;S.name("aix").description("AI CLI tool integrating LM Studio with Claude Code").version("1.0.0");S.command("init").description("Initialize and load a model into LM Studio").option("-m, --model <name>","Model name or ID to load").action(E);S.command("run").description("Run Claude Code with a model from LM Studio").option("-m, --model <name>","Model name or ID to use").option("-v, --verbose","Show verbose output").argument("[args...]","Additional arguments for Claude Code").action(async(t,o)=>{await z({...o,args:t})});S.command("status").description("Show LM Studio status and available models").action(I);S.command("doctor").description("Check system requirements and configuration").action(async()=>{let{lmStudioService:t}=await Promise.resolve().then(()=>(v(),_)),{claudeService:o}=await Promise.resolve().then(()=>(R(),K)),{configService:e}=await Promise.resolve().then(()=>(h(),N));console.log(),console.log(u.bold("System Check")),console.log(u.dim("\u2500".repeat(50)));let r=await t.checkStatus();console.log(` ${r?u.green("\u2713"):u.yellow("\u26A0")} LM Studio: ${r?u.green("Running"):u.yellow("Not running")}`);let n=await o.isClaudeCodeInstalled();console.log(` ${n?u.green("\u2713"):u.red("\u2717")} Claude Code: ${n?u.green("Installed"):u.red("Not installed")}`),console.log(),console.log(u.bold("Configuration")),console.log(u.dim("\u2500".repeat(50))),console.log(` ${u.dim("\u25B8")} LM Studio URL: ${u.cyan(e.getLMStudioUrl())}`),n||(console.log(),console.log(u.yellow("\u26A0 Claude Code is not installed.")),console.log(` Install it with: ${u.cyan("npm install -g @anthropic-ai/claude-code")}`)),r||(console.log(),console.log(u.yellow("\u26A0 LM Studio is not running.")),console.log(` Start the server from the LM Studio app or download from ${u.cyan("https://lmstudio.ai")}`))});S.parse();
4
+ `));try{await U("claude",c,{stdio:"inherit",env:{...process.env,ANTHROPIC_MODEL:i}})}catch(s){if(s instanceof Error&&"exitCode"in s){let P=s.exitCode;process.exit(P??1)}throw s}}extractProvider(o){return o.split("/")[0]}extractModelName(o){let e=o.split("/");if(!(e.length<2))return e.slice(1).join("/")}async getVersion(){try{return(await U("claude",["--version"])).stdout}catch{return}}},O=new C});import{Command as oo}from"commander";import u from"chalk";v();h();import q from"ora";import f from"chalk";import B from"inquirer";async function x(t,o){let e=t.map(l=>({name:`${l.name} (${l.id})`,value:l,short:l.name})),r=o?e.findIndex(l=>l.value.id===o):0;return(await B.prompt([{type:"list",name:"model",message:"Select a model to load:",choices:e,default:Math.max(0,r),pageSize:Math.min(t.length,15)}])).model}async function $(t,o=!0){return(await B.prompt([{type:"confirm",name:"confirm",message:t,default:o}])).confirm}import _ from"chalk";function b(t){if(t===0)return"0 B";let o=1024,e=["B","KB","MB","GB","TB"],r=Math.floor(Math.log(t)/Math.log(o));return`${parseFloat((t/Math.pow(o,r)).toFixed(2))} ${e[r]}`}function L(t){console.log(_.green("\u2713")+" "+t)}function Y(t){console.error(_.red("\u2717")+" "+t)}function p(t,o=1){Y(t),process.exit(o)}async function E(t={}){let o=q({text:"Checking LM Studio status...",color:"cyan"}).start(),e=await g.checkStatus();e||(o.info("LM Studio server not running"),o.stop(),await $("Would you like to start the LM Studio server?")||p("LM Studio server must be running. Start it manually or use the Server tab in LM Studio."),await g.startServer(),e=!0),o.succeed("Connected to LM Studio");let r=q({text:"Fetching available models...",color:"cyan"}).start(),n=await g.getAvailableModels();n.length===0&&(r.fail("No models found. Download some models in LM Studio first."),p("No models available")),r.succeed(`Found ${f.bold(n.length)} model${n.length===1?"":"s"}`),console.log(),console.log(f.bold("Available Models:")),console.log(f.dim("\u2500".repeat(process.stdout.columns||80))),n.forEach((s,P)=>{let H=b(s.size),V=s.loaded?f.green(" [LOADED]"):"";console.log(` ${f.dim(String(P+1).padStart(2))}. ${s.name} ${f.dim(`(${H})`)}${V}`)}),console.log();let l=m.getLastUsedModel(),d=t.model,i=d?n.find(s=>s.id===d||s.name.includes(d)):await x(n,l);i||p("No model selected"),await g.loadModel(i.id,o);let c=i.id.replace("/","--");L(f.bold(`
5
+ Model ready: ${i.name}`)),console.log(),console.log("Run Claude Code with this model:"),console.log(` ${f.cyan("claude --model lmstudio/"+c)}`),console.log(),console.log(`Or use ${f.cyan("aix-cli run")} to start an interactive session`)}v();R();h();import W from"ora";import G from"chalk";async function I(t={}){let o=W({text:"Checking LM Studio status...",color:"cyan"}).start(),e=await g.checkStatus();e||(o.info("LM Studio server not running"),o.stop(),await $("Would you like to start the LM Studio server?")||p("LM Studio server must be running. Start it manually or use the Server tab in LM Studio."),await g.startServer(),e=!0),o.succeed("Connected to LM Studio"),o.text="Fetching available models...";let r=await g.getAvailableModels();r.length===0&&(o.fail("No models found. Download some models in LM Studio first."),p("No models available")),o.stop();let n;if(t.model){let c=r.find(s=>s.id===t.model||s.name.toLowerCase().includes(t.model.toLowerCase()));c||p(`Model "${t.model}" not found. Available models: ${r.map(s=>s.name).join(", ")}`),n=c.id}else{let c=m.getLastUsedModel();n=(await x(r,c)).id}let l=W({text:`Loading model: ${G.cyan(n)}`,color:"cyan"}).start();await g.loadModel(n,l);let i=`lmstudio/${n.replace("/","--")}`;L(G.green(`
6
+ Starting Claude Code with model: ${i}
7
+ `));try{await O.run({model:i,args:t.args??[],verbose:t.verbose})}catch(c){p(`Failed to run Claude Code: ${c instanceof Error?c.message:"Unknown error"}`)}}v();import a from"chalk";async function z(){let t=await g.getStatus();console.log(),console.log(a.bold("LM Studio Status")),console.log(a.dim("\u2500".repeat(50))),console.log(` ${t.running?a.green("\u25CF"):a.red("\u25CB")} Server: ${t.running?a.green("Running"):a.red("Stopped")}`),console.log(` ${a.dim("\u25B8")} Port: ${a.cyan(String(t.port))}`),console.log(` ${a.dim("\u25B8")} URL: ${a.cyan(`http://localhost:${t.port}`)}`),t.activeModel?console.log(` ${a.dim("\u25B8")} Active Model: ${a.green(t.activeModel)}`):console.log(` ${a.dim("\u25B8")} Active Model: ${a.dim("None")}`),console.log(),console.log(a.bold("Models")),console.log(a.dim("\u2500".repeat(50))),t.models.length===0?console.log(` ${a.dim("No models available")}`):t.models.forEach((o,e)=>{let r=b(o.size),n=o.id===t.activeModel?` ${a.green("[LOADED]")}`:"";console.log(` ${a.dim(String(e+1)+".")} ${o.name}${n}`),console.log(` ${a.dim("ID:")} ${o.id}`),console.log(` ${a.dim("Size:")} ${r}`),o.quantization&&console.log(` ${a.dim("Quantization:")} ${o.quantization}`),console.log()})}var S=new oo;S.name("aix").description("AI CLI tool integrating LM Studio with Claude Code").version("1.0.0");S.command("init").description("Initialize and load a model into LM Studio").option("-m, --model <name>","Model name or ID to load").action(E);S.command("run").description("Run Claude Code with a model from LM Studio").option("-m, --model <name>","Model name or ID to use").option("-v, --verbose","Show verbose output").argument("[args...]","Additional arguments for Claude Code").action(async(t,o)=>{await I({...o,args:t})});S.command("status").description("Show LM Studio status and available models").action(z);S.command("doctor").description("Check system requirements and configuration").action(async()=>{let{lmStudioService:t}=await Promise.resolve().then(()=>(v(),j)),{claudeService:o}=await Promise.resolve().then(()=>(R(),K)),{configService:e}=await Promise.resolve().then(()=>(h(),N));console.log(),console.log(u.bold("System Check")),console.log(u.dim("\u2500".repeat(50)));let r=await t.checkStatus();console.log(` ${r?u.green("\u2713"):u.yellow("\u26A0")} LM Studio: ${r?u.green("Running"):u.yellow("Not running")}`);let n=await o.isClaudeCodeInstalled();console.log(` ${n?u.green("\u2713"):u.red("\u2717")} Claude Code: ${n?u.green("Installed"):u.red("Not installed")}`),console.log(),console.log(u.bold("Configuration")),console.log(u.dim("\u2500".repeat(50))),console.log(` ${u.dim("\u25B8")} LM Studio URL: ${u.cyan(e.getLMStudioUrl())}`),n||(console.log(),console.log(u.yellow("\u26A0 Claude Code is not installed.")),console.log(` Install it with: ${u.cyan("npm install -g @anthropic-ai/claude-code")}`)),r||(console.log(),console.log(u.yellow("\u26A0 LM Studio is not running.")),console.log(` Start the server from the LM Studio app or download from ${u.cyan("https://lmstudio.ai")}`))});S.parse();
8
8
  //# sourceMappingURL=index.js.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../src/services/config.ts", "../../src/services/lmstudio.ts", "../../src/services/claude.ts", "../../src/index.ts", "../../src/commands/init.ts", "../../src/utils/prompt.ts", "../../src/utils/format.ts", "../../src/commands/run.ts", "../../src/commands/status.ts"],
4
- "sourcesContent": ["import Conf from 'conf';\nimport type { Config } from '../types/index.js';\n\nexport class ConfigService {\n private store: Conf<Config>;\n\n constructor() {\n this.store = new Conf<Config>({\n projectName: 'aix',\n defaults: {\n lmStudioUrl: 'http://localhost',\n lmStudioPort: 1234,\n defaultTimeout: 30000,\n autoStartServer: false,\n },\n clearInvalidConfig: true,\n });\n }\n\n get<K extends keyof Config>(key: K): Config[K] {\n return this.store.get(key) as Config[K];\n }\n\n set<K extends keyof Config>(key: K, value: Config[K]): void {\n this.store.set(key, value as Config[K]);\n }\n\n setModel(model: string): void {\n this.store.set('model', model);\n }\n\n getLastUsedModel(): string | undefined {\n return this.store.get('model');\n }\n\n getLMStudioUrl(): string {\n const host = this.store.get('lmStudioUrl');\n const port = this.store.get('lmStudioPort');\n return `${host}:${port}`;\n }\n\n reset(): void {\n this.store.clear();\n }\n}\n\nexport const configService = new ConfigService();\n", "import { execa } from 'execa';\nimport ora, { type Ora } from 'ora';\nimport chalk from 'chalk';\nimport { configService } from './config.js';\nimport type { LMStudioStatus, LMStudioModel } from '../types/index.js';\n\nconst LMSTUDIO_PORTS = [1234, 1235, 1236, 1237];\n\nexport class LMStudioService {\n private baseUrl: string;\n\n constructor() {\n this.baseUrl = configService.getLMStudioUrl();\n }\n\n private getApiUrl(path: string): string {\n return `${this.baseUrl}${path}`;\n }\n\n async checkStatus(): Promise<boolean> {\n try {\n const response = await fetch(this.getApiUrl('/api/status'), {\n method: 'GET',\n signal: AbortSignal.timeout(3000),\n });\n return response.ok;\n } catch {\n return false;\n }\n }\n\n async getAvailableModels(): Promise<LMStudioModel[]> {\n const endpoints = ['/api/models', '/api/v1/models', '/api/lsMODEL/list', '/api/ls-model/list'];\n\n for (const endpoint of endpoints) {\n try {\n const response = await fetch(this.getApiUrl(endpoint), {\n method: 'GET',\n signal: AbortSignal.timeout(10000),\n });\n\n if (!response.ok) continue;\n\n const data = (await response.json()) as Record<string, unknown>;\n\n if (Array.isArray(data)) {\n const models = data\n .map((m: unknown) => {\n const model = m as Record<string, unknown>;\n const id = String(model.id || model.model || model.model_id || '');\n const name = String(model.name || model.id || model.model || '');\n return {\n id: String(id),\n name: String(name),\n size: Number(model.size || model.file_size || model.size_bytes || 0),\n quantization: String(model.quantization || model.q || ''),\n };\n })\n .filter((m) => m.id && m.name);\n if (models.length > 0) return models;\n }\n\n if (data.models && Array.isArray(data.models)) {\n return (data.models as unknown[]).map((m: unknown) => {\n const model = m as Record<string, unknown>;\n return {\n id: String(model.id || model.model || model.model_id || ''),\n name: String(model.name || model.id || model.model || ''),\n size: Number(model.size || model.file_size || 0),\n quantization: String(model.quantization || ''),\n };\n });\n }\n\n if (data.data && Array.isArray(data.data)) {\n return data.data as LMStudioModel[];\n }\n } catch {\n continue;\n }\n }\n\n return [];\n }\n\n async getStatus(): Promise<LMStudioStatus> {\n const running = await this.checkStatus();\n\n if (!running) {\n return {\n running: false,\n port: configService.get('lmStudioPort'),\n models: [],\n };\n }\n\n try {\n const response = await fetch(this.getApiUrl('/api/status'), {\n method: 'GET',\n signal: AbortSignal.timeout(10000),\n });\n\n if (!response.ok) {\n return {\n running: false,\n port: configService.get('lmStudioPort'),\n models: [],\n };\n }\n\n const data = (await response.json()) as {\n models: LMStudioModel[];\n active_model?: string;\n };\n\n return {\n running: true,\n port: configService.get('lmStudioPort'),\n models: data.models ?? [],\n activeModel: data.active_model,\n };\n } catch {\n return {\n running: false,\n port: configService.get('lmStudioPort'),\n models: [],\n };\n }\n }\n\n async loadModel(modelId: string, spinner?: Ora): Promise<{ loadSpinner: Ora }> {\n const loadSpinner =\n spinner ??\n ora({\n text: `Loading model: ${chalk.cyan(modelId)}`,\n color: 'cyan',\n }).start();\n\n try {\n const response = await fetch(this.getApiUrl('/api/model/load'), {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify({ model: modelId }),\n signal: AbortSignal.timeout(300000),\n });\n\n if (!response.ok) {\n throw new Error(`Failed to load model: ${response.statusText}`);\n }\n\n loadSpinner.succeed(`Model ${chalk.green(modelId)} loaded successfully`);\n configService.setModel(modelId);\n\n return { loadSpinner };\n } catch (error) {\n loadSpinner.fail(\n `Failed to load model: ${error instanceof Error ? error.message : 'Unknown error'}`\n );\n throw error;\n }\n }\n\n async startServer(spinner?: Ora): Promise<void> {\n const startSpinner =\n spinner ??\n ora({\n text: 'Starting LM Studio server...',\n color: 'cyan',\n }).start();\n\n try {\n const isMac = process.platform === 'darwin';\n const isLinux = process.platform === 'linux';\n const isWindows = process.platform === 'win32';\n\n let lmStudioPath: string | undefined;\n\n if (isMac) {\n const possiblePaths = [\n '/Applications/LM Studio.app',\n `${process.env.HOME}/Applications/LM Studio.app`,\n ];\n for (const p of possiblePaths) {\n try {\n const { existsSync } = await import('fs');\n if (existsSync(p)) {\n lmStudioPath = `open \"${p}\" --args --server`;\n break;\n }\n } catch {\n // continue\n }\n }\n // Use open command for macOS apps\n if (lmStudioPath?.startsWith('open')) {\n await execa(\n 'open',\n [\n possiblePaths.find((p) => {\n try {\n const { existsSync } = require('fs');\n return existsSync(p);\n } catch {\n return false;\n }\n }) || '/Applications/LM Studio.app',\n '--args',\n '--server',\n ],\n {\n detached: true,\n stdio: 'ignore',\n }\n );\n startSpinner.succeed('LM Studio server started');\n await this.waitForServer(60000);\n return;\n }\n } else if (isLinux) {\n lmStudioPath = await this.findLinuxBinary();\n } else if (isWindows) {\n lmStudioPath = await this.findWindowsExecutable();\n }\n\n if (!lmStudioPath) {\n startSpinner.fail('LM Studio not found. Please install it from https://lmstudio.ai');\n throw new Error('LM Studio not installed');\n }\n\n await execa(lmStudioPath, ['--server'], {\n detached: true,\n stdio: 'ignore',\n env: {\n ...process.env,\n LM_STUDIO_SERVER_PORT: String(configService.get('lmStudioPort')),\n },\n });\n\n startSpinner.succeed('LM Studio server started');\n\n await this.waitForServer(60000);\n } catch (error) {\n startSpinner.fail(\n `Failed to start LM Studio: ${error instanceof Error ? error.message : 'Unknown error'}`\n );\n throw error;\n }\n }\n\n private async findLinuxBinary(): Promise<string | undefined> {\n const possiblePaths = [\n '/usr/bin/lm-studio',\n '/usr/local/bin/lm-studio',\n `${process.env.HOME}/.local/bin/lm-studio`,\n ];\n\n for (const path of possiblePaths) {\n try {\n await execa('test', ['-x', path]);\n return path;\n } catch {\n continue;\n }\n }\n\n return undefined;\n }\n\n private async findWindowsExecutable(): Promise<string | undefined> {\n const localAppData = process.env.LOCALAPPDATA;\n const programFiles = process.env.PROGRAMFILES;\n\n const possiblePaths = [\n localAppData ? `${localAppData}\\\\Programs\\\\LM Studio\\\\lm-studio.exe` : '',\n programFiles ? `${programFiles}\\\\LM Studio\\\\lm-studio.exe` : '',\n ].filter(Boolean);\n\n for (const path of possiblePaths) {\n try {\n await execa('cmd', ['/c', 'if exist', `\"${path}\"`, 'echo', 'yes']);\n return path;\n } catch {\n continue;\n }\n }\n\n return undefined;\n }\n\n async waitForServer(timeout: number = 60000): Promise<boolean> {\n const startTime = Date.now();\n\n while (Date.now() - startTime < timeout) {\n if (await this.checkStatus()) {\n return true;\n }\n await this.sleep(2000);\n }\n\n return false;\n }\n\n private sleep(ms: number): Promise<void> {\n return new Promise((resolve) => setTimeout(resolve, ms));\n }\n\n async findAvailablePort(): Promise<number> {\n for (const port of LMSTUDIO_PORTS) {\n try {\n const response = await fetch(`http://localhost:${port}/api/status`, {\n method: 'GET',\n signal: AbortSignal.timeout(1000),\n });\n if (response.ok) {\n return port;\n }\n } catch {\n configService.set('lmStudioPort', port);\n return port;\n }\n }\n\n return LMSTUDIO_PORTS[0] ?? 1234;\n }\n}\n\nexport const lmStudioService = new LMStudioService();\n", "import { execa } from 'execa';\nimport chalk from 'chalk';\n\nexport interface ClaudeOptions {\n model: string;\n args?: string[];\n verbose?: boolean;\n}\n\nexport class ClaudeService {\n async isClaudeCodeInstalled(): Promise<boolean> {\n try {\n await execa('claude', ['--version'], { stdio: 'ignore' });\n return true;\n } catch {\n return false;\n }\n }\n\n async run(options: ClaudeOptions): Promise<void> {\n const { model, args = [], verbose = false } = options;\n\n const provider = this.extractProvider(model);\n const modelName = this.extractModelName(model);\n\n if (!provider || !modelName) {\n throw new Error(`Invalid model format: ${model}. Expected format: provider/model-name`);\n }\n\n const modelArg = `${provider}/${modelName}`;\n const claudeArgs = ['--model', modelArg, ...args];\n\n if (verbose) {\n console.log(chalk.dim(`\\nRunning: claude ${claudeArgs.join(' ')}\\n`));\n }\n\n try {\n await execa('claude', claudeArgs, {\n stdio: 'inherit',\n env: {\n ...process.env,\n ANTHROPIC_MODEL: modelArg,\n },\n });\n } catch (error) {\n if (error instanceof Error && 'exitCode' in error) {\n const exitCode = (error as unknown as { exitCode: number }).exitCode;\n process.exit(exitCode ?? 1);\n }\n throw error;\n }\n }\n\n private extractProvider(model: string): string | undefined {\n const parts = model.split('/');\n return parts[0];\n }\n\n private extractModelName(model: string): string | undefined {\n const parts = model.split('/');\n if (parts.length < 2) return undefined;\n return parts.slice(1).join('/');\n }\n\n async getVersion(): Promise<string | undefined> {\n try {\n const result = await execa('claude', ['--version']);\n return result.stdout;\n } catch {\n return undefined;\n }\n }\n}\n\nexport const claudeService = new ClaudeService();\n", "#!/usr/bin/env node\n\nimport { Command } from 'commander';\nimport chalk from 'chalk';\nimport { initCommand, runCommand, statusCommand } from './commands/index.js';\n\nconst program = new Command();\n\nprogram\n .name('aix')\n .description('AI CLI tool integrating LM Studio with Claude Code')\n .version('1.0.0');\n\nprogram\n .command('init')\n .description('Initialize and load a model into LM Studio')\n .option('-m, --model <name>', 'Model name or ID to load')\n .action(initCommand);\n\nprogram\n .command('run')\n .description('Run Claude Code with a model from LM Studio')\n .option('-m, --model <name>', 'Model name or ID to use')\n .option('-v, --verbose', 'Show verbose output')\n .argument('[args...]', 'Additional arguments for Claude Code')\n .action(async (args: string[], options: Record<string, unknown>) => {\n await runCommand({\n ...options,\n args,\n });\n });\n\nprogram\n .command('status')\n .description('Show LM Studio status and available models')\n .action(statusCommand);\n\nprogram\n .command('doctor')\n .description('Check system requirements and configuration')\n .action(async () => {\n const { lmStudioService } = await import('./services/lmstudio.js');\n const { claudeService } = await import('./services/claude.js');\n const { configService } = await import('./services/config.js');\n\n console.log();\n console.log(chalk.bold('System Check'));\n console.log(chalk.dim('\u2500'.repeat(50)));\n\n const lmStudioRunning = await lmStudioService.checkStatus();\n console.log(\n ` ${lmStudioRunning ? chalk.green('\u2713') : chalk.yellow('\u26A0')} LM Studio: ${lmStudioRunning ? chalk.green('Running') : chalk.yellow('Not running')}`\n );\n\n const claudeInstalled = await claudeService.isClaudeCodeInstalled();\n console.log(\n ` ${claudeInstalled ? chalk.green('\u2713') : chalk.red('\u2717')} Claude Code: ${claudeInstalled ? chalk.green('Installed') : chalk.red('Not installed')}`\n );\n\n console.log();\n console.log(chalk.bold('Configuration'));\n console.log(chalk.dim('\u2500'.repeat(50)));\n console.log(` ${chalk.dim('\u25B8')} LM Studio URL: ${chalk.cyan(configService.getLMStudioUrl())}`);\n\n if (!claudeInstalled) {\n console.log();\n console.log(chalk.yellow('\u26A0 Claude Code is not installed.'));\n console.log(` Install it with: ${chalk.cyan('npm install -g @anthropic-ai/claude-code')}`);\n }\n\n if (!lmStudioRunning) {\n console.log();\n console.log(chalk.yellow('\u26A0 LM Studio is not running.'));\n console.log(\n ` Start the server from the LM Studio app or download from ${chalk.cyan('https://lmstudio.ai')}`\n );\n }\n });\n\nprogram.parse();\n", "import ora from 'ora';\nimport chalk from 'chalk';\nimport { lmStudioService } from '../services/lmstudio.js';\nimport { configService } from '../services/config.js';\nimport { selectModel, confirmAction } from '../utils/prompt.js';\nimport { formatBytes, success, exitWithError } from '../utils/format.js';\nimport type { InitOptions } from '../types/index.js';\n\nexport async function initCommand(options: InitOptions = {}): Promise<void> {\n const spinner = ora({\n text: 'Checking LM Studio status...',\n color: 'cyan',\n }).start();\n\n let isRunning = await lmStudioService.checkStatus();\n\n if (!isRunning) {\n spinner.info('LM Studio server not running');\n spinner.stop();\n\n const shouldStart = await confirmAction('Would you like to start the LM Studio server?');\n\n if (!shouldStart) {\n exitWithError(\n 'LM Studio server must be running. Start it manually or use the Server tab in LM Studio.'\n );\n }\n\n await lmStudioService.startServer();\n isRunning = true;\n }\n\n spinner.succeed('Connected to LM Studio');\n\n const modelsSpinner = ora({\n text: 'Fetching available models...',\n color: 'cyan',\n }).start();\n\n const models = await lmStudioService.getAvailableModels();\n\n if (models.length === 0) {\n modelsSpinner.fail('No models found. Download some models in LM Studio first.');\n exitWithError('No models available');\n }\n\n modelsSpinner.succeed(\n `Found ${chalk.bold(models.length)} model${models.length === 1 ? '' : 's'}`\n );\n\n console.log();\n console.log(chalk.bold('Available Models:'));\n console.log(chalk.dim('\u2500'.repeat(process.stdout.columns || 80)));\n\n models.forEach((model, index) => {\n const size = formatBytes(model.size);\n const loaded = model.loaded ? chalk.green(' [LOADED]') : '';\n console.log(\n ` ${chalk.dim(String(index + 1).padStart(2))}. ${model.name} ${chalk.dim(`(${size})`)}${loaded}`\n );\n });\n console.log();\n\n const lastUsedModel = configService.getLastUsedModel();\n const modelSearch = options.model;\n const selectedModel = modelSearch\n ? models.find((m) => m.id === modelSearch || m.name.includes(modelSearch))\n : await selectModel(models, lastUsedModel);\n\n if (!selectedModel) {\n exitWithError('No model selected');\n }\n\n await lmStudioService.loadModel(selectedModel.id, spinner);\n\n const modelIdentifier = selectedModel.id.replace('/', '--');\n\n success(chalk.bold(`\\nModel ready: ${selectedModel.name}`));\n console.log();\n console.log(`Run Claude Code with this model:`);\n console.log(` ${chalk.cyan('claude --model lmstudio/' + modelIdentifier)}`);\n console.log();\n console.log(`Or use ${chalk.cyan('npx aix run')} to start an interactive session`);\n}\n", "import inquirer from 'inquirer';\nimport type { LMStudioModel } from '../types/index.js';\n\nexport async function selectModel(\n models: LMStudioModel[],\n defaultModel?: string\n): Promise<LMStudioModel> {\n const choices = models.map((model) => ({\n name: `${model.name} (${model.id})`,\n value: model,\n short: model.name,\n }));\n\n const defaultIndex = defaultModel ? choices.findIndex((m) => m.value.id === defaultModel) : 0;\n\n const answers = await inquirer.prompt([\n {\n type: 'list',\n name: 'model',\n message: 'Select a model to load:',\n choices,\n default: Math.max(0, defaultIndex),\n pageSize: Math.min(models.length, 15),\n },\n ]);\n\n return answers['model'] as LMStudioModel;\n}\n\nexport async function confirmAction(\n message: string,\n defaultValue: boolean = true\n): Promise<boolean> {\n const answers = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'confirm',\n message,\n default: defaultValue,\n },\n ]);\n\n return answers['confirm'] as boolean;\n}\n\nexport async function enterPrompt(message: string, defaultValue?: string): Promise<string> {\n const answers = await inquirer.prompt([\n {\n type: 'input',\n name: 'value',\n message,\n default: defaultValue,\n validate: (input: string) => input.trim().length > 0 || 'Please enter a value',\n },\n ]);\n\n return answers['value'] as string;\n}\n", "import chalk from \"chalk\";\n\nexport function formatBytes(bytes: number): string {\n if (bytes === 0) return \"0 B\";\n\n const k = 1024;\n const sizes = [\"B\", \"KB\", \"MB\", \"GB\", \"TB\"];\n const i = Math.floor(Math.log(bytes) / Math.log(k));\n\n return `${parseFloat((bytes / Math.pow(k, i)).toFixed(2))} ${sizes[i]}`;\n}\n\nexport function formatModelName(modelId: string): string {\n return modelId\n .replace(/^.*\\//, \"\")\n .replace(/[-_]/g, \" \")\n .replace(/\\b\\w/g, (c) => c.toUpperCase());\n}\n\nexport function truncate(str: string, maxLength: number): string {\n if (str.length <= maxLength) return str;\n return str.slice(0, maxLength - 3) + \"...\";\n}\n\nexport function promptSeparator(): void {\n console.log(chalk.dim(\"\u2500\".repeat(process.stdout.columns || 80)));\n}\n\nexport function success(message: string): void {\n console.log(chalk.green(\"\u2713\") + \" \" + message);\n}\n\nexport function error(message: string): void {\n console.error(chalk.red(\"\u2717\") + \" \" + message);\n}\n\nexport function info(message: string): void {\n console.log(chalk.blue(\"\u2139\") + \" \" + message);\n}\n\nexport function warn(message: string): void {\n console.log(chalk.yellow(\"\u26A0\") + \" \" + message);\n}\n\nexport function exitWithError(message: string, code: number = 1): never {\n error(message);\n process.exit(code);\n}\n", "import ora from 'ora';\nimport chalk from 'chalk';\nimport { lmStudioService } from '../services/lmstudio.js';\nimport { claudeService } from '../services/claude.js';\nimport { configService } from '../services/config.js';\nimport { selectModel, confirmAction } from '../utils/prompt.js';\nimport { exitWithError, success } from '../utils/format.js';\n\ninterface RunOptions {\n model?: string;\n verbose?: boolean;\n args?: string[];\n}\n\nexport async function runCommand(options: RunOptions = {}): Promise<void> {\n const spinner = ora({\n text: 'Checking LM Studio status...',\n color: 'cyan',\n }).start();\n\n let isRunning = await lmStudioService.checkStatus();\n\n if (!isRunning) {\n spinner.info('LM Studio server not running');\n spinner.stop();\n\n const shouldStart = await confirmAction('Would you like to start the LM Studio server?');\n\n if (!shouldStart) {\n exitWithError(\n 'LM Studio server must be running. Start it manually or use the Server tab in LM Studio.'\n );\n }\n\n await lmStudioService.startServer();\n isRunning = true;\n }\n\n spinner.succeed('Connected to LM Studio');\n\n spinner.text = 'Fetching available models...';\n const models = await lmStudioService.getAvailableModels();\n\n if (models.length === 0) {\n spinner.fail('No models found. Download some models in LM Studio first.');\n exitWithError('No models available');\n }\n\n spinner.stop();\n\n let selectedModelId: string;\n\n if (options.model) {\n const foundModel = models.find(\n (m) => m.id === options.model || m.name.toLowerCase().includes(options.model!.toLowerCase())\n );\n\n if (!foundModel) {\n exitWithError(\n `Model \"${options.model}\" not found. Available models: ${models.map((m) => m.name).join(', ')}`\n );\n }\n\n selectedModelId = foundModel.id;\n } else {\n const lastUsedModel = configService.getLastUsedModel();\n const selectedModel = await selectModel(models, lastUsedModel);\n selectedModelId = selectedModel.id;\n }\n\n const loadSpinner = ora({\n text: `Loading model: ${chalk.cyan(selectedModelId)}`,\n color: 'cyan',\n }).start();\n\n await lmStudioService.loadModel(selectedModelId, loadSpinner);\n\n const modelIdentifier = selectedModelId.replace('/', '--');\n const fullModelName = `lmstudio/${modelIdentifier}`;\n\n success(chalk.green(`\\nStarting Claude Code with model: ${fullModelName}\\n`));\n\n try {\n await claudeService.run({\n model: fullModelName,\n args: options.args ?? [],\n verbose: options.verbose,\n });\n } catch (error) {\n exitWithError(\n `Failed to run Claude Code: ${error instanceof Error ? error.message : 'Unknown error'}`\n );\n }\n}\n", "import chalk from \"chalk\";\nimport { lmStudioService } from \"../services/lmstudio.js\";\nimport { formatBytes } from \"../utils/format.js\";\n\nexport async function statusCommand(): Promise<void> {\n const status = await lmStudioService.getStatus();\n\n console.log();\n console.log(chalk.bold(\"LM Studio Status\"));\n console.log(chalk.dim(\"\u2500\".repeat(50)));\n console.log(\n ` ${status.running ? chalk.green(\"\u25CF\") : chalk.red(\"\u25CB\")} Server: ${status.running ? chalk.green(\"Running\") : chalk.red(\"Stopped\")}`,\n );\n console.log(` ${chalk.dim(\"\u25B8\")} Port: ${chalk.cyan(String(status.port))}`);\n console.log(\n ` ${chalk.dim(\"\u25B8\")} URL: ${chalk.cyan(`http://localhost:${status.port}`)}`,\n );\n\n if (status.activeModel) {\n console.log(\n ` ${chalk.dim(\"\u25B8\")} Active Model: ${chalk.green(status.activeModel)}`,\n );\n } else {\n console.log(` ${chalk.dim(\"\u25B8\")} Active Model: ${chalk.dim(\"None\")}`);\n }\n\n console.log();\n console.log(chalk.bold(\"Models\"));\n console.log(chalk.dim(\"\u2500\".repeat(50)));\n\n if (status.models.length === 0) {\n console.log(` ${chalk.dim(\"No models available\")}`);\n } else {\n status.models.forEach((model, index) => {\n const size = formatBytes(model.size);\n const loaded =\n model.id === status.activeModel ? ` ${chalk.green(\"[LOADED]\")}` : \"\";\n console.log(\n ` ${chalk.dim(String(index + 1) + \".\")} ${model.name}${loaded}`,\n );\n console.log(` ${chalk.dim(\"ID:\")} ${model.id}`);\n console.log(` ${chalk.dim(\"Size:\")} ${size}`);\n if (model.quantization) {\n console.log(` ${chalk.dim(\"Quantization:\")} ${model.quantization}`);\n }\n console.log();\n });\n }\n}\n"],
5
- "mappings": "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",
6
- "names": ["config_exports", "__export", "ConfigService", "configService", "Conf", "init_config", "__esmMin", "key", "value", "model", "host", "port", "lmstudio_exports", "__export", "LMStudioService", "lmStudioService", "execa", "ora", "chalk", "LMSTUDIO_PORTS", "init_lmstudio", "__esmMin", "init_config", "configService", "path", "endpoints", "endpoint", "response", "data", "models", "m", "model", "id", "name", "modelId", "spinner", "loadSpinner", "error", "startSpinner", "isMac", "isLinux", "isWindows", "lmStudioPath", "possiblePaths", "p", "existsSync", "localAppData", "programFiles", "timeout", "startTime", "ms", "resolve", "port", "claude_exports", "__export", "ClaudeService", "claudeService", "execa", "chalk", "init_claude", "__esmMin", "options", "model", "args", "verbose", "provider", "modelName", "modelArg", "claudeArgs", "error", "exitCode", "parts", "Command", "chalk", "init_lmstudio", "init_config", "ora", "chalk", "inquirer", "selectModel", "models", "defaultModel", "choices", "model", "defaultIndex", "m", "confirmAction", "message", "defaultValue", "chalk", "formatBytes", "bytes", "k", "sizes", "i", "success", "message", "chalk", "error", "exitWithError", "message", "code", "error", "initCommand", "options", "spinner", "ora", "isRunning", "lmStudioService", "confirmAction", "exitWithError", "modelsSpinner", "models", "chalk", "model", "index", "size", "formatBytes", "loaded", "lastUsedModel", "configService", "modelSearch", "selectedModel", "m", "selectModel", "modelIdentifier", "success", "init_lmstudio", "init_claude", "init_config", "ora", "chalk", "runCommand", "options", "spinner", "ora", "isRunning", "lmStudioService", "confirmAction", "exitWithError", "models", "selectedModelId", "foundModel", "m", "lastUsedModel", "configService", "selectModel", "loadSpinner", "chalk", "fullModelName", "success", "claudeService", "error", "init_lmstudio", "chalk", "statusCommand", "status", "lmStudioService", "chalk", "model", "index", "size", "formatBytes", "loaded", "program", "Command", "initCommand", "args", "options", "runCommand", "statusCommand", "lmStudioService", "claudeService", "configService", "chalk", "lmStudioRunning", "claudeInstalled"]
4
+ "sourcesContent": ["import Conf from 'conf';\nimport type { Config } from '../types/index.js';\n\nexport class ConfigService {\n private store: Conf<Config>;\n\n constructor() {\n this.store = new Conf<Config>({\n projectName: 'aix',\n defaults: {\n lmStudioUrl: 'http://localhost',\n lmStudioPort: 1234,\n defaultTimeout: 30000,\n autoStartServer: false,\n },\n clearInvalidConfig: true,\n });\n }\n\n get<K extends keyof Config>(key: K): Config[K] {\n return this.store.get(key) as Config[K];\n }\n\n set<K extends keyof Config>(key: K, value: Config[K]): void {\n this.store.set(key, value as Config[K]);\n }\n\n setModel(model: string): void {\n this.store.set('model', model);\n }\n\n getLastUsedModel(): string | undefined {\n return this.store.get('model');\n }\n\n getLMStudioUrl(): string {\n const host = this.store.get('lmStudioUrl');\n const port = this.store.get('lmStudioPort');\n return `${host}:${port}`;\n }\n\n reset(): void {\n this.store.clear();\n }\n}\n\nexport const configService = new ConfigService();\n", "import { execa } from 'execa';\nimport ora, { type Ora } from 'ora';\nimport chalk from 'chalk';\nimport { configService } from './config.js';\nimport type { LMStudioStatus, LMStudioModel } from '../types/index.js';\n\nconst LMSTUDIO_PORTS = [1234, 1235, 1236, 1237];\n\nexport class LMStudioService {\n private baseUrl: string;\n\n constructor() {\n this.baseUrl = configService.getLMStudioUrl();\n }\n\n private getApiUrl(path: string): string {\n return `${this.baseUrl}${path}`;\n }\n\n async checkStatus(): Promise<boolean> {\n try {\n const response = await fetch(this.getApiUrl('/api/status'), {\n method: 'GET',\n signal: AbortSignal.timeout(3000),\n });\n return response.ok;\n } catch {\n return false;\n }\n }\n\n async getAvailableModels(): Promise<LMStudioModel[]> {\n const endpoints = ['/api/v1/models', '/api/models', '/v1/models', '/api/ls-model/list'];\n\n for (const endpoint of endpoints) {\n try {\n const response = await fetch(this.getApiUrl(endpoint), {\n method: 'GET',\n signal: AbortSignal.timeout(10000),\n });\n\n if (!response.ok) continue;\n\n const json = (await response.json()) as Record<string, unknown>;\n\n let models: unknown[] = [];\n\n // Try different response formats\n if (Array.isArray(json)) {\n models = json;\n } else if (json.models && Array.isArray(json.models)) {\n models = json.models;\n } else if (json.data && Array.isArray(json.data)) {\n models = json.data;\n }\n\n return (models as Record<string, unknown>[])\n .map((m) => {\n const model = m as Record<string, unknown>;\n return {\n id: String(model.key || model.id || model.model || ''),\n name: String(model.display_name || model.name || model.id || model.model || ''),\n size: Number(model.size_bytes || model.size || model.file_size || 0),\n quantization: String(\n model.quantization\n ? typeof model.quantization === 'object'\n ? (model.quantization as Record<string, unknown>).name\n : model.quantization\n : ''\n ),\n };\n })\n .filter((m) => m.id && m.name);\n } catch {\n continue;\n }\n }\n\n return [];\n }\n\n async getStatus(): Promise<LMStudioStatus> {\n const running = await this.checkStatus();\n\n if (!running) {\n return {\n running: false,\n port: configService.get('lmStudioPort'),\n models: [],\n };\n }\n\n try {\n const response = await fetch(this.getApiUrl('/api/status'), {\n method: 'GET',\n signal: AbortSignal.timeout(10000),\n });\n\n if (!response.ok) {\n return {\n running: false,\n port: configService.get('lmStudioPort'),\n models: [],\n };\n }\n\n const data = (await response.json()) as {\n models: LMStudioModel[];\n active_model?: string;\n };\n\n return {\n running: true,\n port: configService.get('lmStudioPort'),\n models: data.models ?? [],\n activeModel: data.active_model,\n };\n } catch {\n return {\n running: false,\n port: configService.get('lmStudioPort'),\n models: [],\n };\n }\n }\n\n async loadModel(modelId: string, spinner?: Ora): Promise<{ loadSpinner: Ora }> {\n const loadSpinner =\n spinner ??\n ora({\n text: `Loading model: ${chalk.cyan(modelId)}`,\n color: 'cyan',\n }).start();\n\n try {\n const response = await fetch(this.getApiUrl('/api/model/load'), {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify({ model: modelId }),\n signal: AbortSignal.timeout(300000),\n });\n\n if (!response.ok) {\n throw new Error(`Failed to load model: ${response.statusText}`);\n }\n\n loadSpinner.succeed(`Model ${chalk.green(modelId)} loaded successfully`);\n configService.setModel(modelId);\n\n return { loadSpinner };\n } catch (error) {\n loadSpinner.fail(\n `Failed to load model: ${error instanceof Error ? error.message : 'Unknown error'}`\n );\n throw error;\n }\n }\n\n async startServer(spinner?: Ora): Promise<void> {\n const startSpinner =\n spinner ??\n ora({\n text: 'Starting LM Studio server...',\n color: 'cyan',\n }).start();\n\n try {\n const isMac = process.platform === 'darwin';\n const isLinux = process.platform === 'linux';\n const isWindows = process.platform === 'win32';\n\n let lmStudioPath: string | undefined;\n\n if (isMac) {\n const possiblePaths = [\n '/Applications/LM Studio.app',\n `${process.env.HOME}/Applications/LM Studio.app`,\n ];\n for (const p of possiblePaths) {\n try {\n const { existsSync } = await import('fs');\n if (existsSync(p)) {\n lmStudioPath = `open \"${p}\" --args --server`;\n break;\n }\n } catch {\n // continue\n }\n }\n // Use open command for macOS apps\n if (lmStudioPath?.startsWith('open')) {\n await execa(\n 'open',\n [\n possiblePaths.find((p) => {\n try {\n const { existsSync } = require('fs');\n return existsSync(p);\n } catch {\n return false;\n }\n }) || '/Applications/LM Studio.app',\n '--args',\n '--server',\n ],\n {\n detached: true,\n stdio: 'ignore',\n }\n );\n startSpinner.succeed('LM Studio server started');\n await this.waitForServer(60000);\n return;\n }\n } else if (isLinux) {\n lmStudioPath = await this.findLinuxBinary();\n } else if (isWindows) {\n lmStudioPath = await this.findWindowsExecutable();\n }\n\n if (!lmStudioPath) {\n startSpinner.fail('LM Studio not found. Please install it from https://lmstudio.ai');\n throw new Error('LM Studio not installed');\n }\n\n await execa(lmStudioPath, ['--server'], {\n detached: true,\n stdio: 'ignore',\n env: {\n ...process.env,\n LM_STUDIO_SERVER_PORT: String(configService.get('lmStudioPort')),\n },\n });\n\n startSpinner.succeed('LM Studio server started');\n\n await this.waitForServer(60000);\n } catch (error) {\n startSpinner.fail(\n `Failed to start LM Studio: ${error instanceof Error ? error.message : 'Unknown error'}`\n );\n throw error;\n }\n }\n\n private async findLinuxBinary(): Promise<string | undefined> {\n const possiblePaths = [\n '/usr/bin/lm-studio',\n '/usr/local/bin/lm-studio',\n `${process.env.HOME}/.local/bin/lm-studio`,\n ];\n\n for (const path of possiblePaths) {\n try {\n await execa('test', ['-x', path]);\n return path;\n } catch {\n continue;\n }\n }\n\n return undefined;\n }\n\n private async findWindowsExecutable(): Promise<string | undefined> {\n const localAppData = process.env.LOCALAPPDATA;\n const programFiles = process.env.PROGRAMFILES;\n\n const possiblePaths = [\n localAppData ? `${localAppData}\\\\Programs\\\\LM Studio\\\\lm-studio.exe` : '',\n programFiles ? `${programFiles}\\\\LM Studio\\\\lm-studio.exe` : '',\n ].filter(Boolean);\n\n for (const path of possiblePaths) {\n try {\n await execa('cmd', ['/c', 'if exist', `\"${path}\"`, 'echo', 'yes']);\n return path;\n } catch {\n continue;\n }\n }\n\n return undefined;\n }\n\n async waitForServer(timeout: number = 60000): Promise<boolean> {\n const startTime = Date.now();\n\n while (Date.now() - startTime < timeout) {\n if (await this.checkStatus()) {\n return true;\n }\n await this.sleep(2000);\n }\n\n return false;\n }\n\n private sleep(ms: number): Promise<void> {\n return new Promise((resolve) => setTimeout(resolve, ms));\n }\n\n async findAvailablePort(): Promise<number> {\n for (const port of LMSTUDIO_PORTS) {\n try {\n const response = await fetch(`http://localhost:${port}/api/status`, {\n method: 'GET',\n signal: AbortSignal.timeout(1000),\n });\n if (response.ok) {\n return port;\n }\n } catch {\n configService.set('lmStudioPort', port);\n return port;\n }\n }\n\n return LMSTUDIO_PORTS[0] ?? 1234;\n }\n}\n\nexport const lmStudioService = new LMStudioService();\n", "import { execa } from 'execa';\nimport chalk from 'chalk';\n\nexport interface ClaudeOptions {\n model: string;\n args?: string[];\n verbose?: boolean;\n}\n\nexport class ClaudeService {\n async isClaudeCodeInstalled(): Promise<boolean> {\n try {\n await execa('claude', ['--version'], { stdio: 'ignore' });\n return true;\n } catch {\n return false;\n }\n }\n\n async run(options: ClaudeOptions): Promise<void> {\n const { model, args = [], verbose = false } = options;\n\n const provider = this.extractProvider(model);\n const modelName = this.extractModelName(model);\n\n if (!provider || !modelName) {\n throw new Error(`Invalid model format: ${model}. Expected format: provider/model-name`);\n }\n\n const modelArg = `${provider}/${modelName}`;\n const claudeArgs = ['--model', modelArg, ...args];\n\n if (verbose) {\n console.log(chalk.dim(`\\nRunning: claude ${claudeArgs.join(' ')}\\n`));\n }\n\n try {\n await execa('claude', claudeArgs, {\n stdio: 'inherit',\n env: {\n ...process.env,\n ANTHROPIC_MODEL: modelArg,\n },\n });\n } catch (error) {\n if (error instanceof Error && 'exitCode' in error) {\n const exitCode = (error as unknown as { exitCode: number }).exitCode;\n process.exit(exitCode ?? 1);\n }\n throw error;\n }\n }\n\n private extractProvider(model: string): string | undefined {\n const parts = model.split('/');\n return parts[0];\n }\n\n private extractModelName(model: string): string | undefined {\n const parts = model.split('/');\n if (parts.length < 2) return undefined;\n return parts.slice(1).join('/');\n }\n\n async getVersion(): Promise<string | undefined> {\n try {\n const result = await execa('claude', ['--version']);\n return result.stdout;\n } catch {\n return undefined;\n }\n }\n}\n\nexport const claudeService = new ClaudeService();\n", "#!/usr/bin/env node\n\nimport { Command } from 'commander';\nimport chalk from 'chalk';\nimport { initCommand, runCommand, statusCommand } from './commands/index.js';\n\nconst program = new Command();\n\nprogram\n .name('aix')\n .description('AI CLI tool integrating LM Studio with Claude Code')\n .version('1.0.0');\n\nprogram\n .command('init')\n .description('Initialize and load a model into LM Studio')\n .option('-m, --model <name>', 'Model name or ID to load')\n .action(initCommand);\n\nprogram\n .command('run')\n .description('Run Claude Code with a model from LM Studio')\n .option('-m, --model <name>', 'Model name or ID to use')\n .option('-v, --verbose', 'Show verbose output')\n .argument('[args...]', 'Additional arguments for Claude Code')\n .action(async (args: string[], options: Record<string, unknown>) => {\n await runCommand({\n ...options,\n args,\n });\n });\n\nprogram\n .command('status')\n .description('Show LM Studio status and available models')\n .action(statusCommand);\n\nprogram\n .command('doctor')\n .description('Check system requirements and configuration')\n .action(async () => {\n const { lmStudioService } = await import('./services/lmstudio.js');\n const { claudeService } = await import('./services/claude.js');\n const { configService } = await import('./services/config.js');\n\n console.log();\n console.log(chalk.bold('System Check'));\n console.log(chalk.dim('\u2500'.repeat(50)));\n\n const lmStudioRunning = await lmStudioService.checkStatus();\n console.log(\n ` ${lmStudioRunning ? chalk.green('\u2713') : chalk.yellow('\u26A0')} LM Studio: ${lmStudioRunning ? chalk.green('Running') : chalk.yellow('Not running')}`\n );\n\n const claudeInstalled = await claudeService.isClaudeCodeInstalled();\n console.log(\n ` ${claudeInstalled ? chalk.green('\u2713') : chalk.red('\u2717')} Claude Code: ${claudeInstalled ? chalk.green('Installed') : chalk.red('Not installed')}`\n );\n\n console.log();\n console.log(chalk.bold('Configuration'));\n console.log(chalk.dim('\u2500'.repeat(50)));\n console.log(` ${chalk.dim('\u25B8')} LM Studio URL: ${chalk.cyan(configService.getLMStudioUrl())}`);\n\n if (!claudeInstalled) {\n console.log();\n console.log(chalk.yellow('\u26A0 Claude Code is not installed.'));\n console.log(` Install it with: ${chalk.cyan('npm install -g @anthropic-ai/claude-code')}`);\n }\n\n if (!lmStudioRunning) {\n console.log();\n console.log(chalk.yellow('\u26A0 LM Studio is not running.'));\n console.log(\n ` Start the server from the LM Studio app or download from ${chalk.cyan('https://lmstudio.ai')}`\n );\n }\n });\n\nprogram.parse();\n", "import ora from 'ora';\nimport chalk from 'chalk';\nimport { lmStudioService } from '../services/lmstudio.js';\nimport { configService } from '../services/config.js';\nimport { selectModel, confirmAction } from '../utils/prompt.js';\nimport { formatBytes, success, exitWithError } from '../utils/format.js';\nimport type { InitOptions } from '../types/index.js';\n\nexport async function initCommand(options: InitOptions = {}): Promise<void> {\n const spinner = ora({\n text: 'Checking LM Studio status...',\n color: 'cyan',\n }).start();\n\n let isRunning = await lmStudioService.checkStatus();\n\n if (!isRunning) {\n spinner.info('LM Studio server not running');\n spinner.stop();\n\n const shouldStart = await confirmAction('Would you like to start the LM Studio server?');\n\n if (!shouldStart) {\n exitWithError(\n 'LM Studio server must be running. Start it manually or use the Server tab in LM Studio.'\n );\n }\n\n await lmStudioService.startServer();\n isRunning = true;\n }\n\n spinner.succeed('Connected to LM Studio');\n\n const modelsSpinner = ora({\n text: 'Fetching available models...',\n color: 'cyan',\n }).start();\n\n const models = await lmStudioService.getAvailableModels();\n\n if (models.length === 0) {\n modelsSpinner.fail('No models found. Download some models in LM Studio first.');\n exitWithError('No models available');\n }\n\n modelsSpinner.succeed(\n `Found ${chalk.bold(models.length)} model${models.length === 1 ? '' : 's'}`\n );\n\n console.log();\n console.log(chalk.bold('Available Models:'));\n console.log(chalk.dim('\u2500'.repeat(process.stdout.columns || 80)));\n\n models.forEach((model, index) => {\n const size = formatBytes(model.size);\n const loaded = model.loaded ? chalk.green(' [LOADED]') : '';\n console.log(\n ` ${chalk.dim(String(index + 1).padStart(2))}. ${model.name} ${chalk.dim(`(${size})`)}${loaded}`\n );\n });\n console.log();\n\n const lastUsedModel = configService.getLastUsedModel();\n const modelSearch = options.model;\n const selectedModel = modelSearch\n ? models.find((m) => m.id === modelSearch || m.name.includes(modelSearch))\n : await selectModel(models, lastUsedModel);\n\n if (!selectedModel) {\n exitWithError('No model selected');\n }\n\n await lmStudioService.loadModel(selectedModel.id, spinner);\n\n const modelIdentifier = selectedModel.id.replace('/', '--');\n\n success(chalk.bold(`\\nModel ready: ${selectedModel.name}`));\n console.log();\n console.log(`Run Claude Code with this model:`);\n console.log(` ${chalk.cyan('claude --model lmstudio/' + modelIdentifier)}`);\n console.log();\n console.log(`Or use ${chalk.cyan('aix-cli run')} to start an interactive session`);\n}\n", "import inquirer from 'inquirer';\nimport type { LMStudioModel } from '../types/index.js';\n\nexport async function selectModel(\n models: LMStudioModel[],\n defaultModel?: string\n): Promise<LMStudioModel> {\n const choices = models.map((model) => ({\n name: `${model.name} (${model.id})`,\n value: model,\n short: model.name,\n }));\n\n const defaultIndex = defaultModel ? choices.findIndex((m) => m.value.id === defaultModel) : 0;\n\n const answers = await inquirer.prompt([\n {\n type: 'list',\n name: 'model',\n message: 'Select a model to load:',\n choices,\n default: Math.max(0, defaultIndex),\n pageSize: Math.min(models.length, 15),\n },\n ]);\n\n return answers['model'] as LMStudioModel;\n}\n\nexport async function confirmAction(\n message: string,\n defaultValue: boolean = true\n): Promise<boolean> {\n const answers = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'confirm',\n message,\n default: defaultValue,\n },\n ]);\n\n return answers['confirm'] as boolean;\n}\n\nexport async function enterPrompt(message: string, defaultValue?: string): Promise<string> {\n const answers = await inquirer.prompt([\n {\n type: 'input',\n name: 'value',\n message,\n default: defaultValue,\n validate: (input: string) => input.trim().length > 0 || 'Please enter a value',\n },\n ]);\n\n return answers['value'] as string;\n}\n", "import chalk from \"chalk\";\n\nexport function formatBytes(bytes: number): string {\n if (bytes === 0) return \"0 B\";\n\n const k = 1024;\n const sizes = [\"B\", \"KB\", \"MB\", \"GB\", \"TB\"];\n const i = Math.floor(Math.log(bytes) / Math.log(k));\n\n return `${parseFloat((bytes / Math.pow(k, i)).toFixed(2))} ${sizes[i]}`;\n}\n\nexport function formatModelName(modelId: string): string {\n return modelId\n .replace(/^.*\\//, \"\")\n .replace(/[-_]/g, \" \")\n .replace(/\\b\\w/g, (c) => c.toUpperCase());\n}\n\nexport function truncate(str: string, maxLength: number): string {\n if (str.length <= maxLength) return str;\n return str.slice(0, maxLength - 3) + \"...\";\n}\n\nexport function promptSeparator(): void {\n console.log(chalk.dim(\"\u2500\".repeat(process.stdout.columns || 80)));\n}\n\nexport function success(message: string): void {\n console.log(chalk.green(\"\u2713\") + \" \" + message);\n}\n\nexport function error(message: string): void {\n console.error(chalk.red(\"\u2717\") + \" \" + message);\n}\n\nexport function info(message: string): void {\n console.log(chalk.blue(\"\u2139\") + \" \" + message);\n}\n\nexport function warn(message: string): void {\n console.log(chalk.yellow(\"\u26A0\") + \" \" + message);\n}\n\nexport function exitWithError(message: string, code: number = 1): never {\n error(message);\n process.exit(code);\n}\n", "import ora from 'ora';\nimport chalk from 'chalk';\nimport { lmStudioService } from '../services/lmstudio.js';\nimport { claudeService } from '../services/claude.js';\nimport { configService } from '../services/config.js';\nimport { selectModel, confirmAction } from '../utils/prompt.js';\nimport { exitWithError, success } from '../utils/format.js';\n\ninterface RunOptions {\n model?: string;\n verbose?: boolean;\n args?: string[];\n}\n\nexport async function runCommand(options: RunOptions = {}): Promise<void> {\n const spinner = ora({\n text: 'Checking LM Studio status...',\n color: 'cyan',\n }).start();\n\n let isRunning = await lmStudioService.checkStatus();\n\n if (!isRunning) {\n spinner.info('LM Studio server not running');\n spinner.stop();\n\n const shouldStart = await confirmAction('Would you like to start the LM Studio server?');\n\n if (!shouldStart) {\n exitWithError(\n 'LM Studio server must be running. Start it manually or use the Server tab in LM Studio.'\n );\n }\n\n await lmStudioService.startServer();\n isRunning = true;\n }\n\n spinner.succeed('Connected to LM Studio');\n\n spinner.text = 'Fetching available models...';\n const models = await lmStudioService.getAvailableModels();\n\n if (models.length === 0) {\n spinner.fail('No models found. Download some models in LM Studio first.');\n exitWithError('No models available');\n }\n\n spinner.stop();\n\n let selectedModelId: string;\n\n if (options.model) {\n const foundModel = models.find(\n (m) => m.id === options.model || m.name.toLowerCase().includes(options.model!.toLowerCase())\n );\n\n if (!foundModel) {\n exitWithError(\n `Model \"${options.model}\" not found. Available models: ${models.map((m) => m.name).join(', ')}`\n );\n }\n\n selectedModelId = foundModel.id;\n } else {\n const lastUsedModel = configService.getLastUsedModel();\n const selectedModel = await selectModel(models, lastUsedModel);\n selectedModelId = selectedModel.id;\n }\n\n const loadSpinner = ora({\n text: `Loading model: ${chalk.cyan(selectedModelId)}`,\n color: 'cyan',\n }).start();\n\n await lmStudioService.loadModel(selectedModelId, loadSpinner);\n\n const modelIdentifier = selectedModelId.replace('/', '--');\n const fullModelName = `lmstudio/${modelIdentifier}`;\n\n success(chalk.green(`\\nStarting Claude Code with model: ${fullModelName}\\n`));\n\n try {\n await claudeService.run({\n model: fullModelName,\n args: options.args ?? [],\n verbose: options.verbose,\n });\n } catch (error) {\n exitWithError(\n `Failed to run Claude Code: ${error instanceof Error ? error.message : 'Unknown error'}`\n );\n }\n}\n", "import chalk from \"chalk\";\nimport { lmStudioService } from \"../services/lmstudio.js\";\nimport { formatBytes } from \"../utils/format.js\";\n\nexport async function statusCommand(): Promise<void> {\n const status = await lmStudioService.getStatus();\n\n console.log();\n console.log(chalk.bold(\"LM Studio Status\"));\n console.log(chalk.dim(\"\u2500\".repeat(50)));\n console.log(\n ` ${status.running ? chalk.green(\"\u25CF\") : chalk.red(\"\u25CB\")} Server: ${status.running ? chalk.green(\"Running\") : chalk.red(\"Stopped\")}`,\n );\n console.log(` ${chalk.dim(\"\u25B8\")} Port: ${chalk.cyan(String(status.port))}`);\n console.log(\n ` ${chalk.dim(\"\u25B8\")} URL: ${chalk.cyan(`http://localhost:${status.port}`)}`,\n );\n\n if (status.activeModel) {\n console.log(\n ` ${chalk.dim(\"\u25B8\")} Active Model: ${chalk.green(status.activeModel)}`,\n );\n } else {\n console.log(` ${chalk.dim(\"\u25B8\")} Active Model: ${chalk.dim(\"None\")}`);\n }\n\n console.log();\n console.log(chalk.bold(\"Models\"));\n console.log(chalk.dim(\"\u2500\".repeat(50)));\n\n if (status.models.length === 0) {\n console.log(` ${chalk.dim(\"No models available\")}`);\n } else {\n status.models.forEach((model, index) => {\n const size = formatBytes(model.size);\n const loaded =\n model.id === status.activeModel ? ` ${chalk.green(\"[LOADED]\")}` : \"\";\n console.log(\n ` ${chalk.dim(String(index + 1) + \".\")} ${model.name}${loaded}`,\n );\n console.log(` ${chalk.dim(\"ID:\")} ${model.id}`);\n console.log(` ${chalk.dim(\"Size:\")} ${size}`);\n if (model.quantization) {\n console.log(` ${chalk.dim(\"Quantization:\")} ${model.quantization}`);\n }\n console.log();\n });\n }\n}\n"],
5
+ "mappings": "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",
6
+ "names": ["config_exports", "__export", "ConfigService", "configService", "Conf", "init_config", "__esmMin", "key", "value", "model", "host", "port", "lmstudio_exports", "__export", "LMStudioService", "lmStudioService", "execa", "ora", "chalk", "LMSTUDIO_PORTS", "init_lmstudio", "__esmMin", "init_config", "configService", "path", "endpoints", "endpoint", "response", "json", "models", "m", "model", "data", "modelId", "spinner", "loadSpinner", "error", "startSpinner", "isMac", "isLinux", "isWindows", "lmStudioPath", "possiblePaths", "p", "existsSync", "localAppData", "programFiles", "timeout", "startTime", "ms", "resolve", "port", "claude_exports", "__export", "ClaudeService", "claudeService", "execa", "chalk", "init_claude", "__esmMin", "options", "model", "args", "verbose", "provider", "modelName", "modelArg", "claudeArgs", "error", "exitCode", "parts", "Command", "chalk", "init_lmstudio", "init_config", "ora", "chalk", "inquirer", "selectModel", "models", "defaultModel", "choices", "model", "defaultIndex", "m", "confirmAction", "message", "defaultValue", "chalk", "formatBytes", "bytes", "k", "sizes", "i", "success", "message", "chalk", "error", "exitWithError", "message", "code", "error", "initCommand", "options", "spinner", "ora", "isRunning", "lmStudioService", "confirmAction", "exitWithError", "modelsSpinner", "models", "chalk", "model", "index", "size", "formatBytes", "loaded", "lastUsedModel", "configService", "modelSearch", "selectedModel", "m", "selectModel", "modelIdentifier", "success", "init_lmstudio", "init_claude", "init_config", "ora", "chalk", "runCommand", "options", "spinner", "ora", "isRunning", "lmStudioService", "confirmAction", "exitWithError", "models", "selectedModelId", "foundModel", "m", "lastUsedModel", "configService", "selectModel", "loadSpinner", "chalk", "fullModelName", "success", "claudeService", "error", "init_lmstudio", "chalk", "statusCommand", "status", "lmStudioService", "chalk", "model", "index", "size", "formatBytes", "loaded", "program", "Command", "initCommand", "args", "options", "runCommand", "statusCommand", "lmStudioService", "claudeService", "configService", "chalk", "lmStudioRunning", "claudeInstalled"]
7
7
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@iamharshil/aix-cli",
3
- "version": "1.1.4",
3
+ "version": "1.1.6",
4
4
  "description": "AI CLI tool that integrates LM Studio with Claude Code for enhanced development assistance",
5
5
  "keywords": [
6
6
  "cli",