mirror of
https://bitbucket.org/chromiumembedded/cef
synced 2024-12-12 01:26:03 +01:00
9aa285ac8d
- Fix parsing error in cef_parser.py due to space between angle brackets in template type definitions, and add support for int64 type. - Update copyright messages in Python and generated files. git-svn-id: https://chromiumembedded.googlecode.com/svn/trunk@117 5089003a-bbd8-11dd-ad1f-f1f9622dbc98
85 lines
2.3 KiB
C++
85 lines
2.3 KiB
C++
// Copyright (c) 2010 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.
|
|
//
|
|
// ---------------------------------------------------------------------------
|
|
//
|
|
// A portion of this file was generated by the CEF translator tool. When
|
|
// making changes by hand only do so within the body of existing function
|
|
// implementations. See the translator.README.txt file in the tools directory
|
|
// for more information.
|
|
//
|
|
|
|
#include "libcef_dll/cpptoc/scheme_handler_cpptoc.h"
|
|
#include "libcef_dll/ctocpp/request_ctocpp.h"
|
|
#include "libcef_dll/transfer_util.h"
|
|
|
|
|
|
// MEMBER FUNCTIONS - Body may be edited by hand.
|
|
|
|
int CEF_CALLBACK scheme_handler_process_request(
|
|
struct _cef_scheme_handler_t* self, cef_request_t* request,
|
|
cef_string_t* mime_type, int* response_length)
|
|
{
|
|
DCHECK(self);
|
|
DCHECK(request);
|
|
DCHECK(mime_type);
|
|
DCHECK(response_length);
|
|
if(!self || !request || !mime_type || !response_length)
|
|
return 0;
|
|
|
|
std::wstring mimeTypeStr;
|
|
if(*mime_type)
|
|
mimeTypeStr = *mime_type;
|
|
|
|
bool rv = CefSchemeHandlerCppToC::Get(self)->ProcessRequest(
|
|
CefRequestCToCpp::Wrap(request), mimeTypeStr, response_length);
|
|
|
|
transfer_string_contents(mimeTypeStr, mime_type);
|
|
|
|
return rv?1:0;
|
|
}
|
|
|
|
void CEF_CALLBACK scheme_handler_cancel(struct _cef_scheme_handler_t* self)
|
|
{
|
|
DCHECK(self);
|
|
if(!self)
|
|
return;
|
|
|
|
CefSchemeHandlerCppToC::Get(self)->Cancel();
|
|
}
|
|
|
|
int CEF_CALLBACK scheme_handler_read_response(
|
|
struct _cef_scheme_handler_t* self, void* data_out, int bytes_to_read,
|
|
int* bytes_read)
|
|
{
|
|
DCHECK(self);
|
|
DCHECK(data_out);
|
|
DCHECK(bytes_read);
|
|
if(!self || !data_out || !bytes_read)
|
|
return 0;
|
|
|
|
bool rv = CefSchemeHandlerCppToC::Get(self)->ReadResponse(
|
|
data_out, bytes_to_read, bytes_read);
|
|
|
|
return rv?1:0;
|
|
}
|
|
|
|
|
|
// CONSTRUCTOR - Do not edit by hand.
|
|
|
|
CefSchemeHandlerCppToC::CefSchemeHandlerCppToC(CefSchemeHandler* cls)
|
|
: CefCppToC<CefSchemeHandlerCppToC, CefSchemeHandler, cef_scheme_handler_t>(
|
|
cls)
|
|
{
|
|
struct_.struct_.process_request = scheme_handler_process_request;
|
|
struct_.struct_.cancel = scheme_handler_cancel;
|
|
struct_.struct_.read_response = scheme_handler_read_response;
|
|
}
|
|
|
|
#ifdef _DEBUG
|
|
long CefCppToC<CefSchemeHandlerCppToC, CefSchemeHandler,
|
|
cef_scheme_handler_t>::DebugObjCt = 0;
|
|
#endif
|
|
|