Index: webkit/plugins/npapi/plugin_instance_mac.mm |
=================================================================== |
--- webkit/plugins/npapi/plugin_instance_mac.mm (revision 212369) |
+++ webkit/plugins/npapi/plugin_instance_mac.mm (working copy) |
@@ -1,108 +0,0 @@ |
-// 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. |
- |
-#import <AppKit/AppKit.h> |
- |
-#include "base/logging.h" |
-#include "build/build_config.h" |
-#include "webkit/plugins/npapi/plugin_instance.h" |
- |
-// When C++ exceptions are disabled, the C++ library defines |try| and |
-// |catch| so as to allow exception-expecting C++ code to build properly when |
-// language support for exceptions is not present. These macros interfere |
-// with the use of |@try| and |@catch| in Objective-C files such as this one. |
-// Undefine these macros here, after everything has been #included, since |
-// there will be no C++ uses and only Objective-C uses from this point on. |
-#undef try |
-#undef catch |
- |
-namespace webkit { |
-namespace npapi { |
- |
-namespace { |
- |
-// Returns an autoreleased NSEvent constructed from the given np_event, |
-// targeting the given window. |
-NSEvent* NSEventForNPCocoaEvent(NPCocoaEvent* np_event, NSWindow* window) { |
- bool mouse_down = 1; |
- switch (np_event->type) { |
- case NPCocoaEventMouseDown: |
- mouse_down = 1; |
- break; |
- case NPCocoaEventMouseUp: |
- mouse_down = 0; |
- break; |
- default: |
- // If plugins start bringing up context menus for things other than |
- // clicks, this will need more plumbing; for now just log it and proceed |
- // as if it were a mouse down. |
- NOTREACHED(); |
- } |
- NSEventType event_type = NSLeftMouseDown; |
- switch (np_event->data.mouse.buttonNumber) { |
- case 0: |
- event_type = mouse_down ? NSLeftMouseDown : NSLeftMouseUp; |
- break; |
- case 1: |
- event_type = mouse_down ? NSRightMouseDown : NSRightMouseUp; |
- break; |
- default: |
- event_type = mouse_down ? NSOtherMouseDown : NSOtherMouseUp; |
- break; |
- } |
- |
- NSInteger click_count = np_event->data.mouse.clickCount; |
- NSInteger modifiers = np_event->data.mouse.modifierFlags; |
- // NPCocoaEvent doesn't have a timestamp, so just use the current time. |
- NSEvent* event = |
- [NSEvent mouseEventWithType:event_type |
- location:NSZeroPoint |
- modifierFlags:modifiers |
- timestamp:[[NSApp currentEvent] timestamp] |
- windowNumber:[window windowNumber] |
- context:[NSGraphicsContext currentContext] |
- eventNumber:0 |
- clickCount:click_count |
- pressure:1.0]; |
- return event; |
-} |
- |
-} // namespace |
- |
-NPError PluginInstance::PopUpContextMenu(NPMenu* menu) { |
- if (!currently_handled_event_) |
- return NPERR_GENERIC_ERROR; |
- |
- CGRect main_display_bounds = CGDisplayBounds(CGMainDisplayID()); |
- NSPoint screen_point = NSMakePoint( |
- plugin_origin_.x() + currently_handled_event_->data.mouse.pluginX, |
- plugin_origin_.y() + currently_handled_event_->data.mouse.pluginY); |
- // Plugin offsets are upper-left based, so flip vertically for Cocoa. |
- screen_point.y = main_display_bounds.size.height - screen_point.y; |
- |
- NSMenu* nsmenu = reinterpret_cast<NSMenu*>(menu); |
- NPError return_val = NPERR_NO_ERROR; |
- @try { |
- [nsmenu popUpMenuPositioningItem:nil atLocation:screen_point inView:nil]; |
- } |
- @catch (NSException* e) { |
- NSLog(@"Caught exception while handling PopUpContextMenu: %@", e); |
- return_val = NPERR_GENERIC_ERROR; |
- } |
- |
- return return_val; |
-} |
- |
-ScopedCurrentPluginEvent::ScopedCurrentPluginEvent(PluginInstance* instance, |
- NPCocoaEvent* event) |
- : instance_(instance) { |
- instance_->set_currently_handled_event(event); |
-} |
- |
-ScopedCurrentPluginEvent::~ScopedCurrentPluginEvent() { |
- instance_->set_currently_handled_event(NULL); |
-} |
- |
-} // namespace npapi |
-} // namespace webkit |