X-Git-Url: https://ncurses.scripts.mit.edu/?a=blobdiff_plain;f=ncurses%2Ftinfo%2Flib_tparm.c;h=cba31d9fd36b5e7759fcc6353335c60e289da908;hb=refs%2Ftags%2Fv5.6;hp=041667b4f7c3c5814b9934a62f75dfcbe4b9e56d;hpb=55ccd2b959766810cf7db8d1c4462f338ce0afc8;p=ncurses.git diff --git a/ncurses/tinfo/lib_tparm.c b/ncurses/tinfo/lib_tparm.c index 041667b4..cba31d9f 100644 --- a/ncurses/tinfo/lib_tparm.c +++ b/ncurses/tinfo/lib_tparm.c @@ -1,5 +1,5 @@ /**************************************************************************** - * Copyright (c) 1998-2003,2004 Free Software Foundation, Inc. * + * Copyright (c) 1998-2005,2006 Free Software Foundation, Inc. * * * * Permission is hereby granted, free of charge, to any person obtaining a * * copy of this software and associated documentation files (the * @@ -43,7 +43,7 @@ #include #include -MODULE_ID("$Id: lib_tparm.c,v 1.68 2004/02/07 20:52:51 tom Exp $") +MODULE_ID("$Id: lib_tparm.c,v 1.71 2006/11/26 01:12:56 tom Exp $") /* * char * @@ -146,7 +146,7 @@ _nc_free_tparm(void) } #endif -static inline void +static NCURSES_INLINE void get_space(size_t need) { need += out_used; @@ -158,7 +158,7 @@ get_space(size_t need) } } -static inline void +static NCURSES_INLINE void save_text(const char *fmt, const char *s, int len) { size_t s_len = strlen(s); @@ -171,7 +171,7 @@ save_text(const char *fmt, const char *s, int len) out_used += strlen(out_buff + out_used); } -static inline void +static NCURSES_INLINE void save_number(const char *fmt, int number, int len) { if (len < 30) @@ -183,7 +183,7 @@ save_number(const char *fmt, int number, int len) out_used += strlen(out_buff + out_used); } -static inline void +static NCURSES_INLINE void save_char(int c) { if (c == 0) @@ -192,7 +192,7 @@ save_char(int c) out_buff[out_used++] = c; } -static inline void +static NCURSES_INLINE void npush(int x) { if (stack_ptr < STACKSIZE) { @@ -205,7 +205,7 @@ npush(int x) } } -static inline int +static NCURSES_INLINE int npop(void) { int result = 0; @@ -220,7 +220,7 @@ npop(void) return result; } -static inline void +static NCURSES_INLINE void spush(char *x) { if (stack_ptr < STACKSIZE) { @@ -233,7 +233,7 @@ spush(char *x) } } -static inline char * +static NCURSES_INLINE char * spop(void) { static char dummy[] = ""; /* avoid const-cast */ @@ -249,7 +249,7 @@ spop(void) return result; } -static inline const char * +static NCURSES_INLINE const char * parse_format(const char *s, char *format, int *len) { *len = 0; @@ -471,12 +471,12 @@ _nc_tparm_analyze(const char *string, char *p_is_s[NUM_PARM], int *popcount) return number; } -static inline char * +static NCURSES_INLINE char * tparam_internal(const char *string, va_list ap) { #define NUM_VARS 26 char *p_is_s[NUM_PARM]; - long param[NUM_PARM]; + TPARM_ARG param[NUM_PARM]; int popcount; int number; int len; @@ -514,7 +514,7 @@ tparam_internal(const char *string, va_list ap) if (p_is_s[i] != 0) { p_is_s[i] = va_arg(ap, char *); } else { - param[i] = va_arg(ap, long int); + param[i] = va_arg(ap, TPARM_ARG); } } @@ -774,8 +774,14 @@ tparam_internal(const char *string, va_list ap) return (out_buff); } +#if NCURSES_TPARM_VARARGS +#define tparm_varargs tparm +#else +#define tparm_proto tparm +#endif + NCURSES_EXPORT(char *) -tparm(NCURSES_CONST char *string,...) +tparm_varargs(NCURSES_CONST char *string,...) { va_list ap; char *result; @@ -789,3 +795,20 @@ tparm(NCURSES_CONST char *string,...) va_end(ap); return result; } + +#if !NCURSES_TPARM_VARARGS +NCURSES_EXPORT(char *) +tparm_proto(NCURSES_CONST char *string, + TPARM_ARG a1, + TPARM_ARG a2, + TPARM_ARG a3, + TPARM_ARG a4, + TPARM_ARG a5, + TPARM_ARG a6, + TPARM_ARG a7, + TPARM_ARG a8, + TPARM_ARG a9) +{ + return tparm_varargs(string, a1, a2, a3, a4, a5, a6, a7, a8, a9); +} +#endif /* NCURSES_TPARM_VARARGS */