all messages for Guix-related lists mirrored at yhetil.org
 help / color / mirror / code / Atom feed
* bug#30785: Man pages truncated, repeated
@ 2018-03-12 21:24 Tobias Geerinckx-Rice
  2018-03-13 21:34 ` Ludovic Courtès
                   ` (6 more replies)
  0 siblings, 7 replies; 57+ messages in thread
From: Tobias Geerinckx-Rice @ 2018-03-12 21:24 UTC (permalink / raw)
  To: 30785

Guix,

Perhaps he's just getting old, but our man has a tendency to forget 
where he was, start over from the beginning, and repeat himself several 
times:

   $ guix package -i knot rofi
   $ man 5 knot.conf | grep -E '^(NAME|DESCRIPTION)'
   NAME
   DESCRIPTION
   NAME
   DESCRIPTION
   NAME
   DESCRIPTION
   NAME
   DESCRIPTION
   NAME
   $

There's also some stderr...

   <standard input>:25: error: end of file while defining macro 
`UNINDENT'

...but I think that's just a symptom of the input being cut short; man 
rofi(1) prints no such error yet suffers the same fate.

The affected man pages themselves are not truncated, nor do they repeat:

   $ zgrep '\.SH' `man -w knot.conf`
   .SH NAME
   .SH DESCRIPTION
   .SH COMMENTS
   .SH INCLUDES
   .SH MODULE SECTION
   .SH SERVER SECTION
   .SH KEY SECTION
   .SH ACL SECTION
   .SH CONTROL SECTION
   .SH STATISTICS SECTION
   .SH KEYSTORE SECTION
   .SH SUBMISSION SECTION
   .SH POLICY SECTION
   .SH REMOTE SECTION
   .SH TEMPLATE SECTION
   .SH ZONE SECTION
   .SH LOGGING SECTION
   .SH AUTHOR
   .SH COPYRIGHT
   $

However, even longer man pages such as bash(1) render without fail, so 
there might be something special about the two examples above that 
triggers this behaviour.

Kind regards,

T G-R

Sent from a Web browser. Excuse or enjoy my brevity.

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2018-03-12 21:24 bug#30785: Man pages truncated, repeated Tobias Geerinckx-Rice
@ 2018-03-13 21:34 ` Ludovic Courtès
  2018-03-13 22:01   ` Tobias Geerinckx-Rice
  2018-03-14 13:43 ` Andreas Enge
                   ` (5 subsequent siblings)
  6 siblings, 1 reply; 57+ messages in thread
From: Ludovic Courtès @ 2018-03-13 21:34 UTC (permalink / raw)
  To: Tobias Geerinckx-Rice; +Cc: 30785

Hello,

Tobias Geerinckx-Rice <me@tobias.gr> skribis:

> Perhaps he's just getting old, but our man has a tendency to forget
> where he was, start over from the beginning, and repeat himself
> several times:
>
>   $ guix package -i knot rofi
>   $ man 5 knot.conf | grep -E '^(NAME|DESCRIPTION)'

[...]

> However, even longer man pages such as bash(1) render without fail, so
> there might be something special about the two examples above that
> triggers this behaviour.

I suspect something wrong with ‘knot.conf.5.gz’, but I don’t have
tangible evidence.

Ludo’.

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2018-03-13 21:34 ` Ludovic Courtès
@ 2018-03-13 22:01   ` Tobias Geerinckx-Rice
  2018-03-14 13:22     ` Ludovic Courtès
  0 siblings, 1 reply; 57+ messages in thread
From: Tobias Geerinckx-Rice @ 2018-03-13 22:01 UTC (permalink / raw)
  To: ludo; +Cc: 30785

Ludo',

On 2018-03-13 22:34, ludo@gnu.org wrote:
>> However, even longer man pages such as bash(1) render without fail, so
>> there might be something special about the two examples above that
>> triggers this behaviour.
> 
> I suspect something wrong with ‘knot.conf.5.gz’, but I don’t have
> tangible evidence.

Yup, that's about as far as I got before giving up and submitting to the 
wisdom of the crowd. We need someone who knows something — anything — 
about man pages, or someone who can reproduce this on another distro. I 
had no luck searching for similar bug reports.

...or do you mean with the knot.conf page *specifically*, as opposed to 
the rofi one? Is your suspicion based on something you saw in there?

It's not the .gz part: opening the uncompressed page with man directly 
has the same result.

--

For the record: apparently this doesn't happen on Debian, according to 
some fellow on IRC named ‘civodul’. There goes my brief hope that this 
was an (exclusively) upstream problem after all.

Kind regards,

T G-R

Sent from a Web browser. Excuse or enjoy my brevity.

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2018-03-13 22:01   ` Tobias Geerinckx-Rice
@ 2018-03-14 13:22     ` Ludovic Courtès
  0 siblings, 0 replies; 57+ messages in thread
From: Ludovic Courtès @ 2018-03-14 13:22 UTC (permalink / raw)
  To: Tobias Geerinckx-Rice; +Cc: 30785

Hi,

Tobias Geerinckx-Rice <me@tobias.gr> skribis:

> On 2018-03-13 22:34, ludo@gnu.org wrote:
>>> However, even longer man pages such as bash(1) render without fail, so
>>> there might be something special about the two examples above that
>>> triggers this behaviour.
>>
>> I suspect something wrong with ‘knot.conf.5.gz’, but I don’t have
>> tangible evidence.
>
> Yup, that's about as far as I got before giving up and submitting to
> the wisdom of the crowd. We need someone who knows something —
> anything — about man pages, or someone who can reproduce this on
> another distro. I had no luck searching for similar bug reports.
>
> ...or do you mean with the knot.conf page *specifically*, as opposed
> to the rofi one? Is your suspicion based on something you saw in
> there?

I didn’t check the rofi one.  The knot.conf one is generated by some
“docutils”, a reStructuredText thing, which is where my unfounded
suspicion comes from.  :-)

We’d need to analyze the nroff “code” in there to understand what’s
going on.

> For the record: apparently this doesn't happen on Debian, according to
> some fellow on IRC named ‘civodul’. There goes my brief hope that this
> was an (exclusively) upstream problem after all.

I think I know that person.  ;-)  Perhaps we could check how Debian
generates the page.  Do they have a patch for “docutils”?  Should we try
with a different version to see if that helps?

Cheers,
Ludo’.

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2018-03-12 21:24 bug#30785: Man pages truncated, repeated Tobias Geerinckx-Rice
  2018-03-13 21:34 ` Ludovic Courtès
@ 2018-03-14 13:43 ` Andreas Enge
  2018-03-15  0:40 ` Marius Bakke
                   ` (4 subsequent siblings)
  6 siblings, 0 replies; 57+ messages in thread
From: Andreas Enge @ 2018-03-14 13:43 UTC (permalink / raw)
  To: Tobias Geerinckx-Rice; +Cc: 30785

Hello,

On Mon, Mar 12, 2018 at 10:24:46PM +0100, Tobias Geerinckx-Rice wrote:
>   $ man 5 knot.conf | grep -E '^(NAME|DESCRIPTION)'
>   NAME
>   DESCRIPTION
>   NAME
>   DESCRIPTION
>   NAME
>   DESCRIPTION
>   NAME
>   DESCRIPTION
>   NAME
>   $
> 
> There's also some stderr...
>   <standard input>:25: error: end of file while defining macro `UNINDENT'

with Guix on Debian (git commit 464f5447396fcec9b43f7eab71d5d42b522a157f),
I am not seeing this problem:
$ man 5 knot.conf | grep -E '^(NAME|DESCRIPTION)'
NAME
DESCRIPTION

and no stderr. This uses the "man" binary from Debian (/usr/bin/man) and
/gnu/store/a9w7mm0mrgrakl9khmi91ybp34ly4iqc-knot-2.6.5/share/man/man5/knot.conf.5.gz

What is your distribution? Could it be that the problem is in the "man" binary and
not in the man page?

Actually, also this does work:
$ /gnu/store/kh2av28w5rd3fbidqssp0fzv661hb9l5-man-db-2.7.6.1/bin/man 5 knot.conf | grep -E '^(NAME|DESCRIPTION)'
NAME
DESCRIPTION

Maybe your store is corrupted?

Or did I misunderstand the problem?

Andreas

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2018-03-12 21:24 bug#30785: Man pages truncated, repeated Tobias Geerinckx-Rice
  2018-03-13 21:34 ` Ludovic Courtès
  2018-03-14 13:43 ` Andreas Enge
@ 2018-03-15  0:40 ` Marius Bakke
  2018-05-05 21:40   ` Marius Bakke
  2018-05-05  1:31 ` Vagrant Cascadian
                   ` (3 subsequent siblings)
  6 siblings, 1 reply; 57+ messages in thread
From: Marius Bakke @ 2018-03-15  0:40 UTC (permalink / raw)
  To: Tobias Geerinckx-Rice, 30785

[-- Attachment #1: Type: text/plain, Size: 681 bytes --]

Tobias Geerinckx-Rice <me@tobias.gr> writes:

> Guix,
>
> Perhaps he's just getting old, but our man has a tendency to forget 
> where he was, start over from the beginning, and repeat himself several 
> times:
>
>    $ guix package -i knot rofi
>    $ man 5 knot.conf | grep -E '^(NAME|DESCRIPTION)'
>    NAME
>    DESCRIPTION
>    NAME
>    DESCRIPTION
>    NAME
>    DESCRIPTION
>    NAME
>    DESCRIPTION
>    NAME
>    $

One thing rofi.1 and knot.conf.5 have in common is that they are both
unicode.  Whereas working pages are ASCII.

I've tried running groff and nroff manually on rofi.1, but haven't been
able to reproduce the duplicate sections.

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 487 bytes --]

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2018-03-12 21:24 bug#30785: Man pages truncated, repeated Tobias Geerinckx-Rice
                   ` (2 preceding siblings ...)
  2018-03-15  0:40 ` Marius Bakke
@ 2018-05-05  1:31 ` Vagrant Cascadian
  2018-08-20 10:32 ` Pierre Neidhardt
                   ` (2 subsequent siblings)
  6 siblings, 0 replies; 57+ messages in thread
From: Vagrant Cascadian @ 2018-05-05  1:31 UTC (permalink / raw)
  To: 30785

