]> git.llucax.com Git - software/pymin.git/blobdiff - pymin/procman.py
Make magic methods of procman.ProcessManager aliases of normal methods.
[software/pymin.git] / pymin / procman.py
index 115f3b41e07fba0f7bda8adf65d3569504da94eb..554fdbada88629222e889b77d6b01b180caeab63 100644 (file)
@@ -25,7 +25,7 @@ class ProcessInfo:
     def clear(self):
         self._dont_run = False
         self._signal = None
     def clear(self):
         self._dont_run = False
         self._signal = None
-        self.process = None
+        self._process = None
         self.error_count = 0
     def start(self):
         assert self.process is None
         self.error_count = 0
     def start(self):
         assert self.process is None
@@ -33,7 +33,8 @@ class ProcessInfo:
     def restart(self):
         self.clear()
         log.debug(u'ProcessInfo.restart(): executing %s', self.command)
     def restart(self):
         self.clear()
         log.debug(u'ProcessInfo.restart(): executing %s', self.command)
-        self.process = subprocess.Popen(self.command, *self.args, **self.kwargs)
+        self._process = subprocess.Popen(self.command,
+                                         *self.args, **self.kwargs)
     def stop(self):
         assert self.process is not None
         self._dont_run = True
     def stop(self):
         assert self.process is not None
         self._dont_run = True
@@ -55,6 +56,9 @@ class ProcessInfo:
     @property
     def name(self):
         return self._name
     @property
     def name(self):
         return self._name
+    @property
+    def process(self):
+        return self._process
     def __repr__(self):
         pid = None
         if self.process is not None:
     def __repr__(self):
         pid = None
         if self.process is not None:
@@ -181,6 +185,8 @@ class ProcessManager:
             if name in self.pidmap:
                 return self.pidmap[name]
         raise KeyError, name
             if name in self.pidmap:
                 return self.pidmap[name]
         raise KeyError, name
+    # Syntax sugar for self[name]
+    __getitem__ = get
 
     def has(self, name):
         if isinstance(name, basestring): # is a name
 
     def has(self, name):
         if isinstance(name, basestring): # is a name
@@ -192,12 +198,8 @@ class ProcessManager:
             if name in self.pidmap:
                 return True
         return False
             if name in self.pidmap:
                 return True
         return False
-
-    def __getitem__(self, name):
-        return self.get(name)
-
-    def __contains__(self, name):
-        return self.has(name)
+    # Syntax sugar for name in self
+    __contains__ = has
 
 
 if __name__ == '__main__':
 
 
 if __name__ == '__main__':
@@ -253,6 +255,9 @@ if __name__ == '__main__':
     assert 'test-service' in manager.services
     assert 'test-service' not in manager.namemap
     assert not get('test-service').running
     assert 'test-service' in manager.services
     assert 'test-service' not in manager.namemap
     assert not get('test-service').running
+    assert manager['test-service'] == get('test-service')
+    assert has('test-service')
+    assert 'test-service' in manager
 
     register('test-service-2', ('sleep', '3'), notify, False)
     assert 'test-service-2' in manager.services
 
     register('test-service-2', ('sleep', '3'), notify, False)
     assert 'test-service-2' in manager.services