// Copyright (c) 2010 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. // // This file contains ParamTraits templates to support serialization of WebKit // data types over IPC. // // NOTE: IT IS IMPORTANT THAT ONLY POD (plain old data) TYPES ARE SERIALIZED. // // There are several reasons for this restrictions: // // o We don't want inclusion of this file to imply linking to WebKit code. // // o Many WebKit structures are not thread-safe. WebString, for example, // contains a reference counted buffer, which does not use thread-safe // reference counting. If we allowed serializing WebString, then we may run // the risk of introducing subtle thread-safety bugs if people passed a // WebString across threads via PostTask(NewRunnableMethod(...)). // // o The WebKit API has redundant types for strings, and we should avoid using // those beyond code that interfaces with the WebKit API. #ifndef CHROME_COMMON_WEBKIT_PARAM_TRAITS_H_ #define CHROME_COMMON_WEBKIT_PARAM_TRAITS_H_ #include "ipc/ipc_message_utils.h" #include "third_party/WebKit/WebKit/chromium/public/WebCache.h" #include "third_party/WebKit/WebKit/chromium/public/WebCompositionUnderline.h" #include "third_party/WebKit/WebKit/chromium/public/WebConsoleMessage.h" #include "third_party/WebKit/WebKit/chromium/public/WebContextMenuData.h" #include "third_party/WebKit/WebKit/chromium/public/WebDragOperation.h" #include "third_party/WebKit/WebKit/chromium/public/WebFindOptions.h" #include "third_party/WebKit/WebKit/chromium/public/WebInputEvent.h" #include "third_party/WebKit/WebKit/chromium/public/WebMediaPlayerAction.h" #include "third_party/WebKit/WebKit/chromium/public/WebPopupType.h" #include "third_party/WebKit/WebKit/chromium/public/WebScreenInfo.h" #include "third_party/WebKit/WebKit/chromium/public/WebTextDirection.h" #include "third_party/WebKit/WebKit/chromium/public/WebTextInputType.h" namespace IPC { template <> struct ParamTraits { typedef WebKit::WebRect param_type; static void Write(Message* m, const param_type& p) { WriteParam(m, p.x); WriteParam(m, p.y); WriteParam(m, p.width); WriteParam(m, p.height); } static bool Read(const Message* m, void** iter, param_type* p) { return ReadParam(m, iter, &p->x) && ReadParam(m, iter, &p->y) && ReadParam(m, iter, &p->width) && ReadParam(m, iter, &p->height); } static void Log(const param_type& p, std::wstring* l) { l->append(L"("); LogParam(p.x, l); l->append(L", "); LogParam(p.y, l); l->append(L", "); LogParam(p.width, l); l->append(L", "); LogParam(p.height, l); l->append(L")"); } }; template <> struct ParamTraits { typedef WebKit::WebScreenInfo param_type; static void Write(Message* m, const param_type& p) { WriteParam(m, p.depth); WriteParam(m, p.depthPerComponent); WriteParam(m, p.isMonochrome); WriteParam(m, p.rect); WriteParam(m, p.availableRect); } static bool Read(const Message* m, void** iter, param_type* p) { return ReadParam(m, iter, &p->depth) && ReadParam(m, iter, &p->depthPerComponent) && ReadParam(m, iter, &p->isMonochrome) && ReadParam(m, iter, &p->rect) && ReadParam(m, iter, &p->availableRect); } static void Log(const param_type& p, std::wstring* l) { l->append(L"("); LogParam(p.depth, l); l->append(L", "); LogParam(p.depthPerComponent, l); l->append(L", "); LogParam(p.isMonochrome, l); l->append(L", "); LogParam(p.rect, l); l->append(L", "); LogParam(p.availableRect, l); l->append(L")"); } }; template <> struct ParamTraits { typedef WebKit::WebConsoleMessage::Level param_type; static void Write(Message* m, const param_type& p) { WriteParam(m, static_cast(p)); } static bool Read(const Message* m, void** iter, param_type* r) { int value; if (!ReadParam(m, iter, &value)) return false; *r = static_cast(value); return true; } static void Log(const param_type& p, std::wstring* l) { LogParam(static_cast(p), l); } }; template <> struct ParamTraits { typedef WebKit::WebPopupType param_type; static void Write(Message* m, const param_type& p) { WriteParam(m, static_cast(p)); } static bool Read(const Message* m, void** iter, param_type* r) { int value; if (!ReadParam(m, iter, &value)) return false; *r = static_cast(value); return true; } static void Log(const param_type& p, std::wstring* l) { LogParam(static_cast(p), l); } }; template <> struct ParamTraits { typedef WebKit::WebFindOptions param_type; static void Write(Message* m, const param_type& p) { WriteParam(m, p.forward); WriteParam(m, p.matchCase); WriteParam(m, p.findNext); } static bool Read(const Message* m, void** iter, param_type* p) { return ReadParam(m, iter, &p->forward) && ReadParam(m, iter, &p->matchCase) && ReadParam(m, iter, &p->findNext); } static void Log(const param_type& p, std::wstring* l) { l->append(L"("); LogParam(p.forward, l); l->append(L", "); LogParam(p.matchCase, l); l->append(L", "); LogParam(p.findNext, l); l->append(L")"); } }; template <> struct ParamTraits { typedef WebKit::WebInputEvent::Type param_type; static void Write(Message* m, const param_type& p) { m->WriteInt(p); } static bool Read(const Message* m, void** iter, param_type* p) { int type; if (!m->ReadInt(iter, &type)) return false; *p = static_cast(type); return true; } static void Log(const param_type& p, std::wstring* l) { const wchar_t* type; switch (p) { case WebKit::WebInputEvent::MouseDown: type = L"MouseDown"; break; case WebKit::WebInputEvent::MouseUp: type = L"MouseUp"; break; case WebKit::WebInputEvent::MouseMove: type = L"MouseMove"; break; case WebKit::WebInputEvent::MouseLeave: type = L"MouseLeave"; break; case WebKit::WebInputEvent::MouseEnter: type = L"MouseEnter"; break; case WebKit::WebInputEvent::MouseWheel: type = L"MouseWheel"; break; case WebKit::WebInputEvent::RawKeyDown: type = L"RawKeyDown"; break; case WebKit::WebInputEvent::KeyDown: type = L"KeyDown"; break; case WebKit::WebInputEvent::KeyUp: type = L"KeyUp"; break; default: type = L"None"; break; } LogParam(std::wstring(type), l); } }; template <> struct ParamTraits { typedef WebKit::WebCache::UsageStats param_type; static void Write(Message* m, const param_type& p) { WriteParam(m, p.minDeadCapacity); WriteParam(m, p.maxDeadCapacity); WriteParam(m, p.capacity); WriteParam(m, p.liveSize); WriteParam(m, p.deadSize); } static bool Read(const Message* m, void** iter, param_type* r) { return ReadParam(m, iter, &r->minDeadCapacity) && ReadParam(m, iter, &r->maxDeadCapacity) && ReadParam(m, iter, &r->capacity) && ReadParam(m, iter, &r->liveSize) && ReadParam(m, iter, &r->deadSize); } static void Log(const param_type& p, std::wstring* l) { l->append(L""); } }; template <> struct ParamTraits { typedef WebKit::WebCache::ResourceTypeStat param_type; static void Write(Message* m, const param_type& p) { WriteParam(m, p.count); WriteParam(m, p.size); WriteParam(m, p.liveSize); WriteParam(m, p.decodedSize); } static bool Read(const Message* m, void** iter, param_type* r) { bool result = ReadParam(m, iter, &r->count) && ReadParam(m, iter, &r->size) && ReadParam(m, iter, &r->liveSize) && ReadParam(m, iter, &r->decodedSize); return result; } static void Log(const param_type& p, std::wstring* l) { l->append(StringPrintf(L"%d %d %d %d", p.count, p.size, p.liveSize, p.decodedSize)); } }; template <> struct ParamTraits { typedef WebKit::WebCache::ResourceTypeStats param_type; static void Write(Message* m, const param_type& p) { WriteParam(m, p.images); WriteParam(m, p.cssStyleSheets); WriteParam(m, p.scripts); WriteParam(m, p.xslStyleSheets); WriteParam(m, p.fonts); } static bool Read(const Message* m, void** iter, param_type* r) { bool result = ReadParam(m, iter, &r->images) && ReadParam(m, iter, &r->cssStyleSheets) && ReadParam(m, iter, &r->scripts) && ReadParam(m, iter, &r->xslStyleSheets) && ReadParam(m, iter, &r->fonts); return result; } static void Log(const param_type& p, std::wstring* l) { l->append(L""); LogParam(p.images, l); LogParam(p.cssStyleSheets, l); LogParam(p.scripts, l); LogParam(p.xslStyleSheets, l); LogParam(p.fonts, l); l->append(L""); } }; template <> struct ParamTraits { typedef WebKit::WebTextDirection param_type; static void Write(Message* m, const param_type& p) { WriteParam(m, static_cast(p)); } static bool Read(const Message* m, void** iter, param_type* r) { int value; if (!ReadParam(m, iter, &value)) return false; *r = static_cast(value); return true; } static void Log(const param_type& p, std::wstring* l) { LogParam(static_cast(p), l); } }; template <> struct ParamTraits { typedef WebKit::WebDragOperation param_type; static void Write(Message* m, const param_type& p) { m->WriteInt(p); } static bool Read(const Message* m, void** iter, param_type* r) { int temp; bool res = m->ReadInt(iter, &temp); *r = static_cast(temp); return res; } static void Log(const param_type& p, std::wstring* l) { l->append(StringPrintf(L"%d", p)); } }; template <> struct ParamTraits { typedef WebKit::WebMediaPlayerAction param_type; static void Write(Message* m, const param_type& p) { WriteParam(m, static_cast(p.type)); WriteParam(m, p.enable); } static bool Read(const Message* m, void** iter, param_type* r) { int temp; if (!ReadParam(m, iter, &temp)) return false; r->type = static_cast(temp); return ReadParam(m, iter, &r->enable); } static void Log(const param_type& p, std::wstring* l) { l->append(L"("); switch (p.type) { case WebKit::WebMediaPlayerAction::Play: l->append(L"Play"); break; case WebKit::WebMediaPlayerAction::Mute: l->append(L"Mute"); break; case WebKit::WebMediaPlayerAction::Loop: l->append(L"Loop"); break; default: l->append(L"Unknown"); break; } l->append(L", "); LogParam(p.enable, l); l->append(L")"); } }; template <> struct ParamTraits { typedef WebKit::WebContextMenuData::MediaType param_type; static void Write(Message* m, const param_type& p) { m->WriteInt(p); } static bool Read(const Message* m, void** iter, param_type* r) { int temp; bool res = m->ReadInt(iter, &temp); *r = static_cast(temp); return res; } }; template <> struct ParamTraits { typedef WebKit::WebCompositionUnderline param_type; static void Write(Message* m, const param_type& p) { WriteParam(m, p.startOffset); WriteParam(m, p.endOffset); WriteParam(m, p.color); WriteParam(m, p.thick); } static bool Read(const Message* m, void** iter, param_type* p) { return ReadParam(m, iter, &p->startOffset) && ReadParam(m, iter, &p->endOffset) && ReadParam(m, iter, &p->color) && ReadParam(m, iter, &p->thick); } static void Log(const param_type& p, std::wstring* l) { l->append(L"("); LogParam(p.startOffset, l); l->append(L","); LogParam(p.endOffset, l); l->append(L":"); LogParam(p.color, l); l->append(L":"); LogParam(p.thick, l); l->append(L")"); } }; template <> struct ParamTraits { typedef WebKit::WebTextInputType param_type; static void Write(Message* m, const param_type& p) { m->WriteInt(p); } static bool Read(const Message* m, void** iter, param_type* p) { int type; if (!m->ReadInt(iter, &type)) return false; *p = static_cast(type); return true; } static void Log(const param_type& p, std::wstring* l) { std::wstring control; switch (p) { case WebKit::WebTextInputTypeNone: control = L"WebKit::WebTextInputTypeNone"; break; case WebKit::WebTextInputTypeText: control = L"WebKit::WebTextInputTypeText"; break; case WebKit::WebTextInputTypePassword: control = L"WebKit::WebTextInputTypePassword"; break; default: NOTIMPLEMENTED(); control = L"UNKNOWN"; break; } LogParam(control, l); } }; } // namespace IPC #endif // CHROME_COMMON_WEBKIT_PARAM_TRAITS_H_