2022-06-30 19:06:12 +03:00
|
|
|
import serial.tools.list_ports as list_ports
|
|
|
|
|
2023-02-15 19:56:25 +03:00
|
|
|
|
2022-06-30 19:06:12 +03:00
|
|
|
# Returns a valid port or None, if it cannot be found
|
|
|
|
def resolve_port(logger, portname: str = "auto"):
|
|
|
|
if portname != "auto":
|
|
|
|
return portname
|
|
|
|
# Try guessing
|
|
|
|
flippers = list(list_ports.grep("flip"))
|
|
|
|
if len(flippers) == 1:
|
|
|
|
flipper = flippers[0]
|
|
|
|
logger.info(f"Using {flipper.serial_number} on {flipper.device}")
|
|
|
|
return flipper.device
|
|
|
|
elif len(flippers) == 0:
|
|
|
|
logger.error("Failed to find connected Flipper")
|
|
|
|
elif len(flippers) > 1:
|
|
|
|
logger.error("More than one Flipper is attached")
|
2022-09-24 14:30:19 +03:00
|
|
|
logger.error("Failed to guess which port to use")
|