| Index: ppapi/cpp/message_loop.cc
|
| diff --git a/ppapi/cpp/message_loop.cc b/ppapi/cpp/message_loop.cc
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..df3800737ddce4b53b5dfdb317315541fb3eb02f
|
| --- /dev/null
|
| +++ b/ppapi/cpp/message_loop.cc
|
| @@ -0,0 +1,87 @@
|
| +// Copyright (c) 2012 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 "ppapi/cpp/message_loop.h"
|
| +
|
| +#include "ppapi/c/pp_errors.h"
|
| +#include "ppapi/c/ppb_message_loop.h"
|
| +#include "ppapi/cpp/completion_callback.h"
|
| +#include "ppapi/cpp/instance_handle.h"
|
| +#include "ppapi/cpp/module_impl.h"
|
| +
|
| +namespace pp {
|
| +
|
| +namespace {
|
| +
|
| +template <> const char* interface_name<PPB_MessageLoop>() {
|
| + return PPB_MESSAGELOOP_INTERFACE_1_0;
|
| +}
|
| +
|
| +} // namespace
|
| +
|
| +MessageLoop::MessageLoop() : Resource() {
|
| +}
|
| +
|
| +MessageLoop::MessageLoop(const InstanceHandle& instance) : Resource() {
|
| + if (has_interface<PPB_MessageLoop>()) {
|
| + PassRefFromConstructor(get_interface<PPB_MessageLoop>()->Create(
|
| + instance.pp_instance()));
|
| + }
|
| +}
|
| +
|
| +MessageLoop::MessageLoop(const MessageLoop& other)
|
| + : Resource(other) {
|
| +}
|
| +
|
| +MessageLoop::MessageLoop(PP_Resource pp_message_loop)
|
| + : Resource(pp_message_loop) {
|
| +}
|
| +
|
| +// static
|
| +MessageLoop MessageLoop::GetForMainThread() {
|
| + if (!has_interface<PPB_MessageLoop>())
|
| + return MessageLoop();
|
| + return MessageLoop(
|
| + get_interface<PPB_MessageLoop>()->GetForMainThread());
|
| +}
|
| +
|
| +// static
|
| +MessageLoop MessageLoop::GetCurrent() {
|
| + if (!has_interface<PPB_MessageLoop>())
|
| + return MessageLoop();
|
| + return MessageLoop(
|
| + get_interface<PPB_MessageLoop>()->GetCurrent());
|
| +}
|
| +
|
| +int32_t MessageLoop::AttachToCurrentThread() {
|
| + if (!has_interface<PPB_MessageLoop>())
|
| + return PP_ERROR_NOINTERFACE;
|
| + return get_interface<PPB_MessageLoop>()->AttachToCurrentThread(
|
| + pp_resource());
|
| +}
|
| +
|
| +int32_t MessageLoop::Run() {
|
| + if (!has_interface<PPB_MessageLoop>())
|
| + return PP_ERROR_NOINTERFACE;
|
| + return get_interface<PPB_MessageLoop>()->Run(pp_resource());
|
| +}
|
| +
|
| +int32_t MessageLoop::PostWork(const CompletionCallback& callback,
|
| + int64_t delay_ms) {
|
| + if (!has_interface<PPB_MessageLoop>())
|
| + return PP_ERROR_NOINTERFACE;
|
| + return get_interface<PPB_MessageLoop>()->PostWork(
|
| + pp_resource(),
|
| + callback.pp_completion_callback(),
|
| + delay_ms);
|
| +}
|
| +
|
| +int32_t MessageLoop::PostQuit(bool should_destroy) {
|
| + if (!has_interface<PPB_MessageLoop>())
|
| + return PP_ERROR_NOINTERFACE;
|
| + return get_interface<PPB_MessageLoop>()->PostQuit(
|
| + pp_resource(), PP_FromBool(should_destroy));
|
| +}
|
| +
|
| +} // namespace pp
|
|
|