Mercurial > hg-allpaths
view mercurial_all_paths.py @ 48:00995da9c204
Implemented priorities, fixed bugs in ignoring, both should work.
Testfixes
author | Marcin Kasperski <Marcin.Kasperski@mekk.waw.pl> |
---|---|
date | Sun, 25 Sep 2016 21:20:31 +0200 |
parents | 916b05f73b53 |
children | 55469dbb19c4 |
line wrap: on
line source
# -*- coding: utf-8 -*- # # allpaths.py - execute commands on multiple paths # # This software may be used and distributed according to the terms of # the GNU General Public License version 2 or any later version. '''execute commands on multiple paths''' import mercurial.util import mercurial.commands import mercurial.cmdutil from mercurial.i18n import _ # pylint:disable=invalid-name,broad-except,line-too-long def _find_all_paths(ui, skip_ignored=False, sort_by_priority=False): """ Finds all paths defined for repo :return: list of pairs (alias, path) """ paths = ui.configitems("paths") if not paths: raise mercurial.util.Abort(_('No paths defined for repository')) if skip_ignored: ignored = ui.configlist("all_paths", "ignore") if ignored: paths = [(alias, path) for alias, path in paths if alias not in ignored] if not paths: raise mercurial.util.Abort(_('All paths defined for this repository are ignored')) if sort_by_priority: prior = ui.configlist("all_paths", "prioritize") if prior: prior_val = {} for idx, item in enumerate(prior): prior_val[item] = idx higher = len(prior) paths.sort(key = lambda it: prior_val.get(it[0], higher)) return paths def _find_paths(ui, group=None): """ Finds and returns all paths defined in given group, or all paths (sans config) if group is not specified. :param ui: repository ui :param group: group name or None for all paths :return: list of pairs (alias, path) """ if not group: return _find_all_paths(ui, skip_ignored=True, sort_by_priority=True) print "DBG:GRR", group # „Modern” syntax grp_def = ui.configlist("all_paths", "group." + group) if grp_def: all_paths = dict(_find_all_paths(ui)) paths = [] for item in grp_def: if item in all_paths: paths.append((item, all_paths[item])) if not paths: raise mercurial.util.Abort(_('None of the paths from group %s is defined in this repository') % group) return paths # „Legacy” syntax, used also for all paths paths = ui.configitems(group) if not paths: raise mercurial.util.Abort(_('No paths defined in section %s') % group) return paths def _iter_over_paths(command, ui, repo, add_sep, **opts): """execute given command on multiple paths""" # Extract our options and filter them out group = opts.pop('group', None) ignore_errors = opts.pop('ignore_errors', None) # Get the paths to push to. paths = _find_paths(ui, group) # Used to avoid handling duplicate paths twice handled = {} # Used to add extra newline between items sep = '' # Act! for alias, path in paths: if path in handled: ui.status(sep + _("Skipping %s as path %s was already handled\n") % (alias, handled[path])) sep = '\n' else: ui.status(sep) sep = '\n' if add_sep else '' handled[path] = alias try: command(ui, repo, path, **opts) except Exception as e: if not ignore_errors: raise ui.warn(_('error handling %s: %s\n') % (alias, e)) sep = '\n' def pushall(ui, repo, **opts): """execute push on multiple paths""" _iter_over_paths(mercurial.commands.push, ui, repo, True, **opts) def pullall(ui, repo, **opts): """execute pull on multiple paths""" _iter_over_paths(mercurial.commands.pull, ui, repo, True, **opts) def incomingall(ui, repo, **opts): """execute incoming on multiple paths""" _iter_over_paths(mercurial.commands.incoming, ui, repo, False, **opts) def outgoingall(ui, repo, **opts): """execute outgoing on multiple paths""" _iter_over_paths(mercurial.commands.outgoing, ui, repo, False, **opts) def _original_options(cmdname): """Gets list of given command options as specified in Mercurial core""" _, spec = mercurial.cmdutil.findcmd(cmdname, mercurial.commands.table) return spec[1] EXT_OPTS = [ ('g', 'group', None, _('use a named group instead of all paths')), ('', 'ignore-errors', None, _('continue execution despite errors')), ] cmdtable = { "pushall": ( pushall, EXT_OPTS + _original_options('push'), _('[-g GROUP] [--ignore-errors] <push options>')), "pullall": ( pullall, EXT_OPTS + _original_options('pull'), _('[-g GROUP] [--ignore-errors] <pull options>')), # For incoming and outgoing -g is taken (--git diff format) "incomingall": ( incomingall, EXT_OPTS + _original_options('incoming'), _('[--group GROUP] [--ignore-errors] <incoming options>')), "outgoingall": ( outgoingall, EXT_OPTS + _original_options('outgoing'), _('[--group GROUP] [--ignore-errors] <outgoing options>')), } testedwith = '2.7 2.9 3.0 3.3 3.6 3.7 3.8' buglink = 'https://bitbucket.org/Mekk/mercurial-all_paths/issues'