diff options
author | brettw@chromium.org <brettw@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-11-03 03:22:33 +0000 |
---|---|---|
committer | brettw@chromium.org <brettw@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-11-03 03:22:33 +0000 |
commit | c2932f5e2101022f6fe59dabd462ccc328788d4e (patch) | |
tree | 0690f2db30f3f1591c8dec15fbd4d0c63c662899 /ppapi/proxy/callback_tracker.cc | |
parent | 685b7699b2845fd74e601a3a9f74cf3b63c9f38a (diff) | |
download | chromium_src-c2932f5e2101022f6fe59dabd462ccc328788d4e.zip chromium_src-c2932f5e2101022f6fe59dabd462ccc328788d4e.tar.gz chromium_src-c2932f5e2101022f6fe59dabd462ccc328788d4e.tar.bz2 |
Core PPAPI proxy files. This includes the dispatcher which is the control point
on each end of the IPC channel. It includes the IPC message definitions. It
also includes the base class for the interface proxying, and the core resource
and var tracking.
BUG=none
TEST=none
Review=http://codereview.chromium.org/4229002/show
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@64874 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'ppapi/proxy/callback_tracker.cc')
-rw-r--r-- | ppapi/proxy/callback_tracker.cc | 72 |
1 files changed, 72 insertions, 0 deletions
diff --git a/ppapi/proxy/callback_tracker.cc b/ppapi/proxy/callback_tracker.cc new file mode 100644 index 0000000..9806497 --- /dev/null +++ b/ppapi/proxy/callback_tracker.cc @@ -0,0 +1,72 @@ +// 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 "ppapi/proxy/callback_tracker.h" + +#include "ppapi/proxy/dispatcher.h" +#include "ppapi/proxy/ppapi_messages.h" + +namespace pp { +namespace proxy { + +namespace { + +struct CallbackData { + CallbackTracker* tracker; + uint32_t callback_id; +}; + +void CallbackProxy(void* user_data, int32_t result) { + CallbackData* data = static_cast<CallbackData*>(user_data); + data->tracker->SendExecuteSerializedCallback(data->callback_id, result); + delete data; +} + +} // namespace + +CallbackTracker::CallbackTracker(Dispatcher* dispatcher) + : dispatcher_(dispatcher), + next_callback_id_(1) { +} + +CallbackTracker::~CallbackTracker() { +} + +uint32_t CallbackTracker::SendCallback(PP_CompletionCallback callback) { + // Find the next callback ID we can use (being careful about wraparound). + while (callback_map_.find(next_callback_id_) != callback_map_.end()) + next_callback_id_++; + callback_map_[next_callback_id_] = callback; + return next_callback_id_++; +} + +PP_CompletionCallback CallbackTracker::ReceiveCallback( + uint32_t serialized_callback) { + CallbackData* data = new CallbackData; + data->tracker = this; + data->callback_id = serialized_callback; + return PP_MakeCompletionCallback(&CallbackProxy, data); +} + +void CallbackTracker::SendExecuteSerializedCallback( + uint32_t serialized_callback, + int32_t param) { + dispatcher_->Send(new PpapiMsg_ExecuteCallback(serialized_callback, param)); +} + +void CallbackTracker::ReceiveExecuteSerializedCallback( + uint32_t serialized_callback, + int32_t param) { + CallbackMap::iterator found = callback_map_.find(serialized_callback); + if (found == callback_map_.end()) { + NOTREACHED(); + return; + } + + PP_RunCompletionCallback(&found->second, param); + callback_map_.erase(found); +} + +} // namespace proxy +} // namespace pp |