From d6530b9421d520ac8aa75b3418104c997e91228a Mon Sep 17 00:00:00 2001 From: btea <2356281422@qq.com> Date: Tue, 15 Oct 2024 22:34:51 +0800 Subject: [PATCH 1/4] refactor: replace `test` with `includes` --- packages/node-resolve/src/index.js | 4 ++-- packages/pluginutils/src/attachScopes.ts | 4 ++-- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/packages/node-resolve/src/index.js b/packages/node-resolve/src/index.js index a675247aa..52b454fd8 100644 --- a/packages/node-resolve/src/index.js +++ b/packages/node-resolve/src/index.js @@ -292,7 +292,7 @@ export function nodeResolve(opts = {}) { return importee; } // ignore IDs with null character, these belong to other plugins - if (/\0/.test(importee)) return null; + if (importee.includes('\0')) return null; const { custom = {} } = resolveOptions; const { 'node-resolve': { resolved: alreadyResolved } = {} } = custom; @@ -300,7 +300,7 @@ export function nodeResolve(opts = {}) { return alreadyResolved; } - if (/\0/.test(importer)) { + if (importer.includes('\0')) { importer = undefined; } diff --git a/packages/pluginutils/src/attachScopes.ts b/packages/pluginutils/src/attachScopes.ts index fc6392ddb..b8a33a8ea 100755 --- a/packages/pluginutils/src/attachScopes.ts +++ b/packages/pluginutils/src/attachScopes.ts @@ -82,7 +82,7 @@ const attachScopes: AttachScopes = function attachScopes(ast, propertyName = 'sc let newScope: AttachedScope | undefined; // create new function scope - if (/Function/.test(node.type)) { + if (node.type.includes('Function')) { const func = node as estree.Function; newScope = new Scope({ parent: scope, @@ -106,7 +106,7 @@ const attachScopes: AttachScopes = function attachScopes(ast, propertyName = 'sc } // create new block scope - if (node.type === 'BlockStatement' && !/Function/.test(parent.type)) { + if (node.type === 'BlockStatement' && !parent.type.includes('Function')) { newScope = new Scope({ parent: scope, block: true From 100af13deaba8d0647c1bd064059a858c0087e29 Mon Sep 17 00:00:00 2001 From: btea <2356281422@qq.com> Date: Wed, 16 Oct 2024 12:35:19 +0800 Subject: [PATCH 2/4] fix: update --- packages/node-resolve/src/index.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/packages/node-resolve/src/index.js b/packages/node-resolve/src/index.js index 52b454fd8..7e0614f58 100644 --- a/packages/node-resolve/src/index.js +++ b/packages/node-resolve/src/index.js @@ -292,7 +292,7 @@ export function nodeResolve(opts = {}) { return importee; } // ignore IDs with null character, these belong to other plugins - if (importee.includes('\0')) return null; + if (importee && importee.includes('\0')) return null; const { custom = {} } = resolveOptions; const { 'node-resolve': { resolved: alreadyResolved } = {} } = custom; @@ -300,7 +300,7 @@ export function nodeResolve(opts = {}) { return alreadyResolved; } - if (importer.includes('\0')) { + if (importer && importer.includes('\0')) { importer = undefined; } From feca9eabbb2986f638e25ef45a2c725ebd1e99d1 Mon Sep 17 00:00:00 2001 From: btea <2356281422@qq.com> Date: Wed, 16 Oct 2024 13:11:29 +0800 Subject: [PATCH 3/4] fix(pluginutils): optimize `createFilter` the matching rules when regexp carry flags --- packages/pluginutils/src/createFilter.ts | 6 ++++++ packages/pluginutils/test/createFilter.ts | 24 +++++++++++++++++++++++ 2 files changed, 30 insertions(+) diff --git a/packages/pluginutils/src/createFilter.ts b/packages/pluginutils/src/createFilter.ts index 9f2f093f6..86f9d3be5 100755 --- a/packages/pluginutils/src/createFilter.ts +++ b/packages/pluginutils/src/createFilter.ts @@ -54,11 +54,17 @@ const createFilter: CreateFilter = function createFilter(include?, exclude?, opt for (let i = 0; i < excludeMatchers.length; ++i) { const matcher = excludeMatchers[i]; + if (matcher instanceof RegExp) { + matcher.lastIndex = 0; + } if (matcher.test(pathId)) return false; } for (let i = 0; i < includeMatchers.length; ++i) { const matcher = includeMatchers[i]; + if (matcher instanceof RegExp) { + matcher.lastIndex = 0; + } if (matcher.test(pathId)) return true; } diff --git a/packages/pluginutils/test/createFilter.ts b/packages/pluginutils/test/createFilter.ts index 234bbc205..66116b5a4 100755 --- a/packages/pluginutils/test/createFilter.ts +++ b/packages/pluginutils/test/createFilter.ts @@ -175,3 +175,27 @@ test('normalizes path when pattern has resolution base', (t) => { t.truthy(filterPosix(resolve('test/a'))); t.truthy(filterWin(resolve('test/a'))); }); + +test('pass a regular expression to the include parameter', (t) => { + const filter = createFilter([/zxcvbnmasdfg/]); + t.truthy(filter(resolve('zxcvbnmasdfg'))); + t.falsy(filter(resolve('zxcvbnmasdfe'))); +}); + +test('pass a regular expression to the include parameter with g flag', (t) => { + const filter = createFilter([/zxcvbnmasdfg/g]); + t.truthy(filter(resolve('zxcvbnmasdfg'))); + t.truthy(filter(resolve('zxcvbnmasdfg'))); +}); + +test('pass a regular expression to the exclude parameter', (t) => { + const filter = createFilter(null, [/zxcvbnmasdfg/]); + t.falsy(filter(resolve('zxcvbnmasdfg'))); + t.truthy(filter(resolve('zxcvbnmasdfe'))); +}); + +test('pass a regular expression to the exclude parameter with g flag', (t) => { + const filter = createFilter(null, [/zxcvbnmasdfg/g]); + t.falsy(filter(resolve('zxcvbnmasdfg'))); + t.falsy(filter(resolve('zxcvbnmasdfg'))); +}); From 831b717301e07a783bb2bbecf56e0f043165e047 Mon Sep 17 00:00:00 2001 From: Andrew Powell Date: Sun, 15 Dec 2024 11:06:07 -0500 Subject: [PATCH 4/4] chore: bump workflows --- packages/pluginutils/test/createFilter.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/pluginutils/test/createFilter.ts b/packages/pluginutils/test/createFilter.ts index 66116b5a4..783182eac 100755 --- a/packages/pluginutils/test/createFilter.ts +++ b/packages/pluginutils/test/createFilter.ts @@ -8,7 +8,7 @@ const resolve = (...parts: string[]) => normalizePath(rawResolve(...parts)); test.beforeEach(() => process.chdir(__dirname)); -test('includes by default', (t) => { +test('includes by default ', (t) => { const filter = createFilter(); t.truthy(filter(resolve('x'))); });