169 lines
		
	
	
		
			5.0 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			169 lines
		
	
	
		
			5.0 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
| #!/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 sys
 | |
| import os
 | |
| from ConfigParser import ConfigParser
 | |
| import gettext
 | |
| import signal
 | |
| 
 | |
| import pygtk
 | |
| pygtk.require('2.0')
 | |
| import gtk
 | |
| import gobject
 | |
| import gst
 | |
| 
 | |
| from sugar import env
 | |
| from sugar import logger
 | |
| from sugar.profile import get_profile
 | |
| 
 | |
| sys.path.insert(0, env.get_shell_path())
 | |
| 
 | |
| from view.Shell import Shell
 | |
| from model.shellmodel import ShellModel
 | |
| from shellservice import ShellService
 | |
| from hardware import hardwaremanager
 | |
| from intro import intro
 | |
| import logsmanager
 | |
| 
 | |
| def _start_matchbox():
 | |
|     cmd = ['matchbox-window-manager']
 | |
| 
 | |
|     cmd.extend(['-use_titlebar', 'no'])
 | |
|     cmd.extend(['-theme', 'sugar'])
 | |
|     cmd.extend(['-kbdconfig', env.get_shell_path('kbdconfig')])
 | |
| 
 | |
|     gobject.spawn_async(cmd, flags=gobject.SPAWN_SEARCH_PATH)
 | |
| 
 | |
| def _save_session_info():
 | |
|     # Save our DBus Session Bus address somewhere it can be found
 | |
|     #
 | |
|     # WARNING!!! this is going away at some near future point, do not rely on it
 | |
|     #
 | |
|     session_info_file = os.path.join(env.get_profile_path(), "session.info")
 | |
|     f = open(session_info_file, "w")
 | |
| 
 | |
|     cp = ConfigParser()
 | |
|     cp.add_section('Session')
 | |
|     cp.set('Session', 'dbus_address', os.environ['DBUS_SESSION_BUS_ADDRESS'])
 | |
|     cp.set('Session', 'display', gtk.gdk.display_get_default().get_name())
 | |
|     cp.write(f)
 | |
| 
 | |
|     f.close()
 | |
| 
 | |
| def _setup_translations():
 | |
|     domain = 'sugar'
 | |
|     gettext.bindtextdomain(domain, env.get_locale_path())
 | |
|     gettext.textdomain(domain)
 | |
| 
 | |
| def check_cm(bus_name):
 | |
|     try:
 | |
|         import dbus
 | |
|         bus = dbus.SessionBus()
 | |
|         bus_object = bus.get_object('org.freedesktop.DBus', '/org/freedesktop/DBus')
 | |
|         name = bus_object.GetNameOwner(bus_name, dbus_interface='org.freedesktop.DBus')
 | |
|         if name:
 | |
|             return True
 | |
|     except dbus.DBusException:
 | |
|         pass
 | |
|     return False
 | |
| 
 | |
| def _shell_started_cb():
 | |
|     # Unfreeze the display
 | |
|     hw_manager = hardwaremanager.get_manager()
 | |
|     hw_manager.set_dcon_freeze(0)
 | |
| 
 | |
|     startup_sound = os.path.join(env.get_data_path('startup.flac'))
 | |
|     if os.path.exists(startup_sound):
 | |
|         player = gst.element_factory_make("playbin", "player")
 | |
|         player.set_property("uri", "file://" + startup_sound)
 | |
|         player.set_state(gst.STATE_PLAYING)
 | |
| 
 | |
| def main():
 | |
|     gobject.idle_add(_shell_started_cb)
 | |
| 
 | |
|     logsmanager.setup()
 | |
|     logger.start('shell')
 | |
| 
 | |
|     _save_session_info()
 | |
|     _start_matchbox()
 | |
|     _setup_translations()
 | |
| 
 | |
|     icons_path = env.get_data_path('icons')
 | |
|     gtk.icon_theme_get_default().append_search_path(icons_path)
 | |
| 
 | |
|     # Do initial setup if needed
 | |
|     if not get_profile().is_valid():
 | |
|         win = intro.IntroWindow()
 | |
|         win.show_all()
 | |
|         gtk.main()
 | |
| 
 | |
|     # FIXME avoid zombie activity processes
 | |
|     signal.signal(signal.SIGCHLD, signal.SIG_IGN)
 | |
| 
 | |
|     if os.environ.has_key("SUGAR_TP_DEBUG"):
 | |
|         # Allow the user time to start up telepathy connection managers
 | |
|         # using the Sugar DBus bus address
 | |
|         import time
 | |
|         from telepathy.client import ManagerRegistry
 | |
| 
 | |
|         registry = ManagerRegistry()
 | |
|         registry.LoadManagers()
 | |
| 
 | |
|         debug_flags = os.environ["SUGAR_TP_DEBUG"].split(',')
 | |
|         for cm_name in debug_flags:
 | |
|             if cm_name not in ["gabble", "salut"]:
 | |
|                 continue
 | |
| 
 | |
|             try:
 | |
|                 cm = registry.services[cm_name]
 | |
|             except KeyError:
 | |
|                print RuntimeError("%s connection manager not found!" % cm_name)
 | |
| 
 | |
|             while not check_cm(cm['busname']):
 | |
|                 print "Waiting for %s on: DBUS_SESSION_BUS_ADDRESS=%s" %(cm_name, os.environ["DBUS_SESSION_BUS_ADDRESS"])
 | |
|                 try:
 | |
|                     time.sleep(5)
 | |
|                 except KeyboardInterrupt:
 | |
|                     print "Got Ctrl+C, continuing..."
 | |
|                     break
 | |
| 
 | |
|     model = ShellModel()
 | |
|     shell = Shell(model)
 | |
|     service = ShellService(shell)
 | |
| 
 | |
| if __name__ == '__main__':
 | |
|     # running the gtk.main outside of the main() function allows us to 
 | |
|     # profile startup times.  To profile startup times replace the following
 | |
|     # call to main with:
 | |
|     # import cProfile
 | |
|     # cProfile.run('main()', '/home/olpc/sugar-startup.stats')
 | |
| 
 | |
|     main()
 | |
| 
 | |
|     hw_manager = hardwaremanager.get_manager()
 | |
|     hw_manager.startup()
 | |
| 
 | |
|     try:
 | |
|         gtk.main()
 | |
|     except KeyboardInterrupt:
 | |
|         print 'Ctrl+C pressed, exiting...'
 | |
| 
 | |
|     session_info_file = os.path.join(env.get_profile_path(), "session.info")
 | |
|     os.remove(session_info_file)
 | |
| 
 | 
