add alias boards and bus_device to the support matrix

add list with manual brand names for aliases
the new info in the support_matrix is used in build_board_info.py
This commit is contained in:
Neradoc 2021-03-29 18:14:37 +02:00
parent da16e4dce1
commit 12b0ee0a3e
2 changed files with 63 additions and 30 deletions

View File

@ -32,6 +32,39 @@ from concurrent.futures import ThreadPoolExecutor
SUPPORTED_PORTS = ['atmel-samd', 'cxd56', 'esp32s2', 'litex', 'mimxrt10xx', 'nrf', 'raspberrypi', 'stm'] SUPPORTED_PORTS = ['atmel-samd', 'cxd56', 'esp32s2', 'litex', 'mimxrt10xx', 'nrf', 'raspberrypi', 'stm']
aliases_by_board = {
"circuitplayground_express": [
"circuitplayground_express_4h",
"circuitplayground_express_digikey_pycon2019",
],
"pybadge": ["edgebadge"],
"pyportal": ["pyportal_pynt"],
"gemma_m0": ["gemma_m0_pycon2018"],
"pewpew10": ["pewpew13"],
}
aliases_brand_names = {
"circuitplayground_express_4h":
"Adafruit Circuit Playground Express 4-H",
"circuitplayground_express_digikey_pycon2019":
"Circuit Playground Express Digi-Key PyCon 2019",
"edgebadge":
"Adafruit EdgeBadge",
"pyportal_pynt":
"Adafruit PyPortal Pynt",
"gemma_m0_pycon2018":
"Adafruit Gemma M0 PyCon 2018",
"pewpew13":
"PewPew 13",
}
additional_modules = {
"fontio": "CIRCUITPY_DISPLAYIO",
"terminalio": "CIRCUITPY_DISPLAYIO",
# "socket": "CIRCUITPY_NETWORK",
"adafruit_bus_device": "CIRCUITPY_BUSDEVICE",
}
def get_circuitpython_root_dir(): def get_circuitpython_root_dir():
""" The path to the root './circuitpython' directory """ The path to the root './circuitpython' directory
""" """
@ -71,8 +104,11 @@ def build_module_map():
full_build = False full_build = False
for module in modules: for module in modules:
full_name = module full_name = module
search_name = module.lstrip("_") if module in additional_modules:
re_pattern = "CIRCUITPY_{}\s*\??=\s*(.+)".format(search_name.upper()) search_identifier = additional_modules[module]
else:
search_identifier = 'CIRCUITPY_'+module.lstrip("_").upper()
re_pattern = f"{re.escape(search_identifier)}\s*\??=\s*(.+)"
find_config = re.findall(re_pattern, configs) find_config = re.findall(re_pattern, configs)
if not find_config: if not find_config:
continue continue
@ -84,11 +120,12 @@ def build_module_map():
else: else:
default_val = "None" default_val = "None"
base[search_name] = { base[module] = {
"name": full_name, "name": full_name,
"full_build": str(full_build), "full_build": str(full_build),
"default_value": default_val, "default_value": default_val,
"excluded": {} "excluded": {},
"key": search_identifier,
} }
return base return base
@ -164,14 +201,28 @@ def support_matrix_by_board(use_branded_name=True):
board_modules = [] board_modules = []
for module in base: for module in base:
key = f'CIRCUITPY_{module.upper()}' key = base[module]['key']
if int(lookup_setting(settings, key, '0')): if int(lookup_setting(settings, key, '0')):
board_modules.append(base[module]['name']) board_modules.append(base[module]['name'])
board_modules.sort()
return (board_name, sorted(board_modules)) # generate alias boards too
board_matrix = [(board_name, board_modules)]
if entry.name in aliases_by_board:
for alias in aliases_by_board[entry.name]:
if use_branded_name:
if alias in aliases_brand_names:
alias = aliases_brand_names[alias]
else:
alias = alias.replace("_"," ").title()
board_matrix.append( (alias, board_modules) )
return board_matrix # this is now a list of (board,modules)
executor = ThreadPoolExecutor(max_workers=os.cpu_count()) executor = ThreadPoolExecutor(max_workers=os.cpu_count())
boards = dict(sorted(executor.map(support_matrix, all_ports_all_boards()))) mapped_exec = executor.map(support_matrix, all_ports_all_boards())
# flatmap with comprehensions
boards = dict(sorted([board for matrix in mapped_exec for board in matrix]))
#print(json.dumps(boards, indent=2)) #print(json.dumps(boards, indent=2))
return boards return boards

View File

@ -19,16 +19,8 @@ import shared_bindings_matrix
sys.path.append("adabot") sys.path.append("adabot")
import adabot.github_requests as github import adabot.github_requests as github
SUPPORTED_PORTS = [ from shared_bindings_matrix import SUPPORTED_PORTS
"atmel-samd", from shared_bindings_matrix import aliases_by_board
"cxd56",
"esp32s2",
"litex",
"mimxrt10xx",
"nrf",
"raspberrypi",
"stm",
]
BIN = ("bin",) BIN = ("bin",)
UF2 = ("uf2",) UF2 = ("uf2",)
@ -73,17 +65,6 @@ extension_by_board = {
"meowbit_v121": UF2, "meowbit_v121": UF2,
} }
aliases_by_board = {
"circuitplayground_express": [
"circuitplayground_express_4h",
"circuitplayground_express_digikey_pycon2019",
],
"pybadge": ["edgebadge"],
"pyportal": ["pyportal_pynt"],
"gemma_m0": ["gemma_m0_pycon2018"],
"pewpew10": ["pewpew13"],
}
language_allow_list = set([ language_allow_list = set([
"ID", "ID",
"de_DE", "de_DE",
@ -312,7 +293,7 @@ def generate_download_info():
new_version = { new_version = {
"stable": new_stable, "stable": new_stable,
"version": new_tag, "version": new_tag,
"modules": support_matrix[board_id], "modules": support_matrix[alias],
"languages": languages, "languages": languages,
"extensions": board_info["extensions"], "extensions": board_info["extensions"],
} }
@ -325,7 +306,8 @@ def generate_download_info():
create_pr(changes, current_info, git_info, user) create_pr(changes, current_info, git_info, user)
else: else:
print("No new release to update") print("No new release to update")
# print(create_json(current_info).decode("utf8")) if "DEBUG" in os.environ:
print(create_json(current_info).decode("utf8"))
if __name__ == "__main__": if __name__ == "__main__":