From 4c6bcdac8c7e5ffc9dd70c5afac2e818b9b3f794 Mon Sep 17 00:00:00 2001 From: Refael Ackermann Date: Mon, 27 May 2019 16:42:03 -0400 Subject: [PATCH] lib: no need to strip BOM or shebang for scripts MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Backport-PR-URL: https://github.com/nodejs/node/pull/31228 PR-URL: https://github.com/nodejs/node/pull/27375 Reviewed-By: Michaël Zasso Reviewed-By: Ujjwal Sharma Reviewed-By: Refael Ackermann Reviewed-By: Matteo Collina Reviewed-By: Colin Ihrig Reviewed-By: Rich Trott --- lib/internal/main/check_syntax.js | 6 +--- lib/internal/modules/cjs/helpers.js | 33 ------------------- lib/internal/modules/cjs/loader.js | 23 +++++++------ lib/internal/modules/esm/translators.js | 6 ++-- test/fixtures/utf8-bom-shebang-shebang.js | 3 ++ .../test-internal-modules-strip-shebang.js | 14 -------- test/sequential/test-module-loading.js | 2 +- 7 files changed, 21 insertions(+), 66 deletions(-) create mode 100644 test/fixtures/utf8-bom-shebang-shebang.js delete mode 100644 test/parallel/test-internal-modules-strip-shebang.js diff --git a/lib/internal/main/check_syntax.js b/lib/internal/main/check_syntax.js index 1a5287520414cb..92407d067cd675 100644 --- a/lib/internal/main/check_syntax.js +++ b/lib/internal/main/check_syntax.js @@ -13,10 +13,6 @@ const { const { pathToFileURL } = require('url'); -const { - stripShebangOrBOM, -} = require('internal/modules/cjs/helpers'); - const { Module: { _resolveFilename: resolveCJSModuleName, @@ -68,5 +64,5 @@ function checkSyntax(source, filename) { } } - wrapSafe(filename, stripShebangOrBOM(source)); + wrapSafe(filename, source); } diff --git a/lib/internal/modules/cjs/helpers.js b/lib/internal/modules/cjs/helpers.js index b922f01e36b2af..7a9870024515ed 100644 --- a/lib/internal/modules/cjs/helpers.js +++ b/lib/internal/modules/cjs/helpers.js @@ -111,37 +111,6 @@ function stripBOM(content) { return content; } -/** - * Find end of shebang line and slice it off - */ -function stripShebang(content) { - // Remove shebang - if (content.charAt(0) === '#' && content.charAt(1) === '!') { - // Find end of shebang line and slice it off - let index = content.indexOf('\n', 2); - if (index === -1) - return ''; - if (content.charAt(index - 1) === '\r') - index--; - // Note that this actually includes the newline character(s) in the - // new output. This duplicates the behavior of the regular expression - // that was previously used to replace the shebang line. - content = content.slice(index); - } - return content; -} - -// Strip either the shebang or UTF BOM of a file. -// Note that this only processes one. If both occur in -// either order, the one that comes second is not -// significant. -function stripShebangOrBOM(content) { - if (content.charCodeAt(0) === 0xFEFF) { - return content.slice(1); - } - return stripShebang(content); -} - const builtinLibs = [ 'assert', 'async_hooks', 'buffer', 'child_process', 'cluster', 'crypto', 'dgram', 'dns', 'domain', 'events', 'fs', 'http', 'http2', 'https', 'net', @@ -208,6 +177,4 @@ module.exports = { makeRequireFunction, normalizeReferrerURL, stripBOM, - stripShebang, - stripShebangOrBOM, }; diff --git a/lib/internal/modules/cjs/loader.js b/lib/internal/modules/cjs/loader.js index bd0b4348116937..ff274f7fcd46c4 100644 --- a/lib/internal/modules/cjs/loader.js +++ b/lib/internal/modules/cjs/loader.js @@ -51,7 +51,7 @@ const { makeRequireFunction, normalizeReferrerURL, stripBOM, - stripShebangOrBOM, + loadNativeModule } = require('internal/modules/cjs/helpers'); const { getOptionValue } = require('internal/options'); const enableSourceMaps = getOptionValue('--enable-source-maps'); @@ -961,9 +961,9 @@ function wrapSafe(filename, content) { }); } - let compiledWrapper; + let compiled; try { - compiledWrapper = compileFunction( + compiled = compileFunction( content, filename, 0, @@ -981,13 +981,15 @@ function wrapSafe(filename, content) { ] ); } catch (err) { - enrichCJSError(err); + if (experimentalModules) { + enrichCJSError(err); + } throw err; } if (experimentalModules) { const { callbackMap } = internalBinding('module_wrap'); - callbackMap.set(compiledWrapper, { + callbackMap.set(compiled.cacheKey, { importModuleDynamically: async (specifier) => { const loader = await asyncESM.loaderPromise; return loader.import(specifier, normalizeReferrerURL(filename)); @@ -995,7 +997,7 @@ function wrapSafe(filename, content) { }); } - return compiledWrapper; + return compiled.function; } // Run the file contents in the correct scope or sandbox. Expose @@ -1003,14 +1005,15 @@ function wrapSafe(filename, content) { // the file. // Returns exception, if any. Module.prototype._compile = function(content, filename) { + let moduleURL; + let redirects; if (manifest) { - const moduleURL = pathToFileURL(filename); + moduleURL = pathToFileURL(filename); + redirects = manifest.getRedirector(moduleURL); manifest.assertIntegrity(moduleURL, content); } - // Strip after manifest integrity check - content = stripShebangOrBOM(content); - + maybeCacheSourceMap(filename, content, this); const compiledWrapper = wrapSafe(filename, content); var inspectorWrapper = null; diff --git a/lib/internal/modules/esm/translators.js b/lib/internal/modules/esm/translators.js index 5aede5490feb45..b4d41685ed094b 100644 --- a/lib/internal/modules/esm/translators.js +++ b/lib/internal/modules/esm/translators.js @@ -12,7 +12,8 @@ const { const { Buffer } = require('buffer'); const { - stripBOM + stripBOM, + loadNativeModule } = require('internal/modules/cjs/helpers'); const CJSModule = require('internal/modules/cjs/loader').Module; const internalURLModule = require('internal/url'); @@ -78,9 +79,8 @@ translators.set('module', async function moduleStrategy(url) { const source = `${await getSource(url)}`; maybeCacheSourceMap(url, source); debug(`Translating StandardModule ${url}`); - const { ModuleWrap, callbackMap } = internalBinding('module_wrap'); const module = new ModuleWrap(source, url); - callbackMap.set(module, { + moduleWrap.callbackMap.set(module, { initializeImportMeta, importModuleDynamically, }); diff --git a/test/fixtures/utf8-bom-shebang-shebang.js b/test/fixtures/utf8-bom-shebang-shebang.js new file mode 100644 index 00000000000000..4cf986dff27156 --- /dev/null +++ b/test/fixtures/utf8-bom-shebang-shebang.js @@ -0,0 +1,3 @@ +#!shebang +#!shebang +module.exports = 42; \ No newline at end of file diff --git a/test/parallel/test-internal-modules-strip-shebang.js b/test/parallel/test-internal-modules-strip-shebang.js deleted file mode 100644 index 6c23848a969231..00000000000000 --- a/test/parallel/test-internal-modules-strip-shebang.js +++ /dev/null @@ -1,14 +0,0 @@ -// Flags: --expose-internals -'use strict'; -require('../common'); - -const assert = require('assert'); -const stripShebang = require('internal/modules/cjs/helpers').stripShebang; - -[ - ['', ''], - ['aa', 'aa'], - ['#!', ''], - ['#!bin/bash', ''], - ['#!bin/bash\naa', '\naa'], -].forEach((i) => assert.strictEqual(stripShebang(i[0]), i[1])); diff --git a/test/sequential/test-module-loading.js b/test/sequential/test-module-loading.js index 94acdb191b9044..2e55eb29369fcd 100644 --- a/test/sequential/test-module-loading.js +++ b/test/sequential/test-module-loading.js @@ -355,7 +355,7 @@ assert.strictEqual(require('../fixtures/utf8-bom.json'), 42); // Loading files with BOM + shebang. // See https://github.com/nodejs/node/issues/27767 assert.throws(() => { - require('../fixtures/utf8-bom-shebang.js'); + require('../fixtures/utf8-bom-shebang-shebang.js'); }, { name: 'SyntaxError' }); assert.strictEqual(require('../fixtures/utf8-shebang-bom.js'), 42);