Skip to content

Commit 2000072

Browse files
Fishrock123evanlucas
authored andcommitted
handle_wrap: IsRefed -> Unrefed, no isAlive check
This fixes my perceived usability issues with 7d8882b. Which, at the time of writing, has not landed in any release except v6 RCs. This should not be considered a breaking change due to that. It is useful if you have a handle, even if it has been closed, to be able to inspect whether that handle was unrefed or not. As such, this renames the method accordingly. If people need to check a handle's aliveness, that is a separate API we should consider exposing. Refs: #5834 PR-URL: #6204 Reviewed-By: James M Snell <[email protected]> Reviewed-By: Trevor Norris <[email protected]>
1 parent 316871f commit 2000072

11 files changed

+57
-49
lines changed

src/handle_wrap.cc

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -38,11 +38,11 @@ void HandleWrap::Unref(const FunctionCallbackInfo<Value>& args) {
3838
}
3939

4040

41-
void HandleWrap::IsRefed(const FunctionCallbackInfo<Value>& args) {
41+
void HandleWrap::Unrefed(const FunctionCallbackInfo<Value>& args) {
4242
HandleWrap* wrap = Unwrap<HandleWrap>(args.Holder());
4343

44-
bool refed = IsAlive(wrap) && (wrap->flags_ & kUnref) == 0;
45-
args.GetReturnValue().Set(refed);
44+
bool unrefed = wrap->flags_ & kUnref == 1;
45+
args.GetReturnValue().Set(unrefed);
4646
}
4747

4848

src/handle_wrap.h

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -35,7 +35,7 @@ class HandleWrap : public AsyncWrap {
3535
static void Close(const v8::FunctionCallbackInfo<v8::Value>& args);
3636
static void Ref(const v8::FunctionCallbackInfo<v8::Value>& args);
3737
static void Unref(const v8::FunctionCallbackInfo<v8::Value>& args);
38-
static void IsRefed(const v8::FunctionCallbackInfo<v8::Value>& args);
38+
static void Unrefed(const v8::FunctionCallbackInfo<v8::Value>& args);
3939

4040
static inline bool IsAlive(const HandleWrap* wrap) {
4141
return wrap != nullptr && wrap->GetHandle() != nullptr;

src/pipe_wrap.cc

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -80,7 +80,7 @@ void PipeWrap::Initialize(Local<Object> target,
8080
env->SetProtoMethod(t, "close", HandleWrap::Close);
8181
env->SetProtoMethod(t, "unref", HandleWrap::Unref);
8282
env->SetProtoMethod(t, "ref", HandleWrap::Ref);
83-
env->SetProtoMethod(t, "isRefed", HandleWrap::IsRefed);
83+
env->SetProtoMethod(t, "unrefed", HandleWrap::Unrefed);
8484

8585
StreamWrap::AddMethods(env, t);
8686

src/process_wrap.cc

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -40,7 +40,7 @@ class ProcessWrap : public HandleWrap {
4040

4141
env->SetProtoMethod(constructor, "ref", HandleWrap::Ref);
4242
env->SetProtoMethod(constructor, "unref", HandleWrap::Unref);
43-
env->SetProtoMethod(constructor, "isRefed", HandleWrap::IsRefed);
43+
env->SetProtoMethod(constructor, "unrefed", HandleWrap::Unrefed);
4444

4545
target->Set(FIXED_ONE_BYTE_STRING(env->isolate(), "Process"),
4646
constructor->GetFunction());

src/signal_wrap.cc

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -32,7 +32,7 @@ class SignalWrap : public HandleWrap {
3232
env->SetProtoMethod(constructor, "close", HandleWrap::Close);
3333
env->SetProtoMethod(constructor, "ref", HandleWrap::Ref);
3434
env->SetProtoMethod(constructor, "unref", HandleWrap::Unref);
35-
env->SetProtoMethod(constructor, "isRefed", HandleWrap::IsRefed);
35+
env->SetProtoMethod(constructor, "unrefed", HandleWrap::Unrefed);
3636
env->SetProtoMethod(constructor, "start", Start);
3737
env->SetProtoMethod(constructor, "stop", Stop);
3838

src/tcp_wrap.cc

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -87,7 +87,7 @@ void TCPWrap::Initialize(Local<Object> target,
8787

8888
env->SetProtoMethod(t, "ref", HandleWrap::Ref);
8989
env->SetProtoMethod(t, "unref", HandleWrap::Unref);
90-
env->SetProtoMethod(t, "isRefed", HandleWrap::IsRefed);
90+
env->SetProtoMethod(t, "unrefed", HandleWrap::Unrefed);
9191

9292
StreamWrap::AddMethods(env, t, StreamBase::kFlagHasWritev);
9393

src/timer_wrap.cc

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -39,7 +39,7 @@ class TimerWrap : public HandleWrap {
3939
env->SetProtoMethod(constructor, "close", HandleWrap::Close);
4040
env->SetProtoMethod(constructor, "ref", HandleWrap::Ref);
4141
env->SetProtoMethod(constructor, "unref", HandleWrap::Unref);
42-
env->SetProtoMethod(constructor, "isRefed", HandleWrap::IsRefed);
42+
env->SetProtoMethod(constructor, "unrefed", HandleWrap::Unrefed);
4343

4444
env->SetProtoMethod(constructor, "start", Start);
4545
env->SetProtoMethod(constructor, "stop", Stop);

src/tty_wrap.cc

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -36,7 +36,7 @@ void TTYWrap::Initialize(Local<Object> target,
3636

3737
env->SetProtoMethod(t, "close", HandleWrap::Close);
3838
env->SetProtoMethod(t, "unref", HandleWrap::Unref);
39-
env->SetProtoMethod(t, "isRefed", HandleWrap::IsRefed);
39+
env->SetProtoMethod(t, "unrefed", HandleWrap::Unrefed);
4040

4141
StreamWrap::AddMethods(env, t, StreamBase::kFlagNoShutdown);
4242

src/udp_wrap.cc

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -108,7 +108,7 @@ void UDPWrap::Initialize(Local<Object> target,
108108

109109
env->SetProtoMethod(t, "ref", HandleWrap::Ref);
110110
env->SetProtoMethod(t, "unref", HandleWrap::Unref);
111-
env->SetProtoMethod(t, "isRefed", HandleWrap::IsRefed);
111+
env->SetProtoMethod(t, "unrefed", HandleWrap::Unrefed);
112112

113113
target->Set(FIXED_ONE_BYTE_STRING(env->isolate(), "UDP"), t->GetFunction());
114114
env->set_udp_constructor_function(t->GetFunction());

test/parallel/test-handle-wrap-isrefed-tty.js

Lines changed: 6 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -9,16 +9,18 @@ function makeAssert(message) {
99
strictEqual(actual, expected, message);
1010
};
1111
}
12-
const assert = makeAssert('isRefed() not working on tty_wrap');
12+
const assert = makeAssert('unrefed() not working on tty_wrap');
1313

1414
if (process.argv[2] === 'child') {
1515
// Test tty_wrap in piped child to guarentee stdin being a TTY.
1616
const ReadStream = require('tty').ReadStream;
1717
const tty = new ReadStream(0);
18-
assert(Object.getPrototypeOf(tty._handle).hasOwnProperty('isRefed'), true);
19-
assert(tty._handle.isRefed(), true);
18+
assert(Object.getPrototypeOf(tty._handle).hasOwnProperty('unrefed'), true);
19+
assert(tty._handle.unrefed(), false);
2020
tty.unref();
21-
assert(tty._handle.isRefed(), false);
21+
assert(tty._handle.unrefed(), true);
22+
tty._handle.close();
23+
assert(tty._handle.unrefed(), true);
2224
return;
2325
}
2426

test/parallel/test-handle-wrap-isrefed.js

Lines changed: 40 additions & 34 deletions
Original file line numberDiff line numberDiff line change
@@ -12,86 +12,92 @@ function makeAssert(message) {
1212

1313
// child_process
1414
{
15-
const assert = makeAssert('isRefed() not working on process_wrap');
15+
const assert = makeAssert('unrefed() not working on process_wrap');
1616
const spawn = require('child_process').spawn;
1717
const cmd = common.isWindows ? 'rundll32' : 'ls';
1818
const cp = spawn(cmd);
19-
assert(Object.getPrototypeOf(cp._handle).hasOwnProperty('isRefed'), true);
20-
assert(cp._handle.isRefed(), true);
19+
assert(Object.getPrototypeOf(cp._handle).hasOwnProperty('unrefed'), true);
20+
assert(cp._handle.unrefed(), false);
2121
cp.unref();
22-
assert(cp._handle.isRefed(), false);
22+
assert(cp._handle.unrefed(), true);
2323
cp.ref();
24-
assert(cp._handle.isRefed(), true);
25-
cp.unref();
24+
assert(cp._handle.unrefed(), false);
25+
cp._handle.close();
26+
assert(cp._handle.unrefed(), false);
2627
}
2728

2829

2930
// dgram
3031
{
31-
const assert = makeAssert('isRefed() not working on udp_wrap');
32+
const assert = makeAssert('unrefed() not working on udp_wrap');
3233
const dgram = require('dgram');
3334

3435
const sock4 = dgram.createSocket('udp4');
35-
assert(Object.getPrototypeOf(sock4._handle).hasOwnProperty('isRefed'), true);
36-
assert(sock4._handle.isRefed(), true);
36+
assert(Object.getPrototypeOf(sock4._handle).hasOwnProperty('unrefed'), true);
37+
assert(sock4._handle.unrefed(), false);
3738
sock4.unref();
38-
assert(sock4._handle.isRefed(), false);
39+
assert(sock4._handle.unrefed(), true);
3940
sock4.ref();
40-
assert(sock4._handle.isRefed(), true);
41-
sock4.unref();
41+
assert(sock4._handle.unrefed(), false);
42+
sock4._handle.close();
43+
assert(sock4._handle.unrefed(), false);
4244

4345
const sock6 = dgram.createSocket('udp6');
44-
assert(Object.getPrototypeOf(sock6._handle).hasOwnProperty('isRefed'), true);
45-
assert(sock6._handle.isRefed(), true);
46+
assert(Object.getPrototypeOf(sock6._handle).hasOwnProperty('unrefed'), true);
47+
assert(sock6._handle.unrefed(), false);
4648
sock6.unref();
47-
assert(sock6._handle.isRefed(), false);
49+
assert(sock6._handle.unrefed(), true);
4850
sock6.ref();
49-
assert(sock6._handle.isRefed(), true);
50-
sock6.unref();
51+
assert(sock6._handle.unrefed(), false);
52+
sock6._handle.close();
53+
assert(sock6._handle.unrefed(), false);
5154
}
5255

5356

5457
// pipe
5558
{
56-
const assert = makeAssert('isRefed() not working on pipe_wrap');
59+
const assert = makeAssert('unrefed() not working on pipe_wrap');
5760
const Pipe = process.binding('pipe_wrap').Pipe;
5861
const handle = new Pipe();
59-
assert(Object.getPrototypeOf(handle).hasOwnProperty('isRefed'), true);
60-
assert(handle.isRefed(), true);
62+
assert(Object.getPrototypeOf(handle).hasOwnProperty('unrefed'), true);
63+
assert(handle.unrefed(), false);
6164
handle.unref();
62-
assert(handle.isRefed(), false);
65+
assert(handle.unrefed(), true);
6366
handle.ref();
64-
assert(handle.isRefed(), true);
65-
handle.unref();
67+
assert(handle.unrefed(), false);
68+
handle.close();
69+
assert(handle.unrefed(), false);
6670
}
6771

6872

6973
// tcp
7074
{
71-
const assert = makeAssert('isRefed() not working on tcp_wrap');
75+
const assert = makeAssert('unrefed() not working on tcp_wrap');
7276
const net = require('net');
7377
const server = net.createServer(() => {}).listen(common.PORT);
74-
assert(Object.getPrototypeOf(server._handle).hasOwnProperty('isRefed'), true);
75-
assert(server._handle.isRefed(), true);
78+
assert(Object.getPrototypeOf(server._handle).hasOwnProperty('unrefed'), true);
79+
assert(server._handle.unrefed(), false);
7680
assert(server._unref, false);
7781
server.unref();
78-
assert(server._handle.isRefed(), false);
82+
assert(server._handle.unrefed(), true);
7983
assert(server._unref, true);
8084
server.ref();
81-
assert(server._handle.isRefed(), true);
85+
assert(server._handle.unrefed(), false);
8286
assert(server._unref, false);
83-
server.unref();
87+
server._handle.close();
88+
assert(server._handle.unrefed(), false);
8489
}
8590

8691

8792
// timers
8893
{
89-
const assert = makeAssert('isRefed() not working on timer_wrap');
94+
const assert = makeAssert('unrefed() not working on timer_wrap');
9095
const timer = setTimeout(() => {}, 500);
9196
timer.unref();
92-
assert(Object.getPrototypeOf(timer._handle).hasOwnProperty('isRefed'), true);
93-
assert(timer._handle.isRefed(), false);
97+
assert(Object.getPrototypeOf(timer._handle).hasOwnProperty('unrefed'), true);
98+
assert(timer._handle.unrefed(), true);
9499
timer.ref();
95-
assert(timer._handle.isRefed(), true);
96-
timer.unref();
100+
assert(timer._handle.unrefed(), false);
101+
timer.close();
102+
assert(timer._handle.unrefed(), false);
97103
}

0 commit comments

Comments
 (0)