<div dir="ltr">thank you for the help, <div><br></div><div>With the fix it works now; i have one problem left, is that when i start the server from the gui, the server runs, but the (Qt/PySide) gui becomes unresponsive. Before, i started the web app and server in a separate thread (and had the scheduler run in that), but that probably  wont work if threads are replaced with tasklets (if i understood the monkeypatching somewhat). </div>
<div><br></div><div>Does anyone have any ideas how to solve that (to keep the gui responsive, also to be able to stop the server)?  Before i tried multiprocessing, but that led to a lot of servers running :-)</div><div><br>
</div><div>In another experiment I have overridden the server loop serve_forever() to call stackless.schedule() (or rather tasklets.schedule() in the code above). This seems to work apart from an occasional crash (weird attribute error for (my subclass of) WSGIServer).</div>
<div><br></div><div>Also thanks a lot for putting up the 2.7.5 64 bit binaries!! It finally let me run the demo on my Windows 8 laptop (no idea why, something to do with PySide 32bit and win8 probably)</div><div><br></div>
<div>Cheers, Lars</div><div><br></div></div><div class="gmail_extra"><br><br><div class="gmail_quote">On Mon, Dec 2, 2013 at 12:36 AM, Kristján Valur Jónsson <span dir="ltr"><<a href="mailto:kristjan@ccpgames.com" target="_blank">kristjan@ccpgames.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">




<div>
<div style="direction:ltr;font-size:10pt;font-family:Tahoma">
<p>A bug!</p>
<p>in threadpool.py, replace the final line with:</p>
<p> </p>
<p>return tasklet_call(wrapped, dispatcher=dispatcher, timeout=timeout, onOrphaned=onOrphaned)<br>
</p>
<p>Needs more unittests :)</p>
<p> </p>
<p>K</p>
<div style="font-size:16px;font-family:Times New Roman"><div class="im">
<hr>
<div style="DIRECTION:ltr"><font color="#000000" face="Tahoma"><b>From:</b> <a href="mailto:stackless-bounces@stackless.com" target="_blank">stackless-bounces@stackless.com</a> [<a href="mailto:stackless-bounces@stackless.com" target="_blank">stackless-bounces@stackless.com</a>] on behalf of lars van Gemerden [<a href="mailto:lars@rational-it.com" target="_blank">lars@rational-it.com</a>]<br>

<b>Sent:</b> Sunday, December 01, 2013 1:58 PM<br>
<b>To:</b> The Stackless Python Mailing List<br>
<b>Subject:</b> Re: [Stackless] monkeypatching<br>
</font><br>
</div>
<div></div>
</div><div><div><div class="h5">
<div dir="ltr">OK, thanks for the input, 
<div><br>
</div>
<div>i am trying to get this to work, but i might have found a bug (which i find hard to debug):
<div><br>
</div>
<div>i have reimplemented the code above as:</div>
<div>--------------------------------------------------------------</div>
<div>
<div>import asyncore, traceback, sys, logging</div>
<div><br>
</div>
<div>import stacklesslib.main</div>
<div>import stacklesslib.app</div>
<div><br>
</div>
<div># the unittests use time.time() for various time tests.</div>
<div># Therefore, we must make sure that main uses this</div>
<div>from time import time as elapsed_time</div>
<div>stacklesslib.main.elapsed_time = elapsed_time</div>
<div><br>
</div>
<div>class MonkeyTasklets(object):</div>
<div>    </div>
<div>    _stop = False</div>
<div>    </div>
<div>    stacklesslib.app.install_stackless()</div>
<div>            </div>
<div>    @classmethod</div>
<div>    def run(cls, world, webserver = None, maxcount = None): #param killer is ignored</div>
<div>        world.flowmodel.start()</div>
<div>        if webserver:</div>
<div>            cls.server = webserver.start_server(world_model = world) #starts a tasklet for running the webserver</div>
<div>        counter = 0</div>
<div>        while not cls._stop or counter > maxcount:</div>
<div>            counter += 1</div>
<div>            tick_time = elapsed_time()    </div>
<div>            try:</div>
<div>                stacklesslib.main.mainloop.loop()</div>
<div>            except Exception as e:</div>
<div>                import asyncore</div>
<div>                if isinstance(e, ReferenceError):</div>
<div>                    print("run:EXCEPTION", str(e), asyncore.socket_map)</div>
<div>                else:</div>
<div>                    print("run:EXCEPTION", asyncore.socket_map)</div>
<div>                    traceback.print_exc()</div>
<div>                sys.exc_clear()</div>
<div>        world.flowmodel.stop()</div>
<div>    </div>
<div>    @classmethod</div>
<div>    def schedule(cls):</div>
<div>        stackless.schedule() </div>
<div>        </div>
<div>    @classmethod</div>
<div>    def tasklet(cls, func):</div>
<div>        return stackless.tasklet(func)</div>
<div>    </div>
<div>    @classmethod</div>
<div>    def stop(cls):</div>
<div>        if hasattr(cls, "server"):</div>
<div>            cls.server.stop()</div>
<div>        cls._stop = True</div>
<div>        </div>
<div><br>
</div>
<div>tasklets = MonkeyTasklets</div>
<div><br>
</div>
<div>--------------------------------------------------------------<br>
</div>
<div></div>
<div> and i get the exception:</div>
</div>
<div><br>
</div>
<div>File <span style="FONT-WEIGHT:600;COLOR:rgb(0,0,102)">"d:\Documents\Code\python\floware\server\bottle.py"</span>, line 641, in
<span style="FONT-WEIGHT:600;COLOR:rgb(34,119,34)">run</span><br>
  <span style="FONT-STYLE:italic">run(self, **kwargs)</span><br>
