Fix varargs.h issue with gcc 3.4

PR:		ports/71460
Submitted by:	KIMURA Yasuhiro
This commit is contained in:
Volker Stolz 2004-11-08 12:37:10 +00:00
parent 8688583b78
commit 6fecd67527
Notes: svn2git 2021-03-31 03:12:20 +00:00
svn path=/head/; revision=121124
2 changed files with 100 additions and 0 deletions

View File

@ -0,0 +1,49 @@
--- clients/ftp/ftp.c.orig Thu Aug 17 00:38:44 2000
+++ clients/ftp/ftp.c Tue Sep 7 20:41:35 2004
@@ -48,7 +48,15 @@
#include <fcntl.h>
#endif
+#ifdef HAVE_STDARG_H
+#include <stdarg.h>
+#define VA_START(a, b) va_start((a), (b))
+#define va_alist ...
+#define va_dcl
+#else
#include <varargs.h>
+#define VA_START(a, b) va_start((a))
+#endif
#ifdef FASCIST
#include <syslog.h>
@@ -241,9 +249,8 @@
}
/*VARARGS*/
-int command(va_alist) va_dcl {
+int command(char *fmt, va_alist) va_dcl {
va_list ap;
- char *fmt;
int r;
Sig_t oldintr;
@@ -251,8 +258,7 @@
if (debug) {
printf("---> ");
- va_start(ap);
- fmt = va_arg(ap, char *);
+ VA_START(ap, fmt);
if (strncmp("PASS ", fmt, 5) == 0)
printf("PASS XXXX");
else
@@ -271,8 +277,7 @@
oldintr = Signal(SIGINT, cmdabort);
- va_start(ap);
- fmt = va_arg(ap, char *);
+ VA_START(ap, fmt);
vfprintf(cout, fmt, ap);
va_end(ap);

View File

@ -0,0 +1,51 @@
--- clients/telnet/commands.c.orig Thu Aug 17 00:38:46 2000
+++ clients/telnet/commands.c Tue Sep 7 20:39:04 2004
@@ -83,7 +83,17 @@
#include <signal.h>
#include <ctype.h>
#include <pwd.h>
+
+#ifdef HAVE_STDARG_H
+#include <stdarg.h>
+#define VA_START(a, b) va_start((a), (b))
+#define va_alist ...
+#define va_dcl
+#else
#include <varargs.h>
+#define VA_START(a, b) va_start((a))
+#endif
+
#include <errno.h>
#include <arpa/telnet.h>
@@ -122,7 +132,9 @@
extern int Ambiguous();
extern void herror();
-static int call();
+typedef int (*intrtn_t)();
+
+static int call(intrtn_t routine, va_alist);
typedef struct {
char *name; /* command name */
@@ -2092,17 +2104,14 @@
/*VARARGS1*/
static int
-call(va_alist)
+call(intrtn_t routine, va_alist)
va_dcl
{
va_list ap;
- typedef int (*intrtn_t)();
- intrtn_t routine;
char *args[100];
int argno = 0;
- va_start(ap);
- routine = (va_arg(ap, intrtn_t));
+ VA_START(ap, routine);
while ((args[argno++] = va_arg(ap, char *)) != 0) {
;
}