[Twisted-Python] Having some kind of "finally" clause
Hi! I would like to do something like this with Twisted: x.open() try: x.someoperations() x.otheroperations() finally: x.close() I could do something like this : d = open_and_get_x() d.addCallback(someoperations) d.addCallback(otheroperations) d.addBoth(closeAndReRaiseIfError) return d Each callback would return x to let the next callback proceed it. However, if there is an error, I have no "x" to close in "closeAndReRaiseIfError". How can I do that? Thanks.
On Mon, 22 Sep 2008 15:12:53 +0200, Vincent Bernat <bernat@luffy.cx> wrote:
Hi!
I would like to do something like this with Twisted:
x.open() try: x.someoperations() x.otheroperations() finally: x.close()
I could do something like this :
d = open_and_get_x() d.addCallback(someoperations) d.addCallback(otheroperations) d.addBoth(closeAndReRaiseIfError) return d
Each callback would return x to let the next callback proceed it. However, if there is an error, I have no "x" to close in "closeAndReRaiseIfError". How can I do that?
There are a lot of ways. You could make x an attribute of a shared object, or you could close over it in the first callback to create the "finally" handler, or you could pass it along as an argument to the `addBoth´ call (again, in the first callback). Notice that there's a slight difference between the two code examples you gave. The first won't close x in response to errors from `x.open()´, but `closeAndReRaiseIfError´ will be called even for errors from `open_and_get_x´. If you only add the finally handler in the first callback attached to `d´, then this difference goes away. Jean-Paul
Thanks.
_______________________________________________ Twisted-Python mailing list Twisted-Python@twistedmatrix.com http://twistedmatrix.com/cgi-bin/mailman/listinfo/twisted-python
OoO En ce début d'après-midi ensoleillé du lundi 22 septembre 2008, vers 15:23, Jean-Paul Calderone <exarkun@divmod.com> disait :
There are a lot of ways. You could make x an attribute of a shared object, or you could close over it in the first callback to create the "finally" handler, or you could pass it along as an argument to the `addBoth´ call (again, in the first callback).
Thanks for the tip. I am now using the last approach. -- /* Nobody will ever see this message :-) */ panic("Cannot initialize video hardware\n"); 2.0.38 /usr/src/linux/arch/m68k/atari/atafb.c
participants (2)
-
Jean-Paul Calderone
-
Vincent Bernat