Commit 88709ccd authored by Denis Bilenko's avatar Denis Bilenko

start() no longer raises an exception if Greenlet was already started. it also...

start() no longer raises an exception if Greenlet was already started. it also now does nothing if the greenlet already exited (previously it would schedule another switch)
parent 0e0386be
...@@ -144,7 +144,7 @@ class Greenlet(greenlet): ...@@ -144,7 +144,7 @@ class Greenlet(greenlet):
self._exception = _NONE self._exception = _NONE
loop = hub.loop loop = hub.loop
self._notifier = loop.callback() self._notifier = loop.callback()
self._start_event = loop.callback() self._start_event = None
@property @property
def loop(self): def loop(self):
...@@ -152,11 +152,12 @@ class Greenlet(greenlet): ...@@ -152,11 +152,12 @@ class Greenlet(greenlet):
return self.parent.loop return self.parent.loop
def __nonzero__(self): def __nonzero__(self):
return self._start_event.pending or greenlet.__nonzero__(self) return self._start_event is not None and self._exception is _NONE
@property @property
def started(self): def started(self):
return self._start_event.pending or greenlet.__nonzero__(self) # DEPRECATED
return self.__nonzero__()
def ready(self): def ready(self):
"""Return true if and only if the greenlet has finished execution.""" """Return true if and only if the greenlet has finished execution."""
...@@ -215,7 +216,8 @@ class Greenlet(greenlet): ...@@ -215,7 +216,8 @@ class Greenlet(greenlet):
a) cancel the event that will start it a) cancel the event that will start it
b) fire the notifications as if an exception was raised in a greenlet b) fire the notifications as if an exception was raised in a greenlet
""" """
self._start_event.stop() if self._start_event is not None:
self._start_event.stop()
try: try:
greenlet.throw(self, *args) greenlet.throw(self, *args)
finally: finally:
...@@ -237,14 +239,15 @@ class Greenlet(greenlet): ...@@ -237,14 +239,15 @@ class Greenlet(greenlet):
def start(self): def start(self):
"""Schedule the greenlet to run in this loop iteration""" """Schedule the greenlet to run in this loop iteration"""
assert not self.started, 'Greenlet already started' if self._start_event is None:
self._start_event.start(self.switch) self._start_event = self.parent.loop.callback()
self._start_event.start(self.switch)
def start_later(self, seconds): def start_later(self, seconds):
"""Schedule the greenlet to run in the future loop iteration *seconds* later""" """Schedule the greenlet to run in the future loop iteration *seconds* later"""
assert not self.started, 'Greenlet already started' if self._start_event is None:
self._start_event = self.parent.loop.timer(seconds) self._start_event = self.parent.loop.timer(seconds)
self._start_event.start(self.switch) self._start_event.start(self.switch)
@classmethod @classmethod
def spawn(cls, *args, **kwargs): def spawn(cls, *args, **kwargs):
...@@ -294,7 +297,8 @@ class Greenlet(greenlet): ...@@ -294,7 +297,8 @@ class Greenlet(greenlet):
`Changed in version 0.13.0:` *block* is now ``True`` by default. `Changed in version 0.13.0:` *block* is now ``True`` by default.
""" """
self._start_event.stop() if self._start_event is not None:
self._start_event.stop()
if not self.dead: if not self.dead:
waiter = Waiter() waiter = Waiter()
self.parent.loop.run_callback(_kill, self, exception, waiter) self.parent.loop.run_callback(_kill, self, exception, waiter)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment