zellij/src/main.rs
toymil 9deb033340
feat: list-sessions show newest sessions last, for better user experience (#3194)
* feat: sort `list-sessions` from oldest to newest

by putting the most recent sessions last, the user won't need to scroll back up
to see active sessions when there are a lot of resurrectable sessions.

* feat: add an `--reverse` option to the `list-sessions` subcommand

the `--reverse` flag reverts sorting order back to the old "newest sessions
first".  also updated call sites of `list_sessions` and `print_sessions` with
`reverse: true`, to keep the original behavior everywhere else except the output
of `list-sessions` subcommand.

* chore: update the help message

---------

Co-authored-by: Jae-Heon Ji <atx6419@gmail.com>
2024-03-24 23:30:47 +09:00

196 lines
5.9 KiB
Rust

mod commands;
mod sessions;
#[cfg(test)]
mod tests;
use zellij_utils::{
clap::Parser,
cli::{CliAction, CliArgs, Command, Sessions},
input::config::Config,
logging::*,
};
fn main() {
configure_logger();
let opts = CliArgs::parse();
{
let config = Config::try_from(&opts).ok();
if let Some(Command::Sessions(Sessions::Action(cli_action))) = opts.command {
commands::send_action_to_session(cli_action, opts.session, config);
std::process::exit(0);
}
if let Some(Command::Sessions(Sessions::Run {
command,
direction,
cwd,
floating,
in_place,
name,
close_on_exit,
start_suspended,
x,
y,
width,
height,
})) = opts.command
{
let cwd = cwd.or_else(|| std::env::current_dir().ok());
let skip_plugin_cache = false; // N/A for this action
let command_cli_action = CliAction::NewPane {
command,
plugin: None,
direction,
cwd,
floating,
in_place,
name,
close_on_exit,
start_suspended,
configuration: None,
skip_plugin_cache,
x,
y,
width,
height,
};
commands::send_action_to_session(command_cli_action, opts.session, config);
std::process::exit(0);
}
if let Some(Command::Sessions(Sessions::Plugin {
url,
floating,
in_place,
configuration,
skip_plugin_cache,
x,
y,
width,
height,
})) = opts.command
{
let cwd = None;
let command_cli_action = CliAction::NewPane {
command: vec![],
plugin: Some(url),
direction: None,
cwd,
floating,
in_place,
name: None,
close_on_exit: false,
start_suspended: false,
configuration,
skip_plugin_cache,
x,
y,
width,
height,
};
commands::send_action_to_session(command_cli_action, opts.session, config);
std::process::exit(0);
}
if let Some(Command::Sessions(Sessions::Edit {
file,
direction,
line_number,
floating,
in_place,
cwd,
x,
y,
width,
height,
})) = opts.command
{
let mut file = file;
let cwd = cwd.or_else(|| std::env::current_dir().ok());
if file.is_relative() {
if let Some(cwd) = cwd.as_ref() {
file = cwd.join(file);
}
}
let command_cli_action = CliAction::Edit {
file,
direction,
line_number,
floating,
in_place,
cwd,
x,
y,
width,
height,
};
commands::send_action_to_session(command_cli_action, opts.session, config);
std::process::exit(0);
}
if let Some(Command::Sessions(Sessions::ConvertConfig { old_config_file })) = opts.command {
commands::convert_old_config_file(old_config_file);
std::process::exit(0);
}
if let Some(Command::Sessions(Sessions::ConvertLayout { old_layout_file })) = opts.command {
commands::convert_old_layout_file(old_layout_file);
std::process::exit(0);
}
if let Some(Command::Sessions(Sessions::ConvertTheme { old_theme_file })) = opts.command {
commands::convert_old_theme_file(old_theme_file);
std::process::exit(0);
}
if let Some(Command::Sessions(Sessions::Pipe {
name,
payload,
args,
plugin,
plugin_configuration,
})) = opts.command
{
let command_cli_action = CliAction::Pipe {
name,
payload,
args,
plugin,
plugin_configuration,
force_launch_plugin: false,
skip_plugin_cache: false,
floating_plugin: None,
in_place_plugin: None,
plugin_cwd: None,
plugin_title: None,
};
commands::send_action_to_session(command_cli_action, opts.session, config);
std::process::exit(0);
}
}
if let Some(Command::Sessions(Sessions::ListSessions {
no_formatting,
short,
reverse,
})) = opts.command
{
commands::list_sessions(no_formatting, short, reverse);
} else if let Some(Command::Sessions(Sessions::ListAliases)) = opts.command {
commands::list_aliases(opts);
} else if let Some(Command::Sessions(Sessions::KillAllSessions { yes })) = opts.command {
commands::kill_all_sessions(yes);
} else if let Some(Command::Sessions(Sessions::KillSession { ref target_session })) =
opts.command
{
commands::kill_session(target_session);
} else if let Some(Command::Sessions(Sessions::DeleteAllSessions { yes, force })) = opts.command
{
commands::delete_all_sessions(yes, force);
} else if let Some(Command::Sessions(Sessions::DeleteSession {
ref target_session,
force,
})) = opts.command
{
commands::delete_session(target_session, force);
} else if let Some(path) = opts.server {
commands::start_server(path, opts.debug);
} else {
commands::start_client(opts);
}
}