#! /usr/bin/env python3 import serial, time import subprocess from subprocess import call, Popen from argparse import ArgumentParser import re import sys def do_nsh_cmd(port, baudrate, cmd): databits = serial.EIGHTBITS stopbits = serial.STOPBITS_ONE parity = serial.PARITY_NONE ser = serial.Serial(port, baudrate, databits, parity, stopbits, timeout=0.1) # run command timeout_start = time.time() timeout = 10 # 10 seconds # clear ser.write("\n".encode("ascii")) ser.flush() ser.readline() success_cmd = "cmd succeeded!" serial_cmd = '{0}; echo "{1}"\n'.format(cmd, success_cmd) ser.write(serial_cmd.encode("ascii")) ser.flush() ser.readline() # TODO: require successful command echo # while True: # serial_cmd = '{0}; echo "{1}"\n'.format(cmd, success_cmd) # ser.write(serial_cmd.encode("ascii")) # ser.flush() # serial_line = ser.readline().decode("ascii", errors='ignore') # if cmd in serial_line: # break # else: # print(serial_line, end='') # if time.time() > timeout_start + timeout: # print("Error, timeout") # sys.exit(-1) # break # time.sleep(1) timeout_start = time.time() timeout = 30 # 30 seconds while True: serial_line = ser.readline().decode("ascii", errors='ignore') if success_cmd in serial_line: break else: if len(serial_line) > 0: print(serial_line, end='') if "nsh>" in serial_line: #sys.exit(-1) # error, command didn't complete successfully break # TODO: return error on failure elif "NuttShell (NSH)" in serial_line: #sys.exit(-1) # error, command didn't complete successfully break # TODO: return error on failure if len(serial_line) <= 0: ser.write("\n".encode("ascii")) ser.flush() if time.time() > timeout_start + timeout: print("Error, timeout") sys.exit(-1) ser.close() def main(): parser = ArgumentParser(description=__doc__) parser.add_argument('--device', "-d", nargs='?', default=None, help='', required=True) parser.add_argument("--baudrate", "-b", dest="baudrate", type=int, help="Mavlink port baud rate (default=57600)", default=57600) parser.add_argument("--cmd", "-c", dest="cmd", help="Command to run") args = parser.parse_args() do_nsh_cmd(args.device, args.baudrate, args.cmd) if __name__ == "__main__": main()