summaryrefslogtreecommitdiff
path: root/lib/internal/bootstrap/loaders.js
diff options
context:
space:
mode:
authorJoyee Cheung <joyeec9h3@gmail.com>2018-11-03 14:26:32 +0800
committerDaniel Bevenius <daniel.bevenius@gmail.com>2018-11-06 05:40:58 +0100
commitc3b674cc116e6656a0eedd9e8f01b1c01c955f2c (patch)
tree107b6bbcc6da3f7527152510739fa47d9743ffab /lib/internal/bootstrap/loaders.js
parent17e4213987c6ad8d6d1eb523556b5a074265c7a2 (diff)
downloadandroid-node-v8-c3b674cc116e6656a0eedd9e8f01b1c01c955f2c.tar.gz
android-node-v8-c3b674cc116e6656a0eedd9e8f01b1c01c955f2c.tar.bz2
android-node-v8-c3b674cc116e6656a0eedd9e8f01b1c01c955f2c.zip
lib: move module exports proxy into a separate method
Also added the comment in f074612b7 to make NativeModule.prototype.compile() more readable. PR-URL: https://github.com/nodejs/node/pull/24057 Reviewed-By: Anna Henningsen <anna@addaleax.net> Reviewed-By: Gus Caplan <me@gus.host> Reviewed-By: Refael Ackermann <refack@gmail.com>
Diffstat (limited to 'lib/internal/bootstrap/loaders.js')
-rw-r--r--lib/internal/bootstrap/loaders.js110
1 files changed, 59 insertions, 51 deletions
diff --git a/lib/internal/bootstrap/loaders.js b/lib/internal/bootstrap/loaders.js
index aceb15cc63..cd7a566fb1 100644
--- a/lib/internal/bootstrap/loaders.js
+++ b/lib/internal/bootstrap/loaders.js
@@ -235,6 +235,64 @@
undefined;
};
+ // Provide named exports for all builtin libraries so that the libraries
+ // may be imported in a nicer way for esm users. The default export is left
+ // as the entire namespace (module.exports) and wrapped in a proxy such
+ // that APMs and other behavior are still left intact.
+ NativeModule.prototype.proxifyExports = function() {
+ this.exportKeys = ObjectKeys(this.exports);
+
+ const update = (property, value) => {
+ if (this.reflect !== undefined &&
+ ReflectApply(ObjectHasOwnProperty,
+ this.reflect.exports, [property]))
+ this.reflect.exports[property].set(value);
+ };
+
+ const handler = {
+ __proto__: null,
+ defineProperty: (target, prop, descriptor) => {
+ // Use `Object.defineProperty` instead of `Reflect.defineProperty`
+ // to throw the appropriate error if something goes wrong.
+ ObjectDefineProperty(target, prop, descriptor);
+ if (typeof descriptor.get === 'function' &&
+ !ReflectHas(handler, 'get')) {
+ handler.get = (target, prop, receiver) => {
+ const value = ReflectGet(target, prop, receiver);
+ if (ReflectApply(ObjectHasOwnProperty, target, [prop]))
+ update(prop, value);
+ return value;
+ };
+ }
+ update(prop, getOwn(target, prop));
+ return true;
+ },
+ deleteProperty: (target, prop) => {
+ if (ReflectDeleteProperty(target, prop)) {
+ update(prop, undefined);
+ return true;
+ }
+ return false;
+ },
+ set: (target, prop, value, receiver) => {
+ const descriptor = ReflectGetOwnPropertyDescriptor(target, prop);
+ if (ReflectSet(target, prop, value, receiver)) {
+ if (descriptor && typeof descriptor.set === 'function') {
+ for (const key of this.exportKeys) {
+ update(key, getOwn(target, key, receiver));
+ }
+ } else {
+ update(prop, getOwn(target, prop, receiver));
+ }
+ return true;
+ }
+ return false;
+ }
+ };
+
+ this.exports = new Proxy(this.exports, handler);
+ };
+
NativeModule.prototype.compile = function() {
const id = this.id;
let source = NativeModule.getSource(id);
@@ -299,57 +357,7 @@
fn(this.exports, requireFn, this, process, internalBinding);
if (config.experimentalModules && !NativeModule.isInternal(this.id)) {
- this.exportKeys = ObjectKeys(this.exports);
-
- const update = (property, value) => {
- if (this.reflect !== undefined &&
- ReflectApply(ObjectHasOwnProperty,
- this.reflect.exports, [property]))
- this.reflect.exports[property].set(value);
- };
-
- const handler = {
- __proto__: null,
- defineProperty: (target, prop, descriptor) => {
- // Use `Object.defineProperty` instead of `Reflect.defineProperty`
- // to throw the appropriate error if something goes wrong.
- ObjectDefineProperty(target, prop, descriptor);
- if (typeof descriptor.get === 'function' &&
- !ReflectHas(handler, 'get')) {
- handler.get = (target, prop, receiver) => {
- const value = ReflectGet(target, prop, receiver);
- if (ReflectApply(ObjectHasOwnProperty, target, [prop]))
- update(prop, value);
- return value;
- };
- }
- update(prop, getOwn(target, prop));
- return true;
- },
- deleteProperty: (target, prop) => {
- if (ReflectDeleteProperty(target, prop)) {
- update(prop, undefined);
- return true;
- }
- return false;
- },
- set: (target, prop, value, receiver) => {
- const descriptor = ReflectGetOwnPropertyDescriptor(target, prop);
- if (ReflectSet(target, prop, value, receiver)) {
- if (descriptor && typeof descriptor.set === 'function') {
- for (const key of this.exportKeys) {
- update(key, getOwn(target, key, receiver));
- }
- } else {
- update(prop, getOwn(target, prop, receiver));
- }
- return true;
- }
- return false;
- }
- };
-
- this.exports = new Proxy(this.exports, handler);
+ this.proxifyExports();
}
this.loaded = true;