home *** CD-ROM | disk | FTP | other *** search
/ kermit.columbia.edu / kermit.columbia.edu.tar / kermit.columbia.edu / minix1 / mxuus2.c < prev    next >
C/C++ Source or Header  |  1988-08-15  |  16KB  |  509 lines

  1. /*  C K U U S 2  --  "User Interface" STRINGS module for Unix Kermit  */
  2.  
  3. /*
  4.  Author: Frank da Cruz (SY.FDC@CU20B),
  5.  Columbia University Center for Computing Activities, January 1985.
  6.  Copyright (C) 1985, Trustees of Columbia University in the City of New York.
  7.  Permission is granted to any individual or institution to use, copy, or
  8.  redistribute this software so long as it is not sold for profit, provided this
  9.  copyright notice is retained. 
  10. */
  11.  
  12. /*  This module separates long strings from the body of the ckuser module. */  
  13.  
  14. #include "ckcdeb.h"
  15. #include <stdio.h>
  16. #include <ctype.h>
  17. #include "ckcker.h"
  18. #include "ckucmd.h"
  19. #include "ckuusr.h"
  20.  
  21. extern char cmdbuf[];
  22. extern int nrmt, nprm, dfloc;
  23. extern char *dftty;
  24. extern struct keytab prmtab[];
  25. extern struct keytab remcmd[];
  26.  
  27. static
  28. char *hlp1[] = {
  29. "\n",
  30. "  Usage: kermit [-x arg [-x arg]...[-yyy]..]]\n",
  31. "   x is an option that requires an argument, y an option with no argument:\n",
  32. "     actions (* options also require -l and -b) --\n",
  33. "       -s file(s)   send (use '-s -' to send from stdin)\n",
  34. "       -r           receive\n",
  35. "       -k           receive to stdout\n",
  36. "     * -g file(s)   get remote file(s) from server (quote wildcards)\n",
  37. "       -a name      alternate name, used with -s, -r, -g\n",
  38. "       -x           enter server mode\n",
  39. "     * -f           finish remote server\n",
  40. "     * -c           connect before transaction\n",
  41. "     * -n           connect after transaction\n",
  42. "       -h           help - print this message\n",
  43. "     settings --\n",
  44. "       -l line      communication line device\n",
  45. "       -b baud      line speed, e.g. 1200\n",
  46. "       -i           binary file or Unix-to-Unix\n",
  47. "       -p x         parity, x is one of e,o,m,s,n\n",
  48. "       -t           line turnaround handshake = xon, half duplex\n",
  49. "       -w           don't write over preexisting files\n",
  50. "       -q           be quiet during file transfer\n",
  51. "       -d           log debugging info to debug.log\n",
  52. " If no action command is included, enter interactive dialog.\n",
  53. ""
  54. };
  55.  
  56. /*  U S A G E */
  57.  
  58. usage() {
  59.     conola(hlp1);
  60. }
  61.  
  62.  
  63. /*  Help string definitions  */
  64.  
  65. static char *tophlp[] = { "\n\
  66. Type ? for a list of commands, type 'help x' for any command x.\n\
  67. While typing commands, use the following special characters:\n\n\
  68.  DEL, RUBOUT, BACKSPACE, CTRL-H: Delete the most recent character typed.\n\
  69.  CTRL-W: Delete the most recent word typed.\n",
  70.  
  71. "\
  72.  CTRL-U: Delete the current line.\n\
  73.  CTRL-R: Redisplay the current line.\n\
  74.  ?       (question mark) display help on the current command or field.\n\
  75.  ESC     (Escape or Altmode) Attempt to complete the current field.\n",
  76.  
  77. "\
  78.  \\       (backslash) include the following character literally.\n\n\
  79. From system level, type 'kermit -h' to get help about command line args.\
  80. \n",
  81. "" };
  82.  
  83. static char *hmxxbye = "\
  84. Shut down and log out a remote Kermit server";
  85.  
  86. static char *hmxxclo = "\
  87. Close one of the following logs:\n\
  88.  session, transaction, packet, debugging -- 'help log' for further info.";
  89.  
  90. static char *hmxxcon = "\
  91. Connect to a remote system via the tty device given in the\n\
  92. most recent 'set line' command";
  93.  
  94. static char *hmxxget = "\
  95. Format: 'get filespec'.  Tell the remote Kermit server to send the named\n\
  96. files.  If filespec is omitted, then you are prompted for the remote and\n\
  97. local filenames separately.";
  98.  
  99. static char *hmxxlg[] = { "\
  100. Record information in a log file:\n\n\
  101.  debugging             Debugging information, to help track down\n\
  102.   (default debug.log)  bugs in the C-Kermit program.\n\n\
  103.  packets               Kermit packets, to help track down protocol problems.\n\
  104.   (packet.log)\n\n",
  105.  
  106. " session               Terminal session, during CONNECT command.\n\
  107.   (session.log)\n\n\
  108.  transactions          Names and statistics about files transferred.\n\
  109.   (transact.log)\n",
  110. "" } ;
  111.  
  112.  
  113. static char *hmxxlogi[] = { "\
  114. Syntax: script text\n\n",
  115. "Login to a remote system using the text provided.  The login script\n",
  116. "is intended to operate similarly to uucp \"L.sys\" entries.\n",
  117. "A login script is a sequence of the form:\n\n",
  118. "    expect send [expect send] . . .\n\n",
  119. "where 'expect' is a prompt or message to be issued by the remote site, and\n",
  120. "'send' is the names, numbers, etc, to return.  The send may also be the\n",
  121. "keyword EOT, to send control-d, or BREAK, to send a break.  Letters in\n",
  122. "send may be prefixed by ~ to send special characters.  These are:\n",
  123. "~b backspace, ~s space, ~q '?', ~n linefeed, ~r return, ~c don\'t\n",
  124. "append a return, and ~o[o[o]] for octal of a character.  As with some \n",
  125. "uucp systems, sent strings are followed by ~r unless they end with ~c.\n\n",
  126. "Only the last 7 characters in each expect are matched.  A null expect,\n",
  127. "e.g. ~0 or two adjacent dashes, causes a short delay.  If you expect\n",
  128. "that a sequence might not arrive, as with uucp, conditional sequences\n",
  129. "may be expressed in the form:\n\n",
  130. "    -send-expect[-send-expect[...]]\n\n",
  131. "where dashed sequences are followed as long as previous expects fail.\n",
  132. "" };
  133.  
  134. static char *hmxxrc[] = { "\
  135. Format: 'receive [filespec]'.  Wait for a file to arrive from the other\n\
  136. Kermit, which must be given a 'send' command.  If the optional filespec is\n",
  137.  
  138. "given, the (first) incoming file will be stored under that name, otherwise\n\
  139. it will be stored under the name it arrives with.",
  140. "" } ;
  141.  
  142. static char *hmxxsen = "\
  143. Format: 'send file1 [file2]'.  File1 may contain wildcard characters '*' or\n\
  144. '?'.  If no wildcards, then file2 may be used to specify the name file1 is\n\
  145. sent under; if file2 is omitted, file1 is sent under its own name.";
  146.  
  147. static char *hmxxser = "\
  148. Enter server mode on the currently selected line.  All further commands\n\
  149. will be taken in packet form from the other Kermit program.";
  150.  
  151. static char *hmhset[] = { "\
  152. The 'set' command is used to establish various communication or file\n",
  153. "parameters.  The 'show' command can be used to display the values of\n",
  154. "'set' parameters.  Help is available for each individual parameter;\n",
  155. "type 'help set ?' to see what's available.\n",
  156. "" } ;
  157.  
  158. static char *hmxychkt[] = { "\
  159. Type of packet block check to be used for error detection, 1, 2, or 3.\n",
  160. "Type 1 is standard, and catches most errors.  Types 2 and 3 specify more\n",
  161. "rigorous checking at the cost of higher overhead.  Not all Kermit programs\n",
  162. "support types 2 and 3.\n",
  163. "" } ;
  164.  
  165.  
  166. static char *hmxyf[] = { "\set file: names, type, warning, display.\n\n",
  167. "'names' are normally 'converted', which means file names are converted\n",
  168. "to 'common form' during transmission; 'literal' means use filenames\n",
  169. "literally (useful between like systems).\n\n",
  170. "'type' is normally 'text', in which conversion is done between Unix\n",
  171. "newlines and CRLF line delimiters; 'binary' means to do no conversion.\n",
  172. "Use 'binary' for executable programs or binary data.\n\n",
  173. "'warning' is 'on' or 'off', normally off.  When off, incoming files will\n",
  174. "overwrite existing files of the same name.  When on, new names will be\n",
  175. "given to incoming files whose names are the same as existing files.\n",
  176. "\n\
  177. 'display' is normally 'on', causing file transfer progress to be displayed\n",
  178. "on your screen when in local mode.  'set display off' is useful for\n",
  179. "allowing file transfers to proceed in the background.\n\n",
  180. "" } ;
  181.  
  182. static char *hmhrmt[] = { "\
  183. The 'remote' command is used to send file management instructions to a\n",
  184. "remote Kermit server.  There should already be a Kermit running in server\n",
  185. "mode on the other end of the currently selected line.  Type 'remote ?' to\n",
  186. "see a list of available remote commands.  Type 'help remote x' to get\n",
  187. "further information about a particular remote command 'x'.\n",
  188. "" } ;
  189.  
  190.  
  191. /*  D O H L P  --  Give a help message  */
  192.  
  193. dohlp(xx) int xx; {
  194.     int x,y;
  195.  
  196.     if (xx < 0) return(xx);
  197.     switch (xx) {
  198.  
  199. case XXBYE:
  200.     return(hmsg(hmxxbye));
  201.  
  202. case XXCLO:
  203.     return(hmsg(hmxxclo));
  204.  
  205. case XXCON:
  206.     return(hmsg(hmxxcon));
  207.  
  208. case XXCWD:
  209. #ifdef vms
  210.     return(hmsg("\
  211. Change Working Directory, equivalent to VMS SET DEFAULT command"));
  212. #else
  213.     return(hmsg("Change Working Directory, equivalent to Unix 'cd' command"));
  214. #endif
  215.  
  216. case XXDEL:
  217.     return(hmsg("Delete a local file or files"));
  218.  
  219. case XXDIAL:
  220.     return(hmsg("Dial a number using modem autodialer"));
  221.  
  222. case XXDIR:
  223.     return(hmsg("Display a directory of local files"));
  224.  
  225. case XXECH:
  226.     return(hmsg("Display the rest of the command on the terminal,\n\
  227. useful in command files."));
  228.  
  229. case XXEXI:
  230. case XXQUI:
  231.     return(hmsg("Exit from the Kermit program, closing any open logs."));
  232.  
  233. case XXFIN:
  234.     return(hmsg("\
  235. Tell the remote Kermit server to shut down without logging out."));
  236.  
  237. case XXGET:
  238.     return(hmsg(hmxxget));
  239.  
  240. case XXHLP:
  241.     return(hmsga(tophlp));
  242.  
  243. case XXLOG:
  244.     return(hmsga(hmxxlg));
  245.  
  246. case XXLOGI:
  247.     return(hmsga(hmxxlogi));
  248.  
  249. case XXREC:
  250.     return(hmsga(hmxxrc));
  251.  
  252.  
  253. case XXREM:
  254.     if ((y = cmkey(remcmd,nrmt,"Remote command","")) == -2) return(y);
  255.     if (y == -1) return(y);
  256.     if (x = (cmcfm()) < 0) return(x);
  257.     return(dohrmt(y));
  258.  
  259. case XXSEN:
  260.     return(hmsg(hmxxsen));
  261.  
  262. case XXSER:
  263.     return(hmsg(hmxxser));
  264.  
  265. case XXSET:
  266.     if ((y = cmkey(prmtab,nprm,"Parameter","")) == -2) return(y);
  267.     if (y == -2) return(y);
  268.     if (x = (cmcfm()) < 0) return(x);
  269.     return(dohset(y));
  270.  
  271. case XXSHE:
  272. #ifdef vms
  273.     return(hmsg("\
  274. Issue a command to VMS (space required after '!')"));
  275. #else
  276. #ifdef AMIGA
  277.     return(hmsg("\
  278. Issue a command to CLI (space required after '!')"));
  279. #else
  280.     return(hmsg("\
  281. Issue a command to the Unix shell (space required after '!')"));
  282. #endif
  283. #endif
  284.  
  285. case XXSHO:
  286.     return(hmsg("\
  287. Display current values of 'set' parameters; 'show version' will display\n\
  288. program version information for each of the C-Kermit modules."));
  289.  
  290. case XXSPA:
  291.     return(hmsg("Display disk usage in current device, directory"));
  292.  
  293. case XXSTA:
  294.     return(hmsg("Display statistics about most recent file transfer"));
  295.  
  296. case XXTAK:
  297.     return(hmsg("\
  298. Take Kermit commands from the named file.  Kermit command files may\n\
  299. themselves contain 'take' commands, up to a reasonable depth of nesting."));
  300.  
  301. default:
  302.     if (x = (cmcfm()) < 0) return(x);
  303.     printf("Not available yet - %s\n",cmdbuf);
  304.     break;
  305.     }
  306.     return(0);
  307. }
  308.  
  309.  
  310. /*  H M S G  --  Get confirmation, then print the given message  */
  311.  
  312. hmsg(s) char *s; {
  313.     int x;
  314.     if (x = (cmcfm()) < 0) return(x);
  315.     puts(s);
  316.     return(0);
  317. }
  318.  
  319. hmsga(s) char *s[]; {            /* Same function, but for arrays */
  320.     int x, i;
  321.     if ( x = (cmcfm()) < 0) return(x);
  322.     for ( i = 0; *s[i] ; i++ ) fputs(s[i], stdout);
  323.     fputc( '\n', stdout);
  324.     return(0);
  325. }
  326.  
  327.  
  328. /*  D O H S E T  --  Give help for SET command  */
  329.  
  330. dohset(xx) int xx; {
  331.     
  332.     if (xx == -3) return(hmsga(hmhset));
  333.     if (xx < 0) return(xx);
  334.     switch (xx) {
  335.  
  336. case XYCHKT:
  337.     return(hmsga(hmxychkt));
  338.  
  339. case XYDELA: 
  340.     puts("\
  341. Number of seconds to wait before sending first packet after 'send' command.");
  342.     return(0);
  343.  
  344. case XYDUPL:
  345.     puts("\
  346. During 'connect': 'full' means remote host echoes, 'half' means this program");
  347.     puts("does its own echoing.");
  348.     return(0);
  349.  
  350. case XYESC:
  351.     printf("%s","\
  352. Decimal ASCII value for escape character during 'connect', normally 28\n\
  353. (Control-\\)\n");
  354.     return(0);
  355.  
  356. case XYFILE:
  357.     return(hmsga(hmxyf));
  358.  
  359. case XYFLOW:
  360.     puts("\
  361. Type of flow control to be used.  Choices are 'xon/xoff' and 'none'.");
  362.     puts("normally xon/xoff.");
  363.     return(0);
  364.  
  365. case XYHAND:
  366.     puts("\
  367. Decimal ASCII value for character to use for half duplex line turnaround");
  368.     puts("handshake.  Normally, handshaking is not done.");
  369.     return(0);
  370.  
  371. case XYLINE:
  372.     printf("\
  373. Device name of communication line to use.  Normally %s.\n",dftty);
  374.     if (!dfloc) {
  375.     printf("\
  376. If you set the line to other than %s, then Kermit\n",dftty);
  377.     printf("\
  378. will be in 'local' mode; 'set line' will reset Kermit to remote mode.\n");
  379.     puts("\
  380. If the line has a modem, and if the modem-dialer is set to direct, this");
  381.     puts("\
  382. command causes waiting for a carrier detect (e.g. on a hayes type modem).");
  383.     puts("\
  384. This can be used to wait for incoming calls.");
  385.     puts("\
  386. To use the modem to dial out, first set modem-dialer (e.g., to hayes), then");
  387.     puts("set line, next issue the dial command, and finally connect.");
  388.     }
  389.     return(0);
  390.  
  391. case XYMODM:
  392.     puts("\
  393. Type of modem for dialing remote connections.  Needed to indicate modem can");
  394.     puts("\
  395. be commanded to dial without 'carrier detect' from modem.  Many recently");
  396.     puts("\
  397. manufactured modems use 'hayes' protocol.  Type 'set modem ?' to see what");
  398.     puts("\
  399. types of modems are supported by this program.");
  400.     return(0);
  401.  
  402.  
  403. case XYPARI:
  404.     puts("Parity to use during terminal connection and file transfer:");
  405.     puts("even, odd, mark, space, or none.  Normally none.");
  406.     return(0);
  407.  
  408. case XYPROM:
  409.     puts("Prompt string for this program, normally 'C-Kermit>'.");
  410.     return(0);
  411.  
  412. case XYSPEE:
  413.     puts("\
  414. Communication line speed for external tty line specified in most recent");
  415. #ifdef AMIGA
  416.     puts("\
  417. 'set line' command.  Any baud rate between 110 and 292000, although you");
  418.     puts(" will receive a warning if you do not use a standard baud rate:");
  419.     puts("\
  420. 110, 150, 300, 600, 1200, 1800, 2400, 4800, 9600, 19200, 38400, 57600.");
  421. #else
  422.     puts("\
  423. 'set line' command.  Any of the common baud rates:");
  424.     puts(" 0, 110, 150, 300, 600, 1200, 1800, 2400, 4800, 9600.");
  425. #endif
  426.     return(0);
  427.  
  428. case XYRECV:
  429.     puts("\
  430. Specify parameters for inbound packets:");
  431.     puts("\
  432. End-Of-Packet (ASCII value), Packet-Length (94 or less),");
  433.     puts("\
  434. Padding (amount, 94 or less), Pad-Character (ASCII value),");
  435.     puts("\
  436. Start-Of-Packet (ASCII value), and Timeout (94 seconds or less),");
  437.     puts("\
  438. all specified as decimal numbers.");
  439.     return(0);
  440.  
  441. case XYSEND:
  442.     puts("\
  443. Specify parameters for outbound packets:");
  444.     puts("\
  445. End-Of-Packet (ASCII value), Packet-Length (94 or less),");
  446.     puts("\
  447. Padding (amount, 94 or less), Pad-Character (ASCII value),");
  448.     puts("\
  449. Start-Of-Packet (ASCII value), and Timeout (94 seconds or less),");
  450.     puts("\
  451. all specified as decimal numbers.");
  452.     return(0);
  453.  
  454. default:
  455.     printf("%s","Not available yet - %s\n",cmdbuf);
  456.     return(0);
  457.     }
  458. }
  459.  
  460.  
  461. /*  D O H R M T  --  Give help about REMOTE command  */
  462.  
  463. dohrmt(xx) int xx; {
  464.     int x;
  465.     if (xx == -3) return(hmsga(hmhrmt));
  466.     if (xx < 0) return(xx);
  467.     switch (xx) {
  468.  
  469. case XZCWD:
  470.     return(hmsg("\
  471. Ask remote Kermit server to change its working directory."));
  472.  
  473. case XZDEL:
  474.     return(hmsg("\
  475. Ask remote Kermit server to delete the named file(s)."));
  476.  
  477. case XZDIR:
  478.     return(hmsg("\
  479. Ask remote Kermit server to provide directory listing of the named file(s)."));
  480.  
  481. case XZHLP:
  482.     return(hmsg("\
  483. Ask remote Kermit server to tell you what services it provides."));
  484.  
  485. case XZHOS:
  486.     return(hmsg("\
  487. Send a command to the remote system in its own command language\n\
  488. through the remote Kermit server."));
  489.  
  490. case XZSPA:
  491.     return(hmsg("\
  492. Ask the remote Kermit server to tell you about its disk space."));
  493.  
  494. case XZTYP:
  495.     return(hmsg("\
  496. Ask the remote Kermit server to type the named file(s) on your screen."));
  497.  
  498. case XZWHO:
  499.     return(hmsg("\
  500. Ask the remote Kermit server to list who's logged in, or to give information\n\
  501. about the specified user."));
  502.  
  503. default:
  504.     if (x = (cmcfm()) < 0) return(x);
  505.     printf("%s","not working yet - %s\n",cmdbuf);
  506.     return(-2);
  507.     }
  508. }
  509.