1
1
mirror of https://github.com/wez/wezterm.git synced 2025-01-03 11:11:43 +03:00

deps: structopt -> clap 3

This commit is contained in:
Wez Furlong 2022-05-28 07:07:52 -07:00
parent 75420c1b8f
commit f857ec6a5a
14 changed files with 208 additions and 231 deletions
Cargo.lock
strip-ansi-escapes
wezterm-gui-subcommands
wezterm-gui
wezterm-mux-server
wezterm-ssh
wezterm

137
Cargo.lock generated
View File

@ -43,15 +43,6 @@ dependencies = [
"memchr", "memchr",
] ]
[[package]]
name = "ansi_term"
version = "0.12.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "d52a9bb7ec0cf484c551830a7ce27bd20d67eac647e1befb56b0be4ee39a55d2"
dependencies = [
"winapi 0.3.9",
]
[[package]] [[package]]
name = "anyhow" name = "anyhow"
version = "1.0.57" version = "1.0.57"
@ -534,17 +525,41 @@ dependencies = [
[[package]] [[package]]
name = "clap" name = "clap"
version = "2.34.0" version = "3.1.18"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "a0610544180c38b88101fecf2dd634b174a62eef6946f84dfc6a7127512b381c" checksum = "d2dbdf4bdacb33466e854ce889eee8dfd5729abf7ccd7664d0a2d60cd384440b"
dependencies = [ dependencies = [
"ansi_term",
"atty", "atty",
"bitflags", "bitflags",
"strsim 0.8.0", "clap_derive",
"textwrap 0.11.0", "clap_lex",
"unicode-width", "indexmap",
"vec_map", "lazy_static",
"strsim",
"termcolor",
"textwrap",
]
[[package]]
name = "clap_derive"
version = "3.1.18"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "25320346e922cffe59c0bbc5410c8d8784509efb321488971081313cb1e1a33c"
dependencies = [
"heck",
"proc-macro-error",
"proc-macro2",
"quote",
"syn",
]
[[package]]
name = "clap_lex"
version = "0.2.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "a37c35f1112dad5e6e0b1adaff798507497a18fceeb30cceb3bae7d1427b9213"
dependencies = [
"os_str_bytes",
] ]
[[package]] [[package]]
@ -1645,12 +1660,9 @@ dependencies = [
[[package]] [[package]]
name = "heck" name = "heck"
version = "0.3.3" version = "0.4.0"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "6d621efb26863f0e9924c6ac577e8275e5e6b77455db64ffa6c65c904e9e132c" checksum = "2540771e65fc8cb83cd6e8a237f70c319bd5c29f78ed1084ba5d50eeac86f7f9"
dependencies = [
"unicode-segmentation",
]
[[package]] [[package]]
name = "hermit-abi" name = "hermit-abi"
@ -1743,6 +1755,16 @@ dependencies = [
"tiff", "tiff",
] ]
[[package]]
name = "indexmap"
version = "1.8.2"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "e6012d540c5baa3589337a98ce73408de9b5a25ec9fc2c6fd6be8f0d39e0ca5a"
dependencies = [
"autocfg",
"hashbrown 0.11.2",
]
[[package]] [[package]]
name = "inflate" name = "inflate"
version = "0.4.5" version = "0.4.5"
@ -2324,7 +2346,7 @@ dependencies = [
"terminfo", "terminfo",
"termwiz", "termwiz",
"termwiz-funcs", "termwiz-funcs",
"textwrap 0.15.0", "textwrap",
"thiserror", "thiserror",
"unicode-segmentation", "unicode-segmentation",
"url", "url",
@ -2724,6 +2746,12 @@ dependencies = [
"pin-project-lite", "pin-project-lite",
] ]
[[package]]
name = "os_str_bytes"
version = "6.1.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "21326818e99cfe6ce1e524c2a805c189a99b5ae555a35d19f9a284b427d86afa"
[[package]] [[package]]
name = "parking" name = "parking"
version = "2.0.0" version = "2.0.0"
@ -3925,46 +3953,16 @@ checksum = "a2eb9349b6444b326872e140eb1cf5e7c522154d69e7a0ffb0fb81c06b37543f"
name = "strip-ansi-escapes" name = "strip-ansi-escapes"
version = "0.1.0" version = "0.1.0"
dependencies = [ dependencies = [
"structopt", "clap",
"termwiz", "termwiz",
] ]
[[package]]
name = "strsim"
version = "0.8.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "8ea5119cdb4c55b55d432abb513a0429384878c15dde60cc77b1c99de1a95a6a"
[[package]] [[package]]
name = "strsim" name = "strsim"
version = "0.10.0" version = "0.10.0"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "73473c0e59e6d5812c5dfe2a064a6444949f089e20eec9a2e5506596494e4623" checksum = "73473c0e59e6d5812c5dfe2a064a6444949f089e20eec9a2e5506596494e4623"
[[package]]
name = "structopt"
version = "0.3.26"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "0c6b5c64445ba8094a6ab0c3cd2ad323e07171012d9c98b0b15651daf1787a10"
dependencies = [
"clap",
"lazy_static",
"structopt-derive",
]
[[package]]
name = "structopt-derive"
version = "0.4.18"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "dcb5ae327f9cc13b68763b5749770cb9e048a99bd9dfdfa58d0cf05d5f64afe0"
dependencies = [
"heck",
"proc-macro-error",
"proc-macro2",
"quote",
"syn",
]
[[package]] [[package]]
name = "svg_fmt" name = "svg_fmt"
version = "0.4.1" version = "0.4.1"
@ -4123,15 +4121,6 @@ dependencies = [
"wezterm-dynamic", "wezterm-dynamic",
] ]
[[package]]
name = "textwrap"
version = "0.11.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "d326610f408c7a4eb6f51c37c330e496b08506c9457c9d34287ecc38809fb060"
dependencies = [
"unicode-width",
]
[[package]] [[package]]
name = "textwrap" name = "textwrap"
version = "0.15.0" version = "0.15.0"
@ -4392,12 +4381,6 @@ version = "0.2.15"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "accd4ea62f7bb7a82fe23066fb0957d48ef677f6eeb8215f372f52e48bb32426" checksum = "accd4ea62f7bb7a82fe23066fb0957d48ef677f6eeb8215f372f52e48bb32426"
[[package]]
name = "vec_map"
version = "0.8.2"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "f1bddf1187be692e79c5ffeab891132dfb0f236ed36a43c7ed39f1165ee20191"
[[package]] [[package]]
name = "version_check" name = "version_check"
version = "0.9.4" version = "0.9.4"
@ -4646,6 +4629,7 @@ version = "0.1.0"
dependencies = [ dependencies = [
"anyhow", "anyhow",
"chrono", "chrono",
"clap",
"codec", "codec",
"config", "config",
"env-bootstrap", "env-bootstrap",
@ -4660,12 +4644,11 @@ dependencies = [
"serde_json", "serde_json",
"shell-words", "shell-words",
"smol", "smol",
"structopt",
"tabout", "tabout",
"tempfile", "tempfile",
"termios 0.3.3", "termios 0.3.3",
"termwiz", "termwiz",
"textwrap 0.15.0", "textwrap",
"umask", "umask",
"url", "url",
"wezterm-client", "wezterm-client",
@ -4708,7 +4691,7 @@ dependencies = [
"ratelim", "ratelim",
"smol", "smol",
"termwiz", "termwiz",
"textwrap 0.15.0", "textwrap",
"thiserror", "thiserror",
"uds_windows", "uds_windows",
"umask", "umask",
@ -4734,7 +4717,7 @@ dependencies = [
"log", "log",
"maplit", "maplit",
"ordered-float", "ordered-float",
"strsim 0.10.0", "strsim",
"thiserror", "thiserror",
"wezterm-dynamic-derive", "wezterm-dynamic-derive",
] ]
@ -4792,6 +4775,7 @@ dependencies = [
"bitflags", "bitflags",
"cc", "cc",
"chrono", "chrono",
"clap",
"codec", "codec",
"colorgrad", "colorgrad",
"config", "config",
@ -4829,12 +4813,11 @@ dependencies = [
"serial", "serial",
"shared_library", "shared_library",
"smol", "smol",
"structopt",
"tabout", "tabout",
"terminfo", "terminfo",
"termwiz", "termwiz",
"termwiz-funcs", "termwiz-funcs",
"textwrap 0.15.0", "textwrap",
"thiserror", "thiserror",
"tiny-skia", "tiny-skia",
"uds_windows", "uds_windows",
@ -4863,8 +4846,8 @@ name = "wezterm-gui-subcommands"
version = "0.1.0" version = "0.1.0"
dependencies = [ dependencies = [
"anyhow", "anyhow",
"clap",
"config", "config",
"structopt",
] ]
[[package]] [[package]]
@ -4884,6 +4867,7 @@ version = "0.1.0"
dependencies = [ dependencies = [
"anyhow", "anyhow",
"async_ossl", "async_ossl",
"clap",
"config", "config",
"env-bootstrap", "env-bootstrap",
"libc", "libc",
@ -4892,7 +4876,6 @@ dependencies = [
"openssl", "openssl",
"portable-pty", "portable-pty",
"promise", "promise",
"structopt",
"umask", "umask",
"wezterm-gui-subcommands", "wezterm-gui-subcommands",
"wezterm-mux-server-impl", "wezterm-mux-server-impl",
@ -4934,6 +4917,7 @@ dependencies = [
"base64", "base64",
"bitflags", "bitflags",
"camino", "camino",
"clap",
"dirs-next", "dirs-next",
"env_logger", "env_logger",
"filedescriptor", "filedescriptor",
@ -4952,7 +4936,6 @@ dependencies = [
"smol-potat", "smol-potat",
"socket2", "socket2",
"ssh2", "ssh2",
"structopt",
"termwiz", "termwiz",
"thiserror", "thiserror",
"whoami", "whoami",

View File

@ -7,5 +7,5 @@ edition = "2018"
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html # See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
[dependencies] [dependencies]
structopt = "0.3" clap = {version="3.1", features=["derive"]}
termwiz = { path = "../termwiz" } termwiz = { path = "../termwiz" }

View File

@ -1,12 +1,9 @@
use clap::Parser;
use std::io::{Read, Result}; use std::io::{Read, Result};
use structopt::StructOpt; use termwiz::escape::parser::Parser as TWParser;
use termwiz::escape::parser::Parser;
use termwiz::escape::{Action, ControlCode}; use termwiz::escape::{Action, ControlCode};
#[derive(Debug, StructOpt)] #[derive(Debug, Parser)]
#[structopt(
global_setting = structopt::clap::AppSettings::ColoredHelp,
)]
/// This is a little utility that strips escape sequences from /// This is a little utility that strips escape sequences from
/// stdin and prints the result on stdout. /// stdin and prints the result on stdout.
/// It preserves only printable characters and CR, LF and HT. /// It preserves only printable characters and CR, LF and HT.
@ -17,10 +14,10 @@ use termwiz::escape::{Action, ControlCode};
struct Opt {} struct Opt {}
fn main() -> Result<()> { fn main() -> Result<()> {
let _ = Opt::from_args(); let _ = Opt::parse();
let mut buf = [0u8; 4096]; let mut buf = [0u8; 4096];
let mut parser = Parser::new(); let mut parser = TWParser::new();
loop { loop {
let len = std::io::stdin().read(&mut buf)?; let len = std::io::stdin().read(&mut buf)?;

View File

@ -7,6 +7,6 @@ edition = "2018"
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html # See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
[dependencies] [dependencies]
structopt = "0.3" clap = {version="3.1", features=["derive"]}
config = { path = "../config" } config = { path = "../config" }
anyhow = "1.0" anyhow = "1.0"

View File

@ -1,7 +1,7 @@
use clap::Parser;
use config::{Dimension, GeometryOrigin, SshParameters}; use config::{Dimension, GeometryOrigin, SshParameters};
use std::ffi::OsString; use std::ffi::OsString;
use std::str::FromStr; use std::str::FromStr;
use structopt::StructOpt;
pub const DEFAULT_WINDOW_CLASS: &str = "org.wezfurlong.wezterm"; pub const DEFAULT_WINDOW_CLASS: &str = "org.wezfurlong.wezterm";
@ -142,23 +142,23 @@ mod test {
} }
} }
#[derive(Debug, StructOpt, Default, Clone)] #[derive(Debug, Parser, Default, Clone)]
pub struct StartCommand { pub struct StartCommand {
/// If true, do not connect to domains marked as connect_automatically /// If true, do not connect to domains marked as connect_automatically
/// in your wezterm configuration file. /// in your wezterm configuration file.
#[structopt(long = "no-auto-connect")] #[clap(long = "no-auto-connect")]
pub no_auto_connect: bool, pub no_auto_connect: bool,
/// If enabled, don't try to ask an existing wezterm GUI instance /// If enabled, don't try to ask an existing wezterm GUI instance
/// to start the command. Instead, always start the GUI in this /// to start the command. Instead, always start the GUI in this
/// invocation of wezterm so that you can wait for the command /// invocation of wezterm so that you can wait for the command
/// to complete by waiting for this wezterm process to finish. /// to complete by waiting for this wezterm process to finish.
#[structopt(long = "always-new-process")] #[clap(long = "always-new-process")]
pub always_new_process: bool, pub always_new_process: bool,
/// Specify the current working directory for the initially /// Specify the current working directory for the initially
/// spawned program /// spawned program
#[structopt(long = "cwd", parse(from_os_str))] #[clap(long = "cwd", parse(from_os_str))]
pub cwd: Option<OsString>, pub cwd: Option<OsString>,
/// Override the default windowing system class. /// Override the default windowing system class.
@ -168,12 +168,12 @@ pub struct StartCommand {
/// This changes the class for all windows spawned by this /// This changes the class for all windows spawned by this
/// instance of wezterm, including error, update and ssh /// instance of wezterm, including error, update and ssh
/// authentication dialogs. /// authentication dialogs.
#[structopt(long = "class")] #[clap(long = "class")]
pub class: Option<String>, pub class: Option<String>,
/// Override the default workspace with the provided name. /// Override the default workspace with the provided name.
/// The default is "default". /// The default is "default".
#[structopt(long = "workspace")] #[clap(long = "workspace")]
pub workspace: Option<String>, pub workspace: Option<String>,
/// Override the position for the initial window launched by this process. /// Override the position for the initial window launched by this process.
@ -183,17 +183,17 @@ pub struct StartCommand {
/// --position main:10,20 to set x=10, y=20 relative to the main monitor /// --position main:10,20 to set x=10, y=20 relative to the main monitor
/// --position active:10,20 to set x=10, y=20 relative to the active monitor /// --position active:10,20 to set x=10, y=20 relative to the active monitor
/// --position HDMI-1:10,20 to set x=10, y=20 relative to the monitor named HDMI-1 /// --position HDMI-1:10,20 to set x=10, y=20 relative to the monitor named HDMI-1
#[structopt(long, verbatim_doc_comment)] #[clap(long, verbatim_doc_comment)]
pub position: Option<GuiPosition>, pub position: Option<GuiPosition>,
/// Instead of executing your shell, run PROG. /// Instead of executing your shell, run PROG.
/// For example: `wezterm start -- bash -l` will spawn bash /// For example: `wezterm start -- bash -l` will spawn bash
/// as if it were a login shell. /// as if it were a login shell.
#[structopt(parse(from_os_str))] #[clap(parse(from_os_str))]
pub prog: Vec<OsString>, pub prog: Vec<OsString>,
} }
#[derive(Debug, StructOpt, Clone)] #[derive(Debug, Parser, Clone)]
pub struct SshCommand { pub struct SshCommand {
/// Specifies the remote system using the form: /// Specifies the remote system using the form:
/// `[username@]host[:port]`. /// `[username@]host[:port]`.
@ -212,9 +212,9 @@ pub struct SshCommand {
/// For example: /// For example:
/// ///
/// `wezterm ssh -oIdentityFile=/secret/id_ed25519 some-host` /// `wezterm ssh -oIdentityFile=/secret/id_ed25519 some-host`
#[structopt( #[clap(
long = "ssh-option", long = "ssh-option",
short = "o", short = 'o',
name = "name=value", name = "name=value",
parse(try_from_str = name_equals_value), parse(try_from_str = name_equals_value),
number_of_values = 1)] number_of_values = 1)]
@ -223,7 +223,7 @@ pub struct SshCommand {
/// Enable verbose ssh protocol tracing. /// Enable verbose ssh protocol tracing.
/// The trace information is printed to the stderr stream of /// The trace information is printed to the stderr stream of
/// the process. /// the process.
#[structopt(short = "v")] #[clap(short = 'v')]
pub verbose: bool, pub verbose: bool,
/// Override the default windowing system class. /// Override the default windowing system class.
@ -233,7 +233,7 @@ pub struct SshCommand {
/// This changes the class for all windows spawned by this /// This changes the class for all windows spawned by this
/// instance of wezterm, including error, update and ssh /// instance of wezterm, including error, update and ssh
/// authentication dialogs. /// authentication dialogs.
#[structopt(long = "class")] #[clap(long = "class")]
pub class: Option<String>, pub class: Option<String>,
/// Override the position for the initial window launched by this process. /// Override the position for the initial window launched by this process.
/// ///
@ -242,20 +242,20 @@ pub struct SshCommand {
/// --position main:10,20 to set x=10, y=20 relative to the main monitor /// --position main:10,20 to set x=10, y=20 relative to the main monitor
/// --position active:10,20 to set x=10, y=20 relative to the active monitor /// --position active:10,20 to set x=10, y=20 relative to the active monitor
/// --position HDMI-1:10,20 to set x=10, y=20 relative to the monitor named HDMI-1 /// --position HDMI-1:10,20 to set x=10, y=20 relative to the monitor named HDMI-1
#[structopt(long, verbatim_doc_comment)] #[clap(long, verbatim_doc_comment)]
pub position: Option<GuiPosition>, pub position: Option<GuiPosition>,
/// Instead of executing your shell, run PROG. /// Instead of executing your shell, run PROG.
/// For example: `wezterm ssh user@host -- bash -l` will spawn bash /// For example: `wezterm ssh user@host -- bash -l` will spawn bash
/// as if it were a login shell. /// as if it were a login shell.
#[structopt(parse(from_os_str))] #[clap(parse(from_os_str))]
pub prog: Vec<OsString>, pub prog: Vec<OsString>,
} }
#[derive(Debug, StructOpt, Clone)] #[derive(Debug, Parser, Clone)]
pub struct SerialCommand { pub struct SerialCommand {
/// Set the baud rate. The default is 9600 baud. /// Set the baud rate. The default is 9600 baud.
#[structopt(long = "baud")] #[clap(long = "baud")]
pub baud: Option<usize>, pub baud: Option<usize>,
/// Override the default windowing system class. /// Override the default windowing system class.
@ -265,7 +265,7 @@ pub struct SerialCommand {
/// This changes the class for all windows spawned by this /// This changes the class for all windows spawned by this
/// instance of wezterm, including error, update and ssh /// instance of wezterm, including error, update and ssh
/// authentication dialogs. /// authentication dialogs.
#[structopt(long = "class")] #[clap(long = "class")]
pub class: Option<String>, pub class: Option<String>,
/// Override the position for the initial window launched by this process. /// Override the position for the initial window launched by this process.
/// ///
@ -274,17 +274,17 @@ pub struct SerialCommand {
/// --position main:10,20 to set x=10, y=20 relative to the main monitor /// --position main:10,20 to set x=10, y=20 relative to the main monitor
/// --position active:10,20 to set x=10, y=20 relative to the active monitor /// --position active:10,20 to set x=10, y=20 relative to the active monitor
/// --position HDMI-1:10,20 to set x=10, y=20 relative to the monitor named HDMI-1 /// --position HDMI-1:10,20 to set x=10, y=20 relative to the monitor named HDMI-1
#[structopt(long, verbatim_doc_comment)] #[clap(long, verbatim_doc_comment)]
pub position: Option<GuiPosition>, pub position: Option<GuiPosition>,
/// Specifies the serial device name. /// Specifies the serial device name.
/// On Windows systems this can be a name like `COM0`. /// On Windows systems this can be a name like `COM0`.
/// On posix systems this will be something like `/dev/ttyUSB0` /// On posix systems this will be something like `/dev/ttyUSB0`
#[structopt(parse(from_os_str))] #[clap(parse(from_os_str))]
pub port: OsString, pub port: OsString,
} }
#[derive(Debug, StructOpt, Clone)] #[derive(Debug, Parser, Clone)]
pub struct ConnectCommand { pub struct ConnectCommand {
/// Name of the multiplexer domain section from the configuration /// Name of the multiplexer domain section from the configuration
/// to which you'd like to connect /// to which you'd like to connect
@ -297,12 +297,12 @@ pub struct ConnectCommand {
/// This changes the class for all windows spawned by this /// This changes the class for all windows spawned by this
/// instance of wezterm, including error, update and ssh /// instance of wezterm, including error, update and ssh
/// authentication dialogs. /// authentication dialogs.
#[structopt(long = "class")] #[clap(long = "class")]
pub class: Option<String>, pub class: Option<String>,
/// Override the default workspace with the provided name. /// Override the default workspace with the provided name.
/// The default is "default". /// The default is "default".
#[structopt(long = "workspace")] #[clap(long = "workspace")]
pub workspace: Option<String>, pub workspace: Option<String>,
/// Override the position for the initial window launched by this process. /// Override the position for the initial window launched by this process.
/// ///
@ -311,23 +311,23 @@ pub struct ConnectCommand {
/// --position main:10,20 to set x=10, y=20 relative to the main monitor /// --position main:10,20 to set x=10, y=20 relative to the main monitor
/// --position active:10,20 to set x=10, y=20 relative to the active monitor /// --position active:10,20 to set x=10, y=20 relative to the active monitor
/// --position HDMI-1:10,20 to set x=10, y=20 relative to the monitor named HDMI-1 /// --position HDMI-1:10,20 to set x=10, y=20 relative to the monitor named HDMI-1
#[structopt(long, verbatim_doc_comment)] #[clap(long, verbatim_doc_comment)]
pub position: Option<GuiPosition>, pub position: Option<GuiPosition>,
/// Instead of executing your shell, run PROG. /// Instead of executing your shell, run PROG.
/// For example: `wezterm start -- bash -l` will spawn bash /// For example: `wezterm start -- bash -l` will spawn bash
/// as if it were a login shell. /// as if it were a login shell.
#[structopt(parse(from_os_str))] #[clap(parse(from_os_str))]
pub prog: Vec<OsString>, pub prog: Vec<OsString>,
} }
#[derive(Debug, StructOpt, Clone)] #[derive(Debug, Parser, Clone)]
pub struct LsFontsCommand { pub struct LsFontsCommand {
/// Whether to list all fonts available to the system /// Whether to list all fonts available to the system
#[structopt(long = "list-system")] #[clap(long = "list-system")]
pub list_system: bool, pub list_system: bool,
/// Explain which fonts are used to render the supplied text string /// Explain which fonts are used to render the supplied text string
#[structopt(long = "text", conflicts_with = "list-system")] #[clap(long = "text", conflicts_with = "list-system")]
pub text: Option<String>, pub text: Option<String>,
} }

View File

@ -23,6 +23,7 @@ cc = "1.0"
anyhow = "1.0" anyhow = "1.0"
bitflags = "1.3" bitflags = "1.3"
chrono = {version="0.4", features=["unstable-locales"]} chrono = {version="0.4", features=["unstable-locales"]}
clap = {version="3.1", features=["derive"]}
codec = { path = "../codec" } codec = { path = "../codec" }
colorgrad = "0.5" colorgrad = "0.5"
config = { path = "../config" } config = { path = "../config" }
@ -56,7 +57,6 @@ serde = {version="1.0", features = ["rc", "derive"]}
serde_json = "1.0" serde_json = "1.0"
serial = "0.4" serial = "0.4"
smol = "1.2" smol = "1.2"
structopt = "0.3"
tabout = { path = "../tabout" } tabout = { path = "../tabout" }
terminfo = "0.7" terminfo = "0.7"
termwiz = { path = "../termwiz" } termwiz = { path = "../termwiz" }

View File

@ -3,6 +3,7 @@
use ::window::*; use ::window::*;
use anyhow::{anyhow, Context}; use anyhow::{anyhow, Context};
use clap::Parser;
use config::{ConfigHandle, SshDomain, SshMultiplexing}; use config::{ConfigHandle, SshDomain, SshMultiplexing};
use mux::activity::Activity; use mux::activity::Activity;
use mux::domain::{Domain, LocalDomain}; use mux::domain::{Domain, LocalDomain};
@ -15,7 +16,6 @@ use std::ffi::OsString;
use std::path::PathBuf; use std::path::PathBuf;
use std::rc::Rc; use std::rc::Rc;
use std::sync::Arc; use std::sync::Arc;
use structopt::StructOpt;
use termwiz::cell::{CellAttributes, UnicodeVersion}; use termwiz::cell::{CellAttributes, UnicodeVersion};
use termwiz::surface::{Line, SEQ_ZERO}; use termwiz::surface::{Line, SEQ_ZERO};
use wezterm_bidi::Direction; use wezterm_bidi::Direction;
@ -49,20 +49,19 @@ mod utilsprites;
pub use selection::SelectionMode; pub use selection::SelectionMode;
pub use termwindow::{set_window_class, set_window_position, TermWindow, ICON_DATA}; pub use termwindow::{set_window_class, set_window_position, TermWindow, ICON_DATA};
#[derive(Debug, StructOpt)] #[derive(Debug, Parser)]
#[structopt( #[clap(
about = "Wez's Terminal Emulator\nhttp://github.com/wez/wezterm", about = "Wez's Terminal Emulator\nhttp://github.com/wez/wezterm",
global_setting = structopt::clap::AppSettings::ColoredHelp,
version = config::wezterm_version() version = config::wezterm_version()
)] )]
struct Opt { struct Opt {
/// Skip loading wezterm.lua /// Skip loading wezterm.lua
#[structopt(name = "skip-config", short = "n")] #[clap(name = "skip-config", short = 'n')]
skip_config: bool, skip_config: bool,
/// Specify the configuration file to use, overrides the normal /// Specify the configuration file to use, overrides the normal
/// configuration file resolution /// configuration file resolution
#[structopt( #[clap(
long = "config-file", long = "config-file",
parse(from_os_str), parse(from_os_str),
conflicts_with = "skip-config" conflicts_with = "skip-config"
@ -70,7 +69,7 @@ struct Opt {
config_file: Option<OsString>, config_file: Option<OsString>,
/// Override specific configuration values /// Override specific configuration values
#[structopt( #[clap(
long = "config", long = "config",
name = "name=value", name = "name=value",
parse(try_from_str = name_equals_value), parse(try_from_str = name_equals_value),
@ -79,32 +78,32 @@ struct Opt {
/// On Windows, whether to attempt to attach to the parent /// On Windows, whether to attempt to attach to the parent
/// process console to display logging output /// process console to display logging output
#[structopt(long = "attach-parent-console")] #[clap(long = "attach-parent-console")]
#[allow(dead_code)] #[allow(dead_code)]
attach_parent_console: bool, attach_parent_console: bool,
#[structopt(subcommand)] #[clap(subcommand)]
cmd: Option<SubCommand>, cmd: Option<SubCommand>,
} }
#[derive(Debug, StructOpt, Clone)] #[derive(Debug, Parser, Clone)]
enum SubCommand { enum SubCommand {
#[structopt( #[clap(
name = "start", name = "start",
about = "Start the GUI, optionally running an alternative program" about = "Start the GUI, optionally running an alternative program"
)] )]
Start(StartCommand), Start(StartCommand),
#[structopt(name = "ssh", about = "Establish an ssh session")] #[clap(name = "ssh", about = "Establish an ssh session")]
Ssh(SshCommand), Ssh(SshCommand),
#[structopt(name = "serial", about = "Open a serial port")] #[clap(name = "serial", about = "Open a serial port")]
Serial(SerialCommand), Serial(SerialCommand),
#[structopt(name = "connect", about = "Connect to wezterm multiplexer")] #[clap(name = "connect", about = "Connect to wezterm multiplexer")]
Connect(ConnectCommand), Connect(ConnectCommand),
#[structopt(name = "ls-fonts", about = "Display information about fonts")] #[clap(name = "ls-fonts", about = "Display information about fonts")]
LsFonts(LsFontsCommand), LsFonts(LsFontsCommand),
} }
@ -913,7 +912,7 @@ fn run() -> anyhow::Result<()> {
} }
} }
let opts = Opt::from_args(); let opts = Opt::parse();
// This is a bit gross. // This is a bit gross.
// In order to not to automatically open a standard windows console when // In order to not to automatically open a standard windows console when
@ -953,7 +952,7 @@ fn run() -> anyhow::Result<()> {
for a in &config.default_gui_startup_args { for a in &config.default_gui_startup_args {
argv.push(a.clone()); argv.push(a.clone());
} }
SubCommand::from_iter_safe(&argv).with_context(|| { SubCommand::try_parse_from(&argv).with_context(|| {
format!( format!(
"parsing the default_gui_startup_args config: {:?}", "parsing the default_gui_startup_args config: {:?}",
config.default_gui_startup_args config.default_gui_startup_args

View File

@ -10,6 +10,7 @@ resolver = "2"
[dependencies] [dependencies]
anyhow = "1.0" anyhow = "1.0"
async_ossl = { path = "../async_ossl" } async_ossl = { path = "../async_ossl" }
clap = {version="3.1", features=["derive"]}
config = { path = "../config" } config = { path = "../config" }
env-bootstrap = { path = "../env-bootstrap" } env-bootstrap = { path = "../env-bootstrap" }
libc = "0.2" libc = "0.2"
@ -18,7 +19,6 @@ mux = { path = "../mux" }
openssl = "0.10" openssl = "0.10"
portable-pty = { path = "../pty", features = ["serde_support"]} portable-pty = { path = "../pty", features = ["serde_support"]}
promise = { path = "../promise" } promise = { path = "../promise" }
structopt = "0.3"
umask = { path = "../umask" } umask = { path = "../umask" }
wezterm-mux-server-impl = { path = "../wezterm-mux-server-impl" } wezterm-mux-server-impl = { path = "../wezterm-mux-server-impl" }
wezterm-gui-subcommands = { path = "../wezterm-gui-subcommands" } wezterm-gui-subcommands = { path = "../wezterm-gui-subcommands" }

View File

@ -1,3 +1,4 @@
use clap::*;
use config::configuration; use config::configuration;
use mux::activity::Activity; use mux::activity::Activity;
use mux::domain::{Domain, LocalDomain}; use mux::domain::{Domain, LocalDomain};
@ -8,25 +9,23 @@ use std::process::Command;
use std::rc::Rc; use std::rc::Rc;
use std::sync::Arc; use std::sync::Arc;
use std::thread; use std::thread;
use structopt::*;
use wezterm_gui_subcommands::*; use wezterm_gui_subcommands::*;
mod daemonize; mod daemonize;
#[derive(Debug, StructOpt)] #[derive(Debug, Parser)]
#[structopt( #[clap(
about = "Wez's Terminal Emulator\nhttp://github.com/wez/wezterm", about = "Wez's Terminal Emulator\nhttp://github.com/wez/wezterm",
global_setting = structopt::clap::AppSettings::ColoredHelp,
version = config::wezterm_version() version = config::wezterm_version()
)] )]
struct Opt { struct Opt {
/// Skip loading wezterm.lua /// Skip loading wezterm.lua
#[structopt(name = "skip-config", short = "n")] #[clap(name = "skip-config", short = 'n')]
skip_config: bool, skip_config: bool,
/// Specify the configuration file to use, overrides the normal /// Specify the configuration file to use, overrides the normal
/// configuration file resolution /// configuration file resolution
#[structopt( #[clap(
long = "config-file", long = "config-file",
parse(from_os_str), parse(from_os_str),
conflicts_with = "skip-config" conflicts_with = "skip-config"
@ -34,7 +33,7 @@ struct Opt {
config_file: Option<OsString>, config_file: Option<OsString>,
/// Override specific configuration values /// Override specific configuration values
#[structopt( #[clap(
long = "config", long = "config",
name = "name=value", name = "name=value",
parse(try_from_str = name_equals_value), parse(try_from_str = name_equals_value),
@ -42,18 +41,18 @@ struct Opt {
config_override: Vec<(String, String)>, config_override: Vec<(String, String)>,
/// Detach from the foreground and become a background process /// Detach from the foreground and become a background process
#[structopt(long = "daemonize")] #[clap(long = "daemonize")]
daemonize: bool, daemonize: bool,
/// Specify the current working directory for the initially /// Specify the current working directory for the initially
/// spawned program /// spawned program
#[structopt(long = "cwd", parse(from_os_str))] #[clap(long = "cwd", parse(from_os_str))]
cwd: Option<OsString>, cwd: Option<OsString>,
/// Instead of executing your shell, run PROG. /// Instead of executing your shell, run PROG.
/// For example: `wezterm start -- bash -l` will spawn bash /// For example: `wezterm start -- bash -l` will spawn bash
/// as if it were a login shell. /// as if it were a login shell.
#[structopt(parse(from_os_str))] #[clap(parse(from_os_str))]
prog: Vec<OsString>, prog: Vec<OsString>,
} }
@ -71,7 +70,7 @@ fn run() -> anyhow::Result<()> {
config::designate_this_as_the_main_thread(); config::designate_this_as_the_main_thread();
let _saver = umask::UmaskSaver::new(); let _saver = umask::UmaskSaver::new();
let opts = Opt::from_args(); let opts = Opt::parse();
config::common_init( config::common_init(
opts.config_file.as_ref(), opts.config_file.as_ref(),
&opts.config_override, &opts.config_override,

View File

@ -40,6 +40,7 @@ async_ossl = { path = "../async_ossl" }
[dev-dependencies] [dev-dependencies]
assert_fs = "1.0.4" assert_fs = "1.0.4"
clap = {version="3.1", features=["derive"]}
k9 = "0.11.0" k9 = "0.11.0"
once_cell = "1.8" once_cell = "1.8"
predicates = "2.0" predicates = "2.0"
@ -47,6 +48,5 @@ env_logger = "0.9"
rstest = "0.13" rstest = "0.13"
shell-words = "1.1" shell-words = "1.1"
smol-potat = "1.1.2" smol-potat = "1.1.2"
structopt = "0.3"
termwiz = { version = "0.16", path = "../termwiz" } termwiz = { version = "0.16", path = "../termwiz" }
whoami = "1.1" whoami = "1.1"

View File

@ -2,9 +2,9 @@
//! to test the guts of the ssh handling, rather than //! to test the guts of the ssh handling, rather than
//! to be a full fledged replacement for ssh. //! to be a full fledged replacement for ssh.
use anyhow::Context; use anyhow::Context;
use clap::Parser;
use portable_pty::{Child, MasterPty, PtySize}; use portable_pty::{Child, MasterPty, PtySize};
use std::io::{Read, Write}; use std::io::{Read, Write};
use structopt::StructOpt;
use termwiz::cell::unicode_column_width; use termwiz::cell::unicode_column_width;
use termwiz::lineedit::*; use termwiz::lineedit::*;
use wezterm_ssh::{Config, Session, SessionEvent}; use wezterm_ssh::{Config, Session, SessionEvent};
@ -39,9 +39,9 @@ impl LineEditorHost for PasswordPromptHost {
} }
} }
#[derive(Debug, StructOpt, Default, Clone)] #[derive(Debug, Parser, Default, Clone)]
struct Opt { struct Opt {
#[structopt(long = "user", short = "l")] #[clap(long = "user", short = 'l')]
pub user: Option<String>, pub user: Option<String>,
pub destination: String, pub destination: String,
pub cmd: Vec<String>, pub cmd: Vec<String>,

View File

@ -26,7 +26,7 @@ serde = {version="1.0", features = ["derive"]}
serde_json = "1.0" serde_json = "1.0"
shell-words = "1.1" shell-words = "1.1"
smol = "1.2" smol = "1.2"
structopt = "0.3" clap = {version="3.1", features=["derive"]}
tabout = { path = "../tabout" } tabout = { path = "../tabout" }
tempfile = "3.3" tempfile = "3.3"
termwiz = { path = "../termwiz" } termwiz = { path = "../termwiz" }

View File

@ -1,6 +1,7 @@
use anyhow::Context; use anyhow::Context;
use chrono::serde::ts_seconds_option; use chrono::serde::ts_seconds_option;
use chrono::{DateTime, Utc}; use chrono::{DateTime, Utc};
use clap::Parser;
use config::ConfigHandle; use config::ConfigHandle;
use filedescriptor::FileDescriptor; use filedescriptor::FileDescriptor;
use portable_pty::{native_pty_system, PtySize}; use portable_pty::{native_pty_system, PtySize};
@ -11,8 +12,7 @@ use std::io::{BufRead, BufReader, BufWriter, Read, Write};
use std::path::PathBuf; use std::path::PathBuf;
use std::sync::mpsc::channel; use std::sync::mpsc::channel;
use std::time::{Duration, Instant}; use std::time::{Duration, Instant};
use structopt::StructOpt; use termwiz::escape::parser::Parser as TWParser;
use termwiz::escape::parser::Parser;
use termwiz::escape::Action; use termwiz::escape::Action;
#[cfg(unix)] #[cfg(unix)]
use unix::UnixTty as Tty; use unix::UnixTty as Tty;
@ -335,9 +335,9 @@ enum Message {
Terminated(portable_pty::ExitStatus), Terminated(portable_pty::ExitStatus),
} }
#[derive(Debug, StructOpt, Clone)] #[derive(Debug, Parser, Clone)]
pub struct RecordCommand { pub struct RecordCommand {
#[structopt(parse(from_os_str))] #[clap(parse(from_os_str))]
prog: Vec<OsString>, prog: Vec<OsString>,
} }
@ -474,10 +474,10 @@ impl RecordCommand {
} }
} }
#[derive(Debug, StructOpt, Clone)] #[derive(Debug, Parser, Clone)]
pub struct PlayCommand { pub struct PlayCommand {
/// Explain what is being sent/received /// Explain what is being sent/received
#[structopt(long)] #[clap(long)]
explain: bool, explain: bool,
cast_file: PathBuf, cast_file: PathBuf,
@ -532,7 +532,7 @@ impl PlayCommand {
let start = Instant::now(); let start = Instant::now();
let mut sent_parser = Parser::new(); let mut sent_parser = TWParser::new();
let mut sent_actions = vec![]; let mut sent_actions = vec![];
for line in cast_file.lines() { for line in cast_file.lines() {
@ -590,7 +590,7 @@ impl PlayCommand {
if self.explain { if self.explain {
println!("< RECV"); println!("< RECV");
} }
let mut parser = Parser::new(); let mut parser = TWParser::new();
while let Ok(msg) = rx.try_recv() { while let Ok(msg) = rx.try_recv() {
match msg { match msg {
Message::Stdin(data) => { Message::Stdin(data) => {

View File

@ -1,5 +1,6 @@
use anyhow::{anyhow, Context}; use anyhow::{anyhow, Context};
use chrono::{DateTime, Utc}; use chrono::{DateTime, Utc};
use clap::Parser;
use config::keyassignment::SpawnTabDomain; use config::keyassignment::SpawnTabDomain;
use config::wezterm_version; use config::wezterm_version;
use mux::activity::Activity; use mux::activity::Activity;
@ -12,7 +13,6 @@ use serde::Serializer as _;
use std::ffi::OsString; use std::ffi::OsString;
use std::io::{Read, Write}; use std::io::{Read, Write};
use std::rc::Rc; use std::rc::Rc;
use structopt::StructOpt;
use tabout::{tabulate_output, Alignment, Column}; use tabout::{tabulate_output, Alignment, Column};
use umask::UmaskSaver; use umask::UmaskSaver;
use wezterm_client::client::{unix_connect_with_retry, Client}; use wezterm_client::client::{unix_connect_with_retry, Client};
@ -22,20 +22,19 @@ mod asciicast;
// let message = "; ❤ 😍🤢\n\x1b[91;mw00t\n\x1b[37;104;m bleet\x1b[0;m."; // let message = "; ❤ 😍🤢\n\x1b[91;mw00t\n\x1b[37;104;m bleet\x1b[0;m.";
#[derive(Debug, StructOpt)] #[derive(Debug, Parser)]
#[structopt( #[clap(
about = "Wez's Terminal Emulator\nhttp://github.com/wez/wezterm", about = "Wez's Terminal Emulator\nhttp://github.com/wez/wezterm",
global_setting = structopt::clap::AppSettings::ColoredHelp,
version = wezterm_version() version = wezterm_version()
)] )]
struct Opt { struct Opt {
/// Skip loading wezterm.lua /// Skip loading wezterm.lua
#[structopt(name = "skip-config", short = "n")] #[clap(name = "skip-config", short = 'n')]
skip_config: bool, skip_config: bool,
/// Specify the configuration file to use, overrides the normal /// Specify the configuration file to use, overrides the normal
/// configuration file resolution /// configuration file resolution
#[structopt( #[clap(
long = "config-file", long = "config-file",
parse(from_os_str), parse(from_os_str),
conflicts_with = "skip-config" conflicts_with = "skip-config"
@ -43,85 +42,85 @@ struct Opt {
config_file: Option<OsString>, config_file: Option<OsString>,
/// Override specific configuration values /// Override specific configuration values
#[structopt( #[clap(
long = "config", long = "config",
name = "name=value", name = "name=value",
parse(try_from_str = name_equals_value), parse(try_from_str = name_equals_value),
number_of_values = 1)] number_of_values = 1)]
config_override: Vec<(String, String)>, config_override: Vec<(String, String)>,
#[structopt(subcommand)] #[clap(subcommand)]
cmd: Option<SubCommand>, cmd: Option<SubCommand>,
} }
#[derive(Debug, StructOpt, Clone)] #[derive(Debug, Parser, Clone)]
enum SubCommand { enum SubCommand {
#[structopt( #[clap(
name = "start", name = "start",
about = "Start the GUI, optionally running an alternative program" about = "Start the GUI, optionally running an alternative program"
)] )]
Start(StartCommand), Start(StartCommand),
#[structopt(name = "ssh", about = "Establish an ssh session")] #[clap(name = "ssh", about = "Establish an ssh session")]
Ssh(SshCommand), Ssh(SshCommand),
#[structopt(name = "serial", about = "Open a serial port")] #[clap(name = "serial", about = "Open a serial port")]
Serial(SerialCommand), Serial(SerialCommand),
#[structopt(name = "connect", about = "Connect to wezterm multiplexer")] #[clap(name = "connect", about = "Connect to wezterm multiplexer")]
Connect(ConnectCommand), Connect(ConnectCommand),
#[structopt(name = "ls-fonts", about = "Display information about fonts")] #[clap(name = "ls-fonts", about = "Display information about fonts")]
LsFonts(LsFontsCommand), LsFonts(LsFontsCommand),
#[structopt(name = "cli", about = "Interact with experimental mux server")] #[clap(name = "cli", about = "Interact with experimental mux server")]
Cli(CliCommand), Cli(CliCommand),
#[structopt(name = "imgcat", about = "Output an image to the terminal")] #[clap(name = "imgcat", about = "Output an image to the terminal")]
ImageCat(ImgCatCommand), ImageCat(ImgCatCommand),
#[structopt( #[clap(
name = "set-working-directory", name = "set-working-directory",
about = "Advise the terminal of the current working directory by \ about = "Advise the terminal of the current working directory by \
emitting an OSC 7 escape sequence" emitting an OSC 7 escape sequence"
)] )]
SetCwd(SetCwdCommand), SetCwd(SetCwdCommand),
#[structopt(name = "record", about = "Record a terminal session as an asciicast")] #[clap(name = "record", about = "Record a terminal session as an asciicast")]
Record(asciicast::RecordCommand), Record(asciicast::RecordCommand),
#[structopt(name = "replay", about = "Replay an asciicast terminal session")] #[clap(name = "replay", about = "Replay an asciicast terminal session")]
Replay(asciicast::PlayCommand), Replay(asciicast::PlayCommand),
} }
#[derive(Debug, StructOpt, Clone)] #[derive(Debug, Parser, Clone)]
struct CliCommand { struct CliCommand {
/// Don't automatically start the server /// Don't automatically start the server
#[structopt(long = "no-auto-start")] #[clap(long = "no-auto-start")]
no_auto_start: bool, no_auto_start: bool,
/// Prefer connecting to a background mux server. /// Prefer connecting to a background mux server.
/// The default is to prefer connecting to a running /// The default is to prefer connecting to a running
/// wezterm gui instance /// wezterm gui instance
#[structopt(long = "prefer-mux")] #[clap(long = "prefer-mux")]
prefer_mux: bool, prefer_mux: bool,
/// When connecting to a gui instance, if you started the /// When connecting to a gui instance, if you started the
/// gui with `--class SOMETHING`, you should also pass /// gui with `--class SOMETHING`, you should also pass
/// that same value here in order for the client to find /// that same value here in order for the client to find
/// the correct gui instance. /// the correct gui instance.
#[structopt(long = "class")] #[clap(long = "class")]
class: Option<String>, class: Option<String>,
#[structopt(subcommand)] #[clap(subcommand)]
sub: CliSubCommand, sub: CliSubCommand,
} }
#[derive(Debug, StructOpt, Clone, Copy)] #[derive(Debug, Parser, Clone, Copy)]
enum CliOutputFormatKind { enum CliOutputFormatKind {
#[structopt(name = "table", about = "multi line space separated table")] #[clap(name = "table", about = "multi line space separated table")]
Table, Table,
#[structopt(name = "json", about = "JSON format")] #[clap(name = "json", about = "JSON format")]
Json, Json,
} }
@ -136,29 +135,29 @@ impl std::str::FromStr for CliOutputFormatKind {
} }
} }
#[derive(Debug, StructOpt, Clone, Copy)] #[derive(Debug, Parser, Clone, Copy)]
struct CliOutputFormat { struct CliOutputFormat {
/// Controls the output format. /// Controls the output format.
/// "table" and "json" are possible formats. /// "table" and "json" are possible formats.
#[structopt(long = "format", default_value = "table")] #[clap(long = "format", default_value = "table")]
format: CliOutputFormatKind, format: CliOutputFormatKind,
} }
#[derive(Debug, StructOpt, Clone)] #[derive(Debug, Parser, Clone)]
enum CliSubCommand { enum CliSubCommand {
#[structopt(name = "list", about = "list windows, tabs and panes")] #[clap(name = "list", about = "list windows, tabs and panes")]
List(CliOutputFormat), List(CliOutputFormat),
#[structopt(name = "list-clients", about = "list clients")] #[clap(name = "list-clients", about = "list clients")]
ListClients(CliOutputFormat), ListClients(CliOutputFormat),
#[structopt(name = "proxy", about = "start rpc proxy pipe")] #[clap(name = "proxy", about = "start rpc proxy pipe")]
Proxy, Proxy,
#[structopt(name = "tlscreds", about = "obtain tls credentials")] #[clap(name = "tlscreds", about = "obtain tls credentials")]
TlsCreds, TlsCreds,
#[structopt( #[clap(
name = "move-pane-to-new-tab", name = "move-pane-to-new-tab",
rename_all = "kebab", rename_all = "kebab",
about = "Move a pane into a new tab" about = "Move a pane into a new tab"
@ -167,28 +166,28 @@ enum CliSubCommand {
/// Specify the pane that should be moved. /// Specify the pane that should be moved.
/// The default is to use the current pane based on the /// The default is to use the current pane based on the
/// environment variable WEZTERM_PANE. /// environment variable WEZTERM_PANE.
#[structopt(long)] #[clap(long)]
pane_id: Option<PaneId>, pane_id: Option<PaneId>,
/// Specify the window into which the new tab will be /// Specify the window into which the new tab will be
/// created. /// created.
/// If omitted, the window associated with the current /// If omitted, the window associated with the current
/// pane is used. /// pane is used.
#[structopt(long)] #[clap(long)]
window_id: Option<WindowId>, window_id: Option<WindowId>,
/// Create tab in a new window, rather than the window /// Create tab in a new window, rather than the window
/// currently containing the pane. /// currently containing the pane.
#[structopt(long, conflicts_with = "window_id")] #[clap(long, conflicts_with = "window-id")]
new_window: bool, new_window: bool,
/// If creating a new window, override the default workspace name /// If creating a new window, override the default workspace name
/// with the provided name. The default name is "default". /// with the provided name. The default name is "default".
#[structopt(long)] #[clap(long)]
workspace: Option<String>, workspace: Option<String>,
}, },
#[structopt( #[clap(
name = "split-pane", name = "split-pane",
rename_all = "kebab", rename_all = "kebab",
about = "split the current pane. about = "split the current pane.
@ -198,63 +197,63 @@ Outputs the pane-id for the newly created pane on success"
/// Specify the pane that should be split. /// Specify the pane that should be split.
/// The default is to use the current pane based on the /// The default is to use the current pane based on the
/// environment variable WEZTERM_PANE. /// environment variable WEZTERM_PANE.
#[structopt(long)] #[clap(long)]
pane_id: Option<PaneId>, pane_id: Option<PaneId>,
/// Equivalent to `--right`. If neither this nor any other direction /// Equivalent to `--right`. If neither this nor any other direction
/// is specified, the default is equivalent to `--bottom`. /// is specified, the default is equivalent to `--bottom`.
#[structopt(long, conflicts_with_all=&["left", "right", "top", "bottom"])] #[clap(long, conflicts_with_all=&["left", "right", "top", "bottom"])]
horizontal: bool, horizontal: bool,
/// Split horizontally, with the new pane on the left /// Split horizontally, with the new pane on the left
#[structopt(long, conflicts_with_all=&["right", "top", "bottom"])] #[clap(long, conflicts_with_all=&["right", "top", "bottom"])]
left: bool, left: bool,
/// Split horizontally, with the new pane on the right /// Split horizontally, with the new pane on the right
#[structopt(long, conflicts_with_all=&["left", "top", "bottom"])] #[clap(long, conflicts_with_all=&["left", "top", "bottom"])]
right: bool, right: bool,
/// Split vertically, with the new pane on the top /// Split vertically, with the new pane on the top
#[structopt(long, conflicts_with_all=&["left", "right", "bottom"])] #[clap(long, conflicts_with_all=&["left", "right", "bottom"])]
top: bool, top: bool,
/// Split vertically, with the new pane on the bottom /// Split vertically, with the new pane on the bottom
#[structopt(long, conflicts_with_all=&["left", "right", "top"])] #[clap(long, conflicts_with_all=&["left", "right", "top"])]
bottom: bool, bottom: bool,
/// Rather than splitting the active pane, split the entire /// Rather than splitting the active pane, split the entire
/// window. /// window.
#[structopt(long)] #[clap(long)]
top_level: bool, top_level: bool,
/// The number of cells that the new split should have. /// The number of cells that the new split should have.
/// If omitted, 50% of the available space is used. /// If omitted, 50% of the available space is used.
#[structopt(long)] #[clap(long)]
cells: Option<usize>, cells: Option<usize>,
/// Specify the number of cells that the new split should /// Specify the number of cells that the new split should
/// have, expressed as a percentage of the available space. /// have, expressed as a percentage of the available space.
#[structopt(long, conflicts_with = "cells")] #[clap(long, conflicts_with = "cells")]
percent: Option<u8>, percent: Option<u8>,
/// Specify the current working directory for the initially /// Specify the current working directory for the initially
/// spawned program /// spawned program
#[structopt(long, parse(from_os_str))] #[clap(long, parse(from_os_str))]
cwd: Option<OsString>, cwd: Option<OsString>,
/// Instead of spawning a new command, move the specified /// Instead of spawning a new command, move the specified
/// pane into the newly created split. /// pane into the newly created split.
#[structopt(long, conflicts_with_all=&["cwd", "prog"])] #[clap(long, conflicts_with_all=&["cwd", "prog"])]
move_pane_id: Option<PaneId>, move_pane_id: Option<PaneId>,
/// Instead of executing your shell, run PROG. /// Instead of executing your shell, run PROG.
/// For example: `wezterm cli split-pane -- bash -l` will spawn bash /// For example: `wezterm cli split-pane -- bash -l` will spawn bash
/// as if it were a login shell. /// as if it were a login shell.
#[structopt(parse(from_os_str))] #[clap(parse(from_os_str))]
prog: Vec<OsString>, prog: Vec<OsString>,
}, },
#[structopt( #[clap(
name = "spawn", name = "spawn",
about = "Spawn a command into a new window or tab about = "Spawn a command into a new window or tab
Outputs the pane-id for the newly created pane on success" Outputs the pane-id for the newly created pane on success"
@ -265,52 +264,52 @@ Outputs the pane-id for the newly created pane on success"
/// environment variable WEZTERM_PANE. /// environment variable WEZTERM_PANE.
/// The pane is used to determine the current domain /// The pane is used to determine the current domain
/// and window. /// and window.
#[structopt(long = "pane-id")] #[clap(long = "pane-id")]
pane_id: Option<PaneId>, pane_id: Option<PaneId>,
#[structopt(long = "domain-name")] #[clap(long = "domain-name")]
domain_name: Option<String>, domain_name: Option<String>,
/// Specify the window into which to spawn a tab. /// Specify the window into which to spawn a tab.
/// If omitted, the window associated with the current /// If omitted, the window associated with the current
/// pane is used. /// pane is used.
#[structopt(long = "window-id")] #[clap(long = "window-id")]
window_id: Option<WindowId>, window_id: Option<WindowId>,
/// Spawn into a new window, rather than a new tab /// Spawn into a new window, rather than a new tab
#[structopt(long = "new-window", conflicts_with = "window_id")] #[clap(long = "new-window", conflicts_with = "window-id")]
new_window: bool, new_window: bool,
/// Specify the current working directory for the initially /// Specify the current working directory for the initially
/// spawned program /// spawned program
#[structopt(long = "cwd", parse(from_os_str))] #[clap(long = "cwd", parse(from_os_str))]
cwd: Option<OsString>, cwd: Option<OsString>,
/// When creating a new window, override the default workspace name /// When creating a new window, override the default workspace name
/// with the provided name. The default name is "default". /// with the provided name. The default name is "default".
#[structopt(long = "workspace")] #[clap(long = "workspace")]
workspace: Option<String>, workspace: Option<String>,
/// Instead of executing your shell, run PROG. /// Instead of executing your shell, run PROG.
/// For example: `wezterm cli spawn -- bash -l` will spawn bash /// For example: `wezterm cli spawn -- bash -l` will spawn bash
/// as if it were a login shell. /// as if it were a login shell.
#[structopt(parse(from_os_str))] #[clap(parse(from_os_str))]
prog: Vec<OsString>, prog: Vec<OsString>,
}, },
/// Send text to a pane as though it were pasted. /// Send text to a pane as though it were pasted.
/// If bracketed paste mode is enabled in the pane, then the /// If bracketed paste mode is enabled in the pane, then the
/// text will be sent as a bracketed paste. /// text will be sent as a bracketed paste.
#[structopt(name = "send-text", rename_all = "kebab")] #[clap(name = "send-text", rename_all = "kebab")]
SendText { SendText {
/// Specify the target pane. /// Specify the target pane.
/// The default is to use the current pane based on the /// The default is to use the current pane based on the
/// environment variable WEZTERM_PANE. /// environment variable WEZTERM_PANE.
#[structopt(long)] #[clap(long)]
pane_id: Option<PaneId>, pane_id: Option<PaneId>,
/// Send the text directly, rather than as a bracketed paste. /// Send the text directly, rather than as a bracketed paste.
#[structopt(long)] #[clap(long)]
no_paste: bool, no_paste: bool,
/// The text to send. If omitted, will read the text from stdin. /// The text to send. If omitted, will read the text from stdin.
@ -322,27 +321,27 @@ use termwiz::escape::osc::{
ITermDimension, ITermFileData, ITermProprietary, OperatingSystemCommand, ITermDimension, ITermFileData, ITermProprietary, OperatingSystemCommand,
}; };
#[derive(Debug, StructOpt, Clone)] #[derive(Debug, Parser, Clone)]
struct ImgCatCommand { struct ImgCatCommand {
/// Specify the display width; defaults to "auto" which automatically selects /// Specify the display width; defaults to "auto" which automatically selects
/// an appropriate size. You may also use an integer value `N` to specify the /// an appropriate size. You may also use an integer value `N` to specify the
/// number of cells, or `Npx` to specify the number of pixels, or `N%` to /// number of cells, or `Npx` to specify the number of pixels, or `N%` to
/// size relative to the terminal width. /// size relative to the terminal width.
#[structopt(long = "width")] #[clap(long = "width")]
width: Option<ITermDimension>, width: Option<ITermDimension>,
/// Specify the display height; defaults to "auto" which automatically selects /// Specify the display height; defaults to "auto" which automatically selects
/// an appropriate size. You may also use an integer value `N` to specify the /// an appropriate size. You may also use an integer value `N` to specify the
/// number of cells, or `Npx` to specify the number of pixels, or `N%` to /// number of cells, or `Npx` to specify the number of pixels, or `N%` to
/// size relative to the terminal height. /// size relative to the terminal height.
#[structopt(long = "height")] #[clap(long = "height")]
height: Option<ITermDimension>, height: Option<ITermDimension>,
/// Do not respect the aspect ratio. The default is to respect the aspect /// Do not respect the aspect ratio. The default is to respect the aspect
/// ratio /// ratio
#[structopt(long = "no-preserve-aspect-ratio")] #[clap(long = "no-preserve-aspect-ratio")]
no_preserve_aspect_ratio: bool, no_preserve_aspect_ratio: bool,
/// The name of the image file to be displayed. /// The name of the image file to be displayed.
/// If omitted, will attempt to read it from stdin. /// If omitted, will attempt to read it from stdin.
#[structopt(parse(from_os_str))] #[clap(parse(from_os_str))]
file_name: Option<OsString>, file_name: Option<OsString>,
} }
@ -376,16 +375,16 @@ impl ImgCatCommand {
} }
} }
#[derive(Debug, StructOpt, Clone)] #[derive(Debug, Parser, Clone)]
struct SetCwdCommand { struct SetCwdCommand {
/// The directory to specify. /// The directory to specify.
/// If omitted, will use the current directory of the process itself. /// If omitted, will use the current directory of the process itself.
#[structopt(parse(from_os_str))] #[clap(parse(from_os_str))]
cwd: Option<OsString>, cwd: Option<OsString>,
/// The hostname to use in the constructed file:// URL. /// The hostname to use in the constructed file:// URL.
/// If omitted, the system hostname will be used. /// If omitted, the system hostname will be used.
#[structopt(parse(from_os_str))] #[clap(parse(from_os_str))]
host: Option<OsString>, host: Option<OsString>,
} }
@ -446,7 +445,7 @@ fn run() -> anyhow::Result<()> {
let saver = UmaskSaver::new(); let saver = UmaskSaver::new();
let opts = Opt::from_args(); let opts = Opt::parse();
config::common_init( config::common_init(
opts.config_file.as_ref(), opts.config_file.as_ref(),
&opts.config_override, &opts.config_override,