Hi,

I have following class and problem is that Thread is started but after a short time it is something like paused.
I could not find any reason why.

GUI looks like Window -> Box -> Textview and Cancel Button in VBox widget.

The aim is to open this window and run in thread some application and output of that application will be logged in TextView widget

Do you have any idea?

# -*- coding: utf-8 -*-
"""
Created on Wed Apr  3 13:16:47 2013

@author: Petr Hracek
"""

import sys
import logging
import mainWindow
import pathWindow
import argparse
import threading
from devassistant.logger import logger
from gi.repository import Gtk
from devassistant import path_runner
from devassistant import exceptions

class RunLoggingHandler(logging.Handler):
    def __init__(self, textbuffer):
        logging.Handler.__init__(self)
        self.textbuffer = textbuffer

    def emit(self, record):
        text_iter = self.textbuffer.get_end_iter()
self.textbuffer.insert(text_iter,"{0}\n".format(record.getMessage()))

class ThreadDevAssistantClass(threading.Thread):
    def __init__(self, runWin):
        threading.Thread.__init__(self)
        self.runWin = runWin

    def run(self):
        self.tlh = RunLoggingHandler(self.runWin.textbuffer)
        logger.addHandler(self.tlh)
path = self.runWin.assistant.get_selected_subassistant_path(**self.runWin.parent.kwargs)
        pr = path_runner.PathRunner(path, self.runWin.parent.kwargs)
        try:
            # This is not thread
            pr.run()
        except exceptions.ExecutionException as ex:
            pass

class runWindow(object):
    def __init__(self,  parent, finalWindow, builder, assistant):
        self.parent = parent
        self.finalWindow = finalWindow
        self.runWindow = builder.get_object("runWindow")
        self.textViewLog = builder.get_object("textViewLog")
        self.textbuffer = self.textViewLog.get_buffer()
        self.textViewLog.set_wrap_mode(Gtk.WrapMode.WORD_CHAR)
        self.assistant = assistant

    def open_window(self, widget, data=None):
        dirname, projectname = self.parent.pathWindow.get_data()
        self.runWindow.show_all()

    def visibility_event(self, widget, data=None):
        logger.info("Visibility event")
        thread = ThreadDevAssistantClass(self)
        thread.start()

On 05/16/2013 11:00 AM, Petr Hracek wrote:
Hi Timo,

thank it helps during the showing.
But I think that my way was wrong.

Let's say that I would like to run some command which takes 10minutes (like yum installation under Linux)
and I would like to track in TextView all actions.

I think that python thread would be needed, right?
How to solve that issues?

Or are there any other possibilities?

Best regards / S pozdravem
Petr Hracek

On 05/14/2013 10:22 AM, Timo wrote:
Op 14-05-13 09:34, Petr Hracek schreef:
Hi folks,

I have a little bit simple question
In Glade3 I have GtkWindow object
with GtkButton and TextView widget.

What is my goal.
I would like to run some actions when all widgets (like TextView, GtkButton) are really visible.

It means when this condition is satisfied then some actions are run and output of that actions
are logged into TextView widget.

Actually now I could not find what event should be used for.
It should be some event of GtkWindow, right?

There are some events like visibility_event or show_event, ...
Any advises?
You probable want the realize signal.

window.connect("realize", on_realize)

This will be called when the window is fully shown. This can also be used for seperate widgets as it's a GtkWidget signal.

Timo


_______________________________________________
pygtk mailing list   pygtk@daa.com.au
http://www.daa.com.au/mailman/listinfo/pygtk
Read the PyGTK FAQ: http://faq.pygtk.org/

_______________________________________________
pygtk mailing list   pygtk@daa.com.au
http://www.daa.com.au/mailman/listinfo/pygtk
Read the PyGTK FAQ: http://faq.pygtk.org/


--
Best regards / S pozdravem
Petr Hracek

_______________________________________________
pygtk mailing list   pygtk@daa.com.au
http://www.daa.com.au/mailman/listinfo/pygtk
Read the PyGTK FAQ: http://faq.pygtk.org/

Reply via email to