GNU bug report logs -
#64577
29.0.92; configure on NetBSD forces unstable terminfo library
Previous Next
Reported by: vuori <at> notcom.org
Date: Tue, 11 Jul 2023 20:38:01 UTC
Severity: normal
Found in version 29.0.92
Done: Eli Zaretskii <eliz <at> gnu.org>
Bug is archived. No further changes may be made.
Full log
View this message in rfc822 format
> Date: Wed, 12 Jul 2023 23:22:16 +0300
> From: Valtteri Vuorikoski <vuori <at> notcom.org>
> Cc: 64577 <at> debbugs.gnu.org
>
> On Wed, Jul 12, 2023 at 07:06:42PM +0300, Eli Zaretskii wrote:
> > > It fixes the immediate problem, yes. But I don't think this special
> > > case should stick around, since it seems relevant only to a very
> > > ancient version of NetBSD.
> >
> > We don't want to drop support of old versions just because we can, and
> > we don't really know how "ancient" those ancient versions should
> > actually be to require this special case. We know that in May 2010 it
> > was TRT, but not when it stopped being TRT. Without knowing that, I'd
> > like to avoid removing this, at least until we hear a real problem
> > with it. Asking NetBSD users to install ncurses doesn't sound like a
> > problem to me.
>
> Can't say I'm happy about keeping the magical special case, which will
> result in a different thing happening than what configure prints out.
That happens on other systems as well, look at the code around the
netbsd case. The fact that the configure script says "ncurses" is not
a promise that ncurses will be used, it's just a status report of that
particular test.
> The reason not much has been heard about this is probably that most
> users likely use packaged emacs, and the pkgsrc build system forcibly sets
> TERMINFO=yes if it determines that this is a NetBSD with the relevant
> headers available. See this package build makefile:
> http://cvsweb.netbsd.org/bsdweb.cgi/pkgsrc/editors/emacs21/Makefile.common?rev=1.21&content-type=text/x-cvsweb-markup
> "CPPFLAGS+=-DTERMINFO" (similarly check exists for emacsen up to 28).
If you could find out since when did the NetBSD pkgsrc system start
using this override, it could be a data point that we could consider
in making these decisions.
> How about this then, this way should preserve the intent of the
> original special casing while honoring the library selection configure
> ended up with:
>
> --- a/configure.ac
> +++ b/configure.ac
> @@ -5212,9 +5212,8 @@ AC_DEFUN
> ;;
>
> netbsd)
> - if test "x$LIBS_TERMCAP" != "x-lterminfo"; then
> + if test "x$LIBS_TERMCAP" = "x-ltermcap"; then
> TERMINFO=no
> - LIBS_TERMCAP="-ltermcap"
> fi
> ;;
>
> On ancient NetBSD (without ncurses) LIBS_TERMCAP should be detected as
> -ltermcap, and this will ensure that TERMINFO stays undefined
> (probably a no-op). On a newer system where someone actually wants to use
> termcap and forces LIBS_TERMCAP, this will make sure that TERMINFO is
> "no" even though libtermcap is a symlink to libterminfo (= only
> the termcap compatibility functions will be used and terminfo stuff
> will be ignored even though configure sees tputs() and friends).
>
> The end result should be the same binary as pkgsrc packaging has
> provided for years, except that on a system with ncurses installed
> it will be used.
I don't mind installing the above instead of my proposal, thanks.
This bug report was last modified 1 year and 350 days ago.
Previous Next
GNU bug tracking system
Copyright (C) 1999 Darren O. Benham,
1997,2003 nCipher Corporation Ltd,
1994-97 Ian Jackson.