Module mbed_devices.mbed_devices
API for listing devices.
Expand source code
#
# Copyright (C) 2020 Arm Mbed. All rights reserved.
# SPDX-License-Identifier: Apache-2.0
#
"""API for listing devices."""
from mbed_targets.exceptions import MbedTargetsError
from mbed_devices._internal.detect_candidate_devices import detect_candidate_devices
from mbed_devices._internal.resolve_board import resolve_board
from mbed_devices._internal.exceptions import NoBoardForCandidate
from mbed_devices.device import ConnectedDevices
from mbed_devices.exceptions import DeviceLookupFailed
def get_connected_devices() -> ConnectedDevices:
"""Returns Mbed Devices connected to host computer.
Connected devices which have been identified as Mbed Boards and also connected devices which are potentially
Mbed Boards (but not could not be identified in the database) are returned.
Raises:
DeviceLookupFailed: If there is a problem with the process of identifying Mbed Boards from connected devices.
"""
connected_devices = ConnectedDevices()
for candidate_device in detect_candidate_devices():
try:
board = resolve_board(candidate_device)
except NoBoardForCandidate:
board = None
except MbedTargetsError as err:
raise DeviceLookupFailed("A problem occurred when looking up board data for connected devices.") from err
connected_devices.add_device(candidate_device, board)
return connected_devices
Functions
def get_connected_devices() -> ConnectedDevices
-
Returns Mbed Devices connected to host computer.
Connected devices which have been identified as Mbed Boards and also connected devices which are potentially Mbed Boards (but not could not be identified in the database) are returned.
Raises
DeviceLookupFailed
- If there is a problem with the process of identifying Mbed Boards from connected devices.
Expand source code
def get_connected_devices() -> ConnectedDevices: """Returns Mbed Devices connected to host computer. Connected devices which have been identified as Mbed Boards and also connected devices which are potentially Mbed Boards (but not could not be identified in the database) are returned. Raises: DeviceLookupFailed: If there is a problem with the process of identifying Mbed Boards from connected devices. """ connected_devices = ConnectedDevices() for candidate_device in detect_candidate_devices(): try: board = resolve_board(candidate_device) except NoBoardForCandidate: board = None except MbedTargetsError as err: raise DeviceLookupFailed("A problem occurred when looking up board data for connected devices.") from err connected_devices.add_device(candidate_device, board) return connected_devices