Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
path: root/bin/sugar-shell
blob: 3d32de332f3dcd06c35ab49aeaaec4b0195bac80 (plain)
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
98
99
100
101
102
#!/usr/bin/env python
# Copyright (C) 2006, 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., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA

import os
import gettext
import logging

import gtk
import gobject
import dbus.glib

gtk.gdk.threads_init()
dbus.glib.threads_init()

from sugar import logger
from sugar.profile import get_profile

from jarabe.view import shell
from jarabe.shellservice import ShellService
from jarabe.intro.window import IntroWindow
from jarabe.intro.window import create_profile
from jarabe.session import get_session_manager
from jarabe.nmservice import NMService
from jarabe.model import sound
from jarabe.model import screen
from jarabe import logsmanager
from jarabe import config

def _shell_started_cb():
    screen.set_dcon_freeze(0)

    if os.path.isfile(os.path.expanduser('~/.sugar-update')):
        home_box = shell.get_instance().home_window.get_home_box()
        home_box.show_software_updates_alert()

def main():
    gobject.idle_add(_shell_started_cb)

    try:
        logsmanager.setup()
    except Exception, e:
        # logs setup is not critical; it should not prevent sugar from
        # starting if (for example) the disk is full or read-only.
        print 'Log setup failed: %s' % e

    logger.start('shell')

    gettext.bindtextdomain('sugar', config.locale_path)
    gettext.textdomain('sugar')

    icons_path = os.path.join(config.data_path, 'icons')
    gtk.icon_theme_get_default().append_search_path(icons_path)

    # Do initial setup if needed
    if not get_profile().is_valid():
        if 'SUGAR_PROFILE_NAME' in os.environ:
            create_profile(os.environ['SUGAR_PROFILE_NAME'])
        else:
            win = IntroWindow()
            win.show_all()
            gtk.main()

    # set timezone    
    if get_profile().timezone is not None:    
        os.environ['TZ'] = get_profile().timezone

    # TODO: move initializations from the Shell constructor to a start() method
    shell.get_instance()
    ShellService()

    session_manager = get_session_manager()
    session_manager.start()

    try:
        nm_service = NMService()
    except dbus.DBusException:
        logging.error("Network manager is already running.")

    sound.restore()

    try:
        gtk.main()
    except KeyboardInterrupt:
        print 'Ctrl+C pressed, exiting...'

    sound.save()

main()