[Stackless] Issue #28: enhance tasklet.bind() (stackless-dev/stackless)
Anselm Kruis
issues-reply at bitbucket.org
Mon Dec 2 14:25:12 CET 2013
New issue 28: enhance tasklet.bind()
https://bitbucket.org/stackless-dev/stackless/issue/28/enhance-taskletbind
Anselm Kruis:
This issue proposes an enhancement for the method tasklet.bind(). It adds the functionality of tasklet.setup() except the implicit tasklet.insert() to bind().
The details were discussed on the Stackless mailing list in the thread http://www.stackless.com/pipermail/stackless/2013-November/005899.html. The credits for the idea to enhance tasklet.bind() go to Kristján: http://www.stackless.com/pipermail/stackless/2013-November/005911.html.
## Details ##
Currently tasklet.bind() requires a single positional argument. Kristján proposes to add two optional arguments. The signature of bind then becomes
```def bind(self, function, args=None, keywords=None):```
If both args and keywords are None, bind() behaves as before.
Otherwise presence of args and/or keywords as being non-None, would then
imply a setup, without scheduling the tasklet. In this case, if function is None the value of self.tempval is used as function, similar to tasklet.setup(). If self.tempval is None too, bind() raises RuntimeError('the tasklet was not bound to a function')
With this change tasklet.bind() and tasklet.insert() become the "atomic" building blocks for tasklet creation. tasklet.setup() is then equivalent to
```
#!python
def setup(self, *args, **kw):
self.bind(None, args, kw)
return self.insert()
```
## Plan ##
1. Implement the proposal and appropriate unit tests
2. Update the documentation in Doc/library/stackless/tasklets.rst and tasklet_state_chart.png
3. Update Stackless/changelog.txt
4. Port the change to Stackless version 3.x
Any objections?
Responsible: akruis
More information about the Stackless
mailing list