mirror of
https://bitbucket.org/chromiumembedded/cef
synced 2025-06-05 21:39:12 +02:00
Add DLL build support and wrapper that allows clients to transparently switch between static and dynamic CEF builds.
- The libcef project now builds libcef_static.lib instead of libcef.lib. - The libcef_dll project builds libcef.lib and libcef.dll. This DLL exports the new CEF C API defined in cef_capi.h, cef_nplugin_capi.h, cef_string.h and cef_string_map.h. - The libcef_dll_wrapper project builds libcef_dll_wrapper.lib. This static library wraps the new C API calls with an implementation of the CEF C++ interface as defined in cef.h and cef_nplugin.h. - The cefclient project now uses the DLL instead of the static library. - Type definitions have been moved from cef.h to cef_types.h so that they can be shared by both cef.h and cef_capi.h. This change required some enumeration member name modifications throughout the code base. - Fixed variable naming inconsistencies. - Added CefVariant::GetArraySize() method and _NPN_ArrayObjectGetVectorSize() function. - Remove the ProjectSection(WebsiteProperties) sections from cef.sln to improve VS2005 performance. git-svn-id: https://chromiumembedded.googlecode.com/svn/trunk@16 5089003a-bbd8-11dd-ad1f-f1f9622dbc98
This commit is contained in:
497
libcef_dll/cpptoc/browser_cpptoc.cc
Normal file
497
libcef_dll/cpptoc/browser_cpptoc.cc
Normal file
@ -0,0 +1,497 @@
|
||||
// Copyright (c) 2009 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 "../precompiled_libcef.h"
|
||||
#include "cpptoc/browser_cpptoc.h"
|
||||
#include "cpptoc/request_cpptoc.h"
|
||||
#include "cpptoc/stream_cpptoc.h"
|
||||
#include "ctocpp/handler_ctocpp.h"
|
||||
#include "ctocpp/jshandler_ctocpp.h"
|
||||
#include "base/logging.h"
|
||||
|
||||
int CEF_CALLBACK browser_can_go_back(cef_browser_t* browser)
|
||||
{
|
||||
DCHECK(browser);
|
||||
if(!browser)
|
||||
return 0;
|
||||
|
||||
CefBrowserCppToC::Struct* impl =
|
||||
reinterpret_cast<CefBrowserCppToC::Struct*>(browser);
|
||||
return impl->class_->GetClass()->CanGoBack();
|
||||
}
|
||||
|
||||
void CEF_CALLBACK browser_go_back(cef_browser_t* browser)
|
||||
{
|
||||
DCHECK(browser);
|
||||
if(!browser)
|
||||
return;
|
||||
|
||||
CefBrowserCppToC::Struct* impl =
|
||||
reinterpret_cast<CefBrowserCppToC::Struct*>(browser);
|
||||
impl->class_->GetClass()->GoBack();
|
||||
}
|
||||
|
||||
int CEF_CALLBACK browser_can_go_forward(cef_browser_t* browser)
|
||||
{
|
||||
DCHECK(browser);
|
||||
if(!browser)
|
||||
return 0;
|
||||
|
||||
CefBrowserCppToC::Struct* impl =
|
||||
reinterpret_cast<CefBrowserCppToC::Struct*>(browser);
|
||||
return impl->class_->GetClass()->CanGoForward();
|
||||
}
|
||||
|
||||
void CEF_CALLBACK browser_go_forward(cef_browser_t* browser)
|
||||
{
|
||||
DCHECK(browser);
|
||||
if(!browser)
|
||||
return;
|
||||
|
||||
CefBrowserCppToC::Struct* impl =
|
||||
reinterpret_cast<CefBrowserCppToC::Struct*>(browser);
|
||||
impl->class_->GetClass()->GoForward();
|
||||
}
|
||||
|
||||
void CEF_CALLBACK browser_reload(cef_browser_t* browser)
|
||||
{
|
||||
DCHECK(browser);
|
||||
if(!browser)
|
||||
return;
|
||||
|
||||
CefBrowserCppToC::Struct* impl =
|
||||
reinterpret_cast<CefBrowserCppToC::Struct*>(browser);
|
||||
impl->class_->GetClass()->Reload();
|
||||
}
|
||||
|
||||
void CEF_CALLBACK browser_stop_load(cef_browser_t* browser)
|
||||
{
|
||||
DCHECK(browser);
|
||||
if(!browser)
|
||||
return;
|
||||
|
||||
CefBrowserCppToC::Struct* impl =
|
||||
reinterpret_cast<CefBrowserCppToC::Struct*>(browser);
|
||||
impl->class_->GetClass()->StopLoad();
|
||||
}
|
||||
|
||||
void CEF_CALLBACK browser_undo(cef_browser_t* browser,
|
||||
enum cef_targetframe_t targetFrame)
|
||||
{
|
||||
DCHECK(browser);
|
||||
if(!browser)
|
||||
return;
|
||||
|
||||
CefBrowserCppToC::Struct* impl =
|
||||
reinterpret_cast<CefBrowserCppToC::Struct*>(browser);
|
||||
impl->class_->GetClass()->Undo(targetFrame);
|
||||
}
|
||||
|
||||
void CEF_CALLBACK browser_redo(cef_browser_t* browser,
|
||||
enum cef_targetframe_t targetFrame)
|
||||
{
|
||||
DCHECK(browser);
|
||||
if(!browser)
|
||||
return;
|
||||
|
||||
CefBrowserCppToC::Struct* impl =
|
||||
reinterpret_cast<CefBrowserCppToC::Struct*>(browser);
|
||||
impl->class_->GetClass()->Redo(targetFrame);
|
||||
}
|
||||
|
||||
void CEF_CALLBACK browser_cut(cef_browser_t* browser,
|
||||
enum cef_targetframe_t targetFrame)
|
||||
{
|
||||
DCHECK(browser);
|
||||
if(!browser)
|
||||
return;
|
||||
|
||||
CefBrowserCppToC::Struct* impl =
|
||||
reinterpret_cast<CefBrowserCppToC::Struct*>(browser);
|
||||
impl->class_->GetClass()->Cut(targetFrame);
|
||||
}
|
||||
|
||||
void CEF_CALLBACK browser_copy(cef_browser_t* browser,
|
||||
enum cef_targetframe_t targetFrame)
|
||||
{
|
||||
DCHECK(browser);
|
||||
if(!browser)
|
||||
return;
|
||||
|
||||
CefBrowserCppToC::Struct* impl =
|
||||
reinterpret_cast<CefBrowserCppToC::Struct*>(browser);
|
||||
impl->class_->GetClass()->Copy(targetFrame);
|
||||
}
|
||||
|
||||
void CEF_CALLBACK browser_paste(cef_browser_t* browser,
|
||||
enum cef_targetframe_t targetFrame)
|
||||
{
|
||||
DCHECK(browser);
|
||||
if(!browser)
|
||||
return;
|
||||
|
||||
CefBrowserCppToC::Struct* impl =
|
||||
reinterpret_cast<CefBrowserCppToC::Struct*>(browser);
|
||||
impl->class_->GetClass()->Paste(targetFrame);
|
||||
}
|
||||
|
||||
void CEF_CALLBACK browser_delete(cef_browser_t* browser,
|
||||
enum cef_targetframe_t targetFrame)
|
||||
{
|
||||
DCHECK(browser);
|
||||
if(!browser)
|
||||
return;
|
||||
|
||||
CefBrowserCppToC::Struct* impl =
|
||||
reinterpret_cast<CefBrowserCppToC::Struct*>(browser);
|
||||
impl->class_->GetClass()->Delete(targetFrame);
|
||||
}
|
||||
|
||||
void CEF_CALLBACK browser_select_all(cef_browser_t* browser,
|
||||
enum cef_targetframe_t targetFrame)
|
||||
{
|
||||
DCHECK(browser);
|
||||
if(!browser)
|
||||
return;
|
||||
|
||||
CefBrowserCppToC::Struct* impl =
|
||||
reinterpret_cast<CefBrowserCppToC::Struct*>(browser);
|
||||
impl->class_->GetClass()->SelectAll(targetFrame);
|
||||
}
|
||||
|
||||
void CEF_CALLBACK browser_print(cef_browser_t* browser,
|
||||
enum cef_targetframe_t targetFrame)
|
||||
{
|
||||
DCHECK(browser);
|
||||
if(!browser)
|
||||
return;
|
||||
|
||||
CefBrowserCppToC::Struct* impl =
|
||||
reinterpret_cast<CefBrowserCppToC::Struct*>(browser);
|
||||
impl->class_->GetClass()->Print(targetFrame);
|
||||
}
|
||||
|
||||
void CEF_CALLBACK browser_view_source(cef_browser_t* browser,
|
||||
enum cef_targetframe_t targetFrame)
|
||||
{
|
||||
DCHECK(browser);
|
||||
if(!browser)
|
||||
return;
|
||||
|
||||
CefBrowserCppToC::Struct* impl =
|
||||
reinterpret_cast<CefBrowserCppToC::Struct*>(browser);
|
||||
impl->class_->GetClass()->ViewSource(targetFrame);
|
||||
}
|
||||
|
||||
cef_string_t CEF_CALLBACK browser_get_source(cef_browser_t* browser,
|
||||
enum cef_targetframe_t targetFrame)
|
||||
{
|
||||
DCHECK(browser);
|
||||
if(!browser)
|
||||
return NULL;
|
||||
|
||||
CefBrowserCppToC::Struct* impl =
|
||||
reinterpret_cast<CefBrowserCppToC::Struct*>(browser);
|
||||
|
||||
std::wstring sourceStr = impl->class_->GetClass()->GetSource(targetFrame);
|
||||
if(sourceStr.empty())
|
||||
return NULL;
|
||||
return cef_string_alloc(sourceStr.c_str());
|
||||
}
|
||||
|
||||
cef_string_t CEF_CALLBACK browser_get_text(cef_browser_t* browser,
|
||||
enum cef_targetframe_t targetFrame)
|
||||
{
|
||||
DCHECK(browser);
|
||||
if(!browser)
|
||||
return NULL;
|
||||
|
||||
CefBrowserCppToC::Struct* impl =
|
||||
reinterpret_cast<CefBrowserCppToC::Struct*>(browser);
|
||||
|
||||
std::wstring textStr = impl->class_->GetClass()->GetText(targetFrame);
|
||||
if(textStr.empty())
|
||||
return NULL;
|
||||
return cef_string_alloc(textStr.c_str());
|
||||
}
|
||||
|
||||
void CEF_CALLBACK browser_load_request(cef_browser_t* browser,
|
||||
cef_request_t* request)
|
||||
{
|
||||
DCHECK(browser);
|
||||
DCHECK(request);
|
||||
if(!browser || !request)
|
||||
return;
|
||||
|
||||
CefBrowserCppToC::Struct* impl =
|
||||
reinterpret_cast<CefBrowserCppToC::Struct*>(browser);
|
||||
|
||||
CefRequestCppToC::Struct* structPtr =
|
||||
reinterpret_cast<CefRequestCppToC::Struct*>(request);
|
||||
CefRefPtr<CefRequest> requestPtr(structPtr->class_->GetClass());
|
||||
structPtr->class_->Release();
|
||||
impl->class_->GetClass()->LoadRequest(requestPtr);
|
||||
}
|
||||
|
||||
void CEF_CALLBACK browser_load_url(cef_browser_t* browser, const wchar_t* url,
|
||||
const wchar_t* frame)
|
||||
{
|
||||
DCHECK(browser);
|
||||
if(!browser)
|
||||
return;
|
||||
|
||||
CefBrowserCppToC::Struct* impl =
|
||||
reinterpret_cast<CefBrowserCppToC::Struct*>(browser);
|
||||
|
||||
std::wstring urlStr, frameStr;
|
||||
if(url)
|
||||
urlStr = url;
|
||||
if(frame)
|
||||
frameStr = frame;
|
||||
impl->class_->GetClass()->LoadURL(urlStr, frameStr);
|
||||
}
|
||||
|
||||
void CEF_CALLBACK browser_load_string(cef_browser_t* browser,
|
||||
const wchar_t* string,
|
||||
const wchar_t* url)
|
||||
{
|
||||
DCHECK(browser);
|
||||
if(!browser)
|
||||
return;
|
||||
|
||||
CefBrowserCppToC::Struct* impl =
|
||||
reinterpret_cast<CefBrowserCppToC::Struct*>(browser);
|
||||
|
||||
std::wstring stringStr, urlStr;
|
||||
if(string)
|
||||
stringStr = string;
|
||||
if(url)
|
||||
urlStr = url;
|
||||
impl->class_->GetClass()->LoadString(stringStr, urlStr);
|
||||
}
|
||||
|
||||
void CEF_CALLBACK browser_load_stream(cef_browser_t* browser,
|
||||
cef_stream_reader_t* stream,
|
||||
const wchar_t* url)
|
||||
{
|
||||
DCHECK(browser);
|
||||
DCHECK(stream);
|
||||
if(!browser || !stream)
|
||||
return;
|
||||
|
||||
CefBrowserCppToC::Struct* impl =
|
||||
reinterpret_cast<CefBrowserCppToC::Struct*>(browser);
|
||||
|
||||
CefStreamReaderCppToC::Struct* structPtr =
|
||||
reinterpret_cast<CefStreamReaderCppToC::Struct*>(stream);
|
||||
CefRefPtr<CefStreamReader> streamPtr(structPtr->class_->GetClass());
|
||||
structPtr->class_->Release();
|
||||
|
||||
std::wstring urlStr;
|
||||
if(url)
|
||||
urlStr = url;
|
||||
impl->class_->GetClass()->LoadStream(streamPtr, urlStr);
|
||||
}
|
||||
|
||||
void CEF_CALLBACK browser_execute_javascript(cef_browser_t* browser,
|
||||
const wchar_t* jsCode,
|
||||
const wchar_t* scriptUrl,
|
||||
int startLine,
|
||||
enum cef_targetframe_t targetFrame)
|
||||
{
|
||||
DCHECK(browser);
|
||||
if(!browser)
|
||||
return;
|
||||
|
||||
CefBrowserCppToC::Struct* impl =
|
||||
reinterpret_cast<CefBrowserCppToC::Struct*>(browser);
|
||||
|
||||
std::wstring jsCodeStr, scriptUrlStr;
|
||||
if(jsCode)
|
||||
jsCodeStr = jsCode;
|
||||
if(scriptUrl)
|
||||
scriptUrlStr = scriptUrl;
|
||||
|
||||
impl->class_->GetClass()->ExecuteJavaScript(jsCodeStr, scriptUrlStr,
|
||||
startLine, targetFrame);
|
||||
}
|
||||
|
||||
int CEF_CALLBACK browser_add_jshandler(cef_browser_t* browser,
|
||||
const wchar_t* classname,
|
||||
cef_jshandler_t* handler)
|
||||
{
|
||||
DCHECK(browser);
|
||||
DCHECK(handler);
|
||||
if(!browser || !handler)
|
||||
return 0;
|
||||
|
||||
CefBrowserCppToC::Struct* impl =
|
||||
reinterpret_cast<CefBrowserCppToC::Struct*>(browser);
|
||||
|
||||
CefJSHandlerCToCpp* hp = new CefJSHandlerCToCpp(handler);
|
||||
CefRefPtr<CefJSHandler> handlerPtr(hp);
|
||||
hp->UnderlyingRelease();
|
||||
|
||||
std::wstring classnameStr;
|
||||
if(classname)
|
||||
classnameStr = classname;
|
||||
return impl->class_->GetClass()->AddJSHandler(classnameStr, handlerPtr);
|
||||
}
|
||||
|
||||
int CEF_CALLBACK browser_has_jshandler(cef_browser_t* browser,
|
||||
const wchar_t* classname)
|
||||
{
|
||||
DCHECK(browser);
|
||||
if(!browser)
|
||||
return 0;
|
||||
|
||||
CefBrowserCppToC::Struct* impl =
|
||||
reinterpret_cast<CefBrowserCppToC::Struct*>(browser);
|
||||
|
||||
std::wstring classnameStr;
|
||||
if(classname)
|
||||
classnameStr = classname;
|
||||
return impl->class_->GetClass()->HasJSHandler(classnameStr);
|
||||
}
|
||||
|
||||
cef_jshandler_t* CEF_CALLBACK browser_get_jshandler(cef_browser_t* browser,
|
||||
const wchar_t* classname)
|
||||
{
|
||||
DCHECK(browser);
|
||||
if(!browser)
|
||||
return NULL;
|
||||
|
||||
CefBrowserCppToC::Struct* impl =
|
||||
reinterpret_cast<CefBrowserCppToC::Struct*>(browser);
|
||||
|
||||
std::wstring classnameStr;
|
||||
if(classname)
|
||||
classnameStr = classname;
|
||||
CefRefPtr<CefJSHandler> handler =
|
||||
impl->class_->GetClass()->GetJSHandler(classnameStr);
|
||||
if(handler.get()) {
|
||||
CefJSHandlerCToCpp* hp = static_cast<CefJSHandlerCToCpp*>(handler.get());
|
||||
hp->UnderlyingAddRef();
|
||||
return hp->GetStruct();
|
||||
}
|
||||
return NULL;
|
||||
}
|
||||
|
||||
int CEF_CALLBACK browser_remove_jshandler(cef_browser_t* browser,
|
||||
const wchar_t* classname)
|
||||
{
|
||||
DCHECK(browser);
|
||||
if(!browser)
|
||||
return 0;
|
||||
|
||||
CefBrowserCppToC::Struct* impl =
|
||||
reinterpret_cast<CefBrowserCppToC::Struct*>(browser);
|
||||
|
||||
std::wstring classnameStr;
|
||||
if(classname)
|
||||
classnameStr = classname;
|
||||
return impl->class_->GetClass()->RemoveJSHandler(classnameStr);
|
||||
}
|
||||
|
||||
void CEF_CALLBACK browser_remove_all_jshandlers(cef_browser_t* browser)
|
||||
{
|
||||
DCHECK(browser);
|
||||
if(!browser)
|
||||
return;
|
||||
|
||||
CefBrowserCppToC::Struct* impl =
|
||||
reinterpret_cast<CefBrowserCppToC::Struct*>(browser);
|
||||
return impl->class_->GetClass()->RemoveAllJSHandlers();
|
||||
}
|
||||
|
||||
cef_window_handle_t CEF_CALLBACK browser_get_window_handle(cef_browser_t* browser)
|
||||
{
|
||||
DCHECK(browser);
|
||||
if(!browser)
|
||||
return NULL;
|
||||
|
||||
CefBrowserCppToC::Struct* impl =
|
||||
reinterpret_cast<CefBrowserCppToC::Struct*>(browser);
|
||||
return impl->class_->GetClass()->GetWindowHandle();
|
||||
}
|
||||
|
||||
int CEF_CALLBACK browser_is_popup(cef_browser_t* browser)
|
||||
{
|
||||
DCHECK(browser);
|
||||
if(!browser)
|
||||
return 0;
|
||||
|
||||
CefBrowserCppToC::Struct* impl =
|
||||
reinterpret_cast<CefBrowserCppToC::Struct*>(browser);
|
||||
return impl->class_->GetClass()->IsPopup();
|
||||
}
|
||||
|
||||
cef_handler_t* CEF_CALLBACK browser_get_handler(cef_browser_t* browser)
|
||||
{
|
||||
DCHECK(browser);
|
||||
if(!browser)
|
||||
return NULL;
|
||||
|
||||
CefBrowserCppToC::Struct* impl =
|
||||
reinterpret_cast<CefBrowserCppToC::Struct*>(browser);
|
||||
|
||||
CefRefPtr<CefHandler> handler = impl->class_->GetClass()->GetHandler();
|
||||
if(handler.get()) {
|
||||
CefHandlerCToCpp* hp = static_cast<CefHandlerCToCpp*>(handler.get());
|
||||
hp->UnderlyingAddRef();
|
||||
return hp->GetStruct();
|
||||
}
|
||||
return NULL;
|
||||
}
|
||||
|
||||
cef_string_t CEF_CALLBACK browser_get_url(cef_browser_t* browser)
|
||||
{
|
||||
DCHECK(browser);
|
||||
if(!browser)
|
||||
return NULL;
|
||||
|
||||
CefBrowserCppToC::Struct* impl =
|
||||
reinterpret_cast<CefBrowserCppToC::Struct*>(browser);
|
||||
|
||||
std::wstring urlStr = impl->class_->GetClass()->GetURL();
|
||||
if(urlStr.empty())
|
||||
return NULL;
|
||||
return cef_string_alloc(urlStr.c_str());
|
||||
}
|
||||
|
||||
CefBrowserCppToC::CefBrowserCppToC(CefRefPtr<CefBrowser> cls)
|
||||
: CefCppToC<CefBrowser, cef_browser_t>(cls)
|
||||
{
|
||||
struct_.struct_.can_go_back = browser_can_go_back;
|
||||
struct_.struct_.go_back = browser_go_back;
|
||||
struct_.struct_.can_go_forward = browser_can_go_forward;
|
||||
struct_.struct_.go_forward = browser_go_forward;
|
||||
struct_.struct_.reload = browser_reload;
|
||||
struct_.struct_.stop_load = browser_stop_load;
|
||||
struct_.struct_.undo = browser_undo;
|
||||
struct_.struct_.redo = browser_redo;
|
||||
struct_.struct_.cut = browser_cut;
|
||||
struct_.struct_.copy = browser_copy;
|
||||
struct_.struct_.paste = browser_paste;
|
||||
struct_.struct_.del = browser_delete;
|
||||
struct_.struct_.select_all = browser_select_all;
|
||||
struct_.struct_.print = browser_print;
|
||||
struct_.struct_.view_source = browser_view_source;
|
||||
struct_.struct_.get_source = browser_get_source;
|
||||
struct_.struct_.get_text = browser_get_text;
|
||||
struct_.struct_.load_request = browser_load_request;
|
||||
struct_.struct_.load_url = browser_load_url;
|
||||
struct_.struct_.load_string = browser_load_string;
|
||||
struct_.struct_.load_stream = browser_load_stream;
|
||||
struct_.struct_.execute_javascript = browser_execute_javascript;
|
||||
struct_.struct_.add_jshandler = browser_add_jshandler;
|
||||
struct_.struct_.has_jshandler = browser_has_jshandler;
|
||||
struct_.struct_.get_jshandler = browser_get_jshandler;
|
||||
struct_.struct_.remove_jshandler = browser_remove_jshandler;
|
||||
struct_.struct_.remove_all_jshandlers = browser_remove_all_jshandlers;
|
||||
struct_.struct_.get_window_handle = browser_get_window_handle;
|
||||
struct_.struct_.is_popup = browser_is_popup;
|
||||
struct_.struct_.get_handler = browser_get_handler;
|
||||
struct_.struct_.get_url = browser_get_url;
|
||||
}
|
28
libcef_dll/cpptoc/browser_cpptoc.h
Normal file
28
libcef_dll/cpptoc/browser_cpptoc.h
Normal file
@ -0,0 +1,28 @@
|
||||
// Copyright (c) 2009 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.
|
||||
|
||||
#ifndef _BROWSER_CPPTOC_H
|
||||
#define _BROWSER_CPPTOC_H
|
||||
|
||||
#ifndef BUILDING_CEF_SHARED
|
||||
#pragma message("Warning: "__FILE__" may be accessed DLL-side only")
|
||||
#else // BUILDING_CEF_SHARED
|
||||
|
||||
#include "cef.h"
|
||||
#include "cef_capi.h"
|
||||
#include "cpptoc.h"
|
||||
|
||||
|
||||
// Wrap a C++ browser class with a C browser structure.
|
||||
// This class may be instantiated and accessed DLL-side only.
|
||||
class CefBrowserCppToC : public CefCppToC<CefBrowser, cef_browser_t>
|
||||
{
|
||||
public:
|
||||
CefBrowserCppToC(CefRefPtr<CefBrowser> cls);
|
||||
virtual ~CefBrowserCppToC() {}
|
||||
};
|
||||
|
||||
|
||||
#endif // BUILDING_CEF_SHARED
|
||||
#endif // _BROWSER_CPPTOC_H
|
92
libcef_dll/cpptoc/cpptoc.h
Normal file
92
libcef_dll/cpptoc/cpptoc.h
Normal file
@ -0,0 +1,92 @@
|
||||
// Copyright (c) 2009 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.
|
||||
|
||||
#ifndef _CPPTOC_H
|
||||
#define _CPPTOC_H
|
||||
|
||||
#include "cef.h"
|
||||
#include "cef_capi.h"
|
||||
#include "base/logging.h"
|
||||
|
||||
|
||||
// Wrap a C++ class with a C structure.
|
||||
template <class ClassName, class StructName>
|
||||
class CefCppToC : public CefThreadSafeBase<CefBase>
|
||||
{
|
||||
public:
|
||||
// Structure representation with pointer to the C++ class.
|
||||
struct Struct
|
||||
{
|
||||
StructName struct_;
|
||||
CefCppToC<ClassName, StructName>* class_;
|
||||
};
|
||||
|
||||
CefCppToC(CefRefPtr<ClassName> cls)
|
||||
: class_(cls)
|
||||
{
|
||||
DCHECK(cls.get());
|
||||
|
||||
struct_.class_ = this;
|
||||
|
||||
// zero the underlying structure and set base members
|
||||
memset(&struct_.struct_, 0, sizeof(StructName));
|
||||
struct_.struct_.base.size = sizeof(StructName);
|
||||
struct_.struct_.base.add_ref = struct_add_ref;
|
||||
struct_.struct_.base.release = struct_release;
|
||||
}
|
||||
virtual ~CefCppToC()
|
||||
{
|
||||
}
|
||||
|
||||
CefRefPtr<ClassName> GetClass() { return class_; }
|
||||
|
||||
// If returning the structure across the DLL boundary you should call
|
||||
// AddRef() on this CefCppToC object. On the other side of the DLL boundary,
|
||||
// call UnderlyingRelease() on the wrapping CefCToCpp object.
|
||||
StructName* GetStruct() { return &struct_.struct_; }
|
||||
|
||||
// CefBase methods increment/decrement reference counts on both this object
|
||||
// and the underlying wrapper class.
|
||||
virtual int AddRef()
|
||||
{
|
||||
UnderlyingAddRef();
|
||||
return CefThreadSafeBase<CefBase>::AddRef();
|
||||
}
|
||||
virtual int Release()
|
||||
{
|
||||
UnderlyingRelease();
|
||||
return CefThreadSafeBase<CefBase>::Release();
|
||||
}
|
||||
|
||||
// Increment/decrement reference counts on only the underlying class.
|
||||
int UnderlyingAddRef() { return class_->AddRef(); }
|
||||
int UnderlyingRelease() { return class_->Release(); }
|
||||
|
||||
private:
|
||||
static int CEF_CALLBACK struct_add_ref(struct _cef_base_t* base)
|
||||
{
|
||||
DCHECK(base);
|
||||
if(!base)
|
||||
return 0;
|
||||
|
||||
Struct* impl = reinterpret_cast<Struct*>(base);
|
||||
return impl->class_->AddRef();
|
||||
}
|
||||
|
||||
static int CEF_CALLBACK struct_release(struct _cef_base_t* base)
|
||||
{
|
||||
DCHECK(base);
|
||||
if(!base)
|
||||
return 0;
|
||||
|
||||
Struct* impl = reinterpret_cast<Struct*>(base);
|
||||
return impl->class_->Release();
|
||||
}
|
||||
|
||||
protected:
|
||||
Struct struct_;
|
||||
CefRefPtr<ClassName> class_;
|
||||
};
|
||||
|
||||
#endif // _CPPTOC_H
|
521
libcef_dll/cpptoc/handler_cpptoc.cc
Normal file
521
libcef_dll/cpptoc/handler_cpptoc.cc
Normal file
@ -0,0 +1,521 @@
|
||||
// Copyright (c) 2009 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 "../precompiled_libcef.h"
|
||||
#include "cpptoc/handler_cpptoc.h"
|
||||
#include "ctocpp/browser_ctocpp.h"
|
||||
#include "ctocpp/request_ctocpp.h"
|
||||
#include "ctocpp/stream_ctocpp.h"
|
||||
#include "transfer_util.h"
|
||||
#include "base/logging.h"
|
||||
|
||||
|
||||
enum cef_retval_t CEF_CALLBACK handler_handle_before_created(
|
||||
struct _cef_handler_t* handler, cef_browser_t* parentBrowser,
|
||||
cef_window_info_t* windowInfo, int popup,
|
||||
struct _cef_handler_t** newHandler, cef_string_t* url)
|
||||
{
|
||||
DCHECK(handler);
|
||||
DCHECK(windowInfo);
|
||||
DCHECK(newHandler && *newHandler);
|
||||
DCHECK(url);
|
||||
if(!handler || !windowInfo || !newHandler || !*newHandler || !url)
|
||||
return RV_CONTINUE;
|
||||
|
||||
CefHandlerCppToC::Struct* impl =
|
||||
reinterpret_cast<CefHandlerCppToC::Struct*>(handler);
|
||||
|
||||
// |newHandler| will start off pointing to the current handler.
|
||||
CefHandlerCppToC::Struct* structPtr
|
||||
= reinterpret_cast<CefHandlerCppToC::Struct*>(*newHandler);
|
||||
|
||||
CefWindowInfo wndInfo(*windowInfo);
|
||||
CefRefPtr<CefBrowser> browserPtr;
|
||||
CefRefPtr<CefHandler> handlerPtr(structPtr->class_->GetClass());
|
||||
structPtr->class_->Release();
|
||||
|
||||
std::wstring urlStr;
|
||||
|
||||
// |parentBrowser| will be NULL if this is a top-level browser window.
|
||||
if(parentBrowser)
|
||||
{
|
||||
CefBrowserCToCpp* bp = new CefBrowserCToCpp(parentBrowser);
|
||||
browserPtr = bp;
|
||||
bp->UnderlyingRelease();
|
||||
}
|
||||
|
||||
if(*url)
|
||||
urlStr = *url;
|
||||
|
||||
enum cef_retval_t rv = impl->class_->GetClass()->HandleBeforeCreated(
|
||||
browserPtr, wndInfo, popup, handlerPtr, urlStr);
|
||||
|
||||
transfer_string_contents(urlStr, url);
|
||||
|
||||
if(handlerPtr.get() != structPtr->class_->GetClass().get())
|
||||
{
|
||||
// The handler has been changed.
|
||||
CefHandlerCppToC* hobj = new CefHandlerCppToC(handlerPtr);
|
||||
hobj->AddRef();
|
||||
*newHandler = hobj->GetStruct();
|
||||
}
|
||||
|
||||
// WindowInfo may or may not have changed.
|
||||
*windowInfo = wndInfo;
|
||||
|
||||
return rv;
|
||||
}
|
||||
|
||||
enum cef_retval_t CEF_CALLBACK handler_handle_after_created(
|
||||
struct _cef_handler_t* handler, cef_browser_t* browser)
|
||||
{
|
||||
DCHECK(handler);
|
||||
DCHECK(browser);
|
||||
if(!handler || !browser)
|
||||
return RV_CONTINUE;
|
||||
|
||||
CefHandlerCppToC::Struct* impl =
|
||||
reinterpret_cast<CefHandlerCppToC::Struct*>(handler);
|
||||
|
||||
CefBrowserCToCpp* bp = new CefBrowserCToCpp(browser);
|
||||
CefRefPtr<CefBrowser> browserPtr(bp);
|
||||
bp->UnderlyingRelease();
|
||||
|
||||
return impl->class_->GetClass()->HandleAfterCreated(browserPtr);
|
||||
}
|
||||
|
||||
enum cef_retval_t CEF_CALLBACK handler_handle_address_change(
|
||||
struct _cef_handler_t* handler, cef_browser_t* browser,
|
||||
const wchar_t* url)
|
||||
{
|
||||
DCHECK(handler);
|
||||
DCHECK(browser);
|
||||
if(!handler || !browser)
|
||||
return RV_CONTINUE;
|
||||
|
||||
CefHandlerCppToC::Struct* impl =
|
||||
reinterpret_cast<CefHandlerCppToC::Struct*>(handler);
|
||||
|
||||
CefBrowserCToCpp* bp = new CefBrowserCToCpp(browser);
|
||||
CefRefPtr<CefBrowser> browserPtr(bp);
|
||||
bp->UnderlyingRelease();
|
||||
|
||||
std::wstring urlStr;
|
||||
if(url)
|
||||
urlStr = url;
|
||||
|
||||
return impl->class_->GetClass()->HandleAddressChange(browserPtr, urlStr);
|
||||
}
|
||||
|
||||
enum cef_retval_t CEF_CALLBACK handler_handle_title_change(
|
||||
struct _cef_handler_t* handler, cef_browser_t* browser,
|
||||
const wchar_t* title)
|
||||
{
|
||||
DCHECK(handler);
|
||||
DCHECK(browser);
|
||||
if(!handler || !browser)
|
||||
return RV_CONTINUE;
|
||||
|
||||
CefHandlerCppToC::Struct* impl =
|
||||
reinterpret_cast<CefHandlerCppToC::Struct*>(handler);
|
||||
|
||||
CefBrowserCToCpp* bp = new CefBrowserCToCpp(browser);
|
||||
CefRefPtr<CefBrowser> browserPtr(bp);
|
||||
bp->UnderlyingRelease();
|
||||
|
||||
std::wstring titleStr;
|
||||
if(title)
|
||||
titleStr = title;
|
||||
|
||||
return impl->class_->GetClass()->HandleTitleChange(browserPtr, titleStr);
|
||||
}
|
||||
|
||||
enum cef_retval_t CEF_CALLBACK handler_handle_before_browse(
|
||||
struct _cef_handler_t* handler, cef_browser_t* browser,
|
||||
struct _cef_request_t* request, cef_handler_navtype_t navType,
|
||||
int isRedirect)
|
||||
{
|
||||
DCHECK(handler);
|
||||
DCHECK(browser);
|
||||
DCHECK(request);
|
||||
if(!handler || !browser || !request)
|
||||
return RV_CONTINUE;
|
||||
|
||||
CefHandlerCppToC::Struct* impl =
|
||||
reinterpret_cast<CefHandlerCppToC::Struct*>(handler);
|
||||
|
||||
CefBrowserCToCpp* bp = new CefBrowserCToCpp(browser);
|
||||
CefRefPtr<CefBrowser> browserPtr(bp);
|
||||
bp->UnderlyingRelease();
|
||||
|
||||
CefRequestCToCpp* rp = new CefRequestCToCpp(request);
|
||||
CefRefPtr<CefRequest> requestPtr(rp);
|
||||
rp->UnderlyingRelease();
|
||||
|
||||
return impl->class_->GetClass()->HandleBeforeBrowse(browserPtr, requestPtr,
|
||||
navType, (isRedirect ? true : false));
|
||||
}
|
||||
|
||||
enum cef_retval_t CEF_CALLBACK handler_handle_load_start(
|
||||
struct _cef_handler_t* handler, cef_browser_t* browser)
|
||||
{
|
||||
DCHECK(handler);
|
||||
DCHECK(browser);
|
||||
if(!handler || !browser)
|
||||
return RV_CONTINUE;
|
||||
|
||||
CefHandlerCppToC::Struct* impl =
|
||||
reinterpret_cast<CefHandlerCppToC::Struct*>(handler);
|
||||
|
||||
CefBrowserCToCpp* bp = new CefBrowserCToCpp(browser);
|
||||
CefRefPtr<CefBrowser> browserPtr(bp);
|
||||
bp->UnderlyingRelease();
|
||||
|
||||
return impl->class_->GetClass()->HandleLoadStart(browserPtr);
|
||||
}
|
||||
|
||||
enum cef_retval_t CEF_CALLBACK handler_handle_load_end(
|
||||
struct _cef_handler_t* handler, cef_browser_t* browser)
|
||||
{
|
||||
DCHECK(handler);
|
||||
DCHECK(browser);
|
||||
if(!handler || !browser)
|
||||
return RV_CONTINUE;
|
||||
|
||||
CefHandlerCppToC::Struct* impl =
|
||||
reinterpret_cast<CefHandlerCppToC::Struct*>(handler);
|
||||
|
||||
CefBrowserCToCpp* bp = new CefBrowserCToCpp(browser);
|
||||
CefRefPtr<CefBrowser> browserPtr(bp);
|
||||
bp->UnderlyingRelease();
|
||||
|
||||
return impl->class_->GetClass()->HandleLoadEnd(browserPtr);
|
||||
}
|
||||
|
||||
enum cef_retval_t CEF_CALLBACK handler_handle_load_error(
|
||||
struct _cef_handler_t* handler, cef_browser_t* browser,
|
||||
cef_handler_errorcode_t errorCode, const wchar_t* failedUrl,
|
||||
cef_string_t* errorText)
|
||||
{
|
||||
DCHECK(handler);
|
||||
DCHECK(browser);
|
||||
DCHECK(errorText);
|
||||
if(!handler || !browser || !errorText)
|
||||
return RV_CONTINUE;
|
||||
|
||||
CefHandlerCppToC::Struct* impl =
|
||||
reinterpret_cast<CefHandlerCppToC::Struct*>(handler);
|
||||
|
||||
CefBrowserCToCpp* bp = new CefBrowserCToCpp(browser);
|
||||
CefRefPtr<CefBrowser> browserPtr(bp);
|
||||
bp->UnderlyingRelease();
|
||||
|
||||
std::wstring failedUrlStr, errorTextStr;
|
||||
|
||||
if(failedUrl)
|
||||
failedUrlStr = failedUrl;
|
||||
if(*errorText)
|
||||
errorTextStr = *errorText;
|
||||
|
||||
enum cef_retval_t rv = impl->class_->GetClass()->HandleLoadError(browserPtr,
|
||||
errorCode, failedUrlStr, errorTextStr);
|
||||
|
||||
transfer_string_contents(errorTextStr, errorText);
|
||||
|
||||
return rv;
|
||||
}
|
||||
|
||||
enum cef_retval_t CEF_CALLBACK handler_handle_before_resource_load(
|
||||
struct _cef_handler_t* handler, cef_browser_t* browser,
|
||||
struct _cef_request_t* request, cef_string_t* redirectUrl,
|
||||
struct _cef_stream_reader_t** resourceStream, cef_string_t* mimeType,
|
||||
int loadFlags)
|
||||
{
|
||||
DCHECK(handler);
|
||||
DCHECK(browser);
|
||||
DCHECK(redirectUrl);
|
||||
DCHECK(resourceStream);
|
||||
DCHECK(mimeType);
|
||||
if(!handler || !browser || !redirectUrl || !resourceStream || !mimeType)
|
||||
return RV_CONTINUE;
|
||||
|
||||
CefHandlerCppToC::Struct* impl =
|
||||
reinterpret_cast<CefHandlerCppToC::Struct*>(handler);
|
||||
|
||||
CefBrowserCToCpp* bp = new CefBrowserCToCpp(browser);
|
||||
CefRefPtr<CefBrowser> browserPtr(bp);
|
||||
bp->UnderlyingRelease();
|
||||
|
||||
CefRequestCToCpp* rp = new CefRequestCToCpp(request);
|
||||
CefRefPtr<CefRequest> requestPtr(rp);
|
||||
rp->UnderlyingRelease();
|
||||
|
||||
std::wstring redirectUrlStr, mimeTypeStr;
|
||||
CefRefPtr<CefStreamReader> streamPtr;
|
||||
|
||||
if(*redirectUrl)
|
||||
redirectUrlStr = *redirectUrl;
|
||||
if(*mimeType)
|
||||
mimeTypeStr = *mimeType;
|
||||
|
||||
enum cef_retval_t rv = impl->class_->GetClass()->HandleBeforeResourceLoad(
|
||||
browserPtr, requestPtr, redirectUrlStr, streamPtr, mimeTypeStr,
|
||||
loadFlags);
|
||||
|
||||
transfer_string_contents(redirectUrlStr, redirectUrl);
|
||||
transfer_string_contents(mimeTypeStr, mimeType);
|
||||
|
||||
if(streamPtr.get())
|
||||
{
|
||||
CefStreamReaderCToCpp* sp =
|
||||
static_cast<CefStreamReaderCToCpp*>(streamPtr.get());
|
||||
sp->UnderlyingAddRef();
|
||||
*resourceStream = sp->GetStruct();
|
||||
}
|
||||
|
||||
return rv;
|
||||
}
|
||||
|
||||
enum cef_retval_t CEF_CALLBACK handler_handle_before_menu(
|
||||
struct _cef_handler_t* handler, cef_browser_t* browser,
|
||||
const cef_handler_menuinfo_t* menuInfo)
|
||||
{
|
||||
DCHECK(handler);
|
||||
DCHECK(browser);
|
||||
DCHECK(menuInfo);
|
||||
if(!handler || !browser || !menuInfo)
|
||||
return RV_CONTINUE;
|
||||
|
||||
CefHandlerCppToC::Struct* impl =
|
||||
reinterpret_cast<CefHandlerCppToC::Struct*>(handler);
|
||||
|
||||
CefBrowserCToCpp* bp = new CefBrowserCToCpp(browser);
|
||||
CefRefPtr<CefBrowser> browserPtr(bp);
|
||||
bp->UnderlyingRelease();
|
||||
|
||||
return impl->class_->GetClass()->HandleBeforeMenu(browserPtr, *menuInfo);
|
||||
}
|
||||
|
||||
enum cef_retval_t CEF_CALLBACK handler_handle_get_menu_label(
|
||||
struct _cef_handler_t* handler, cef_browser_t* browser,
|
||||
cef_handler_menuid_t menuId, cef_string_t* label)
|
||||
{
|
||||
DCHECK(handler);
|
||||
DCHECK(browser);
|
||||
DCHECK(label);
|
||||
if(!handler || !browser || !label)
|
||||
return RV_CONTINUE;
|
||||
|
||||
CefHandlerCppToC::Struct* impl =
|
||||
reinterpret_cast<CefHandlerCppToC::Struct*>(handler);
|
||||
|
||||
CefBrowserCToCpp* bp = new CefBrowserCToCpp(browser);
|
||||
CefRefPtr<CefBrowser> browserPtr(bp);
|
||||
bp->UnderlyingRelease();
|
||||
|
||||
std::wstring labelStr;
|
||||
if(*label)
|
||||
labelStr = *label;
|
||||
|
||||
enum cef_retval_t rv = impl->class_->GetClass()->HandleGetMenuLabel(
|
||||
browserPtr, menuId, labelStr);
|
||||
|
||||
transfer_string_contents(labelStr, label);
|
||||
|
||||
return rv;
|
||||
}
|
||||
|
||||
enum cef_retval_t CEF_CALLBACK handler_handle_menu_action(
|
||||
struct _cef_handler_t* handler, cef_browser_t* browser,
|
||||
cef_handler_menuid_t menuId)
|
||||
{
|
||||
DCHECK(handler);
|
||||
DCHECK(browser);
|
||||
if(!handler || !browser)
|
||||
return RV_CONTINUE;
|
||||
|
||||
CefHandlerCppToC::Struct* impl =
|
||||
reinterpret_cast<CefHandlerCppToC::Struct*>(handler);
|
||||
|
||||
CefBrowserCToCpp* bp = new CefBrowserCToCpp(browser);
|
||||
CefRefPtr<CefBrowser> browserPtr(bp);
|
||||
bp->UnderlyingRelease();
|
||||
|
||||
return impl->class_->GetClass()->HandleMenuAction(browserPtr, menuId);
|
||||
}
|
||||
|
||||
enum cef_retval_t CEF_CALLBACK handler_handle_print_header_footer(
|
||||
struct _cef_handler_t* handler, cef_browser_t* browser,
|
||||
cef_print_info_t* printInfo, const wchar_t* url, const wchar_t* title,
|
||||
int currentPage, int maxPages, cef_string_t* topLeft,
|
||||
cef_string_t* topCenter, cef_string_t* topRight,
|
||||
cef_string_t* bottomLeft, cef_string_t* bottomCenter,
|
||||
cef_string_t* bottomRight)
|
||||
{
|
||||
DCHECK(handler);
|
||||
DCHECK(browser);
|
||||
DCHECK(printInfo);
|
||||
DCHECK(topLeft && topCenter && topRight);
|
||||
DCHECK(bottomLeft && bottomCenter && bottomRight);
|
||||
if(!handler || !browser || !printInfo || !topLeft || !topCenter || !topRight
|
||||
|| !bottomLeft || !bottomCenter || !bottomRight)
|
||||
return RV_CONTINUE;
|
||||
|
||||
CefHandlerCppToC::Struct* impl =
|
||||
reinterpret_cast<CefHandlerCppToC::Struct*>(handler);
|
||||
|
||||
CefBrowserCToCpp* bp = new CefBrowserCToCpp(browser);
|
||||
CefRefPtr<CefBrowser> browserPtr(bp);
|
||||
bp->UnderlyingRelease();
|
||||
|
||||
std::wstring urlStr, titleStr;
|
||||
std::wstring topLeftStr, topCenterStr, topRightStr;
|
||||
std::wstring bottomLeftStr, bottomCenterStr, bottomRightStr;
|
||||
CefPrintInfo info = *printInfo;
|
||||
|
||||
if(url)
|
||||
urlStr = url;
|
||||
if(title)
|
||||
titleStr = title;
|
||||
if(*topLeft)
|
||||
topLeftStr = *topLeft;
|
||||
if(*topCenter)
|
||||
topCenterStr = *topCenter;
|
||||
if(*topRight)
|
||||
topRightStr = *topRight;
|
||||
if(*bottomLeft)
|
||||
bottomLeftStr = *bottomLeft;
|
||||
if(*bottomCenter)
|
||||
bottomCenterStr = *bottomCenter;
|
||||
if(*bottomRight)
|
||||
bottomRightStr = *bottomRight;
|
||||
|
||||
enum cef_retval_t rv = impl->class_->GetClass()->
|
||||
HandlePrintHeaderFooter(browserPtr, info, urlStr, titleStr,
|
||||
currentPage, maxPages, topLeftStr, topCenterStr, topRightStr,
|
||||
bottomLeftStr, bottomCenterStr, bottomRightStr);
|
||||
|
||||
transfer_string_contents(topLeftStr, topLeft);
|
||||
transfer_string_contents(topCenterStr, topCenter);
|
||||
transfer_string_contents(topRightStr, topRight);
|
||||
transfer_string_contents(bottomLeftStr, bottomLeft);
|
||||
transfer_string_contents(bottomCenterStr, bottomCenter);
|
||||
transfer_string_contents(bottomRightStr, bottomRight);
|
||||
|
||||
return rv;
|
||||
}
|
||||
|
||||
enum cef_retval_t CEF_CALLBACK handler_handle_jsalert(
|
||||
struct _cef_handler_t* handler, cef_browser_t* browser,
|
||||
const wchar_t* message)
|
||||
{
|
||||
DCHECK(handler);
|
||||
DCHECK(browser);
|
||||
if(!handler || !browser)
|
||||
return RV_CONTINUE;
|
||||
|
||||
CefHandlerCppToC::Struct* impl =
|
||||
reinterpret_cast<CefHandlerCppToC::Struct*>(handler);
|
||||
|
||||
CefBrowserCToCpp* bp = new CefBrowserCToCpp(browser);
|
||||
CefRefPtr<CefBrowser> browserPtr(bp);
|
||||
bp->UnderlyingRelease();
|
||||
|
||||
std::wstring messageStr;
|
||||
if(message)
|
||||
messageStr = message;
|
||||
|
||||
return impl->class_->GetClass()->HandleJSAlert(browserPtr, messageStr);
|
||||
}
|
||||
|
||||
enum cef_retval_t CEF_CALLBACK handler_handle_jsconfirm(
|
||||
struct _cef_handler_t* handler, cef_browser_t* browser,
|
||||
const wchar_t* message, int* retval)
|
||||
{
|
||||
DCHECK(handler);
|
||||
DCHECK(browser);
|
||||
DCHECK(retval);
|
||||
if(!handler || !browser || !retval)
|
||||
return RV_CONTINUE;
|
||||
|
||||
CefHandlerCppToC::Struct* impl =
|
||||
reinterpret_cast<CefHandlerCppToC::Struct*>(handler);
|
||||
|
||||
CefBrowserCToCpp* bp = new CefBrowserCToCpp(browser);
|
||||
CefRefPtr<CefBrowser> browserPtr(bp);
|
||||
bp->UnderlyingRelease();
|
||||
|
||||
std::wstring messageStr;
|
||||
if(message)
|
||||
messageStr = message;
|
||||
|
||||
bool ret = false;
|
||||
enum cef_retval_t rv = impl->class_->GetClass()->HandleJSConfirm(browserPtr,
|
||||
messageStr, ret);
|
||||
*retval = (ret ? 1 : 0);
|
||||
|
||||
return rv;
|
||||
}
|
||||
|
||||
enum cef_retval_t CEF_CALLBACK handler_handle_jsprompt(
|
||||
struct _cef_handler_t* handler, cef_browser_t* browser,
|
||||
const wchar_t* message, const wchar_t* defaultValue, int* retval,
|
||||
cef_string_t* result)
|
||||
{
|
||||
DCHECK(handler);
|
||||
DCHECK(browser);
|
||||
DCHECK(retval);
|
||||
DCHECK(result);
|
||||
if(!handler || !browser || !retval || !result)
|
||||
return RV_CONTINUE;
|
||||
|
||||
CefHandlerCppToC::Struct* impl =
|
||||
reinterpret_cast<CefHandlerCppToC::Struct*>(handler);
|
||||
|
||||
CefBrowserCToCpp* bp = new CefBrowserCToCpp(browser);
|
||||
CefRefPtr<CefBrowser> browserPtr(bp);
|
||||
bp->UnderlyingRelease();
|
||||
|
||||
std::wstring messageStr, defaultValueStr, resultStr;
|
||||
|
||||
if(message)
|
||||
messageStr = message;
|
||||
if(defaultValue)
|
||||
defaultValueStr = defaultValue;
|
||||
if(*result)
|
||||
resultStr = *result;
|
||||
|
||||
bool ret = false;
|
||||
enum cef_retval_t rv = impl->class_->GetClass()->HandleJSPrompt(
|
||||
browserPtr, messageStr, defaultValueStr, ret, resultStr);
|
||||
*retval = (ret ? 1 : 0);
|
||||
|
||||
transfer_string_contents(resultStr, result);
|
||||
|
||||
return rv;
|
||||
}
|
||||
|
||||
|
||||
CefHandlerCppToC::CefHandlerCppToC(CefRefPtr<CefHandler> cls)
|
||||
: CefCppToC<CefHandler, cef_handler_t>(cls)
|
||||
{
|
||||
struct_.struct_.handle_before_created = handler_handle_before_created;
|
||||
struct_.struct_.handle_after_created = handler_handle_after_created;
|
||||
struct_.struct_.handle_address_change = handler_handle_address_change;
|
||||
struct_.struct_.handle_title_change = handler_handle_title_change;
|
||||
struct_.struct_.handle_before_browse = handler_handle_before_browse;
|
||||
struct_.struct_.handle_load_start = handler_handle_load_start;
|
||||
struct_.struct_.handle_load_end = handler_handle_load_end;
|
||||
struct_.struct_.handle_load_error = handler_handle_load_error;
|
||||
struct_.struct_.handle_before_resource_load =
|
||||
handler_handle_before_resource_load;
|
||||
struct_.struct_.handle_before_menu = handler_handle_before_menu;
|
||||
struct_.struct_.handle_get_menu_label = handler_handle_get_menu_label;
|
||||
struct_.struct_.handle_menu_action = handler_handle_menu_action;
|
||||
struct_.struct_.handle_print_header_footer =
|
||||
handler_handle_print_header_footer;
|
||||
struct_.struct_.handle_jsalert = handler_handle_jsalert;
|
||||
struct_.struct_.handle_jsconfirm = handler_handle_jsconfirm;
|
||||
struct_.struct_.handle_jsprompt = handler_handle_jsprompt;
|
||||
}
|
28
libcef_dll/cpptoc/handler_cpptoc.h
Normal file
28
libcef_dll/cpptoc/handler_cpptoc.h
Normal file
@ -0,0 +1,28 @@
|
||||
// Copyright (c) 2009 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.
|
||||
|
||||
#ifndef _HANDLER_CPPTOC_H
|
||||
#define _HANDLER_CPPTOC_H
|
||||
|
||||
#ifndef USING_CEF_SHARED
|
||||
#pragma message("Warning: "__FILE__" may be accessed wrapper-side only")
|
||||
#else // USING_CEF_SHARED
|
||||
|
||||
#include "cef.h"
|
||||
#include "cef_capi.h"
|
||||
#include "cpptoc.h"
|
||||
|
||||
|
||||
// Wrap a C++ handler class with a C handler structure.
|
||||
// This class may be instantiated and accessed wrapper-side only.
|
||||
class CefHandlerCppToC : public CefCppToC<CefHandler, cef_handler_t>
|
||||
{
|
||||
public:
|
||||
CefHandlerCppToC(CefRefPtr<CefHandler> cls);
|
||||
virtual ~CefHandlerCppToC() {}
|
||||
};
|
||||
|
||||
|
||||
#endif // USING_CEF_SHARED
|
||||
#endif // _HANDLER_CPPTOC_H
|
155
libcef_dll/cpptoc/jshandler_cpptoc.cc
Normal file
155
libcef_dll/cpptoc/jshandler_cpptoc.cc
Normal file
@ -0,0 +1,155 @@
|
||||
// Copyright (c) 2009 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 "../precompiled_libcef.h"
|
||||
#include "cpptoc/jshandler_cpptoc.h"
|
||||
#include "ctocpp/browser_ctocpp.h"
|
||||
#include "ctocpp/variant_ctocpp.h"
|
||||
#include "base/logging.h"
|
||||
|
||||
|
||||
bool CEF_CALLBACK jshandler_has_method(struct _cef_jshandler_t* jshandler,
|
||||
cef_browser_t* browser, const wchar_t* name)
|
||||
{
|
||||
DCHECK(jshandler);
|
||||
DCHECK(browser);
|
||||
if(!jshandler || !browser)
|
||||
return RV_CONTINUE;
|
||||
|
||||
CefJSHandlerCppToC::Struct* impl =
|
||||
reinterpret_cast<CefJSHandlerCppToC::Struct*>(jshandler);
|
||||
|
||||
CefBrowserCToCpp* bp = new CefBrowserCToCpp(browser);
|
||||
CefRefPtr<CefBrowser> browserPtr(bp);
|
||||
bp->UnderlyingRelease();
|
||||
|
||||
std::wstring nameStr;
|
||||
if(name)
|
||||
nameStr = name;
|
||||
|
||||
return impl->class_->GetClass()->HasMethod(browserPtr, nameStr);
|
||||
}
|
||||
|
||||
bool CEF_CALLBACK jshandler_has_property(struct _cef_jshandler_t* jshandler,
|
||||
cef_browser_t* browser, const wchar_t* name)
|
||||
{
|
||||
DCHECK(jshandler);
|
||||
DCHECK(browser);
|
||||
if(!jshandler || !browser)
|
||||
return RV_CONTINUE;
|
||||
|
||||
CefJSHandlerCppToC::Struct* impl =
|
||||
reinterpret_cast<CefJSHandlerCppToC::Struct*>(jshandler);
|
||||
|
||||
CefBrowserCToCpp* bp = new CefBrowserCToCpp(browser);
|
||||
CefRefPtr<CefBrowser> browserPtr(bp);
|
||||
bp->UnderlyingRelease();
|
||||
|
||||
std::wstring nameStr;
|
||||
if(name)
|
||||
nameStr = name;
|
||||
|
||||
return impl->class_->GetClass()->HasProperty(browserPtr, nameStr);
|
||||
}
|
||||
|
||||
bool CEF_CALLBACK jshandler_set_property(struct _cef_jshandler_t* jshandler,
|
||||
cef_browser_t* browser, const wchar_t* name,
|
||||
struct _cef_variant_t* value)
|
||||
{
|
||||
DCHECK(jshandler);
|
||||
DCHECK(browser);
|
||||
if(!jshandler || !browser)
|
||||
return RV_CONTINUE;
|
||||
|
||||
CefJSHandlerCppToC::Struct* impl =
|
||||
reinterpret_cast<CefJSHandlerCppToC::Struct*>(jshandler);
|
||||
|
||||
CefBrowserCToCpp* bp = new CefBrowserCToCpp(browser);
|
||||
CefRefPtr<CefBrowser> browserPtr(bp);
|
||||
bp->UnderlyingRelease();
|
||||
|
||||
std::wstring nameStr;
|
||||
if(name)
|
||||
nameStr = name;
|
||||
|
||||
CefVariantCToCpp* vp = new CefVariantCToCpp(value);
|
||||
CefRefPtr<CefVariant> valuePtr(vp);
|
||||
vp->UnderlyingRelease();
|
||||
|
||||
return impl->class_->GetClass()->SetProperty(browserPtr, nameStr, valuePtr);
|
||||
}
|
||||
|
||||
bool CEF_CALLBACK jshandler_get_property(struct _cef_jshandler_t* jshandler,
|
||||
cef_browser_t* browser, const wchar_t* name,
|
||||
struct _cef_variant_t* value)
|
||||
{
|
||||
DCHECK(jshandler);
|
||||
DCHECK(browser);
|
||||
if(!jshandler || !browser)
|
||||
return RV_CONTINUE;
|
||||
|
||||
CefJSHandlerCppToC::Struct* impl =
|
||||
reinterpret_cast<CefJSHandlerCppToC::Struct*>(jshandler);
|
||||
|
||||
CefBrowserCToCpp* bp = new CefBrowserCToCpp(browser);
|
||||
CefRefPtr<CefBrowser> browserPtr(bp);
|
||||
bp->UnderlyingRelease();
|
||||
|
||||
std::wstring nameStr;
|
||||
if(name)
|
||||
nameStr = name;
|
||||
|
||||
CefVariantCToCpp* vp = new CefVariantCToCpp(value);
|
||||
CefRefPtr<CefVariant> valuePtr(vp);
|
||||
vp->UnderlyingRelease();
|
||||
|
||||
return impl->class_->GetClass()->GetProperty(browserPtr, nameStr, valuePtr);
|
||||
}
|
||||
|
||||
bool CEF_CALLBACK jshandler_execute_method(struct _cef_jshandler_t* jshandler,
|
||||
cef_browser_t* browser, const wchar_t* name, size_t numargs,
|
||||
struct _cef_variant_t** args, struct _cef_variant_t* retval)
|
||||
{
|
||||
DCHECK(jshandler);
|
||||
DCHECK(browser);
|
||||
if(!jshandler || !browser)
|
||||
return RV_CONTINUE;
|
||||
|
||||
CefJSHandlerCppToC::Struct* impl =
|
||||
reinterpret_cast<CefJSHandlerCppToC::Struct*>(jshandler);
|
||||
|
||||
CefBrowserCToCpp* bp = new CefBrowserCToCpp(browser);
|
||||
CefRefPtr<CefBrowser> browserPtr(bp);
|
||||
bp->UnderlyingRelease();
|
||||
|
||||
std::wstring nameStr;
|
||||
if(name)
|
||||
nameStr = name;
|
||||
|
||||
CefVariantCToCpp* vp = new CefVariantCToCpp(retval);
|
||||
CefRefPtr<CefVariant> retvalPtr(vp);
|
||||
vp->UnderlyingRelease();
|
||||
|
||||
CefJSHandler::VariantVector vec;
|
||||
for(int i = 0; i < (int)numargs; ++i) {
|
||||
vp = new CefVariantCToCpp(args[i]);
|
||||
CefRefPtr<CefVariant> argPtr(vp);
|
||||
vp->UnderlyingRelease();
|
||||
vec.push_back(argPtr);
|
||||
}
|
||||
|
||||
return impl->class_->GetClass()->ExecuteMethod(browserPtr, nameStr, vec,
|
||||
retvalPtr);
|
||||
}
|
||||
|
||||
|
||||
CefJSHandlerCppToC::CefJSHandlerCppToC(CefRefPtr<CefJSHandler> cls)
|
||||
: CefCppToC<CefJSHandler, cef_jshandler_t>(cls)
|
||||
{
|
||||
struct_.struct_.has_method = jshandler_has_method;
|
||||
struct_.struct_.has_property = jshandler_has_property;
|
||||
struct_.struct_.set_property = jshandler_set_property;
|
||||
struct_.struct_.get_property = jshandler_get_property;
|
||||
struct_.struct_.execute_method = jshandler_execute_method;
|
||||
}
|
28
libcef_dll/cpptoc/jshandler_cpptoc.h
Normal file
28
libcef_dll/cpptoc/jshandler_cpptoc.h
Normal file
@ -0,0 +1,28 @@
|
||||
// Copyright (c) 2009 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.
|
||||
|
||||
#ifndef _JSHANDLER_CPPTOC_H
|
||||
#define _JSHANDLER_CPPTOC_H
|
||||
|
||||
#ifndef USING_CEF_SHARED
|
||||
#pragma message("Warning: "__FILE__" may be accessed wrapper-side only")
|
||||
#else // USING_CEF_SHARED
|
||||
|
||||
#include "cef.h"
|
||||
#include "cef_capi.h"
|
||||
#include "cpptoc.h"
|
||||
|
||||
|
||||
// Wrap a C++ jshandler class with a C jshandler structure.
|
||||
// This class may be instantiated and accessed wrapper-side only.
|
||||
class CefJSHandlerCppToC : public CefCppToC<CefJSHandler, cef_jshandler_t>
|
||||
{
|
||||
public:
|
||||
CefJSHandlerCppToC(CefRefPtr<CefJSHandler> cls);
|
||||
virtual ~CefJSHandlerCppToC() {}
|
||||
};
|
||||
|
||||
|
||||
#endif // USING_CEF_SHARED
|
||||
#endif // _JSHANDLER_CPPTOC_H
|
425
libcef_dll/cpptoc/request_cpptoc.cc
Normal file
425
libcef_dll/cpptoc/request_cpptoc.cc
Normal file
@ -0,0 +1,425 @@
|
||||
// Copyright (c) 2009 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 "../precompiled_libcef.h"
|
||||
#include "cpptoc/request_cpptoc.h"
|
||||
#include "transfer_util.h"
|
||||
#include "base/logging.h"
|
||||
|
||||
|
||||
cef_string_t CEF_CALLBACK request_get_url(struct _cef_request_t* request)
|
||||
{
|
||||
DCHECK(request);
|
||||
if(!request)
|
||||
return NULL;
|
||||
|
||||
CefRequestCppToC::Struct* impl =
|
||||
reinterpret_cast<CefRequestCppToC::Struct*>(request);
|
||||
|
||||
std::wstring urlStr = impl->class_->GetClass()->GetURL();
|
||||
if(urlStr.empty())
|
||||
return NULL;
|
||||
return cef_string_alloc(urlStr.c_str());
|
||||
}
|
||||
|
||||
void CEF_CALLBACK request_set_url(struct _cef_request_t* request,
|
||||
const wchar_t* url)
|
||||
{
|
||||
DCHECK(request);
|
||||
if(!request)
|
||||
return;
|
||||
|
||||
CefRequestCppToC::Struct* impl =
|
||||
reinterpret_cast<CefRequestCppToC::Struct*>(request);
|
||||
|
||||
std::wstring urlStr;
|
||||
if(url)
|
||||
urlStr = url;
|
||||
impl->class_->GetClass()->SetURL(urlStr);
|
||||
}
|
||||
|
||||
cef_string_t CEF_CALLBACK request_get_frame(struct _cef_request_t* request)
|
||||
{
|
||||
DCHECK(request);
|
||||
if(!request)
|
||||
return NULL;
|
||||
|
||||
CefRequestCppToC::Struct* impl =
|
||||
reinterpret_cast<CefRequestCppToC::Struct*>(request);
|
||||
|
||||
std::wstring frameStr = impl->class_->GetClass()->GetFrame();
|
||||
if(frameStr.empty())
|
||||
return NULL;
|
||||
return cef_string_alloc(frameStr.c_str());
|
||||
}
|
||||
|
||||
void CEF_CALLBACK request_set_frame(struct _cef_request_t* request,
|
||||
const wchar_t* frame)
|
||||
{
|
||||
DCHECK(request);
|
||||
if(!request)
|
||||
return;
|
||||
|
||||
CefRequestCppToC::Struct* impl =
|
||||
reinterpret_cast<CefRequestCppToC::Struct*>(request);
|
||||
|
||||
std::wstring frameStr;
|
||||
if(frame)
|
||||
frameStr = frame;
|
||||
impl->class_->GetClass()->SetFrame(frameStr);
|
||||
}
|
||||
|
||||
cef_string_t CEF_CALLBACK request_get_method(struct _cef_request_t* request)
|
||||
{
|
||||
DCHECK(request);
|
||||
if(!request)
|
||||
return NULL;
|
||||
|
||||
CefRequestCppToC::Struct* impl =
|
||||
reinterpret_cast<CefRequestCppToC::Struct*>(request);
|
||||
|
||||
std::wstring methodStr = impl->class_->GetClass()->GetMethod();
|
||||
if(methodStr.empty())
|
||||
return NULL;
|
||||
return cef_string_alloc(methodStr.c_str());
|
||||
}
|
||||
|
||||
void CEF_CALLBACK request_set_method(struct _cef_request_t* request,
|
||||
const wchar_t* method)
|
||||
{
|
||||
DCHECK(request);
|
||||
if(!request)
|
||||
return;
|
||||
|
||||
CefRequestCppToC::Struct* impl =
|
||||
reinterpret_cast<CefRequestCppToC::Struct*>(request);
|
||||
|
||||
std::wstring methodStr;
|
||||
if(method)
|
||||
methodStr = method;
|
||||
impl->class_->GetClass()->SetMethod(methodStr);
|
||||
}
|
||||
|
||||
struct _cef_post_data_t* CEF_CALLBACK request_get_post_data(
|
||||
struct _cef_request_t* request)
|
||||
{
|
||||
DCHECK(request);
|
||||
if(!request)
|
||||
return NULL;
|
||||
|
||||
CefRequestCppToC::Struct* impl =
|
||||
reinterpret_cast<CefRequestCppToC::Struct*>(request);
|
||||
|
||||
CefRefPtr<CefPostData> postdata =
|
||||
impl->class_->GetClass()->GetPostData();
|
||||
if(!postdata.get())
|
||||
return NULL;
|
||||
|
||||
CefPostDataCppToC* rp = new CefPostDataCppToC(postdata);
|
||||
rp->AddRef();
|
||||
return rp->GetStruct();
|
||||
}
|
||||
|
||||
void CEF_CALLBACK request_set_post_data(struct _cef_request_t* request,
|
||||
struct _cef_post_data_t* postData)
|
||||
{
|
||||
DCHECK(request);
|
||||
if(!request)
|
||||
return;
|
||||
|
||||
CefRequestCppToC::Struct* impl =
|
||||
reinterpret_cast<CefRequestCppToC::Struct*>(request);
|
||||
CefPostDataCppToC::Struct* postStructPtr =
|
||||
reinterpret_cast<CefPostDataCppToC::Struct*>(postData);
|
||||
|
||||
CefRefPtr<CefPostData> postDataPtr;
|
||||
if(postStructPtr)
|
||||
postDataPtr = postStructPtr->class_->GetClass();
|
||||
|
||||
impl->class_->GetClass()->SetPostData(postDataPtr);
|
||||
}
|
||||
|
||||
void CEF_CALLBACK request_get_header_map(struct _cef_request_t* request,
|
||||
cef_string_map_t headerMap)
|
||||
{
|
||||
DCHECK(request);
|
||||
if(!request)
|
||||
return;
|
||||
|
||||
CefRequestCppToC::Struct* impl =
|
||||
reinterpret_cast<CefRequestCppToC::Struct*>(request);
|
||||
|
||||
CefRequest::HeaderMap map;
|
||||
impl->class_->GetClass()->GetHeaderMap(map);
|
||||
|
||||
transfer_string_map_contents(map, headerMap);
|
||||
}
|
||||
|
||||
void CEF_CALLBACK request_set_header_map(struct _cef_request_t* request,
|
||||
cef_string_map_t headerMap)
|
||||
{
|
||||
DCHECK(request);
|
||||
if(!request)
|
||||
return;
|
||||
|
||||
CefRequestCppToC::Struct* impl =
|
||||
reinterpret_cast<CefRequestCppToC::Struct*>(request);
|
||||
|
||||
CefRequest::HeaderMap map;
|
||||
if(headerMap)
|
||||
transfer_string_map_contents(headerMap, map);
|
||||
|
||||
impl->class_->GetClass()->SetHeaderMap(map);
|
||||
}
|
||||
|
||||
void CEF_CALLBACK request_set(struct _cef_request_t* request,
|
||||
const wchar_t* url, const wchar_t* frame,
|
||||
const wchar_t* method,
|
||||
struct _cef_post_data_t* postData,
|
||||
cef_string_map_t headerMap)
|
||||
{
|
||||
DCHECK(request);
|
||||
if(!request)
|
||||
return;
|
||||
|
||||
CefRequestCppToC::Struct* impl =
|
||||
reinterpret_cast<CefRequestCppToC::Struct*>(request);
|
||||
CefPostDataCppToC::Struct* postStructPtr =
|
||||
reinterpret_cast<CefPostDataCppToC::Struct*>(postData);
|
||||
|
||||
std::wstring urlStr, frameStr, methodStr;
|
||||
CefRefPtr<CefPostData> postPtr;
|
||||
CefRequest::HeaderMap map;
|
||||
|
||||
if(url)
|
||||
urlStr = url;
|
||||
if(frame)
|
||||
frameStr = frame;
|
||||
if(method)
|
||||
methodStr = method;
|
||||
if(postStructPtr)
|
||||
postPtr = postStructPtr->class_->GetClass();
|
||||
if(headerMap)
|
||||
transfer_string_map_contents(headerMap, map);
|
||||
|
||||
impl->class_->GetClass()->Set(urlStr, frameStr, methodStr, postPtr, map);
|
||||
}
|
||||
|
||||
|
||||
CefRequestCppToC::CefRequestCppToC(CefRefPtr<CefRequest> cls)
|
||||
: CefCppToC<CefRequest, cef_request_t>(cls)
|
||||
{
|
||||
struct_.struct_.get_url = request_get_url;
|
||||
struct_.struct_.set_url = request_set_url;
|
||||
struct_.struct_.get_frame = request_get_frame;
|
||||
struct_.struct_.set_frame = request_set_frame;
|
||||
struct_.struct_.get_method = request_get_method;
|
||||
struct_.struct_.set_method = request_set_method;
|
||||
struct_.struct_.get_post_data = request_get_post_data;
|
||||
struct_.struct_.set_post_data = request_set_post_data;
|
||||
struct_.struct_.get_header_map = request_get_header_map;
|
||||
struct_.struct_.set_header_map = request_set_header_map;
|
||||
struct_.struct_.set = request_set;
|
||||
}
|
||||
|
||||
|
||||
|
||||
size_t CEF_CALLBACK post_data_get_element_count(
|
||||
struct _cef_post_data_t* postData)
|
||||
{
|
||||
DCHECK(postData);
|
||||
if(!postData)
|
||||
return 0;
|
||||
|
||||
CefPostDataCppToC::Struct* impl =
|
||||
reinterpret_cast<CefPostDataCppToC::Struct*>(postData);
|
||||
return impl->class_->GetClass()->GetElementCount();
|
||||
}
|
||||
|
||||
struct _cef_post_data_element_t* CEF_CALLBACK post_data_get_element(
|
||||
struct _cef_post_data_t* postData, int index)
|
||||
{
|
||||
DCHECK(postData);
|
||||
if(!postData)
|
||||
return NULL;
|
||||
|
||||
CefPostDataCppToC::Struct* impl =
|
||||
reinterpret_cast<CefPostDataCppToC::Struct*>(postData);
|
||||
|
||||
CefPostData::ElementVector elements;
|
||||
impl->class_->GetClass()->GetElements(elements);
|
||||
|
||||
if(index < 0 || index >= (int)elements.size())
|
||||
return NULL;
|
||||
|
||||
CefPostDataElementCppToC* rp = new CefPostDataElementCppToC(elements[index]);
|
||||
rp->AddRef();
|
||||
return rp->GetStruct();
|
||||
}
|
||||
|
||||
int CEF_CALLBACK post_data_remove_element(struct _cef_post_data_t* postData,
|
||||
struct _cef_post_data_element_t* element)
|
||||
{
|
||||
DCHECK(postData);
|
||||
DCHECK(element);
|
||||
if(!postData || !element)
|
||||
return 0;
|
||||
|
||||
CefPostDataCppToC::Struct* impl =
|
||||
reinterpret_cast<CefPostDataCppToC::Struct*>(postData);
|
||||
CefPostDataElementCppToC::Struct* structPtr =
|
||||
reinterpret_cast<CefPostDataElementCppToC::Struct*>(element);
|
||||
|
||||
return impl->class_->GetClass()->RemoveElement(structPtr->class_->GetClass());
|
||||
}
|
||||
|
||||
int CEF_CALLBACK post_data_add_element(struct _cef_post_data_t* postData,
|
||||
struct _cef_post_data_element_t* element)
|
||||
{
|
||||
DCHECK(postData);
|
||||
DCHECK(element);
|
||||
if(!postData || !element)
|
||||
return 0;
|
||||
|
||||
CefPostDataCppToC::Struct* impl =
|
||||
reinterpret_cast<CefPostDataCppToC::Struct*>(postData);
|
||||
CefPostDataElementCppToC::Struct* structPtr =
|
||||
reinterpret_cast<CefPostDataElementCppToC::Struct*>(element);
|
||||
|
||||
return impl->class_->GetClass()->AddElement(structPtr->class_->GetClass());
|
||||
}
|
||||
|
||||
void CEF_CALLBACK post_data_remove_elements(struct _cef_post_data_t* postData)
|
||||
{
|
||||
DCHECK(postData);
|
||||
if(!postData)
|
||||
return;
|
||||
|
||||
CefPostDataCppToC::Struct* impl =
|
||||
reinterpret_cast<CefPostDataCppToC::Struct*>(postData);
|
||||
|
||||
impl->class_->GetClass()->RemoveElements();
|
||||
}
|
||||
|
||||
|
||||
CefPostDataCppToC::CefPostDataCppToC(CefRefPtr<CefPostData> cls)
|
||||
: CefCppToC<CefPostData, cef_post_data_t>(cls)
|
||||
{
|
||||
struct_.struct_.get_element_count = post_data_get_element_count;
|
||||
struct_.struct_.get_element = post_data_get_element;
|
||||
struct_.struct_.remove_element = post_data_remove_element;
|
||||
struct_.struct_.add_element = post_data_add_element;
|
||||
struct_.struct_.remove_elements = post_data_remove_elements;
|
||||
}
|
||||
|
||||
|
||||
|
||||
void CEF_CALLBACK post_data_element_set_to_empty(
|
||||
struct _cef_post_data_element_t* postDataElement)
|
||||
{
|
||||
DCHECK(postDataElement);
|
||||
if(!postDataElement)
|
||||
return;
|
||||
|
||||
CefPostDataElementCppToC::Struct* impl =
|
||||
reinterpret_cast<CefPostDataElementCppToC::Struct*>(postDataElement);
|
||||
impl->class_->GetClass()->SetToEmpty();
|
||||
}
|
||||
|
||||
void CEF_CALLBACK post_data_element_set_to_file(
|
||||
struct _cef_post_data_element_t* postDataElement,
|
||||
const wchar_t* fileName)
|
||||
{
|
||||
DCHECK(postDataElement);
|
||||
if(!postDataElement)
|
||||
return;
|
||||
|
||||
CefPostDataElementCppToC::Struct* impl =
|
||||
reinterpret_cast<CefPostDataElementCppToC::Struct*>(postDataElement);
|
||||
|
||||
std::wstring fileNameStr;
|
||||
if(fileName)
|
||||
fileNameStr = fileName;
|
||||
impl->class_->GetClass()->SetToFile(fileNameStr);
|
||||
}
|
||||
|
||||
void CEF_CALLBACK post_data_element_set_to_bytes(
|
||||
struct _cef_post_data_element_t* postDataElement, size_t size,
|
||||
const void* bytes)
|
||||
{
|
||||
DCHECK(postDataElement);
|
||||
if(!postDataElement)
|
||||
return;
|
||||
|
||||
CefPostDataElementCppToC::Struct* impl =
|
||||
reinterpret_cast<CefPostDataElementCppToC::Struct*>(postDataElement);
|
||||
impl->class_->GetClass()->SetToBytes(size, bytes);
|
||||
}
|
||||
|
||||
cef_postdataelement_type_t CEF_CALLBACK post_data_element_get_type(
|
||||
struct _cef_post_data_element_t* postDataElement)
|
||||
{
|
||||
DCHECK(postDataElement);
|
||||
if(!postDataElement)
|
||||
return PDE_TYPE_EMPTY;
|
||||
|
||||
CefPostDataElementCppToC::Struct* impl =
|
||||
reinterpret_cast<CefPostDataElementCppToC::Struct*>(postDataElement);
|
||||
return impl->class_->GetClass()->GetType();
|
||||
}
|
||||
|
||||
cef_string_t CEF_CALLBACK post_data_element_get_file(
|
||||
struct _cef_post_data_element_t* postDataElement)
|
||||
{
|
||||
DCHECK(postDataElement);
|
||||
if(!postDataElement)
|
||||
return NULL;
|
||||
|
||||
CefPostDataElementCppToC::Struct* impl =
|
||||
reinterpret_cast<CefPostDataElementCppToC::Struct*>(postDataElement);
|
||||
|
||||
std::wstring fileNameStr = impl->class_->GetClass()->GetFile();
|
||||
if(fileNameStr.empty())
|
||||
return NULL;
|
||||
return cef_string_alloc(fileNameStr.c_str());
|
||||
}
|
||||
|
||||
size_t CEF_CALLBACK post_data_element_get_bytes_count(
|
||||
struct _cef_post_data_element_t* postDataElement)
|
||||
{
|
||||
DCHECK(postDataElement);
|
||||
if(!postDataElement)
|
||||
return 0;
|
||||
|
||||
CefPostDataElementCppToC::Struct* impl =
|
||||
reinterpret_cast<CefPostDataElementCppToC::Struct*>(postDataElement);
|
||||
return impl->class_->GetClass()->GetBytesCount();
|
||||
}
|
||||
|
||||
size_t CEF_CALLBACK post_data_element_get_bytes(
|
||||
struct _cef_post_data_element_t* postDataElement, size_t size,
|
||||
void *bytes)
|
||||
{
|
||||
DCHECK(postDataElement);
|
||||
if(!postDataElement)
|
||||
return 0;
|
||||
|
||||
CefPostDataElementCppToC::Struct* impl =
|
||||
reinterpret_cast<CefPostDataElementCppToC::Struct*>(postDataElement);
|
||||
return impl->class_->GetClass()->GetBytes(size, bytes);
|
||||
}
|
||||
|
||||
|
||||
CefPostDataElementCppToC::CefPostDataElementCppToC(
|
||||
CefRefPtr<CefPostDataElement> cls)
|
||||
: CefCppToC<CefPostDataElement, cef_post_data_element_t>(cls)
|
||||
{
|
||||
struct_.struct_.set_to_empty = post_data_element_set_to_empty;
|
||||
struct_.struct_.set_to_file = post_data_element_set_to_file;
|
||||
struct_.struct_.set_to_bytes = post_data_element_set_to_bytes;
|
||||
struct_.struct_.get_type = post_data_element_get_type;
|
||||
struct_.struct_.get_file = post_data_element_get_file;
|
||||
struct_.struct_.get_bytes_count = post_data_element_get_bytes_count;
|
||||
struct_.struct_.get_bytes = post_data_element_get_bytes;
|
||||
}
|
51
libcef_dll/cpptoc/request_cpptoc.h
Normal file
51
libcef_dll/cpptoc/request_cpptoc.h
Normal file
@ -0,0 +1,51 @@
|
||||
// Copyright (c) 2009 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.
|
||||
|
||||
#ifndef _REQUEST_CPPTOC_H
|
||||
#define _REQUEST_CPPTOC_H
|
||||
|
||||
#ifndef BUILDING_CEF_SHARED
|
||||
#pragma message("Warning: "__FILE__" may be accessed DLL-side only")
|
||||
#else // BUILDING_CEF_SHARED
|
||||
|
||||
#include "cef.h"
|
||||
#include "cef_capi.h"
|
||||
#include "cpptoc.h"
|
||||
|
||||
|
||||
// Wrap a C++ request class with a C request structure.
|
||||
// This class may be instantiated and accessed DLL-side only.
|
||||
class CefRequestCppToC : public CefCppToC<CefRequest, cef_request_t>
|
||||
{
|
||||
public:
|
||||
CefRequestCppToC(CefRefPtr<CefRequest> cls);
|
||||
virtual ~CefRequestCppToC() {}
|
||||
};
|
||||
|
||||
|
||||
// Wrap a C++ post data class with a C post data structure.
|
||||
// This class may be instantiated and accessed DLL-side only.
|
||||
class CefPostDataCppToC : public CefCppToC<CefPostData, cef_post_data_t>
|
||||
{
|
||||
public:
|
||||
CefPostDataCppToC(CefRefPtr<CefPostData> cls);
|
||||
virtual ~CefPostDataCppToC() {}
|
||||
};
|
||||
|
||||
class CefPostDataElementCppToC;
|
||||
|
||||
|
||||
// Wrap a C++ post data element class with a C post data element structure.
|
||||
// This class may be instantiated and accessed DLL-side only.
|
||||
class CefPostDataElementCppToC :
|
||||
public CefCppToC<CefPostDataElement, cef_post_data_element_t>
|
||||
{
|
||||
public:
|
||||
CefPostDataElementCppToC(CefRefPtr<CefPostDataElement> cls);
|
||||
virtual ~CefPostDataElementCppToC() {}
|
||||
};
|
||||
|
||||
|
||||
#endif // BUILDING_CEF_SHARED
|
||||
#endif // _REQUEST_CPPTOC_H
|
122
libcef_dll/cpptoc/stream_cpptoc.cc
Normal file
122
libcef_dll/cpptoc/stream_cpptoc.cc
Normal file
@ -0,0 +1,122 @@
|
||||
// Copyright (c) 2009 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 "../precompiled_libcef.h"
|
||||
#include "cpptoc/stream_cpptoc.h"
|
||||
#include "base/logging.h"
|
||||
|
||||
|
||||
size_t CEF_CALLBACK stream_reader_read(struct _cef_stream_reader_t* stream,
|
||||
void *ptr, size_t size, size_t n)
|
||||
{
|
||||
DCHECK(stream);
|
||||
if(!stream)
|
||||
return 0;
|
||||
|
||||
CefStreamReaderCppToC::Struct* impl =
|
||||
reinterpret_cast<CefStreamReaderCppToC::Struct*>(stream);
|
||||
return impl->class_->GetClass()->Read(ptr, size, n);
|
||||
}
|
||||
|
||||
int CEF_CALLBACK stream_reader_seek(struct _cef_stream_reader_t* stream,
|
||||
long offset, int whence)
|
||||
{
|
||||
DCHECK(stream);
|
||||
if(!stream)
|
||||
return 0;
|
||||
|
||||
CefStreamReaderCppToC::Struct* impl =
|
||||
reinterpret_cast<CefStreamReaderCppToC::Struct*>(stream);
|
||||
return impl->class_->GetClass()->Seek(offset, whence);
|
||||
}
|
||||
|
||||
long CEF_CALLBACK stream_reader_tell(struct _cef_stream_reader_t* stream)
|
||||
{
|
||||
DCHECK(stream);
|
||||
if(!stream)
|
||||
return 0;
|
||||
|
||||
CefStreamReaderCppToC::Struct* impl =
|
||||
reinterpret_cast<CefStreamReaderCppToC::Struct*>(stream);
|
||||
return impl->class_->GetClass()->Tell();
|
||||
}
|
||||
|
||||
int CEF_CALLBACK stream_reader_eof(struct _cef_stream_reader_t* stream)
|
||||
{
|
||||
DCHECK(stream);
|
||||
if(!stream)
|
||||
return 0;
|
||||
|
||||
CefStreamReaderCppToC::Struct* impl =
|
||||
reinterpret_cast<CefStreamReaderCppToC::Struct*>(stream);
|
||||
return impl->class_->GetClass()->Eof();
|
||||
}
|
||||
|
||||
|
||||
CefStreamReaderCppToC::CefStreamReaderCppToC(CefRefPtr<CefStreamReader> cls)
|
||||
: CefCppToC<CefStreamReader, cef_stream_reader_t>(cls)
|
||||
{
|
||||
struct_.struct_.read = stream_reader_read;
|
||||
struct_.struct_.seek = stream_reader_seek;
|
||||
struct_.struct_.tell = stream_reader_tell;
|
||||
struct_.struct_.eof = stream_reader_eof;
|
||||
}
|
||||
|
||||
|
||||
|
||||
size_t CEF_CALLBACK stream_writer_write(struct _cef_stream_writer_t* stream,
|
||||
const void *ptr, size_t size, size_t n)
|
||||
{
|
||||
DCHECK(stream);
|
||||
if(!stream)
|
||||
return 0;
|
||||
|
||||
CefStreamWriterCppToC::Struct* impl =
|
||||
reinterpret_cast<CefStreamWriterCppToC::Struct*>(stream);
|
||||
return impl->class_->GetClass()->Write(ptr, size, n);
|
||||
}
|
||||
|
||||
int CEF_CALLBACK stream_writer_seek(struct _cef_stream_writer_t* stream,
|
||||
long offset, int whence)
|
||||
{
|
||||
DCHECK(stream);
|
||||
if(!stream)
|
||||
return 0;
|
||||
|
||||
CefStreamWriterCppToC::Struct* impl =
|
||||
reinterpret_cast<CefStreamWriterCppToC::Struct*>(stream);
|
||||
return impl->class_->GetClass()->Seek(offset, whence);
|
||||
}
|
||||
|
||||
long CEF_CALLBACK stream_writer_tell(struct _cef_stream_writer_t* stream)
|
||||
{
|
||||
DCHECK(stream);
|
||||
if(!stream)
|
||||
return 0;
|
||||
|
||||
CefStreamWriterCppToC::Struct* impl =
|
||||
reinterpret_cast<CefStreamWriterCppToC::Struct*>(stream);
|
||||
return impl->class_->GetClass()->Tell();
|
||||
}
|
||||
|
||||
int CEF_CALLBACK stream_writer_flush(struct _cef_stream_writer_t* stream)
|
||||
{
|
||||
DCHECK(stream);
|
||||
if(!stream)
|
||||
return 0;
|
||||
|
||||
CefStreamWriterCppToC::Struct* impl =
|
||||
reinterpret_cast<CefStreamWriterCppToC::Struct*>(stream);
|
||||
return impl->class_->GetClass()->Flush();
|
||||
}
|
||||
|
||||
|
||||
CefStreamWriterCppToC::CefStreamWriterCppToC(CefRefPtr<CefStreamWriter> cls)
|
||||
: CefCppToC<CefStreamWriter, cef_stream_writer_t>(cls)
|
||||
{
|
||||
struct_.struct_.write = stream_writer_write;
|
||||
struct_.struct_.seek = stream_writer_seek;
|
||||
struct_.struct_.tell = stream_writer_tell;
|
||||
struct_.struct_.flush = stream_writer_flush;
|
||||
}
|
40
libcef_dll/cpptoc/stream_cpptoc.h
Normal file
40
libcef_dll/cpptoc/stream_cpptoc.h
Normal file
@ -0,0 +1,40 @@
|
||||
// Copyright (c) 2009 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.
|
||||
|
||||
#ifndef _STREAM_CPPTOC_H
|
||||
#define _STREAM_CPPTOC_H
|
||||
|
||||
#ifndef BUILDING_CEF_SHARED
|
||||
#pragma message("Warning: "__FILE__" may be accessed DLL-side only")
|
||||
#else // BUILDING_CEF_SHARED
|
||||
|
||||
#include "cef.h"
|
||||
#include "cef_capi.h"
|
||||
#include "cpptoc.h"
|
||||
|
||||
|
||||
// Wrap a C++ stream reader class with a C stream reader structure.
|
||||
// This class may be instantiated and accessed DLL-side only.
|
||||
class CefStreamReaderCppToC :
|
||||
public CefCppToC<CefStreamReader, cef_stream_reader_t>
|
||||
{
|
||||
public:
|
||||
CefStreamReaderCppToC(CefRefPtr<CefStreamReader> cls);
|
||||
virtual ~CefStreamReaderCppToC() {}
|
||||
};
|
||||
|
||||
|
||||
// Wrap a C++ stream writer class with a C stream writer structure.
|
||||
// This class may be instantiated and accessed DLL-side only.
|
||||
class CefStreamWriterCppToC :
|
||||
public CefCppToC<CefStreamWriter, cef_stream_writer_t>
|
||||
{
|
||||
public:
|
||||
CefStreamWriterCppToC(CefRefPtr<CefStreamWriter> cls);
|
||||
virtual ~CefStreamWriterCppToC() {}
|
||||
};
|
||||
|
||||
|
||||
#endif // BUILDING_CEF_SHARED
|
||||
#endif // _STREAM_CPPTOC_H
|
307
libcef_dll/cpptoc/variant_cpptoc.cc
Normal file
307
libcef_dll/cpptoc/variant_cpptoc.cc
Normal file
@ -0,0 +1,307 @@
|
||||
// Copyright (c) 2009 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 "../precompiled_libcef.h"
|
||||
#include "cpptoc/variant_cpptoc.h"
|
||||
#include "base/logging.h"
|
||||
|
||||
|
||||
cef_variant_type_t CEF_CALLBACK variant_get_type(struct _cef_variant_t* variant)
|
||||
{
|
||||
DCHECK(variant);
|
||||
if(!variant)
|
||||
return VARIANT_TYPE_NULL;
|
||||
|
||||
CefVariantCppToC::Struct* impl =
|
||||
reinterpret_cast<CefVariantCppToC::Struct*>(variant);
|
||||
return impl->class_->GetClass()->GetType();
|
||||
}
|
||||
|
||||
void CEF_CALLBACK variant_set_null(struct _cef_variant_t* variant)
|
||||
{
|
||||
DCHECK(variant);
|
||||
if(!variant)
|
||||
return;
|
||||
|
||||
CefVariantCppToC::Struct* impl =
|
||||
reinterpret_cast<CefVariantCppToC::Struct*>(variant);
|
||||
impl->class_->GetClass()->SetNull();
|
||||
}
|
||||
|
||||
void CEF_CALLBACK variant_set_bool(struct _cef_variant_t* variant, int val)
|
||||
{
|
||||
DCHECK(variant);
|
||||
if(!variant)
|
||||
return;
|
||||
|
||||
CefVariantCppToC::Struct* impl =
|
||||
reinterpret_cast<CefVariantCppToC::Struct*>(variant);
|
||||
impl->class_->GetClass()->SetBool(val ? true : false);
|
||||
}
|
||||
|
||||
void CEF_CALLBACK variant_set_int(struct _cef_variant_t* variant, int val)
|
||||
{
|
||||
DCHECK(variant);
|
||||
if(!variant)
|
||||
return;
|
||||
|
||||
CefVariantCppToC::Struct* impl =
|
||||
reinterpret_cast<CefVariantCppToC::Struct*>(variant);
|
||||
impl->class_->GetClass()->SetInt(val);
|
||||
}
|
||||
|
||||
void CEF_CALLBACK variant_set_double(struct _cef_variant_t* variant, double val)
|
||||
{
|
||||
DCHECK(variant);
|
||||
if(!variant)
|
||||
return;
|
||||
|
||||
CefVariantCppToC::Struct* impl =
|
||||
reinterpret_cast<CefVariantCppToC::Struct*>(variant);
|
||||
impl->class_->GetClass()->SetDouble(val);
|
||||
}
|
||||
|
||||
void CEF_CALLBACK variant_set_string(struct _cef_variant_t* variant,
|
||||
const wchar_t* val)
|
||||
{
|
||||
DCHECK(variant);
|
||||
if(!variant)
|
||||
return;
|
||||
|
||||
CefVariantCppToC::Struct* impl =
|
||||
reinterpret_cast<CefVariantCppToC::Struct*>(variant);
|
||||
impl->class_->GetClass()->SetString(val);
|
||||
}
|
||||
|
||||
void CEF_CALLBACK variant_set_bool_array(struct _cef_variant_t* variant,
|
||||
size_t count, const int* vals)
|
||||
{
|
||||
DCHECK(variant);
|
||||
if(!variant)
|
||||
return;
|
||||
|
||||
CefVariantCppToC::Struct* impl =
|
||||
reinterpret_cast<CefVariantCppToC::Struct*>(variant);
|
||||
|
||||
std::vector<bool> vec;
|
||||
for(size_t i = 0; i < count; ++i)
|
||||
vec.push_back(vals[i] ? true : false);
|
||||
|
||||
impl->class_->GetClass()->SetBoolArray(vec);
|
||||
}
|
||||
|
||||
void CEF_CALLBACK variant_set_int_array(struct _cef_variant_t* variant,
|
||||
size_t count, const int* vals)
|
||||
{
|
||||
DCHECK(variant);
|
||||
if(!variant)
|
||||
return;
|
||||
|
||||
CefVariantCppToC::Struct* impl =
|
||||
reinterpret_cast<CefVariantCppToC::Struct*>(variant);
|
||||
|
||||
std::vector<int> vec;
|
||||
for(size_t i = 0; i < count; ++i)
|
||||
vec.push_back(vals[i]);
|
||||
|
||||
impl->class_->GetClass()->SetIntArray(vec);
|
||||
}
|
||||
|
||||
void CEF_CALLBACK variant_set_double_array(struct _cef_variant_t* variant,
|
||||
size_t count, const double* vals)
|
||||
{
|
||||
DCHECK(variant);
|
||||
if(!variant)
|
||||
return;
|
||||
|
||||
CefVariantCppToC::Struct* impl =
|
||||
reinterpret_cast<CefVariantCppToC::Struct*>(variant);
|
||||
|
||||
std::vector<double> vec;
|
||||
for(size_t i = 0; i < count; ++i)
|
||||
vec.push_back(vals[i]);
|
||||
|
||||
impl->class_->GetClass()->SetDoubleArray(vec);
|
||||
}
|
||||
|
||||
void CEF_CALLBACK variant_set_string_array(struct _cef_variant_t* variant,
|
||||
size_t count,
|
||||
const cef_string_t* vals)
|
||||
{
|
||||
DCHECK(variant);
|
||||
if(!variant)
|
||||
return;
|
||||
|
||||
CefVariantCppToC::Struct* impl =
|
||||
reinterpret_cast<CefVariantCppToC::Struct*>(variant);
|
||||
|
||||
std::vector<std::wstring> vec;
|
||||
for(size_t i = 0; i < count; ++i)
|
||||
vec.push_back(vals[i] ? vals[i] : std::wstring());
|
||||
|
||||
impl->class_->GetClass()->SetStringArray(vec);
|
||||
}
|
||||
|
||||
|
||||
int CEF_CALLBACK variant_get_bool(struct _cef_variant_t* variant)
|
||||
{
|
||||
DCHECK(variant);
|
||||
if(!variant)
|
||||
return 0;
|
||||
|
||||
CefVariantCppToC::Struct* impl =
|
||||
reinterpret_cast<CefVariantCppToC::Struct*>(variant);
|
||||
return impl->class_->GetClass()->GetBool();
|
||||
}
|
||||
|
||||
int CEF_CALLBACK variant_get_int(struct _cef_variant_t* variant)
|
||||
{
|
||||
DCHECK(variant);
|
||||
if(!variant)
|
||||
return 0;
|
||||
|
||||
CefVariantCppToC::Struct* impl =
|
||||
reinterpret_cast<CefVariantCppToC::Struct*>(variant);
|
||||
return impl->class_->GetClass()->GetInt();
|
||||
}
|
||||
|
||||
double CEF_CALLBACK variant_get_double(struct _cef_variant_t* variant)
|
||||
{
|
||||
DCHECK(variant);
|
||||
if(!variant)
|
||||
return 0;
|
||||
|
||||
CefVariantCppToC::Struct* impl =
|
||||
reinterpret_cast<CefVariantCppToC::Struct*>(variant);
|
||||
return impl->class_->GetClass()->GetDouble();
|
||||
}
|
||||
|
||||
cef_string_t CEF_CALLBACK variant_get_string(struct _cef_variant_t* variant)
|
||||
{
|
||||
DCHECK(variant);
|
||||
if(!variant)
|
||||
return NULL;
|
||||
|
||||
CefVariantCppToC::Struct* impl =
|
||||
reinterpret_cast<CefVariantCppToC::Struct*>(variant);
|
||||
|
||||
std::wstring str;
|
||||
str = impl->class_->GetClass()->GetString();
|
||||
if(str.empty())
|
||||
return NULL;
|
||||
return cef_string_alloc(str.c_str());
|
||||
}
|
||||
|
||||
int CEF_CALLBACK variant_get_array_size(struct _cef_variant_t* variant)
|
||||
{
|
||||
DCHECK(variant);
|
||||
if(!variant)
|
||||
return 0;
|
||||
|
||||
CefVariantCppToC::Struct* impl =
|
||||
reinterpret_cast<CefVariantCppToC::Struct*>(variant);
|
||||
return impl->class_->GetClass()->GetArraySize();
|
||||
}
|
||||
|
||||
size_t CEF_CALLBACK variant_get_bool_array(struct _cef_variant_t* variant,
|
||||
size_t maxcount, int* vals)
|
||||
{
|
||||
DCHECK(variant);
|
||||
if(!variant)
|
||||
return 0;
|
||||
|
||||
CefVariantCppToC::Struct* impl =
|
||||
reinterpret_cast<CefVariantCppToC::Struct*>(variant);
|
||||
|
||||
std::vector<bool> vec;
|
||||
impl->class_->GetClass()->GetBoolArray(vec);
|
||||
|
||||
size_t ct = 0;
|
||||
for(; ct < maxcount && ct < vec.size(); ++ct)
|
||||
vals[ct] = vec[ct];
|
||||
return ct;
|
||||
}
|
||||
|
||||
size_t CEF_CALLBACK variant_get_int_array(struct _cef_variant_t* variant,
|
||||
size_t maxcount, int* vals)
|
||||
{
|
||||
DCHECK(variant);
|
||||
if(!variant)
|
||||
return 0;
|
||||
|
||||
CefVariantCppToC::Struct* impl =
|
||||
reinterpret_cast<CefVariantCppToC::Struct*>(variant);
|
||||
|
||||
std::vector<int> vec;
|
||||
impl->class_->GetClass()->GetIntArray(vec);
|
||||
|
||||
size_t ct = 0;
|
||||
for(; ct < maxcount && ct < vec.size(); ++ct)
|
||||
vals[ct] = vec[ct];
|
||||
return ct;
|
||||
}
|
||||
|
||||
size_t CEF_CALLBACK variant_get_double_array(struct _cef_variant_t* variant,
|
||||
size_t maxcount, double* vals)
|
||||
{
|
||||
DCHECK(variant);
|
||||
if(!variant)
|
||||
return 0;
|
||||
|
||||
CefVariantCppToC::Struct* impl =
|
||||
reinterpret_cast<CefVariantCppToC::Struct*>(variant);
|
||||
|
||||
std::vector<double> vec;
|
||||
impl->class_->GetClass()->GetDoubleArray(vec);
|
||||
|
||||
size_t ct = 0;
|
||||
for(; ct < maxcount && ct < vec.size(); ++ct)
|
||||
vals[ct] = vec[ct];
|
||||
return ct;
|
||||
}
|
||||
|
||||
size_t CEF_CALLBACK variant_get_string_array(struct _cef_variant_t* variant,
|
||||
size_t maxcount,
|
||||
cef_string_t* vals)
|
||||
{
|
||||
DCHECK(variant);
|
||||
if(!variant)
|
||||
return 0;
|
||||
|
||||
CefVariantCppToC::Struct* impl =
|
||||
reinterpret_cast<CefVariantCppToC::Struct*>(variant);
|
||||
|
||||
std::vector<std::wstring> vec;
|
||||
impl->class_->GetClass()->GetStringArray(vec);
|
||||
|
||||
size_t ct = 0;
|
||||
for(; ct < maxcount && ct < vec.size(); ++ct)
|
||||
vals[ct] = cef_string_alloc(vec[ct].c_str());
|
||||
return ct;
|
||||
}
|
||||
|
||||
|
||||
CefVariantCppToC::CefVariantCppToC(CefRefPtr<CefVariant> cls)
|
||||
: CefCppToC<CefVariant, cef_variant_t>(cls)
|
||||
{
|
||||
struct_.struct_.get_type = variant_get_type;
|
||||
struct_.struct_.set_null = variant_set_null;
|
||||
struct_.struct_.set_bool = variant_set_bool;
|
||||
struct_.struct_.set_int = variant_set_int;
|
||||
struct_.struct_.set_double = variant_set_double;
|
||||
struct_.struct_.set_string = variant_set_string;
|
||||
struct_.struct_.set_bool_array = variant_set_bool_array;
|
||||
struct_.struct_.set_int_array = variant_set_int_array;
|
||||
struct_.struct_.set_double_array = variant_set_double_array;
|
||||
struct_.struct_.set_string_array = variant_set_string_array;
|
||||
struct_.struct_.get_bool = variant_get_bool;
|
||||
struct_.struct_.get_int = variant_get_int;
|
||||
struct_.struct_.get_double = variant_get_double;
|
||||
struct_.struct_.get_string = variant_get_string;
|
||||
struct_.struct_.get_array_size = variant_get_array_size;
|
||||
struct_.struct_.get_bool_array = variant_get_bool_array;
|
||||
struct_.struct_.get_int_array = variant_get_int_array;
|
||||
struct_.struct_.get_double_array = variant_get_double_array;
|
||||
struct_.struct_.get_string_array = variant_get_string_array;
|
||||
}
|
28
libcef_dll/cpptoc/variant_cpptoc.h
Normal file
28
libcef_dll/cpptoc/variant_cpptoc.h
Normal file
@ -0,0 +1,28 @@
|
||||
// Copyright (c) 2009 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.
|
||||
|
||||
#ifndef _VARIANT_CPPTOC_H
|
||||
#define _VARIANT_CPPTOC_H
|
||||
|
||||
#ifndef BUILDING_CEF_SHARED
|
||||
#pragma message("Warning: "__FILE__" may be accessed DLL-side only")
|
||||
#else // BUILDING_CEF_SHARED
|
||||
|
||||
#include "cef.h"
|
||||
#include "cef_capi.h"
|
||||
#include "cpptoc.h"
|
||||
|
||||
|
||||
// Wrap a C++ browser class with a C browser structure.
|
||||
// This class may be instantiated and accessed DLL-side only.
|
||||
class CefVariantCppToC : public CefCppToC<CefVariant, cef_variant_t>
|
||||
{
|
||||
public:
|
||||
CefVariantCppToC(CefRefPtr<CefVariant> cls);
|
||||
virtual ~CefVariantCppToC() {}
|
||||
};
|
||||
|
||||
|
||||
#endif // BUILDING_CEF_SHARED
|
||||
#endif // _VARIANT_CPPTOC_H
|
Reference in New Issue
Block a user