just-bash 2.5.0 → 2.5.2
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/chunks/chunk-CTLU5QUH.js +17 -0
- package/dist/bin/chunks/{grep-WDHYDUUD.js → grep-QCXXYC54.js} +1 -1
- package/dist/bin/chunks/rg-GVIT6FTE.js +33 -0
- package/dist/bin/just-bash.js +99 -99
- package/dist/bin/shell/chunks/chunk-CTLU5QUH.js +17 -0
- package/dist/bin/shell/chunks/{grep-WDHYDUUD.js → grep-QCXXYC54.js} +1 -1
- package/dist/bin/shell/chunks/rg-GVIT6FTE.js +33 -0
- package/dist/bin/shell/shell.js +33 -33
- package/dist/bundle/browser.js +379 -375
- package/dist/bundle/chunks/chunk-OHJS5H37.js +16 -0
- package/dist/bundle/chunks/{grep-QVR5G7SC.js → grep-TUWLGQC2.js} +1 -1
- package/dist/bundle/chunks/rg-KTCMPGU6.js +32 -0
- package/dist/bundle/index.js +116 -116
- package/dist/commands/rg/file-types.d.ts +33 -7
- package/dist/commands/rg/gitignore.d.ts +32 -3
- package/dist/commands/rg/rg-options.d.ts +14 -0
- package/dist/commands/search-engine/index.d.ts +1 -1
- package/dist/commands/search-engine/regex.d.ts +10 -0
- package/dist/fs/in-memory-fs/in-memory-fs.d.ts +51 -0
- package/dist/fs/in-memory-fs/index.d.ts +1 -0
- package/dist/fs/init.d.ts +12 -0
- package/dist/fs/interface.d.ts +203 -0
- package/dist/fs/mountable-fs/index.d.ts +1 -0
- package/dist/fs/mountable-fs/mountable-fs.d.ts +108 -0
- package/dist/fs/overlay-fs/index.d.ts +1 -0
- package/dist/fs/overlay-fs/overlay-fs.d.ts +107 -0
- package/dist/fs/read-write-fs/index.d.ts +1 -0
- package/dist/fs/read-write-fs/read-write-fs.d.ts +47 -0
- package/dist/fs/utils.d.ts +17 -0
- package/package.json +2 -3
- package/dist/bin/chunks/chunk-X4WRNADE.js +0 -17
- package/dist/bin/chunks/rg-ALK3CYAN.js +0 -29
- package/dist/bin/shell/chunks/chunk-X4WRNADE.js +0 -17
- package/dist/bin/shell/chunks/rg-ALK3CYAN.js +0 -29
- package/dist/bundle/chunks/chunk-7VH6U2UX.js +0 -16
- package/dist/bundle/chunks/rg-43HLKW4V.js +0 -28
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
function D(u,e){return u.replace(/\$(&|\d+|<([^>]+)>)/g,(h,c,f)=>{if(c==="&")return e[0];if(f!==void 0)return e.groups?.[f]??"";let T=parseInt(c,10);return e[T]??""})}function F(u,e,h={}){let{invertMatch:c=!1,showLineNumbers:f=!1,countOnly:T=!1,countMatches:j=!1,filename:o="",onlyMatching:v=!1,beforeContext:A=0,afterContext:P=0,maxCount:w=0,contextSeparator:B="--",showColumn:S=!1,vimgrep:_=!1,showByteOffset:M=!1,replace:p=null,passthru:y=!1,multiline:N=!1}=h;if(N)return W(u,e,{invertMatch:c,showLineNumbers:f,countOnly:T,countMatches:j,filename:o,onlyMatching:v,beforeContext:A,afterContext:P,maxCount:w,contextSeparator:B,showColumn:S,showByteOffset:M,replace:p});let d=u.split(`
|
|
3
|
+
`),g=d.length,O=g>0&&d[g-1]===""?g-1:g;if(T||j){let l=0,a=(j||v)&&!c;for(let t=0;t<O;t++)if(e.lastIndex=0,a)for(let s=e.exec(d[t]);s!==null;s=e.exec(d[t]))l++,s[0].length===0&&e.lastIndex++;else e.test(d[t])!==c&&l++;return{output:`${o?`${o}:${l}`:String(l)}
|
|
4
|
+
`,matched:l>0,matchCount:l}}if(A===0&&P===0&&!y){let l=[],a=!1,n=0,t=0;for(let s=0;s<O&&!(w>0&&n>=w);s++){let L=d[s];if(e.lastIndex=0,e.test(L)!==c)if(a=!0,n++,v){e.lastIndex=0;for(let r=e.exec(L);r!==null;r=e.exec(L)){let b=p!==null?D(p,r):r[0],k=o?`${o}:`:"";M&&(k+=`${t+r.index}:`),f&&(k+=`${s+1}:`),S&&(k+=`${r.index+1}:`),l.push(k+b),r[0].length===0&&e.lastIndex++}}else if(_){e.lastIndex=0;for(let r=e.exec(L);r!==null;r=e.exec(L)){let b=o?`${o}:`:"";M&&(b+=`${t+r.index}:`),f&&(b+=`${s+1}:`),S&&(b+=`${r.index+1}:`),l.push(b+L),r[0].length===0&&e.lastIndex++}}else{e.lastIndex=0;let r=e.exec(L),b=r?r.index+1:1,k=L;p!==null&&(e.lastIndex=0,k=L.replace(e,(...I)=>{if(I[0].length===0)return"";let z=I,Z=I[I.length-1];return typeof Z=="object"&&Z!==null?(z.groups=Z,z.input=I[I.length-2],z.index=I[I.length-3]):(z.input=I[I.length-1],z.index=I[I.length-2]),D(p,z)}));let E=o?`${o}:`:"";M&&(E+=`${t+(r?r.index:0)}:`),f&&(E+=`${s+1}:`),S&&(E+=`${b}:`),l.push(E+k)}t+=L.length+1}return{output:l.length>0?`${l.join(`
|
|
5
|
+
`)}
|
|
6
|
+
`:"",matched:a,matchCount:n}}if(y){let l=[],a=!1,n=0;for(let t=0;t<O;t++){let s=d[t];e.lastIndex=0;let R=e.test(s)!==c;R&&(a=!0,n++);let r=R?":":"-",b=o?`${o}${r}`:"";f&&(b+=`${t+1}${r}`),l.push(b+s)}return{output:l.length>0?`${l.join(`
|
|
7
|
+
`)}
|
|
8
|
+
`:"",matched:a,matchCount:n}}let $=[],C=0,m=new Set,x=-1,i=[];for(let l=0;l<O&&!(w>0&&C>=w);l++)e.lastIndex=0,e.test(d[l])!==c&&(i.push(l),C++);for(let l of i){let a=Math.max(0,l-A);x>=0&&a>x+1&&$.push(B);for(let t=a;t<l;t++)if(!m.has(t)){m.add(t),x=t;let s=d[t];f&&(s=`${t+1}-${s}`),o&&(s=`${o}-${s}`),$.push(s)}if(!m.has(l)){m.add(l),x=l;let t=d[l];if(v){e.lastIndex=0;for(let s=e.exec(t);s!==null;s=e.exec(t)){let L=p!==null?p:s[0],R=o?`${o}:`:"";f&&(R+=`${l+1}:`),S&&(R+=`${s.index+1}:`),$.push(R+L),s[0].length===0&&e.lastIndex++}}else{let s=t;f&&(s=`${l+1}:${s}`),o&&(s=`${o}:${s}`),$.push(s)}}let n=Math.min(O-1,l+P);for(let t=l+1;t<=n;t++)if(!m.has(t)){m.add(t),x=t;let s=d[t];f&&(s=`${t+1}-${s}`),o&&(s=`${o}-${s}`),$.push(s)}}return{output:$.length>0?`${$.join(`
|
|
9
|
+
`)}
|
|
10
|
+
`:"",matched:C>0,matchCount:C}}function W(u,e,h){let{invertMatch:c,showLineNumbers:f,countOnly:T,countMatches:j,filename:o,onlyMatching:v,beforeContext:A,afterContext:P,maxCount:w,contextSeparator:B,showColumn:S,showByteOffset:_,replace:M}=h,p=u.split(`
|
|
11
|
+
`),y=p.length,N=y>0&&p[y-1]===""?y-1:y,d=[0];for(let i=0;i<u.length;i++)u[i]===`
|
|
12
|
+
`&&d.push(i+1);let g=i=>{let l=0;for(let a=0;a<d.length&&!(d[a]>i);a++)l=a;return l},O=i=>{let l=g(i);return i-d[l]+1},$=[];e.lastIndex=0;for(let i=e.exec(u);i!==null&&!(w>0&&$.length>=w);i=e.exec(u)){let l=g(i.index),a=g(i.index+Math.max(0,i[0].length-1));$.push({startLine:l,endLine:a,byteOffset:i.index,column:O(i.index),matchText:i[0]}),i[0].length===0&&e.lastIndex++}if(T||j){let i;if(j)i=c?0:$.length;else{let a=new Set;for(let n of $)for(let t=n.startLine;t<=n.endLine;t++)a.add(t);i=c?N-a.size:a.size}return{output:`${o?`${o}:${i}`:String(i)}
|
|
13
|
+
`,matched:i>0,matchCount:i}}if(c){let i=new Set;for(let a of $)for(let n=a.startLine;n<=a.endLine;n++)i.add(n);let l=[];for(let a=0;a<N;a++)if(!i.has(a)){let n=p[a];f&&(n=`${a+1}:${n}`),o&&(n=`${o}:${n}`),l.push(n)}return{output:l.length>0?`${l.join(`
|
|
14
|
+
`)}
|
|
15
|
+
`:"",matched:l.length>0,matchCount:l.length}}if($.length===0)return{output:"",matched:!1,matchCount:0};let C=new Set,m=-1,x=[];for(let i of $){let l=Math.max(0,i.startLine-A),a=Math.min(N-1,i.endLine+P);m>=0&&l>m+1&&x.push(B);for(let n=l;n<i.startLine;n++)if(!C.has(n)){C.add(n),m=n;let t=p[n];f&&(t=`${n+1}-${t}`),o&&(t=`${o}-${t}`),x.push(t)}if(v){let n=M!==null?M:i.matchText,t=o?`${o}:`:"";_&&(t+=`${i.byteOffset}:`),f&&(t+=`${i.startLine+1}:`),S&&(t+=`${i.column}:`),x.push(t+n);for(let s=i.startLine;s<=i.endLine;s++)C.add(s),m=s}else for(let n=i.startLine;n<=i.endLine&&n<N;n++)if(!C.has(n)){C.add(n),m=n;let t=p[n];M!==null&&n===i.startLine&&(e.lastIndex=0,t=t.replace(e,M));let s=o?`${o}:`:"";_&&n===i.startLine&&(s+=`${i.byteOffset}:`),f&&(s+=`${n+1}:`),S&&n===i.startLine&&(s+=`${i.column}:`),x.push(s+t)}for(let n=i.endLine+1;n<=a;n++)if(!C.has(n)){C.add(n),m=n;let t=p[n];f&&(t=`${n+1}-${t}`),o&&(t=`${o}-${t}`),x.push(t)}}return{output:x.length>0?`${x.join(`
|
|
16
|
+
`)}
|
|
17
|
+
`:"",matched:!0,matchCount:$.length}}function q(u,e){let h;switch(e.mode){case"fixed":h=u.replace(/[.*+?^${}()|[\]\\]/g,"\\$&");break;case"extended":case"perl":h=u.replace(/\(\?P<([^>]+)>/g,"(?<$1>");break;default:h=H(u);break}e.wholeWord&&(h=`(?<![\\w])(?:${h})(?![\\w])`),e.lineRegexp&&(h=`^${h}$`);let c="g"+(e.ignoreCase?"i":"")+(e.multiline?"m":"")+(e.multilineDotall?"s":"");return new RegExp(h,c)}function G(u){let e=u.replace(/\$\{0\}|\$0(?![0-9])/g,"$$&");return e=e.replace(/\$\{([^0-9}][^}]*)\}/g,"$$<$1>"),e=e.replace(/\$([a-zA-Z_][a-zA-Z0-9_]*)(?![>0-9])/g,"$$<$1>"),e}function H(u){let e="",h=0;for(;h<u.length;){let c=u[h];if(c==="\\"&&h+1<u.length){let f=u[h+1];if(f==="|"||f==="("||f===")"){e+=f,h+=2;continue}else if(f==="{"||f==="}"){e+=`\\${f}`,h+=2;continue}}c==="+"||c==="?"||c==="|"||c==="("||c===")"||c==="{"||c==="}"?e+=`\\${c}`:e+=c,h++}return e}export{F as a,q as b,G as c};
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import{a as y}from"./chunk-26Q3PZQ6.js";import{a as S,b as j}from"./chunk-
|
|
2
|
+
import{a as y}from"./chunk-26Q3PZQ6.js";import{a as S,b as j}from"./chunk-CTLU5QUH.js";import{a as Z,b as _,c as L}from"./chunk-GTNBSMZR.js";import"./chunk-KGOUQS5A.js";var ee={name:"grep",summary:"print lines that match patterns",usage:"grep [OPTION]... PATTERN [FILE]...",options:["-E, --extended-regexp PATTERN is an extended regular expression","-P, --perl-regexp PATTERN is a Perl regular expression","-F, --fixed-strings PATTERN is a set of newline-separated strings","-i, --ignore-case ignore case distinctions","-v, --invert-match select non-matching lines","-w, --word-regexp match only whole words","-x, --line-regexp match only whole lines","-c, --count print only a count of matching lines","-l, --files-with-matches print only names of files with matches","-L, --files-without-match print names of files with no matches","-m NUM, --max-count=NUM stop after NUM matches","-n, --line-number print line number with output lines","-h, --no-filename suppress the file name prefix on output","-o, --only-matching show only nonempty parts of lines that match","-q, --quiet, --silent suppress all normal output","-r, -R, --recursive search directories recursively","-A NUM print NUM lines of trailing context","-B NUM print NUM lines of leading context","-C NUM print NUM lines of context","-e PATTERN use PATTERN for matching"," --include=GLOB search only files matching GLOB"," --exclude=GLOB skip files matching GLOB"," --exclude-dir=DIR skip directories matching DIR"," --help display this help and exit"]},z={name:"grep",async execute(t,s){if(_(t))return Z(ee);let o=!1,f=!1,c=!1,p=!1,m=!1,l=!1,i=!1,d=!1,w=!1,u=!1,h=!1,T=!1,x=!1,q=!1,B=!1,W=0,F=0,N=0,R=[],A=[],Q=[],$=null,I=[];for(let r=0;r<t.length;r++){let n=t[r];if(n.startsWith("-")&&n!=="-"){if(n==="-e"&&r+1<t.length){$=t[++r];continue}if(n.startsWith("--include=")){R.push(n.slice(10));continue}if(n.startsWith("--exclude=")){A.push(n.slice(10));continue}if(n.startsWith("--exclude-dir=")){Q.push(n.slice(14));continue}if(n.startsWith("--max-count=")){W=parseInt(n.slice(12),10);continue}let C=n.match(/^-m(\d+)$/);if(C){W=parseInt(C[1],10);continue}if(n==="-m"&&r+1<t.length){W=parseInt(t[++r],10);continue}let a=n.match(/^-([ABC])(\d+)$/);if(a){let e=parseInt(a[2],10);a[1]==="A"?N=e:a[1]==="B"?F=e:a[1]==="C"&&(F=e,N=e);continue}if((n==="-A"||n==="-B"||n==="-C")&&r+1<t.length){let e=parseInt(t[++r],10);n==="-A"?N=e:n==="-B"?F=e:(F=e,N=e);continue}let g=n.startsWith("--")?[n]:n.slice(1).split("");for(let e of g)if(e==="i"||e==="--ignore-case")o=!0;else if(e==="n"||e==="--line-number")f=!0;else if(e==="v"||e==="--invert-match")c=!0;else if(e==="c"||e==="--count")p=!0;else if(e==="l"||e==="--files-with-matches")m=!0;else if(e==="L"||e==="--files-without-match")l=!0;else if(e==="r"||e==="R"||e==="--recursive")i=!0;else if(e==="w"||e==="--word-regexp")d=!0;else if(e==="x"||e==="--line-regexp")w=!0;else if(e==="E"||e==="--extended-regexp")u=!0;else if(e==="P"||e==="--perl-regexp")h=!0;else if(e==="F"||e==="--fixed-strings")T=!0;else if(e==="o"||e==="--only-matching")x=!0;else if(e==="h"||e==="--no-filename")q=!0;else if(e==="q"||e==="--quiet"||e==="--silent")B=!0;else{if(e.startsWith("--"))return L("grep",e);if(e.length===1)return L("grep",`-${e}`)}}else $===null?$=n:I.push(n)}if($===null)return{stdout:"",stderr:`grep: missing pattern
|
|
3
3
|
`,exitCode:2};let K=T?"fixed":u?"extended":h?"perl":"basic",U;try{U=j($,{mode:K,ignoreCase:o,wholeWord:d,lineRegexp:w})}catch{return{stdout:"",stderr:`grep: invalid regular expression: ${$}
|
|
4
4
|
`,exitCode:2}}if(I.length===0&&s.stdin){let r=S(s.stdin,U,{invertMatch:c,showLineNumbers:f,countOnly:p,filename:"",onlyMatching:x,beforeContext:F,afterContext:N,maxCount:W});return B?{stdout:"",stderr:"",exitCode:r.matched?0:1}:{stdout:r.output,stderr:"",exitCode:r.matched?0:1}}if(I.length===0)return{stdout:"",stderr:`grep: no input files
|
|
5
5
|
`,exitCode:2};let v="",D="",G=!1,H=!1,P=[];for(let r of I)if(r.includes("*")||r.includes("?")||r.includes("[")){let n=await te(r,s);if(i)for(let C of n){let a=await O(C.path,s,R,A,Q,C.isFile);P.push(...a)}else P.push(...n)}else if(i){let n=await O(r,s,R,A,Q);P.push(...n)}else P.push({path:r});let V=(P.length>1||i)&&!q,k=50;for(let r=0;r<P.length;r+=k){let n=P.slice(r,r+k),C=await Promise.all(n.map(async a=>{let g=a.path,e=g.split("/").pop()||g;if(A.length>0&&!i&&A.some(M=>y(e,M,{stripQuotes:!0}))||R.length>0&&!i&&!R.some(M=>y(e,M,{stripQuotes:!0})))return null;try{let M=s.fs.resolvePath(s.cwd,g),b=!1;if(a.isFile===void 0?b=(await s.fs.stat(M)).isDirectory:b=!a.isFile,b)return i?null:{error:`grep: ${g}: Is a directory
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
import{a as E,b as R,c as A}from"./chunk-CTLU5QUH.js";import{a as L,b as _,c as k}from"./chunk-GTNBSMZR.js";import"./chunk-KGOUQS5A.js";var z={js:{extensions:[".js",".mjs",".cjs",".jsx"],globs:[]},ts:{extensions:[".ts",".tsx",".mts",".cts"],globs:[]},html:{extensions:[".html",".htm",".xhtml"],globs:[]},css:{extensions:[".css",".scss",".sass",".less"],globs:[]},json:{extensions:[".json",".jsonc",".json5"],globs:[]},xml:{extensions:[".xml",".xsl",".xslt"],globs:[]},c:{extensions:[".c",".h"],globs:[]},cpp:{extensions:[".cpp",".cc",".cxx",".hpp",".hh",".hxx",".h"],globs:[]},rust:{extensions:[".rs"],globs:[]},go:{extensions:[".go"],globs:[]},zig:{extensions:[".zig"],globs:[]},java:{extensions:[".java"],globs:[]},kotlin:{extensions:[".kt",".kts"],globs:[]},scala:{extensions:[".scala",".sc"],globs:[]},clojure:{extensions:[".clj",".cljc",".cljs",".edn"],globs:[]},py:{extensions:[".py",".pyi",".pyw"],globs:[]},rb:{extensions:[".rb",".rake",".gemspec"],globs:["Rakefile","Gemfile"]},php:{extensions:[".php",".phtml",".php3",".php4",".php5"],globs:[]},perl:{extensions:[".pl",".pm",".pod",".t"],globs:[]},lua:{extensions:[".lua"],globs:[]},sh:{extensions:[".sh",".bash",".zsh",".fish"],globs:[".bashrc",".zshrc",".profile"]},bat:{extensions:[".bat",".cmd"],globs:[]},ps:{extensions:[".ps1",".psm1",".psd1"],globs:[]},yaml:{extensions:[".yaml",".yml"],globs:[]},toml:{extensions:[".toml"],globs:["Cargo.toml","pyproject.toml"]},ini:{extensions:[".ini",".cfg",".conf"],globs:[]},csv:{extensions:[".csv",".tsv"],globs:[]},md:{extensions:[".md",".mdx",".markdown",".mdown",".mkd"],globs:[]},markdown:{extensions:[".md",".mdx",".markdown",".mdown",".mkd"],globs:[]},rst:{extensions:[".rst"],globs:[]},txt:{extensions:[".txt",".text"],globs:[]},tex:{extensions:[".tex",".ltx",".sty",".cls"],globs:[]},sql:{extensions:[".sql"],globs:[]},graphql:{extensions:[".graphql",".gql"],globs:[]},proto:{extensions:[".proto"],globs:[]},make:{extensions:[".mk",".mak"],globs:["Makefile","GNUmakefile","makefile"]},docker:{extensions:[],globs:["Dockerfile","Dockerfile.*","*.dockerfile"]},tf:{extensions:[".tf",".tfvars"],globs:[]}},S=class{types;constructor(){this.types=new Map(Object.entries(z).map(([t,n])=>[t,{extensions:[...n.extensions],globs:[...n.globs]}]))}addType(t){let n=t.indexOf(":");if(n===-1)return;let s=t.slice(0,n),r=t.slice(n+1);if(r.startsWith("include:")){let l=r.slice(8),i=this.types.get(l);if(i){let a=this.types.get(s)||{extensions:[],globs:[]};a.extensions.push(...i.extensions),a.globs.push(...i.globs),this.types.set(s,a)}}else{let l=this.types.get(s)||{extensions:[],globs:[]};if(r.startsWith("*.")&&!r.slice(2).includes("*")){let i=r.slice(1);l.extensions.includes(i)||l.extensions.push(i)}else l.globs.includes(r)||l.globs.push(r);this.types.set(s,l)}}clearType(t){let n=this.types.get(t);n&&(n.extensions=[],n.globs=[])}getType(t){return this.types.get(t)}getAllTypes(){return this.types}matchesType(t,n){let s=t.toLowerCase();for(let r of n){if(r==="all"){if(this.matchesAnyType(t))return!0;continue}let l=this.types.get(r);if(l){for(let i of l.extensions)if(s.endsWith(i))return!0;for(let i of l.globs)if(i.includes("*")){let a=i.replace(/\./g,"\\.").replace(/\*/g,".*");if(new RegExp(`^${a}$`,"i").test(t))return!0}else if(s===i.toLowerCase())return!0}}return!1}matchesAnyType(t){let n=t.toLowerCase();for(let s of this.types.values()){for(let r of s.extensions)if(n.endsWith(r))return!0;for(let r of s.globs)if(r.includes("*")){let l=r.replace(/\./g,"\\.").replace(/\*/g,".*");if(new RegExp(`^${l}$`,"i").test(t))return!0}else if(n===r.toLowerCase())return!0}return!1}};function B(){let e=[];for(let[t,n]of Object.entries(z).sort()){let s=[];for(let r of n.extensions)s.push(`*${r}`);for(let r of n.globs)s.push(r);e.push(`${t}: ${s.join(", ")}`)}return`${e.join(`
|
|
3
|
+
`)}
|
|
4
|
+
`}function G(){return{ignoreCase:!1,caseSensitive:!1,smartCase:!0,fixedStrings:!1,wordRegexp:!1,lineRegexp:!1,invertMatch:!1,multiline:!1,multilineDotall:!1,patterns:[],patternFiles:[],count:!1,countMatches:!1,files:!1,filesWithMatches:!1,filesWithoutMatch:!1,stats:!1,onlyMatching:!1,maxCount:0,lineNumber:!0,noFilename:!1,withFilename:!1,nullSeparator:!1,byteOffset:!1,column:!1,vimgrep:!1,replace:null,afterContext:0,beforeContext:0,contextSeparator:"--",quiet:!1,heading:!1,passthru:!1,includeZero:!1,sort:"path",json:!1,globs:[],iglobs:[],globCaseInsensitive:!1,types:[],typesNot:[],typeAdd:[],typeClear:[],hidden:!1,noIgnore:!1,noIgnoreDot:!1,noIgnoreVcs:!1,ignoreFiles:[],maxDepth:1/0,maxFilesize:0,followSymlinks:!1,searchZip:!1,searchBinary:!1,preprocessor:null,preprocessorGlobs:[]}}function K(e){let t=e.match(/^(\d+)([KMG])?$/i);if(!t)return 0;let n=parseInt(t[1],10);switch((t[2]||"").toUpperCase()){case"K":return n*1024;case"M":return n*1024*1024;case"G":return n*1024*1024*1024;default:return n}}function X(e){return/^\d+[KMG]?$/i.test(e)?null:{stdout:"",stderr:`rg: invalid --max-filesize value: ${e}
|
|
5
|
+
`,exitCode:1}}function U(e){return null}var q=[{short:"g",long:"glob",target:"globs",multi:!0},{long:"iglob",target:"iglobs",multi:!0},{short:"t",long:"type",target:"types",multi:!0,validate:U},{short:"T",long:"type-not",target:"typesNot",multi:!0,validate:U},{long:"type-add",target:"typeAdd",multi:!0},{long:"type-clear",target:"typeClear",multi:!0},{short:"m",long:"max-count",target:"maxCount",parse:parseInt},{short:"e",long:"regexp",target:"patterns",multi:!0},{short:"f",long:"file",target:"patternFiles",multi:!0},{short:"r",long:"replace",target:"replace"},{short:"d",long:"max-depth",target:"maxDepth",parse:parseInt},{long:"max-filesize",target:"maxFilesize",parse:K,validate:X},{long:"context-separator",target:"contextSeparator"},{short:"j",long:"threads",target:"maxDepth",parse:()=>1/0},{long:"ignore-file",target:"ignoreFiles",multi:!0},{long:"pre",target:"preprocessor"},{long:"pre-glob",target:"preprocessorGlobs",multi:!0}],Q={i:e=>{e.ignoreCase=!0,e.caseSensitive=!1,e.smartCase=!1},"--ignore-case":e=>{e.ignoreCase=!0,e.caseSensitive=!1,e.smartCase=!1},s:e=>{e.caseSensitive=!0,e.ignoreCase=!1,e.smartCase=!1},"--case-sensitive":e=>{e.caseSensitive=!0,e.ignoreCase=!1,e.smartCase=!1},S:e=>{e.smartCase=!0,e.ignoreCase=!1,e.caseSensitive=!1},"--smart-case":e=>{e.smartCase=!0,e.ignoreCase=!1,e.caseSensitive=!1},F:e=>{e.fixedStrings=!0},"--fixed-strings":e=>{e.fixedStrings=!0},w:e=>{e.wordRegexp=!0},"--word-regexp":e=>{e.wordRegexp=!0},x:e=>{e.lineRegexp=!0},"--line-regexp":e=>{e.lineRegexp=!0},v:e=>{e.invertMatch=!0},"--invert-match":e=>{e.invertMatch=!0},U:e=>{e.multiline=!0},"--multiline":e=>{e.multiline=!0},"--multiline-dotall":e=>{e.multilineDotall=!0,e.multiline=!0},c:e=>{e.count=!0},"--count":e=>{e.count=!0},"--count-matches":e=>{e.countMatches=!0},l:e=>{e.filesWithMatches=!0},"--files":e=>{e.files=!0},"--files-with-matches":e=>{e.filesWithMatches=!0},"--files-without-match":e=>{e.filesWithoutMatch=!0},"--stats":e=>{e.stats=!0},o:e=>{e.onlyMatching=!0},"--only-matching":e=>{e.onlyMatching=!0},q:e=>{e.quiet=!0},"--quiet":e=>{e.quiet=!0},N:e=>{e.lineNumber=!1},"--no-line-number":e=>{e.lineNumber=!1},H:e=>{e.withFilename=!0},"--with-filename":e=>{e.withFilename=!0},I:e=>{e.noFilename=!0},"--no-filename":e=>{e.noFilename=!0},0:e=>{e.nullSeparator=!0},"--null":e=>{e.nullSeparator=!0},b:e=>{e.byteOffset=!0},"--byte-offset":e=>{e.byteOffset=!0},"--column":e=>{e.column=!0,e.lineNumber=!0},"--no-column":e=>{e.column=!1},"--vimgrep":e=>{e.vimgrep=!0,e.column=!0,e.lineNumber=!0},"--json":e=>{e.json=!0},"--hidden":e=>{e.hidden=!0},"--no-ignore":e=>{e.noIgnore=!0},"--no-ignore-dot":e=>{e.noIgnoreDot=!0},"--no-ignore-vcs":e=>{e.noIgnoreVcs=!0},L:e=>{e.followSymlinks=!0},"--follow":e=>{e.followSymlinks=!0},z:e=>{e.searchZip=!0},"--search-zip":e=>{e.searchZip=!0},a:e=>{e.searchBinary=!0},"--text":e=>{e.searchBinary=!0},"--heading":e=>{e.heading=!0},"--passthru":e=>{e.passthru=!0},"--include-zero":e=>{e.includeZero=!0},"--glob-case-insensitive":e=>{e.globCaseInsensitive=!0}},ee=new Set(["n","--line-number"]);function te(e){e.hidden?e.searchBinary=!0:e.noIgnore?e.hidden=!0:e.noIgnore=!0}function se(e,t,n){let s=e[t];for(let r of q){if(s.startsWith(`--${r.long}=`)){let l=s.slice(`--${r.long}=`.length),i=j(n,r,l);return i?{newIndex:t,error:i}:{newIndex:t}}if(r.short&&s.startsWith(`-${r.short}`)&&s.length>2){let l=s.slice(2),i=j(n,r,l);return i?{newIndex:t,error:i}:{newIndex:t}}if(r.short&&s===`-${r.short}`||s===`--${r.long}`){if(t+1>=e.length)return null;let l=e[t+1],i=j(n,r,l);return i?{newIndex:t+1,error:i}:{newIndex:t+1}}}return null}function ne(e){return q.find(t=>t.short===e)}function j(e,t,n){if(t.validate){let r=t.validate(n);if(r)return r}let s=t.parse?t.parse(n):n;t.multi?e[t.target].push(s):e[t.target]=s}function re(e,t){let n=e[t];if(n==="--sort"&&t+1<e.length){let s=e[t+1];if(s==="path"||s==="none")return{value:s,newIndex:t+1}}if(n.startsWith("--sort=")){let s=n.slice(7);if(s==="path"||s==="none")return{value:s,newIndex:t}}return null}function ie(e,t){let n=e[t],s=n.match(/^-([ABC])(\d+)$/);return s?{flag:s[1],value:parseInt(s[2],10),newIndex:t}:(n==="-A"||n==="-B"||n==="-C")&&t+1<e.length?{flag:n[1],value:parseInt(e[t+1],10),newIndex:t+1}:null}function le(e){let t=e.match(/^-m(\d+)$/);return t?parseInt(t[1],10):null}function V(e){let t=G(),n=null,s=[],r=-1,l=-1,i=-1,a=!1;for(let c=0;c<e.length;c++){let o=e[c];if(o.startsWith("-")&&o!=="-"){let h=ie(e,c);if(h){let{flag:f,value:w,newIndex:d}=h;f==="A"?r=Math.max(r,w):f==="B"?l=Math.max(l,w):i=w,c=d;continue}let m=le(o);if(m!==null){t.maxCount=m;continue}let y=se(e,c,t);if(y){if(y.error)return{success:!1,error:y.error};c=y.newIndex;continue}let p=re(e,c);if(p){t.sort=p.value,c=p.newIndex;continue}let b=o.startsWith("--")?[o]:o.slice(1).split(""),u=!1;for(let f of b){if(ee.has(f)){t.lineNumber=!0,a=!0;continue}if(f==="u"||f==="--unrestricted"){te(t);continue}if(f==="P"||f==="--pcre2")return{success:!1,error:{stdout:"",stderr:`rg: PCRE2 is not supported. Use standard regex syntax instead.
|
|
6
|
+
`,exitCode:1}};if(f.length===1){let d=ne(f);if(d){if(c+1>=e.length)return{success:!1,error:k("rg",`-${f}`)};let g=j(t,d,e[c+1]);if(g)return{success:!1,error:g};c++,u=!0;continue}}let w=Q[f];if(w){w(t);continue}if(f.startsWith("--"))return{success:!1,error:k("rg",f)};if(f.length===1)return{success:!1,error:k("rg",`-${f}`)}}}else n===null&&t.patterns.length===0&&t.patternFiles.length===0?n=o:s.push(o)}return(r>=0||i>=0)&&(t.afterContext=Math.max(r>=0?r:0,i>=0?i:0)),(l>=0||i>=0)&&(t.beforeContext=Math.max(l>=0?l:0,i>=0?i:0)),n!==null&&t.patterns.push(n),(t.column||t.vimgrep)&&(a=!0),{success:!0,options:t,paths:s,explicitLineNumbers:a}}import{gunzipSync as oe}from"node:zlib";var $=class{patterns=[];basePath;constructor(t="/"){this.basePath=t}parse(t){let n=t.split(`
|
|
7
|
+
`);for(let s of n){let r=s.replace(/\s+$/,"");if(!r||r.startsWith("#"))continue;let l=!1;r.startsWith("!")&&(l=!0,r=r.slice(1));let i=!1;r.endsWith("/")&&(i=!0,r=r.slice(0,-1));let a=!1;r.startsWith("/")?(a=!0,r=r.slice(1)):r.includes("/")&&!r.startsWith("**/")&&(a=!0);let c=this.patternToRegex(r,a);this.patterns.push({pattern:s,regex:c,negated:l,directoryOnly:i,rooted:a})}}patternToRegex(t,n){let s="";n?s="^":s="(?:^|/)";let r=0;for(;r<t.length;){let l=t[r];if(l==="*")t[r+1]==="*"?t[r+2]==="/"?(s+="(?:.*/)?",r+=3):(r+2>=t.length,s+=".*",r+=2):(s+="[^/]*",r++);else if(l==="?")s+="[^/]",r++;else if(l==="["){let i=r+1;for(i<t.length&&t[i]==="!"&&i++,i<t.length&&t[i]==="]"&&i++;i<t.length&&t[i]!=="]";)i++;if(i<t.length){let a=t.slice(r,i+1);a.startsWith("[!")&&(a=`[^${a.slice(2)}`),s+=a,r=i+1}else s+="\\[",r++}else l==="/"?(s+="/",r++):(s+=l.replace(/[.*+?^${}()|[\]\\]/g,"\\$&"),r++)}return s+="(?:/.*)?$",new RegExp(s)}matches(t,n){let s=t.replace(/^\.\//,"");s=s.replace(/^\//,"");let r=!1;for(let l of this.patterns)l.directoryOnly&&!n||l.regex.test(s)&&(r=!l.negated);return r}isWhitelisted(t,n){let s=t.replace(/^\.\//,"");s=s.replace(/^\//,"");for(let r of this.patterns)if(!(r.directoryOnly&&!n)&&r.negated&&r.regex.test(s))return!0;return!1}getBasePath(){return this.basePath}},M=class{parsers=[];fs;skipDotIgnore;skipVcsIgnore;loadedDirs=new Set;constructor(t,n,s=!1,r=!1){this.fs=t,this.skipDotIgnore=s,this.skipVcsIgnore=r}async load(t){let n=[],s=t;for(;;){n.unshift(s);let l=this.fs.resolvePath(s,"..");if(l===s)break;s=l}let r=[];this.skipVcsIgnore||r.push(".gitignore"),this.skipDotIgnore||r.push(".rgignore",".ignore");for(let l of n){this.loadedDirs.add(l);for(let i of r){let a=this.fs.resolvePath(l,i);try{let c=await this.fs.readFile(a),o=new $(l);o.parse(c),this.parsers.push(o)}catch{}}}}async loadForDirectory(t){if(this.loadedDirs.has(t))return;this.loadedDirs.add(t);let n=[];this.skipVcsIgnore||n.push(".gitignore"),this.skipDotIgnore||n.push(".rgignore",".ignore");for(let s of n){let r=this.fs.resolvePath(t,s);try{let l=await this.fs.readFile(r),i=new $(t);i.parse(l),this.parsers.push(i)}catch{}}}addPatternsFromContent(t,n){let s=new $(n);s.parse(t),this.parsers.push(s)}matches(t,n){for(let s of this.parsers){let r=s.getBasePath();if(!t.startsWith(r))continue;let l=t.slice(r.length).replace(/^\//,"");if(s.matches(l,n))return!0}return!1}isWhitelisted(t,n){for(let s of this.parsers){let r=s.getBasePath();if(!t.startsWith(r))continue;let l=t.slice(r.length).replace(/^\//,"");if(s.isWhitelisted(l,n))return!0}return!1}static isCommonIgnored(t){return new Set(["node_modules",".git",".svn",".hg","__pycache__",".pytest_cache",".mypy_cache","venv",".venv",".next",".nuxt",".cargo"]).has(t)}};async function O(e,t,n=!1,s=!1,r=[]){let l=new M(e,t,n,s);await l.load(t);for(let i of r)try{let a=e.resolvePath(t,i),c=await e.readFile(a);l.addPatternsFromContent(c,t)}catch{}return l}function ae(e){return e.length>=2&&e[0]===31&&e[1]===139}function ce(e){let t=!1;for(let n=0;n<e.length;n++){let s=e[n];s==="["&&!t?t=!0:s==="]"&&t&&(t=!1)}return t?`rg: glob '${e}' has an unclosed character class`:null}async function Z(e){let{ctx:t,options:n,paths:s,explicitLineNumbers:r}=e;for(let u of n.globs){let f=u.startsWith("!")?u.slice(1):u,w=ce(f);if(w)return{stdout:"",stderr:`${w}
|
|
8
|
+
`,exitCode:1}}if(n.files){let u=[...n.patterns,...s];return he(t,u,n)}let l=[...n.patterns];for(let u of n.patternFiles)try{let f;if(u==="-")f=t.stdin;else{let d=t.fs.resolvePath(t.cwd,u);f=await t.fs.readFile(d)}let w=f.split(`
|
|
9
|
+
`).filter(d=>d.length>0);l.push(...w)}catch{return{stdout:"",stderr:`rg: ${u}: No such file or directory
|
|
10
|
+
`,exitCode:2}}if(l.length===0)return n.patternFiles.length>0?{stdout:"",stderr:"",exitCode:1}:{stdout:"",stderr:`rg: no pattern given
|
|
11
|
+
`,exitCode:2};let i=s.length===0?["."]:s,a=fe(n,l),c;try{c=ue(l,n,a)}catch{return{stdout:"",stderr:`rg: invalid regex: ${l.join(", ")}
|
|
12
|
+
`,exitCode:2}}let o=null;n.noIgnore||(o=await O(t.fs,t.cwd,n.noIgnoreDot,n.noIgnoreVcs,n.ignoreFiles));let h=new S;for(let u of n.typeClear)h.clearType(u);for(let u of n.typeAdd)h.addType(u);let{files:m,singleExplicitFile:y}=await H(t,i,n,o,h);if(m.length===0)return{stdout:"",stderr:"",exitCode:1};let p=!n.noFilename&&(n.withFilename||!y||m.length>1),b=n.lineNumber;return r||(y&&m.length===1&&(b=!1),n.onlyMatching&&(b=!1)),pe(t,m,c,n,p,b)}function fe(e,t){return e.caseSensitive?!1:e.ignoreCase?!0:e.smartCase?!t.some(n=>/[A-Z]/.test(n)):!1}function ue(e,t,n){let s;return e.length===1?s=e[0]:s=e.map(r=>t.fixedStrings?r.replace(/[.*+?^${}()|[\]\\]/g,"\\$&"):`(?:${r})`).join("|"),R(s,{mode:t.fixedStrings&&e.length===1?"fixed":"perl",ignoreCase:n,wholeWord:t.wordRegexp,lineRegexp:t.lineRegexp,multiline:t.multiline,multilineDotall:t.multilineDotall})}async function H(e,t,n,s,r){let l=[],i=0,a=0;for(let o of t){let h=e.fs.resolvePath(e.cwd,o);try{let m=await e.fs.stat(h);if(m.isFile){if(i++,n.maxFilesize>0&&m.size>n.maxFilesize)continue;Y(o,n,s,h,r)&&l.push(o)}else m.isDirectory&&(a++,await J(e,o,h,0,n,s,r,l))}catch{}}return{files:n.sort==="path"?l.sort():l,singleExplicitFile:i===1&&a===0}}async function J(e,t,n,s,r,l,i,a){if(!(s>=r.maxDepth)){l&&await l.loadForDirectory(n);try{let c=e.fs.readdirWithFileTypes?await e.fs.readdirWithFileTypes(n):(await e.fs.readdir(n)).map(o=>({name:o,isFile:void 0}));for(let o of c){let h=o.name;if(!r.noIgnore&&M.isCommonIgnored(h))continue;let m=h.startsWith("."),y=t==="."?h:t==="./"?`./${h}`:t.endsWith("/")?`${t}${h}`:`${t}/${h}`,p=e.fs.resolvePath(n,h),b,u,f=!1;if(o.isFile!==void 0&&"isDirectory"in o){let g=o;if(f=g.isSymbolicLink===!0,f&&!r.followSymlinks)continue;if(f&&r.followSymlinks)try{let x=await e.fs.stat(p);b=x.isFile,u=x.isDirectory}catch{continue}else b=g.isFile,u=g.isDirectory}else try{let g=e.fs.lstat?await e.fs.lstat(p):await e.fs.stat(p);if(f=g.isSymbolicLink===!0,f&&!r.followSymlinks)continue;let x=f&&r.followSymlinks?await e.fs.stat(p):g;b=x.isFile,u=x.isDirectory}catch{continue}if(!l?.matches(p,u)&&!(m&&!r.hidden&&!l?.isWhitelisted(p,u))){if(u)await J(e,y,p,s+1,r,l,i,a);else if(b){if(r.maxFilesize>0)try{if((await e.fs.stat(p)).size>r.maxFilesize)continue}catch{continue}Y(y,r,l,p,i)&&a.push(y)}}}}catch{}}}function Y(e,t,n,s,r){let l=e.split("/").pop()||e;if(n?.matches(s,!1)||t.types.length>0&&!r.matchesType(l,t.types)||t.typesNot.length>0&&r.matchesType(l,t.typesNot))return!1;if(t.globs.length>0){let i=t.globCaseInsensitive,a=t.globs.filter(o=>!o.startsWith("!")),c=t.globs.filter(o=>o.startsWith("!")).map(o=>o.slice(1));if(a.length>0){let o=!1;for(let h of a)if(v(l,h,i)||v(e,h,i)){o=!0;break}if(!o)return!1}for(let o of c)if(o.startsWith("/")){let h=o.slice(1);if(v(e,h,i))return!1}else if(v(l,o,i)||v(e,o,i))return!1}if(t.iglobs.length>0){let i=t.iglobs.filter(c=>!c.startsWith("!")),a=t.iglobs.filter(c=>c.startsWith("!")).map(c=>c.slice(1));if(i.length>0){let c=!1;for(let o of i)if(v(l,o,!0)||v(e,o,!0)){c=!0;break}if(!c)return!1}for(let c of a)if(c.startsWith("/")){let o=c.slice(1);if(v(e,o,!0))return!1}else if(v(l,c,!0)||v(e,c,!0))return!1}return!0}function v(e,t,n=!1){let s="^";for(let r=0;r<t.length;r++){let l=t[r];if(l==="*")t[r+1]==="*"?(s+=".*",r++):s+="[^/]*";else if(l==="?")s+="[^/]";else if(l==="["){let i=r+1;for(i<t.length&&t[i]==="!"&&i++,i<t.length&&t[i]==="]"&&i++;i<t.length&&t[i]!=="]";)i++;if(i<t.length){let a=t.slice(r,i+1);a.startsWith("[!")&&(a=`[^${a.slice(2)}`),s+=a,r=i}else s+="\\["}else s+=l.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}return s+="$",new RegExp(s,n?"i":"").test(e)}async function he(e,t,n){let s=null;n.noIgnore||(s=await O(e.fs,e.cwd,n.noIgnoreDot,n.noIgnoreVcs,n.ignoreFiles));let r=new S;for(let o of n.typeClear)r.clearType(o);for(let o of n.typeAdd)r.addType(o);let l=t.length===0?["."]:t,{files:i}=await H(e,l,n,s,r);if(i.length===0)return{stdout:"",stderr:"",exitCode:1};if(n.quiet)return{stdout:"",stderr:"",exitCode:0};let a=n.nullSeparator?"\0":`
|
|
13
|
+
`;return{stdout:i.map(o=>o+a).join(""),stderr:"",exitCode:0}}function ge(e,t){if(t.length===0)return!0;for(let n of t)if(v(e,n,!1))return!0;return!1}async function de(e,t,n,s){try{if(s.preprocessor&&e.exec){let i=n.split("/").pop()||n;if(ge(i,s.preprocessorGlobs)){let a=await e.exec(`${s.preprocessor} "${t}"`,{cwd:e.cwd});if(a.exitCode===0&&a.stdout){let c=a.stdout.slice(0,8192);return{content:a.stdout,isBinary:c.includes("\0")}}}}if(s.searchZip&&n.endsWith(".gz")){let i=await e.fs.readFileBuffer(t);if(ae(i))try{let a=oe(i),c=new TextDecoder().decode(a),o=c.slice(0,8192);return{content:c,isBinary:o.includes("\0")}}catch{return null}}let r=await e.fs.readFile(t),l=r.slice(0,8192);return{content:r,isBinary:l.includes("\0")}}catch{return null}}async function pe(e,t,n,s,r,l){let i="",a=!1,c=[],o=0,h=0,m=0,y=50;e:for(let u=0;u<t.length;u+=y){let f=t.slice(u,u+y),w=await Promise.all(f.map(async d=>{let g=e.fs.resolvePath(e.cwd,d),x=await de(e,g,d,s);if(!x)return null;let{content:C,isBinary:T}=x;if(m+=C.length,T&&!s.searchBinary)return null;let W=r&&!s.heading?d:"",I=E(C,n,{invertMatch:s.invertMatch,showLineNumbers:l,countOnly:s.count,countMatches:s.countMatches,filename:W,onlyMatching:s.onlyMatching,beforeContext:s.beforeContext,afterContext:s.afterContext,maxCount:s.maxCount,contextSeparator:s.contextSeparator,showColumn:s.column,vimgrep:s.vimgrep,showByteOffset:s.byteOffset,replace:s.replace!==null?A(s.replace):null,passthru:s.passthru,multiline:s.multiline});return s.json&&I.matched?{file:d,result:I,content:C,isBinary:!1}:{file:d,result:I}}));for(let d of w){if(!d)continue;let{file:g,result:x}=d;if(x.matched){if(a=!0,h++,o+=x.matchCount,s.quiet&&!s.json)break e;if(s.json&&!s.quiet){let C=d.content||"";c.push(JSON.stringify({type:"begin",data:{path:{text:g}}}));let T=C.split(`
|
|
14
|
+
`);n.lastIndex=0;let W=0;for(let I=0;I<T.length;I++){let N=T[I];n.lastIndex=0;let D=[];for(let F=n.exec(N);F!==null;F=n.exec(N)){let P={match:{text:F[0]},start:F.index,end:F.index+F[0].length};s.replace!==null&&(P.replacement={text:s.replace}),D.push(P),F[0].length===0&&n.lastIndex++}if(D.length>0){let F={type:"match",data:{path:{text:g},lines:{text:`${N}
|
|
15
|
+
`},line_number:I+1,absolute_offset:W,submatches:D}};c.push(JSON.stringify(F))}W+=N.length+1}c.push(JSON.stringify({type:"end",data:{path:{text:g},binary_offset:null,stats:{elapsed:{secs:0,nanos:0,human:"0s"},searches:1,searches_with_match:1,bytes_searched:C.length,bytes_printed:0,matched_lines:x.matchCount,matches:x.matchCount}}}))}else if(s.filesWithMatches){let C=s.nullSeparator?"\0":`
|
|
16
|
+
`;i+=`${g}${C}`}else s.filesWithoutMatch||(s.heading&&!s.noFilename&&(i+=`${g}
|
|
17
|
+
`),i+=x.output)}else if(s.filesWithoutMatch){let C=s.nullSeparator?"\0":`
|
|
18
|
+
`;i+=`${g}${C}`}else s.includeZero&&(s.count||s.countMatches)&&(i+=x.output)}}s.json&&(c.push(JSON.stringify({type:"summary",data:{elapsed_total:{secs:0,nanos:0,human:"0s"},stats:{elapsed:{secs:0,nanos:0,human:"0s"},searches:t.length,searches_with_match:h,bytes_searched:m,bytes_printed:0,matched_lines:o,matches:o}}})),i=`${c.join(`
|
|
19
|
+
`)}
|
|
20
|
+
`);let p=s.quiet&&!s.json?"":i;if(s.stats&&!s.json){let u=["",`${o} matches`,`${o} matched lines`,`${h} files contained matches`,`${t.length} files searched`,`${m} bytes searched`].join(`
|
|
21
|
+
`);p+=`${u}
|
|
22
|
+
`}let b;return s.filesWithoutMatch?b=i.length>0?0:1:b=a?0:1,{stdout:p,stderr:"",exitCode:b}}var me={name:"rg",summary:"recursively search for a pattern",usage:"rg [OPTIONS] PATTERN [PATH ...]",description:`rg (ripgrep) recursively searches directories for a regex pattern.
|
|
23
|
+
Unlike grep, rg is recursive by default and respects .gitignore files.
|
|
24
|
+
|
|
25
|
+
EXAMPLES:
|
|
26
|
+
rg foo Search for 'foo' in current directory
|
|
27
|
+
rg foo src/ Search in src/ directory
|
|
28
|
+
rg -i foo Case-insensitive search
|
|
29
|
+
rg -w foo Match whole words only
|
|
30
|
+
rg -t js foo Search only JavaScript files
|
|
31
|
+
rg -g '*.ts' foo Search files matching glob
|
|
32
|
+
rg --hidden foo Include hidden files
|
|
33
|
+
rg -l foo List files with matches only`,options:["-e, --regexp PATTERN search for PATTERN (can be used multiple times)","-f, --file FILE read patterns from FILE, one per line","-i, --ignore-case case-insensitive search","-s, --case-sensitive case-sensitive search (overrides smart-case)","-S, --smart-case smart case (default: case-insensitive unless pattern has uppercase)","-F, --fixed-strings treat pattern as literal string","-w, --word-regexp match whole words only","-x, --line-regexp match whole lines only","-v, --invert-match select non-matching lines","-r, --replace TEXT replace matches with TEXT","-c, --count print count of matching lines per file"," --count-matches print count of individual matches per file","-l, --files-with-matches print only file names with matches"," --files-without-match print file names without matches"," --files list files that would be searched","-o, --only-matching print only matching parts","-m, --max-count NUM stop after NUM matches per file","-q, --quiet suppress output, exit 0 on match"," --stats print search statistics","-n, --line-number print line numbers (default: on)","-N, --no-line-number do not print line numbers","-I, --no-filename suppress the prefixing of file names","-0, --null use NUL as filename separator","-b, --byte-offset show byte offset of each match"," --column show column number of first match"," --vimgrep show results in vimgrep format"," --json show results in JSON Lines format","-A NUM print NUM lines after each match","-B NUM print NUM lines before each match","-C NUM print NUM lines before and after each match"," --context-separator SEP separator for context groups (default: --)","-U, --multiline match patterns across lines","-z, --search-zip search in compressed files (gzip only)","-g, --glob GLOB include files matching GLOB","-t, --type TYPE only search files of TYPE (e.g., js, py, ts)","-T, --type-not TYPE exclude files of TYPE","-L, --follow follow symbolic links","-u, --unrestricted reduce filtering (-u: no ignore, -uu: +hidden, -uuu: +binary)","-a, --text search binary files as text"," --hidden search hidden files and directories"," --no-ignore don't respect .gitignore/.ignore files","-d, --max-depth NUM maximum search depth"," --sort TYPE sort files (path, none)"," --heading show file path above matches"," --passthru print all lines (non-matches use - separator)"," --include-zero include files with 0 matches in count output"," --type-list list all available file types"," --help display this help and exit"]},je={name:"rg",async execute(e,t){if(_(e))return L(me);if(e.includes("--type-list"))return{stdout:B(),stderr:"",exitCode:0};let n=V(e);return n.success?Z({ctx:t,options:n.options,paths:n.paths,explicitLineNumbers:n.explicitLineNumbers}):n.error}};export{je as rgCommand};
|