Fix #4947
This commit is contained in:
parent
2f367fa90c
commit
4c77b0c562
@ -18,6 +18,7 @@ class CloseTab(RemoteCommand):
|
|||||||
'''
|
'''
|
||||||
match: Which tab to close
|
match: Which tab to close
|
||||||
self: Boolean indicating whether to close the tab of the window the command is run in
|
self: Boolean indicating whether to close the tab of the window the command is run in
|
||||||
|
target_group: The target group to close
|
||||||
'''
|
'''
|
||||||
|
|
||||||
short_desc = 'Close the specified tab(s)'
|
short_desc = 'Close the specified tab(s)'
|
||||||
@ -25,13 +26,51 @@ class CloseTab(RemoteCommand):
|
|||||||
--self
|
--self
|
||||||
type=bool-set
|
type=bool-set
|
||||||
If specified close the tab of the window this command is run in, rather than the active tab.
|
If specified close the tab of the window this command is run in, rather than the active tab.
|
||||||
|
|
||||||
|
|
||||||
|
--target-group
|
||||||
|
choices=unactive-in-os-window,unactive,others,others-in-os-window,none
|
||||||
|
default=none
|
||||||
|
Close the specified group of tabs. When specified, this option takes precedence over other
|
||||||
|
options controlling which tabs to close.
|
||||||
|
unactive is all tabs in the kitty instance except the currently active tab.
|
||||||
|
unactive-in-os-window is the same as unactive except restricted to the OS Window with the currently active tab
|
||||||
|
others is all tabs except the tab containing the window this command was run in
|
||||||
|
others-in-os-window is the same as others except restricted to the OS window this command was run in
|
||||||
'''
|
'''
|
||||||
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, 'target_group': opts.target_group}
|
||||||
|
|
||||||
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:
|
||||||
|
g = payload_get('target_group')
|
||||||
|
if g == 'others' and window:
|
||||||
|
avoid = boss.tab_for_window(window)
|
||||||
|
for tab in boss.all_tabs:
|
||||||
|
if tab is not avoid:
|
||||||
|
boss.close_tab_no_confirm(tab)
|
||||||
|
elif g == 'others-in-os-window' and window:
|
||||||
|
avoid = boss.tab_for_window(window)
|
||||||
|
if avoid:
|
||||||
|
tm = boss.os_window_map[avoid.os_window_id]
|
||||||
|
for tab in tm:
|
||||||
|
if tab is not avoid:
|
||||||
|
boss.close_tab_no_confirm(tab)
|
||||||
|
elif g == 'unactive':
|
||||||
|
avoid = boss.active_tab
|
||||||
|
for tab in boss.all_tabs:
|
||||||
|
if tab is not avoid:
|
||||||
|
boss.close_tab_no_confirm(tab)
|
||||||
|
elif g == 'unactive-in-os-window':
|
||||||
|
avoid = boss.active_tab
|
||||||
|
if avoid:
|
||||||
|
tm = boss.os_window_map[avoid.os_window_id]
|
||||||
|
for tab in tm:
|
||||||
|
if tab is not avoid:
|
||||||
|
boss.close_tab_no_confirm(tab)
|
||||||
|
if g:
|
||||||
|
return None
|
||||||
for tab in self.tabs_for_match_payload(boss, window, payload_get):
|
for tab in self.tabs_for_match_payload(boss, window, payload_get):
|
||||||
if tab:
|
if tab:
|
||||||
boss.close_tab_no_confirm(tab)
|
boss.close_tab_no_confirm(tab)
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user