From 972996374a6728e082bd08753c301b892d1daca1 Mon Sep 17 00:00:00 2001 From: Skye Soss Date: Mon, 3 Jul 2023 04:43:57 -0500 Subject: [PATCH] XDG Base Directory Compliance (#431) This uses xdg to load files in the right place. --- CHANGES.md | 3 +++ README.md | 2 +- dune-project | 3 ++- src/lib/dune | 2 +- src/lib/uTop.ml | 3 ++- src/lib/uTop_private.ml | 23 ++++++++++++++++++++++- src/lib/uTop_styles.ml | 3 ++- utop.opam | 1 + utoprc-dark | 2 +- utoprc-light | 2 +- 10 files changed, 36 insertions(+), 8 deletions(-) diff --git a/CHANGES.md b/CHANGES.md index ed9789fa..f5019ea3 100644 --- a/CHANGES.md +++ b/CHANGES.md @@ -1,6 +1,9 @@ 2.13.0 (unreleased) ------------------- +* Load files from XDG directories (the legacy paths still work). (#431, + @Skyb0rg007) + * Remove deprecated values `prompt_continue`, `prompt_comment`, `smart_accept`, `new_prompt_hooks`, `at_new_prompt` (#..., @emillon) diff --git a/README.md b/README.md index 2d4ea752..4ba1b456 100644 --- a/README.md +++ b/README.md @@ -63,7 +63,7 @@ Customization ### Colors To add colors to utop, copy one of the files `utoprc-dark` or -`utoprc-light` to `~/.utoprc`. `utoprc-dark` is for terminals with +`utoprc-light` to `~/.config/utop/utoprc`. `utoprc-dark` is for terminals with dark colors (such as white on black) and `utoprc-light` is for terminals with light colors (such as black on white). diff --git a/dune-project b/dune-project index 3bca72e4..46284469 100644 --- a/dune-project +++ b/dune-project @@ -26,4 +26,5 @@ (zed (>= 3.2.0)) (react (>= 1.0.0)) (cppo (>= 1.1.2)) - (alcotest :with-test))) + (alcotest :with-test) + (xdg (>= 3.9.0)))) diff --git a/src/lib/dune b/src/lib/dune index 4728b96a..1e1658e5 100644 --- a/src/lib/dune +++ b/src/lib/dune @@ -4,7 +4,7 @@ (wrapped false) (modes byte) (libraries compiler-libs.toplevel findlib.top lambda-term logs.lwt threads - zed) + xdg zed) (preprocess (action (run %{bin:cppo} -V OCAML:%{ocaml_version} %{input-file})))) diff --git a/src/lib/uTop.ml b/src/lib/uTop.ml index 85029764..dafcd728 100644 --- a/src/lib/uTop.ml +++ b/src/lib/uTop.ml @@ -23,9 +23,10 @@ let version = "%%VERSION%%" (* +-----------------------------------------------------------------+ | History | +-----------------------------------------------------------------+ *) +module Default_paths = UTop_private.Default_paths let history = LTerm_history.create [] -let history_file_name = ref (Some (Filename.concat LTerm_resources.home ".utop-history")) +let history_file_name = ref (Some (Default_paths.history_file_name)) let history_file_max_size = ref None let history_file_max_entries = ref None let stashable_session_history = UTop_history.create () diff --git a/src/lib/uTop_private.ml b/src/lib/uTop_private.ml index ba64c574..a694a9ad 100644 --- a/src/lib/uTop_private.ml +++ b/src/lib/uTop_private.ml @@ -9,6 +9,27 @@ open Lwt_react +module Default_paths = struct + let ( / ) = Filename.concat + let xdg = Xdg.create ~env:Sys.getenv_opt () + + let resolve ~legacy ~filename = + if Sys.file_exists legacy then + legacy + else + filename + + let history_file_name = + resolve + ~legacy:(LTerm_resources.home / ".utop-history") + ~filename:(Xdg.state_dir xdg / "utop-history") + + let config_file_name = + resolve + ~legacy:(LTerm_resources.home / ".utoprc") + ~filename:(Xdg.config_dir xdg / "utoprc") +end + let size, set_size = let ev, set_size = E.create () in let init = S.const { LTerm_geom.rows = 25; LTerm_geom.cols = 80 } in @@ -27,7 +48,7 @@ let ui, set_ui = S.create Console let error_style = ref LTerm_style.none -(* Config from ~/.utoprc *) +(* Config from $XDG_CONFIG_HOME/utop/utoprc *) let autoload = ref true let margin_function, set_margin_function = diff --git a/src/lib/uTop_styles.ml b/src/lib/uTop_styles.ml index 59f228ed..cd018e2b 100644 --- a/src/lib/uTop_styles.ml +++ b/src/lib/uTop_styles.ml @@ -12,6 +12,7 @@ open UTop_token let return, (>>=) = Lwt.return, Lwt.(>>=) module String_set = Set.Make (String) +module Default_paths = UTop_private.Default_paths type styles = { mutable style_keyword : LTerm_style.t; @@ -56,7 +57,7 @@ let styles = { } let load () = - let fn = Filename.concat LTerm_resources.home ".utoprc" in + let fn = Default_paths.config_file_name in Lwt.catch (fun () -> LTerm_resources.load fn >>= fun res -> diff --git a/utop.opam b/utop.opam index d6097154..7eb74ae8 100644 --- a/utop.opam +++ b/utop.opam @@ -23,6 +23,7 @@ depends: [ "react" {>= "1.0.0"} "cppo" {>= "1.1.2"} "alcotest" {with-test} + "xdg" {>= "3.9.0"} ] build: [ ["dune" "subst"] {pinned} diff --git a/utoprc-dark b/utoprc-dark index ec5dd697..2fc8c2ff 100644 --- a/utoprc-dark +++ b/utoprc-dark @@ -1,6 +1,6 @@ ! -*- conf-xdefaults -*- -! Copy this file to ~/.utoprc +! Copy this file to $XDG_CONFIG_HOME/utoprc (~/.config/utoprc) ! Common resources diff --git a/utoprc-light b/utoprc-light index 7a4fb9b1..0524712f 100644 --- a/utoprc-light +++ b/utoprc-light @@ -1,6 +1,6 @@ ! -*- conf-xdefaults -*- -! Copy this file to ~/.utoprc +! Copy this file to $XDG_CONFIG_HOME/utoprc (~/.config/utoprc) ! Common resources