From c81c818a21703a8f63080a13e007e05a8131e691 Mon Sep 17 00:00:00 2001 From: Marco Ippolito Date: Fri, 11 Oct 2024 20:41:38 +0500 Subject: [PATCH] module: throw ERR_NO_TYPESCRIPT when compiled without amaro PR-URL: https://github.com/nodejs/node/pull/55332 Reviewed-By: Richard Lau Reviewed-By: Jacob Smith Reviewed-By: Chemi Atlow Reviewed-By: Antoine du Hamel --- doc/api/errors.md | 12 ++++++++++++ lib/internal/errors.js | 2 ++ lib/internal/modules/helpers.js | 3 ++- lib/internal/util.js | 17 ++++++++++++++--- 4 files changed, 30 insertions(+), 4 deletions(-) diff --git a/doc/api/errors.md b/doc/api/errors.md index 5a613a1422dc07..c62f70f51ceb51 100644 --- a/doc/api/errors.md +++ b/doc/api/errors.md @@ -2343,6 +2343,17 @@ OpenSSL crypto support. An attempt was made to use features that require [ICU][], but Node.js was not compiled with ICU support. + + +### `ERR_NO_TYPESCRIPT` + + + +An attempt was made to use features that require [Native TypeScript support][], but Node.js was not +compiled with TypeScript support. + ### `ERR_OPERATION_FAILED` @@ -4112,6 +4123,7 @@ An error occurred trying to allocate memory. This should never happen. [ICU]: intl.md#internationalization-support [JSON Web Key Elliptic Curve Registry]: https://www.iana.org/assignments/jose/jose.xhtml#web-key-elliptic-curve [JSON Web Key Types Registry]: https://www.iana.org/assignments/jose/jose.xhtml#web-key-types +[Native TypeScript support]: typescript.md#type-stripping [Node.js error codes]: #nodejs-error-codes [Permission Model]: permissions.md#permission-model [RFC 7230 Section 3]: https://tools.ietf.org/html/rfc7230#section-3 diff --git a/lib/internal/errors.js b/lib/internal/errors.js index f31bac27e3fd40..be5ce9fc24bc5d 100644 --- a/lib/internal/errors.js +++ b/lib/internal/errors.js @@ -1605,6 +1605,8 @@ E('ERR_NO_CRYPTO', 'Node.js is not compiled with OpenSSL crypto support', Error); E('ERR_NO_ICU', '%s is not supported on Node.js compiled without ICU', TypeError); +E('ERR_NO_TYPESCRIPT', + 'Node.js is not compiled with TypeScript support', Error); E('ERR_OPERATION_FAILED', 'Operation failed: %s', Error, TypeError); E('ERR_OUT_OF_RANGE', (str, range, input, replaceDefaultBoolean = false) => { diff --git a/lib/internal/modules/helpers.js b/lib/internal/modules/helpers.js index 11adec360cc98c..85bc51635a13d6 100644 --- a/lib/internal/modules/helpers.js +++ b/lib/internal/modules/helpers.js @@ -28,7 +28,7 @@ const assert = require('internal/assert'); const { Buffer } = require('buffer'); const { getOptionValue } = require('internal/options'); -const { setOwnProperty, getLazy } = require('internal/util'); +const { assertTypeScript, setOwnProperty, getLazy } = require('internal/util'); const { inspect } = require('internal/util/inspect'); const lazyTmpdir = getLazy(() => require('os').tmpdir()); @@ -328,6 +328,7 @@ const getTypeScriptParsingMode = getLazy(() => * @returns {Function} The TypeScript parser function. */ const loadTypeScriptParser = getLazy(() => { + assertTypeScript(); const amaro = require('internal/deps/amaro/dist/index'); return amaro.transformSync; }); diff --git a/lib/internal/util.js b/lib/internal/util.js index d7b5642ad0ce82..809e9697a29990 100644 --- a/lib/internal/util.js +++ b/lib/internal/util.js @@ -45,6 +45,7 @@ const { const { codes: { ERR_NO_CRYPTO, + ERR_NO_TYPESCRIPT, ERR_UNKNOWN_SIGNAL, }, isErrorStackTraceLimitWritable, @@ -65,6 +66,7 @@ const { getOptionValue } = require('internal/options'); const { encodings } = internalBinding('string_decoder'); const noCrypto = !process.versions.openssl; +const noTypeScript = !process.versions.amaro; const isWindows = process.platform === 'win32'; const isMacOS = process.platform === 'darwin'; @@ -196,9 +198,17 @@ function assertCrypto() { throw new ERR_NO_CRYPTO(); } -// Return undefined if there is no match. -// Move the "slow cases" to a separate function to make sure this function gets -// inlined properly. That prioritizes the common case. +function assertTypeScript() { + if (noTypeScript) + throw new ERR_NO_TYPESCRIPT(); +} + +/** + * Move the "slow cases" to a separate function to make sure this function gets + * inlined properly. That prioritizes the common case. + * @param {unknown} enc + * @returns {string | undefined} Returns undefined if there is no match. + */ function normalizeEncoding(enc) { if (enc == null || enc === 'utf8' || enc === 'utf-8') return 'utf8'; return slowCases(enc); @@ -862,6 +872,7 @@ for (let i = 0; i < encodings.length; ++i) module.exports = { getLazy, assertCrypto, + assertTypeScript, cachedResult, convertToValidSignal, createClassWrapper,