mirror of
https://github.com/pre-commit/pre-commit.git
synced 2026-04-15 18:11:48 +04:00
Merge a46b3a1231 into 51ac0e8bc0
This commit is contained in:
commit
5950fbf29d
2 changed files with 25 additions and 6 deletions
|
|
@ -57,6 +57,8 @@ def _add_hook_type_option(parser):
|
|||
def _add_run_options(parser):
|
||||
parser.add_argument('hook', nargs='?', help='A single hook-id to run')
|
||||
parser.add_argument('--verbose', '-v', action='store_true', default=False)
|
||||
parser.add_argument('--only', '-i', action='store_true', default=False,
|
||||
help='Save some bandwidth')
|
||||
parser.add_argument(
|
||||
'--origin', '-o',
|
||||
help="The origin branch's commit_id when using `git push`.",
|
||||
|
|
@ -230,7 +232,11 @@ def main(argv=None):
|
|||
|
||||
with error_handler():
|
||||
add_logging_handler(args.color)
|
||||
runner = Runner.create(args.config)
|
||||
runner = Runner.create(
|
||||
args.config,
|
||||
filter_repos=args.only,
|
||||
filter_hook=args.hook,
|
||||
)
|
||||
git.check_for_cygwin_mismatch()
|
||||
|
||||
if args.command == 'install':
|
||||
|
|
|
|||
|
|
@ -15,20 +15,26 @@ class Runner(object):
|
|||
repository under test.
|
||||
"""
|
||||
|
||||
def __init__(self, git_root, config_file, store_dir=None):
|
||||
def __init__(self, git_root, config_file, store_dir=None,
|
||||
filter_repos=False, filter_hook=None):
|
||||
self.git_root = git_root
|
||||
self.config_file = config_file
|
||||
self._store_dir = store_dir
|
||||
self._filter_repos = filter_repos
|
||||
self._filter_hook = filter_hook
|
||||
|
||||
@classmethod
|
||||
def create(cls, config_file):
|
||||
def create(cls, config_file, filter_repos=False, filter_hook=None):
|
||||
"""Creates a Runner by doing the following:
|
||||
- Finds the root of the current git repository
|
||||
- chdir to that directory
|
||||
"""
|
||||
root = git.get_root()
|
||||
os.chdir(root)
|
||||
return cls(root, config_file)
|
||||
return cls(
|
||||
root, config_file,
|
||||
filter_repos=filter_repos, filter_hook=filter_hook
|
||||
)
|
||||
|
||||
@cached_property
|
||||
def git_dir(self):
|
||||
|
|
@ -45,8 +51,15 @@ class Runner(object):
|
|||
@cached_property
|
||||
def repositories(self):
|
||||
"""Returns a tuple of the configured repositories."""
|
||||
repos = self.config['repos']
|
||||
return tuple(Repository.create(x, self.store) for x in repos)
|
||||
filtered_repos = repos = self.config['repos']
|
||||
if self._filter_repos and self._filter_hook:
|
||||
filtered_repos = (
|
||||
r for r in repos
|
||||
if self._filter_hook in (
|
||||
h['id'] for h in r['hooks']
|
||||
)
|
||||
)
|
||||
return tuple(Repository.create(x, self.store) for x in filtered_repos)
|
||||
|
||||
def get_hook_path(self, hook_type):
|
||||
return os.path.join(self.git_dir, 'hooks', hook_type)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue