Commy is a small console utility for communicating with tty, UART or COM port devices. It runs on Mac, Linux and Windows. Windows support is experimental (bug reports appreciated).
Does (some of) the same things as tio, minicom, screen, miniterm.py, zcom, PuTTY, etc.
Commy incorporates a VT220/xterm/ECMA-48 terminal emulator for consistency whether running in Windows Terminal, XTerm or Terminal.app.
zig build
zig-out/bin/commy -h
The binary is:
zig-out/bin/commy
Copy it to a directory in your path for easy access:
sudo cp zig-out/bin/commy /usr/local/bin
Or if you prefer, let zig install it in your home directory (assuming ~/.local/bin
is in your $PATH
):
zig build -Doptimize=ReleaseSafe --prefix ~/.local
commy
is a single statically linked binary. No further runtime files are required.
You may install it on another system by simply copying the binary. It can be cross compiled using zig's -Dtarget
zig build -Dtarget=x86_64-windows
List available serial ports
commy -l
/dev/cu.usbmodem1124101
/dev/cu.usbmodem1124203
Connect to a port
commy /dev/cu.usbmodem1124203 115200
Commy will try to find available ports which match so connecting to /dev/ttyUSB0
can be written as:
commy USB0 115200
The status bar at the top shows keyboard shortcuts. Press ctrl-a
then q
, \
or x
to quit.
Log data received from a device (only received data will be logged, unless local echo is enabled):
commy /dev/cu.usbmodem1124203 115200 -o log.txt
Enable local echo of sent data, used for devices which do not echo back characters they receive:
commy /dev/cu.usbmodem1124203 115200 -e
It tells you how to quit.
Commy does what I use GNU screen
for, but it's better in two important respects. First, it is slightly smaller; and secondly it has the words "ctrl-a and quit" inscribed in large friendly letters on its cover.
Usage: commy [ARGS] [OPTIONS]
Args:
port serial port file
speed baudrate
Options:
-v, --version Version
-l, --list List available serial ports
-e, --echo Enable local echo
-o, --output=<output> Log to file
-p, --parity=<parity> Parity
values: { none, even, odd, mark, space }
-w, --wordsize=<wordsize> wordsize
values: { five, six, seven, eight }
-s, --stop=<stop> stop
values: { one, two }
-f, --flow=<flow> flow
values: { none, software, hardware }
-h, --help Print this help and exit
If no serial device is available, commy can connect to a Linux serial terminal inside docker. From here, any standard linux terminal software can be used.
cd linux-test
./lincommy.sh
This will build commy, then build a docker container and start it. Inside the container socat
will create a virtual serial port and bind it to bash
. commy will then connect to the virtual serial port. Quitting commy will close down the docker container.