[-- Attachment #1: Type: text/plain, Size: 1331 bytes --]

On 2018-03-12, Tobias Geerinckx-Rice wrote:
> Perhaps he's just getting old, but our man has a tendency to forget 
> where he was, start over from the beginning, and repeat himself several 
> times:
>
>    $ guix package -i knot rofi
>    $ man 5 knot.conf | grep -E '^(NAME|DESCRIPTION)'
>    NAME
>    DESCRIPTION
>    NAME

I'm seeing this same behavior with the gpg-agent manpage as well, for
what it's worth.

  $ man gpg-agent | grep ^NAME
  <standard input>:172: warning [p 2, 10.5i]: cannot
  adjust line
  <standard input>:172: warning [p 6, 4.8i]: cannot
  adjust line
  NAME
  <standard input>:172: warning [p 9, 10.0i]: cannot
  adjust line
  NAME
  NAME
  NAME

Grepping the file directly:

  $ zgrep NAME $(dirname $(readlink $(which gpg)))/../share/man/man1/gpg-agent.1.gz
  .SH NAME
  identified in the environment variable
  \fBLISTEN_FDNAMES\fR (see
  

Interestingly enough, gpg manpage from the same package doesn't seem to
have the issue:

  $ man gpg | grep ^NAME
  NAME
  <standard input>:1481: warning [p 19, 7.2i]: cannot adjust line

I've also copied the gpg-agent.1.gz file to a Debian system running the
same upstream version of man 2.8.3, and that has no issue. So it's
something specific to the guix version of the "man" command.


live well,
  vagrant

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 832 bytes --]

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2018-03-15  0:40 ` Marius Bakke
@ 2018-05-05 21:40   ` Marius Bakke
  2018-05-06 13:53     ` Marius Bakke
  0 siblings, 1 reply; 57+ messages in thread
From: Marius Bakke @ 2018-05-05 21:40 UTC (permalink / raw)
  To: Tobias Geerinckx-Rice, 30785


[-- Attachment #1.1: Type: text/plain, Size: 820 bytes --]

Marius Bakke <mbakke@fastmail.com> writes:

> Tobias Geerinckx-Rice <me@tobias.gr> writes:
>
>> Guix,
>>
>> Perhaps he's just getting old, but our man has a tendency to forget 
>> where he was, start over from the beginning, and repeat himself several 
>> times:
>>
>>    $ guix package -i knot rofi
>>    $ man 5 knot.conf | grep -E '^(NAME|DESCRIPTION)'
>>    NAME
>>    DESCRIPTION
>>    NAME
>>    DESCRIPTION
>>    NAME
>>    DESCRIPTION
>>    NAME
>>    DESCRIPTION
>>    NAME
>>    $
>
> One thing rofi.1 and knot.conf.5 have in common is that they are both
> unicode.  Whereas working pages are ASCII.

This ultimately turned out to be due to man-db not finding "preconv".

The attached patches fixes it.

Adding preconv adds ~0.1 MiB to the groff-minimal closure size.

WDYT?


[-- Warning: decoded text below may be mangled, UTF-8 assumed --]
[-- Attachment #1.2: bug-30785.patch --]
[-- Type: text/x-patch, Size: 3040 bytes --]

From 42b43fca11ab1f9417499aea252ae7a871a53b1b Mon Sep 17 00:00:00 2001
From: Marius Bakke <mbakke@fastmail.com>
Date: Sat, 5 May 2018 23:13:16 +0200
Subject: [PATCH 1/2] gnu: groff-minimal: Preserve 'preconv' executable.

* gnu/packages/groff.scm (groff-minimal)[arguments]: Add 'preconv' to the list
of kept programs.
---
 gnu/packages/groff.scm | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/gnu/packages/groff.scm b/gnu/packages/groff.scm
index 5f1b8d0ed..77728a5d7 100644
--- a/gnu/packages/groff.scm
+++ b/gnu/packages/groff.scm
@@ -101,7 +101,7 @@ is usually the formatter of \"man\" documentation pages.")
                    ;; Keep only the programs that man-db needs at run time,
                    ;; and make sure we don't pull in Perl.
                    (let ((out  (assoc-ref outputs "out"))
-                         (kept '("eqn" "neqn" "pic" "tbl" "refer"
+                         (kept '("eqn" "neqn" "pic" "tbl" "refer" "preconv"
                                  "nroff" "groff" "troff" "grotty")))
                      (for-each (lambda (file)
                                  (unless (member (basename file) kept)
-- 
2.17.0


From 095d0db7db77261f59e6582af3a9b18b61dcb630 Mon Sep 17 00:00:00 2001
From: Marius Bakke <mbakke@fastmail.com>
Date: Sat, 5 May 2018 23:30:04 +0200
Subject: [PATCH 2/2] gnu: man-db: Embed absolute reference to 'preconv'.

Fixes <https://bugs.gnu.org/30785>.
Reported by Tobias Geerinckx-Rice <me@tobias.gr>.

* gnu/packages/man.scm (man-db)[arguments]: Rename 'patch-iconv-path' to
'patch-absolute-paths'.  Add substitution for "preconv".
---
 gnu/packages/man.scm | 10 +++++++++-
 1 file changed, 9 insertions(+), 1 deletion(-)

diff --git a/gnu/packages/man.scm b/gnu/packages/man.scm
index ca6fd351d..f0bb2b66e 100644
--- a/gnu/packages/man.scm
+++ b/gnu/packages/man.scm
@@ -80,11 +80,19 @@ a flexible and convenient way.")
                               (string-append "#!" (which "sh")))))
                          (remove file-is-directory?
                                  (find-files "src/tests" ".*"))))))
-         (add-after 'unpack 'patch-iconv-path
+         (add-after 'unpack 'patch-absolute-paths
            (lambda* (#:key inputs #:allow-other-keys)
              (substitute* "src/man.c"
                (("\"iconv\"")
                 (string-append "\"" (which "iconv") "\"")))
+             ;; Embed an absolute reference to "preconv", otherwise it
+             ;; falls back to searching in PATH and ultimately fails
+             ;; to render unicode data (see <https://bugs.gnu.org/30785>).
+             (substitute* "lib/encodings.c"
+               (("groff_preconv = NULL")
+                (string-append "groff_preconv = \""
+                               (assoc-ref inputs "groff-minimal")
+                               "/bin/preconv\"")))
              #t)))
        #:configure-flags
        (let ((groff (assoc-ref %build-inputs "groff"))
-- 
2.17.0


[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 487 bytes --]

^ permalink raw reply related	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2018-05-05 21:40   ` Marius Bakke
@ 2018-05-06 13:53     ` Marius Bakke
  2018-05-06 22:06       ` Marius Bakke
  0 siblings, 1 reply; 57+ messages in thread
From: Marius Bakke @ 2018-05-06 13:53 UTC (permalink / raw)
  To: Tobias Geerinckx-Rice, 30785-done

[-- Attachment #1: Type: text/plain, Size: 885 bytes --]

Marius Bakke <mbakke@fastmail.com> writes:

> Marius Bakke <mbakke@fastmail.com> writes:
>
>> Tobias Geerinckx-Rice <me@tobias.gr> writes:
>>
>>> Guix,
>>>
>>> Perhaps he's just getting old, but our man has a tendency to forget 
>>> where he was, start over from the beginning, and repeat himself several 
>>> times:
>>>
>>>    $ guix package -i knot rofi
>>>    $ man 5 knot.conf | grep -E '^(NAME|DESCRIPTION)'
>>>    NAME
>>>    DESCRIPTION
>>>    NAME
>>>    DESCRIPTION
>>>    NAME
>>>    DESCRIPTION
>>>    NAME
>>>    DESCRIPTION
>>>    NAME
>>>    $
>>
>> One thing rofi.1 and knot.conf.5 have in common is that they are both
>> unicode.  Whereas working pages are ASCII.
>
> This ultimately turned out to be due to man-db not finding "preconv".
>
> The attached patches fixes it.

I pushed the fix as 296551a2e9310d4a030ee49530e9367e73aaeecf.

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 487 bytes --]

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2018-05-06 13:53     ` Marius Bakke
@ 2018-05-06 22:06       ` Marius Bakke
  0 siblings, 0 replies; 57+ messages in thread
From: Marius Bakke @ 2018-05-06 22:06 UTC (permalink / raw)
  To: Tobias Geerinckx-Rice, 30785

reopen 30785

Marius Bakke <mbakke@fastmail.com> writes:

> Marius Bakke <mbakke@fastmail.com> writes:
>
>> Marius Bakke <mbakke@fastmail.com> writes:
>>
>>> Tobias Geerinckx-Rice <me@tobias.gr> writes:
>>>
>>>> Guix,
>>>>
>>>> Perhaps he's just getting old, but our man has a tendency to forget 
>>>> where he was, start over from the beginning, and repeat himself several 
>>>> times:
>>>>
>>>>    $ guix package -i knot rofi
>>>>    $ man 5 knot.conf | grep -E '^(NAME|DESCRIPTION)'
>>>>    NAME
>>>>    DESCRIPTION
>>>>    NAME
>>>>    DESCRIPTION
>>>>    NAME
>>>>    DESCRIPTION
>>>>    NAME
>>>>    DESCRIPTION
>>>>    NAME
>>>>    $
>>>
>>> One thing rofi.1 and knot.conf.5 have in common is that they are both
>>> unicode.  Whereas working pages are ASCII.
>>
>> This ultimately turned out to be due to man-db not finding "preconv".
>>
>> The attached patches fixes it.
>
> I pushed the fix as 296551a2e9310d4a030ee49530e9367e73aaeecf.

This patch caused `man` to segfault when invoked outside `guix
environment`(!) so I reverted it for now.

To be continued...

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2018-03-12 21:24 bug#30785: Man pages truncated, repeated Tobias Geerinckx-Rice
                   ` (3 preceding siblings ...)
  2018-05-05  1:31 ` Vagrant Cascadian
@ 2018-08-20 10:32 ` Pierre Neidhardt
  2019-01-13 16:09 ` Pierre Neidhardt
  2021-04-22 18:53 ` G. Branden Robinson
  6 siblings, 0 replies; 57+ messages in thread
From: Pierre Neidhardt @ 2018-08-20 10:32 UTC (permalink / raw)
  To: 30785

[-- Attachment #1: Type: text/plain, Size: 489 bytes --]

The 'man' program from the 'man-db' Guix package has an issue with UTF-8
man pages: the page is truncated and sometimes the truncation is
repeated a couple of times.

The bug does not occur when non-ASCII characters are removed.
I haven't tried with other non-ASCII encodings.

There must be something wrong with the way we package man-db.

See https://lists.gnu.org/archive/html/help-guix/2018-05/msg00084.html
for a discussion.

-- 
Pierre Neidhardt
https://ambrevar.xyz/

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 487 bytes --]

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2018-03-12 21:24 bug#30785: Man pages truncated, repeated Tobias Geerinckx-Rice
                   ` (4 preceding siblings ...)
  2018-08-20 10:32 ` Pierre Neidhardt
@ 2019-01-13 16:09 ` Pierre Neidhardt
  2019-01-13 16:15   ` Pierre Neidhardt
  2021-04-22 18:53 ` G. Branden Robinson
  6 siblings, 1 reply; 57+ messages in thread
From: Pierre Neidhardt @ 2019-01-13 16:09 UTC (permalink / raw)
  To: 30785, Tobias Geerinckx-Rice, Christopher Baines,
	Ludovic Courtès

[-- Attachment #1: Type: text/plain, Size: 1526 bytes --]

Great news, I've (finally) made some progress!

On a suggestion from Christopher Baines, I compared the strace of a
working man and Guix' man.
I noticed that Guix man failed to find "preconv".

If I install groff-minimal into my user profile, the issue disappears
indeed.  So it's just a matter of letting man-db find preconv.

I've tried the following substitution:

--8<---------------cut here---------------start------------->8---
(substitute* "lib/encodings.c"
               (("const char \\*groff_preconv = NULL;")
                (string-append "const char *groff_preconv = \""
                               (assoc-ref inputs "groff-minimal")
                               "/bin/preconv"
                               "\";")))
--8<---------------cut here---------------end--------------->8---

Surprisingly, man only displays this on every call:

--8<---------------cut here---------------start------------->8---
/gnu/store/6dv1q0s8rlf1ndaqx2qhnkiz9x4840ba-man-db-2.8.3/bin/man: /gnu/store/mpjn4jfx5i8jxblfj538n22hv56rdnhw-groff-minimal-1.22.3/bin/preconv: Segmentation fault
--8<---------------cut here---------------end--------------->8---

However, calling

--8<---------------cut here---------------start------------->8---
echo "hêlló"  | /gnu/store/mpjn4jfx5i8jxblfj538n22hv56rdnhw-groff-minimal-1.22.3/bin/preconv -e UTF-8
--8<---------------cut here---------------end--------------->8---

works.

I'm stuck here...  Anyone?

-- 
Pierre Neidhardt
https://ambrevar.xyz/

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 487 bytes --]

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-13 16:09 ` Pierre Neidhardt
@ 2019-01-13 16:15   ` Pierre Neidhardt
  2019-01-13 17:00     ` Ludovic Courtès
  0 siblings, 1 reply; 57+ messages in thread
From: Pierre Neidhardt @ 2019-01-13 16:15 UTC (permalink / raw)
  To: 30785, Tobias Geerinckx-Rice, Christopher Baines,
	Ludovic Courtès, Marius Bakke

[-- Attachment #1: Type: text/plain, Size: 210 bytes --]

And... from the log I just noticed that Marius had arrived to the same
conclusion 8 months ago :(

That'll teach me to look at logs before getting started...

-- 
Pierre Neidhardt
https://ambrevar.xyz/

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 487 bytes --]

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-13 16:15   ` Pierre Neidhardt
@ 2019-01-13 17:00     ` Ludovic Courtès
  2019-01-13 17:31       ` Pierre Neidhardt
  0 siblings, 1 reply; 57+ messages in thread
From: Ludovic Courtès @ 2019-01-13 17:00 UTC (permalink / raw)
  To: Pierre Neidhardt; +Cc: 30785

Pierre Neidhardt <mail@ambrevar.xyz> skribis:

> And... from the log I just noticed that Marius had arrived to the same
> conclusion 8 months ago :(
>
> That'll teach me to look at logs before getting started...

Heheh.  :-)

Another useful debugging tip is setting PIPELINE_DEBUG=1.

Anyway I hope we’ll soon squash that bug!

Ludo’.

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-13 17:00     ` Ludovic Courtès
@ 2019-01-13 17:31       ` Pierre Neidhardt
  2019-01-13 17:43         ` Pierre Neidhardt
  0 siblings, 1 reply; 57+ messages in thread
From: Pierre Neidhardt @ 2019-01-13 17:31 UTC (permalink / raw)
  To: Ludovic Courtès; +Cc: 30785

[-- Attachment #1: Type: text/plain, Size: 5500 bytes --]

Indeed.  So the reason that there is an issue at all is that man-db uses
libpipeline to run a pipeline of programs.

I've used Ludo's trick to see if could get more details:

--8<---------------cut here---------------start------------->8---
ambrevar@mimimi ~/projects/guix/gnu/packages$ PIPELINE_DEBUG=1 /gnu/store/fm7jlkf93bh7bw03m8hbha2b5qxjz0kz-man-db-2.8.3/bin/man emacs
Starting pipeline: /gnu/store/h0c398zan9ibhk4w0c944vp5pwgzkfpd-gzip-1.9/bin/gzip -dc /gnu/store/gppr8msvzgxr87psbj3w6hc07lnnzpvx-emacs-26.1/share/man/man1/emacs.1.gz [input: {0, /gnu/store/gppr8msvzgxr87psbj3w6hc07lnnzpvx-emacs-26.1/share/man/man1/emacs.1.gz}, output: {-1, NULL}]
Started "/gnu/store/h0c398zan9ibhk4w0c944vp5pwgzkfpd-gzip-1.9/bin/gzip", pid 13814
Waiting for pipeline: /gnu/store/h0c398zan9ibhk4w0c944vp5pwgzkfpd-gzip-1.9/bin/gzip -dc /gnu/store/gppr8msvzgxr87psbj3w6hc07lnnzpvx-emacs-26.1/share/man/man1/emacs.1.gz [input: {0, /gnu/store/gppr8msvzgxr87psbj3w6hc07lnnzpvx-emacs-26.1/share/man/man1/emacs.1.gz}, output: {-1, NULL}]
Active processes (1):
  "/gnu/store/h0c398zan9ibhk4w0c944vp5pwgzkfpd-gzip-1.9/bin/gzip" (13814) -> 0
Starting pipeline: /gnu/store/h0c398zan9ibhk4w0c944vp5pwgzkfpd-gzip-1.9/bin/gzip -dc /gnu/store/gppr8msvzgxr87psbj3w6hc07lnnzpvx-emacs-26.1/share/man/man1/emacs.1.gz [input: {0, /gnu/store/gppr8msvzgxr87psbj3w6hc07lnnzpvx-emacs-26.1/share/man/man1/emacs.1.gz}, output: {-1, NULL}]
Started "/gnu/store/h0c398zan9ibhk4w0c944vp5pwgzkfpd-gzip-1.9/bin/gzip", pid 13815
Waiting for pipeline: /gnu/store/h0c398zan9ibhk4w0c944vp5pwgzkfpd-gzip-1.9/bin/gzip -dc /gnu/store/gppr8msvzgxr87psbj3w6hc07lnnzpvx-emacs-26.1/share/man/man1/emacs.1.gz [input: {0, /gnu/store/gppr8msvzgxr87psbj3w6hc07lnnzpvx-emacs-26.1/share/man/man1/emacs.1.gz}, output: {-1, NULL}]
Active processes (1):
  "/gnu/store/h0c398zan9ibhk4w0c944vp5pwgzkfpd-gzip-1.9/bin/gzip" (13815) -> -1
Active processes (1):
  "/gnu/store/h0c398zan9ibhk4w0c944vp5pwgzkfpd-gzip-1.9/bin/gzip" (13815) -> 0
Starting pipeline: /gnu/store/h0c398zan9ibhk4w0c944vp5pwgzkfpd-gzip-1.9/bin/gzip -dc /gnu/store/gppr8msvzgxr87psbj3w6hc07lnnzpvx-emacs-26.1/share/man/man1/emacs.1.gz [input: {0, /gnu/store/gppr8msvzgxr87psbj3w6hc07lnnzpvx-emacs-26.1/share/man/man1/emacs.1.gz}, output: {-1, NULL}]
Started "/gnu/store/h0c398zan9ibhk4w0c944vp5pwgzkfpd-gzip-1.9/bin/gzip", pid 13816
Starting pipeline: (cd /home/ambrevar/.guix-profile/share/man && /gnu/store/fm7jlkf93bh7bw03m8hbha2b5qxjz0kz-man-db-2.8.3/libexec/man-db/zsoelim) | (cd /home/ambrevar/.guix-profile/share/man && /gnu/store/fm7jlkf93bh7bw03m8hbha2b5qxjz0kz-man-db-2.8.3/libexec/man-db/manconv -f UTF-8:ISO-8859-1 -t UTF-8//IGNORE) | (cd /home/ambrevar/.guix-profile/share/man && /gnu/store/mpjn4jfx5i8jxblfj538n22hv56rdnhw-groff-minimal-1.22.3/bin/preconv -e UTF-8) | (cd /home/ambrevar/.guix-profile/share/man && /gnu/store/mpjn4jfx5i8jxblfj538n22hv56rdnhw-groff-minimal-1.22.3/bin/tbl) | (cd /home/ambrevar/.guix-profile/share/man && /gnu/store/mpjn4jfx5i8jxblfj538n22hv56rdnhw-groff-minimal-1.22.3/bin/nroff -mandoc -Tutf8) [input: {-1, NULL}, output: {-1, NULL}]
Started "/gnu/store/fm7jlkf93bh7bw03m8hbha2b5qxjz0kz-man-db-2.8.3/libexec/man-db/zsoelim", pid 13817
Started "/gnu/store/fm7jlkf93bh7bw03m8hbha2b5qxjz0kz-man-db-2.8.3/libexec/man-db/manconv -f UTF-8:ISO-8859-1 -t UTF-8//IGNORE", pid 13818
Started "/gnu/store/mpjn4jfx5i8jxblfj538n22hv56rdnhw-groff-minimal-1.22.3/bin/preconv", pid 13819
Started "/gnu/store/mpjn4jfx5i8jxblfj538n22hv56rdnhw-groff-minimal-1.22.3/bin/tbl", pid 13820
Started "/gnu/store/mpjn4jfx5i8jxblfj538n22hv56rdnhw-groff-minimal-1.22.3/bin/nroff", pid 13821
Starting pipeline: sed -e '/^[[:space:]]*$/{ N; /^[[:space:]]*\n[[:space:]]*$/D; }' | LESS=-ix8RmPm Manual page emacs(1) ?ltline %lt?L/%L.:byte %bB?s/%s..?e (END):?pB %pB\%.. (press h for help or q to quit)$PM Manual page emacs(1) ?ltline %lt?L/%L.:byte %bB?s/%s..?e (END):?pB %pB\%.. (press h for help or q to quit)$ MAN_PN=emacs(1) less -s [input: {-1, NULL}, output: {0, NULL}]
Started "sed -e '/^[[:space:]]*$/{ N; /^[[:space:]]*\n[[:space:]]*$/D; }'", pid 13822
Started "less", pid 13823
source pipeline 0 returned error or EOF
Active processes (1):
  "less" (13823) -> 0
/gnu/store/fm7jlkf93bh7bw03m8hbha2b5qxjz0kz-man-db-2.8.3/bin/man: command exited with status 127: (cd /home/ambrevar/.guix-profile/share/man && /gnu/store/fm7jlkf93bh7bw03m8hbha2b5qxjz0kz-man-db-2.8.3/libexec/man-db/zsoelim) | (cd /home/ambrevar/.guix-profile/share/man && /gnu/store/fm7jlkf93bh7bw03m8hbha2b5qxjz0kz-man-db-2.8.3/libexec/man-db/manconv -f UTF-8:ISO-8859-1 -t UTF-8//IGNORE) | (cd /home/ambrevar/.guix-profile/share/man && /gnu/store/mpjn4jfx5i8jxblfj538n22hv56rdnhw-groff-minimal-1.22.3/bin/preconv -e UTF-8) | (cd /home/ambrevar/.guix-profile/share/man && /gnu/store/mpjn4jfx5i8jxblfj538n22hv56rdnhw-groff-minimal-1.22.3/bin/tbl) | (cd /home/ambrevar/.guix-profile/share/man && /gnu/store/mpjn4jfx5i8jxblfj538n22hv56rdnhw-groff-minimal-1.22.3/bin/nroff -mandoc -Tutf8)
--8<---------------cut here---------------end--------------->8---

I'm not sure this tells us much.

From libpipeline's documentation
(http://libpipeline.nongnu.org/libpipeline.3.html), it seems that libpipeline
accepts "program names", and it's unclear to me if it accepts full paths (would
be weird, but we never know).

If we can't figure it out, a workaround would be to wrap "man" to add
groff-minimal to PATH.

Thoughts?

-- 
Pierre Neidhardt
https://ambrevar.xyz/

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 487 bytes --]

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-13 17:31       ` Pierre Neidhardt
@ 2019-01-13 17:43         ` Pierre Neidhardt
  2019-01-13 20:27           ` Ludovic Courtès
  0 siblings, 1 reply; 57+ messages in thread
From: Pierre Neidhardt @ 2019-01-13 17:43 UTC (permalink / raw)
  To: Ludovic Courtès; +Cc: 30785

[-- Attachment #1: Type: text/plain, Size: 658 bytes --]

My proposed patch:

--8<---------------cut here---------------start------------->8---
(add-after 'install 'wrap-program
           (lambda* (#:key inputs outputs #:allow-other-keys)
            (let* ((out  (assoc-ref outputs "out"))
                   (groff (assoc-ref inputs "groff-minimal")))
              (wrap-program (string-append out "/bin/man")
                `("PATH" ":" prefix (,(string-append groff "/bin")))))
            #t))
--8<---------------cut here---------------end--------------->8---

Not completely ideal, but at least man-db would be fully functional for Guix
1.0! :)

-- 
Pierre Neidhardt
https://ambrevar.xyz/

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 487 bytes --]

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-13 17:43         ` Pierre Neidhardt
@ 2019-01-13 20:27           ` Ludovic Courtès
  2019-01-13 20:37             ` Pierre Neidhardt
  0 siblings, 1 reply; 57+ messages in thread
From: Ludovic Courtès @ 2019-01-13 20:27 UTC (permalink / raw)
  To: Pierre Neidhardt; +Cc: 30785

Pierre Neidhardt <mail@ambrevar.xyz> skribis:

> My proposed patch:
>
> (add-after 'install 'wrap-program
>            (lambda* (#:key inputs outputs #:allow-other-keys)
>             (let* ((out  (assoc-ref outputs "out"))
>                    (groff (assoc-ref inputs "groff-minimal")))
>               (wrap-program (string-append out "/bin/man")
>                 `("PATH" ":" prefix (,(string-append groff "/bin")))))
>             #t))

It would have the same effect as Marius’ commit
296551a2e9310d4a030ee49530e9367e73aaeecf, wouldn’t it?

My understanding, at this point, is that we need to find out why
‘preconv’ segfaults, no?

Thanks,
Ludo’.

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-13 20:27           ` Ludovic Courtès
@ 2019-01-13 20:37             ` Pierre Neidhardt
  2019-01-14  8:36               ` Ludovic Courtès
  0 siblings, 1 reply; 57+ messages in thread
From: Pierre Neidhardt @ 2019-01-13 20:37 UTC (permalink / raw)
  To: Ludovic Courtès; +Cc: 30785

[-- Attachment #1: Type: text/plain, Size: 571 bytes --]


> It would have the same effect as Marius’ commit
> 296551a2e9310d4a030ee49530e9367e73aaeecf, wouldn’t it?

I tested and it works! :)

> My understanding, at this point, is that we need to find out why
> ‘preconv’ segfaults, no?

I'm not completely sure but it seems that libpipeline breaks preconv for one of
those two reasons:
- Because it's a path (maybe the slashes create a problem?).
- Because it's not in the PATH.

Very weird indeed.  The libpipeline developers could probably tell us more.

-- 
Pierre Neidhardt
https://ambrevar.xyz/

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 487 bytes --]

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-13 20:37             ` Pierre Neidhardt
@ 2019-01-14  8:36               ` Ludovic Courtès
  2019-01-14  8:49                 ` Pierre Neidhardt
  0 siblings, 1 reply; 57+ messages in thread
From: Ludovic Courtès @ 2019-01-14  8:36 UTC (permalink / raw)
  To: Pierre Neidhardt; +Cc: 30785

Hi,

Pierre Neidhardt <mail@ambrevar.xyz> skribis:

>> It would have the same effect as Marius’ commit
>> 296551a2e9310d4a030ee49530e9367e73aaeecf, wouldn’t it?
>
> I tested and it works! :)
>
>> My understanding, at this point, is that we need to find out why
>> ‘preconv’ segfaults, no?
>
> I'm not completely sure but it seems that libpipeline breaks preconv for one of
> those two reasons:

Did you get a backtrace of ‘preconv’ showing that the segfault is in
libpipeline?

Thanks,
Ludo’.

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-14  8:36               ` Ludovic Courtès
@ 2019-01-14  8:49                 ` Pierre Neidhardt
  2019-01-14 10:19                   ` Pierre Neidhardt
  0 siblings, 1 reply; 57+ messages in thread
From: Pierre Neidhardt @ 2019-01-14  8:49 UTC (permalink / raw)
  To: Ludovic Courtès; +Cc: 30785

[-- Attachment #1: Type: text/plain, Size: 341 bytes --]


> Did you get a backtrace of ‘preconv’ showing that the segfault is in
> libpipeline?

I'm not sure what you mean.  preconv is only run from libpipeline, and according
to the debug output and the error message above, preconv segfaults.

I'll try to run a GDB session on it later.

-- 
Pierre Neidhardt
https://ambrevar.xyz/

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 487 bytes --]

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-14  8:49                 ` Pierre Neidhardt
@ 2019-01-14 10:19                   ` Pierre Neidhardt
  2019-01-14 10:59                     ` Gábor Boskovits
  0 siblings, 1 reply; 57+ messages in thread
From: Pierre Neidhardt @ 2019-01-14 10:19 UTC (permalink / raw)
  To: Ludovic Courtès; +Cc: 30785

[-- Attachment #1: Type: text/plain, Size: 330 bytes --]

Hmmm... Not sure how to trace that with GDB.
I'm not sure how to handle child processes.

The offending libpipeline call is "pipeline_pump" in src/man.c:2329 in the
"display" function.

I'd need more time to investigate this, time which I don't have at the moment,
sorry :(

-- 
Pierre Neidhardt
https://ambrevar.xyz/

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 487 bytes --]

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-14 10:19                   ` Pierre Neidhardt
@ 2019-01-14 10:59                     ` Gábor Boskovits
  2019-01-14 15:06                       ` Pierre Neidhardt
  0 siblings, 1 reply; 57+ messages in thread
From: Gábor Boskovits @ 2019-01-14 10:59 UTC (permalink / raw)
  To: Pierre Neidhardt; +Cc: 30785

Hello Pierre,

Pierre Neidhardt <mail@ambrevar.xyz> ezt írta (időpont: 2019. jan.
14., H, 11:42):
>
> Hmmm... Not sure how to trace that with GDB.
> I'm not sure how to handle child processes.
>

https://sourceware.org/gdb/onlinedocs/gdb/Forks.html

this might help here.

> The offending libpipeline call is "pipeline_pump" in src/man.c:2329 in the
> "display" function.
>
> I'd need more time to investigate this, time which I don't have at the moment,
> sorry :(
>
> --
> Pierre Neidhardt
> https://ambrevar.xyz/

Can we trigger the segfault without libpipeline?

If it is so, then IMO preconv is at fault...

Best regards,
g_bor

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-14 10:59                     ` Gábor Boskovits
@ 2019-01-14 15:06                       ` Pierre Neidhardt
  2019-01-14 16:10                         ` Ludovic Courtès
  0 siblings, 1 reply; 57+ messages in thread
From: Pierre Neidhardt @ 2019-01-14 15:06 UTC (permalink / raw)
  To: Gábor Boskovits; +Cc: 30785

[-- Attachment #1: Type: text/plain, Size: 649 bytes --]


> https://sourceware.org/gdb/onlinedocs/gdb/Forks.html
> 
> this might help here.

Thanks Gábor.
So I tried the following in gdb:

> set follow-for-mode child
> set detach-on-fork off
> run emacs
[inferior 2 completes]
> inferior 1
[inferior 3 completes]
> inferior 1
[inferior 4 completes]
> inferior 1
[inferior 5 hangs]

GDB seems to be stuck on the 5th inferior.  Maybe this is not so reliable.

> Can we trigger the segfault without libpipeline?

"preconv" by itself seems to work perfectly.  It even works in man if it's in
the PATH.  It only breaks from libpipeline.

-- 
Pierre Neidhardt
https://ambrevar.xyz/

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 487 bytes --]

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-14 15:06                       ` Pierre Neidhardt
@ 2019-01-14 16:10                         ` Ludovic Courtès
  2019-01-14 16:24                           ` Pierre Neidhardt
  0 siblings, 1 reply; 57+ messages in thread
From: Ludovic Courtès @ 2019-01-14 16:10 UTC (permalink / raw)
  To: Pierre Neidhardt; +Cc: 30785

Pierre Neidhardt <mail@ambrevar.xyz> skribis:

>> https://sourceware.org/gdb/onlinedocs/gdb/Forks.html
>> 
>> this might help here.
>
> Thanks Gábor.
> So I tried the following in gdb:
>
>> set follow-for-mode child
>> set detach-on-fork off
>> run emacs
> [inferior 2 completes]
>> inferior 1
> [inferior 3 completes]
>> inferior 1
> [inferior 4 completes]
>> inferior 1
> [inferior 5 hangs]
>
> GDB seems to be stuck on the 5th inferior.  Maybe this is not so reliable.

Maybe it’s just that the inferior is still running, no?

>> Can we trigger the segfault without libpipeline?
>
> "preconv" by itself seems to work perfectly.  It even works in man if it's in
> the PATH.  It only breaks from libpipeline.

What about reproducing the segfault and getting a core dump?  Roughly
you can do:

  ulimit -c unlimited
  man whatever that causes the crash
  gdb /path/to/preconv core

HTH!

Ludo’.

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-14 16:10                         ` Ludovic Courtès
@ 2019-01-14 16:24                           ` Pierre Neidhardt
  2019-01-14 16:42                             ` Danny Milosavljevic
  0 siblings, 1 reply; 57+ messages in thread
From: Pierre Neidhardt @ 2019-01-14 16:24 UTC (permalink / raw)
  To: Ludovic Courtès; +Cc: 30785

[-- Attachment #1: Type: text/plain, Size: 1555 bytes --]


ludo@gnu.org (Ludovic Courtès) writes:
> Maybe it’s just that the inferior is still running, no?

Well, it should finish in a fraction of a second.

sudo sh -c "echo '/tmp/core_%e.%p' >  /proc/sys/kernel/core_pattern"

>   ulimit -c unlimited
>   man whatever that causes the crash
>   gdb /path/to/preconv core

Smart!

This gave me no coredump at first because the pipeline "cd" into the
store/profile, which is readonly.  So I did

--8<---------------cut here---------------start------------->8---
sudo sh -c "echo '/tmp/core_%e.%p' > /proc/sys/kernel/core_pattern"
--8<---------------cut here---------------end--------------->8---

and then the segfault would generate a core.  From which GDB gives me:

--8<---------------cut here---------------start------------->8---
Core was generated by `preconv -e UTF-8'.
Program terminated with signal SIGSEGV, Segmentation fault.
#0  __stpcpy_sse2_unaligned () at ../sysdeps/x86_64/multiarch/strcpy-sse2-unaligned.S:298
298     ../sysdeps/x86_64/multiarch/strcpy-sse2-unaligned.S: No such file or directory.
(gdb) bt
#0  __stpcpy_sse2_unaligned () at ../sysdeps/x86_64/multiarch/strcpy-sse2-unaligned.S:298
#1  0x00000000004062c3 in relocatep ()
#2  0x0000000000405b5d in locale_charset ()
#3  0x0000000000402445 in main ()
(gdb) 
--8<---------------cut here---------------end--------------->8---

I haven't looked at the code yet, but here is my clue: argv[0], the program
name, is too long and overflows some string.

-- 
Pierre Neidhardt
https://ambrevar.xyz/

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 487 bytes --]

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-14 16:24                           ` Pierre Neidhardt
@ 2019-01-14 16:42                             ` Danny Milosavljevic
  2019-01-14 16:57                               ` Pierre Neidhardt
  0 siblings, 1 reply; 57+ messages in thread
From: Danny Milosavljevic @ 2019-01-14 16:42 UTC (permalink / raw)
  To: Pierre Neidhardt; +Cc: 30785

[-- Attachment #1: Type: text/plain, Size: 425 bytes --]

Hi Pierre,

locale_charset, implemented in groff, uses nl_langinfo(CODESET)--and just a few
days ago we had a bug report that CP437 doesn't work there.  Maybe it's related.

(libs/libgroff/localcharset.c's locale_charset looks overly complicated, WTF?)

Maybe argv[0] is still the cause, but try setting the environment variable
LC_ALL to "C" to disable locales before invoking "man".  Does this make it not
crash?

[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 488 bytes --]

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-14 16:42                             ` Danny Milosavljevic
@ 2019-01-14 16:57                               ` Pierre Neidhardt
  2019-01-14 17:46                                 ` Danny Milosavljevic
  2019-01-14 17:48                                 ` Danny Milosavljevic
  0 siblings, 2 replies; 57+ messages in thread
From: Pierre Neidhardt @ 2019-01-14 16:57 UTC (permalink / raw)
  To: Danny Milosavljevic; +Cc: 30785

[-- Attachment #1: Type: text/plain, Size: 1640 bytes --]


> (libs/libgroff/localcharset.c's locale_charset looks overly complicated, WTF?)

Oh dear... relocatep.cpp is not much better, here is the offending function:

--8<---------------cut here---------------start------------->8---
// Strip the installation prefix and replace it
// with the current installation prefix; return the relocated path.
char *relocatep(const char *path)
{
#if DEBUG
  fprintf(stderr, "relocatep: path = %s\n", path);
  fprintf(stderr, "relocatep: INSTALLPATH = %s\n", INSTALLPATH);
  fprintf(stderr, "relocatep: INSTALLPATHLEN = %d\n", INSTALLPATHLEN);
#endif
  if (!curr_prefix)
    set_current_prefix();
  if (strncmp(INSTALLPATH, path, INSTALLPATHLEN))
    return strsave(path);
  char *relative_path = (char *)path + INSTALLPATHLEN;
  size_t relative_path_len = strlen(relative_path);
  char *relocated_path = new char[curr_prefix_len + relative_path_len + 1];
  strcpy(relocated_path, curr_prefix);
  strcat(relocated_path, relative_path);
#if DEBUG
  fprintf(stderr, "relocated_path: %s\n", relocated_path);
#endif /* DEBUG */
  return relocated_path;
}
--8<---------------cut here---------------end--------------->8---

I don't even get the use case of the function...  From locale_charset, it seems
that the argument is LIBDIR.

So maybe INSTALLPATH and/or LIBDIR is not properly set when we compile groff.

> Maybe argv[0] is still the cause, but try setting the environment variable
> LC_ALL to "C" to disable locales before invoking "man".  Does this make it not
> crash?

This works indeed!  Can you see a fix then?

-- 
Pierre Neidhardt
https://ambrevar.xyz/

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 487 bytes --]

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-14 16:57                               ` Pierre Neidhardt
@ 2019-01-14 17:46                                 ` Danny Milosavljevic
  2019-01-14 17:48                                 ` Danny Milosavljevic
  1 sibling, 0 replies; 57+ messages in thread
From: Danny Milosavljevic @ 2019-01-14 17:46 UTC (permalink / raw)
  To: Pierre Neidhardt; +Cc: 30785

[-- Attachment #1: Type: text/plain, Size: 2255 bytes --]

Hi Pierre,

On Mon, 14 Jan 2019 17:57:12 +0100
Pierre Neidhardt <mail@ambrevar.xyz> wrote:

> > (libs/libgroff/localcharset.c's locale_charset looks overly complicated, WTF?)  
> 
> Oh dear... relocatep.cpp is not much better, here is the offending function:
> 
> --8<---------------cut here---------------start------------->8---
> // Strip the installation prefix and replace it
> // with the current installation prefix; return the relocated path.
> char *relocatep(const char *path)
> {
> #if DEBUG
>   fprintf(stderr, "relocatep: path = %s\n", path);
>   fprintf(stderr, "relocatep: INSTALLPATH = %s\n", INSTALLPATH);
>   fprintf(stderr, "relocatep: INSTALLPATHLEN = %d\n", INSTALLPATHLEN);
> #endif
>   if (!curr_prefix)
>     set_current_prefix();
>   if (strncmp(INSTALLPATH, path, INSTALLPATHLEN))
>     return strsave(path);
>   char *relative_path = (char *)path + INSTALLPATHLEN;
>   size_t relative_path_len = strlen(relative_path);
>   char *relocated_path = new char[curr_prefix_len + relative_path_len + 1];
>   strcpy(relocated_path, curr_prefix);
>   strcat(relocated_path, relative_path);
> #if DEBUG
>   fprintf(stderr, "relocated_path: %s\n", relocated_path);
> #endif /* DEBUG */
>   return relocated_path;
> }
> --8<---------------cut here---------------end--------------->8---
> 
> I don't even get the use case of the function...  From locale_charset, it seems
> that the argument is LIBDIR.

It's used inside get_charset_aliases, which reads the file "charset.alias".
We have only one alias in our file "charset.alias" (in GuixSD), so let's try
ignoring it completely for now.

What happens if you don't mess with LC_ALL but set the environment variable
CHARSETALIASDIR to "/does_not_exist" ?

> Can you see a fix then?

If the avove also works, we can just patch get_charset_aliases to always return
the empty string (or a string literal).

The one alias we do have in "charset.alias" is:

ISO_646.IRV:1983 ASCII

Alternatively, we could patch get_charset_aliases so it always takes our
charset.alias from our libiconv (without get_charset_aliases calling
"relocate").

Still it would be interesting to find the Segmentation fault (that's
not supposed to ever happen).

[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 488 bytes --]

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-14 16:57                               ` Pierre Neidhardt
  2019-01-14 17:46                                 ` Danny Milosavljevic
@ 2019-01-14 17:48                                 ` Danny Milosavljevic
  2019-01-14 17:50                                   ` Danny Milosavljevic
  1 sibling, 1 reply; 57+ messages in thread
From: Danny Milosavljevic @ 2019-01-14 17:48 UTC (permalink / raw)
  To: Pierre Neidhardt; +Cc: 30785

[-- Attachment #1: Type: text/plain, Size: 356 bytes --]

set_current_prefix() searches for the current program executable file in $PATH,
and it can fail and return 0. 

In that case, relocatep will probably segfault at the location marked below:

>   char *relocated_path = new char[curr_prefix_len + relative_path_len + 1];
>   strcpy(relocated_path, curr_prefix);
                           ^^^^^^^^^^^

[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 488 bytes --]

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-14 17:48                                 ` Danny Milosavljevic
@ 2019-01-14 17:50                                   ` Danny Milosavljevic
  2019-01-14 18:19                                     ` Pierre Neidhardt
  2019-01-14 20:27                                     ` Ludovic Courtès
  0 siblings, 2 replies; 57+ messages in thread
From: Danny Milosavljevic @ 2019-01-14 17:50 UTC (permalink / raw)
  To: Pierre Neidhardt; +Cc: 30785

[-- Attachment #1: Type: text/plain, Size: 609 bytes --]

On Mon, 14 Jan 2019 18:48:53 +0100
Danny Milosavljevic <dannym@scratchpost.org> wrote:

> set_current_prefix() searches for the current program executable file in $PATH,
> and it can fail and return 0. 
> 
> In that case, relocatep will probably segfault at the location marked below:
> 
> >   char *relocated_path = new char[curr_prefix_len + relative_path_len + 1];
> >   strcpy(relocated_path, curr_prefix);  
>                            ^^^^^^^^^^^

This probably happens when argv[0] is not an absolute path, but still the program
somehow got started, but it is not found in $PATH either.

[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 488 bytes --]

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-14 17:50                                   ` Danny Milosavljevic
@ 2019-01-14 18:19                                     ` Pierre Neidhardt
  2019-01-14 20:27                                     ` Ludovic Courtès
  1 sibling, 0 replies; 57+ messages in thread
From: Pierre Neidhardt @ 2019-01-14 18:19 UTC (permalink / raw)
  To: Danny Milosavljevic; +Cc: 30785

[-- Attachment #1: Type: text/plain, Size: 202 bytes --]

You are right:

    CHARSETALIASDIR=/does_not_exist /gnu/store/fm7jlkf93bh7bw03m8hbha2b5qxjz0kz-man-db-2.8.3/bin/man nmcli-examples
    
also works.

-- 
Pierre Neidhardt
https://ambrevar.xyz/

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 487 bytes --]

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-14 17:50                                   ` Danny Milosavljevic
  2019-01-14 18:19                                     ` Pierre Neidhardt
@ 2019-01-14 20:27                                     ` Ludovic Courtès
  2019-01-14 21:42                                       ` Danny Milosavljevic
  1 sibling, 1 reply; 57+ messages in thread
From: Ludovic Courtès @ 2019-01-14 20:27 UTC (permalink / raw)
  To: Danny Milosavljevic; +Cc: Pierre Neidhardt, 30785

Danny Milosavljevic <dannym@scratchpost.org> skribis:

> On Mon, 14 Jan 2019 18:48:53 +0100
> Danny Milosavljevic <dannym@scratchpost.org> wrote:
>
>> set_current_prefix() searches for the current program executable file in $PATH,
>> and it can fail and return 0. 
>> 
>> In that case, relocatep will probably segfault at the location marked below:
>> 
>> >   char *relocated_path = new char[curr_prefix_len + relative_path_len + 1];
>> >   strcpy(relocated_path, curr_prefix);  
>>                            ^^^^^^^^^^^
>
> This probably happens when argv[0] is not an absolute path, but still the program
> somehow got started, but it is not found in $PATH either.

The ‘set_current_prefix’ logic is extremely fragile; it should readlink
from /proc/self/exe on GNU/Linux.

But in our case, no relocation happens, so we can just patch it to do:

  void set_current_prefix (void)
  {
    curr_prefix = "/gnu/store/…";
  }

Ludo’.

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-14 20:27                                     ` Ludovic Courtès
@ 2019-01-14 21:42                                       ` Danny Milosavljevic
  2019-01-14 21:59                                         ` Pierre Neidhardt
  2019-01-14 22:14                                         ` Danny Milosavljevic
  0 siblings, 2 replies; 57+ messages in thread
From: Danny Milosavljevic @ 2019-01-14 21:42 UTC (permalink / raw)
  To: Ludovic Courtès, Pierre Neidhardt; +Cc: 30785

[-- Attachment #1: Type: text/plain, Size: 1257 bytes --]

Hi Pierre,
Hi Ludo,

On Mon, 14 Jan 2019 21:27:35 +0100
Ludovic Courtès <ludo@gnu.org> wrote:

> The ‘set_current_prefix’ logic is extremely fragile; it should readlink
> from /proc/self/exe on GNU/Linux.
> 
> But in our case, no relocation happens, so we can just patch it to do:
> 
>   void set_current_prefix (void)
>   {
>     curr_prefix = "/gnu/store/…";
>   }

I agree.

However, in this case the question is why is it picking up all that stuff anyway.

The relocation is only used in the case of the groff-local localcharset.c being
used.
It's only a fallback that is used if glibc < 2.1.  I've checked the guix build
logs, the glibc version is newer and also found by the 'configure phase of groff.

I can't tell about groff-minimal because the build log as given by
"guix build --log-file groff-minimal"
(https://ci.guix.info/log/mpjn4jfx5i8jxblfj538n22hv56rdnhw-groff-minimal-1.22.3)
has 0 Bytes.

Anyway, a simple way to disable this weird relocation business would be to remove:

./src/libs/libgroff/Makefile.sub:             -DENABLE_RELOCATABLE=1 \

However, it would be preferrable to find out why ./src/libs/gnulib/lib/localcharset.c
(the only user of it) is used at all.  It really shouldn't be.

[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 488 bytes --]

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-14 21:42                                       ` Danny Milosavljevic
@ 2019-01-14 21:59                                         ` Pierre Neidhardt
  2019-01-14 22:14                                         ` Danny Milosavljevic
  1 sibling, 0 replies; 57+ messages in thread
From: Pierre Neidhardt @ 2019-01-14 21:59 UTC (permalink / raw)
  To: Danny Milosavljevic; +Cc: 30785

[-- Attachment #1: Type: text/plain, Size: 466 bytes --]


Maybe I'm judging a bit too fast, but it seems to me that this part of the code
is rusty to the point that I wonder if getting down to understanding the hows
and the whys will ever reveal useful or enlightening at all.  It's rather safe
to bet that nothing will ever depend on man-db's rendering ;)

I feel that it's just easier to apply one of the 3-4 fixes we've already come up
with :p

My two cents :)

-- 
Pierre Neidhardt
https://ambrevar.xyz/

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 487 bytes --]

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-14 21:42                                       ` Danny Milosavljevic
  2019-01-14 21:59                                         ` Pierre Neidhardt
@ 2019-01-14 22:14                                         ` Danny Milosavljevic
  2019-01-14 22:39                                           ` Pierre Neidhardt
  2019-01-15 12:29                                           ` Ludovic Courtès
  1 sibling, 2 replies; 57+ messages in thread
From: Danny Milosavljevic @ 2019-01-14 22:14 UTC (permalink / raw)
  To: Ludovic Courtès, Pierre Neidhardt; +Cc: 30785

[-- Attachment #1: Type: text/plain, Size: 1137 bytes --]

Correction, the file "charset.alias" is only installed for groff for glibc < 2.1 .
The code that reads charset.alias is always created.
What could possibly go wrong?

Anyway, I suggest the following minimal patch:

diff --git a/gnu/packages/groff.scm b/gnu/packages/groff.scm
index 77728a5d7..ee2896367 100644
--- a/gnu/packages/groff.scm
+++ b/gnu/packages/groff.scm
@@ -62,6 +62,16 @@
     `(#:parallel-build? #f   ; parallel build fails
       #:phases
       (modify-phases %standard-phases
+        (add-after 'unpack 'disable-relocatability
+          (lambda _
+            (substitute* "src/libs/libgroff/Makefile.sub"
+             (("-DENABLE_RELOCATABLE=1") ""))
+            ;; That file contains a crash bug--so make sure that
+            ;; its contents are not there.
+            (call-with-output-file "src/libs/libgroff/relocate.cpp"
+              (lambda (port)
+                #t))
+            #t))
         (add-after 'unpack 'setenv
           (lambda _
             (setenv "GS_GENERATE_UUIDS" "0")

I filed an upstream bug report:

https://savannah.gnu.org/bugs/index.php?55475

[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 488 bytes --]

^ permalink raw reply related	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-14 22:14                                         ` Danny Milosavljevic
@ 2019-01-14 22:39                                           ` Pierre Neidhardt
  2019-01-15 12:29                                           ` Ludovic Courtès
  1 sibling, 0 replies; 57+ messages in thread
From: Pierre Neidhardt @ 2019-01-14 22:39 UTC (permalink / raw)
  To: Danny Milosavljevic; +Cc: 30785

[-- Attachment #1: Type: text/plain, Size: 138 bytes --]

I suggest your patch explain that crash involves man-db + add a link to this discussion.

-- 
Pierre Neidhardt
https://ambrevar.xyz/

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 487 bytes --]

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-14 22:14                                         ` Danny Milosavljevic
  2019-01-14 22:39                                           ` Pierre Neidhardt
@ 2019-01-15 12:29                                           ` Ludovic Courtès
  2019-01-16 10:01                                             ` Pierre Neidhardt
  1 sibling, 1 reply; 57+ messages in thread
From: Ludovic Courtès @ 2019-01-15 12:29 UTC (permalink / raw)
  To: Danny Milosavljevic; +Cc: Pierre Neidhardt, 30785

Danny Milosavljevic <dannym@scratchpost.org> skribis:

> Correction, the file "charset.alias" is only installed for groff for glibc < 2.1 .
> The code that reads charset.alias is always created.
> What could possibly go wrong?
>
> Anyway, I suggest the following minimal patch:
>
> diff --git a/gnu/packages/groff.scm b/gnu/packages/groff.scm
> index 77728a5d7..ee2896367 100644
> --- a/gnu/packages/groff.scm
> +++ b/gnu/packages/groff.scm
> @@ -62,6 +62,16 @@
>      `(#:parallel-build? #f   ; parallel build fails
>        #:phases
>        (modify-phases %standard-phases
> +        (add-after 'unpack 'disable-relocatability
> +          (lambda _
> +            (substitute* "src/libs/libgroff/Makefile.sub"
> +             (("-DENABLE_RELOCATABLE=1") ""))
> +            ;; That file contains a crash bug--so make sure that
> +            ;; its contents are not there.
> +            (call-with-output-file "src/libs/libgroff/relocate.cpp"
> +              (lambda (port)
> +                #t))
> +            #t))
>          (add-after 'unpack 'setenv
>            (lambda _
>              (setenv "GS_GENERATE_UUIDS" "0")
>
> I filed an upstream bug report:
>
> https://savannah.gnu.org/bugs/index.php?55475

Neat!  Pierre, can you confirm it fixes the issue?

If it does, I agree with Pierre that you should add a comment
referencing this bug and upstream’s, but apart from that, please go
ahead!

Thanks,
Ludo’.

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-15 12:29                                           ` Ludovic Courtès
@ 2019-01-16 10:01                                             ` Pierre Neidhardt
  2019-01-16 10:56                                               ` Danny Milosavljevic
  0 siblings, 1 reply; 57+ messages in thread
From: Pierre Neidhardt @ 2019-01-16 10:01 UTC (permalink / raw)
  To: Ludovic Courtès; +Cc: 30785

[-- Attachment #1: Type: text/plain, Size: 477 bytes --]

Nope, the patch does not work for me.

I applied the patch in the Guix checkout, 
then

--8<---------------cut here---------------start------------->8---
$ ./pre-inst-env guix build man-db
...
/gnu/store/1w83i51wvap67kl7gdz51ly3pbbx29dv-man-db-2.8.3
$ /gnu/store/1w83i51wvap67kl7gdz51ly3pbbx29dv-man-db-2.8.3/bin/man nmcli-examples
--8<---------------cut here---------------end--------------->8---

Still truncated.

-- 
Pierre Neidhardt
https://ambrevar.xyz/

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 487 bytes --]

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-16 10:01                                             ` Pierre Neidhardt
@ 2019-01-16 10:56                                               ` Danny Milosavljevic
  2019-01-16 13:02                                                 ` Pierre Neidhardt
  0 siblings, 1 reply; 57+ messages in thread
From: Danny Milosavljevic @ 2019-01-16 10:56 UTC (permalink / raw)
  To: Pierre Neidhardt; +Cc: 30785

[-- Attachment #1: Type: text/plain, Size: 729 bytes --]

Hi Pierre,

On Wed, 16 Jan 2019 11:01:44 +0100
Pierre Neidhardt <mail@ambrevar.xyz> wrote:

> Nope, the patch does not work for me.
> 
> I applied the patch in the Guix checkout, 
> then
> 
> --8<---------------cut here---------------start------------->8---
> $ ./pre-inst-env guix build man-db
> ...
> /gnu/store/1w83i51wvap67kl7gdz51ly3pbbx29dv-man-db-2.8.3
> $ /gnu/store/1w83i51wvap67kl7gdz51ly3pbbx29dv-man-db-2.8.3/bin/man nmcli-examples
> --8<---------------cut here---------------end--------------->8---
> 
> Still truncated.
> 

Does this include your groff preconv path substitution in man?
Does preconv still segfault?
How can I reproduce this situation?  Is it a guix branch other than master?

[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 488 bytes --]

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-16 10:56                                               ` Danny Milosavljevic
@ 2019-01-16 13:02                                                 ` Pierre Neidhardt
  2019-01-16 14:17                                                   ` Danny Milosavljevic
  0 siblings, 1 reply; 57+ messages in thread
From: Pierre Neidhardt @ 2019-01-16 13:02 UTC (permalink / raw)
  To: Danny Milosavljevic; +Cc: 30785

[-- Attachment #1: Type: text/plain, Size: 169 bytes --]

Stupid me, forgot to patch man-db with the preconv path substitution!
OK, now it works.

Who would like to merge? :)

-- 
Pierre Neidhardt
https://ambrevar.xyz/

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 487 bytes --]

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-16 13:02                                                 ` Pierre Neidhardt
@ 2019-01-16 14:17                                                   ` Danny Milosavljevic
  2019-01-16 17:39                                                     ` Pierre Neidhardt
  0 siblings, 1 reply; 57+ messages in thread
From: Danny Milosavljevic @ 2019-01-16 14:17 UTC (permalink / raw)
  To: Pierre Neidhardt; +Cc: 30785

[-- Attachment #1: Type: text/plain, Size: 415 bytes --]

Hi Pierre,

On Wed, 16 Jan 2019 14:02:10 +0100
Pierre Neidhardt <mail@ambrevar.xyz> wrote:

> OK, now it works.
> 
> Who would like to merge? :)

I've pushed the disable-relocatability patch, amended by a huge comment that's
larger than the actual code, as f57693e17c7905d2f11e46d04cb558fe0b0fc39b.

Please push the part that does the preconv path substitution and mention that
it fixes this bug.



[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 488 bytes --]

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-16 14:17                                                   ` Danny Milosavljevic
@ 2019-01-16 17:39                                                     ` Pierre Neidhardt
  2019-01-16 18:12                                                       ` Efraim Flashner
  2019-01-17  8:33                                                       ` Ludovic Courtès
  0 siblings, 2 replies; 57+ messages in thread
From: Pierre Neidhardt @ 2019-01-16 17:39 UTC (permalink / raw)
  To: Danny Milosavljevic; +Cc: Ludovic Courtès, 30785

[-- Attachment #1: Type: text/plain, Size: 157 bytes --]

Danny, Efraim just reverted your commit because it rebuilds 3600+ packages :p

How shall we proceed then?

-- 
Pierre Neidhardt
https://ambrevar.xyz/

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 487 bytes --]

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-16 17:39                                                     ` Pierre Neidhardt
@ 2019-01-16 18:12                                                       ` Efraim Flashner
  2019-01-16 18:18                                                         ` Pierre Neidhardt
  2019-01-17  8:33                                                       ` Ludovic Courtès
  1 sibling, 1 reply; 57+ messages in thread
From: Efraim Flashner @ 2019-01-16 18:12 UTC (permalink / raw)
  To: Pierre Neidhardt; +Cc: Ludovic Courtès, 30785

[-- Attachment #1: Type: text/plain, Size: 502 bytes --]

On Wed, Jan 16, 2019 at 06:39:19PM +0100, Pierre Neidhardt wrote:
> Danny, Efraim just reverted your commit because it rebuilds 3600+ packages :p
> 
> How shall we proceed then?
> 

groff-minimal only has ~20 dependents, does that work? Otherwise
groff-for-manpages is an option


-- 
Efraim Flashner   <efraim@flashner.co.il>   אפרים פלשנר
GPG key = A28B F40C 3E55 1372 662D  14F7 41AA E7DC CA3D 8351
Confidentiality cannot be guaranteed on emails sent or received unencrypted

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 833 bytes --]

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-16 18:12                                                       ` Efraim Flashner
@ 2019-01-16 18:18                                                         ` Pierre Neidhardt
  2019-01-16 19:57                                                           ` Danny Milosavljevic
  0 siblings, 1 reply; 57+ messages in thread
From: Pierre Neidhardt @ 2019-01-16 18:18 UTC (permalink / raw)
  To: Efraim Flashner; +Cc: Ludovic Courtès, 30785

[-- Attachment #1: Type: text/plain, Size: 100 bytes --]

My guess is that groff-minimal would work.
Danny?

-- 
Pierre Neidhardt
https://ambrevar.xyz/

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 487 bytes --]

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-16 18:18                                                         ` Pierre Neidhardt
@ 2019-01-16 19:57                                                           ` Danny Milosavljevic
  2019-01-16 22:32                                                             ` Ludovic Courtès
  0 siblings, 1 reply; 57+ messages in thread
From: Danny Milosavljevic @ 2019-01-16 19:57 UTC (permalink / raw)
  To: Pierre Neidhardt; +Cc: Ludovic Courtès, 30785


[-- Attachment #1.1: Type: text/plain, Size: 368 bytes --]

Apparently, man-db has groff-minimal as a regular input, so I guess we are lucky.
So we could adapt groff-minimal only if we wanted to.

But that would mean that even after that, the "groff" package would still
contain a memory corruption bug in preconv - which is arguably a security
problem.  Should we use grafts instead?

Patch for the former is attached.

[-- Warning: decoded text below may be mangled, UTF-8 assumed --]
[-- Attachment #1.2: 0001-gnu-groff-minimal-Disable-relocatability.patch --]
[-- Type: text/x-patch, Size: 2928 bytes --]

From adc9e7940b54e467732ec923c6a3fcec810dce48 Mon Sep 17 00:00:00 2001
From: Danny Milosavljevic <dannym@scratchpost.org>
Date: Wed, 16 Jan 2019 15:00:04 +0100
Subject: [PATCH] gnu: groff-minimal: Disable relocatability.
Tags: patch

* gnu/packages/groff.scm (groff-minimal)[arguments]<#:phases>
[disable-relocatability]: New phase.
---
 gnu/packages/groff.scm | 30 ++++++++++++++++++++++++++++++
 1 file changed, 30 insertions(+)

diff --git a/gnu/packages/groff.scm b/gnu/packages/groff.scm
index 77728a5d7..cf392f546 100644
--- a/gnu/packages/groff.scm
+++ b/gnu/packages/groff.scm
@@ -96,6 +96,36 @@ is usually the formatter of \"man\" documentation pages.")
        ,@(substitute-keyword-arguments (package-arguments groff)
            ((#:phases phases)
             `(modify-phases ,phases
+               (add-after 'unpack 'disable-relocatability
+                 (lambda _
+                   ;; Groff contains a Rube Goldberg-esque relocator for the
+                   ;; file "charset.alias".
+                   ;; It tries to find the current executable using realpath,
+                   ;; a do-it-yourself search in $PATH and so on.
+                   ;; Furthermore, the routine that does the search is buggy
+                   ;; in that it doesn't handle error cases when they arise.
+                   ;; This causes preconv to segfault when trying to look up
+                   ;; the file "charset.alias" in the NULL location.
+                   ;; The "charset.alias" parser is a copy of gnulib's, and a
+                   ;; non-broken version of gnulib's "charset.alias" parser
+                   ;; is part of glibc's libcharset.
+                   ;; However, groff unconditionally uses their own
+                   ;; "charset.alias" parser, but then DOES NOT INSTALL the
+                   ;; file "charset.alias" when glibc is too new.
+                   ;; In Guix, our file "charset.alias" only contains an
+                   ;; obscure alias for ASCII and nothing else.
+                   ;; So just disable relocation and make the entire
+                   ;; "charset.alias" lookup fail.
+                   ;; See <https://debbugs.gnu.org/cgi/bugreport.cgi?bug=30785>
+                   ;; for details.
+                   (substitute* "src/libs/libgroff/Makefile.sub"
+                    (("-DENABLE_RELOCATABLE=1") ""))
+                   ;; That file contains a crash bug--so make sure that
+                   ;; its contents are not there.
+                   (call-with-output-file "src/libs/libgroff/relocate.cpp"
+                     (lambda (port)
+                       #t))
+                   #t))
                (add-after 'install 'remove-non-essential-programs
                  (lambda* (#:key outputs #:allow-other-keys)
                    ;; Keep only the programs that man-db needs at run time,

[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 488 bytes --]

^ permalink raw reply related	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-16 19:57                                                           ` Danny Milosavljevic
@ 2019-01-16 22:32                                                             ` Ludovic Courtès
  2019-01-16 22:45                                                               ` Danny Milosavljevic
  0 siblings, 1 reply; 57+ messages in thread
From: Ludovic Courtès @ 2019-01-16 22:32 UTC (permalink / raw)
  To: Danny Milosavljevic; +Cc: Pierre Neidhardt, 30785

Hello!

Danny Milosavljevic <dannym@scratchpost.org> skribis:

> Apparently, man-db has groff-minimal as a regular input, so I guess we are lucky.
> So we could adapt groff-minimal only if we wanted to.
>
> But that would mean that even after that, the "groff" package would still
> contain a memory corruption bug in preconv - which is arguably a security
> problem.  Should we use grafts instead?

Though in practice we don’t do much with ‘groff’ itself, unless users
explicitly install it and use it, right?  I’m leaning towards fixing it
in ‘core-updates’.

> From adc9e7940b54e467732ec923c6a3fcec810dce48 Mon Sep 17 00:00:00 2001
> From: Danny Milosavljevic <dannym@scratchpost.org>
> Date: Wed, 16 Jan 2019 15:00:04 +0100
> Subject: [PATCH] gnu: groff-minimal: Disable relocatability.
> Tags: patch
>
> * gnu/packages/groff.scm (groff-minimal)[arguments]<#:phases>
> [disable-relocatability]: New phase.

Please add the “Fixes” line in the log.  Otherwise LGTM (I like the
description of the bug ;-)).

Thanks!

Ludo’.

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-16 22:32                                                             ` Ludovic Courtès
@ 2019-01-16 22:45                                                               ` Danny Milosavljevic
  2019-01-17  7:31                                                                 ` Pierre Neidhardt
  0 siblings, 1 reply; 57+ messages in thread
From: Danny Milosavljevic @ 2019-01-16 22:45 UTC (permalink / raw)
  To: Ludovic Courtès, Pierre Neidhardt; +Cc: 30785

[-- Attachment #1: Type: text/plain, Size: 352 bytes --]

> Please add the “Fixes” line in the log.

It alone does not fix the bug.  Only combined with Pierre's part does it fix it,
the part which makes man-db find groff's preconv in the first place (I don't
believe a patch about that was submitted yet).

Should I still add a "Fixes" line here?

>(I like the description of the bug ;-)).

:-)

[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 488 bytes --]

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-16 22:45                                                               ` Danny Milosavljevic
@ 2019-01-17  7:31                                                                 ` Pierre Neidhardt
  2019-01-17  8:43                                                                   ` Ludovic Courtès
  2019-01-17  9:10                                                                   ` Danny Milosavljevic
  0 siblings, 2 replies; 57+ messages in thread
From: Pierre Neidhardt @ 2019-01-17  7:31 UTC (permalink / raw)
  To: Danny Milosavljevic; +Cc: 30785

[-- Attachment #1: Type: text/plain, Size: 465 bytes --]


> It alone does not fix the bug.  Only combined with Pierre's part does it fix it,
> the part which makes man-db find groff's preconv in the first place (I don't
> believe a patch about that was submitted yet).

I can only only add my patch (well, Markus patch, really) after yours, otherwise
it cause `man` to segfault all the time.

Let me know when you've applied it on core-updates and I'll follow you.

-- 
Pierre Neidhardt
https://ambrevar.xyz/

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 487 bytes --]

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-16 17:39                                                     ` Pierre Neidhardt
  2019-01-16 18:12                                                       ` Efraim Flashner
@ 2019-01-17  8:33                                                       ` Ludovic Courtès
  2019-01-17  8:41                                                         ` Pierre Neidhardt
  1 sibling, 1 reply; 57+ messages in thread
From: Ludovic Courtès @ 2019-01-17  8:33 UTC (permalink / raw)
  To: Pierre Neidhardt; +Cc: 30785

Hello,

Pierre Neidhardt <mail@ambrevar.xyz> skribis:

> Danny, Efraim just reverted your commit because it rebuilds 3600+ packages :p

BTW, we must pay a great deal of attention to issues like this one:
someone who pulled right after that commit must have been wondering
what’s going on.  That makes for a very bad user experience.

I wonder if we could come up with a pre-push hook that runs ‘guix
refresh -l’ or something.

Thoughts?

Ludo’.

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-17  8:33                                                       ` Ludovic Courtès
@ 2019-01-17  8:41                                                         ` Pierre Neidhardt
  0 siblings, 0 replies; 57+ messages in thread
From: Pierre Neidhardt @ 2019-01-17  8:41 UTC (permalink / raw)
  To: Ludovic Courtès; +Cc: 30785

[-- Attachment #1: Type: text/plain, Size: 184 bytes --]


> I wonder if we could come up with a pre-push hook that runs ‘guix
> refresh -l’ or something.
> 
> Thoughts?

Absolutely!

-- 
Pierre Neidhardt
https://ambrevar.xyz/

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 487 bytes --]

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-17  7:31                                                                 ` Pierre Neidhardt
@ 2019-01-17  8:43                                                                   ` Ludovic Courtès
  2019-01-17  9:39                                                                     ` Pierre Neidhardt
  2019-01-17  9:10                                                                   ` Danny Milosavljevic
  1 sibling, 1 reply; 57+ messages in thread
From: Ludovic Courtès @ 2019-01-17  8:43 UTC (permalink / raw)
  To: Pierre Neidhardt; +Cc: 30785

Pierre Neidhardt <mail@ambrevar.xyz> skribis:

>> It alone does not fix the bug.  Only combined with Pierre's part does it fix it,
>> the part which makes man-db find groff's preconv in the first place (I don't
>> believe a patch about that was submitted yet).
>
> I can only only add my patch (well, Markus patch, really) after yours, otherwise
> it cause `man` to segfault all the time.
>
> Let me know when you've applied it on core-updates and I'll follow you.

On ‘master’ you mean?  The patch that touches ‘groff-minimal’ (not
‘groff’) can go to ‘master’.

Thanks,
Ludo’.

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-17  7:31                                                                 ` Pierre Neidhardt
  2019-01-17  8:43                                                                   ` Ludovic Courtès
@ 2019-01-17  9:10                                                                   ` Danny Milosavljevic
  1 sibling, 0 replies; 57+ messages in thread
From: Danny Milosavljevic @ 2019-01-17  9:10 UTC (permalink / raw)
  To: Pierre Neidhardt; +Cc: 30785

[-- Attachment #1: Type: text/plain, Size: 67 bytes --]

Hi Pierre,

I've applied the groff-minimal patch to master now.

[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 488 bytes --]

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-17  8:43                                                                   ` Ludovic Courtès
@ 2019-01-17  9:39                                                                     ` Pierre Neidhardt
  2019-01-17  9:42                                                                       ` Pierre Neidhardt
  0 siblings, 1 reply; 57+ messages in thread
From: Pierre Neidhardt @ 2019-01-17  9:39 UTC (permalink / raw)
  To: Ludovic Courtès; +Cc: 30785

[-- Attachment #1: Type: text/plain, Size: 220 bytes --]

I meant the man-db patch should be applied after the groff (or groff-minimal)
patch.

Are we applying anything on master?  I'd rather just patch groff on core-updates.

-- 
Pierre Neidhardt
https://ambrevar.xyz/

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 487 bytes --]

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-17  9:39                                                                     ` Pierre Neidhardt
@ 2019-01-17  9:42                                                                       ` Pierre Neidhardt
  2019-01-17 11:32                                                                         ` Pierre Neidhardt
  0 siblings, 1 reply; 57+ messages in thread
From: Pierre Neidhardt @ 2019-01-17  9:42 UTC (permalink / raw)
  To: Ludovic Courtès; +Cc: 30785

[-- Attachment #1: Type: text/plain, Size: 223 bytes --]


Danny Milosavljevic <dannym@scratchpost.org> writes:
> I've applied the groff-minimal patch to master now.

Just saw that.  OK, I'll go ahead and apply my man-db patch.

-- 
Pierre Neidhardt
https://ambrevar.xyz/

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 487 bytes --]

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-17  9:42                                                                       ` Pierre Neidhardt
@ 2019-01-17 11:32                                                                         ` Pierre Neidhardt
  2019-11-28  0:13                                                                           ` Marius Bakke
  0 siblings, 1 reply; 57+ messages in thread
From: Pierre Neidhardt @ 2019-01-17 11:32 UTC (permalink / raw)
  To: Ludovic Courtès; +Cc: 30785

[-- Attachment #1: Type: text/plain, Size: 117 bytes --]

Done.

Keeping this bug open till we patch groff on core-updates.

-- 
Pierre Neidhardt
https://ambrevar.xyz/

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 487 bytes --]

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2019-01-17 11:32                                                                         ` Pierre Neidhardt
@ 2019-11-28  0:13                                                                           ` Marius Bakke
  0 siblings, 0 replies; 57+ messages in thread
From: Marius Bakke @ 2019-11-28  0:13 UTC (permalink / raw)
  To: Pierre Neidhardt, Ludovic Courtès; +Cc: 30785-done

[-- Attachment #1: Type: text/plain, Size: 167 bytes --]

Pierre Neidhardt <mail@ambrevar.xyz> writes:

> Keeping this bug open till we patch groff on core-updates.

This was done in 5466e82a1e61349e5a3f9726a03874e4f9817226.

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 487 bytes --]

^ permalink raw reply	[flat|nested] 57+ messages in thread

* bug#30785: Man pages truncated, repeated
  2018-03-12 21:24 bug#30785: Man pages truncated, repeated Tobias Geerinckx-Rice
                   ` (5 preceding siblings ...)
  2019-01-13 16:09 ` Pierre Neidhardt
@ 2021-04-22 18:53 ` G. Branden Robinson
  6 siblings, 0 replies; 57+ messages in thread
From: G. Branden Robinson @ 2021-04-22 18:53 UTC (permalink / raw)
  To: 30785

[-- Attachment #1: Type: text/plain, Size: 488 bytes --]

Hello Guix folks,

I submitted a change addressing this bug to groff Git back in
January[1].  Despite repeated requests I couldn't scare up any Windows
users to test it, and that's only environment except for Guix (until you
patched around it) that ever exhibited it.

If my understanding of the problem is correct, then something (possibly
preconv) using libgroff should throw an assertion failure.

My thanks if you can help.

Regards,
Branden

[1] https://savannah.gnu.org/bugs/?55475

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 833 bytes --]

^ permalink raw reply	[flat|nested] 57+ messages in thread

end of thread, other threads:[~2021-04-22 18:56 UTC | newest]

Thread overview: 57+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2018-03-12 21:24 bug#30785: Man pages truncated, repeated Tobias Geerinckx-Rice
2018-03-13 21:34 ` Ludovic Courtès
2018-03-13 22:01   ` Tobias Geerinckx-Rice
2018-03-14 13:22     ` Ludovic Courtès
2018-03-14 13:43 ` Andreas Enge
2018-03-15  0:40 ` Marius Bakke
2018-05-05 21:40   ` Marius Bakke
2018-05-06 13:53     ` Marius Bakke
2018-05-06 22:06       ` Marius Bakke
2018-05-05  1:31 ` Vagrant Cascadian
2018-08-20 10:32 ` Pierre Neidhardt
2019-01-13 16:09 ` Pierre Neidhardt
2019-01-13 16:15   ` Pierre Neidhardt
2019-01-13 17:00     ` Ludovic Courtès
2019-01-13 17:31       ` Pierre Neidhardt
2019-01-13 17:43         ` Pierre Neidhardt
2019-01-13 20:27           ` Ludovic Courtès
2019-01-13 20:37             ` Pierre Neidhardt
2019-01-14  8:36               ` Ludovic Courtès
2019-01-14  8:49                 ` Pierre Neidhardt
2019-01-14 10:19                   ` Pierre Neidhardt
2019-01-14 10:59                     ` Gábor Boskovits
2019-01-14 15:06                       ` Pierre Neidhardt
2019-01-14 16:10                         ` Ludovic Courtès
2019-01-14 16:24                           ` Pierre Neidhardt
2019-01-14 16:42                             ` Danny Milosavljevic
2019-01-14 16:57                               ` Pierre Neidhardt
2019-01-14 17:46                                 ` Danny Milosavljevic
2019-01-14 17:48                                 ` Danny Milosavljevic
2019-01-14 17:50                                   ` Danny Milosavljevic
2019-01-14 18:19                                     ` Pierre Neidhardt
2019-01-14 20:27                                     ` Ludovic Courtès
2019-01-14 21:42                                       ` Danny Milosavljevic
2019-01-14 21:59                                         ` Pierre Neidhardt
2019-01-14 22:14                                         ` Danny Milosavljevic
2019-01-14 22:39                                           ` Pierre Neidhardt
2019-01-15 12:29                                           ` Ludovic Courtès
2019-01-16 10:01                                             ` Pierre Neidhardt
2019-01-16 10:56                                               ` Danny Milosavljevic
2019-01-16 13:02                                                 ` Pierre Neidhardt
2019-01-16 14:17                                                   ` Danny Milosavljevic
2019-01-16 17:39                                                     ` Pierre Neidhardt
2019-01-16 18:12                                                       ` Efraim Flashner
2019-01-16 18:18                                                         ` Pierre Neidhardt
2019-01-16 19:57                                                           ` Danny Milosavljevic
2019-01-16 22:32                                                             ` Ludovic Courtès
2019-01-16 22:45                                                               ` Danny Milosavljevic
2019-01-17  7:31                                                                 ` Pierre Neidhardt
2019-01-17  8:43                                                                   ` Ludovic Courtès
2019-01-17  9:39                                                                     ` Pierre Neidhardt
2019-01-17  9:42                                                                       ` Pierre Neidhardt
2019-01-17 11:32                                                                         ` Pierre Neidhardt
2019-11-28  0:13                                                                           ` Marius Bakke
2019-01-17  9:10                                                                   ` Danny Milosavljevic
2019-01-17  8:33                                                       ` Ludovic Courtès
2019-01-17  8:41                                                         ` Pierre Neidhardt
2021-04-22 18:53 ` G. Branden Robinson

Code repositories for project(s) associated with this external index

	https://git.savannah.gnu.org/cgit/guix.git

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.