|
1 |
| -import subprocess |
| 1 | +import sys |
| 2 | +from pathlib import Path |
| 3 | +from typing import Optional |
| 4 | +import logging |
2 | 5 |
|
| 6 | +from clang_tools.install import is_installed, install_tool |
3 | 7 |
|
4 |
| -def check_installed(tool: str, version="") -> int: |
5 |
| - if version: |
6 |
| - check_version_cmd = [f'{tool}-{version} ', '--version'] |
7 |
| - else: |
8 |
| - check_version_cmd = [tool, '--version'] |
9 |
| - try: |
10 |
| - subprocess.run(check_version_cmd, stdout=subprocess.PIPE) |
11 |
| - retval = 0 |
12 |
| - except FileNotFoundError: |
13 |
| - retval = install_clang_tools(version) |
14 |
| - return retval |
15 | 8 |
|
| 9 | +LOG = logging.getLogger(__name__) |
16 | 10 |
|
17 |
| -def install_clang_tools(version: str) -> int: |
18 |
| - if version: |
19 |
| - # clang-tools exist because install_requires=['clang-tools'] in setup.py |
20 |
| - install_tool_cmd = ['clang-tools', '-i', version] |
21 |
| - else: |
22 |
| - # install version 13 by default if clang-tools not exist. |
23 |
| - install_tool_cmd = ['clang-tools', '-i', '13'] |
24 |
| - try: |
25 |
| - subprocess.run(install_tool_cmd, stdout=subprocess.PIPE) |
26 |
| - retval = 0 |
27 |
| - except Exception: |
28 |
| - retval = 1 |
29 |
| - return retval |
30 | 11 |
|
| 12 | +def ensure_installed(tool_name: str, version: Optional[str] = None): |
| 13 | + # install version 13 by default if clang-tools not exist. |
| 14 | + if version is None: |
| 15 | + version = "13" |
31 | 16 |
|
32 |
| -def get_expect_version(args) -> str: |
33 |
| - for arg in args: |
34 |
| - if arg.startswith("--version"): # expect specific clang-tools version. |
35 |
| - # If --version is passed in as 2 arguments, the second is version |
36 |
| - if arg == "--version" and args.index(arg) != len(args) - 1: |
37 |
| - # when --version 14 |
38 |
| - expect_version = args[args.index(arg) + 1] |
39 |
| - else: |
40 |
| - # when --version=14 |
41 |
| - expect_version = arg.replace(" ", "").replace("=", "").replace("--version", "") |
42 |
| - return expect_version |
43 |
| - return "" |
| 17 | + LOG.info("Checking for %s, version %s", tool_name, version) |
| 18 | + if not is_installed(tool_name, version): |
| 19 | + LOG.info("Installing %s, version %s", tool_name, version) |
| 20 | + directory = Path(sys.executable).parent |
| 21 | + install_tool(tool_name, version, directory=str(directory), no_progress_bar=True) |
| 22 | + else: |
| 23 | + LOG.info("%s, version %s is already installed", tool_name, version) |
0 commit comments