Allow ignoring failure to close windows/tabs via rc commands
This commit is contained in:
parent
9e9aa52553
commit
b7a4281985
@ -106,6 +106,8 @@ Detailed list of changes
|
|||||||
|
|
||||||
- macOS: Fix speaking selected text not working (:iss:`5357`)
|
- macOS: Fix speaking selected text not working (:iss:`5357`)
|
||||||
|
|
||||||
|
- Allow ignoring failure to close windows/tabs via rc commands (:disc:`5406`)
|
||||||
|
|
||||||
|
|
||||||
0.25.2 [2022-06-07]
|
0.25.2 [2022-06-07]
|
||||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|||||||
@ -5,8 +5,8 @@
|
|||||||
from typing import TYPE_CHECKING, Optional
|
from typing import TYPE_CHECKING, Optional
|
||||||
|
|
||||||
from .base import (
|
from .base import (
|
||||||
MATCH_TAB_OPTION, ArgsType, Boss, PayloadGetType, PayloadType, RCOptions,
|
MATCH_TAB_OPTION, ArgsType, Boss, MatchError, PayloadGetType, PayloadType,
|
||||||
RemoteCommand, ResponseType, Window
|
RCOptions, RemoteCommand, ResponseType, Window
|
||||||
)
|
)
|
||||||
|
|
||||||
if TYPE_CHECKING:
|
if TYPE_CHECKING:
|
||||||
@ -18,6 +18,7 @@ class CloseTab(RemoteCommand):
|
|||||||
'''
|
'''
|
||||||
match/str: Which tab to close
|
match/str: Which tab to close
|
||||||
self/bool: Boolean indicating whether to close the tab of the window the command is run in
|
self/bool: Boolean indicating whether to close the tab of the window the command is run in
|
||||||
|
ignore_no_match/bool: Boolean indicating whether no matches should be ignored or return an error
|
||||||
'''
|
'''
|
||||||
|
|
||||||
short_desc = 'Close the specified tabs'
|
short_desc = 'Close the specified tabs'
|
||||||
@ -32,14 +33,25 @@ tabs in the currently focused OS window, use::
|
|||||||
--self
|
--self
|
||||||
type=bool-set
|
type=bool-set
|
||||||
Close the tab of the window this command is run in, rather than the active tab.
|
Close the tab of the window this command is run in, rather than the active tab.
|
||||||
|
|
||||||
|
|
||||||
|
--ignore-no-match
|
||||||
|
type=bool-set
|
||||||
|
Do not return an error if no tabs are matched to be closed.
|
||||||
'''
|
'''
|
||||||
argspec = ''
|
argspec = ''
|
||||||
|
|
||||||
def message_to_kitty(self, global_opts: RCOptions, opts: 'CLIOptions', args: ArgsType) -> PayloadType:
|
def message_to_kitty(self, global_opts: RCOptions, opts: 'CLIOptions', args: ArgsType) -> PayloadType:
|
||||||
return {'match': opts.match, 'self': opts.self}
|
return {'match': opts.match, 'self': opts.self, 'ignore_no_match': opts.ignore_no_match}
|
||||||
|
|
||||||
def response_from_kitty(self, boss: Boss, window: Optional[Window], payload_get: PayloadGetType) -> ResponseType:
|
def response_from_kitty(self, boss: Boss, window: Optional[Window], payload_get: PayloadGetType) -> ResponseType:
|
||||||
for tab in self.tabs_for_match_payload(boss, window, payload_get):
|
try:
|
||||||
|
tabs = self.tabs_for_match_payload(boss, window, payload_get)
|
||||||
|
except MatchError:
|
||||||
|
if payload_get('ignore_no_match'):
|
||||||
|
return None
|
||||||
|
raise
|
||||||
|
for tab in tabs:
|
||||||
if tab:
|
if tab:
|
||||||
boss.close_tab_no_confirm(tab)
|
boss.close_tab_no_confirm(tab)
|
||||||
return None
|
return None
|
||||||
|
|||||||
@ -6,7 +6,7 @@ from typing import TYPE_CHECKING, Optional
|
|||||||
|
|
||||||
from .base import (
|
from .base import (
|
||||||
MATCH_WINDOW_OPTION, ArgsType, Boss, PayloadGetType, PayloadType,
|
MATCH_WINDOW_OPTION, ArgsType, Boss, PayloadGetType, PayloadType,
|
||||||
RCOptions, RemoteCommand, ResponseType, Window
|
RCOptions, RemoteCommand, ResponseType, Window, MatchError
|
||||||
)
|
)
|
||||||
|
|
||||||
if TYPE_CHECKING:
|
if TYPE_CHECKING:
|
||||||
@ -17,6 +17,7 @@ class CloseWindow(RemoteCommand):
|
|||||||
'''
|
'''
|
||||||
match/str: Which window to close
|
match/str: Which window to close
|
||||||
self/bool: Boolean indicating whether to close the window the command is run in
|
self/bool: Boolean indicating whether to close the window the command is run in
|
||||||
|
ignore_no_match/bool: Boolean indicating whether no matches should be ignored or return an error
|
||||||
'''
|
'''
|
||||||
|
|
||||||
short_desc = 'Close the specified windows'
|
short_desc = 'Close the specified windows'
|
||||||
@ -24,14 +25,25 @@ class CloseWindow(RemoteCommand):
|
|||||||
--self
|
--self
|
||||||
type=bool-set
|
type=bool-set
|
||||||
Close the window this command is run in, rather than the active window.
|
Close the window this command is run in, rather than the active window.
|
||||||
|
|
||||||
|
|
||||||
|
--ignore-no-match
|
||||||
|
type=bool-set
|
||||||
|
Do not return an error if no windows are matched to be closed.
|
||||||
'''
|
'''
|
||||||
argspec = ''
|
argspec = ''
|
||||||
|
|
||||||
def message_to_kitty(self, global_opts: RCOptions, opts: 'CLIOptions', args: ArgsType) -> PayloadType:
|
def message_to_kitty(self, global_opts: RCOptions, opts: 'CLIOptions', args: ArgsType) -> PayloadType:
|
||||||
return {'match': opts.match, 'self': opts.self}
|
return {'match': opts.match, 'self': opts.self, 'ignore_no_match': opts.ignore_no_match}
|
||||||
|
|
||||||
def response_from_kitty(self, boss: Boss, window: Optional[Window], payload_get: PayloadGetType) -> ResponseType:
|
def response_from_kitty(self, boss: Boss, window: Optional[Window], payload_get: PayloadGetType) -> ResponseType:
|
||||||
for window in self.windows_for_match_payload(boss, window, payload_get):
|
try:
|
||||||
|
windows = self.windows_for_match_payload(boss, window, payload_get)
|
||||||
|
except MatchError:
|
||||||
|
if payload_get('ignore_no_match'):
|
||||||
|
return None
|
||||||
|
raise
|
||||||
|
for window in windows:
|
||||||
if window:
|
if window:
|
||||||
boss.mark_window_for_close(window)
|
boss.mark_window_for_close(window)
|
||||||
return None
|
return None
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user