common_param_traits.h revision 90dce4d38c5ff5333bea97d859d4e484e27edf0c
1// Copyright (c) 2012 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 is used to define IPC::ParamTraits<> specializations for a number
6// of types so that they can be serialized over IPC.  IPC::ParamTraits<>
7// specializations for basic types (like int and std::string) and types in the
8// 'base' project can be found in ipc/ipc_message_utils.h.  This file contains
9// specializations for types that are used by the content code, and which need
10// manual serialization code.  This is usually because they're not structs with
11// public members, or because the same type is being used in multiple
12// *_messages.h headers.
13
14#ifndef CONTENT_PUBLIC_COMMON_COMMON_PARAM_TRAITS_H_
15#define CONTENT_PUBLIC_COMMON_COMMON_PARAM_TRAITS_H_
16
17#include "base/memory/ref_counted.h"
18#include "content/common/content_export.h"
19#include "content/public/common/common_param_traits_macros.h"
20#include "googleurl/src/gurl.h"
21#include "ipc/ipc_message_utils.h"
22#include "ui/gfx/native_widget_types.h"
23#include "ui/surface/transport_dib.h"
24
25class SkBitmap;
26
27namespace content {
28class PageState;
29struct Referrer;
30}
31
32namespace gfx {
33class Point;
34class Rect;
35class RectF;
36class Size;
37class Vector2d;
38}  // namespace gfx
39
40namespace net {
41class HostPortPair;
42}
43
44namespace IPC {
45
46template <>
47struct CONTENT_EXPORT ParamTraits<GURL> {
48  typedef GURL param_type;
49  static void Write(Message* m, const param_type& p);
50  static bool Read(const Message* m, PickleIterator* iter, param_type* p);
51  static void Log(const param_type& p, std::string* l);
52};
53
54template<>
55struct CONTENT_EXPORT ParamTraits<net::HostPortPair> {
56  typedef net::HostPortPair 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
62template <>
63struct CONTENT_EXPORT ParamTraits<content::PageState> {
64  typedef content::PageState param_type;
65  static void Write(Message* m, const param_type& p);
66  static bool Read(const Message* m, PickleIterator* iter, param_type* p);
67  static void Log(const param_type& p, std::string* l);
68};
69
70template <>
71struct CONTENT_EXPORT ParamTraits<content::Referrer> {
72  typedef content::Referrer param_type;
73  static void Write(Message* m, const param_type& p);
74  static bool Read(const Message* m, PickleIterator* iter, param_type* p);
75  static void Log(const param_type& p, std::string* l);
76};
77
78template <>
79struct CONTENT_EXPORT ParamTraits<gfx::Point> {
80  typedef gfx::Point param_type;
81  static void Write(Message* m, const param_type& p);
82  static bool Read(const Message* m, PickleIterator* iter, param_type* r);
83  static void Log(const param_type& p, std::string* l);
84};
85
86template <>
87struct CONTENT_EXPORT ParamTraits<gfx::PointF> {
88  typedef gfx::PointF param_type;
89  static void Write(Message* m, const param_type& p);
90  static bool Read(const Message* m, PickleIterator* iter, param_type* r);
91  static void Log(const param_type& p, std::string* l);
92};
93
94template <>
95struct CONTENT_EXPORT ParamTraits<gfx::Size> {
96  typedef gfx::Size param_type;
97  static void Write(Message* m, const param_type& p);
98  static bool Read(const Message* m, PickleIterator* iter, param_type* r);
99  static void Log(const param_type& p, std::string* l);
100};
101
102template <>
103struct CONTENT_EXPORT ParamTraits<gfx::SizeF> {
104  typedef gfx::SizeF param_type;
105  static void Write(Message* m, const param_type& p);
106  static bool Read(const Message* m, PickleIterator* iter, param_type* r);
107  static void Log(const param_type& p, std::string* l);
108};
109
110template <>
111struct CONTENT_EXPORT ParamTraits<gfx::Vector2d> {
112  typedef gfx::Vector2d param_type;
113  static void Write(Message* m, const param_type& p);
114  static bool Read(const Message* m, PickleIterator* iter, param_type* r);
115  static void Log(const param_type& p, std::string* l);
116};
117
118template <>
119struct CONTENT_EXPORT ParamTraits<gfx::Vector2dF> {
120  typedef gfx::Vector2dF param_type;
121  static void Write(Message* m, const param_type& p);
122  static bool Read(const Message* m, PickleIterator* iter, param_type* r);
123  static void Log(const param_type& p, std::string* l);
124};
125
126template <>
127struct CONTENT_EXPORT ParamTraits<gfx::Rect> {
128  typedef gfx::Rect param_type;
129  static void Write(Message* m, const param_type& p);
130  static bool Read(const Message* m, PickleIterator* iter, param_type* r);
131  static void Log(const param_type& p, std::string* l);
132};
133
134template <>
135struct CONTENT_EXPORT ParamTraits<gfx::RectF> {
136  typedef gfx::RectF param_type;
137  static void Write(Message* m, const param_type& p);
138  static bool Read(const Message* m, PickleIterator* iter, param_type* r);
139  static void Log(const param_type& p, std::string* l);
140};
141
142template <>
143struct ParamTraits<gfx::NativeWindow> {
144  typedef gfx::NativeWindow param_type;
145  static void Write(Message* m, const param_type& p) {
146#if defined(OS_WIN)
147    // HWNDs are always 32 bits on Windows, even on 64 bit systems.
148    m->WriteUInt32(reinterpret_cast<uint32>(p));
149#else
150    m->WriteData(reinterpret_cast<const char*>(&p), sizeof(p));
151#endif
152  }
153  static bool Read(const Message* m, PickleIterator* iter, param_type* r) {
154#if defined(OS_WIN)
155    return m->ReadUInt32(iter, reinterpret_cast<uint32*>(r));
156#else
157    const char *data;
158    int data_size = 0;
159    bool result = m->ReadData(iter, &data, &data_size);
160    if (result && data_size == sizeof(gfx::NativeWindow)) {
161      memcpy(r, data, sizeof(gfx::NativeWindow));
162    } else {
163      result = false;
164      NOTREACHED();
165    }
166    return result;
167#endif
168  }
169  static void Log(const param_type& p, std::string* l) {
170    l->append("<gfx::NativeWindow>");
171  }
172};
173
174#if defined(OS_WIN)
175template<>
176struct ParamTraits<TransportDIB::Id> {
177  typedef TransportDIB::Id param_type;
178  static void Write(Message* m, const param_type& p) {
179    WriteParam(m, p.handle);
180    WriteParam(m, p.sequence_num);
181  }
182  static bool Read(const Message* m, PickleIterator* iter, param_type* r) {
183    return (ReadParam(m, iter, &r->handle) &&
184            ReadParam(m, iter, &r->sequence_num));
185  }
186  static void Log(const param_type& p, std::string* l) {
187    l->append("TransportDIB(");
188    LogParam(p.handle, l);
189    l->append(", ");
190    LogParam(p.sequence_num, l);
191    l->append(")");
192  }
193};
194#endif
195
196#if defined(TOOLKIT_GTK)
197template<>
198struct ParamTraits<TransportDIB::Id> {
199  typedef TransportDIB::Id param_type;
200  static void Write(Message* m, const param_type& p) {
201    WriteParam(m, p.shmkey);
202  }
203  static bool Read(const Message* m, PickleIterator* iter, param_type* r) {
204    return ReadParam(m, iter, &r->shmkey);
205  }
206  static void Log(const param_type& p, std::string* l) {
207    l->append("TransportDIB(");
208    LogParam(p.shmkey, l);
209    l->append(")");
210  }
211};
212#endif
213
214template <>
215struct CONTENT_EXPORT ParamTraits<SkBitmap> {
216  typedef SkBitmap param_type;
217  static void Write(Message* m, const param_type& p);
218
219  // Note: This function expects parameter |r| to be of type &SkBitmap since
220  // r->SetConfig() and r->SetPixels() are called.
221  static bool Read(const Message* m, PickleIterator* iter, param_type* r);
222
223  static void Log(const param_type& p, std::string* l);
224};
225
226}  // namespace IPC
227
228#endif  // CONTENT_PUBLIC_COMMON_COMMON_PARAM_TRAITS_H_
229