// Copyright (c) 2012 The Chromium Embedded Framework 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 "libcef/browser/context_menu_params_impl.h" #include "base/logging.h" CefContextMenuParamsImpl::CefContextMenuParamsImpl( content::ContextMenuParams* value) : CefValueBase( value, NULL, kOwnerNoDelete, true, new CefValueControllerNonThreadSafe()) { // Indicate that this object owns the controller. SetOwnsController(); } int CefContextMenuParamsImpl::GetXCoord() { CEF_VALUE_VERIFY_RETURN(false, 0); return const_value().x; } int CefContextMenuParamsImpl::GetYCoord() { CEF_VALUE_VERIFY_RETURN(false, 0); return const_value().y; } CefContextMenuParamsImpl::TypeFlags CefContextMenuParamsImpl::GetTypeFlags() { CEF_VALUE_VERIFY_RETURN(false, CM_TYPEFLAG_NONE); const content::ContextMenuParams& params = const_value(); int type_flags = CM_TYPEFLAG_NONE; if (!params.page_url.is_empty()) type_flags |= CM_TYPEFLAG_PAGE; if (!params.frame_url.is_empty()) type_flags |= CM_TYPEFLAG_FRAME; if (!params.link_url.is_empty()) type_flags |= CM_TYPEFLAG_LINK; if (params.media_type != blink::WebContextMenuData::MediaTypeNone) type_flags |= CM_TYPEFLAG_MEDIA; if (!params.selection_text.empty()) type_flags |= CM_TYPEFLAG_SELECTION; if (params.is_editable) type_flags |= CM_TYPEFLAG_EDITABLE; return static_cast(type_flags); } CefString CefContextMenuParamsImpl::GetLinkUrl() { CEF_VALUE_VERIFY_RETURN(false, CefString()); return const_value().link_url.spec(); } CefString CefContextMenuParamsImpl::GetUnfilteredLinkUrl() { CEF_VALUE_VERIFY_RETURN(false, CefString()); return const_value().unfiltered_link_url.spec(); } CefString CefContextMenuParamsImpl::GetSourceUrl() { CEF_VALUE_VERIFY_RETURN(false, CefString()); return const_value().src_url.spec(); } bool CefContextMenuParamsImpl::HasImageContents() { CEF_VALUE_VERIFY_RETURN(false, true); return const_value().has_image_contents; } CefString CefContextMenuParamsImpl::GetPageUrl() { CEF_VALUE_VERIFY_RETURN(false, CefString()); return const_value().page_url.spec(); } CefString CefContextMenuParamsImpl::GetFrameUrl() { CEF_VALUE_VERIFY_RETURN(false, CefString()); return const_value().frame_url.spec(); } CefString CefContextMenuParamsImpl::GetFrameCharset() { CEF_VALUE_VERIFY_RETURN(false, CefString()); return const_value().frame_charset; } CefContextMenuParamsImpl::MediaType CefContextMenuParamsImpl::GetMediaType() { CEF_VALUE_VERIFY_RETURN(false, CM_MEDIATYPE_NONE); return static_cast(const_value().media_type); } CefContextMenuParamsImpl::MediaStateFlags CefContextMenuParamsImpl::GetMediaStateFlags() { CEF_VALUE_VERIFY_RETURN(false, CM_MEDIAFLAG_NONE); return static_cast(const_value().media_flags); } CefString CefContextMenuParamsImpl::GetSelectionText() { CEF_VALUE_VERIFY_RETURN(false, CefString()); return const_value().selection_text; } CefString CefContextMenuParamsImpl::GetMisspelledWord() { CEF_VALUE_VERIFY_RETURN(false, CefString()); return const_value().misspelled_word; } bool CefContextMenuParamsImpl::GetDictionarySuggestions( std::vector& suggestions) { CEF_VALUE_VERIFY_RETURN(false, false); if (!suggestions.empty()) suggestions.clear(); if(const_value().dictionary_suggestions.empty()) return false; std::vector::const_iterator it = const_value().dictionary_suggestions.begin(); for (; it != const_value().dictionary_suggestions.end(); ++it) suggestions.push_back(*it); return true; } bool CefContextMenuParamsImpl::IsEditable() { CEF_VALUE_VERIFY_RETURN(false, false); return const_value().is_editable; } bool CefContextMenuParamsImpl::IsSpellCheckEnabled() { CEF_VALUE_VERIFY_RETURN(false, false); return const_value().spellcheck_enabled; } CefContextMenuParamsImpl::EditStateFlags CefContextMenuParamsImpl::GetEditStateFlags() { CEF_VALUE_VERIFY_RETURN(false, CM_EDITFLAG_NONE); return static_cast(const_value().edit_flags); }