summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorJoyee Cheung <joyeec9h3@gmail.com>2019-01-31 03:08:25 +0800
committerJoyee Cheung <joyeec9h3@gmail.com>2019-02-08 08:08:48 +0800
commit09a5f0252ed8e367dd29ba77e2931e5cf2a39a9e (patch)
tree137d43029fab008be5d06adb6a61da4d3383228c /lib
parent041424f87cf7cb75e6b509e86411fa833c4c2dd8 (diff)
downloadandroid-node-v8-09a5f0252ed8e367dd29ba77e2931e5cf2a39a9e.tar.gz
android-node-v8-09a5f0252ed8e367dd29ba77e2931e5cf2a39a9e.tar.bz2
android-node-v8-09a5f0252ed8e367dd29ba77e2931e5cf2a39a9e.zip
process: move deprecation warning initialization into pre_execution.js
Since this is only necessary when user code execution is expected. PR-URL: https://github.com/nodejs/node/pull/25825 Reviewed-By: Anna Henningsen <anna@addaleax.net> Reviewed-By: Daniel Bevenius <daniel.bevenius@gmail.com> Reviewed-By: James M Snell <jasnell@gmail.com>
Diffstat (limited to 'lib')
-rw-r--r--lib/internal/bootstrap/node.js25
-rw-r--r--lib/internal/bootstrap/pre_execution.js40
-rw-r--r--lib/internal/main/check_syntax.js2
-rw-r--r--lib/internal/main/eval_stdin.js2
-rw-r--r--lib/internal/main/eval_string.js2
-rw-r--r--lib/internal/main/repl.js2
-rw-r--r--lib/internal/main/run_main_module.js2
-rw-r--r--lib/internal/main/worker_thread.js2
8 files changed, 54 insertions, 23 deletions
diff --git a/lib/internal/bootstrap/node.js b/lib/internal/bootstrap/node.js
index 360b871d0c..b4f2d4e838 100644
--- a/lib/internal/bootstrap/node.js
+++ b/lib/internal/bootstrap/node.js
@@ -226,29 +226,6 @@ Object.defineProperty(process, 'argv0', {
});
process.argv[0] = process.execPath;
-const { deprecate } = NativeModule.require('internal/util');
-{
- // Install legacy getters on the `util` binding for typechecking.
- // TODO(addaleax): Turn into a full runtime deprecation.
- const pendingDeprecation = getOptionValue('--pending-deprecation');
- const utilBinding = internalBinding('util');
- const types = NativeModule.require('internal/util/types');
- for (const name of [
- 'isArrayBuffer', 'isArrayBufferView', 'isAsyncFunction',
- 'isDataView', 'isDate', 'isExternal', 'isMap', 'isMapIterator',
- 'isNativeError', 'isPromise', 'isRegExp', 'isSet', 'isSetIterator',
- 'isTypedArray', 'isUint8Array', 'isAnyArrayBuffer'
- ]) {
- utilBinding[name] = pendingDeprecation ?
- deprecate(types[name],
- 'Accessing native typechecking bindings of Node ' +
- 'directly is deprecated. ' +
- `Please use \`util.types.${name}\` instead.`,
- 'DEP0103') :
- types[name];
- }
-}
-
// process.allowedNodeEnvironmentFlags
Object.defineProperty(process, 'allowedNodeEnvironmentFlags', {
get() {
@@ -269,6 +246,8 @@ Object.defineProperty(process, 'allowedNodeEnvironmentFlags', {
enumerable: true,
configurable: true
});
+
+const { deprecate } = NativeModule.require('internal/util');
// process.assert
process.assert = deprecate(
perThreadSetup.assert,
diff --git a/lib/internal/bootstrap/pre_execution.js b/lib/internal/bootstrap/pre_execution.js
index 798c581a72..d09fdb131a 100644
--- a/lib/internal/bootstrap/pre_execution.js
+++ b/lib/internal/bootstrap/pre_execution.js
@@ -2,6 +2,45 @@
const { getOptionValue } = require('internal/options');
+// In general deprecations are intialized wherever the APIs are implemented,
+// this is used to deprecate APIs implemented in C++ where the deprecation
+// utitlities are not easily accessible.
+function initializeDeprecations() {
+ const { deprecate } = require('internal/util');
+ const pendingDeprecation = getOptionValue('--pending-deprecation');
+
+ // DEP0103: access to `process.binding('util').isX` type checkers
+ // TODO(addaleax): Turn into a full runtime deprecation.
+ const utilBinding = internalBinding('util');
+ const types = require('internal/util/types');
+ for (const name of [
+ 'isArrayBuffer',
+ 'isArrayBufferView',
+ 'isAsyncFunction',
+ 'isDataView',
+ 'isDate',
+ 'isExternal',
+ 'isMap',
+ 'isMapIterator',
+ 'isNativeError',
+ 'isPromise',
+ 'isRegExp',
+ 'isSet',
+ 'isSetIterator',
+ 'isTypedArray',
+ 'isUint8Array',
+ 'isAnyArrayBuffer'
+ ]) {
+ utilBinding[name] = pendingDeprecation ?
+ deprecate(types[name],
+ 'Accessing native typechecking bindings of Node ' +
+ 'directly is deprecated. ' +
+ `Please use \`util.types.${name}\` instead.`,
+ 'DEP0103') :
+ types[name];
+ }
+}
+
function initializeClusterIPC() {
// If this is a worker in cluster mode, start up the communication
// channel. This needs to be done before any user code gets executed
@@ -75,6 +114,7 @@ function loadPreloadModules() {
}
module.exports = {
+ initializeDeprecations,
initializeClusterIPC,
initializePolicy,
initializeESMLoader,
diff --git a/lib/internal/main/check_syntax.js b/lib/internal/main/check_syntax.js
index 5d4d7a04eb..97584841b3 100644
--- a/lib/internal/main/check_syntax.js
+++ b/lib/internal/main/check_syntax.js
@@ -4,6 +4,7 @@
// instead of actually running the file.
const {
+ initializeDeprecations,
initializeClusterIPC,
initializePolicy,
initializeESMLoader,
@@ -21,6 +22,7 @@ const {
} = require('internal/modules/cjs/helpers');
// TODO(joyeecheung): not every one of these are necessary
+initializeDeprecations();
initializeClusterIPC();
initializePolicy();
initializeESMLoader();
diff --git a/lib/internal/main/eval_stdin.js b/lib/internal/main/eval_stdin.js
index ad15fdb93c..f02d9ffa0c 100644
--- a/lib/internal/main/eval_stdin.js
+++ b/lib/internal/main/eval_stdin.js
@@ -3,6 +3,7 @@
// Stdin is not a TTY, we will read it and execute it.
const {
+ initializeDeprecations,
initializeClusterIPC,
initializePolicy,
initializeESMLoader,
@@ -14,6 +15,7 @@ const {
readStdin
} = require('internal/process/execution');
+initializeDeprecations();
initializeClusterIPC();
initializePolicy();
initializeESMLoader();
diff --git a/lib/internal/main/eval_string.js b/lib/internal/main/eval_string.js
index cd382b48e7..7f746a6b11 100644
--- a/lib/internal/main/eval_string.js
+++ b/lib/internal/main/eval_string.js
@@ -4,6 +4,7 @@
// `--interactive`.
const {
+ initializeDeprecations,
initializeClusterIPC,
initializePolicy,
initializeESMLoader,
@@ -13,6 +14,7 @@ const { evalScript } = require('internal/process/execution');
const { addBuiltinLibsToObject } = require('internal/modules/cjs/helpers');
const source = require('internal/options').getOptionValue('--eval');
+initializeDeprecations();
initializeClusterIPC();
initializePolicy();
initializeESMLoader();
diff --git a/lib/internal/main/repl.js b/lib/internal/main/repl.js
index 4ca328421b..e931444ef3 100644
--- a/lib/internal/main/repl.js
+++ b/lib/internal/main/repl.js
@@ -4,6 +4,7 @@
// the main module is not specified and stdin is a TTY.
const {
+ initializeDeprecations,
initializeClusterIPC,
initializePolicy,
initializeESMLoader,
@@ -14,6 +15,7 @@ const {
evalScript
} = require('internal/process/execution');
+initializeDeprecations();
initializeClusterIPC();
initializePolicy();
initializeESMLoader();
diff --git a/lib/internal/main/run_main_module.js b/lib/internal/main/run_main_module.js
index b5049cffc5..abc41fc202 100644
--- a/lib/internal/main/run_main_module.js
+++ b/lib/internal/main/run_main_module.js
@@ -1,12 +1,14 @@
'use strict';
const {
+ initializeDeprecations,
initializeClusterIPC,
initializePolicy,
initializeESMLoader,
loadPreloadModules
} = require('internal/bootstrap/pre_execution');
+initializeDeprecations();
initializeClusterIPC();
initializePolicy();
initializeESMLoader();
diff --git a/lib/internal/main/worker_thread.js b/lib/internal/main/worker_thread.js
index 94d0e613e8..7e4466c24d 100644
--- a/lib/internal/main/worker_thread.js
+++ b/lib/internal/main/worker_thread.js
@@ -4,6 +4,7 @@
// message port.
const {
+ initializeDeprecations,
initializeClusterIPC,
initializeESMLoader,
loadPreloadModules
@@ -55,6 +56,7 @@ port.on('message', (message) => {
if (manifestSrc) {
require('internal/process/policy').setup(manifestSrc, manifestURL);
}
+ initializeDeprecations();
initializeClusterIPC();
initializeESMLoader();
loadPreloadModules();