Detectar logout / desligamento do usuário em Python / GTK no Linux - SIGTERM / HUP não recebido

OK, é presumivelmente difícil, eu tenho um aplicativo pyGTK que tem falhas aleatórias devido a erros do X Window que não consigo capturar / controlar.

Então, criei um invólucro que reinicia o aplicativo assim que detecta uma falha. Agora surge o problema. Quando o usuário efetua logout ou encerra o sistema, o aplicativo sai com o status 1. Mas em alguns erros do X também ocorre.

Então, tentei literalmente qualquer coisa para travar o desligamento / logout, sem sucesso, eis o que tentei:

import pygtk
import gtk
import sys


class Test(gtk.Window):
    def delete_event(self, widget, event, data=None):
        open("delete_event", "wb")

    def destroy_event(self, widget, data=None):
        open("destroy_event", "wb")

    def destroy_event2(self, widget, event, data=None):
        open("destroy_event2", "wb")

    def __init__(self):
        gtk.Window.__init__(self, gtk.WINDOW_TOPLEVEL)
        self.show()
        self.connect("delete_event", self.delete_event)
        self.connect("destroy", self.destroy_event)
        self.connect("destroy-event", self.destroy_event2)      

def foo():
    open("add_event", "wb")

def ex():
    open("sys_event", "wb")


from signal import *
def clean(sig):
    f = open("sig_event", "wb")
    f.write(str(sig))
    f.close()
    exit(0)

for sig in (SIGABRT, SIGILL, SIGINT, SIGSEGV, SIGTERM):
    signal(sig, lambda *args: clean(sig))


def at():
    open("at_event", "wb")

import atexit
atexit.register(at)

f = Test()
sys.exitfunc = ex
gtk.quit_add(gtk.main_level(), foo)

gtk.main()
open("exit_event", "wb")

Nenhuma delas é bem-sucedida; existe alguma maneira de baixo nível de detectar o desligamento do sistema? O Google não encontrou nada relacionado a isso.

Eu acho que deve haver uma maneira, estou certo? : /

EDITAR: OK, mais coisas.

Eu criei este script de shell:

#!/bin/bash


trap test_term TERM
trap test_hup HUP


test_term(){
    echo "teeeeeeeeeerm" >~/Desktop/term.info
    exit 0
}

test_hup(){
    echo "huuuuuuuuuuup" >~/Desktop/hup.info
    exit 1
}

while [ true ]
do
    echo "idle..."
    sleep 2
done

E também criou um arquivo .desktop para executá-lo:

[Desktop Entry]
Name=Kittens
GenericName=Kittens
Comment=Kitten Script
Exec=kittens
StartupNotify=true
Terminal=false
Encoding=UTF-8
Type=Application
Categories=Network;GTK;
Name[de_DE]=Kittens 

Normalmente, isso deve criar o arquivo de termo no logout e o arquivo hup quando ele foi iniciado com &. Mas não no meu sistema. O GDM não se importa com o script, quando eu me logar novamente, ele ainda está em execução.

Eu também tentei usarshopt -s huponexit, sem sucesso.

EDIT2:
Também aqui estão mais algumas informações sobre o código real, a coisa toda se parece com isso:

Wrapper Script, that catches errors and restarts the programm
    -> Main Programm with GTK Mainloop
        -> Background Updater Thread

O fluxo é assim:

Start Wrapper
-> enter restart loop
    while restarts < max:
        -> start program
            -> check return code
                -> write error to file or exit the wrapper on 0

Agora no desligamento,start program return 1. Isso significa que ele terminou ou o processo pai foi encerrado, o principal problema é descobrir qual desses dois acabou de acontecer. Erros X resultam em 1 também. Interceptar o shellscript não funciona.

Se você quiser dar uma olhada no código real, confira no GitHub:
http://github.com/BonsaiDen/Atarashii

questionAnswers(2)

yourAnswerToTheQuestion