mirror of https://github.com/nodejs/node.git
tools: update inspector_protocol to 83b1154
PR-URL: https://github.com/nodejs/node/pull/51309 Reviewed-By: Stephen Belanger <admin@stephenbelanger.com>
This commit is contained in:
parent
d0e455044e
commit
d102d16e98
|
@ -39,7 +39,6 @@
|
||||||
],
|
],
|
||||||
'node_protocol_files': [
|
'node_protocol_files': [
|
||||||
'<(protocol_tool_path)/lib/Allocator_h.template',
|
'<(protocol_tool_path)/lib/Allocator_h.template',
|
||||||
'<(protocol_tool_path)/lib/Array_h.template',
|
|
||||||
'<(protocol_tool_path)/lib/base_string_adapter_cc.template',
|
'<(protocol_tool_path)/lib/base_string_adapter_cc.template',
|
||||||
'<(protocol_tool_path)/lib/base_string_adapter_h.template',
|
'<(protocol_tool_path)/lib/base_string_adapter_h.template',
|
||||||
'<(protocol_tool_path)/lib/DispatcherBase_cpp.template',
|
'<(protocol_tool_path)/lib/DispatcherBase_cpp.template',
|
||||||
|
|
|
@ -147,8 +147,8 @@ DispatchResponse TracingAgent::start(
|
||||||
std::set<std::string> categories_set;
|
std::set<std::string> categories_set;
|
||||||
protocol::Array<std::string>* categories =
|
protocol::Array<std::string>* categories =
|
||||||
traceConfig->getIncludedCategories();
|
traceConfig->getIncludedCategories();
|
||||||
for (size_t i = 0; i < categories->length(); i++)
|
for (size_t i = 0; i < categories->size(); i++)
|
||||||
categories_set.insert(categories->get(i));
|
categories_set.insert((*categories)[i]);
|
||||||
|
|
||||||
if (categories_set.empty())
|
if (categories_set.empty())
|
||||||
return DispatchResponse::Error("At least one category should be enabled");
|
return DispatchResponse::Error("At least one category should be enabled");
|
||||||
|
@ -172,29 +172,29 @@ DispatchResponse TracingAgent::stop() {
|
||||||
|
|
||||||
DispatchResponse TracingAgent::getCategories(
|
DispatchResponse TracingAgent::getCategories(
|
||||||
std::unique_ptr<protocol::Array<String>>* categories) {
|
std::unique_ptr<protocol::Array<String>>* categories) {
|
||||||
*categories = Array<String>::create();
|
*categories = std::make_unique<Array<String>>();
|
||||||
protocol::Array<String>* categories_list = categories->get();
|
protocol::Array<String>* categories_list = categories->get();
|
||||||
// In alphabetical order
|
// In alphabetical order
|
||||||
categories_list->addItem("node");
|
categories_list->emplace_back("node");
|
||||||
categories_list->addItem("node.async_hooks");
|
categories_list->emplace_back("node.async_hooks");
|
||||||
categories_list->addItem("node.bootstrap");
|
categories_list->emplace_back("node.bootstrap");
|
||||||
categories_list->addItem("node.console");
|
categories_list->emplace_back("node.console");
|
||||||
categories_list->addItem("node.dns.native");
|
categories_list->emplace_back("node.dns.native");
|
||||||
categories_list->addItem("node.environment");
|
categories_list->emplace_back("node.environment");
|
||||||
categories_list->addItem("node.fs.async");
|
categories_list->emplace_back("node.fs.async");
|
||||||
categories_list->addItem("node.fs.sync");
|
categories_list->emplace_back("node.fs.sync");
|
||||||
categories_list->addItem("node.fs_dir.async");
|
categories_list->emplace_back("node.fs_dir.async");
|
||||||
categories_list->addItem("node.fs_dir.sync");
|
categories_list->emplace_back("node.fs_dir.sync");
|
||||||
categories_list->addItem("node.http");
|
categories_list->emplace_back("node.http");
|
||||||
categories_list->addItem("node.net.native");
|
categories_list->emplace_back("node.net.native");
|
||||||
categories_list->addItem("node.perf");
|
categories_list->emplace_back("node.perf");
|
||||||
categories_list->addItem("node.perf.timerify");
|
categories_list->emplace_back("node.perf.timerify");
|
||||||
categories_list->addItem("node.perf.usertiming");
|
categories_list->emplace_back("node.perf.usertiming");
|
||||||
categories_list->addItem("node.promises.rejections");
|
categories_list->emplace_back("node.promises.rejections");
|
||||||
categories_list->addItem("node.threadpoolwork.async");
|
categories_list->emplace_back("node.threadpoolwork.async");
|
||||||
categories_list->addItem("node.threadpoolwork.sync");
|
categories_list->emplace_back("node.threadpoolwork.sync");
|
||||||
categories_list->addItem("node.vm.script");
|
categories_list->emplace_back("node.vm.script");
|
||||||
categories_list->addItem("v8");
|
categories_list->emplace_back("v8");
|
||||||
return DispatchResponse::OK();
|
return DispatchResponse::OK();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -638,7 +638,6 @@ def main():
|
||||||
"Object_h.template",
|
"Object_h.template",
|
||||||
"ValueConversions_h.template",
|
"ValueConversions_h.template",
|
||||||
"Maybe_h.template",
|
"Maybe_h.template",
|
||||||
"Array_h.template",
|
|
||||||
"DispatcherBase_h.template",
|
"DispatcherBase_h.template",
|
||||||
"Parser_h.template",
|
"Parser_h.template",
|
||||||
"encoding_h.template",
|
"encoding_h.template",
|
||||||
|
|
|
@ -36,7 +36,6 @@ template("inspector_protocol_generate") {
|
||||||
"$inspector_protocol_dir/lib/encoding_h.template",
|
"$inspector_protocol_dir/lib/encoding_h.template",
|
||||||
"$inspector_protocol_dir/lib/encoding_cpp.template",
|
"$inspector_protocol_dir/lib/encoding_cpp.template",
|
||||||
"$inspector_protocol_dir/lib/Allocator_h.template",
|
"$inspector_protocol_dir/lib/Allocator_h.template",
|
||||||
"$inspector_protocol_dir/lib/Array_h.template",
|
|
||||||
"$inspector_protocol_dir/lib/DispatcherBase_cpp.template",
|
"$inspector_protocol_dir/lib/DispatcherBase_cpp.template",
|
||||||
"$inspector_protocol_dir/lib/DispatcherBase_h.template",
|
"$inspector_protocol_dir/lib/DispatcherBase_h.template",
|
||||||
"$inspector_protocol_dir/lib/ErrorSupport_cpp.template",
|
"$inspector_protocol_dir/lib/ErrorSupport_cpp.template",
|
||||||
|
|
|
@ -8,7 +8,6 @@
|
||||||
'lib/encoding_h.template',
|
'lib/encoding_h.template',
|
||||||
'lib/encoding_cpp.template',
|
'lib/encoding_cpp.template',
|
||||||
'lib/Allocator_h.template',
|
'lib/Allocator_h.template',
|
||||||
'lib/Array_h.template',
|
|
||||||
'lib/DispatcherBase_cpp.template',
|
'lib/DispatcherBase_cpp.template',
|
||||||
'lib/DispatcherBase_h.template',
|
'lib/DispatcherBase_h.template',
|
||||||
'lib/ErrorSupport_cpp.template',
|
'lib/ErrorSupport_cpp.template',
|
||||||
|
|
|
@ -1,138 +0,0 @@
|
||||||
// This file is generated by Array_h.template.
|
|
||||||
|
|
||||||
// Copyright 2016 The Chromium Authors. All rights reserved.
|
|
||||||
// Use of this source code is governed by a BSD-style license that can be
|
|
||||||
// found in the LICENSE file.
|
|
||||||
|
|
||||||
#ifndef {{"_".join(config.protocol.namespace)}}_Array_h
|
|
||||||
#define {{"_".join(config.protocol.namespace)}}_Array_h
|
|
||||||
|
|
||||||
//#include "ErrorSupport.h"
|
|
||||||
//#include "Forward.h"
|
|
||||||
//#include "ValueConversions.h"
|
|
||||||
//#include "Values.h"
|
|
||||||
|
|
||||||
{% for namespace in config.protocol.namespace %}
|
|
||||||
namespace {{namespace}} {
|
|
||||||
{% endfor %}
|
|
||||||
|
|
||||||
template<typename T>
|
|
||||||
class Array {
|
|
||||||
public:
|
|
||||||
static std::unique_ptr<Array<T>> create()
|
|
||||||
{
|
|
||||||
return std::unique_ptr<Array<T>>(new Array<T>());
|
|
||||||
}
|
|
||||||
|
|
||||||
static std::unique_ptr<Array<T>> fromValue(protocol::Value* value, ErrorSupport* errors)
|
|
||||||
{
|
|
||||||
protocol::ListValue* array = ListValue::cast(value);
|
|
||||||
if (!array) {
|
|
||||||
errors->addError("array expected");
|
|
||||||
return nullptr;
|
|
||||||
}
|
|
||||||
std::unique_ptr<Array<T>> result(new Array<T>());
|
|
||||||
errors->push();
|
|
||||||
for (size_t i = 0; i < array->size(); ++i) {
|
|
||||||
errors->setName(StringUtil::fromInteger(i));
|
|
||||||
std::unique_ptr<T> item = ValueConversions<T>::fromValue(array->at(i), errors);
|
|
||||||
result->m_vector.push_back(std::move(item));
|
|
||||||
}
|
|
||||||
errors->pop();
|
|
||||||
if (errors->hasErrors())
|
|
||||||
return nullptr;
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
void addItem(std::unique_ptr<T> value)
|
|
||||||
{
|
|
||||||
m_vector.push_back(std::move(value));
|
|
||||||
}
|
|
||||||
|
|
||||||
size_t length()
|
|
||||||
{
|
|
||||||
return m_vector.size();
|
|
||||||
}
|
|
||||||
|
|
||||||
T* get(size_t index)
|
|
||||||
{
|
|
||||||
return m_vector[index].get();
|
|
||||||
}
|
|
||||||
|
|
||||||
std::unique_ptr<protocol::ListValue> toValue()
|
|
||||||
{
|
|
||||||
std::unique_ptr<protocol::ListValue> result = ListValue::create();
|
|
||||||
for (auto& item : m_vector)
|
|
||||||
result->pushValue(ValueConversions<T>::toValue(item));
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
std::vector<std::unique_ptr<T>> m_vector;
|
|
||||||
};
|
|
||||||
|
|
||||||
template<typename T>
|
|
||||||
class ArrayBase {
|
|
||||||
public:
|
|
||||||
static std::unique_ptr<Array<T>> create()
|
|
||||||
{
|
|
||||||
return std::unique_ptr<Array<T>>(new Array<T>());
|
|
||||||
}
|
|
||||||
|
|
||||||
static std::unique_ptr<Array<T>> fromValue(protocol::Value* value, ErrorSupport* errors)
|
|
||||||
{
|
|
||||||
protocol::ListValue* array = ListValue::cast(value);
|
|
||||||
if (!array) {
|
|
||||||
errors->addError("array expected");
|
|
||||||
return nullptr;
|
|
||||||
}
|
|
||||||
errors->push();
|
|
||||||
std::unique_ptr<Array<T>> result(new Array<T>());
|
|
||||||
for (size_t i = 0; i < array->size(); ++i) {
|
|
||||||
errors->setName(StringUtil::fromInteger(i));
|
|
||||||
T item = ValueConversions<T>::fromValue(array->at(i), errors);
|
|
||||||
result->m_vector.push_back(item);
|
|
||||||
}
|
|
||||||
errors->pop();
|
|
||||||
if (errors->hasErrors())
|
|
||||||
return nullptr;
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
void addItem(const T& value)
|
|
||||||
{
|
|
||||||
m_vector.push_back(value);
|
|
||||||
}
|
|
||||||
|
|
||||||
size_t length()
|
|
||||||
{
|
|
||||||
return m_vector.size();
|
|
||||||
}
|
|
||||||
|
|
||||||
T get(size_t index)
|
|
||||||
{
|
|
||||||
return m_vector[index];
|
|
||||||
}
|
|
||||||
|
|
||||||
std::unique_ptr<protocol::ListValue> toValue()
|
|
||||||
{
|
|
||||||
std::unique_ptr<protocol::ListValue> result = ListValue::create();
|
|
||||||
for (auto& item : m_vector)
|
|
||||||
result->pushValue(ValueConversions<T>::toValue(item));
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
std::vector<T> m_vector;
|
|
||||||
};
|
|
||||||
|
|
||||||
template<> class Array<String> : public ArrayBase<String> {};
|
|
||||||
template<> class Array<int> : public ArrayBase<int> {};
|
|
||||||
template<> class Array<double> : public ArrayBase<double> {};
|
|
||||||
template<> class Array<bool> : public ArrayBase<bool> {};
|
|
||||||
|
|
||||||
{% for namespace in config.protocol.namespace %}
|
|
||||||
} // namespace {{namespace}}
|
|
||||||
{% endfor %}
|
|
||||||
|
|
||||||
#endif // !defined({{"_".join(config.protocol.namespace)}}_Array_h)
|
|
|
@ -22,7 +22,6 @@
|
||||||
namespace {{namespace}} {
|
namespace {{namespace}} {
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
|
|
||||||
template<typename T> class Array;
|
|
||||||
class DictionaryValue;
|
class DictionaryValue;
|
||||||
class DispatchResponse;
|
class DispatchResponse;
|
||||||
class ErrorSupport;
|
class ErrorSupport;
|
||||||
|
@ -35,6 +34,26 @@ class StringValue;
|
||||||
class UberDispatcher;
|
class UberDispatcher;
|
||||||
class Value;
|
class Value;
|
||||||
|
|
||||||
|
namespace detail {
|
||||||
|
template <typename T>
|
||||||
|
struct ArrayTypedef { typedef std::vector<std::unique_ptr<T>> type; };
|
||||||
|
|
||||||
|
template <>
|
||||||
|
struct ArrayTypedef<String> { typedef std::vector<String> type; };
|
||||||
|
|
||||||
|
template <>
|
||||||
|
struct ArrayTypedef<int> { typedef std::vector<int> type; };
|
||||||
|
|
||||||
|
template <>
|
||||||
|
struct ArrayTypedef<double> { typedef std::vector<double> type; };
|
||||||
|
|
||||||
|
template <>
|
||||||
|
struct ArrayTypedef<bool> { typedef std::vector<bool> type; };
|
||||||
|
} // namespace detail
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
using Array = typename detail::ArrayTypedef<T>::type;
|
||||||
|
|
||||||
{% for namespace in config.protocol.namespace %}
|
{% for namespace in config.protocol.namespace %}
|
||||||
} // namespace {{namespace}}
|
} // namespace {{namespace}}
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
|
|
|
@ -128,6 +128,72 @@ struct ValueConversions<Binary> {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
template<typename T>
|
||||||
|
struct ValueConversions<std::vector<std::unique_ptr<T>>> {
|
||||||
|
static std::unique_ptr<std::vector<std::unique_ptr<T>>> fromValue(protocol::Value* value, ErrorSupport* errors) {
|
||||||
|
protocol::ListValue* array = ListValue::cast(value);
|
||||||
|
if (!array) {
|
||||||
|
errors->addError("array expected");
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
errors->push();
|
||||||
|
std::unique_ptr<std::vector<std::unique_ptr<T>>> result(
|
||||||
|
new std::vector<std::unique_ptr<T>>());
|
||||||
|
result->reserve(array->size());
|
||||||
|
for (size_t i = 0; i < array->size(); ++i) {
|
||||||
|
errors->setName(StringUtil::fromInteger(i));
|
||||||
|
auto item = ValueConversions<T>::fromValue(array->at(i), errors);
|
||||||
|
result->emplace_back(std::move(item));
|
||||||
|
}
|
||||||
|
errors->pop();
|
||||||
|
if (errors->hasErrors())
|
||||||
|
return nullptr;
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
static std::unique_ptr<protocol::ListValue> toValue(std::vector<std::unique_ptr<T>>* v)
|
||||||
|
{
|
||||||
|
std::unique_ptr<protocol::ListValue> result = ListValue::create();
|
||||||
|
result->reserve(v->size());
|
||||||
|
for (auto& item : *v)
|
||||||
|
result->pushValue(ValueConversions<T>::toValue(item.get()));
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
template<typename T>
|
||||||
|
struct ValueConversions<std::vector<T>> {
|
||||||
|
static std::unique_ptr<std::vector<T>> fromValue(protocol::Value* value, ErrorSupport* errors) {
|
||||||
|
protocol::ListValue* array = ListValue::cast(value);
|
||||||
|
if (!array) {
|
||||||
|
errors->addError("array expected");
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
errors->push();
|
||||||
|
std::unique_ptr<std::vector<T>> result(new std::vector<T>());
|
||||||
|
result->reserve(array->size());
|
||||||
|
for (size_t i = 0; i < array->size(); ++i) {
|
||||||
|
errors->setName(StringUtil::fromInteger(i));
|
||||||
|
auto item = ValueConversions<T>::fromValue(array->at(i), errors);
|
||||||
|
result->emplace_back(std::move(item));
|
||||||
|
}
|
||||||
|
errors->pop();
|
||||||
|
if (errors->hasErrors())
|
||||||
|
return nullptr;
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
static std::unique_ptr<protocol::ListValue> toValue(std::vector<T>* v)
|
||||||
|
{
|
||||||
|
std::unique_ptr<protocol::ListValue> result = ListValue::create();
|
||||||
|
result->reserve(v->size());
|
||||||
|
for (auto& item : *v)
|
||||||
|
result->pushValue(ValueConversions<T>::toValue(item));
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
template<>
|
template<>
|
||||||
struct ValueConversions<Value> {
|
struct ValueConversions<Value> {
|
||||||
static std::unique_ptr<Value> fromValue(protocol::Value* value, ErrorSupport* errors)
|
static std::unique_ptr<Value> fromValue(protocol::Value* value, ErrorSupport* errors)
|
||||||
|
|
|
@ -271,6 +271,7 @@ public:
|
||||||
|
|
||||||
Value* at(size_t index);
|
Value* at(size_t index);
|
||||||
size_t size() const { return m_data.size(); }
|
size_t size() const { return m_data.size(); }
|
||||||
|
void reserve(size_t capacity) { m_data.reserve(capacity); }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
ListValue();
|
ListValue();
|
||||||
|
|
Loading…
Reference in New Issue