Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTomeu Vizoso <tomeu@tomeuvizoso.net>2006-11-10 10:58:11 (GMT)
committer Tomeu Vizoso <tomeu@tomeuvizoso.net>2006-11-10 10:58:11 (GMT)
commit028bf526f27d1352fa6d71bdb2540311e02b7e77 (patch)
tree5e7ed9a286fbbd63cd3ec7b7a9a771bdd9ae899b
parenta7e4092b0e4f3d30a21ee5a7982aecd5252a0822 (diff)
parent6260647edac30a4f24ff4e6d922ffc0808dfa83e (diff)
Merge branch 'master' of git://dev.laptop.org/sugar
-rw-r--r--README5
-rw-r--r--configure.ac2
-rw-r--r--lib/src/sugar-address-entry.c8
-rw-r--r--shell/Makefile.am3
-rw-r--r--shell/data/kbdconfig1
-rwxr-xr-xshell/sugar-shutdown4
-rw-r--r--shell/view/Makefile.am1
-rw-r--r--shell/view/Shell.py17
-rw-r--r--shell/view/dconmanager.py43
9 files changed, 77 insertions, 7 deletions
diff --git a/README b/README
index df40e46..6b4c2b1 100644
--- a/README
+++ b/README
@@ -24,5 +24,10 @@ F3 Friends zoom level
F4 Mesh zoom level
F5 Show the frame
F6 Open a terminal activity
+F7 Toggle chat visibility
+F8 Color mode (DCON)
+F9 Black and white mode (DCON)
+F10 Decrease brightness (DCON)
+F11 Increase brightness (DCON)
F12 Open the log viewer
Ctrl+S Activate sketch mode in chat
diff --git a/configure.ac b/configure.ac
index d192edb..52320d1 100644
--- a/configure.ac
+++ b/configure.ac
@@ -1,4 +1,4 @@
-AC_INIT([Sugar],[0.49],[],[sugar])
+AC_INIT([Sugar],[0.51],[],[sugar])
AC_PREREQ([2.59])
diff --git a/lib/src/sugar-address-entry.c b/lib/src/sugar-address-entry.c
index 67a9f14..68fab0a 100644
--- a/lib/src/sugar-address-entry.c
+++ b/lib/src/sugar-address-entry.c
@@ -378,9 +378,9 @@ gtk_entry_draw_text (GtkEntry *entry)
}
static void
-_gtk_entry_get_borders (GtkEntry *entry,
- gint *xborder,
- gint *yborder)
+sugar_address_entry_get_borders (GtkEntry *entry,
+ gint *xborder,
+ gint *yborder)
{
GtkWidget *widget = GTK_WIDGET (entry);
gint focus_width;
@@ -422,7 +422,7 @@ get_text_area_size (GtkEntry *entry,
gtk_widget_get_child_requisition (widget, &requisition);
- _gtk_entry_get_borders (entry, &xborder, &yborder);
+ sugar_address_entry_get_borders (entry, &xborder, &yborder);
if (x)
*x = xborder;
diff --git a/shell/Makefile.am b/shell/Makefile.am
index a5c8533..885ca5e 100644
--- a/shell/Makefile.am
+++ b/shell/Makefile.am
@@ -4,7 +4,8 @@ bin_SCRIPTS = \
sugar-activity \
sugar-activity-factory \
sugar-log-viewer \
- sugar-shell
+ sugar-shell \
+ sugar-shutdown
sugardir = $(pkgdatadir)/shell
sugar_PYTHON = \
diff --git a/shell/data/kbdconfig b/shell/data/kbdconfig
index 967361a..30e4953 100644
--- a/shell/data/kbdconfig
+++ b/shell/data/kbdconfig
@@ -8,3 +8,4 @@
F12=!sugar-log-viewer
<Alt>q=!sugar-emulator-shutdown
+<Alt><Shift>Escape=!sugar-shutdown
diff --git a/shell/sugar-shutdown b/shell/sugar-shutdown
new file mode 100755
index 0000000..e511b3d
--- /dev/null
+++ b/shell/sugar-shutdown
@@ -0,0 +1,4 @@
+#!/bin/sh
+dbus-send --system --print-reply --dest=org.freedesktop.Hal \
+/org/freedesktop/Hal/devices/computer \
+org.freedesktop.Hal.Device.SystemPowerManagement.Shutdown
diff --git a/shell/view/Makefile.am b/shell/view/Makefile.am
index 4438f9b..bd90a2d 100644
--- a/shell/view/Makefile.am
+++ b/shell/view/Makefile.am
@@ -11,4 +11,5 @@ sugar_PYTHON = \
ClipboardMenu.py \
OverlayWindow.py \
Shell.py \
+ dconmanager.py \
stylesheet.py
diff --git a/shell/view/Shell.py b/shell/view/Shell.py
index 401c935..7daade7 100644
--- a/shell/view/Shell.py
+++ b/shell/view/Shell.py
@@ -26,6 +26,7 @@ from view.ActivityHost import ActivityHost
from sugar.activity import ActivityFactory
from sugar.activity import Activity
from view.frame.Frame import Frame
+from view.dconmanager import DCONManager
from _sugar import KeyGrabber
import sugar
@@ -49,6 +50,8 @@ class Shell(gobject.GObject):
style.load_stylesheet(view.stylesheet)
+ self._dcon_manager = DCONManager()
+
self._key_grabber = KeyGrabber()
self._key_grabber.connect('key-pressed',
self.__global_key_pressed_cb)
@@ -60,7 +63,11 @@ class Shell(gobject.GObject):
self._key_grabber.grab('F4')
self._key_grabber.grab('F5')
self._key_grabber.grab('F6')
+ self._key_grabber.grab('F7')
+ self._key_grabber.grab('F8')
self._key_grabber.grab('F9')
+ self._key_grabber.grab('F10')
+ self._key_grabber.grab('F11')
self._home_window = HomeWindow(self)
self._home_window.show()
@@ -87,8 +94,16 @@ class Shell(gobject.GObject):
self._frame.notify_key_press()
elif key == 'F6':
self.start_activity('org.sugar.Terminal')
- elif key == 'F9':
+ elif key == 'F7':
self.toggle_chat_visibility()
+ elif key == 'F8':
+ self._dcon_manager.set_mode(DCONManager.COLOR_MODE)
+ elif key == 'F9':
+ self._dcon_manager.set_mode(DCONManager.BLACK_AND_WHITE_MODE)
+ elif key == 'F10':
+ self._dcon_manager.decrease_brightness()
+ elif key == 'F11':
+ self._dcon_manager.increase_brightness()
def __global_key_released_cb(self, grabber, key):
if key == 'F5':
diff --git a/shell/view/dconmanager.py b/shell/view/dconmanager.py
new file mode 100644
index 0000000..2cf40b5
--- /dev/null
+++ b/shell/view/dconmanager.py
@@ -0,0 +1,43 @@
+# 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 dbus
+
+DCON_MANAGER_INTERFACE = 'org.laptop.DCONManager'
+DCON_MANAGER_SERVICE = 'org.laptop.DCONManager'
+DCON_MANAGER_OBJECT_PATH = '/org/laptop/DCONManager'
+
+class DCONManager(object):
+ COLOR_MODE = 0
+ BLACK_AND_WHITE_MODE = 1
+
+ def __init__(self):
+ bus = dbus.SystemBus()
+ proxy = bus.get_object(DCON_MANAGER_SERVICE, DCON_MANAGER_OBJECT_PATH)
+ self._service = dbus.Interface(proxy, DCON_MANAGER_INTERFACE)
+
+ def set_mode(self, mode):
+ self._service.set_mode(mode)
+
+ def increase_brightness(self):
+ level = self._service.get_backlight_level()
+ if level >= 0:
+ self._service.set_backlight_level(level + 1)
+
+ def decrease_brightness(self):
+ level = self._service.get_backlight_level()
+ if level >= 0:
+ self._service.set_backlight_level(level - 1)