Skip to content

Commit

Permalink
Performance - Drastically improve worst case regex performance
Browse files Browse the repository at this point in the history
Converting from array to string repeatedly in a loop leads to
very poor performance in some contexts.
  • Loading branch information
adam-arthur committed Jan 16, 2023
1 parent 99ada39 commit fb7027c
Showing 1 changed file with 4 additions and 3 deletions.
7 changes: 4 additions & 3 deletions index.js
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,7 @@ const wrapWord = (rows, word, columns) => {

if (ESCAPES.has(character)) {
isInsideEscape = true;
isInsideLinkEscape = characters.slice(index + 1).join('').startsWith(ANSI_ESCAPE_LINK);
isInsideLinkEscape = word.slice(index + 1).startsWith(ANSI_ESCAPE_LINK);
}

if (isInsideEscape) {
Expand Down Expand Up @@ -164,13 +164,14 @@ const exec = (string, columns, options = {}) => {
rows = rows.map(row => stringVisibleTrimSpacesRight(row));
}

const pre = [...rows.join('\n')];
const preString = rows.join('\n');
const pre = [...preString];

for (const [index, character] of pre.entries()) {
returnValue += character;

if (ESCAPES.has(character)) {
const {groups} = new RegExp(`(?:\\${ANSI_CSI}(?<code>\\d+)m|\\${ANSI_ESCAPE_LINK}(?<uri>.*)${ANSI_ESCAPE_BELL})`).exec(pre.slice(index).join('')) || {groups: {}};
const {groups} = new RegExp(`(?:\\${ANSI_CSI}(?<code>\\d+)m|\\${ANSI_ESCAPE_LINK}(?<uri>.*)${ANSI_ESCAPE_BELL})`).exec(preString.slice(index)) || {groups: {}};
if (groups.code !== undefined) {
const code = Number.parseFloat(groups.code);
escapeCode = code === END_CODE ? undefined : code;
Expand Down

0 comments on commit fb7027c

Please sign in to comment.