$97 GRAYBYTE WORDPRESS FILE MANAGER $14

SERVER : premium201.web-hosting.com #1 SMP Wed Mar 26 12:08:09 UTC 2025
SERVER IP : 172.67.162.162 | ADMIN IP 216.73.216.174
OPTIONS : CRL = ON | WGT = ON | SDO = OFF | PKEX = OFF
DEACTIVATED : NONE

/opt/hc_python/lib/python3.12/site-packages/pre_commit/

HOME
Current File : /opt/hc_python/lib/python3.12/site-packages/pre_commit//lang_base.py
from __future__ import annotations

import contextlib
import os
import random
import re
import shlex
import sys
from collections.abc import Generator
from collections.abc import Sequence
from typing import Any
from typing import ContextManager
from typing import NoReturn
from typing import Protocol

import pre_commit.constants as C
from pre_commit import parse_shebang
from pre_commit import xargs
from pre_commit.prefix import Prefix
from pre_commit.util import cmd_output_b

FIXED_RANDOM_SEED = 1542676187

SHIMS_RE = re.compile(r'[/\\]shims[/\\]')


class Language(Protocol):
    # Use `None` for no installation / environment
    @property
    def ENVIRONMENT_DIR(self) -> str | None: ...
    # return a value to replace `'default` for `language_version`
    def get_default_version(self) -> str: ...
    # return whether the environment is healthy (or should be rebuilt)
    def health_check(self, prefix: Prefix, version: str) -> str | None: ...

    # install a repository for the given language and language_version
    def install_environment(
            self,
            prefix: Prefix,
            version: str,
            additional_dependencies: Sequence[str],
    ) -> None:
        ...

    # modify the environment for hook execution
    def in_env(self, prefix: Prefix, version: str) -> ContextManager[None]: ...

    # execute a hook and return the exit code and output
    def run_hook(
            self,
            prefix: Prefix,
            entry: str,
            args: Sequence[str],
            file_args: Sequence[str],
            *,
            is_local: bool,
            require_serial: bool,
            color: bool,
    ) -> tuple[int, bytes]:
        ...


def exe_exists(exe: str) -> bool:
    found = parse_shebang.find_executable(exe)
    if found is None:  # exe exists
        return False

    homedir = os.path.expanduser('~')
    try:
        common: str | None = os.path.commonpath((found, homedir))
    except ValueError:  # on windows, different drives raises ValueError
        common = None

    return (
        # it is not in a /shims/ directory
        not SHIMS_RE.search(found) and
        (
            # the homedir is / (docker, service user, etc.)
            os.path.dirname(homedir) == homedir or
            # the exe is not contained in the home directory
            common != homedir
        )
    )


def setup_cmd(prefix: Prefix, cmd: tuple[str, ...], **kwargs: Any) -> None:
    cmd_output_b(*cmd, cwd=prefix.prefix_dir, **kwargs)


def environment_dir(prefix: Prefix, d: str, language_version: str) -> str:
    return prefix.path(f'{d}-{language_version}')


def assert_version_default(binary: str, version: str) -> None:
    if version != C.DEFAULT:
        raise AssertionError(
            f'for now, pre-commit requires system-installed {binary} -- '
            f'you selected `language_version: {version}`',
        )


def assert_no_additional_deps(
        lang: str,
        additional_deps: Sequence[str],
) -> None:
    if additional_deps:
        raise AssertionError(
            f'for now, pre-commit does not support '
            f'additional_dependencies for {lang} -- '
            f'you selected `additional_dependencies: {additional_deps}`',
        )


def basic_get_default_version() -> str:
    return C.DEFAULT


def basic_health_check(prefix: Prefix, language_version: str) -> str | None:
    return None


def no_install(
        prefix: Prefix,
        version: str,
        additional_dependencies: Sequence[str],
) -> NoReturn:
    raise AssertionError('This language is not installable')


@contextlib.contextmanager
def no_env(prefix: Prefix, version: str) -> Generator[None]:
    yield


def target_concurrency() -> int:
    if 'PRE_COMMIT_NO_CONCURRENCY' in os.environ:
        return 1
    else:
        # Travis appears to have a bunch of CPUs, but we can't use them all.
        if 'TRAVIS' in os.environ:
            return 2
        else:
            return xargs.cpu_count()


