diff options
author | Marco Pesenti Gritti <mpgritti@gmail.com> | 2008-09-30 16:41:13 (GMT) |
---|---|---|
committer | Marco Pesenti Gritti <mpgritti@gmail.com> | 2008-09-30 16:41:13 (GMT) |
commit | 1f9e32e0cfa67c6a80d9200b7f7a586aff117133 (patch) | |
tree | 2ede00387e2d8f3f1cc5f3203f03b43b57bf8474 | |
parent | 6619fc343aa99a7f27136eced6b8f9b71232d97b (diff) |
Move emulator code in the script.
-rw-r--r-- | bin/sugar-emulator | 106 | ||||
-rw-r--r-- | src/jarabe/Makefile.am | 1 | ||||
-rwxr-xr-x | src/jarabe/emulator.py | 134 |
3 files changed, 103 insertions, 138 deletions
diff --git a/bin/sugar-emulator b/bin/sugar-emulator index 90e0234..36958db 100644 --- a/bin/sugar-emulator +++ b/bin/sugar-emulator @@ -1,5 +1,5 @@ #!/usr/bin/env python -# Copyright (C) 2008, Red Hat, Inc. +# Copyright (C) 2006-2008, 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 @@ -15,8 +15,108 @@ # along with this program; if not, write to the Free Software # Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA -from jarabe.emulator import main +import os +import subprocess +import time +from optparse import OptionParser -main() +import gtk +import gobject + +from sugar import env + +def _run_xephyr(display, dpi): + cmd = [ 'Xephyr' ] + cmd.append(':%d' % display) + cmd.append('-ac') + + if gtk.gdk.screen_width() < 1200 or gtk.gdk.screen_height() < 900: + cmd.append('-fullscreen') + else: + cmd.append('-screen') + cmd.append('%dx%d' % (1200, 900)) + + if not dpi: + dpi = gtk.settings_get_default().get_property('gtk-xft-dpi') / 1024 + if dpi > 0: + cmd.append('-dpi') + cmd.append('%d' % dpi) + + result = gobject.spawn_async(cmd, flags=gobject.SPAWN_SEARCH_PATH) + pid = result[0] + + os.environ['DISPLAY'] = ":%d" % (display) + os.environ['SUGAR_EMULATOR_PID'] = str(pid) + +def _check_xephyr(display): + result = subprocess.call(['xdpyinfo', '-display', ':%d' % display], + stdout=open(os.devnull, "w"), + stderr=open(os.devnull, "w")) + return result == 0 + +def _start_xephyr(dpi=None): + for display in range(100, 110): + if not _check_xephyr(display): + _run_xephyr(display, dpi) + + tries = 10 + while tries > 0: + if _check_xephyr(display): + return + else: + tries -= 1 + time.sleep(0.1) + +def _start_matchbox(): + cmd = ['matchbox-window-manager'] + + cmd.extend(['-use_titlebar', 'no']) + cmd.extend(['-theme', 'sugar']) + gobject.spawn_async(cmd, flags=gobject.SPAWN_SEARCH_PATH) +def _setup_env(): + os.environ['SUGAR_EMULATOR'] = 'yes' + os.environ['GABBLE_LOGFILE'] = os.path.join( + env.get_profile_path(), 'logs', 'telepathy-gabble.log') + os.environ['SALUT_LOGFILE'] = os.path.join( + env.get_profile_path(), 'logs', 'telepathy-salut.log') + os.environ['STREAM_ENGINE_LOGFILE'] = os.path.join( + env.get_profile_path(), 'logs', 'telepathy-stream-engine.log') + +def main(): + """Script-level operations""" + + parser = OptionParser() + parser.add_option('-x', '--xo-style', dest='xo_style', + action='store_true', help='use the XO style') + (options, args) = parser.parse_args() + + _setup_env() + + if options.xo_style: + _start_xephyr(dpi=201) + else: + _start_xephyr() + + if options.xo_style: + os.environ['SUGAR_THEME'] = 'sugar-xo' + os.environ['SUGAR_XO_STYLE'] = 'yes' + else: + os.environ['SUGAR_XO_STYLE'] = 'no' + + command = ['dbus-launch', 'dbus-launch', '--exit-with-session'] + + if not args: + command.append('sugar-shell') + else: + _start_matchbox() + + if args[0].endswith('.py'): + command.append('python') + + command.append(args[0]) + + os.execlp(*command) + +main() diff --git a/src/jarabe/Makefile.am b/src/jarabe/Makefile.am index 17c3838..3983433 100644 --- a/src/jarabe/Makefile.am +++ b/src/jarabe/Makefile.am @@ -4,7 +4,6 @@ sugardir = $(pythondir)/jarabe sugar_PYTHON = \ __init__.py \ config.py \ - emulator.py \ logsmanager.py \ main.py \ session.py \ diff --git a/src/jarabe/emulator.py b/src/jarabe/emulator.py deleted file mode 100755 index ac1f4e2..0000000 --- a/src/jarabe/emulator.py +++ /dev/null @@ -1,134 +0,0 @@ -# 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 logging -import subprocess -import time -from optparse import OptionParser - -log = logging.getLogger( 'sugar-emulator' ) -log.setLevel( logging.DEBUG ) - -import pygtk -pygtk.require('2.0') -import gtk -import gobject - -from sugar import env - -def _run_xephyr(display, dpi): - log.info('Starting Xephyr on display %s', display) - - cmd = [ 'Xephyr' ] - cmd.append(':%d' % display) - cmd.append('-ac') - - if gtk.gdk.screen_width() < 1200 or gtk.gdk.screen_height() < 900: - cmd.append('-fullscreen') - else: - cmd.append('-screen') - cmd.append('%dx%d' % (1200, 900)) - - if not dpi: - dpi = gtk.settings_get_default().get_property('gtk-xft-dpi') / 1024 - if dpi > 0: - cmd.append('-dpi') - cmd.append('%d' % dpi) - - log.debug('Xephyr command: %s', " ".join( cmd )) - result = gobject.spawn_async(cmd, flags=gobject.SPAWN_SEARCH_PATH) - pid = result[0] - - os.environ['DISPLAY'] = ":%d" % (display) - os.environ['SUGAR_EMULATOR_PID'] = str(pid) - -def _check_xephyr(display): - result = subprocess.call(['xdpyinfo', '-display', ':%d' % display], - stdout=open(os.devnull, "w"), - stderr=open(os.devnull, "w")) - return result == 0 - -def _start_xephyr(dpi=None): - for display in range(100, 110): - if not _check_xephyr(display): - _run_xephyr(display, dpi) - - tries = 10 - while tries > 0: - if _check_xephyr(display): - return - else: - tries -= 1 - time.sleep(0.1) - -def _start_matchbox(): - log.info('Starting the matchbox window manager') - cmd = ['matchbox-window-manager'] - - cmd.extend(['-use_titlebar', 'no']) - cmd.extend(['-theme', 'sugar']) - - log.debug('Matchbox command: %s', " ".join( cmd)) - gobject.spawn_async(cmd, flags=gobject.SPAWN_SEARCH_PATH) - -def _setup_env(): - os.environ['SUGAR_EMULATOR'] = 'yes' - os.environ['GABBLE_LOGFILE'] = os.path.join( - env.get_profile_path(), 'logs', 'telepathy-gabble.log') - os.environ['SALUT_LOGFILE'] = os.path.join( - env.get_profile_path(), 'logs', 'telepathy-salut.log') - os.environ['STREAM_ENGINE_LOGFILE'] = os.path.join( - env.get_profile_path(), 'logs', 'telepathy-stream-engine.log') - -def main(): - """Script-level operations""" - - parser = OptionParser() - parser.add_option('-x', '--xo-style', dest='xo_style', - action='store_true', help='use the XO style') - (options, args) = parser.parse_args() - - logging.basicConfig() - - _setup_env() - - if options.xo_style: - _start_xephyr(dpi=201) - else: - _start_xephyr() - - if options.xo_style: - os.environ['SUGAR_THEME'] = 'sugar-xo' - os.environ['SUGAR_XO_STYLE'] = 'yes' - else: - os.environ['SUGAR_XO_STYLE'] = 'no' - - command = ['dbus-launch', 'dbus-launch', '--exit-with-session'] - - if not args: - command.append('sugar-shell') - else: - _start_matchbox() - - if args[0].endswith('.py'): - command.append('python') - - command.append(args[0]) - - log.info("Attempting to launch sugar to replace this process: %s" - % " ".join(command)) - os.execlp( *command ) |