blob: be20600c034aeeca97c01363f536bbf81860f2b5 [file] [log] [blame]
// 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.
#include "chrome/common/render_messages.h"
#include "base/values.h"
#include "chrome/common/edit_command.h"
#include "chrome/common/extensions/extension_extent.h"
#include "chrome/common/extensions/url_pattern.h"
#include "chrome/common/gpu_param_traits.h"
#include "chrome/common/indexed_db_key.h"
#include "chrome/common/indexed_db_param_traits.h"
#include "chrome/common/render_messages_params.h"
#include "chrome/common/resource_response.h"
#include "chrome/common/serialized_script_value.h"
#include "chrome/common/speech_input_result.h"
#include "chrome/common/thumbnail_score.h"
#include "chrome/common/web_apps.h"
#include "gfx/rect.h"
#include "ipc/ipc_channel_handle.h"
#include "media/audio/audio_buffers_state.h"
#include "net/base/upload_data.h"
#include "net/http/http_response_headers.h"
#include "third_party/WebKit/WebKit/chromium/public/WebCompositionUnderline.h"
#include "third_party/WebKit/WebKit/chromium/public/WebFindOptions.h"
#include "third_party/WebKit/WebKit/chromium/public/WebMediaPlayerAction.h"
#include "third_party/WebKit/WebKit/chromium/public/WebScreenInfo.h"
#include "third_party/skia/include/core/SkBitmap.h"
#include "webkit/appcache/appcache_interfaces.h"
#include "webkit/blob/blob_data.h"
#include "webkit/glue/context_menu.h"
#include "webkit/glue/form_data.h"
#include "webkit/glue/form_field.h"
#include "webkit/glue/password_form.h"
#include "webkit/glue/password_form_dom_manager.h"
#include "webkit/glue/plugins/webplugin.h"
#include "webkit/glue/plugins/webplugininfo.h"
#include "webkit/glue/resource_loader_bridge.h"
#include "webkit/glue/webaccessibility.h"
#include "webkit/glue/webcookie.h"
#include "webkit/glue/webcursor.h"
#include "webkit/glue/webdropdata.h"
#include "webkit/glue/webmenuitem.h"
#if defined(OS_MACOSX)
#include "chrome/common/font_descriptor_mac.h"
#endif
#define MESSAGES_INTERNAL_IMPL_FILE \
"chrome/common/render_messages_internal.h"
#include "ipc/ipc_message_impl_macros.h"
namespace IPC {
template<>
struct ParamTraits<WebMenuItem::Type> {
typedef WebMenuItem::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<WebMenuItem::Type>(type);
return true;
}
static void Log(const param_type& p, std::string* l) {
std::string type;
switch (p) {
case WebMenuItem::OPTION:
type = "OPTION";
break;
case WebMenuItem::GROUP:
type = "GROUP";
break;
case WebMenuItem::SEPARATOR:
type = "SEPARATOR";
break;
default:
type = "UNKNOWN";
break;
}
LogParam(type, l);
}
};
void ParamTraits<webkit_glue::FormField>::Write(Message* m,
const param_type& p) {
WriteParam(m, p.label());
WriteParam(m, p.name());
WriteParam(m, p.value());
WriteParam(m, p.form_control_type());
WriteParam(m, p.max_length());
WriteParam(m, p.is_autofilled());
WriteParam(m, p.option_strings());
}
bool ParamTraits<webkit_glue::FormField>::Read(const Message* m, void** iter,
param_type* p) {
string16 label, name, value, form_control_type;
int max_length = 0;
bool is_autofilled;
std::vector<string16> options;
bool result = ReadParam(m, iter, &label);
result = result && ReadParam(m, iter, &name);
result = result && ReadParam(m, iter, &value);
result = result && ReadParam(m, iter, &form_control_type);
result = result && ReadParam(m, iter, &max_length);
result = result && ReadParam(m, iter, &is_autofilled);
result = result && ReadParam(m, iter, &options);
if (!result)
return false;
p->set_label(label);
p->set_name(name);
p->set_value(value);
p->set_form_control_type(form_control_type);
p->set_max_length(max_length);
p->set_autofilled(is_autofilled);
p->set_option_strings(options);
return true;
}
void ParamTraits<webkit_glue::FormField>::Log(const param_type& p,
std::string* l) {
l->append("<FormField>");
}
#if defined(OS_MACOSX)
void ParamTraits<FontDescriptor>::Write(Message* m, const param_type& p) {
WriteParam(m, p.font_name);
WriteParam(m, p.font_point_size);
}
bool ParamTraits<FontDescriptor>::Read(const Message* m,
void** iter,
param_type* p) {
return(
ReadParam(m, iter, &p->font_name) &&
ReadParam(m, iter, &p->font_point_size));
}
void ParamTraits<FontDescriptor>::Log(const param_type& p, std::string* l) {
l->append("<FontDescriptor>");
}
#endif
void ParamTraits<ContextMenuParams>::Write(Message* m, const param_type& p) {
WriteParam(m, p.media_type);
WriteParam(m, p.x);
WriteParam(m, p.y);
WriteParam(m, p.link_url);
WriteParam(m, p.unfiltered_link_url);
WriteParam(m, p.src_url);
WriteParam(m, p.is_image_blocked);
WriteParam(m, p.page_url);
WriteParam(m, p.frame_url);
WriteParam(m, p.media_flags);
WriteParam(m, p.selection_text);
WriteParam(m, p.misspelled_word);
WriteParam(m, p.dictionary_suggestions);
WriteParam(m, p.spellcheck_enabled);
WriteParam(m, p.is_editable);
#if defined(OS_MACOSX)
WriteParam(m, p.writing_direction_default);
WriteParam(m, p.writing_direction_left_to_right);
WriteParam(m, p.writing_direction_right_to_left);
#endif // OS_MACOSX
WriteParam(m, p.edit_flags);
WriteParam(m, p.security_info);
WriteParam(m, p.frame_charset);
WriteParam(m, p.custom_items);
}
bool ParamTraits<ContextMenuParams>::Read(const Message* m, void** iter,
param_type* p) {
return
ReadParam(m, iter, &p->media_type) &&
ReadParam(m, iter, &p->x) &&
ReadParam(m, iter, &p->y) &&
ReadParam(m, iter, &p->link_url) &&
ReadParam(m, iter, &p->unfiltered_link_url) &&
ReadParam(m, iter, &p->src_url) &&
ReadParam(m, iter, &p->is_image_blocked) &&
ReadParam(m, iter, &p->page_url) &&
ReadParam(m, iter, &p->frame_url) &&
ReadParam(m, iter, &p->media_flags) &&
ReadParam(m, iter, &p->selection_text) &&
ReadParam(m, iter, &p->misspelled_word) &&
ReadParam(m, iter, &p->dictionary_suggestions) &&
ReadParam(m, iter, &p->spellcheck_enabled) &&
ReadParam(m, iter, &p->is_editable) &&
#if defined(OS_MACOSX)
ReadParam(m, iter, &p->writing_direction_default) &&
ReadParam(m, iter, &p->writing_direction_left_to_right) &&
ReadParam(m, iter, &p->writing_direction_right_to_left) &&
#endif // OS_MACOSX
ReadParam(m, iter, &p->edit_flags) &&
ReadParam(m, iter, &p->security_info) &&
ReadParam(m, iter, &p->frame_charset) &&
ReadParam(m, iter, &p->custom_items);
}
void ParamTraits<ContextMenuParams>::Log(const param_type& p,
std::string* l) {
l->append("<ContextMenuParams>");
}
void ParamTraits<webkit_glue::WebPluginGeometry>::Write(Message* m,
const param_type& p) {
WriteParam(m, p.window);
WriteParam(m, p.window_rect);
WriteParam(m, p.clip_rect);
WriteParam(m, p.cutout_rects);
WriteParam(m, p.rects_valid);
WriteParam(m, p.visible);
}
bool ParamTraits<webkit_glue::WebPluginGeometry>::Read(
const Message* m, void** iter, param_type* p) {
return
ReadParam(m, iter, &p->window) &&
ReadParam(m, iter, &p->window_rect) &&
ReadParam(m, iter, &p->clip_rect) &&
ReadParam(m, iter, &p->cutout_rects) &&
ReadParam(m, iter, &p->rects_valid) &&
ReadParam(m, iter, &p->visible);
}
void ParamTraits<webkit_glue::WebPluginGeometry>::Log(const param_type& p,
std::string* l) {
l->append("(");
LogParam(p.window, l);
l->append(", ");
LogParam(p.window_rect, l);
l->append(", ");
LogParam(p.clip_rect, l);
l->append(", ");
LogParam(p.cutout_rects, l);
l->append(", ");
LogParam(p.rects_valid, l);
l->append(", ");
LogParam(p.visible, l);
l->append(")");
}
void ParamTraits<WebPluginMimeType>::Write(Message* m, const param_type& p) {
WriteParam(m, p.mime_type);
WriteParam(m, p.file_extensions);
WriteParam(m, p.description);
}
bool ParamTraits<WebPluginMimeType>::Read(const Message* m, void** iter,
param_type* r) {
return
ReadParam(m, iter, &r->mime_type) &&
ReadParam(m, iter, &r->file_extensions) &&
ReadParam(m, iter, &r->description);
}
void ParamTraits<WebPluginMimeType>::Log(const param_type& p, std::string* l) {
l->append("(");
LogParam(p.mime_type, l);
l->append(", ");
LogParam(p.file_extensions, l);
l->append(", ");
LogParam(p.description, l);
l->append(")");
}
void ParamTraits<WebPluginInfo>::Write(Message* m, const param_type& p) {
WriteParam(m, p.name);
WriteParam(m, p.path);
WriteParam(m, p.version);
WriteParam(m, p.desc);
WriteParam(m, p.mime_types);
WriteParam(m, p.enabled);
}
bool ParamTraits<WebPluginInfo>::Read(const Message* m, void** iter,
param_type* r) {
return
ReadParam(m, iter, &r->name) &&
ReadParam(m, iter, &r->path) &&
ReadParam(m, iter, &r->version) &&
ReadParam(m, iter, &r->desc) &&
ReadParam(m, iter, &r->mime_types) &&
ReadParam(m, iter, &r->enabled);
}
void ParamTraits<WebPluginInfo>::Log(const param_type& p, std::string* l) {
l->append("(");
LogParam(p.name, l);
l->append(", ");
l->append(", ");
LogParam(p.path, l);
l->append(", ");
LogParam(p.version, l);
l->append(", ");
LogParam(p.desc, l);
l->append(", ");
LogParam(p.mime_types, l);
l->append(", ");
LogParam(p.enabled, l);
l->append(")");
}
void ParamTraits<webkit_glue::PasswordFormFillData>::Write(
Message* m, const param_type& p) {
WriteParam(m, p.basic_data);
WriteParam(m, p.additional_logins);
WriteParam(m, p.wait_for_username);
}
bool ParamTraits<webkit_glue::PasswordFormFillData>::Read(
const Message* m, void** iter, param_type* r) {
return
ReadParam(m, iter, &r->basic_data) &&
ReadParam(m, iter, &r->additional_logins) &&
ReadParam(m, iter, &r->wait_for_username);
}
void ParamTraits<webkit_glue::PasswordFormFillData>::Log(const param_type& p,
std::string* l) {
l->append("<PasswordFormFillData>");
}
void ParamTraits<scoped_refptr<net::HttpResponseHeaders> >::Write(
Message* m, const param_type& p) {
WriteParam(m, p.get() != NULL);
if (p) {
// Do not disclose Set-Cookie headers over IPC.
p->Persist(m, net::HttpResponseHeaders::PERSIST_SANS_COOKIES);
}
}
bool ParamTraits<scoped_refptr<net::HttpResponseHeaders> >::Read(
const Message* m, void** iter, param_type* r) {
bool has_object;
if (!ReadParam(m, iter, &has_object))
return false;
if (has_object)
*r = new net::HttpResponseHeaders(*m, iter);
return true;
}
void ParamTraits<scoped_refptr<net::HttpResponseHeaders> >::Log(
const param_type& p, std::string* l) {
l->append("<HttpResponseHeaders>");
}
void ParamTraits<webkit_glue::ResourceLoadTimingInfo>::Write(
Message* m, const param_type& p) {
WriteParam(m, p.base_time.is_null());
if (p.base_time.is_null())
return;
WriteParam(m, p.base_time);
WriteParam(m, p.proxy_start);
WriteParam(m, p.proxy_end);
WriteParam(m, p.dns_start);
WriteParam(m, p.dns_end);
WriteParam(m, p.connect_start);
WriteParam(m, p.connect_end);
WriteParam(m, p.ssl_start);
WriteParam(m, p.ssl_end);
WriteParam(m, p.send_start);
WriteParam(m, p.send_end);
WriteParam(m, p.receive_headers_start);
WriteParam(m, p.receive_headers_end);
}
bool ParamTraits<webkit_glue::ResourceLoadTimingInfo>::Read(
const Message* m, void** iter, param_type* r) {
bool is_null;
if (!ReadParam(m, iter, &is_null))
return false;
if (is_null)
return true;
return
ReadParam(m, iter, &r->base_time) &&
ReadParam(m, iter, &r->proxy_start) &&
ReadParam(m, iter, &r->proxy_end) &&
ReadParam(m, iter, &r->dns_start) &&
ReadParam(m, iter, &r->dns_end) &&
ReadParam(m, iter, &r->connect_start) &&
ReadParam(m, iter, &r->connect_end) &&
ReadParam(m, iter, &r->ssl_start) &&
ReadParam(m, iter, &r->ssl_end) &&
ReadParam(m, iter, &r->send_start) &&
ReadParam(m, iter, &r->send_end) &&
ReadParam(m, iter, &r->receive_headers_start) &&
ReadParam(m, iter, &r->receive_headers_end);
}
void ParamTraits<webkit_glue::ResourceLoadTimingInfo>::Log(const param_type& p,
std::string* l) {
l->append("(");
LogParam(p.base_time, l);
l->append(", ");
LogParam(p.proxy_start, l);
l->append(", ");
LogParam(p.proxy_end, l);
l->append(", ");
LogParam(p.dns_start, l);
l->append(", ");
LogParam(p.dns_end, l);
l->append(", ");
LogParam(p.connect_start, l);
l->append(", ");
LogParam(p.connect_end, l);
l->append(", ");
LogParam(p.ssl_start, l);
l->append(", ");
LogParam(p.ssl_end, l);
l->append(", ");
LogParam(p.send_start, l);
l->append(", ");
LogParam(p.send_end, l);
l->append(", ");
LogParam(p.receive_headers_start, l);
l->append(", ");
LogParam(p.receive_headers_end, l);
l->append(")");
}
void ParamTraits<scoped_refptr<webkit_glue::ResourceDevToolsInfo> >::Write(
Message* m, const param_type& p) {
WriteParam(m, p.get() != NULL);
if (p.get()) {
WriteParam(m, p->http_status_code);
WriteParam(m, p->http_status_text);
WriteParam(m, p->request_headers);
WriteParam(m, p->response_headers);
}
}
bool ParamTraits<scoped_refptr<webkit_glue::ResourceDevToolsInfo> >::Read(
const Message* m, void** iter, param_type* r) {
bool has_object;
if (!ReadParam(m, iter, &has_object))
return false;
if (!has_object)
return true;
*r = new webkit_glue::ResourceDevToolsInfo();
return
ReadParam(m, iter, &(*r)->http_status_code) &&
ReadParam(m, iter, &(*r)->http_status_text) &&
ReadParam(m, iter, &(*r)->request_headers) &&
ReadParam(m, iter, &(*r)->response_headers);
}
void ParamTraits<scoped_refptr<webkit_glue::ResourceDevToolsInfo> >::Log(
const param_type& p, std::string* l) {
l->append("(");
if (p) {
LogParam(p->request_headers, l);
l->append(", ");
LogParam(p->response_headers, l);
}
l->append(")");
}
void ParamTraits<webkit_glue::ResourceResponseInfo>::Write(
Message* m, const param_type& p) {
WriteParam(m, p.request_time);
WriteParam(m, p.response_time);
WriteParam(m, p.headers);
WriteParam(m, p.mime_type);
WriteParam(m, p.charset);
WriteParam(m, p.security_info);
WriteParam(m, p.content_length);
WriteParam(m, p.appcache_id);
WriteParam(m, p.appcache_manifest_url);
WriteParam(m, p.connection_id);
WriteParam(m, p.connection_reused);
WriteParam(m, p.load_timing);
WriteParam(m, p.devtools_info);
WriteParam(m, p.download_file_path);
WriteParam(m, p.was_fetched_via_spdy);
WriteParam(m, p.was_npn_negotiated);
WriteParam(m, p.was_alternate_protocol_available);
WriteParam(m, p.was_fetched_via_proxy);
}
bool ParamTraits<webkit_glue::ResourceResponseInfo>::Read(
const Message* m, void** iter, param_type* r) {
return
ReadParam(m, iter, &r->request_time) &&
ReadParam(m, iter, &r->response_time) &&
ReadParam(m, iter, &r->headers) &&
ReadParam(m, iter, &r->mime_type) &&
ReadParam(m, iter, &r->charset) &&
ReadParam(m, iter, &r->security_info) &&
ReadParam(m, iter, &r->content_length) &&
ReadParam(m, iter, &r->appcache_id) &&
ReadParam(m, iter, &r->appcache_manifest_url) &&
ReadParam(m, iter, &r->connection_id) &&
ReadParam(m, iter, &r->connection_reused) &&
ReadParam(m, iter, &r->load_timing) &&
ReadParam(m, iter, &r->devtools_info) &&
ReadParam(m, iter, &r->download_file_path) &&
ReadParam(m, iter, &r->was_fetched_via_spdy) &&
ReadParam(m, iter, &r->was_npn_negotiated) &&
ReadParam(m, iter, &r->was_alternate_protocol_available) &&
ReadParam(m, iter, &r->was_fetched_via_proxy);
}
void ParamTraits<webkit_glue::ResourceResponseInfo>::Log(
const param_type& p, std::string* l) {
l->append("(");
LogParam(p.request_time, l);
l->append(", ");
LogParam(p.response_time, l);
l->append(", ");
LogParam(p.headers, l);
l->append(", ");
LogParam(p.mime_type, l);
l->append(", ");
LogParam(p.charset, l);
l->append(", ");
LogParam(p.security_info, l);
l->append(", ");
LogParam(p.content_length, l);
l->append(", ");
LogParam(p.appcache_id, l);
l->append(", ");
LogParam(p.appcache_manifest_url, l);
l->append(", ");
LogParam(p.connection_id, l);
l->append(", ");
LogParam(p.connection_reused, l);
l->append(", ");
LogParam(p.load_timing, l);
l->append(", ");
LogParam(p.devtools_info, l);
l->append(", ");
LogParam(p.download_file_path, l);
l->append(", ");
LogParam(p.was_fetched_via_spdy, l);
l->append(", ");
LogParam(p.was_npn_negotiated, l);
l->append(", ");
LogParam(p.was_alternate_protocol_available, l);
l->append(", ");
LogParam(p.was_fetched_via_proxy, l);
l->append(")");
}
void ParamTraits<ResourceResponseHead>::Write(Message* m, const param_type& p) {
ParamTraits<webkit_glue::ResourceResponseInfo>::Write(m, p);
WriteParam(m, p.status);
WriteParam(m, p.replace_extension_localization_templates);
}
bool ParamTraits<ResourceResponseHead>::Read(const Message* m,
void** iter,
param_type* r) {
return ParamTraits<webkit_glue::ResourceResponseInfo>::Read(
m, iter, r) &&
ReadParam(m, iter, &r->status) &&
ReadParam(m, iter, &r->replace_extension_localization_templates);
}
void ParamTraits<ResourceResponseHead>::Log(const param_type& p,
std::string* l) {
// log more?
ParamTraits<webkit_glue::ResourceResponseInfo>::Log(p, l);
}
void ParamTraits<SyncLoadResult>::Write(Message* m, const param_type& p) {
ParamTraits<ResourceResponseHead>::Write(m, p);
WriteParam(m, p.final_url);
WriteParam(m, p.data);
}
bool ParamTraits<SyncLoadResult>::Read(const Message* m, void** iter,
param_type* r) {
return
ParamTraits<ResourceResponseHead>::Read(m, iter, r) &&
ReadParam(m, iter, &r->final_url) &&
ReadParam(m, iter, &r->data);
}
void ParamTraits<SyncLoadResult>::Log(const param_type& p, std::string* l) {
// log more?
ParamTraits<webkit_glue::ResourceResponseInfo>::Log(p, l);
}
void ParamTraits<webkit_glue::FormData>::Write(Message* m,
const param_type& p) {
WriteParam(m, p.name);
WriteParam(m, p.method);
WriteParam(m, p.origin);
WriteParam(m, p.action);
WriteParam(m, p.user_submitted);
WriteParam(m, p.fields);
}
bool ParamTraits<webkit_glue::FormData>::Read(const Message* m, void** iter,
param_type* p) {
return
ReadParam(m, iter, &p->name) &&
ReadParam(m, iter, &p->method) &&
ReadParam(m, iter, &p->origin) &&
ReadParam(m, iter, &p->action) &&
ReadParam(m, iter, &p->user_submitted) &&
ReadParam(m, iter, &p->fields);
}
void ParamTraits<webkit_glue::FormData>::Log(const param_type& p,
std::string* l) {
l->append("<FormData>");
}
void ParamTraits<RendererPreferences>::Write(Message* m, const param_type& p) {
WriteParam(m, p.can_accept_load_drops);
WriteParam(m, p.should_antialias_text);
WriteParam(m, static_cast<int>(p.hinting));
WriteParam(m, static_cast<int>(p.subpixel_rendering));
WriteParam(m, p.focus_ring_color);
WriteParam(m, p.thumb_active_color);
WriteParam(m, p.thumb_inactive_color);
WriteParam(m, p.track_color);
WriteParam(m, p.active_selection_bg_color);
WriteParam(m, p.active_selection_fg_color);
WriteParam(m, p.inactive_selection_bg_color);
WriteParam(m, p.inactive_selection_fg_color);
WriteParam(m, p.browser_handles_top_level_requests);
WriteParam(m, p.caret_blink_interval);
}
bool ParamTraits<RendererPreferences>::Read(const Message* m, void** iter,
param_type* p) {
if (!ReadParam(m, iter, &p->can_accept_load_drops))
return false;
if (!ReadParam(m, iter, &p->should_antialias_text))
return false;
int hinting = 0;
if (!ReadParam(m, iter, &hinting))
return false;
p->hinting = static_cast<RendererPreferencesHintingEnum>(hinting);
int subpixel_rendering = 0;
if (!ReadParam(m, iter, &subpixel_rendering))
return false;
p->subpixel_rendering =
static_cast<RendererPreferencesSubpixelRenderingEnum>(
subpixel_rendering);
int focus_ring_color;
if (!ReadParam(m, iter, &focus_ring_color))
return false;
p->focus_ring_color = focus_ring_color;
int thumb_active_color, thumb_inactive_color, track_color;
int active_selection_bg_color, active_selection_fg_color;
int inactive_selection_bg_color, inactive_selection_fg_color;
if (!ReadParam(m, iter, &thumb_active_color) ||
!ReadParam(m, iter, &thumb_inactive_color) ||
!ReadParam(m, iter, &track_color) ||
!ReadParam(m, iter, &active_selection_bg_color) ||
!ReadParam(m, iter, &active_selection_fg_color) ||
!ReadParam(m, iter, &inactive_selection_bg_color) ||
!ReadParam(m, iter, &inactive_selection_fg_color))
return false;
p->thumb_active_color = thumb_active_color;
p->thumb_inactive_color = thumb_inactive_color;
p->track_color = track_color;
p->active_selection_bg_color = active_selection_bg_color;
p->active_selection_fg_color = active_selection_fg_color;
p->inactive_selection_bg_color = inactive_selection_bg_color;
p->inactive_selection_fg_color = inactive_selection_fg_color;
if (!ReadParam(m, iter, &p->browser_handles_top_level_requests))
return false;
if (!ReadParam(m, iter, &p->caret_blink_interval))
return false;
return true;
}
void ParamTraits<RendererPreferences>::Log(const param_type& p,
std::string* l) {
l->append("<RendererPreferences>");
}
void ParamTraits<WebPreferences>::Write(Message* m, const param_type& p) {
WriteParam(m, p.standard_font_family);
WriteParam(m, p.fixed_font_family);
WriteParam(m, p.serif_font_family);
WriteParam(m, p.sans_serif_font_family);
WriteParam(m, p.cursive_font_family);
WriteParam(m, p.fantasy_font_family);
WriteParam(m, p.default_font_size);
WriteParam(m, p.default_fixed_font_size);
WriteParam(m, p.minimum_font_size);
WriteParam(m, p.minimum_logical_font_size);
WriteParam(m, p.default_encoding);
WriteParam(m, p.javascript_enabled);
WriteParam(m, p.web_security_enabled);
WriteParam(m, p.javascript_can_open_windows_automatically);
WriteParam(m, p.loads_images_automatically);
WriteParam(m, p.plugins_enabled);
WriteParam(m, p.dom_paste_enabled);
WriteParam(m, p.developer_extras_enabled);
WriteParam(m, p.inspector_settings);
WriteParam(m, p.site_specific_quirks_enabled);
WriteParam(m, p.shrinks_standalone_images_to_fit);
WriteParam(m, p.uses_universal_detector);
WriteParam(m, p.text_areas_are_resizable);
WriteParam(m, p.java_enabled);
WriteParam(m, p.allow_scripts_to_close_windows);
WriteParam(m, p.uses_page_cache);
WriteParam(m, p.remote_fonts_enabled);
WriteParam(m, p.javascript_can_access_clipboard);
WriteParam(m, p.xss_auditor_enabled);
WriteParam(m, p.local_storage_enabled);
WriteParam(m, p.databases_enabled);
WriteParam(m, p.application_cache_enabled);
WriteParam(m, p.tabs_to_links);
WriteParam(m, p.hyperlink_auditing_enabled);
WriteParam(m, p.user_style_sheet_enabled);
WriteParam(m, p.user_style_sheet_location);
WriteParam(m, p.author_and_user_styles_enabled);
WriteParam(m, p.frame_flattening_enabled);
WriteParam(m, p.allow_universal_access_from_file_urls);
WriteParam(m, p.allow_file_access_from_file_urls);
WriteParam(m, p.experimental_webgl_enabled);
WriteParam(m, p.show_composited_layer_borders);
WriteParam(m, p.accelerated_compositing_enabled);
WriteParam(m, p.accelerated_2d_canvas_enabled);
WriteParam(m, p.accelerated_layers_enabled);
WriteParam(m, p.memory_info_enabled);
}
bool ParamTraits<WebPreferences>::Read(const Message* m, void** iter,
param_type* p) {
return
ReadParam(m, iter, &p->standard_font_family) &&
ReadParam(m, iter, &p->fixed_font_family) &&
ReadParam(m, iter, &p->serif_font_family) &&
ReadParam(m, iter, &p->sans_serif_font_family) &&
ReadParam(m, iter, &p->cursive_font_family) &&
ReadParam(m, iter, &p->fantasy_font_family) &&
ReadParam(m, iter, &p->default_font_size) &&
ReadParam(m, iter, &p->default_fixed_font_size) &&
ReadParam(m, iter, &p->minimum_font_size) &&
ReadParam(m, iter, &p->minimum_logical_font_size) &&
ReadParam(m, iter, &p->default_encoding) &&
ReadParam(m, iter, &p->javascript_enabled) &&
ReadParam(m, iter, &p->web_security_enabled) &&
ReadParam(m, iter, &p->javascript_can_open_windows_automatically) &&
ReadParam(m, iter, &p->loads_images_automatically) &&
ReadParam(m, iter, &p->plugins_enabled) &&
ReadParam(m, iter, &p->dom_paste_enabled) &&
ReadParam(m, iter, &p->developer_extras_enabled) &&
ReadParam(m, iter, &p->inspector_settings) &&
ReadParam(m, iter, &p->site_specific_quirks_enabled) &&
ReadParam(m, iter, &p->shrinks_standalone_images_to_fit) &&
ReadParam(m, iter, &p->uses_universal_detector) &&
ReadParam(m, iter, &p->text_areas_are_resizable) &&
ReadParam(m, iter, &p->java_enabled) &&
ReadParam(m, iter, &p->allow_scripts_to_close_windows) &&
ReadParam(m, iter, &p->uses_page_cache) &&
ReadParam(m, iter, &p->remote_fonts_enabled) &&
ReadParam(m, iter, &p->javascript_can_access_clipboard) &&
ReadParam(m, iter, &p->xss_auditor_enabled) &&
ReadParam(m, iter, &p->local_storage_enabled) &&
ReadParam(m, iter, &p->databases_enabled) &&
ReadParam(m, iter, &p->application_cache_enabled) &&
ReadParam(m, iter, &p->tabs_to_links) &&
ReadParam(m, iter, &p->hyperlink_auditing_enabled) &&
ReadParam(m, iter, &p->user_style_sheet_enabled) &&
ReadParam(m, iter, &p->user_style_sheet_location) &&
ReadParam(m, iter, &p->author_and_user_styles_enabled) &&
ReadParam(m, iter, &p->frame_flattening_enabled) &&
ReadParam(m, iter, &p->allow_universal_access_from_file_urls) &&
ReadParam(m, iter, &p->allow_file_access_from_file_urls) &&
ReadParam(m, iter, &p->experimental_webgl_enabled) &&
ReadParam(m, iter, &p->show_composited_layer_borders) &&
ReadParam(m, iter, &p->accelerated_compositing_enabled) &&
ReadParam(m, iter, &p->accelerated_2d_canvas_enabled) &&
ReadParam(m, iter, &p->accelerated_layers_enabled) &&
ReadParam(m, iter, &p->memory_info_enabled);
}
void ParamTraits<WebPreferences>::Log(const param_type& p, std::string* l) {
l->append("<WebPreferences>");
}
void ParamTraits<WebDropData>::Write(Message* m, const param_type& p) {
WriteParam(m, p.identity);
WriteParam(m, p.url);
WriteParam(m, p.url_title);
WriteParam(m, p.download_metadata);
WriteParam(m, p.file_extension);
WriteParam(m, p.filenames);
WriteParam(m, p.plain_text);
WriteParam(m, p.text_html);
WriteParam(m, p.html_base_url);
WriteParam(m, p.file_description_filename);
WriteParam(m, p.file_contents);
}
bool ParamTraits<WebDropData>::Read(const Message* m, void** iter,
param_type* p) {
return
ReadParam(m, iter, &p->identity) &&
ReadParam(m, iter, &p->url) &&
ReadParam(m, iter, &p->url_title) &&
ReadParam(m, iter, &p->download_metadata) &&
ReadParam(m, iter, &p->file_extension) &&
ReadParam(m, iter, &p->filenames) &&
ReadParam(m, iter, &p->plain_text) &&
ReadParam(m, iter, &p->text_html) &&
ReadParam(m, iter, &p->html_base_url) &&
ReadParam(m, iter, &p->file_description_filename) &&
ReadParam(m, iter, &p->file_contents);
}
void ParamTraits<WebDropData>::Log(const param_type& p, std::string* l) {
l->append("<WebDropData>");
}
void ParamTraits<WebMenuItem>::Write(Message* m, const param_type& p) {
WriteParam(m, p.label);
WriteParam(m, p.type);
WriteParam(m, p.enabled);
WriteParam(m, p.checked);
WriteParam(m, p.action);
}
bool ParamTraits<WebMenuItem>::Read(const Message* m,
void** iter,
param_type* p) {
return
ReadParam(m, iter, &p->label) &&
ReadParam(m, iter, &p->type) &&
ReadParam(m, iter, &p->enabled) &&
ReadParam(m, iter, &p->checked) &&
ReadParam(m, iter, &p->action);
}
void ParamTraits<WebMenuItem>::Log(const param_type& p, std::string* l) {
l->append("(");
LogParam(p.label, l);
l->append(", ");
LogParam(p.type, l);
l->append(", ");
LogParam(p.enabled, l);
l->append(", ");
LogParam(p.checked, l);
l->append(", ");
LogParam(p.action, l);
l->append(")");
}
void ParamTraits<URLPattern>::Write(Message* m, const param_type& p) {
WriteParam(m, p.valid_schemes());
WriteParam(m, p.GetAsString());
}
bool ParamTraits<URLPattern>::Read(const Message* m, void** iter,
param_type* p) {
int valid_schemes;
std::string spec;
if (!ReadParam(m, iter, &valid_schemes) ||
!ReadParam(m, iter, &spec))
return false;
p->set_valid_schemes(valid_schemes);
return URLPattern::PARSE_SUCCESS == p->Parse(spec);
}
void ParamTraits<URLPattern>::Log(const param_type& p, std::string* l) {
LogParam(p.GetAsString(), l);
}
void ParamTraits<EditCommand>::Write(Message* m, const param_type& p) {
WriteParam(m, p.name);
WriteParam(m, p.value);
}
bool ParamTraits<EditCommand>::Read(const Message* m, void** iter,
param_type* p) {
return ReadParam(m, iter, &p->name) && ReadParam(m, iter, &p->value);
}
void ParamTraits<EditCommand>::Log(const param_type& p, std::string* l) {
l->append("(");
LogParam(p.name, l);
l->append(":");
LogParam(p.value, l);
l->append(")");
}
void ParamTraits<webkit_glue::WebCookie>::Write(Message* m,
const param_type& p) {
WriteParam(m, p.name);
WriteParam(m, p.value);
WriteParam(m, p.domain);
WriteParam(m, p.path);
WriteParam(m, p.expires);
WriteParam(m, p.http_only);
WriteParam(m, p.secure);
WriteParam(m, p.session);
}
bool ParamTraits<webkit_glue::WebCookie>::Read(const Message* m, void** iter,
param_type* p) {
return
ReadParam(m, iter, &p->name) &&
ReadParam(m, iter, &p->value) &&
ReadParam(m, iter, &p->domain) &&
ReadParam(m, iter, &p->path) &&
ReadParam(m, iter, &p->expires) &&
ReadParam(m, iter, &p->http_only) &&
ReadParam(m, iter, &p->secure) &&
ReadParam(m, iter, &p->session);
}
void ParamTraits<webkit_glue::WebCookie>::Log(const param_type& p,
std::string* l) {
l->append("<WebCookie>");
}
void ParamTraits<ExtensionExtent>::Write(Message* m, const param_type& p) {
WriteParam(m, p.patterns());
}
bool ParamTraits<ExtensionExtent>::Read(const Message* m, void** iter,
param_type* p) {
std::vector<URLPattern> patterns;
bool success =
ReadParam(m, iter, &patterns);
if (!success)
return false;
for (size_t i = 0; i < patterns.size(); ++i)
p->AddPattern(patterns[i]);
return true;
}
void ParamTraits<ExtensionExtent>::Log(const param_type& p, std::string* l) {
LogParam(p.patterns(), l);
}
void ParamTraits<appcache::AppCacheResourceInfo>::Write(Message* m,
const param_type& p) {
WriteParam(m, p.url);
WriteParam(m, p.size);
WriteParam(m, p.is_manifest);
WriteParam(m, p.is_master);
WriteParam(m, p.is_fallback);
WriteParam(m, p.is_foreign);
WriteParam(m, p.is_explicit);
}
bool ParamTraits<appcache::AppCacheResourceInfo>::Read(
const Message* m, void** iter, param_type* p) {
return ReadParam(m, iter, &p->url) &&
ReadParam(m, iter, &p->size) &&
ReadParam(m, iter, &p->is_manifest) &&
ReadParam(m, iter, &p->is_master) &&
ReadParam(m, iter, &p->is_fallback) &&
ReadParam(m, iter, &p->is_foreign) &&
ReadParam(m, iter, &p->is_explicit);
}
void ParamTraits<appcache::AppCacheResourceInfo>::Log(const param_type& p,
std::string* l) {
l->append("(");
LogParam(p.url, l);
l->append(", ");
LogParam(p.size, l);
l->append(", ");
LogParam(p.is_manifest, l);
l->append(", ");
LogParam(p.is_master, l);
l->append(", ");
LogParam(p.is_fallback, l);
l->append(", ");
LogParam(p.is_foreign, l);
l->append(", ");
LogParam(p.is_explicit, l);
l->append(")");
}
void ParamTraits<appcache::AppCacheInfo>::Write(Message* m,
const param_type& p) {
WriteParam(m, p.manifest_url);
WriteParam(m, p.creation_time);
WriteParam(m, p.last_update_time);
WriteParam(m, p.last_access_time);
WriteParam(m, p.cache_id);
WriteParam(m, p.status);
WriteParam(m, p.size);
WriteParam(m, p.is_complete);
}
bool ParamTraits<appcache::AppCacheInfo>::Read(const Message* m, void** iter,
param_type* p) {
return ReadParam(m, iter, &p->manifest_url) &&
ReadParam(m, iter, &p->creation_time) &&
ReadParam(m, iter, &p->last_update_time) &&
ReadParam(m, iter, &p->last_access_time) &&
ReadParam(m, iter, &p->cache_id) &&
ReadParam(m, iter, &p->status) &&
ReadParam(m, iter, &p->size) &&
ReadParam(m, iter, &p->is_complete);
}
void ParamTraits<appcache::AppCacheInfo>::Log(const param_type& p,
std::string* l) {
l->append("(");
LogParam(p.manifest_url, l);
l->append(", ");
LogParam(p.creation_time, l);
l->append(", ");
LogParam(p.last_update_time, l);
l->append(", ");
LogParam(p.last_access_time, l);
l->append(", ");
LogParam(p.cache_id, l);
l->append(", ");
LogParam(p.status, l);
l->append(", ");
LogParam(p.size, l);
l->append(")");
LogParam(p.is_complete, l);
l->append(", ");
}
void ParamTraits<webkit_glue::WebAccessibility>::Write(Message* m,
const param_type& p) {
WriteParam(m, p.id);
WriteParam(m, p.name);
WriteParam(m, p.value);
WriteParam(m, static_cast<int>(p.role));
WriteParam(m, static_cast<int>(p.state));
WriteParam(m, p.location);
WriteParam(m, p.attributes);
WriteParam(m, p.children);
WriteParam(m, p.html_attributes);
}
bool ParamTraits<webkit_glue::WebAccessibility>::Read(
const Message* m, void** iter, param_type* p) {
bool ret = ReadParam(m, iter, &p->id);
ret = ret && ReadParam(m, iter, &p->name);
ret = ret && ReadParam(m, iter, &p->value);
int role = -1;
ret = ret && ReadParam(m, iter, &role);
if (role >= webkit_glue::WebAccessibility::ROLE_NONE &&
role < webkit_glue::WebAccessibility::NUM_ROLES) {
p->role = static_cast<webkit_glue::WebAccessibility::Role>(role);
} else {
p->role = webkit_glue::WebAccessibility::ROLE_NONE;
}
int state = 0;
ret = ret && ReadParam(m, iter, &state);
p->state = static_cast<webkit_glue::WebAccessibility::State>(state);
ret = ret && ReadParam(m, iter, &p->location);
ret = ret && ReadParam(m, iter, &p->attributes);
ret = ret && ReadParam(m, iter, &p->children);
ret = ret && ReadParam(m, iter, &p->html_attributes);
return ret;
}
void ParamTraits<webkit_glue::WebAccessibility>::Log(const param_type& p,
std::string* l) {
l->append("(");
LogParam(p.id, l);
l->append(", ");
LogParam(p.name, l);
l->append(", ");
LogParam(p.value, l);
l->append(", ");
LogParam(static_cast<int>(p.role), l);
l->append(", ");
LogParam(static_cast<int>(p.state), l);
l->append(", ");
LogParam(p.location, l);
l->append(", ");
LogParam(p.attributes, l);
l->append(", ");
LogParam(p.children, l);
l->append(", ");
LogParam(p.html_attributes, l);
l->append(")");
}
// Only the webkit_blob::BlobData ParamTraits<> definition needs this
// definition, so keep this in the implementation file so we can forward declare
// BlobData in the header.
template <>
struct ParamTraits<webkit_blob::BlobData::Item> {
typedef webkit_blob::BlobData::Item param_type;
static void Write(Message* m, const param_type& p) {
WriteParam(m, static_cast<int>(p.type()));
if (p.type() == webkit_blob::BlobData::TYPE_DATA) {
WriteParam(m, p.data());
} else if (p.type() == webkit_blob::BlobData::TYPE_FILE) {
WriteParam(m, p.file_path());
WriteParam(m, p.offset());
WriteParam(m, p.length());
WriteParam(m, p.expected_modification_time());
} else {
WriteParam(m, p.blob_url());
WriteParam(m, p.offset());
WriteParam(m, p.length());
}
}
static bool Read(const Message* m, void** iter, param_type* r) {
int type;
if (!ReadParam(m, iter, &type))
return false;
if (type == webkit_blob::BlobData::TYPE_DATA) {
std::string data;
if (!ReadParam(m, iter, &data))
return false;
r->SetToData(data);
} else if (type == webkit_blob::BlobData::TYPE_FILE) {
FilePath file_path;
uint64 offset, length;
base::Time expected_modification_time;
if (!ReadParam(m, iter, &file_path))
return false;
if (!ReadParam(m, iter, &offset))
return false;
if (!ReadParam(m, iter, &length))
return false;
if (!ReadParam(m, iter, &expected_modification_time))
return false;
r->SetToFile(file_path, offset, length, expected_modification_time);
} else {
DCHECK(type == webkit_blob::BlobData::TYPE_BLOB);
GURL blob_url;
uint64 offset, length;
if (!ReadParam(m, iter, &blob_url))
return false;
if (!ReadParam(m, iter, &offset))
return false;
if (!ReadParam(m, iter, &length))
return false;
r->SetToBlob(blob_url, offset, length);
}
return true;
}
static void Log(const param_type& p, std::string* l) {
l->append("<BlobData::Item>");
}
};
void ParamTraits<scoped_refptr<webkit_blob::BlobData> >::Write(
Message* m, const param_type& p) {
WriteParam(m, p.get() != NULL);
if (p) {
WriteParam(m, p->items());
WriteParam(m, p->content_type());
WriteParam(m, p->content_disposition());
}
}
bool ParamTraits<scoped_refptr<webkit_blob::BlobData> >::Read(
const Message* m, void** iter, param_type* r) {
bool has_object;
if (!ReadParam(m, iter, &has_object))
return false;
if (!has_object)
return true;
std::vector<webkit_blob::BlobData::Item> items;
if (!ReadParam(m, iter, &items))
return false;
std::string content_type;
if (!ReadParam(m, iter, &content_type))
return false;
std::string content_disposition;
if (!ReadParam(m, iter, &content_disposition))
return false;
*r = new webkit_blob::BlobData;
(*r)->swap_items(&items);
(*r)->set_content_type(content_type);
(*r)->set_content_disposition(content_disposition);
return true;
}
void ParamTraits<scoped_refptr<webkit_blob::BlobData> >::Log(
const param_type& p, std::string* l) {
l->append("<webkit_blob::BlobData>");
}
void ParamTraits<AudioBuffersState>::Write(Message* m, const param_type& p) {
WriteParam(m, p.pending_bytes);
WriteParam(m, p.hardware_delay_bytes);
WriteParam(m, p.timestamp);
}
bool ParamTraits<AudioBuffersState>::Read(const Message* m,
void** iter,
param_type* p) {
return
ReadParam(m, iter, &p->pending_bytes) &&
ReadParam(m, iter, &p->hardware_delay_bytes) &&
ReadParam(m, iter, &p->timestamp);
}
void ParamTraits<AudioBuffersState>::Log(const param_type& p, std::string* l) {
l->append("(");
LogParam(p.pending_bytes, l);
l->append(", ");
LogParam(p.hardware_delay_bytes, l);
l->append(", ");
LogParam(p.timestamp, l);
l->append(")");
}
void ParamTraits<PepperDirEntry>::Write(Message* m, const param_type& p) {
WriteParam(m, p.name);
WriteParam(m, p.is_dir);
}
bool ParamTraits<PepperDirEntry>::Read(const Message* m,
void** iter,
param_type* p) {
return ReadParam(m, iter, &p->name) &&
ReadParam(m, iter, &p->is_dir);
}
void ParamTraits<PepperDirEntry>::Log(const param_type& p, std::string* l) {
l->append("(");
LogParam(p.name, l);
l->append(", ");
LogParam(p.is_dir, l);
l->append(")");
}
void ParamTraits<speech_input::SpeechInputResultItem>::Write(
Message* m, const param_type& p) {
WriteParam(m, p.utterance);
WriteParam(m, p.confidence);
}
bool ParamTraits<speech_input::SpeechInputResultItem>::Read(const Message* m,
void** iter,
param_type* p) {
return ReadParam(m, iter, &p->utterance) &&
ReadParam(m, iter, &p->confidence);
}
void ParamTraits<speech_input::SpeechInputResultItem>::Log(const param_type& p,
std::string* l) {
l->append("(");
LogParam(p.utterance, l);
l->append(":");
LogParam(p.confidence, l);
l->append(")");
}
} // namespace IPC