micropython-stubber 1.20.4__py3-none-any.whl → 1.20.6__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- {micropython_stubber-1.20.4.dist-info → micropython_stubber-1.20.6.dist-info}/LICENSE +30 -30
- {micropython_stubber-1.20.4.dist-info → micropython_stubber-1.20.6.dist-info}/METADATA +4 -4
- micropython_stubber-1.20.6.dist-info/RECORD +159 -0
- mpflash/README.md +184 -184
- mpflash/libusb_flash.ipynb +203 -203
- mpflash/mpflash/add_firmware.py +98 -98
- mpflash/mpflash/ask_input.py +236 -226
- mpflash/mpflash/bootloader/__init__.py +37 -0
- mpflash/mpflash/bootloader/manual.py +102 -0
- mpflash/mpflash/bootloader/micropython.py +10 -0
- mpflash/mpflash/bootloader/touch1200.py +45 -0
- mpflash/mpflash/cli_download.py +129 -128
- mpflash/mpflash/cli_flash.py +219 -212
- mpflash/mpflash/cli_group.py +98 -92
- mpflash/mpflash/cli_list.py +81 -77
- mpflash/mpflash/cli_main.py +41 -38
- mpflash/mpflash/common.py +164 -151
- mpflash/mpflash/config.py +47 -31
- mpflash/mpflash/connected.py +74 -74
- mpflash/mpflash/download.py +360 -361
- mpflash/mpflash/downloaded.py +129 -129
- mpflash/mpflash/errors.py +9 -5
- mpflash/mpflash/flash.py +52 -69
- mpflash/mpflash/flash_esp.py +59 -59
- mpflash/mpflash/flash_stm32.py +24 -24
- mpflash/mpflash/flash_stm32_cube.py +111 -111
- mpflash/mpflash/flash_stm32_dfu.py +101 -101
- mpflash/mpflash/flash_uf2.py +67 -67
- mpflash/mpflash/flash_uf2_boardid.py +15 -15
- mpflash/mpflash/flash_uf2_linux.py +123 -123
- mpflash/mpflash/flash_uf2_macos.py +34 -37
- mpflash/mpflash/flash_uf2_windows.py +34 -34
- mpflash/mpflash/list.py +89 -89
- mpflash/mpflash/logger.py +41 -41
- mpflash/mpflash/mpboard_id/__init__.py +93 -93
- mpflash/mpflash/mpboard_id/add_boards.py +255 -255
- mpflash/mpflash/mpboard_id/board.py +37 -37
- mpflash/mpflash/mpboard_id/board_id.py +86 -86
- mpflash/mpflash/mpboard_id/store.py +43 -43
- mpflash/mpflash/mpremoteboard/__init__.py +221 -221
- mpflash/mpflash/mpremoteboard/mpy_fw_info.py +141 -141
- mpflash/mpflash/mpremoteboard/runner.py +140 -140
- mpflash/mpflash/uf2disk.py +12 -12
- mpflash/mpflash/vendor/basicgit.py +288 -288
- mpflash/mpflash/vendor/click_aliases.py +91 -0
- mpflash/mpflash/vendor/dfu.py +165 -165
- mpflash/mpflash/vendor/pydfu.py +605 -605
- mpflash/mpflash/vendor/readme.md +2 -2
- mpflash/mpflash/vendor/versions.py +119 -117
- mpflash/mpflash/worklist.py +170 -170
- mpflash/poetry.lock +1588 -1623
- mpflash/pyproject.toml +60 -60
- mpflash/stm32_udev_rules.md +62 -62
- stubber/__init__.py +3 -3
- stubber/basicgit.py +294 -288
- stubber/board/board_info.csv +193 -193
- stubber/board/boot.py +34 -34
- stubber/board/createstubs.py +986 -987
- stubber/board/createstubs_db.py +825 -826
- stubber/board/createstubs_db_min.py +331 -331
- stubber/board/createstubs_db_mpy.mpy +0 -0
- stubber/board/createstubs_lvgl.py +741 -741
- stubber/board/createstubs_lvgl_min.py +741 -741
- stubber/board/createstubs_mem.py +766 -767
- stubber/board/createstubs_mem_min.py +306 -306
- stubber/board/createstubs_mem_mpy.mpy +0 -0
- stubber/board/createstubs_min.py +294 -294
- stubber/board/createstubs_mpy.mpy +0 -0
- stubber/board/fw_info.py +141 -141
- stubber/board/info.py +183 -183
- stubber/board/main.py +19 -19
- stubber/board/modulelist.txt +247 -247
- stubber/board/pyrightconfig.json +34 -34
- stubber/bulk/mcu_stubber.py +454 -455
- stubber/codemod/_partials/__init__.py +48 -50
- stubber/codemod/_partials/db_main.py +147 -147
- stubber/codemod/_partials/lvgl_main.py +77 -77
- stubber/codemod/_partials/modules_reader.py +80 -80
- stubber/codemod/add_comment.py +53 -53
- stubber/codemod/add_method.py +65 -65
- stubber/codemod/board.py +317 -317
- stubber/codemod/enrich.py +145 -145
- stubber/codemod/merge_docstub.py +284 -284
- stubber/codemod/modify_list.py +54 -54
- stubber/codemod/utils.py +57 -57
- stubber/commands/build_cmd.py +94 -94
- stubber/commands/cli.py +51 -51
- stubber/commands/clone_cmd.py +66 -66
- stubber/commands/config_cmd.py +29 -29
- stubber/commands/enrich_folder_cmd.py +70 -70
- stubber/commands/get_core_cmd.py +69 -69
- stubber/commands/get_docstubs_cmd.py +87 -87
- stubber/commands/get_frozen_cmd.py +112 -112
- stubber/commands/get_mcu_cmd.py +56 -56
- stubber/commands/merge_cmd.py +66 -66
- stubber/commands/publish_cmd.py +119 -119
- stubber/commands/stub_cmd.py +30 -30
- stubber/commands/switch_cmd.py +54 -54
- stubber/commands/variants_cmd.py +48 -48
- stubber/cst_transformer.py +178 -178
- stubber/data/board_info.csv +193 -193
- stubber/data/board_info.json +1729 -1729
- stubber/data/micropython_tags.csv +15 -15
- stubber/data/requirements-core-micropython.txt +38 -38
- stubber/data/requirements-core-pycopy.txt +39 -39
- stubber/downloader.py +36 -36
- stubber/freeze/common.py +68 -68
- stubber/freeze/freeze_folder.py +69 -69
- stubber/freeze/freeze_manifest_2.py +113 -113
- stubber/freeze/get_frozen.py +127 -127
- stubber/get_cpython.py +101 -101
- stubber/get_lobo.py +59 -59
- stubber/minify.py +418 -418
- stubber/publish/bump.py +86 -86
- stubber/publish/candidates.py +262 -283
- stubber/publish/database.py +18 -18
- stubber/publish/defaults.py +45 -45
- stubber/publish/enums.py +24 -30
- stubber/publish/helpers.py +29 -29
- stubber/publish/merge_docstubs.py +130 -130
- stubber/publish/missing_class_methods.py +49 -49
- stubber/publish/package.py +146 -177
- stubber/publish/pathnames.py +51 -51
- stubber/publish/publish.py +120 -121
- stubber/publish/pypi.py +38 -38
- stubber/publish/stubpackage.py +1029 -1029
- stubber/rst/__init__.py +9 -9
- stubber/rst/classsort.py +77 -77
- stubber/rst/lookup.py +530 -530
- stubber/rst/output_dict.py +401 -401
- stubber/rst/reader.py +822 -823
- stubber/rst/report_return.py +69 -69
- stubber/rst/rst_utils.py +540 -540
- stubber/stubber.py +38 -38
- stubber/stubs_from_docs.py +90 -90
- stubber/tools/manifestfile.py +610 -610
- stubber/tools/readme.md +5 -5
- stubber/update_fallback.py +117 -117
- stubber/update_module_list.py +123 -125
- stubber/utils/__init__.py +5 -5
- stubber/utils/config.py +127 -127
- stubber/utils/makeversionhdr.py +54 -54
- stubber/utils/manifest.py +92 -92
- stubber/utils/post.py +79 -79
- stubber/utils/repos.py +157 -154
- stubber/utils/stubmaker.py +139 -139
- stubber/utils/typed_config_toml.py +77 -77
- stubber/utils/versions.py +128 -120
- stubber/variants.py +106 -106
- micropython_stubber-1.20.4.dist-info/RECORD +0 -154
- {micropython_stubber-1.20.4.dist-info → micropython_stubber-1.20.6.dist-info}/WHEEL +0 -0
- {micropython_stubber-1.20.4.dist-info → micropython_stubber-1.20.6.dist-info}/entry_points.txt +0 -0
@@ -1,112 +1,112 @@
|
|
1
|
-
"""Get the frozen stubs for MicroPython."""
|
2
|
-
|
3
|
-
##########################################################################################
|
4
|
-
# get-frozen
|
5
|
-
##########################################################################################
|
6
|
-
from pathlib import Path
|
7
|
-
from typing import List, Optional
|
8
|
-
|
9
|
-
import click
|
10
|
-
from loguru import logger as log
|
11
|
-
|
12
|
-
import stubber.utils as utils
|
13
|
-
from stubber.codemod.enrich import enrich_folder
|
14
|
-
from stubber.freeze.get_frozen import freeze_any
|
15
|
-
from stubber.utils.config import CONFIG
|
16
|
-
from stubber.utils.repos import fetch_repos
|
17
|
-
|
18
|
-
from .cli import stubber_cli
|
19
|
-
|
20
|
-
##########################################################################################
|
21
|
-
|
22
|
-
|
23
|
-
@stubber_cli.command(name="get-frozen")
|
24
|
-
@click.option(
|
25
|
-
"--stub-folder",
|
26
|
-
"-stubs",
|
27
|
-
default=CONFIG.stub_path.as_posix(),
|
28
|
-
type=click.Path(exists=True, file_okay=False, dir_okay=True),
|
29
|
-
show_default=True,
|
30
|
-
)
|
31
|
-
@click.option(
|
32
|
-
"--version",
|
33
|
-
"--Version",
|
34
|
-
"-V",
|
35
|
-
"version",
|
36
|
-
default="",
|
37
|
-
# default=[CONFIG.stable_version],
|
38
|
-
show_default=True,
|
39
|
-
help="The version of MicroPython to get the frozen modules for. Use 'preview' to get the latest version from the micropython repo",
|
40
|
-
)
|
41
|
-
@click.option(
|
42
|
-
"--stubgen/--no-stubgen",
|
43
|
-
default=True,
|
44
|
-
help="Run stubgen to create .pyi files for the (new) frozen modules",
|
45
|
-
show_default=True,
|
46
|
-
)
|
47
|
-
@click.option(
|
48
|
-
"--black/--no-black",
|
49
|
-
default=True,
|
50
|
-
help="Run black on the (new) frozen modules",
|
51
|
-
show_default=True,
|
52
|
-
)
|
53
|
-
def cli_get_frozen(
|
54
|
-
stub_folder: Optional[str] = None,
|
55
|
-
# path: str = config.repo_path.as_posix(),
|
56
|
-
version: str = "",
|
57
|
-
stubgen: bool = True,
|
58
|
-
black: bool = True,
|
59
|
-
autoflake: bool = True,
|
60
|
-
):
|
61
|
-
"""
|
62
|
-
Get the frozen stubs for MicroPython.
|
63
|
-
|
64
|
-
Get the frozen modules for the checked out version of MicroPython
|
65
|
-
"""
|
66
|
-
# default parameter values
|
67
|
-
stub_folder = stub_folder or CONFIG.stub_path.as_posix()
|
68
|
-
# FIXME: Stub_folder is not used
|
69
|
-
|
70
|
-
stub_paths: List[Path] = []
|
71
|
-
|
72
|
-
if version:
|
73
|
-
version = utils.clean_version(version, drop_v=False)
|
74
|
-
result = fetch_repos(version, CONFIG.mpy_path, CONFIG.mpy_lib_path)
|
75
|
-
if not result:
|
76
|
-
log.error(
|
77
|
-
"Failed to fetch repos for version: {} for micropython folder: {} and micropython-lib folder: {}".format(
|
78
|
-
version, CONFIG.mpy_path.as_posix(), CONFIG.mpy_lib_path.as_posix()
|
79
|
-
)
|
80
|
-
)
|
81
|
-
return -1
|
82
|
-
# folder/{family}-{version[_preview]}-frozen
|
83
|
-
family = "micropython"
|
84
|
-
# get the current checked out version
|
85
|
-
version = utils.checkedout_version(CONFIG.mpy_path)
|
86
|
-
log.info("MicroPython version : {}".format(version))
|
87
|
-
|
88
|
-
stub_path = freeze_any(version=version, mpy_path=CONFIG.mpy_path, mpy_lib_path=CONFIG.mpy_lib_path)
|
89
|
-
stub_paths.append(stub_path)
|
90
|
-
# Also enrich the frozen modules from the doc stubs if available
|
91
|
-
|
92
|
-
# first create .pyi files so they can be enriched
|
93
|
-
utils.do_post_processing(stub_paths, stubgen=stubgen, black=False, autoflake=False)
|
94
|
-
family = "micropython"
|
95
|
-
_version = utils.clean_version(version, drop_v=False, flat=True)
|
96
|
-
docstubs_path = Path(CONFIG.stub_path) / f"{family}-{_version}-docstubs"
|
97
|
-
if docstubs_path.exists():
|
98
|
-
log.info(f"Enriching {str(stub_path)} with {docstubs_path}")
|
99
|
-
if merged := enrich_folder(
|
100
|
-
stub_path,
|
101
|
-
docstubs_path,
|
102
|
-
show_diff=False,
|
103
|
-
write_back=True,
|
104
|
-
require_docstub=False,
|
105
|
-
):
|
106
|
-
log.info(f"Enriched {merged} frozen modules from docstubs")
|
107
|
-
else:
|
108
|
-
log.info(f"No docstubs found at {docstubs_path}")
|
109
|
-
|
110
|
-
log.info("::group:: start post processing of retrieved stubs")
|
111
|
-
utils.do_post_processing(stub_paths, stubgen=False, black=black, autoflake=autoflake)
|
112
|
-
log.info("::group:: Done")
|
1
|
+
"""Get the frozen stubs for MicroPython."""
|
2
|
+
|
3
|
+
##########################################################################################
|
4
|
+
# get-frozen
|
5
|
+
##########################################################################################
|
6
|
+
from pathlib import Path
|
7
|
+
from typing import List, Optional
|
8
|
+
|
9
|
+
import click
|
10
|
+
from loguru import logger as log
|
11
|
+
|
12
|
+
import stubber.utils as utils
|
13
|
+
from stubber.codemod.enrich import enrich_folder
|
14
|
+
from stubber.freeze.get_frozen import freeze_any
|
15
|
+
from stubber.utils.config import CONFIG
|
16
|
+
from stubber.utils.repos import fetch_repos
|
17
|
+
|
18
|
+
from .cli import stubber_cli
|
19
|
+
|
20
|
+
##########################################################################################
|
21
|
+
|
22
|
+
|
23
|
+
@stubber_cli.command(name="get-frozen")
|
24
|
+
@click.option(
|
25
|
+
"--stub-folder",
|
26
|
+
"-stubs",
|
27
|
+
default=CONFIG.stub_path.as_posix(),
|
28
|
+
type=click.Path(exists=True, file_okay=False, dir_okay=True),
|
29
|
+
show_default=True,
|
30
|
+
)
|
31
|
+
@click.option(
|
32
|
+
"--version",
|
33
|
+
"--Version",
|
34
|
+
"-V",
|
35
|
+
"version",
|
36
|
+
default="",
|
37
|
+
# default=[CONFIG.stable_version],
|
38
|
+
show_default=True,
|
39
|
+
help="The version of MicroPython to get the frozen modules for. Use 'preview' to get the latest version from the micropython repo",
|
40
|
+
)
|
41
|
+
@click.option(
|
42
|
+
"--stubgen/--no-stubgen",
|
43
|
+
default=True,
|
44
|
+
help="Run stubgen to create .pyi files for the (new) frozen modules",
|
45
|
+
show_default=True,
|
46
|
+
)
|
47
|
+
@click.option(
|
48
|
+
"--black/--no-black",
|
49
|
+
default=True,
|
50
|
+
help="Run black on the (new) frozen modules",
|
51
|
+
show_default=True,
|
52
|
+
)
|
53
|
+
def cli_get_frozen(
|
54
|
+
stub_folder: Optional[str] = None,
|
55
|
+
# path: str = config.repo_path.as_posix(),
|
56
|
+
version: str = "",
|
57
|
+
stubgen: bool = True,
|
58
|
+
black: bool = True,
|
59
|
+
autoflake: bool = True,
|
60
|
+
):
|
61
|
+
"""
|
62
|
+
Get the frozen stubs for MicroPython.
|
63
|
+
|
64
|
+
Get the frozen modules for the checked out version of MicroPython
|
65
|
+
"""
|
66
|
+
# default parameter values
|
67
|
+
stub_folder = stub_folder or CONFIG.stub_path.as_posix()
|
68
|
+
# FIXME: Stub_folder is not used
|
69
|
+
|
70
|
+
stub_paths: List[Path] = []
|
71
|
+
|
72
|
+
if version:
|
73
|
+
version = utils.clean_version(version, drop_v=False)
|
74
|
+
result = fetch_repos(version, CONFIG.mpy_path, CONFIG.mpy_lib_path)
|
75
|
+
if not result:
|
76
|
+
log.error(
|
77
|
+
"Failed to fetch repos for version: {} for micropython folder: {} and micropython-lib folder: {}".format(
|
78
|
+
version, CONFIG.mpy_path.as_posix(), CONFIG.mpy_lib_path.as_posix()
|
79
|
+
)
|
80
|
+
)
|
81
|
+
return -1
|
82
|
+
# folder/{family}-{version[_preview]}-frozen
|
83
|
+
family = "micropython"
|
84
|
+
# get the current checked out version
|
85
|
+
version = utils.checkedout_version(CONFIG.mpy_path)
|
86
|
+
log.info("MicroPython version : {}".format(version))
|
87
|
+
|
88
|
+
stub_path = freeze_any(version=version, mpy_path=CONFIG.mpy_path, mpy_lib_path=CONFIG.mpy_lib_path)
|
89
|
+
stub_paths.append(stub_path)
|
90
|
+
# Also enrich the frozen modules from the doc stubs if available
|
91
|
+
|
92
|
+
# first create .pyi files so they can be enriched
|
93
|
+
utils.do_post_processing(stub_paths, stubgen=stubgen, black=False, autoflake=False)
|
94
|
+
family = "micropython"
|
95
|
+
_version = utils.clean_version(version, drop_v=False, flat=True)
|
96
|
+
docstubs_path = Path(CONFIG.stub_path) / f"{family}-{_version}-docstubs"
|
97
|
+
if docstubs_path.exists():
|
98
|
+
log.info(f"Enriching {str(stub_path)} with {docstubs_path}")
|
99
|
+
if merged := enrich_folder(
|
100
|
+
stub_path,
|
101
|
+
docstubs_path,
|
102
|
+
show_diff=False,
|
103
|
+
write_back=True,
|
104
|
+
require_docstub=False,
|
105
|
+
):
|
106
|
+
log.info(f"Enriched {merged} frozen modules from docstubs")
|
107
|
+
else:
|
108
|
+
log.info(f"No docstubs found at {docstubs_path}")
|
109
|
+
|
110
|
+
log.info("::group:: start post processing of retrieved stubs")
|
111
|
+
utils.do_post_processing(stub_paths, stubgen=False, black=black, autoflake=autoflake)
|
112
|
+
log.info("::group:: Done")
|
stubber/commands/get_mcu_cmd.py
CHANGED
@@ -1,56 +1,56 @@
|
|
1
|
-
"""Deploy and run createstubs on one or more microcontrollers."""
|
2
|
-
|
3
|
-
##########################################################################################
|
4
|
-
# stub
|
5
|
-
##########################################################################################
|
6
|
-
|
7
|
-
|
8
|
-
import click
|
9
|
-
from loguru import logger as log
|
10
|
-
|
11
|
-
from stubber.bulk.mcu_stubber import stub_connected_mcus
|
12
|
-
from stubber.utils.config import CONFIG
|
13
|
-
|
14
|
-
from .cli import stubber_cli
|
15
|
-
|
16
|
-
##########################################################################################
|
17
|
-
# log = logging.getLogger("stubber")
|
18
|
-
#########################################################################################
|
19
|
-
|
20
|
-
|
21
|
-
@stubber_cli.command(name="get-mcu-stubs")
|
22
|
-
@click.option(
|
23
|
-
"--variant",
|
24
|
-
"-v",
|
25
|
-
type=click.Choice(["Full", "Mem", "DB"], case_sensitive=False),
|
26
|
-
default="DB",
|
27
|
-
show_default=True,
|
28
|
-
help="Variant of createstubs to run",
|
29
|
-
)
|
30
|
-
@click.option(
|
31
|
-
"--format",
|
32
|
-
"-f",
|
33
|
-
type=click.Choice(["py", "mpy"], case_sensitive=False),
|
34
|
-
default="mpy",
|
35
|
-
show_default=True,
|
36
|
-
help="Python source or pre-compiled.",
|
37
|
-
)
|
38
|
-
@click.option("--debug/--no-debug", default=False, show_default=True, help="Debug mode.")
|
39
|
-
@click.option(
|
40
|
-
"--reset/--no-reset", default=False, show_default=True, help="Reset the board before running createstubs."
|
41
|
-
)
|
42
|
-
@click.option(
|
43
|
-
"--github/--local",
|
44
|
-
default=True,
|
45
|
-
show_default=True,
|
46
|
-
help="where to install the board files from. local is intended for development.",
|
47
|
-
)
|
48
|
-
def cli_create_mcu_stubs(variant: str, format: str, debug: bool, reset: bool, github: bool) -> int:
|
49
|
-
"""Run createstubs on one or more MCUs, and add the stubs to the micropython-stub repo."""
|
50
|
-
# check if all repos have been cloned
|
51
|
-
for repo in CONFIG.repos:
|
52
|
-
if not repo.exists():
|
53
|
-
log.error(f"Repo {repo} not found, use 'stubber clone --add-stubs' to clone the repos.")
|
54
|
-
exit(1)
|
55
|
-
|
56
|
-
exit(stub_connected_mcus(variant=variant, format=format, debug=debug))
|
1
|
+
"""Deploy and run createstubs on one or more microcontrollers."""
|
2
|
+
|
3
|
+
##########################################################################################
|
4
|
+
# stub
|
5
|
+
##########################################################################################
|
6
|
+
|
7
|
+
|
8
|
+
import click
|
9
|
+
from loguru import logger as log
|
10
|
+
|
11
|
+
from stubber.bulk.mcu_stubber import stub_connected_mcus
|
12
|
+
from stubber.utils.config import CONFIG
|
13
|
+
|
14
|
+
from .cli import stubber_cli
|
15
|
+
|
16
|
+
##########################################################################################
|
17
|
+
# log = logging.getLogger("stubber")
|
18
|
+
#########################################################################################
|
19
|
+
|
20
|
+
|
21
|
+
@stubber_cli.command(name="get-mcu-stubs")
|
22
|
+
@click.option(
|
23
|
+
"--variant",
|
24
|
+
"-v",
|
25
|
+
type=click.Choice(["Full", "Mem", "DB"], case_sensitive=False),
|
26
|
+
default="DB",
|
27
|
+
show_default=True,
|
28
|
+
help="Variant of createstubs to run",
|
29
|
+
)
|
30
|
+
@click.option(
|
31
|
+
"--format",
|
32
|
+
"-f",
|
33
|
+
type=click.Choice(["py", "mpy"], case_sensitive=False),
|
34
|
+
default="mpy",
|
35
|
+
show_default=True,
|
36
|
+
help="Python source or pre-compiled.",
|
37
|
+
)
|
38
|
+
@click.option("--debug/--no-debug", default=False, show_default=True, help="Debug mode.")
|
39
|
+
@click.option(
|
40
|
+
"--reset/--no-reset", default=False, show_default=True, help="Reset the board before running createstubs."
|
41
|
+
)
|
42
|
+
@click.option(
|
43
|
+
"--github/--local",
|
44
|
+
default=True,
|
45
|
+
show_default=True,
|
46
|
+
help="where to install the board files from. local is intended for development.",
|
47
|
+
)
|
48
|
+
def cli_create_mcu_stubs(variant: str, format: str, debug: bool, reset: bool, github: bool) -> int:
|
49
|
+
"""Run createstubs on one or more MCUs, and add the stubs to the micropython-stub repo."""
|
50
|
+
# check if all repos have been cloned
|
51
|
+
for repo in CONFIG.repos:
|
52
|
+
if not repo.exists():
|
53
|
+
log.error(f"Repo {repo} not found, use 'stubber clone --add-stubs' to clone the repos.")
|
54
|
+
exit(1)
|
55
|
+
|
56
|
+
exit(stub_connected_mcus(variant=variant, format=format, debug=debug))
|
stubber/commands/merge_cmd.py
CHANGED
@@ -1,66 +1,66 @@
|
|
1
|
-
"""
|
2
|
-
enrich machinestubs with docstubs
|
3
|
-
"""
|
4
|
-
from typing import List, Union
|
5
|
-
|
6
|
-
import click
|
7
|
-
from loguru import logger as log
|
8
|
-
|
9
|
-
from stubber.publish.merge_docstubs import merge_all_docstubs
|
10
|
-
from stubber.publish.package import GENERIC_L
|
11
|
-
from stubber.utils.config import CONFIG
|
12
|
-
|
13
|
-
from .cli import stubber_cli
|
14
|
-
|
15
|
-
|
16
|
-
@stubber_cli.command(name="merge")
|
17
|
-
@click.option("--family", default="micropython", type=str, show_default=True)
|
18
|
-
@click.option(
|
19
|
-
"--version",
|
20
|
-
"--Version",
|
21
|
-
"-V",
|
22
|
-
"versions",
|
23
|
-
multiple=True,
|
24
|
-
default=["all"],
|
25
|
-
# type=click.Choice(ALL_VERSIONS),
|
26
|
-
show_default=True,
|
27
|
-
help="'latest', 'auto', or one or more versions",
|
28
|
-
)
|
29
|
-
@click.option(
|
30
|
-
"--port",
|
31
|
-
"-p",
|
32
|
-
"ports",
|
33
|
-
multiple=True,
|
34
|
-
default=["all"],
|
35
|
-
show_default=True,
|
36
|
-
help="multiple: ",
|
37
|
-
)
|
38
|
-
@click.option(
|
39
|
-
"--board",
|
40
|
-
"-b",
|
41
|
-
"boards",
|
42
|
-
multiple=True,
|
43
|
-
default=[GENERIC_L], # or "all" ?
|
44
|
-
show_default=True,
|
45
|
-
help="multiple: ",
|
46
|
-
)
|
47
|
-
def cli_merge_docstubs(
|
48
|
-
versions: Union[str, List[str]],
|
49
|
-
boards: Union[str, List[str]],
|
50
|
-
ports: Union[str, List[str]],
|
51
|
-
family: str,
|
52
|
-
):
|
53
|
-
"""
|
54
|
-
Enrich the stubs in stub_folder with the docstubs in docstubs_folder.
|
55
|
-
"""
|
56
|
-
if isinstance(ports, tuple):
|
57
|
-
ports = list(ports)
|
58
|
-
if isinstance(boards, tuple):
|
59
|
-
boards = list(boards)
|
60
|
-
if isinstance(versions, tuple):
|
61
|
-
versions = list(versions)
|
62
|
-
# single version should be a string
|
63
|
-
log.info(f"Merge docstubs for {family} {versions}")
|
64
|
-
_ = merge_all_docstubs(
|
65
|
-
versions=versions, family=family, boards=boards, ports=ports, mpy_path=CONFIG.mpy_path
|
66
|
-
)
|
1
|
+
"""
|
2
|
+
enrich machinestubs with docstubs
|
3
|
+
"""
|
4
|
+
from typing import List, Union
|
5
|
+
|
6
|
+
import click
|
7
|
+
from loguru import logger as log
|
8
|
+
|
9
|
+
from stubber.publish.merge_docstubs import merge_all_docstubs
|
10
|
+
from stubber.publish.package import GENERIC_L
|
11
|
+
from stubber.utils.config import CONFIG
|
12
|
+
|
13
|
+
from .cli import stubber_cli
|
14
|
+
|
15
|
+
|
16
|
+
@stubber_cli.command(name="merge")
|
17
|
+
@click.option("--family", default="micropython", type=str, show_default=True)
|
18
|
+
@click.option(
|
19
|
+
"--version",
|
20
|
+
"--Version",
|
21
|
+
"-V",
|
22
|
+
"versions",
|
23
|
+
multiple=True,
|
24
|
+
default=["all"],
|
25
|
+
# type=click.Choice(ALL_VERSIONS),
|
26
|
+
show_default=True,
|
27
|
+
help="'latest', 'auto', or one or more versions",
|
28
|
+
)
|
29
|
+
@click.option(
|
30
|
+
"--port",
|
31
|
+
"-p",
|
32
|
+
"ports",
|
33
|
+
multiple=True,
|
34
|
+
default=["all"],
|
35
|
+
show_default=True,
|
36
|
+
help="multiple: ",
|
37
|
+
)
|
38
|
+
@click.option(
|
39
|
+
"--board",
|
40
|
+
"-b",
|
41
|
+
"boards",
|
42
|
+
multiple=True,
|
43
|
+
default=[GENERIC_L], # or "all" ?
|
44
|
+
show_default=True,
|
45
|
+
help="multiple: ",
|
46
|
+
)
|
47
|
+
def cli_merge_docstubs(
|
48
|
+
versions: Union[str, List[str]],
|
49
|
+
boards: Union[str, List[str]],
|
50
|
+
ports: Union[str, List[str]],
|
51
|
+
family: str,
|
52
|
+
):
|
53
|
+
"""
|
54
|
+
Enrich the stubs in stub_folder with the docstubs in docstubs_folder.
|
55
|
+
"""
|
56
|
+
if isinstance(ports, tuple):
|
57
|
+
ports = list(ports)
|
58
|
+
if isinstance(boards, tuple):
|
59
|
+
boards = list(boards)
|
60
|
+
if isinstance(versions, tuple):
|
61
|
+
versions = list(versions)
|
62
|
+
# single version should be a string
|
63
|
+
log.info(f"Merge docstubs for {family} {versions}")
|
64
|
+
_ = merge_all_docstubs(
|
65
|
+
versions=versions, family=family, boards=boards, ports=ports, mpy_path=CONFIG.mpy_path
|
66
|
+
)
|