micropython-stubber 1.23.1__py3-none-any.whl → 1.23.2__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.23.1.dist-info → micropython_stubber-1.23.2.dist-info}/LICENSE +30 -30
- {micropython_stubber-1.23.1.dist-info → micropython_stubber-1.23.2.dist-info}/METADATA +32 -15
- micropython_stubber-1.23.2.dist-info/RECORD +158 -0
- micropython_stubber-1.23.2.dist-info/entry_points.txt +5 -0
- mpflash/README.md +220 -194
- mpflash/libusb_flash.ipynb +203 -203
- mpflash/mpflash/add_firmware.py +98 -98
- mpflash/mpflash/ask_input.py +236 -236
- mpflash/mpflash/basicgit.py +284 -284
- mpflash/mpflash/bootloader/__init__.py +2 -2
- mpflash/mpflash/bootloader/activate.py +60 -60
- mpflash/mpflash/bootloader/detect.py +82 -82
- mpflash/mpflash/bootloader/manual.py +101 -101
- mpflash/mpflash/bootloader/micropython.py +12 -12
- mpflash/mpflash/bootloader/touch1200.py +36 -36
- mpflash/mpflash/cli_download.py +129 -129
- mpflash/mpflash/cli_flash.py +224 -219
- mpflash/mpflash/cli_group.py +111 -111
- mpflash/mpflash/cli_list.py +87 -81
- mpflash/mpflash/cli_main.py +39 -39
- mpflash/mpflash/common.py +210 -165
- mpflash/mpflash/config.py +44 -44
- mpflash/mpflash/connected.py +96 -78
- mpflash/mpflash/download.py +364 -364
- mpflash/mpflash/downloaded.py +130 -130
- mpflash/mpflash/errors.py +9 -9
- mpflash/mpflash/flash/__init__.py +55 -55
- mpflash/mpflash/flash/esp.py +59 -59
- mpflash/mpflash/flash/stm32.py +19 -19
- mpflash/mpflash/flash/stm32_dfu.py +104 -104
- mpflash/mpflash/flash/uf2/__init__.py +88 -88
- mpflash/mpflash/flash/uf2/boardid.py +15 -15
- mpflash/mpflash/flash/uf2/linux.py +136 -130
- mpflash/mpflash/flash/uf2/macos.py +42 -42
- mpflash/mpflash/flash/uf2/uf2disk.py +12 -12
- mpflash/mpflash/flash/uf2/windows.py +43 -43
- mpflash/mpflash/flash/worklist.py +170 -170
- mpflash/mpflash/list.py +106 -99
- mpflash/mpflash/logger.py +41 -41
- mpflash/mpflash/mpboard_id/__init__.py +93 -93
- mpflash/mpflash/mpboard_id/add_boards.py +251 -251
- 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 +266 -222
- mpflash/mpflash/mpremoteboard/mpy_fw_info.py +141 -141
- mpflash/mpflash/mpremoteboard/runner.py +140 -140
- 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/versions.py +135 -135
- mpflash/poetry.lock +1599 -1599
- mpflash/pyproject.toml +65 -65
- mpflash/stm32_udev_rules.md +62 -62
- stubber/__init__.py +3 -3
- stubber/board/board_info.csv +193 -193
- stubber/board/boot.py +34 -34
- stubber/board/createstubs.py +1004 -986
- stubber/board/createstubs_db.py +826 -825
- stubber/board/createstubs_db_min.py +332 -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 +767 -766
- stubber/board/createstubs_mem_min.py +307 -306
- stubber/board/createstubs_mem_mpy.mpy +0 -0
- stubber/board/createstubs_min.py +295 -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 +437 -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 +151 -145
- stubber/codemod/merge_docstub.py +284 -284
- stubber/codemod/modify_list.py +54 -54
- stubber/codemod/utils.py +56 -56
- stubber/commands/build_cmd.py +94 -94
- stubber/commands/cli.py +49 -55
- stubber/commands/clone_cmd.py +78 -78
- stubber/commands/config_cmd.py +29 -29
- stubber/commands/enrich_folder_cmd.py +71 -71
- stubber/commands/get_core_cmd.py +71 -71
- stubber/commands/get_docstubs_cmd.py +92 -89
- stubber/commands/get_frozen_cmd.py +117 -114
- stubber/commands/get_mcu_cmd.py +102 -61
- stubber/commands/merge_cmd.py +66 -66
- stubber/commands/publish_cmd.py +118 -118
- stubber/commands/stub_cmd.py +31 -31
- stubber/commands/switch_cmd.py +62 -62
- 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 +37 -36
- stubber/freeze/common.py +72 -68
- stubber/freeze/freeze_folder.py +69 -69
- stubber/freeze/freeze_manifest_2.py +126 -113
- stubber/freeze/get_frozen.py +131 -127
- stubber/get_cpython.py +112 -101
- stubber/get_lobo.py +59 -59
- stubber/minify.py +423 -419
- stubber/publish/bump.py +86 -86
- stubber/publish/candidates.py +275 -256
- stubber/publish/database.py +18 -18
- stubber/publish/defaults.py +40 -40
- stubber/publish/enums.py +24 -24
- stubber/publish/helpers.py +29 -29
- stubber/publish/merge_docstubs.py +136 -130
- stubber/publish/missing_class_methods.py +51 -49
- stubber/publish/package.py +150 -146
- stubber/publish/pathnames.py +51 -51
- stubber/publish/publish.py +120 -120
- stubber/publish/pypi.py +42 -38
- stubber/publish/stubpackage.py +1055 -1027
- stubber/rst/__init__.py +9 -9
- stubber/rst/classsort.py +78 -77
- stubber/rst/lookup.py +533 -530
- stubber/rst/output_dict.py +401 -401
- stubber/rst/reader.py +814 -814
- stubber/rst/report_return.py +77 -69
- stubber/rst/rst_utils.py +541 -540
- stubber/stubber.py +38 -38
- stubber/stubs_from_docs.py +90 -90
- stubber/tools/manifestfile.py +654 -654
- stubber/tools/readme.md +6 -6
- stubber/update_fallback.py +117 -117
- stubber/update_module_list.py +123 -123
- stubber/utils/__init__.py +6 -6
- stubber/utils/config.py +137 -125
- stubber/utils/makeversionhdr.py +54 -54
- stubber/utils/manifest.py +90 -90
- stubber/utils/post.py +80 -79
- stubber/utils/repos.py +156 -150
- stubber/utils/stubmaker.py +139 -139
- stubber/utils/typed_config_toml.py +80 -77
- stubber/variants.py +106 -106
- micropython_stubber-1.23.1.dist-info/RECORD +0 -159
- micropython_stubber-1.23.1.dist-info/entry_points.txt +0 -3
- mpflash/basicgit.py +0 -288
- {micropython_stubber-1.23.1.dist-info → micropython_stubber-1.23.2.dist-info}/WHEEL +0 -0
stubber/commands/clone_cmd.py
CHANGED
@@ -1,78 +1,78 @@
|
|
1
|
-
"""Clone/fetch the micropython repos locally."""
|
2
|
-
|
3
|
-
##########################################################################################
|
4
|
-
# clone
|
5
|
-
##########################################################################################
|
6
|
-
import os
|
7
|
-
from pathlib import Path
|
8
|
-
from typing import List, Tuple, Union
|
9
|
-
|
10
|
-
import rich_click as click
|
11
|
-
import mpflash.basicgit as git
|
12
|
-
from
|
13
|
-
from stubber.utils.config import CONFIG
|
14
|
-
|
15
|
-
from .cli import stubber_cli
|
16
|
-
|
17
|
-
##########################################################################################
|
18
|
-
# log = logging.getLogger("stubber")
|
19
|
-
#########################################################################################
|
20
|
-
|
21
|
-
|
22
|
-
@stubber_cli.command(name="clone")
|
23
|
-
@click.option(
|
24
|
-
"--path",
|
25
|
-
"-p",
|
26
|
-
default=CONFIG.repo_path.as_posix(),
|
27
|
-
type=click.Path(file_okay=False, dir_okay=True),
|
28
|
-
)
|
29
|
-
@click.option(
|
30
|
-
"--stubs/--no-stubs",
|
31
|
-
"--add-stubs/--no-stubs",
|
32
|
-
"stubs",
|
33
|
-
default=False,
|
34
|
-
is_flag=True,
|
35
|
-
help="Also clone the micropython-stubs repo",
|
36
|
-
)
|
37
|
-
def cli_clone(path: Union[str, Path], stubs: bool = False):
|
38
|
-
"""
|
39
|
-
Clone/fetch the micropython repos locally.
|
40
|
-
|
41
|
-
The local repos are used to generate frozen-stubs and doc-stubs.
|
42
|
-
"""
|
43
|
-
dest_path = Path(path)
|
44
|
-
if not dest_path.exists():
|
45
|
-
os.mkdir(dest_path)
|
46
|
-
if dest_path == CONFIG.repo_path:
|
47
|
-
# same as default
|
48
|
-
mpy_path = CONFIG.mpy_path
|
49
|
-
mpy_lib_path = CONFIG.mpy_lib_path
|
50
|
-
mpy_stubs_path = CONFIG.mpy_stubs_path
|
51
|
-
else:
|
52
|
-
# repos are relative to provided path
|
53
|
-
mpy_path = dest_path / "micropython"
|
54
|
-
mpy_lib_path = dest_path / "micropython-lib"
|
55
|
-
mpy_stubs_path = dest_path / "micropython-stubs"
|
56
|
-
|
57
|
-
repos: List[Tuple[Path, str, str]] = [
|
58
|
-
(mpy_path, "https://github.com/micropython/micropython.git", "master"),
|
59
|
-
(mpy_lib_path, "https://github.com/micropython/micropython-lib.git", "master"),
|
60
|
-
]
|
61
|
-
if stubs:
|
62
|
-
repos.append((mpy_stubs_path, "https://github.com/josverl/micropython-stubs.git", "main"))
|
63
|
-
|
64
|
-
for _path, remote, branch in repos:
|
65
|
-
log.info(f"Cloning {remote} branch {branch} to {_path}")
|
66
|
-
if not (_path / ".git").exists():
|
67
|
-
log.debug(f"Cloning {_path.name}...")
|
68
|
-
git.clone(remote_repo=remote, path=_path)
|
69
|
-
else:
|
70
|
-
log.debug(f"{_path.name} already exists, fetching...")
|
71
|
-
git.fetch(
|
72
|
-
_path,
|
73
|
-
)
|
74
|
-
git.pull(_path, branch=branch) # DEFAULT
|
75
|
-
|
76
|
-
log.info(f"{mpy_path} {git.get_local_tag(mpy_path)}")
|
77
|
-
log.info(f"{mpy_lib_path} {git.get_local_tag(mpy_lib_path)}")
|
78
|
-
# click.echo(f"{mpy_stubs_path} {git.get_tag(mpy_stubs_path)}")
|
1
|
+
"""Clone/fetch the micropython repos locally."""
|
2
|
+
|
3
|
+
##########################################################################################
|
4
|
+
# clone
|
5
|
+
##########################################################################################
|
6
|
+
import os
|
7
|
+
from pathlib import Path
|
8
|
+
from typing import List, Tuple, Union
|
9
|
+
|
10
|
+
import rich_click as click
|
11
|
+
import mpflash.basicgit as git
|
12
|
+
from mpflash.logger import log
|
13
|
+
from stubber.utils.config import CONFIG
|
14
|
+
|
15
|
+
from .cli import stubber_cli
|
16
|
+
|
17
|
+
##########################################################################################
|
18
|
+
# log = logging.getLogger("stubber")
|
19
|
+
#########################################################################################
|
20
|
+
|
21
|
+
|
22
|
+
@stubber_cli.command(name="clone")
|
23
|
+
@click.option(
|
24
|
+
"--path",
|
25
|
+
"-p",
|
26
|
+
default=CONFIG.repo_path.as_posix(),
|
27
|
+
type=click.Path(file_okay=False, dir_okay=True),
|
28
|
+
)
|
29
|
+
@click.option(
|
30
|
+
"--stubs/--no-stubs",
|
31
|
+
"--add-stubs/--no-stubs",
|
32
|
+
"stubs",
|
33
|
+
default=False,
|
34
|
+
is_flag=True,
|
35
|
+
help="Also clone the micropython-stubs repo",
|
36
|
+
)
|
37
|
+
def cli_clone(path: Union[str, Path], stubs: bool = False):
|
38
|
+
"""
|
39
|
+
Clone/fetch the micropython repos locally.
|
40
|
+
|
41
|
+
The local repos are used to generate frozen-stubs and doc-stubs.
|
42
|
+
"""
|
43
|
+
dest_path = Path(path)
|
44
|
+
if not dest_path.exists():
|
45
|
+
os.mkdir(dest_path)
|
46
|
+
if dest_path == CONFIG.repo_path:
|
47
|
+
# same as default
|
48
|
+
mpy_path = CONFIG.mpy_path
|
49
|
+
mpy_lib_path = CONFIG.mpy_lib_path
|
50
|
+
mpy_stubs_path = CONFIG.mpy_stubs_path
|
51
|
+
else:
|
52
|
+
# repos are relative to provided path
|
53
|
+
mpy_path = dest_path / "micropython"
|
54
|
+
mpy_lib_path = dest_path / "micropython-lib"
|
55
|
+
mpy_stubs_path = dest_path / "micropython-stubs"
|
56
|
+
|
57
|
+
repos: List[Tuple[Path, str, str]] = [
|
58
|
+
(mpy_path, "https://github.com/micropython/micropython.git", "master"),
|
59
|
+
(mpy_lib_path, "https://github.com/micropython/micropython-lib.git", "master"),
|
60
|
+
]
|
61
|
+
if stubs:
|
62
|
+
repos.append((mpy_stubs_path, "https://github.com/josverl/micropython-stubs.git", "main"))
|
63
|
+
|
64
|
+
for _path, remote, branch in repos:
|
65
|
+
log.info(f"Cloning {remote} branch {branch} to {_path}")
|
66
|
+
if not (_path / ".git").exists():
|
67
|
+
log.debug(f"Cloning {_path.name}...")
|
68
|
+
git.clone(remote_repo=remote, path=_path)
|
69
|
+
else:
|
70
|
+
log.debug(f"{_path.name} already exists, fetching...")
|
71
|
+
git.fetch(
|
72
|
+
_path,
|
73
|
+
)
|
74
|
+
git.pull(_path, branch=branch) # DEFAULT
|
75
|
+
|
76
|
+
log.info(f"{mpy_path} {git.get_local_tag(mpy_path)}")
|
77
|
+
log.info(f"{mpy_lib_path} {git.get_local_tag(mpy_lib_path)}")
|
78
|
+
# click.echo(f"{mpy_stubs_path} {git.get_tag(mpy_stubs_path)}")
|
stubber/commands/config_cmd.py
CHANGED
@@ -1,29 +1,29 @@
|
|
1
|
-
"""Show the current configuration"""
|
2
|
-
|
3
|
-
# pragma: no cover
|
4
|
-
|
5
|
-
from
|
6
|
-
|
7
|
-
from stubber.utils.config import CONFIG
|
8
|
-
|
9
|
-
from .cli import stubber_cli
|
10
|
-
|
11
|
-
|
12
|
-
@stubber_cli.command(name="show-config")
|
13
|
-
def cli_config():
|
14
|
-
"""
|
15
|
-
Show the current configuration
|
16
|
-
"""
|
17
|
-
try:
|
18
|
-
# todo: sources[1] is depedent on the order the providers are added in
|
19
|
-
log.info(f"config file {CONFIG._provider._config_sources[1].filename}") # type: ignore
|
20
|
-
except Exception:
|
21
|
-
pass
|
22
|
-
log.info(f"CONFIG.repo_path {CONFIG.repo_path}")
|
23
|
-
log.info(f"CONFIG.mpy_path {CONFIG.mpy_path}")
|
24
|
-
log.info(f"CONFIG.mpy_lib_path {CONFIG.mpy_lib_path}")
|
25
|
-
log.info(f"CONFIG.mpy_stubs_path {CONFIG.mpy_stubs_path}")
|
26
|
-
|
27
|
-
log.info(f"CONFIG.stub_path {CONFIG.stub_path}")
|
28
|
-
log.info(f"CONFIG.publish_path {CONFIG.publish_path}")
|
29
|
-
log.info(f"CONFIG.template_path {CONFIG.template_path}")
|
1
|
+
"""Show the current configuration"""
|
2
|
+
|
3
|
+
# pragma: no cover
|
4
|
+
|
5
|
+
from mpflash.logger import log
|
6
|
+
|
7
|
+
from stubber.utils.config import CONFIG
|
8
|
+
|
9
|
+
from .cli import stubber_cli
|
10
|
+
|
11
|
+
|
12
|
+
@stubber_cli.command(name="show-config")
|
13
|
+
def cli_config():
|
14
|
+
"""
|
15
|
+
Show the current configuration
|
16
|
+
"""
|
17
|
+
try:
|
18
|
+
# todo: sources[1] is depedent on the order the providers are added in
|
19
|
+
log.info(f"config file {CONFIG._provider._config_sources[1].filename}") # type: ignore
|
20
|
+
except Exception:
|
21
|
+
pass
|
22
|
+
log.info(f"CONFIG.repo_path {CONFIG.repo_path}")
|
23
|
+
log.info(f"CONFIG.mpy_path {CONFIG.mpy_path}")
|
24
|
+
log.info(f"CONFIG.mpy_lib_path {CONFIG.mpy_lib_path}")
|
25
|
+
log.info(f"CONFIG.mpy_stubs_path {CONFIG.mpy_stubs_path}")
|
26
|
+
|
27
|
+
log.info(f"CONFIG.stub_path {CONFIG.stub_path}")
|
28
|
+
log.info(f"CONFIG.publish_path {CONFIG.publish_path}")
|
29
|
+
log.info(f"CONFIG.template_path {CONFIG.template_path}")
|
@@ -1,71 +1,71 @@
|
|
1
|
-
"""
|
2
|
-
enrich machinestubs with docstubs
|
3
|
-
"""
|
4
|
-
|
5
|
-
from pathlib import Path
|
6
|
-
from typing import Union
|
7
|
-
|
8
|
-
import rich_click as click
|
9
|
-
from
|
10
|
-
|
11
|
-
from stubber.codemod.enrich import enrich_folder
|
12
|
-
from stubber.utils.config import CONFIG
|
13
|
-
|
14
|
-
from .cli import stubber_cli
|
15
|
-
|
16
|
-
|
17
|
-
@stubber_cli.command(name="enrich")
|
18
|
-
@click.option(
|
19
|
-
"--stubs",
|
20
|
-
"-s",
|
21
|
-
"stubs_folder",
|
22
|
-
default=CONFIG.stub_path.as_posix(),
|
23
|
-
type=click.Path(exists=True, file_okay=True, dir_okay=True),
|
24
|
-
help="File or folder containing the MCU stubs to be updated",
|
25
|
-
show_default=True,
|
26
|
-
)
|
27
|
-
@click.option(
|
28
|
-
"--docstubs",
|
29
|
-
"-ds",
|
30
|
-
"docstubs_folder",
|
31
|
-
default=CONFIG.stub_path.as_posix(),
|
32
|
-
type=click.Path(exists=True, file_okay=True, dir_okay=True),
|
33
|
-
help="File or folder containing the docstubs to be applied",
|
34
|
-
show_default=True,
|
35
|
-
)
|
36
|
-
@click.option("--diff", default=False, help="Show diff", show_default=True, is_flag=True)
|
37
|
-
@click.option(
|
38
|
-
"--dry-run",
|
39
|
-
default=False,
|
40
|
-
help="Dry run does not write the files back",
|
41
|
-
show_default=True,
|
42
|
-
is_flag=True,
|
43
|
-
)
|
44
|
-
@click.option(
|
45
|
-
"--package-name",
|
46
|
-
"-p",
|
47
|
-
"package_name",
|
48
|
-
default="",
|
49
|
-
help="Package name to be enriched (Optional)",
|
50
|
-
show_default=True,
|
51
|
-
)
|
52
|
-
def cli_enrich_folder(
|
53
|
-
stubs_folder: Union[str, Path],
|
54
|
-
docstubs_folder: Union[str, Path],
|
55
|
-
diff: bool = False,
|
56
|
-
dry_run: bool = False,
|
57
|
-
package_name: str = "",
|
58
|
-
):
|
59
|
-
"""
|
60
|
-
Enrich the stubs in stub_folder with the docstubs in docstubs_folder.
|
61
|
-
"""
|
62
|
-
write_back = not dry_run
|
63
|
-
log.info(f"Enriching {stubs_folder} with {docstubs_folder}")
|
64
|
-
_ = enrich_folder(
|
65
|
-
Path(stubs_folder),
|
66
|
-
Path(docstubs_folder),
|
67
|
-
show_diff=diff,
|
68
|
-
write_back=write_back,
|
69
|
-
require_docstub=False,
|
70
|
-
package_name=package_name,
|
71
|
-
)
|
1
|
+
"""
|
2
|
+
enrich machinestubs with docstubs
|
3
|
+
"""
|
4
|
+
|
5
|
+
from pathlib import Path
|
6
|
+
from typing import Union
|
7
|
+
|
8
|
+
import rich_click as click
|
9
|
+
from mpflash.logger import log
|
10
|
+
|
11
|
+
from stubber.codemod.enrich import enrich_folder
|
12
|
+
from stubber.utils.config import CONFIG
|
13
|
+
|
14
|
+
from .cli import stubber_cli
|
15
|
+
|
16
|
+
|
17
|
+
@stubber_cli.command(name="enrich")
|
18
|
+
@click.option(
|
19
|
+
"--stubs",
|
20
|
+
"-s",
|
21
|
+
"stubs_folder",
|
22
|
+
default=CONFIG.stub_path.as_posix(),
|
23
|
+
type=click.Path(exists=True, file_okay=True, dir_okay=True),
|
24
|
+
help="File or folder containing the MCU stubs to be updated",
|
25
|
+
show_default=True,
|
26
|
+
)
|
27
|
+
@click.option(
|
28
|
+
"--docstubs",
|
29
|
+
"-ds",
|
30
|
+
"docstubs_folder",
|
31
|
+
default=CONFIG.stub_path.as_posix(),
|
32
|
+
type=click.Path(exists=True, file_okay=True, dir_okay=True),
|
33
|
+
help="File or folder containing the docstubs to be applied",
|
34
|
+
show_default=True,
|
35
|
+
)
|
36
|
+
@click.option("--diff", default=False, help="Show diff", show_default=True, is_flag=True)
|
37
|
+
@click.option(
|
38
|
+
"--dry-run",
|
39
|
+
default=False,
|
40
|
+
help="Dry run does not write the files back",
|
41
|
+
show_default=True,
|
42
|
+
is_flag=True,
|
43
|
+
)
|
44
|
+
@click.option(
|
45
|
+
"--package-name",
|
46
|
+
"-p",
|
47
|
+
"package_name",
|
48
|
+
default="",
|
49
|
+
help="Package name to be enriched (Optional)",
|
50
|
+
show_default=True,
|
51
|
+
)
|
52
|
+
def cli_enrich_folder(
|
53
|
+
stubs_folder: Union[str, Path],
|
54
|
+
docstubs_folder: Union[str, Path],
|
55
|
+
diff: bool = False,
|
56
|
+
dry_run: bool = False,
|
57
|
+
package_name: str = "",
|
58
|
+
):
|
59
|
+
"""
|
60
|
+
Enrich the stubs in stub_folder with the docstubs in docstubs_folder.
|
61
|
+
"""
|
62
|
+
write_back = not dry_run
|
63
|
+
log.info(f"Enriching {stubs_folder} with {docstubs_folder}")
|
64
|
+
_ = enrich_folder(
|
65
|
+
Path(stubs_folder),
|
66
|
+
Path(docstubs_folder),
|
67
|
+
show_diff=diff,
|
68
|
+
write_back=write_back,
|
69
|
+
require_docstub=False,
|
70
|
+
package_name=package_name,
|
71
|
+
)
|
stubber/commands/get_core_cmd.py
CHANGED
@@ -1,71 +1,71 @@
|
|
1
|
-
"""Get core CPython stubs from PyPi."""
|
2
|
-
|
3
|
-
##########################################################################################
|
4
|
-
# core
|
5
|
-
##########################################################################################
|
6
|
-
|
7
|
-
from pathlib import Path
|
8
|
-
from typing import List
|
9
|
-
|
10
|
-
import rich_click as click
|
11
|
-
from
|
12
|
-
|
13
|
-
import stubber.get_cpython as get_cpython
|
14
|
-
import stubber.utils as utils
|
15
|
-
from stubber.utils.config import CONFIG
|
16
|
-
|
17
|
-
from .cli import stubber_cli
|
18
|
-
|
19
|
-
##########################################################################################
|
20
|
-
# log = logging.getLogger("stubber")
|
21
|
-
#########################################################################################
|
22
|
-
|
23
|
-
|
24
|
-
@stubber_cli.command(name="get-core")
|
25
|
-
@click.option(
|
26
|
-
"--stub-folder",
|
27
|
-
"-stubs",
|
28
|
-
default=CONFIG.stub_path.as_posix(),
|
29
|
-
type=click.Path(exists=True, file_okay=False, dir_okay=True),
|
30
|
-
show_default=True,
|
31
|
-
)
|
32
|
-
@click.option(
|
33
|
-
"--stubgen/--no-stubgen",
|
34
|
-
default=True,
|
35
|
-
help="run stubgen to create .pyi files for the (new) frozen modules",
|
36
|
-
show_default=True,
|
37
|
-
)
|
38
|
-
@click.option(
|
39
|
-
"--black/--no-black",
|
40
|
-
default=True,
|
41
|
-
help="Run black on the (new) frozen modules",
|
42
|
-
show_default=True,
|
43
|
-
)
|
44
|
-
def cli_get_core(
|
45
|
-
stub_folder: str = "",
|
46
|
-
# core_type: str = "pycopy", # pycopy or Micropython CPython stubs
|
47
|
-
stubgen: bool = True,
|
48
|
-
black: bool = True,
|
49
|
-
):
|
50
|
-
"""
|
51
|
-
Download core CPython stubs from PyPi.
|
52
|
-
|
53
|
-
Get the core (CPython compat) modules for both MicroPython and Pycopy.
|
54
|
-
"""
|
55
|
-
# default parameter values
|
56
|
-
stub_folder = stub_folder or CONFIG.stub_path.as_posix()
|
57
|
-
|
58
|
-
stub_paths: List[Path] = []
|
59
|
-
for core_type in ["pycopy", "micropython"]:
|
60
|
-
log.info(f"::group:: Get Cpython core :{core_type}")
|
61
|
-
req_filename = f"requirements-core-{core_type}.txt"
|
62
|
-
stub_path = Path(stub_folder) / f"cpython_core-{core_type}"
|
63
|
-
|
64
|
-
get_cpython.get_core(
|
65
|
-
stub_path=stub_path.as_posix(), requirements=req_filename, family=core_type
|
66
|
-
)
|
67
|
-
stub_paths.append(stub_path)
|
68
|
-
|
69
|
-
log.info("::group:: start post processing of retrieved stubs")
|
70
|
-
utils.do_post_processing(stub_paths, stubgen=stubgen, black=black, autoflake=True)
|
71
|
-
log.info("::group:: Done")
|
1
|
+
"""Get core CPython stubs from PyPi."""
|
2
|
+
|
3
|
+
##########################################################################################
|
4
|
+
# core
|
5
|
+
##########################################################################################
|
6
|
+
|
7
|
+
from pathlib import Path
|
8
|
+
from typing import List
|
9
|
+
|
10
|
+
import rich_click as click
|
11
|
+
from mpflash.logger import log
|
12
|
+
|
13
|
+
import stubber.get_cpython as get_cpython
|
14
|
+
import stubber.utils as utils
|
15
|
+
from stubber.utils.config import CONFIG
|
16
|
+
|
17
|
+
from .cli import stubber_cli
|
18
|
+
|
19
|
+
##########################################################################################
|
20
|
+
# log = logging.getLogger("stubber")
|
21
|
+
#########################################################################################
|
22
|
+
|
23
|
+
|
24
|
+
@stubber_cli.command(name="get-core")
|
25
|
+
@click.option(
|
26
|
+
"--stub-folder",
|
27
|
+
"-stubs",
|
28
|
+
default=CONFIG.stub_path.as_posix(),
|
29
|
+
type=click.Path(exists=True, file_okay=False, dir_okay=True),
|
30
|
+
show_default=True,
|
31
|
+
)
|
32
|
+
@click.option(
|
33
|
+
"--stubgen/--no-stubgen",
|
34
|
+
default=True,
|
35
|
+
help="run stubgen to create .pyi files for the (new) frozen modules",
|
36
|
+
show_default=True,
|
37
|
+
)
|
38
|
+
@click.option(
|
39
|
+
"--black/--no-black",
|
40
|
+
default=True,
|
41
|
+
help="Run black on the (new) frozen modules",
|
42
|
+
show_default=True,
|
43
|
+
)
|
44
|
+
def cli_get_core(
|
45
|
+
stub_folder: str = "",
|
46
|
+
# core_type: str = "pycopy", # pycopy or Micropython CPython stubs
|
47
|
+
stubgen: bool = True,
|
48
|
+
black: bool = True,
|
49
|
+
):
|
50
|
+
"""
|
51
|
+
Download core CPython stubs from PyPi.
|
52
|
+
|
53
|
+
Get the core (CPython compat) modules for both MicroPython and Pycopy.
|
54
|
+
"""
|
55
|
+
# default parameter values
|
56
|
+
stub_folder = stub_folder or CONFIG.stub_path.as_posix()
|
57
|
+
|
58
|
+
stub_paths: List[Path] = []
|
59
|
+
for core_type in ["pycopy", "micropython"]:
|
60
|
+
log.info(f"::group:: Get Cpython core :{core_type}")
|
61
|
+
req_filename = f"requirements-core-{core_type}.txt"
|
62
|
+
stub_path = Path(stub_folder) / f"cpython_core-{core_type}"
|
63
|
+
|
64
|
+
get_cpython.get_core(
|
65
|
+
stub_path=stub_path.as_posix(), requirements=req_filename, family=core_type
|
66
|
+
)
|
67
|
+
stub_paths.append(stub_path)
|
68
|
+
|
69
|
+
log.info("::group:: start post processing of retrieved stubs")
|
70
|
+
utils.do_post_processing(stub_paths, stubgen=stubgen, black=black, autoflake=True)
|
71
|
+
log.info("::group:: Done")
|