Roll third_party/inspector_protocol to 4ad35c45aca9834b67ec2cb152c816ea1b7ceb48

This roll includes:
  - [inspector_protocol] Introduce protocol::Serializable [1]

[1] https://codereview.chromium.org/2526603002

BUG=chromium:350797
R=dgozman@chromium.org

Review-Url: https://codereview.chromium.org/2523583005
Cr-Commit-Position: refs/heads/master@{#41197}
This commit is contained in:
kozyatinskiy 2016-11-22 16:45:30 -08:00 committed by Commit bot
parent 9d1d3878dd
commit eb3551d0a3
20 changed files with 300 additions and 128 deletions

View File

@ -248,9 +248,15 @@ class V8_EXPORT V8Inspector {
class V8_EXPORT Channel { class V8_EXPORT Channel {
public: public:
virtual ~Channel() {} virtual ~Channel() {}
virtual void sendProtocolResponse(int callId, virtual void sendProtocolResponse(int callId, const StringView& message) {}
const StringView& message) = 0; virtual void sendProtocolNotification(const StringView& message) {}
virtual void sendProtocolNotification(const StringView& message) = 0; virtual void sendResponse(int callId,
std::unique_ptr<StringBuffer> message) {
sendProtocolResponse(callId, message->string());
}
virtual void sendNotification(std::unique_ptr<StringBuffer> message) {
sendProtocolNotification(message->string());
}
virtual void flushProtocolNotifications() = 0; virtual void flushProtocolNotifications() = 0;
}; };
virtual std::unique_ptr<V8InspectorSession> connect( virtual std::unique_ptr<V8InspectorSession> connect(

View File

@ -150,7 +150,7 @@ Response InjectedScript::getProperties(
if (!response.isSuccess()) return response; if (!response.isSuccess()) return response;
protocol::ErrorSupport errors; protocol::ErrorSupport errors;
std::unique_ptr<Array<PropertyDescriptor>> result = std::unique_ptr<Array<PropertyDescriptor>> result =
Array<PropertyDescriptor>::parse(protocolValue.get(), &errors); Array<PropertyDescriptor>::fromValue(protocolValue.get(), &errors);
if (errors.hasErrors()) return Response::Error(errors.errors()); if (errors.hasErrors()) return Response::Error(errors.errors());
*properties = std::move(result); *properties = std::move(result);
return Response::OK(); return Response::OK();
@ -184,7 +184,7 @@ Response InjectedScript::wrapObject(
if (!response.isSuccess()) return response; if (!response.isSuccess()) return response;
*result = *result =
protocol::Runtime::RemoteObject::parse(protocolValue.get(), &errors); protocol::Runtime::RemoteObject::fromValue(protocolValue.get(), &errors);
if (!result->get()) return Response::Error(errors.errors()); if (!result->get()) return Response::Error(errors.errors());
return Response::OK(); return Response::OK();
} }
@ -260,7 +260,8 @@ std::unique_ptr<protocol::Runtime::RemoteObject> InjectedScript::wrapTable(
Response response = toProtocolValue(context, r, &protocolValue); Response response = toProtocolValue(context, r, &protocolValue);
if (!response.isSuccess()) return nullptr; if (!response.isSuccess()) return nullptr;
protocol::ErrorSupport errors; protocol::ErrorSupport errors;
return protocol::Runtime::RemoteObject::parse(protocolValue.get(), &errors); return protocol::Runtime::RemoteObject::fromValue(protocolValue.get(),
&errors);
} }
Response InjectedScript::findObject(const RemoteObjectId& objectId, Response InjectedScript::findObject(const RemoteObjectId& objectId,
@ -317,7 +318,7 @@ Response InjectedScript::resolveCallArgument(
if (callArgument->hasValue() || callArgument->hasUnserializableValue()) { if (callArgument->hasValue() || callArgument->hasUnserializableValue()) {
String16 value = String16 value =
callArgument->hasValue() callArgument->hasValue()
? callArgument->getValue(nullptr)->toJSONString() ? callArgument->getValue(nullptr)->serialize()
: "Number(\"" + callArgument->getUnserializableValue("") + "\")"; : "Number(\"" + callArgument->getUnserializableValue("") + "\")";
if (!m_context->inspector() if (!m_context->inspector()
->compileAndRunInternalScript( ->compileAndRunInternalScript(

View File

@ -1031,7 +1031,7 @@ Response V8DebuggerAgentImpl::currentCallFrames(
Response response = toProtocolValue(debuggerContext, objects, &protocolValue); Response response = toProtocolValue(debuggerContext, objects, &protocolValue);
if (!response.isSuccess()) return response; if (!response.isSuccess()) return response;
protocol::ErrorSupport errorSupport; protocol::ErrorSupport errorSupport;
*result = Array<CallFrame>::parse(protocolValue.get(), &errorSupport); *result = Array<CallFrame>::fromValue(protocolValue.get(), &errorSupport);
if (!*result) return Response::Error(errorSupport.errors()); if (!*result) return Response::Error(errorSupport.errors());
TranslateWasmStackTraceLocations(result->get(), m_debugger->wasmTranslation(), TranslateWasmStackTraceLocations(result->get(), m_debugger->wasmTranslation(),
m_session->contextGroupId()); m_session->contextGroupId());
@ -1164,7 +1164,7 @@ V8DebuggerAgentImpl::SkipPauseRequest V8DebuggerAgentImpl::didPause(
injectedScript->wrapObject(exception, kBacktraceObjectGroup, false, false, injectedScript->wrapObject(exception, kBacktraceObjectGroup, false, false,
&obj); &obj);
if (obj) { if (obj) {
m_breakAuxData = obj->serialize(); m_breakAuxData = obj->toValue();
m_breakAuxData->setBoolean("uncaught", isUncaught); m_breakAuxData->setBoolean("uncaught", isUncaught);
} else { } else {
m_breakAuxData = nullptr; m_breakAuxData = nullptr;

View File

@ -126,13 +126,42 @@ protocol::DictionaryValue* V8InspectorSessionImpl::agentState(
return state; return state;
} }
void V8InspectorSessionImpl::sendProtocolResponse(int callId, namespace {
const String16& message) {
m_channel->sendProtocolResponse(callId, toStringView(message)); class MessageBuffer : public StringBuffer {
public:
static std::unique_ptr<MessageBuffer> create(
std::unique_ptr<protocol::Serializable> message) {
return std::unique_ptr<MessageBuffer>(
new MessageBuffer(std::move(message)));
}
const StringView& string() override {
if (!m_serialized) {
m_serialized = StringBuffer::create(toStringView(m_message->serialize()));
m_message.reset(nullptr);
}
return m_serialized->string();
}
private:
explicit MessageBuffer(std::unique_ptr<protocol::Serializable> message)
: m_message(std::move(message)) {}
std::unique_ptr<protocol::Serializable> m_message;
std::unique_ptr<StringBuffer> m_serialized;
};
} // namespace
void V8InspectorSessionImpl::sendProtocolResponse(
int callId, std::unique_ptr<protocol::Serializable> message) {
m_channel->sendResponse(callId, MessageBuffer::create(std::move(message)));
} }
void V8InspectorSessionImpl::sendProtocolNotification(const String16& message) { void V8InspectorSessionImpl::sendProtocolNotification(
m_channel->sendProtocolNotification(toStringView(message)); std::unique_ptr<protocol::Serializable> message) {
m_channel->sendNotification(MessageBuffer::create(std::move(message)));
} }
void V8InspectorSessionImpl::flushProtocolNotifications() { void V8InspectorSessionImpl::flushProtocolNotifications() {
@ -309,7 +338,7 @@ void V8InspectorSessionImpl::dispatchProtocolMessage(
} }
std::unique_ptr<StringBuffer> V8InspectorSessionImpl::stateJSON() { std::unique_ptr<StringBuffer> V8InspectorSessionImpl::stateJSON() {
String16 json = m_state->toJSONString(); String16 json = m_state->serialize();
return StringBufferImpl::adopt(json); return StringBufferImpl::adopt(json);
} }

View File

@ -96,8 +96,10 @@ class V8InspectorSessionImpl : public V8InspectorSession,
protocol::DictionaryValue* agentState(const String16& name); protocol::DictionaryValue* agentState(const String16& name);
// protocol::FrontendChannel implementation. // protocol::FrontendChannel implementation.
void sendProtocolResponse(int callId, const String16& message) override; void sendProtocolResponse(
void sendProtocolNotification(const String16& message) override; int callId, std::unique_ptr<protocol::Serializable> message) override;
void sendProtocolNotification(
std::unique_ptr<protocol::Serializable> message) override;
void flushProtocolNotifications() override; void flushProtocolNotifications() override;
int m_contextGroupId; int m_contextGroupId;

View File

@ -8,6 +8,7 @@ import optparse
import collections import collections
import functools import functools
import re import re
import copy
try: try:
import json import json
except ImportError: except ImportError:
@ -469,6 +470,20 @@ def main():
protocol.imported_domains = read_protocol_file(config.imported.path, protocol.json_api) if config.imported else [] protocol.imported_domains = read_protocol_file(config.imported.path, protocol.json_api) if config.imported else []
patch_full_qualified_refs(protocol) patch_full_qualified_refs(protocol)
calculate_imports_and_exports(config, protocol) calculate_imports_and_exports(config, protocol)
for domain in protocol.json_api["domains"]:
if "events" in domain:
for event in domain["events"]:
event_type = dict()
event_type["description"] = "Wrapper for notification params"
event_type["type"] = "object"
event_type["id"] = to_title_case(event["name"]) + "Notification"
if "parameters" in event:
event_type["properties"] = copy.deepcopy(event["parameters"])
if "types" not in domain:
domain["types"] = list()
domain["types"].append(event_type)
create_type_definitions(protocol, "::".join(config.imported.namespace) if config.imported else "") create_type_definitions(protocol, "::".join(config.imported.namespace) if config.imported else "")
if not config.exported and len(protocol.exported_domains): if not config.exported and len(protocol.exported_domains):

View File

@ -2,7 +2,7 @@ Name: inspector protocol
Short Name: inspector_protocol Short Name: inspector_protocol
URL: https://chromium.googlesource.com/deps/inspector_protocol/ URL: https://chromium.googlesource.com/deps/inspector_protocol/
Version: 0 Version: 0
Revision: ef8aa4e19e53a105843cd469e8122d098d902b47 Revision: 4ad35c45aca9834b67ec2cb152c816ea1b7ceb48
License: BSD License: BSD
License File: LICENSE License File: LICENSE
Security Critical: no Security Critical: no

View File

@ -22,7 +22,7 @@ public:
return std::unique_ptr<Array<T>>(new Array<T>()); return std::unique_ptr<Array<T>>(new Array<T>());
} }
static std::unique_ptr<Array<T>> parse(protocol::Value* value, ErrorSupport* errors) static std::unique_ptr<Array<T>> fromValue(protocol::Value* value, ErrorSupport* errors)
{ {
protocol::ListValue* array = ListValue::cast(value); protocol::ListValue* array = ListValue::cast(value);
if (!array) { if (!array) {
@ -33,7 +33,7 @@ public:
errors->push(); errors->push();
for (size_t i = 0; i < array->size(); ++i) { for (size_t i = 0; i < array->size(); ++i) {
errors->setName(StringUtil::fromInteger(i)); errors->setName(StringUtil::fromInteger(i));
std::unique_ptr<T> item = ValueConversions<T>::parse(array->at(i), errors); std::unique_ptr<T> item = ValueConversions<T>::fromValue(array->at(i), errors);
result->m_vector.push_back(std::move(item)); result->m_vector.push_back(std::move(item));
} }
errors->pop(); errors->pop();
@ -57,11 +57,11 @@ public:
return m_vector[index].get(); return m_vector[index].get();
} }
std::unique_ptr<protocol::ListValue> serialize() std::unique_ptr<protocol::ListValue> toValue()
{ {
std::unique_ptr<protocol::ListValue> result = ListValue::create(); std::unique_ptr<protocol::ListValue> result = ListValue::create();
for (auto& item : m_vector) for (auto& item : m_vector)
result->pushValue(ValueConversions<T>::serialize(item)); result->pushValue(ValueConversions<T>::toValue(item));
return result; return result;
} }
@ -77,7 +77,7 @@ public:
return std::unique_ptr<Array<T>>(new Array<T>()); return std::unique_ptr<Array<T>>(new Array<T>());
} }
static std::unique_ptr<Array<T>> parse(protocol::Value* value, ErrorSupport* errors) static std::unique_ptr<Array<T>> fromValue(protocol::Value* value, ErrorSupport* errors)
{ {
protocol::ListValue* array = ListValue::cast(value); protocol::ListValue* array = ListValue::cast(value);
if (!array) { if (!array) {
@ -88,7 +88,7 @@ public:
std::unique_ptr<Array<T>> result(new Array<T>()); std::unique_ptr<Array<T>> result(new Array<T>());
for (size_t i = 0; i < array->size(); ++i) { for (size_t i = 0; i < array->size(); ++i) {
errors->setName(StringUtil::fromInteger(i)); errors->setName(StringUtil::fromInteger(i));
T item = ValueConversions<T>::parse(array->at(i), errors); T item = ValueConversions<T>::fromValue(array->at(i), errors);
result->m_vector.push_back(item); result->m_vector.push_back(item);
} }
errors->pop(); errors->pop();
@ -112,11 +112,11 @@ public:
return m_vector[index]; return m_vector[index];
} }
std::unique_ptr<protocol::ListValue> serialize() std::unique_ptr<protocol::ListValue> toValue()
{ {
std::unique_ptr<protocol::ListValue> result = ListValue::create(); std::unique_ptr<protocol::ListValue> result = ListValue::create();
for (auto& item : m_vector) for (auto& item : m_vector)
result->pushValue(ValueConversions<T>::serialize(item)); result->pushValue(ValueConversions<T>::toValue(item));
return result; return result;
} }

View File

@ -137,16 +137,13 @@ bool DispatcherBase::getCommandName(const String& message, String* result)
void DispatcherBase::sendResponse(int callId, const DispatchResponse& response, std::unique_ptr<protocol::DictionaryValue> result) void DispatcherBase::sendResponse(int callId, const DispatchResponse& response, std::unique_ptr<protocol::DictionaryValue> result)
{ {
if (!m_frontendChannel)
return;
if (response.status() == DispatchResponse::kError) { if (response.status() == DispatchResponse::kError) {
reportProtocolError(callId, response.errorCode(), response.errorMessage(), nullptr); reportProtocolError(callId, response.errorCode(), response.errorMessage(), nullptr);
return; return;
} }
m_frontendChannel->sendProtocolResponse(callId, InternalResponse::createResponse(callId, std::move(result)));
std::unique_ptr<protocol::DictionaryValue> responseMessage = DictionaryValue::create();
responseMessage->setInteger("id", callId);
responseMessage->setObject("result", std::move(result));
if (m_frontendChannel)
m_frontendChannel->sendProtocolResponse(callId, responseMessage->toJSONString());
} }
void DispatcherBase::sendResponse(int callId, const DispatchResponse& response) void DispatcherBase::sendResponse(int callId, const DispatchResponse& response)
@ -154,31 +151,67 @@ void DispatcherBase::sendResponse(int callId, const DispatchResponse& response)
sendResponse(callId, response, DictionaryValue::create()); sendResponse(callId, response, DictionaryValue::create());
} }
namespace {
class ProtocolError : public Serializable {
public:
static std::unique_ptr<ProtocolError> createErrorResponse(int callId, DispatchResponse::ErrorCode code, const String& errorMessage, ErrorSupport* errors)
{
std::unique_ptr<ProtocolError> protocolError(new ProtocolError(code, errorMessage));
protocolError->m_callId = callId;
protocolError->m_hasCallId = true;
if (errors && errors->hasErrors())
protocolError->m_data = errors->errors();
return protocolError;
}
static std::unique_ptr<ProtocolError> createErrorNotification(DispatchResponse::ErrorCode code, const String& errorMessage)
{
return std::unique_ptr<ProtocolError>(new ProtocolError(code, errorMessage));
}
String serialize() override
{
std::unique_ptr<protocol::DictionaryValue> error = DictionaryValue::create();
error->setInteger("code", m_code);
error->setString("message", m_errorMessage);
if (m_data.length())
error->setString("data", m_data);
std::unique_ptr<protocol::DictionaryValue> message = DictionaryValue::create();
message->setObject("error", std::move(error));
if (m_hasCallId)
message->setInteger("id", m_callId);
return message->serialize();
}
~ProtocolError() override {}
private:
ProtocolError(DispatchResponse::ErrorCode code, const String& errorMessage)
: m_code(code)
, m_errorMessage(errorMessage)
{
}
DispatchResponse::ErrorCode m_code;
String m_errorMessage;
String m_data;
int m_callId = 0;
bool m_hasCallId = false;
};
} // namespace
static void reportProtocolErrorTo(FrontendChannel* frontendChannel, int callId, DispatchResponse::ErrorCode code, const String& errorMessage, ErrorSupport* errors) static void reportProtocolErrorTo(FrontendChannel* frontendChannel, int callId, DispatchResponse::ErrorCode code, const String& errorMessage, ErrorSupport* errors)
{ {
if (!frontendChannel) if (frontendChannel)
return; frontendChannel->sendProtocolResponse(callId, ProtocolError::createErrorResponse(callId, code, errorMessage, errors));
std::unique_ptr<protocol::DictionaryValue> error = DictionaryValue::create();
error->setInteger("code", code);
error->setString("message", errorMessage);
if (errors && errors->hasErrors())
error->setString("data", errors->errors());
std::unique_ptr<protocol::DictionaryValue> message = DictionaryValue::create();
message->setObject("error", std::move(error));
message->setInteger("id", callId);
frontendChannel->sendProtocolResponse(callId, message->toJSONString());
} }
static void reportProtocolErrorTo(FrontendChannel* frontendChannel, DispatchResponse::ErrorCode code, const String& errorMessage) static void reportProtocolErrorTo(FrontendChannel* frontendChannel, DispatchResponse::ErrorCode code, const String& errorMessage)
{ {
if (!frontendChannel) if (frontendChannel)
return; frontendChannel->sendProtocolNotification(ProtocolError::createErrorNotification(code, errorMessage));
std::unique_ptr<protocol::DictionaryValue> error = DictionaryValue::create();
error->setInteger("code", code);
error->setString("message", errorMessage);
std::unique_ptr<protocol::DictionaryValue> message = DictionaryValue::create();
message->setObject("error", std::move(error));
frontendChannel->sendProtocolNotification(message->toJSONString());
} }
void DispatcherBase::reportProtocolError(int callId, DispatchResponse::ErrorCode code, const String& errorMessage, ErrorSupport* errors) void DispatcherBase::reportProtocolError(int callId, DispatchResponse::ErrorCode code, const String& errorMessage, ErrorSupport* errors)
@ -263,6 +296,39 @@ DispatchResponse::Status UberDispatcher::dispatch(std::unique_ptr<Value> parsedM
UberDispatcher::~UberDispatcher() = default; UberDispatcher::~UberDispatcher() = default;
// static
std::unique_ptr<InternalResponse> InternalResponse::createResponse(int callId, std::unique_ptr<Serializable> params)
{
return std::unique_ptr<InternalResponse>(new InternalResponse(callId, String(), std::move(params)));
}
// static
std::unique_ptr<InternalResponse> InternalResponse::createNotification(const String& notification, std::unique_ptr<Serializable> params)
{
return std::unique_ptr<InternalResponse>(new InternalResponse(0, notification, std::move(params)));
}
String InternalResponse::serialize()
{
std::unique_ptr<DictionaryValue> result = DictionaryValue::create();
std::unique_ptr<Serializable> params(m_params ? std::move(m_params) : DictionaryValue::create());
if (m_notification.length()) {
result->setString("method", m_notification);
result->setValue("params", SerializedValue::create(params->serialize()));
} else {
result->setInteger("id", m_callId);
result->setValue("result", SerializedValue::create(params->serialize()));
}
return result->serialize();
}
InternalResponse::InternalResponse(int callId, const String& notification, std::unique_ptr<Serializable> params)
: m_callId(callId)
, m_notification(notification)
, m_params(params ? std::move(params) : nullptr)
{
}
{% for namespace in config.protocol.namespace %} {% for namespace in config.protocol.namespace %}
} // namespace {{namespace}} } // namespace {{namespace}}
{% endfor %} {% endfor %}

View File

@ -125,6 +125,46 @@ private:
protocol::HashMap<String, std::unique_ptr<protocol::DispatcherBase>> m_dispatchers; protocol::HashMap<String, std::unique_ptr<protocol::DispatcherBase>> m_dispatchers;
}; };
class InternalResponse : public Serializable {
PROTOCOL_DISALLOW_COPY(InternalResponse);
public:
static std::unique_ptr<InternalResponse> createResponse(int callId, std::unique_ptr<Serializable> params);
static std::unique_ptr<InternalResponse> createNotification(const String& notification, std::unique_ptr<Serializable> params = nullptr);
String serialize() override;
~InternalResponse() override {}
private:
InternalResponse(int callId, const String& notification, std::unique_ptr<Serializable> params);
int m_callId;
String m_notification;
std::unique_ptr<Serializable> m_params;
};
class InternalRawNotification : public Serializable {
public:
static std::unique_ptr<InternalRawNotification> create(const String& notification)
{
return std::unique_ptr<InternalRawNotification>(new InternalRawNotification(notification));
}
~InternalRawNotification() override {}
String serialize() override
{
return m_notification;
}
private:
explicit InternalRawNotification(const String& notification)
: m_notification(notification)
{
}
String m_notification;
};
{% for namespace in config.protocol.namespace %} {% for namespace in config.protocol.namespace %}
} // namespace {{namespace}} } // namespace {{namespace}}
{% endfor %} {% endfor %}

View File

@ -9,11 +9,17 @@
namespace {{namespace}} { namespace {{namespace}} {
{% endfor %} {% endfor %}
class {{config.lib.export_macro}} Serializable {
public:
virtual String serialize() = 0;
virtual ~Serializable() = default;
};
class {{config.lib.export_macro}} FrontendChannel { class {{config.lib.export_macro}} FrontendChannel {
public: public:
virtual ~FrontendChannel() { } virtual ~FrontendChannel() { }
virtual void sendProtocolResponse(int callId, const String& message) = 0; virtual void sendProtocolResponse(int callId, std::unique_ptr<Serializable> message) = 0;
virtual void sendProtocolNotification(const String& message) = 0; virtual void sendProtocolNotification(std::unique_ptr<Serializable> message) = 0;
virtual void flushProtocolNotifications() = 0; virtual void flushProtocolNotifications() = 0;
}; };

View File

@ -21,7 +21,7 @@ public:
T* fromJust() const { DCHECK(m_value); return m_value.get(); } T* fromJust() const { DCHECK(m_value); return m_value.get(); }
T* fromMaybe(T* defaultValue) const { return m_value ? m_value.get() : defaultValue; } T* fromMaybe(T* defaultValue) const { return m_value ? m_value.get() : defaultValue; }
bool isJust() const { return !!m_value; } bool isJust() const { return !!m_value; }
std::unique_ptr<T> takeJust() { DCHECK(m_value); return m_value.release(); } std::unique_ptr<T> takeJust() { DCHECK(m_value); return std::move(m_value); }
private: private:
std::unique_ptr<T> m_value; std::unique_ptr<T> m_value;
}; };

View File

@ -8,7 +8,7 @@
namespace {{namespace}} { namespace {{namespace}} {
{% endfor %} {% endfor %}
std::unique_ptr<Object> Object::parse(protocol::Value* value, ErrorSupport* errors) std::unique_ptr<Object> Object::fromValue(protocol::Value* value, ErrorSupport* errors)
{ {
protocol::DictionaryValue* dictionary = DictionaryValue::cast(value); protocol::DictionaryValue* dictionary = DictionaryValue::cast(value);
if (!dictionary) { if (!dictionary) {
@ -19,7 +19,7 @@ std::unique_ptr<Object> Object::parse(protocol::Value* value, ErrorSupport* erro
return std::unique_ptr<Object>(new Object(std::unique_ptr<DictionaryValue>(dictionary))); return std::unique_ptr<Object>(new Object(std::unique_ptr<DictionaryValue>(dictionary)));
} }
std::unique_ptr<protocol::DictionaryValue> Object::serialize() const std::unique_ptr<protocol::DictionaryValue> Object::toValue() const
{ {
return DictionaryValue::cast(m_object->clone()); return DictionaryValue::cast(m_object->clone());
} }

View File

@ -15,10 +15,10 @@ namespace {{namespace}} {
class {{config.lib.export_macro}} Object { class {{config.lib.export_macro}} Object {
public: public:
static std::unique_ptr<Object> parse(protocol::Value*, ErrorSupport*); static std::unique_ptr<Object> fromValue(protocol::Value*, ErrorSupport*);
~Object(); ~Object();
std::unique_ptr<protocol::DictionaryValue> serialize() const; std::unique_ptr<protocol::DictionaryValue> toValue() const;
std::unique_ptr<Object> clone() const; std::unique_ptr<Object> clone() const;
private: private:
explicit Object(std::unique_ptr<protocol::DictionaryValue>); explicit Object(std::unique_ptr<protocol::DictionaryValue>);

View File

@ -15,25 +15,25 @@ namespace {{namespace}} {
template<typename T> template<typename T>
struct ValueConversions { struct ValueConversions {
static std::unique_ptr<T> parse(protocol::Value* value, ErrorSupport* errors) static std::unique_ptr<T> fromValue(protocol::Value* value, ErrorSupport* errors)
{ {
return T::parse(value, errors); return T::fromValue(value, errors);
} }
static std::unique_ptr<protocol::Value> serialize(T* value) static std::unique_ptr<protocol::Value> toValue(T* value)
{ {
return value->serialize(); return value->toValue();
} }
static std::unique_ptr<protocol::Value> serialize(const std::unique_ptr<T>& value) static std::unique_ptr<protocol::Value> toValue(const std::unique_ptr<T>& value)
{ {
return value->serialize(); return value->toValue();
} }
}; };
template<> template<>
struct ValueConversions<bool> { struct ValueConversions<bool> {
static bool parse(protocol::Value* value, ErrorSupport* errors) static bool fromValue(protocol::Value* value, ErrorSupport* errors)
{ {
bool result = false; bool result = false;
bool success = value ? value->asBoolean(&result) : false; bool success = value ? value->asBoolean(&result) : false;
@ -42,7 +42,7 @@ struct ValueConversions<bool> {
return result; return result;
} }
static std::unique_ptr<protocol::Value> serialize(bool value) static std::unique_ptr<protocol::Value> toValue(bool value)
{ {
return FundamentalValue::create(value); return FundamentalValue::create(value);
} }
@ -50,7 +50,7 @@ struct ValueConversions<bool> {
template<> template<>
struct ValueConversions<int> { struct ValueConversions<int> {
static int parse(protocol::Value* value, ErrorSupport* errors) static int fromValue(protocol::Value* value, ErrorSupport* errors)
{ {
int result = 0; int result = 0;
bool success = value ? value->asInteger(&result) : false; bool success = value ? value->asInteger(&result) : false;
@ -59,7 +59,7 @@ struct ValueConversions<int> {
return result; return result;
} }
static std::unique_ptr<protocol::Value> serialize(int value) static std::unique_ptr<protocol::Value> toValue(int value)
{ {
return FundamentalValue::create(value); return FundamentalValue::create(value);
} }
@ -67,7 +67,7 @@ struct ValueConversions<int> {
template<> template<>
struct ValueConversions<double> { struct ValueConversions<double> {
static double parse(protocol::Value* value, ErrorSupport* errors) static double fromValue(protocol::Value* value, ErrorSupport* errors)
{ {
double result = 0; double result = 0;
bool success = value ? value->asDouble(&result) : false; bool success = value ? value->asDouble(&result) : false;
@ -76,7 +76,7 @@ struct ValueConversions<double> {
return result; return result;
} }
static std::unique_ptr<protocol::Value> serialize(double value) static std::unique_ptr<protocol::Value> toValue(double value)
{ {
return FundamentalValue::create(value); return FundamentalValue::create(value);
} }
@ -84,7 +84,7 @@ struct ValueConversions<double> {
template<> template<>
struct ValueConversions<String> { struct ValueConversions<String> {
static String parse(protocol::Value* value, ErrorSupport* errors) static String fromValue(protocol::Value* value, ErrorSupport* errors)
{ {
String result; String result;
bool success = value ? value->asString(&result) : false; bool success = value ? value->asString(&result) : false;
@ -93,7 +93,7 @@ struct ValueConversions<String> {
return result; return result;
} }
static std::unique_ptr<protocol::Value> serialize(const String& value) static std::unique_ptr<protocol::Value> toValue(const String& value)
{ {
return StringValue::create(value); return StringValue::create(value);
} }
@ -101,7 +101,7 @@ struct ValueConversions<String> {
template<> template<>
struct ValueConversions<Value> { struct ValueConversions<Value> {
static std::unique_ptr<Value> parse(protocol::Value* value, ErrorSupport* errors) static std::unique_ptr<Value> fromValue(protocol::Value* value, ErrorSupport* errors)
{ {
bool success = !!value; bool success = !!value;
if (!success) { if (!success) {
@ -111,12 +111,12 @@ struct ValueConversions<Value> {
return value->clone(); return value->clone();
} }
static std::unique_ptr<protocol::Value> serialize(Value* value) static std::unique_ptr<protocol::Value> toValue(Value* value)
{ {
return value->clone(); return value->clone();
} }
static std::unique_ptr<protocol::Value> serialize(const std::unique_ptr<Value>& value) static std::unique_ptr<protocol::Value> toValue(const std::unique_ptr<Value>& value)
{ {
return value->clone(); return value->clone();
} }
@ -124,7 +124,7 @@ struct ValueConversions<Value> {
template<> template<>
struct ValueConversions<DictionaryValue> { struct ValueConversions<DictionaryValue> {
static std::unique_ptr<DictionaryValue> parse(protocol::Value* value, ErrorSupport* errors) static std::unique_ptr<DictionaryValue> fromValue(protocol::Value* value, ErrorSupport* errors)
{ {
bool success = value && value->type() == protocol::Value::TypeObject; bool success = value && value->type() == protocol::Value::TypeObject;
if (!success) if (!success)
@ -132,12 +132,12 @@ struct ValueConversions<DictionaryValue> {
return DictionaryValue::cast(value->clone()); return DictionaryValue::cast(value->clone());
} }
static std::unique_ptr<protocol::Value> serialize(DictionaryValue* value) static std::unique_ptr<protocol::Value> toValue(DictionaryValue* value)
{ {
return value->clone(); return value->clone();
} }
static std::unique_ptr<protocol::Value> serialize(const std::unique_ptr<DictionaryValue>& value) static std::unique_ptr<protocol::Value> toValue(const std::unique_ptr<DictionaryValue>& value)
{ {
return value->clone(); return value->clone();
} }
@ -145,7 +145,7 @@ struct ValueConversions<DictionaryValue> {
template<> template<>
struct ValueConversions<ListValue> { struct ValueConversions<ListValue> {
static std::unique_ptr<ListValue> parse(protocol::Value* value, ErrorSupport* errors) static std::unique_ptr<ListValue> fromValue(protocol::Value* value, ErrorSupport* errors)
{ {
bool success = value && value->type() == protocol::Value::TypeArray; bool success = value && value->type() == protocol::Value::TypeArray;
if (!success) if (!success)
@ -153,12 +153,12 @@ struct ValueConversions<ListValue> {
return ListValue::cast(value->clone()); return ListValue::cast(value->clone());
} }
static std::unique_ptr<protocol::Value> serialize(ListValue* value) static std::unique_ptr<protocol::Value> toValue(ListValue* value)
{ {
return value->clone(); return value->clone();
} }
static std::unique_ptr<protocol::Value> serialize(const std::unique_ptr<ListValue>& value) static std::unique_ptr<protocol::Value> toValue(const std::unique_ptr<ListValue>& value)
{ {
return value->clone(); return value->clone();
} }

View File

@ -93,14 +93,6 @@ bool Value::asSerialized(String*) const
return false; return false;
} }
String Value::toJSONString() const
{
StringBuilder result;
StringUtil::builderReserve(result, 512);
writeJSON(&result);
return result.toString();
}
void Value::writeJSON(StringBuilder* output) const void Value::writeJSON(StringBuilder* output) const
{ {
DCHECK(m_type == TypeNull); DCHECK(m_type == TypeNull);
@ -112,6 +104,14 @@ std::unique_ptr<Value> Value::clone() const
return Value::null(); return Value::null();
} }
String Value::serialize()
{
StringBuilder result;
StringUtil::builderReserve(result, 512);
writeJSON(&result);
return result.toString();
}
bool FundamentalValue::asBoolean(bool* output) const bool FundamentalValue::asBoolean(bool* output) const
{ {
if (type() != TypeBoolean) if (type() != TypeBoolean)

View File

@ -17,10 +17,10 @@ class ListValue;
class DictionaryValue; class DictionaryValue;
class Value; class Value;
class {{config.lib.export_macro}} Value { class {{config.lib.export_macro}} Value : public Serializable {
PROTOCOL_DISALLOW_COPY(Value); PROTOCOL_DISALLOW_COPY(Value);
public: public:
virtual ~Value() { } virtual ~Value() override { }
static std::unique_ptr<Value> null() static std::unique_ptr<Value> null()
{ {
@ -48,9 +48,9 @@ public:
virtual bool asString(String* output) const; virtual bool asString(String* output) const;
virtual bool asSerialized(String* output) const; virtual bool asSerialized(String* output) const;
String toJSONString() const;
virtual void writeJSON(StringBuilder* output) const; virtual void writeJSON(StringBuilder* output) const;
virtual std::unique_ptr<Value> clone() const; virtual std::unique_ptr<Value> clone() const;
String serialize() override;
protected: protected:
Value() : m_type(TypeNull) { } Value() : m_type(TypeNull) { }

View File

@ -22,28 +22,28 @@ namespace {{namespace}} {
template<> template<>
struct ValueConversions<{{"::".join(config.imported.namespace)}}::{{domain.domain}}::API::{{type.id}}> { struct ValueConversions<{{"::".join(config.imported.namespace)}}::{{domain.domain}}::API::{{type.id}}> {
static std::unique_ptr<{{"::".join(config.imported.namespace)}}::{{domain.domain}}::API::{{type.id}}> parse(protocol::Value* value, ErrorSupport* errors) static std::unique_ptr<{{"::".join(config.imported.namespace)}}::{{domain.domain}}::API::{{type.id}}> fromValue(protocol::Value* value, ErrorSupport* errors)
{ {
if (!value) { if (!value) {
errors->addError("value expected"); errors->addError("value expected");
return nullptr; return nullptr;
} }
String json = value->toJSONString(); String json = value->serialize();
auto result = {{"::".join(config.imported.namespace)}}::{{domain.domain}}::API::{{type.id}}::fromJSONString({{config.imported.to_imported_string % "json"}}); auto result = {{"::".join(config.imported.namespace)}}::{{domain.domain}}::API::{{type.id}}::fromJSONString({{config.imported.to_imported_string % "json"}});
if (!result) if (!result)
errors->addError("cannot parse"); errors->addError("cannot parse");
return result; return result;
} }
static std::unique_ptr<protocol::Value> serialize(const {{"::".join(config.imported.namespace)}}::{{domain.domain}}::API::{{type.id}}* value) static std::unique_ptr<protocol::Value> toValue(const {{"::".join(config.imported.namespace)}}::{{domain.domain}}::API::{{type.id}}* value)
{ {
auto json = value->toJSONString(); auto json = value->toJSONString();
return SerializedValue::create({{config.imported.from_imported_string % "std::move(json)"}}); return SerializedValue::create({{config.imported.from_imported_string % "std::move(json)"}});
} }
static std::unique_ptr<protocol::Value> serialize(const std::unique_ptr<{{"::".join(config.imported.namespace)}}::{{domain.domain}}::API::{{type.id}}>& value) static std::unique_ptr<protocol::Value> toValue(const std::unique_ptr<{{"::".join(config.imported.namespace)}}::{{domain.domain}}::API::{{type.id}}>& value)
{ {
return serialize(value.get()); return toValue(value.get());
} }
}; };
{% endfor %} {% endfor %}

View File

@ -47,7 +47,7 @@ const char* {{type.id}}::{{property.name | to_title_case}}Enum::{{literal | dash
{% endfor %} {% endfor %}
{% if not (type.type == "object") or not ("properties" in type) %}{% continue %}{% endif %} {% if not (type.type == "object") or not ("properties" in type) %}{% continue %}{% endif %}
std::unique_ptr<{{type.id}}> {{type.id}}::parse(protocol::Value* value, ErrorSupport* errors) std::unique_ptr<{{type.id}}> {{type.id}}::fromValue(protocol::Value* value, ErrorSupport* errors)
{ {
if (!value || value->type() != protocol::Value::TypeObject) { if (!value || value->type() != protocol::Value::TypeObject) {
errors->addError("object expected"); errors->addError("object expected");
@ -62,11 +62,11 @@ std::unique_ptr<{{type.id}}> {{type.id}}::parse(protocol::Value* value, ErrorSup
{% if property.optional %} {% if property.optional %}
if ({{property.name}}Value) { if ({{property.name}}Value) {
errors->setName("{{property.name}}"); errors->setName("{{property.name}}");
result->m_{{property.name}} = ValueConversions<{{resolve_type(property).raw_type}}>::parse({{property.name}}Value, errors); result->m_{{property.name}} = ValueConversions<{{resolve_type(property).raw_type}}>::fromValue({{property.name}}Value, errors);
} }
{% else %} {% else %}
errors->setName("{{property.name}}"); errors->setName("{{property.name}}");
result->m_{{property.name}} = ValueConversions<{{resolve_type(property).raw_type}}>::parse({{property.name}}Value, errors); result->m_{{property.name}} = ValueConversions<{{resolve_type(property).raw_type}}>::fromValue({{property.name}}Value, errors);
{% endif %} {% endif %}
{% endfor %} {% endfor %}
errors->pop(); errors->pop();
@ -75,15 +75,15 @@ std::unique_ptr<{{type.id}}> {{type.id}}::parse(protocol::Value* value, ErrorSup
return result; return result;
} }
std::unique_ptr<protocol::DictionaryValue> {{type.id}}::serialize() const std::unique_ptr<protocol::DictionaryValue> {{type.id}}::toValue() const
{ {
std::unique_ptr<protocol::DictionaryValue> result = DictionaryValue::create(); std::unique_ptr<protocol::DictionaryValue> result = DictionaryValue::create();
{% for property in type.properties %} {% for property in type.properties %}
{% if property.optional %} {% if property.optional %}
if (m_{{property.name}}.isJust()) if (m_{{property.name}}.isJust())
result->setValue("{{property.name}}", ValueConversions<{{resolve_type(property).raw_type}}>::serialize(m_{{property.name}}.fromJust())); result->setValue("{{property.name}}", ValueConversions<{{resolve_type(property).raw_type}}>::toValue(m_{{property.name}}.fromJust()));
{% else %} {% else %}
result->setValue("{{property.name}}", ValueConversions<{{resolve_type(property).raw_type}}>::serialize({{resolve_type(property).to_raw_type % ("m_" + property.name)}})); result->setValue("{{property.name}}", ValueConversions<{{resolve_type(property).raw_type}}>::toValue({{resolve_type(property).to_raw_type % ("m_" + property.name)}}));
{% endif %} {% endif %}
{% endfor %} {% endfor %}
return result; return result;
@ -92,13 +92,13 @@ std::unique_ptr<protocol::DictionaryValue> {{type.id}}::serialize() const
std::unique_ptr<{{type.id}}> {{type.id}}::clone() const std::unique_ptr<{{type.id}}> {{type.id}}::clone() const
{ {
ErrorSupport errors; ErrorSupport errors;
return parse(serialize().get(), &errors); return fromValue(toValue().get(), &errors);
} }
{% if type.exported %} {% if type.exported %}
{{config.exported.string_out}} {{type.id}}::toJSONString() const {{config.exported.string_out}} {{type.id}}::toJSONString() const
{ {
String json = serialize()->toJSONString(); String json = toValue()->serialize();
return {{config.exported.to_string_out % "json"}}; return {{config.exported.to_string_out % "json"}};
} }
@ -109,7 +109,7 @@ std::unique_ptr<API::{{type.id}}> API::{{type.id}}::fromJSONString(const {{confi
std::unique_ptr<Value> value = StringUtil::parseJSON(json); std::unique_ptr<Value> value = StringUtil::parseJSON(json);
if (!value) if (!value)
return nullptr; return nullptr;
return protocol::{{domain.domain}}::{{type.id}}::parse(value.get(), &errors); return protocol::{{domain.domain}}::{{type.id}}::fromValue(value.get(), &errors);
} }
{% endif %} {% endif %}
{% endfor %} {% endfor %}
@ -156,20 +156,26 @@ void Frontend::{{event.name | to_method_case}}(
{%- endif %} {{parameter.name}}{%- if not loop.last -%}, {% endif -%} {%- endif %} {{parameter.name}}{%- if not loop.last -%}, {% endif -%}
{% endfor -%}) {% endfor -%})
{ {
std::unique_ptr<protocol::DictionaryValue> jsonMessage = DictionaryValue::create(); if (!m_frontendChannel)
jsonMessage->setString("method", "{{domain.domain}}.{{event.name}}"); return;
std::unique_ptr<protocol::DictionaryValue> paramsObject = DictionaryValue::create(); {% if event.parameters %}
{% for parameter in event.parameters %} std::unique_ptr<{{event.name | to_title_case}}Notification> messageData = {{event.name | to_title_case}}Notification::{{"create" | to_method_case}}()
{% if "optional" in parameter %} {% for parameter in event.parameters %}
{% if not "optional" in parameter %}
.{{"set" | to_method_case}}{{parameter.name | to_title_case}}({{resolve_type(parameter).to_pass_type % parameter.name}})
{% endif %}
{% endfor %}
.{{ "build" | to_method_case }}();
{% for parameter in event.parameters %}
{% if "optional" in parameter %}
if ({{parameter.name}}.isJust()) if ({{parameter.name}}.isJust())
paramsObject->setValue("{{parameter.name}}", ValueConversions<{{resolve_type(parameter).raw_type}}>::serialize({{parameter.name}}.fromJust())); messageData->{{"set" | to_method_case}}{{parameter.name | to_title_case}}(std::move({{parameter.name}}).takeJust());
{% endif %}
{% endfor %}
m_frontendChannel->sendProtocolNotification(InternalResponse::createNotification("{{domain.domain}}.{{event.name}}", std::move(messageData)));
{% else %} {% else %}
paramsObject->setValue("{{parameter.name}}", ValueConversions<{{resolve_type(parameter).raw_type}}>::serialize({{resolve_type(parameter).to_raw_type % parameter.name}})); m_frontendChannel->sendProtocolNotification(InternalResponse::createNotification("{{domain.domain}}.{{event.name}}"));
{% endif %} {% endif %}
{% endfor %}
jsonMessage->setObject("params", std::move(paramsObject));
if (m_frontendChannel)
m_frontendChannel->sendProtocolNotification(jsonMessage->toJSONString());
} }
{% endfor %} {% endfor %}
@ -180,7 +186,7 @@ void Frontend::flush()
void Frontend::sendRawNotification(const String& notification) void Frontend::sendRawNotification(const String& notification)
{ {
m_frontendChannel->sendProtocolNotification(notification); m_frontendChannel->sendProtocolNotification(InternalRawNotification::create(notification));
} }
// --------------------- Dispatcher. // --------------------- Dispatcher.
@ -253,9 +259,9 @@ public:
{% for parameter in command.returns %} {% for parameter in command.returns %}
{% if "optional" in parameter %} {% if "optional" in parameter %}
if ({{parameter.name}}.isJust()) if ({{parameter.name}}.isJust())
resultObject->setValue("{{parameter.name}}", ValueConversions<{{resolve_type(parameter).raw_type}}>::serialize({{parameter.name}}.fromJust())); resultObject->setValue("{{parameter.name}}", ValueConversions<{{resolve_type(parameter).raw_type}}>::toValue({{parameter.name}}.fromJust()));
{% else %} {% else %}
resultObject->setValue("{{parameter.name}}", ValueConversions<{{resolve_type(parameter).raw_type}}>::serialize({{resolve_type(parameter).to_raw_type % parameter.name}})); resultObject->setValue("{{parameter.name}}", ValueConversions<{{resolve_type(parameter).raw_type}}>::toValue({{resolve_type(parameter).to_raw_type % parameter.name}}));
{% endif %} {% endif %}
{% endfor %} {% endfor %}
sendIfActive(std::move(resultObject), DispatchResponse::OK()); sendIfActive(std::move(resultObject), DispatchResponse::OK());
@ -286,11 +292,11 @@ DispatchResponse::Status DispatcherImpl::{{command.name}}(int callId, std::uniqu
Maybe<{{resolve_type(property).raw_type}}> in_{{property.name}}; Maybe<{{resolve_type(property).raw_type}}> in_{{property.name}};
if ({{property.name}}Value) { if ({{property.name}}Value) {
errors->setName("{{property.name}}"); errors->setName("{{property.name}}");
in_{{property.name}} = ValueConversions<{{resolve_type(property).raw_type}}>::parse({{property.name}}Value, errors); in_{{property.name}} = ValueConversions<{{resolve_type(property).raw_type}}>::fromValue({{property.name}}Value, errors);
} }
{% else %} {% else %}
errors->setName("{{property.name}}"); errors->setName("{{property.name}}");
{{resolve_type(property).type}} in_{{property.name}} = ValueConversions<{{resolve_type(property).raw_type}}>::parse({{property.name}}Value, errors); {{resolve_type(property).type}} in_{{property.name}} = ValueConversions<{{resolve_type(property).raw_type}}>::fromValue({{property.name}}Value, errors);
{% endif %} {% endif %}
{% endfor %} {% endfor %}
errors->pop(); errors->pop();
@ -335,9 +341,9 @@ DispatchResponse::Status DispatcherImpl::{{command.name}}(int callId, std::uniqu
{% for parameter in command.returns %} {% for parameter in command.returns %}
{% if "optional" in parameter %} {% if "optional" in parameter %}
if (out_{{parameter.name}}.isJust()) if (out_{{parameter.name}}.isJust())
result->setValue("{{parameter.name}}", ValueConversions<{{resolve_type(parameter).raw_type}}>::serialize(out_{{parameter.name}}.fromJust())); result->setValue("{{parameter.name}}", ValueConversions<{{resolve_type(parameter).raw_type}}>::toValue(out_{{parameter.name}}.fromJust()));
{% else %} {% else %}
result->setValue("{{parameter.name}}", ValueConversions<{{resolve_type(parameter).raw_type}}>::serialize({{resolve_type(parameter).to_raw_type % ("out_" + parameter.name)}})); result->setValue("{{parameter.name}}", ValueConversions<{{resolve_type(parameter).raw_type}}>::toValue({{resolve_type(parameter).to_raw_type % ("out_" + parameter.name)}}));
{% endif %} {% endif %}
{% endfor %} {% endfor %}
} }

View File

@ -71,12 +71,12 @@ namespace {{param.name | to_title_case}}Enum {
{% set type_def = type_definition(domain.domain + "." + type.id)%} {% set type_def = type_definition(domain.domain + "." + type.id)%}
// {{type.description}} // {{type.description}}
class {{config.protocol.export_macro}} {{type.id}} {% if type.exported %}: public API::{{type.id}} {% endif %}{ class {{config.protocol.export_macro}} {{type.id}} : public Serializable{% if type.exported %}, public API::{{type.id}}{% endif %}{
PROTOCOL_DISALLOW_COPY({{type.id}}); PROTOCOL_DISALLOW_COPY({{type.id}});
public: public:
static std::unique_ptr<{{type.id}}> parse(protocol::Value* value, ErrorSupport* errors); static std::unique_ptr<{{type.id}}> fromValue(protocol::Value* value, ErrorSupport* errors);
~{{type.id}}() { } ~{{type.id}}() override { }
{% for property in type.properties %} {% for property in type.properties %}
{% if "enum" in property %} {% if "enum" in property %}
@ -96,7 +96,8 @@ public:
void {{"set" | to_method_case}}{{property.name | to_title_case}}({{resolve_type(property).pass_type}} value) { m_{{property.name}} = {{resolve_type(property).to_rvalue % "value"}}; } void {{"set" | to_method_case}}{{property.name | to_title_case}}({{resolve_type(property).pass_type}} value) { m_{{property.name}} = {{resolve_type(property).to_rvalue % "value"}}; }
{% endfor %} {% endfor %}
std::unique_ptr<protocol::DictionaryValue> serialize() const; std::unique_ptr<protocol::DictionaryValue> toValue() const;
String serialize() override { return toValue()->serialize(); }
std::unique_ptr<{{type.id}}> clone() const; std::unique_ptr<{{type.id}}> clone() const;
{% if type.exported %} {% if type.exported %}
{{config.exported.string_out}} toJSONString() const override; {{config.exported.string_out}} toJSONString() const override;