forked from mirrors/gecko-dev
		
	Backed out 8 changesets (bug 1081542) for causing Bug 1885050
Backed out changeset 38614c34e575 (bug 1081542) Backed out changeset 7571e95ed78c (bug 1081542) Backed out changeset 29f139450ccc (bug 1081542) Backed out changeset 058d5712354b (bug 1081542) Backed out changeset 7f46e8820023 (bug 1081542) Backed out changeset d29d7e9c38bd (bug 1081542) Backed out changeset 0a6b3d90e636 (bug 1081542) Backed out changeset 27dae926668f (bug 1081542)
This commit is contained in:
		
							parent
							
								
									3575a6ca31
								
							
						
					
					
						commit
						6169ac57de
					
				
					 18 changed files with 174 additions and 365 deletions
				
			
		|  | @ -886,6 +886,8 @@ pref("browser.tabs.warnOnClose", false); | |||
| pref("browser.tabs.warnOnCloseOtherTabs", true); | ||||
| pref("browser.tabs.warnOnOpen", true); | ||||
| pref("browser.tabs.maxOpenBeforeWarn", 15); | ||||
| pref("browser.tabs.loadInBackground", true); | ||||
| pref("browser.tabs.opentabfor.middleclick", true); | ||||
| pref("browser.tabs.loadDivertedInBackground", false); | ||||
| pref("browser.tabs.loadBookmarksInBackground", false); | ||||
| pref("browser.tabs.loadBookmarksInTabs", false); | ||||
|  |  | |||
|  | @ -6053,7 +6053,7 @@ nsBrowserAccess.prototype = { | |||
|     aName = "", | ||||
|     aCsp = null, | ||||
|     aSkipLoad = false, | ||||
|     aWhere = undefined | ||||
|     aForceLoadInBackground = false | ||||
|   ) { | ||||
|     let win, needToFocusWin; | ||||
| 
 | ||||
|  | @ -6076,20 +6076,11 @@ nsBrowserAccess.prototype = { | |||
|       return win.gBrowser.selectedBrowser; | ||||
|     } | ||||
| 
 | ||||
|     // OPEN_NEWTAB_BACKGROUND and OPEN_NEWTAB_FOREGROUND are used by
 | ||||
|     // `window.open` with modifiers.
 | ||||
|     // The last case is OPEN_NEWTAB, which is used by:
 | ||||
|     //   * a link with `target="_blank"`, without modifiers
 | ||||
|     //   * `window.open` without features, without modifiers
 | ||||
|     let loadInBackground; | ||||
|     if (aWhere === Ci.nsIBrowserDOMWindow.OPEN_NEWTAB_BACKGROUND) { | ||||
|       loadInBackground = true; | ||||
|     } else if (aWhere === Ci.nsIBrowserDOMWindow.OPEN_NEWTAB_FOREGROUND) { | ||||
|       loadInBackground = false; | ||||
|     } else { | ||||
|       loadInBackground = Services.prefs.getBoolPref( | ||||
|     let loadInBackground = Services.prefs.getBoolPref( | ||||
|       "browser.tabs.loadDivertedInBackground" | ||||
|     ); | ||||
|     if (aForceLoadInBackground) { | ||||
|       loadInBackground = true; | ||||
|     } | ||||
| 
 | ||||
|     let tab = win.gBrowser.addTab(aURI ? aURI.spec : "about:blank", { | ||||
|  | @ -6266,8 +6257,7 @@ nsBrowserAccess.prototype = { | |||
|         } | ||||
|         break; | ||||
|       case Ci.nsIBrowserDOMWindow.OPEN_NEWTAB: | ||||
|       case Ci.nsIBrowserDOMWindow.OPEN_NEWTAB_BACKGROUND: | ||||
|       case Ci.nsIBrowserDOMWindow.OPEN_NEWTAB_FOREGROUND: { | ||||
|       case Ci.nsIBrowserDOMWindow.OPEN_NEWTAB_BACKGROUND: { | ||||
|         // If we have an opener, that means that the caller is expecting access
 | ||||
|         // to the nsIDOMWindow of the opened tab right away. For e10s windows,
 | ||||
|         // this means forcing the newly opened browser to be non-remote so that
 | ||||
|  | @ -6278,6 +6268,8 @@ nsBrowserAccess.prototype = { | |||
|         let userContextId = aOpenWindowInfo | ||||
|           ? aOpenWindowInfo.originAttributes.userContextId | ||||
|           : openingUserContextId; | ||||
|         let forceLoadInBackground = | ||||
|           aWhere == Ci.nsIBrowserDOMWindow.OPEN_NEWTAB_BACKGROUND; | ||||
|         let browser = this._openURIInNewTab( | ||||
|           aURI, | ||||
|           referrerInfo, | ||||
|  | @ -6291,7 +6283,7 @@ nsBrowserAccess.prototype = { | |||
|           "", | ||||
|           aCsp, | ||||
|           aSkipLoad, | ||||
|           aWhere | ||||
|           forceLoadInBackground | ||||
|         ); | ||||
|         if (browser) { | ||||
|           browsingContext = browser.browsingContext; | ||||
|  | @ -6392,8 +6384,7 @@ nsBrowserAccess.prototype = { | |||
| 
 | ||||
|       if ( | ||||
|         aWhere != Ci.nsIBrowserDOMWindow.OPEN_NEWTAB && | ||||
|         aWhere != Ci.nsIBrowserDOMWindow.OPEN_NEWTAB_BACKGROUND && | ||||
|         aWhere != Ci.nsIBrowserDOMWindow.OPEN_NEWTAB_FOREGROUND | ||||
|         aWhere != Ci.nsIBrowserDOMWindow.OPEN_NEWTAB_BACKGROUND | ||||
|       ) { | ||||
|         dump("Error: openURIInFrame can only open in new tabs or print"); | ||||
|         return null; | ||||
|  | @ -6407,6 +6398,9 @@ nsBrowserAccess.prototype = { | |||
|           ? aParams.openerOriginAttributes.userContextId | ||||
|           : Ci.nsIScriptSecurityManager.DEFAULT_USER_CONTEXT_ID; | ||||
| 
 | ||||
|       var forceLoadInBackground = | ||||
|         aWhere == Ci.nsIBrowserDOMWindow.OPEN_NEWTAB_BACKGROUND; | ||||
| 
 | ||||
|       return this._openURIInNewTab( | ||||
|         aURI, | ||||
|         aParams.referrerInfo, | ||||
|  | @ -6420,7 +6414,7 @@ nsBrowserAccess.prototype = { | |||
|         aName, | ||||
|         aParams.csp, | ||||
|         aSkipLoad, | ||||
|         aWhere | ||||
|         forceLoadInBackground | ||||
|       ); | ||||
|     }, | ||||
| 
 | ||||
|  |  | |||
|  | @ -11,7 +11,6 @@ add_task(async function () { | |||
|   const tests = [ | ||||
|     ["OPEN_NEWTAB", false], | ||||
|     ["OPEN_NEWTAB_BACKGROUND", true], | ||||
|     ["OPEN_NEWTAB_FOREGROUND", false], | ||||
|   ]; | ||||
| 
 | ||||
|   for (const [flag, isBackground] of tests) { | ||||
|  |  | |||
|  | @ -5,30 +5,18 @@ | |||
| "use strict"; | ||||
| 
 | ||||
| // Opening many windows take long time on some configuration.
 | ||||
| requestLongerTimeout(6); | ||||
| 
 | ||||
| const TEST_URL = | ||||
|   "https://example.com/browser/browser/base/content/test/tabs/file_window_open.html"; | ||||
| requestLongerTimeout(4); | ||||
| 
 | ||||
| add_task(async function () { | ||||
|   await BrowserTestUtils.withNewTab( | ||||
|     "https://example.com/browser/browser/base/content/test/tabs/file_window_open.html", | ||||
|     async function (browser) { | ||||
|       const metaKey = AppConstants.platform == "macosx" ? "metaKey" : "ctrlKey"; | ||||
| 
 | ||||
|       const normalEvent = {}; | ||||
|       const shiftEvent = { shiftKey: true }; | ||||
|       const metaEvent = { [metaKey]: true }; | ||||
|       const metaShiftEvent = { [metaKey]: true, shiftKey: true }; | ||||
| 
 | ||||
| const altEvent = { altKey: true }; | ||||
| const altShiftEvent = { altKey: true, shiftKey: true }; | ||||
| const altMetaEvent = { altKey: true, [metaKey]: true }; | ||||
| const altMetaShiftEvent = { altKey: true, [metaKey]: true, shiftKey: true }; | ||||
| 
 | ||||
| const middleEvent = { button: 1 }; | ||||
| const middleShiftEvent = { button: 1, shiftKey: true }; | ||||
| const middleMetaEvent = { button: 1, [metaKey]: true }; | ||||
| const middleMetaShiftEvent = { button: 1, [metaKey]: true, shiftKey: true }; | ||||
| 
 | ||||
| add_task(async function testMouse() { | ||||
|   await BrowserTestUtils.withNewTab(TEST_URL, async function (browser) { | ||||
|       const tests = [ | ||||
|         // type, id, options, result
 | ||||
|         ["mouse", "#instant", normalEvent, "tab"], | ||||
|  | @ -50,86 +38,7 @@ add_task(async function testMouse() { | |||
|         ["mouse", "#delayed-popup", shiftEvent, "window"], | ||||
|         ["mouse", "#delayed-popup", metaEvent, "tab-bg"], | ||||
|         ["mouse", "#delayed-popup", metaShiftEvent, "tab"], | ||||
|     ]; | ||||
|     await runWindowOpenTests(browser, tests); | ||||
|   }); | ||||
| }); | ||||
| 
 | ||||
| add_task(async function testAlt() { | ||||
|   // Alt key shouldn't affect the behavior.
 | ||||
|   await BrowserTestUtils.withNewTab(TEST_URL, async function (browser) { | ||||
|     const tests = [ | ||||
|       ["mouse", "#instant", altEvent, "tab"], | ||||
|       ["mouse", "#instant", altShiftEvent, "window"], | ||||
|       ["mouse", "#instant", altMetaEvent, "tab-bg"], | ||||
|       ["mouse", "#instant", altMetaShiftEvent, "tab"], | ||||
| 
 | ||||
|       ["mouse", "#instant-popup", altEvent, "popup"], | ||||
|       ["mouse", "#instant-popup", altShiftEvent, "window"], | ||||
|       ["mouse", "#instant-popup", altMetaEvent, "tab-bg"], | ||||
|       ["mouse", "#instant-popup", altMetaShiftEvent, "tab"], | ||||
| 
 | ||||
|       ["mouse", "#delayed", altEvent, "tab"], | ||||
|       ["mouse", "#delayed", altShiftEvent, "window"], | ||||
|       ["mouse", "#delayed", altMetaEvent, "tab-bg"], | ||||
|       ["mouse", "#delayed", altMetaShiftEvent, "tab"], | ||||
| 
 | ||||
|       ["mouse", "#delayed-popup", altEvent, "popup"], | ||||
|       ["mouse", "#delayed-popup", altShiftEvent, "window"], | ||||
|       ["mouse", "#delayed-popup", altMetaEvent, "tab-bg"], | ||||
|       ["mouse", "#delayed-popup", altMetaShiftEvent, "tab"], | ||||
|     ]; | ||||
|     await runWindowOpenTests(browser, tests); | ||||
|   }); | ||||
| }); | ||||
| 
 | ||||
| add_task(async function testMiddleMouse() { | ||||
|   // Middle click is equivalent to meta key.
 | ||||
|   await BrowserTestUtils.withNewTab(TEST_URL, async function (browser) { | ||||
|     const tests = [ | ||||
|       ["mouse", "#instant", middleEvent, "tab-bg"], | ||||
|       ["mouse", "#instant", middleShiftEvent, "tab"], | ||||
|       ["mouse", "#instant", middleMetaEvent, "tab-bg"], | ||||
|       ["mouse", "#instant", middleMetaShiftEvent, "tab"], | ||||
| 
 | ||||
|       ["mouse", "#instant-popup", middleEvent, "tab-bg"], | ||||
|       ["mouse", "#instant-popup", middleShiftEvent, "tab"], | ||||
|       ["mouse", "#instant-popup", middleMetaEvent, "tab-bg"], | ||||
|       ["mouse", "#instant-popup", middleMetaShiftEvent, "tab"], | ||||
| 
 | ||||
|       ["mouse", "#delayed", middleEvent, "tab-bg"], | ||||
|       ["mouse", "#delayed", middleShiftEvent, "tab"], | ||||
|       ["mouse", "#delayed", middleMetaEvent, "tab-bg"], | ||||
|       ["mouse", "#delayed", middleMetaShiftEvent, "tab"], | ||||
| 
 | ||||
|       ["mouse", "#delayed-popup", middleEvent, "tab-bg"], | ||||
|       ["mouse", "#delayed-popup", middleShiftEvent, "tab"], | ||||
|       ["mouse", "#delayed-popup", middleMetaEvent, "tab-bg"], | ||||
|       ["mouse", "#delayed-popup", middleMetaShiftEvent, "tab"], | ||||
|     ]; | ||||
|     await runWindowOpenTests(browser, tests); | ||||
|   }); | ||||
| }); | ||||
| 
 | ||||
| add_task(async function testBackgroundPrefTests() { | ||||
|   await SpecialPowers.pushPrefEnv({ | ||||
|     set: [["browser.tabs.loadInBackground", false]], | ||||
|   }); | ||||
| 
 | ||||
|   await BrowserTestUtils.withNewTab(TEST_URL, async function (browser) { | ||||
|     const tests = [ | ||||
|       ["mouse", "#instant", metaEvent, "tab"], | ||||
|       ["mouse", "#instant", metaShiftEvent, "tab-bg"], | ||||
|     ]; | ||||
|     await runWindowOpenTests(browser, tests); | ||||
|   }); | ||||
| 
 | ||||
|   await SpecialPowers.popPrefEnv(); | ||||
| }); | ||||
| 
 | ||||
| add_task(async function testSpaceKey() { | ||||
|   await BrowserTestUtils.withNewTab(TEST_URL, async function (browser) { | ||||
|     const tests = [ | ||||
|         // NOTE: meta+keyboard doesn't activate.
 | ||||
| 
 | ||||
|         ["VK_SPACE", "#instant", normalEvent, "tab"], | ||||
|  | @ -143,14 +52,7 @@ add_task(async function testSpaceKey() { | |||
| 
 | ||||
|         ["VK_SPACE", "#delayed-popup", normalEvent, "popup"], | ||||
|         ["VK_SPACE", "#delayed-popup", shiftEvent, "window"], | ||||
|     ]; | ||||
|     await runWindowOpenTests(browser, tests); | ||||
|   }); | ||||
| }); | ||||
| 
 | ||||
| add_task(async function testEnterKey() { | ||||
|   await BrowserTestUtils.withNewTab(TEST_URL, async function (browser) { | ||||
|     const tests = [ | ||||
|         ["KEY_Enter", "#link-instant", normalEvent, "tab"], | ||||
|         ["KEY_Enter", "#link-instant", shiftEvent, "window"], | ||||
| 
 | ||||
|  | @ -162,14 +64,7 @@ add_task(async function testEnterKey() { | |||
| 
 | ||||
|         ["KEY_Enter", "#link-delayed-popup", normalEvent, "popup"], | ||||
|         ["KEY_Enter", "#link-delayed-popup", shiftEvent, "window"], | ||||
|     ]; | ||||
|     await runWindowOpenTests(browser, tests); | ||||
|   }); | ||||
| }); | ||||
| 
 | ||||
| add_task(async function testUserDefinedShortcut() { | ||||
|   await BrowserTestUtils.withNewTab(TEST_URL, async function (browser) { | ||||
|     const tests = [ | ||||
|         // Trigger user-defined shortcut key, where modifiers shouldn't affect.
 | ||||
| 
 | ||||
|         ["x", "#instant", normalEvent, "tab"], | ||||
|  | @ -182,13 +77,8 @@ add_task(async function testUserDefinedShortcut() { | |||
|         ["y", "#instant", metaEvent, "popup"], | ||||
|         ["y", "#instant", metaShiftEvent, "popup"], | ||||
|       ]; | ||||
|     await runWindowOpenTests(browser, tests); | ||||
|   }); | ||||
| }); | ||||
| 
 | ||||
| async function runWindowOpenTests(browser, tests) { | ||||
|       for (const [type, id, event, result] of tests) { | ||||
|     let eventStr = JSON.stringify(event); | ||||
|         const eventStr = JSON.stringify(event); | ||||
| 
 | ||||
|         let openPromise; | ||||
|         if (result == "tab" || result == "tab-bg") { | ||||
|  | @ -214,7 +104,8 @@ async function runWindowOpenTests(browser, tests) { | |||
|           BrowserTestUtils.synthesizeKey("VK_SPACE", {}, browser); | ||||
|           await ContentTask.spawn(browser, {}, async () => { | ||||
|             await ContentTaskUtils.waitForCondition( | ||||
|           () => content.document.querySelector("#focus-result").value === "ok" | ||||
|               () => | ||||
|                 content.document.querySelector("#focus-result").value === "ok" | ||||
|             ); | ||||
|           }); | ||||
| 
 | ||||
|  | @ -269,10 +160,16 @@ async function runWindowOpenTests(browser, tests) { | |||
|           // Make sure the focus comes back to this window before proceeding
 | ||||
|           // to the next test.
 | ||||
|           if (Services.focus.focusedWindow != window) { | ||||
|         const focusBack = BrowserTestUtils.waitForEvent(window, "focus", true); | ||||
|             const focusBack = BrowserTestUtils.waitForEvent( | ||||
|               window, | ||||
|               "focus", | ||||
|               true | ||||
|             ); | ||||
|             window.focus(); | ||||
|             await focusBack; | ||||
|           } | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   ); | ||||
| }); | ||||
|  |  | |||
|  | @ -11,23 +11,19 @@ div { | |||
| <body> | ||||
|   <div> | ||||
|   <input id="instant" type="button" value="instant no features" | ||||
|          onclick="window.open('about:blank', '_blank');" | ||||
|          onmousedown="if (event.button == 1) { window.open('about:blank', '_blank'); event.preventDefault(); }"> | ||||
|          onclick="window.open('about:blank', '_blank');"> | ||||
|   </div> | ||||
|   <div> | ||||
|   <input id="instant-popup" type="button" value="instant popup" | ||||
|          onclick="window.open('about:blank', '_blank', 'popup=true');" | ||||
|          onmousedown="if (event.button == 1) { window.open('about:blank', '_blank', 'popup=true'); }"> | ||||
|          onclick="window.open('about:blank', '_blank', 'popup=true');"> | ||||
|   </div> | ||||
|   <div> | ||||
|   <input id="delayed" type="button" value="delayed no features" | ||||
|          onclick="setTimeout(() => window.open('about:blank', '_blank'), 100);" | ||||
|          onmousedown="if (event.button == 1) { setTimeout(() => window.open('about:blank', '_blank'), 100); }"> | ||||
|          onclick="setTimeout(() => window.open('about:blank', '_blank'), 100);"> | ||||
|   </div> | ||||
|   <div> | ||||
|   <input id="delayed-popup" type="button" value="delayed popup" | ||||
|          onclick="setTimeout(() => window.open('about:blank', '_blank', 'popup=true'), 100);" | ||||
|          onmousedown="if (event.button == 1) { setTimeout(() => window.open('about:blank', '_blank', 'popup=true'), 100); }"> | ||||
|          onclick="setTimeout(() => window.open('about:blank', '_blank', 'popup=true'), 100);"> | ||||
|   <div> | ||||
|   <div> | ||||
|   <a id="link-instant" href="" | ||||
|  |  | |||
|  | @ -59,12 +59,8 @@ class UserActivation final : public nsISupports, public nsWrapperCache { | |||
|     static constexpr uint8_t Meta = 0x20; | ||||
|     static constexpr uint8_t Control = 0x40; | ||||
|     static constexpr uint8_t Alt = 0x80; | ||||
|     static constexpr uint8_t MiddleMouse = 0x08; | ||||
| 
 | ||||
|     static constexpr uint8_t Mask = 0xF8; | ||||
| 
 | ||||
|     static_assert((uint8_t(State::EndGuard_) & ~Mask) == | ||||
|                   uint8_t(State::EndGuard_)); | ||||
|     static constexpr uint8_t Mask = 0xF0; | ||||
| 
 | ||||
|     constexpr Modifiers() = default; | ||||
|     explicit constexpr Modifiers(uint8_t aModifiers) : mModifiers(aModifiers) {} | ||||
|  | @ -75,13 +71,11 @@ class UserActivation final : public nsISupports, public nsWrapperCache { | |||
|     void SetMeta() { mModifiers |= Meta; } | ||||
|     void SetControl() { mModifiers |= Control; } | ||||
|     void SetAlt() { mModifiers |= Alt; } | ||||
|     void SetMiddleMouse() { mModifiers |= MiddleMouse; } | ||||
| 
 | ||||
|     bool IsShift() const { return mModifiers & Shift; } | ||||
|     bool IsMeta() const { return mModifiers & Meta; } | ||||
|     bool IsControl() const { return mModifiers & Control; } | ||||
|     bool IsAlt() const { return mModifiers & Alt; } | ||||
|     bool IsMiddleMouse() const { return mModifiers & MiddleMouse; } | ||||
| 
 | ||||
|    private: | ||||
|     uint8_t mModifiers = 0; | ||||
|  |  | |||
|  | @ -1131,13 +1131,6 @@ void EventStateManager::NotifyTargetUserActivation(WidgetEvent* aEvent, | |||
|       if (inputEvent->IsAlt()) { | ||||
|         modifiers.SetAlt(); | ||||
|       } | ||||
| 
 | ||||
|       WidgetMouseEvent* mouseEvent = inputEvent->AsMouseEvent(); | ||||
|       if (mouseEvent) { | ||||
|         if (mouseEvent->mButton == MouseButton::eMiddle) { | ||||
|           modifiers.SetMiddleMouse(); | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|   doc->NotifyUserGestureActivation(modifiers); | ||||
|  |  | |||
|  | @ -65,8 +65,6 @@ interface nsIBrowserDOMWindow : nsISupports | |||
|   /** | ||||
|    * Open in a new content tab in the toplevel browser window corresponding to | ||||
|    * this nsIBrowserDOMWindow. | ||||
|    * Use browser.tabs.loadDivertedInBackground pref to choose whether to open | ||||
|    * in background tab or foreground tab. | ||||
|    */ | ||||
|   const short OPEN_NEWTAB        = 3; | ||||
|   /** | ||||
|  | @ -78,11 +76,6 @@ interface nsIBrowserDOMWindow : nsISupports | |||
|    * corresponding to this nsIBrowserDOMWindow. | ||||
|    */ | ||||
|   const short OPEN_NEWTAB_BACKGROUND = 5; | ||||
|   /** | ||||
|    * Open in a new foreground content tab in the toplevel browser window | ||||
|    * corresponding to this nsIBrowserDOMWindow. | ||||
|    */ | ||||
|   const short OPEN_NEWTAB_FOREGROUND = 6; | ||||
| 
 | ||||
|   /** | ||||
|    * Values for createContentWindow's and openURI's aFlags parameter. | ||||
|  |  | |||
|  | @ -5597,7 +5597,6 @@ mozilla::ipc::IPCResult ContentParent::CommonCreateWindow( | |||
| 
 | ||||
|   MOZ_ASSERT(aOpenLocation == nsIBrowserDOMWindow::OPEN_NEWTAB || | ||||
|              aOpenLocation == nsIBrowserDOMWindow::OPEN_NEWTAB_BACKGROUND || | ||||
|              aOpenLocation == nsIBrowserDOMWindow::OPEN_NEWTAB_FOREGROUND || | ||||
|              aOpenLocation == nsIBrowserDOMWindow::OPEN_NEWWINDOW || | ||||
|              aOpenLocation == nsIBrowserDOMWindow::OPEN_PRINT_BROWSER); | ||||
| 
 | ||||
|  | @ -5608,7 +5607,6 @@ mozilla::ipc::IPCResult ContentParent::CommonCreateWindow( | |||
| 
 | ||||
|   if (aOpenLocation == nsIBrowserDOMWindow::OPEN_NEWTAB || | ||||
|       aOpenLocation == nsIBrowserDOMWindow::OPEN_NEWTAB_BACKGROUND || | ||||
|       aOpenLocation == nsIBrowserDOMWindow::OPEN_NEWTAB_FOREGROUND || | ||||
|       aOpenLocation == nsIBrowserDOMWindow::OPEN_PRINT_BROWSER) { | ||||
|     RefPtr<Element> openerElement = do_QueryObject(frame); | ||||
| 
 | ||||
|  | @ -5837,8 +5835,7 @@ mozilla::ipc::IPCResult ContentParent::RecvCreateWindow( | |||
|   // do this work.
 | ||||
|   MOZ_ALWAYS_SUCCEEDS(newBC->SetHasSiblings( | ||||
|       openLocation == nsIBrowserDOMWindow::OPEN_NEWTAB || | ||||
|       openLocation == nsIBrowserDOMWindow::OPEN_NEWTAB_BACKGROUND || | ||||
|       openLocation == nsIBrowserDOMWindow::OPEN_NEWTAB_FOREGROUND)); | ||||
|       openLocation == nsIBrowserDOMWindow::OPEN_NEWTAB_BACKGROUND)); | ||||
| 
 | ||||
|   newTab->SwapFrameScriptsFrom(cwi.frameScripts()); | ||||
|   newTab->MaybeShowFrame(); | ||||
|  |  | |||
|  | @ -652,7 +652,7 @@ public class GeckoSession { | |||
|             case 0: // OPEN_DEFAULTWINDOW | ||||
|             case 1: // OPEN_CURRENTWINDOW | ||||
|               return NavigationDelegate.TARGET_WINDOW_CURRENT; | ||||
|             default: // OPEN_NEWWINDOW, OPEN_NEWTAB, OPEN_NEWTAB_BACKGROUND, OPEN_NEWTAB_FOREGROUND | ||||
|             default: // OPEN_NEWWINDOW, OPEN_NEWTAB, OPEN_NEWTAB_BACKGROUND | ||||
|               return NavigationDelegate.TARGET_WINDOW_NEW; | ||||
|           } | ||||
|         } | ||||
|  | @ -5030,7 +5030,7 @@ public class GeckoSession { | |||
|           case 0: // OPEN_DEFAULTWINDOW | ||||
|           case 1: // OPEN_CURRENTWINDOW | ||||
|             return TARGET_WINDOW_CURRENT; | ||||
|           default: // OPEN_NEWWINDOW, OPEN_NEWTAB, OPEN_NEWTAB_BACKGROUND, OPEN_NEWTAB_FOREGROUND | ||||
|           default: // OPEN_NEWWINDOW, OPEN_NEWTAB, OPEN_NEWTAB_BACKGROUND | ||||
|             return TARGET_WINDOW_NEW; | ||||
|         } | ||||
|       } | ||||
|  |  | |||
|  | @ -489,8 +489,7 @@ export class GeckoViewNavigation extends GeckoViewModule { | |||
|     if ( | ||||
|       where === Ci.nsIBrowserDOMWindow.OPEN_NEWWINDOW || | ||||
|       where === Ci.nsIBrowserDOMWindow.OPEN_NEWTAB || | ||||
|       where === Ci.nsIBrowserDOMWindow.OPEN_NEWTAB_BACKGROUND || | ||||
|       where === Ci.nsIBrowserDOMWindow.OPEN_NEWTAB_FOREGROUND | ||||
|       where === Ci.nsIBrowserDOMWindow.OPEN_NEWTAB_BACKGROUND | ||||
|     ) { | ||||
|       browser = this.handleNewSession(uri, openWindowInfo, where, flags, name); | ||||
|     } | ||||
|  |  | |||
|  | @ -1685,18 +1685,6 @@ | |||
|   value: false | ||||
|   mirror: always | ||||
| 
 | ||||
| # If set, when a link is opened to a new tab, do not switch to the new tab. | ||||
| # | ||||
| # This pref is used when the link is opened with "Open Link in New Tab", | ||||
| # middle-click, etc. | ||||
| # | ||||
| # See also browser.tabs.loadDivertedInBackground, which is used when the website | ||||
| # diverts the link into a new tab. | ||||
| - name: browser.tabs.loadInBackground | ||||
|   type: bool | ||||
|   value: true | ||||
|   mirror: always | ||||
| 
 | ||||
| # Whether we should draw the tabs on top of the titlebar. | ||||
| # | ||||
| # no (0), yes (1), or default (2), which is true everywhere except Linux. | ||||
|  | @ -1712,12 +1700,6 @@ | |||
|   value: false | ||||
|   mirror: always | ||||
| 
 | ||||
| # If set, middle clicking on a link opens the link in a new tab. | ||||
| - name: browser.tabs.opentabfor.middleclick | ||||
|   type: bool | ||||
|   value: true | ||||
|   mirror: always | ||||
| 
 | ||||
| # Testing-only pref which makes data: URIs be loaded in a "web" content process | ||||
| # instead of within a process based on the URI's loader. | ||||
| - name: browser.tabs.remote.dataUriInDefaultWebProcess | ||||
|  | @ -11212,21 +11194,6 @@ | |||
|   value: 262144 | ||||
|   mirror: always | ||||
| 
 | ||||
| #--------------------------------------------------------------------------- | ||||
| # Prefs starting with "middlemouse." | ||||
| #--------------------------------------------------------------------------- | ||||
| 
 | ||||
| # If set and browser.tabs.opentabfor.middleclick is not set, middle clicking on | ||||
| # a link opens the link in a new window. | ||||
| - name: middlemouse.openNewWindow | ||||
|   type: bool | ||||
| #if defined(ANDROID) || !defined(XP_MACOSX) && defined(XP_UNIX) | ||||
|   value: true | ||||
| #else | ||||
|   value: false | ||||
| #endif | ||||
|   mirror: always | ||||
| 
 | ||||
| #--------------------------------------------------------------------------- | ||||
| # Prefs starting with "midi." | ||||
| #--------------------------------------------------------------------------- | ||||
|  |  | |||
|  | @ -2674,6 +2674,7 @@ pref("font.size.monospace.x-math", 13); | |||
| 
 | ||||
|   // Middle-mouse handling
 | ||||
|   pref("middlemouse.paste", true); | ||||
|   pref("middlemouse.openNewWindow", true); | ||||
|   pref("middlemouse.scrollbarPosition", true); | ||||
| 
 | ||||
|   // Tab focus model bit field:
 | ||||
|  | @ -2704,6 +2705,7 @@ pref("font.size.monospace.x-math", 13); | |||
| 
 | ||||
|   // Middle-mouse handling
 | ||||
|   pref("middlemouse.paste", true); | ||||
|   pref("middlemouse.openNewWindow", true); | ||||
|   pref("middlemouse.scrollbarPosition", true); | ||||
| 
 | ||||
|   // Tab focus model bit field:
 | ||||
|  |  | |||
|  | @ -62,7 +62,6 @@ pref_groups = [ | |||
|     "mathml", | ||||
|     "media", | ||||
|     "memory", | ||||
|     "middlemouse", | ||||
|     "midi", | ||||
|     "mousewheel", | ||||
|     "mozilla", | ||||
|  |  | |||
|  | @ -1666,9 +1666,8 @@ static int32_t GetWhereToOpen(nsIChannel* aChannel, bool aIsDocumentLoad) { | |||
|       where == nsIBrowserDOMWindow::OPEN_NEWTAB) { | ||||
|     return where; | ||||
|   } | ||||
|   // NOTE: nsIBrowserDOMWindow::OPEN_NEWTAB_BACKGROUND and
 | ||||
|   //       nsIBrowserDOMWindow::OPEN_NEWTAB_FOREGROUND are not allowed as pref
 | ||||
|   //       values.
 | ||||
|   // NOTE: nsIBrowserDOMWindow::OPEN_NEWTAB_BACKGROUND is not allowed as a pref
 | ||||
|   //       value.
 | ||||
|   return nsIBrowserDOMWindow::OPEN_NEWTAB; | ||||
| } | ||||
| 
 | ||||
|  | @ -1761,7 +1760,6 @@ static RefPtr<dom::BrowsingContextCallbackReceivedPromise> SwitchToNewTab( | |||
|     CanonicalBrowsingContext* aLoadingBrowsingContext, int32_t aWhere) { | ||||
|   MOZ_ASSERT(aWhere == nsIBrowserDOMWindow::OPEN_NEWTAB || | ||||
|                  aWhere == nsIBrowserDOMWindow::OPEN_NEWTAB_BACKGROUND || | ||||
|                  aWhere == nsIBrowserDOMWindow::OPEN_NEWTAB_FOREGROUND || | ||||
|                  aWhere == nsIBrowserDOMWindow::OPEN_NEWWINDOW, | ||||
|              "Unsupported open location"); | ||||
| 
 | ||||
|  |  | |||
|  | @ -64,7 +64,6 @@ | |||
| #include "mozilla/Preferences.h" | ||||
| #include "mozilla/ResultExtensions.h" | ||||
| #include "mozilla/StaticPrefs_browser.h" | ||||
| #include "mozilla/StaticPrefs_middlemouse.h" | ||||
| #include "mozilla/StaticPrefs_full_screen_api.h" | ||||
| #include "mozilla/dom/Element.h" | ||||
| #include "mozilla/dom/Storage.h" | ||||
|  | @ -2443,44 +2442,26 @@ bool nsWindowWatcher::IsWindowOpenLocationModified( | |||
|     const mozilla::dom::UserActivation::Modifiers& aModifiers, | ||||
|     int32_t* aLocation) { | ||||
|   // Perform the subset of BrowserUtils.whereToOpenLink in
 | ||||
|   // toolkit/modules/BrowserUtils.sys.mjs for modifier key handling, and
 | ||||
|   // URILoadingHelper.openLinkIn in browser/modules/URILoadingHelper.sys.mjs
 | ||||
|   // for loadInBackground pref handling.
 | ||||
|   // toolkit/modules/BrowserUtils.sys.mjs
 | ||||
| #ifdef XP_MACOSX | ||||
|   bool metaKey = aModifiers.IsMeta(); | ||||
| #else | ||||
|   bool metaKey = aModifiers.IsControl(); | ||||
| #endif | ||||
|   bool shiftKey = aModifiers.IsShift(); | ||||
| 
 | ||||
|   bool middleMouse = aModifiers.IsMiddleMouse(); | ||||
|   bool middleUsesTabs = StaticPrefs::browser_tabs_opentabfor_middleclick(); | ||||
|   bool middleUsesNewWindow = StaticPrefs::middlemouse_openNewWindow(); | ||||
| 
 | ||||
|   if (metaKey || (middleMouse && middleUsesTabs)) { | ||||
|     bool loadInBackground = StaticPrefs::browser_tabs_loadInBackground(); | ||||
|   if (metaKey) { | ||||
|     if (shiftKey) { | ||||
|       loadInBackground = !loadInBackground; | ||||
|     } | ||||
|     if (loadInBackground) { | ||||
|       *aLocation = nsIBrowserDOMWindow::OPEN_NEWTAB_BACKGROUND; | ||||
|     } else { | ||||
|       *aLocation = nsIBrowserDOMWindow::OPEN_NEWTAB_FOREGROUND; | ||||
|     } | ||||
|       *aLocation = nsIBrowserDOMWindow::OPEN_NEWTAB; | ||||
|       return true; | ||||
|     } | ||||
| 
 | ||||
|   if (shiftKey || (middleMouse && !middleUsesTabs && middleUsesNewWindow)) { | ||||
|     *aLocation = nsIBrowserDOMWindow::OPEN_NEWTAB_BACKGROUND; | ||||
|     return true; | ||||
|   } | ||||
|   if (shiftKey) { | ||||
|     *aLocation = nsIBrowserDOMWindow::OPEN_NEWWINDOW; | ||||
|     return true; | ||||
|   } | ||||
| 
 | ||||
|   // If both middleUsesTabs and middleUsesNewWindow are false, it means the
 | ||||
|   // middle-click is used for different purpose, such as paste or scroll.
 | ||||
|   // Webpage still can trigger `window.open` for the user activation, and in
 | ||||
|   // that case use the `window.open`'s `features` parameter and other prefs to
 | ||||
|   // decide where to open.
 | ||||
| 
 | ||||
|   return false; | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -13,7 +13,6 @@ add_task(async function testStopStartingAutoScroll() { | |||
|         "accessibility.mouse_focuses_formcontrol", | ||||
|         !navigator.platform.includes("Mac"), | ||||
|       ], | ||||
|       ["browser.tabs.loadInBackground", false], | ||||
|     ], | ||||
|   }); | ||||
| 
 | ||||
|  |  | |||
|  | @ -544,7 +544,6 @@ nsContentTreeOwner::ProvideWindow( | |||
| 
 | ||||
|   if (openLocation != nsIBrowserDOMWindow::OPEN_NEWTAB && | ||||
|       openLocation != nsIBrowserDOMWindow::OPEN_NEWTAB_BACKGROUND && | ||||
|       openLocation != nsIBrowserDOMWindow::OPEN_NEWTAB_FOREGROUND && | ||||
|       openLocation != nsIBrowserDOMWindow::OPEN_CURRENTWINDOW && | ||||
|       openLocation != nsIBrowserDOMWindow::OPEN_PRINT_BROWSER) { | ||||
|     // Just open a window normally
 | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue
	
	 Cristian Tuns
						Cristian Tuns