[Kde-bindings] Using threads with QtRuby

Richard Dale rdale at foton.es
Fri Feb 5 17:02:50 UTC 2010


On Friday 05 February 2010 04:55:28 pm Uriel wrote:
> Thanks for your answers.
> 
> > Thats strange because Qt on my system uses to same glib event loop as
> > GTK uses
> > and QtRuby still doesn't work well with Ruby threads as you say. Maybe
> > GTK
> > ruby is using some hook to periodically run code in threads I don't know.
> >
> > Threads in Ruby 1.8.x are really just broken, but it might be possible
> > to get
> > QtRuby and Ruby threads working with Ruby 1.9.x.
> 
> Sorry for not telling you about versions of packages I'm using.
> I'm on ArchLinux and have latest build of all packages. So Ruby is
> 1.9.1, QtRuby is in package kdebindings-ruby 4.3.4, Qt is 4.5.3, glib is
> 2.22.4 and GTK is 2.18.6 if it's important. :)
> So then I'll try to find out how GtkRuby works with threads.
> 
> > This is basically what I do to make threads work which seems to work
> > great.  By calling Ruby's sleep method in a Timer, you allow the Ruby
> > thread scheduler to run:
> 
> This is really works great for me, thank you very much.
> But would it be wrong to go a bit more further and add some extra code
> to Qt::Application?
> Something like that:
> 
> class Qt::Application
> protected
>    def timerEvent(ev)
>      sleep 0.001
>    end
> public
>    alias :__oldExec :exec
>    def exec
>      startTimer 0
>      __oldExec
>    end
> end
> 
> It can be more 'advanced': start timer only when new instance of the
> Thread class is created and stop when there is no more threads left.
Looks a good idea. Maybe rather than alias the standard exec() we could add an 
exec_with_threads() method?

-- Richard



More information about the Kde-bindings mailing list