Обнаружить выход пользователя из системы / завершение работы в Python / GTK под Linux - SIGTERM / HUP не получен

Хорошо, это, вероятно, трудный вопрос, у меня есть приложение pyGTK, которое имеет случайные сбои из-за ошибок X Window, которые я не могу отловить / контролировать.

Итак, я создал оболочку, которая перезапускает приложение, как только оно обнаруживает сбой, теперь возникает проблема: когда пользователь выходит из системы или выключает систему, приложение выходит со статусом 1. Но на некоторых ошибках X оно тоже так делает.

Итак, я попытался буквально что-нибудь, чтобы поймать выключение / выход из системы, но безуспешно, вот что я попробовал:

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")

Не один из этих успехов, есть ли какой-нибудь низкоуровневый способ обнаружения выключения системы? Google не нашел ничего связанного с этим.

Я думаю, что должен быть способ, я прав? : /

РЕДАКТИРОВАТЬ: ОК, больше вещей.

Я создал этот сценарий оболочки:

#!/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

А также создал файл .desktop для его запуска:

[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 

Обычно это должно создать файл термина при выходе из системы и файл hup, когда он был запущен с &. Но не в моей Системе. GDM вообще не заботится о скрипте, когда я перезаписываю его, он все еще работает.

Я также пытался использоватьshopt -s huponexitбез успеха.

EDIT2:
Также вот еще немного информации о реальном коде, все выглядит примерно так:

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

Поток такой:

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

Сейчас на выключении,start program return 1. Это означает, что либо он сделал hanup, либо родительский процесс завершен, основная проблема состоит в том, чтобы выяснить, какой из этих двух только что произошел. X Ошибки приводят к 1 тоже. Ловушка в шеллскрипте не работает.

Если вы хотите взглянуть на реальный код, проверьте его на GitHub:
http://github.com/BonsaiDen/Atarashii

Ответы на вопрос(2)

Ваш ответ на вопрос