Files
platformio-core/platformio/commands/remote.py

188 lines
5.5 KiB
Python
Raw Normal View History

2016-09-26 22:15:08 +03:00
# Copyright 2014-present PlatformIO <contact@platformio.org>
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
import sys
import threading
from os import getcwd
from os.path import isfile, join
from tempfile import mkdtemp
from time import sleep
import click
2016-10-05 21:43:28 +03:00
from platformio import exception, util
2016-09-26 22:15:08 +03:00
from platformio.commands.device import device_monitor as cmd_device_monitor
from platformio.pioplus import pioplus_call
# pylint: disable=unused-argument
@click.group("remote", short_help="PIO Remote")
2016-10-04 01:24:38 +03:00
@click.option("-a", "--agent", multiple=True)
def cli(**kwargs):
2016-09-26 22:15:08 +03:00
pass
2016-10-04 01:24:38 +03:00
@cli.group("agent", short_help="Start new agent or list active")
2016-09-26 22:15:08 +03:00
def remote_agent():
2016-10-04 01:24:38 +03:00
pass
@remote_agent.command("start", short_help="Start agent")
@click.option("-n", "--name")
@click.option("-s", "--share", multiple=True, metavar="E-MAIL")
2016-10-04 01:24:38 +03:00
def remote_agent_start(**kwargs):
pioplus_call(sys.argv[1:])
@remote_agent.command("list", short_help="List active agents")
def remote_agent_list():
2016-09-26 22:15:08 +03:00
pioplus_call(sys.argv[1:])
2016-11-02 18:24:52 +02:00
@cli.command("run", short_help="Process project environments remotely")
2016-09-26 22:15:08 +03:00
@click.option("-e", "--environment", multiple=True)
@click.option("-t", "--target", multiple=True)
@click.option("--upload-port")
@click.option(
"-d",
"--project-dir",
default=getcwd,
type=click.Path(
exists=True,
file_okay=True,
dir_okay=True,
writable=True,
resolve_path=True))
2016-11-02 18:24:52 +02:00
@click.option("--disable-auto-clean", is_flag=True)
@click.option("-r", "--build-remotely", is_flag=True)
2016-09-26 22:15:08 +03:00
@click.option("-s", "--silent", is_flag=True)
@click.option("-v", "--verbose", is_flag=True)
def remote_run(**kwargs):
pioplus_call(sys.argv[1:])
2016-11-02 18:24:52 +02:00
@cli.command("test", short_help="Remote Unit Testing")
@click.option("--environment", "-e", multiple=True, metavar="<environment>")
@click.option("--ignore", "-i", multiple=True, metavar="<pattern>")
@click.option("--upload-port")
@click.option("--test-port")
@click.option(
"-d",
"--project-dir",
default=getcwd,
type=click.Path(
exists=True,
file_okay=False,
dir_okay=True,
writable=True,
resolve_path=True))
@click.option("-r", "--build-remotely", is_flag=True)
@click.option("--without-building", is_flag=True)
@click.option("--without-uploading", is_flag=True)
@click.option("--verbose", "-v", is_flag=True)
def remote_test(**kwargs):
pioplus_call(sys.argv[1:])
@cli.group("device", short_help="Monitor remote device or list existing")
2016-09-26 22:15:08 +03:00
def remote_device():
pass
2016-11-02 18:24:52 +02:00
@remote_device.command("list", short_help="List remote devices")
2016-09-26 22:15:08 +03:00
@click.option("--json-output", is_flag=True)
def device_list(json_output):
pioplus_call(sys.argv[1:])
2016-11-02 18:24:52 +02:00
@remote_device.command("monitor", short_help="Monitor remote device")
2016-10-31 18:13:41 +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=None,
type=click.Choice(["0", "1"]),
help="Set initial RTS line state")
@click.option(
"--dtr",
default=None,
type=click.Choice(["0", "1"]),
help="Set initial DTR line state")
@click.option("--echo", is_flag=True, help="Enable local echo, default=Off")
@click.option(
"--encoding",
default="UTF-8",
help="Set the encoding for the serial port (e.g. hexlify, "
"Latin1, UTF-8), default: UTF-8")
@click.option("--filter", "-f", multiple=True, help="Add text transformation")
@click.option(
"--eol",
default="CRLF",
type=click.Choice(["CR", "LF", "CRLF"]),
help="End of line mode, default=CRLF")
@click.option(
"--raw", is_flag=True, help="Do not apply any encodings/transformations")
@click.option(
"--exit-char",
type=int,
default=3,
help="ASCII code of special character that is used to exit "
"the application, default=3 (Ctrl+C)")
@click.option(
"--menu-char",
type=int,
default=20,
help="ASCII code of special character that is used to "
"control miniterm (menu), default=20 (DEC)")
@click.option(
"--quiet",
is_flag=True,
help="Diagnostics: suppress non-error messages, default=Off")
@click.pass_context
def device_monitor(ctx, **kwargs):
2016-10-05 21:43:28 +03:00
def _tx_target(sock_dir):
try:
pioplus_call(sys.argv[1:] + ["--sock", sock_dir])
except exception.ReturnErrorCode:
pass
2016-09-26 22:15:08 +03:00
sock_dir = mkdtemp(suffix="pioplus")
sock_file = join(sock_dir, "sock")
try:
2016-10-05 21:43:28 +03:00
t = threading.Thread(target=_tx_target, args=(sock_dir, ))
2016-09-26 22:15:08 +03:00
t.start()
while t.is_alive() and not isfile(sock_file):
sleep(0.1)
if not t.is_alive():
return
kwargs['port'] = open(sock_file).read()
ctx.invoke(cmd_device_monitor, **kwargs)
2016-09-26 22:15:08 +03:00
t.join(2)
finally:
util.rmtree_(sock_dir)