Subversion Repositories Kolibri OS

Rev

Blame | Last modification | View Log | RSS feed

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