expand with_* docstrings in invirt.common
authorGreg Price <price@mit.edu>
Thu, 31 Jul 2008 01:05:33 +0000 (21:05 -0400)
committerGreg Price <price@mit.edu>
Thu, 31 Jul 2008 01:05:33 +0000 (21:05 -0400)
svn path=/trunk/packages/sipb-xen-base/; revision=786

files/usr/share/python-support/sipb-xen-base/invirt/common.py

index ca90714..b193ecc 100644 (file)
@@ -26,7 +26,15 @@ def dicts2struct(x):
 #
 
 def with_closing(rsrc):
-    "Utility to emulate Python 2.5's `with closing(rsrc)` context manager."
+    """
+    Utility to emulate Python 2.5's `with closing(rsrc)` context manager.
+
+    E.g.,
+    @with_closing(file('/tmp/foo'))
+    def contents(f):
+        return f.read()
+    # now 'contents' is the contents of /tmp/foo
+    """
     def wrapper(func):
         try: return func(rsrc)
         finally: rsrc.close()
@@ -40,8 +48,8 @@ def with_lock_file(path):
     def input():
         print 'locked'
         return raw_input()
-    # decorator is executed immediately
-    print input # prints the input text
+    # prints 'locked'
+    print input # prints what raw_input() returned
     """
     def wrapper(func):
         @with_closing(file(path, 'w'))