2014-07-27 22:29:32 +03:00
|
|
|
# Copyright (C) Ivan Kravets <me@ikravets.com>
|
|
|
|
# See LICENSE for details.
|
|
|
|
|
2014-08-09 23:13:29 +03:00
|
|
|
import sys
|
|
|
|
|
2014-12-03 20:16:50 +02:00
|
|
|
import click
|
2014-08-09 23:13:29 +03:00
|
|
|
from serial.tools import miniterm
|
2014-07-27 22:29:32 +03:00
|
|
|
|
|
|
|
from platformio.util import get_serialports
|
|
|
|
|
|
|
|
|
2014-12-03 20:16:50 +02:00
|
|
|
@click.group(short_help="List or Monitor Serial ports")
|
2014-07-27 22:29:32 +03:00
|
|
|
def cli():
|
2014-08-09 23:13:29 +03:00
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
|
|
@cli.command("list", short_help="List Serial ports")
|
|
|
|
def serialports_list():
|
2014-07-27 22:29:32 +03:00
|
|
|
|
|
|
|
for item in get_serialports():
|
2014-12-03 20:16:50 +02:00
|
|
|
click.secho(item['port'], fg="cyan")
|
|
|
|
click.echo("----------")
|
|
|
|
click.echo("Hardware ID: %s" % item['hwid'])
|
|
|
|
click.echo("Description: %s" % item['description'])
|
|
|
|
click.echo("")
|
2014-08-09 23:13:29 +03:00
|
|
|
|
|
|
|
|
|
|
|
@cli.command("monitor", short_help="Monitor Serial port")
|
2014-12-03 20:16:50 +02:00
|
|
|
@click.option("--port", "-p", help="Port, a number or a device name")
|
|
|
|
@click.option("--baud", "-b", type=int, default=9600,
|
|
|
|
help="Set baud rate, default=9600")
|
|
|
|
@click.option("--parity", default="N",
|
|
|
|
type=click.Choice(["N", "E", "O", "S", "M"]),
|
|
|
|
help="Set parity, default=N")
|
|
|
|
@click.option("--rtscts", is_flag=True,
|
|
|
|
help="Enable RTS/CTS flow control, default=Off")
|
|
|
|
@click.option("--xonxoff", is_flag=True,
|
|
|
|
help="Enable software flow control, default=Off")
|
|
|
|
@click.option("--rts", default="0", type=click.Choice(["0", "1"]),
|
|
|
|
help="Set initial RTS line state, default=0")
|
|
|
|
@click.option("--dtr", default="0", type=click.Choice(["0", "1"]),
|
|
|
|
help="Set initial DTR line state, default=0")
|
|
|
|
@click.option("--echo", is_flag=True,
|
|
|
|
help="Enable local echo, default=Off")
|
|
|
|
@click.option("--cr", is_flag=True,
|
|
|
|
help="Do not send CR+LF, send CR only, default=Off")
|
|
|
|
@click.option("--lf", is_flag=True,
|
|
|
|
help="Do not send CR+LF, send LF only, default=Off")
|
|
|
|
@click.option("--debug", "-d", count=True,
|
|
|
|
help="""Debug received data (escape non-printable chars)
|
2014-08-09 23:13:29 +03:00
|
|
|
# --debug can be given multiple times:
|
|
|
|
# 0: just print what is received
|
|
|
|
# 1: escape non-printable characters, do newlines as unusual
|
|
|
|
# 2: escape non-printable characters, newlines too
|
|
|
|
# 3: hex dump everything""")
|
2014-12-03 20:16:50 +02:00
|
|
|
@click.option("--exit-char", type=int, default=0x1d,
|
|
|
|
help="ASCII code of special character that is used to exit the "
|
|
|
|
"application, default=0x1d")
|
|
|
|
@click.option("--menu-char", type=int, default=0x14,
|
|
|
|
help="ASCII code of special character that is used to control "
|
|
|
|
"miniterm (menu), default=0x14")
|
|
|
|
@click.option("--quiet", is_flag=True,
|
|
|
|
help="Diagnostics: suppress non-error messages, default=Off")
|
2014-08-09 23:13:29 +03:00
|
|
|
def serialports_monitor(**_):
|
|
|
|
sys.argv = sys.argv[3:]
|
|
|
|
try:
|
|
|
|
miniterm.main()
|
|
|
|
except: # pylint: disable=W0702
|
|
|
|
pass
|