/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