vimPlugins: remove repetition from update.main

Adding some abstraction makes main() more readable which is important
since it's the main control flow of the script.
This commit is contained in:
ryneeverett 2020-03-28 18:11:51 +00:00
parent f1ae95f6d3
commit 1f32eb7987
1 changed files with 32 additions and 24 deletions

View File

@ -222,11 +222,12 @@ def get_current_plugins() -> List[Plugin]:
def prefetch_plugin(
user: str, repo_name: str, alias: str, cache: "Cache"
user: str, repo_name: str, alias: str, cache: "Cache" = None
) -> Tuple[Plugin, Dict[str, str]]:
repo = Repo(user, repo_name, alias)
commit, date = repo.latest_commit()
has_submodules = repo.has_submodules()
if cache is not None:
cached_plugin = cache[commit]
if cached_plugin is not None:
cached_plugin.name = alias or repo_name
@ -524,19 +525,28 @@ class NixpkgsRepo:
return self.repo.is_dirty() and not self.allow_dirty
def update_plugins(input_file: str, outfile: str, cache: Cache) -> Dict:
plugin_names = load_plugin_spec(input_file)
prefetch_with_cache = functools.partial(prefetch, cache=cache)
class PluginUpdater:
def __init__(self, input_file: str, outfile: str, proc: int):
self.input_file: str = input_file
self.outfile: str = outfile
self.proc = proc
self.cache: Cache = Cache(get_current_plugins())
self.prefetch = functools.partial(prefetch, cache=self.cache)
def __call__(self) -> Dict:
plugin_names = load_plugin_spec(self.input_file)
try:
pool = Pool(processes=args.proc)
results = pool.map(prefetch_with_cache, plugin_names)
# synchronous variant for debugging
# results = list(map(self.prefetch, plugin_names))
pool = Pool(processes=self.proc)
results = pool.map(self.prefetch, plugin_names)
finally:
cache.store()
self.cache.store()
plugins, redirects = check_results(results)
generate_nix(plugins, outfile)
generate_nix(plugins, self.outfile)
return redirects
@ -547,26 +557,24 @@ def main() -> None:
raise Exception("The --add argument requires setting the --commit flag.")
if args.commit:
nixpkgs_repo = NixpkgsRepo(args.allow_dirty)
current_plugins = get_current_plugins()
cache = Cache(current_plugins)
redirects = {}
updater = PluginUpdater(args.input_file, args.outfile, args.proc)
redirects = update_plugins(args.input_file, args.outfile, cache)
redirects = updater()
rewrite_input(args.input_file, redirects)
if args.commit:
nixpkgs_repo.commit("vimPlugins: Update", [args.outfile])
if redirects:
update_plugins(args.input_file, args.outfile, cache)
updater()
nixpkgs_repo.commit(
"vimPlugins: Update redirects",
[args.outfile, args.input_file, DEPRECATED],
)
for plugin_line in args.add_plugins:
rewrite_input(args.input_file, append=(plugin_line + "\n",))
update_plugins(args.input_file, args.outfile, cache)
updater()
plugin, _ = prefetch_plugin(*parse_plugin_line(plugin_line), cache)
plugin, _ = prefetch_plugin(*parse_plugin_line(plugin_line))
nixpkgs_repo.commit(
"vimPlugins.{name}: init at {version}".format(
name=plugin.normalized_name, version=plugin.version