per_context: add warning to Atomics.wake

PR-URL: https://github.com/nodejs/node/pull/21518
Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl>
Reviewed-By: Anna Henningsen <anna@addaleax.net>
This commit is contained in:
Gus Caplan 2018-06-25 02:14:59 -05:00
parent d13cdd9c48
commit dcb371ff1f
No known key found for this signature in database
GPG Key ID: F00BD11880E82F0E
3 changed files with 55 additions and 9 deletions

View File

@ -25,6 +25,7 @@ module.exports = {
// the code cache is also used when compiling these // the code cache is also used when compiling these
// two files. // two files.
'internal/bootstrap/loaders', 'internal/bootstrap/loaders',
'internal/bootstrap/node' 'internal/bootstrap/node',
'internal/per_context',
] ]
}; };

View File

@ -7,10 +7,46 @@
delete global.Intl.v8BreakIterator; delete global.Intl.v8BreakIterator;
// https://github.com/nodejs/node/issues/21219 // https://github.com/nodejs/node/issues/21219
Object.defineProperty(global.Atomics, 'notify', { // Adds Atomics.notify and warns on first usage of Atomics.wake
value: global.Atomics.wake,
writable: true, const AtomicsWake = global.Atomics.wake;
enumerable: false, const ReflectApply = global.Reflect.apply;
configurable: true,
// wrap for function.name
function notify(...args) {
return ReflectApply(AtomicsWake, this, args);
}
const warning = 'Atomics.wake will be removed in a future version, ' +
'use Atomics.notify instead.';
let wakeWarned = false;
function wake(...args) {
if (!wakeWarned) {
wakeWarned = true;
if (global.process !== undefined) {
global.process.emitWarning(warning, 'Atomics');
} else {
global.console.error(`Atomics: ${warning}`);
}
}
return ReflectApply(AtomicsWake, this, args);
}
global.Object.defineProperties(global.Atomics, {
notify: {
value: notify,
writable: true,
enumerable: false,
configurable: true,
},
wake: {
value: wake,
writable: true,
enumerable: false,
configurable: true,
},
}); });
}(this)); }(this));

View File

@ -1,10 +1,19 @@
'use strict'; 'use strict';
require('../common'); const { expectWarning, noWarnCode } = require('../common');
const assert = require('assert'); const assert = require('assert');
const { runInNewContext } = require('vm'); const { runInNewContext } = require('vm');
assert.strictEqual(Atomics.wake, Atomics.notify); assert.strictEqual(typeof Atomics.wake, 'function');
assert.strictEqual(typeof Atomics.notify, 'function');
assert(runInNewContext('Atomics.wake === Atomics.notify')); assert.strictEqual(runInNewContext('typeof Atomics.wake'), 'function');
assert.strictEqual(runInNewContext('typeof Atomics.notify'), 'function');
expectWarning(
'Atomics',
'Atomics.wake will be removed in a future version, ' +
'use Atomics.notify instead.', noWarnCode);
Atomics.wake(new Int32Array(new SharedArrayBuffer(4)), 0, 0);