mozilla-bmo1360278.patch
author Wolfgang Rosenauer <wr@rosenauer.org>
Wed, 03 Jan 2018 14:41:12 +0100
branchfirefox57
changeset 1014 963651ec972e
parent 1012 0c59a30173da
permissions -rw-r--r--
real fix for Bug 1069962 - Tumbleweed: OpenSuse's Firefox version crashes when "cancel" pressed in "File Upload" dialogue, e.g. TYPO3, BUGZILLA
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1012
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
     1
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
     2
# HG changeset patch
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
     3
# User Robin Grenet <robin.grenet@wanadoo.fr>
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
     4
# Date 1510835758 -3600
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
     5
# Node ID f540f9e801cb2e0be5259baea13dfce953ccb520
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
     6
# Parent  0abbf75bd0ecfa99ab4386f551a622983f5f27ea
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
     7
Bug 1360278 - Add preference to trigger context menu on mouse up for GTK+ and macOS, r=mstange,smaug
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
     8
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
     9
MozReview-Commit-ID: Bg60bD8jIg6
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    10
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    11
diff --git a/modules/libpref/init/all.js b/modules/libpref/init/all.js
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    12
--- a/modules/libpref/init/all.js
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    13
+++ b/modules/libpref/init/all.js
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    14
@@ -229,16 +229,20 @@ pref("dom.script_loader.bytecode_cache.e
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    15
 pref("dom.script_loader.bytecode_cache.strategy", 0);
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    16
 
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    17
 // Fastback caching - if this pref is negative, then we calculate the number
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    18
 // of content viewers to cache based on the amount of available memory.
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    19
 pref("browser.sessionhistory.max_total_viewers", -1);
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    20
 
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    21
 pref("ui.use_native_colors", true);
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    22
 pref("ui.click_hold_context_menus", false);
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    23
+
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    24
+// Pop up context menu on mouseup instead of mousedown, if that's the OS default.
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    25
+// Note: ignored on Windows (context menus always use mouseup)
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    26
+pref("ui.context_menus.after_mouseup", false);
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    27
 // Duration of timeout of incremental search in menus (ms).  0 means infinite.
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    28
 pref("ui.menu.incremental_search.timeout", 1000);
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    29
 // If true, all popups won't hide automatically on blur
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    30
 pref("ui.popup.disable_autohide", false);
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    31
 
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    32
 pref("browser.display.use_document_fonts",  1);  // 0 = never, 1 = quick, 2 = always
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    33
 // 0 = default: always, except in high contrast mode
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    34
 // 1 = always
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    35
diff --git a/widget/cocoa/nsChildView.mm b/widget/cocoa/nsChildView.mm
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    36
--- a/widget/cocoa/nsChildView.mm
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    37
+++ b/widget/cocoa/nsChildView.mm
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    38
@@ -4695,18 +4695,20 @@ NSEvent* gLastDragMouseDownEvent = nil;
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    39
   [self convertCocoaMouseEvent:theEvent toGeckoEvent:&geckoEvent];
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    40
   geckoEvent.button = WidgetMouseEvent::eRightButton;
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    41
   geckoEvent.mClickCount = [theEvent clickCount];
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    42
 
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    43
   mGeckoChild->DispatchInputEvent(&geckoEvent);
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    44
   if (!mGeckoChild)
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    45
     return;
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    46
 
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    47
-  // Let the superclass do the context menu stuff.
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    48
-  [super rightMouseDown:theEvent];
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    49
+  if (!nsBaseWidget::ShowContextMenuAfterMouseUp()) {
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    50
+    // Let the superclass do the context menu stuff.
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    51
+    [super rightMouseDown:theEvent];
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    52
+  }
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    53
 
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    54
   NS_OBJC_END_TRY_ABORT_BLOCK;
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    55
 }
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    56
 
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    57
 - (void)rightMouseUp:(NSEvent *)theEvent
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    58
 {
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    59
   NS_OBJC_BEGIN_TRY_ABORT_BLOCK;
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    60
 
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    61
@@ -4719,16 +4721,33 @@ NSEvent* gLastDragMouseDownEvent = nil;
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    62
   WidgetMouseEvent geckoEvent(true, eMouseUp, mGeckoChild,
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    63
                               WidgetMouseEvent::eReal);
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    64
   [self convertCocoaMouseEvent:theEvent toGeckoEvent:&geckoEvent];
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    65
   geckoEvent.button = WidgetMouseEvent::eRightButton;
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    66
   geckoEvent.mClickCount = [theEvent clickCount];
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    67
 
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    68
   nsAutoRetainCocoaObject kungFuDeathGrip(self);
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    69
   mGeckoChild->DispatchInputEvent(&geckoEvent);
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    70
+  if (!mGeckoChild)
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    71
+    return;
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    72
+
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    73
+  if (nsBaseWidget::ShowContextMenuAfterMouseUp()) {
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    74
+    // Let the superclass do the context menu stuff, but pretend it's rightMouseDown.
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    75
+    NSEvent *dupeEvent = [NSEvent mouseEventWithType:NSRightMouseDown
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    76
+                                            location:theEvent.locationInWindow
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    77
+                                       modifierFlags:theEvent.modifierFlags
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    78
+                                           timestamp:theEvent.timestamp
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    79
+                                        windowNumber:theEvent.windowNumber
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    80
+                                             context:theEvent.context
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    81
+                                         eventNumber:theEvent.eventNumber
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    82
+                                          clickCount:theEvent.clickCount
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    83
+                                            pressure:theEvent.pressure];
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    84
+
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    85
+    [super rightMouseDown:dupeEvent];
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    86
+  }
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    87
 
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    88
   NS_OBJC_END_TRY_ABORT_BLOCK;
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    89
 }
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    90
 
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    91
 - (void)rightMouseDragged:(NSEvent*)theEvent
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    92
 {
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    93
   if (!mGeckoChild)
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    94
     return;
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    95
diff --git a/widget/gtk/nsWindow.cpp b/widget/gtk/nsWindow.cpp
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    96
--- a/widget/gtk/nsWindow.cpp
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    97
+++ b/widget/gtk/nsWindow.cpp
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    98
@@ -2733,16 +2733,29 @@ nsWindow::InitButtonEvent(WidgetMouseEve
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    99
 }
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   100
 
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   101
 static guint ButtonMaskFromGDKButton(guint button)
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   102
 {
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   103
     return GDK_BUTTON1_MASK << (button - 1);
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   104
 }
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   105
 
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   106
 void
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   107
+nsWindow::DispatchContextMenuEventFromMouseEvent(uint16_t domButton,
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   108
+                                                 GdkEventButton *aEvent)
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   109
+{
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   110
+    if (domButton == WidgetMouseEvent::eRightButton && MOZ_LIKELY(!mIsDestroyed)) {
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   111
+        WidgetMouseEvent contextMenuEvent(true, eContextMenu, this,
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   112
+                                          WidgetMouseEvent::eReal);
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   113
+        InitButtonEvent(contextMenuEvent, aEvent);
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   114
+        contextMenuEvent.pressure = mLastMotionPressure;
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   115
+        DispatchInputEvent(&contextMenuEvent);
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   116
+    }
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   117
+}
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   118
+
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   119
+void
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   120
 nsWindow::OnButtonPressEvent(GdkEventButton *aEvent)
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   121
 {
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   122
     LOG(("Button %u press on %p\n", aEvent->button, (void *)this));
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   123
 
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   124
     // If you double click in GDK, it will actually generate a second
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   125
     // GDK_BUTTON_PRESS before sending the GDK_2BUTTON_PRESS, and this is
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   126
     // different than the DOM spec.  GDK puts this in the queue
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   127
     // programatically, so it's safe to assume that if there's a
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   128
@@ -2801,23 +2814,18 @@ nsWindow::OnButtonPressEvent(GdkEventBut
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   129
     WidgetMouseEvent event(true, eMouseDown, this, WidgetMouseEvent::eReal);
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   130
     event.button = domButton;
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   131
     InitButtonEvent(event, aEvent);
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   132
     event.pressure = mLastMotionPressure;
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   133
 
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   134
     DispatchInputEvent(&event);
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   135
 
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   136
     // right menu click on linux should also pop up a context menu
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   137
-    if (domButton == WidgetMouseEvent::eRightButton &&
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   138
-        MOZ_LIKELY(!mIsDestroyed)) {
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   139
-        WidgetMouseEvent contextMenuEvent(true, eContextMenu, this,
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   140
-                                          WidgetMouseEvent::eReal);
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   141
-        InitButtonEvent(contextMenuEvent, aEvent);
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   142
-        contextMenuEvent.pressure = mLastMotionPressure;
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   143
-        DispatchInputEvent(&contextMenuEvent);
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   144
+    if (!nsBaseWidget::ShowContextMenuAfterMouseUp()) {
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   145
+        DispatchContextMenuEventFromMouseEvent(domButton, aEvent);
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   146
     }
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   147
 }
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   148
 
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   149
 void
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   150
 nsWindow::OnButtonReleaseEvent(GdkEventButton *aEvent)
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   151
 {
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   152
     LOG(("Button %u release on %p\n", aEvent->button, (void *)this));
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   153
 
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   154
@@ -2843,16 +2851,21 @@ nsWindow::OnButtonReleaseEvent(GdkEventB
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   155
     event.button = domButton;
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   156
     InitButtonEvent(event, aEvent);
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   157
     gdouble pressure = 0;
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   158
     gdk_event_get_axis ((GdkEvent*)aEvent, GDK_AXIS_PRESSURE, &pressure);
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   159
     event.pressure = pressure ? pressure : mLastMotionPressure;
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   160
 
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   161
     DispatchInputEvent(&event);
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   162
     mLastMotionPressure = pressure;
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   163
+
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   164
+    // right menu click on linux should also pop up a context menu
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   165
+    if (nsBaseWidget::ShowContextMenuAfterMouseUp()) {
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   166
+        DispatchContextMenuEventFromMouseEvent(domButton, aEvent);
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   167
+    }
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   168
 }
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   169
 
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   170
 void
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   171
 nsWindow::OnContainerFocusInEvent(GdkEventFocus *aEvent)
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   172
 {
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   173
     LOGFOCUS(("OnContainerFocusInEvent [%p]\n", (void *)this));
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   174
 
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   175
     // Unset the urgency hint, if possible
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   176
diff --git a/widget/gtk/nsWindow.h b/widget/gtk/nsWindow.h
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   177
--- a/widget/gtk/nsWindow.h
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   178
+++ b/widget/gtk/nsWindow.h
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   179
@@ -240,16 +240,18 @@ private:
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   180
     LayoutDeviceIntSize GetSafeWindowSize(LayoutDeviceIntSize aSize);
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   181
 
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   182
     void               EnsureGrabs  (void);
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   183
     void               GrabPointer  (guint32 aTime);
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   184
     void               ReleaseGrabs (void);
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   185
 
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   186
     void               UpdateClientOffset();
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   187
 
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   188
+    void               DispatchContextMenuEventFromMouseEvent(uint16_t domButton,
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   189
+                                                              GdkEventButton *aEvent);
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   190
 public:
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   191
     void               ThemeChanged(void);
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   192
     void               OnDPIChanged(void);
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   193
     void               OnCheckResize(void);
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   194
     void               OnCompositedChanged(void);
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   195
 
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   196
 #ifdef MOZ_X11
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   197
     Window             mOldFocusWindow;
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   198
diff --git a/widget/nsBaseWidget.cpp b/widget/nsBaseWidget.cpp
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   199
--- a/widget/nsBaseWidget.cpp
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   200
+++ b/widget/nsBaseWidget.cpp
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   201
@@ -1213,16 +1213,32 @@ nsBaseWidget::DispatchEventToAPZOnly(moz
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   202
   if (mAPZC) {
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   203
     MOZ_ASSERT(APZThreadUtils::IsControllerThread());
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   204
     uint64_t inputBlockId = 0;
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   205
     ScrollableLayerGuid guid;
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   206
     mAPZC->ReceiveInputEvent(*aEvent, &guid, &inputBlockId);
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   207
   }
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   208
 }
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   209
 
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   210
+// static
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   211
+bool
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   212
+nsBaseWidget::ShowContextMenuAfterMouseUp()
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   213
+{
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   214
+  static bool gContextMenuAfterMouseUp = false;
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   215
+  static bool gContextMenuAfterMouseUpCached = false;
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   216
+  if (!gContextMenuAfterMouseUpCached) {
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   217
+    Preferences::AddBoolVarCache(&gContextMenuAfterMouseUp,
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   218
+                                 "ui.context_menus.after_mouseup",
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   219
+                                 false);
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   220
+
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   221
+    gContextMenuAfterMouseUpCached = true;
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   222
+  }
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   223
+  return gContextMenuAfterMouseUp;
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   224
+}
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   225
+
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   226
 nsIDocument*
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   227
 nsBaseWidget::GetDocument() const
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   228
 {
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   229
   if (mWidgetListener) {
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   230
     if (nsIPresShell* presShell = mWidgetListener->GetPresShell()) {
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   231
       return presShell->GetDocument();
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   232
     }
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   233
   }
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   234
diff --git a/widget/nsBaseWidget.h b/widget/nsBaseWidget.h
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   235
--- a/widget/nsBaseWidget.h
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   236
+++ b/widget/nsBaseWidget.h
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   237
@@ -412,16 +412,22 @@ public:
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   238
   void NotifyLiveResizeStopped();
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   239
 
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   240
 #if defined(MOZ_WIDGET_ANDROID)
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   241
   void RecvToolbarAnimatorMessageFromCompositor(int32_t) override {};
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   242
   void UpdateRootFrameMetrics(const ScreenPoint& aScrollOffset, const CSSToScreenScale& aZoom) override {};
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   243
   void RecvScreenPixels(mozilla::ipc::Shmem&& aMem, const ScreenIntSize& aSize) override {};
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   244
 #endif
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   245
 
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   246
+  /**
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   247
+   * Whether context menus should only appear on mouseup instead of mousedown,
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   248
+   * on OSes where they normally appear on mousedown (macOS, *nix).
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   249
+   */
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   250
+  static bool ShowContextMenuAfterMouseUp();
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   251
+
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   252
 protected:
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   253
   // These are methods for CompositorWidgetWrapper, and should only be
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   254
   // accessed from that class. Derived widgets can choose which methods to
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   255
   // implement, or none if supporting out-of-process compositing.
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   256
   virtual bool PreRender(mozilla::widget::WidgetRenderingContext* aContext) {
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   257
     return true;
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   258
   }
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   259
   virtual void PostRender(mozilla::widget::WidgetRenderingContext* aContext)
0c59a30173da several changes
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   260