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
stubber/commands/config_cmd.py
CHANGED
@@ -1,29 +1,29 @@
|
|
1
|
-
"""Show the current configuration"""
|
2
|
-
|
3
|
-
# pragma: no cover
|
4
|
-
|
5
|
-
from loguru import logger as 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
|
+
"""Show the current configuration"""
|
2
|
+
|
3
|
+
# pragma: no cover
|
4
|
+
|
5
|
+
from loguru import logger as 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,70 +1,70 @@
|
|
1
|
-
"""
|
2
|
-
enrich machinestubs with docstubs
|
3
|
-
"""
|
4
|
-
from pathlib import Path
|
5
|
-
from typing import Union
|
6
|
-
|
7
|
-
import click
|
8
|
-
from loguru import logger as log
|
9
|
-
|
10
|
-
from stubber.codemod.enrich import enrich_folder
|
11
|
-
from stubber.utils.config import CONFIG
|
12
|
-
|
13
|
-
from .cli import stubber_cli
|
14
|
-
|
15
|
-
|
16
|
-
@stubber_cli.command(name="enrich")
|
17
|
-
@click.option(
|
18
|
-
"--stubs",
|
19
|
-
"-s",
|
20
|
-
"stubs_folder",
|
21
|
-
default=CONFIG.stub_path.as_posix(),
|
22
|
-
type=click.Path(exists=True, file_okay=True, dir_okay=True),
|
23
|
-
help="File or folder containing the MCU stubs to be updated",
|
24
|
-
show_default=True,
|
25
|
-
)
|
26
|
-
@click.option(
|
27
|
-
"--docstubs",
|
28
|
-
"-ds",
|
29
|
-
"docstubs_folder",
|
30
|
-
default=CONFIG.stub_path.as_posix(),
|
31
|
-
type=click.Path(exists=True, file_okay=True, dir_okay=True),
|
32
|
-
help="File or folder containing the docstubs to be applied",
|
33
|
-
show_default=True,
|
34
|
-
)
|
35
|
-
@click.option("--diff", default=False, help="Show diff", show_default=True, is_flag=True)
|
36
|
-
@click.option(
|
37
|
-
"--dry-run",
|
38
|
-
default=False,
|
39
|
-
help="Dry run does not write the files back",
|
40
|
-
show_default=True,
|
41
|
-
is_flag=True,
|
42
|
-
)
|
43
|
-
@click.option(
|
44
|
-
"--package-name",
|
45
|
-
"-p",
|
46
|
-
"package_name",
|
47
|
-
default="",
|
48
|
-
help="Package name to be enriched (Optional)",
|
49
|
-
show_default=True,
|
50
|
-
)
|
51
|
-
def cli_enrich_folder(
|
52
|
-
stubs_folder: Union[str, Path],
|
53
|
-
docstubs_folder: Union[str, Path],
|
54
|
-
diff: bool = False,
|
55
|
-
dry_run: bool = False,
|
56
|
-
package_name: str = "",
|
57
|
-
):
|
58
|
-
"""
|
59
|
-
Enrich the stubs in stub_folder with the docstubs in docstubs_folder.
|
60
|
-
"""
|
61
|
-
write_back = not dry_run
|
62
|
-
log.info(f"Enriching {stubs_folder} with {docstubs_folder}")
|
63
|
-
_ = enrich_folder(
|
64
|
-
Path(stubs_folder),
|
65
|
-
Path(docstubs_folder),
|
66
|
-
show_diff=diff,
|
67
|
-
write_back=write_back,
|
68
|
-
require_docstub=False,
|
69
|
-
package_name=package_name,
|
70
|
-
)
|
1
|
+
"""
|
2
|
+
enrich machinestubs with docstubs
|
3
|
+
"""
|
4
|
+
from pathlib import Path
|
5
|
+
from typing import Union
|
6
|
+
|
7
|
+
import click
|
8
|
+
from loguru import logger as log
|
9
|
+
|
10
|
+
from stubber.codemod.enrich import enrich_folder
|
11
|
+
from stubber.utils.config import CONFIG
|
12
|
+
|
13
|
+
from .cli import stubber_cli
|
14
|
+
|
15
|
+
|
16
|
+
@stubber_cli.command(name="enrich")
|
17
|
+
@click.option(
|
18
|
+
"--stubs",
|
19
|
+
"-s",
|
20
|
+
"stubs_folder",
|
21
|
+
default=CONFIG.stub_path.as_posix(),
|
22
|
+
type=click.Path(exists=True, file_okay=True, dir_okay=True),
|
23
|
+
help="File or folder containing the MCU stubs to be updated",
|
24
|
+
show_default=True,
|
25
|
+
)
|
26
|
+
@click.option(
|
27
|
+
"--docstubs",
|
28
|
+
"-ds",
|
29
|
+
"docstubs_folder",
|
30
|
+
default=CONFIG.stub_path.as_posix(),
|
31
|
+
type=click.Path(exists=True, file_okay=True, dir_okay=True),
|
32
|
+
help="File or folder containing the docstubs to be applied",
|
33
|
+
show_default=True,
|
34
|
+
)
|
35
|
+
@click.option("--diff", default=False, help="Show diff", show_default=True, is_flag=True)
|
36
|
+
@click.option(
|
37
|
+
"--dry-run",
|
38
|
+
default=False,
|
39
|
+
help="Dry run does not write the files back",
|
40
|
+
show_default=True,
|
41
|
+
is_flag=True,
|
42
|
+
)
|
43
|
+
@click.option(
|
44
|
+
"--package-name",
|
45
|
+
"-p",
|
46
|
+
"package_name",
|
47
|
+
default="",
|
48
|
+
help="Package name to be enriched (Optional)",
|
49
|
+
show_default=True,
|
50
|
+
)
|
51
|
+
def cli_enrich_folder(
|
52
|
+
stubs_folder: Union[str, Path],
|
53
|
+
docstubs_folder: Union[str, Path],
|
54
|
+
diff: bool = False,
|
55
|
+
dry_run: bool = False,
|
56
|
+
package_name: str = "",
|
57
|
+
):
|
58
|
+
"""
|
59
|
+
Enrich the stubs in stub_folder with the docstubs in docstubs_folder.
|
60
|
+
"""
|
61
|
+
write_back = not dry_run
|
62
|
+
log.info(f"Enriching {stubs_folder} with {docstubs_folder}")
|
63
|
+
_ = enrich_folder(
|
64
|
+
Path(stubs_folder),
|
65
|
+
Path(docstubs_folder),
|
66
|
+
show_diff=diff,
|
67
|
+
write_back=write_back,
|
68
|
+
require_docstub=False,
|
69
|
+
package_name=package_name,
|
70
|
+
)
|
stubber/commands/get_core_cmd.py
CHANGED
@@ -1,69 +1,69 @@
|
|
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 click
|
11
|
-
from loguru import logger as 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(stub_path=stub_path.as_posix(), requirements=req_filename, family=core_type)
|
65
|
-
stub_paths.append(stub_path)
|
66
|
-
|
67
|
-
log.info("::group:: start post processing of retrieved stubs")
|
68
|
-
utils.do_post_processing(stub_paths, stubgen=stubgen, black=black, autoflake=True)
|
69
|
-
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 click
|
11
|
+
from loguru import logger as 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(stub_path=stub_path.as_posix(), requirements=req_filename, family=core_type)
|
65
|
+
stub_paths.append(stub_path)
|
66
|
+
|
67
|
+
log.info("::group:: start post processing of retrieved stubs")
|
68
|
+
utils.do_post_processing(stub_paths, stubgen=stubgen, black=black, autoflake=True)
|
69
|
+
log.info("::group:: Done")
|
@@ -1,87 +1,87 @@
|
|
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("--version", "--tag", default="", type=str, help="Version number to use. [default: Git tag]")
|
44
|
-
@click.option("--black/--no-black", "-b/-nb", default=True, help="Run black", show_default=True)
|
45
|
-
@click.pass_context
|
46
|
-
def cli_docstubs(
|
47
|
-
ctx: click.Context,
|
48
|
-
path: Optional[str] = None,
|
49
|
-
target:Optional[str] = None,
|
50
|
-
black: bool = True,
|
51
|
-
basename: Optional[str] = None,
|
52
|
-
version: str = "",
|
53
|
-
):
|
54
|
-
"""
|
55
|
-
Build stubs from documentation.
|
56
|
-
|
57
|
-
Read the Micropython library documentation files and use them to build stubs that can be used for static typechecking.
|
58
|
-
"""
|
59
|
-
# default parameter values
|
60
|
-
path = path or CONFIG.repo_path.as_posix()
|
61
|
-
target = target or CONFIG.stub_path.as_posix()
|
62
|
-
basename = basename or "micropython"
|
63
|
-
|
64
|
-
if path == CONFIG.repo_path.as_posix():
|
65
|
-
# default
|
66
|
-
rst_path = CONFIG.mpy_path / "docs" / "library"
|
67
|
-
elif Path(path).stem == "micropython":
|
68
|
-
# path to a micropython repo
|
69
|
-
rst_path = Path(path) / "docs" / "library"
|
70
|
-
else:
|
71
|
-
rst_path = Path(path) # or specify full path
|
72
|
-
|
73
|
-
if version:
|
74
|
-
version = utils.clean_version(version, drop_v=False)
|
75
|
-
result = fetch_repos(version, CONFIG.mpy_path, CONFIG.mpy_lib_path)
|
76
|
-
if not result:
|
77
|
-
return -1
|
78
|
-
# get the current checked out version
|
79
|
-
version = utils.checkedout_version(CONFIG.mpy_path)
|
80
|
-
|
81
|
-
release = git.get_local_tag(rst_path.as_posix(), abbreviate=False) or ""
|
82
|
-
|
83
|
-
dst_path = Path(target) / f"{basename}-{utils.clean_version(version, flat=True)}-docstubs"
|
84
|
-
|
85
|
-
log.info(f"Get docstubs for MicroPython {utils.clean_version(version, drop_v=False)}")
|
86
|
-
generate_from_rst(rst_path, dst_path, version, release=release, suffix=".pyi", black=black)
|
87
|
-
log.info("::group:: Done")
|
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("--version", "--tag", default="", type=str, help="Version number to use. [default: Git tag]")
|
44
|
+
@click.option("--black/--no-black", "-b/-nb", default=True, help="Run black", show_default=True)
|
45
|
+
@click.pass_context
|
46
|
+
def cli_docstubs(
|
47
|
+
ctx: click.Context,
|
48
|
+
path: Optional[str] = None,
|
49
|
+
target:Optional[str] = None,
|
50
|
+
black: bool = True,
|
51
|
+
basename: Optional[str] = None,
|
52
|
+
version: str = "",
|
53
|
+
):
|
54
|
+
"""
|
55
|
+
Build stubs from documentation.
|
56
|
+
|
57
|
+
Read the Micropython library documentation files and use them to build stubs that can be used for static typechecking.
|
58
|
+
"""
|
59
|
+
# default parameter values
|
60
|
+
path = path or CONFIG.repo_path.as_posix()
|
61
|
+
target = target or CONFIG.stub_path.as_posix()
|
62
|
+
basename = basename or "micropython"
|
63
|
+
|
64
|
+
if path == CONFIG.repo_path.as_posix():
|
65
|
+
# default
|
66
|
+
rst_path = CONFIG.mpy_path / "docs" / "library"
|
67
|
+
elif Path(path).stem == "micropython":
|
68
|
+
# path to a micropython repo
|
69
|
+
rst_path = Path(path) / "docs" / "library"
|
70
|
+
else:
|
71
|
+
rst_path = Path(path) # or specify full path
|
72
|
+
|
73
|
+
if version:
|
74
|
+
version = utils.clean_version(version, drop_v=False)
|
75
|
+
result = fetch_repos(version, CONFIG.mpy_path, CONFIG.mpy_lib_path)
|
76
|
+
if not result:
|
77
|
+
return -1
|
78
|
+
# get the current checked out version
|
79
|
+
version = utils.checkedout_version(CONFIG.mpy_path)
|
80
|
+
|
81
|
+
release = git.get_local_tag(rst_path.as_posix(), abbreviate=False) or ""
|
82
|
+
|
83
|
+
dst_path = Path(target) / f"{basename}-{utils.clean_version(version, flat=True)}-docstubs"
|
84
|
+
|
85
|
+
log.info(f"Get docstubs for MicroPython {utils.clean_version(version, drop_v=False)}")
|
86
|
+
generate_from_rst(rst_path, dst_path, version, release=release, suffix=".pyi", black=black)
|
87
|
+
log.info("::group:: Done")
|