~aw/sabayon-template/trunk

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