summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--system/less/APKBUILD11
-rw-r--r--system/less/search-path-history-file.patch88
-rw-r--r--system/less/search-path-lesskey-file.patch37
3 files changed, 133 insertions, 3 deletions
diff --git a/system/less/APKBUILD b/system/less/APKBUILD
index 29eb4916b..793d3bbab 100644
--- a/system/less/APKBUILD
+++ b/system/less/APKBUILD
@@ -1,7 +1,7 @@
# Contributor: Cameron Banta <cbanta@gmail.com>
# Maintainer: A. Wilcox <awilfox@adelielinux.org>
pkgname=less
-pkgver=581
+pkgver=590
pkgrel=0
pkgdesc="File pager"
url="http://www.greenwoodsoftware.com/less/"
@@ -10,7 +10,10 @@ license="BSD-2-Clause OR GPL-3.0+"
options="!check"
makedepends="ncurses-dev"
subpackages="$pkgname-doc"
-source="http://www.greenwoodsoftware.com/$pkgname/$pkgname-$pkgver.tar.gz"
+source="http://www.greenwoodsoftware.com/$pkgname/$pkgname-$pkgver.tar.gz
+ search-path-history-file.patch
+ search-path-lesskey-file.patch
+ "
prepare() {
default_prepare
@@ -32,4 +35,6 @@ package() {
make DESTDIR="$pkgdir" install
}
-sha512sums="b2892c73fb6e8a5cb5d5c22280c653194d6a1667a7d65a4b972a76038818cce827f1d00f266d6222e65f93fecfe1760d30109e9d2cf1aa6872b476b49eecefd9 less-581.tar.gz"
+sha512sums="426fa5840fd43c17bd5a452ad35ad24f2d6684623c6914403fd0059af62266bf2138e6828c7d73a1cef26a736c0d2b8ed4ab180eea8297281dae79a4228eb903 less-590.tar.gz
+d059a3b4e28c8c8473a9834e00eade8bb9ab14922235bf0344d71604ad656449dcb95763f7103a21d2443881d599178d333f1e4c88a4372d9cb526eb36ebd8b0 search-path-history-file.patch
+62d92ba9ae2e152cbf47d214f92a202591f901a68e74afa7a46fbaa6af1f6c38b76e067cf5c9f4fba2ee9602857c5900a0857d5402ebd593ab2410527b5f162d search-path-lesskey-file.patch"
diff --git a/system/less/search-path-history-file.patch b/system/less/search-path-history-file.patch
new file mode 100644
index 000000000..7ec0ce9f1
--- /dev/null
+++ b/system/less/search-path-history-file.patch
@@ -0,0 +1,88 @@
+From 5e1f4ce2c3a2c0fd6a953c4f7ca2839370f9c3ae Mon Sep 17 00:00:00 2001
+From: Mark Nudelman <markn@greenwoodsoftware.com>
+Date: Fri, 3 Dec 2021 09:38:22 -0800
+Subject: [PATCH] Add $XDG_STATE_HOME and $HOME/.local/state to list of
+ directories to search for the history file.
+
+---
+ cmdbuf.c | 48 ++++++++++++++++++++++++++++++++----------------
+ less.nro.VER | 6 +++---
+ 2 files changed, 35 insertions(+), 19 deletions(-)
+
+diff --git a/cmdbuf.c b/cmdbuf.c
+index cd99010d..abbda9b9 100644
+--- a/cmdbuf.c
++++ b/cmdbuf.c
+@@ -1401,14 +1401,41 @@ mlist_size(ml)
+ /*
+ * Get the name of the history file.
+ */
++ static char *
++histfile_find(must_exist)
++ int must_exist;
++{
++ char *home = lgetenv("HOME");
++ char *name = NULL;
++
++ /* Try in $XDG_DATA_STATE, then in $HOME/.local/state, then in $XDG_DATA_HOME, then in $HOME. */
++#if OS2
++ if (isnullenv(home))
++ home = lgetenv("INIT");
++#endif
++ name = dirfile(lgetenv("XDG_STATE_HOME"), &LESSHISTFILE[1], must_exist);
++ if (name == NULL)
++ {
++ char *dir = dirfile(home, ".local/state", 1);
++ if (dir != NULL)
++ {
++ name = dirfile(dir, &LESSHISTFILE[1], must_exist);
++ free(dir);
++ }
++ }
++ if (name == NULL)
++ name = dirfile(lgetenv("XDG_DATA_HOME"), &LESSHISTFILE[1], must_exist);
++ if (name == NULL)
++ name = dirfile(home, LESSHISTFILE, must_exist);
++ return (name);
++}
++
+ static char *
+ histfile_name(must_exist)
+ int must_exist;
+ {
+- char *home;
+- char *xdg;
+ char *name;
+-
++
+ /* See if filename is explicitly specified by $LESSHISTFILE. */
+ name = lgetenv("LESSHISTFILE");
+ if (!isnullenv(name))
+@@ -1423,25 +1450,14 @@ histfile_name(must_exist)
+ if (strcmp(LESSHISTFILE, "") == 0 || strcmp(LESSHISTFILE, "-") == 0)
+ return (NULL);
+
+- /* Try in $XDG_DATA_HOME first, then in $HOME. */
+- xdg = lgetenv("XDG_DATA_HOME");
+- home = lgetenv("HOME");
+-#if OS2
+- if (isnullenv(home))
+- home = lgetenv("INIT");
+-#endif
+ name = NULL;
+ if (!must_exist)
+ {
+ /* If we're writing the file and the file already exists, use it. */
+- name = dirfile(xdg, &LESSHISTFILE[1], 1);
+- if (name == NULL)
+- name = dirfile(home, LESSHISTFILE, 1);
++ name = histfile_find(1);
+ }
+ if (name == NULL)
+- name = dirfile(xdg, &LESSHISTFILE[1], must_exist);
+- if (name == NULL)
+- name = dirfile(home, LESSHISTFILE, must_exist);
++ name = histfile_find(must_exist);
+ return (name);
+ }
+
diff --git a/system/less/search-path-lesskey-file.patch b/system/less/search-path-lesskey-file.patch
new file mode 100644
index 000000000..422376930
--- /dev/null
+++ b/system/less/search-path-lesskey-file.patch
@@ -0,0 +1,37 @@
+From d3edebf528da8a9e15d6be518c24e90462a28698 Mon Sep 17 00:00:00 2001
+From: Mark Nudelman <markn@greenwoodsoftware.com>
+Date: Tue, 19 Oct 2021 14:24:04 -0700
+Subject: [PATCH] Add $HOME/.config to possible locations of lesskey file.
+
+---
+ NEWS | 4 ++++
+ decode.c | 13 ++++++++++++-
+ less.nro.VER | 2 +-
+ 3 files changed, 17 insertions(+), 2 deletions(-)
+
+diff --git a/decode.c b/decode.c
+index e1a55198..2eb480fa 100644
+--- a/decode.c
++++ b/decode.c
+@@ -952,9 +952,20 @@ add_hometable(call_lesskey, envname, def_filename, sysvar)
+ filename = save(def_filename);
+ else /* def_filename is just basename */
+ {
++ /* Remove first char (normally a dot) unless stored in $HOME. */
+ char *xdg = lgetenv("XDG_CONFIG_HOME");
+ if (!isnullenv(xdg))
+- filename = dirfile(xdg, def_filename+1, 1);
++ filename = dirfile(xdg, &def_filename[1], 1);
++ if (filename == NULL)
++ {
++ char *home = lgetenv("HOME");
++ if (!isnullenv(home))
++ {
++ char *cfg_dir = dirfile(home, ".config", 0);
++ filename = dirfile(cfg_dir, &def_filename[1], 1);
++ free(cfg_dir);
++ }
++ }
+ if (filename == NULL)
+ filename = homefile(def_filename);
+ }