File <span style="FONT-WEIGHT:600;COLOR:rgb(0,0,102)">"d:\Documents\Code\python\floware\server\bottle.py"</span>, line 2720, in
<span style="FONT-WEIGHT:600;COLOR:rgb(34,119,34)">run</span><br>
  <span style="FONT-STYLE:italic">server.run(app)</span><br>
File <span style="FONT-WEIGHT:600;COLOR:rgb(0,0,102)">"d:\Documents\Code\python\floware\server\webserver.py"</span>, line 329, in
<span style="FONT-WEIGHT:600;COLOR:rgb(34,119,34)">run</span><br>
  <span style="FONT-STYLE:italic">self.server.serve_forever()</span><br>
File <span style="FONT-WEIGHT:600;COLOR:rgb(0,0,102)">"C:\Python27\lib\SocketServer.py"</span>, line 236, in
<span style="FONT-WEIGHT:600;COLOR:rgb(34,119,34)">serve_forever</span><br>
  <span style="FONT-STYLE:italic">poll_interval)</span><br>
File <span style="FONT-WEIGHT:600;COLOR:rgb(0,0,102)">"C:\Python27\lib\SocketServer.py"</span>, line 155, in
<span style="FONT-WEIGHT:600;COLOR:rgb(34,119,34)">_eintr_retry</span><br>
  <span style="FONT-STYLE:italic">return func(*args)</span><br>
File <span style="FONT-WEIGHT:600;COLOR:rgb(0,0,102)">"d:\Documents\Code\python\floware\stacklesslib\replacements\select.py"</span>, line 27, in
<span style="FONT-WEIGHT:600;COLOR:rgb(34,119,34)">select</span><br>
  <span style="FONT-STYLE:italic">return stacklesslib.threadpool.call_on_thread(real_select.select, args, kwargs)</span><br>
File <span style="FONT-WEIGHT:600;COLOR:rgb(0,0,102)">"d:\Documents\Code\python\floware\stacklesslib\threadpool.py"</span>, line 123, in
<span style="FONT-WEIGHT:600;COLOR:rgb(34,119,34)">call_on_thread</span><br>
  <span style="FONT-STYLE:italic">return tasklet_call(wrapped, dispatcher, timeout=timeout, onOrphaned=onOrphaned)</span><br>
File <span style="FONT-WEIGHT:600;COLOR:rgb(0,0,102)">"d:\Documents\Code\python\floware\stacklesslib\util.py"</span>, line 209, in
<span style="FONT-WEIGHT:600;COLOR:rgb(34,119,34)">tasklet_call</span><br>
  <span style="FONT-STYLE:italic">return channel_wait(chan, timeout)</span><br>
File <span style="FONT-WEIGHT:600;COLOR:rgb(0,0,102)">"d:\Documents\Code\python\floware\stacklesslib\util.py"</span>, line 53, in
<span style="FONT-WEIGHT:600;COLOR:rgb(34,119,34)">channel_wait</span><br>
  <span style="FONT-STYLE:italic">return chan.receive()</span><br>
File <span style="FONT-WEIGHT:600;COLOR:rgb(0,0,102)">"d:\Documents\Code\python\floware\stacklesslib\util.py"</span>, line 192, in
<span style="FONT-WEIGHT:600;COLOR:rgb(34,119,34)">helper</span><br>
  <span style="FONT-STYLE:italic">result = function(*args, **kwargs)</span><br>
