gitpick 4.16.0-canary.6 ā 4.16.1
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 +21 -13
- package/dist/index.mjs +4 -1
- 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 (~22/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)
|
|
@@ -83,18 +83,20 @@ npx gitpick <url/shorthand> [target] [options]
|
|
|
83
83
|
Examples:
|
|
84
84
|
|
|
85
85
|
```sh
|
|
86
|
-
npx gitpick https://github.com/owner/repo
|
|
87
|
-
npx gitpick owner/repo/tree/main/path/to/folder
|
|
88
|
-
npx gitpick owner/repo/blob/main/path/to/file
|
|
89
|
-
|
|
90
|
-
npx gitpick <url/shorthand>
|
|
91
|
-
npx gitpick <url/shorthand> [target]
|
|
92
|
-
npx gitpick <url/shorthand> -b [branch/SHA]
|
|
93
|
-
npx gitpick <url/shorthand> -o
|
|
94
|
-
npx gitpick <url/shorthand> -r
|
|
95
|
-
npx gitpick <url/shorthand> -w 30s
|
|
96
|
-
npx gitpick
|
|
97
|
-
npx gitpick
|
|
86
|
+
npx gitpick https://github.com/owner/repo # repo without .git
|
|
87
|
+
npx gitpick owner/repo/tree/main/path/to/folder # a folder aka tree
|
|
88
|
+
npx gitpick owner/repo/blob/main/path/to/file # a file aka blob
|
|
89
|
+
|
|
90
|
+
npx gitpick <url/shorthand> # default git behavior
|
|
91
|
+
npx gitpick <url/shorthand> [target] # with optional target
|
|
92
|
+
npx gitpick <url/shorthand> -b [branch/SHA] # branch or commit SHA
|
|
93
|
+
npx gitpick <url/shorthand> -o # overwrite if exists
|
|
94
|
+
npx gitpick <url/shorthand> -r # clone submodules
|
|
95
|
+
npx gitpick <url/shorthand> -w 30s # sync every 30 seconds
|
|
96
|
+
npx gitpick <url/shorthand> --dry-run # preview without cloning
|
|
97
|
+
npx gitpick https://<token>@github.com/owner/repo # private repository
|
|
98
|
+
npx gitpick https://gitlab.com/owner/repo # GitLab
|
|
99
|
+
npx gitpick https://bitbucket.org/owner/repo # Bitbucket
|
|
98
100
|
```
|
|
99
101
|
|
|
100
102
|
<img width="720" alt="Image" src="https://github.com/user-attachments/assets/ddbc41b4-bfc6-4287-bb85-eb949d723591" />
|
|
@@ -159,6 +161,12 @@ Create a `.gitpick.json` or `.gitpick.jsonc` in your project to pick multiple fi
|
|
|
159
161
|
"https://github.com/owner/repo -r",
|
|
160
162
|
// clone a private repo
|
|
161
163
|
"https://<token>@github.com/owner/repo",
|
|
164
|
+
// GitLab
|
|
165
|
+
"https://gitlab.com/owner/repo",
|
|
166
|
+
"https://gitlab.com/owner/repo/-/tree/main/path/to/folder",
|
|
167
|
+
// Bitbucket
|
|
168
|
+
"https://bitbucket.org/owner/repo",
|
|
169
|
+
"https://bitbucket.org/owner/repo/src/main/path/to/folder",
|
|
162
170
|
]
|
|
163
171
|
```
|
|
164
172
|
|
package/dist/index.mjs
CHANGED
|
@@ -5,7 +5,7 @@ import e from"node:fs";import t from"node:path";import{parseArgs as n,stripVTCon
|
|
|
5
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 a of i){if(a.name===`.git`)continue;let i=t.join(n,a.name),o=t.join(r,a.name);if(a.isDirectory())await P(i,o);else if(a.isSymbolicLink()){let t=await e.promises.readlink(i);await e.promises.symlink(t,o)}else await e.promises.copyFile(i,o)}},F=async(n,r,i)=>{process.platform===`win32`&&await O(`git`,[`config`,`--global`,`core.longpaths`,`true`]);let o=`https://${n.token?n.token+`@`:n.token}${n.host}/${n.owner}/${n.repository}.git`,s=t.resolve(a.tmpdir(),`${n.repository}-${Date.now()}${Math.random().toString(16).slice(2,6)}`),c=N(),l=performance.now();r.watch||c.start(`Picking ${n.type}${n.type===`repository`?` without .git`:` from repository`}...`);try{await O(`git`,[`clone`,o,s,`--branch`,n.branch,`--depth`,`1`,`--single-branch`,...r.recursive?[`--recursive`]:[]])}catch{await O(`git`,[`clone`,o,s,...r.recursive?[`--recursive`]:[]]),await O(`git`,[`checkout`,n.branch],{cwd:s})}let u=t.resolve(s,n.path);(await e.promises.stat(u)).isDirectory()?(await e.promises.mkdir(i,{recursive:!0}),await P(u,i)):(await e.promises.mkdir(t.dirname(i),{recursive:!0}),await e.promises.copyFile(u,i)),r.watch?console.log(`- Synced at `+new Date().toLocaleTimeString()):c.success(`Picked ${n.type}${n.type===`repository`?` without .git`:` from repository`} in ${((performance.now()-l)/1e3).toFixed(2)} seconds.`),await e.promises.rm(s,{recursive:!0,force:!0})};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.16.
|
|
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.16.1`;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]`)}
|
|
@@ -34,6 +34,9 @@ ${p(`Examples:`)}
|
|
|
34
34
|
$ gitpick <url> [target] -b [branch/SHA]
|
|
35
35
|
$ gitpick <url> [target] -w [time]
|
|
36
36
|
$ gitpick <url> [target] -b [branch/SHA] -w [time]
|
|
37
|
+
$ gitpick <url> --dry-run
|
|
38
|
+
$ gitpick https://gitlab.com/owner/repo
|
|
39
|
+
$ gitpick https://bitbucket.org/owner/repo
|
|
37
40
|
|
|
38
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}=Z({allowPositionals:!0,options:{branch:{type:`string`,short:`b`},"dry-run":{type:`boolean`,short:`n`},force:{type:`boolean`,short:`f`},help:{type:`boolean`,short:`h`},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,overwrite:r.overwrite,recursive:r.recursive,watch:r.watch};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 s=await z(i,{branch:o.branch,target:a});if(s.type===`blob`){let e=s.target.split(/[/\\]/).filter(e=>e!==``),t=e[e.length-1];t!==`.`&&t!==`..`&&t.includes(`.`)?e.pop():t=s.path.split(`/`).pop()||t,s.target=[...e,t].join(`/`)}console.info(`\n${h(`ā`)} ${s.owner}/${s.repository} ${_(s.type+`:`+s.branch)} ${s.type===`repository`?`> ${h(s.target)}`:`${s.path.length?g(s.path)+` >`:`>`} ${h(s.target)}`}`),o.dryRun&&(console.log(),process.exit(0));let c=t.resolve(s.target);if(o.overwrite=o.overwrite||o.force,o.watch&&(o.overwrite=!0),e.existsSync(c)&&!o.overwrite&&(s.type===`blob`&&(console.log(`${g(`\nWarning: The target file exists at ${h(s.target)}. Use ${_(`-f`)} or ${_(`-o`)} to overwrite.`)}`),process.exit(1)),(await e.promises.readdir(c)).length&&(console.log(`${g(`\nWarning: The target directory exists at ${h(s.target)} and is not empty. Use ${_(`-f`)} or ${_(`-o`)} to overwrite.`)}`),process.exit(1))),o.watch){console.log(`\nš Watching every ${I(o.watch)/1e3+`s`}\n`),await F(s,o,c);let e=I(o.watch);setInterval(async()=>await F(s,o,c),e)}else await F(s,o,c),process.exit(0)}catch(e){e instanceof Error?console.log(p(`\n${m(`Error: `)}`)+e.message):console.log(p(`${m(`
|
|
39
42
|
Unexpected Error: `)}`)+JSON.stringify(e,null,2)),process.exit(1)}})();export{};
|