mirror of
https://github.com/pre-commit/pre-commit.git
synced 2026-04-15 18:11:48 +04:00
Add ability to specify rust language version
This commit is contained in:
parent
e431b2b898
commit
af740dfedb
1 changed files with 62 additions and 20 deletions
|
|
@ -18,25 +18,61 @@ from pre_commit.util import clean_path_on_failure
|
||||||
from pre_commit.util import cmd_output_b
|
from pre_commit.util import cmd_output_b
|
||||||
|
|
||||||
ENVIRONMENT_DIR = 'rustenv'
|
ENVIRONMENT_DIR = 'rustenv'
|
||||||
|
RUNTIME_DIR = 'rustup'
|
||||||
get_default_version = helpers.basic_get_default_version
|
get_default_version = helpers.basic_get_default_version
|
||||||
healthy = helpers.basic_healthy
|
|
||||||
|
|
||||||
|
|
||||||
def get_env_patch(target_dir: str) -> PatchesT:
|
def _envdir(prefix: Prefix, version: str) -> str:
|
||||||
return (
|
directory = helpers.environment_dir(ENVIRONMENT_DIR, version)
|
||||||
('PATH', (os.path.join(target_dir, 'bin'), os.pathsep, Var('PATH'))),
|
return prefix.path(directory)
|
||||||
|
|
||||||
|
|
||||||
|
def _version_flag(version: str) -> Sequence[str]:
|
||||||
|
return [] if version == C.DEFAULT else [f'+{version}']
|
||||||
|
|
||||||
|
|
||||||
|
def _resolve_version(prefix: Prefix, version: str) -> str:
|
||||||
|
if version != C.DEFAULT:
|
||||||
|
return version
|
||||||
|
|
||||||
|
if prefix.exists('rust-toolchain'):
|
||||||
|
with open(prefix.path('rust-toolchain')) as f:
|
||||||
|
return f.readline().strip()
|
||||||
|
|
||||||
|
return version
|
||||||
|
|
||||||
|
|
||||||
|
def get_env_patch(prefix: Prefix, version: str) -> PatchesT:
|
||||||
|
env_path = _envdir(prefix, version)
|
||||||
|
patch = (
|
||||||
|
('CARGO_HOME', env_path),
|
||||||
|
('PATH', (os.path.join(env_path, 'bin'), os.pathsep, Var('PATH'))),
|
||||||
)
|
)
|
||||||
|
|
||||||
|
if version != C.DEFAULT:
|
||||||
|
return (*patch, ('RUSTUP_HOME', prefix.path(RUNTIME_DIR)))
|
||||||
|
|
||||||
|
return patch
|
||||||
|
|
||||||
|
|
||||||
@contextlib.contextmanager
|
@contextlib.contextmanager
|
||||||
def in_env(prefix: Prefix) -> Generator[None, None, None]:
|
def in_env(prefix: Prefix, version: str) -> Generator[None, None, None]:
|
||||||
target_dir = prefix.path(
|
with envcontext(get_env_patch(prefix, version)):
|
||||||
helpers.environment_dir(ENVIRONMENT_DIR, C.DEFAULT),
|
|
||||||
)
|
|
||||||
with envcontext(get_env_patch(target_dir)):
|
|
||||||
yield
|
yield
|
||||||
|
|
||||||
|
|
||||||
|
def healthy(prefix: Prefix, version: str) -> bool:
|
||||||
|
language_version = _resolve_version(prefix, version)
|
||||||
|
with in_env(prefix, language_version):
|
||||||
|
version_flag = _version_flag(language_version)
|
||||||
|
retcode, _, _ = cmd_output_b(
|
||||||
|
'rustc', *version_flag, '--version',
|
||||||
|
retcode=None,
|
||||||
|
cwd=prefix.prefix_dir,
|
||||||
|
)
|
||||||
|
return retcode == 0
|
||||||
|
|
||||||
|
|
||||||
def _add_dependencies(
|
def _add_dependencies(
|
||||||
cargo_toml_path: str,
|
cargo_toml_path: str,
|
||||||
additional_dependencies: Set[str],
|
additional_dependencies: Set[str],
|
||||||
|
|
@ -57,11 +93,6 @@ def install_environment(
|
||||||
version: str,
|
version: str,
|
||||||
additional_dependencies: Sequence[str],
|
additional_dependencies: Sequence[str],
|
||||||
) -> None:
|
) -> None:
|
||||||
helpers.assert_version_default('rust', version)
|
|
||||||
directory = prefix.path(
|
|
||||||
helpers.environment_dir(ENVIRONMENT_DIR, C.DEFAULT),
|
|
||||||
)
|
|
||||||
|
|
||||||
# There are two cases where we might want to specify more dependencies:
|
# There are two cases where we might want to specify more dependencies:
|
||||||
# as dependencies for the library being built, and as binary packages
|
# as dependencies for the library being built, and as binary packages
|
||||||
# to be `cargo install`'d.
|
# to be `cargo install`'d.
|
||||||
|
|
@ -80,19 +111,29 @@ def install_environment(
|
||||||
if len(lib_deps) > 0:
|
if len(lib_deps) > 0:
|
||||||
_add_dependencies(prefix.path('Cargo.toml'), lib_deps)
|
_add_dependencies(prefix.path('Cargo.toml'), lib_deps)
|
||||||
|
|
||||||
with clean_path_on_failure(directory):
|
language_version = _resolve_version(prefix, version)
|
||||||
|
directory = _envdir(prefix, language_version)
|
||||||
|
with clean_path_on_failure(directory), in_env(prefix, language_version):
|
||||||
|
if language_version != C.DEFAULT:
|
||||||
|
cmd_output_b(
|
||||||
|
'rustup', 'toolchain', 'install',
|
||||||
|
'--no-self-update', '--profile', 'minimal', language_version,
|
||||||
|
cwd=prefix.prefix_dir,
|
||||||
|
)
|
||||||
|
|
||||||
packages_to_install: Set[Tuple[str, ...]] = {('--path', '.')}
|
packages_to_install: Set[Tuple[str, ...]] = {('--path', '.')}
|
||||||
for cli_dep in cli_deps:
|
for cli_dep in cli_deps:
|
||||||
cli_dep = cli_dep[len('cli:'):]
|
cli_dep = cli_dep[len('cli:'):]
|
||||||
package, _, version = cli_dep.partition(':')
|
package, _, dep_version = cli_dep.partition(':')
|
||||||
if version != '':
|
if dep_version != '':
|
||||||
packages_to_install.add((package, '--version', version))
|
packages_to_install.add((package, '--version', dep_version))
|
||||||
else:
|
else:
|
||||||
packages_to_install.add((package,))
|
packages_to_install.add((package,))
|
||||||
|
|
||||||
|
version_flag = _version_flag(language_version)
|
||||||
for args in packages_to_install:
|
for args in packages_to_install:
|
||||||
cmd_output_b(
|
cmd_output_b(
|
||||||
'cargo', 'install', '--bins', '--root', directory, *args,
|
'cargo', *version_flag, 'install', '--bins', *args,
|
||||||
cwd=prefix.prefix_dir,
|
cwd=prefix.prefix_dir,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
@ -102,5 +143,6 @@ def run_hook(
|
||||||
file_args: Sequence[str],
|
file_args: Sequence[str],
|
||||||
color: bool,
|
color: bool,
|
||||||
) -> Tuple[int, bytes]:
|
) -> Tuple[int, bytes]:
|
||||||
with in_env(hook.prefix):
|
language_version = _resolve_version(hook.prefix, hook.language_version)
|
||||||
|
with in_env(hook.prefix, language_version):
|
||||||
return helpers.run_xargs(hook, hook.cmd, file_args, color=color)
|
return helpers.run_xargs(hook, hook.cmd, file_args, color=color)
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue