diff options
-rw-r--r-- | usr.bin/ftp/Makefile | 6 | ||||
-rw-r--r-- | usr.bin/ftp/cmds.c | 681 | ||||
-rw-r--r-- | usr.bin/ftp/cmds.h | 84 | ||||
-rw-r--r-- | usr.bin/ftp/cmdtab.c | 36 | ||||
-rw-r--r-- | usr.bin/ftp/complete.c | 5 | ||||
-rw-r--r-- | usr.bin/ftp/cookie.c | 5 | ||||
-rw-r--r-- | usr.bin/ftp/domacro.c | 3 | ||||
-rw-r--r-- | usr.bin/ftp/extern.h | 139 | ||||
-rw-r--r-- | usr.bin/ftp/fetch.c | 8 | ||||
-rw-r--r-- | usr.bin/ftp/ftp_var.h | 5 | ||||
-rw-r--r-- | usr.bin/ftp/list.c | 5 | ||||
-rw-r--r-- | usr.bin/ftp/main.c | 51 | ||||
-rw-r--r-- | usr.bin/ftp/ruserpass.c | 4 | ||||
-rw-r--r-- | usr.bin/ftp/small.c | 723 | ||||
-rw-r--r-- | usr.bin/ftp/small.h | 35 | ||||
-rw-r--r-- | usr.bin/ftp/stringlist.c | 7 | ||||
-rw-r--r-- | usr.bin/ftp/stringlist.h | 7 | ||||
-rw-r--r-- | usr.bin/ftp/util.c | 11 |
18 files changed, 949 insertions, 866 deletions
diff --git a/usr.bin/ftp/Makefile b/usr.bin/ftp/Makefile index a08c78af65f..876cb494f4e 100644 --- a/usr.bin/ftp/Makefile +++ b/usr.bin/ftp/Makefile @@ -1,4 +1,4 @@ -# $OpenBSD: Makefile,v 1.24 2009/01/05 18:51:49 martynas Exp $ +# $OpenBSD: Makefile,v 1.25 2009/05/05 19:35:30 martynas Exp $ # Define SMALL to disable command line editing and https support #CFLAGS+=-DSMALL @@ -12,8 +12,8 @@ LDADD += -L/usr/local/lib -lsocks .endif PROG= ftp -SRCS= cmds.c cmdtab.c complete.c cookie.c domacro.c fetch.c ftp.c list.c \ - main.c ruserpass.c stringlist.c util.c +SRCS= cmds.c cmdtab.c complete.c cookie.c domacro.c fetch.c ftp.c \ + list.c main.c ruserpass.c small.c stringlist.c util.c CPPFLAGS+= -DINET6 diff --git a/usr.bin/ftp/cmds.c b/usr.bin/ftp/cmds.c index d050003c2dc..ec6e99357b2 100644 --- a/usr.bin/ftp/cmds.c +++ b/usr.bin/ftp/cmds.c @@ -1,4 +1,4 @@ -/* $OpenBSD: cmds.c,v 1.69 2009/04/27 22:51:51 martynas Exp $ */ +/* $OpenBSD: cmds.c,v 1.70 2009/05/05 19:35:30 martynas Exp $ */ /* $NetBSD: cmds.c,v 1.27 1997/08/18 10:20:15 lukem Exp $ */ /* @@ -59,6 +59,8 @@ * SUCH DAMAGE. */ +#ifndef SMALL + /* * FTP User Program -- Command Routines. */ @@ -70,9 +72,7 @@ #include <ctype.h> #include <err.h> -#ifndef SMALL #include <fnmatch.h> -#endif /* !SMALL */ #include <glob.h> #include <netdb.h> #include <stdio.h> @@ -82,124 +82,7 @@ #include "ftp_var.h" #include "pathnames.h" - -jmp_buf jabort; -char *mname; -char *home = "/"; - -struct types { - char *t_name; - char *t_mode; - int t_type; - char *t_arg; -} types[] = { - { "ascii", "A", TYPE_A, 0 }, - { "binary", "I", TYPE_I, 0 }, - { "image", "I", TYPE_I, 0 }, - { "ebcdic", "E", TYPE_E, 0 }, - { "tenex", "L", TYPE_L, bytename }, - { NULL } -}; - -/* - * Set transfer type. - */ -void -settype(int argc, char *argv[]) -{ - struct types *p; - int comret; - - if (argc > 2) { - char *sep; - - fprintf(ttyout, "usage: %s [", argv[0]); - sep = ""; - for (p = types; p->t_name; p++) { - fprintf(ttyout, "%s%s", sep, p->t_name); - sep = " | "; - } - fputs("]\n", ttyout); - code = -1; - return; - } - if (argc < 2) { - fprintf(ttyout, "Using %s mode to transfer files.\n", typename); - code = 0; - return; - } - for (p = types; p->t_name; p++) - if (strcmp(argv[1], p->t_name) == 0) - break; - if (p->t_name == 0) { - fprintf(ttyout, "%s: unknown mode.\n", argv[1]); - code = -1; - return; - } - if ((p->t_arg != NULL) && (*(p->t_arg) != '\0')) - comret = command("TYPE %s %s", p->t_mode, p->t_arg); - else - comret = command("TYPE %s", p->t_mode); - if (comret == COMPLETE) { - (void)strlcpy(typename, p->t_name, sizeof typename); - curtype = type = p->t_type; - } -} - -/* - * Internal form of settype; changes current type in use with server - * without changing our notion of the type for data transfers. - * Used to change to and from ascii for listings. - */ -void -changetype(int newtype, int show) -{ - struct types *p; - int comret, oldverbose = verbose; - - if (newtype == 0) - newtype = TYPE_I; - if (newtype == curtype) - return; - if ( -#ifndef SMALL - !debug && -#endif /* !SMALL */ - show == 0) - verbose = 0; - for (p = types; p->t_name; p++) - if (newtype == p->t_type) - break; - if (p->t_name == 0) { - warnx("internal error: unknown type %d.", newtype); - return; - } - if (newtype == TYPE_L && bytename[0] != '\0') - comret = command("TYPE %s %s", p->t_mode, bytename); - else - comret = command("TYPE %s", p->t_mode); - if (comret == COMPLETE) - curtype = newtype; - verbose = oldverbose; -} - -char *stype[] = { - "type", - "", - 0 -}; - -/* - * Set binary transfer type. - */ -/*ARGSUSED*/ -void -setbinary(int argc, char *argv[]) -{ - - stype[1] = "binary"; - settype(2, stype); -} +#include "cmds.h" /* * Set ascii transfer type. @@ -261,28 +144,23 @@ setstruct(int argc, char *argv[]) code = -1; } -#ifndef SMALL void reput(int argc, char *argv[]) { (void)putit(argc, argv, 1); } -#endif /* !SMALL */ -#ifndef SMALL void put(int argc, char *argv[]) { (void)putit(argc, argv, 0); } -#endif /* !SMALL */ /* * Send a single file. */ -#ifndef SMALL void putit(int argc, char *argv[], int restartit) { @@ -317,7 +195,6 @@ usage: if (argv[1] != oldargv1 && argv[2] == oldargv1) { argv[2] = argv[1]; } -#ifndef SMALL if (restartit == 1) { if (curtype != type) changetype(type, 0); @@ -328,7 +205,6 @@ usage: return; } } -#endif /* !SMALL */ if (strcmp(argv[0], "append") == 0) { restartit = 1; } @@ -345,12 +221,10 @@ usage: if (oldargv1 != argv[1]) /* free up after globulize() */ free(argv[1]); } -#endif /* !SMALL */ /* * Send multiple files. */ -#ifndef SMALL void mput(int argc, char *argv[]) { @@ -361,7 +235,6 @@ mput(int argc, char *argv[]) optind = optreset = 1; -#ifndef SMALL while ((ch = getopt(argc, argv, "c")) != -1) { switch(ch) { case 'c': @@ -371,7 +244,6 @@ mput(int argc, char *argv[]) goto usage; } } -#endif /* !SMALL */ if (argc - optind < 1 && !another(&argc, &argv, "local-files")) { usage: @@ -380,11 +252,9 @@ usage: return; } -#ifndef SMALL argv[optind - 1] = argv[0]; argc -= optind - 1; argv += optind - 1; -#endif /* !SMALL */ mname = argv[0]; mflag = 1; @@ -425,7 +295,6 @@ usage: if (mapflag) { tp = domap(tp); } -#ifndef SMALL if (restartit == 1) { off_t ret; @@ -434,7 +303,6 @@ usage: ret = remotesize(tp, 0); restart_point = (ret < 0) ? 0 : ret; } -#endif /* !SMALL */ cmd = restartit ? "APPE" : ((sunique) ? "STOU" : "STOR"); sendrequest(cmd, cp, tp, @@ -459,7 +327,6 @@ usage: if (mflag && confirm(argv[0], argv[i])) { tp = (ntflag) ? dotrans(argv[i]) : argv[i]; tp = (mapflag) ? domap(tp) : tp; -#ifndef SMALL if (restartit == 1) { off_t ret; @@ -468,7 +335,6 @@ usage: ret = remotesize(tp, 0); restart_point = (ret < 0) ? 0 : ret; } -#endif /* !SMALL */ cmd = restartit ? "APPE" : ((sunique) ? "STOU" : "STOR"); sendrequest(cmd, argv[i], tp, @@ -493,7 +359,6 @@ usage: if (mflag && confirm(argv[0], *cpp)) { tp = (ntflag) ? dotrans(*cpp) : *cpp; tp = (mapflag) ? domap(tp) : tp; -#ifndef SMALL if (restartit == 1) { off_t ret; @@ -502,7 +367,6 @@ usage: ret = remotesize(tp, 0); restart_point = (ret < 0) ? 0 : ret; } -#endif /* !SMALL */ cmd = restartit ? "APPE" : ((sunique) ? "STOU" : "STOR"); sendrequest(cmd, *cpp, tp, @@ -519,286 +383,13 @@ usage: (void)signal(SIGINT, oldintr); mflag = 0; } -#endif /* !SMALL */ -#ifndef SMALL void reget(int argc, char *argv[]) { (void)getit(argc, argv, 1, "a+w"); } -#endif /* !SMALL */ - -void -get(int argc, char *argv[]) -{ - - (void)getit(argc, argv, 0, restart_point ? "a+w" : "w" ); -} - -/* - * Receive one file. - */ -int -getit(int argc, char *argv[], int restartit, const char *mode) -{ - int loc = 0; - int rval = 0; - char *oldargv1, *oldargv2, *globargv2; - - if (argc == 2) { - argc++; - argv[2] = argv[1]; - loc++; - } - if (argc < 2 && !another(&argc, &argv, "remote-file")) - goto usage; - if ((argc < 3 && !another(&argc, &argv, "local-file")) || argc > 3) { -usage: - fprintf(ttyout, "usage: %s remote-file [local-file]\n", - argv[0]); - code = -1; - return (0); - } - oldargv1 = argv[1]; - oldargv2 = argv[2]; - if (!globulize(&argv[2])) { - code = -1; - return (0); - } - globargv2 = argv[2]; - if (loc && mcase) { - char *tp = argv[1], *tp2, tmpbuf[MAXPATHLEN]; - - while (*tp && !islower(*tp)) { - tp++; - } - if (!*tp) { - tp = argv[2]; - tp2 = tmpbuf; - while ((*tp2 = *tp) != '\0') { - if (isupper(*tp2)) { - *tp2 = tolower(*tp2); - } - tp++; - tp2++; - } - argv[2] = tmpbuf; - } - } - if (loc && ntflag) - argv[2] = dotrans(argv[2]); - if (loc && mapflag) - argv[2] = domap(argv[2]); -#ifndef SMALL - if (restartit) { - struct stat stbuf; - int ret; - - ret = stat(argv[2], &stbuf); - if (restartit == 1) { - restart_point = (ret < 0) ? 0 : stbuf.st_size; - } else { - if (ret == 0) { - time_t mtime; - - mtime = remotemodtime(argv[1], 0); - if (mtime == -1) - goto freegetit; - if (stbuf.st_mtime >= mtime) { - rval = 1; - goto freegetit; - } - } - } - } -#endif /* !SMALL */ - - recvrequest("RETR", argv[2], argv[1], mode, - argv[1] != oldargv1 || argv[2] != oldargv2 || !interactive, loc); - restart_point = 0; -freegetit: - if (oldargv2 != globargv2) /* free up after globulize() */ - free(globargv2); - return (rval); -} - -/* XXX - Signal race. */ -/* ARGSUSED */ -void -mabort(int signo) -{ - alarmtimer(0); - putc('\n', ttyout); - (void)fflush(ttyout); - if (mflag && fromatty) - if (confirm(mname, NULL)) - longjmp(jabort, 1); - mflag = 0; - longjmp(jabort, 1); -} - -/* - * Get multiple files. - */ -void -mget(int argc, char *argv[]) -{ - extern int optind, optreset; - sig_t oldintr; - int ch, xargc = 2; - char *cp, localcwd[MAXPATHLEN], *xargv[] = {argv[0], NULL, NULL}; - static int restartit = 0; -#ifndef SMALL - extern char *optarg; - const char *errstr; - int i = 1; - char type = NULL, *dummyargv[] = {argv[0], ".", NULL}; - FILE *ftemp = NULL; - static int depth = 0, max_depth = 0; -#endif /* !SMALL */ - - optind = optreset = 1; - -#ifndef SMALL - - if (depth) - depth++; - - while ((ch = getopt(argc, argv, "cd:nr")) != -1) { - switch(ch) { - case 'c': - restartit = 1; - break; - case 'd': - max_depth = strtonum(optarg, 0, INT_MAX, &errstr); - if (errstr != NULL) { - fprintf(ttyout, "bad depth value, %s: %s\n", - errstr, optarg); - code = -1; - return; - } - break; - case 'n': - restartit = -1; - break; - case 'r': - depth = 1; - break; - default: - goto usage; - } - } -#endif /* !SMALL */ - - if (argc - optind < 1 && !another(&argc, &argv, "remote-files")) { -usage: - fprintf(ttyout, "usage: %s [-cnr] [-d depth] remote-files\n", - argv[0]); - code = -1; - return; - } - -#ifndef SMALL - argv[optind - 1] = argv[0]; - argc -= optind - 1; - argv += optind - 1; -#endif /* !SMALL */ - - mname = argv[0]; - mflag = 1; - if (getcwd(localcwd, sizeof(localcwd)) == NULL) - err(1, "can't get cwd"); - - oldintr = signal(SIGINT, mabort); - (void)setjmp(jabort); - while ((cp = -#ifndef SMALL - depth ? remglob2(dummyargv, proxy, NULL, &ftemp, &type) : -#endif /* !SMALL */ - remglob(argv, proxy, NULL)) != NULL -#ifndef SMALL - || (mflag && depth && ++i < argc) -#endif /* !SMALL */ - ) { -#ifndef SMALL - if (cp == NULL) - continue; -#endif /* !SMALL */ - if (*cp == '\0') { - mflag = 0; - continue; - } - if (!mflag) - continue; -#ifndef SMALL - if (depth && fnmatch(argv[i], cp, FNM_PATHNAME) != 0) - continue; -#endif /* !SMALL */ - if (!fileindir(cp, localcwd)) { - fprintf(ttyout, "Skipping non-relative filename `%s'\n", - cp); - continue; - } -#ifndef SMALL - if (type == 'd' && depth == max_depth) - continue; -#endif /* !SMALL */ - if (confirm(argv[0], cp)) { -#ifndef SMALL - if (type == 'd') { - mkdir(cp, 0755); - if (chdir(cp) != 0) { - warn("local: %s", cp); - continue; - } - - xargv[1] = cp; - cd(xargc, xargv); - if (dirchange != 1) - goto out; - - xargv[1] = "*"; - mget(xargc, xargv); - - xargv[1] = ".."; - cd(xargc, xargv); - if (dirchange != 1) { - mflag = 0; - goto out; - } - -out: - if (chdir("..") != 0) { - warn("local: %s", cp); - mflag = 0; - } - continue; - } - if (type == 's') - /* Currently ignored. */ - continue; -#endif /* !SMALL */ - xargv[1] = cp; - (void)getit(xargc, xargv, restartit, - (restartit == 1 || restart_point) ? "a+w" : "w"); - if (!mflag && fromatty) { - if (confirm(argv[0], NULL)) - mflag = 1; - } - } - } - (void)signal(SIGINT, oldintr); -#ifndef SMALL - if (depth) - depth--; - if (depth == 0 || mflag == 0) - depth = max_depth = mflag = restartit = 0; -#else /* !SMALL */ - mflag = 0; -#endif /* !SMALL */ -} char * onoff(int bool) @@ -861,7 +452,6 @@ status(int argc, char *argv[]) fprintf(ttyout, "Use of PORT/LPRT cmds: %s.\n", onoff(sendport)); fprintf(ttyout, "Use of EPSV/EPRT cmds for IPv4: %s%s.\n", onoff(epsv4), epsv4bad ? " (disabled for this connection)" : ""); -#ifndef SMALL fprintf(ttyout, "Command line editing: %s.\n", onoff(editing)); if (macnum > 0) { fputs("Macros:\n", ttyout); @@ -869,7 +459,6 @@ status(int argc, char *argv[]) fprintf(ttyout, "\t%s\n", macros[i].mac_name); } } -#endif /* !SMALL */ code = 0; } @@ -908,7 +497,6 @@ setbell(int argc, char *argv[]) /* * Set command line editing */ -#ifndef SMALL /*ARGSUSED*/ void setedit(int argc, char *argv[]) @@ -917,7 +505,6 @@ setedit(int argc, char *argv[]) code = togglevar(argc, argv, &editing, "Editing mode"); controlediting(); } -#endif /* !SMALL */ /* * Toggle use of IPv4 EPSV/EPRT @@ -1093,7 +680,6 @@ setpreserve(int argc, char *argv[]) /* * Set debugging mode on/off and/or set level of debugging. */ -#ifndef SMALL /*ARGSUSED*/ void setdebug(int argc, char *argv[]) @@ -1129,35 +715,6 @@ setdebug(int argc, char *argv[]) fprintf(ttyout, "Debugging %s (debug=%d).\n", onoff(debug), debug); code = debug > 0; } -#endif /* !SMALL */ - -/* - * Set current working directory on remote machine. - */ -void -cd(int argc, char *argv[]) -{ - int r; - - if ((argc < 2 && !another(&argc, &argv, "remote-directory")) || - argc > 2) { - fprintf(ttyout, "usage: %s remote-directory\n", argv[0]); - code = -1; - return; - } - r = command("CWD %s", argv[1]); - if (r == ERROR && code == 500) { - if (verbose) - fputs("CWD command not recognized, trying XCWD.\n", ttyout); - r = command("XCWD %s", argv[1]); - } - if (r == ERROR && code == 550) { - dirchange = 0; - return; - } - if (r == COMPLETE) - dirchange = 1; -} /* * Set current working directory on local machine. @@ -1378,13 +935,11 @@ shell(int argc, char *argv[]) (void)strlcpy(shellnam + 1, ++namep, sizeof(shellnam) - 1); if (strcmp(namep, "sh") != 0) shellnam[0] = '+'; -#ifndef SMALL if (debug) { fputs(shellp, ttyout); fputc('\n', ttyout); (void)fflush(ttyout); } -#endif /* !SMALL */ if (argc > 1) { execl(shellp, shellnam, "-c", altarg, (char *)0); } @@ -1671,30 +1226,6 @@ quit(int argc, char *argv[]) exit(0); } -/* - * Terminate session, but don't exit. - */ -/* ARGSUSED */ -void -disconnect(int argc, char *argv[]) -{ - - if (!connected) - return; - (void)command("QUIT"); - if (cout) { - (void)fclose(cout); - } - cout = NULL; - connected = 0; - data = -1; -#ifndef SMALL - if (!proxy) { - macnum = 0; - } -#endif /* !SMALL */ -} - void account(int argc, char *argv[]) { @@ -1825,34 +1356,6 @@ setntrans(int argc, char *argv[]) (void)strlcpy(ntout, argv[2], sizeof(ntout)); } -char * -dotrans(char *name) -{ - static char new[MAXPATHLEN]; - char *cp1, *cp2 = new; - int i, ostop, found; - - for (ostop = 0; *(ntout + ostop) && ostop < 16; ostop++) - continue; - for (cp1 = name; *cp1; cp1++) { - found = 0; - for (i = 0; *(ntin + i) && i < 16; i++) { - if (*cp1 == *(ntin + i)) { - found++; - if (i < ostop) { - *cp2++ = *(ntout + i); - } - break; - } - } - if (!found) { - *cp2++ = *cp1; - } - } - *cp2 = '\0'; - return (new); -} - void setnmap(int argc, char *argv[]) { @@ -1885,177 +1388,6 @@ setnmap(int argc, char *argv[]) (void)strncpy(mapout, cp, MAXPATHLEN - 1); } -char * -domap(char *name) -{ - static char new[MAXPATHLEN]; - char *cp1 = name, *cp2 = mapin; - char *tp[9], *te[9]; - int i, toks[9], toknum = 0, match = 1; - - for (i=0; i < 9; ++i) { - toks[i] = 0; - } - while (match && *cp1 && *cp2) { - switch (*cp2) { - case '\\': - if (*++cp2 != *cp1) { - match = 0; - } - break; - case '$': - if (*(cp2+1) >= '1' && (*cp2+1) <= '9') { - if (*cp1 != *(++cp2+1)) { - toks[toknum = *cp2 - '1']++; - tp[toknum] = cp1; - while (*++cp1 && *(cp2+1) - != *cp1); - te[toknum] = cp1; - } - cp2++; - break; - } - /* FALLTHROUGH */ - default: - if (*cp2 != *cp1) { - match = 0; - } - break; - } - if (match && *cp1) { - cp1++; - } - if (match && *cp2) { - cp2++; - } - } - if (!match && *cp1) /* last token mismatch */ - { - toks[toknum] = 0; - } - cp1 = new; - *cp1 = '\0'; - cp2 = mapout; - while (*cp2) { - match = 0; - switch (*cp2) { - case '\\': - if (*(cp2 + 1)) { - *cp1++ = *++cp2; - } - break; - case '[': -LOOP: - if (*++cp2 == '$' && isdigit(*(cp2+1))) { - if (*++cp2 == '0') { - char *cp3 = name; - - while (*cp3) { - *cp1++ = *cp3++; - } - match = 1; - } - else if (toks[toknum = *cp2 - '1']) { - char *cp3 = tp[toknum]; - - while (cp3 != te[toknum]) { - *cp1++ = *cp3++; - } - match = 1; - } - } - else { - while (*cp2 && *cp2 != ',' && - *cp2 != ']') { - if (*cp2 == '\\') { - cp2++; - } - else if (*cp2 == '$' && - isdigit(*(cp2+1))) { - if (*++cp2 == '0') { - char *cp3 = name; - - while (*cp3) { - *cp1++ = *cp3++; - } - } - else if (toks[toknum = - *cp2 - '1']) { - char *cp3=tp[toknum]; - - while (cp3 != - te[toknum]) { - *cp1++ = *cp3++; - } - } - } - else if (*cp2) { - *cp1++ = *cp2++; - } - } - if (!*cp2) { - fputs( -"nmap: unbalanced brackets.\n", ttyout); - return (name); - } - match = 1; - cp2--; - } - if (match) { - while (*++cp2 && *cp2 != ']') { - if (*cp2 == '\\' && *(cp2 + 1)) { - cp2++; - } - } - if (!*cp2) { - fputs( -"nmap: unbalanced brackets.\n", ttyout); - return (name); - } - break; - } - switch (*++cp2) { - case ',': - goto LOOP; - case ']': - break; - default: - cp2--; - goto LOOP; - } - break; - case '$': - if (isdigit(*(cp2 + 1))) { - if (*++cp2 == '0') { - char *cp3 = name; - - while (*cp3) { - *cp1++ = *cp3++; - } - } - else if (toks[toknum = *cp2 - '1']) { - char *cp3 = tp[toknum]; - - while (cp3 != te[toknum]) { - *cp1++ = *cp3++; - } - } - break; - } - /* FALLTHROUGH */ - default: - *cp1++ = *cp2; - break; - } - cp2++; - } - *cp1 = '\0'; - if (!*new) { - return (name); - } - return (new); -} - void setpassive(int argc, char *argv[]) { @@ -2130,7 +1462,6 @@ syst(int argc, char *argv[]) (void)command("SYST"); } -#ifndef SMALL void macdef(int argc, char *argv[]) { @@ -2188,7 +1519,6 @@ macdef(int argc, char *argv[]) } } } -#endif /* !SMALL */ /* * Get size of file on remote machine @@ -2287,3 +1617,6 @@ page(int argc, char *argv[]) if (oldargv1 != argv[1]) /* free up after globulize() */ free(argv[1]); } + +#endif /* !SMALL */ + diff --git a/usr.bin/ftp/cmds.h b/usr.bin/ftp/cmds.h new file mode 100644 index 00000000000..2d7740761b2 --- /dev/null +++ b/usr.bin/ftp/cmds.h @@ -0,0 +1,84 @@ +/* $OpenBSD: cmds.h,v 1.1 2009/05/05 19:35:30 martynas Exp $ */ + +/* + * Copyright (c) 2009 Martynas Venckus <martynas@openbsd.org> + * + * Permission to use, copy, modify, and distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +void setascii(int, char **); +void settenex(int, char **); +void setftmode(int, char **); +void setform(int, char **); +void setstruct(int, char **); +void reput(int, char **); +void put(int, char **); +void putit(int, char **, int); +void mput(int, char **); +void reget(int, char **); +char *onoff(int); +void status(int, char **); +int togglevar(int, char **, int *, const char *); +void setbell(int, char **); +void setedit(int, char **); +void setepsv4(int, char **); +void settrace(int, char **); +void sethash(int, char **); +void setverbose(int, char **); +void setport(int, char **); +void setprogress(int, char **); +void setprompt(int, char **); +void setgate(int, char **); +void setglob(int, char **); +void setpreserve(int, char **); +void setdebug(int, char **); +void lcd(int, char **); +void deletecmd(int, char **); +void mdelete(int, char **); +void renamefile(int, char **); +void ls(int, char **); +void mls(int, char **); +void shell(int, char **); +void user(int, char **); +void pwd(int, char **); +void lpwd(int, char **); +void makedir(int, char **); +void removedir(int, char **); +void quote(int, char **); +void site(int, char **); +void quote1(const char *, int, char **); +void do_chmod(int, char **); +void do_umask(int, char **); +void idle(int, char **); +void rmthelp(int, char **); +void quit(int, char **); +void account(int, char **); +void proxabort(int); +void doproxy(int, char **); +void setcase(int, char **); +void setcr(int, char **); +void setntrans(int, char **); +void setnmap(int, char **); +void setpassive(int, char **); +void setsunique(int, char **); +void setrunique(int, char **); +void cdup(int, char **); +void restart(int, char **); +void syst(int, char **); +void macdef(int, char **); +void sizecmd(int, char **); +void modtime(int, char **); +void rmtstatus(int, char **); +void newer(int, char **); +void page(int, char **); + diff --git a/usr.bin/ftp/cmdtab.c b/usr.bin/ftp/cmdtab.c index b96a9004e26..49bf88f8b01 100644 --- a/usr.bin/ftp/cmdtab.c +++ b/usr.bin/ftp/cmdtab.c @@ -1,4 +1,4 @@ -/* $OpenBSD: cmdtab.c,v 1.25 2009/04/27 22:51:51 martynas Exp $ */ +/* $OpenBSD: cmdtab.c,v 1.26 2009/05/05 19:35:30 martynas Exp $ */ /* $NetBSD: cmdtab.c,v 1.17 1997/08/18 10:20:17 lukem Exp $ */ /* @@ -30,14 +30,16 @@ * SUCH DAMAGE. */ +#ifndef SMALL + #include <stdio.h> #include "ftp_var.h" +#include "cmds.h" /* * User FTP -- Command Tables. */ -#ifndef SMALL char accounthelp[] = "send account command to remote server"; char appendhelp[] = "append to a file"; char asciihelp[] = "set ascii transfer type"; @@ -115,29 +117,18 @@ char typehelp[] = "set file transfer type"; char umaskhelp[] = "get (set) umask on remote side"; char userhelp[] = "send new user information"; char verbosehelp[] = "toggle verbose mode"; -#endif /* !SMALL */ char empty[] = ""; -#ifdef SMALL -#define CMPL(x) -#define CMPL0 -#define H(x) empty -#else /* SMALL */ #define CMPL(x) __STRING(x), #define CMPL0 "", #define H(x) x -#endif /* SMALL */ struct cmd cmdtab[] = { { "!", H(shellhelp), 0, 0, 0, CMPL0 shell }, -#ifndef SMALL { "$", H(domachelp), 1, 0, 0, CMPL0 domacro }, -#endif /* !SMALL */ { "account", H(accounthelp), 0, 1, 1, CMPL0 account}, -#ifndef SMALL { "append", H(appendhelp), 1, 1, 1, CMPL(lr) put }, -#endif /* !SMALL */ { "ascii", H(asciihelp), 0, 1, 1, CMPL0 setascii }, { "bell", H(beephelp), 0, 0, 0, CMPL0 setbell }, { "binary", H(binaryhelp), 0, 1, 1, CMPL0 setbinary }, @@ -148,15 +139,11 @@ struct cmd cmdtab[] = { { "chmod", H(chmodhelp), 0, 1, 1, CMPL(nr) do_chmod }, { "close", H(disconhelp), 0, 1, 1, CMPL0 disconnect }, { "cr", H(crhelp), 0, 0, 0, CMPL0 setcr }, -#ifndef SMALL { "debug", H(debughelp), 0, 0, 0, CMPL0 setdebug }, -#endif /* !SMALL */ { "delete", H(deletehelp), 0, 1, 1, CMPL(r) deletecmd }, { "dir", H(dirhelp), 1, 1, 1, CMPL(rl) ls }, { "disconnect", H(disconhelp), 0, 1, 1, CMPL0 disconnect }, -#ifndef SMALL { "edit", H(edithelp), 0, 0, 0, CMPL0 setedit }, -#endif /* !SMALL */ { "epsv4", H(epsv4help), 0, 0, 0, CMPL0 setepsv4 }, { "exit", H(quithelp), 0, 0, 0, CMPL0 quit }, { "form", H(formhelp), 0, 1, 1, CMPL0 setform }, @@ -172,9 +159,7 @@ struct cmd cmdtab[] = { { "less", H(pagehelp), 1, 1, 1, CMPL(r) page }, { "lpwd", H(lpwdhelp), 0, 0, 0, CMPL0 lpwd }, { "ls", H(lshelp), 1, 1, 1, CMPL(rl) ls }, -#ifndef SMALL { "macdef", H(macdefhelp), 0, 0, 0, CMPL0 macdef }, -#endif /* !SMALL */ { "mdelete", H(mdeletehelp), 1, 1, 1, CMPL(R) mdelete }, { "mdir", H(mdirhelp), 1, 1, 1, CMPL(R) mls }, { "mget", H(mgethelp), 1, 1, 1, CMPL(R) mget }, @@ -183,10 +168,8 @@ struct cmd cmdtab[] = { { "mode", H(modehelp), 0, 1, 1, CMPL0 setftmode }, { "modtime", H(modtimehelp), 0, 1, 1, CMPL(r) modtime }, { "more", H(pagehelp), 1, 1, 1, CMPL(r) page }, -#ifndef SMALL { "mput", H(mputhelp), 1, 1, 1, CMPL(L) mput }, { "msend", H(mputhelp), 1, 1, 1, CMPL(L) mput }, -#endif /* !SMALL */ { "newer", H(newerhelp), 1, 1, 1, CMPL(r) newer }, { "nlist", H(nlisthelp), 1, 1, 1, CMPL(rl) ls }, { "nmap", H(nmaphelp), 0, 0, 1, CMPL0 setnmap }, @@ -198,29 +181,21 @@ struct cmd cmdtab[] = { { "progress", H(progresshelp),0, 0, 0, CMPL0 setprogress }, { "prompt", H(prompthelp), 0, 0, 0, CMPL0 setprompt }, { "proxy", H(proxyhelp), 0, 0, 1, CMPL(c) doproxy }, -#ifndef SMALL { "put", H(sendhelp), 1, 1, 1, CMPL(lr) put }, -#endif /* !SMALL */ { "pwd", H(pwdhelp), 0, 1, 1, CMPL0 pwd }, { "quit", H(quithelp), 0, 0, 0, CMPL0 quit }, { "quote", H(quotehelp), 1, 1, 1, CMPL0 quote }, { "recv", H(receivehelp), 1, 1, 1, CMPL(rl) get }, -#ifndef SMALL { "reget", H(regethelp), 1, 1, 1, CMPL(rl) reget }, -#endif /* !SMALL */ { "rename", H(renamehelp), 0, 1, 1, CMPL(rr) renamefile }, -#ifndef SMALL { "reput", H(reputhelp), 1, 1, 1, CMPL(lr) reput }, -#endif /* !SMALL */ { "reset", H(resethelp), 0, 1, 1, CMPL0 reset }, { "restart", H(restarthelp), 1, 1, 1, CMPL0 restart }, { "rhelp", H(remotehelp), 0, 1, 1, CMPL0 rmthelp }, { "rmdir", H(rmdirhelp), 0, 1, 1, CMPL(r) removedir }, { "rstatus", H(rmtstatushelp),0, 1, 1, CMPL(r) rmtstatus }, { "runique", H(runiquehelp), 0, 0, 1, CMPL0 setrunique }, -#ifndef SMALL { "send", H(sendhelp), 1, 1, 1, CMPL(lr) put }, -#endif /* !SMALL */ { "sendport", H(porthelp), 0, 0, 0, CMPL0 setport }, { "site", H(sitehelp), 0, 1, 1, CMPL0 site }, { "size", H(sizecmdhelp), 1, 1, 1, CMPL(r) sizecmd }, @@ -239,3 +214,6 @@ struct cmd cmdtab[] = { }; int NCMDS = (sizeof(cmdtab) / sizeof(cmdtab[0])) - 1; + +#endif /* !SMALL */ + diff --git a/usr.bin/ftp/complete.c b/usr.bin/ftp/complete.c index 8acd8e907e5..aaedf2dbafc 100644 --- a/usr.bin/ftp/complete.c +++ b/usr.bin/ftp/complete.c @@ -1,4 +1,4 @@ -/* $OpenBSD: complete.c,v 1.22 2009/04/27 21:37:13 deraadt Exp $ */ +/* $OpenBSD: complete.c,v 1.23 2009/05/05 19:35:30 martynas Exp $ */ /* $NetBSD: complete.c,v 1.10 1997/08/18 10:20:18 lukem Exp $ */ /*- @@ -231,10 +231,8 @@ complete_remote(char *word, int list) mflag = 1; emesg = NULL; -#ifndef SMALL if (debug) (void)putc('\n', ttyout); -#endif /* !SMALL */ while ((cp = remglob(dummyargv, 0, &emesg)) != NULL) { char *tcp; @@ -350,3 +348,4 @@ complete(EditLine *el, int ch) } #endif /* !SMALL */ + diff --git a/usr.bin/ftp/cookie.c b/usr.bin/ftp/cookie.c index 9fde85a245d..266f24dbcd4 100644 --- a/usr.bin/ftp/cookie.c +++ b/usr.bin/ftp/cookie.c @@ -1,4 +1,5 @@ -/* $OpenBSD: cookie.c,v 1.4 2008/12/07 21:12:07 cloder Exp $ */ +/* $OpenBSD: cookie.c,v 1.5 2009/05/05 19:35:30 martynas Exp $ */ + /* * Copyright (c) 2007 Pierre-Yves Ritschard <pyr@openbsd.org> * @@ -16,6 +17,7 @@ */ #ifndef SMALL + #include <sys/types.h> #include <sys/queue.h> @@ -226,3 +228,4 @@ cookie_get(const char *domain, const char *path, int secure, char **pstr) } #endif /* !SMALL */ + diff --git a/usr.bin/ftp/domacro.c b/usr.bin/ftp/domacro.c index 69013024023..107708deb51 100644 --- a/usr.bin/ftp/domacro.c +++ b/usr.bin/ftp/domacro.c @@ -1,4 +1,4 @@ -/* $OpenBSD: domacro.c,v 1.16 2009/04/27 22:51:51 martynas Exp $ */ +/* $OpenBSD: domacro.c,v 1.17 2009/05/05 19:35:30 martynas Exp $ */ /* $NetBSD: domacro.c,v 1.10 1997/07/20 09:45:45 lukem Exp $ */ /* @@ -146,3 +146,4 @@ TOP: } #endif /* !SMALL */ + diff --git a/usr.bin/ftp/extern.h b/usr.bin/ftp/extern.h index fd6ec8b7bcc..56c47aea643 100644 --- a/usr.bin/ftp/extern.h +++ b/usr.bin/ftp/extern.h @@ -1,4 +1,4 @@ -/* $OpenBSD: extern.h,v 1.38 2009/04/27 22:51:51 martynas Exp $ */ +/* $OpenBSD: extern.h,v 1.39 2009/05/05 19:35:30 martynas Exp $ */ /* $NetBSD: extern.h,v 1.17 1997/08/18 10:20:19 lukem Exp $ */ /* @@ -63,161 +63,69 @@ #include <sys/types.h> -void abort_remote(FILE *); -void abortpt(int); -void abortrecv(int); -#ifndef SMALL -void abortsend(int); -#endif /* !SMALL */ -void account(int, char **); +void abort_remote(FILE *); +void abortpt(int); +void abortrecv(int); void alarmtimer(int); int another(int *, char ***, const char *); int auto_fetch(int, char **, char *); void blkfree(char **); -void cd(int, char **); void cdup(int, char **); -void changetype(int, int); void cmdabort(int); void cmdscanner(int); int command(const char *, ...); -#ifndef SMALL -unsigned char complete(EditLine *, int); -void controlediting(void); -#endif /* !SMALL */ int confirm(const char *, const char *); FILE *dataconn(const char *); -void deletecmd(int, char **); -void disconnect(int, char **); -void do_chmod(int, char **); -void do_umask(int, char **); -#ifndef SMALL -void domacro(int, char **); -#endif /* !SMALL */ -char *domap(char *); -void doproxy(int, char **); -char *dotrans(char *); int foregroundproc(void); int fileindir(const char *, const char *); -void get(int, char **); struct cmd *getcmd(const char *); -int getit(int, char **, int, const char *); int getreply(int); int globulize(char **); char *gunique(const char *); void help(int, char **); char *hookup(char *, char *); -void idle(int, char **); -int initconn(void); +int initconn(void); void intr(void); int isurl(const char *); -void list_vertical(StringList *); -void lcd(int, char **); int ftp_login(const char *, char *, char *); void lostpeer(void); -void lpwd(int, char **); -void ls(int, char **); -void mabort(int); -#ifndef SMALL -void macdef(int, char **); -#endif /* !SMALL */ void makeargv(void); -void makedir(int, char **); -void mdelete(int, char **); -void mget(int, char **); -void mls(int, char **); -void modtime(int, char **); -#ifndef SMALL -void mput(int, char **); -#endif /* !SMALL */ -char *onoff(int); -void newer(int, char **); -void page(int, char **); -void progressmeter(int, const char *); +void progressmeter(int, const char *); char *prompt(void); -void proxabort(int); -void proxtrans(const char *, const char *, const char *); -void psabort(int); +void proxtrans(const char *, const char *, const char *); +void psabort(int); void psummary(int); -void pswitch(int); -void ptransfer(int); -#ifndef SMALL -void put(int, char **); -void putit(int, char **, int); -#endif /* !SMALL */ -void pwd(int, char **); -void quit(int, char **); -void quote(int, char **); -void quote1(const char *, int, char **); -void recvrequest(const char *, const char *, const char *, +void pswitch(int); +void ptransfer(int); +void recvrequest(const char *, const char *, const char *, const char *, int, int); -void reget(int, char **); char *remglob(char **, int, char **); #ifndef SMALL -char *remglob2(char **, int, char **, FILE **ftemp, char *type); #endif /* !SMALL */ off_t remotesize(const char *, int); time_t remotemodtime(const char *, int); -void removedir(int, char **); -void renamefile(int, char **); -#ifndef SMALL -void reput(int, char **); -#endif /* !SMALL */ -void reset(int, char **); -void restart(int, char **); +void reset(int, char **); void rmthelp(int, char **); -void rmtstatus(int, char **); -#ifndef SMALL -void sendrequest(const char *, const char *, const char *, int); -#endif /* !SMALL */ -void setascii(int, char **); -void setbell(int, char **); -void setbinary(int, char **); -void setcase(int, char **); -void setcr(int, char **); -#ifndef SMALL -void setdebug(int, char **); -#endif /* !SMALL */ -void setedit(int, char **); -void setepsv4(int, char **); -void setform(int, char **); -void setftmode(int, char **); -void setgate(int, char **); -void setglob(int, char **); void sethash(int, char **); -void setnmap(int, char **); -void setntrans(int, char **); -void setpassive(int, char **); void setpeer(int, char **); -void setport(int, char **); -void setpreserve(int, char **); -void setprogress(int, char **); -void setprompt(int, char **); -void setrunique(int, char **); -void setstruct(int, char **); -void setsunique(int, char **); -void settenex(int, char **); -void settrace(int, char **); void setttywidth(int); -void settype(int, char **); -void setverbose(int, char **); -void shell(int, char **); -void site(int, char **); -void sizecmd(int, char **); char *slurpstring(void); -void status(int, char **); -void syst(int, char **); -int togglevar(int, char **, int *, const char *); void usage(void); -void user(int, char **); #ifndef SMALL -int ruserpass(const char *, char **, char **, char **); -void cookie_load(void); +void abortsend(int); +unsigned char complete(EditLine *, int); +void controlediting(void); void cookie_get(const char *, const char *, int, char **); +void cookie_load(void); +void domacro(int, char **); +void list_vertical(StringList *); void parse_list(char **, char *); +char *remglob2(char **, int, char **, FILE **ftemp, char *type); +int ruserpass(const char *, char **, char **, char **); +void sendrequest(const char *, const char *, const char *, int); #endif /* !SMALL */ - extern jmp_buf abortprox; extern int abrtflag; extern struct cmd cmdtab[]; @@ -229,8 +137,11 @@ extern int family; extern int proxy; extern char reply_string[]; extern off_t restart_point; -extern int NCMDS; extern int keep_alive_timeout; +#ifndef SMALL +extern int NCMDS; +#endif /* !SMALL */ + extern char *__progname; /* from crt0.o */ diff --git a/usr.bin/ftp/fetch.c b/usr.bin/ftp/fetch.c index 4cc777d7d95..947589b7be6 100644 --- a/usr.bin/ftp/fetch.c +++ b/usr.bin/ftp/fetch.c @@ -1,4 +1,4 @@ -/* $OpenBSD: fetch.c,v 1.85 2009/04/27 21:37:13 deraadt Exp $ */ +/* $OpenBSD: fetch.c,v 1.86 2009/05/05 19:35:30 martynas Exp $ */ /* $NetBSD: fetch.c,v 1.14 1997/08/18 10:20:20 lukem Exp $ */ /*- @@ -68,6 +68,7 @@ #endif /* !SMALL */ #include "ftp_var.h" +#include "cmds.h" static int url_get(const char *, const char *, const char *); void aborthttp(int); @@ -1045,7 +1046,12 @@ bad_ftp_url: } if (EMPTYSTRING(file)) { +#ifndef SMALL rval = -1; +#else /* !SMALL */ + recvrequest("NLST", "-", NULL, "w", 0, 0); + rval = 0; +#endif /* !SMALL */ continue; } diff --git a/usr.bin/ftp/ftp_var.h b/usr.bin/ftp/ftp_var.h index ac5ec68981b..b2824f8ce27 100644 --- a/usr.bin/ftp/ftp_var.h +++ b/usr.bin/ftp/ftp_var.h @@ -1,4 +1,4 @@ -/* $OpenBSD: ftp_var.h,v 1.28 2009/04/27 22:51:51 martynas Exp $ */ +/* $OpenBSD: ftp_var.h,v 1.29 2009/05/05 19:35:30 martynas Exp $ */ /* $NetBSD: ftp_var.h,v 1.18 1997/08/18 10:20:25 lukem Exp $ */ /* @@ -79,6 +79,7 @@ int fclose(FILE *); #include "stringlist.h" #include "extern.h" +#include "small.h" #define HASHBYTES 1024 #define FTPBUFLEN MAXPATHLEN + 200 @@ -187,7 +188,9 @@ char line[FTPBUFLEN]; /* input line buffer */ char *stringbase; /* current scan point in line buffer */ char argbuf[FTPBUFLEN]; /* argument storage buffer */ char *argbase; /* current storage point in arg buffer */ +#ifndef SMALL StringList *marg_sl; /* stringlist containing margv */ +#endif /* !SMALL */ int margc; /* count of arguments on input line */ #define margv (marg_sl->sl_str) /* args parsed from input line */ int cpend; /* flag: if != 0, then pending server reply */ diff --git a/usr.bin/ftp/list.c b/usr.bin/ftp/list.c index 6f0befb997e..d0d9621875a 100644 --- a/usr.bin/ftp/list.c +++ b/usr.bin/ftp/list.c @@ -1,4 +1,5 @@ -/* $OpenBSD: list.c,v 1.2 2008/10/21 17:54:00 martynas Exp $ */ +/* $OpenBSD: list.c,v 1.3 2009/05/05 19:35:30 martynas Exp $ */ + /* * Copyright (c) 2008 Martynas Venckus <martynas@openbsd.org> * @@ -16,6 +17,7 @@ */ #ifndef SMALL + #include <string.h> void @@ -75,3 +77,4 @@ parse_list(char **line, char *type) } #endif /* !SMALL */ + diff --git a/usr.bin/ftp/main.c b/usr.bin/ftp/main.c index 32b78c18863..7f53dc531b1 100644 --- a/usr.bin/ftp/main.c +++ b/usr.bin/ftp/main.c @@ -1,4 +1,4 @@ -/* $OpenBSD: main.c,v 1.76 2009/04/27 22:51:51 martynas Exp $ */ +/* $OpenBSD: main.c,v 1.77 2009/05/05 19:35:30 martynas Exp $ */ /* $NetBSD: main.c,v 1.24 1997/08/18 10:20:26 lukem Exp $ */ /* @@ -76,6 +76,7 @@ #include <unistd.h> #include "ftp_var.h" +#include "cmds.h" int family = PF_UNSPEC; @@ -112,9 +113,9 @@ main(volatile int argc, char *argv[]) hist = NULL; cookiefile = NULL; resume = 0; + marg_sl = sl_init(); #endif /* !SMALL */ mark = HASHBYTES; - marg_sl = sl_init(); #ifdef INET6 epsv4 = 1; #else @@ -318,6 +319,7 @@ main(volatile int argc, char *argv[]) if (rval >= 0) /* -1 == connected and cd-ed */ exit(rval); } else { +#ifndef SMALL char *xargv[5]; if (setjmp(toplevel)) @@ -334,19 +336,17 @@ main(volatile int argc, char *argv[]) if (!retry_connect) break; if (!connected) { -#ifndef SMALL macnum = 0; -#endif /* !SMALL */ fputs("Retrying...\n", ttyout); sleep(retry_connect); } } while (!connected); retry_connect = 0; /* connected, stop hiding msgs */ +#endif /* !SMALL */ } } #ifndef SMALL controlediting(); -#endif /* !SMALL */ top = setjmp(toplevel) == 0; if (top) { (void)signal(SIGINT, (sig_t)intr); @@ -356,6 +356,9 @@ main(volatile int argc, char *argv[]) cmdscanner(top); top = 1; } +#else /* !SMALL */ + usage(); +#endif /* !SMALL */ } void @@ -399,6 +402,7 @@ lostpeer(void) errno = save_errno; } +#ifndef SMALL /* * Generate a prompt */ @@ -416,20 +420,12 @@ cmdscanner(int top) { struct cmd *c; int num; -#ifndef SMALL HistEvent hev; -#endif /* !SMALL */ - if (!top -#ifndef SMALL - && !editing -#endif /* !SMALL */ - ) + if (!top && !editing) (void)putc('\n', ttyout); for (;;) { -#ifndef SMALL if (!editing) { -#endif /* !SMALL */ if (fromatty) { fputs(prompt(), ttyout); (void)fflush(ttyout); @@ -449,7 +445,6 @@ cmdscanner(int top) /* void */; break; } /* else it was a line without a newline */ -#ifndef SMALL } else { const char *buf; cursor_pos = NULL; @@ -468,7 +463,6 @@ cmdscanner(int top) line[num] = '\0'; history(hist, &hev, H_ENTER, buf); } -#endif /* !SMALL */ makeargv(); if (margc == 0) @@ -479,7 +473,6 @@ cmdscanner(int top) continue; } if (c == 0) { -#ifndef SMALL /* * Give editline(3) a shot at unknown commands. * XXX - bogus commands with a colon in @@ -487,7 +480,6 @@ cmdscanner(int top) */ if (editing && el_parse(el, margc, (const char **)margv) != 0) -#endif /* !SMALL */ fputs("?Invalid command.\n", ttyout); continue; } @@ -558,7 +550,6 @@ makeargv(void) if (argp == NULL) break; } -#ifndef SMALL if (cursor_pos == line) { cursor_argc = 0; cursor_argo = 0; @@ -566,20 +557,14 @@ makeargv(void) cursor_argc = margc; cursor_argo = strlen(margv[margc-1]); } -#endif /* !SMALL */ } -#ifdef SMALL -#define INC_CHKCURSOR(x) (x)++ -#else /* SMALL */ #define INC_CHKCURSOR(x) { (x)++ ; \ if (x == cursor_pos) { \ cursor_argc = margc; \ cursor_argo = ap-argbase; \ cursor_pos = NULL; \ } } - -#endif /* SMALL */ /* * Parse string into argbuf; @@ -753,19 +738,16 @@ help(int argc, char *argv[]) c->c_name, c->c_help); } } +#endif /* !SMALL */ void usage(void) { - (void)fprintf(stderr, - "usage: %s [-46Aa" + (void)fprintf(stderr, "usage: %s " #ifndef SMALL - "d" -#endif /* !SMALL */ - "EegimnptVv] [-k seconds] [-P port] [-r seconds] [host [port]]\n" - " %s " -#ifndef SMALL - "[-C] " + "[-46AadEegimnptVv] [-k seconds] [-P port] " + "[-r seconds] [host [port]]\n" + " %s [-C] " #endif /* !SMALL */ "[-o output] " "ftp://[user:password@]host[:port]/file[/]\n" @@ -787,7 +769,8 @@ usage(void) #ifndef SMALL __progname, __progname, __progname, __progname, __progname); #else /* !SMALL */ - __progname, __progname, __progname, __progname); + __progname, __progname, __progname); #endif /* !SMALL */ exit(1); } + diff --git a/usr.bin/ftp/ruserpass.c b/usr.bin/ftp/ruserpass.c index bdb8e961181..3f52d6c523a 100644 --- a/usr.bin/ftp/ruserpass.c +++ b/usr.bin/ftp/ruserpass.c @@ -1,4 +1,4 @@ -/* $OpenBSD: ruserpass.c,v 1.27 2009/04/27 21:37:13 deraadt Exp $ */ +/* $OpenBSD: ruserpass.c,v 1.28 2009/05/05 19:35:30 martynas Exp $ */ /* $NetBSD: ruserpass.c,v 1.14 1997/07/20 09:46:01 lukem Exp $ */ /* @@ -312,4 +312,6 @@ token(void) return (t->tval); return (ID); } + #endif /* !SMALL */ + diff --git a/usr.bin/ftp/small.c b/usr.bin/ftp/small.c new file mode 100644 index 00000000000..ce31ef8b535 --- /dev/null +++ b/usr.bin/ftp/small.c @@ -0,0 +1,723 @@ +/* $OpenBSD: small.c,v 1.1 2009/05/05 19:35:30 martynas Exp $ */ +/* $NetBSD: cmds.c,v 1.27 1997/08/18 10:20:15 lukem Exp $ */ + +/* + * Copyright (C) 1997 and 1998 WIDE Project. + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * 3. Neither the name of the project nor the names of its contributors + * may be used to endorse or promote products derived from this software + * without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE PROJECT AND CONTRIBUTORS ``AS IS'' AND + * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + * ARE DISCLAIMED. IN NO EVENT SHALL THE PROJECT OR CONTRIBUTORS BE LIABLE + * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL + * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS + * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) + * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT + * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY + * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF + * SUCH DAMAGE. + */ + +/* + * Copyright (c) 1985, 1989, 1993, 1994 + * The Regents of the University of California. All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * 3. Neither the name of the University nor the names of its contributors + * may be used to endorse or promote products derived from this software + * without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND + * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE + * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL + * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS + * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) + * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT + * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY + * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF + * SUCH DAMAGE. + */ + +/* + * FTP User Program -- Command Routines. + */ +#include <sys/types.h> +#include <sys/socket.h> +#include <sys/stat.h> +#include <sys/wait.h> +#include <arpa/ftp.h> + +#include <ctype.h> +#include <err.h> +#include <fnmatch.h> +#include <glob.h> +#include <netdb.h> +#include <stdio.h> +#include <stdlib.h> +#include <string.h> +#include <unistd.h> + +#include "ftp_var.h" +#include "pathnames.h" +#include "small.h" + +jmp_buf jabort; +char *mname; +char *home = "/"; + +struct types { + char *t_name; + char *t_mode; + int t_type; + char *t_arg; +} types[] = { + { "ascii", "A", TYPE_A, 0 }, + { "binary", "I", TYPE_I, 0 }, + { "image", "I", TYPE_I, 0 }, + { "ebcdic", "E", TYPE_E, 0 }, + { "tenex", "L", TYPE_L, bytename }, + { NULL } +}; + +/* + * Set transfer type. + */ +void +settype(int argc, char *argv[]) +{ + struct types *p; + int comret; + + if (argc > 2) { + char *sep; + + fprintf(ttyout, "usage: %s [", argv[0]); + sep = ""; + for (p = types; p->t_name; p++) { + fprintf(ttyout, "%s%s", sep, p->t_name); + sep = " | "; + } + fputs("]\n", ttyout); + code = -1; + return; + } + if (argc < 2) { + fprintf(ttyout, "Using %s mode to transfer files.\n", typename); + code = 0; + return; + } + for (p = types; p->t_name; p++) + if (strcmp(argv[1], p->t_name) == 0) + break; + if (p->t_name == 0) { + fprintf(ttyout, "%s: unknown mode.\n", argv[1]); + code = -1; + return; + } + if ((p->t_arg != NULL) && (*(p->t_arg) != '\0')) + comret = command("TYPE %s %s", p->t_mode, p->t_arg); + else + comret = command("TYPE %s", p->t_mode); + if (comret == COMPLETE) { + (void)strlcpy(typename, p->t_name, sizeof typename); + curtype = type = p->t_type; + } +} + +/* + * Internal form of settype; changes current type in use with server + * without changing our notion of the type for data transfers. + * Used to change to and from ascii for listings. + */ +void +changetype(int newtype, int show) +{ + struct types *p; + int comret, oldverbose = verbose; + + if (newtype == 0) + newtype = TYPE_I; + if (newtype == curtype) + return; + if ( +#ifndef SMALL + !debug && +#endif /* !SMALL */ + show == 0) + verbose = 0; + for (p = types; p->t_name; p++) + if (newtype == p->t_type) + break; + if (p->t_name == 0) { + warnx("internal error: unknown type %d.", newtype); + return; + } + if (newtype == TYPE_L && bytename[0] != '\0') + comret = command("TYPE %s %s", p->t_mode, bytename); + else + comret = command("TYPE %s", p->t_mode); + if (comret == COMPLETE) + curtype = newtype; + verbose = oldverbose; +} + +char *stype[] = { + "type", + "", + 0 +}; + +/* + * Set binary transfer type. + */ +/*ARGSUSED*/ +void +setbinary(int argc, char *argv[]) +{ + + stype[1] = "binary"; + settype(2, stype); +} + +void +get(int argc, char *argv[]) +{ + + (void)getit(argc, argv, 0, restart_point ? "a+w" : "w" ); +} + +/* + * Receive one file. + */ +int +getit(int argc, char *argv[], int restartit, const char *mode) +{ + int loc = 0; + int rval = 0; + char *oldargv1, *oldargv2, *globargv2; + + if (argc == 2) { + argc++; + argv[2] = argv[1]; + loc++; + } +#ifndef SMALL + if (argc < 2 && !another(&argc, &argv, "remote-file")) + goto usage; + if ((argc < 3 && !another(&argc, &argv, "local-file")) || argc > 3) { +usage: + fprintf(ttyout, "usage: %s remote-file [local-file]\n", + argv[0]); + code = -1; + return (0); + } +#endif /* !SMALL */ + oldargv1 = argv[1]; + oldargv2 = argv[2]; + if (!globulize(&argv[2])) { + code = -1; + return (0); + } + globargv2 = argv[2]; + if (loc && mcase) { + char *tp = argv[1], *tp2, tmpbuf[MAXPATHLEN]; + + while (*tp && !islower(*tp)) { + tp++; + } + if (!*tp) { + tp = argv[2]; + tp2 = tmpbuf; + while ((*tp2 = *tp) != '\0') { + if (isupper(*tp2)) { + *tp2 = tolower(*tp2); + } + tp++; + tp2++; + } + argv[2] = tmpbuf; + } + } + if (loc && ntflag) + argv[2] = dotrans(argv[2]); + if (loc && mapflag) + argv[2] = domap(argv[2]); +#ifndef SMALL + if (restartit) { + struct stat stbuf; + int ret; + + ret = stat(argv[2], &stbuf); + if (restartit == 1) { + restart_point = (ret < 0) ? 0 : stbuf.st_size; + } else { + if (ret == 0) { + time_t mtime; + + mtime = remotemodtime(argv[1], 0); + if (mtime == -1) + goto freegetit; + if (stbuf.st_mtime >= mtime) { + rval = 1; + goto freegetit; + } + } + } + } +#endif /* !SMALL */ + + recvrequest("RETR", argv[2], argv[1], mode, + argv[1] != oldargv1 || argv[2] != oldargv2 || !interactive, loc); + restart_point = 0; +freegetit: + if (oldargv2 != globargv2) /* free up after globulize() */ + free(globargv2); + return (rval); +} + +/* XXX - Signal race. */ +/* ARGSUSED */ +void +mabort(int signo) +{ + alarmtimer(0); + putc('\n', ttyout); + (void)fflush(ttyout); +#ifndef SMALL + if (mflag && fromatty) + if (confirm(mname, NULL)) + longjmp(jabort, 1); +#endif /* !SMALL */ + mflag = 0; + longjmp(jabort, 1); +} + +/* + * Get multiple files. + */ +void +mget(int argc, char *argv[]) +{ + extern int optind, optreset; + sig_t oldintr; + int ch, xargc = 2; + char *cp, localcwd[MAXPATHLEN], *xargv[] = { argv[0], NULL, NULL }; + static int restartit = 0; +#ifndef SMALL + extern char *optarg; + const char *errstr; + int i = 1; + char type = 0, *dummyargv[] = { argv[0], ".", NULL }; + FILE *ftemp = NULL; + static int depth = 0, max_depth = 0; + + optind = optreset = 1; + + if (depth) + depth++; + + while ((ch = getopt(argc, argv, "cd:nr")) != -1) { + switch(ch) { + case 'c': + restartit = 1; + break; + case 'd': + max_depth = strtonum(optarg, 0, INT_MAX, &errstr); + if (errstr != NULL) { + fprintf(ttyout, "bad depth value, %s: %s\n", + errstr, optarg); + code = -1; + return; + } + break; + case 'n': + restartit = -1; + break; + case 'r': + depth = 1; + break; + default: + goto usage; + } + } + + if (argc - optind < 1 && !another(&argc, &argv, "remote-files")) { +usage: + fprintf(ttyout, "usage: %s [-cnr] [-d depth] remote-files\n", + argv[0]); + code = -1; + return; + } + + argv[optind - 1] = argv[0]; + argc -= optind - 1; + argv += optind - 1; +#endif /* !SMALL */ + + mname = argv[0]; + mflag = 1; + if (getcwd(localcwd, sizeof(localcwd)) == NULL) + err(1, "can't get cwd"); + + oldintr = signal(SIGINT, mabort); + (void)setjmp(jabort); + while ((cp = +#ifdef SMALL + remglob(argv, proxy, NULL)) != NULL + ) { +#else /* SMALL */ + depth ? remglob2(dummyargv, proxy, NULL, &ftemp, &type) : + remglob(argv, proxy, NULL)) != NULL + || (mflag && depth && ++i < argc) + ) { + if (cp == NULL) + continue; +#endif /* SMALL */ + if (*cp == '\0') { + mflag = 0; + continue; + } + if (!mflag) + continue; +#ifndef SMALL + if (depth && fnmatch(argv[i], cp, FNM_PATHNAME) != 0) + continue; +#endif /* !SMALL */ + if (!fileindir(cp, localcwd)) { + fprintf(ttyout, "Skipping non-relative filename `%s'\n", + cp); + continue; + } +#ifndef SMALL + if (type == 'd' && depth == max_depth) + continue; + if (!confirm(argv[0], cp)) + continue; + if (type == 'd') { + mkdir(cp, 0755); + if (chdir(cp) != 0) { + warn("local: %s", cp); + continue; + } + + xargv[1] = cp; + cd(xargc, xargv); + if (dirchange != 1) + goto out; + + xargv[1] = "*"; + mget(xargc, xargv); + + xargv[1] = ".."; + cd(xargc, xargv); + if (dirchange != 1) { + mflag = 0; + goto out; + } + +out: + if (chdir("..") != 0) { + warn("local: %s", cp); + mflag = 0; + } + continue; + } + if (type == 's') + /* Currently ignored. */ + continue; +#endif /* !SMALL */ + xargv[1] = cp; + (void)getit(xargc, xargv, restartit, + (restartit == 1 || restart_point) ? "a+w" : "w"); +#ifndef SMALL + if (!mflag && fromatty) { + if (confirm(argv[0], NULL)) + mflag = 1; + } +#endif /* !SMALL */ + } + (void)signal(SIGINT, oldintr); +#ifndef SMALL + if (depth) + depth--; + if (depth == 0 || mflag == 0) + depth = max_depth = mflag = restartit = 0; +#else /* !SMALL */ + mflag = 0; +#endif /* !SMALL */ +} + +/* + * Set current working directory on remote machine. + */ +void +cd(int argc, char *argv[]) +{ + int r; + +#ifndef SMALL + if ((argc < 2 && !another(&argc, &argv, "remote-directory")) || + argc > 2) { + fprintf(ttyout, "usage: %s remote-directory\n", argv[0]); + code = -1; + return; + } +#endif /* !SMALL */ + r = command("CWD %s", argv[1]); + if (r == ERROR && code == 500) { + if (verbose) + fputs("CWD command not recognized, trying XCWD.\n", ttyout); + r = command("XCWD %s", argv[1]); + } + if (r == ERROR && code == 550) { + dirchange = 0; + return; + } + if (r == COMPLETE) + dirchange = 1; +} + +/* + * Terminate session, but don't exit. + */ +/* ARGSUSED */ +void +disconnect(int argc, char *argv[]) +{ + + if (!connected) + return; + (void)command("QUIT"); + if (cout) { + (void)fclose(cout); + } + cout = NULL; + connected = 0; + data = -1; +#ifndef SMALL + if (!proxy) { + macnum = 0; + } +#endif /* !SMALL */ +} + +char * +dotrans(char *name) +{ + static char new[MAXPATHLEN]; + char *cp1, *cp2 = new; + int i, ostop, found; + + for (ostop = 0; *(ntout + ostop) && ostop < 16; ostop++) + continue; + for (cp1 = name; *cp1; cp1++) { + found = 0; + for (i = 0; *(ntin + i) && i < 16; i++) { + if (*cp1 == *(ntin + i)) { + found++; + if (i < ostop) { + *cp2++ = *(ntout + i); + } + break; + } + } + if (!found) { + *cp2++ = *cp1; + } + } + *cp2 = '\0'; + return (new); +} + +char * +domap(char *name) +{ + static char new[MAXPATHLEN]; + char *cp1 = name, *cp2 = mapin; + char *tp[9], *te[9]; + int i, toks[9], toknum = 0, match = 1; + + for (i=0; i < 9; ++i) { + toks[i] = 0; + } + while (match && *cp1 && *cp2) { + switch (*cp2) { + case '\\': + if (*++cp2 != *cp1) { + match = 0; + } + break; + case '$': + if (*(cp2+1) >= '1' && (*cp2+1) <= '9') { + if (*cp1 != *(++cp2+1)) { + toks[toknum = *cp2 - '1']++; + tp[toknum] = cp1; + while (*++cp1 && *(cp2+1) + != *cp1); + te[toknum] = cp1; + } + cp2++; + break; + } + /* FALLTHROUGH */ + default: + if (*cp2 != *cp1) { + match = 0; + } + break; + } + if (match && *cp1) { + cp1++; + } + if (match && *cp2) { + cp2++; + } + } + if (!match && *cp1) /* last token mismatch */ + { + toks[toknum] = 0; + } + cp1 = new; + *cp1 = '\0'; + cp2 = mapout; + while (*cp2) { + match = 0; + switch (*cp2) { + case '\\': + if (*(cp2 + 1)) { + *cp1++ = *++cp2; + } + break; + case '[': +LOOP: + if (*++cp2 == '$' && isdigit(*(cp2+1))) { + if (*++cp2 == '0') { + char *cp3 = name; + + while (*cp3) { + *cp1++ = *cp3++; + } + match = 1; + } + else if (toks[toknum = *cp2 - '1']) { + char *cp3 = tp[toknum]; + + while (cp3 != te[toknum]) { + *cp1++ = *cp3++; + } + match = 1; + } + } + else { + while (*cp2 && *cp2 != ',' && + *cp2 != ']') { + if (*cp2 == '\\') { + cp2++; + } + else if (*cp2 == '$' && + isdigit(*(cp2+1))) { + if (*++cp2 == '0') { + char *cp3 = name; + + while (*cp3) { + *cp1++ = *cp3++; + } + } + else if (toks[toknum = + *cp2 - '1']) { + char *cp3=tp[toknum]; + + while (cp3 != + te[toknum]) { + *cp1++ = *cp3++; + } + } + } + else if (*cp2) { + *cp1++ = *cp2++; + } + } + if (!*cp2) { + fputs( +"nmap: unbalanced brackets.\n", ttyout); + return (name); + } + match = 1; + cp2--; + } + if (match) { + while (*++cp2 && *cp2 != ']') { + if (*cp2 == '\\' && *(cp2 + 1)) { + cp2++; + } + } + if (!*cp2) { + fputs( +"nmap: unbalanced brackets.\n", ttyout); + return (name); + } + break; + } + switch (*++cp2) { + case ',': + goto LOOP; + case ']': + break; + default: + cp2--; + goto LOOP; + } + break; + case '$': + if (isdigit(*(cp2 + 1))) { + if (*++cp2 == '0') { + char *cp3 = name; + + while (*cp3) { + *cp1++ = *cp3++; + } + } + else if (toks[toknum = *cp2 - '1']) { + char *cp3 = tp[toknum]; + + while (cp3 != te[toknum]) { + *cp1++ = *cp3++; + } + } + break; + } + /* FALLTHROUGH */ + default: + *cp1++ = *cp2; + break; + } + cp2++; + } + *cp1 = '\0'; + if (!*new) { + return (name); + } + return (new); +} + diff --git a/usr.bin/ftp/small.h b/usr.bin/ftp/small.h new file mode 100644 index 00000000000..a051f2dc621 --- /dev/null +++ b/usr.bin/ftp/small.h @@ -0,0 +1,35 @@ +/* $OpenBSD: small.h,v 1.1 2009/05/05 19:35:30 martynas Exp $ */ + +/* + * Copyright (c) 2009 Martynas Venckus <martynas@openbsd.org> + * + * Permission to use, copy, modify, and distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +extern jmp_buf jabort; +extern char *mname; +extern char *home; +extern char *stype[]; + +void settype(int, char **); +void changetype(int, int); +void setbinary(int, char **); +void get(int, char **); +int getit(int, char **, int, const char *); +void mabort(int); +void mget(int, char **); +void cd(int, char **); +void disconnect(int, char **); +char *dotrans(char *); +char *domap(char *); + diff --git a/usr.bin/ftp/stringlist.c b/usr.bin/ftp/stringlist.c index c10df836572..ea65fcdbfbd 100644 --- a/usr.bin/ftp/stringlist.c +++ b/usr.bin/ftp/stringlist.c @@ -1,4 +1,4 @@ -/* $OpenBSD: stringlist.c,v 1.9 2009/04/27 21:37:13 deraadt Exp $ */ +/* $OpenBSD: stringlist.c,v 1.10 2009/05/05 19:35:30 martynas Exp $ */ /* $NetBSD: stringlist.c,v 1.2 1997/01/17 07:26:20 lukem Exp $ */ /* @@ -32,6 +32,8 @@ * SUCH DAMAGE. */ +#ifndef SMALL + #include <stdio.h> #include <string.h> #include <err.h> @@ -94,3 +96,6 @@ sl_free(StringList *sl, int all) } free(sl); } + +#endif /* !SMALL */ + diff --git a/usr.bin/ftp/stringlist.h b/usr.bin/ftp/stringlist.h index 1f7630c0112..00def0b132a 100644 --- a/usr.bin/ftp/stringlist.h +++ b/usr.bin/ftp/stringlist.h @@ -1,4 +1,4 @@ -/* $OpenBSD: stringlist.h,v 1.2 2002/02/16 21:27:46 millert Exp $ */ +/* $OpenBSD: stringlist.h,v 1.3 2009/05/05 19:35:30 martynas Exp $ */ /* $NetBSD: stringlist.h,v 1.2 1997/01/17 06:11:36 lukem Exp $ */ /* @@ -32,6 +32,8 @@ * SUCH DAMAGE. */ +#ifndef SMALL + #ifndef _STRINGLIST_H #define _STRINGLIST_H @@ -55,3 +57,6 @@ char *sl_find(StringList *, char *); __END_DECLS #endif /* _STRINGLIST_H */ + +#endif /* !SMALL */ + diff --git a/usr.bin/ftp/util.c b/usr.bin/ftp/util.c index bc32c337552..92cbbf12871 100644 --- a/usr.bin/ftp/util.c +++ b/usr.bin/ftp/util.c @@ -1,4 +1,4 @@ -/* $OpenBSD: util.c,v 1.61 2009/04/27 22:51:51 martynas Exp $ */ +/* $OpenBSD: util.c,v 1.62 2009/05/05 19:35:30 martynas Exp $ */ /* $NetBSD: util.c,v 1.12 1997/08/18 10:20:27 lukem Exp $ */ /*- @@ -106,6 +106,7 @@ setpeer(int argc, char *argv[]) code = -1; return; } +#ifndef SMALL if (argc < 2) (void)another(&argc, &argv, "to"); if (argc < 2 || argc > 3) { @@ -113,6 +114,7 @@ setpeer(int argc, char *argv[]) code = -1; return; } +#endif /* !SMALL */ if (gatemode) port = gateport; else @@ -335,6 +337,7 @@ tryagain: * * Returns false if no new arguments have been added. */ +#ifndef SMALL int another(int *pargc, char ***pargv, const char *prompt) { @@ -359,6 +362,7 @@ another(int *pargc, char ***pargv, const char *prompt) *pargv = margv; return (ret); } +#endif /* !SMALL */ /* * glob files given in argv[] from the remote server. @@ -478,6 +482,7 @@ remglob(char *argv[], int doswitch, char **errbuf) return remglob2(argv, doswitch, errbuf, &ftemp, NULL); } +#ifndef SMALL int confirm(const char *cmd, const char *file) { @@ -530,6 +535,7 @@ quit: } return (1); } +#endif /* !SMALL */ /* * Glob a local file name specification with @@ -937,6 +943,7 @@ ptransfer(int siginfo) /* * List words in stringlist, vertically arranged */ +#ifndef SMALL void list_vertical(StringList *sl) { @@ -974,6 +981,7 @@ list_vertical(StringList *sl) } } } +#endif /* !SMALL */ /* * Update the global ttywidth value, using TIOCGWINSZ. @@ -1044,3 +1052,4 @@ controlediting(void) } } #endif /* !SMALL */ + |