- 
          
- 
                Notifications
    You must be signed in to change notification settings 
- Fork 33.6k
src: migrate to new V8 array API #24613
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
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