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

Side by Side Diff: content/common/input/input_param_traits.h

Issue 19624005: Add InputEvent and EventPacket types for batched input delivery (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Code review Created 7 years, 3 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 unified diff | Download patch
OLDNEW
(Empty)
1 // Copyright (c) 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 // This file defines IPC::ParamTraits<> specializations for several
6 // input-related types that require manual serialiation code.
7
8 #ifndef CONTENT_COMMON_INPUT_INPUT_PARAM_TRAITS_H_
9 #define CONTENT_COMMON_INPUT_INPUT_PARAM_TRAITS_H_
10
11 #include "base/memory/scoped_ptr.h"
12 #include "content/common/content_param_traits_macros.h"
13 #include "content/common/input/input_event.h"
14 #include "content/common/input/web_input_event_payload.h"
15
16 namespace IPC {
17
18 // TODO(jdduke): There should be a common copy of this utility somewhere...
19 // Move or remove appropriately.
20 template<class P>
21 struct ParamTraits<scoped_ptr<P> > {
22 typedef scoped_ptr<P> param_type;
23 static void Write(Message* m, const param_type& p) {
24 bool valid = !!p;
25 WriteParam(m, valid);
26 if (valid)
27 WriteParam(m, *p);
28 }
29 static bool Read(const Message* m, PickleIterator* iter, param_type* r) {
30 bool valid = false;
31 if (!ReadParam(m, iter, &valid))
32 return false;
33
34 if (!valid) {
35 r->reset();
36 return true;
37 }
38
39 param_type temp(new P());
palmer 2013/09/03 23:12:47 Just to make sure I understand: You allocate a new
jdduke (slow) 2013/09/04 17:53:24 Well, param_type* r is a pointer to any empty scop
jdduke (slow) 2013/09/05 00:01:21 Or perhaps you meant we should go ahead and assign
palmer 2013/09/05 01:20:15 No, I think you are right. I was trying to figure
jdduke (slow) 2013/09/05 19:31:48 Yeah, that crossed my mind. This operation *shoul
40 if (!ReadParam(m, iter, temp.get()))
41 return false;
42
43 r->swap(temp);
44 return true;
45 }
46 static void Log(const param_type& p, std::string* l) {
47 if (p)
48 LogParam(*p, l);
49 else
50 l->append("NULL");
51 }
52 };
53
54 template <>
55 struct CONTENT_EXPORT ParamTraits<content::InputEvent> {
56 typedef content::InputEvent param_type;
57 static void Write(Message* m, const param_type& p);
58 static bool Read(const Message* m, PickleIterator* iter, param_type* r);
59 static void Log(const param_type& p, std::string* l);
60 };
61
62 template <>
63 struct CONTENT_EXPORT ParamTraits<content::WebInputEventPayload> {
64 typedef content::WebInputEventPayload param_type;
65 static void Write(Message* m, const param_type& p);
66 static bool Read(const Message* m, PickleIterator* iter, param_type* r);
67 static void Log(const param_type& p, std::string* l);
68 };
69
70 } // namespace IPC
71
72 #endif // CONTENT_COMMON_INPUT_INPUT_PARAM_TRAITS_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698