mbed-os/tools/python/mbed_tools/targets/boards.py

88 lines
2.7 KiB
Python

#
# Copyright (c) 2020-2021 Arm Limited and Contributors. All rights reserved.
# SPDX-License-Identifier: Apache-2.0
#
"""Interface to the Board Database."""
import json
from dataclasses import asdict
from collections.abc import Set
from typing import Iterator, Iterable, Any, Callable
from mbed_tools.targets._internal import board_database
from mbed_tools.targets.exceptions import UnknownBoard
from mbed_tools.targets.board import Board
class Boards(Set):
"""Interface to the Board Database.
Boards is initialised with an Iterable[Board]. The classmethods
can be used to construct Boards with data from either the online or offline database.
"""
@classmethod
def from_offline_database(cls) -> "Boards":
"""Initialise with the offline board database.
Raises:
BoardDatabaseError: Could not retrieve data from the board database.
"""
return cls(Board.from_offline_board_entry(b) for b in board_database.get_offline_board_data())
@classmethod
def from_online_database(cls) -> "Boards":
"""Initialise with the online board database.
Raises:
BoardDatabaseError: Could not retrieve data from the board database.
"""
return cls(Board.from_online_board_entry(b) for b in board_database.get_online_board_data())
def __init__(self, boards_data: Iterable["Board"]) -> None:
"""Initialise with a list of boards.
Args:
boards_data: iterable of board data from a board database source.
"""
self._boards_data = tuple(boards_data)
def __iter__(self) -> Iterator["Board"]:
"""Yield an Board on each iteration."""
for board in self._boards_data:
yield board
def __len__(self) -> int:
"""Return the number of boards."""
return len(self._boards_data)
def __contains__(self, board: object) -> Any:
"""Check if a board is in the collection of boards.
Args:
board: An instance of Board.
"""
if not isinstance(board, Board):
return False
return any(x == board for x in self)
def get_board(self, matching: Callable) -> Board:
"""Returns first Board for which `matching` returns True.
Args:
matching: A function which will be called for each board in database
Raises:
UnknownBoard: the given product code was not found in the board database.
"""
try:
return next(board for board in self if matching(board))
except StopIteration:
raise UnknownBoard()
def json_dump(self) -> str:
"""Return the contents of the board database as a json string."""
return json.dumps([asdict(b) for b in self], indent=4)