2 from fcntl import flock, LOCK_EX, LOCK_UN
6 'A simple namespace object.'
7 def __init__(self, d = {}, **kwargs):
8 'd is the dictionary to update my __dict__ with.'
9 self.__dict__.update(d)
10 self.__dict__.update(kwargs)
14 Given a tree of lists/dicts, perform a deep traversal to transform all the
18 return struct((k, dicts2struct(v)) for k,v in x.iteritems())
20 return [dicts2struct(v) for v in x]
25 # Hacks to work around lack of Python 2.5's `with` statement.
28 def with_closing(rsrc):
30 Utility to emulate Python 2.5's `with closing(rsrc)` context manager.
33 @with_closing(file('/tmp/foo'))
36 # now 'contents' is the contents of /tmp/foo
39 try: return func(rsrc)
43 def with_lock_file(path):
45 Context manager for lock files. Example:
47 @with_lock_file('/tmp/mylock')
52 print input # prints what raw_input() returned
55 @with_closing(file(path, 'w'))
59 finally: flock(f, LOCK_UN)
68 class common_tests(unittest.TestCase):
69 def test_dicts2structs(self):
72 'dict': { 'atom': 'atom', 'list': [1,2,3] },
73 'list': [ 'atom', {'key': 'value'} ]
75 structs = dicts2struct(dicts)
76 self.assertEqual(structs.atom, dicts['atom'])
77 self.assertEqual(structs.dict.atom, dicts['dict']['atom'])
78 self.assertEqual(structs.dict.list, dicts['dict']['list'])
79 self.assertEqual(structs.list[0], dicts['list'][0])
80 self.assertEqual(structs.list[1].key, dicts['list'][1]['key'])
82 if __name__ == '__main__':