ccommand 1.0.87 → 1.0.89
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +12 -2
- package/cli.mjs +1 -1
- package/dist/ccommand-BTvHS8S5.cjs +23 -0
- package/dist/ccommand-xkHK1_kY.mjs +23 -0
- package/dist/cli.cjs +1 -0
- package/dist/cli.d.mts +1 -0
- package/dist/cli.mjs +1 -0
- package/dist/index.cjs +1 -0
- package/dist/index.d.cts +4 -0
- package/dist/index.d.mts +6 -0
- package/dist/index.mjs +1 -0
- package/package.json +7 -6
- package/dist/ccommand-DbBDev6g.js +0 -23
- package/dist/cli.js +0 -1
- package/dist/index.d.ts +0 -5
- package/dist/index.js +0 -1
- /package/dist/{cli.d.ts → cli.d.cts} +0 -0
package/README.md
CHANGED
|
@@ -27,12 +27,22 @@ ccommand -help # 查看帮助 view help
|
|
|
27
27
|
```
|
|
28
28
|
# 导出环境变量在你的bash或者zsh中 Export environment variables in your bash or zsh
|
|
29
29
|
# 中文 Chinese
|
|
30
|
-
export
|
|
30
|
+
export PI_LANG=zh
|
|
31
31
|
# 英文 English
|
|
32
|
-
export
|
|
32
|
+
export PI_LANG=en
|
|
33
33
|
|
|
34
34
|
```
|
|
35
35
|
|
|
36
|
+
## 配置 | Config
|
|
37
|
+
|
|
38
|
+
```
|
|
39
|
+
# 禁用 gum 自动安装/交互选择 (也支持 NO_GUM)
|
|
40
|
+
export CCOMMAND_NO_GUM=1
|
|
41
|
+
|
|
42
|
+
# 禁用写入 shell history (也支持 NO_HISTORY)
|
|
43
|
+
export CCOMMAND_NO_HISTORY=1
|
|
44
|
+
```
|
|
45
|
+
|
|
36
46
|
## 新特性 | Feature
|
|
37
47
|
|
|
38
48
|
when you run command with search the quick command will be output with tips
|
package/cli.mjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
#!/usr/bin/env node --no-warnings
|
|
2
|
-
import('./dist/cli.
|
|
2
|
+
import('./dist/cli.mjs')
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
var e=Object.create,t=Object.defineProperty,n=Object.getOwnPropertyDescriptor,r=Object.getOwnPropertyNames,i=Object.getPrototypeOf,a=Object.prototype.hasOwnProperty,o=(e,i,o,s)=>{if(i&&typeof i==`object`||typeof i==`function`)for(var c=r(i),l=0,u=c.length,d;l<u;l++)d=c[l],!a.call(e,d)&&d!==o&&t(e,d,{get:(e=>i[e]).bind(null,d),enumerable:!(s=n(i,d))||s.enumerable});return e},s=(n,r,a)=>(a=n==null?{}:e(i(n)),o(r||!n||!n.__esModule?t(a,`default`,{value:n,enumerable:!0}):a,n));let c=require(`node:fs/promises`);c=s(c);let l=require(`node:path`);l=s(l);let u=require(`node:process`);u=s(u);let d=require(`@simon_he/colorize`);d=s(d);let f=require(`lazy-js-utils`),p=require(`lazy-js-utils/node`),m=require(`fast-glob`);m=s(m);let h=require(`node:child_process`),g=require(`node:util`),_=require(`node:buffer`),v=require(`node:os`);v=s(v);var y=`1.0.89`;const b=console.log,x=`__ccommand__split`,S=(u.default.env.PI_LANG||u.default.env.LANG||``).startsWith(`zh`),C=S?`已取消...`:`Cancelled...`,w=S?`当前目录并未找到 package.json 文件`:`package.json file not found in current directory`,T=S?`正在为您执行...`:`is running for you...`;function E(){return b(`[33m${C}[0m`),u.default.exit(130)}const D=/^[\w./:@%+=,-]+$/;function O(e){let t=[],n=``,r=null,i=!1,a=()=>{i&&=(t.push(n),n=``,!1)};for(let t=0;t<e.length;t++){let o=e[t];if(r){if(o===r){r=null,i=!0;continue}if(r===`"`&&o===`\\`){let r=e[t+1];if(r){n+=r,i=!0,t++;continue}}n+=o,i=!0;continue}if(o===`"`||o===`'`){r=o,i=!0;continue}if(/\s/.test(o)){for(a();t+1<e.length&&/\s/.test(e[t+1]);)t++;continue}if(o===`\\`){let r=e[t+1];if(r){n+=r,i=!0,t++;continue}}n+=o,i=!0}return a(),t}function ee(e){if(!e)return[];if(Array.isArray(e))return e;let t=e.trim();return t?O(t):[]}function k(e){return e===``?`''`:D.test(e)?e:`'${e.replace(/'/g,`'\\''`)}'`}function A(e){return e.filter(e=>typeof e==`string`).map(k).join(` `)}function j(e){return D.test(e)}function te(e){let t=e[0];if(!t)return[``,``,[]];let n=e.indexOf(`--`);if(n!==-1){let t=e.slice(0,n),r=e.slice(n+1),i=t[0]||``,a=t[1]||``,o=t.slice(2);return i.startsWith(`-`)?[``,``,e.slice()]:[i,a,[...o,...r]]}return t.startsWith(`-`)?[``,``,e.slice()]:e[1]&&e[1].startsWith(`-`)?[t,``,e.slice(1)]:[t,e[1]||``,e.slice(2)]}function ne(e){return e.replace(/[.*+?^${}()|[\]\\]/g,`\\$&`)}function M(e,t){let n=Object.keys(e),r=n.find(e=>e.startsWith(t));if(r)return r;try{if(!t)return;let e=t.split(``).map(e=>ne(e)).join(`[_-\\w$.:]*`),r=new RegExp(e);return n.find(e=>r.test(e))}catch(e){b(`${S?`正则错误`:`RegExp error`}: ${e}`),u.default.exit(1)}}async function re(e){let{termStart:t,params:n,dirname:r,argv:i,val:a,isZh:o,pushHistory:s,jsShell:c,isNeedPrefix:l,fuzzyWorkspace:u}=e,d=[...n||[]],f=``;t!==`npm`&&d.length&&!d[0].startsWith(`--`)&&(f=d[0],d=d.slice(1));let p=f||a||u||``;a=`${p}`;let m=l(d)&&d.length>0&&d[0]!==`--`,h=[];if(t===`npm`){h.push(`run`),r&&h.push(`--prefix`,r),p&&h.push(p);let e=[...d];e[0]===`--`&&e.shift(),e.length&&h.push(`--`,...e)}else t===`pnpm`?(h.push(`run`),r&&h.push(`--filter`,r),p&&h.push(p),m&&h.push(`--`),h.push(...d)):t===`yarn`?(r&&h.push(`workspace`,r),p&&h.push(p),m&&h.push(`--`),h.push(...d)):t===`bun`?(h.push(`run`),p&&h.push(p),m&&h.push(`--`),h.push(...d)):t===`make`&&(p&&h.push(p),m&&h.push(`--`),h.push(...d));let g=A([t,...h]),_=[];return i[0]===`find`?(_.push(`pfind`),r&&_.push(r)):_.push(`prun`),p&&_.push(p),_.push(...d),await s(A(_)),{command:g,text:_.map((e,t)=>t===_.length-1&&j(e)?`'${e}'`:k(e)).join(` `),val:a}}let N=null,P=[],F=null,I=null;function L(){return P}async function ie(e){let t=e===`pnpm`?l.default.resolve(u.default.cwd(),`pnpm-workspace.yaml`):l.default.resolve(u.default.cwd(),`package.json`);try{try{I=(await c.default.stat(t)).mtimeMs}catch{}return await c.default.readFile(t,`utf-8`)}catch{return``}}async function ae(e,t){if(!t)return[];if(e===`pnpm`)try{if(!N){let e=await import(`yamljs`);N=e&&e.default||e}let e=N.parse(t)?.packages;return Array.isArray(e)?e.filter(Boolean):[]}catch{return[]}try{let e=JSON.parse(t)?.workspaces;return(0,f.isPlainObject)(e)?e?.packages||[]:Array.isArray(e)?e:[]}catch{return[]}}async function oe(e){if(!e.length)return{};let t=await(0,m.default)(e.map(e=>`${e}/package.json`),{dot:!0,ignore:[`**/node_modules/**`]});return(await Promise.all(t.map(async e=>{try{let t=await(0,p.getPkg)(e);if(!t)return null;let{name:n,scripts:r}=t;return{name:n,scripts:r}}catch{return null}}))).reduce((e,t)=>(!t||!t.name||!t.scripts||(e[t.name]=Object.keys(t.scripts).reduce((e,n)=>(n.startsWith(`//`)||(e[n]=t.scripts[n]),e),{})),e),{})}async function se(e){if(F)try{let t=e===`pnpm`?l.default.resolve(u.default.cwd(),`pnpm-workspace.yaml`):l.default.resolve(u.default.cwd(),`package.json`),n=await c.default.stat(t);if(I&&n.mtimeMs<=I)return F}catch{return F}return F=await oe(await ae(e,await ie(e)))||{},P=Object.keys(F).filter(e=>F&&F[e]&&Object.keys(F[e]).length),F}async function R(e){return se(e)}const z=(0,f.memorizeFn)(p.getPkg),B={};async function ce(e,t){try{let n=e||`root`;if(B[n])return B[n];let r;return!e||t===`bun`||t===`npm`?r=(await z(`./package.json`))?.scripts:(t===`pnpm`||t===`yarn`)&&(r=(await R(t))[e]||(await z(`${e}/package.json`))?.scripts),r&&(B[n]=r),r}catch{return null}}async function le(e,t,n,r,i,a,o,s,c,l){let u,d=``,f=r[0]?.trim(),p=A([t,...n]),m=A([t||r[0]||``,...n]);t&&f&&f!==t?console.log(o({text:`🤔 ${o({text:`'${r[0]}'`,color:`cyan`})} ${s?`自动的为您匹配成`:`automatically match for you`} ${o({text:`'${p}'`,color:`cyan`})} `,color:`yellow`})):t&&console.log(o({text:`🤔 is running for you... ${p}`,color:`magenta`}));let h=()=>{switch(e){case`npm`:{let e=[`run`,t];return n.length&&(n[0]!==`--`&&e.push(`--`),e.push(...n)),A([`npm`,...e])}case`pnpm`:return A([`pnpm`,`run`,t,...n]);case`yarn`:return A([`yarn`,t,...n]);case`bun`:return A([`bun`,`run`,t,...n]);case`make`:return A([`make`,t,...n]);default:return A([t,...n])}},g=()=>{let e=[`run`,t];return n.length&&(n[0]!==`--`&&e.push(`--`),e.push(...n)),A([`npm`,...e])};switch(e){case`npm`:{let{status:e,result:t}=await a(h(),{errorExit:!1,isLog:!1,stdio:`inherit`});u=e,d=t;break}case`pnpm`:{let{status:e,result:t=``}=await a(h(),{errorExit:!1,isLog:!1,stdio:`inherit`});if(d=t,u=e,d.includes(`pnpm versions with respective Node.js version support`)){console.log(o({text:s?`正在尝试使用 npm 再次执行...`:`Trying to use npm to run again...`,color:`yellow`}));let{status:e,result:t}=await a(g(),{errorExit:!1,isLog:!1,stdio:`inherit`});u=e,d=t}break}case`yarn`:{let{status:e,result:t}=await a(h(),{errorExit:!1,isLog:!1,stdio:`inherit`});u=e,d=t;break}case`bun`:{let{status:e,result:t}=await a(h(),{errorExit:!1,isLog:!1,stdio:`inherit`});u=e,d=t;break}case`make`:{let{status:e,result:t}=await a(h(),{errorExit:!1,isLog:!1,stdio:`inherit`});u=e,d=t;break}}if(u===0){let e=A([`prun`,t,...n]);return await i(e),console.log(o({color:`green`,text:`\n${e} ${c} 🎉`}))}return console.log(o({color:`red`,text:`\ncommand ${o({bold:!0,color:`cyan`,text:`'${m}'`})} ${l} ❌`}))}let V=null;async function ue(){return V||(V=(await import(`@simon_he/colorize`)).default,V)}const H=new Map;function de(){let e=(u.default.env.CCOMMAND_NO_HISTORY||u.default.env.NO_HISTORY||``).toLowerCase();return e===`1`||e===`true`||e===`yes`}async function U(e){if(de())return;let t=await ue();b(t({text:`${S?`快捷指令`:`shortcut command`}: ${e}`,color:`blue`,bold:!0}));let n=(u.default.env.SHELL||`/bin/bash`).split(`/`).pop()||`bash`,r=``,i=`bash`,a=u.default.env.HOME||v.default.homedir();switch(n){case`zsh`:r=l.default.join(a,`.zsh_history`),i=`zsh`;break;case`bash`:r=u.default.env.HISTFILE||l.default.join(a,`.bash_history`),i=`bash`;break;case`fish`:r=l.default.join(a,`.local`,`share`,`fish`,`fish_history`),i=`fish`;break;default:r=u.default.env.HISTFILE||l.default.join(a,`.bash_history`),i=`bash`}try{try{await c.default.access(r)}catch{b(t({text:`${S?`未找到 ${n} 历史文件`:`${n} history file not found`}`,color:`yellow`}));return}let a=await c.default.stat(r).catch(()=>null),o=Math.floor(Date.now()/1e3),s=``;s=i===`zsh`?`: ${o}:0;${e}`:i===`fish`?`- cmd: ${e}\n when: ${o}`:u.default.env.HISTTIMEFORMAT?`#${o}\n${e}`:e;function l(e){if(i===`fish`){let t=e.split(/\r?\n/),n=[],r=[];for(let e of t)e.startsWith(`- cmd: `)?(r.length&&(n.push(r.join(`
|
|
2
|
+
`)),r=[]),r.push(e)):r.length?r.push(e):e.trim()!==``&&n.push(e);return r.length&&n.push(r.join(`
|
|
3
|
+
`)),n.filter(Boolean)}else if(i===`zsh`)return e.split(/\r?\n/).map(e=>e.trim()).filter(Boolean);else{let t=e.split(/\r?\n/),n=[];for(let e=0;e<t.length;e++){let r=t[e];if(r.startsWith(`#`)){let i=t[e+1]??``;n.push(`${r}\n${i}`),e++}else r.trim()!==``&&n.push(r)}return n}}let d=[],f=H.get(r);d=f&&a&&f.mtimeMs===a.mtimeMs&&f.size===a.size&&f.format===i?f.entries.slice():l(await c.default.readFile(r,`utf8`));function p(e){if(i===`fish`){let t=e.split(`
|
|
4
|
+
`)[0].match(/^- cmd: (.*)$/);return(t?t[1]:e).trim()}else if(i===`zsh`){let t=e.match(/^[^;]*;(.+)$/);return(t?t[1]:e).trim()}else{if(e.startsWith(`#`)){let t=e.split(/\r?\n/);return(t[1]??t[0]).trim()}return e.trim()}}let m=[],h=p(s),g=null;for(let e of d){if(p(e)===h){if(i===`fish`){g=e;continue}continue}m.push(e)}if(i===`fish`&&g){let e=g.split(`
|
|
5
|
+
`),t=!1,n=e.map(e=>e.trim().startsWith(`when:`)||e.startsWith(` when:`)?(t=!0,` when: ${o}`):e);t||n.splice(1,0,` when: ${o}`),m.push(n.join(`
|
|
6
|
+
`))}else m.push(s);let v=``;v=i===`fish`?`${m.map(e=>e.trimEnd()).join(`
|
|
7
|
+
`)}\n`:`${m.join(`
|
|
8
|
+
`)}\n`;let y=`${r}.ccommand.tmp`;await c.default.writeFile(y,v,`utf8`),await c.default.rename(y,r);try{let e=await c.default.stat(r);H.set(r,{mtimeMs:e.mtimeMs,size:e.size,entries:m,format:i})}catch{H.set(r,{mtimeMs:Date.now(),size:_.Buffer.byteLength(v),entries:m,format:i})}}catch(e){b(t({text:`${S?`❌ 添加到 ${n} 历史记录失败`:`❌ Failed to add to ${n} history`}${e?`: ${String(e)}`:``}`,color:`red`}))}}const fe=(0,g.promisify)(h.exec),W={};async function G(e){if(W[e]!==void 0)return W[e];try{return await fe(`command -v ${e}`),W[e]=!0,!0}catch{return W[e]=!1,!1}}let K=null;async function pe(){return K===null&&(K=await G(`bun`)?`bun`:await G(`esno`)?`esno`:await G(`tsx`)?`tsx`:null),K}async function q(e,t,n,r){let i=A([`prun`,e]);await U(i);let{status:a}=await(0,p.jsShell)(t,{errorExit:!1,isLog:!1,stdio:`inherit`}),o=a===0;return o||(u.default.exitCode=a??1),b((0,d.default)({color:o?`green`:`red`,text:`\n"${i}" ${o?n:r} ${o?`🎉`:`❌`}`})),o}async function J(e,t,n){let r=l.default.extname(e),i=`node`;if(r===`.ts`)if(K===null&&await pe(),K)i=K;else return b((0,d.default)({text:S?`没有找到可以直接执行TypeScript的工具,推荐安装下列工具之一:
|
|
9
|
+
- npm install -g bun
|
|
10
|
+
- npm install -g esno
|
|
11
|
+
- npm install -g tsx`:`No TypeScript executor found. Recommend installing one of:
|
|
12
|
+
- npm install -g bun
|
|
13
|
+
- npm install -g esno
|
|
14
|
+
- npm install -g tsx`,color:`yellow`})),u.default.exitCode=1,!1;return q(e,A([i,e]),t,n)}async function me(e,t,n){let r=[`.js`,`.ts`,`.mjs`,`.cjs`],i=l.default.extname(e);if(i&&r.includes(i)&&await c.default.stat(e).then(e=>e.isFile()).catch(()=>!1))return await J(e,t,n),!0;if(!i)for(let i of r){let r=`${e}${i}`;if(await c.default.stat(r).then(e=>e.isFile()).catch(()=>!1))return await J(r,t,n),!0}let a=await c.default.stat(e).catch(()=>null);if(a&&a.isDirectory())for(let i of r){let r=l.default.join(e,`index${i}`);if(await c.default.stat(r).then(e=>e.isFile()).catch(()=>!1))return await J(r,t,n),!0}return!1}async function he(e,t,n){e.endsWith(`.py`)?await q(e,`python ${e}`,t,n):e.endsWith(`.rs`)&&((await(0,p.jsShell)(`rustc ${e}`)).status===0&&(await(0,p.jsShell)(`./${l.default.basename(e,`.rs`)}`,{stdio:`inherit`})).status===0?(await U(`prun ${e}`),b((0,d.default)({color:`green`,text:`\n"prun ${e}" ${t} 🎉`}))):b((0,d.default)({color:`red`,text:`\ncommand "prun ${e}" ${n} ❌`})))}const Y=console.log;let X=null;async function Z(){return X||(X=(await import(`@simon_he/colorize`)).default,X)}function ge(){let e=(u.default.env.CCOMMAND_NO_GUM||u.default.env.NO_GUM||``).toLowerCase();return e===`1`||e===`true`||e===`yes`}function _e(){return!!(u.default.stdin.isTTY&&u.default.stdout.isTTY)}async function ve(e){if(ge()||!_e()||u.default.env.CI)return!1;try{if((await(0,p.jsShell)(`gum -v`,{stdio:`pipe`,errorExit:!1})).status===0)return!0;if(Y((await Z())({color:`blue`,text:e?`正在为您安装gum...`:`install gum...`})),(await(0,p.jsShell)(`brew install gum`,{errorExit:!1})).status===0||(await(0,p.jsShell)(`sudo mkdir -p /etc/apt/keyrings && curl -fsSL https://repo.charm.sh/apt/gpg.key | sudo gpg --dearmor -o /etc/apt/keyrings/charm.gpg && echo "deb [signed-by=/etc/apt/keyrings/charm.gpg] https://repo.charm.sh/apt/ * *" | sudo tee /etc/apt/sources.list.d/charm.list && sudo apt update && sudo apt install -y gum`,{errorExit:!1})).status===0)return Y((await Z())({color:`green`,text:e?`gum安装成功 🎉`:`gum install successfully 🎉`})),!0;let t=(await import(`terminal-link`)).default,n=t(e?`gum官网链接`:`the official website of gum`,`https://github.com/charmbracelet/gum#installation`),r=await Z();return Y(r({color:`red`,text:`${e?`gum安装失败,你可以自行从以下链接安装`:`gum install error, you can install it yourself through`} ${r({color:`yellow`,text:n,bold:!0})}`})),!1}catch(e){return Y((await Z())({color:`red`,text:`gum install check failed: ${String(e)}`})),!1}}async function Q(e){return ve(e)}async function ye(e){try{let t=(await c.default.readFile(e,`utf-8`)).split(/\r?\n/),n=new Set;for(let e=0;e<t.length;e++){let r=t[e].trim();if(r.startsWith(`.PHONY:`)){let e=r.substring(7).replace(/\\\\$/g,``).trim();for(let t of e.split(/\s+/))t&&n.add(t)}}let r=[];for(let e of n){let n=``;for(let r=0;r<t.length;r++){let i=t[r];if(!i)continue;let a=i.trimStart();if(a.startsWith(`${e}:`)||a.startsWith(`${e} :`)){let e=a.split(`:`,2)[1]||``,i=e.indexOf(`;`);if(i!==-1&&(n=e.slice(i+1).trim()),!n&&r+1<t.length){let e=t[r+1];e.startsWith(` `)&&(n=e.trim())}if(!n){let t=e.trim();n=t?t.replace(/\s+/g,` `).slice(0,120):``}break}}r.push({name:e,detail:n?`${n}...`:``})}return r}catch{return[]}}const be=(0,f.memorizeFn)(p.getPkg),xe=ce,Se=re,$=le;function Ce(e,t,n){return!!(n[1]&&t.length)}async function we(e=u.default.argv.slice(2)){let t=S?`当前目录不存在任何子目录`:`The current directory does not have any subdirectories`,n=S?`运行成功`:`run successfully`,r=S?`运行失败`:`run error`,i=ee(e);if(i[0]===`-v`||i[0]===`--version`)return b((0,d.default)({text:S?`ccommand 当前版本: ${y}`:`ccommand Version: ${y}`,color:`green`}));if(i[0]===`-h`||i[0]===`--help`){let e=(await import(`terminal-link`)).default,t=e(S?`打开一个新的问题`:`open an issue`,`https://github.com/Simon-He95/ccommand/issues`),n=e(S?`✨帮助点一个星星`:`✨star it`,`https://github.com/Simon-He95/ccommand`);return b((0,d.default)({color:`white`,text:`
|
|
15
|
+
${(0,d.default)({bold:!0,text:`Common Commands:`,bgColor:`blue`})}
|
|
16
|
+
${(0,d.default)({text:`- ccommand -v 查看当前版本
|
|
17
|
+
- ccommand -help 查看帮助
|
|
18
|
+
- ccommand 执行当前package.json
|
|
19
|
+
- ccommand find 查找当前workspace的所有目录
|
|
20
|
+
`,color:`cyan`})}
|
|
21
|
+
If you encounter any problems, you can ${(0,d.default)({color:`magenta`,text:t})}.
|
|
22
|
+
If you like it, please ${(0,d.default)({text:n,bold:!0,color:`cyan`})} `}))}else if(i[0]?.endsWith(`.py`)||i[0]?.endsWith(`.rs`)){await he(i[0],n,r);return}let a;try{a=await(0,p.getPkgTool)()}catch{try{if(await c.default.readFile(l.default.resolve(u.default.cwd(),`./Makefile`),`utf-8`)){a=`make`;let e=await ye(`./Makefile`),t=e.reduce((e,t)=>{let{name:n,detail:r}=t;return e[n]=r,e},{}),o=``,s=[];if(i.length){let e=i[0];if(s=i.slice(1),o=M(t,e)||``,!o)return b((0,d.default)({color:`red`,text:w}))}else{if(!await Q(S))return b((0,d.default)({color:`yellow`,text:S?`未检测到可用的交互环境或 gum 已被禁用,请直接传入 make 目标名称`:`Gum is unavailable (non-interactive or disabled). Please pass a make target explicitly.`}));let{result:t,status:n}=await(0,p.jsShell)(`echo "${e.map(e=>e.name).join(`
|
|
23
|
+
`)}" | gum filter --placeholder=" 🤔请选择一个要执行的指令"`,`pipe`);if(n===130)return E();o=t}await $(a,o.trim(),s,i,U,p.jsShell,d.default,S,n,r);return}else return b((0,d.default)({color:`red`,text:w}))}catch{if(i[0]!==`find`)return b((0,d.default)({color:`red`,text:w}))}}let[o,s,f]=te(i),m=o,h;if(i[0]===`find`){if(s)await R(a),m=L().filter(e=>e.includes(s))[0];else if(a===`yarn`){if(await R(a),!L().length)return b((0,d.default)({color:`yellow`,text:t}));if(!await Q(S))return b((0,d.default)({color:`yellow`,text:S?`未检测到可用的交互环境或 gum 已被禁用,请直接传入 workspace 名称`:`Gum is unavailable (non-interactive or disabled). Please pass a workspace name explicitly.`}));let{result:e,status:n}=await(0,p.jsShell)(`echo ${L().join(`,`)} | sed "s/,/\\n/g" | gum filter --placeholder=" 🤔${S?`请选择一个要执行的目录`:`Please select a directory to execute`}"`,[`inherit`,`pipe`,`inherit`]);if(m=e,n===130)return E()}else if(a===`pnpm`){if(await R(a),!L().length)return b((0,d.default)({color:`yellow`,text:t}));if(!await Q(S))return b((0,d.default)({color:`yellow`,text:S?`未检测到可用的交互环境或 gum 已被禁用,请直接传入 workspace 名称`:`Gum is unavailable (non-interactive or disabled). Please pass a workspace name explicitly.`}));let{result:e,status:n}=await(0,p.jsShell)(`echo ${L().join(`,`)} | sed "s/,/\\n/g" | gum filter --placeholder=" 🤔${S?`请选择一个要执行的目录`:`Please select a directory to execute`}"`,[`inherit`,`pipe`,`inherit`]);if(n===130)return E();m=e.trim()}else return b((0,d.default)({color:`red`,text:S?`find指令只能支持在yarn或pnpm的monorepo模式下使用`:`find command only support yarn or pnpm`}));h=await xe(m,a)||void 0}else{h=await xe(m,a)||void 0;try{let e=(await be(`./package.json`)||{})?.scripts;if(e&&e[i[0]]){await $(a,i[0],i.slice(1),i,U,p.jsShell,d.default,S,n,r);return}else if(e&&o){let t=M(e,i[0]);if(t){let e=i.slice(1);await $(a,t,e,i,U,p.jsShell,d.default,S,n,r);return}else{if(await me(i[0],n,r))return;let e=`${o}.py`;if(await c.default.stat(e).then(e=>e.isFile()).catch(()=>!1)){b((0,d.default)({text:`🤔 ${S?`找到Python文件`:`Found Python file`}: ${e}`,color:`yellow`}));return}let t=`${o}.rs`;if(await c.default.stat(t).then(e=>e.isFile()).catch(()=>!1))return;b((0,d.default)({color:`red`,text:`"${i[0]}" ${S?`在工作区、当前目录中找不到任何可执行的脚本或文件,请检查`:`is not found in workspace, current directory or current scripts, please check`}`})),u.default.exit(1)}}}catch{}}if(!h)return b((0,d.default)({color:`red`,text:S?`找不到任何可执行脚本`:`No scripts found`}));let g=[],_=``;if(!s||i[0]===`find`&&(!i[2]||i[2].startsWith(`--`))){let e=Object.keys(h).reduce((e,t)=>{let n=h?.[t]??``;return g.push(t),e+=`"${t}: ${n.replace(/\\/g,`\\\\`).replace(/(["`])/g,`\\$1`)}"${x}`,e},``);if(!await Q(S))return b((0,d.default)({color:`yellow`,text:S?`未检测到可用的交互环境或 gum 已被禁用,请直接传入脚本名称`:`Gum is unavailable (non-interactive or disabled). Please pass a script name explicitly.`}));let{result:t,status:n}=await(0,p.jsShell)(`echo ${e} | sed "s/${x}/\\n/g" | gum filter --placeholder=" 🤔请选择一个要执行的指令"`,{stdio:[`inherit`,`pipe`,`inherit`],isLog:!1});if(n===130)return E();_=t.substring(0,t.indexOf(`: `))}if(!s&&!_)return E();b((0,d.default)({text:`🤔 ${T} ${_}`,color:`magenta`}));let{command:v,text:C,val:D}=await Se({termStart:a,params:f,dirname:m,argv:i,val:_,runMsg:T,isZh:S,pushHistory:U,jsShell:p.jsShell,isNeedPrefix:e=>Ce(i[0],e,i),fuzzyWorkspace:s}),O=v;_=D;let{status:k,result:j=``}=await(0,p.jsShell)(O,{errorExit:!1,stdio:`inherit`});if(k===0)return b((0,d.default)({color:`green`,text:`\n${C} 🎉`}));if(j.includes(`pnpm versions with respective Node.js version support`)){b((0,d.default)({text:S?`正在尝试使用 npm 再次执行...`:`Trying to use npm to run again...`,color:`yellow`}));let e=[...f];e[0]===`--`&&e.shift();let{status:t}=await(0,p.jsShell)(A([`npm`,`run`,_,...e.length?[`--`,...e]:[]]),`inherit`);if(t===0)return b((0,d.default)({color:`green`,text:`\n${C} 🎉`}))}b((0,d.default)({color:`red`,text:`\ncommand '${_}' ${r} ❌`}))}Object.defineProperty(exports,`t`,{enumerable:!0,get:function(){return we}});
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import e from"node:fs/promises";import t from"node:path";import n from"node:process";import r from"@simon_he/colorize";import{isPlainObject as i,memorizeFn as a}from"lazy-js-utils";import{getPkg as o,getPkgTool as s,jsShell as c}from"lazy-js-utils/node";import l from"fast-glob";import{exec as u}from"node:child_process";import{promisify as d}from"node:util";import{Buffer as f}from"node:buffer";import p from"node:os";var m=`1.0.89`;const h=console.log,g=`__ccommand__split`,_=(n.env.PI_LANG||n.env.LANG||``).startsWith(`zh`),v=_?`已取消...`:`Cancelled...`,y=_?`当前目录并未找到 package.json 文件`:`package.json file not found in current directory`,b=_?`正在为您执行...`:`is running for you...`;function x(){return h(`[33m${v}[0m`),n.exit(130)}const S=/^[\w./:@%+=,-]+$/;function C(e){let t=[],n=``,r=null,i=!1,a=()=>{i&&=(t.push(n),n=``,!1)};for(let t=0;t<e.length;t++){let o=e[t];if(r){if(o===r){r=null,i=!0;continue}if(r===`"`&&o===`\\`){let r=e[t+1];if(r){n+=r,i=!0,t++;continue}}n+=o,i=!0;continue}if(o===`"`||o===`'`){r=o,i=!0;continue}if(/\s/.test(o)){for(a();t+1<e.length&&/\s/.test(e[t+1]);)t++;continue}if(o===`\\`){let r=e[t+1];if(r){n+=r,i=!0,t++;continue}}n+=o,i=!0}return a(),t}function ee(e){if(!e)return[];if(Array.isArray(e))return e;let t=e.trim();return t?C(t):[]}function w(e){return e===``?`''`:S.test(e)?e:`'${e.replace(/'/g,`'\\''`)}'`}function T(e){return e.filter(e=>typeof e==`string`).map(w).join(` `)}function E(e){return S.test(e)}function te(e){let t=e[0];if(!t)return[``,``,[]];let n=e.indexOf(`--`);if(n!==-1){let t=e.slice(0,n),r=e.slice(n+1),i=t[0]||``,a=t[1]||``,o=t.slice(2);return i.startsWith(`-`)?[``,``,e.slice()]:[i,a,[...o,...r]]}return t.startsWith(`-`)?[``,``,e.slice()]:e[1]&&e[1].startsWith(`-`)?[t,``,e.slice(1)]:[t,e[1]||``,e.slice(2)]}function D(e){return e.replace(/[.*+?^${}()|[\]\\]/g,`\\$&`)}function O(e,t){let r=Object.keys(e),i=r.find(e=>e.startsWith(t));if(i)return i;try{if(!t)return;let e=t.split(``).map(e=>D(e)).join(`[_-\\w$.:]*`),n=new RegExp(e);return r.find(e=>n.test(e))}catch(e){h(`${_?`正则错误`:`RegExp error`}: ${e}`),n.exit(1)}}async function k(e){let{termStart:t,params:n,dirname:r,argv:i,val:a,isZh:o,pushHistory:s,jsShell:c,isNeedPrefix:l,fuzzyWorkspace:u}=e,d=[...n||[]],f=``;t!==`npm`&&d.length&&!d[0].startsWith(`--`)&&(f=d[0],d=d.slice(1));let p=f||a||u||``;a=`${p}`;let m=l(d)&&d.length>0&&d[0]!==`--`,h=[];if(t===`npm`){h.push(`run`),r&&h.push(`--prefix`,r),p&&h.push(p);let e=[...d];e[0]===`--`&&e.shift(),e.length&&h.push(`--`,...e)}else t===`pnpm`?(h.push(`run`),r&&h.push(`--filter`,r),p&&h.push(p),m&&h.push(`--`),h.push(...d)):t===`yarn`?(r&&h.push(`workspace`,r),p&&h.push(p),m&&h.push(`--`),h.push(...d)):t===`bun`?(h.push(`run`),p&&h.push(p),m&&h.push(`--`),h.push(...d)):t===`make`&&(p&&h.push(p),m&&h.push(`--`),h.push(...d));let g=T([t,...h]),_=[];return i[0]===`find`?(_.push(`pfind`),r&&_.push(r)):_.push(`prun`),p&&_.push(p),_.push(...d),await s(T(_)),{command:g,text:_.map((e,t)=>t===_.length-1&&E(e)?`'${e}'`:w(e)).join(` `),val:a}}let A=null,j=[],M=null,N=null;function P(){return j}async function F(r){let i=r===`pnpm`?t.resolve(n.cwd(),`pnpm-workspace.yaml`):t.resolve(n.cwd(),`package.json`);try{try{N=(await e.stat(i)).mtimeMs}catch{}return await e.readFile(i,`utf-8`)}catch{return``}}async function ne(e,t){if(!t)return[];if(e===`pnpm`)try{if(!A){let e=await import(`yamljs`);A=e&&e.default||e}let e=A.parse(t)?.packages;return Array.isArray(e)?e.filter(Boolean):[]}catch{return[]}try{let e=JSON.parse(t)?.workspaces;return i(e)?e?.packages||[]:Array.isArray(e)?e:[]}catch{return[]}}async function I(e){if(!e.length)return{};let t=await l(e.map(e=>`${e}/package.json`),{dot:!0,ignore:[`**/node_modules/**`]});return(await Promise.all(t.map(async e=>{try{let t=await o(e);if(!t)return null;let{name:n,scripts:r}=t;return{name:n,scripts:r}}catch{return null}}))).reduce((e,t)=>(!t||!t.name||!t.scripts||(e[t.name]=Object.keys(t.scripts).reduce((e,n)=>(n.startsWith(`//`)||(e[n]=t.scripts[n]),e),{})),e),{})}async function re(r){if(M)try{let i=r===`pnpm`?t.resolve(n.cwd(),`pnpm-workspace.yaml`):t.resolve(n.cwd(),`package.json`),a=await e.stat(i);if(N&&a.mtimeMs<=N)return M}catch{return M}return M=await I(await ne(r,await F(r)))||{},j=Object.keys(M).filter(e=>M&&M[e]&&Object.keys(M[e]).length),M}async function L(e){return re(e)}const R=a(o),z={};async function ie(e,t){try{let n=e||`root`;if(z[n])return z[n];let r;return!e||t===`bun`||t===`npm`?r=(await R(`./package.json`))?.scripts:(t===`pnpm`||t===`yarn`)&&(r=(await L(t))[e]||(await R(`${e}/package.json`))?.scripts),r&&(z[n]=r),r}catch{return null}}async function ae(e,t,n,r,i,a,o,s,c,l){let u,d=``,f=r[0]?.trim(),p=T([t,...n]),m=T([t||r[0]||``,...n]);t&&f&&f!==t?console.log(o({text:`🤔 ${o({text:`'${r[0]}'`,color:`cyan`})} ${s?`自动的为您匹配成`:`automatically match for you`} ${o({text:`'${p}'`,color:`cyan`})} `,color:`yellow`})):t&&console.log(o({text:`🤔 is running for you... ${p}`,color:`magenta`}));let h=()=>{switch(e){case`npm`:{let e=[`run`,t];return n.length&&(n[0]!==`--`&&e.push(`--`),e.push(...n)),T([`npm`,...e])}case`pnpm`:return T([`pnpm`,`run`,t,...n]);case`yarn`:return T([`yarn`,t,...n]);case`bun`:return T([`bun`,`run`,t,...n]);case`make`:return T([`make`,t,...n]);default:return T([t,...n])}},g=()=>{let e=[`run`,t];return n.length&&(n[0]!==`--`&&e.push(`--`),e.push(...n)),T([`npm`,...e])};switch(e){case`npm`:{let{status:e,result:t}=await a(h(),{errorExit:!1,isLog:!1,stdio:`inherit`});u=e,d=t;break}case`pnpm`:{let{status:e,result:t=``}=await a(h(),{errorExit:!1,isLog:!1,stdio:`inherit`});if(d=t,u=e,d.includes(`pnpm versions with respective Node.js version support`)){console.log(o({text:s?`正在尝试使用 npm 再次执行...`:`Trying to use npm to run again...`,color:`yellow`}));let{status:e,result:t}=await a(g(),{errorExit:!1,isLog:!1,stdio:`inherit`});u=e,d=t}break}case`yarn`:{let{status:e,result:t}=await a(h(),{errorExit:!1,isLog:!1,stdio:`inherit`});u=e,d=t;break}case`bun`:{let{status:e,result:t}=await a(h(),{errorExit:!1,isLog:!1,stdio:`inherit`});u=e,d=t;break}case`make`:{let{status:e,result:t}=await a(h(),{errorExit:!1,isLog:!1,stdio:`inherit`});u=e,d=t;break}}if(u===0){let e=T([`prun`,t,...n]);return await i(e),console.log(o({color:`green`,text:`\n${e} ${c} 🎉`}))}return console.log(o({color:`red`,text:`\ncommand ${o({bold:!0,color:`cyan`,text:`'${m}'`})} ${l} ❌`}))}let B=null;async function oe(){return B||(B=(await import(`@simon_he/colorize`)).default,B)}const V=new Map;function se(){let e=(n.env.CCOMMAND_NO_HISTORY||n.env.NO_HISTORY||``).toLowerCase();return e===`1`||e===`true`||e===`yes`}async function H(r){if(se())return;let i=await oe();h(i({text:`${_?`快捷指令`:`shortcut command`}: ${r}`,color:`blue`,bold:!0}));let a=(n.env.SHELL||`/bin/bash`).split(`/`).pop()||`bash`,o=``,s=`bash`,c=n.env.HOME||p.homedir();switch(a){case`zsh`:o=t.join(c,`.zsh_history`),s=`zsh`;break;case`bash`:o=n.env.HISTFILE||t.join(c,`.bash_history`),s=`bash`;break;case`fish`:o=t.join(c,`.local`,`share`,`fish`,`fish_history`),s=`fish`;break;default:o=n.env.HISTFILE||t.join(c,`.bash_history`),s=`bash`}try{try{await e.access(o)}catch{h(i({text:`${_?`未找到 ${a} 历史文件`:`${a} history file not found`}`,color:`yellow`}));return}let t=await e.stat(o).catch(()=>null),c=Math.floor(Date.now()/1e3),l=``;l=s===`zsh`?`: ${c}:0;${r}`:s===`fish`?`- cmd: ${r}\n when: ${c}`:n.env.HISTTIMEFORMAT?`#${c}\n${r}`:r;function u(e){if(s===`fish`){let t=e.split(/\r?\n/),n=[],r=[];for(let e of t)e.startsWith(`- cmd: `)?(r.length&&(n.push(r.join(`
|
|
2
|
+
`)),r=[]),r.push(e)):r.length?r.push(e):e.trim()!==``&&n.push(e);return r.length&&n.push(r.join(`
|
|
3
|
+
`)),n.filter(Boolean)}else if(s===`zsh`)return e.split(/\r?\n/).map(e=>e.trim()).filter(Boolean);else{let t=e.split(/\r?\n/),n=[];for(let e=0;e<t.length;e++){let r=t[e];if(r.startsWith(`#`)){let i=t[e+1]??``;n.push(`${r}\n${i}`),e++}else r.trim()!==``&&n.push(r)}return n}}let d=[],p=V.get(o);d=p&&t&&p.mtimeMs===t.mtimeMs&&p.size===t.size&&p.format===s?p.entries.slice():u(await e.readFile(o,`utf8`));function m(e){if(s===`fish`){let t=e.split(`
|
|
4
|
+
`)[0].match(/^- cmd: (.*)$/);return(t?t[1]:e).trim()}else if(s===`zsh`){let t=e.match(/^[^;]*;(.+)$/);return(t?t[1]:e).trim()}else{if(e.startsWith(`#`)){let t=e.split(/\r?\n/);return(t[1]??t[0]).trim()}return e.trim()}}let g=[],v=m(l),y=null;for(let e of d){if(m(e)===v){if(s===`fish`){y=e;continue}continue}g.push(e)}if(s===`fish`&&y){let e=y.split(`
|
|
5
|
+
`),t=!1,n=e.map(e=>e.trim().startsWith(`when:`)||e.startsWith(` when:`)?(t=!0,` when: ${c}`):e);t||n.splice(1,0,` when: ${c}`),g.push(n.join(`
|
|
6
|
+
`))}else g.push(l);let b=``;b=s===`fish`?`${g.map(e=>e.trimEnd()).join(`
|
|
7
|
+
`)}\n`:`${g.join(`
|
|
8
|
+
`)}\n`;let x=`${o}.ccommand.tmp`;await e.writeFile(x,b,`utf8`),await e.rename(x,o);try{let t=await e.stat(o);V.set(o,{mtimeMs:t.mtimeMs,size:t.size,entries:g,format:s})}catch{V.set(o,{mtimeMs:Date.now(),size:f.byteLength(b),entries:g,format:s})}}catch(e){h(i({text:`${_?`❌ 添加到 ${a} 历史记录失败`:`❌ Failed to add to ${a} history`}${e?`: ${String(e)}`:``}`,color:`red`}))}}const ce=d(u),U={};async function W(e){if(U[e]!==void 0)return U[e];try{return await ce(`command -v ${e}`),U[e]=!0,!0}catch{return U[e]=!1,!1}}let G=null;async function le(){return G===null&&(G=await W(`bun`)?`bun`:await W(`esno`)?`esno`:await W(`tsx`)?`tsx`:null),G}async function K(e,t,i,a){let o=T([`prun`,e]);await H(o);let{status:s}=await c(t,{errorExit:!1,isLog:!1,stdio:`inherit`}),l=s===0;return l||(n.exitCode=s??1),h(r({color:l?`green`:`red`,text:`\n"${o}" ${l?i:a} ${l?`🎉`:`❌`}`})),l}async function q(e,i,a){let o=t.extname(e),s=`node`;if(o===`.ts`)if(G===null&&await le(),G)s=G;else return h(r({text:_?`没有找到可以直接执行TypeScript的工具,推荐安装下列工具之一:
|
|
9
|
+
- npm install -g bun
|
|
10
|
+
- npm install -g esno
|
|
11
|
+
- npm install -g tsx`:`No TypeScript executor found. Recommend installing one of:
|
|
12
|
+
- npm install -g bun
|
|
13
|
+
- npm install -g esno
|
|
14
|
+
- npm install -g tsx`,color:`yellow`})),n.exitCode=1,!1;return K(e,T([s,e]),i,a)}async function ue(n,r,i){let a=[`.js`,`.ts`,`.mjs`,`.cjs`],o=t.extname(n);if(o&&a.includes(o)&&await e.stat(n).then(e=>e.isFile()).catch(()=>!1))return await q(n,r,i),!0;if(!o)for(let t of a){let a=`${n}${t}`;if(await e.stat(a).then(e=>e.isFile()).catch(()=>!1))return await q(a,r,i),!0}let s=await e.stat(n).catch(()=>null);if(s&&s.isDirectory())for(let o of a){let a=t.join(n,`index${o}`);if(await e.stat(a).then(e=>e.isFile()).catch(()=>!1))return await q(a,r,i),!0}return!1}async function de(e,n,i){e.endsWith(`.py`)?await K(e,`python ${e}`,n,i):e.endsWith(`.rs`)&&((await c(`rustc ${e}`)).status===0&&(await c(`./${t.basename(e,`.rs`)}`,{stdio:`inherit`})).status===0?(await H(`prun ${e}`),h(r({color:`green`,text:`\n"prun ${e}" ${n} 🎉`}))):h(r({color:`red`,text:`\ncommand "prun ${e}" ${i} ❌`})))}const J=console.log;let Y=null;async function X(){return Y||(Y=(await import(`@simon_he/colorize`)).default,Y)}function fe(){let e=(n.env.CCOMMAND_NO_GUM||n.env.NO_GUM||``).toLowerCase();return e===`1`||e===`true`||e===`yes`}function pe(){return!!(n.stdin.isTTY&&n.stdout.isTTY)}async function me(e){if(fe()||!pe()||n.env.CI)return!1;try{if((await c(`gum -v`,{stdio:`pipe`,errorExit:!1})).status===0)return!0;if(J((await X())({color:`blue`,text:e?`正在为您安装gum...`:`install gum...`})),(await c(`brew install gum`,{errorExit:!1})).status===0||(await c(`sudo mkdir -p /etc/apt/keyrings && curl -fsSL https://repo.charm.sh/apt/gpg.key | sudo gpg --dearmor -o /etc/apt/keyrings/charm.gpg && echo "deb [signed-by=/etc/apt/keyrings/charm.gpg] https://repo.charm.sh/apt/ * *" | sudo tee /etc/apt/sources.list.d/charm.list && sudo apt update && sudo apt install -y gum`,{errorExit:!1})).status===0)return J((await X())({color:`green`,text:e?`gum安装成功 🎉`:`gum install successfully 🎉`})),!0;let t=(await import(`terminal-link`)).default,n=t(e?`gum官网链接`:`the official website of gum`,`https://github.com/charmbracelet/gum#installation`),r=await X();return J(r({color:`red`,text:`${e?`gum安装失败,你可以自行从以下链接安装`:`gum install error, you can install it yourself through`} ${r({color:`yellow`,text:n,bold:!0})}`})),!1}catch(e){return J((await X())({color:`red`,text:`gum install check failed: ${String(e)}`})),!1}}async function Z(e){return me(e)}async function he(t){try{let n=(await e.readFile(t,`utf-8`)).split(/\r?\n/),r=new Set;for(let e=0;e<n.length;e++){let t=n[e].trim();if(t.startsWith(`.PHONY:`)){let e=t.substring(7).replace(/\\\\$/g,``).trim();for(let t of e.split(/\s+/))t&&r.add(t)}}let i=[];for(let e of r){let t=``;for(let r=0;r<n.length;r++){let i=n[r];if(!i)continue;let a=i.trimStart();if(a.startsWith(`${e}:`)||a.startsWith(`${e} :`)){let e=a.split(`:`,2)[1]||``,i=e.indexOf(`;`);if(i!==-1&&(t=e.slice(i+1).trim()),!t&&r+1<n.length){let e=n[r+1];e.startsWith(` `)&&(t=e.trim())}if(!t){let n=e.trim();t=n?n.replace(/\s+/g,` `).slice(0,120):``}break}}i.push({name:e,detail:t?`${t}...`:``})}return i}catch{return[]}}const ge=a(o),Q=ie,_e=k,$=ae;function ve(e,t,n){return!!(n[1]&&t.length)}async function ye(i=n.argv.slice(2)){let a=_?`当前目录不存在任何子目录`:`The current directory does not have any subdirectories`,o=_?`运行成功`:`run successfully`,l=_?`运行失败`:`run error`,u=ee(i);if(u[0]===`-v`||u[0]===`--version`)return h(r({text:_?`ccommand 当前版本: ${m}`:`ccommand Version: ${m}`,color:`green`}));if(u[0]===`-h`||u[0]===`--help`){let e=(await import(`terminal-link`)).default,t=e(_?`打开一个新的问题`:`open an issue`,`https://github.com/Simon-He95/ccommand/issues`),n=e(_?`✨帮助点一个星星`:`✨star it`,`https://github.com/Simon-He95/ccommand`);return h(r({color:`white`,text:`
|
|
15
|
+
${r({bold:!0,text:`Common Commands:`,bgColor:`blue`})}
|
|
16
|
+
${r({text:`- ccommand -v 查看当前版本
|
|
17
|
+
- ccommand -help 查看帮助
|
|
18
|
+
- ccommand 执行当前package.json
|
|
19
|
+
- ccommand find 查找当前workspace的所有目录
|
|
20
|
+
`,color:`cyan`})}
|
|
21
|
+
If you encounter any problems, you can ${r({color:`magenta`,text:t})}.
|
|
22
|
+
If you like it, please ${r({text:n,bold:!0,color:`cyan`})} `}))}else if(u[0]?.endsWith(`.py`)||u[0]?.endsWith(`.rs`)){await de(u[0],o,l);return}let d;try{d=await s()}catch{try{if(await e.readFile(t.resolve(n.cwd(),`./Makefile`),`utf-8`)){d=`make`;let e=await he(`./Makefile`),t=e.reduce((e,t)=>{let{name:n,detail:r}=t;return e[n]=r,e},{}),n=``,i=[];if(u.length){let e=u[0];if(i=u.slice(1),n=O(t,e)||``,!n)return h(r({color:`red`,text:y}))}else{if(!await Z(_))return h(r({color:`yellow`,text:_?`未检测到可用的交互环境或 gum 已被禁用,请直接传入 make 目标名称`:`Gum is unavailable (non-interactive or disabled). Please pass a make target explicitly.`}));let{result:t,status:i}=await c(`echo "${e.map(e=>e.name).join(`
|
|
23
|
+
`)}" | gum filter --placeholder=" 🤔请选择一个要执行的指令"`,`pipe`);if(i===130)return x();n=t}await $(d,n.trim(),i,u,H,c,r,_,o,l);return}else return h(r({color:`red`,text:y}))}catch{if(u[0]!==`find`)return h(r({color:`red`,text:y}))}}let[f,p,v]=te(u),S=f,C;if(u[0]===`find`){if(p)await L(d),S=P().filter(e=>e.includes(p))[0];else if(d===`yarn`){if(await L(d),!P().length)return h(r({color:`yellow`,text:a}));if(!await Z(_))return h(r({color:`yellow`,text:_?`未检测到可用的交互环境或 gum 已被禁用,请直接传入 workspace 名称`:`Gum is unavailable (non-interactive or disabled). Please pass a workspace name explicitly.`}));let{result:e,status:t}=await c(`echo ${P().join(`,`)} | sed "s/,/\\n/g" | gum filter --placeholder=" 🤔${_?`请选择一个要执行的目录`:`Please select a directory to execute`}"`,[`inherit`,`pipe`,`inherit`]);if(S=e,t===130)return x()}else if(d===`pnpm`){if(await L(d),!P().length)return h(r({color:`yellow`,text:a}));if(!await Z(_))return h(r({color:`yellow`,text:_?`未检测到可用的交互环境或 gum 已被禁用,请直接传入 workspace 名称`:`Gum is unavailable (non-interactive or disabled). Please pass a workspace name explicitly.`}));let{result:e,status:t}=await c(`echo ${P().join(`,`)} | sed "s/,/\\n/g" | gum filter --placeholder=" 🤔${_?`请选择一个要执行的目录`:`Please select a directory to execute`}"`,[`inherit`,`pipe`,`inherit`]);if(t===130)return x();S=e.trim()}else return h(r({color:`red`,text:_?`find指令只能支持在yarn或pnpm的monorepo模式下使用`:`find command only support yarn or pnpm`}));C=await Q(S,d)||void 0}else{C=await Q(S,d)||void 0;try{let t=(await ge(`./package.json`)||{})?.scripts;if(t&&t[u[0]]){await $(d,u[0],u.slice(1),u,H,c,r,_,o,l);return}else if(t&&f){let i=O(t,u[0]);if(i){let e=u.slice(1);await $(d,i,e,u,H,c,r,_,o,l);return}else{if(await ue(u[0],o,l))return;let t=`${f}.py`;if(await e.stat(t).then(e=>e.isFile()).catch(()=>!1)){h(r({text:`🤔 ${_?`找到Python文件`:`Found Python file`}: ${t}`,color:`yellow`}));return}let i=`${f}.rs`;if(await e.stat(i).then(e=>e.isFile()).catch(()=>!1))return;h(r({color:`red`,text:`"${u[0]}" ${_?`在工作区、当前目录中找不到任何可执行的脚本或文件,请检查`:`is not found in workspace, current directory or current scripts, please check`}`})),n.exit(1)}}}catch{}}if(!C)return h(r({color:`red`,text:_?`找不到任何可执行脚本`:`No scripts found`}));let w=[],E=``;if(!p||u[0]===`find`&&(!u[2]||u[2].startsWith(`--`))){let e=Object.keys(C).reduce((e,t)=>{let n=C?.[t]??``;return w.push(t),e+=`"${t}: ${n.replace(/\\/g,`\\\\`).replace(/(["`])/g,`\\$1`)}"${g}`,e},``);if(!await Z(_))return h(r({color:`yellow`,text:_?`未检测到可用的交互环境或 gum 已被禁用,请直接传入脚本名称`:`Gum is unavailable (non-interactive or disabled). Please pass a script name explicitly.`}));let{result:t,status:n}=await c(`echo ${e} | sed "s/${g}/\\n/g" | gum filter --placeholder=" 🤔请选择一个要执行的指令"`,{stdio:[`inherit`,`pipe`,`inherit`],isLog:!1});if(n===130)return x();E=t.substring(0,t.indexOf(`: `))}if(!p&&!E)return x();h(r({text:`🤔 ${b} ${E}`,color:`magenta`}));let{command:D,text:k,val:A}=await _e({termStart:d,params:v,dirname:S,argv:u,val:E,runMsg:b,isZh:_,pushHistory:H,jsShell:c,isNeedPrefix:e=>ve(u[0],e,u),fuzzyWorkspace:p}),j=D;E=A;let{status:M,result:N=``}=await c(j,{errorExit:!1,stdio:`inherit`});if(M===0)return h(r({color:`green`,text:`\n${k} 🎉`}));if(N.includes(`pnpm versions with respective Node.js version support`)){h(r({text:_?`正在尝试使用 npm 再次执行...`:`Trying to use npm to run again...`,color:`yellow`}));let e=[...v];e[0]===`--`&&e.shift();let{status:t}=await c(T([`npm`,`run`,E,...e.length?[`--`,...e]:[]]),`inherit`);if(t===0)return h(r({color:`green`,text:`\n${k} 🎉`}))}h(r({color:`red`,text:`\ncommand '${E}' ${l} ❌`}))}export{ye as t};
|
package/dist/cli.cjs
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
require(`./ccommand-BTvHS8S5.cjs`).t();
|
package/dist/cli.d.mts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { };
|
package/dist/cli.mjs
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{t as e}from"./ccommand-xkHK1_kY.mjs";e();export{};
|
package/dist/index.cjs
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
const e=require(`./ccommand-BTvHS8S5.cjs`);exports.ccommand=e.t;
|
package/dist/index.d.cts
ADDED
package/dist/index.d.mts
ADDED
package/dist/index.mjs
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{t as e}from"./ccommand-xkHK1_kY.mjs";export{e as ccommand};
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "ccommand",
|
|
3
3
|
"type": "module",
|
|
4
|
-
"version": "1.0.
|
|
4
|
+
"version": "1.0.89",
|
|
5
5
|
"description": "ccommand",
|
|
6
6
|
"author": "Simon He",
|
|
7
7
|
"license": "MIT",
|
|
@@ -20,7 +20,7 @@
|
|
|
20
20
|
".": {
|
|
21
21
|
"types": "./dist/index.d.ts",
|
|
22
22
|
"import": "./dist/index.mjs",
|
|
23
|
-
"require": "./dist/index.
|
|
23
|
+
"require": "./dist/index.cjs"
|
|
24
24
|
}
|
|
25
25
|
},
|
|
26
26
|
"main": "./dist/index.mjs",
|
|
@@ -32,7 +32,7 @@
|
|
|
32
32
|
"dist"
|
|
33
33
|
],
|
|
34
34
|
"scripts": {
|
|
35
|
-
"build": "tsdown ./src/index.ts ./src/cli.ts --minify",
|
|
35
|
+
"build": "tsdown ./src/index.ts ./src/cli.ts --minify --format cjs,esm",
|
|
36
36
|
"dev": "tsdown ./src/index.ts ./src/cli.ts --watch",
|
|
37
37
|
"play": "pnpm run -C playground dev",
|
|
38
38
|
"play:build": "pnpm run -C playground build",
|
|
@@ -49,18 +49,19 @@
|
|
|
49
49
|
"dependencies": {
|
|
50
50
|
"@simon_he/colorize": "^0.0.1",
|
|
51
51
|
"fast-glob": "^3.3.3",
|
|
52
|
-
"lazy-js-utils": "^0.1.
|
|
52
|
+
"lazy-js-utils": "^0.1.49",
|
|
53
53
|
"picocolors": "^1.1.1",
|
|
54
54
|
"terminal-link": "^3.0.0",
|
|
55
55
|
"yamljs": "^0.3.0"
|
|
56
56
|
},
|
|
57
57
|
"devDependencies": {
|
|
58
|
-
"@antfu/eslint-config": "^
|
|
58
|
+
"@antfu/eslint-config": "^7.2.0",
|
|
59
59
|
"@types/node": "^17.0.45",
|
|
60
60
|
"bumpp": "^8.2.1",
|
|
61
|
-
"eslint": "^9.
|
|
61
|
+
"eslint": "^9.39.2",
|
|
62
62
|
"lint-staged": "^13.3.0",
|
|
63
63
|
"prettier": "^2.8.8",
|
|
64
|
+
"tsdown": "^0.20.1",
|
|
64
65
|
"tsx": "^3.14.0",
|
|
65
66
|
"typescript": "^4.9.5",
|
|
66
67
|
"vitest": "^0.13.1"
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
import e from"node:fs/promises";import t from"node:path";import n from"node:process";import r from"@simon_he/colorize";import{isPlainObject as i,memorizeFn as a}from"lazy-js-utils";import{getPkg as o,getPkgTool as s,jsShell as c}from"lazy-js-utils/node";import l from"fast-glob";import{exec as u}from"node:child_process";import{promisify as d}from"node:util";import f from"node:os";var p=`1.0.87`;async function m(e){let{termStart:t,params:n,dirname:r,argv:i,val:a,isZh:o,pushHistory:s,jsShell:c,isNeedPrefix:l,fuzzyWorkspace:u}=e,d=``,f=``,p=t!==`yarn`;t===`npm`?(f=n?` -- ${n}`:``,d=r?` --prefix ${r} `:` `):t===`pnpm`?(f=n?` ${n}`:``,d=r?` --filter ${r} `:` `):t===`yarn`?(f=n?` ${n}`:``,d=r?` workspace ${r} `:` `):t===`bun`&&(f=n?` ${n}`:``,d=``);let m=``,h=``;if(f&&!f.startsWith(` --`)){let e=f.split(` `).filter(Boolean);m=e[0],f=e.slice(1).join(` `)}let g=`${t}${p?` run`:` `}${d} ${m||a||u} ${l(f)?`-- ${f}`:f}`;a=`${m||a||u}`,h=i[0]===`find`?`pfind ${r} ${a} ${f}`.replace(/\s+/g,` `).trim():`prun ${a} ${f}`.replace(/\s+/g,` `).trim(),await s(h);let _=h.split(` `),v=_.slice(-1)[0];_[_.length-1]=`'${v}'`;let y=_.join(` `);return{command:g,text:y,val:a}}let h=null,g=[],_=null,v=null;function y(){return g}async function b(r){let i=r===`pnpm`?t.resolve(n.cwd(),`pnpm-workspace.yaml`):t.resolve(n.cwd(),`package.json`);try{try{v=(await e.stat(i)).mtimeMs}catch{}return await e.readFile(i,`utf-8`)}catch{return``}}async function x(e,t){if(!t)return[];if(e===`pnpm`)try{if(!h){let e=await import(`yamljs`);h=e&&e.default||e}let e=h.parse(t)?.packages;return Array.isArray(e)?e.filter(Boolean):[]}catch{return[]}try{let e=JSON.parse(t)?.workspaces;return i(e)?e?.packages||[]:Array.isArray(e)?e:[]}catch{return[]}}async function S(e){if(!e.length)return{};let t=await l(e.map(e=>`${e}/package.json`),{dot:!0,ignore:[`**/node_modules/**`]});return(await Promise.all(t.map(async e=>{try{let t=await o(e);if(!t)return null;let{name:n,scripts:r}=t;return{name:n,scripts:r}}catch{return null}}))).reduce((e,t)=>(!t||!t.name||!t.scripts||(e[t.name]=Object.keys(t.scripts).reduce((e,n)=>(n.startsWith(`//`)||(e[n]=t.scripts[n]),e),{})),e),{})}async function C(r){if(_)try{let i=r===`pnpm`?t.resolve(n.cwd(),`pnpm-workspace.yaml`):t.resolve(n.cwd(),`package.json`),a=await e.stat(i);if(v&&a.mtimeMs<=v)return _}catch{return _}let i=await b(r),a=await x(r,i);return _=await S(a)||{},g=Object.keys(_).filter(e=>_&&_[e]&&Object.keys(_[e]).length),_}async function w(e){return C(e)}const T=a(o),E={};async function D(e,t){try{let n=e||`root`;if(E[n])return E[n];let r;return!e||t===`bun`||t===`npm`?r=(await T(`./package.json`))?.scripts:(t===`pnpm`||t===`yarn`)&&(r=(await w(t))[e]||(await T(`${e}/package.json`))?.scripts),r&&(E[n]=r),r}catch{return null}}async function O(e,t,n,r,i,a,o,s,c,l){let u,d=``,f=r[0]?.trim();switch(t&&f&&f!==t?console.log(o({text:`🤔 ${o({text:`'${r[0]}'`,color:`cyan`})} ${s?`自动的为您匹配成`:`automatically match for you`} ${o({text:`'${t}${n?` ${n}`:``}'`,color:`cyan`})} `,color:`yellow`})):t&&console.log(o({text:`🤔 is running for you... ${t}`,color:`magenta`})),e){case`npm`:{let{status:e,result:r}=await a(`npm run ${t}${n?` -- ${n}`:``}`,{errorExit:!1,isLog:!1,stdio:`inherit`});u=e,d=r;break}case`pnpm`:{let{status:e,result:r=``}=await a(`pnpm run ${t}${n?` ${n}`:``}`,{errorExit:!1,isLog:!1,stdio:`inherit`});if(d=r,u=e,d.includes(`pnpm versions with respective Node.js version support`)){console.log(o({text:s?`正在尝试使用 npm 再次执行...`:`Trying to use npm to run again...`,color:`yellow`}));let{status:e,result:r}=await a(`npm run ${t}${n?` -- ${n}`:``}`,{errorExit:!1,isLog:!1,stdio:`inherit`});u=e,d=r}break}case`yarn`:{let{status:e,result:r}=await a(`yarn ${t}${n?` ${n}`:``}`,{errorExit:!1,isLog:!1,stdio:`inherit`});u=e,d=r;break}case`bun`:{let{status:e,result:r}=await a(`bun run ${t} ${n}`,{errorExit:!1,isLog:!1,stdio:`inherit`});u=e,d=r;break}case`make`:{let{status:e,result:r}=await a(`make ${t} ${n}`,{errorExit:!1,isLog:!1,stdio:`inherit`});u=e,d=r;break}}return u===0?(await i(`prun ${t}${n?` ${n}`:``}`),console.log(o({color:`green`,text:`\nprun '${t}${n?` ${n}`:``}' ${c} 🎉`}))):console.log(o({color:`red`,text:`\ncommand ${o({bold:!0,color:`cyan`,text:`'${t||r[0]}${n?` ${n}`:``}'`})} ${l} ❌`}))}const k=console.log,A=`__ccommand__split`,j=(n.env.PI_LANG||n.env.LANG||``).startsWith(`zh`),M=j?`已取消...`:`Cancelled...`,N=j?`当前目录并未找到 package.json 文件`:`package.json file not found in current directory`,P=j?`正在为您执行...`:`is running for you...`;function F(){return k(`[33m${M}[0m`),n.exit(130)}let I=null;async function L(){return I||(I=(await import(`@simon_he/colorize`)).default,I)}async function R(r){let i=await L();k(i({text:`${j?`快捷指令`:`shortcut command`}: ${r}`,color:`blue`,bold:!0}));let a=(n.env.SHELL||`/bin/bash`).split(`/`).pop()||`bash`,o=``,s=`bash`,c=n.env.HOME||f.homedir();switch(a){case`zsh`:o=t.join(c,`.zsh_history`),s=`zsh`;break;case`bash`:o=n.env.HISTFILE||t.join(c,`.bash_history`),s=`bash`;break;case`fish`:o=t.join(c,`.local`,`share`,`fish`,`fish_history`),s=`fish`;break;default:o=n.env.HISTFILE||t.join(c,`.bash_history`),s=`bash`}try{try{await e.access(o)}catch{k(i({text:`${j?`未找到 ${a} 历史文件`:`${a} history file not found`}`,color:`yellow`}));return}let t=await e.readFile(o,`utf8`),c=Math.floor(Date.now()/1e3),l=``;l=s===`zsh`?`: ${c}:0;${r}`:s===`fish`?`- cmd: ${r}\n when: ${c}`:n.env.HISTTIMEFORMAT?`#${c}\n${r}`:r;function u(e){if(s===`fish`){let t=e.split(/\r?\n/),n=[],r=[];for(let e of t)e.startsWith(`- cmd: `)?(r.length&&(n.push(r.join(`
|
|
2
|
-
`)),r=[]),r.push(e)):r.length?r.push(e):e.trim()!==``&&n.push(e);return r.length&&n.push(r.join(`
|
|
3
|
-
`)),n.filter(Boolean)}else if(s===`zsh`)return e.split(/\r?\n/).map(e=>e.trim()).filter(Boolean);else{let t=e.split(/\r?\n/),n=[];for(let e=0;e<t.length;e++){let r=t[e];if(r.startsWith(`#`)){let i=t[e+1]??``;n.push(`${r}\n${i}`),e++}else r.trim()!==``&&n.push(r)}return n}}let d=u(t);function f(e){if(s===`fish`){let t=e.split(`
|
|
4
|
-
`)[0].match(/^- cmd: (.*)$/);return t?t[1]:e}else if(s===`zsh`){let t=e.match(/^[^;]*;(.+)$/);return t?t[1]:e}else{if(e.startsWith(`#`)){let t=e.split(/\r?\n/);return t[1]??t[0]}return e}}let p=[],m=f(l),h=null;for(let e of d){if(f(e)===m){if(s===`fish`){h=e;continue}continue}p.push(e)}if(s===`fish`&&h){let e=h.split(`
|
|
5
|
-
`),t=!1,n=e.map(e=>e.trim().startsWith(`when:`)||e.startsWith(` when:`)?(t=!0,` when: ${c}`):e);t||n.splice(1,0,` when: ${c}`),p.push(n.join(`
|
|
6
|
-
`))}else p.push(l);let g=``;g=s===`fish`?`${p.map(e=>e.trimEnd()).join(`
|
|
7
|
-
`)}\n`:`${p.join(`
|
|
8
|
-
`)}\n`;let _=`${o}.ccommand.tmp`;await e.writeFile(_,g,`utf8`),await e.rename(_,o)}catch(e){k(i({text:`${j?`❌ 添加到 ${a} 历史记录失败`:`❌ Failed to add to ${a} history`}${e?`: ${String(e)}`:``}`,color:`red`}))}}const z=d(u),B={};async function V(e){if(B[e]!==void 0)return B[e];try{return await z(`command -v ${e}`),B[e]=!0,!0}catch{return B[e]=!1,!1}}let H=null;async function U(){return H===null&&(H=await V(`bun`)?`bun`:await V(`esno`)?`esno`:await V(`tsx`)?`tsx`:null),H}async function W(e,t,n,i){await R(`prun ${e}`);let{status:a}=await c(t,{errorExit:!1,isLog:!1,stdio:`inherit`});k(r({color:a===0?`green`:`red`,text:`\n"prun ${e}" ${a===0?n:i} ${a===0?`🎉`:`❌`}`}))}async function G(e,n,i){let a=t.extname(e),o=`node`;if(a===`.ts`)if(H===null&&await U(),H)o=H;else{k(r({text:j?`没有找到可以直接执行TypeScript的工具,推荐安装下列工具之一:
|
|
9
|
-
- npm install -g bun
|
|
10
|
-
- npm install -g esno
|
|
11
|
-
- npm install -g tsx`:`No TypeScript executor found. Recommend installing one of:
|
|
12
|
-
- npm install -g bun
|
|
13
|
-
- npm install -g esno
|
|
14
|
-
- npm install -g tsx`,color:`yellow`}));return}let s=`${o} ${e}`;await W(e,s,n,i)}async function K(n,r,i){let a=[`.js`,`.ts`,`.mjs`,`.cjs`],o=t.extname(n);if(o&&a.includes(o)&&await e.stat(n).then(e=>e.isFile()).catch(()=>!1))return await G(n,r,i),!0;if(!o)for(let t of a){let a=`${n}${t}`;if(await e.stat(a).then(e=>e.isFile()).catch(()=>!1))return await G(a,r,i),!0}let s=await e.stat(n).catch(()=>null);if(s&&s.isDirectory())for(let o of a){let a=t.join(n,`index${o}`);if(await e.stat(a).then(e=>e.isFile()).catch(()=>!1))return await G(a,r,i),!0}return!1}async function q(e,n,i){if(e.endsWith(`.py`))await W(e,`python ${e}`,n,i);else if(e.endsWith(`.rs`))if((await c(`rustc ${e}`)).status===0){let a=`./${t.basename(e,`.rs`)}`;(await c(a,{stdio:`inherit`})).status===0?(await R(`prun ${e}`),k(r({color:`green`,text:`\n"prun ${e}" ${n} 🎉`}))):k(r({color:`red`,text:`\ncommand "prun ${e}" ${i} ❌`}))}else k(r({color:`red`,text:`\ncommand "prun ${e}" ${i} ❌`}))}const J=console.log;let Y=null;async function X(){return Y||(Y=(await import(`@simon_he/colorize`)).default,Y)}async function ee(e){try{if((await c(`gum -v`,`pipe`)).status===0)return;let t=await X();if(J(t({color:`blue`,text:e?`正在为您安装gum...`:`install gum...`})),(await c(`brew install gum`)).status===0){let t=await X();return J(t({color:`green`,text:e?`gum安装成功 🎉`:`gum install successfully 🎉`}))}if((await c(`sudo mkdir -p /etc/apt/keyrings && curl -fsSL https://repo.charm.sh/apt/gpg.key | sudo gpg --dearmor -o /etc/apt/keyrings/charm.gpg && echo "deb [signed-by=/etc/apt/keyrings/charm.gpg] https://repo.charm.sh/apt/ * *" | sudo tee /etc/apt/sources.list.d/charm.list && sudo apt update && sudo apt install -y gum`)).status===0){let t=await X();return J(t({color:`green`,text:e?`gum安装成功 🎉`:`gum install successfully 🎉`}))}let n=(await import(`terminal-link`)).default,r=n(e?`gum官网链接`:`the official website of gum`,`https://github.com/charmbracelet/gum#installation`),i=await X();return J(i({color:`red`,text:`${e?`gum安装失败,你可以自行从以下链接安装`:`gum install error, you can install it yourself through`} ${i({color:`yellow`,text:r,bold:!0})}`}))}catch(e){let t=await X();J(t({color:`red`,text:`gum install check failed: ${String(e)}`}))}}async function te(t){try{let n=(await e.readFile(t,`utf-8`)).split(/\r?\n/),r=new Set;for(let e=0;e<n.length;e++){let t=n[e].trim();if(t.startsWith(`.PHONY:`)){let e=t.substring(7).replace(/\\\\$/g,``).trim();for(let t of e.split(/\s+/))t&&r.add(t)}}let i=[];for(let e of r){let t=``;for(let r=0;r<n.length;r++){let i=n[r];if(!i)continue;let a=i.trimStart();if(a.startsWith(`${e}:`)||a.startsWith(`${e} :`)){let e=a.split(`:`,2)[1]||``,i=e.indexOf(`;`);if(i!==-1&&(t=e.slice(i+1).trim()),!t&&r+1<n.length){let e=n[r+1];e.startsWith(` `)&&(t=e.trim())}if(!t){let n=e.trim();t=n?n.replace(/\s+/g,` `).slice(0,120):``}break}}i.push({name:e,detail:t?`${t}...`:``})}return i}catch{return[]}}function ne(e){let t=e[0];return t?t.startsWith(`--`)?[``,``,e.join(` `)]:e[1]&&e[1].startsWith(`--`)?[t,``,e.slice(1).join(` `)]:[t,e[1]||``,e.slice(2).join(` `)]:[``,``,``]}function re(e){return e.replace(/[.*+?^${}()|[\]\\]/g,`\\$&`)}function Z(e,t){let r=Object.keys(e),i=r.find(e=>e.startsWith(t));if(i)return i;try{if(!t)return;let e=t.split(``).map(e=>re(e)).join(`[_-\\w$.:]*`),n=new RegExp(e);return r.find(e=>n.test(e))}catch(e){k(`${j?`正则错误`:`RegExp error`}: ${e}`),n.exit(1)}}const ie=a(o),Q=D,ae=m,$=O;function oe(e,t,n){return!!(n[1]&&t)}async function se(i=n.argv.slice(2).join(` `)){await ee(j);let a=j?`当前目录不存在任何子目录`:`The current directory does not have any subdirectories`,o=j?`运行成功`:`run successfully`,l=j?`运行失败`:`run error`,u=i?i.replace(/\s+/g,` `).trim().split(` `):n.argv.slice(2);if(u[0]===`-v`||u[0]===`--version`)return k(r({text:j?`ccommand 当前版本: ${p}`:`ccommand Version: ${p}`,color:`green`}));if(u[0]===`-h`||u[0]===`--help`){let e=(await import(`terminal-link`)).default,t=e(j?`打开一个新的问题`:`open an issue`,`https://github.com/Simon-He95/ccommand/issues`),n=e(j?`✨帮助点一个星星`:`✨star it`,`https://github.com/Simon-He95/ccommand`);return k(r({color:`white`,text:`
|
|
15
|
-
${r({bold:!0,text:`Common Commands:`,bgColor:`blue`})}
|
|
16
|
-
${r({text:`- ccommand -v 查看当前版本
|
|
17
|
-
- ccommand -help 查看帮助
|
|
18
|
-
- ccommand 执行当前package.json
|
|
19
|
-
- ccommand find 查找当前workspace的所有目录
|
|
20
|
-
`,color:`cyan`})}
|
|
21
|
-
If you encounter any problems, you can ${r({color:`magenta`,text:t})}.
|
|
22
|
-
If you like it, please ${r({text:n,bold:!0,color:`cyan`})} `}))}else if(u[0]?.endsWith(`.py`)||u[0]?.endsWith(`.rs`)){await q(u[0],o,l);return}let d;try{d=await s()}catch{try{if(await e.readFile(t.resolve(n.cwd(),`./Makefile`),`utf-8`)){d=`make`;let e=await te(`./Makefile`),t=e.reduce((e,t)=>{let{name:n,detail:r}=t;return e[n]=r,e},{}),n=``;if(i){if(n=Z(t,i)||``,!n)return k(r({color:`red`,text:N}))}else{let{result:t,status:r}=await c(`echo "${e.map(e=>e.name).join(`
|
|
23
|
-
`)}" | gum filter --placeholder=" 🤔请选择一个要执行的指令"`,`pipe`);if(r===130)return F();n=t}await $(d,n.trim(),``,u,R,c,r,j,o,l);return}else return k(r({color:`red`,text:N}))}catch{if(u[0]!==`find`)return k(r({color:`red`,text:N}))}}let[f,m,h]=ne(u),g=f,_;if(u[0]===`find`){if(m)await w(d),g=y().filter(e=>e.includes(m))[0];else if(d===`yarn`){if(await w(d),!y().length)return k(r({color:`yellow`,text:a}));let{result:e,status:t}=await c(`echo ${y().join(`,`)} | sed "s/,/\\n/g" | gum filter --placeholder=" 🤔${j?`请选择一个要执行的目录`:`Please select a directory to execute`}"`,[`inherit`,`pipe`,`inherit`]);if(g=e,t===130)return F()}else if(d===`pnpm`){if(await w(d),!y().length)return k(r({color:`yellow`,text:a}));let{result:e,status:t}=await c(`echo ${y().join(`,`)} | sed "s/,/\\n/g" | gum filter --placeholder=" 🤔${j?`请选择一个要执行的目录`:`Please select a directory to execute`}"`,[`inherit`,`pipe`,`inherit`]);if(t===130)return F();g=e.trim()}else return k(r({color:`red`,text:j?`find指令只能支持在yarn或pnpm的monorepo模式下使用`:`find command only support yarn or pnpm`}));_=await Q(g,d)||void 0}else{_=await Q(g,d)||void 0;try{let t=(await ie(`./package.json`)||{})?.scripts;if(t&&t[u[0]]){await $(d,u[0],u.slice(1).join(` `),u,R,c,r,j,o,l);return}else if(t&&f){let i=Z(t,u[0]);if(i){let e=u.slice(1).join(` `);await $(d,i,e,u,R,c,r,j,o,l);return}else{if(await K(u[0],o,l))return;let t=`${f}.py`;if(await e.stat(t).then(e=>e.isFile()).catch(()=>!1)){k(r({text:`🤔 ${j?`找到Python文件`:`Found Python file`}: ${t}`,color:`yellow`}));return}let i=`${f}.rs`;if(await e.stat(i).then(e=>e.isFile()).catch(()=>!1))return;k(r({color:`red`,text:`"${u[0]}" ${j?`在工作区、当前目录中找不到任何可执行的脚本或文件,请检查`:`is not found in workspace, current directory or current scripts, please check`}`})),n.exit(1)}}}catch{}}if(!_)return k(r({color:`red`,text:j?`找不到任何可执行脚本`:`No scripts found`}));let v=[],b=``;if(!m||u[0]===`find`&&(!u[2]||u[2].startsWith(`--`))){let e=Object.keys(_).reduce((e,t)=>{let n=_?.[t]??``;return v.push(t),e+=`"${t}: ${n.replace(/\\/g,`\\\\`).replace(/(["`])/g,`\\$1`)}"${A}`,e},``),{result:t,status:n}=await c(`echo ${e} | sed "s/${A}/\\n/g" | gum filter --placeholder=" 🤔请选择一个要执行的指令"`,{stdio:[`inherit`,`pipe`,`inherit`],isLog:!1});if(n===130)return F();b=t.substring(0,t.indexOf(`: `))}if(!m&&!b)return F();k(r({text:`🤔 ${P} ${b}`,color:`magenta`}));let{command:x,text:S,val:C}=await ae({termStart:d,params:h,dirname:g,argv:u,val:b,runMsg:P,isZh:j,pushHistory:R,jsShell:c,isNeedPrefix:e=>oe(u[0],e,u),fuzzyWorkspace:m}),T=x.replace(/\s+/g,` `);b=C;let{status:E,result:D=``}=await c(T,{errorExit:!1,stdio:`inherit`});if(E===0)return k(r({color:`green`,text:`\n${S} 🎉`}));if(D.includes(`pnpm versions with respective Node.js version support`)){k(r({text:j?`正在尝试使用 npm 再次执行...`:`Trying to use npm to run again...`,color:`yellow`}));let{status:e}=await c(`npm run ${b}${h?` -- ${h}`:``}`,`inherit`);if(e===0)return k(r({color:`green`,text:`\n${S} 🎉`}))}k(r({color:`red`,text:`\ncommand '${b}' ${l} ❌`}))}export{se as ccommand};
|
package/dist/cli.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{ccommand as e}from"./ccommand-DbBDev6g.js";e();export{};
|
package/dist/index.d.ts
DELETED
package/dist/index.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{ccommand as e}from"./ccommand-DbBDev6g.js";export{e as ccommand};
|
|
File without changes
|