Now compiles on alpha

git-svn-id: svn://svn.h5l.se/heimdal/trunk/heimdal@386 ec53bebd-3082-4978-b11e-865c3cabbd6b
This commit is contained in:
Unknown User d91-jda
1996-04-06 06:37:59 +00:00
parent ddec2e194e
commit fae6f2292a
10 changed files with 327 additions and 526 deletions

View File

@@ -1,8 +1,13 @@
# @(#)Makefile 8.2 (Berkeley) 4/3/94
# $NetBSD: Makefile,v 1.6 1995/11/22 21:52:48 cgd Exp $
CC=cc -std1
#CC=gcc
CFLAGS=-g -DHAVE_CONFIG_H -I.. -I../libmissing -I$(ATHENA)/include -I.
PROG= ftp
SRCS= cmds.c cmdtab.c ftp.c main.c ruserpass.c domacro.c
CFLAGS+= -Dunix
ATHENA = /usr/athena
.include <bsd.prog.mk>
ftp_OBJS = cmds.o cmdtab.o ftp.o main.o ruserpass.o domacro.o globals.o
ftp: $(ftp_OBJS)
$(CC) -o ftp $(ftp_OBJS) ../libmissing/libmissing.a -L$(ATHENA)/lib -lkrb -ldes
clean:
rm -f *~ *.o core ftpd ftpcmd.c \#*

View File

