From c03420798f79b8a410f69aae5cb9e44ffd59ac56 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jonatan=20K=C5=82osko?= Date: Mon, 17 Apr 2023 15:40:48 +0200 Subject: [PATCH] Add @home CLI argument for opening homepage (#1868) --- lib/livebook_cli/server.ex | 24 +++++++++++++++--------- 1 file changed, 15 insertions(+), 9 deletions(-) diff --git a/lib/livebook_cli/server.ex b/lib/livebook_cli/server.ex index e1b4a9188..8b5bfacb0 100644 --- a/lib/livebook_cli/server.ex +++ b/lib/livebook_cli/server.ex @@ -20,14 +20,17 @@ defmodule LivebookCLI.Server do An optional open-command can be given as argument. It will open up a browser window according these rules: - * If the open-command is "new", the browser window will point + * If the open-command is "@home", the browser window will point + to the home page + + * If the open-command is "@new", the browser window will point to a new notebook * If the open-command is a URL, the notebook at the given URL will be imported * If the open-command is a directory, the browser window will point - to the home page with the directory selected + to the open page with the directory selected * If the open-command is a notebook file, the browser window will point to the opened notebook @@ -39,7 +42,6 @@ defmodule LivebookCLI.Server do ## Available options --cookie Sets a cookie for the app distributed node - --home The home path for the Livebook instance --ip The ip address to start the web application on, defaults to 127.0.0.1 Must be a valid IPv4 or IPv6 address --name Sets a name for the app distributed node @@ -149,12 +151,21 @@ defmodule LivebookCLI.Server do :ok end - defp open_from_args(base_url, ["new"]) do + defp open_from_args(base_url, ["@home"]) do + Livebook.Utils.browser_open(base_url) + end + + defp open_from_args(base_url, ["@new"]) do base_url |> set_path("/learn/notebooks/new") |> Livebook.Utils.browser_open() end + defp open_from_args(base_url, ["new"]) do + IO.warn(~s/passing "new" as an argument is deprecated, use "@new" instead/, []) + open_from_args(base_url, ["@new"]) + end + defp open_from_args(base_url, [url_or_file_or_dir]) do url = URI.parse(url_or_file_or_dir) path = Path.expand(url_or_file_or_dir) @@ -221,11 +232,6 @@ defmodule LivebookCLI.Server do ]) end - defp opts_to_config([{:home, home} | opts], config) do - home = Livebook.Config.writable_dir!("--home", home) - opts_to_config(opts, [{:livebook, :home, home} | config]) - end - defp opts_to_config([{:sname, sname} | opts], config) do sname = String.to_atom(sname) opts_to_config(opts, [{:livebook, :node, {:shortnames, sname}} | config])