From f02a1baf412f386a4d4ea060e51a56328bfa567f Mon Sep 17 00:00:00 2001 From: uzlopak Date: Thu, 21 Mar 2024 02:08:02 +0100 Subject: [PATCH] util: improve isInsideNodeModules --- lib/internal/util.js | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/lib/internal/util.js b/lib/internal/util.js index 226a57ddda55b3..3af54538ce7def 100644 --- a/lib/internal/util.js +++ b/lib/internal/util.js @@ -35,6 +35,7 @@ const { SafeSet, SafeWeakMap, SafeWeakRef, + StringPrototypeIncludes, StringPrototypeReplace, StringPrototypeToLowerCase, StringPrototypeToUpperCase, @@ -476,7 +477,7 @@ function spliceOne(list, index) { list.pop(); } -const kNodeModulesRE = /^(.*)[\\/]node_modules[\\/]/; +const kNodeModulesRE = /^(?:.*)[\\/]node_modules[\\/]/; let getStructuredStack; @@ -506,8 +507,12 @@ function isInsideNodeModules() { const filename = frame.getFileName(); // If a filename does not start with / or contain \, // it's likely from Node.js core. - if (RegExpPrototypeExec(/^\/|\\/, filename) === null) + if ( + filename[0] !== '/' && + StringPrototypeIncludes(filename, '\\') === false + ) { continue; + } return RegExpPrototypeExec(kNodeModulesRE, filename) !== null; } }