Hi All,

On Thu, May 1, 2025 at 8:41 AM Chris Packham <judge.pack...@gmail.com> wrote:
>
> C23 changes how function definitions like int `int tputs ()` are
> interpreted. In older standards this meant that the function arguments
> are unknown. In C23 this is interpreted as `int tputs (void)` so now
> when we compile with GCC15 (which defaults to -std=gnu23) we get an
> error such as
>
>   readline/display.c:2839:17: error: too many arguments to function 'tputs'; 
> expected 0, have 3
>
> Add the function arguments for tgetent(), tgetflag(), tgetnum(),
> tgetstr(), tputs() and tgoto().
>
> Signed-off-by: Chris Packham <judge.pack...@gmail.com>

I originally sent this to gdb-patches because I hit the build issue
with gdb. It looks like this is already fixed in upstream readline so
sorry for the noise.

> ---
>  readline/readline/tcap.h | 12 ++++++------
>  1 file changed, 6 insertions(+), 6 deletions(-)
>
> diff --git a/readline/readline/tcap.h b/readline/readline/tcap.h
> index 859e6eed5aa..9e2ed124e49 100644
> --- a/readline/readline/tcap.h
> +++ b/readline/readline/tcap.h
> @@ -46,14 +46,14 @@ extern char *UP, *BC;
>
>  extern short ospeed;
>
> -extern int tgetent ();
> -extern int tgetflag ();
> -extern int tgetnum ();
> -extern char *tgetstr ();
> +extern int tgetent (char *bp, const char *name);
> +extern int tgetflag (char *id);
> +extern int tgetnum (char *id);
> +extern char *tgetstr (char *id, char **area);
>
> -extern int tputs ();
> +extern int tputs (const char *str, int affcnt, int (*putc)(int));
>
> -extern char *tgoto ();
> +extern char *tgoto (const char *cap, int col, int row);
>
>  #endif /* HAVE_TERMCAP_H */
>
> --
> 2.49.0
>

Reply via email to