Mercurial > piecrust2
view piecrust/events.py @ 414:c4b3a7fd2f87
bake: Make pipeline processing multi-process.
Not many changes here, as it's pretty straightforward, but an API change for
processors so they know if they're being initialized/disposed from the main
process or from one of the workers. This makes it possible to do global stuff
that has side-effects (e.g. create a directory) vs. doing in-memory stuff.
author | Ludovic Chabant <ludovic@chabant.com> |
---|---|
date | Sat, 20 Jun 2015 19:20:30 -0700 |
parents | f485ba500df3 |
children | f070a4fc033c |
line wrap: on
line source
class Event(object): def __init__(self): self._handlers = [] def __iadd__(self, handler): self._handlers.append(handler) return self def __isub__(self, handler): self._handlers.remove(handler) return self def fire(self, *args, **kwargs): # Make a copy of the handlers list in case some handler removes # itself while executing. handlers = list(self._handlers) for handler in handlers: handler(*args, **kwargs)