Skip to content

uckermit: μC‑Kermit (μCKermit, micro‑C‑Kermit, microkermit) is a minimalistic Kermit implementation for small, embedded, or resource constrained systems (CP/M, PDP‑11, etc.)

License

Notifications You must be signed in to change notification settings

BAN-AI-Communications/uckermit

Repository files navigation

μC֊Kermit

micro–C֊Kermit (microkermit)

License: BSD GitHubCodeSize TickgitTODOs CodebeatBadge DeepSourceA DeepSourceR

NAME

  • uckermit - minimalistic kermit file transfer

SYNOPSIS

  • uckermit [ option ... ] [ file ... ]

DESCRIPTION

μCKermit is a file transfer program that allows files to be moved between machines of many different operating systems and architectures.

Arguments are optional. If μCKermit is executed without arguments, it will enter command mode. Otherwise, μCKermit will read the arguments off the command line and interpret them.

The following notation is used in command descriptions:

  • fn
    • A UNIX file specification, possibly containing the "wildcard" characters '~', '*', or '?'.
      • '~' matches a user's home directory name,
      • '*' matches all character strings,
      • '?' matches any single character.
  • fn1
    • A UNIX file specification which may not contain '*' or '?'.
  • rfn
    • A remote file specification in the remote system's own syntax, which may denote a single file or a group of files.
  • rfn1
    • A remote file specification which should denote only a single file.
  • n
    • A decimal number, in most cases between 0 and 94.
  • c
    • A decimal number between 0 and 127 representing the value of an ASCII character.
  • cc
    • A decimal number between 0 and 31, or else exactly 127, representing the value of an ASCII control character.
  • [ ... ]
    • Any field in square braces is optional.
  • { x, y, z }
    • Alternatives are listed in curly braces.

μCKermit command line options may specify either actions or settings. If μCKermit is invoked with a command line that specifies no actions, then it will issue a prompt and begin interactive dialog. Action options specify either protocol transactions or terminal connection.

