Skip to content

Commit

Permalink
n-api: add fast paths for integer getters
Browse files Browse the repository at this point in the history
Ref: #14379
PR-URL: #14393
Reviewed-By: Ben Noordhuis <[email protected]>
Reviewed-By: James M Snell <[email protected]>
Reviewed-By: Timothy Gu <[email protected]>
Reviewed-By: Colin Ihrig <[email protected]>
Reviewed-By: Jason Ginchereau <[email protected]>
  • Loading branch information
addaleax committed Jul 24, 2017
1 parent 28f0693 commit fa134dd
Showing 1 changed file with 19 additions and 0 deletions.
19 changes: 19 additions & 0 deletions src/node_api.cc
Original file line number Diff line number Diff line change
Expand Up @@ -1822,6 +1822,12 @@ napi_status napi_get_value_int32(napi_env env,
CHECK_ARG(env, result);

v8::Local<v8::Value> val = v8impl::V8LocalValueFromJsValue(value);

if (val->IsInt32()) {
*result = val.As<v8::Int32>()->Value();
return napi_clear_last_error(env);
}

RETURN_STATUS_IF_FALSE(env, val->IsNumber(), napi_number_expected);

v8::Isolate* isolate = env->isolate;
Expand All @@ -1841,6 +1847,12 @@ napi_status napi_get_value_uint32(napi_env env,
CHECK_ARG(env, result);

v8::Local<v8::Value> val = v8impl::V8LocalValueFromJsValue(value);

if (val->IsUint32()) {
*result = val.As<v8::Uint32>()->Value();
return napi_clear_last_error(env);
}

RETURN_STATUS_IF_FALSE(env, val->IsNumber(), napi_number_expected);

v8::Isolate* isolate = env->isolate;
Expand All @@ -1860,6 +1872,13 @@ napi_status napi_get_value_int64(napi_env env,
CHECK_ARG(env, result);

v8::Local<v8::Value> val = v8impl::V8LocalValueFromJsValue(value);

// This is still a fast path very likely to be taken.
if (val->IsInt32()) {
*result = val.As<v8::Int32>()->Value();
return napi_clear_last_error(env);
}

RETURN_STATUS_IF_FALSE(env, val->IsNumber(), napi_number_expected);

// v8::Value::IntegerValue() converts NaN to INT64_MIN, inconsistent with
Expand Down

0 comments on commit fa134dd

Please sign in to comment.