<br>
<span style="FONT-WEIGHT:600;COLOR:rgb(0,0,102)">TypeError: wrapped() argument after * must be a sequence, not function</span></div>
<div>--------------------------------------------------------------<span style="FONT-SIZE:large;FONT-WEIGHT:600;COLOR:rgb(0,0,102)"><br>
</span></div>
<div><span style="COLOR:rgb(0,0,102)">is this something i am doing wrong or indeed a buggy in stacklesslib and if so, how can it be fixed?</span></div>
<div><span style="COLOR:rgb(0,0,102)"><br>
</span></div>
<div><span style="COLOR:rgb(0,0,102)">Cheers, Lars</span></div>
</div>
</div>
</div></div><div class="gmail_extra"><div><div class="h5"><br>
<br>
<div class="gmail_quote">On Sun, Dec 1, 2013 at 4:05 AM, Richard Tew <span dir="ltr">
<<a href="mailto:richard.m.tew@gmail.com" target="_blank">richard.m.tew@gmail.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="PADDING-LEFT:1ex;MARGIN:0px 0px 0px 0.8ex;BORDER-LEFT:#ccc 1px solid">
latest stacklesslib, i mean.<br>
<div>
<div><br>
On 12/1/13, Richard Tew <<a href="mailto:richard.m.tew@gmail.com" target="_blank">richard.m.tew@gmail.com</a>> wrote:<br>
> Hi Lars,<br>
><br>
> stacklessio is internal ccp stuff.<br>
><br>
> main.py in stacklesslib is pretty much all you need to understand,<br>
> beyond calling patch_all().  It is a scheduler, and makes your Open<br>
> scheduler redundant.<br>
><br>
> I suggest you get the latest stacklessio from:<br>
><br>
> <a href="https://bitbucket.org/krisvale/stacklesslib" target="_blank">https://bitbucket.org/krisvale/stacklesslib</a><br>
><br>
> And then you check out test / teststdlibunittests.py, which is a short<br>
> example of monkey patching and running the stacklesslib scheduler.<br>
><br>
> Cheers,<br>
> Richard.<br>
><br>
> On 12/1/13, lars van Gemerden <<a href="mailto:lars@rational-it.com" target="_blank">lars@rational-it.com</a>> wrote:<br>
>> sorry,<br>
>><br>
>> patch_all seemed to simple, question was a bit rethoric ;-) tried it 2<br>
>> mins<br>
>> after pressing send just in case and indeed no cigar.<br>
>><br>
>> I am trying to get this demo running and all kinds of last minute #### is<br>
>> popping up.<br>
>><br>
>> I tried reading the source but it doesn't click; i am not familiar with<br>
>> using sockets etc. at all.<br>
>><br>
>> e.g.<br>
>><br>
>> - do i need 'stacklessio'?<br>
>> - can i (essentially) just put a stackless.schedule() (or<br>
>> OpenTasklets.schedule() in the code below) in the serve_forever loop?<br>
>> - will this work at all with an adapted scheduler like this:<br>
>><br>
>> class OpenTasklets(object):<br>
>><br>
>>     _stop = False<br>
>><br>
>>     @classmethod<br>
>>     def run(cls, maxcount = None):<br>
>>         cls.schedule_channel = stackless.channel()<br>
>>         cls.schedule_channel.preference = 1<br>
>>         counter = 0<br>
>>         OpenTasklets._stop = False<br>
>>         while stackless.getruncount() != 1:<br>
>>             stackless.run()<br>
>>             cls.reschedule(cls._stop or (maxcount and counter ><br>
>> maxcount))<br>
>>             counter += 1<br>
>><br>
>>     @classmethod<br>
>>     def schedule(cls):<br>
>>         if cls.schedule_channel.receive():<br>
>>             raise TaskletExit<br>
>><br>
>>     @classmethod<br>
>>     def reschedule(cls, stop = False):<br>
>>         while cls.schedule_channel.balance < 0:<br>
>>             cls.schedule_channel.send(stop)<br>
>><br>
>> Any help is appreciated ..<br>
>><br>
>> Lars<br>
>><br>
>><br>
>><br>
>><br>
>> On Sat, Nov 30, 2013 at 8:53 PM, Richard Tew<br>
>> <<a href="mailto:richard.m.tew@gmail.com" target="_blank">richard.m.tew@gmail.com</a>>wrote:<br>
>><br>
>>> Lars :-)<br>
>>><br>
>>> Yes, there is no documentation for stacklesslib yet.  To use it, you<br>
>>> really need to be willing to read the source code.<br>
>>><br>
>>> You should already know whether calling patch_all would be enough.  It<br>
>>> would have been something you could have tried immediately, rather<br>
>>> than asking the list and waiting.<br>
>>><br>
>>> Cheers,<br>
>>> Richard.<br>
>>><br>
>>> On 11/30/13, lars van Gemerden <<a href="mailto:lars@rational-it.com" target="_blank">lars@rational-it.com</a>> wrote:<br>
>>> > Hi all,<br>
>>> ><br>
>>> > I though i could avoid it to run my demo but it seems i need to let<br>
>>> > the<br>
>>> > webserver (simple server?, single thread, 'bottle' micro framework)<br>
>>> > yield<br>
>>> > to the scheduler i am using. I have downloaded stacklesslib 1.0.3, but<br>
>>> > can't find any documentation to help with monkeypatching.<br>
>>> ><br>
>>> > - Do i just run patch_all at the start of the program?<br>
>>> ><br>
>>> > Any help is very welcome ..<br>
>>> ><br>
>>> > Cheers, Lars<br>
>>> ><br>
>>> > --<br>
>>> > ====================================<br>
>>> > Lars van Gemerden<br>
>>> > <a href="mailto:lars@rational-it.com" target="_blank">lars@rational-it.com</a><br>
>>> > <a href="tel:%2B31%206%2026%2088%2055%2039" value="+31626885539" target="_blank">
+31 6 26 88 55 39</a><br>
>>> > ====================================<br>
>>> ><br>
>>><br>
>>> _______________________________________________<br>
>>> Stackless mailing list<br>
>>> <a href="mailto:Stackless@stackless.com" target="_blank">Stackless@stackless.com</a><br>
>>> <a href="http://www.stackless.com/mailman/listinfo/stackless" target="_blank">
http://www.stackless.com/mailman/listinfo/stackless</a><br>
>>><br>
>><br>
>><br>
>><br>
>> --<br>
>> ====================================<br>
>> Lars van Gemerden<br>
>> <a href="mailto:lars@rational-it.com" target="_blank">lars@rational-it.com</a><br>
>> <a href="tel:%2B31%206%2026%2088%2055%2039" value="+31626885539" target="_blank">
+31 6 26 88 55 39</a><br>
>> ====================================<br>
>><br>
><br>
<br>
_______________________________________________<br>
Stackless mailing list<br>
<a href="mailto:Stackless@stackless.com" target="_blank">Stackless@stackless.com</a><br>
<a href="http://www.stackless.com/mailman/listinfo/stackless" target="_blank">http://www.stackless.com/mailman/listinfo/stackless</a><br>
</div>
</div>
</blockquote>
</div>
<br>
<br clear="all">
<div><br>
</div>
-- <br>
====================================<br>
Lars van Gemerden<br>
<a href="mailto:lars@rational-it.com" target="_blank">lars@rational-it.com</a><br>
</div></div><span style="WHITE-SPACE:nowrap"><a href="tel:%2B31%206%2026%2088%2055%2039" value="+31626885539" target="_blank">+31 6 26 88 55 39</a><a title="Call: +31 6 26 88 55 39" style="OVERFLOW:hidden;BORDER-TOP:medium none;min-height:16px;BORDER-RIGHT:medium none;WIDTH:16px;VERTICAL-ALIGN:middle;WHITE-SPACE:nowrap;BORDER-BOTTOM:medium none;FLOAT:none;MARGIN:0px;BORDER-LEFT:medium none;DISPLAY:inline" href="#142b0afb3d212348_"><img title="Call: +31 6 26 88 55 39" style="OVERFLOW:hidden;BORDER-TOP:medium none;min-height:16px;BORDER-RIGHT:medium none;WIDTH:16px;VERTICAL-ALIGN:middle;WHITE-SPACE:nowrap;BORDER-BOTTOM:medium none;FLOAT:none;MARGIN:0px;BORDER-LEFT:medium none;DISPLAY:inline"></a></span><br>

==================================== </div>
</div>
</div>
</div>
</div>

<br>_______________________________________________<br>
Stackless mailing list<br>
<a href="mailto:Stackless@stackless.com">Stackless@stackless.com</a><br>
<a href="http://www.stackless.com/mailman/listinfo/stackless" target="_blank">http://www.stackless.com/mailman/listinfo/stackless</a><br></blockquote></div><br><br clear="all"><div><br></div>-- <br>====================================<br>
Lars van Gemerden<br><a href="mailto:lars@rational-it.com">lars@rational-it.com</a><br>+31 6 26 88 55 39<br>====================================
</div>