Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(226)

Unified Diff: mojo/public/cpp/bindings/lib/control_message_proxy.cc

Issue 2064903002: Mojo: Report bindings validation errors via MojoNotifyBadMessage (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 4 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: mojo/public/cpp/bindings/lib/control_message_proxy.cc
diff --git a/mojo/public/cpp/bindings/lib/control_message_proxy.cc b/mojo/public/cpp/bindings/lib/control_message_proxy.cc
index 6189e6973e792f691b9a94fb8cdc7ec329062273..92b8cb8301727fadba22a3c745b42212ddcf6009 100644
--- a/mojo/public/cpp/bindings/lib/control_message_proxy.cc
+++ b/mojo/public/cpp/bindings/lib/control_message_proxy.cc
@@ -25,14 +25,14 @@ class RunResponseForwardToCallback : public MessageReceiver {
public:
RunResponseForwardToCallback(const RunCallback& callback)
: callback_(callback) {}
- bool Accept(Message* message) override;
+ bool Accept(Message* message, Error* error) override;
private:
RunCallback callback_;
DISALLOW_COPY_AND_ASSIGN(RunResponseForwardToCallback);
};
-bool RunResponseForwardToCallback::Accept(Message* message) {
+bool RunResponseForwardToCallback::Accept(Message* message, Error* error) {
RunResponseMessageParams_Data* params =
reinterpret_cast<RunResponseMessageParams_Data*>(
message->mutable_payload());
@@ -63,7 +63,8 @@ void SendRunMessage(MessageReceiverWithResponder* receiver,
context);
params->EncodePointers();
MessageReceiver* responder = new RunResponseForwardToCallback(callback);
- if (!receiver->AcceptWithResponder(builder.message(), responder))
+ Error send_error;
+ if (!receiver->AcceptWithResponder(builder.message(), responder, &send_error))
delete responder;
}
@@ -83,7 +84,8 @@ void SendRunOrClosePipeMessage(MessageReceiverWithResponder* receiver,
Serialize<RunOrClosePipeMessageParamsPtr>(params_ptr, builder.buffer(),
&params, context);
params->EncodePointers();
- bool ok = receiver->Accept(builder.message());
+ Error send_error;
+ bool ok = receiver->Accept(builder.message(), &send_error);
ALLOW_UNUSED_LOCAL(ok);
}

Powered by Google App Engine
This is Rietveld 408576698