mirror of
https://github.com/pre-commit/pre-commit.git
synced 2026-01-14 04:50:20 -06:00
Autoupdate works. Closes #44.
This commit is contained in:
@@ -6,8 +6,12 @@ import pkg_resources
|
||||
import stat
|
||||
from plumbum import local
|
||||
|
||||
import pre_commit.constants as C
|
||||
from pre_commit.clientlib.validate_config import load_config
|
||||
from pre_commit.ordereddict import OrderedDict
|
||||
from pre_commit.repository import Repository
|
||||
from pre_commit.yaml_extensions import ordered_dump
|
||||
from pre_commit.yaml_extensions import ordered_load
|
||||
|
||||
|
||||
def install(runner):
|
||||
@@ -75,4 +79,41 @@ def _update_repository(repo_config):
|
||||
|
||||
def autoupdate(runner):
|
||||
"""Auto-update the pre-commit config to the latest versions of repos."""
|
||||
pass
|
||||
retv = 0
|
||||
output_configs = []
|
||||
changed = False
|
||||
|
||||
input_configs = load_config(
|
||||
runner.config_file_path,
|
||||
load_strategy=ordered_load,
|
||||
)
|
||||
|
||||
for repo_config in input_configs:
|
||||
print('Updating {0}...'.format(repo_config['repo']), end='')
|
||||
try:
|
||||
new_repo_config = _update_repository(repo_config)
|
||||
except RepositoryCannotBeUpdatedError as e:
|
||||
print(e.args[0])
|
||||
output_configs.append(repo_config)
|
||||
retv = 1
|
||||
continue
|
||||
|
||||
if new_repo_config['sha'] != repo_config['sha']:
|
||||
changed = True
|
||||
print(
|
||||
'updating {0} -> {1}.'.format(
|
||||
repo_config['sha'], new_repo_config['sha'],
|
||||
)
|
||||
)
|
||||
output_configs.append(new_repo_config)
|
||||
else:
|
||||
print('already up to date.')
|
||||
output_configs.append(repo_config)
|
||||
|
||||
if changed:
|
||||
with open(runner.config_file_path, 'w') as config_file:
|
||||
config_file.write(
|
||||
ordered_dump(output_configs, **C.YAML_DUMP_KWARGS)
|
||||
)
|
||||
|
||||
return retv
|
||||
|
||||
@@ -10,3 +10,9 @@ SUPPORTED_LANGUAGES = set([
|
||||
'ruby',
|
||||
'node',
|
||||
])
|
||||
|
||||
|
||||
YAML_DUMP_KWARGS = {
|
||||
'default_flow_style': False,
|
||||
'indent': 4,
|
||||
}
|
||||
|
||||
@@ -18,7 +18,7 @@ def ordered_load(s):
|
||||
|
||||
|
||||
def ordered_dump(s, **kwargs):
|
||||
class OrderedDumper(yaml.dumper.Dumper): pass
|
||||
class OrderedDumper(yaml.dumper.SafeDumper): pass
|
||||
def dict_representer(dumper, data):
|
||||
return dumper.represent_mapping(
|
||||
yaml.resolver.BaseResolver.DEFAULT_MAPPING_TAG,
|
||||
|
||||
Reference in New Issue
Block a user