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 |