* [bug#53238] [PATCH] gnu: tree: Remove stddata feature. @ 2022-01-13 20:33 Olivier Dion via Guix-patches via 2022-01-13 20:44 ` Tobias Geerinckx-Rice via Guix-patches via 0 siblings, 1 reply; 8+ messages in thread From: Olivier Dion via Guix-patches via @ 2022-01-13 20:33 UTC (permalink / raw) To: 53238; +Cc: Olivier Dion * gnu/packages/admin.scm (tree) [arguments]: Add 'remove-stddata-feature phase after 'unpack phase. Since version 2.0.0, there's a new feature call `stddata`. From the ChangeLog: -------------------------------------------------------------------------------- Output un-indented JSON on file descriptor 3 ("stddata") automatically if file descriptor 3 is present (currently Linux only.) Maybe switch to BSON. -------------------------------------------------------------------------------- This feature breaks some UNIX utilities. Fix it by disabling the feature. --- gnu/packages/admin.scm | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/gnu/packages/admin.scm b/gnu/packages/admin.scm index f11374a439..3d4909176a 100644 --- a/gnu/packages/admin.scm +++ b/gnu/packages/admin.scm @@ -2408,6 +2408,14 @@ (define-public tree (list #:phases #~(modify-phases %standard-phases + (add-after 'unpack 'remove-stddata-feature + (lambda _ + (substitute* "tree.h" + (("# define STDDATA_FILENO 3") + "")) + (substitute* "tree.c" + (("#ifdef __linux__") + "#ifdef STDDATA_FILENO")))) (delete 'configure)) ; No configure script. #:tests? #f ; No check target. #:make-flags -- 2.34.0 ^ permalink raw reply related [flat|nested] 8+ messages in thread
* [bug#53238] [PATCH] gnu: tree: Remove stddata feature. 2022-01-13 20:33 [bug#53238] [PATCH] gnu: tree: Remove stddata feature Olivier Dion via Guix-patches via @ 2022-01-13 20:44 ` Tobias Geerinckx-Rice via Guix-patches via 2022-01-13 20:57 ` Olivier Dion via Guix-patches via 0 siblings, 1 reply; 8+ messages in thread From: Tobias Geerinckx-Rice via Guix-patches via @ 2022-01-13 20:44 UTC (permalink / raw) To: Olivier Dion; +Cc: 53238 [-- Attachment #1: Type: text/plain, Size: 506 bytes --] Olivier, Thanks again for tracking down this weird bug! Olivier Dion via Guix-patches via 写道: > This feature breaks some UNIX utilities. Fix it by disabling > the feature. Hm… How long would we have to carry this fork? My fear is we'd do so indefinitely. How about creating a (possibly hidden) tree-without-stddata package variant, to use as input to packages who currently break with this feature enabled? That lets us refcount the need for it. Kind regards, T G-R [-- Attachment #2: signature.asc --] [-- Type: application/pgp-signature, Size: 247 bytes --] ^ permalink raw reply [flat|nested] 8+ messages in thread
* [bug#53238] [PATCH] gnu: tree: Remove stddata feature. 2022-01-13 20:44 ` Tobias Geerinckx-Rice via Guix-patches via @ 2022-01-13 20:57 ` Olivier Dion via Guix-patches via 2022-01-13 22:26 ` Maxim Cournoyer 2022-01-13 22:33 ` Tobias Geerinckx-Rice via Guix-patches via 0 siblings, 2 replies; 8+ messages in thread From: Olivier Dion via Guix-patches via @ 2022-01-13 20:57 UTC (permalink / raw) To: Tobias Geerinckx-Rice; +Cc: 53238 On Thu, 13 Jan 2022, Tobias Geerinckx-Rice <me@tobias.gr> wrote: > Olivier, > > Thanks again for tracking down this weird bug! > > Olivier Dion via Guix-patches via 写道: >> This feature breaks some UNIX utilities. Fix it by disabling >> the feature. > > Hm… How long would we have to carry this fork? My fear is we'd > do so indefinitely. I've contacted the maintainer asking for removal of the feature in its next release. I'm not sure if this will have some impact. Feel free to do the same at <ice+tree@mama.indstate.edu>, maybe adding more weight in the balance would help. > How about creating a (possibly hidden) tree-without-stddata > package variant, to use as input to packages who currently break > with this feature enabled? That lets us refcount the need for it. It's more than just packages, it's also user scripts that can be broken and believe me when I say that this is not an easy bug to track down ;-). -- Olivier Dion Polymtl ^ permalink raw reply [flat|nested] 8+ messages in thread
* [bug#53238] [PATCH] gnu: tree: Remove stddata feature. 2022-01-13 20:57 ` Olivier Dion via Guix-patches via @ 2022-01-13 22:26 ` Maxim Cournoyer 2022-01-13 22:33 ` Tobias Geerinckx-Rice via Guix-patches via 1 sibling, 0 replies; 8+ messages in thread From: Maxim Cournoyer @ 2022-01-13 22:26 UTC (permalink / raw) To: Olivier Dion; +Cc: Tobias Geerinckx-Rice, 53238 [-- Attachment #1: Type: text/plain, Size: 1326 bytes --] Hi, Olivier Dion <olivier.dion@polymtl.ca> writes: > On Thu, 13 Jan 2022, Tobias Geerinckx-Rice <me@tobias.gr> wrote: >> Olivier, >> >> Thanks again for tracking down this weird bug! >> >> Olivier Dion via Guix-patches via 写道: >>> This feature breaks some UNIX utilities. Fix it by disabling >>> the feature. >> >> Hm… How long would we have to carry this fork? My fear is we'd >> do so indefinitely. > > I've contacted the maintainer asking for removal of the feature in its > next release. I'm not sure if this will have some impact. Feel free to > do the same at <ice+tree@mama.indstate.edu>, maybe adding more weight > in the balance would help. > >> How about creating a (possibly hidden) tree-without-stddata >> package variant, to use as input to packages who currently break >> with this feature enabled? That lets us refcount the need for it. > > It's more than just packages, it's also user scripts that can be broken > and believe me when I say that this is not an easy bug to track down ;-). I'm on the fence about this, it does indeed seem an undesirable change, especially since there's a --json option, but I am not the author of the 'tree' software. Attached is an alternative that adjusts password-store instead of removing this new tree "feature"... [-- Warning: decoded text below may be mangled, UTF-8 assumed --] [-- Attachment #2: 0001-gnu-password-store-Fix-test-failure-following-tree-u.patch --] [-- Type: text/x-patch, Size: 2913 bytes --] From 2a30d95c46ff1eb0bdac9307c5d6bb8e460de02f Mon Sep 17 00:00:00 2001 From: Maxim Cournoyer <maxim.cournoyer@gmail.com> Date: Thu, 13 Jan 2022 15:09:54 -0500 Subject: [PATCH] gnu: password-store: Fix test failure following 'tree' update. Thanks to Olivier Dion <olivier.dion@polymtl.ca> for diagnosing the source of the problem! * gnu/packages/password-utils.scm (password-store): Delete trailing #t. [phases]{adjust-for-tree-2}: New phase. --- gnu/packages/password-utils.scm | 21 +++++++++++++++++---- 1 file changed, 17 insertions(+), 4 deletions(-) diff --git a/gnu/packages/password-utils.scm b/gnu/packages/password-utils.scm index 0ff8608c9c..16d889344b 100644 --- a/gnu/packages/password-utils.scm +++ b/gnu/packages/password-utils.scm @@ -487,6 +487,21 @@ (define-public password-store (arguments '(#:phases (modify-phases %standard-phases + (add-after 'unpack 'adjust-for-tree-2 + (lambda _ + ;; XXX: tree 2.0.1 has this new "stddata pipe" that is + ;; automatically used to output in JSON if the file descriptor 3 + ;; is available. This conflicts with the test harness use of + ;; file descriptor 3, causing one of the tests to fail. + ;; Increment the file descriptors used by the harness by one to + ;; avoid the conflict. + (substitute* "tests/sharness.sh" + (("exec 4>&2 3>&1") + "exec 5>&2 4>&1") + (("exec 4>/dev/null 3>/dev/null") + "exec 5>/dev/null 4>/dev/null") + (("&4") "&5") + (("&3") "&4")))) (delete 'configure) (delete 'build) (add-before 'install 'patch-system-extension-dir @@ -500,8 +515,7 @@ (define-public password-store (string-append " SYSTEM_EXTENSION_DIR=\"" "${PASSWORD_STORE_SYSTEM_EXTENSION_DIR:-" extension-dir - "}\"\n")))) - #t)) + "}\"\n")))))) (add-before 'install 'patch-passmenu-path ;; FIXME Wayland support requires ydotool and dmenu-wl packages ;; We are ignoring part of the script that gets executed if @@ -530,8 +544,7 @@ (define-public password-store '("coreutils" "getopt" "git" "gnupg" "qrencode" "sed" "tree" "which" "wl-clipboard" "xclip")))) (wrap-program (string-append out "/bin/pass") - `("PATH" ":" prefix (,(string-join path ":")))) - #t)))) + `("PATH" ":" prefix (,(string-join path ":")))))))) #:make-flags (list "CC=gcc" (string-append "PREFIX=" %output) "WITH_ALLCOMP=yes" (string-append "BASHCOMPDIR=" -- 2.34.0 [-- Attachment #3: Type: text/plain, Size: 16 bytes --] Thanks, Maxim ^ permalink raw reply related [flat|nested] 8+ messages in thread
* [bug#53238] [PATCH] gnu: tree: Remove stddata feature. 2022-01-13 20:57 ` Olivier Dion via Guix-patches via 2022-01-13 22:26 ` Maxim Cournoyer @ 2022-01-13 22:33 ` Tobias Geerinckx-Rice via Guix-patches via 2022-01-14 1:55 ` Olivier Dion via Guix-patches via 2022-01-15 14:37 ` bug#53238: " Tobias Geerinckx-Rice via Bug reports for GNU Guix 1 sibling, 2 replies; 8+ messages in thread From: Tobias Geerinckx-Rice via Guix-patches via @ 2022-01-13 22:33 UTC (permalink / raw) To: Olivier Dion; +Cc: 53238 [-- Attachment #1.1: Type: text/plain, Size: 1235 bytes --] Hullo Olivier, I was going to apply the patch below to fix the password-store package, but Maxime just submitted another version which I prefer. I'd rather not provide two trees in Guix. Olivier Dion 写道: > I've contacted the maintainer asking for removal of the feature > in its > next release. After some consideration, I think it's an interesting feature. Something like this is long overdue. I don't know if this approach is the right one, but I'll begrudgingly settle for JSON if it finally catches on… > It's more than just packages, it's also user scripts that can be > broken They can be fixed, or better yet rewritten. tree(1) is not tr(1). ‘Some lazy idiot could parse this with bash’ != ‘frozen API which upstream can never improve’. Really. …uh, I'm describing myself there, by the way ;-) I feel quite seen. Not that they needed to, but upstream even bumped the major revision along with this change. > and believe me when I say that this is not an easy bug to track > down ;-). Fully agree! I wasted too much time trying to track it down myself. I blame password-store's spaghetto of redirection more than tree. Kind regards, T G-R [-- Attachment #1.2: 0004-gnu-password-store-Fix-failing-test-suite.patch --] [-- Type: text/x-patch, Size: 2366 bytes --] From e100fedb52df07738c2d535928c6c9f98042e07f Mon Sep 17 00:00:00 2001 From: Tobias Geerinckx-Rice <me@tobias.gr> Date: Thu, 13 Jan 2022 13:45:25 +0000 Subject: [PATCH 04/26] gnu: password-store: Fix failing test suite. * gnu/packages/admin.scm (tree-1): New public variable. * gnu/packages/password-utils.scm (password-store)[inputs]: Use it rather than the default tree@2. Reported by Maxim Cournoyer <maxim.cournoyer@gmail.com> and Olivier Dion <olivier.dion@polymtl.ca>. --- gnu/packages/admin.scm | 20 ++++++++++++++++++++ gnu/packages/password-utils.scm | 3 ++- 2 files changed, 22 insertions(+), 1 deletion(-) diff --git a/gnu/packages/admin.scm b/gnu/packages/admin.scm index f11374a439..c2e656db1a 100644 --- a/gnu/packages/admin.scm +++ b/gnu/packages/admin.scm @@ -2421,6 +2421,26 @@ (define-public tree (home-page "http://mama.indstate.edu/users/ice/tree/") (license license:gpl2+))) +(define-public tree-1 + ;; tree 2.0.0 introduced a feature called ‘stddata’ that emits JSON when + ;; output is directed to file descriptor 3. At least password-store still + ;; requires the old version. + (package + (inherit tree) + (version "1.8.0") + (source (origin + (method url-fetch) + (uri (string-append + "http://mama.indstate.edu/users/ice/tree/src/tree-" + version ".tgz")) + (sha256 + (base32 "1hmpz6k0mr6salv0nprvm1g0rdjva1kx03bdf1scw8a38d5mspbi")))) + (arguments + (substitute-keyword-arguments (package-arguments tree) + ((#:make-flags flags '()) + #~(append #$flags + (list (string-append "prefix=" #$output)))))))) + (define-public lr (package (name "lr") diff --git a/gnu/packages/password-utils.scm b/gnu/packages/password-utils.scm index 0ff8608c9c..86af0deb47 100644 --- a/gnu/packages/password-utils.scm +++ b/gnu/packages/password-utils.scm @@ -552,7 +552,8 @@ (define-public password-store ("gnupg" ,gnupg) ("qrencode" ,qrencode) ("sed" ,sed) - ("tree" ,tree) + ;; XXX v1.7.4 tests are broken with tree@2: <issues.guix.gnu.org/53238>. + ("tree" ,tree-1) ("which" ,which) ("wl-clipboard" ,wl-clipboard) ("xclip" ,xclip) -- 2.34.0 [-- Attachment #2: signature.asc --] [-- Type: application/pgp-signature, Size: 247 bytes --] ^ permalink raw reply related [flat|nested] 8+ messages in thread
* [bug#53238] [PATCH] gnu: tree: Remove stddata feature. 2022-01-13 22:33 ` Tobias Geerinckx-Rice via Guix-patches via @ 2022-01-14 1:55 ` Olivier Dion via Guix-patches via 2022-01-14 2:05 ` Tobias Geerinckx-Rice via Guix-patches via 2022-01-15 14:37 ` bug#53238: " Tobias Geerinckx-Rice via Bug reports for GNU Guix 1 sibling, 1 reply; 8+ messages in thread From: Olivier Dion via Guix-patches via @ 2022-01-14 1:55 UTC (permalink / raw) To: Tobias Geerinckx-Rice; +Cc: 53238 On Thu, 13 Jan 2022, Tobias Geerinckx-Rice <me@tobias.gr> wrote: > Hullo Olivier, > > I was going to apply the patch below to fix the password-store > package, but Maxime just submitted another version which I prefer. > I'd rather not provide two trees in Guix. I'm fine with both solutions. In the end, password-store is not broken, only its test suite. > Olivier Dion 写道: >> I've contacted the maintainer asking for removal of the feature in >> its next release. > > After some consideration, I think it's an interesting feature. > Something like this is long overdue. > > I don't know if this approach is the right one, but I'll > begrudgingly settle for JSON if it finally catches on… Just to be clear that the JSON is still there with the switch -J. I just think that using some random file descriptor like this is a path to break many tools. Any program that open a file and try to do a popen(3) with "tree" for its output will get bitten by it. It's not like if `stddata` is some common knowledge outside of the PowerShell world. >> and believe me when I say that this is not an easy bug to track >> down ;-). > > Fully agree! I wasted too much time trying to track it down > myself. I blame password-store's spaghetto of redirection more > than tree. Happy to know I'm not the only one who spend way too much time on this ^^ -- Olivier Dion Polymtl ^ permalink raw reply [flat|nested] 8+ messages in thread
* [bug#53238] [PATCH] gnu: tree: Remove stddata feature. 2022-01-14 1:55 ` Olivier Dion via Guix-patches via @ 2022-01-14 2:05 ` Tobias Geerinckx-Rice via Guix-patches via 0 siblings, 0 replies; 8+ messages in thread From: Tobias Geerinckx-Rice via Guix-patches via @ 2022-01-14 2:05 UTC (permalink / raw) To: Olivier Dion; +Cc: 53238 [-- Attachment #1: Type: text/plain, Size: 223 bytes --] Olivier Dion 写道: > It's not like if > `stddata` is some common knowledge outside of the PowerShell > world. FWIW I had never heard of it. I'll admit it's not a good start in life. Kind regards, T G-R [-- Attachment #2: signature.asc --] [-- Type: application/pgp-signature, Size: 247 bytes --] ^ permalink raw reply [flat|nested] 8+ messages in thread
* bug#53238: [PATCH] gnu: tree: Remove stddata feature. 2022-01-13 22:33 ` Tobias Geerinckx-Rice via Guix-patches via 2022-01-14 1:55 ` Olivier Dion via Guix-patches via @ 2022-01-15 14:37 ` Tobias Geerinckx-Rice via Bug reports for GNU Guix 1 sibling, 0 replies; 8+ messages in thread From: Tobias Geerinckx-Rice via Bug reports for GNU Guix @ 2022-01-15 14:37 UTC (permalink / raw) To: Olivier Dion; +Cc: 53238, guix-patches [-- Attachment #1: Type: text/plain, Size: 554 bytes --] Olivier, Maxim(no -e, sorry! :-), Going by the number of bug reports, password-store is more popular than I thought. Tobias Geerinckx-Rice 写道: > I was going to apply the patch below to fix the password-store > package, but Maxime just submitted another version which I > prefer. I'd > rather not provide two trees in Guix. I haven't changed my mind, but I did push the tree-1 solution as a ‘temporary fix’ since it's the least invasive. If Maxim's patch LGTeveryone, please go ahead and replace. Kind regards, T G-R [-- Attachment #2: signature.asc --] [-- Type: application/pgp-signature, Size: 247 bytes --] ^ permalink raw reply [flat|nested] 8+ messages in thread
end of thread, other threads:[~2022-01-15 14:41 UTC | newest] Thread overview: 8+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2022-01-13 20:33 [bug#53238] [PATCH] gnu: tree: Remove stddata feature Olivier Dion via Guix-patches via 2022-01-13 20:44 ` Tobias Geerinckx-Rice via Guix-patches via 2022-01-13 20:57 ` Olivier Dion via Guix-patches via 2022-01-13 22:26 ` Maxim Cournoyer 2022-01-13 22:33 ` Tobias Geerinckx-Rice via Guix-patches via 2022-01-14 1:55 ` Olivier Dion via Guix-patches via 2022-01-14 2:05 ` Tobias Geerinckx-Rice via Guix-patches via 2022-01-15 14:37 ` bug#53238: " Tobias Geerinckx-Rice via Bug reports for GNU Guix
Code repositories for project(s) associated with this public inbox https://git.savannah.gnu.org/cgit/guix.git This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).