From 972d0beb591859a1a0df59a3d1818493a6132bf5 Mon Sep 17 00:00:00 2001 From: Daniel Bevenius Date: Mon, 8 Oct 2018 08:38:02 +0200 Subject: [PATCH] http2: make Http2Settings constructors delegate This commit extracts the common code in the existing Http2Settings constructors into a private constructor, allowing the existing ones to delegate to the private constructor it and avoid code duplication. PR-URL: https://github.com/nodejs/node/pull/23326 Reviewed-By: James M Snell Reviewed-By: Sakthipriyan Vairamani --- src/node_http2.cc | 27 +++++++++++---------------- src/node_http2.h | 1 + 2 files changed, 12 insertions(+), 16 deletions(-) diff --git a/src/node_http2.cc b/src/node_http2.cc index 2c339d7249562e..633d2389c7cf35 100644 --- a/src/node_http2.cc +++ b/src/node_http2.cc @@ -226,32 +226,27 @@ void Http2Session::Http2Settings::Init() { count_ = n; } -Http2Session::Http2Settings::Http2Settings( - Environment* env) +Http2Session::Http2Settings::Http2Settings(Environment* env, + Http2Session* session, uint64_t start_time) : AsyncWrap(env, env->http2settings_constructor_template() ->NewInstance(env->context()) .ToLocalChecked(), - AsyncWrap::PROVIDER_HTTP2SETTINGS), - session_(nullptr), - startTime_(0) { + PROVIDER_HTTP2SETTINGS), + session_(session), + startTime_(start_time) { Init(); } + +Http2Session::Http2Settings::Http2Settings(Environment* env) + : Http2Settings(env, nullptr, 0) {} + // The Http2Settings class is used to configure a SETTINGS frame that is // to be sent to the connected peer. The settings are set using a TypedArray // that is shared with the JavaScript side. -Http2Session::Http2Settings::Http2Settings( - Http2Session* session) - : AsyncWrap(session->env(), - session->env()->http2settings_constructor_template() - ->NewInstance(session->env()->context()) - .ToLocalChecked(), - AsyncWrap::PROVIDER_HTTP2SETTINGS), - session_(session), - startTime_(uv_hrtime()) { - Init(); -} +Http2Session::Http2Settings::Http2Settings(Http2Session* session) + : Http2Settings(session->env(), session, uv_hrtime()) {} // Generates a Buffer that contains the serialized payload of a SETTINGS // frame. This can be used, for instance, to create the Base64-encoded diff --git a/src/node_http2.h b/src/node_http2.h index 8ecca63aeb0c0e..4dc33d84c2af61 100644 --- a/src/node_http2.h +++ b/src/node_http2.h @@ -1136,6 +1136,7 @@ class Http2Session::Http2Settings : public AsyncWrap { get_setting fn); private: + Http2Settings(Environment* env, Http2Session* session, uint64_t start_time); void Init(); Http2Session* session_; uint64_t startTime_;