@xterm/addon-search 0.16.0-beta.119 → 0.16.0-beta.120

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.
@@ -40,5 +40,5 @@ ${v.join(`
40
40
  `))}},be=class extends Error{constructor(e,t){super(e),this.name="ListenerLeakError",this.stack=t}},ge=class extends Error{constructor(e,t){super(e),this.name="ListenerRefusalError",this.stack=t}},Ye=0,V=class{constructor(e){this.value=e;this.id=Ye++}},Je=2,Xe=(r,e)=>{if(r instanceof V)e(r);else for(let t=0;t<r.length;t++){let n=r[t];n&&e(n)}},ue;if(qe){let r=[];setInterval(()=>{r.length!==0&&(console.warn("[LEAKING LISTENERS] GC'ed these listeners that were NOT yet disposed:"),console.warn(r.join(`
41
41
  `)),r.length=0)},3e3),ue=new FinalizationRegistry(e=>{typeof e=="string"&&r.push(e)})}var A=class{constructor(e){this._size=0;this._options=e,this._leakageMon=Me>0||this._options?.leakWarningThreshold?new ve(e?.onListenerError??ee,this._options?.leakWarningThreshold??Me):void 0,this._perfMon=this._options?._profName?new me(this._options._profName):void 0,this._deliveryQueue=this._options?.deliveryQueue}dispose(){if(!this._disposed){if(this._disposed=!0,this._deliveryQueue?.current===this&&this._deliveryQueue.reset(),this._listeners){if(Ae){let e=this._listeners;queueMicrotask(()=>{Xe(e,t=>t.stack?.print())})}this._listeners=void 0,this._size=0}this._options?.onDidRemoveLastListener?.(),this._leakageMon?.dispose()}}get event(){return this._event??=(e,t,n)=>{if(this._leakageMon&&this._size>this._leakageMon.threshold**2){let a=`[${this._leakageMon.name}] REFUSES to accept new listeners because it exceeded its threshold by far (${this._size} vs ${this._leakageMon.threshold})`;console.warn(a);let f=this._leakageMon.getMostFrequentStack()??["UNKNOWN stack",-1],v=new ge(`${a}. HINT: Stack shows most frequent listener (${f[1]}-times)`,f[0]);return(this._options?.onListenerError||ee)(v),O.None}if(this._disposed)return O.None;t&&(e=e.bind(t));let i=new V(e),s,l;this._leakageMon&&this._size>=Math.ceil(this._leakageMon.threshold*.2)&&(i.stack=B.create(),s=this._leakageMon.check(i.stack,this._size+1)),Ae&&(i.stack=l??B.create()),this._listeners?this._listeners instanceof V?(this._deliveryQueue??=new _e,this._listeners=[this._listeners,i]):this._listeners.push(i):(this._options?.onWillAddFirstListener?.(this),this._listeners=i,this._options?.onDidAddFirstListener?.(this)),this._size++;let u=q(()=>{ue?.unregister(u),s?.(),this._removeListener(i)});if(n instanceof N?n.add(u):Array.isArray(n)&&n.push(u),ue){let a=new Error().stack.split(`
42
42
  `).slice(2,3).join(`
43
- `).trim(),f=/(file:|vscode-file:\/\/vscode-app)?(\/[^:]*:\d+:\d+)/.exec(a);ue.register(u,f?.[2]??a,u)}return u},this._event}_removeListener(e){if(this._options?.onWillRemoveListener?.(this),!this._listeners)return;if(this._size===1){this._listeners=void 0,this._options?.onDidRemoveLastListener?.(this),this._size=0;return}let t=this._listeners,n=t.indexOf(e);if(n===-1)throw console.log("disposed?",this._disposed),console.log("size?",this._size),console.log("arr?",JSON.stringify(this._listeners)),new Error("Attempted to dispose unknown listener");this._size--,t[n]=void 0;let i=this._deliveryQueue.current===this;if(this._size*Je<=t.length){let s=0;for(let l=0;l<t.length;l++)t[l]?t[s++]=t[l]:i&&(this._deliveryQueue.end--,s<this._deliveryQueue.i&&this._deliveryQueue.i--);t.length=s}}_deliver(e,t){if(!e)return;let n=this._options?.onListenerError||ee;if(!n){e.value(t);return}try{e.value(t)}catch(i){n(i)}}_deliverQueue(e){let t=e.current._listeners;for(;e.i<e.end;)this._deliver(t[e.i++],e.value);e.reset()}fire(e){if(this._deliveryQueue?.current&&(this._deliverQueue(this._deliveryQueue),this._perfMon?.stop()),this._perfMon?.start(this._size),this._listeners)if(this._listeners instanceof V)this._deliver(this._listeners,e);else{let t=this._deliveryQueue;t.enqueue(this,e,this._listeners.length),this._deliverQueue(t)}this._perfMon?.stop()}hasListeners(){return this._size>0}};var _e=class{constructor(){this.i=-1;this.end=0}enqueue(e,t,n){this.i=0,this.end=n,this.current=e,this.value=t}reset(){this.i=this.end,this.current=void 0,this.value=void 0}};var Fe=" ~!@#$%^&*()+`-=[]{}|\\;:\"',./<>?",Ze=15*1e3,et=1e3,Pe=class extends O{constructor(t){super();this._highlightedLines=new Set;this._highlightDecorations=[];this._searchResultsWithHighlight=[];this._selectedDecoration=this._register(new $);this._linesCacheTimeoutId=0;this._linesCacheDisposables=new $;this._onDidChangeResults=this._register(new A);this.onDidChangeResults=this._onDidChangeResults.event;this._highlightLimit=t?.highlightLimit??et}activate(t){this._terminal=t,this._register(this._terminal.onWriteParsed(()=>this._updateMatches())),this._register(this._terminal.onResize(()=>this._updateMatches())),this._register(q(()=>this.clearDecorations()))}_updateMatches(){this._highlightTimeout&&window.clearTimeout(this._highlightTimeout),this._cachedSearchTerm&&this._lastSearchOptions?.decorations&&(this._highlightTimeout=setTimeout(()=>{let t=this._cachedSearchTerm;this._cachedSearchTerm=void 0,this.findPrevious(t,{...this._lastSearchOptions,incremental:!0,noScroll:!0})},200))}clearDecorations(t){this._selectedDecoration.clear(),W(this._highlightDecorations),this._highlightDecorations=[],this._searchResultsWithHighlight=[],this._highlightedLines.clear(),t||(this._cachedSearchTerm=void 0)}clearActiveDecoration(){this._selectedDecoration.clear()}findNext(t,n){if(!this._terminal)throw new Error("Cannot use addon until it has been loaded");let i=this._lastSearchOptions?this._didOptionsChange(this._lastSearchOptions,n):!0;this._lastSearchOptions=n,n?.decorations&&(this._cachedSearchTerm===void 0||t!==this._cachedSearchTerm||i)&&this._highlightAllMatches(t,n);let s=this._findNextAndSelect(t,n);return this._fireResults(n),this._cachedSearchTerm=t,s}_highlightAllMatches(t,n){if(!this._terminal)throw new Error("Cannot use addon until it has been loaded");if(!t||t.length===0){this.clearDecorations();return}n=n||{},this.clearDecorations(!0);let i,s=this._find(t,0,0,n);for(;s&&(i?.row!==s.row||i?.col!==s.col)&&!(this._searchResultsWithHighlight.length>=this._highlightLimit);)i=s,this._searchResultsWithHighlight.push(i),s=this._find(t,i.col+i.term.length>=this._terminal.cols?i.row+1:i.row,i.col+i.term.length>=this._terminal.cols?0:i.col+1,n);for(let l of this._searchResultsWithHighlight){let u=this._createResultDecorations(l,n.decorations,!1);if(u)for(let a of u)this._storeDecoration(a,l)}}_storeDecoration(t,n){this._highlightedLines.add(t.marker.line),this._highlightDecorations.push({decoration:t,match:n,dispose(){t.dispose()}})}_find(t,n,i,s){if(!this._terminal||!t||t.length===0){this._terminal?.clearSelection(),this.clearDecorations();return}if(i>this._terminal.cols)throw new Error(`Invalid col: ${i} to search in terminal of ${this._terminal.cols} cols`);let l;this._initLinesCache();let u={startRow:n,startCol:i};if(l=this._findInLine(t,u,s),!l)for(let a=n+1;a<this._terminal.buffer.active.baseY+this._terminal.rows&&(u.startRow=a,u.startCol=0,l=this._findInLine(t,u,s),!l);a++);return l}_findNextAndSelect(t,n){if(!this._terminal||!t||t.length===0)return this._terminal?.clearSelection(),this.clearDecorations(),!1;let i=this._terminal.getSelectionPosition();this._terminal.clearSelection();let s=0,l=0;i&&(this._cachedSearchTerm===t?(s=i.end.x,l=i.end.y):(s=i.start.x,l=i.start.y)),this._initLinesCache();let u={startRow:l,startCol:s},a=this._findInLine(t,u,n);if(!a)for(let f=l+1;f<this._terminal.buffer.active.baseY+this._terminal.rows&&(u.startRow=f,u.startCol=0,a=this._findInLine(t,u,n),!a);f++);if(!a&&l!==0)for(let f=0;f<l&&(u.startRow=f,u.startCol=0,a=this._findInLine(t,u,n),!a);f++);return!a&&i&&(u.startRow=i.start.y,u.startCol=0,a=this._findInLine(t,u,n)),this._selectResult(a,n?.decorations,n?.noScroll)}findPrevious(t,n){if(!this._terminal)throw new Error("Cannot use addon until it has been loaded");let i=this._lastSearchOptions?this._didOptionsChange(this._lastSearchOptions,n):!0;this._lastSearchOptions=n,n?.decorations&&(this._cachedSearchTerm===void 0||t!==this._cachedSearchTerm||i)&&this._highlightAllMatches(t,n);let s=this._findPreviousAndSelect(t,n);return this._fireResults(n),this._cachedSearchTerm=t,s}_didOptionsChange(t,n){return n?t.caseSensitive!==n.caseSensitive||t.regex!==n.regex||t.wholeWord!==n.wholeWord:!1}_fireResults(t){if(t?.decorations){let n=-1;if(this._selectedDecoration.value){let i=this._selectedDecoration.value.match;for(let s=0;s<this._searchResultsWithHighlight.length;s++){let l=this._searchResultsWithHighlight[s];if(l.row===i.row&&l.col===i.col&&l.size===i.size){n=s;break}}}this._onDidChangeResults.fire({resultIndex:n,resultCount:this._searchResultsWithHighlight.length})}}_findPreviousAndSelect(t,n){if(!this._terminal)throw new Error("Cannot use addon until it has been loaded");if(!this._terminal||!t||t.length===0)return this._terminal?.clearSelection(),this.clearDecorations(),!1;let i=this._terminal.getSelectionPosition();this._terminal.clearSelection();let s=this._terminal.buffer.active.baseY+this._terminal.rows-1,l=this._terminal.cols,u=!0;this._initLinesCache();let a={startRow:s,startCol:l},f;if(i&&(a.startRow=s=i.start.y,a.startCol=l=i.start.x,this._cachedSearchTerm!==t&&(f=this._findInLine(t,a,n,!1),f||(a.startRow=s=i.end.y,a.startCol=l=i.end.x))),f||(f=this._findInLine(t,a,n,u)),!f){a.startCol=Math.max(a.startCol,this._terminal.cols);for(let v=s-1;v>=0&&(a.startRow=v,f=this._findInLine(t,a,n,u),!f);v--);}if(!f&&s!==this._terminal.buffer.active.baseY+this._terminal.rows-1)for(let v=this._terminal.buffer.active.baseY+this._terminal.rows-1;v>=s&&(a.startRow=v,f=this._findInLine(t,a,n,u),!f);v--);return this._selectResult(f,n?.decorations,n?.noScroll)}_initLinesCache(){let t=this._terminal;this._linesCache||(this._linesCache=new Array(t.buffer.active.length),this._linesCacheDisposables.value=ae(t.onLineFeed(()=>this._destroyLinesCache()),t.onCursorMove(()=>this._destroyLinesCache()),t.onResize(()=>this._destroyLinesCache()))),window.clearTimeout(this._linesCacheTimeoutId),this._linesCacheTimeoutId=window.setTimeout(()=>this._destroyLinesCache(),Ze)}_destroyLinesCache(){this._linesCache=void 0,this._linesCacheDisposables.clear(),this._linesCacheTimeoutId&&(window.clearTimeout(this._linesCacheTimeoutId),this._linesCacheTimeoutId=0)}_isWholeWord(t,n,i){return(t===0||Fe.includes(n[t-1]))&&(t+i.length===n.length||Fe.includes(n[t+i.length]))}_findInLine(t,n,i={},s=!1){let l=this._terminal,u=n.startRow,a=n.startCol;if(l.buffer.active.getLine(u)?.isWrapped){if(s){n.startCol+=l.cols;return}return n.startRow--,n.startCol+=l.cols,this._findInLine(t,n,i)}let v=this._linesCache?.[u];v||(v=this._translateBufferLineToStringWithWrap(u,!0),this._linesCache&&(this._linesCache[u]=v));let[m,I]=v,E=this._bufferColsToStringOffset(u,a),k=t,R=m;i.regex||(k=i.caseSensitive?t:t.toLowerCase(),R=i.caseSensitive?m:m.toLowerCase());let D=-1;if(i.regex){let w=RegExp(k,i.caseSensitive?"g":"gi"),y;if(s)for(;y=w.exec(R.slice(0,E));)D=w.lastIndex-y[0].length,t=y[0],w.lastIndex-=t.length-1;else y=w.exec(R.slice(E)),y&&y[0].length>0&&(D=E+(w.lastIndex-y[0].length),t=y[0])}else s?E-k.length>=0&&(D=R.lastIndexOf(k,E-k.length)):D=R.indexOf(k,E);if(D>=0){if(i.wholeWord&&!this._isWholeWord(D,R,t))return;let w=0;for(;w<I.length-1&&D>=I[w+1];)w++;let y=w;for(;y<I.length-1&&D+t.length>=I[y+1];)y++;let j=D-I[w],T=D+t.length-I[y],g=this._stringLengthToBufferSize(u+w,j),C=this._stringLengthToBufferSize(u+y,T)-g+l.cols*(y-w);return{term:t,col:g,row:u+w,size:C}}}_stringLengthToBufferSize(t,n){let i=this._terminal.buffer.active.getLine(t);if(!i)return 0;for(let s=0;s<n;s++){let l=i.getCell(s);if(!l)break;let u=l.getChars();u.length>1&&(n-=u.length-1);let a=i.getCell(s+1);a&&a.getWidth()===0&&n++}return n}_bufferColsToStringOffset(t,n){let i=this._terminal,s=t,l=0,u=i.buffer.active.getLine(s);for(;n>0&&u;){for(let a=0;a<n&&a<i.cols;a++){let f=u.getCell(a);if(!f)break;f.getWidth()&&(l+=f.getCode()===0?1:f.getChars().length)}if(s++,u=i.buffer.active.getLine(s),u&&!u.isWrapped)break;n-=i.cols}return l}_translateBufferLineToStringWithWrap(t,n){let i=this._terminal,s=[],l=[0],u=i.buffer.active.getLine(t);for(;u;){let a=i.buffer.active.getLine(t+1),f=a?a.isWrapped:!1,v=u.translateToString(!f&&n);if(f&&a){let m=u.getCell(u.length-1);m&&m.getCode()===0&&m.getWidth()===1&&a.getCell(0)?.getWidth()===2&&(v=v.slice(0,-1))}if(s.push(v),f)l.push(l[l.length-1]+v.length);else break;t++,u=a}return[s.join(""),l]}_selectResult(t,n,i){let s=this._terminal;if(this._selectedDecoration.clear(),!t)return s.clearSelection(),!1;if(s.select(t.col,t.row,t.size),n){let l=this._createResultDecorations(t,n,!0);l&&(this._selectedDecoration.value={decorations:l,match:t,dispose(){W(l)}})}if(!i&&(t.row>=s.buffer.active.viewportY+s.rows||t.row<s.buffer.active.viewportY)){let l=t.row-s.buffer.active.viewportY;l-=Math.floor(s.rows/2),s.scrollLines(l)}return!0}_applyStyles(t,n,i){t.classList.contains("xterm-find-result-decoration")||(t.classList.add("xterm-find-result-decoration"),n&&(t.style.outline=`1px solid ${n}`)),i&&t.classList.add("xterm-find-active-result-decoration")}_createResultDecorations(t,n,i){let s=this._terminal,l=[],u=t.col,a=t.size,f=-s.buffer.active.baseY-s.buffer.active.cursorY+t.row;for(;a>0;){let m=Math.min(s.cols-u,a);l.push([f,u,m]),u=0,a-=m,f++}let v=[];for(let m of l){let I=s.registerMarker(m[0]),E=s.registerDecoration({marker:I,x:m[1],width:m[2],backgroundColor:i?n.activeMatchBackground:n.matchBackground,overviewRulerOptions:this._highlightedLines.has(I.line)?void 0:{color:i?n.activeMatchColorOverviewRuler:n.matchOverviewRuler,position:"center"}});if(E){let k=[];k.push(I),k.push(E.onRender(R=>this._applyStyles(R,i?n.activeMatchBorder:n.matchBorder,!1))),k.push(E.onDispose(()=>W(k))),v.push(E)}}return v.length===0?void 0:v}};export{Pe as SearchAddon};
43
+ `).trim(),f=/(file:|vscode-file:\/\/vscode-app)?(\/[^:]*:\d+:\d+)/.exec(a);ue.register(u,f?.[2]??a,u)}return u},this._event}_removeListener(e){if(this._options?.onWillRemoveListener?.(this),!this._listeners)return;if(this._size===1){this._listeners=void 0,this._options?.onDidRemoveLastListener?.(this),this._size=0;return}let t=this._listeners,n=t.indexOf(e);if(n===-1)throw console.log("disposed?",this._disposed),console.log("size?",this._size),console.log("arr?",JSON.stringify(this._listeners)),new Error("Attempted to dispose unknown listener");this._size--,t[n]=void 0;let i=this._deliveryQueue.current===this;if(this._size*Je<=t.length){let s=0;for(let l=0;l<t.length;l++)t[l]?t[s++]=t[l]:i&&(this._deliveryQueue.end--,s<this._deliveryQueue.i&&this._deliveryQueue.i--);t.length=s}}_deliver(e,t){if(!e)return;let n=this._options?.onListenerError||ee;if(!n){e.value(t);return}try{e.value(t)}catch(i){n(i)}}_deliverQueue(e){let t=e.current._listeners;for(;e.i<e.end;)this._deliver(t[e.i++],e.value);e.reset()}fire(e){if(this._deliveryQueue?.current&&(this._deliverQueue(this._deliveryQueue),this._perfMon?.stop()),this._perfMon?.start(this._size),this._listeners)if(this._listeners instanceof V)this._deliver(this._listeners,e);else{let t=this._deliveryQueue;t.enqueue(this,e,this._listeners.length),this._deliverQueue(t)}this._perfMon?.stop()}hasListeners(){return this._size>0}};var _e=class{constructor(){this.i=-1;this.end=0}enqueue(e,t,n){this.i=0,this.end=n,this.current=e,this.value=t}reset(){this.i=this.end,this.current=void 0,this.value=void 0}};var Fe=" ~!@#$%^&*()+`-=[]{}|\\;:\"',./<>?",Ze=15*1e3,et=1e3,Pe=class extends O{constructor(t){super();this._highlightedLines=new Set;this._highlightDecorations=[];this._searchResultsWithHighlight=[];this._selectedDecoration=this._register(new $);this._linesCacheTimeoutId=0;this._linesCacheDisposables=new $;this._onDidChangeResults=this._register(new A);this._highlightLimit=t?.highlightLimit??et}get onDidChangeResults(){return this._onDidChangeResults.event}activate(t){this._terminal=t,this._register(this._terminal.onWriteParsed(()=>this._updateMatches())),this._register(this._terminal.onResize(()=>this._updateMatches())),this._register(q(()=>this.clearDecorations()))}_updateMatches(){this._highlightTimeout&&window.clearTimeout(this._highlightTimeout),this._cachedSearchTerm&&this._lastSearchOptions?.decorations&&(this._highlightTimeout=setTimeout(()=>{let t=this._cachedSearchTerm;this._cachedSearchTerm=void 0,this.findPrevious(t,{...this._lastSearchOptions,incremental:!0,noScroll:!0})},200))}clearDecorations(t){this._selectedDecoration.clear(),W(this._highlightDecorations),this._highlightDecorations=[],this._searchResultsWithHighlight=[],this._highlightedLines.clear(),t||(this._cachedSearchTerm=void 0)}clearActiveDecoration(){this._selectedDecoration.clear()}findNext(t,n){if(!this._terminal)throw new Error("Cannot use addon until it has been loaded");let i=this._lastSearchOptions?this._didOptionsChange(this._lastSearchOptions,n):!0;this._lastSearchOptions=n,n?.decorations&&(this._cachedSearchTerm===void 0||t!==this._cachedSearchTerm||i)&&this._highlightAllMatches(t,n);let s=this._findNextAndSelect(t,n);return this._fireResults(n),this._cachedSearchTerm=t,s}_highlightAllMatches(t,n){if(!this._terminal)throw new Error("Cannot use addon until it has been loaded");if(!t||t.length===0){this.clearDecorations();return}n=n||{},this.clearDecorations(!0);let i,s=this._find(t,0,0,n);for(;s&&(i?.row!==s.row||i?.col!==s.col)&&!(this._searchResultsWithHighlight.length>=this._highlightLimit);)i=s,this._searchResultsWithHighlight.push(i),s=this._find(t,i.col+i.term.length>=this._terminal.cols?i.row+1:i.row,i.col+i.term.length>=this._terminal.cols?0:i.col+1,n);for(let l of this._searchResultsWithHighlight){let u=this._createResultDecorations(l,n.decorations,!1);if(u)for(let a of u)this._storeDecoration(a,l)}}_storeDecoration(t,n){this._highlightedLines.add(t.marker.line),this._highlightDecorations.push({decoration:t,match:n,dispose(){t.dispose()}})}_find(t,n,i,s){if(!this._terminal||!t||t.length===0){this._terminal?.clearSelection(),this.clearDecorations();return}if(i>this._terminal.cols)throw new Error(`Invalid col: ${i} to search in terminal of ${this._terminal.cols} cols`);let l;this._initLinesCache();let u={startRow:n,startCol:i};if(l=this._findInLine(t,u,s),!l)for(let a=n+1;a<this._terminal.buffer.active.baseY+this._terminal.rows&&(u.startRow=a,u.startCol=0,l=this._findInLine(t,u,s),!l);a++);return l}_findNextAndSelect(t,n){if(!this._terminal||!t||t.length===0)return this._terminal?.clearSelection(),this.clearDecorations(),!1;let i=this._terminal.getSelectionPosition();this._terminal.clearSelection();let s=0,l=0;i&&(this._cachedSearchTerm===t?(s=i.end.x,l=i.end.y):(s=i.start.x,l=i.start.y)),this._initLinesCache();let u={startRow:l,startCol:s},a=this._findInLine(t,u,n);if(!a)for(let f=l+1;f<this._terminal.buffer.active.baseY+this._terminal.rows&&(u.startRow=f,u.startCol=0,a=this._findInLine(t,u,n),!a);f++);if(!a&&l!==0)for(let f=0;f<l&&(u.startRow=f,u.startCol=0,a=this._findInLine(t,u,n),!a);f++);return!a&&i&&(u.startRow=i.start.y,u.startCol=0,a=this._findInLine(t,u,n)),this._selectResult(a,n?.decorations,n?.noScroll)}findPrevious(t,n){if(!this._terminal)throw new Error("Cannot use addon until it has been loaded");let i=this._lastSearchOptions?this._didOptionsChange(this._lastSearchOptions,n):!0;this._lastSearchOptions=n,n?.decorations&&(this._cachedSearchTerm===void 0||t!==this._cachedSearchTerm||i)&&this._highlightAllMatches(t,n);let s=this._findPreviousAndSelect(t,n);return this._fireResults(n),this._cachedSearchTerm=t,s}_didOptionsChange(t,n){return n?t.caseSensitive!==n.caseSensitive||t.regex!==n.regex||t.wholeWord!==n.wholeWord:!1}_fireResults(t){if(t?.decorations){let n=-1;if(this._selectedDecoration.value){let i=this._selectedDecoration.value.match;for(let s=0;s<this._searchResultsWithHighlight.length;s++){let l=this._searchResultsWithHighlight[s];if(l.row===i.row&&l.col===i.col&&l.size===i.size){n=s;break}}}this._onDidChangeResults.fire({resultIndex:n,resultCount:this._searchResultsWithHighlight.length})}}_findPreviousAndSelect(t,n){if(!this._terminal)throw new Error("Cannot use addon until it has been loaded");if(!this._terminal||!t||t.length===0)return this._terminal?.clearSelection(),this.clearDecorations(),!1;let i=this._terminal.getSelectionPosition();this._terminal.clearSelection();let s=this._terminal.buffer.active.baseY+this._terminal.rows-1,l=this._terminal.cols,u=!0;this._initLinesCache();let a={startRow:s,startCol:l},f;if(i&&(a.startRow=s=i.start.y,a.startCol=l=i.start.x,this._cachedSearchTerm!==t&&(f=this._findInLine(t,a,n,!1),f||(a.startRow=s=i.end.y,a.startCol=l=i.end.x))),f||(f=this._findInLine(t,a,n,u)),!f){a.startCol=Math.max(a.startCol,this._terminal.cols);for(let v=s-1;v>=0&&(a.startRow=v,f=this._findInLine(t,a,n,u),!f);v--);}if(!f&&s!==this._terminal.buffer.active.baseY+this._terminal.rows-1)for(let v=this._terminal.buffer.active.baseY+this._terminal.rows-1;v>=s&&(a.startRow=v,f=this._findInLine(t,a,n,u),!f);v--);return this._selectResult(f,n?.decorations,n?.noScroll)}_initLinesCache(){let t=this._terminal;this._linesCache||(this._linesCache=new Array(t.buffer.active.length),this._linesCacheDisposables.value=ae(t.onLineFeed(()=>this._destroyLinesCache()),t.onCursorMove(()=>this._destroyLinesCache()),t.onResize(()=>this._destroyLinesCache()))),window.clearTimeout(this._linesCacheTimeoutId),this._linesCacheTimeoutId=window.setTimeout(()=>this._destroyLinesCache(),Ze)}_destroyLinesCache(){this._linesCache=void 0,this._linesCacheDisposables.clear(),this._linesCacheTimeoutId&&(window.clearTimeout(this._linesCacheTimeoutId),this._linesCacheTimeoutId=0)}_isWholeWord(t,n,i){return(t===0||Fe.includes(n[t-1]))&&(t+i.length===n.length||Fe.includes(n[t+i.length]))}_findInLine(t,n,i={},s=!1){let l=this._terminal,u=n.startRow,a=n.startCol;if(l.buffer.active.getLine(u)?.isWrapped){if(s){n.startCol+=l.cols;return}return n.startRow--,n.startCol+=l.cols,this._findInLine(t,n,i)}let v=this._linesCache?.[u];v||(v=this._translateBufferLineToStringWithWrap(u,!0),this._linesCache&&(this._linesCache[u]=v));let[m,I]=v,E=this._bufferColsToStringOffset(u,a),k=t,R=m;i.regex||(k=i.caseSensitive?t:t.toLowerCase(),R=i.caseSensitive?m:m.toLowerCase());let D=-1;if(i.regex){let w=RegExp(k,i.caseSensitive?"g":"gi"),y;if(s)for(;y=w.exec(R.slice(0,E));)D=w.lastIndex-y[0].length,t=y[0],w.lastIndex-=t.length-1;else y=w.exec(R.slice(E)),y&&y[0].length>0&&(D=E+(w.lastIndex-y[0].length),t=y[0])}else s?E-k.length>=0&&(D=R.lastIndexOf(k,E-k.length)):D=R.indexOf(k,E);if(D>=0){if(i.wholeWord&&!this._isWholeWord(D,R,t))return;let w=0;for(;w<I.length-1&&D>=I[w+1];)w++;let y=w;for(;y<I.length-1&&D+t.length>=I[y+1];)y++;let j=D-I[w],T=D+t.length-I[y],g=this._stringLengthToBufferSize(u+w,j),C=this._stringLengthToBufferSize(u+y,T)-g+l.cols*(y-w);return{term:t,col:g,row:u+w,size:C}}}_stringLengthToBufferSize(t,n){let i=this._terminal.buffer.active.getLine(t);if(!i)return 0;for(let s=0;s<n;s++){let l=i.getCell(s);if(!l)break;let u=l.getChars();u.length>1&&(n-=u.length-1);let a=i.getCell(s+1);a&&a.getWidth()===0&&n++}return n}_bufferColsToStringOffset(t,n){let i=this._terminal,s=t,l=0,u=i.buffer.active.getLine(s);for(;n>0&&u;){for(let a=0;a<n&&a<i.cols;a++){let f=u.getCell(a);if(!f)break;f.getWidth()&&(l+=f.getCode()===0?1:f.getChars().length)}if(s++,u=i.buffer.active.getLine(s),u&&!u.isWrapped)break;n-=i.cols}return l}_translateBufferLineToStringWithWrap(t,n){let i=this._terminal,s=[],l=[0],u=i.buffer.active.getLine(t);for(;u;){let a=i.buffer.active.getLine(t+1),f=a?a.isWrapped:!1,v=u.translateToString(!f&&n);if(f&&a){let m=u.getCell(u.length-1);m&&m.getCode()===0&&m.getWidth()===1&&a.getCell(0)?.getWidth()===2&&(v=v.slice(0,-1))}if(s.push(v),f)l.push(l[l.length-1]+v.length);else break;t++,u=a}return[s.join(""),l]}_selectResult(t,n,i){let s=this._terminal;if(this._selectedDecoration.clear(),!t)return s.clearSelection(),!1;if(s.select(t.col,t.row,t.size),n){let l=this._createResultDecorations(t,n,!0);l&&(this._selectedDecoration.value={decorations:l,match:t,dispose(){W(l)}})}if(!i&&(t.row>=s.buffer.active.viewportY+s.rows||t.row<s.buffer.active.viewportY)){let l=t.row-s.buffer.active.viewportY;l-=Math.floor(s.rows/2),s.scrollLines(l)}return!0}_applyStyles(t,n,i){t.classList.contains("xterm-find-result-decoration")||(t.classList.add("xterm-find-result-decoration"),n&&(t.style.outline=`1px solid ${n}`)),i&&t.classList.add("xterm-find-active-result-decoration")}_createResultDecorations(t,n,i){let s=this._terminal,l=[],u=t.col,a=t.size,f=-s.buffer.active.baseY-s.buffer.active.cursorY+t.row;for(;a>0;){let m=Math.min(s.cols-u,a);l.push([f,u,m]),u=0,a-=m,f++}let v=[];for(let m of l){let I=s.registerMarker(m[0]),E=s.registerDecoration({marker:I,x:m[1],width:m[2],backgroundColor:i?n.activeMatchBackground:n.matchBackground,overviewRulerOptions:this._highlightedLines.has(I.line)?void 0:{color:i?n.activeMatchColorOverviewRuler:n.matchOverviewRuler,position:"center"}});if(E){let k=[];k.push(I),k.push(E.onRender(R=>this._applyStyles(R,i?n.activeMatchBorder:n.matchBorder,!1))),k.push(E.onDispose(()=>W(k))),v.push(E)}}return v.length===0?void 0:v}};export{Pe as SearchAddon};
44
44
  //# sourceMappingURL=addon-search.mjs.map