// Copyright (c) 2009 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 "webkit/api/public/WebCache.h" #include "webkit/api/public/WebCompositionCommand.h" #include "webkit/api/public/WebConsoleMessage.h" #include "webkit/api/public/WebFindOptions.h" #include "webkit/api/public/WebInputEvent.h" #include "webkit/api/public/WebScreenInfo.h" #include "webkit/api/public/WebTextDirection.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::WebCompositionCommand 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::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::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); } }; } // namespace IPC #endif // CHROME_COMMON_WEBKIT_PARAM_TRAITS_H_