def _shuffled(seq: Sequence[str]) -> list[str]:
    """Deterministically shuffle"""
    fixed_random = random.Random()
    fixed_random.seed(FIXED_RANDOM_SEED, version=1)

    seq = list(seq)
    fixed_random.shuffle(seq)
    return seq


def run_xargs(
        cmd: tuple[str, ...],
        file_args: Sequence[str],
        *,
        require_serial: bool,
        color: bool,
) -> tuple[int, bytes]:
    if require_serial:
        jobs = 1
    else:
        # Shuffle the files so that they more evenly fill out the xargs
        # partitions, but do it deterministically in case a hook cares about
        # ordering.
        file_args = _shuffled(file_args)
        jobs = target_concurrency()
    return xargs.xargs(cmd, file_args, target_concurrency=jobs, color=color)


def hook_cmd(entry: str, args: Sequence[str]) -> tuple[str, ...]:
    cmd = shlex.split(entry)
    if cmd[:2] == ['pre-commit', 'hazmat']:
        cmd = [sys.executable, '-m', 'pre_commit.commands.hazmat', *cmd[2:]]
    return (*cmd, *args)


def basic_run_hook(
        prefix: Prefix,
        entry: str,
        args: Sequence[str],
        file_args: Sequence[str],
        *,
        is_local: bool,
        require_serial: bool,
        color: bool,
) -> tuple[int, bytes]:
    return run_xargs(
        hook_cmd(entry, args),
        file_args,
        require_serial=require_serial,
        color=color,
    )


Current_dir [ NOT WRITEABLE ] Document_root [ WRITEABLE ]


[ Back ]
NAME
SIZE
LAST TOUCH
USER
CAN-I?
FUNCTIONS
..
--
3 Dec 2025 9.30 AM
root / root
0755
__pycache__
--
3 Dec 2025 9.30 AM
root / root
0755
commands
--
3 Dec 2025 9.30 AM
root / root
0755
languages
--
3 Dec 2025 9.30 AM
root / root
0755
meta_hooks
--
3 Dec 2025 9.30 AM
root / root
0755
resources
--
3 Dec 2025 9.30 AM
root / root
0755
__init__.py
0 KB
3 Dec 2025 9.30 AM
root / root
0644
__main__.py
0.124 KB
3 Dec 2025 9.30 AM
root / root
0644
all_languages.py
1.429 KB
3 Dec 2025 9.30 AM
root / root
0644
clientlib.py
16.421 KB
3 Dec 2025 9.30 AM
root / root
0644
color.py
3.144 KB
3 Dec 2025 9.30 AM
root / root
0644
constants.py
0.275 KB
3 Dec 2025 9.30 AM
root / root
0644
envcontext.py
1.556 KB
3 Dec 2025 9.30 AM
root / root
0644
error_handler.py
2.56 KB
3 Dec 2025 9.30 AM
root / root
0644
errors.py
0.076 KB
3 Dec 2025 9.30 AM
root / root
0644
file_lock.py
2.296 KB
3 Dec 2025 9.30 AM
root / root
0644
git.py
8.327 KB
3 Dec 2025 9.30 AM
root / root
0644
hook.py
1.478 KB
3 Dec 2025 9.30 AM
root / root
0644
lang_base.py
5.258 KB
3 Dec 2025 9.30 AM
root / root
0644
logging_handler.py
0.995 KB
3 Dec 2025 9.30 AM
root / root
0644
main.py
15.545 KB
3 Dec 2025 9.30 AM
root / root
0644
output.py
0.89 KB
3 Dec 2025 9.30 AM
root / root
0644
parse_shebang.py
2.423 KB
3 Dec 2025 9.30 AM
root / root
0644
prefix.py
0.483 KB
3 Dec 2025 9.30 AM
root / root
0644
repository.py
7.43 KB
3 Dec 2025 9.30 AM
root / root
0644
staged_files_only.py
4.058 KB
3 Dec 2025 9.30 AM
root / root
0644
store.py
8.271 KB
3 Dec 2025 9.30 AM
root / root
0644
util.py
6.882 KB
3 Dec 2025 9.30 AM
root / root
0644
xargs.py
5.42 KB
3 Dec 2025 9.30 AM
root / root
0644
yaml.py
0.548 KB
3 Dec 2025 9.30 AM
root / root
0644
yaml_rewrite.py
1.306 KB
3 Dec 2025 9.30 AM
root / root
0644

GRAYBYTE WORDPRESS FILE MANAGER @ 2025 CONTACT ME
Static GIF