COMMAND LINE OPTIONS

  • -s fn

    • Send the specified file or files. If fn contains wildcard (shell meta) characters, the UNIX shell expands it into a list. If fn is '-' then μCKermit sends from standard input, which may come from a file: uckermit -s - < foo.bar or a parallel process: ls -l | uckermit -s -. You cannot use this mechanism to send terminal type-in. If you want to send file whose name is "-" you can precede it with a path name, as in: uckermit -s ./-.
  • -r

    • Receive a file or files. Wait passively for files to arrive.
  • -k

    • Receive (passively) a file or files, sending them to standard output. This option can be used in several ways: uckermit -k displays the incoming files on your screen; to be used only in "local mode" (see below). uckermit -k > fn1 sends the incoming file or files to the named file, fn1. If more than one file arrives, all are concatenated together into the single file fn1. uckermit -k | command pipes the incoming data (single or multiple files) to the indicated command, as in: uckermit -k | sort > sorted.stuff
  • -a fn1

    • If you have specified a file transfer option, you may specify an alternate name for a single file with the -a option. For example, uckermit -s foo -a bar sends the file foo telling the receiver that its name is bar. If more than one file arrives or is sent, only the first file is affected by the -a option: uckermit -ra baz stores the first incoming file under the name baz.
  • -x

    • Begin server operation. May be used in either local or remote mode. Before proceeding, a few words about remote and local operation are necessary. μCKermit is "local" if it is running on a PC or workstation that you are using directly, or if it is running on a multiuser system and transferring files over an external communication line — not your job's controlling terminal or console. μCKermit is remote if it is running on a multiuser system and transferring files over its own controlling terminal's communication line, connected to your PC or workstation. On most systems, μCKermit runs in remote mode by default, so on a PC or workstation, you will have to put it into local mode. The following command sets μCKermit's "mode":
  • -l dev

    • Line — Specify a terminal line to use for file transfer and terminal connection, as in: uckermit -l /dev/ttyS5. When an external line is being used, you might also need some additional options for successful communication with the remote system:
  • -b n

    • Baud — Specify the baud rate for the line given in the -l option, as in: uckermit -l /dev/ttyS5 -b 9600. This option should always be included with the -l option, since the speed of an external line is not necessarily what you might expect.
  • -p x

    • Parity — e, o, m, s, n (even, odd, mark, space, or none). If parity is other than none, then the 8th-bit prefixing mechanism will be used for transferring 8-bit binary data, provided the opposite Kermit agrees. The default parity is none.
  • -t

    • Specifies half duplex, line turnaround with XON as the handshake character. The following commands may be used only with a μCKermit which is local — either by default or else because the -l option has been specified.
  • -g rfn

    • Actively request a remote server to send the named file or files; rfn is a file specification in the remote host's own syntax. If fn happens to contain any special shell characters, like '*', these must be quoted, as in: uckermit -g x\*.\?
  • -f

    • Send a 'finish' command to a remote server.
  • -c

    • Establish a terminal connection over the specified or default communication line, before any protocol transaction takes place. Get back to the local system by typing the escape character (normally Control-\) followed by the letter 'c'.
  • -n

    • Like -c, but after a protocol transaction takes place; -c and -n may both be used in the same command. The use of -n and -c is illustrated below.
  • On a timesharing system, the -l and -b options will also have to be included with the -r, -k, or -s options if the other μCKermit is on a remote system.

  • If uckermit is in local mode, the screen (stdout) is continously updated to show the progress of the file transer. A dot is printed for every four data packets, other packets are shown by type (e.g. 'S' for Send-Init), 'T' is printed when there's a timeout, and '%' for each retransmission. In addition, you may type (to stdin) certain "interrupt" commands during file transfer:

    • Control-F: Interrupt the current File, and go on to the next (if any).
    • Control-B: Interrupt the entire Batch of files, terminate the transaction.
    • Control-R: Resend the current packet
    • Control-A: Display a status report for the current transaction.
  • These interrupt characters differ from the ones used in other Kermit implementations to avoid conflict with UNIX shell interrupt characters. With System III and System V implementations of UNIX, interrupt commands must be preceeded by the escape character (e.g. Control-\).

  • Several other command-line options are provided:

    • -i
      • Specifies that files should be sent or received with text conversion.
    • -e n
      • Specifies the (extended) receive-packet length, a number between 10 and about 1200 (depending on the system). Lengths of 95 or greater require that the opposite Kermit support the long packet protocol extension.
    • -w
      • Overwrite — Allow overwriting of local files with incoming files.
    • -q
      • Quiet — Suppress screen update during file transfer, for instance to allow a file transfer to proceed in the background.
    • -d
      • Debug — Record debugging information in the file debug.log in the current directory. Use this option if you believe the program is misbehaving, and show the resulting log to your local μCKermit maintainer.
    • -h
      • Help — Display a brief synopsis of the command line options. The command line may contain no more than one protocol action option.

