Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(918)

Side by Side Diff: chrome/browser/ui/cocoa/event_utils.mm

Issue 7792048: WindowOpenDisposition should not be exposed in base and ui modules. (mac) (Closed) Base URL: http://git.chromium.org/git/chromium.git@trunk
Patch Set: Created 9 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2009 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #import "chrome/browser/ui/cocoa/event_utils.h" 5 #import "chrome/browser/ui/cocoa/event_utils.h"
6 6
7 #include "chrome/browser/event_disposition.h"
7 #include "content/browser/disposition_utils.h" 8 #include "content/browser/disposition_utils.h"
9 #include "ui/base/events.h"
10
11 namespace {
Avi (use Gerrit) 2011/08/30 20:11:17 mark end of namespace with // namespace, and with
shinyak (Google) 2011/08/31 06:09:23 Done.
12 bool isLeftButtonEvent(NSEvent* event) {
13 NSEventType type = [event type];
14 return type == NSLeftMouseDown ||
15 type == NSLeftMouseDragged ||
16 type == NSLeftMouseUp;
17 }
18
19 bool isRightButtonEvent(NSEvent* event) {
20 NSEventType type = [event type];
21 return type == NSRightMouseDown ||
22 type == NSRightMouseDragged ||
23 type == NSRightMouseUp;
24 }
25
26 bool isMiddleButtonEvent(NSEvent* event) {
27 if ([event buttonNumber] != 2)
28 return false;
29
30 NSEventType type = [event type];
31 return type == NSOtherMouseDown ||
32 type == NSOtherMouseDragged ||
33 type == NSOtherMouseUp;
34 }
35 }
8 36
9 namespace event_utils { 37 namespace event_utils {
10 38
39 // Retrieves a bitsum of ui::EventFlags from NSEvent.
40 int EventFlagsFromNSEvent(NSEvent* event) {
41 NSUInteger modifiers = [event modifierFlags];
42 return EventFlagsFromNSEventWithModifiers(event, modifiers);
43 }
44
45 int EventFlagsFromNSEventWithModifiers(NSEvent* event, NSUInteger modifiers) {
46 int flags = 0;
47 flags |= (modifiers & NSAlphaShiftKeyMask) ? ui::EF_CAPS_LOCK_DOWN : 0;
48 flags |= (modifiers & NSShiftKeyMask) ? ui::EF_SHIFT_DOWN : 0;
49 flags |= (modifiers & NSControlKeyMask) ? ui::EF_CONTROL_DOWN : 0;
50 flags |= (modifiers & NSAlternateKeyMask) ? ui::EF_ALT_DOWN : 0;
51 flags |= (modifiers & NSCommandKeyMask) ? ui::EF_COMMAND_DOWN : 0;
52 flags |= isLeftButtonEvent(event) ? ui::EF_LEFT_BUTTON_DOWN : 0;
53 flags |= isRightButtonEvent(event) ? ui::EF_RIGHT_BUTTON_DOWN : 0;
54 flags |= isMiddleButtonEvent(event) ? ui::EF_MIDDLE_BUTTON_DOWN : 0;
55 return flags;
56 }
57
11 WindowOpenDisposition WindowOpenDispositionFromNSEvent(NSEvent* event) { 58 WindowOpenDisposition WindowOpenDispositionFromNSEvent(NSEvent* event) {
12 NSUInteger modifiers = [event modifierFlags]; 59 NSUInteger modifiers = [event modifierFlags];
13 return WindowOpenDispositionFromNSEventWithFlags(event, modifiers); 60 return WindowOpenDispositionFromNSEventWithFlags(event, modifiers);
14 } 61 }
15 62
16 WindowOpenDisposition WindowOpenDispositionFromNSEventWithFlags( 63 WindowOpenDisposition WindowOpenDispositionFromNSEventWithFlags(
17 NSEvent* event, NSUInteger flags) { 64 NSEvent* event, NSUInteger modifiers) {
18 return disposition_utils::DispositionFromClick( 65 int event_flags = EventFlagsFromNSEventWithModifiers(event, modifiers);
19 [event buttonNumber] == 2, 66 return browser::DispositionFromEventFlags(event_flags);
20 flags & NSAlternateKeyMask,
21 flags & NSControlKeyMask,
22 flags & NSCommandKeyMask,
23 flags & NSShiftKeyMask);
24 } 67 }
25 68
26 } // namespace event_utils 69 } // namespace event_utils
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698