diff --git a/src/tests/e2e/remote_runner.rs b/src/tests/e2e/remote_runner.rs index 05f4bf2aad..466b180524 100644 --- a/src/tests/e2e/remote_runner.rs +++ b/src/tests/e2e/remote_runner.rs @@ -127,7 +127,7 @@ fn start_zellij_with_layout(channel: &mut ssh2::Channel, layout_path: &str) { channel .write_all( format!( - "{} --layout-path {} --session {} --data-dir {}\n", + "{} --layout {} --session {} --data-dir {}\n", ZELLIJ_EXECUTABLE_LOCATION, layout_path, SESSION_NAME, ZELLIJ_DATA_DIR ) .as_bytes(), diff --git a/zellij-utils/src/cli.rs b/zellij-utils/src/cli.rs index 39ee0cbf63..0a8d8a9e37 100644 --- a/zellij-utils/src/cli.rs +++ b/zellij-utils/src/cli.rs @@ -26,14 +26,10 @@ pub struct CliArgs { #[clap(long, short, overrides_with = "session")] pub session: Option, - /// Name of a layout file in the layout directory + /// Name of a predefined layout or path to a layout file #[clap(short, long, parse(from_os_str), overrides_with = "layout")] pub layout: Option, - /// Path to a layout yaml file - #[clap(long, parse(from_os_str), overrides_with = "layout_path")] - pub layout_path: Option, - /// Change where zellij looks for the configuration file #[clap(short, long, overrides_with = "config", env = ZELLIJ_CONFIG_FILE_ENV, parse(from_os_str))] pub config: Option, diff --git a/zellij-utils/src/input/layout.rs b/zellij-utils/src/input/layout.rs index 4e91bcdc16..90cd09a73f 100644 --- a/zellij-utils/src/input/layout.rs +++ b/zellij-utils/src/input/layout.rs @@ -239,12 +239,21 @@ impl LayoutFromYamlIntermediate { pub fn from_path_or_default( layout: Option<&PathBuf>, - layout_path: Option<&PathBuf>, layout_dir: Option, ) -> Option { layout - .map(|p| LayoutFromYamlIntermediate::from_dir(p, layout_dir.as_ref())) - .or_else(|| layout_path.map(|p| LayoutFromYamlIntermediate::from_path(p))) + .map(|layout| { + // The way we determine where to look for the layout is similar to + // how a path would look for an executable. + // See the gh issue for more: https://github.com/zellij-org/zellij/issues/1412#issuecomment-1131559720 + if layout.extension().is_some() || layout.components().count() > 1 { + // We look localy! + LayoutFromYamlIntermediate::from_path(layout) + } else { + // We look in the default dir + LayoutFromYamlIntermediate::from_dir(layout, layout_dir.as_ref()) + } + }) .or_else(|| { Some(LayoutFromYamlIntermediate::from_dir( &std::path::PathBuf::from("default"), diff --git a/zellij-utils/src/setup.rs b/zellij-utils/src/setup.rs index 79392c2ee1..301bcee939 100644 --- a/zellij-utils/src/setup.rs +++ b/zellij-utils/src/setup.rs @@ -223,11 +223,8 @@ impl Setup { .layout_dir .clone() .or_else(|| get_layout_dir(opts.config_dir.clone().or_else(find_default_config_dir))); - let layout_result = LayoutFromYamlIntermediate::from_path_or_default( - opts.layout.as_ref(), - opts.layout_path.as_ref(), - layout_dir, - ); + let layout_result = + LayoutFromYamlIntermediate::from_path_or_default(opts.layout.as_ref(), layout_dir); let layout = match layout_result { None => None, Some(Ok(layout)) => Some(layout),