gitpick 4.17.0-canary.4 ā 4.17.0-canary.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/README.md +2 -1
- package/dist/index.mjs +4 -3
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
|
|
5
5
|
**Clone exactly what you need aka straightforward project scaffolding!**
|
|
6
6
|
|
|
7
|
-
š¦ `Zero dependencies` / `Un/packed (~
|
|
7
|
+
š¦ `Zero dependencies` / `Un/packed (~23/9kb)` / `Faster and more features` yet drop-in replacement for `degit`
|
|
8
8
|
|
|
9
9
|
[](https://twitter.com/nrjdalal_dev)
|
|
10
10
|
[](https://www.npmjs.com/package/gitpick)
|
|
@@ -112,6 +112,7 @@ npx gitpick https://bitbucket.org/owner/repo # Bitbucket
|
|
|
112
112
|
-r, --recursive Clone submodules
|
|
113
113
|
-w, --watch [time] Watch the repository and sync every [time]
|
|
114
114
|
(e.g. 1h, 30m, 15s)
|
|
115
|
+
--tree List copied files as a tree
|
|
115
116
|
-h, --help display help for command
|
|
116
117
|
-v, --version display the version number
|
|
117
118
|
```
|
package/dist/index.mjs
CHANGED
|
@@ -2,10 +2,10 @@
|
|
|
2
2
|
import e from"node:fs";import t from"node:path";import{parseArgs as n,stripVTControlCharacters as r}from"node:util";import i from"node:tty";import a from"node:os";import{spawn as o}from"node:child_process";import{once as s}from"node:events";import c from"node:fs/promises";import l from"node:process";import{fileURLToPath as u}from"node:url";const d=i?.WriteStream?.prototype?.hasColors?.()??!1,f=(e,t)=>{if(!d)return e=>e;let n=`\u001B[${e}m`,r=`\u001B[${t}m`;return e=>{let i=e+``,a=i.indexOf(r);if(a===-1)return n+i+r;let o=n,s=0,c=(t===22?r:``)+n;for(;a!==-1;)o+=i.slice(s,a)+c,s=a+r.length,a=i.indexOf(r,s);return o+=i.slice(s)+r,o}},p=f(1,22),m=f(31,39),h=f(32,39),g=f(33,39),_=f(36,39);var v=class extends Error{constructor(...e){super(...e),this.name=`SubprocessError`,this.stdout=``,this.stderr=``}};const y=[`.exe`,`.com`],b={},x=e=>(...t)=>b[t.join(`\0`)]??=e(...t),S=x(async(...e)=>{try{return await c.access(e[0]),!0}catch{return!1}}),C=x(async(e,n,r)=>{let i=r.split(t.delimiter).filter(Boolean).map(e=>e.replace(/^"(.*)"$/,`$1`));try{await Promise.any([n,...i].flatMap(n=>y.map(r=>S(`${t.resolve(n,e)}${r}`))))}catch{return!1}return!0}),w=async(e,t)=>l.platform===`win32`&&!t.shell&&!y.some(t=>e.toLowerCase().endsWith(t))&&!await C(e,t.cwd??`.`,(l.env.PATH||l.env.Path)??``),T=e=>e.replaceAll(/([()\][%!^"`<>&|;, *?])/g,`^$1`),E=e=>T(T(`"${e.replaceAll(/(\\*)"/g,`$1$1\\"`).replace(/(\\*)$/,`$1$1`)}"`)),D=e=>/[^\w./-]/.test(e)?`'${e.replaceAll(`'`,`'\\''`)}'`:e;async function O(e,n=[],i={}){let{stdin:a,stdout:c,stderr:d,stdio:f,cwd:p=`.`,env:m,...h}=i,g=p instanceof URL?u(p):t.resolve(p),_=m?{...l.env,...m}:void 0,y=f??[a,c,d],b=[e,...n].map(e=>D(r(e))).join(` `);[`node`,`node.exe`].includes(e.toLowerCase())&&(e=l.execPath,n=[...l.execArgv.filter(e=>!e.startsWith(`--inspect`)),...n]);let x={...h,stdio:y,env:_,cwd:g};await w(e,x)&&(n=n.map(e=>E(e)),e=T(e),x={...x,shell:!0}),x.shell&&n.length>0&&(e=[e,...n].join(` `),n=[]);let S=o(e,n,x),C=``,O=``;S.stdout&&(S.stdout.setEncoding(`utf8`),S.stdout.on(`data`,e=>C+=e)),S.stderr&&(S.stderr.setEncoding(`utf8`),S.stderr.on(`data`,e=>O+=e)),S.once(`error`,()=>{});try{await s(S,`spawn`)}catch(e){throw Object.assign(new v(`Command failed: ${b}`,{cause:e}),{stdout:C,stderr:O})}await s(S,`close`);let k=e=>e.at(-1)===`
|
|
3
3
|
`?e.slice(0,e.at(-2)===`\r`?-2:-1):e;if(S.exitCode&&S.exitCode>0)throw Object.assign(new v(`Command failed with exit code ${S.exitCode}: ${b}`),{stdout:k(C),stderr:k(O),exitCode:S.exitCode});if(S.signalCode)throw Object.assign(new v(`Command was terminated with ${S.signalCode}: ${b}`),{stdout:k(C),stderr:k(O)});return{stdout:k(C),stderr:k(O)}}const k=l.platform!==`win32`||!!l.env.WT_SESSION||l.env.TERM_PROGRAM===`vscode`,A=e=>!!(e.isTTY&&l.env.TERM!==`dumb`&&!(`CI`in l.env)),j=h(k?`ā`:`ā`),M=k?[`ā `,`ā `,`ā ¹`,`ā ø`,`ā ¼`,`ā “`,`ā ¦`,`ā §`,`ā `,`ā `]:[`-`,`\\`,`|`,`/`],N=(e={})=>{let t=-1,n,i=e.text??``,a=e.stream??l.stderr,o=A(a),s=0,c=0,u=!1,d=e=>a.write(e),f=()=>{if(!(!o||s===0)){a.cursorTo(0);for(let e=0;e<s;e++)e>0&&a.moveCursor(0,-1),a.clearLine(1);s=0}},p=e=>{let t=a.columns??80,n=r(e).split(`
|
|
4
4
|
`),i=0;for(let e of n)i+=Math.max(1,Math.ceil(e.length/t));return i},m=()=>{let e=Date.now();(t===-1||e-c>=80)&&(t=++t%M.length,c=e);let n=M[t],r=`${_(n)} ${i}`;o?(f(),d(r),s=p(r)):d(r+`
|
|
5
|
-
`)};return{start(e){return i=e,u=!0,o&&d(`\x1B[?25l`),m(),o&&(n=setInterval(m,80)),this},success(e){return u?(u=!1,n&&=(clearInterval(n),void 0),f(),o&&d(`\x1B[?25h`),d(`${j} ${e??i}\n`),this):this}}},P=async(n,r)=>{let i=await e.promises.readdir(n,{withFileTypes:!0});await e.promises.mkdir(r,{recursive:!0});for(let
|
|
5
|
+
`)};return{start(e){return i=e,u=!0,o&&d(`\x1B[?25l`),m(),o&&(n=setInterval(m,80)),this},success(e){return u?(u=!1,n&&=(clearInterval(n),void 0),f(),o&&d(`\x1B[?25h`),d(`${j} ${e??i}\n`),this):this}}},P=async(n,r,i)=>{let a=i??r,o=await e.promises.readdir(n,{withFileTypes:!0});await e.promises.mkdir(r,{recursive:!0});let s=[];for(let i of o){if(i.name===`.git`)continue;let o=t.join(n,i.name),c=t.join(r,i.name);if(i.isDirectory())s.push(...await P(o,c,a));else if(i.isSymbolicLink()){let n=await e.promises.readlink(o);await e.promises.symlink(n,c),s.push(t.relative(a,c))}else await e.promises.copyFile(o,c),s.push(t.relative(a,c))}return s},F=async(n,r,i)=>{let o=r.tree;process.platform===`win32`&&await O(`git`,[`config`,`--global`,`core.longpaths`,`true`]);let s=`https://${n.token?n.token+`@`:n.token}${n.host}/${n.owner}/${n.repository}.git`,c=t.resolve(a.tmpdir(),`${n.repository}-${Date.now()}${Math.random().toString(16).slice(2,6)}`),l=N(),u=performance.now();!r.watch&&!o&&l.start(`Picking ${n.type}${n.type===`repository`?` without .git`:` from repository`}...`);try{await O(`git`,[`clone`,s,c,`--branch`,n.branch,`--depth`,`1`,`--single-branch`,...r.recursive?[`--recursive`]:[]])}catch{await O(`git`,[`clone`,s,c,...r.recursive?[`--recursive`]:[]]),await O(`git`,[`checkout`,n.branch],{cwd:c})}let d=t.resolve(c,n.path),f=await e.promises.stat(d),p=[];f.isDirectory()?(await e.promises.mkdir(i,{recursive:!0}),p=await P(d,i)):(await e.promises.mkdir(t.dirname(i),{recursive:!0}),await e.promises.copyFile(d,i),p=[t.basename(i)]);let m=Number(((performance.now()-u)/1e3).toFixed(2));return o||(r.watch?console.log(`- Synced at `+new Date().toLocaleTimeString()):l.success(`Picked ${n.type}${n.type===`repository`?` without .git`:` from repository`} in ${m} seconds.`)),await e.promises.rm(c,{recursive:!0,force:!0}),{files:p,duration:m}};function I(e){if(typeof e==`number`||/^\d+$/.test(e))return typeof e==`number`?e:parseInt(e,10);let t=/(\d+)([hms])/g,n=0,r;for(;(r=t.exec(e))!==null;){let e=parseInt(r[1],10);switch(r[2]){case`h`:n+=e*36e5;break;case`m`:n+=e*6e4;break;case`s`:n+=e*1e3;break}}return n}const L=async e=>{let t=(await O(`git`,[`ls-remote`,e])).stdout,n=t.match(/(.+)\s+HEAD/)?.[1],r=t.match(RegExp(`${n}\\s+refs/heads/(.+)`))?.[1];if(!r)throw Error(`Could not determine default branch!`);return r},R=[{prefix:`git@github.com:`,host:`github.com`},{prefix:`https://github.com/`,host:`github.com`},{prefix:`https://raw.githubusercontent.com/`,host:`github.com`},{prefix:`git@gitlab.com:`,host:`gitlab.com`},{prefix:`https://gitlab.com/`,host:`gitlab.com`},{prefix:`git@bitbucket.org:`,host:`bitbucket.org`},{prefix:`https://bitbucket.org/`,host:`bitbucket.org`}];async function z(e,{branch:t,target:n}){let r=e.match(/^https:\/\/([^@]+)@(github\.com|gitlab\.com|bitbucket\.org)/),i=``;r&&(i=r[1],e=e.replace(`${r[1]}@`,``));let a=`github.com`;for(let{prefix:t,host:n}of R)if(e.startsWith(t)){a=n,e=e.replace(t,``);break}let o=e.split(`/`),s=o[0],c=o[1]?.endsWith(`.git`)?o[1].slice(0,-4):o[1],l=`https://${i&&i+`@`}${a}/${s}/${c}`,u,d,f;a===`github.com`?o[2]===`refs`&&[`heads`,`tags`].includes(o[3])?(u=`raw`,d=t||o[4],f=o.slice(5).join(`/`)):o[2]===`refs`&&o[3]===`remotes`?(u=`raw`,d=t||`${o[4]}/${o[5]}`,f=o.slice(6).join(`/`)):o[2]===`blob`?(u=`blob`,d=t||o[3],f=o.slice(4).join(`/`)):o[2]===`tree`?(u=`tree`,d=t||o[3],f=o.slice(4).join(`/`)):o[2]===`commit`?(u=`repository`,d=t||o[3],f=``):(u=`repository`,d=t||await L(l),f=``):a===`gitlab.com`?o[2]===`-`&&o[3]===`blob`?(u=`blob`,d=t||o[4],f=o.slice(5).join(`/`)):o[2]===`-`&&o[3]===`tree`?(u=`tree`,d=t||o[4],f=o.slice(5).join(`/`)):(u=`repository`,d=t||await L(l),f=``):o[2]===`src`?(u=`tree`,d=t||o[3],f=o.slice(4).join(`/`)):(u=`repository`,d=t||await L(l),f=``);let p=n||(u===`blob`?`.`:f.split(`/`).pop()||c);return{token:i,host:a,owner:s,repository:c,type:u,branch:d,path:f,target:p}}const B=Symbol(`singleComment`),V=Symbol(`multiComment`),H=(e,t,n)=>e.slice(t,n).replace(/[^ \t\r\n]/g,` `),U=(e,t)=>{let n=t-1,r=0;for(;e[n]===`\\`;)--n,r+=1;return!!(r%2)};function W(e){if(typeof e!=`string`)throw TypeError(`Expected argument \`jsonString\` to be a \`string\`, got \`${typeof e}\``);let t=!1,n=!1,r=0,i=``,a=``,o=-1;for(let s=0;s<e.length;s++){let c=e[s],l=e[s+1];if(!n&&c===`"`&&(U(e,s)||(t=!t)),!t)if(!n&&c+l===`//`)i+=e.slice(r,s),r=s,n=B,s++;else if(n===B&&c+l===`\r
|
|
6
6
|
`){s++,n=!1,i+=H(e,r,s),r=s;continue}else if(n===B&&c===`
|
|
7
7
|
`)n=!1,i+=H(e,r,s),r=s;else if(!n&&c+l===`/*`){i+=e.slice(r,s),r=s,n=V,s++;continue}else if(n===V&&c+l===`*/`){s++,n=!1,i+=H(e,r,s+1),r=s+1;continue}else n||(o===-1?c===`,`&&(a+=i+e.slice(r,s),i=``,r=s,o=s):c===`}`||c===`]`?(i+=e.slice(r,s),a+=H(i,0,1)+i.slice(1),i=``,r=s,o=-1):c!==` `&&c!==` `&&c!==`\r`&&c!==`
|
|
8
|
-
`&&(i+=e.slice(r,s),r=s,o=-1))}let s=n===B?H(e,r):e.slice(r);return a+i+s}const G=[`.gitpick.json`,`.gitpick.jsonc`],K=async()=>{let n;for(let r of G){let i=t.resolve(r);if(e.existsSync(i)){n=i;break}}if(!n)return!1;let r=await e.promises.readFile(n,`utf-8`),i=JSON.parse(W(r));if(!Array.isArray(i)||!i.every(e=>typeof e==`string`))throw Error(`${t.basename(n)} must be an array of strings`);for(let e of i)await O(process.argv[0],[...process.argv.slice(1),...e.split(/\s+/),`-o`],{stdio:`inherit`});return!0};var q=`gitpick`,J=`4.17.0-canary.
|
|
8
|
+
`&&(i+=e.slice(r,s),r=s,o=-1))}let s=n===B?H(e,r):e.slice(r);return a+i+s}const G=[`.gitpick.json`,`.gitpick.jsonc`],K=async()=>{let n;for(let r of G){let i=t.resolve(r);if(e.existsSync(i)){n=i;break}}if(!n)return!1;let r=await e.promises.readFile(n,`utf-8`),i=JSON.parse(W(r));if(!Array.isArray(i)||!i.every(e=>typeof e==`string`))throw Error(`${t.basename(n)} must be an array of strings`);for(let e of i)await O(process.argv[0],[...process.argv.slice(1),...e.split(/\s+/),`-o`],{stdio:`inherit`});return!0};var q=`gitpick`,J=`4.17.0-canary.6`;const Y=(e,t)=>`\x1b]8;;${t}\x07${e}\x1b]8;;\x07`,X=`
|
|
9
9
|
With ${p(`${Y(`GitPick`,`https://github.com/nrjdalal/gitpick`)}`)} clone specific directories or files from GitHub, GitLab and Bitbucket!
|
|
10
10
|
|
|
11
11
|
$ gitpick ${g(`<url>`)} ${h(`[target]`)} ${_(`[options]`)}
|
|
@@ -25,6 +25,7 @@ ${p(`Options:`)}
|
|
|
25
25
|
${_(`-r, --recursive`)} Clone submodules
|
|
26
26
|
${_(`-w, --watch [time]`)} Watch the repository and sync every [time]
|
|
27
27
|
(e.g. 1h, 30m, 15s)
|
|
28
|
+
${_(` --tree`)} List copied files as a tree
|
|
28
29
|
${_(`-h, --help`)} display help for command
|
|
29
30
|
${_(`-v, --version`)} display the version number
|
|
30
31
|
|
|
@@ -38,5 +39,5 @@ ${p(`Examples:`)}
|
|
|
38
39
|
$ gitpick https://gitlab.com/owner/repo
|
|
39
40
|
$ gitpick https://bitbucket.org/owner/repo
|
|
40
41
|
|
|
41
|
-
š More awesome tools at ${_(`https://github.com/nrjdalal`)}`,Z=e=>{try{return n(e)}catch(e){throw Error(`Error parsing arguments: ${e.message}`)}};(async()=>{try{let{positionals:n,values:r}=
|
|
42
|
+
š More awesome tools at ${_(`https://github.com/nrjdalal`)}`,Z=async(n,r=``)=>{let i=(await e.promises.readdir(n,{withFileTypes:!0})).filter(e=>e.name!==`.git`).sort((e,t)=>e.name.localeCompare(t.name,void 0,{sensitivity:`base`}));for(let a=0;a<i.length;a++){let o=i[a],s=a===i.length-1,c=s?`āāā `:`āāā `,l=t.join(n,o.name);if(o.isSymbolicLink()){let t=await e.promises.readlink(l);process.stdout.write(`${r}${c}${o.name} -> ${t}\n`)}else o.isDirectory()?(process.stdout.write(`${r}${c}${o.name}\n`),await Z(l,`${r}${s?` `:`ā `}`)):process.stdout.write(`${r}${c}${o.name}\n`)}},Q=e=>{try{return n(e)}catch(e){throw Error(`Error parsing arguments: ${e.message}`)}};(async()=>{try{let{positionals:n,values:r}=Q({allowPositionals:!0,options:{branch:{type:`string`,short:`b`},"dry-run":{type:`boolean`,short:`n`},force:{type:`boolean`,short:`f`},help:{type:`boolean`,short:`h`},tree:{type:`boolean`},overwrite:{type:`boolean`,short:`o`},recursive:{type:`boolean`,short:`r`},version:{type:`boolean`,short:`v`},watch:{type:`string`,short:`w`}}});n.length||(r.version&&(console.log(`\n${q}@${J}`),process.exit(0)),await K()&&process.exit(0),console.log(X),process.exit(0)),n[0]===`clone`&&n.shift();let[i,a]=n,o={branch:r.branch,dryRun:r[`dry-run`],force:r.force,tree:r.tree,overwrite:r.overwrite,recursive:r.recursive,watch:r.watch},s=o.tree;s||console.log(`\nWith ${p(`${Y(`GitPick`,`https://github.com/nrjdalal/gitpick`)}`)} clone specific files, folders, branches, commits and more from GitHub, GitLab and Bitbucket!`);let c=await z(i,{branch:o.branch,target:a});if(c.type===`blob`){let e=c.target.split(/[/\\]/).filter(e=>e!==``),t=e[e.length-1];t!==`.`&&t!==`..`&&t.includes(`.`)?e.pop():t=c.path.split(`/`).pop()||t,c.target=[...e,t].join(`/`)}s||console.info(`\n${h(`ā`)} ${c.owner}/${c.repository} ${_(c.type+`:`+c.branch)} ${c.type===`repository`?`> ${h(c.target)}`:`${c.path.length?g(c.path)+` >`:`>`} ${h(c.target)}`}`),o.dryRun&&(o.tree&&c.path&&console.log(c.path),s||console.log(),process.exit(0));let l=t.resolve(c.target);o.overwrite=o.overwrite||o.force,o.watch&&(o.overwrite=!0),e.existsSync(l)&&!o.overwrite&&(c.type===`blob`&&(console.log(`${g(`\nWarning: The target file exists at ${h(c.target)}. Use ${_(`-f`)} or ${_(`-o`)} to overwrite.`)}`),process.exit(1)),(await e.promises.readdir(l)).length&&(console.log(`${g(`\nWarning: The target directory exists at ${h(c.target)} and is not empty. Use ${_(`-f`)} or ${_(`-o`)} to overwrite.`)}`),process.exit(1)));let u=async()=>{o.tree&&(e.statSync(l).isDirectory()?await Z(l):process.stdout.write(`āāā ${t.basename(l)}\n`))};if(o.watch){s||console.log(`\nš Watching every ${I(o.watch)/1e3+`s`}\n`),await F(c,o,l),await u();let e=I(o.watch);setInterval(async()=>{await F(c,o,l),await u()},e)}else await F(c,o,l),await u(),process.exit(0)}catch(e){e instanceof Error?console.log(p(`\n${m(`Error: `)}`)+e.message):console.log(p(`${m(`
|
|
42
43
|
Unexpected Error: `)}`)+JSON.stringify(e,null,2)),process.exit(1)}})();export{};
|