Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--.gitignore1
-rw-r--r--activities/browser/BrowserActivity.py2
-rw-r--r--lib/python/_sugar.c214
-rw-r--r--lib/python/_sugar.defs73
-rw-r--r--lib/python/_sugar.override2
-rw-r--r--lib/src/Makefile.am4
-rw-r--r--lib/src/gecko-browser.cpp158
-rw-r--r--lib/src/gecko-browser.h57
-rw-r--r--lib/src/sugar-browser.cpp235
-rw-r--r--lib/src/sugar-browser.h60
-rw-r--r--lib/src/sugar-key-grabber.c16
-rw-r--r--lib/src/sugar-key-grabber.h17
12 files changed, 388 insertions, 451 deletions
diff --git a/.gitignore b/.gitignore
index e2834ee..c7f648a 100644
--- a/.gitignore
+++ b/.gitignore
@@ -8,6 +8,7 @@ Makefile.in
*.libs
*.la
*.lo
+*.loT
# Absolute
diff --git a/activities/browser/BrowserActivity.py b/activities/browser/BrowserActivity.py
index d9e5bbf..27a706d 100644
--- a/activities/browser/BrowserActivity.py
+++ b/activities/browser/BrowserActivity.py
@@ -69,7 +69,7 @@ class PopupCreator(gobject.GObject):
return self._embed
class Browser(_sugar.Browser):
- __gtype_name__ = "SugarBrowser"
+ __gtype_name__ = "SugarWebBrowser"
def __init__(self):
_sugar.Browser.__init__(self)
self._popup_creators = []
diff --git a/lib/python/_sugar.c b/lib/python/_sugar.c
index 585cd0d..a1bd3c0 100644
--- a/lib/python/_sugar.c
+++ b/lib/python/_sugar.c
@@ -8,7 +8,7 @@
#include <Python.h>
#include "pygobject.h"
-#include "gecko-browser.h"
+#include "sugar-browser.h"
#include "sugar-key-grabber.h"
#include "sugar-address-entry.h"
@@ -25,83 +25,20 @@ static PyTypeObject *_PyGtkMozEmbed_Type;
/* ---------- forward type declarations ---------- */
-PyTypeObject G_GNUC_INTERNAL PyGeckoBrowser_Type;
PyTypeObject G_GNUC_INTERNAL PySugarAddressEntry_Type;
+PyTypeObject G_GNUC_INTERNAL PySugarBrowser_Type;
PyTypeObject G_GNUC_INTERNAL PySugarKeyGrabber_Type;
#line 33 "_sugar.c"
-/* ----------- GeckoBrowser ----------- */
-
-static int
-_wrap_gecko_browser_new(PyGObject *self, PyObject *args, PyObject *kwargs)
-{
- static char* kwlist[] = { NULL };
-
- if (!PyArg_ParseTupleAndKeywords(args, kwargs,
- ":gecko.Browser.__init__",
- kwlist))
- return -1;
-
- pygobject_constructv(self, 0, NULL);
- if (!self->obj) {
- PyErr_SetString(
- PyExc_RuntimeError,
- "could not create gecko.Browser object");
- return -1;
- }
- return 0;
-}
-
-static PyObject *
-_wrap_gecko_browser_create_window(PyGObject *self)
-{
- GeckoBrowser *ret;
-
-
- ret = gecko_browser_create_window(GECKO_BROWSER(self->obj));
-
- /* pygobject_new handles NULL checking */
- return pygobject_new((GObject *)ret);
-}
-
-static PyObject *
-_wrap_GeckoBrowser__do_create_window(PyObject *cls, PyObject *args, PyObject *kwargs)
-{
- gpointer klass;
- static char *kwlist[] = { "self", NULL };
- PyGObject *self;
- GeckoBrowser *ret;
-
- if (!PyArg_ParseTupleAndKeywords(args, kwargs,"O!:GeckoBrowser.create_window", kwlist, &PyGeckoBrowser_Type, &self))
- return NULL;
- klass = g_type_class_ref(pyg_type_from_object(cls));
- if (GECKO_BROWSER_CLASS(klass)->create_window)
- ret = GECKO_BROWSER_CLASS(klass)->create_window(GECKO_BROWSER(self->obj));
- else {
- PyErr_SetString(PyExc_NotImplementedError, "virtual method GeckoBrowser.create_window not implemented");
- g_type_class_unref(klass);
- return NULL;
- }
- g_type_class_unref(klass);
- /* pygobject_new handles NULL checking */
- return pygobject_new((GObject *)ret);
-}
-
-static const PyMethodDef _PyGeckoBrowser_methods[] = {
- { "create_window", (PyCFunction)_wrap_gecko_browser_create_window, METH_NOARGS,
- NULL },
- { "do_create_window", (PyCFunction)_wrap_GeckoBrowser__do_create_window, METH_VARARGS|METH_KEYWORDS|METH_CLASS,
- NULL },
- { NULL, NULL, 0, NULL }
-};
+/* ----------- SugarAddressEntry ----------- */
-PyTypeObject G_GNUC_INTERNAL PyGeckoBrowser_Type = {
+PyTypeObject G_GNUC_INTERNAL PySugarAddressEntry_Type = {
PyObject_HEAD_INIT(NULL)
0, /* ob_size */
- "gecko.Browser", /* tp_name */
+ "gecko.AddressEntry", /* tp_name */
sizeof(PyGObject), /* tp_basicsize */
0, /* tp_itemsize */
/* methods */
@@ -128,7 +65,7 @@ PyTypeObject G_GNUC_INTERNAL PyGeckoBrowser_Type = {
offsetof(PyGObject, weakreflist), /* tp_weaklistoffset */
(getiterfunc)0, /* tp_iter */
(iternextfunc)0, /* tp_iternext */
- (struct PyMethodDef*)_PyGeckoBrowser_methods, /* tp_methods */
+ (struct PyMethodDef*)NULL, /* tp_methods */
(struct PyMemberDef*)0, /* tp_members */
(struct PyGetSetDef*)0, /* tp_getset */
NULL, /* tp_base */
@@ -136,96 +73,39 @@ PyTypeObject G_GNUC_INTERNAL PyGeckoBrowser_Type = {
(descrgetfunc)0, /* tp_descr_get */
(descrsetfunc)0, /* tp_descr_set */
offsetof(PyGObject, inst_dict), /* tp_dictoffset */
- (initproc)_wrap_gecko_browser_new, /* tp_init */
+ (initproc)0, /* tp_init */
(allocfunc)0, /* tp_alloc */
(newfunc)0, /* tp_new */
(freefunc)0, /* tp_free */
(inquiry)0 /* tp_is_gc */
};
-static GeckoBrowser*
-_wrap_GeckoBrowser__proxy_do_create_window(GeckoBrowser *self)
+
+
+/* ----------- SugarBrowser ----------- */
+
+static PyObject *
+_wrap_sugar_browser_create_window(PyGObject *self)
{
- PyGILState_STATE __py_state;
- PyObject *py_self;
- GeckoBrowser* retval;
- PyObject *py_retval;
- PyObject *py_method;
-
- __py_state = pyg_gil_state_ensure();
- py_self = pygobject_new((GObject *) self);
- if (!py_self) {
- if (PyErr_Occurred())
- PyErr_Print();
- pyg_gil_state_release(__py_state);
- return NULL;
- }
-
-
- py_method = PyObject_GetAttrString(py_self, "do_create_window");
- if (!py_method) {
- if (PyErr_Occurred())
- PyErr_Print();
- Py_DECREF(py_self);
- pyg_gil_state_release(__py_state);
- return NULL;
- }
- py_retval = PyObject_CallObject(py_method, NULL);
- if (!py_retval) {
- if (PyErr_Occurred())
- PyErr_Print();
- Py_DECREF(py_method);
- Py_DECREF(py_self);
- pyg_gil_state_release(__py_state);
- return NULL;
- }
- if (!PyObject_TypeCheck(py_retval, &PyGObject_Type)) {
- PyErr_SetString(PyExc_TypeError, "retval should be a GObject");
- PyErr_Print();
- Py_DECREF(py_retval);
- Py_DECREF(py_method);
- Py_DECREF(py_self);
- pyg_gil_state_release(__py_state);
- return NULL;
- }
- retval = (GeckoBrowser*) pygobject_get(py_retval);
- g_object_ref((GObject *) retval);
-
+ SugarBrowser *ret;
+
- Py_DECREF(py_retval);
- Py_DECREF(py_method);
- Py_DECREF(py_self);
- pyg_gil_state_release(__py_state);
+ ret = sugar_browser_create_window(SUGAR_BROWSER(self->obj));
- return retval;
-}
-
-static int
-__GeckoBrowser_class_init(gpointer gclass, PyTypeObject *pyclass)
-{
- PyObject *o;
- GeckoBrowserClass *klass = GECKO_BROWSER_CLASS(gclass);
- PyObject *gsignals = PyDict_GetItemString(pyclass->tp_dict, "__gsignals__");
-
- o = PyObject_GetAttrString((PyObject *) pyclass, "do_create_window");
- if (o == NULL)
- PyErr_Clear();
- else {
- if (!PyObject_TypeCheck(o, &PyCFunction_Type)
- && !(gsignals && PyDict_GetItemString(gsignals, "create_window")))
- klass->create_window = _wrap_GeckoBrowser__proxy_do_create_window;
- Py_DECREF(o);
- }
- return 0;
+ /* pygobject_new handles NULL checking */
+ return pygobject_new((GObject *)ret);
}
+static const PyMethodDef _PySugarBrowser_methods[] = {
+ { "create_window", (PyCFunction)_wrap_sugar_browser_create_window, METH_NOARGS,
+ NULL },
+ { NULL, NULL, 0, NULL }
+};
-/* ----------- SugarAddressEntry ----------- */
-
-PyTypeObject G_GNUC_INTERNAL PySugarAddressEntry_Type = {
+PyTypeObject G_GNUC_INTERNAL PySugarBrowser_Type = {
PyObject_HEAD_INIT(NULL)
0, /* ob_size */
- "gecko.AddressEntry", /* tp_name */
+ "gecko.Browser", /* tp_name */
sizeof(PyGObject), /* tp_basicsize */
0, /* tp_itemsize */
/* methods */
@@ -252,7 +132,7 @@ PyTypeObject G_GNUC_INTERNAL PySugarAddressEntry_Type = {
offsetof(PyGObject, weakreflist), /* tp_weaklistoffset */
(getiterfunc)0, /* tp_iter */
(iternextfunc)0, /* tp_iternext */
- (struct PyMethodDef*)NULL, /* tp_methods */
+ (struct PyMethodDef*)_PySugarBrowser_methods, /* tp_methods */
(struct PyMemberDef*)0, /* tp_members */
(struct PyGetSetDef*)0, /* tp_getset */
NULL, /* tp_base */
@@ -271,36 +151,16 @@ PyTypeObject G_GNUC_INTERNAL PySugarAddressEntry_Type = {
/* ----------- SugarKeyGrabber ----------- */
-static int
-_wrap_sugar_key_grabber_new(PyGObject *self, PyObject *args, PyObject *kwargs)
-{
- static char* kwlist[] = { NULL };
-
- if (!PyArg_ParseTupleAndKeywords(args, kwargs,
- ":gecko.KeyGrabber.__init__",
- kwlist))
- return -1;
-
- pygobject_constructv(self, 0, NULL);
- if (!self->obj) {
- PyErr_SetString(
- PyExc_RuntimeError,
- "could not create gecko.KeyGrabber object");
- return -1;
- }
- return 0;
-}
-
static PyObject *
_wrap_sugar_key_grabber_grab(PyGObject *self, PyObject *args, PyObject *kwargs)
{
- static char *kwlist[] = { "address", NULL };
- char *address;
+ static char *kwlist[] = { "key", NULL };
+ char *key;
- if (!PyArg_ParseTupleAndKeywords(args, kwargs,"s:SugarKeyGrabber.grab", kwlist, &address))
+ if (!PyArg_ParseTupleAndKeywords(args, kwargs,"s:SugarKeyGrabber.grab", kwlist, &key))
return NULL;
- sugar_key_grabber_grab(SUGAR_KEY_GRABBER(self->obj), address);
+ sugar_key_grabber_grab(SUGAR_KEY_GRABBER(self->obj), key);
Py_INCREF(Py_None);
return Py_None;
@@ -350,7 +210,7 @@ PyTypeObject G_GNUC_INTERNAL PySugarKeyGrabber_Type = {
(descrgetfunc)0, /* tp_descr_get */
(descrsetfunc)0, /* tp_descr_set */
offsetof(PyGObject, inst_dict), /* tp_dictoffset */
- (initproc)_wrap_sugar_key_grabber_new, /* tp_init */
+ (initproc)0, /* tp_init */
(allocfunc)0, /* tp_alloc */
(newfunc)0, /* tp_new */
(freefunc)0, /* tp_free */
@@ -362,17 +222,17 @@ PyTypeObject G_GNUC_INTERNAL PySugarKeyGrabber_Type = {
/* ----------- functions ----------- */
static PyObject *
-_wrap_gecko_browser_startup(PyObject *self)
+_wrap_sugar_browser_startup(PyObject *self)
{
- gecko_browser_startup();
+ sugar_browser_startup();
Py_INCREF(Py_None);
return Py_None;
}
const PyMethodDef py_sugar_functions[] = {
- { "startup_browser", (PyCFunction)_wrap_gecko_browser_startup, METH_NOARGS,
+ { "startup_browser", (PyCFunction)_wrap_sugar_browser_startup, METH_NOARGS,
NULL },
{ NULL, NULL, 0, NULL }
};
@@ -421,11 +281,9 @@ py_sugar_register_classes(PyObject *d)
}
-#line 425 "_sugar.c"
- pygobject_register_class(d, "GeckoBrowser", GECKO_TYPE_BROWSER, &PyGeckoBrowser_Type, Py_BuildValue("(O)", &PyGtkMozEmbed_Type));
- pyg_set_object_has_new_constructor(GECKO_TYPE_BROWSER);
- pyg_register_class_init(GECKO_TYPE_BROWSER, __GeckoBrowser_class_init);
+#line 285 "_sugar.c"
pygobject_register_class(d, "SugarAddressEntry", SUGAR_TYPE_ADDRESS_ENTRY, &PySugarAddressEntry_Type, Py_BuildValue("(O)", &PyGtkEntry_Type));
+ pygobject_register_class(d, "SugarBrowser", SUGAR_TYPE_BROWSER, &PySugarBrowser_Type, Py_BuildValue("(O)", &PyGtkMozEmbed_Type));
pygobject_register_class(d, "SugarKeyGrabber", SUGAR_TYPE_KEY_GRABBER, &PySugarKeyGrabber_Type, Py_BuildValue("(O)", &PyGObject_Type));
pyg_set_object_has_new_constructor(SUGAR_TYPE_KEY_GRABBER);
}
diff --git a/lib/python/_sugar.defs b/lib/python/_sugar.defs
index bdf51a8..56c52ac 100644
--- a/lib/python/_sugar.defs
+++ b/lib/python/_sugar.defs
@@ -1,12 +1,5 @@
;; -*- scheme -*-
; object definitions ...
-(define-object Browser
- (in-module "Gecko")
- (parent "GtkMozEmbed")
- (c-name "GeckoBrowser")
- (gtype-id "GECKO_TYPE_BROWSER")
-)
-
(define-object AddressEntry
(in-module "Sugar")
(parent "GtkEntry")
@@ -14,60 +7,66 @@
(gtype-id "SUGAR_TYPE_ADDRESS_ENTRY")
)
+(define-object Browser
+ (in-module "Sugar")
+ (parent "GtkMozEmbed")
+ (c-name "SugarBrowser")
+ (gtype-id "SUGAR_TYPE_BROWSER")
+)
+
+(define-object KeyGrabber
+ (in-module "Sugar")
+ (parent "GObject")
+ (c-name "SugarKeyGrabber")
+ (gtype-id "SUGAR_TYPE_KEY_GRABBER")
+)
+
;; Enumerations and flags ...
-;; From gecko-browser.h
+;; From sugar-address-entry.h
-(define-function get_type
- (c-name "gecko_browser_get_type")
+(define-function sugar_address_entry_get_type
+ (c-name "sugar_address_entry_get_type")
(return-type "GType")
)
-(define-function startup_browser
- (c-name "gecko_browser_startup")
- (return-type "none")
+
+
+;; From sugar-browser.h
+
+(define-function sugar_browser_get_type
+ (c-name "sugar_browser_get_type")
+ (return-type "GType")
)
-(define-function new
- (c-name "gecko_browser_new")
- (is-constructor-of "GeckoBrowser")
- (return-type "GeckoBrowser*")
+(define-function startup_browser
+ (c-name "sugar_browser_startup")
+ (return-type "none")
)
(define-method create_window
- (of-object "GeckoBrowser")
- (c-name "gecko_browser_create_window")
- (return-type "GeckoBrowser*")
+ (of-object "SugarBrowser")
+ (c-name "sugar_browser_create_window")
+ (return-type "SugarBrowser*")
)
-(define-virtual create_window
- (of-object "GeckoBrowser")
- (return-type "GeckoBrowser*")
-)
-(define-object KeyGrabber
- (in-module "globalkeys")
- (parent "GObject")
- (c-name "SugarKeyGrabber")
- (gtype-id "SUGAR_TYPE_KEY_GRABBER")
-)
+
+
+;; From sugar-key-grabber.h
(define-function sugar_key_grabber_get_type
(c-name "sugar_key_grabber_get_type")
(return-type "GType")
)
-(define-function sugar_key_grabber_new
- (c-name "sugar_key_grabber_new")
- (is-constructor-of "SugarKeyGrabber")
- (return-type "GObject*")
-)
-
(define-method grab
(of-object "SugarKeyGrabber")
(c-name "sugar_key_grabber_grab")
(return-type "none")
(parameters
- '("const-char*" "address")
+ '("const-char*" "key")
)
)
+
+
diff --git a/lib/python/_sugar.override b/lib/python/_sugar.override
index 4f9b9d7..f85a43b 100644
--- a/lib/python/_sugar.override
+++ b/lib/python/_sugar.override
@@ -4,7 +4,7 @@ headers
#include <Python.h>
#include "pygobject.h"
-#include "gecko-browser.h"
+#include "sugar-browser.h"
#include "sugar-key-grabber.h"
#include "sugar-address-entry.h"
diff --git a/lib/src/Makefile.am b/lib/src/Makefile.am
index 8693ead..ec762da 100644
--- a/lib/src/Makefile.am
+++ b/lib/src/Makefile.am
@@ -9,8 +9,8 @@ libsugarprivate_la_LIBADD = $(GECKO_LIBS)
libsugarprivate_la_SOURCES = \
eggaccelerators.h \
eggaccelerators.c \
- gecko-browser.h \
- gecko-browser.cpp \
+ sugar-browser.h \
+ sugar-browser.cpp \
sugar-address-entry.h \
sugar-address-entry.c \
sugar-key-grabber.h \
diff --git a/lib/src/gecko-browser.cpp b/lib/src/gecko-browser.cpp
deleted file mode 100644
index b0612c0..0000000
--- a/lib/src/gecko-browser.cpp
+++ /dev/null
@@ -1,158 +0,0 @@
-/*
- * Copyright (C) 2006 Red Hat, Inc
- *
- * Sugar 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.
- *
- * Sugar 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA.
- */
-
-#include "gecko-browser.h"
-
-#include <nsCOMPtr.h>
-#include <nsIPrefService.h>
-#include <nsServiceManagerUtils.h>
-
-enum {
- PROP_0,
- PROP_PROGRESS
-};
-
-void
-gecko_browser_startup(void)
-{
- nsCOMPtr<nsIPrefService> prefService;
-
- prefService = do_GetService(NS_PREFSERVICE_CONTRACTID);
- NS_ENSURE_TRUE(prefService, );
-
- nsCOMPtr<nsIPrefBranch> pref;
- prefService->GetBranch("", getter_AddRefs(pref));
- NS_ENSURE_TRUE(pref, );
-
- pref->SetBoolPref ("dom.disable_open_during_load", TRUE);
-}
-
-G_DEFINE_TYPE(GeckoBrowser, gecko_browser, GTK_TYPE_MOZ_EMBED)
-
-//static guint signals[N_SIGNALS];
-
-GeckoBrowser *
-gecko_browser_new(void)
-{
- return GECKO_BROWSER(g_object_new(GECKO_TYPE_BROWSER, NULL));
-}
-
-static void
-gecko_browser_get_property(GObject *object,
- guint prop_id,
- GValue *value,
- GParamSpec *pspec)
-{
- GeckoBrowser *browser = GECKO_BROWSER(object);
-
- switch (prop_id) {
- case PROP_PROGRESS:
- g_value_set_double(value, browser->progress);
- break;
-
- default:
- G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
- break;
- }
-}
-
-
-static void
-gecko_browser_class_init(GeckoBrowserClass *browser_class)
-{
- GObjectClass *gobject_class = G_OBJECT_CLASS(browser_class);
-
- gobject_class->get_property = gecko_browser_get_property;
-
- g_object_class_install_property (gobject_class, PROP_PROGRESS,
- g_param_spec_double ("progress",
- "Progress",
- "Progress",
- 0.0, 1.0, 0.0,
- G_PARAM_READABLE));
-}
-
-GeckoBrowser *
-gecko_browser_create_window(GeckoBrowser *browser)
-{
- return GECKO_BROWSER_GET_CLASS(browser)->create_window(browser);
-}
-
-static void
-new_window_cb(GtkMozEmbed *embed,
- GtkMozEmbed **newEmbed,
- guint chromemask)
-{
- GeckoBrowser *browser;
-
- browser = gecko_browser_create_window(GECKO_BROWSER(embed));
-
- *newEmbed = GTK_MOZ_EMBED(browser);
-}
-
-static void
-gecko_browser_set_progress(GeckoBrowser *browser, float progress)
-{
- g_return_if_fail(GECKO_IS_BROWSER(browser));
-
- browser->progress = progress;
- g_object_notify (G_OBJECT(browser), "progress");
-}
-
-static void
-net_state_cb(GtkMozEmbed *embed, const char *aURI, gint state, guint status)
-{
- GeckoBrowser *browser = GECKO_BROWSER(embed);
-
- if (state & GTK_MOZ_EMBED_FLAG_IS_NETWORK) {
- if (state & GTK_MOZ_EMBED_FLAG_START) {
- browser->total_requests = 0;
- browser->current_requests = 0;
- browser->progress = 0.0;
- }
- }
-
- if (state & GTK_MOZ_EMBED_FLAG_IS_REQUEST) {
- float progress;
-
- if (state & GTK_MOZ_EMBED_FLAG_START) {
- browser->total_requests++;
- }
- else if (state & GTK_MOZ_EMBED_FLAG_STOP)
- {
- browser->current_requests++;
- }
-
- progress = float(browser->current_requests) /
- float(browser->total_requests);
- if (progress > browser->progress) {
- gecko_browser_set_progress(browser, progress);
- }
- }
-}
-
-static void
-gecko_browser_init(GeckoBrowser *browser)
-{
- browser->progress = 0.0;
-
- g_signal_connect(G_OBJECT(browser), "new-window",
- G_CALLBACK(new_window_cb), NULL);
- g_signal_connect(G_OBJECT(browser), "net-state-all",
- G_CALLBACK(net_state_cb), NULL);
-}
diff --git a/lib/src/gecko-browser.h b/lib/src/gecko-browser.h
deleted file mode 100644
index 9a62783..0000000
--- a/lib/src/gecko-browser.h
+++ /dev/null
@@ -1,57 +0,0 @@
-/*
- * Copyright (C) 2006 Red Hat, Inc
- *
- * Sugar 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.
- *
- * Sugar 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA.
- */
-
-#ifndef __GECKO_BROWSER_H__
-#define __GECKO_BROWSER_H__
-
-#include <gtkmozembed.h>
-
-G_BEGIN_DECLS
-
-typedef struct _GeckoBrowser GeckoBrowser;
-typedef struct _GeckoBrowserClass GeckoBrowserClass;
-
-#define GECKO_TYPE_BROWSER (gecko_browser_get_type())
-#define GECKO_BROWSER(object) (G_TYPE_CHECK_INSTANCE_CAST((object), GECKO_TYPE_BROWSER, GeckoBrowser))
-#define GECKO_BROWSER_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST((klass), GECKO_TYPE_BROWSER, GeckoBrowserClass))
-#define GECKO_IS_BROWSER(object) (G_TYPE_CHECK_INSTANCE_TYPE((object), GECKO_TYPE_BROWSER))
-#define GECKO_IS_BROWSER_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE((klass), GECKO_TYPE_BROWSER))
-#define GECKO_BROWSER_GET_CLASS(object) (G_TYPE_INSTANCE_GET_CLASS((object), GECKO_TYPE_BROWSER, GeckoBrowserClass))
-
-struct _GeckoBrowser {
- GtkMozEmbed base_instance;
-
- int total_requests;
- int current_requests;
- float progress;
-};
-
-struct _GeckoBrowserClass {
- GtkMozEmbedClass base_class;
-
- GeckoBrowser * (* create_window) (GeckoBrowser *browser);
-};
-
-GType gecko_browser_get_type (void);
-void gecko_browser_startup (void);
-GeckoBrowser *gecko_browser_new (void);
-GeckoBrowser *gecko_browser_create_window (GeckoBrowser *browser);
-
-G_END_DECLS
-
-#endif
diff --git a/lib/src/sugar-browser.cpp b/lib/src/sugar-browser.cpp
new file mode 100644
index 0000000..5081c38
--- /dev/null
+++ b/lib/src/sugar-browser.cpp
@@ -0,0 +1,235 @@
+/*
+ * Copyright (C) 2006 Red Hat, Inc
+ *
+ * Sugar 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.
+ *
+ * Sugar 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA.
+ */
+
+#include "sugar-browser.h"
+
+#include <nsCOMPtr.h>
+#include <nsIPrefService.h>
+#include <nsServiceManagerUtils.h>
+
+enum {
+ PROP_0,
+ PROP_PROGRESS,
+ PROP_TITLE,
+ PROP_ADDRESS,
+ PROP_CAN_GO_BACK,
+ PROP_CAN_GO_FORWARD
+};
+
+void
+sugar_browser_startup(void)
+{
+ nsCOMPtr<nsIPrefService> prefService;
+
+ prefService = do_GetService(NS_PREFSERVICE_CONTRACTID);
+ NS_ENSURE_TRUE(prefService, );
+
+ nsCOMPtr<nsIPrefBranch> pref;
+ prefService->GetBranch("", getter_AddRefs(pref));
+ NS_ENSURE_TRUE(pref, );
+
+ pref->SetBoolPref ("dom.disable_open_during_load", TRUE);
+}
+
+G_DEFINE_TYPE(SugarBrowser, sugar_browser, GTK_TYPE_MOZ_EMBED)
+
+static void
+sugar_browser_get_property(GObject *object,
+ guint prop_id,
+ GValue *value,
+ GParamSpec *pspec)
+{
+ SugarBrowser *browser = SUGAR_BROWSER(object);
+
+ switch (prop_id) {
+ case PROP_PROGRESS:
+ g_value_set_double(value, browser->progress);
+ break;
+ case PROP_ADDRESS:
+ g_value_set_string(value, browser->address);
+ break;
+ case PROP_TITLE:
+ g_value_set_string(value, browser->title);
+ break;
+ case PROP_CAN_GO_BACK:
+ g_value_set_boolean(value, browser->can_go_back);
+ break;
+ case PROP_CAN_GO_FORWARD:
+ g_value_set_boolean(value, browser->can_go_forward);
+ break;
+ default:
+ G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
+ break;
+ }
+}
+
+
+static void
+sugar_browser_class_init(SugarBrowserClass *browser_class)
+{
+ GObjectClass *gobject_class = G_OBJECT_CLASS(browser_class);
+
+ gobject_class->get_property = sugar_browser_get_property;
+
+ g_object_class_install_property(gobject_class, PROP_PROGRESS,
+ g_param_spec_double ("progress",
+ "Progress",
+ "Progress",
+ 0.0, 1.0, 0.0,
+ G_PARAM_READABLE));
+
+ g_object_class_install_property (gobject_class, PROP_ADDRESS,
+ g_param_spec_string ("address",
+ "Address",
+ "Address",
+ "",
+ G_PARAM_READABLE));
+
+ g_object_class_install_property (gobject_class, PROP_TITLE,
+ g_param_spec_string ("title",
+ "Title",
+ "Title",
+ "",
+ G_PARAM_READABLE));
+
+ g_object_class_install_property (gobject_class, PROP_CAN_GO_BACK,
+ g_param_spec_boolean ("can-go-back",
+ "Can go back",
+ "Can go back",
+ FALSE,
+ G_PARAM_READABLE));
+
+ g_object_class_install_property (gobject_class, PROP_CAN_GO_FORWARD,
+ g_param_spec_boolean ("can-go-forward",
+ "Can go forward",
+ "Can go forward",
+ FALSE,
+ G_PARAM_READABLE));
+}
+
+SugarBrowser *
+sugar_browser_create_window(SugarBrowser *browser)
+{
+ return SUGAR_BROWSER_GET_CLASS(browser)->create_window(browser);
+}
+
+static void
+update_navigation_properties(SugarBrowser *browser)
+{
+ GtkMozEmbed *embed = GTK_MOZ_EMBED(browser);
+
+ browser->can_go_back = gtk_moz_embed_can_go_back(embed);
+ g_object_notify (G_OBJECT(browser), "can_go_back");
+
+ browser->can_go_forward = gtk_moz_embed_can_go_forward(embed);
+ g_object_notify (G_OBJECT(browser), "can_go_forward");
+}
+
+static void
+new_window_cb(GtkMozEmbed *embed,
+ GtkMozEmbed **newEmbed,
+ guint chromemask)
+{
+ SugarBrowser *browser;
+
+ browser = sugar_browser_create_window(SUGAR_BROWSER(embed));
+
+ *newEmbed = GTK_MOZ_EMBED(browser);
+}
+
+static void
+sugar_browser_set_progress(SugarBrowser *browser, float progress)
+{
+ g_return_if_fail(SUGAR_IS_BROWSER(browser));
+
+ browser->progress = progress;
+ g_object_notify (G_OBJECT(browser), "progress");
+}
+
+static void
+net_state_cb(GtkMozEmbed *embed, const char *aURI, gint state, guint status)
+{
+ SugarBrowser *browser = SUGAR_BROWSER(embed);
+
+ if (state & GTK_MOZ_EMBED_FLAG_IS_NETWORK) {
+ if (state & GTK_MOZ_EMBED_FLAG_START) {
+ browser->total_requests = 0;
+ browser->current_requests = 0;
+ browser->progress = 0.0;
+ }
+
+ update_navigation_properties(browser);
+ }
+
+ if (state & GTK_MOZ_EMBED_FLAG_IS_REQUEST) {
+ float progress;
+
+ if (state & GTK_MOZ_EMBED_FLAG_START) {
+ browser->total_requests++;
+ }
+ else if (state & GTK_MOZ_EMBED_FLAG_STOP)
+ {
+ browser->current_requests++;
+ }
+
+ progress = float(browser->current_requests) /
+ float(browser->total_requests);
+ if (progress > browser->progress) {
+ sugar_browser_set_progress(browser, progress);
+ }
+ }
+}
+
+static void
+title_cb(GtkMozEmbed *embed)
+{
+ SugarBrowser *browser = SUGAR_BROWSER(embed);
+
+ g_free(browser->title);
+ browser->title = gtk_moz_embed_get_title(embed);
+
+ g_object_notify (G_OBJECT(browser), "title");
+}
+
+static void
+location_cb(GtkMozEmbed *embed)
+{
+ SugarBrowser *browser = SUGAR_BROWSER(embed);
+
+ g_free(browser->address);
+ browser->address = gtk_moz_embed_get_location(embed);
+
+ g_object_notify (G_OBJECT(browser), "address");
+}
+
+static void
+sugar_browser_init(SugarBrowser *browser)
+{
+ browser->title = NULL;
+ browser->address = NULL;
+ browser->progress = 0.0;
+
+ g_signal_connect(G_OBJECT(browser), "new-window",
+ G_CALLBACK(new_window_cb), NULL);
+ g_signal_connect(G_OBJECT(browser), "net-state-all",
+ G_CALLBACK(net_state_cb), NULL);
+ g_signal_connect(G_OBJECT(browser), "title",
+ G_CALLBACK(title_cb), NULL);
+ g_signal_connect(G_OBJECT(browser), "location",
+ G_CALLBACK(location_cb), NULL);
+}
diff --git a/lib/src/sugar-browser.h b/lib/src/sugar-browser.h
new file mode 100644
index 0000000..e6aca96
--- /dev/null
+++ b/lib/src/sugar-browser.h
@@ -0,0 +1,60 @@
+/*
+ * Copyright (C) 2006 Red Hat, Inc
+ *
+ * Sugar 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.
+ *
+ * Sugar 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA.
+ */
+
+#ifndef __SUGAR_BROWSER_H__
+#define __SUGAR_BROWSER_H__
+
+#include <gtkmozembed.h>
+
+G_BEGIN_DECLS
+
+typedef struct _SugarBrowser SugarBrowser;
+typedef struct _SugarBrowserClass SugarBrowserClass;
+
+#define SUGAR_TYPE_BROWSER (sugar_browser_get_type())
+#define SUGAR_BROWSER(object) (G_TYPE_CHECK_INSTANCE_CAST((object), SUGAR_TYPE_BROWSER, SugarBrowser))
+#define SUGAR_BROWSER_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST((klass), SUGAR_TYPE_BROWSER, SugarBrowserClass))
+#define SUGAR_IS_BROWSER(object) (G_TYPE_CHECK_INSTANCE_TYPE((object), SUGAR_TYPE_BROWSER))
+#define SUGAR_IS_BROWSER_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE((klass), SUGAR_TYPE_BROWSER))
+#define SUGAR_BROWSER_GET_CLASS(object) (G_TYPE_INSTANCE_GET_CLASS((object), SUGAR_TYPE_BROWSER, SugarBrowserClass))
+
+struct _SugarBrowser {
+ GtkMozEmbed base_instance;
+
+ int total_requests;
+ int current_requests;
+ float progress;
+ char *address;
+ char *title;
+ gboolean can_go_back;
+ gboolean can_go_forward;
+};
+
+struct _SugarBrowserClass {
+ GtkMozEmbedClass base_class;
+
+ SugarBrowser * (* create_window) (SugarBrowser *browser);
+};
+
+GType sugar_browser_get_type (void);
+void sugar_browser_startup (void);
+SugarBrowser *sugar_browser_create_window (SugarBrowser *browser);
+
+G_END_DECLS
+
+#endif
diff --git a/lib/src/sugar-key-grabber.c b/lib/src/sugar-key-grabber.c
index f31e012..ee428cb 100644
--- a/lib/src/sugar-key-grabber.c
+++ b/lib/src/sugar-key-grabber.c
@@ -33,22 +33,6 @@
* for these set */
#define USED_MODS (GDK_SHIFT_MASK | GDK_CONTROL_MASK | GDK_MOD1_MASK)
-struct _SugarKeyGrabber {
- GObject base_instance;
-
- GdkWindow *root;
- GList *keys;
-};
-
-struct _SugarKeyGrabberClass {
- GObjectClass base_class;
-
- void (* key_pressed) (SugarKeyGrabber *grabber,
- const char *key);
- void (* key_released) (SugarKeyGrabber *grabber,
- const char *key);
-};
-
enum {
KEY_PRESSED,
KEY_RELEASED,
diff --git a/lib/src/sugar-key-grabber.h b/lib/src/sugar-key-grabber.h
index 3791e02..720a931 100644
--- a/lib/src/sugar-key-grabber.h
+++ b/lib/src/sugar-key-grabber.h
@@ -34,8 +34,23 @@ typedef struct _SugarKeyGrabberPrivate SugarKeyGrabberPrivate;
#define SUGAR_IS_KEYGRABBER_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE((klass), SUGAR_TYPE_KEY_GRABBER))
#define SUGAR_KEY_GRABBER_GET_CLASS(object) (G_TYPE_INSTANCE_GET_CLASS((object), SUGAR_TYPE_KEY_GRABBER, SugarKeyGrabberClass))
+struct _SugarKeyGrabber {
+ GObject base_instance;
+
+ GdkWindow *root;
+ GList *keys;
+};
+
+struct _SugarKeyGrabberClass {
+ GObjectClass base_class;
+
+ void (* key_pressed) (SugarKeyGrabber *grabber,
+ const char *key);
+ void (* key_released) (SugarKeyGrabber *grabber,
+ const char *key);
+};
+
GType sugar_key_grabber_get_type (void);
-GObject *sugar_key_grabber_new (void);
void sugar_key_grabber_grab (SugarKeyGrabber *grabber,
const char *key);