Skip to content
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.

Commit f3f1a93

Browse files
committedDec 19, 2017
async_hooks: rename initTriggerId
rename initTriggerId to defaultTriggerAsyncId such it matches the rest of our naming. PR-URL: #17273 Reviewed-By: Matteo Collina <[email protected]> Reviewed-By: James M Snell <[email protected]>
1 parent fe257ac commit f3f1a93

15 files changed

+69
-67
lines changed
 

‎lib/_http_client.js

+1-1
Original file line numberDiff line numberDiff line change
@@ -547,7 +547,7 @@ function responseKeepAlive(res, req) {
547547
socket.removeListener('error', socketErrorListener);
548548
socket.once('error', freeSocketErrorListener);
549549
// There are cases where _handle === null. Avoid those. Passing null to
550-
// nextTick() will call initTriggerId() to retrieve the id.
550+
// nextTick() will call getDefaultTriggerAsyncId() to retrieve the id.
551551
const asyncId = socket._handle ? socket._handle.getAsyncId() : null;
552552
// Mark this socket as available, AFTER user-added end
553553
// handlers have a chance to run.

‎lib/async_hooks.js

+2-2
Original file line numberDiff line numberDiff line change
@@ -15,7 +15,7 @@ const {
1515
disableHooks,
1616
// Internal Embedder API
1717
newUid,
18-
initTriggerId,
18+
getDefaultTriggerAsyncId,
1919
emitInit,
2020
emitBefore,
2121
emitAfter,
@@ -147,7 +147,7 @@ class AsyncResource {
147147
if (typeof opts === 'number') {
148148
opts = { triggerAsyncId: opts, requireManualDestroy: false };
149149
} else if (opts.triggerAsyncId === undefined) {
150-
opts.triggerAsyncId = initTriggerId();
150+
opts.triggerAsyncId = getDefaultTriggerAsyncId();
151151
}
152152

153153
// Unlike emitInitScript, AsyncResource doesn't supports null as the

‎lib/dgram.js

+2-2
Original file line numberDiff line numberDiff line change
@@ -28,7 +28,7 @@ const dns = require('dns');
2828
const util = require('util');
2929
const { isUint8Array } = require('internal/util/types');
3030
const EventEmitter = require('events');
31-
const { setInitTriggerId } = require('internal/async_hooks');
31+
const { setDefaultTriggerAsyncId } = require('internal/async_hooks');
3232
const { UV_UDP_REUSEADDR } = process.binding('constants').os;
3333
const { async_id_symbol } = process.binding('async_wrap');
3434
const { nextTick } = require('internal/process/next_tick');
@@ -481,7 +481,7 @@ function doSend(ex, self, ip, list, address, port, callback) {
481481
// node::SendWrap isn't instantiated and attached to the JS instance of
482482
// SendWrap above until send() is called. So don't set the init trigger id
483483
// until now.
484-
setInitTriggerId(self[async_id_symbol]);
484+
setDefaultTriggerAsyncId(self[async_id_symbol]);
485485
var err = self._handle.send(req,
486486
list,
487487
list.length,

‎lib/internal/async_hooks.js

+18-18
Original file line numberDiff line numberDiff line change
@@ -14,10 +14,10 @@ const async_wrap = process.binding('async_wrap');
1414
* kTriggerAsyncId: The trigger_async_id of the resource responsible for
1515
* the current execution stack.
1616
* kAsyncIdCounter: Incremental counter tracking the next assigned async_id.
17-
* kInitTriggerAsyncId: Written immediately before a resource's constructor
17+
* kDefaultTriggerAsyncId: Written immediately before a resource's constructor
1818
* that sets the value of the init()'s triggerAsyncId. The order of
1919
* retrieving the triggerAsyncId value is passing directly to the
20-
* constructor -> value set in kInitTriggerAsyncId -> executionAsyncId of
20+
* constructor -> value set in kDefaultTriggerAsyncId -> executionAsyncId of
2121
* the current resource.
2222
*/
2323
const { async_hook_fields, async_id_fields } = async_wrap;
@@ -61,7 +61,7 @@ const active_hooks = {
6161
// for a given step, that step can bail out early.
6262
const { kInit, kBefore, kAfter, kDestroy, kPromiseResolve,
6363
kCheck, kExecutionAsyncId, kAsyncIdCounter,
64-
kInitTriggerAsyncId } = async_wrap.constants;
64+
kDefaultTriggerAsyncId } = async_wrap.constants;
6565

6666
// Used in AsyncHook and AsyncResource.
6767
const init_symbol = Symbol('init');
@@ -245,25 +245,25 @@ function newUid() {
245245
return ++async_id_fields[kAsyncIdCounter];
246246
}
247247

248-
249248
// Return the triggerAsyncId meant for the constructor calling it. It's up to
250249
// the user to safeguard this call and make sure it's zero'd out when the
251250
// constructor is complete.
252-
function initTriggerId() {
253-
var triggerAsyncId = async_id_fields[kInitTriggerAsyncId];
251+
function getDefaultTriggerAsyncId() {
252+
var defaultTriggerAsyncId = async_id_fields[kDefaultTriggerAsyncId];
254253
// Reset value after it's been called so the next constructor doesn't
255254
// inherit it by accident.
256-
async_id_fields[kInitTriggerAsyncId] = 0;
257-
if (triggerAsyncId <= 0)
258-
triggerAsyncId = async_id_fields[kExecutionAsyncId];
259-
return triggerAsyncId;
255+
async_id_fields[kDefaultTriggerAsyncId] = 0;
256+
// If defaultTriggerAsyncId isn't set, use the executionAsyncId
257+
if (defaultTriggerAsyncId <= 0)
258+
defaultTriggerAsyncId = async_id_fields[kExecutionAsyncId];
259+
return defaultTriggerAsyncId;
260260
}
261261

262262

263-
function setInitTriggerId(triggerAsyncId) {
263+
function setDefaultTriggerAsyncId(triggerAsyncId) {
264264
// CHECK(Number.isSafeInteger(triggerAsyncId))
265265
// CHECK(triggerAsyncId > 0)
266-
async_id_fields[kInitTriggerAsyncId] = triggerAsyncId;
266+
async_id_fields[kDefaultTriggerAsyncId] = triggerAsyncId;
267267
}
268268

269269

@@ -282,13 +282,13 @@ function emitInitScript(asyncId, type, triggerAsyncId, resource) {
282282
return;
283283

284284
// This can run after the early return check b/c running this function
285-
// manually means that the embedder must have used initTriggerId().
285+
// manually means that the embedder must have used getDefaultTriggerAsyncId().
286286
if (triggerAsyncId === null) {
287-
triggerAsyncId = initTriggerId();
287+
triggerAsyncId = getDefaultTriggerAsyncId();
288288
} else {
289-
// If a triggerAsyncId was passed, any kInitTriggerAsyncId still must be
289+
// If a triggerAsyncId was passed, any kDefaultTriggerAsyncId still must be
290290
// null'd.
291-
async_id_fields[kInitTriggerAsyncId] = 0;
291+
async_id_fields[kDefaultTriggerAsyncId] = 0;
292292
}
293293

294294
emitInitNative(asyncId, type, triggerAsyncId, resource);
@@ -340,8 +340,8 @@ module.exports = {
340340
disableHooks,
341341
// Internal Embedder API
342342
newUid,
343-
initTriggerId,
344-
setInitTriggerId,
343+
getDefaultTriggerAsyncId,
344+
setDefaultTriggerAsyncId,
345345
emitInit: emitInitScript,
346346
emitBefore: emitBeforeScript,
347347
emitAfter: emitAfterScript,

‎lib/internal/bootstrap_node.js

+4-4
Original file line numberDiff line numberDiff line change
@@ -369,14 +369,14 @@
369369
// Internal functions needed to manipulate the stack.
370370
const { clearAsyncIdStack, asyncIdStackSize } = async_wrap;
371371
const { kAfter, kExecutionAsyncId,
372-
kInitTriggerAsyncId } = async_wrap.constants;
372+
kDefaultTriggerAsyncId } = async_wrap.constants;
373373

374374
process._fatalException = function(er) {
375375
var caught;
376376

377-
// It's possible that kInitTriggerAsyncId was set for a constructor call
378-
// that threw and was never cleared. So clear it now.
379-
async_id_fields[kInitTriggerAsyncId] = 0;
377+
// It's possible that kDefaultTriggerAsyncId was set for a constructor
378+
// call that threw and was never cleared. So clear it now.
379+
async_id_fields[kDefaultTriggerAsyncId] = 0;
380380

381381
if (exceptionHandlerState.captureFn !== null) {
382382
exceptionHandlerState.captureFn(er);

‎lib/internal/process/next_tick.js

+3-3
Original file line numberDiff line numberDiff line change
@@ -48,7 +48,7 @@ function setupNextTick() {
4848
const promises = require('internal/process/promises');
4949
const errors = require('internal/errors');
5050
const emitPendingUnhandledRejections = promises.setup(scheduleMicrotasks);
51-
const initTriggerId = async_hooks.initTriggerId;
51+
const getDefaultTriggerAsyncId = async_hooks.getDefaultTriggerAsyncId;
5252
// Two arrays that share state between C++ and JS.
5353
const { async_hook_fields, async_id_fields } = async_wrap;
5454
// Used to change the state of the async id stack.
@@ -210,7 +210,7 @@ function setupNextTick() {
210210
nextTickQueue.push(new TickObject(callback,
211211
args,
212212
++async_id_fields[kAsyncIdCounter],
213-
initTriggerId()));
213+
getDefaultTriggerAsyncId()));
214214
}
215215

216216
// `internalNextTick()` will not enqueue any callback when the process is
@@ -237,7 +237,7 @@ function setupNextTick() {
237237
}
238238

239239
if (triggerAsyncId === null)
240-
triggerAsyncId = initTriggerId();
240+
triggerAsyncId = getDefaultTriggerAsyncId();
241241
// In V8 6.2, moving tickInfo & async_id_fields[kAsyncIdCounter] into the
242242
// TickObject incurs a significant performance penalty in the
243243
// next-tick-breadth-args benchmark (revisit later)

‎lib/net.js

+5-5
Original file line numberDiff line numberDiff line change
@@ -43,7 +43,7 @@ const { TCPConnectWrap } = process.binding('tcp_wrap');
4343
const { PipeConnectWrap } = process.binding('pipe_wrap');
4444
const { ShutdownWrap, WriteWrap } = process.binding('stream_wrap');
4545
const { async_id_symbol } = process.binding('async_wrap');
46-
const { newUid, setInitTriggerId } = require('internal/async_hooks');
46+
const { newUid, setDefaultTriggerAsyncId } = require('internal/async_hooks');
4747
const { nextTick } = require('internal/process/next_tick');
4848
const errors = require('internal/errors');
4949
const dns = require('dns');
@@ -304,7 +304,7 @@ function onSocketFinish() {
304304
// node::ShutdownWrap isn't instantiated and attached to the JS instance of
305305
// ShutdownWrap above until shutdown() is called. So don't set the init
306306
// trigger id until now.
307-
setInitTriggerId(this[async_id_symbol]);
307+
setDefaultTriggerAsyncId(this[async_id_symbol]);
308308
var err = this._handle.shutdown(req);
309309

310310
if (err)
@@ -948,7 +948,7 @@ function internalConnect(
948948
// node::TCPConnectWrap isn't instantiated and attached to the JS instance
949949
// of TCPConnectWrap above until connect() is called. So don't set the init
950950
// trigger id until now.
951-
setInitTriggerId(self[async_id_symbol]);
951+
setDefaultTriggerAsyncId(self[async_id_symbol]);
952952
if (addressType === 4)
953953
err = self._handle.connect(req, address, port);
954954
else
@@ -961,7 +961,7 @@ function internalConnect(
961961
// node::PipeConnectWrap isn't instantiated and attached to the JS instance
962962
// of PipeConnectWrap above until connect() is called. So don't set the
963963
// init trigger id until now.
964-
setInitTriggerId(self[async_id_symbol]);
964+
setDefaultTriggerAsyncId(self[async_id_symbol]);
965965
err = self._handle.connect(req, address, afterConnect);
966966
}
967967

@@ -1097,7 +1097,7 @@ function lookupAndConnect(self, options) {
10971097
debug('connect: dns options', dnsopts);
10981098
self._host = host;
10991099
var lookup = options.lookup || dns.lookup;
1100-
setInitTriggerId(self[async_id_symbol]);
1100+
setDefaultTriggerAsyncId(self[async_id_symbol]);
11011101
lookup(host, dnsopts, function emitLookup(err, ip, addressType) {
11021102
self.emit('lookup', err, ip, addressType, host);
11031103

‎lib/timers.js

+4-4
Original file line numberDiff line numberDiff line change
@@ -34,7 +34,7 @@ const kOnTimeout = TimerWrap.kOnTimeout | 0;
3434
// Two arrays that share state between C++ and JS.
3535
const { async_hook_fields, async_id_fields } = async_wrap;
3636
const {
37-
initTriggerId,
37+
getDefaultTriggerAsyncId,
3838
// The needed emit*() functions.
3939
emitInit,
4040
emitBefore,
@@ -181,7 +181,7 @@ function insert(item, unrefed) {
181181
if (!item[async_id_symbol] || item._destroyed) {
182182
item._destroyed = false;
183183
item[async_id_symbol] = ++async_id_fields[kAsyncIdCounter];
184-
item[trigger_async_id_symbol] = initTriggerId();
184+
item[trigger_async_id_symbol] = getDefaultTriggerAsyncId();
185185
if (async_hook_fields[kInit] > 0) {
186186
emitInit(item[async_id_symbol],
187187
'Timeout',
@@ -560,7 +560,7 @@ function Timeout(callback, after, args, isRepeat) {
560560
this._destroyed = false;
561561

562562
this[async_id_symbol] = ++async_id_fields[kAsyncIdCounter];
563-
this[trigger_async_id_symbol] = initTriggerId();
563+
this[trigger_async_id_symbol] = getDefaultTriggerAsyncId();
564564
if (async_hook_fields[kInit] > 0) {
565565
emitInit(this[async_id_symbol],
566566
'Timeout',
@@ -786,7 +786,7 @@ function Immediate(callback, args) {
786786
this._destroyed = false;
787787

788788
this[async_id_symbol] = ++async_id_fields[kAsyncIdCounter];
789-
this[trigger_async_id_symbol] = initTriggerId();
789+
this[trigger_async_id_symbol] = getDefaultTriggerAsyncId();
790790
if (async_hook_fields[kInit] > 0) {
791791
emitInit(this[async_id_symbol],
792792
'Immediate',

‎src/async_wrap.cc

+7-6
Original file line numberDiff line numberDiff line change
@@ -310,7 +310,7 @@ static void PromiseHook(PromiseHookType type, Local<Promise> promise,
310310
}
311311
// get id from parentWrap
312312
double trigger_async_id = parent_wrap->get_async_id();
313-
env->set_init_trigger_async_id(trigger_async_id);
313+
env->set_default_trigger_async_id(trigger_async_id);
314314
}
315315

316316
wrap = PromiseWrap::New(env, promise, parent_wrap, silent);
@@ -542,9 +542,10 @@ void AsyncWrap::Initialize(Local<Object> target,
542542
//
543543
// kAsyncUid: Maintains the state of the next unique id to be assigned.
544544
//
545-
// kInitTriggerAsyncId: Write the id of the resource responsible for a
545+
// kDefaultTriggerAsyncId: Write the id of the resource responsible for a
546546
// handle's creation just before calling the new handle's constructor.
547-
// After the new handle is constructed kInitTriggerAsyncId is set back to 0.
547+
// After the new handle is constructed kDefaultTriggerAsyncId is set back
548+
// to 0.
548549
FORCE_SET_TARGET_FIELD(target,
549550
"async_id_fields",
550551
env->async_hooks()->async_id_fields().GetJSArray());
@@ -564,7 +565,7 @@ void AsyncWrap::Initialize(Local<Object> target,
564565
SET_HOOKS_CONSTANT(kExecutionAsyncId);
565566
SET_HOOKS_CONSTANT(kTriggerAsyncId);
566567
SET_HOOKS_CONSTANT(kAsyncIdCounter);
567-
SET_HOOKS_CONSTANT(kInitTriggerAsyncId);
568+
SET_HOOKS_CONSTANT(kDefaultTriggerAsyncId);
568569
#undef SET_HOOKS_CONSTANT
569570
FORCE_SET_TARGET_FIELD(target, "constants", constants);
570571

@@ -677,7 +678,7 @@ void AsyncWrap::EmitDestroy(Environment* env, double async_id) {
677678
void AsyncWrap::AsyncReset(double execution_async_id, bool silent) {
678679
async_id_ =
679680
execution_async_id == -1 ? env()->new_async_id() : execution_async_id;
680-
trigger_async_id_ = env()->get_init_trigger_async_id();
681+
trigger_async_id_ = env()->get_default_trigger_async_id();
681682

682683
switch (provider_type()) {
683684
#define V(PROVIDER) \
@@ -778,7 +779,7 @@ async_context EmitAsyncInit(Isolate* isolate,
778779

779780
// Initialize async context struct
780781
if (trigger_async_id == -1)
781-
trigger_async_id = env->get_init_trigger_async_id();
782+
trigger_async_id = env->get_default_trigger_async_id();
782783

783784
async_context context = {
784785
env->new_async_id(), // async_id_

‎src/connection_wrap.cc

+1-1
Original file line numberDiff line numberDiff line change
@@ -49,7 +49,7 @@ void ConnectionWrap<WrapType, UVType>::OnConnection(uv_stream_t* handle,
4949
};
5050

5151
if (status == 0) {
52-
env->set_init_trigger_async_id(wrap_data->get_async_id());
52+
env->set_default_trigger_async_id(wrap_data->get_async_id());
5353
// Instantiate the client javascript object and handle.
5454
Local<Object> client_obj = WrapType::Instantiate(env,
5555
wrap_data,

‎src/env-inl.h

+12-11
Original file line numberDiff line numberDiff line change
@@ -447,17 +447,18 @@ inline double Environment::trigger_async_id() {
447447
return async_hooks()->async_id_fields()[AsyncHooks::kTriggerAsyncId];
448448
}
449449

450-
inline double Environment::get_init_trigger_async_id() {
451-
AliasedBuffer<double, v8::Float64Array>& async_id_fields =
452-
async_hooks()->async_id_fields();
453-
double tid = async_id_fields[AsyncHooks::kInitTriggerAsyncId];
454-
async_id_fields[AsyncHooks::kInitTriggerAsyncId] = 0;
455-
if (tid <= 0) tid = execution_async_id();
456-
return tid;
457-
}
458-
459-
inline void Environment::set_init_trigger_async_id(const double id) {
460-
async_hooks()->async_id_fields()[AsyncHooks::kInitTriggerAsyncId] = id;
450+
inline double Environment::get_default_trigger_async_id() {
451+
double default_trigger_async_id =
452+
async_hooks()->async_id_fields()[AsyncHooks::kDefaultTriggerAsyncId];
453+
async_hooks()->async_id_fields()[AsyncHooks::kDefaultTriggerAsyncId] = 0;
454+
// If defaultTriggerAsyncId isn't set, use the executionAsyncId
455+
if (default_trigger_async_id <= 0)
456+
default_trigger_async_id = execution_async_id();
457+
return default_trigger_async_id;
458+
}
459+
460+
inline void Environment::set_default_trigger_async_id(const double id) {
461+
async_hooks()->async_id_fields()[AsyncHooks::kDefaultTriggerAsyncId] = id;
461462
}
462463

463464
inline double* Environment::heap_statistics_buffer() const {

‎src/env.h

+3-3
Original file line numberDiff line numberDiff line change
@@ -381,7 +381,7 @@ class Environment {
381381
kExecutionAsyncId,
382382
kTriggerAsyncId,
383383
kAsyncIdCounter,
384-
kInitTriggerAsyncId,
384+
kDefaultTriggerAsyncId,
385385
kUidFieldsCount,
386386
};
387387

@@ -558,8 +558,8 @@ class Environment {
558558
inline double new_async_id();
559559
inline double execution_async_id();
560560
inline double trigger_async_id();
561-
inline double get_init_trigger_async_id();
562-
inline void set_init_trigger_async_id(const double id);
561+
inline double get_default_trigger_async_id();
562+
inline void set_default_trigger_async_id(const double id);
563563

564564
// List of id's that have been destroyed and need the destroy() cb called.
565565
inline std::vector<double>* destroy_async_id_list();

0 commit comments

Comments
 (0)
Please sign in to comment.