feat(cli): zellij run improvements (#1804)

* feat(cli): move command to the end of the cli arguments

* feat(cli): allow naming panes from the command line

* fix(cli): adjust actions after pane rename

* feat(cli): zellij run completions for fish

* feat(cli): zellij run completions for bash and zsh

* style(fmt): rustfmt

* fix(e2e): fix run test and snapshot

* style(fmt): rustfmt
This commit is contained in:
Aram Drevekenin 2022-10-17 19:39:37 +02:00 committed by GitHub
parent 4562982409
commit 271abb3ea2
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
30 changed files with 270 additions and 121 deletions

View file

@ -148,12 +148,12 @@ fn get_keys_and_hints(mi: &ModeInfo) -> Vec<(String, String, Vec<Key>)> {
(s("Move focus"), s("Move"), (s("Move focus"), s("Move"),
action_key_group(&km, &[&[A::MoveFocus(Dir::Left)], &[A::MoveFocus(Dir::Down)], action_key_group(&km, &[&[A::MoveFocus(Dir::Left)], &[A::MoveFocus(Dir::Down)],
&[A::MoveFocus(Dir::Up)], &[A::MoveFocus(Dir::Right)]])), &[A::MoveFocus(Dir::Up)], &[A::MoveFocus(Dir::Right)]])),
(s("New"), s("New"), action_key(&km, &[A::NewPane(None), TO_NORMAL])), (s("New"), s("New"), action_key(&km, &[A::NewPane(None, None), TO_NORMAL])),
(s("Close"), s("Close"), action_key(&km, &[A::CloseFocus, TO_NORMAL])), (s("Close"), s("Close"), action_key(&km, &[A::CloseFocus, TO_NORMAL])),
(s("Rename"), s("Rename"), (s("Rename"), s("Rename"),
action_key(&km, &[A::SwitchToMode(IM::RenamePane), A::PaneNameInput(vec![0])])), action_key(&km, &[A::SwitchToMode(IM::RenamePane), A::PaneNameInput(vec![0])])),
(s("Split down"), s("Down"), action_key(&km, &[A::NewPane(Some(Dir::Down)), TO_NORMAL])), (s("Split down"), s("Down"), action_key(&km, &[A::NewPane(Some(Dir::Down), None), TO_NORMAL])),
(s("Split right"), s("Right"), action_key(&km, &[A::NewPane(Some(Dir::Right)), TO_NORMAL])), (s("Split right"), s("Right"), action_key(&km, &[A::NewPane(Some(Dir::Right), None), TO_NORMAL])),
(s("Fullscreen"), s("Fullscreen"), action_key(&km, &[A::ToggleFocusFullscreen, TO_NORMAL])), (s("Fullscreen"), s("Fullscreen"), action_key(&km, &[A::ToggleFocusFullscreen, TO_NORMAL])),
(s("Frames"), s("Frames"), action_key(&km, &[A::TogglePaneFrames, TO_NORMAL])), (s("Frames"), s("Frames"), action_key(&km, &[A::TogglePaneFrames, TO_NORMAL])),
(s("Floating toggle"), s("Floating"), (s("Floating toggle"), s("Floating"),
@ -239,8 +239,8 @@ fn get_keys_and_hints(mi: &ModeInfo) -> Vec<(String, String, Vec<Key>)> {
(s("Move focus"), s("Move"), action_key_group(&km, &[ (s("Move focus"), s("Move"), action_key_group(&km, &[
&[A::MoveFocus(Dir::Left)], &[A::MoveFocus(Dir::Down)], &[A::MoveFocus(Dir::Left)], &[A::MoveFocus(Dir::Down)],
&[A::MoveFocus(Dir::Up)], &[A::MoveFocus(Dir::Right)]])), &[A::MoveFocus(Dir::Up)], &[A::MoveFocus(Dir::Right)]])),
(s("Split down"), s("Down"), action_key(&km, &[A::NewPane(Some(Dir::Down)), TO_NORMAL])), (s("Split down"), s("Down"), action_key(&km, &[A::NewPane(Some(Dir::Down), None), TO_NORMAL])),
(s("Split right"), s("Right"), action_key(&km, &[A::NewPane(Some(Dir::Right)), TO_NORMAL])), (s("Split right"), s("Right"), action_key(&km, &[A::NewPane(Some(Dir::Right), None), TO_NORMAL])),
(s("Fullscreen"), s("Fullscreen"), action_key(&km, &[A::ToggleFocusFullscreen, TO_NORMAL])), (s("Fullscreen"), s("Fullscreen"), action_key(&km, &[A::ToggleFocusFullscreen, TO_NORMAL])),
(s("New tab"), s("New"), action_key(&km, &[A::NewTab(None, None), TO_NORMAL])), (s("New tab"), s("New"), action_key(&km, &[A::NewTab(None, None), TO_NORMAL])),
(s("Rename tab"), s("Rename"), (s("Rename tab"), s("Rename"),
@ -673,7 +673,7 @@ mod tests {
Key::Right, Key::Right,
vec![Action::MoveFocus(actions::Direction::Right)], vec![Action::MoveFocus(actions::Direction::Right)],
), ),
(Key::Char('n'), vec![Action::NewPane(None), TO_NORMAL]), (Key::Char('n'), vec![Action::NewPane(None, None), TO_NORMAL]),
(Key::Char('x'), vec![Action::CloseFocus, TO_NORMAL]), (Key::Char('x'), vec![Action::CloseFocus, TO_NORMAL]),
( (
Key::Char('f'), Key::Char('f'),
@ -708,7 +708,7 @@ mod tests {
Key::Right, Key::Right,
vec![Action::MoveFocus(actions::Direction::Right)], vec![Action::MoveFocus(actions::Direction::Right)],
), ),
(Key::Char('n'), vec![Action::NewPane(None), TO_NORMAL]), (Key::Char('n'), vec![Action::NewPane(None, None), TO_NORMAL]),
(Key::Char('x'), vec![Action::CloseFocus, TO_NORMAL]), (Key::Char('x'), vec![Action::CloseFocus, TO_NORMAL]),
( (
Key::Char('f'), Key::Char('f'),
@ -748,7 +748,7 @@ mod tests {
Key::Ctrl(' '), Key::Ctrl(' '),
vec![Action::MoveFocus(actions::Direction::Right)], vec![Action::MoveFocus(actions::Direction::Right)],
), ),
(Key::Backspace, vec![Action::NewPane(None), TO_NORMAL]), (Key::Backspace, vec![Action::NewPane(None, None), TO_NORMAL]),
(Key::Esc, vec![Action::CloseFocus, TO_NORMAL]), (Key::Esc, vec![Action::CloseFocus, TO_NORMAL]),
(Key::End, vec![Action::ToggleFocusFullscreen, TO_NORMAL]), (Key::End, vec![Action::ToggleFocusFullscreen, TO_NORMAL]),
], ],

View file

@ -65,7 +65,7 @@ struct Keygroups<'a> {
fn add_keybinds(help: &ModeInfo) -> Keygroups { fn add_keybinds(help: &ModeInfo) -> Keygroups {
let normal_keymap = help.get_mode_keybinds(); let normal_keymap = help.get_mode_keybinds();
let new_pane_keys = action_key(&normal_keymap, &[Action::NewPane(None)]); let new_pane_keys = action_key(&normal_keymap, &[Action::NewPane(None, None)]);
let new_pane = if new_pane_keys.is_empty() { let new_pane = if new_pane_keys.is_empty() {
vec![Style::new().bold().paint("UNBOUND")] vec![Style::new().bold().paint("UNBOUND")]
} else { } else {

View file

@ -24,6 +24,7 @@ fn main() {
direction, direction,
cwd, cwd,
floating, floating,
name,
})) = opts.command })) = opts.command
{ {
let command_cli_action = CliAction::NewPane { let command_cli_action = CliAction::NewPane {
@ -31,6 +32,7 @@ fn main() {
direction, direction,
cwd, cwd,
floating, floating,
name,
}; };
commands::send_action_to_session(command_cli_action, opts.session); commands::send_action_to_session(command_cli_action, opts.session);
std::process::exit(0); std::process::exit(0);

View file

@ -345,7 +345,9 @@ impl RemoteTerminal {
pub fn send_command_through_the_cli(&mut self, command: &str) { pub fn send_command_through_the_cli(&mut self, command: &str) {
let mut channel = self.channel.lock().unwrap(); let mut channel = self.channel.lock().unwrap();
channel channel
.write_all(format!("{} run \"{}\"\n", ZELLIJ_EXECUTABLE_LOCATION, command).as_bytes()) .write_all(
format!("{} run -- \"{}\"\n", ZELLIJ_EXECUTABLE_LOCATION, command).as_bytes(),
)
.unwrap(); .unwrap();
channel.flush().unwrap(); channel.flush().unwrap();
} }

View file

@ -6,7 +6,7 @@ expression: last_snapshot
Zellij (e2e-test)  Tab #1  Zellij (e2e-test)  Tab #1 
┌ Pane #1 ─────────────────────────────────────────────────┐┌ /usr/src/zellij/fixtures/append-echo-script.sh ──────────┐ ┌ Pane #1 ─────────────────────────────────────────────────┐┌ /usr/src/zellij/fixtures/append-echo-script.sh ──────────┐
│$ /usr/src/zellij/x86_64-unknown-linux-musl/release/zellij││foo │ │$ /usr/src/zellij/x86_64-unknown-linux-musl/release/zellij││foo │
│ run "/usr/src/zellij/fixtures/append-echo-script.sh" ││foo │ │ run -- "/usr/src/zellij/fixtures/append-echo-script.sh" ││foo │
│$ ││█ │ │$ ││█ │
│ ││ │ │ ││ │
│ ││ │ │ ││ │

View file

@ -267,7 +267,7 @@ impl InputHandler {
.send_to_server(ClientToServerMsg::Action(action, None)); .send_to_server(ClientToServerMsg::Action(action, None));
}, },
Action::CloseFocus Action::CloseFocus
| Action::NewPane(_) | Action::NewPane(..)
| Action::Run(_) | Action::Run(_)
| Action::ToggleFloatingPanes | Action::ToggleFloatingPanes
| Action::TogglePaneEmbedOrFloating | Action::TogglePaneEmbedOrFloating

View file

@ -343,9 +343,7 @@ impl Pane for TerminalPane {
input_mode: InputMode, input_mode: InputMode,
) -> Option<(Vec<CharacterChunk>, Option<String>)> { ) -> Option<(Vec<CharacterChunk>, Option<String>)> {
// TODO: remove the cursor stuff from here // TODO: remove the cursor stuff from here
let pane_title = if let Some((_exit_status, run_command)) = &self.is_held { let pane_title = if self.pane_name.is_empty()
format!("{}", run_command)
} else if self.pane_name.is_empty()
&& input_mode == InputMode::RenamePane && input_mode == InputMode::RenamePane
&& frame_params.is_main_client && frame_params.is_main_client
{ {

View file

@ -31,11 +31,20 @@ pub enum ClientOrTabIndex {
/// Instructions related to PTYs (pseudoterminals). /// Instructions related to PTYs (pseudoterminals).
#[derive(Clone, Debug)] #[derive(Clone, Debug)]
pub(crate) enum PtyInstruction { pub(crate) enum PtyInstruction {
SpawnTerminal(Option<TerminalAction>, Option<bool>, ClientOrTabIndex), // bool (if Some) is SpawnTerminal(
// should_float Option<TerminalAction>,
Option<bool>,
Option<String>,
ClientOrTabIndex,
), // bool (if Some) is
// should_float, String is an optional pane name
OpenInPlaceEditor(PathBuf, Option<usize>, ClientId), // Option<usize> is the optional line number OpenInPlaceEditor(PathBuf, Option<usize>, ClientId), // Option<usize> is the optional line number
SpawnTerminalVertically(Option<TerminalAction>, ClientId), SpawnTerminalVertically(Option<TerminalAction>, Option<String>, ClientId), // String is an
SpawnTerminalHorizontally(Option<TerminalAction>, ClientId), // optional pane
// name
SpawnTerminalHorizontally(Option<TerminalAction>, Option<String>, ClientId), // String is an
// optional pane
// name
UpdateActivePane(Option<PaneId>, ClientId), UpdateActivePane(Option<PaneId>, ClientId),
GoToTab(TabIndex, ClientId), GoToTab(TabIndex, ClientId),
NewTab( NewTab(
@ -82,14 +91,19 @@ pub(crate) fn pty_thread_main(mut pty: Pty, layout: Box<Layout>) {
let (event, mut err_ctx) = pty.bus.recv().expect("failed to receive event on channel"); let (event, mut err_ctx) = pty.bus.recv().expect("failed to receive event on channel");
err_ctx.add_call(ContextType::Pty((&event).into())); err_ctx.add_call(ContextType::Pty((&event).into()));
match event { match event {
PtyInstruction::SpawnTerminal(terminal_action, should_float, client_or_tab_index) => { PtyInstruction::SpawnTerminal(
terminal_action,
should_float,
name,
client_or_tab_index,
) => {
let (hold_on_close, run_command, pane_title) = match &terminal_action { let (hold_on_close, run_command, pane_title) = match &terminal_action {
Some(TerminalAction::RunCommand(run_command)) => ( Some(TerminalAction::RunCommand(run_command)) => (
run_command.hold_on_close, run_command.hold_on_close,
Some(run_command.clone()), Some(run_command.clone()),
Some(run_command.to_string()), Some(name.unwrap_or_else(|| run_command.to_string())),
), ),
_ => (false, None, None), _ => (false, None, name),
}; };
match pty.spawn_terminal(terminal_action, client_or_tab_index) { match pty.spawn_terminal(terminal_action, client_or_tab_index) {
Ok(pid) => { Ok(pid) => {
@ -149,14 +163,14 @@ pub(crate) fn pty_thread_main(mut pty: Pty, layout: Box<Layout>) {
}, },
} }
}, },
PtyInstruction::SpawnTerminalVertically(terminal_action, client_id) => { PtyInstruction::SpawnTerminalVertically(terminal_action, name, client_id) => {
let (hold_on_close, run_command, pane_title) = match &terminal_action { let (hold_on_close, run_command, pane_title) = match &terminal_action {
Some(TerminalAction::RunCommand(run_command)) => ( Some(TerminalAction::RunCommand(run_command)) => (
run_command.hold_on_close, run_command.hold_on_close,
Some(run_command.clone()), Some(run_command.clone()),
Some(run_command.to_string()), Some(name.unwrap_or_else(|| run_command.to_string())),
), ),
_ => (false, None, None), _ => (false, None, name),
}; };
match pty.spawn_terminal(terminal_action, ClientOrTabIndex::ClientId(client_id)) { match pty.spawn_terminal(terminal_action, ClientOrTabIndex::ClientId(client_id)) {
Ok(pid) => { Ok(pid) => {
@ -209,14 +223,14 @@ pub(crate) fn pty_thread_main(mut pty: Pty, layout: Box<Layout>) {
}, },
} }
}, },
PtyInstruction::SpawnTerminalHorizontally(terminal_action, client_id) => { PtyInstruction::SpawnTerminalHorizontally(terminal_action, name, client_id) => {
let (hold_on_close, run_command, pane_title) = match &terminal_action { let (hold_on_close, run_command, pane_title) = match &terminal_action {
Some(TerminalAction::RunCommand(run_command)) => ( Some(TerminalAction::RunCommand(run_command)) => (
run_command.hold_on_close, run_command.hold_on_close,
Some(run_command.clone()), Some(run_command.clone()),
Some(run_command.to_string()), Some(name.unwrap_or_else(|| run_command.to_string())),
), ),
_ => (false, None, None), _ => (false, None, name),
}; };
match pty.spawn_terminal(terminal_action, ClientOrTabIndex::ClientId(client_id)) { match pty.spawn_terminal(terminal_action, ClientOrTabIndex::ClientId(client_id)) {
Ok(pid) => { Ok(pid) => {

View file

@ -235,43 +235,56 @@ pub(crate) fn route_action(
.send_to_screen(ScreenInstruction::TogglePaneFrames) .send_to_screen(ScreenInstruction::TogglePaneFrames)
.unwrap(); .unwrap();
}, },
Action::NewPane(direction) => { Action::NewPane(direction, name) => {
let shell = session.default_shell.clone(); let shell = session.default_shell.clone();
let pty_instr = match direction { let pty_instr = match direction {
Some(Direction::Left) => PtyInstruction::SpawnTerminalVertically(shell, client_id), Some(Direction::Left) => {
Some(Direction::Right) => PtyInstruction::SpawnTerminalVertically(shell, client_id), PtyInstruction::SpawnTerminalVertically(shell, name, client_id)
Some(Direction::Up) => PtyInstruction::SpawnTerminalHorizontally(shell, client_id), },
Some(Direction::Right) => {
PtyInstruction::SpawnTerminalVertically(shell, name, client_id)
},
Some(Direction::Up) => {
PtyInstruction::SpawnTerminalHorizontally(shell, name, client_id)
},
Some(Direction::Down) => { Some(Direction::Down) => {
PtyInstruction::SpawnTerminalHorizontally(shell, client_id) PtyInstruction::SpawnTerminalHorizontally(shell, name, client_id)
}, },
// No direction specified - try to put it in the biggest available spot // No direction specified - try to put it in the biggest available spot
None => PtyInstruction::SpawnTerminal( None => PtyInstruction::SpawnTerminal(
shell, shell,
None, None,
name,
ClientOrTabIndex::ClientId(client_id), ClientOrTabIndex::ClientId(client_id),
), ),
}; };
session.senders.send_to_pty(pty_instr).unwrap(); session.senders.send_to_pty(pty_instr).unwrap();
}, },
Action::EditFile(path_to_file, line_number, split_direction, should_float) => { Action::EditFile(path_to_file, line_number, split_direction, should_float) => {
let title = format!("Editing: {}", path_to_file.display());
let open_file = TerminalAction::OpenFile(path_to_file, line_number); let open_file = TerminalAction::OpenFile(path_to_file, line_number);
let pty_instr = match (split_direction, should_float) { let pty_instr = match (split_direction, should_float) {
(Some(Direction::Left), false) => { (Some(Direction::Left), false) => {
PtyInstruction::SpawnTerminalVertically(Some(open_file), client_id) PtyInstruction::SpawnTerminalVertically(Some(open_file), Some(title), client_id)
}, },
(Some(Direction::Right), false) => { (Some(Direction::Right), false) => {
PtyInstruction::SpawnTerminalVertically(Some(open_file), client_id) PtyInstruction::SpawnTerminalVertically(Some(open_file), Some(title), client_id)
},
(Some(Direction::Up), false) => {
PtyInstruction::SpawnTerminalHorizontally(Some(open_file), client_id)
},
(Some(Direction::Down), false) => {
PtyInstruction::SpawnTerminalHorizontally(Some(open_file), client_id)
}, },
(Some(Direction::Up), false) => PtyInstruction::SpawnTerminalHorizontally(
Some(open_file),
Some(title),
client_id,
),
(Some(Direction::Down), false) => PtyInstruction::SpawnTerminalHorizontally(
Some(open_file),
Some(title),
client_id,
),
// No direction specified or should float - defer placement to screen // No direction specified or should float - defer placement to screen
(None, _) | (_, true) => PtyInstruction::SpawnTerminal( (None, _) | (_, true) => PtyInstruction::SpawnTerminal(
Some(open_file), Some(open_file),
Some(should_float), Some(should_float),
Some(title),
ClientOrTabIndex::ClientId(client_id), ClientOrTabIndex::ClientId(client_id),
), ),
}; };
@ -296,7 +309,7 @@ pub(crate) fn route_action(
))) )))
.unwrap(); .unwrap();
}, },
Action::NewFloatingPane(run_command) => { Action::NewFloatingPane(run_command, name) => {
let should_float = true; let should_float = true;
let run_cmd = run_command let run_cmd = run_command
.map(|cmd| TerminalAction::RunCommand(cmd.into())) .map(|cmd| TerminalAction::RunCommand(cmd.into()))
@ -306,32 +319,34 @@ pub(crate) fn route_action(
.send_to_pty(PtyInstruction::SpawnTerminal( .send_to_pty(PtyInstruction::SpawnTerminal(
run_cmd, run_cmd,
Some(should_float), Some(should_float),
name,
ClientOrTabIndex::ClientId(client_id), ClientOrTabIndex::ClientId(client_id),
)) ))
.unwrap(); .unwrap();
}, },
Action::NewTiledPane(direction, run_command) => { Action::NewTiledPane(direction, run_command, name) => {
let should_float = false; let should_float = false;
let run_cmd = run_command let run_cmd = run_command
.map(|cmd| TerminalAction::RunCommand(cmd.into())) .map(|cmd| TerminalAction::RunCommand(cmd.into()))
.or_else(|| session.default_shell.clone()); .or_else(|| session.default_shell.clone());
let pty_instr = match direction { let pty_instr = match direction {
Some(Direction::Left) => { Some(Direction::Left) => {
PtyInstruction::SpawnTerminalVertically(run_cmd, client_id) PtyInstruction::SpawnTerminalVertically(run_cmd, name, client_id)
}, },
Some(Direction::Right) => { Some(Direction::Right) => {
PtyInstruction::SpawnTerminalVertically(run_cmd, client_id) PtyInstruction::SpawnTerminalVertically(run_cmd, name, client_id)
}, },
Some(Direction::Up) => { Some(Direction::Up) => {
PtyInstruction::SpawnTerminalHorizontally(run_cmd, client_id) PtyInstruction::SpawnTerminalHorizontally(run_cmd, name, client_id)
}, },
Some(Direction::Down) => { Some(Direction::Down) => {
PtyInstruction::SpawnTerminalHorizontally(run_cmd, client_id) PtyInstruction::SpawnTerminalHorizontally(run_cmd, name, client_id)
}, },
// No direction specified - try to put it in the biggest available spot // No direction specified - try to put it in the biggest available spot
None => PtyInstruction::SpawnTerminal( None => PtyInstruction::SpawnTerminal(
run_cmd, run_cmd,
Some(should_float), Some(should_float),
name,
ClientOrTabIndex::ClientId(client_id), ClientOrTabIndex::ClientId(client_id),
), ),
}; };
@ -368,21 +383,22 @@ pub(crate) fn route_action(
let run_cmd = Some(TerminalAction::RunCommand(command.clone().into())); let run_cmd = Some(TerminalAction::RunCommand(command.clone().into()));
let pty_instr = match command.direction { let pty_instr = match command.direction {
Some(Direction::Left) => { Some(Direction::Left) => {
PtyInstruction::SpawnTerminalVertically(run_cmd, client_id) PtyInstruction::SpawnTerminalVertically(run_cmd, None, client_id)
}, },
Some(Direction::Right) => { Some(Direction::Right) => {
PtyInstruction::SpawnTerminalVertically(run_cmd, client_id) PtyInstruction::SpawnTerminalVertically(run_cmd, None, client_id)
}, },
Some(Direction::Up) => { Some(Direction::Up) => {
PtyInstruction::SpawnTerminalHorizontally(run_cmd, client_id) PtyInstruction::SpawnTerminalHorizontally(run_cmd, None, client_id)
}, },
Some(Direction::Down) => { Some(Direction::Down) => {
PtyInstruction::SpawnTerminalHorizontally(run_cmd, client_id) PtyInstruction::SpawnTerminalHorizontally(run_cmd, None, client_id)
}, },
// No direction specified - try to put it in the biggest available spot // No direction specified - try to put it in the biggest available spot
None => PtyInstruction::SpawnTerminal( None => PtyInstruction::SpawnTerminal(
run_cmd, run_cmd,
None, None,
None,
ClientOrTabIndex::ClientId(client_id), ClientOrTabIndex::ClientId(client_id),
), ),
}; };

View file

@ -780,10 +780,12 @@ impl Tab {
} }
}, },
None => { None => {
let name = None;
let should_float = true; let should_float = true;
let instruction = PtyInstruction::SpawnTerminal( let instruction = PtyInstruction::SpawnTerminal(
default_shell, default_shell,
Some(should_float), Some(should_float),
name,
ClientOrTabIndex::ClientId(client_id), ClientOrTabIndex::ClientId(client_id),
); );
self.senders.send_to_pty(instruction).with_context(|| { self.senders.send_to_pty(instruction).with_context(|| {

View file

@ -1815,9 +1815,10 @@ pub fn send_cli_new_pane_action_with_default_parameters() {
); );
let cli_new_pane_action = CliAction::NewPane { let cli_new_pane_action = CliAction::NewPane {
direction: None, direction: None,
command: None, command: vec![],
cwd: None, cwd: None,
floating: false, floating: false,
name: None,
}; };
send_cli_action_to_server( send_cli_action_to_server(
&session_metadata, &session_metadata,
@ -1852,9 +1853,10 @@ pub fn send_cli_new_pane_action_with_split_direction() {
); );
let cli_new_pane_action = CliAction::NewPane { let cli_new_pane_action = CliAction::NewPane {
direction: Some(Direction::Right), direction: Some(Direction::Right),
command: None, command: vec![],
cwd: None, cwd: None,
floating: false, floating: false,
name: None,
}; };
send_cli_action_to_server( send_cli_action_to_server(
&session_metadata, &session_metadata,
@ -1889,9 +1891,10 @@ pub fn send_cli_new_pane_action_with_command_and_cwd() {
); );
let cli_new_pane_action = CliAction::NewPane { let cli_new_pane_action = CliAction::NewPane {
direction: Some(Direction::Right), direction: Some(Direction::Right),
command: Some("htop".into()), command: vec!["htop".into()],
cwd: Some("/some/folder".into()), cwd: Some("/some/folder".into()),
floating: false, floating: false,
name: None,
}; };
send_cli_action_to_server( send_cli_action_to_server(
&session_metadata, &session_metadata,

View file

@ -1,6 +1,6 @@
--- ---
source: zellij-server/src/./unit/screen_tests.rs source: zellij-server/src/./unit/screen_tests.rs
assertion_line: 1937 assertion_line: 1944
expression: "format!(\"{:?}\", * received_pty_instructions.lock().unwrap())" expression: "format!(\"{:?}\", * received_pty_instructions.lock().unwrap())"
--- ---
[SpawnTerminal(Some(OpenFile("/file/to/edit", None)), Some(false), ClientId(10)), UpdateActivePane(Some(Terminal(0)), 1), UpdateActivePane(Some(Terminal(0)), 1), Exit] [SpawnTerminal(Some(OpenFile("/file/to/edit", None)), Some(false), Some("Editing: /file/to/edit"), ClientId(10)), UpdateActivePane(Some(Terminal(0)), 1), UpdateActivePane(Some(Terminal(0)), 1), Exit]

View file

@ -1,6 +1,6 @@
--- ---
source: zellij-server/src/./unit/screen_tests.rs source: zellij-server/src/./unit/screen_tests.rs
assertion_line: 1974 assertion_line: 1981
expression: "format!(\"{:?}\", * received_pty_instructions.lock().unwrap())" expression: "format!(\"{:?}\", * received_pty_instructions.lock().unwrap())"
--- ---
[SpawnTerminal(Some(OpenFile("/file/to/edit", Some(100))), Some(false), ClientId(10)), UpdateActivePane(Some(Terminal(0)), 1), UpdateActivePane(Some(Terminal(0)), 1), Exit] [SpawnTerminal(Some(OpenFile("/file/to/edit", Some(100))), Some(false), Some("Editing: /file/to/edit"), ClientId(10)), UpdateActivePane(Some(Terminal(0)), 1), UpdateActivePane(Some(Terminal(0)), 1), Exit]

View file

@ -1,6 +1,6 @@
--- ---
source: zellij-server/src/./unit/screen_tests.rs source: zellij-server/src/./unit/screen_tests.rs
assertion_line: 2011 assertion_line: 2018
expression: "format!(\"{:?}\", * received_pty_instructions.lock().unwrap())" expression: "format!(\"{:?}\", * received_pty_instructions.lock().unwrap())"
--- ---
[SpawnTerminalHorizontally(Some(OpenFile("/file/to/edit", None)), 10), UpdateActivePane(Some(Terminal(0)), 1), UpdateActivePane(Some(Terminal(0)), 1), Exit] [SpawnTerminalHorizontally(Some(OpenFile("/file/to/edit", None)), Some("Editing: /file/to/edit"), 10), UpdateActivePane(Some(Terminal(0)), 1), UpdateActivePane(Some(Terminal(0)), 1), Exit]

View file

@ -1,6 +1,6 @@
--- ---
source: zellij-server/src/./unit/screen_tests.rs source: zellij-server/src/./unit/screen_tests.rs
assertion_line: 1900 assertion_line: 1907
expression: "format!(\"{:?}\", * received_pty_instructions.lock().unwrap())" expression: "format!(\"{:?}\", * received_pty_instructions.lock().unwrap())"
--- ---
[SpawnTerminalVertically(Some(RunCommand(RunCommand { command: "htop", args: [], cwd: Some("/some/folder"), hold_on_close: true })), 10), UpdateActivePane(Some(Terminal(0)), 1), UpdateActivePane(Some(Terminal(0)), 1), Exit] [SpawnTerminalVertically(Some(RunCommand(RunCommand { command: "htop", args: [], cwd: Some("/some/folder"), hold_on_close: true })), None, 10), UpdateActivePane(Some(Terminal(0)), 1), UpdateActivePane(Some(Terminal(0)), 1), Exit]

View file

@ -1,6 +1,6 @@
--- ---
source: zellij-server/src/./unit/screen_tests.rs source: zellij-server/src/./unit/screen_tests.rs
assertion_line: 1826 assertion_line: 1831
expression: "format!(\"{:?}\", * received_pty_instructions.lock().unwrap())" expression: "format!(\"{:?}\", * received_pty_instructions.lock().unwrap())"
--- ---
[SpawnTerminal(None, Some(false), ClientId(10)), UpdateActivePane(Some(Terminal(0)), 1), UpdateActivePane(Some(Terminal(0)), 1), Exit] [SpawnTerminal(None, Some(false), None, ClientId(10)), UpdateActivePane(Some(Terminal(0)), 1), UpdateActivePane(Some(Terminal(0)), 1), Exit]

View file

@ -1,6 +1,6 @@
--- ---
source: zellij-server/src/./unit/screen_tests.rs source: zellij-server/src/./unit/screen_tests.rs
assertion_line: 1863 assertion_line: 1869
expression: "format!(\"{:?}\", * received_pty_instructions.lock().unwrap())" expression: "format!(\"{:?}\", * received_pty_instructions.lock().unwrap())"
--- ---
[SpawnTerminalVertically(None, 10), UpdateActivePane(Some(Terminal(0)), 1), UpdateActivePane(Some(Terminal(0)), 1), Exit] [SpawnTerminalVertically(None, None, 10), UpdateActivePane(Some(Terminal(0)), 1), UpdateActivePane(Some(Terminal(0)), 1), Exit]

View file

@ -395,6 +395,7 @@ fn host_open_file(plugin_env: &PluginEnv) {
.send_to_pty(PtyInstruction::SpawnTerminal( .send_to_pty(PtyInstruction::SpawnTerminal(
Some(TerminalAction::OpenFile(path, None)), Some(TerminalAction::OpenFile(path, None)),
None, None,
None,
ClientOrTabIndex::TabIndex(plugin_env.tab_index), ClientOrTabIndex::TabIndex(plugin_env.tab_index),
)) ))
.unwrap(); .unwrap();

View file

@ -0,0 +1,4 @@
function zp () { zellij run --name "$*" -- bash -c "$*";} # zellij pane
function zpf () { zellij run --name "$*" --floating -- bash -c "$*";} # zellij pane floating
function zo () { zellij edit "$*";} # zellij open
function zof () { zellij edit --floating "$*";} # zellij open floating

View file

@ -6,3 +6,19 @@ complete -c zellij -n "__fish_seen_subcommand_from a" -f -a "(__fish_complete_se
complete -c zellij -n "__fish_seen_subcommand_from kill-session" -f -a "(__fish_complete_sessions)" -d "Session" complete -c zellij -n "__fish_seen_subcommand_from kill-session" -f -a "(__fish_complete_sessions)" -d "Session"
complete -c zellij -n "__fish_seen_subcommand_from k" -f -a "(__fish_complete_sessions)" -d "Session" complete -c zellij -n "__fish_seen_subcommand_from k" -f -a "(__fish_complete_sessions)" -d "Session"
complete -c zellij -n "__fish_seen_subcommand_from setup" -l "generate-completion" -x -a "bash elvish fish zsh powershell" -d "Shell" complete -c zellij -n "__fish_seen_subcommand_from setup" -l "generate-completion" -x -a "bash elvish fish zsh powershell" -d "Shell"
function zp
# zellij pane
command zellij run --name "$argv" -- fish -c "$argv"
end
function zpf
# zellij pane floating
command zellij run --name "$argv" --floating -- fish -c "$argv"
end
function zo
# zellij open
command zellij edit $argv
end
function zof
# zellij open floating
command zellij edit --floating $argv
end

View file

@ -0,0 +1,4 @@
function zp () { zellij run --name "$*" -- zsh -c "$*";} # zellij pane
function zpf () { zellij run --name "$*" --floating -- zsh -c "$*";} # zellij pane floating
function zo () { zellij edit "$*";} # zellij open
function zof () { zellij edit --floating "$*";} # zellij open floating

View file

@ -127,13 +127,16 @@ pub enum Sessions {
/// Run a command in a new pane /// Run a command in a new pane
#[clap(visible_alias = "r")] #[clap(visible_alias = "r")]
Run { Run {
command: Option<String>, #[clap(last(true), required(true))]
command: Vec<String>,
#[clap(short, long, value_parser, conflicts_with("floating"))] #[clap(short, long, value_parser, conflicts_with("floating"))]
direction: Option<Direction>, direction: Option<Direction>,
#[clap(long, value_parser)] #[clap(long, value_parser)]
cwd: Option<PathBuf>, cwd: Option<PathBuf>,
#[clap(short, long, value_parser, default_value("false"), takes_value(false))] #[clap(short, long, value_parser, default_value("false"), takes_value(false))]
floating: bool, floating: bool,
#[clap(short, long, value_parser)]
name: Option<String>,
}, },
/// Edit file with default $EDITOR / $VISUAL /// Edit file with default $EDITOR / $VISUAL
#[clap(visible_alias = "e")] #[clap(visible_alias = "e")]
@ -206,12 +209,14 @@ pub enum CliAction {
NewPane { NewPane {
#[clap(short, long, value_parser, conflicts_with("floating"))] #[clap(short, long, value_parser, conflicts_with("floating"))]
direction: Option<Direction>, direction: Option<Direction>,
#[clap(short, long, value_parser)] #[clap(last(true))]
command: Option<String>, command: Vec<String>,
#[clap(long, value_parser)] #[clap(long, value_parser)]
cwd: Option<PathBuf>, cwd: Option<PathBuf>,
#[clap(short, long, value_parser, default_value("false"), takes_value(false))] #[clap(short, long, value_parser, default_value("false"), takes_value(false))]
floating: bool, floating: bool,
#[clap(short, long, value_parser)]
name: Option<String>,
}, },
/// Open the specified file in a new zellij pane with your default EDITOR /// Open the specified file in a new zellij pane with your default EDITOR
Edit { Edit {

View file

@ -109,37 +109,6 @@ impl FromStr for SearchOption {
} }
} }
fn split_escaped_whitespace(s: &str) -> Vec<String> {
s.split_ascii_whitespace()
.map(|s| String::from(s))
.fold(vec![], |mut acc, part| {
if let Some(previous_part) = acc.last_mut() {
if previous_part.ends_with('\\') {
previous_part.push(' ');
previous_part.push_str(&part);
return acc;
}
}
acc.push(part);
acc
})
}
fn split_command_and_args(command: String) -> (PathBuf, Vec<String>) {
let mut full_command = split_escaped_whitespace(&command);
let mut command = None;
let mut command_args = vec![];
for part in full_command.drain(..) {
if command.is_none() {
command = Some(part);
} else {
command_args.push(part);
}
}
let command = PathBuf::from(command.unwrap());
(command, command_args)
}
// As these actions are bound to the default config, please // As these actions are bound to the default config, please
// do take care when refactoring - or renaming. // do take care when refactoring - or renaming.
// They might need to be adjusted in the default config // They might need to be adjusted in the default config
@ -198,13 +167,15 @@ pub enum Action {
ToggleActiveSyncTab, ToggleActiveSyncTab,
/// Open a new pane in the specified direction (relative to focus). /// Open a new pane in the specified direction (relative to focus).
/// If no direction is specified, will try to use the biggest available space. /// If no direction is specified, will try to use the biggest available space.
NewPane(Option<Direction>), NewPane(Option<Direction>, Option<String>), // String is an optional pane name
/// Open the file in a new pane using the default editor /// Open the file in a new pane using the default editor
EditFile(PathBuf, Option<usize>, Option<Direction>, bool), // usize is an optional line number, bool is floating true/false EditFile(PathBuf, Option<usize>, Option<Direction>, bool), // usize is an optional line number, bool is floating true/false
/// Open a new floating pane /// Open a new floating pane
NewFloatingPane(Option<RunCommandAction>), NewFloatingPane(Option<RunCommandAction>, Option<String>), // String is an optional pane name
/// Open a new tiled (embedded, non-floating) pane /// Open a new tiled (embedded, non-floating) pane
NewTiledPane(Option<Direction>, Option<RunCommandAction>), NewTiledPane(Option<Direction>, Option<RunCommandAction>, Option<String>), // String is an
// optional pane
// name
/// Embed focused pane in tab if floating or float focused pane if embedded /// Embed focused pane in tab if floating or float focused pane if embedded
TogglePaneEmbedOrFloating, TogglePaneEmbedOrFloating,
/// Toggle the visibility of all floating panes (if any) in the current Tab /// Toggle the visibility of all floating panes (if any) in the current Tab
@ -285,9 +256,11 @@ impl Action {
command, command,
cwd, cwd,
floating, floating,
} => match command { name,
Some(command) => { } => {
let (command, args) = split_command_and_args(command); if !command.is_empty() {
let mut command = command.clone();
let (command, args) = (PathBuf::from(command.remove(0)), command);
let cwd = cwd.or_else(|| std::env::current_dir().ok()); let cwd = cwd.or_else(|| std::env::current_dir().ok());
let run_command_action = RunCommandAction { let run_command_action = RunCommandAction {
command, command,
@ -297,21 +270,24 @@ impl Action {
hold_on_close: true, hold_on_close: true,
}; };
if floating { if floating {
Ok(vec![Action::NewFloatingPane(Some(run_command_action))]) Ok(vec![Action::NewFloatingPane(
Some(run_command_action),
name,
)])
} else { } else {
Ok(vec![Action::NewTiledPane( Ok(vec![Action::NewTiledPane(
direction, direction,
Some(run_command_action), Some(run_command_action),
name,
)]) )])
} }
}, } else {
None => {
if floating { if floating {
Ok(vec![Action::NewFloatingPane(None)]) Ok(vec![Action::NewFloatingPane(None, name)])
} else { } else {
Ok(vec![Action::NewTiledPane(direction, None)]) Ok(vec![Action::NewTiledPane(direction, None, name)])
} }
}, }
}, },
CliAction::Edit { CliAction::Edit {
direction, direction,

View file

@ -430,7 +430,7 @@ impl Action {
"DumpScreen" => Ok(Action::DumpScreen(string)), "DumpScreen" => Ok(Action::DumpScreen(string)),
"NewPane" => { "NewPane" => {
if string.is_empty() { if string.is_empty() {
return Ok(Action::NewPane(None)); return Ok(Action::NewPane(None, None));
} else { } else {
let direction = Direction::from_str(string.as_str()).map_err(|_| { let direction = Direction::from_str(string.as_str()).map_err(|_| {
ConfigError::new_kdl_error( ConfigError::new_kdl_error(
@ -439,7 +439,7 @@ impl Action {
action_node.span().len(), action_node.span().len(),
) )
})?; })?;
Ok(Action::NewPane(Some(direction))) Ok(Action::NewPane(Some(direction), None))
} }
}, },
"SearchToggleOption" => { "SearchToggleOption" => {

View file

@ -125,6 +125,18 @@ pub const FISH_EXTRA_COMPLETION: &[u8] = include_bytes!(concat!(
"assets/completions/comp.fish" "assets/completions/comp.fish"
)); ));
pub const BASH_EXTRA_COMPLETION: &[u8] = include_bytes!(concat!(
env!("CARGO_MANIFEST_DIR"),
"/",
"assets/completions/comp.bash"
));
pub const ZSH_EXTRA_COMPLETION: &[u8] = include_bytes!(concat!(
env!("CARGO_MANIFEST_DIR"),
"/",
"assets/completions/comp.zsh"
));
pub const BASH_AUTO_START_SCRIPT: &[u8] = include_bytes!(concat!( pub const BASH_AUTO_START_SCRIPT: &[u8] = include_bytes!(concat!(
env!("CARGO_MANIFEST_DIR"), env!("CARGO_MANIFEST_DIR"),
"/", "/",
@ -412,13 +424,17 @@ impl Setup {
clap_complete::generate(shell, &mut CliArgs::command(), "zellij", &mut out); clap_complete::generate(shell, &mut CliArgs::command(), "zellij", &mut out);
// add shell dependent extra completion // add shell dependent extra completion
match shell { match shell {
Shell::Bash => {}, Shell::Bash => {
let _ = out.write_all(BASH_EXTRA_COMPLETION);
},
Shell::Elvish => {}, Shell::Elvish => {},
Shell::Fish => { Shell::Fish => {
let _ = out.write_all(FISH_EXTRA_COMPLETION); let _ = out.write_all(FISH_EXTRA_COMPLETION);
}, },
Shell::PowerShell => {}, Shell::PowerShell => {},
Shell::Zsh => {}, Shell::Zsh => {
let _ = out.write_all(ZSH_EXTRA_COMPLETION);
},
_ => {}, _ => {},
}; };
} }

View file

@ -1,6 +1,6 @@
--- ---
source: zellij-utils/src/setup.rs source: zellij-utils/src/setup.rs
assertion_line: 491 assertion_line: 503
expression: "format!(\"{:#?}\", config)" expression: "format!(\"{:#?}\", config)"
--- ---
Config { Config {
@ -76,6 +76,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -339,6 +340,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -498,6 +500,7 @@ Config {
Some( Some(
Down, Down,
), ),
None,
), ),
SwitchToMode( SwitchToMode(
Normal, Normal,
@ -552,6 +555,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
SwitchToMode( SwitchToMode(
Normal, Normal,
@ -569,6 +573,7 @@ Config {
Some( Some(
Right, Right,
), ),
None,
), ),
SwitchToMode( SwitchToMode(
Normal, Normal,
@ -668,6 +673,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -1019,6 +1025,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -1280,6 +1287,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -1481,6 +1489,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -1761,6 +1770,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -1962,6 +1972,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -2160,6 +2171,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -2363,6 +2375,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -2624,6 +2637,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -2819,6 +2833,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -2978,6 +2993,7 @@ Config {
Some( Some(
Down, Down,
), ),
None,
), ),
SwitchToMode( SwitchToMode(
Normal, Normal,
@ -2990,6 +3006,7 @@ Config {
Some( Some(
Right, Right,
), ),
None,
), ),
SwitchToMode( SwitchToMode(
Normal, Normal,
@ -3164,6 +3181,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(

View file

@ -1,6 +1,6 @@
--- ---
source: zellij-utils/src/setup.rs source: zellij-utils/src/setup.rs
assertion_line: 541 assertion_line: 561
expression: "format!(\"{:#?}\", config)" expression: "format!(\"{:#?}\", config)"
--- ---
Config { Config {
@ -76,6 +76,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -339,6 +340,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -498,6 +500,7 @@ Config {
Some( Some(
Down, Down,
), ),
None,
), ),
SwitchToMode( SwitchToMode(
Normal, Normal,
@ -552,6 +555,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
SwitchToMode( SwitchToMode(
Normal, Normal,
@ -569,6 +573,7 @@ Config {
Some( Some(
Right, Right,
), ),
None,
), ),
SwitchToMode( SwitchToMode(
Normal, Normal,
@ -668,6 +673,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -1019,6 +1025,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -1280,6 +1287,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -1481,6 +1489,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -1761,6 +1770,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -1962,6 +1972,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -2160,6 +2171,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -2363,6 +2375,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -2624,6 +2637,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -2819,6 +2833,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -2978,6 +2993,7 @@ Config {
Some( Some(
Down, Down,
), ),
None,
), ),
SwitchToMode( SwitchToMode(
Normal, Normal,
@ -2990,6 +3006,7 @@ Config {
Some( Some(
Right, Right,
), ),
None,
), ),
SwitchToMode( SwitchToMode(
Normal, Normal,
@ -3164,6 +3181,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(

View file

@ -1,6 +1,6 @@
--- ---
source: zellij-utils/src/setup.rs source: zellij-utils/src/setup.rs
assertion_line: 557 assertion_line: 589
expression: "format!(\"{:#?}\", config)" expression: "format!(\"{:#?}\", config)"
--- ---
Config { Config {
@ -76,6 +76,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -339,6 +340,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -498,6 +500,7 @@ Config {
Some( Some(
Down, Down,
), ),
None,
), ),
SwitchToMode( SwitchToMode(
Normal, Normal,
@ -552,6 +555,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
SwitchToMode( SwitchToMode(
Normal, Normal,
@ -569,6 +573,7 @@ Config {
Some( Some(
Right, Right,
), ),
None,
), ),
SwitchToMode( SwitchToMode(
Normal, Normal,
@ -668,6 +673,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -1019,6 +1025,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -1280,6 +1287,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -1481,6 +1489,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -1761,6 +1770,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -1962,6 +1972,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -2160,6 +2171,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -2363,6 +2375,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -2624,6 +2637,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -2819,6 +2833,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -2978,6 +2993,7 @@ Config {
Some( Some(
Down, Down,
), ),
None,
), ),
SwitchToMode( SwitchToMode(
Normal, Normal,
@ -2990,6 +3006,7 @@ Config {
Some( Some(
Right, Right,
), ),
None,
), ),
SwitchToMode( SwitchToMode(
Normal, Normal,
@ -3164,6 +3181,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(

View file

@ -1,6 +1,6 @@
--- ---
source: zellij-utils/src/setup.rs source: zellij-utils/src/setup.rs
assertion_line: 565 assertion_line: 603
expression: "format!(\"{:#?}\", config)" expression: "format!(\"{:#?}\", config)"
--- ---
Config { Config {
@ -76,6 +76,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -339,6 +340,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -498,6 +500,7 @@ Config {
Some( Some(
Down, Down,
), ),
None,
), ),
SwitchToMode( SwitchToMode(
Normal, Normal,
@ -552,6 +555,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
SwitchToMode( SwitchToMode(
Normal, Normal,
@ -569,6 +573,7 @@ Config {
Some( Some(
Right, Right,
), ),
None,
), ),
SwitchToMode( SwitchToMode(
Normal, Normal,
@ -668,6 +673,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -1019,6 +1025,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -1280,6 +1287,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -1481,6 +1489,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -1761,6 +1770,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -1962,6 +1972,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -2160,6 +2171,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -2363,6 +2375,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -2624,6 +2637,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -2819,6 +2833,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -2978,6 +2993,7 @@ Config {
Some( Some(
Down, Down,
), ),
None,
), ),
SwitchToMode( SwitchToMode(
Normal, Normal,
@ -2990,6 +3006,7 @@ Config {
Some( Some(
Right, Right,
), ),
None,
), ),
SwitchToMode( SwitchToMode(
Normal, Normal,
@ -3164,6 +3181,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(

View file

@ -1,6 +1,6 @@
--- ---
source: zellij-utils/src/setup.rs source: zellij-utils/src/setup.rs
assertion_line: 549 assertion_line: 575
expression: "format!(\"{:#?}\", config)" expression: "format!(\"{:#?}\", config)"
--- ---
Config { Config {
@ -76,6 +76,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -339,6 +340,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -498,6 +500,7 @@ Config {
Some( Some(
Down, Down,
), ),
None,
), ),
SwitchToMode( SwitchToMode(
Normal, Normal,
@ -552,6 +555,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
SwitchToMode( SwitchToMode(
Normal, Normal,
@ -569,6 +573,7 @@ Config {
Some( Some(
Right, Right,
), ),
None,
), ),
SwitchToMode( SwitchToMode(
Normal, Normal,
@ -668,6 +673,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -1019,6 +1025,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -1280,6 +1287,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -1481,6 +1489,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -1761,6 +1770,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -1962,6 +1972,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -2160,6 +2171,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -2363,6 +2375,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -2624,6 +2637,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -2819,6 +2833,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(
@ -2978,6 +2993,7 @@ Config {
Some( Some(
Down, Down,
), ),
None,
), ),
SwitchToMode( SwitchToMode(
Normal, Normal,
@ -2990,6 +3006,7 @@ Config {
Some( Some(
Right, Right,
), ),
None,
), ),
SwitchToMode( SwitchToMode(
Normal, Normal,
@ -3164,6 +3181,7 @@ Config {
): [ ): [
NewPane( NewPane(
None, None,
None,
), ),
], ],
Alt( Alt(