]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - usr.bin/ftp/ftp_var.h
BSD 4.4 Lite Usr.bin Sources
[FreeBSD/FreeBSD.git] / usr.bin / ftp / ftp_var.h
1 /*
2  * Copyright (c) 1985, 1989, 1993, 1994
3  *      The Regents of the University of California.  All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions
7  * are met:
8  * 1. Redistributions of source code must retain the above copyright
9  *    notice, this list of conditions and the following disclaimer.
10  * 2. Redistributions in binary form must reproduce the above copyright
11  *    notice, this list of conditions and the following disclaimer in the
12  *    documentation and/or other materials provided with the distribution.
13  * 3. All advertising materials mentioning features or use of this software
14  *    must display the following acknowledgement:
15  *      This product includes software developed by the University of
16  *      California, Berkeley and its contributors.
17  * 4. Neither the name of the University nor the names of its contributors
18  *    may be used to endorse or promote products derived from this software
19  *    without specific prior written permission.
20  *
21  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
22  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
25  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
26  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
27  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
28  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
29  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
30  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
31  * SUCH DAMAGE.
32  *
33  *      @(#)ftp_var.h   8.3 (Berkeley) 4/2/94
34  */
35
36 /*
37  * FTP global variables.
38  */
39
40 #include <sys/param.h>
41 #include <setjmp.h>
42
43 #include "extern.h"
44
45 /*
46  * Options and other state info.
47  */
48 int     trace;                  /* trace packets exchanged */
49 int     hash;                   /* print # for each buffer transferred */
50 int     sendport;               /* use PORT cmd for each data connection */
51 int     verbose;                /* print messages coming back from server */
52 int     connected;              /* connected to server */
53 int     fromatty;               /* input is from a terminal */
54 int     interactive;            /* interactively prompt on m* cmds */
55 int     debug;                  /* debugging level */
56 int     bell;                   /* ring bell on cmd completion */
57 int     doglob;                 /* glob local file names */
58 int     autologin;              /* establish user account on connection */
59 int     proxy;                  /* proxy server connection active */
60 int     proxflag;               /* proxy connection exists */
61 int     sunique;                /* store files on server with unique name */
62 int     runique;                /* store local files with unique name */
63 int     mcase;                  /* map upper to lower case for mget names */
64 int     ntflag;                 /* use ntin ntout tables for name translation */
65 int     mapflag;                /* use mapin mapout templates on file names */
66 int     code;                   /* return/reply code for ftp command */
67 int     crflag;                 /* if 1, strip car. rets. on ascii gets */
68 char    pasv[64];               /* passive port for proxy data connection */
69 char    *altarg;                /* argv[1] with no shell-like preprocessing  */
70 char    ntin[17];               /* input translation table */
71 char    ntout[17];              /* output translation table */
72 char    mapin[MAXPATHLEN];      /* input map template */
73 char    mapout[MAXPATHLEN];     /* output map template */
74 char    typename[32];           /* name of file transfer type */
75 int     type;                   /* requested file transfer type */
76 int     curtype;                /* current file transfer type */
77 char    structname[32];         /* name of file transfer structure */
78 int     stru;                   /* file transfer structure */
79 char    formname[32];           /* name of file transfer format */
80 int     form;                   /* file transfer format */
81 char    modename[32];           /* name of file transfer mode */
82 int     mode;                   /* file transfer mode */
83 char    bytename[32];           /* local byte size in ascii */
84 int     bytesize;               /* local byte size in binary */
85
86 char    *hostname;              /* name of host connected to */
87 int     unix_server;            /* server is unix, can use binary for ascii */
88 int     unix_proxy;             /* proxy is unix, can use binary for ascii */
89
90 struct  servent *sp;            /* service spec for tcp/ftp */
91
92 jmp_buf toplevel;               /* non-local goto stuff for cmd scanner */
93
94 char    line[200];              /* input line buffer */
95 char    *stringbase;            /* current scan point in line buffer */
96 char    argbuf[200];            /* argument storage buffer */
97 char    *argbase;               /* current storage point in arg buffer */
98 int     margc;                  /* count of arguments on input line */
99 char    *margv[20];             /* args parsed from input line */
100 int     cpend;                  /* flag: if != 0, then pending server reply */
101 int     mflag;                  /* flag: if != 0, then active multi command */
102
103 int     options;                /* used during socket creation */
104
105 /*
106  * Format of command table.
107  */
108 struct cmd {
109         char    *c_name;        /* name of command */
110         char    *c_help;        /* help string */
111         char    c_bell;         /* give bell when command completes */
112         char    c_conn;         /* must be connected to use command */
113         char    c_proxy;        /* proxy server may execute */
114         void    (*c_handler) __P((int, char **)); /* function to call */
115 };
116
117 struct macel {
118         char mac_name[9];       /* macro name */
119         char *mac_start;        /* start of macro in macbuf */
120         char *mac_end;          /* end of macro in macbuf */
121 };
122
123 int macnum;                     /* number of defined macros */
124 struct macel macros[16];
125 char macbuf[4096];