annotate glimmerHMM/BCBio/GFF/_utils.py @ 0:0a15677c6668 default tip

Uploaded
author bjoern-gruening
date Wed, 11 Jan 2012 09:58:35 -0500
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
0a15677c6668 Uploaded
bjoern-gruening
parents:
diff changeset
1 class defaultdict(dict):
0a15677c6668 Uploaded
bjoern-gruening
parents:
diff changeset
2 """Back compatible defaultdict: http://code.activestate.com/recipes/523034/
0a15677c6668 Uploaded
bjoern-gruening
parents:
diff changeset
3 """
0a15677c6668 Uploaded
bjoern-gruening
parents:
diff changeset
4 def __init__(self, default_factory=None, *a, **kw):
0a15677c6668 Uploaded
bjoern-gruening
parents:
diff changeset
5 if (default_factory is not None and
0a15677c6668 Uploaded
bjoern-gruening
parents:
diff changeset
6 not hasattr(default_factory, '__call__')):
0a15677c6668 Uploaded
bjoern-gruening
parents:
diff changeset
7 raise TypeError('first argument must be callable')
0a15677c6668 Uploaded
bjoern-gruening
parents:
diff changeset
8 dict.__init__(self, *a, **kw)
0a15677c6668 Uploaded
bjoern-gruening
parents:
diff changeset
9 self.default_factory = default_factory
0a15677c6668 Uploaded
bjoern-gruening
parents:
diff changeset
10 def __getitem__(self, key):
0a15677c6668 Uploaded
bjoern-gruening
parents:
diff changeset
11 try:
0a15677c6668 Uploaded
bjoern-gruening
parents:
diff changeset
12 return dict.__getitem__(self, key)
0a15677c6668 Uploaded
bjoern-gruening
parents:
diff changeset
13 except KeyError:
0a15677c6668 Uploaded
bjoern-gruening
parents:
diff changeset
14 return self.__missing__(key)
0a15677c6668 Uploaded
bjoern-gruening
parents:
diff changeset
15 def __missing__(self, key):
0a15677c6668 Uploaded
bjoern-gruening
parents:
diff changeset
16 if self.default_factory is None:
0a15677c6668 Uploaded
bjoern-gruening
parents:
diff changeset
17 raise KeyError(key)
0a15677c6668 Uploaded
bjoern-gruening
parents:
diff changeset
18 self[key] = value = self.default_factory()
0a15677c6668 Uploaded
bjoern-gruening
parents:
diff changeset
19 return value
0a15677c6668 Uploaded
bjoern-gruening
parents:
diff changeset
20 def __reduce__(self):
0a15677c6668 Uploaded
bjoern-gruening
parents:
diff changeset
21 if self.default_factory is None:
0a15677c6668 Uploaded
bjoern-gruening
parents:
diff changeset
22 args = tuple()
0a15677c6668 Uploaded
bjoern-gruening
parents:
diff changeset
23 else:
0a15677c6668 Uploaded
bjoern-gruening
parents:
diff changeset
24 args = self.default_factory,
0a15677c6668 Uploaded
bjoern-gruening
parents:
diff changeset
25 return type(self), args, None, None, self.items()
0a15677c6668 Uploaded
bjoern-gruening
parents:
diff changeset
26 def copy(self):
0a15677c6668 Uploaded
bjoern-gruening
parents:
diff changeset
27 return self.__copy__()
0a15677c6668 Uploaded
bjoern-gruening
parents:
diff changeset
28 def __copy__(self):
0a15677c6668 Uploaded
bjoern-gruening
parents:
diff changeset
29 return type(self)(self.default_factory, self)
0a15677c6668 Uploaded
bjoern-gruening
parents:
diff changeset
30 def __deepcopy__(self, memo):
0a15677c6668 Uploaded
bjoern-gruening
parents:
diff changeset
31 import copy
0a15677c6668 Uploaded
bjoern-gruening
parents:
diff changeset
32 return type(self)(self.default_factory,
0a15677c6668 Uploaded
bjoern-gruening
parents:
diff changeset
33 copy.deepcopy(self.items()))
0a15677c6668 Uploaded
bjoern-gruening
parents:
diff changeset
34 def __repr__(self):
0a15677c6668 Uploaded
bjoern-gruening
parents:
diff changeset
35 return 'defaultdict(%s, %s)' % (self.default_factory,
0a15677c6668 Uploaded
bjoern-gruening
parents:
diff changeset
36 dict.__repr__(self))
0a15677c6668 Uploaded
bjoern-gruening
parents:
diff changeset
37