-
Notifications
You must be signed in to change notification settings - Fork 30.2k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
src: migrate to new V8 array API #24613
Conversation
This change migrates the deprecated V8 Array API to new APIs.
src/node_util.cc
Outdated
|
||
int state = promise->State(); | ||
ret->Set(env->context(), 0, Integer::New(isolate, state)).FromJust(); | ||
std::vector<Local<Value>> values; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
values(2)
, as we can have a maximum of two values.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Then way not simply:
std::vector<Local<Value>> values; | |
Local<Value> values[2] = { Integer::New(isolate, state) }; | |
size_t number_of_values = 1; | |
if (state != Promise::PromiseState::kPending) | |
values[number_of_values++] = promise->Result(); | |
DCHECK_LE(number_of_values, arraysize(values)); | |
Local<Array> ret = Array::New(isolate, values, number_of_values); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
That’s much longer and doesn’t really provide too much of an advantage over using a vector.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
AFAICT it's only one line longer, and we get everything on the stack with no free-store allocations.
I thought that when possible, we prefer static sized data structures?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I tried @refack's suggestion, but I couldn't find a reasonable way to include DCHECK_LE in this file. DCHECK_LE is defined in deps/v8/src/base/logging.h
, and when I add #include "../deps/v8/src/base/logging.h"
at the top, the compile doesn't seem passing (relative path inside logging.h doesn't seem resolving...)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I followed @TimothyGu's comment for the moment.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
With values(2)
, the values are initialized with empty values and it has size 2. So I needed to add an else
block and .pop_back()
the last (empty) value. (I think that's unnecessarily complex and not desirable code.)
So I changed the code to follow @refack's comment (without DCHECK_LE assertion).
This addresses the comment in nodejs#24613
fe987df
to
0098eb2
Compare
Use static sized data structure
0098eb2
to
3729328
Compare
(I force-pushed with empty change a few times to fix CI status but it keeps failing because of the rate limit of github API, which is used for fetching the commit message.) |
Landed in 27139fc |
This change migrates the deprecated V8 Array API to new APIs. PR-URL: nodejs#24613 Reviewed-By: Anna Henningsen <[email protected]> Reviewed-By: Joyee Cheung <[email protected]> Reviewed-By: Colin Ihrig <[email protected]> Reviewed-By: Gireesh Punathil <[email protected]> Reviewed-By: Gus Caplan <[email protected]> Reviewed-By: Tiancheng "Timothy" Gu <[email protected]>
Thank you for the reviews! Thank you for landing! |
This change migrates the deprecated V8 Array API to new APIs. PR-URL: #24613 Reviewed-By: Anna Henningsen <[email protected]> Reviewed-By: Joyee Cheung <[email protected]> Reviewed-By: Colin Ihrig <[email protected]> Reviewed-By: Gireesh Punathil <[email protected]> Reviewed-By: Gus Caplan <[email protected]> Reviewed-By: Tiancheng "Timothy" Gu <[email protected]>
This change migrates the deprecated V8 Array API to new APIs. PR-URL: nodejs#24613 Reviewed-By: Anna Henningsen <[email protected]> Reviewed-By: Joyee Cheung <[email protected]> Reviewed-By: Colin Ihrig <[email protected]> Reviewed-By: Gireesh Punathil <[email protected]> Reviewed-By: Gus Caplan <[email protected]> Reviewed-By: Tiancheng "Timothy" Gu <[email protected]>
This PR uses new V8 API for array creation, instead of old one.
related PR: #24125
Checklist
make -j4 test
(UNIX), orvcbuild test
(Windows) passes