summaryrefslogtreecommitdiffstats
path: root/ppapi/thunk/ppb_cursor_control_thunk.cc
diff options
context:
space:
mode:
authorbrettw@chromium.org <brettw@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-05-27 21:50:28 +0000
committerbrettw@chromium.org <brettw@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-05-27 21:50:28 +0000
commit9815108ef72b28eab4c78fe43db9db171f24cd57 (patch)
treef7fe8ea186168eb655eb927113a7f68886ed65dd /ppapi/thunk/ppb_cursor_control_thunk.cc
parent25fe7fc560ac4350eb57f070194e2755279f7fb4 (diff)
downloadchromium_src-9815108ef72b28eab4c78fe43db9db171f24cd57.zip
chromium_src-9815108ef72b28eab4c78fe43db9db171f24cd57.tar.gz
chromium_src-9815108ef72b28eab4c78fe43db9db171f24cd57.tar.bz2
Move Broker, Buffer, CharSet, and CursorControl to use the new thunk/API system.
This changes the way that the function APIs work in the webkit directory, now they're created per-instance rather than globally, and have their Plugininstance as a class member (this cleans up some code). I had to move the InstanceData member to be a linked_ptr due to copy constructor issues, but this should be more efficient anyway. Review URL: http://codereview.chromium.org/7077024 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@87094 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'ppapi/thunk/ppb_cursor_control_thunk.cc')
-rw-r--r--ppapi/thunk/ppb_cursor_control_thunk.cc67
1 files changed, 67 insertions, 0 deletions
diff --git a/ppapi/thunk/ppb_cursor_control_thunk.cc b/ppapi/thunk/ppb_cursor_control_thunk.cc
new file mode 100644
index 0000000..56ba078
--- /dev/null
+++ b/ppapi/thunk/ppb_cursor_control_thunk.cc
@@ -0,0 +1,67 @@
+// Copyright (c) 2011 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/thunk/thunk.h"
+#include "ppapi/thunk/enter.h"
+#include "ppapi/thunk/ppb_cursor_control_api.h"
+
+namespace ppapi {
+namespace thunk {
+
+namespace {
+
+PP_Bool SetCursor(PP_Instance instance,
+ PP_CursorType_Dev type,
+ PP_Resource custom_image,
+ const PP_Point* hot_spot) {
+ EnterFunction<PPB_CursorControl_FunctionAPI> enter(instance, true);
+ if (enter.failed())
+ return PP_FALSE;
+ return enter.functions()->SetCursor(instance, type, custom_image, hot_spot);
+}
+
+PP_Bool LockCursor(PP_Instance instance) {
+ EnterFunction<PPB_CursorControl_FunctionAPI> enter(instance, true);
+ if (enter.failed())
+ return PP_FALSE;
+ return enter.functions()->LockCursor(instance);
+}
+
+PP_Bool UnlockCursor(PP_Instance instance) {
+ EnterFunction<PPB_CursorControl_FunctionAPI> enter(instance, true);
+ if (enter.failed())
+ return PP_FALSE;
+ return enter.functions()->UnlockCursor(instance);
+}
+
+PP_Bool HasCursorLock(PP_Instance instance) {
+ EnterFunction<PPB_CursorControl_FunctionAPI> enter(instance, true);
+ if (enter.failed())
+ return PP_FALSE;
+ return enter.functions()->HasCursorLock(instance);
+}
+
+PP_Bool CanLockCursor(PP_Instance instance) {
+ EnterFunction<PPB_CursorControl_FunctionAPI> enter(instance, true);
+ if (enter.failed())
+ return PP_FALSE;
+ return enter.functions()->CanLockCursor(instance);
+}
+
+const PPB_CursorControl_Dev g_ppb_cursor_control_thunk = {
+ &SetCursor,
+ &LockCursor,
+ &UnlockCursor,
+ &HasCursorLock,
+ &CanLockCursor
+};
+
+} // namespace
+
+const PPB_CursorControl_Dev* GetPPB_CursorControl_Thunk() {
+ return &g_ppb_cursor_control_thunk;
+}
+
+} // namespace thunk
+} // namespace ppapi