From 6d411c01fc8a7c6856a0acb6941780f3c283613e Mon Sep 17 00:00:00 2001 From: eight Date: Thu, 9 Nov 2017 13:50:03 +0800 Subject: [PATCH] Fix: use sticky flag to avoid text slicing --- edit/applies-to-line-widget.js | 23 ++++++++++------------- 1 file changed, 10 insertions(+), 13 deletions(-) diff --git a/edit/applies-to-line-widget.js b/edit/applies-to-line-widget.js index 5e170755..99233943 100644 --- a/edit/applies-to-line-widget.js +++ b/edit/applies-to-line-widget.js @@ -374,33 +374,30 @@ function createAppliesToLineWidget(cm) { function *findAppliesTo(posStart, posEnd) { const text = cm.getValue(); const re = /^[\t ]*@-moz-document\s+/mg; - const applyRe = /^(url|url-prefix|domain|regexp)\(((['"])(?:\\\\|\\\n|\\\3|[^\n])*?\3|[^)\n]*)\)[\s,]*/i; - let preIndex = re.lastIndex = posStart; + const applyRe = /(url|url-prefix|domain|regexp)\(((['"])(?:\\\\|\\\n|\\\3|[^\n])*?\3|[^)\n]*)\)[\s,]*/iyg; let match; - let pos = cm.posFromIndex(preIndex); + re.lastIndex = posStart; while ((match = re.exec(text))) { if (match.index >= posEnd) { return; } - pos = cm.findPosH(pos, match.index - preIndex, 'char'); const applies = []; - let t = text.slice(re.lastIndex); let m; - let offset = 0; - while ((m = t.match(applyRe))) { + applyRe.lastIndex = re.lastIndex; + while ((m = applyRe.exec(text))) { const apply = createApply( - re.lastIndex + offset, + m.index, m[1], unquote(m[2]), unquote(m[2]) !== m[2] ); applies.push(apply); - t = t.slice(m[0].length); - offset += m[0].length; + re.lastIndex = applyRe.lastIndex; } - yield {pos, applies}; - preIndex = match.index; - re.lastIndex = text.length - t.length; + yield { + pos: cm.posFromIndex(match.index), + applies + }; } }