@@ -33,37 +33,13 @@
* SUCH DAMAGE.
*/
#ifndef lint
#if 0
static char sccsid[] = "@(#)cmds.c 8.6 (Berkeley) 10/9/94";
#else
static char rcsid[] = "$NetBSD: cmds.c,v 1.8 1995/09/08 01:06:05 tls Exp $";
#endif
#endif /* not lint */
/*
* FTP User Program -- Command Routines.
*/
#include <sys/param.h>
#include <sys/wait.h>
#include <sys/stat.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/ftp.h>
#include <ctype.h>
#include <err.h>
#include <glob.h>
#include <netdb.h>
#include <signal.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <time.h>
#include <unistd.h>
#include "ftp_locl.h"
#include "ftp_var.h"
#include "pathnames.h"
typedef void (*sighand)(int);
jmp_buf jabort;
char *mname;
@@ -76,21 +52,18 @@ char *home = "/";
* Returns false if no new arguments have been added.
*/
int
another(pargc, pargv, prompt)
int *pargc;
char ***pargv;
char *prompt;
another(int *pargc, char ***pargv, char *prompt)
{
int len = strlen(line), ret;
if (len >= sizeof(line) - 3) {
printf("sorry, arguments too long\n");
intr();
intr(0);
}
printf("(%s) ", prompt);
line[len++] = ' ';
if (fgets(&line[len], sizeof(line) - len, stdin) == NULL)
intr();
intr(0);
len += strlen(&line[len]);
if (len > 0 && line[len - 1] == '\n')
line[len - 1] = '\0';
@@ -106,9 +79,7 @@ another(pargc, pargv, prompt)
* auto-login, if possible.
*/
void
setpeer(argc, argv)
int argc;
char *argv[];
setpeer(int argc, char **argv)
{
char *host;
short port;
@@ -228,9 +199,7 @@ struct types {
* Set transfer type.
*/
void
settype(argc, argv)
int argc;
char *argv[];
settype(int argc, char **argv)
{
struct types *p;
int comret;
@@ -277,8 +246,7 @@ settype(argc, argv)
* Used to change to and from ascii for listings.
*/
void
changetype(newtype, show)
int newtype, show;
changetype(int newtype, int show)
{
struct types *p;
int comret, oldverbose = verbose;
@@ -316,9 +284,7 @@ char *stype[] = {
*/
/*VARARGS*/
void
setbinary(argc, argv)
int argc;
char **argv;
setbinary(int argc, char **argv)
{
stype[1] = "binary";
@@ -330,9 +296,7 @@ setbinary(argc, argv)
*/
/*VARARGS*/
void
setascii(argc, argv)
int argc;
char *argv[];
setascii(int argc, char **argv)
{
stype[1] = "ascii";
@@ -344,9 +308,7 @@ setascii(argc, argv)
*/
/*VARARGS*/
void
settenex(argc, argv)
int argc;
char *argv[];
settenex(int argc, char **argv)
{
stype[1] = "tenex";
@@ -358,9 +320,7 @@ settenex(argc, argv)
*/
/*ARGSUSED*/
void
setftmode(argc, argv)
int argc;
char *argv[];
setftmode(int argc, char **argv)
{
printf("We only support %s mode, sorry.\n", modename);
@@ -372,9 +332,7 @@ setftmode(argc, argv)
*/
/*ARGSUSED*/
void
setform(argc, argv)
int argc;
char *argv[];
setform(int argc, char **argv)
{
printf("We only support %s format, sorry.\n", formname);
@@ -386,9 +344,7 @@ setform(argc, argv)
*/
/*ARGSUSED*/
void
setstruct(argc, argv)
int argc;
char *argv[];
setstruct(int argc, char **argv)
{
printf("We only support %s structure, sorry.\n", structname);
@@ -399,9 +355,7 @@ setstruct(argc, argv)
* Send a single file.
*/
void
put(argc, argv)
int argc;
char *argv[];
put(int argc, char **argv)
{
char *cmd;
int loc = 0;
@@ -448,12 +402,10 @@ usage:
* Send multiple files.
*/
void
mput(argc, argv)
int argc;
char **argv;
mput(int argc, char **argv)
{
int i;
sig_t oldintr;
sighand oldintr;
int ointer;
char *tp;
@@ -568,18 +520,14 @@ mput(argc, argv)
}
void
reget(argc, argv)
int argc;
char *argv[];
reget(int argc, char **argv)
{
(void) getit(argc, argv, 1, "r+w");
}
void
get(argc, argv)
int argc;
char *argv[];
get(int argc, char **argv)
{
(void) getit(argc, argv, 0, restart_point ? "r+w" : "w" );
@@ -589,11 +537,7 @@ get(argc, argv)
* Receive one file.
*/
int
getit(argc, argv, restartit, mode)
int argc;
char *argv[];
char *mode;
int restartit;
getit(int argc, char **argv, int restartit, char *mode)
{
int loc = 0;
char *oldargv1, *oldargv2;
@@ -697,8 +641,7 @@ usage:
/* ARGSUSED */
void
mabort(signo)
int signo;
mabort(int signo)
{
int ointer;
@@ -721,11 +664,9 @@ mabort(signo)
* Get multiple files.
*/
void
mget(argc, argv)
int argc;
char **argv;
mget(int argc, char **argv)
{
sig_t oldintr;
sighand oldintr;
int ch, ointer;
char *cp, *tp, *tp2, tmpbuf[MAXPATHLEN];
@@ -774,9 +715,7 @@ mget(argc, argv)
}
char *
remglob(argv,doswitch)
char *argv[];
int doswitch;
remglob(char **argv, int doswitch)
{
char temp[16];
static char buf[MAXPATHLEN];
@@ -835,8 +774,7 @@ remglob(argv,doswitch)
}
char *
onoff(bool)
int bool;
onoff(int bool)
{
return (bool ? "on" : "off");
@@ -847,9 +785,7 @@ onoff(bool)
*/
/*ARGSUSED*/
void
status(argc, argv)
int argc;
char *argv[];
status(int argc, char **argv)
{
int i;
@@ -903,9 +839,7 @@ status(argc, argv)
*/
/*VARARGS*/
void
setbell(argc, argv)
int argc;
char *argv[];
setbell(int argc, char **argv)
{
bell = !bell;
@@ -918,9 +852,7 @@ setbell(argc, argv)
*/
/*VARARGS*/
void
settrace(argc, argv)
int argc;
char *argv[];
settrace(int argc, char **argv)
{
trace = !trace;
@@ -933,9 +865,7 @@ settrace(argc, argv)
*/
/*VARARGS*/
void
sethash(argc, argv)
int argc;
char *argv[];
sethash(int argc, char **argv)
{
hash = !hash;
@@ -951,9 +881,7 @@ sethash(argc, argv)
*/
/*VARARGS*/
void
setverbose(argc, argv)
int argc;
char *argv[];
setverbose(int argc, char **argv)
{
verbose = !verbose;
@@ -966,9 +894,7 @@ setverbose(argc, argv)
*/
/*VARARGS*/
void
setport(argc, argv)
int argc;
char *argv[];
setport(int argc, char **argv)
{
sendport = !sendport;
@@ -982,9 +908,7 @@ setport(argc, argv)
*/
/*VARARGS*/
void
setprompt(argc, argv)
int argc;
char *argv[];
setprompt(int argc, char **argv)
{
interactive = !interactive;
@@ -998,9 +922,7 @@ setprompt(argc, argv)
*/
/*VARARGS*/
void
setglob(argc, argv)
int argc;
char *argv[];
setglob(int argc, char **argv)
{
doglob = !doglob;
@@ -1014,9 +936,7 @@ setglob(argc, argv)
*/
/*VARARGS*/
void
setdebug(argc, argv)
int argc;
char *argv[];
setdebug(int argc, char **argv)
{
int val;
@@ -1043,9 +963,7 @@ setdebug(argc, argv)
* on remote machine.
*/
void
cd(argc, argv)
int argc;
char *argv[];
cd(int argc, char **argv)
{
if (argc < 2 && !another(&argc, &argv, "remote-directory")) {
@@ -1065,9 +983,7 @@ cd(argc, argv)
* on local machine.
*/
void
lcd(argc, argv)
int argc;
char *argv[];
lcd(int argc, char **argv)
{
char buf[MAXPATHLEN];
@@ -1098,9 +1014,7 @@ lcd(argc, argv)
* Delete a single file.
*/
void
delete(argc, argv)
int argc;
char *argv[];
delete(int argc, char **argv)
{
if (argc < 2 && !another(&argc, &argv, "remote-file")) {
@@ -1115,11 +1029,9 @@ delete(argc, argv)
* Delete multiple files.
*/
void
mdelete(argc, argv)
int argc;
char **argv;
mdelete(int argc, char **argv)
{
sig_t oldintr;
sighand oldintr;
int ointer;
char *cp;
@@ -1157,9 +1069,7 @@ mdelete(argc, argv)
* Rename a remote file.
*/
void
renamefile(argc, argv)
int argc;
char *argv[];
renamefile(int argc, char **argv)
{
if (argc < 2 && !another(&argc, &argv, "from-name"))
@@ -1179,9 +1089,7 @@ usage:
* of remote files.
*/
void
ls(argc, argv)
int argc;
char *argv[];
ls(int argc, char **argv)
{
char *cmd;
@@ -1212,11 +1120,9 @@ ls(argc, argv)
* of multiple remote files.
*/
void
mls(argc, argv)
int argc;
char **argv;
mls(int argc, char **argv)
{
sig_t oldintr;
sighand oldintr;
int ointer, i;
char *cmd, mode[1], *dest;
@@ -1262,14 +1168,12 @@ usage:
*/
/*ARGSUSED*/
void
shell(argc, argv)
int argc;
char **argv;
shell(int argc, char **argv)
{
pid_t pid;
sig_t old1, old2;
sighand old1, old2;
char shellnam[40], *shell, *namep;
union wait status;
int status;
old1 = signal (SIGINT, SIG_IGN);
old2 = signal (SIGQUIT, SIG_IGN);
@@ -1303,7 +1207,7 @@ shell(argc, argv)
exit(1);
}
if (pid > 0)
while (wait((int *)&status) != pid)
while (wait(&status) != pid)
;
(void) signal(SIGINT, old1);
(void) signal(SIGQUIT, old2);
@@ -1320,9 +1224,7 @@ shell(argc, argv)
* Send new user information (re-login)
*/
void
user(argc, argv)
int argc;
char **argv;
user(int argc, char **argv)
{
char acct[80];
int n, aflag = 0;
@@ -1364,9 +1266,7 @@ user(argc, argv)
*/
/*VARARGS*/
void
pwd(argc, argv)
int argc;
char *argv[];
pwd(int argc, char **argv)
{
int oldverbose = verbose;
@@ -1385,9 +1285,7 @@ pwd(argc, argv)
* Make a directory.
*/
void
makedir(argc, argv)
int argc;
char *argv[];
makedir(int argc, char **argv)
{
if (argc < 2 && !another(&argc, &argv, "directory-name")) {
@@ -1406,9 +1304,7 @@ makedir(argc, argv)
* Remove a directory.
*/
void
removedir(argc, argv)
int argc;
char *argv[];
removedir(int argc, char **argv)
{
if (argc < 2 && !another(&argc, &argv, "directory-name")) {
@@ -1427,9 +1323,7 @@ removedir(argc, argv)
* Send a line, verbatim, to the remote machine.
*/
void
quote(argc, argv)
int argc;
char *argv[];
quote(int argc, char **argv)
{
if (argc < 2 && !another(&argc, &argv, "command line to send")) {
@@ -1446,9 +1340,7 @@ quote(argc, argv)
* word "SITE" is added at the front.
*/
void
site(argc, argv)
int argc;
char *argv[];
site(int argc, char **argv)
{
if (argc < 2 && !another(&argc, &argv, "arguments to SITE command")) {
@@ -1464,10 +1356,7 @@ site(argc, argv)
* Send the result as a one-line command and get response.
*/
void
quote1(initial, argc, argv)
char *initial;
int argc;
char **argv;
quote1(char *initial, int argc, char **argv)
{
int i, len;
char buf[BUFSIZ]; /* must be >= sizeof(line) */
@@ -1488,9 +1377,7 @@ quote1(initial, argc, argv)
}
void
do_chmod(argc, argv)
int argc;
char *argv[];
do_chmod(int argc, char **argv)
{
if (argc < 2 && !another(&argc, &argv, "mode"))
@@ -1505,9 +1392,7 @@ usage:
}
void
do_umask(argc, argv)
int argc;
char *argv[];
do_umask(int argc, char **argv)
{
int oldverbose = verbose;
@@ -1517,9 +1402,7 @@ do_umask(argc, argv)
}
void
idle(argc, argv)
int argc;
char *argv[];
idle(int argc, char **argv)
{
int oldverbose = verbose;
@@ -1532,9 +1415,7 @@ idle(argc, argv)
* Ask the other side for help.
*/
void
rmthelp(argc, argv)
int argc;
char *argv[];
rmthelp(int argc, char **argv)
{
int oldverbose = verbose;
@@ -1548,9 +1429,7 @@ rmthelp(argc, argv)
*/
/*VARARGS*/
void
quit(argc, argv)
int argc;
char *argv[];
quit(int argc, char **argv)
{
if (connected)
@@ -1566,9 +1445,7 @@ quit(argc, argv)
* Terminate session, but don't exit.
*/
void
disconnect(argc, argv)
int argc;
char *argv[];
disconnect(int argc, char **argv)
{
if (!connected)
@@ -1586,8 +1463,7 @@ disconnect(argc, argv)
}
int
confirm(cmd, file)
char *cmd, *file;
confirm(char *cmd, char *file)
{
char line[BUFSIZ];
@@ -1601,8 +1477,7 @@ confirm(cmd, file)
}
void
fatal(msg)
char *msg;
fatal(char *msg)
{
errx(1, "%s", msg);
@@ -1615,8 +1490,7 @@ fatal(msg)
* from the expression, we return only the first.
*/
int
globulize(cpp)
char **cpp;
globulize(char **cpp)
{
glob_t gl;
int flags;
@@ -1638,9 +1512,7 @@ globulize(cpp)
}
void
account(argc,argv)
int argc;
char **argv;
account(int argc, char **argv)
{
char acct[50], *ap;
@@ -1665,7 +1537,7 @@ account(argc,argv)
jmp_buf abortprox;
void
proxabort()
proxabort(int sig)
{
if (!proxy) {
@@ -1682,12 +1554,10 @@ proxabort()
}
void
doproxy(argc, argv)
int argc;
char *argv[];
doproxy(int argc, char **argv)
{
struct cmd *c;
sig_t oldintr;
sighand oldintr;
if (argc < 2 && !another(&argc, &argv, "command")) {
printf("usage: %s command\n", argv[0]);
@@ -1739,9 +1609,7 @@ doproxy(argc, argv)
}
void
setcase(argc, argv)
int argc;
char *argv[];
setcase(int argc, char **argv)
{
mcase = !mcase;
@@ -1750,9 +1618,7 @@ setcase(argc, argv)
}
void
setcr(argc, argv)
int argc;
char *argv[];
setcr(int argc, char **argv)
{
crflag = !crflag;
@@ -1761,9 +1627,7 @@ setcr(argc, argv)
}
void
setntrans(argc,argv)
int argc;
char *argv[];
setntrans(int argc, char **argv)
{
if (argc == 1) {
ntflag = 0;
@@ -1784,8 +1648,7 @@ setntrans(argc,argv)
}
char *
dotrans(name)
char *name;
dotrans(char *name)
{
static char new[MAXPATHLEN];
char *cp1, *cp2 = new;
@@ -1813,9 +1676,7 @@ dotrans(name)
}
void
setnmap(argc, argv)
int argc;
char *argv[];
setnmap(int argc, char **argv)
{
char *cp;
@@ -1847,8 +1708,7 @@ setnmap(argc, argv)
}
char *
domap(name)
char *name;
domap(char *name)
{
static char new[MAXPATHLEN];
char *cp1 = name, *cp2 = mapin;
@@ -2017,9 +1877,7 @@ LOOP:
}
void
setpassive(argc, argv)
int argc;
char *argv[];
setpassive(int argc, char **argv)
{
passivemode = !passivemode;
@@ -2028,9 +1886,7 @@ setpassive(argc, argv)
}
void
setsunique(argc, argv)
int argc;
char *argv[];
setsunique(int argc, char **argv)
{
sunique = !sunique;
@@ -2039,9 +1895,7 @@ setsunique(argc, argv)
}
void
setrunique(argc, argv)
int argc;
char *argv[];
setrunique(int argc, char **argv)
{
runique = !runique;
@@ -2051,9 +1905,7 @@ setrunique(argc, argv)
/* change directory to perent directory */
void
cdup(argc, argv)
int argc;
char *argv[];
cdup(int argc, char **argv)
{
if (command("CDUP") == ERROR && code == 500) {
@@ -2065,9 +1917,7 @@ cdup(argc, argv)
/* restart transfer at specific point */
void
restart(argc, argv)
int argc;
char *argv[];
restart(int argc, char **argv)
{
if (argc != 2)
@@ -2081,18 +1931,14 @@ restart(argc, argv)
/* show remote system type */
void
syst(argc, argv)
int argc;
char *argv[];
syst(int argc, char **argv)
{
(void) command("SYST");
}
void
macdef(argc, argv)
int argc;
char *argv[];
macdef(int argc, char **argv)
{
char *tmp;
int c;
@@ -2154,9 +2000,7 @@ macdef(argc, argv)
* get size of file on remote machine
*/
void
sizecmd(argc, argv)
int argc;
char *argv[];
sizecmd(int argc, char **argv)
{
if (argc < 2 && !another(&argc, &argv, "filename")) {
@@ -2171,9 +2015,7 @@ sizecmd(argc, argv)
* get last modification time of file on remote machine
*/
void
modtime(argc, argv)
int argc;
char *argv[];
modtime(int argc, char **argv)
{
int overbose;
@@ -2201,9 +2043,7 @@ modtime(argc, argv)
* show status on reomte machine
*/
void
rmtstatus(argc, argv)
int argc;
char *argv[];
rmtstatus(int argc, char **argv)
{
(void) command(argc > 1 ? "STAT %s" : "STAT" , argv[1]);
@@ -2213,9 +2053,7 @@ rmtstatus(argc, argv)
* get file if modtime is more recent than current file
*/
void
newer(argc, argv)
int argc;
char *argv[];
newer(int argc, char **argv)
{
if (getit(argc, argv, -1, "w"))

View File

@@ -33,16 +33,7 @@
* SUCH DAMAGE.
*/
#ifndef lint
#if 0
static char sccsid[] = "@(#)cmdtab.c 8.4 (Berkeley) 10/9/94";
#else
static char rcsid[] = "$NetBSD: cmdtab.c,v 1.6 1995/09/08 01:06:10 tls Exp $";
#endif
#endif /* not lint */
#include <stdio.h>
#include "ftp_var.h"
#include "ftp_locl.h"
/*
* User FTP -- Command Tables.

View File

@@ -33,25 +33,10 @@
* SUCH DAMAGE.
*/
#ifndef lint
#if 0
static char sccsid[] = "@(#)domacro.c 8.3 (Berkeley) 4/2/94";
#else
static char rcsid[] = "$NetBSD: domacro.c,v 1.5 1995/09/08 01:06:14 tls Exp $";
#endif
#endif /* not lint */
#include <ctype.h>
#include <signal.h>
#include <stdio.h>
#include <strings.h>
#include "ftp_var.h"
#include "ftp_locl.h"
void
domacro(argc, argv)
int argc;
char *argv[];
domacro(int argc, char **argv)
{
int i, j, count = 2, loopflg = 0;
char *cp1, *cp2, line2[200];

View File

@@ -35,22 +35,32 @@
* @(#)extern.h 8.3 (Berkeley) 10/9/94
*/
struct timeval;
struct fd_set;
#include <setjmp.h>
#include <stdlib.h>
#include <sys/time.h>
#include <sys/select.h>
#ifndef __P
#ifdef __STDC__
#define __P(X) X
#else
#define __P(X)
#endif
#endif
void abort_remote __P((FILE *));
void abortpt __P(());
void abortrecv __P(());
void abortsend __P(());
void abortpt __P((int));
void abortrecv __P((int));
void abortsend __P((int));
void account __P((int, char **));
int another __P((int *, char ***, char *));
void blkfree __P((char **));
void cd __P((int, char **));
void cdup __P((int, char **));
void changetype __P((int, int));
void cmdabort __P(());
void cmdabort __P((int));
void cmdscanner __P((int));
int command __P(());
int command __((char *fmt, ...));
int confirm __P((char *, char *));
FILE *dataconn __P((char *));
void delete __P((int, char **));
@@ -73,10 +83,10 @@ void help __P((int, char **));
char *hookup __P((char *, int));
void idle __P((int, char **));
int initconn __P((void));
void intr __P(());
void intr __P((int));
void lcd __P((int, char **));
int login __P((char *));
void lostpeer __P(());
void lostpeer __P((int));
void ls __P((int, char **));
void mabort __P((int));
void macdef __P((int, char **));
@@ -89,9 +99,9 @@ void modtime __P((int, char **));
void mput __P((int, char **));
char *onoff __P((int));
void newer __P((int, char **));
void proxabort __P(());
void proxabort __P((int));
void proxtrans __P((char *, char *, char *));
void psabort __P(());
void psabort __P((int));
void pswitch __P((int));
void ptransfer __P((char *, long, struct timeval *, struct timeval *));
void put __P((int, char **));

View File

@@ -33,44 +33,7 @@
* SUCH DAMAGE.
*/
#ifndef lint
#if 0
static char sccsid[] = "@(#)ftp.c 8.6 (Berkeley) 10/27/94";
#else
static char rcsid[] = "$NetBSD: ftp.c,v 1.13 1995/09/16 22:32:59 pk Exp $";
#endif
#endif /* not lint */
#include <sys/param.h>
#include <sys/stat.h>
#include <sys/ioctl.h>
#include <sys/socket.h>
#include <sys/time.h>
#include <sys/file.h>
#include <netinet/in.h>
#include <netinet/in_systm.h>
#include <netinet/ip.h>
#include <arpa/inet.h>
#include <arpa/ftp.h>
#include <arpa/telnet.h>
#include <ctype.h>
#include <err.h>
#include <errno.h>
#include <fcntl.h>
#include <netdb.h>
#include <pwd.h>
#include <signal.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <varargs.h>
#include "ftp_var.h"
extern int h_errno;
#include "ftp_locl.h"
struct sockaddr_in hisctladdr;
struct sockaddr_in data_addr;
@@ -85,10 +48,10 @@ off_t restart_point = 0;
FILE *cin, *cout;
typedef void (*sighand)(int);
char *
hookup(host, port)
char *host;
int port;
hookup(char *host, int port)
{
struct hostent *hp = 0;
int s, len, tos;
@@ -195,8 +158,7 @@ bad:
}
int
login(host)
char *host;
login(char *host)
{
char tmp[80];
char *user, *pass, *acct;
@@ -258,7 +220,7 @@ login(host)
}
void
cmdabort()
cmdabort(int sig)
{
printf("\n");
@@ -268,39 +230,34 @@ cmdabort()
longjmp(ptabort,1);
}
/*VARARGS*/
int
command(va_alist)
va_dcl
command(char *fmt, ...)
{
va_list ap;
char *fmt;
int r;
sig_t oldintr;
sighand oldintr;
abrtflag = 0;
if (debug) {
if (debug)
printf("---> ");
va_start(ap);
fmt = va_arg(ap, char *);
if (strncmp("PASS ", fmt, 5) == 0)
printf("PASS XXXX");
else
vfprintf(stdout, fmt, ap);
va_end(ap);
printf("\n");
(void) fflush(stdout);
}
if (cout == NULL) {
warn("No control connection for command");
code = -1;
return (0);
}
oldintr = signal(SIGINT, cmdabort);
va_start(ap);
fmt = va_arg(ap, char *);
va_start(ap, fmt);
if(debug)
if (strncmp("PASS ", fmt, 5) == 0)
printf("PASS XXXX");
else
vfprintf(stdout, fmt, ap);
vfprintf(cout, fmt, ap);
va_end(ap);
if(debug){
printf("\n");
(void) fflush(stdout);
}
fprintf(cout, "\r\n");
(void) fflush(cout);
cpend = 1;
@@ -314,13 +271,12 @@ va_dcl
char reply_string[BUFSIZ]; /* last line of previous reply */
int
getreply(expecteof)
int expecteof;
getreply(int expecteof)
{
int c, n;
int dig;
int originalcode = 0, continuation = 0;
sig_t oldintr;
sighand oldintr;
int pflag = 0;
char *cp, *pt = pasv;
@@ -355,7 +311,7 @@ getreply(expecteof)
code = 221;
return (0);
}
lostpeer();
lostpeer(0);
if (verbose) {
printf("421 Service not available, remote server has closed connection\n");
(void) fflush(stdout);
@@ -408,7 +364,7 @@ getreply(expecteof)
cpend = 0;
(void) signal(SIGINT,oldintr);
if (code == 421 || originalcode == 421)
lostpeer();
lostpeer(0);
if (abrtflag && oldintr != cmdabort && oldintr != SIG_IGN)
(*oldintr)(SIGINT);
return (n - '0');
@@ -416,9 +372,7 @@ getreply(expecteof)
}
int
empty(mask, sec)
struct fd_set *mask;
int sec;
empty(struct fd_set *mask, int sec)
{
struct timeval t;
@@ -430,7 +384,7 @@ empty(mask, sec)
jmp_buf sendabort;
void
abortsend()
abortsend(int sig)
{
mflag = 0;
@@ -443,16 +397,14 @@ abortsend()
#define HASHBYTES 1024
void
sendrequest(cmd, local, remote, printnames)
char *cmd, *local, *remote;
int printnames;
sendrequest(char *cmd, char *local, char *remote, int printnames)
{
struct stat st;
struct timeval start, stop;
int c, d;
FILE *fin, *dout = 0, *popen();
FILE *fin, *dout = 0, *popen(const char *, const char *);
int (*closefunc) __P((FILE *));
sig_t oldintr, oldintp;
sighand oldintr, oldintp;
long bytes = 0, hashbytes = HASHBYTES;
char *lmode, buf[BUFSIZ], *bufp;
@@ -689,7 +641,7 @@ abort:
jmp_buf recvabort;
void
abortrecv()
abortrecv(int sig)
{
mflag = 0;
@@ -700,13 +652,11 @@ abortrecv()
}
void
recvrequest(cmd, local, remote, lmode, printnames)
char *cmd, *local, *remote, *lmode;
int printnames;
recvrequest(char *cmd, char *local, char *remote, char *lmode, int printnames)
{
FILE *fout, *din = 0;
int (*closefunc) __P((FILE *));
sig_t oldintr, oldintp;
sighand oldintr, oldintp;
int c, d, is_retr, tcrflag, bare_lfs = 0;
static int bufsize;
static char *buf;
@@ -1001,7 +951,7 @@ abort:
* otherwise the server's connect may fail.
*/
int
initconn()
initconn(void)
{
char *p, *a;
int result, len, tmpno = 0;
@@ -1038,7 +988,7 @@ initconn()
goto bad;
}
bzero(&data_addr, sizeof(data_addr));
bzero((char*)&data_addr, sizeof(data_addr));
data_addr.sin_family = AF_INET;
a = (char *)&data_addr.sin_addr.s_addr;
a[0] = a0 & 0xff;
@@ -1126,8 +1076,7 @@ bad:
}
FILE *
dataconn(lmode)
char *lmode;
dataconn(char *lmode)
{
struct sockaddr_in from;
int s, fromlen = sizeof (from), tos;
@@ -1152,37 +1101,38 @@ dataconn(lmode)
}
void
ptransfer(direction, bytes, t0, t1)
char *direction;
long bytes;
struct timeval *t0, *t1;
ptransfer(char *direction, long int bytes,
struct timeval *t0, struct timeval *t1)
{
struct timeval td;
float s;
long bs;
if (verbose) {
timersub(t1, t0, &td);
td.tv_sec = t0->tv_sec - t1->tv_sec;
td.tv_usec = t0->tv_usec - t1->tv_usec;
if(td.tv_usec < 0){
td.tv_sec--;
td.tv_usec += 1000000;
}
s = td.tv_sec + (td.tv_usec / 1000000.);
#define nz(x) ((x) == 0 ? 1 : (x))
bs = bytes / nz(s);
bs = bytes / (s?s:1);
printf("%ld bytes %s in %.3g seconds (%ld bytes/s)\n",
bytes, direction, s, bs);
}
}
void
psabort()
psabort(int sig)
{
abrtflag++;
}
void
pswitch(flag)
int flag;
pswitch(int flag)
{
sig_t oldintr;
sighand oldintr;
static struct comvars {
int connect;
char name[MAXHOSTNAMELEN];
@@ -1272,7 +1222,7 @@ pswitch(flag)
}
void
abortpt()
abortpt(int sig)
{
printf("\n");
@@ -1284,10 +1234,9 @@ abortpt()
}
void
proxtrans(cmd, local, remote)
char *cmd, *local, *remote;
proxtrans(char *cmd, char *local, char *remote)
{
sig_t oldintr;
sighand oldintr;
int secndflag = 0, prox_type, nfnd;
char *cmd2;
struct fd_set mask;
@@ -1389,7 +1338,7 @@ abort:
}
if (ptabflg)
code = -1;
lostpeer();
lostpeer(0);
}
(void) getreply(0);
(void) getreply(0);
@@ -1403,9 +1352,7 @@ abort:
}
void
reset(argc, argv)
int argc;
char *argv[];
reset(int argc, char **argv)
{
struct fd_set mask;
int nfnd = 1;
@@ -1416,7 +1363,7 @@ reset(argc, argv)
if ((nfnd = empty(&mask,0)) < 0) {
warn("reset");
code = -1;
lostpeer();
lostpeer(0);
}
else if (nfnd) {
(void) getreply(0);
@@ -1425,8 +1372,7 @@ reset(argc, argv)
}
char *
gunique(local)
char *local;
gunique(char *local)
{
static char new[MAXPATHLEN];
char *cp = strrchr(local, '/');
@@ -1471,8 +1417,7 @@ gunique(local)
}
void
abort_remote(din)
FILE *din;
abort_remote(FILE *din)
{
char buf[BUFSIZ];
int nfnd;
@@ -1498,7 +1443,7 @@ abort_remote(din)
}
if (ptabflg)
code = -1;
lostpeer();
lostpeer(0);
}
if (din && FD_ISSET(fileno(din), &mask)) {
while (read(fileno(din), buf, BUFSIZ) > 0)

View File

@@ -47,64 +47,64 @@
/*
* Options and other state info.
*/
int trace; /* trace packets exchanged */
int hash; /* print # for each buffer transferred */
int sendport; /* use PORT cmd for each data connection */
int verbose; /* print messages coming back from server */
int connected; /* connected to server */
int fromatty; /* input is from a terminal */
int interactive; /* interactively prompt on m* cmds */
int debug; /* debugging level */
int bell; /* ring bell on cmd completion */
int doglob; /* glob local file names */
int autologin; /* establish user account on connection */
int proxy; /* proxy server connection active */
int proxflag; /* proxy connection exists */
int sunique; /* store files on server with unique name */
int runique; /* store local files with unique name */
int mcase; /* map upper to lower case for mget names */
int ntflag; /* use ntin ntout tables for name translation */
int mapflag; /* use mapin mapout templates on file names */
int code; /* return/reply code for ftp command */
int crflag; /* if 1, strip car. rets. on ascii gets */
char pasv[64]; /* passive port for proxy data connection */
int passivemode; /* passive mode enabled */
char *altarg; /* argv[1] with no shell-like preprocessing */
char ntin[17]; /* input translation table */
char ntout[17]; /* output translation table */
char mapin[MAXPATHLEN]; /* input map template */
char mapout[MAXPATHLEN]; /* output map template */
char typename[32]; /* name of file transfer type */
int type; /* requested file transfer type */
int curtype; /* current file transfer type */
char structname[32]; /* name of file transfer structure */
int stru; /* file transfer structure */
char formname[32]; /* name of file transfer format */
int form; /* file transfer format */
char modename[32]; /* name of file transfer mode */
int mode; /* file transfer mode */
char bytename[32]; /* local byte size in ascii */
int bytesize; /* local byte size in binary */
extern int trace; /* trace packets exchanged */
extern int hash; /* print # for each buffer transferred */
extern int sendport; /* use PORT cmd for each data connection */
extern int verbose; /* print messages coming back from server */
extern int connected; /* connected to server */
extern int fromatty; /* input is from a terminal */
extern int interactive; /* interactively prompt on m* cmds */
extern int debug; /* debugging level */
extern int bell; /* ring bell on cmd completion */
extern int doglob; /* glob local file names */
extern int autologin; /* establish user account on connection */
extern int proxy; /* proxy server connection active */
extern int proxflag; /* proxy connection exists */
extern int sunique; /* store files on server with unique name */
extern int runique; /* store local files with unique name */
extern int mcase; /* map upper to lower case for mget names */
extern int ntflag; /* use ntin ntout tables for name translation */
extern int mapflag; /* use mapin mapout templates on file names */
extern int code; /* return/reply code for ftp command */
extern int crflag; /* if 1, strip car. rets. on ascii gets */
extern char pasv[64]; /* passive port for proxy data connection */
extern int passivemode; /* passive mode enabled */
extern char *altarg; /* argv[1] with no shell-like preprocessing */
extern char ntin[17]; /* input translation table */
extern char ntout[17]; /* output translation table */
extern char mapin[MAXPATHLEN]; /* input map template */
extern char mapout[MAXPATHLEN]; /* output map template */
extern char typename[32]; /* name of file transfer type */
extern int type; /* requested file transfer type */
extern int curtype; /* current file transfer type */
extern char structname[32]; /* name of file transfer structure */
extern int stru; /* file transfer structure */
extern char formname[32]; /* name of file transfer format */
extern int form; /* file transfer format */
extern char modename[32]; /* name of file transfer mode */
extern int mode; /* file transfer mode */
extern char bytename[32]; /* local byte size in ascii */
extern int bytesize; /* local byte size in binary */
char *hostname; /* name of host connected to */
int unix_server; /* server is unix, can use binary for ascii */
int unix_proxy; /* proxy is unix, can use binary for ascii */
extern char *hostname; /* name of host connected to */
extern int unix_server; /* server is unix, can use binary for ascii */
extern int unix_proxy; /* proxy is unix, can use binary for ascii */
struct servent *sp; /* service spec for tcp/ftp */
extern struct servent *sp; /* service spec for tcp/ftp */
jmp_buf toplevel; /* non-local goto stuff for cmd scanner */
extern jmp_buf toplevel; /* non-local goto stuff for cmd scanner */
char line[200]; /* input line buffer */
char *stringbase; /* current scan point in line buffer */
char argbuf[200]; /* argument storage buffer */
char *argbase; /* current storage point in arg buffer */
int margc; /* count of arguments on input line */
char **margv; /* args parsed from input line */
int margvlen; /* how large margv is currently */
int cpend; /* flag: if != 0, then pending server reply */
int mflag; /* flag: if != 0, then active multi command */
extern char line[200]; /* input line buffer */
extern char *stringbase; /* current scan point in line buffer */
extern char argbuf[200]; /* argument storage buffer */
extern char *argbase; /* current storage point in arg buffer */
extern int margc; /* count of arguments on input line */
extern char **margv; /* args parsed from input line */
extern int margvlen; /* how large margv is currently */
extern int cpend; /* flag: if != 0, then pending server reply */
extern int mflag; /* flag: if != 0, then active multi command */
int options; /* used during socket creation */
extern int options; /* used during socket creation */
/*
* Format of command table.
@@ -124,6 +124,6 @@ struct macel {
char *mac_end; /* end of macro in macbuf */
};
int macnum; /* number of defined macros */
struct macel macros[16];
char macbuf[4096];
extern int macnum; /* number of defined macros */
extern struct macel macros[16];
extern char macbuf[4096];

71
appl/ftp/ftp/globals.c Normal file
View File

@@ -0,0 +1,71 @@
#include "ftp_locl.h"
/*
* Options and other state info.
*/
int trace; /* trace packets exchanged */
int hash; /* print # for each buffer transferred */
int sendport; /* use PORT cmd for each data connection */
int verbose; /* print messages coming back from server */
int connected; /* connected to server */
int fromatty; /* input is from a terminal */
int interactive; /* interactively prompt on m* cmds */
int debug; /* debugging level */
int bell; /* ring bell on cmd completion */
int doglob; /* glob local file names */
int autologin; /* establish user account on connection */
int proxy; /* proxy server connection active */
int proxflag; /* proxy connection exists */
int sunique; /* store files on server with unique name */
int runique; /* store local files with unique name */
int mcase; /* map upper to lower case for mget names */
int ntflag; /* use ntin ntout tables for name translation */
int mapflag; /* use mapin mapout templates on file names */
int code; /* return/reply code for ftp command */
int crflag; /* if 1, strip car. rets. on ascii gets */
char pasv[64]; /* passive port for proxy data connection */
int passivemode; /* passive mode enabled */
char *altarg; /* argv[1] with no shell-like preprocessing */
char ntin[17]; /* input translation table */
char ntout[17]; /* output translation table */
char mapin[MAXPATHLEN]; /* input map template */
char mapout[MAXPATHLEN]; /* output map template */
char typename[32]; /* name of file transfer type */
int type; /* requested file transfer type */
int curtype; /* current file transfer type */
char structname[32]; /* name of file transfer structure */
int stru; /* file transfer structure */
char formname[32]; /* name of file transfer format */
int form; /* file transfer format */
char modename[32]; /* name of file transfer mode */
int mode; /* file transfer mode */
char bytename[32]; /* local byte size in ascii */
int bytesize; /* local byte size in binary */
char *hostname; /* name of host connected to */
int unix_server; /* server is unix, can use binary for ascii */
int unix_proxy; /* proxy is unix, can use binary for ascii */
struct servent *sp; /* service spec for tcp/ftp */
jmp_buf toplevel; /* non-local goto stuff for cmd scanner */
char line[200]; /* input line buffer */
char *stringbase; /* current scan point in line buffer */
char argbuf[200]; /* argument storage buffer */
char *argbase; /* current storage point in arg buffer */
int margc; /* count of arguments on input line */
char **margv; /* args parsed from input line */
int margvlen; /* how large margv is currently */
int cpend; /* flag: if != 0, then pending server reply */
int mflag; /* flag: if != 0, then active multi command */
int options; /* used during socket creation */
/*
* Format of command table.
*/
int macnum; /* number of defined macros */
struct macel macros[16];
char macbuf[4096];

View File

@@ -31,45 +31,18 @@
* SUCH DAMAGE.
*/
#ifndef lint
static char copyright[] =
"@(#) Copyright (c) 1985, 1989, 1993, 1994\n\
The Regents of the University of California. All rights reserved.\n";
#endif /* not lint */
#ifndef lint
#if 0
static char sccsid[] = "@(#)main.c 8.6 (Berkeley) 10/9/94";
#else
static char rcsid[] = "$NetBSD: main.c,v 1.10 1995/09/15 00:32:33 pk Exp $";
#endif
#endif /* not lint */
/*
* FTP User Program -- Command Interface.
*/
/*#include <sys/ioctl.h>*/
#include <sys/types.h>
#include <sys/socket.h>
#include <arpa/ftp.h>
#include "ftp_locl.h"
#include <ctype.h>
#include <err.h>
#include <netdb.h>
#include <pwd.h>
#include <signal.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include "ftp_var.h"
#ifndef HAVE___PROGNAME
char *__progname;
#endif
int
main(argc, argv)
int argc;
char *argv[];
main(int argc, char **argv)
{
int ch, top;
struct passwd *pw = NULL;
@@ -82,6 +55,10 @@ main(argc, argv)
interactive = 1;
autologin = 1;
#ifndef HAVE___PROGNAME
__progname = argv[0];
#endif
while ((ch = getopt(argc, argv, "dgintv")) != EOF) {
switch (ch) {
case 'd':
@@ -141,7 +118,6 @@ main(argc, argv)
}
if (argc > 0) {
char *xargv[5];
extern char *__progname;
if (setjmp(toplevel))
exit(0);
@@ -166,14 +142,14 @@ main(argc, argv)
}
void
intr()
intr(int sig)
{
longjmp(toplevel, 1);
}
void
lostpeer()
lostpeer(int sig)
{
if (connected) {
@@ -225,8 +201,7 @@ tail(filename)
* Command parser.
*/
void
cmdscanner(top)
int top;
cmdscanner(int top)
{
struct cmd *c;
int l;
@@ -281,8 +256,7 @@ cmdscanner(top)
}
struct cmd *
getcmd(name)
char *name;
getcmd(char *name)
{
char *p, *q;
struct cmd *c, *found;
@@ -316,7 +290,7 @@ getcmd(name)
int slrflag;
void
makeargv()
makeargv(void)
{
char **argp;
@@ -349,7 +323,7 @@ makeargv()
* handle quoting and strings
*/
char *
slurpstring()
slurpstring(void)
{
int got_one = 0;
char *sb = stringbase;
@@ -473,9 +447,7 @@ OUT:
* Call each command handler with argc == 0 and argv[0] == name.
*/
void
help(argc, argv)
int argc;
char *argv[];
help(int argc, char **argv)
{
struct cmd *c;

View File

@@ -33,22 +33,7 @@
* SUCH DAMAGE.
*/
#ifndef lint
static char sccsid[] = "@(#)ruserpass.c 8.4 (Berkeley) 4/27/95";
#endif /* not lint */
#include <sys/types.h>
#include <sys/stat.h>
#include <ctype.h>
#include <err.h>
#include <errno.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include "ftp_var.h"
#include "ftp_locl.h"
static int token __P((void));
static FILE *cfile;
@@ -78,8 +63,7 @@ static struct toktab {
};
int
ruserpass(host, aname, apass, aacct)
char *host, **aname, **apass, **aacct;
ruserpass(char *host, char **aname, char **apass, char **aacct)
{
char *hdir, buf[BUFSIZ], *tmp;
char myname[MAXHOSTNAMELEN], *mydomain;
@@ -244,7 +228,7 @@ bad:
}
static int
token()
token(void)
{
char *cp;
int c;