1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
|
#!/usr/bin/env python
# -*- mode: python -*-
#
# Copyright (C) 2005 Red Hat, Inc.
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
#
if __name__ == '__main__':
import os
import sys
import optparse
import pygtk; pygtk.require('2.0');
import gtk
from sabayon import debuglog
from sabayon import config
from sabayon import errors
from sabayon import util
from sabayon import sessionwindow
def dprint (fmt, *args):
debuglog.debug_log (False, debuglog.DEBUG_LOG_DOMAIN_SABAYON_SESSION, fmt % args)
def mprint (fmt, *args):
debuglog.debug_log (True, debuglog.DEBUG_LOG_DOMAIN_SABAYON_SESSION, fmt % args)
util.init_gettext ()
option_parser = optparse.OptionParser (usage="usage: %prog [--admin-log-config FILE] [--readable-log-config FILE] <profile_name> <profile_path> <display_number>")
# FIXME: say that "man sabayon" will give you the
# syntax for the debug log config file.
option_parser.add_option ("--admin-log-config", dest="admin_log_config",
metavar="FILE",
help="File with options for the debug log (readable by the system administrator)")
option_parser.add_option ("--readable-log-config", dest="readable_log_config",
metavar="FILE",
help="File with options for the debug log (readable by Sabayon's helper processes)")
options, args = option_parser.parse_args ()
try:
admin_log_config_filename = options.admin_log_config or ("~/" + config.LOG_CONFIG_FILENAME)
if options.readable_log_config != None:
readable_log_config_filename = options.readable_log_config
else:
readable_log_config_filename = os.path.join (util.get_home_dir (), config.LOG_CONFIG_FILENAME)
debuglog.debug_log_load_configuration (readable_log_config_filename)
util.set_admin_log_config_filename (admin_log_config_filename)
util.set_readable_log_config_filename (readable_log_config_filename)
if len (args) != 3:
sys.stderr.write (_("Usage: %s <profile-name> <profile-path> <display-number>\n") % sys.argv[0])
sys.exit (util.EXIT_CODE_FATAL)
(profile_name, profile_path, display_number) = args
mprint ("Starting session window for profile_name='%s', profile_path='%s', display_number='%s'",
profile_name, profile_path, display_number)
window = sessionwindow.SessionWindow (profile_name, profile_path, display_number)
window.window.connect ("destroy", gtk.main_quit)
window.window.show ()
except errors.RecoverableApplyErrorException:
pass # this will exit the program below
except:
errors.errors_exit_with_fatal_exception (debuglog.DEBUG_LOG_DOMAIN_SABAYON_SESSION,
util.get_admin_log_config_filename ())
else:
# We put the call to gtk.main() *outside* the "try" block,
# since exceptions thrown in callbacks will not get caught
# here (i.e. the C stack won't be unrolled when an
# exception happens).
mprint ("Entering main loop. Wheeee!")
gtk.main ()
mprint ("Terminating")
if errors.errors_have_fatal_error ():
mprint ("Exiting abnormally; dumping log due to a fatal error")
debuglog.debug_log_dump_to_file (util.get_admin_log_config_filename (), sys.stderr)
sys.exit (util.EXIT_CODE_FATAL)
else:
errors.errors_exit_helper_normally (util.get_admin_log_config_filename ())
|