159 lines
4.3 KiB
Python
Executable File
159 lines
4.3 KiB
Python
Executable File
import os
|
|
import logging
|
|
|
|
import dbus
|
|
import dbus.glib
|
|
import gtk
|
|
import gobject
|
|
import wnck
|
|
|
|
from sugar.LogWriter import LogWriter
|
|
from ActivityRegistry import ActivityRegistry
|
|
from HomeWindow import HomeWindow
|
|
from sugar import env
|
|
from ConsoleWindow import ConsoleWindow
|
|
from Owner import ShellOwner
|
|
from sugar.presence.PresenceService import PresenceService
|
|
from ActivityHost import ActivityHost
|
|
from ChatController import ChatController
|
|
from sugar.activity import ActivityFactory
|
|
from sugar.activity import Activity
|
|
|
|
class ShellDbusService(dbus.service.Object):
|
|
def __init__(self, shell, bus_name):
|
|
dbus.service.Object.__init__(self, bus_name, '/com/redhat/Sugar/Shell')
|
|
self._shell = shell
|
|
|
|
def __show_people_idle(self):
|
|
self._shell.show_people()
|
|
|
|
def __show_console_idle(self):
|
|
self._shell.show_console()
|
|
|
|
def __log_idle(self, (module_id, message)):
|
|
self._shell.log(module_id, message)
|
|
|
|
@dbus.service.method('com.redhat.Sugar.Shell')
|
|
def show_people(self):
|
|
gobject.idle_add(self.__show_people_idle)
|
|
|
|
@dbus.service.method('com.redhat.Sugar.Shell')
|
|
def show_console(self):
|
|
gobject.idle_add(self.__show_console_idle)
|
|
|
|
@dbus.service.method('com.redhat.Sugar.Shell')
|
|
def log(self, module_id, message):
|
|
gobject.idle_add(self.__log_idle, (module_id, message))
|
|
|
|
class Shell:
|
|
def __init__(self, registry):
|
|
self._screen = wnck.screen_get_default()
|
|
self._registry = registry
|
|
self._hosts = {}
|
|
self._console_windows = {}
|
|
|
|
def start(self):
|
|
#log_writer = LogWriter("Shell", False)
|
|
#log_writer.start()
|
|
|
|
session_bus = dbus.SessionBus()
|
|
bus_name = dbus.service.BusName('com.redhat.Sugar.Shell', bus=session_bus)
|
|
ShellDbusService(self, bus_name)
|
|
|
|
self._owner = ShellOwner()
|
|
self._owner.announce()
|
|
|
|
chat_controller = ChatController(self)
|
|
chat_controller.listen()
|
|
|
|
self._home_window = HomeWindow(self)
|
|
self._home_window.show()
|
|
|
|
self._screen.connect('window-opened', self.__window_opened_cb)
|
|
self._screen.connect('window-closed', self.__window_closed_cb)
|
|
|
|
def __window_opened_cb(self, screen, window):
|
|
if window.get_window_type() == wnck.WINDOW_NORMAL:
|
|
self._hosts[window.get_xid()] = ActivityHost(self, window)
|
|
|
|
def __window_closed_cb(self, screen, window):
|
|
if window.get_window_type() == wnck.WINDOW_NORMAL:
|
|
xid = window.get_xid()
|
|
self._hosts[xid] = None
|
|
|
|
def get_activity(self, activity_id):
|
|
for host in self._hosts:
|
|
if host.get_id() == activity_id:
|
|
return host
|
|
return None
|
|
|
|
def get_current_activity(self):
|
|
window = self._screen.get_active_window()
|
|
if window:
|
|
xid = None
|
|
|
|
if window.get_window_type() == wnck.WINDOW_NORMAL:
|
|
xid = window.get_xid()
|
|
elif window.get_window_type() == wnck.WINDOW_DIALOG:
|
|
parent = window.get_transient()
|
|
if not parent is None:
|
|
xid = parent.get_xid()
|
|
|
|
if xid != None:
|
|
return self._hosts[xid]
|
|
|
|
return None
|
|
|
|
def show_people(self):
|
|
activity = self.get_current_activity()
|
|
activity.show_people()
|
|
|
|
def get_console(self, module_id):
|
|
if not self._console_windows.has_key(module_id):
|
|
dialog = ConsoleWindow()
|
|
self._console_windows[module_id] = dialog
|
|
else:
|
|
dialog = self._console_windows[module_id]
|
|
return dialog
|
|
|
|
def show_console(self):
|
|
activity = self.get_current_activity()
|
|
if activity:
|
|
module = self._registry.get_activity(activity.get_default_type())
|
|
console = self.get_console(module.get_id())
|
|
activity.show_dialog(console)
|
|
|
|
def join_activity(self, service):
|
|
info = self._registry.get_activity(service.get_type())
|
|
|
|
activity_id = service.get_activity_id()
|
|
pservice = PresenceService()
|
|
activity_ps = pservice.get_activity(activity_id)
|
|
|
|
if activity_ps:
|
|
activity = ActivityFactory.create(info.get_id())
|
|
activity.set_default_type(service.get_type())
|
|
activity.join(activity_ps.object_path())
|
|
else:
|
|
logging.error('Cannot start activity.')
|
|
|
|
def start_activity(self, activity_name):
|
|
activity = ActivityFactory.create(activity_name)
|
|
info = self._registry.get_activity_from_id(activity_name)
|
|
if info:
|
|
default_type = info.get_default_type()
|
|
if default_type != None:
|
|
activity.set_default_type(default_type)
|
|
activity.execute('test', [])
|
|
return activity
|
|
else:
|
|
logging.error('No such activity in the directory')
|
|
return None
|
|
|
|
def log(self, module_id, message):
|
|
console = self.get_console(module_id)
|
|
console.log(message)
|
|
|
|
def get_registry(self):
|
|
return self._registry
|