diff options
author | brettw@chromium.org <brettw@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2011-05-27 21:50:28 +0000 |
---|---|---|
committer | brettw@chromium.org <brettw@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2011-05-27 21:50:28 +0000 |
commit | 9815108ef72b28eab4c78fe43db9db171f24cd57 (patch) | |
tree | f7fe8ea186168eb655eb927113a7f68886ed65dd /ppapi/thunk/ppb_cursor_control_thunk.cc | |
parent | 25fe7fc560ac4350eb57f070194e2755279f7fb4 (diff) | |
download | chromium_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.cc | 67 |
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 |