micropython-stubber 1.20.5__py3-none-any.whl → 1.23.0__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.5.dist-info → micropython_stubber-1.23.0.dist-info}/LICENSE +30 -30
- {micropython_stubber-1.20.5.dist-info → micropython_stubber-1.23.0.dist-info}/METADATA +1 -1
- micropython_stubber-1.23.0.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 -236
- mpflash/mpflash/bootloader/__init__.py +37 -36
- mpflash/mpflash/bootloader/manual.py +102 -102
- mpflash/mpflash/bootloader/micropython.py +10 -10
- mpflash/mpflash/bootloader/touch1200.py +45 -45
- mpflash/mpflash/cli_download.py +129 -129
- mpflash/mpflash/cli_flash.py +219 -219
- mpflash/mpflash/cli_group.py +98 -98
- mpflash/mpflash/cli_list.py +81 -81
- mpflash/mpflash/cli_main.py +41 -41
- mpflash/mpflash/common.py +164 -164
- mpflash/mpflash/config.py +43 -47
- mpflash/mpflash/connected.py +74 -74
- mpflash/mpflash/download.py +360 -360
- mpflash/mpflash/downloaded.py +130 -129
- mpflash/mpflash/errors.py +9 -9
- mpflash/mpflash/flash.py +55 -52
- mpflash/mpflash/flash_esp.py +59 -59
- mpflash/mpflash/flash_stm32.py +18 -24
- mpflash/mpflash/flash_stm32_cube.py +111 -111
- mpflash/mpflash/flash_stm32_dfu.py +104 -101
- mpflash/mpflash/flash_uf2.py +89 -67
- mpflash/mpflash/flash_uf2_boardid.py +15 -15
- mpflash/mpflash/flash_uf2_linux.py +129 -123
- mpflash/mpflash/flash_uf2_macos.py +37 -34
- mpflash/mpflash/flash_uf2_windows.py +38 -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 +226 -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 -91
- 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 +171 -170
- mpflash/poetry.lock +1588 -1588
- mpflash/pyproject.toml +64 -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 -986
- stubber/board/createstubs_db.py +825 -825
- 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 -766
- 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 -454
- stubber/codemod/_partials/__init__.py +48 -48
- 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 +55 -51
- stubber/commands/clone_cmd.py +77 -66
- stubber/commands/config_cmd.py +29 -29
- stubber/commands/enrich_folder_cmd.py +71 -70
- stubber/commands/get_core_cmd.py +71 -69
- stubber/commands/get_docstubs_cmd.py +89 -87
- stubber/commands/get_frozen_cmd.py +114 -112
- stubber/commands/get_mcu_cmd.py +61 -56
- stubber/commands/merge_cmd.py +67 -66
- stubber/commands/publish_cmd.py +119 -119
- stubber/commands/stub_cmd.py +31 -30
- stubber/commands/switch_cmd.py +62 -54
- stubber/commands/variants_cmd.py +49 -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 -262
- stubber/publish/database.py +18 -18
- stubber/publish/defaults.py +45 -45
- stubber/publish/enums.py +24 -24
- 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 -146
- stubber/publish/pathnames.py +51 -51
- stubber/publish/publish.py +120 -120
- 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 -822
- 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 +655 -610
- stubber/tools/readme.md +7 -6
- stubber/update_fallback.py +117 -117
- stubber/update_module_list.py +123 -123
- 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.5.dist-info/RECORD +0 -159
- {micropython_stubber-1.20.5.dist-info → micropython_stubber-1.23.0.dist-info}/WHEEL +0 -0
- {micropython_stubber-1.20.5.dist-info → micropython_stubber-1.23.0.dist-info}/entry_points.txt +0 -0
@@ -1,87 +1,89 @@
|
|
1
|
-
"""
|
2
|
-
get-docstubs
|
3
|
-
|
4
|
-
"""
|
5
|
-
|
6
|
-
from pathlib import Path
|
7
|
-
from typing import Optional
|
8
|
-
|
9
|
-
import click
|
10
|
-
from loguru import logger as log
|
11
|
-
|
12
|
-
import stubber.basicgit as git
|
13
|
-
import stubber.utils as utils
|
14
|
-
from stubber.stubs_from_docs import generate_from_rst
|
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
|
-
# log = logging.getLogger("stubber")
|
22
|
-
#########################################################################################
|
23
|
-
|
24
|
-
|
25
|
-
@stubber_cli.command(name="get-docstubs")
|
26
|
-
@click.option(
|
27
|
-
"--path",
|
28
|
-
"-p",
|
29
|
-
default=CONFIG.repo_path.as_posix(),
|
30
|
-
type=click.Path(file_okay=False, dir_okay=True),
|
31
|
-
show_default=True,
|
32
|
-
)
|
33
|
-
@click.option(
|
34
|
-
"--stub-path",
|
35
|
-
"--stub-folder",
|
36
|
-
"target",
|
37
|
-
default=CONFIG.stub_path.as_posix(),
|
38
|
-
type=click.Path(exists=True, file_okay=False, dir_okay=True),
|
39
|
-
help="Destination of the files to be generated.",
|
40
|
-
show_default=True,
|
41
|
-
)
|
42
|
-
# @click.option("--family", "-f", "basename", default="micropython", help="Micropython family.", show_default=True)
|
43
|
-
@click.option(
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
""
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
rst_path = Path(path)
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
|
76
|
-
|
77
|
-
|
78
|
-
|
79
|
-
|
80
|
-
|
81
|
-
|
82
|
-
|
83
|
-
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
log.info("
|
1
|
+
"""
|
2
|
+
get-docstubs
|
3
|
+
|
4
|
+
"""
|
5
|
+
|
6
|
+
from pathlib import Path
|
7
|
+
from typing import Optional
|
8
|
+
|
9
|
+
import rich_click as click
|
10
|
+
from loguru import logger as log
|
11
|
+
|
12
|
+
import stubber.basicgit as git
|
13
|
+
import stubber.utils as utils
|
14
|
+
from stubber.stubs_from_docs import generate_from_rst
|
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
|
+
# log = logging.getLogger("stubber")
|
22
|
+
#########################################################################################
|
23
|
+
|
24
|
+
|
25
|
+
@stubber_cli.command(name="get-docstubs")
|
26
|
+
@click.option(
|
27
|
+
"--path",
|
28
|
+
"-p",
|
29
|
+
default=CONFIG.repo_path.as_posix(),
|
30
|
+
type=click.Path(file_okay=False, dir_okay=True),
|
31
|
+
show_default=True,
|
32
|
+
)
|
33
|
+
@click.option(
|
34
|
+
"--stub-path",
|
35
|
+
"--stub-folder",
|
36
|
+
"target",
|
37
|
+
default=CONFIG.stub_path.as_posix(),
|
38
|
+
type=click.Path(exists=True, file_okay=False, dir_okay=True),
|
39
|
+
help="Destination of the files to be generated.",
|
40
|
+
show_default=True,
|
41
|
+
)
|
42
|
+
# @click.option("--family", "-f", "basename", default="micropython", help="Micropython family.", show_default=True)
|
43
|
+
@click.option(
|
44
|
+
"--version", "--tag", default="", type=str, help="Version number to use. [default: Git tag]"
|
45
|
+
)
|
46
|
+
@click.option("--black/--no-black", "-b/-nb", default=True, help="Run black", show_default=True)
|
47
|
+
@click.pass_context
|
48
|
+
def cli_docstubs(
|
49
|
+
ctx: click.Context,
|
50
|
+
path: Optional[str] = None,
|
51
|
+
target: Optional[str] = None,
|
52
|
+
black: bool = True,
|
53
|
+
basename: Optional[str] = None,
|
54
|
+
version: str = "",
|
55
|
+
):
|
56
|
+
"""
|
57
|
+
Build stubs from documentation.
|
58
|
+
|
59
|
+
Read the Micropython library documentation files and use them to build stubs that can be used for static typechecking.
|
60
|
+
"""
|
61
|
+
# default parameter values
|
62
|
+
path = path or CONFIG.repo_path.as_posix()
|
63
|
+
target = target or CONFIG.stub_path.as_posix()
|
64
|
+
basename = basename or "micropython"
|
65
|
+
|
66
|
+
if path == CONFIG.repo_path.as_posix():
|
67
|
+
# default
|
68
|
+
rst_path = CONFIG.mpy_path / "docs" / "library"
|
69
|
+
elif Path(path).stem == "micropython":
|
70
|
+
# path to a micropython repo
|
71
|
+
rst_path = Path(path) / "docs" / "library"
|
72
|
+
else:
|
73
|
+
rst_path = Path(path) # or specify full path
|
74
|
+
|
75
|
+
if version:
|
76
|
+
version = utils.clean_version(version, drop_v=False)
|
77
|
+
result = fetch_repos(version, CONFIG.mpy_path, CONFIG.mpy_lib_path)
|
78
|
+
if not result:
|
79
|
+
return -1
|
80
|
+
# get the current checked out version
|
81
|
+
version = utils.checkedout_version(CONFIG.mpy_path)
|
82
|
+
|
83
|
+
release = git.get_local_tag(rst_path.as_posix(), abbreviate=False) or ""
|
84
|
+
|
85
|
+
dst_path = Path(target) / f"{basename}-{utils.clean_version(version, flat=True)}-docstubs"
|
86
|
+
|
87
|
+
log.info(f"Get docstubs for MicroPython {utils.clean_version(version, drop_v=False)}")
|
88
|
+
generate_from_rst(rst_path, dst_path, version, release=release, suffix=".pyi", black=black)
|
89
|
+
log.info("::group:: Done")
|
@@ -1,112 +1,114 @@
|
|
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(
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
#
|
93
|
-
|
94
|
-
|
95
|
-
|
96
|
-
|
97
|
-
|
98
|
-
|
99
|
-
|
100
|
-
|
101
|
-
|
102
|
-
|
103
|
-
|
104
|
-
|
105
|
-
|
106
|
-
|
107
|
-
|
108
|
-
|
109
|
-
|
110
|
-
|
111
|
-
|
112
|
-
log.info("::group::
|
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 rich_click as 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(
|
89
|
+
version=version, mpy_path=CONFIG.mpy_path, mpy_lib_path=CONFIG.mpy_lib_path
|
90
|
+
)
|
91
|
+
stub_paths.append(stub_path)
|
92
|
+
# Also enrich the frozen modules from the doc stubs if available
|
93
|
+
|
94
|
+
# first create .pyi files so they can be enriched
|
95
|
+
utils.do_post_processing(stub_paths, stubgen=stubgen, black=False, autoflake=False)
|
96
|
+
family = "micropython"
|
97
|
+
_version = utils.clean_version(version, drop_v=False, flat=True)
|
98
|
+
docstubs_path = Path(CONFIG.stub_path) / f"{family}-{_version}-docstubs"
|
99
|
+
if docstubs_path.exists():
|
100
|
+
log.info(f"Enriching {str(stub_path)} with {docstubs_path}")
|
101
|
+
if merged := enrich_folder(
|
102
|
+
stub_path,
|
103
|
+
docstubs_path,
|
104
|
+
show_diff=False,
|
105
|
+
write_back=True,
|
106
|
+
require_docstub=False,
|
107
|
+
):
|
108
|
+
log.info(f"Enriched {merged} frozen modules from docstubs")
|
109
|
+
else:
|
110
|
+
log.info(f"No docstubs found at {docstubs_path}")
|
111
|
+
|
112
|
+
log.info("::group:: start post processing of retrieved stubs")
|
113
|
+
utils.do_post_processing(stub_paths, stubgen=False, black=black, autoflake=autoflake)
|
114
|
+
log.info("::group:: Done")
|
stubber/commands/get_mcu_cmd.py
CHANGED
@@ -1,56 +1,61 @@
|
|
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",
|
41
|
-
|
42
|
-
|
43
|
-
"
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
"
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
1
|
+
"""Deploy and run createstubs on one or more microcontrollers."""
|
2
|
+
|
3
|
+
##########################################################################################
|
4
|
+
# stub
|
5
|
+
##########################################################################################
|
6
|
+
|
7
|
+
|
8
|
+
import rich_click as 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",
|
41
|
+
default=False,
|
42
|
+
show_default=True,
|
43
|
+
help="Reset the board before running createstubs.",
|
44
|
+
)
|
45
|
+
@click.option(
|
46
|
+
"--github/--local",
|
47
|
+
default=True,
|
48
|
+
show_default=True,
|
49
|
+
help="where to install the board files from. local is intended for development.",
|
50
|
+
)
|
51
|
+
def cli_create_mcu_stubs(variant: str, format: str, debug: bool, reset: bool, github: bool) -> int:
|
52
|
+
"""Run createstubs on one or more MCUs, and add the stubs to the micropython-stub repo."""
|
53
|
+
# check if all repos have been cloned
|
54
|
+
for repo in CONFIG.repos:
|
55
|
+
if not repo.exists():
|
56
|
+
log.error(
|
57
|
+
f"Repo {repo} not found, use 'stubber clone --add-stubs' to clone the repos."
|
58
|
+
)
|
59
|
+
exit(1)
|
60
|
+
|
61
|
+
exit(stub_connected_mcus(variant=variant, format=format, debug=debug))
|
stubber/commands/merge_cmd.py
CHANGED
@@ -1,66 +1,67 @@
|
|
1
|
-
"""
|
2
|
-
enrich machinestubs with docstubs
|
3
|
-
"""
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
from stubber.publish.
|
11
|
-
from stubber.
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
@
|
18
|
-
@click.option(
|
19
|
-
|
20
|
-
"--
|
21
|
-
"
|
22
|
-
"
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
"
|
32
|
-
"
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
"
|
41
|
-
"
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
1
|
+
"""
|
2
|
+
enrich machinestubs with docstubs
|
3
|
+
"""
|
4
|
+
|
5
|
+
from typing import List, Union
|
6
|
+
|
7
|
+
import rich_click as click
|
8
|
+
from loguru import logger as log
|
9
|
+
|
10
|
+
from stubber.publish.merge_docstubs import merge_all_docstubs
|
11
|
+
from stubber.publish.package import GENERIC_L
|
12
|
+
from stubber.utils.config import CONFIG
|
13
|
+
|
14
|
+
from .cli import stubber_cli
|
15
|
+
|
16
|
+
|
17
|
+
@stubber_cli.command(name="merge")
|
18
|
+
@click.option("--family", default="micropython", type=str, show_default=True)
|
19
|
+
@click.option(
|
20
|
+
"--version",
|
21
|
+
"--Version",
|
22
|
+
"-V",
|
23
|
+
"versions",
|
24
|
+
multiple=True,
|
25
|
+
default=["all"],
|
26
|
+
# type=click.Choice(ALL_VERSIONS),
|
27
|
+
show_default=True,
|
28
|
+
help="'latest', 'auto', or one or more versions",
|
29
|
+
)
|
30
|
+
@click.option(
|
31
|
+
"--port",
|
32
|
+
"-p",
|
33
|
+
"ports",
|
34
|
+
multiple=True,
|
35
|
+
default=["all"],
|
36
|
+
show_default=True,
|
37
|
+
help="multiple: ",
|
38
|
+
)
|
39
|
+
@click.option(
|
40
|
+
"--board",
|
41
|
+
"-b",
|
42
|
+
"boards",
|
43
|
+
multiple=True,
|
44
|
+
default=[GENERIC_L], # or "all" ?
|
45
|
+
show_default=True,
|
46
|
+
help="multiple: ",
|
47
|
+
)
|
48
|
+
def cli_merge_docstubs(
|
49
|
+
versions: Union[str, List[str]],
|
50
|
+
boards: Union[str, List[str]],
|
51
|
+
ports: Union[str, List[str]],
|
52
|
+
family: str,
|
53
|
+
):
|
54
|
+
"""
|
55
|
+
Enrich the stubs in stub_folder with the docstubs in docstubs_folder.
|
56
|
+
"""
|
57
|
+
if isinstance(ports, tuple):
|
58
|
+
ports = list(ports)
|
59
|
+
if isinstance(boards, tuple):
|
60
|
+
boards = list(boards)
|
61
|
+
if isinstance(versions, tuple):
|
62
|
+
versions = list(versions)
|
63
|
+
# single version should be a string
|
64
|
+
log.info(f"Merge docstubs for {family} {versions}")
|
65
|
+
_ = merge_all_docstubs(
|
66
|
+
versions=versions, family=family, boards=boards, ports=ports, mpy_path=CONFIG.mpy_path
|
67
|
+
)
|