/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar
0.64.30 by Ian Clatworthy
add heads analysis to info processor
1
# Copyright (C) 2008 Canonical Ltd
2
#
3
# This program is free software; you can redistribute it and/or modify
4
# it under the terms of the GNU General Public License as published by
5
# the Free Software Foundation; either version 2 of the License, or
6
# (at your option) any later version.
7
#
8
# This program is distributed in the hope that it will be useful,
9
# but WITHOUT ANY WARRANTY; without even the implied warranty of
10
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
11
# GNU General Public License for more details.
12
#
13
# You should have received a copy of the GNU General Public License
14
# along with this program; if not, write to the Free Software
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
16
0.64.32 by Ian Clatworthy
move single_plural into helpers
17
"""Miscellaneous useful stuff."""
18
19
20
def single_plural(n, single, plural):
21
    """Return a single or plural form of a noun based on number."""
22
    if n == 1:
23
        return single
24
    else:
25
        return plural
0.64.30 by Ian Clatworthy
add heads analysis to info processor
26
27
0.64.38 by Ian Clatworthy
clean-up doc ready for initial release
28
def defines_to_dict(defines):
29
    """Convert a list of definition strings to a dictionary."""
30
    if defines is None:
31
        return None
32
    result = {}
33
    for define in defines:
34
        kv = define.split('=', 1)
35
        if len(kv) == 1:
36
            result[define.strip()] = 1
37
        else:
38
            result[kv[0].strip()] = kv[1].strip()
39
    return result
40
41
0.64.30 by Ian Clatworthy
add heads analysis to info processor
42
def invert_dict(d):
43
    """Invert a dictionary with keys matching each value turned into a list."""
44
    # Based on recipe from ASPN
45
    result = {}
46
    for k, v in d.iteritems():
47
        keys = result.setdefault(v, [])
48
        keys.append(k)
49
    return result
0.75.1 by Brian de Alwis
Add support for multiple branches by supporting the 'reset' command.
50
0.77.8 by Ian Clatworthy
include subdir & multiple files tests
51
0.75.1 by Brian de Alwis
Add support for multiple branches by supporting the 'reset' command.
52
def invert_dictset(d):
53
    """Invert a dictionary with keys matching a set of values, turned into lists."""
54
    # Based on recipe from ASPN
55
    result = {}
56
    for k, c in d.iteritems():
57
        for v in c:
58
            keys = result.setdefault(v, [])
59
            keys.append(k)
60
    return result
0.77.8 by Ian Clatworthy
include subdir & multiple files tests
61
62
63
def common_path(l1, l2, common=[]):
64
    """Find the common bit of 2 paths."""
65
    # From http://code.activestate.com/recipes/208993/
66
    if len(l1) < 1: return (common, l1, l2)
67
    if len(l2) < 1: return (common, l1, l2)
68
    if l1[0] != l2[0]: return (common, l1, l2)
69
    return common_path(l1[1:], l2[1:], common+[l1[0]])
70
71
72
def common_directory(paths):
73
    """Find the deepest common directory of a list of paths.
74
    
75
    :return: if no paths are provided, None is returned,
76
      otherwise a directory with a trailing /.
77
    """
78
    from bzrlib import osutils
79
    def get_dir_with_slash(path):
80
        if path.endswith('/'):
81
            return path
82
        else:
83
            dirname, basename = osutils.split(path)
84
            return dirname + '/'
85
86
    if not paths:
87
        return None
88
    elif len(paths) == 1:
89
        return get_dir_with_slash(paths[0])
90
    else:
91
        common = common_path(paths[0], paths[1])[0]
92
        for path in paths[2:]:
93
            common = common_path(common, path)
94
        return get_dir_with_slash(''.join(common))