Merge remote-tracking branch 'origin/pr/3055'
This commit is contained in:
commit
1b5f1aaebf
@ -71,9 +71,5 @@ coll = COLLECT(exe,
|
|||||||
app = BUNDLE(coll,
|
app = BUNDLE(coll,
|
||||||
name='qutebrowser.app',
|
name='qutebrowser.app',
|
||||||
icon=icon,
|
icon=icon,
|
||||||
info_plist={
|
|
||||||
'NSHighResolutionCapable': 'True',
|
|
||||||
'NSSupportsAutomaticGraphicsSwitching': 'True',
|
|
||||||
},
|
|
||||||
# https://github.com/pyinstaller/pyinstaller/blob/b78bfe530cdc2904f65ce098bdf2de08c9037abb/PyInstaller/hooks/hook-PyQt5.QtWebEngineWidgets.py#L24
|
# https://github.com/pyinstaller/pyinstaller/blob/b78bfe530cdc2904f65ce098bdf2de08c9037abb/PyInstaller/hooks/hook-PyQt5.QtWebEngineWidgets.py#L24
|
||||||
bundle_identifier='org.qt-project.Qt.QtWebEngineCore')
|
bundle_identifier='org.qt-project.Qt.QtWebEngineCore')
|
||||||
|
@ -288,11 +288,7 @@ def process_pos_args(args, via_ipc=False, cwd=None, target_arg=None):
|
|||||||
if via_ipc and target_arg and target_arg != 'auto':
|
if via_ipc and target_arg and target_arg != 'auto':
|
||||||
open_target = target_arg
|
open_target = target_arg
|
||||||
else:
|
else:
|
||||||
open_target = config.val.new_instance_open_target
|
open_target = None
|
||||||
win_id = mainwindow.get_window(via_ipc, force_target=open_target)
|
|
||||||
tabbed_browser = objreg.get('tabbed-browser', scope='window',
|
|
||||||
window=win_id)
|
|
||||||
log.init.debug("Startup URL {}".format(cmd))
|
|
||||||
if not cwd: # could also be an empty string due to the PyQt signal
|
if not cwd: # could also be an empty string due to the PyQt signal
|
||||||
cwd = None
|
cwd = None
|
||||||
try:
|
try:
|
||||||
@ -301,9 +297,30 @@ def process_pos_args(args, via_ipc=False, cwd=None, target_arg=None):
|
|||||||
message.error("Error in startup argument '{}': {}".format(
|
message.error("Error in startup argument '{}': {}".format(
|
||||||
cmd, e))
|
cmd, e))
|
||||||
else:
|
else:
|
||||||
background = open_target in ['tab-bg', 'tab-bg-silent']
|
win_id = open_url(url, target=open_target, via_ipc=via_ipc)
|
||||||
tabbed_browser.tabopen(url, background=background,
|
|
||||||
related=False)
|
|
||||||
|
def open_url(url, target=None, no_raise=False, via_ipc=True):
|
||||||
|
"""Open an URL in new window/tab
|
||||||
|
|
||||||
|
Args:
|
||||||
|
url: An URL to open
|
||||||
|
target: same as new_instance_open_target (used as a default)
|
||||||
|
no_raise: suppress target window raising
|
||||||
|
via_ipc: Whether the arguments were transmitted over IPC.
|
||||||
|
|
||||||
|
Return:
|
||||||
|
ID of a window that was used to open URL
|
||||||
|
"""
|
||||||
|
target = target or config.val.new_instance_open_target
|
||||||
|
background = target in {'tab-bg', 'tab-bg-silent'}
|
||||||
|
win_id = mainwindow.get_window(via_ipc, force_target=target,
|
||||||
|
no_raise=no_raise)
|
||||||
|
tabbed_browser = objreg.get('tabbed-browser', scope='window',
|
||||||
|
window=win_id)
|
||||||
|
log.init.debug("About to open URL: {}".format(url.toDisplayString()))
|
||||||
|
tabbed_browser.tabopen(url, background=background, related=False)
|
||||||
|
return win_id
|
||||||
|
|
||||||
|
|
||||||
def _open_startpage(win_id=None):
|
def _open_startpage(win_id=None):
|
||||||
@ -810,6 +827,14 @@ class Application(QApplication):
|
|||||||
log.misc.debug("Focus object changed: {}".format(output))
|
log.misc.debug("Focus object changed: {}".format(output))
|
||||||
self._last_focus_object = output
|
self._last_focus_object = output
|
||||||
|
|
||||||
|
def event(self, e):
|
||||||
|
if e.type() == QEvent.FileOpen:
|
||||||
|
open_url(e.url(), no_raise=True)
|
||||||
|
else:
|
||||||
|
return super().event(e)
|
||||||
|
|
||||||
|
return True
|
||||||
|
|
||||||
def __repr__(self):
|
def __repr__(self):
|
||||||
return utils.get_repr(self)
|
return utils.get_repr(self)
|
||||||
|
|
||||||
|
@ -43,7 +43,7 @@ win_id_gen = itertools.count(0)
|
|||||||
|
|
||||||
|
|
||||||
def get_window(via_ipc, force_window=False, force_tab=False,
|
def get_window(via_ipc, force_window=False, force_tab=False,
|
||||||
force_target=None):
|
force_target=None, no_raise=False):
|
||||||
"""Helper function for app.py to get a window id.
|
"""Helper function for app.py to get a window id.
|
||||||
|
|
||||||
Args:
|
Args:
|
||||||
@ -51,6 +51,10 @@ def get_window(via_ipc, force_window=False, force_tab=False,
|
|||||||
force_window: Whether to force opening in a window.
|
force_window: Whether to force opening in a window.
|
||||||
force_tab: Whether to force opening in a tab.
|
force_tab: Whether to force opening in a tab.
|
||||||
force_target: Override the new_instance_open_target config
|
force_target: Override the new_instance_open_target config
|
||||||
|
no_raise: suppress target window raising
|
||||||
|
|
||||||
|
Return:
|
||||||
|
ID of a window that was used to open URL
|
||||||
"""
|
"""
|
||||||
if force_window and force_tab:
|
if force_window and force_tab:
|
||||||
raise ValueError("force_window and force_tab are mutually exclusive!")
|
raise ValueError("force_window and force_tab are mutually exclusive!")
|
||||||
@ -71,28 +75,32 @@ def get_window(via_ipc, force_window=False, force_tab=False,
|
|||||||
open_target = 'tab-silent'
|
open_target = 'tab-silent'
|
||||||
|
|
||||||
window = None
|
window = None
|
||||||
raise_window = False
|
should_raise = False
|
||||||
|
|
||||||
# Try to find the existing tab target if opening in a tab
|
# Try to find the existing tab target if opening in a tab
|
||||||
if open_target != 'window':
|
if open_target != 'window':
|
||||||
window = get_target_window()
|
window = get_target_window()
|
||||||
raise_window = open_target not in ['tab-silent', 'tab-bg-silent']
|
should_raise = open_target not in ['tab-silent', 'tab-bg-silent']
|
||||||
|
|
||||||
# Otherwise, or if no window was found, create a new one
|
# Otherwise, or if no window was found, create a new one
|
||||||
if window is None:
|
if window is None:
|
||||||
window = MainWindow(private=None)
|
window = MainWindow(private=None)
|
||||||
window.show()
|
window.show()
|
||||||
raise_window = True
|
should_raise = True
|
||||||
|
|
||||||
if raise_window:
|
if should_raise and not no_raise:
|
||||||
|
raise_window(window)
|
||||||
|
|
||||||
|
return window.win_id
|
||||||
|
|
||||||
|
|
||||||
|
def raise_window(window):
|
||||||
window.setWindowState(window.windowState() & ~Qt.WindowMinimized)
|
window.setWindowState(window.windowState() & ~Qt.WindowMinimized)
|
||||||
window.setWindowState(window.windowState() | Qt.WindowActive)
|
window.setWindowState(window.windowState() | Qt.WindowActive)
|
||||||
window.raise_()
|
window.raise_()
|
||||||
window.activateWindow()
|
window.activateWindow()
|
||||||
QApplication.instance().alert(window)
|
QApplication.instance().alert(window)
|
||||||
|
|
||||||
return window.win_id
|
|
||||||
|
|
||||||
|
|
||||||
def get_target_window():
|
def get_target_window():
|
||||||
"""Get the target window for new tabs, or None if none exist."""
|
"""Get the target window for new tabs, or None if none exist."""
|
||||||
|
@ -26,6 +26,7 @@ import sys
|
|||||||
import glob
|
import glob
|
||||||
import os.path
|
import os.path
|
||||||
import shutil
|
import shutil
|
||||||
|
import plistlib
|
||||||
import subprocess
|
import subprocess
|
||||||
import argparse
|
import argparse
|
||||||
import tarfile
|
import tarfile
|
||||||
@ -123,6 +124,40 @@ def patch_mac_app():
|
|||||||
os.symlink(os.path.join(os.pardir, os.pardir, os.pardir, 'Contents',
|
os.symlink(os.path.join(os.pardir, os.pardir, os.pardir, 'Contents',
|
||||||
'MacOS', lib),
|
'MacOS', lib),
|
||||||
os.path.join(dest, lib))
|
os.path.join(dest, lib))
|
||||||
|
# Patch Info.plist - pyinstaller's options are too limiting
|
||||||
|
plist_path = os.path.join(app_path, 'Contents', 'Info.plist')
|
||||||
|
with open(plist_path, "rb") as f:
|
||||||
|
plist_data = plistlib.load(f)
|
||||||
|
plist_data.update(INFO_PLIST_UPDATES)
|
||||||
|
with open(plist_path, "wb") as f:
|
||||||
|
plistlib.dump(plist_data, f)
|
||||||
|
|
||||||
|
|
||||||
|
INFO_PLIST_UPDATES = {
|
||||||
|
'CFBundleVersion': qutebrowser.__version__,
|
||||||
|
'CFBundleShortVersionString': qutebrowser.__version__,
|
||||||
|
'NSSupportsAutomaticGraphicsSwitching': True,
|
||||||
|
'NSHighResolutionCapable': True,
|
||||||
|
'CFBundleURLTypes': [{
|
||||||
|
"CFBundleURLName": "http(s) URL",
|
||||||
|
"CFBundleURLSchemes": ["http", "https"]
|
||||||
|
}, {
|
||||||
|
"CFBundleURLName": "local file URL",
|
||||||
|
"CFBundleURLSchemes": ["file"]
|
||||||
|
}],
|
||||||
|
'CFBundleDocumentTypes': [{
|
||||||
|
"CFBundleTypeExtensions": ["html", "htm"],
|
||||||
|
"CFBundleTypeMIMETypes": ["text/html"],
|
||||||
|
"CFBundleTypeName": "HTML document",
|
||||||
|
"CFBundleTypeOSTypes": ["HTML"],
|
||||||
|
"CFBundleTypeRole": "Viewer",
|
||||||
|
}, {
|
||||||
|
"CFBundleTypeExtensions": ["xhtml"],
|
||||||
|
"CFBundleTypeMIMETypes": ["text/xhtml"],
|
||||||
|
"CFBundleTypeName": "XHTML document",
|
||||||
|
"CFBundleTypeRole": "Viewer",
|
||||||
|
}]
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
def build_mac():
|
def build_mac():
|
||||||
|
Loading…
Reference in New Issue
Block a user