mirror of
https://github.com/DarkFlippers/unleashed-firmware
synced 2025-01-18 15:53:53 +00:00
e680cf59b6
* added some extra timeouts, fixed duration of units run command and minor logging changes. No list_ports yet needed * increased timeouts * make pvs happy --------- Co-authored-by: doomwastaken <k.volkov@flipperdevices.com> Co-authored-by: SG <who.just.the.doctor@gmail.com>
61 lines
1.5 KiB
Python
Executable file
61 lines
1.5 KiB
Python
Executable file
#!/usr/bin/env python3
|
|
import logging
|
|
import os
|
|
import sys
|
|
import time
|
|
|
|
|
|
def flp_serial_by_name(flp_name):
|
|
if sys.platform == "darwin": # MacOS
|
|
flp_serial = "/dev/cu.usbmodemflip_" + flp_name + "1"
|
|
logging.info(f"Darwin, looking for {flp_serial}")
|
|
elif sys.platform == "linux": # Linux
|
|
flp_serial = (
|
|
"/dev/serial/by-id/usb-Flipper_Devices_Inc._Flipper_"
|
|
+ flp_name
|
|
+ "_flip_"
|
|
+ flp_name
|
|
+ "-if00"
|
|
)
|
|
logging.info(f"linux, looking for {flp_serial}")
|
|
|
|
if os.path.exists(flp_serial):
|
|
return flp_serial
|
|
else:
|
|
logging.info(f"Couldn't find {logging.info} on this attempt.")
|
|
if os.path.exists(flp_name):
|
|
return flp_name
|
|
else:
|
|
return ""
|
|
|
|
|
|
UPDATE_TIMEOUT = 60 * 4 # 4 minutes
|
|
|
|
|
|
def main():
|
|
flipper_name = sys.argv[1]
|
|
elapsed = 0
|
|
flipper = flp_serial_by_name(flipper_name)
|
|
logging.basicConfig(
|
|
format="%(asctime)s %(levelname)-8s %(message)s",
|
|
level=logging.INFO,
|
|
datefmt="%Y-%m-%d %H:%M:%S",
|
|
)
|
|
logging.info(f"Waiting for Flipper {flipper_name} to be ready...")
|
|
|
|
while flipper == "" and elapsed < UPDATE_TIMEOUT:
|
|
elapsed += 1
|
|
time.sleep(1)
|
|
flipper = flp_serial_by_name(flipper_name)
|
|
|
|
if flipper == "":
|
|
logging.error("Flipper not found!")
|
|
sys.exit(1)
|
|
|
|
logging.info(f"Found Flipper at {flipper}")
|
|
|
|
sys.exit(0)
|
|
|
|
|
|
if __name__ == "__main__":
|
|
main()
|