INTERACTIVE OPERATION

  • μCKermit's interactive command prompt is "uCKermit>". In response to this prompt, you may type any valid command.

  • μCKermit executes the command and then prompts you for another command. The process continues until you instruct the program to terminate.

  • Commands begin with a keyword, normally an English verb, such as "send". You may omit trailing characters from any keyword, so long as you specify sufficient characters to distinguish it from any other keyword valid in that field.

  • Certain characters have special functions in interactive commands:

    • ?
      • Question mark, typed at any point in a command, will produce a message explaining what is possible or expected at that point. Depending on the context, the message may be a brief phrase, a menu of keywords, or a list of files.
    • ESC
      • The Escape, Meta, or Altmode key — Request completion of the current keyword or filename, or insertion of a default value. The result will be a beep if the requested operation fails.
    • DEL
      • The Delete or Rubout key — Delete the previous character from the command. You may also use BS (Backspace) or Control-H for this function.
    • ^W
      • Control-W — Erase the rightmost word from the command line.
    • ^U
      • Control-U — Erase the entire command.
    • ^R
      • Control-R — Redisplay the current command.
    • SP
      • Space — Delimits fields (keywords, filenames, numbers) within a command. HT (Horizontal Tab) may also be used for this purpose.
    • CR
      • Carriage Return — Enters the command for execution. LF (Linefeed) or FF (Formfeed) may also be used for this purpose.
    • \
      • Backslash — Enter any of the above characters into the command, literally. To enter a backslash, type two backslashes in a row (\\). A single backslash immediately preceding a carriage return allows you to continue the command on the next line.
  • You may type the editing characters (DEL, ^W, etc) repeatedly, to delete all the way back to the prompt. No action will be performed until the command is entered by typing carriage return, linefeed, or formfeed. If you make any mistakes, you will receive an informative error message and a new prompt — make liberal use of '?' and ESC to feel your way through the commands. One important command is "help" — you should use it the first time you run μCKermit.

  • Interactive μCKermit accepts commands from files as well as from the keyboard. Upon startup, μCKermit looks for the file .uckermrc in your home or current directory (first it looks in the home directory, then in the current one) and executes any commands it finds there. These commands must be in interactive format, not UNIX command-line format. A "take" command is also provided for use at any time during an interactive session. Command files may be nested to any reasonable depth.

  • Here is a brief list of μCKermit interactive commands:

    • ! command
      • Execute a UNIX shell command. A space is required after after the !.
    • % text
      • A comment. Useful in take-command files.
    • bye
      • Terminate and log out a remote μCKermit server.
    • close
      • Close a log file.
    • connect
      • Establish a terminal connection to a remote system.
    • cwd
      • Change Working Directory.
    • dial
      • Dial a telephone number.
    • directory
      • Display a directory listing.
    • echo
      • Display arguments literally. Useful in take-command files.
    • exit
      • Exit from the program, closing any open logs.
    • finish
      • Instruct a remote μCKermit server to exit, but not log out.
    • get
      • Get files from a remote μCKermit server.
    • hangup
      • Hang up the phone.
    • help
      • Display a help message for a given command.
    • log
      • Open a log file — debugging, packet, session, transaction.
    • quit
      • Same as 'exit'.
    • receive
      • Passively wait for files to arrive.
    • remote
      • Issue file management commands to a remote μCKermit server.
    • script
      • Execute a login script with a remote system.
    • send
      • Send files.
    • server
      • Begin server operation.
    • set
      • Set various parameters.
    • show
      • Display values of 'set' parameters, program version, etc.
    • space
      • Display current disk space usage.
    • statistics
      • Display statistics about most recent transaction.
    • take
      • Execute commands from a file.
    • transmit
      • Send a file without error checking.
  • The 'set' parameters are:

    • attributes
      • Turn attribute packet exchange on or off (default is on).
    • block-check
      • Level of packet error detection.
    • delay
      • How long to wait before sending first packet.
    • duplex
      • Specify which side echoes during 'connect'.
    • escape-character
      • Character to prefix "escape commands" during 'connect'.
    • file
      • Set various file parameters.
    • flow-control
      • Communication line full-duplex flow control.
    • handshake
      • Communication line half-duplex turnaround character.
    • line
      • Communication line device name.
    • modem-dialer
      • Type of modem-dialer on communication line.
    • parity
      • Communication line character parity.
    • prompt
      • Change the μCKermit program's prompt.
    • receive
      • Set various parameters for inbound packets.
    • retry
      • Set the packet retransmission limit.
    • send
      • Set various parameters for outbound packets.
    • server
      • Set server-related parameters (like timeout).
    • speed
      • Communication line speed.
  • The 'remote' commands are:

    • cwd
      • Change remote working directory.
    • delete
      • Delete remote files.
    • directory
      • Display a listing of remote file names.
    • help
      • Request help from a remote server.
    • host
      • Issue a command to the remote host in its own command language.
    • space
      • Display current disk space usage on remote system.
    • type
      • Display a remote file on your screen.
    • who
      • Display who's logged in, or get information about a user.

CONTACT

HOMEPAGE

ORIGINAL AUTHORS

  • Frank da Cruz, Columbia University Center for Computing Activities,
    • with contributions from many others.

LICENSE

Revised 3‑Clause BSD License for Columbia University Kermit Software

Copyright © 1981—2011, Trustees of Columbia University in the City of New York.
Copyright © 1984 Jeff Damens, Columbia University Center for Computing Activites
Copyright © 1985, Herman Fischer, Encino CA
Copyright © 2021, 2022, 2023 Jeffrey H. Johnson <trnsz@pobox.com>

All rights reserved.

  • Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:

    • Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.

    • 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.

    • Neither the name of Columbia 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 COPYRIGHT HOLDERS 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 COPYRIGHT HOLDER 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.

FILES

  • $HOME/.uckermrc μCKermit initialization commands
  • ./.uckermrc more μCKermit initialization commands

SEE ALSO

DIAGNOSTICS

  • The diagnostics produced by μCKermit itself are intended to be self-explanatory.

BUGS

  • Probably way too many.