aboutsummaryrefslogtreecommitdiffstats
path: root/embed
diff options
context:
space:
mode:
authorChristian Persch <chpe@src.gnome.org>2008-04-03 22:47:00 +0800
committerChristian Persch <chpe@src.gnome.org>2008-04-03 22:47:00 +0800
commitc0267b1c65c216a3f1e4743be20b7175ac903b50 (patch)
tree535bef47775e664f85e071ca2fbb7c56816d17de /embed
parentbfe81e9680d7520a4bca4429bc02d5db45245212 (diff)
downloadgsoc2013-epiphany-c0267b1c65c216a3f1e4743be20b7175ac903b50.tar
gsoc2013-epiphany-c0267b1c65c216a3f1e4743be20b7175ac903b50.tar.gz
gsoc2013-epiphany-c0267b1c65c216a3f1e4743be20b7175ac903b50.tar.bz2
gsoc2013-epiphany-c0267b1c65c216a3f1e4743be20b7175ac903b50.tar.lz
gsoc2013-epiphany-c0267b1c65c216a3f1e4743be20b7175ac903b50.tar.xz
gsoc2013-epiphany-c0267b1c65c216a3f1e4743be20b7175ac903b50.tar.zst
gsoc2013-epiphany-c0267b1c65c216a3f1e4743be20b7175ac903b50.zip
Decruftify
svn path=/trunk/; revision=8182
Diffstat (limited to 'embed')
-rw-r--r--embed/xulrunner/AUTHORS2
-rw-r--r--embed/xulrunner/COPYRIGHT6
-rw-r--r--embed/xulrunner/ChangeLog-preEphy548
-rw-r--r--embed/xulrunner/HACKING10
-rw-r--r--embed/xulrunner/MAINTAINERS2
-rw-r--r--embed/xulrunner/Makefile.am12
-rw-r--r--embed/xulrunner/NEWS0
-rw-r--r--embed/xulrunner/PLAN26
-rw-r--r--embed/xulrunner/README0
-rw-r--r--embed/xulrunner/STATUS2
-rw-r--r--embed/xulrunner/TODO1
-rw-r--r--embed/xulrunner/bindings/Makefile.am7
-rw-r--r--embed/xulrunner/bindings/python/Makefile.am62
-rw-r--r--embed/xulrunner/bindings/python/gnomegeckoembed.defs294
-rw-r--r--embed/xulrunner/bindings/python/gnomegeckoembed.override19
-rw-r--r--embed/xulrunner/bindings/python/gnomegeckoembedmodule.c29
-rw-r--r--embed/xulrunner/bindings/python/test.py32
-rw-r--r--embed/xulrunner/components/ContentHandler.cpp481
-rw-r--r--embed/xulrunner/components/ContentHandler.h81
-rw-r--r--embed/xulrunner/components/EphyAboutModule.cpp724
-rw-r--r--embed/xulrunner/components/EphyAboutModule.h65
-rw-r--r--embed/xulrunner/components/EphyContentPolicy.cpp244
-rw-r--r--embed/xulrunner/components/EphyContentPolicy.h76
-rw-r--r--embed/xulrunner/components/EphyHistoryListener.cpp170
-rw-r--r--embed/xulrunner/components/EphyHistoryListener.h49
-rw-r--r--embed/xulrunner/components/EphyRedirectChannel.cpp32
-rw-r--r--embed/xulrunner/components/EphyRedirectChannel.h50
-rw-r--r--embed/xulrunner/components/EphySidebar.cpp161
-rw-r--r--embed/xulrunner/components/EphySidebar.h66
-rw-r--r--embed/xulrunner/components/FilePicker.cpp453
-rw-r--r--embed/xulrunner/components/FilePicker.h62
-rw-r--r--embed/xulrunner/components/GeckoCookiePromptService.cpp160
-rw-r--r--embed/xulrunner/components/GeckoCookiePromptService.h43
-rw-r--r--embed/xulrunner/components/GeckoFormSigningDialog.cpp158
-rw-r--r--embed/xulrunner/components/GeckoFormSigningDialog.h42
-rw-r--r--embed/xulrunner/components/GeckoPrintService.cpp714
-rw-r--r--embed/xulrunner/components/GeckoPrintService.h54
-rw-r--r--embed/xulrunner/components/GeckoPrintSession.cpp629
-rw-r--r--embed/xulrunner/components/GeckoPrintSession.h94
-rw-r--r--embed/xulrunner/components/GeckoPromptService.cpp907
-rw-r--r--embed/xulrunner/components/GeckoPromptService.h48
-rw-r--r--embed/xulrunner/components/GeckoSpellCheckEngine.cpp200
-rw-r--r--embed/xulrunner/components/GeckoSpellCheckEngine.h52
-rw-r--r--embed/xulrunner/components/GlobalHistory.cpp221
-rw-r--r--embed/xulrunner/components/GlobalHistory.h68
-rw-r--r--embed/xulrunner/components/GtkNSSClientAuthDialogs.cpp284
-rw-r--r--embed/xulrunner/components/GtkNSSClientAuthDialogs.h45
-rw-r--r--embed/xulrunner/components/GtkNSSDialogs.cpp1695
-rw-r--r--embed/xulrunner/components/GtkNSSDialogs.h61
-rw-r--r--embed/xulrunner/components/GtkNSSKeyPairDialogs.cpp216
-rw-r--r--embed/xulrunner/components/GtkNSSKeyPairDialogs.h45
-rw-r--r--embed/xulrunner/components/GtkNSSSecurityWarningDialogs.cpp285
-rw-r--r--embed/xulrunner/components/GtkNSSSecurityWarningDialogs.h83
-rw-r--r--embed/xulrunner/components/Makefile.am104
-rw-r--r--embed/xulrunner/components/MozDownload.cpp824
-rw-r--r--embed/xulrunner/components/MozDownload.h153
-rw-r--r--embed/xulrunner/components/MozRegisterComponents.cpp330
-rw-r--r--embed/xulrunner/components/MozRegisterComponents.h28
-rw-r--r--embed/xulrunner/data/Makefile.am2
-rw-r--r--embed/xulrunner/data/gnome-gecko-embed.pc.in11
-rw-r--r--embed/xulrunner/embed/EphyBrowser.cpp1612
-rw-r--r--embed/xulrunner/embed/EphyBrowser.h223
-rw-r--r--embed/xulrunner/embed/EphyDirectoryProvider.cpp101
-rw-r--r--embed/xulrunner/embed/EphyDirectoryProvider.h37
-rw-r--r--embed/xulrunner/embed/EphyFind.cpp222
-rw-r--r--embed/xulrunner/embed/EphyFind.h60
-rw-r--r--embed/xulrunner/embed/EphyHeaderSniffer.cpp441
-rw-r--r--embed/xulrunner/embed/EphyHeaderSniffer.h95
-rw-r--r--embed/xulrunner/embed/EphySingle.cpp394
-rw-r--r--embed/xulrunner/embed/EphySingle.h67
-rw-r--r--embed/xulrunner/embed/EventContext.cpp1105
-rw-r--r--embed/xulrunner/embed/EventContext.h78
-rw-r--r--embed/xulrunner/embed/Makefile.am57
-rw-r--r--embed/xulrunner/embed/mozilla-download.cpp313
-rw-r--r--embed/xulrunner/embed/mozilla-download.h61
-rw-r--r--embed/xulrunner/embed/mozilla-embed-event.cpp221
-rw-r--r--embed/xulrunner/embed/mozilla-embed-event.h74
-rw-r--r--embed/xulrunner/embed/mozilla-embed-find.cpp198
-rw-r--r--embed/xulrunner/embed/mozilla-embed-find.h57
-rw-r--r--embed/xulrunner/embed/mozilla-embed-persist.cpp416
-rw-r--r--embed/xulrunner/embed/mozilla-embed-persist.h63
-rw-r--r--embed/xulrunner/embed/mozilla-embed-single.cpp1389
-rw-r--r--embed/xulrunner/embed/mozilla-embed-single.h57
-rw-r--r--embed/xulrunner/embed/mozilla-embed.cpp1271
-rw-r--r--embed/xulrunner/embed/mozilla-embed.h66
-rw-r--r--embed/xulrunner/embed/mozilla-notifiers.cpp1257
-rw-r--r--embed/xulrunner/embed/mozilla-notifiers.h58
-rw-r--r--embed/xulrunner/src/EmbedContentListener.cpp159
-rw-r--r--embed/xulrunner/src/EmbedContentListener.h63
-rw-r--r--embed/xulrunner/src/EmbedEventListener.cpp183
-rw-r--r--embed/xulrunner/src/EmbedEventListener.h102
-rw-r--r--embed/xulrunner/src/EmbedProgress.cpp224
-rw-r--r--embed/xulrunner/src/EmbedProgress.h63
-rw-r--r--embed/xulrunner/src/EmbedStream.cpp311
-rw-r--r--embed/xulrunner/src/EmbedStream.h79
-rw-r--r--embed/xulrunner/src/EmbedWindow.cpp467
-rw-r--r--embed/xulrunner/src/EmbedWindow.h97
-rw-r--r--embed/xulrunner/src/EmbedWindowCreator.cpp108
-rw-r--r--embed/xulrunner/src/EmbedWindowCreator.h51
-rw-r--r--embed/xulrunner/src/GeckoBrowser.cpp676
-rw-r--r--embed/xulrunner/src/GeckoBrowser.h159
-rw-r--r--embed/xulrunner/src/GeckoSingle.cpp122
-rw-r--r--embed/xulrunner/src/GeckoSingle.h97
-rw-r--r--embed/xulrunner/src/Makefile.am132
-rw-r--r--embed/xulrunner/src/gecko-dom-event-internal.h28
-rw-r--r--embed/xulrunner/src/gecko-dom-event-private.h38
-rw-r--r--embed/xulrunner/src/gecko-dom-event.cpp78
-rw-r--r--embed/xulrunner/src/gecko-dom-event.h40
-rw-r--r--embed/xulrunner/src/gecko-embed-marshal.list10
-rw-r--r--embed/xulrunner/src/gecko-embed-private.h54
-rw-r--r--embed/xulrunner/src/gecko-embed-signals.h82
-rw-r--r--embed/xulrunner/src/gecko-embed-single-private.h59
-rw-r--r--embed/xulrunner/src/gecko-embed-single.cpp182
-rw-r--r--embed/xulrunner/src/gecko-embed-single.h88
-rw-r--r--embed/xulrunner/src/gecko-embed-types.h118
-rw-r--r--embed/xulrunner/src/gecko-embed.cpp1029
-rw-r--r--embed/xulrunner/src/gecko-embed.h151
-rw-r--r--embed/xulrunner/src/gecko-init-internal.h30
-rw-r--r--embed/xulrunner/src/gecko-init-private.h33
-rw-r--r--embed/xulrunner/src/gecko-init.cpp372
-rw-r--r--embed/xulrunner/src/gecko-init.h35
-rw-r--r--embed/xulrunner/tests/Makefile.am30
-rw-r--r--embed/xulrunner/tests/TestGtkEmbedNotebook.cpp49
-rw-r--r--embed/xulrunner/tests/testgeckoembed.cpp1145
-rw-r--r--embed/xulrunner/utils/AutoJSContextStack.cpp48
-rw-r--r--embed/xulrunner/utils/AutoJSContextStack.h41
-rw-r--r--embed/xulrunner/utils/AutoWindowModalState.cpp43
-rw-r--r--embed/xulrunner/utils/AutoWindowModalState.h38
-rw-r--r--embed/xulrunner/utils/EphyBadCertRejector.cpp68
-rw-r--r--embed/xulrunner/utils/EphyBadCertRejector.h36
-rw-r--r--embed/xulrunner/utils/EphyUtils.cpp203
-rw-r--r--embed/xulrunner/utils/EphyUtils.h66
-rw-r--r--embed/xulrunner/utils/GeckoUtils.cpp87
-rw-r--r--embed/xulrunner/utils/GeckoUtils.h34
-rw-r--r--embed/xulrunner/utils/Makefile.am43
-rw-r--r--embed/xulrunner/utils/ggeAutoModalDialog.cpp189
-rw-r--r--embed/xulrunner/utils/ggeAutoModalDialog.h70
-rw-r--r--embed/xulrunner/utils/ggeAutoSurvivalArea.cpp42
-rw-r--r--embed/xulrunner/utils/ggeAutoSurvivalArea.h44
139 files changed, 0 insertions, 29111 deletions
diff --git a/embed/xulrunner/AUTHORS b/embed/xulrunner/AUTHORS
deleted file mode 100644
index 7b35d3e1d..000000000
--- a/embed/xulrunner/AUTHORS
+++ /dev/null
@@ -1,2 +0,0 @@
-The code was originally taken from mozilla's gtkmozembed
-code. \ No newline at end of file
diff --git a/embed/xulrunner/COPYRIGHT b/embed/xulrunner/COPYRIGHT
deleted file mode 100644
index 0f81722a0..000000000
--- a/embed/xulrunner/COPYRIGHT
+++ /dev/null
@@ -1,6 +0,0 @@
-This library is available under the terms of the
-GNU Lesser General Public Licence, either version 2.1, or
-(at your option) any later version.
-
-NOTE: Some files in components/ are under GPL2+, so if they are
-compiled in, the result is under GPL2+.
diff --git a/embed/xulrunner/ChangeLog-preEphy b/embed/xulrunner/ChangeLog-preEphy
deleted file mode 100644
index a927488fe..000000000
--- a/embed/xulrunner/ChangeLog-preEphy
+++ /dev/null
@@ -1,548 +0,0 @@
-This is the old ChangeLog from gnome-gecko-embed before being imported into
-Epiphany SVN.
-
-2006-10-13 Jean-François Rameau <jframeau@cvs.gnome.org>
-
- * src/Makefile.am:
- * tests/testgeckoembed.cpp:
-
- Fix type-builtin part. Fix missing include in testgeckoembed.cpp.
-
-2006-10-08 Christian Persch <chpe@cvs.gnome.org>
-
- * src/Makefile.am:
-
- Fix a bug in the last commit.
-
-2006-10-08 Christian Persch <chpe@cvs.gnome.org>
-
- * src/Makefile.am:
-
- Make the type builtins value types not global.
-
-2006-09-17 Christian Persch <chpe@cvs.gnome.org>
-
- * Makefile.am:
- * configure.ac:
- * data/Makefile.am:
- * data/gnome-gecko-embed.pc.in:
- * m4/gecko.m4:
-
- Add pkg-config file.
-
-2006-09-06 Christian Persch <chpe@cvs.gnome.org>
-
- * *.c *.cpp:
-
- Remove some unnecessary static data.
-
-2006-08-22 Christian Persch <chpe@cvs.gnome.org>
-
- * configure.ac:
- * src/EmbedProgress.cpp:
- * src/Makefile.am:
- * src/gecko-embed-single.h:
- R src/gecko-embed-types.c:
- * src/gecko-embed-types.h:
- * src/gecko-embed.cpp:
- * src/gecko-embed.h:
-
- Autogenerate the type builtins.
-
-2006-08-22 Christian Persch <chpe@cvs.gnome.org>
-
- A src/AutoWindowModalState.cpp:
- A src/AutoWindowModalState.h:
- * src/GeckoPromptService.cpp:
- * src/Makefile.am:
-
- Sync with Epiphany.
-
-2006-08-22 Christian Persch <chpe@cvs.gnome.org>
-
- * src/AutoJSContextStack.cpp:
- * src/EmbedContentListener.cpp:
- * src/EmbedEventListener.cpp:
- * src/EmbedProgress.cpp:
- * src/EmbedWindowCreator.cpp:
- * src/GeckoBrowser.cpp:
- * src/GeckoPromptService.cpp:
- * src/GeckoSingle.cpp:
- * src/GeckoUtils.cpp:
- * src/gecko-dom-event.cpp:
- * src/gecko-embed-single.cpp:
- * src/gecko-embed-types.c:
- * src/gecko-embed.cpp:
- * src/gecko-init.cpp:
- * src/nsEmbedAPI.cpp:
-
- Include config.h unconditionally.
-
-2006-08-22 Christian Persch <chpe@cvs.gnome.org>
-
- R COPYING:
- A COPYING.LESSER:
- R COPYING.MPL:
- * COPYRIGHT:
- * Makefile.am:
- * configure.ac:
- R src/EmbedComponents.cpp.in:
- * src/EmbedContentListener.cpp:
- * src/EmbedContentListener.h:
- * src/EmbedEventListener.cpp:
- * src/EmbedEventListener.h:
- * src/EmbedProgress.cpp:
- * src/EmbedProgress.h:
- * src/EmbedStream.cpp:
- * src/EmbedStream.h:
- * src/EmbedWindow.cpp:
- * src/EmbedWindow.h:
- * src/EmbedWindowCreator.cpp:
- * src/EmbedWindowCreator.h:
- * src/GeckoBrowser.cpp:
- * src/GeckoBrowser.h:
- * src/GeckoSingle.cpp:
- * src/GeckoSingle.h:
- * src/gecko-embed-private.h:
- * src/gecko-embed-signals.h:
- * src/gecko-embed-single-private.h:
- * src/gecko-embed-single.cpp:
- * src/gecko-embed-single.h:
- * src/gecko-embed-types.c:
- * src/gecko-embed-types.h:
- * src/gecko-embed.cpp:
- * src/gecko-embed.h:
- * src/gecko-init.cpp:
- * src/nsEmbedAPI.cpp:
- * src/nsProfileDirServiceProvider.cpp:
- * src/nsProfileDirServiceProvider2.cpp:
- * tests/testgeckoembed.cpp:
-
- Cleanup and exercise relicence clause to make this LGPL 2.1+ only.
-
-2006-07-18 Christian Persch <chpe@cvs.gnome.org>
-
- * src/GeckoPromptService.cpp:
-
- Force label wrapping.
-
-2006-04-01 Christian Persch <chpe@cvs.gnome.org>
-
- * src/GeckoPromptService.cpp:
-
- Fix crash when cancelling the prompt before the timeout has run.
-
-2006-03-21 Christian Persch <chpe@cvs.gnome.org>
-
- * tests/testgeckoembed.cpp:
-
- Add handler for context menu signal.
-
-2006-03-21 Christian Persch <chpe@cvs.gnome.org>
-
- * src/gecko-embed.cpp:
-
- Fix focus signal connection.
-
-2006-03-21 Christian Persch <chpe@cvs.gnome.org>
-
- * src/gecko-embed.cpp:
-
- Fix typo.
-
-2006-03-21 Christian Persch <chpe@cvs.gnome.org>
-
- * src/Makefile.am:
- A src/gecko-dom-event.h:
- A src/gecko-dom-event-internal.h:
- A src/gecko-dom-event-private.h:
- A src/gecko-dom-event.cpp:
- * src/EmbedEventListener.cpp:
- * src/EmbedEventListener.h:
- * src/GeckoBrowser.cpp:
- * src/gecko-embed-marshal.list:
- * src/gecko-embed-signals.h:
- * src/gecko-embed.cpp:
- * src/gecko-embed.h:
- * tests/testgeckoembed.cpp:
-
- Rework the DOM signals.
- Add context menu signal.
-
-2006-03-21 Christian Persch <chpe@cvs.gnome.org>
-
- R src/gecko-embed-marshal.c:
- R src/gecko-embed-marshal.h:
-
- Remove autogenerated files from cvs.
-
-2006-03-17 Xan Lopez <xan@gnome.org>
-
- * src/GeckoSingle.cpp:
- * src/Makefile.am:
- * src/gecko-init-private.h:
- * src/gecko-init.cpp:
- * src/gecko-init.h:
- * tests/testgeckoembed.cpp:
-
- Rework headers.
-
-2006-03-17 Xan Lopez <xan@gnome.org>
-
- * src/GeckoSingle.cpp:
- * src/GeckoSingle.h:
- * src/Makefile.am:
- * src/gecko-embed-single.cpp:
- * src/gecko-embed-single.h:
- * src/gecko-init-private.h:
- * src/gecko-init.cpp:
- * src/gecko-init.h:
-
- Moved init/shutdown logic to gecko-init
-
- * tests/testgeckoembed.cpp:
-
- Change test to use new functions
-
-2006-03-15 Xan Lopez <xan@gnome.org>
-
- * bindings/python/test.py:
-
- Update.
-
-2006-03-15 Xan Lopez <xan@gnome.org>
-
- * bindings/python/gnomegeckoembed.defs:
- * src/gecko-embed-types.h:
-
- Fix the flags/enum thing properly.
-
-2006-03-15 Xan Lopez <xan@gnome.org>
-
- * m4/python.m4:
-
- Forgot.
-
-2006-03-15 Xan Lopez <xan@gnome.org>
-
- * Makefile.am:
- * bindings/Makefile.am:
- * bindings/python/Makefile.am:
- * bindings/python/gnomegeckoembed.defs:
- * bindings/python/gnomegeckoembed.override:
- * bindings/python/gnomegeckoembedmodule.c: (initgnomegeckoembed):
- * bindings/python/test.py:
- * configure.ac:
-
- Python bindings.
-
- * src/GeckoBrowser.cpp:
-
- Fix typo.
-
- * src/gecko-embed-types.h:
-
- s/GECKO_TYPE_EMBED_STATUS_ENUM/GECKO_TYPE_EMBED_STATUS_FLAGS/
-
-2006-03-14 Jean-François Rameau <jframeau@cvs.gnome.org>
-
- * autogen.sh:
- * src/GeckoSingle.cpp:
-
- Fix some typos.
-
-2006-03-13 Christian Persch <chpe@cvs.gnome.org>
-
- R src/EmbedPrompter.cpp:
- R src/EmbedPrompter.h:
- R src/GtkPromptService.cpp:
- R src/GtkPromptService.h:
- A src/AutoJSContextStack.cpp:
- A src/AutoJSContextStack.h:
- A src/GeckoPromptService.cpp:
- A src/GeckoPromptService.h:
- * src/EmbedWindow.cpp:
- * src/GeckoBrowser.cpp:
- * src/GeckoSingle.cpp:
- * src/GeckoUtils.cpp:
- * src/GeckoUtils.h:
- * src/Makefile.am:
-
- Import prompt service implementation from Epiphany.
-
-2004-03-13 Christian Persch <chpe@cvs.gnome.org>
-
- * src/gecko-embed.cpp:
-
- Fix signal declarations to include RUN_LAST.
-
-2006-03-13 Xan Lopez <xan@gnome.org>
-
- * src/EmbedEventListener.cpp:
-
- Merge https://bugzilla.mozilla.org/show_bug.cgi?id=306839
-
-2004-03-13 Christian Persch <chpe@cvs.gnome.org>
-
- * Makefile.am:
-
- Add ACLOCAL_AMFLAGS.
-
-2004-03-13 Christian Persch <chpe@cvs.gnome.org>
-
- * configure.ac:
-
- We don't want to support gecko 1.7 or non-toolkit geckos.
-
-2006-03-13 Xan Lopez <xan@gnome.org>
-
- * src/gecko-embed-types.c: (gecko_embed_progress_flags_get_type):
- * src/gecko-embed-types.h:
-
- Merge https://bugzilla.mozilla.org/show_bug.cgi?id=306550
-
-2006-03-13 Xan Lopez <xan@gnome.org>
-
- * src/GeckoBrowser.cpp:
- * src/GeckoSingle.h:
- * src/gecko-embed.cpp:
-
- Merge https://bugzilla.mozilla.org/show_bug.cgi?id=210373
-
-2006-03-13 Xan Lopez <xan@gnome.org>
-
- * src/GeckoBrowser.h:
- * src/GeckoSingle.cpp:
- * src/GeckoSingle.h:
- * src/Makefile.am:
-
- Merge https://bugzilla.mozilla.org/show_bug.cgi?id=275463
-
-2006-03-13 Xan Lopez <xan@gnome.org>
-
- * src/GeckoBrowser.cpp:
- * src/GeckoBrowser.h:
- * src/gecko-embed.cpp:
-
- Ahem, back off #97580.
-
-2006-03-13 Xan Lopez <xan@gnome.org>
-
- * src/gecko-embed.cpp:
-
- Merge http://bonsai.mozilla.org/cvsview2.cgi?diff_mode=context&whitespace_mode=show&subdir=mozilla/embedding/browser/gtk/src&command=DIFF_FRAMESET&file=gtkmozembed2.cpp&rev1=1.42&rev2=1.43&root=/cvsroot
-
-2006-03-13 Xan Lopez <xan@gnome.org>
-
- * src/EmbedContentListener.cpp:
-
- Merge http://bonsai.mozilla.org/cvsview2.cgi?diff_mode=context&whitespace_mode=show&subdir=mozilla/embedding/browser/gtk/src&command=DIFF_FRAMESET&file=EmbedContentListener.cpp&rev1=1.17&rev2=1.18&root=/cvsroot
-
-2006-03-13 Xan Lopez <xan@gnome.org>
-
- * src/GeckoBrowser.cpp:
- * src/GeckoBrowser.h:
- * src/gecko-embed.cpp:
-
- Merge https://bugzilla.mozilla.org/show_bug.cgi?id=97580
-
-2006-03-13 Xan Lopez <xan@gnome.org>
-
- * src/GeckoSingle.cpp:
-
- Merge https://bugzilla.mozilla.org/show_bug.cgi?id=242024
-
-2006-03-13 Xan Lopez <xan@gnome.org>
-
- * src/EmbedWindow.cpp:
-
- Merge https://bugzilla.mozilla.org/show_bug.cgi?id=238052
-
-2006-03-13 Xan Lopez <xan@gnome.org>
-
- * configure.ac:
-
- Fix typo.
-
- * src/GeckoBrowser.cpp:
-
- Merge https://bugzilla.mozilla.org/show_bug.cgi?id=276482
-
-2004-09-25 Christian Persch <chpe@cvs.gnome.org>
-
- * src/GeckoBrowser.cpp:
- * src/GeckoSingle.cpp:
- * src/gecko-embed-single.cpp:
- * tests/testgeckoembed.cpp:
-
- Make testgeckoembed link.
-
-2004-09-24 Christian Persch <chpe@cvs.gnome.org>
-
- * src/EmbedProgress.cpp:
- * src/GeckoBrowser.cpp:
- * src/GeckoSingle.cpp:
- * src/GeckoSingle.h:
- * src/gecko-embed-single.cpp:
- * src/gecko-embed.cpp:
-
- Fix startup.
-
-2004-09-24 Christian Persch <chpe@cvs.gnome.org>
-
- * src/gecko-embed.cpp:
-
- Last GtkSignal bits ported to gobject.
-
-2004-09-24 Christian Persch <chpe@cvs.gnome.org>
-
- * src/EmbedEventListener.cpp:
- * src/EmbedProgress.cpp:
- * src/EmbedWindow.cpp:
- * src/EmbedWindowCreator.cpp:
- * src/GeckoBrowser.h:
- * src/GeckoSingle.cpp:
- * src/gecko-embed-signals.h:
- * src/gecko-embed.cpp:
- * src/gecko-embed.h:
-
- More gobject porting.
-
-2004-09-24 Christian Persch <chpe@cvs.gnome.org>
-
- * tests/Makefile.am:
- * tests/TestGtkEmbed.cpp:
- * tests/testgeckoembed.cpp:
-
- Started to port testgeckoembed to GeckoEmbed.
-
-2004-09-24 Christian Persch <chpe@cvs.gnome.org>
-
- * src/EmbedWindowCreator.cpp:
-
- Ported to gobject.
-
-2004-09-24 Christian Persch <chpe@cvs.gnome.org>
-
- * src/EmbedPrompter.cpp:
- * src/EmbedWindow.cpp:
-
- Ported to gobject.
-
-2004-09-24 Christian Persch <chpe@cvs.gnome.org>
-
- * src/EmbedProgress.cpp:
-
- Ported to gobject.
-
- * src/gecko-embed-marshal.list:
- * src/gecko-embed.cpp:
-
- Fix a signal.
-
-2004-09-24 Christian Persch <chpe@cvs.gnome.org>
-
- * src/EmbedContentListener.cpp:
- * src/EmbedEventListener.cpp:
-
- Ported to gobject.
-
-2004-09-24 Christian Persch <chpe@cvs.gnome.org>
-
- * src/EmbedContentListener.cpp:
- * src/EmbedContentListener.h:
- * src/EmbedEventListener.cpp:
- * src/EmbedEventListener.h:
- * src/EmbedPrivate.cpp:
- * src/EmbedPrivate.h:
- * src/EmbedProgress.cpp:
- * src/EmbedProgress.h:
- * src/EmbedWindow.cpp:
- * src/EmbedWindow.h:
- * src/EmbedWindowCreator.cpp:
- * src/GeckoBrowser.cpp:
- * src/GeckoBrowser.h:
- * src/GeckoSingle.cpp:
- * src/GeckoSingle.h:
- * src/Makefile.am:
- * src/gecko-embed-marshal.list:
- * src/gecko-embed-marshalers.list:
- * src/gecko-embed-private.h:
- * src/gecko-embed-signals.h:
- * src/gecko-embed-single-private.h:
- * src/gecko-embed-single.cpp:
- * src/gecko-embed-types.c: (gecko_embed_progress_flags_get_type),
- (gecko_embed_status_enums_get_type),
- (gecko_embed_reload_flags_get_type),
- (gecko_embed_chrome_flags_get_type):
- * src/gecko-embed-types.h:
- * src/gecko-embed.cpp:
- * src/gecko-embed.h:
- * src/gtkmozembed.h:
- * src/gtkmozembed2.cpp:
- * src/gtkmozembed_internal.h:
- * src/gtkmozembedmarshal.list:
- * src/gtkmozembedprivate.h:
-
- Renamed GtkMozEmbed to GeckoEmbed, EmbedPrivate to GeckoBrowser and split
- GeckoBrowser into per-embed and global things (-> GeckoSingle).
- First round of making things use gobject instead of gtkobject.
-
-2004-09-23 Christian Persch <chpe@cvs.gnome.org>
-
- * src/Makefile.am:
- * src/gtkmozembedmarshal.c:
- * src/gtkmozembedmarshal.h:
-
- Make marshalers autogenerate from list.
-
-2004-09-23 Christian Persch <chpe@cvs.gnome.org>
-
- * src/EmbedPrivate.cpp:
- * src/EmbedWindow.cpp:
- * src/gtkmozembed2.cpp:
- * tests/TestGtkEmbed.cpp:
- * tests/TestGtkEmbedChild.cpp:
- * tests/TestGtkEmbedMDI.cpp:
- * tests/TestGtkEmbedSocket.cpp:
-
- Remove all #ifdef MOZ_WIDGET_GTK code, and remove the
- checks for MOZ_WIDGET_GTK2.
-
-2004-09-23 Christian Persch <chpe@cvs.gnome.org>
-
- * src/EmbedPrivate.cpp:
- * src/Makefile.am:
- * tests/Makefile.am:
- * tests/TestGtkEmbed.cpp:
-
- Make it link and run.
-
-2004-09-21 Christian Persch <chpe@cvs.gnome.org>
-
- * data/gnome-gecko-embed-0.0.pc.in:
- * src/EmbedContentListener.cpp:
- * src/EmbedPrivate.cpp:
- * src/EmbedPrivate.h:
- * src/EmbedProgress.cpp:
- * src/EmbedProgress.h:
- * src/EmbedPrompter.cpp:
- * src/EmbedPrompter.h:
- * src/EmbedWindow.cpp:
- * src/EmbedWindow.h:
- * src/GtkPromptService.cpp:
- * src/GtkPromptService.h:
- * src/Makefile.am:
- * src/gtkmozembed2.cpp:
-
- Incorporate latest patch [http://bugzilla.mozilla.org/attachment.cgi?id=148650&action=view]
- from bug [http://bugzilla.mozilla.org/show_bug.cgi?id=205425].
-
-2004-09-21 Christian Persch <chpe@cvs.gnome.org>
-
- * TODO:
- * autogen.sh:
- * configure.ac:
- * src/Makefile.am:
-
- Make it pass autogen.
diff --git a/embed/xulrunner/HACKING b/embed/xulrunner/HACKING
deleted file mode 100644
index b93d7ae64..000000000
--- a/embed/xulrunner/HACKING
+++ /dev/null
@@ -1,10 +0,0 @@
-Do NOT commit to this module without permission from
-chpe@gnome.org .
-
-Please send patches either to chpe@gnome.org or for discussion to
-epiphany-list@gnome.org.
-
-Code style is mozilla code style, that is 2-spaces for indentation, and
-curly brackets are on a the same line.
-
-All files have to be encoded in UTF-8.
diff --git a/embed/xulrunner/MAINTAINERS b/embed/xulrunner/MAINTAINERS
deleted file mode 100644
index 7e15500c2..000000000
--- a/embed/xulrunner/MAINTAINERS
+++ /dev/null
@@ -1,2 +0,0 @@
-Email: chpe@gnome.org
-Email: xan@gnome.org
diff --git a/embed/xulrunner/Makefile.am b/embed/xulrunner/Makefile.am
deleted file mode 100644
index 86f3d8372..000000000
--- a/embed/xulrunner/Makefile.am
+++ /dev/null
@@ -1,12 +0,0 @@
-SUBDIRS = utils src embed components data bindings
-# SUBDIRS += tests
-
-DIST_SUBDIRS = utils src embed components data bindings tests
-
-NULL =
-
-EXTRA_DIST = \
- README \
- TODO \
- COPYRIGHT \
- $(NULL)
diff --git a/embed/xulrunner/NEWS b/embed/xulrunner/NEWS
deleted file mode 100644
index e69de29bb..000000000
--- a/embed/xulrunner/NEWS
+++ /dev/null
diff --git a/embed/xulrunner/PLAN b/embed/xulrunner/PLAN
deleted file mode 100644
index 50d0e9427..000000000
--- a/embed/xulrunner/PLAN
+++ /dev/null
@@ -1,26 +0,0 @@
-The plan is to fix the things which suck in gtkmozembed and some of
-which require direct access to the embedding layer to be fixed.
-
-Note that the following plans are not set in stone.
-
-- lifecycle:
- Move from the push_startup/pop_startup lifecycle management to explicit
- init/shutdown.
-- dom events:
- Make the DOM events signals actually useful by implementing a DOM context
- class accessible from C, where the context is only calculated on demand
- (since DOM signals can be emitted frequently and getting context is slow)
-- gtk-like tooltips:
- Make tooltips follow mouse (like in evince), not time out, and and make sure
- they don't fall off the side of the screen
-- printing:
- Integrate with gtk+ 2.10 printing out-of-the-box; atm every application
- codes its own libgnomeprint ps-to-printer support.
-- more gobject-like:
- Make use of gobject properties instead of signals (à la EphyTab)
-- find:
- Copy EphyEmbedFind.
-- prefs:
- Provide access to mozilla prefs from C (like mozilla-notifiers.h in epiphany/embed/mozilla/)
- and map common gconf prefs to moz prefs automatically (like mozilla-notifiers.cpp).
- That way we can also share the font prefs between epiphany, yelp and devhelp.
diff --git a/embed/xulrunner/README b/embed/xulrunner/README
deleted file mode 100644
index e69de29bb..000000000
--- a/embed/xulrunner/README
+++ /dev/null
diff --git a/embed/xulrunner/STATUS b/embed/xulrunner/STATUS
deleted file mode 100644
index 7732c1479..000000000
--- a/embed/xulrunner/STATUS
+++ /dev/null
@@ -1,2 +0,0 @@
-Taken from gtkmozembed trunk on 2004-09-21
-
diff --git a/embed/xulrunner/TODO b/embed/xulrunner/TODO
deleted file mode 100644
index e8bb8e81b..000000000
--- a/embed/xulrunner/TODO
+++ /dev/null
@@ -1 +0,0 @@
-- Fix tooltip direction: on RTL the tooltip should be RTL too! (see https://bugzilla.mozilla.org/show_bug.cgi?id=91312)
diff --git a/embed/xulrunner/bindings/Makefile.am b/embed/xulrunner/bindings/Makefile.am
deleted file mode 100644
index 4a6744246..000000000
--- a/embed/xulrunner/bindings/Makefile.am
+++ /dev/null
@@ -1,7 +0,0 @@
-SUBDIRS =
-
-# if ENABLE_PYTHON
-# SUBDIRS += python
-# endif
-
-DIST_SUBDIRS = python
diff --git a/embed/xulrunner/bindings/python/Makefile.am b/embed/xulrunner/bindings/python/Makefile.am
deleted file mode 100644
index 5343696e0..000000000
--- a/embed/xulrunner/bindings/python/Makefile.am
+++ /dev/null
@@ -1,62 +0,0 @@
-defsdir = $(datadir)/pygtk/2.0/defs
-defs_DATA = gnomegeckoembed.defs
-
-pkgpythondir = $(pyexecdir)/gtk-2.0
-pkgpyexecdir = $(pyexecdir)/gtk-2.0
-
-# gnomegeckoembed module
-pkgpyexec_LTLIBRARIES = gnomegeckoembed.la
-
-gnomegeckoembed_la_CPPFLAGS = \
- -I$(top_srcdir) \
- -I$(top_srcdir)/embed/xulrunner/src \
- -I$(top_builddir)/embed/xulrunner/src \
- $(AM_CPPFLAGS)
-
-gnomegeckoembed_la_CFLAGS = \
- $(GTK_CFLAGS) \
- $(NO_STRICT_ALIASING_CFLAGS) \
- $(PYGTK_CFLAGS) \
- $(PYTHON_CFLAGS) \
- $(AM_CFLAGS)
-
-gnomegeckoembed_la_LIBADD = \
- $(top_builddir)/embed/xulrunner/src/libgnomegeckoembed-0.0.la \
- $(GTK_LIBS) \
- $(PYTHON_LIBS) \
- $(PYTHON_EXTRA_LIBS) \
- $(PYGTK_LIBS)
-
-gnomegeckoembed_la_LDFLAGS = \
- -module -avoid-version \
- -export-symbols-regex initgnomegeckoembed \
- -R$(GECKO_HOME) \
- $(AM_LDFLAGS)
-
-gnomegeckoembed_la_SOURCES = gnomegeckoembedmodule.c
-nodist_gnomegeckoembed_la_SOURCES = gnomegeckoembed.c
-
-gnomegeckoembed.c: gnomegeckoembed.defs gnomegeckoembed.override
-CLEANFILES = gnomegeckoembed.c
-EXTRA_DIST = gnomegeckoembed.override gnomegeckoembed.defs
-
-.defs.c:
- (cd $(srcdir)\
- && $(PYGTK_CODEGEN) \
- --override $*.override \
- --prefix py$* $*.defs) > gen-$*.c \
- && cp gen-$*.c $*.c \
- && rm -f gen-$*.c
-
-BINDING_HEADERS_SRCDIR_IN = \
- src/gecko-embed.h \
- src/gecko-embed-single.h \
- src/gecko-embed-types.h
-
-BINDING_HEADERS_BUILDDIR_IN =
-
-BINDING_HEADERS_SRCDIR := $(addprefix $(top_srcdir)/,$(BINDING_HEADERS_SRCDIR_IN))
-BINDING_HEADERS_BUILDDIR := $(addprefix $(top_builddir)/,$(BINDING_HEADERS_BUILDDIR_IN))
-
-regenerate-python-binding:
- $(PYGTK_H2DEF) $(sort $(BINDING_HEADERS_SRCDIR) $(BINDING_HEADERS_BUILDDIR)) > gnomegeckoembed.defs.new
diff --git a/embed/xulrunner/bindings/python/gnomegeckoembed.defs b/embed/xulrunner/bindings/python/gnomegeckoembed.defs
deleted file mode 100644
index e3c0f10b5..000000000
--- a/embed/xulrunner/bindings/python/gnomegeckoembed.defs
+++ /dev/null
@@ -1,294 +0,0 @@
-;; -*- scheme -*-
-; object definitions ...
-(define-object Embed
- (in-module "Gecko")
- (parent "GtkBin")
- (c-name "GeckoEmbed")
- (gtype-id "GECKO_TYPE_EMBED")
-)
-
-(define-object EmbedSingle
- (in-module "Gecko")
- (parent "GObject")
- (c-name "GeckoEmbedSingle")
- (gtype-id "GECKO_TYPE_EMBED_SINGLE")
-)
-
-;; Enumerations and flags ...
-
-(define-enum EmbedProgressFlags
- (in-module "Gecko")
- (c-name "GeckoEmbedProgressFlags")
- (gtype-id "GECKO_TYPE_EMBED_PROGRESS_FLAGS")
- (values
- '("start" "GECKO_EMBED_FLAG_START")
- '("redirecting" "GECKO_EMBED_FLAG_REDIRECTING")
- '("transferring" "GECKO_EMBED_FLAG_TRANSFERRING")
- '("negotiating" "GECKO_EMBED_FLAG_NEGOTIATING")
- '("stop" "GECKO_EMBED_FLAG_STOP")
- '("is-request" "GECKO_EMBED_FLAG_IS_REQUEST")
- '("is-document" "GECKO_EMBED_FLAG_IS_DOCUMENT")
- '("is-network" "GECKO_EMBED_FLAG_IS_NETWORK")
- '("is-window" "GECKO_EMBED_FLAG_IS_WINDOW")
- '("restoring" "GECKO_EMBED_FLAG_RESTORING")
- )
-)
-
-(define-enum EmbedStatusEnum
- (in-module "Gecko")
- (c-name "GeckoEmbedStatusEnum")
- (gtype-id "GECKO_TYPE_EMBED_STATUS_ENUM")
- (values
- '("dns" "GECKO_EMBED_STATUS_FAILED_DNS")
- '("connect" "GECKO_EMBED_STATUS_FAILED_CONNECT")
- '("timeout" "GECKO_EMBED_STATUS_FAILED_TIMEOUT")
- '("usercanceled" "GECKO_EMBED_STATUS_FAILED_USERCANCELED")
- )
-)
-
-(define-enum EmbedReloadFlags
- (in-module "Gecko")
- (c-name "GeckoEmbedReloadFlags")
- (gtype-id "GECKO_TYPE_EMBED_RELOAD_FLAGS")
- (values
- '("normal" "GECKO_EMBED_FLAG_RELOADNORMAL")
- '("bypasscache" "GECKO_EMBED_FLAG_RELOADBYPASSCACHE")
- '("bypassproxy" "GECKO_EMBED_FLAG_RELOADBYPASSPROXY")
- '("bypassproxyandcache" "GECKO_EMBED_FLAG_RELOADBYPASSPROXYANDCACHE")
- '("charsetchange" "GECKO_EMBED_FLAG_RELOADCHARSETCHANGE")
- )
-)
-
-(define-enum EmbedChromeFlags
- (in-module "Gecko")
- (c-name "GeckoEmbedChromeFlags")
- (gtype-id "GECKO_TYPE_EMBED_CHROME_FLAGS")
- (values
- '("defaultchrome" "GECKO_EMBED_FLAG_DEFAULTCHROME")
- '("windowborderson" "GECKO_EMBED_FLAG_WINDOWBORDERSON")
- '("windowcloseon" "GECKO_EMBED_FLAG_WINDOWCLOSEON")
- '("windowresizeon" "GECKO_EMBED_FLAG_WINDOWRESIZEON")
- '("menubaron" "GECKO_EMBED_FLAG_MENUBARON")
- '("toolbaron" "GECKO_EMBED_FLAG_TOOLBARON")
- '("locationbaron" "GECKO_EMBED_FLAG_LOCATIONBARON")
- '("statusbaron" "GECKO_EMBED_FLAG_STATUSBARON")
- '("personaltoolbaron" "GECKO_EMBED_FLAG_PERSONALTOOLBARON")
- '("scrollbarson" "GECKO_EMBED_FLAG_SCROLLBARSON")
- '("titlebaron" "GECKO_EMBED_FLAG_TITLEBARON")
- '("extrachromeon" "GECKO_EMBED_FLAG_EXTRACHROMEON")
- '("allchrome" "GECKO_EMBED_FLAG_ALLCHROME")
- '("windowraised" "GECKO_EMBED_FLAG_WINDOWRAISED")
- '("windowlowered" "GECKO_EMBED_FLAG_WINDOWLOWERED")
- '("centerscreen" "GECKO_EMBED_FLAG_CENTERSCREEN")
- '("dependent" "GECKO_EMBED_FLAG_DEPENDENT")
- '("modal" "GECKO_EMBED_FLAG_MODAL")
- '("openasdialog" "GECKO_EMBED_FLAG_OPENASDIALOG")
- '("openaschrome" "GECKO_EMBED_FLAG_OPENASCHROME")
- )
-)
-
-
-;; From ../../src/gecko-embed-single.h
-
-(define-function gecko_embed_single_get_type
- (c-name "gecko_embed_single_get_type")
- (return-type "GType")
-)
-
-(define-function gecko_embed_single_get
- (c-name "gecko_embed_single_get")
- (return-type "GeckoEmbedSingle*")
-)
-
-(define-function gecko_embed_single_push_startup
- (c-name "gecko_embed_single_push_startup")
- (return-type "none")
-)
-
-(define-function gecko_embed_single_pop_startup
- (c-name "gecko_embed_single_pop_startup")
- (return-type "none")
-)
-
-(define-function gecko_embed_single_set_comp_path
- (c-name "gecko_embed_single_set_comp_path")
- (return-type "none")
- (parameters
- '("const-char*" "aPath")
- )
-)
-
-(define-function gecko_embed_single_set_profile_path
- (c-name "gecko_embed_single_set_profile_path")
- (return-type "none")
- (parameters
- '("const-char*" "aDir")
- '("const-char*" "aName")
- )
-)
-
-
-
-;; From ../../src/gecko-embed-types.h
-
-(define-function gecko_embed_progress_flags_get_type
- (c-name "gecko_embed_progress_flags_get_type")
- (return-type "GType")
-)
-
-(define-function gecko_embed_status_enum_get_type
- (c-name "gecko_embed_status_enum_get_type")
- (return-type "GType")
-)
-
-(define-function gecko_embed_reload_flags_get_type
- (c-name "gecko_embed_reload_flags_get_type")
- (return-type "GType")
-)
-
-(define-function gecko_embed_chrome_flags_get_type
- (c-name "gecko_embed_chrome_flags_get_type")
- (return-type "GType")
-)
-
-
-
-;; From ../../src/gecko-embed.h
-
-(define-function gecko_embed_get_type
- (c-name "gecko_embed_get_type")
- (return-type "GType")
-)
-
-(define-function gecko_embed_new
- (c-name "gecko_embed_new")
- (is-constructor-of "GeckoEmbed")
- (return-type "GtkWidget*")
-)
-
-(define-method load_url
- (of-object "GeckoEmbed")
- (c-name "gecko_embed_load_url")
- (return-type "none")
- (parameters
- '("const-char*" "url")
- )
-)
-
-(define-method stop_load
- (of-object "GeckoEmbed")
- (c-name "gecko_embed_stop_load")
- (return-type "none")
-)
-
-(define-method can_go_back
- (of-object "GeckoEmbed")
- (c-name "gecko_embed_can_go_back")
- (return-type "gboolean")
-)
-
-(define-method can_go_forward
- (of-object "GeckoEmbed")
- (c-name "gecko_embed_can_go_forward")
- (return-type "gboolean")
-)
-
-(define-method go_back
- (of-object "GeckoEmbed")
- (c-name "gecko_embed_go_back")
- (return-type "none")
-)
-
-(define-method go_forward
- (of-object "GeckoEmbed")
- (c-name "gecko_embed_go_forward")
- (return-type "none")
-)
-
-(define-method render_data
- (of-object "GeckoEmbed")
- (c-name "gecko_embed_render_data")
- (return-type "none")
- (parameters
- '("const-char*" "data")
- '("guint32" "len")
- '("const-char*" "base_uri")
- '("const-char*" "mime_type")
- )
-)
-
-(define-method open_stream
- (of-object "GeckoEmbed")
- (c-name "gecko_embed_open_stream")
- (return-type "none")
- (parameters
- '("const-char*" "base_uri")
- '("const-char*" "mime_type")
- )
-)
-
-(define-method append_data
- (of-object "GeckoEmbed")
- (c-name "gecko_embed_append_data")
- (return-type "none")
- (parameters
- '("const-char*" "data")
- '("guint32" "len")
- )
-)
-
-(define-method close_stream
- (of-object "GeckoEmbed")
- (c-name "gecko_embed_close_stream")
- (return-type "none")
-)
-
-(define-method get_link_message
- (of-object "GeckoEmbed")
- (c-name "gecko_embed_get_link_message")
- (return-type "char*")
-)
-
-(define-method get_js_status
- (of-object "GeckoEmbed")
- (c-name "gecko_embed_get_js_status")
- (return-type "char*")
-)
-
-(define-method get_title
- (of-object "GeckoEmbed")
- (c-name "gecko_embed_get_title")
- (return-type "char*")
-)
-
-(define-method get_location
- (of-object "GeckoEmbed")
- (c-name "gecko_embed_get_location")
- (return-type "char*")
-)
-
-(define-method reload
- (of-object "GeckoEmbed")
- (c-name "gecko_embed_reload")
- (return-type "none")
- (parameters
- '("gint32" "flags")
- )
-)
-
-(define-method set_chrome_mask
- (of-object "GeckoEmbed")
- (c-name "gecko_embed_set_chrome_mask")
- (return-type "none")
- (parameters
- '("guint32" "flags")
- )
-)
-
-(define-method get_chrome_mask
- (of-object "GeckoEmbed")
- (c-name "gecko_embed_get_chrome_mask")
- (return-type "guint32")
-)
-
-
diff --git a/embed/xulrunner/bindings/python/gnomegeckoembed.override b/embed/xulrunner/bindings/python/gnomegeckoembed.override
deleted file mode 100644
index e40fb9afe..000000000
--- a/embed/xulrunner/bindings/python/gnomegeckoembed.override
+++ /dev/null
@@ -1,19 +0,0 @@
-%%
-headers
-#include <Python.h>
-
-#include "pygobject.h"
-#include "gecko-embed.h"
-#include "gecko-embed-single.h"
-
-%%
-modulename gnomegeckoembed
-%%
-import gobject.GObject as PyGObject_Type
-import gtk.Object as PyGtkObject_Type
-import gtk.Bin as PyGtkBin_Type
-%%
-ignore-glob
- *_get_type
- _*
-%%
diff --git a/embed/xulrunner/bindings/python/gnomegeckoembedmodule.c b/embed/xulrunner/bindings/python/gnomegeckoembedmodule.c
deleted file mode 100644
index f7786fa17..000000000
--- a/embed/xulrunner/bindings/python/gnomegeckoembedmodule.c
+++ /dev/null
@@ -1,29 +0,0 @@
-#ifdef HAVE_CONFIG_H
-#include "config.h"
-#endif
-
-/* include this first, before NO_IMPORT_PYGOBJECT is defined */
-#include <pygobject.h>
-
-void pygtkmozembed_register_classes (PyObject *d);
-void pygtkmozembed_add_constants(PyObject *module, const gchar *strip_prefix);
-
-extern PyMethodDef pygnomegeckoembed_functions[];
-
-DL_EXPORT(void)
-initgnomegeckoembed(void)
-{
- PyObject *m, *d;
-
- init_pygobject ();
-
- m = Py_InitModule ("gnomegeckoembed", pygnomegeckoembed_functions);
- d = PyModule_GetDict (m);
-
- pygnomegeckoembed_register_classes (d);
- /*pygnomegeckoembed_add_constants(m, "GNOME_GECKO_EMBED_");*/
-
- if (PyErr_Occurred ()) {
- Py_FatalError ("can't initialise module gnomegeckoembed");
- }
-}
diff --git a/embed/xulrunner/bindings/python/test.py b/embed/xulrunner/bindings/python/test.py
deleted file mode 100644
index d06278e5f..000000000
--- a/embed/xulrunner/bindings/python/test.py
+++ /dev/null
@@ -1,32 +0,0 @@
-#! /usr/bin/python
-import pygtk
-pygtk.require("2.0")
-import gtk
-import gnomegeckoembed
-import os
-
-class Base:
- def destroy(self, widget, data=None):
- gtk.main_quit()
-
- def __init__(self):
- gnomegeckoembed.gecko_embed_single_set_comp_path("/usr/lib/firefox")
- gnomegeckoembed.gecko_embed_single_push_startup()
- self.browser = gnomegeckoembed.Embed()
- self.browser.load_url("www.gnome.org")
-
- self.window = gtk.Window(gtk.WINDOW_TOPLEVEL)
- self.window.connect("destroy", self.destroy)
- self.window.set_default_size(800, 600)
- self.window.add(self.browser)
- self.browser.show()
- self.window.show()
-
- def main(self):
- gtk.main()
-
-print __name__
-if __name__ == "__main__":
- base = Base()
- base.main()
-
diff --git a/embed/xulrunner/components/ContentHandler.cpp b/embed/xulrunner/components/ContentHandler.cpp
deleted file mode 100644
index ef8ca62a8..000000000
--- a/embed/xulrunner/components/ContentHandler.cpp
+++ /dev/null
@@ -1,481 +0,0 @@
-/*
- * Copyright © 2001 Philip Langdale
- * Copyright © 2003 Marco Pesenti Gritti
- * Copyright © 2003 Xan Lopez
- * Copyright © 2004 Christian Persch
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include <glib/gi18n.h>
-#include <gio/gio.h>
-#include <gtk/gtkbutton.h>
-#include <gtk/gtkdialog.h>
-#include <gtk/gtkimage.h>
-#include <gtk/gtkmain.h>
-#include <gtk/gtkmessagedialog.h>
-#include <gtk/gtkstock.h>
-
-#include <nsStringGlue.h>
-
-#include <nsCExternalHandlerService.h>
-#include <nsComponentManagerUtils.h>
-#include <nsIDOMWindow.h>
-#include <nsIInterfaceRequestorUtils.h>
-#include <nsILocalFile.h>
-#include <nsIMIMEInfo.h>
-#include <nsIURL.h>
-#include <nsMemory.h>
-#include <nsNetError.h>
-#include <nsServiceManagerUtils.h>
-
-#include "eel-gconf-extensions.h"
-#include "ephy-debug.h"
-#include "ephy-embed-shell.h"
-#include "ephy-embed-single.h"
-#include "ephy-file-chooser.h"
-#include "ephy-file-helpers.h"
-#include "ephy-gui.h"
-#include "ephy-prefs.h"
-#include "ephy-stock-icons.h"
-
-#include "AutoJSContextStack.h"
-#include "AutoWindowModalState.h"
-#include "EphyUtils.h"
-#include "MozDownload.h"
-
-#include "ContentHandler.h"
-
-/* FIXME: we don't generally have a timestamp for the user action which initiated this
- * content handler.
- */
-GContentHandler::GContentHandler()
-: mUserTime(0)
-{
- LOG ("GContentHandler ctor (%p)", this);
-}
-
-GContentHandler::~GContentHandler()
-{
- LOG ("GContentHandler dtor (%p)", this);
-}
-
-NS_IMPL_ISUPPORTS1(GContentHandler, nsIHelperAppLauncherDialog)
-
-/* void show (in nsIHelperAppLauncher aLauncher, in nsISupports aContext, in unsigned long aReason); */
-NS_IMETHODIMP
-GContentHandler::Show (nsIHelperAppLauncher *aLauncher,
- nsISupports *aContext,
- PRUint32 aReason)
-{
- nsresult rv;
- EphyEmbedSingle *single;
- gboolean handled = FALSE;
-
- /* FIXME: handle aForced / aReason argument in some way? */
-
- mContext = aContext;
-
- /* Check for a potential veto */
- nsCOMPtr<nsIDOMWindow> window (do_GetInterface (aContext));
- GtkWidget *embed = EphyUtils::FindEmbed (window);
- if (EPHY_IS_EMBED (embed))
- {
- if (g_object_get_data (G_OBJECT (embed), "content-handler-deny"))
- {
- return NS_OK;
- }
- }
-
- mLauncher = aLauncher;
- rv = Init ();
- NS_ENSURE_SUCCESS (rv, rv);
-
- single = EPHY_EMBED_SINGLE (ephy_embed_shell_get_embed_single (embed_shell));
- g_signal_emit_by_name (single, "handle_content", mMimeType.get(),
- mUrl.get(), &handled);
-
- if (!handled)
- {
- MIMEInitiateAction ();
- }
- else
- {
- mLauncher->Cancel (NS_BINDING_ABORTED);
- }
-
- return NS_OK;
-}
-
-/* nsILocalFile promptForSaveToFile (in nsISupports aWindowContext, in wstring aDefaultFile, in wstring aSuggestedFileExtension); */
-NS_IMETHODIMP GContentHandler::PromptForSaveToFile(
- nsIHelperAppLauncher *aLauncher,
- nsISupports *aWindowContext,
- const PRUnichar *aDefaultFile,
- const PRUnichar *aSuggestedFileExtension,
- nsILocalFile **_retval)
-{
- EphyFileChooser *dialog;
- int response;
- char *filename = NULL;
- nsCString defaultFile;
-
- NS_UTF16ToCString (nsString (aDefaultFile),
- NS_CSTRING_ENCODING_UTF8, defaultFile);
-
- if (mAction != CONTENT_ACTION_SAVEAS)
- {
- return BuildDownloadPath (defaultFile.get(), _retval);
- }
-
- nsresult rv;
- AutoJSContextStack stack;
- rv = stack.Init ();
- if (NS_FAILED (rv)) return rv;
-
- nsCOMPtr<nsIDOMWindow> parentDOMWindow (do_GetInterface (aWindowContext));
- GtkWidget *parentWindow = GTK_WIDGET (EphyUtils::FindGtkParent (parentDOMWindow));
-
- AutoWindowModalState modalState (parentDOMWindow);
-
- dialog = ephy_file_chooser_new (_("Save"), parentWindow,
- GTK_FILE_CHOOSER_ACTION_SAVE,
- CONF_STATE_SAVE_DIR,
- EPHY_FILE_FILTER_ALL);
- gtk_file_chooser_set_do_overwrite_confirmation (GTK_FILE_CHOOSER (dialog), TRUE);
- gtk_file_chooser_set_current_name (GTK_FILE_CHOOSER (dialog), defaultFile.get());
-
- if (parentWindow)
- {
- gtk_window_group_add_window (ephy_gui_ensure_window_group (GTK_WINDOW (parentWindow)),
- GTK_WINDOW (dialog));
- }
-
- /* FIXME: this will only be the real user time if we came from ::Show */
- ephy_gui_window_update_user_time (GTK_WIDGET (dialog), (guint32) mUserTime);
-
- /* FIXME: modal -- mozilla sucks! */
- do
- {
- g_free (filename);
- response = gtk_dialog_run (GTK_DIALOG (dialog));
- filename = gtk_file_chooser_get_filename (GTK_FILE_CHOOSER (dialog));
- } while (response == GTK_RESPONSE_ACCEPT
- && !ephy_gui_check_location_writable (GTK_WIDGET (dialog), filename));
-
- if (response == GTK_RESPONSE_ACCEPT)
- {
- nsCOMPtr <nsILocalFile> destFile (do_CreateInstance(NS_LOCAL_FILE_CONTRACTID));
- NS_ENSURE_TRUE (destFile, NS_ERROR_FAILURE);
-
- destFile->InitWithNativePath (nsCString (filename));
- g_free (filename);
-
- NS_IF_ADDREF (*_retval = destFile);
-
- gtk_widget_destroy (GTK_WIDGET (dialog));
-
- return NS_OK;
- }
- else
- {
- gtk_widget_destroy (GTK_WIDGET (dialog));
- g_free (filename);
-
- return NS_ERROR_FAILURE;
- }
-}
-
-NS_METHOD GContentHandler::Init ()
-{
- nsresult rv;
-
- NS_ENSURE_TRUE (mLauncher, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsIMIMEInfo> MIMEInfo;
- mLauncher->GetMIMEInfo (getter_AddRefs(MIMEInfo));
- NS_ENSURE_TRUE (MIMEInfo, NS_ERROR_FAILURE);
-
- rv = MIMEInfo->GetMIMEType (mMimeType);
-
- nsCOMPtr<nsIURI> uri;
- mLauncher->GetSource (getter_AddRefs(uri));
- NS_ENSURE_TRUE (uri, NS_ERROR_FAILURE);
-
- uri->GetSpec (mUrl);
-
- return NS_OK;
-}
-
-static void
-response_cb (GtkWidget *dialog,
- int response,
- GContentHandler *self)
-{
- gtk_widget_destroy (dialog);
-
- if (response > 0)
- {
- self->mAction = (ContentAction) response;
- }
- else
- {
- self->mAction = CONTENT_ACTION_NONE;
- }
-
- self->MIMEDoAction ();
-}
-
-static void
-release_cb (GContentHandler *data)
-{
- NS_RELEASE (data);
-}
-
-NS_METHOD GContentHandler::MIMEConfirmAction ()
-{
- GtkWidget *dialog, *button, *image;
- const char *action_label;
- char *mime_description;
- nsCString file_name;
-
- nsCOMPtr<nsIDOMWindow> parentDOMWindow = do_GetInterface (mContext);
- GtkWindow *parentWindow = GTK_WINDOW (EphyUtils::FindGtkParent(parentDOMWindow));
-
- action_label = (mAction == CONTENT_ACTION_OPEN) ||
- (mAction == CONTENT_ACTION_OPEN_TMP) ?
- GTK_STOCK_OPEN : STOCK_DOWNLOAD;
-
- mime_description = g_content_type_get_description (mMimeType.get());
- if (mime_description == NULL)
- {
- /* Translators: The text before the "|" is context to help you decide on
- * the correct translation. You MUST OMIT it in the translated string. */
- mime_description = g_strdup (Q_("File Type:|Unknown"));
- }
-
- /* We have one tiny, minor issue, the filename can be empty (""),
- is that severe enough to be completely fixed ? */
- nsString suggested;
-
- mLauncher->GetSuggestedFileName (suggested);
- NS_UTF16ToCString (suggested,
- NS_CSTRING_ENCODING_UTF8, file_name);
-
- if (mPermission != EPHY_MIME_PERMISSION_SAFE && mHelperApp)
- {
- dialog = gtk_message_dialog_new
- (parentWindow, GTK_DIALOG_DESTROY_WITH_PARENT,
- GTK_MESSAGE_WARNING, GTK_BUTTONS_NONE,
- _("Download this potentially unsafe file?"));
-
- gtk_message_dialog_format_secondary_text
- (GTK_MESSAGE_DIALOG (dialog),
- /* translators: First %s is the file type description,
- Second %s is the file name */
- _("File Type: “%s”.\n\nIt is unsafe to open “%s” as "
- "it could potentially damage your documents or "
- "invade your privacy. You can download it instead."),
- mime_description, file_name.get());
- }
- else if (mAction == CONTENT_ACTION_OPEN_TMP && mHelperApp)
- {
- dialog = gtk_message_dialog_new
- (parentWindow, GTK_DIALOG_DESTROY_WITH_PARENT,
- GTK_MESSAGE_QUESTION, GTK_BUTTONS_NONE,
- _("Open this file?"));
-
- gtk_message_dialog_format_secondary_text
- (GTK_MESSAGE_DIALOG (dialog),
- /* translators: First %s is the file type description,
- Second %s is the file name,
- Third %s is the application used to open the file */
- _("File Type: “%s”.\n\nYou can open “%s” using “%s” or save it."),
- mime_description, file_name.get(), mHelperApp->name);
- }
- else
- {
- dialog = gtk_message_dialog_new
- (parentWindow, GTK_DIALOG_DESTROY_WITH_PARENT,
- GTK_MESSAGE_QUESTION, GTK_BUTTONS_NONE,
- _("Download this file?"));
-
- gtk_message_dialog_format_secondary_text
- (GTK_MESSAGE_DIALOG (dialog),
- /* translators: First %s is the file type description,
- Second %s is the file name */
- _("File Type: “%s”.\n\nYou have no application able to open “%s”. "
- "You can download it instead."),
- mime_description, file_name.get());
- }
-
- g_free (mime_description);
-
- button = gtk_button_new_with_label (_("_Save As..."));
- image = gtk_image_new_from_stock (GTK_STOCK_SAVE_AS, GTK_ICON_SIZE_BUTTON);
- gtk_button_set_image (GTK_BUTTON (button), image);
- /* don't show the image! see bug #307818 */
- gtk_widget_show (button);
- gtk_dialog_add_action_widget (GTK_DIALOG (dialog), button, CONTENT_ACTION_SAVEAS);
-
- gtk_dialog_add_button (GTK_DIALOG (dialog),
- GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL);
- gtk_dialog_add_button (GTK_DIALOG (dialog),
- action_label, mAction);
-
- gtk_window_set_icon_name (GTK_WINDOW (dialog), EPHY_STOCK_EPHY);
-
- int defaultResponse = mAction == CONTENT_ACTION_NONE
- ? (int) GTK_RESPONSE_CANCEL
- : (int) mAction;
- gtk_dialog_set_default_response (GTK_DIALOG (dialog), defaultResponse);
-
- NS_ADDREF_THIS();
- g_signal_connect_data (dialog, "response",
- G_CALLBACK (response_cb), this,
- (GClosureNotify) release_cb, (GConnectFlags) 0);
-
- /* FIXME: should find a way to get the user time of the user action which
- * initiated this content handler
- */
- gtk_window_present (GTK_WINDOW (dialog));
-
- return NS_OK;
-}
-
-NS_METHOD GContentHandler::MIMEInitiateAction (void)
-{
- gboolean auto_downloads;
-
- if (eel_gconf_get_boolean (CONF_LOCKDOWN_DISABLE_SAVE_TO_DISK)) return NS_OK;
-
- auto_downloads = eel_gconf_get_boolean (CONF_AUTO_DOWNLOADS);
-
- mHelperApp = g_app_info_get_default_for_type (mMimeType.get(), TRUE);
- mPermission = ephy_file_check_mime (mMimeType.get());
-
- /* HACK! Check that this 'helper application' isn't Epiphany itself,
- * see bug #310023.
- */
- if (mHelperApp)
- {
- const char *id = g_app_info_get_id (mHelperApp);
-
- /* FIXME! menu editing can make this check fail!!!! */
- if (id && strcmp (id, "epiphany.desktop") == 0)
- {
- mHelperApp = nsnull;
- }
- }
-
- if (auto_downloads)
- {
- mAction = CONTENT_ACTION_OPEN;
- }
- else
- {
- mAction = CONTENT_ACTION_OPEN_TMP;
- }
-
- if (!mHelperApp || mPermission != EPHY_MIME_PERMISSION_SAFE)
- {
- mAction = CONTENT_ACTION_DOWNLOAD;
- }
-
- if (!auto_downloads || mAction == CONTENT_ACTION_DOWNLOAD)
- {
- MIMEConfirmAction ();
- }
- else
- {
- MIMEDoAction ();
- }
-
- return NS_OK;
-}
-
-NS_METHOD GContentHandler::MIMEDoAction (void)
-{
- /* This is okay, since we either clicked on a button, or we get 0 */
- mUserTime = gtk_get_current_event_time ();
-
- nsCOMPtr<nsIMIMEInfo> mimeInfo;
- mLauncher->GetMIMEInfo(getter_AddRefs(mimeInfo));
- NS_ENSURE_TRUE (mimeInfo, NS_ERROR_FAILURE);
-
- char *info = NULL;
-
- if (mAction == CONTENT_ACTION_OPEN)
- {
- g_return_val_if_fail (mHelperApp, NS_ERROR_FAILURE);
-
- const char *id;
- id = g_app_info_get_id (mHelperApp);
-
- /* The current time is fine here as the user has just clicked
- * a button (it is used as the time for the application opening)
- */
- info = g_strdup_printf ("gnome-default:%d:%s", gtk_get_current_event_time(), id);
- }
- else if (mAction == CONTENT_ACTION_DOWNLOAD)
- {
- info = g_strdup_printf ("gnome-browse-to-file:%d", gtk_get_current_event_time());
- }
-
- /* See http://bugzilla.gnome.org/show_bug.cgi?id=456945 */
- // FIXME convert this properly to 1.9
-#ifdef HAVE_GECKO_1_9
- if (info != NULL)
- {
- nsString desc;
- NS_CStringToUTF16 (nsCString (info),
- NS_CSTRING_ENCODING_UTF8, desc);
- g_free (info);
-
- /* HACK we use the application description to ask
- MozDownload to open the file when download
- is finished */
- mimeInfo->SetApplicationDescription (desc);
- }
- else
- {
- mimeInfo->SetApplicationDescription (nsString ());
- }
-#endif /* HAVE_GECKO_1_9 */
-
- if (mAction == CONTENT_ACTION_OPEN)
- {
- mLauncher->SaveToDisk (nsnull, PR_FALSE);
- }
- else if (mAction == CONTENT_ACTION_OPEN_TMP)
- {
- mLauncher->LaunchWithApplication (nsnull, PR_FALSE);
- }
- else if (mAction == CONTENT_ACTION_NONE)
- {
- mLauncher->Cancel (NS_BINDING_ABORTED);
- }
- else
- {
- mLauncher->SaveToDisk (nsnull, PR_FALSE);
- }
-
- return NS_OK;
-}
diff --git a/embed/xulrunner/components/ContentHandler.h b/embed/xulrunner/components/ContentHandler.h
deleted file mode 100644
index 52813e0c5..000000000
--- a/embed/xulrunner/components/ContentHandler.h
+++ /dev/null
@@ -1,81 +0,0 @@
-/*
- * Copyright © 2000-2003 Marco Pesenti Gritti,
- * Copyright © 2003 Xan Lopez
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#ifndef CONTENT_HANDLER_H
-#define CONTENT_HANDLER_H
-
-#include <libgnomevfs/gnome-vfs-mime-handlers.h>
-
-#include <nsCOMPtr.h>
-#include <nsIFile.h>
-#include <nsIHelperAppLauncherDialog.h>
-#include <nsIURI.h>
-
-#include "ephy-file-helpers.h"
-
-
-typedef enum
-{
- CONTENT_ACTION_OPEN = 1,
- CONTENT_ACTION_OPEN_TMP,
- CONTENT_ACTION_DOWNLOAD,
- CONTENT_ACTION_SAVEAS,
- CONTENT_ACTION_NONE
-} ContentAction;
-
-#define G_CONTENTHANDLER_CID \
-{ /* 16072c4a-23a6-4996-9beb-9335c06bbeae */ \
- 0x16072c4a, \
- 0x23a6, \
- 0x4996, \
- {0x9b, 0xeb, 0x93, 0x35, 0xc0, 0x6b, 0xbe, 0xae} \
-}
-
-class GContentHandler : public nsIHelperAppLauncherDialog
-{
- public:
- NS_DECL_ISUPPORTS
- NS_DECL_NSIHELPERAPPLAUNCHERDIALOG
-
- GContentHandler();
- virtual ~GContentHandler();
-
- NS_METHOD MIMEDoAction ();
- ContentAction mAction;
- private:
-
- NS_METHOD Init ();
-
- NS_METHOD MIMEInitiateAction ();
- NS_METHOD MIMEConfirmAction ();
-
- nsCOMPtr<nsIHelperAppLauncher> mLauncher;
- nsCOMPtr<nsISupports> mContext;
-
- GAppInfo *mHelperApp;
- EphyMimePermission mPermission;
-
- nsCString mUrl;
- nsCString mMimeType;
- PRUint32 mUserTime;
-};
-
-#endif /* CONTENT_HANDLER_H */
diff --git a/embed/xulrunner/components/EphyAboutModule.cpp b/embed/xulrunner/components/EphyAboutModule.cpp
deleted file mode 100644
index 78ce93bec..000000000
--- a/embed/xulrunner/components/EphyAboutModule.cpp
+++ /dev/null
@@ -1,724 +0,0 @@
-/*
- * Copyright © 2001 Matt Aubury, Philip Langdale
- * Copyright © 2004 Crispin Flowerday
- * Copyright © 2005 Adam Hooper
- * Copyright © 2005, 2007 Christian Persch
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include <string.h>
-
-#include <glib/gi18n.h>
-#include <gtk/gtk.h>
-
-#include <nsStringGlue.h>
-
-#include <nsAutoPtr.h>
-#include <nsCOMPtr.h>
-#include <nsIChannel.h>
-#include <nsIInputStreamChannel.h>
-#include <nsIInputStream.h>
-#include <nsIIOService.h>
-#include <nsINetUtil.h>
-#include <nsIOutputStream.h>
-#include <nsIScriptSecurityManager.h>
-#include <nsIStorageStream.h>
-#include <nsIURI.h>
-#include <nsNetCID.h>
-#include <nsNetUtil.h>
-#include <nsServiceManagerUtils.h>
-
-#include "ephy-debug.h"
-
-#include "EphyRedirectChannel.h"
-
-#include "EphyAboutModule.h"
-
-EphyAboutModule::EphyAboutModule()
-{
- LOG ("EphyAboutModule ctor [%p]\n", this);
-}
-
-EphyAboutModule::~EphyAboutModule()
-{
- LOG ("EphyAboutModule dtor [%p]\n", this);
-}
-
-NS_IMPL_ISUPPORTS1 (EphyAboutModule, nsIAboutModule)
-
-/* nsIChannel newChannel (in nsIURI aURI); */
-NS_IMETHODIMP
-EphyAboutModule::NewChannel(nsIURI *aURI,
- nsIChannel **_retval)
-{
- NS_ENSURE_ARG(aURI);
-
- nsCAutoString path;
- aURI->GetPath (path);
-
- if (strncmp (path.get(), "neterror?", strlen ("neterror?")) == 0)
- {
- return CreateErrorPage (aURI, _retval);
- }
-
- if (strncmp (path.get (), "recover?", strlen ("recover?")) == 0)
- {
- return CreateRecoverPage (aURI, _retval);
- }
-
- if (strcmp (path.get (), "epiphany") == 0)
- {
- return Redirect (nsDependentCString ("file://" SHARE_DIR "/epiphany.xhtml"), _retval);
- }
-
- return NS_ERROR_ILLEGAL_VALUE;
-}
-
-/* unsigned long getURIFlags(in nsIURI aURI); */
-NS_IMETHODIMP
-EphyAboutModule::GetURIFlags (nsIURI *aURI,
- PRUint32 *_result)
-{
- *_result = 0;
- return NS_OK;
-}
-
-/* private functions */
-
-nsresult
-EphyAboutModule::Redirect(const nsACString &aURL,
- nsIChannel **_retval)
-{
- *_retval = nsnull;
-
- nsresult rv;
- nsCOMPtr<nsIURI> uri;
- rv = NS_NewURI (getter_AddRefs (uri), aURL);
- NS_ENSURE_SUCCESS (rv, rv);
-
- nsCOMPtr<nsIChannel> tempChannel;
- rv = NS_NewChannel (getter_AddRefs (tempChannel), uri);
- NS_ENSURE_SUCCESS (rv, rv);
-
- tempChannel->SetOriginalURI (uri);
-
- nsCOMPtr<nsIScriptSecurityManager> securityManager =
- do_GetService(NS_SCRIPTSECURITYMANAGER_CONTRACTID, &rv);
- NS_ENSURE_SUCCESS (rv, rv);
-
- nsCOMPtr<nsIPrincipal> principal;
- rv = securityManager->GetCodebasePrincipal(uri, getter_AddRefs(principal));
- NS_ENSURE_SUCCESS (rv, rv);
-
- rv = tempChannel->SetOwner(principal);
- NS_ENSURE_SUCCESS (rv, rv);
-
- tempChannel.swap (*_retval);
-
- return NS_OK;
-}
-
-nsresult
-EphyAboutModule::ParseURL(const char *aURL,
- nsACString &aCode,
- nsACString &aRawOriginURL,
- nsACString &aOriginURL,
- nsACString &aOriginCharset,
- nsACString &aTitle)
-{
- /* The page URL is of the form "about:neterror?e=<errorcode>&u=<URL>&c=<charset>&d=<description>" */
- const char *query = strstr (aURL, "?");
- if (!query) return NS_ERROR_FAILURE;
-
- /* skip the '?' */
- ++query;
-
- char **params = g_strsplit (query, "&", -1);
- if (!params) return NS_ERROR_FAILURE;
-
- nsCOMPtr<nsINetUtil> netUtil (do_GetService (NS_NETUTIL_CONTRACTID));
- if (!netUtil) return NS_ERROR_FAILURE;
-
- for (PRUint32 i = 0; params[i] != NULL; ++i)
- {
- char *param = params[i];
-
- if (strlen (param) <= 2) continue;
-
- switch (param[0])
- {
- case 'e':
- netUtil->UnescapeString (nsDependentCString (param + 2), 0, aCode);
- break;
- case 'u':
- aRawOriginURL.Assign (param + 2);
- netUtil->UnescapeString (nsDependentCString (param + 2), 0, aOriginURL);
- break;
- case 'c':
- netUtil->UnescapeString (nsDependentCString (param + 2), 0, aOriginCharset);
- break;
- /* The next one is not used in neterror but recover: */
- case 't':
- netUtil->UnescapeString (nsDependentCString (param + 2), 0, aTitle);
- break;
- case 'd':
- /* we don't need mozilla's description parameter */
- default:
- break;
- }
- }
-
- g_strfreev (params);
-
- return NS_OK;
-}
-
-nsresult
-EphyAboutModule::GetErrorMessage(nsIURI *aURI,
- const char *aError,
- char **aStockIcon,
- char **aTitle,
- char **aPrimary,
- char **aSecondary,
- char **aTertiary,
- char **aLinkIntro)
-{
- *aStockIcon = GTK_STOCK_DIALOG_ERROR;
-
- if (strcmp (aError, "protocolNotFound") == 0)
- {
- nsCAutoString scheme;
- aURI->GetScheme (scheme);
-
- /* Translators: %s is the name of a protocol, like "http" etc. */
- *aTitle = g_strdup_printf (_("“%s” Protocol is not Supported"), scheme.get());
- /* Translators: %s is the name of a protocol, like "http" etc. */
- *aPrimary = g_strdup_printf (_("“%s” protocol is not supported."), scheme.get());
- /* FIXME: get the list of supported protocols from necko */
- *aSecondary = g_strdup (_("Supported protocols are “http”, “https”, “ftp”, “file”, “smb” "
- "and “sftp”."));
- }
- else if (strcmp (aError, "fileNotFound") == 0)
- {
- nsCAutoString path;
- aURI->GetPath (path);
-
- /* Translators: %s is the path and filename, for example "/home/user/test.html" */
- *aTitle = g_markup_printf_escaped (_("File “%s” not Found"), path.get());
- /* Translators: %s is the path and filename, for example "/home/user/test.html" */
- *aPrimary = g_markup_printf_escaped (_("File “%s” not found."), path.get());
- *aSecondary = g_strdup (_("Check the location of the file and try again."));
- }
- else if (strcmp (aError, "dnsNotFound") == 0)
- {
- nsCAutoString host;
- aURI->GetHost (host);
-
- /* Translators: %s is the hostname, like "www.example.com" */
- *aTitle = g_markup_printf_escaped (_("“%s” Could not be Found"),
- host.get());
- /* Translators: %s is the hostname, like "www.example.com" */
- *aPrimary = g_markup_printf_escaped (_("“%s” could not be found."),
- host.get());
- *aSecondary = g_strdup (_("Check that you are connected to the internet, and "
- "that the address is correct."));
- *aLinkIntro = _("If this page used to exist, you may find an archived version:");
- }
- else if (strcmp (aError, "connectionFailure") == 0)
- {
- nsCAutoString host;
- aURI->GetHost (host);
-
- /* Translators: %s is the hostname, like "www.example.com" */
- *aTitle = g_markup_printf_escaped
- (_("“%s” Refused the Connection"),
- host.get());
- /* Translators: %s is the hostname, like "www.example.com" */
- *aPrimary = g_markup_printf_escaped
- (_("“%s” refused the connection."),
- host.get());
-
- /* FIXME what about 127.0.0.* ? */
- if (strcmp (host.get(), "localhost") == 0)
- {
- PRInt32 port;
- aURI->GetPort (&port);
-
- *aSecondary = g_strdup (_("Likely causes of the problem are"));
-
- /* Try to get the service name attached to that port */
- if (port != -1)
- {
- struct servent *serv;
-
- if ((serv = getservbyport (htons (port), NULL)) != NULL)
- {
- *aTertiary = g_markup_printf_escaped (
- _("<ul>"
- "<li>the service ""%s"" isn't started.</li>"
- "Try to start it using the Services Configuration Tool in "
- "System > Control Center, or</ul>"
- "<ul><li>the port number %d is wrong.</li>"
- "</ul>"),
- serv->s_name, port);
- }
- else
- {
- *aTertiary = g_markup_printf_escaped (
- _("<ul>"
- "<li>some service isn't started, or</li>"
- "<li>the port number %d is wrong.</li>"
- "</ul>"),
- port);
- }
- }
- else
- {
- *aTertiary = _("<ul>"
- "<li>some service isn't started, or</li>"
- "<li>you got the port number wrong.</li>"
- "</ul>");
- }
- }
- else
- {
- *aSecondary = g_strdup (_("The server may be busy or you may have a "
- "network connection problem. Try again later."));
- *aLinkIntro = _("There may be an old version of the page you wanted:");
- }
- }
- else if (strcmp (aError, "netInterrupt") == 0)
- {
- nsCAutoString host;
- aURI->GetHost (host);
-
- /* Translators: %s is the hostname, like "www.example.com" */
- *aTitle = g_markup_printf_escaped
- (_("“%s” Interrupted the Connection"),
- host.get());
- /* Translators: %s is the hostname, like "www.example.com" */
- *aPrimary = g_markup_printf_escaped
- (_("“%s” interrupted the connection."),
- host.get());
- *aSecondary = g_strdup (_("The server may be busy or you may have a "
- "network connection problem. Try again later."));
- *aLinkIntro = _("There may be an old version of the page you wanted:");
- }
- else if (strcmp (aError, "netTimeout") == 0)
- {
- nsCAutoString host;
- aURI->GetHost (host);
-
- /* Translators: %s is the hostname, like "www.example.com" */
- *aTitle = g_markup_printf_escaped
- (_("“%s” is not Responding"),
- host.get());
- /* Translators: %s is the hostname, like "www.example.com" */
- *aPrimary = g_markup_printf_escaped
- (_("“%s” is not responding."),
- host.get());
- *aSecondary = g_strdup (_("The connection was lost because the "
- "server took too long to respond."));
- *aTertiary = _("The server may be busy or you may have a network "
- "connection problem. Try again later.");
- *aLinkIntro = _("There may be an old version of the page you wanted:");
- }
- else if (strcmp (aError, "malformedURI") == 0)
- {
- *aTitle = g_strdup (_("Invalid Address"));
- *aPrimary = g_strdup (_("Invalid address."));
- *aSecondary = g_strdup (_("The address you entered is not valid."));
- }
- else if (strcmp (aError, "redirectLoop") == 0)
- {
- nsCAutoString host;
- aURI->GetHost (host);
-
- /* Translators: %s is the hostname, like "www.example.com" */
- *aTitle = g_markup_printf_escaped
- (_("“%s” Redirected Too Many Times"),
- host.get());
- /* Translators: %s is the hostname, like "www.example.com" */
- *aPrimary = g_strdup (_("This page cannot load because of a problem with the Web site."));
-
- *aSecondary = g_markup_printf_escaped
- (_("The server “%s” is redirecting in a way that will never complete."),
- host.get());
- *aLinkIntro = _("There may be an old version of the page you wanted:");
- }
- else if (strcmp (aError, "unknownSocketType") == 0)
- {
- nsCAutoString host;
- aURI->GetHost (host);
-
- /* Translators: %s is the hostname, like "www.example.com" */
- *aTitle = g_markup_printf_escaped
- (_("“%s” Requires an Encrypted Connection"),
- host.get());
- /* Translators: %s is the hostname, like "www.example.com" */
- *aPrimary = g_markup_printf_escaped
- (_("“%s” requires an encrypted connection."),
- host.get());
- *aSecondary = g_strdup (_("The document could not be loaded because "
- "encryption support is not installed."));
- }
- else if (strcmp (aError, "netReset") == 0)
- {
- nsCAutoString host;
- aURI->GetHost (host);
-
- /* Translators: %s is the hostname, like "www.example.com" */
- *aTitle = g_markup_printf_escaped
- (_("“%s” Dropped the Connection"),
- host.get());
- /* Translators: %s is the hostname, like "www.example.com" */
- *aPrimary = g_markup_printf_escaped
- (_("“%s” dropped the connection."),
- host.get());
- *aSecondary = g_strdup (_("The server dropped the connection "
- "before any data could be read."));
- *aTertiary = _("The server may be busy or you may have a "
- "network connection problem. Try again later.");
- *aLinkIntro = _("There may be an old version of the page you wanted:");
- }
- else if (strcmp (aError, "netOffline") == 0)
- {
- /* Error is a bit too strong here */
- *aStockIcon = GTK_STOCK_DIALOG_INFO;
-
- *aTitle = g_strdup (_("Cannot Load Document Whilst Working Offline"));
- *aPrimary = g_strdup (_("Cannot load document whilst working offline."));
- *aSecondary = g_strdup (_("To view this document, disable “Work Offline” and try again."));
- }
- else if (strcmp (aError, "deniedPortAccess") == 0)
- {
- nsCAutoString host;
- aURI->GetHost (host);
-
- PRInt32 port = -1;
- aURI->GetPort (&port);
-
- /* Translators: %s is the hostname, like "www.example.com" */
- *aTitle = g_markup_printf_escaped
- (_("“%s” Denied Access to Port “%d”"),
- host.get(), port > 0 ? port : 80);
- /* Translators: %s is the hostname, like "www.example.com" */
- *aPrimary = g_markup_printf_escaped
- (_("“%s” denied access to port “%d”."),
- host.get(), port > 0 ? port : 80);
- *aSecondary = g_strdup (_("The server dropped the connection "
- "before any data could be read."));
- *aTertiary = _("The server may be busy or you may have a "
- "network connection problem. Try again later.");
- *aLinkIntro = _("There may be an old version of the page you wanted:");
- }
- else if (strcmp (aError, "proxyResolveFailure") == 0 ||
- strcmp (aError, "proxyConnectFailure") == 0)
- {
- *aTitle = g_strdup (_("Could not Connect to Proxy Server"));
- *aPrimary = g_strdup (_("Could not connect to proxy server."));
- *aSecondary = g_strdup (_("Check your proxy server settings. "
- "If the connection still fails, there may be "
- "a problem with your proxy server or your "
- "network connection."));
- }
- /* This was introduced in gecko 1.9 */
- else if (strcmp (aError, "contentEncodingError") == 0)
- {
- *aTitle = g_strdup (_("Could not Display Content"));
- *aPrimary = g_strdup (_("Could not display content."));
- *aSecondary = g_strdup (_("The page uses an unsupported or invalid form of compression."));
- }
- else
- {
- return NS_ERROR_ILLEGAL_VALUE;
- }
-
- return NS_OK;
-}
-
-nsresult
-EphyAboutModule::CreateErrorPage(nsIURI *aErrorURI,
- nsIChannel **_retval)
-{
- *_retval = nsnull;
-
- /* First parse the arguments */
- nsresult rv;
- nsCAutoString spec;
- rv = aErrorURI->GetSpec (spec);
- NS_ENSURE_TRUE (NS_SUCCEEDED (rv), rv);
-
- nsCAutoString error, rawurl, url, charset, dummy;
- rv = ParseURL (spec.get (), error, rawurl, url, charset, dummy);
- if (NS_FAILED (rv)) return rv;
- if (error.IsEmpty () || rawurl.IsEmpty () || url.IsEmpty()) return NS_ERROR_FAILURE;
-
- nsCOMPtr<nsIURI> uri;
- rv = NS_NewURI (getter_AddRefs (uri), url, charset.get());
- /* FIXME can uri be NULL if the original url was invalid? */
- NS_ENSURE_SUCCESS (rv, rv);
-
- char *stock_id = nsnull, *title = nsnull, *primary = nsnull,
- *secondary = nsnull, *tertiary = nsnull, *linkintro = nsnull;
- rv = GetErrorMessage (uri, error.get(), &stock_id, &title, &primary,
- &secondary, &tertiary, &linkintro);
-
- /* we don't know about this error code.
- * FIXME: We'd like to forward to mozilla's about:neterror handler,
- * but I don't know how to. So just redirect to the same page that
- * mozilla's handler redirects to.
- */
- if (rv == NS_ERROR_ILLEGAL_VALUE)
- {
- nsCAutoString newurl(spec);
-
- /* remove "about:neterror" part and insert mozilla's error page url */
- newurl.Cut(0, strlen ("about:neterror"));
- newurl.Insert("chrome://global/content/netError.xhtml", 0);
-
- return Redirect (newurl, _retval);
- }
- NS_ENSURE_SUCCESS (rv, rv);
- NS_ENSURE_TRUE (primary && secondary, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsIChannel> channel;
- rv = WritePage (aErrorURI, uri, aErrorURI, rawurl, title, stock_id, primary, secondary, tertiary, linkintro, getter_AddRefs (channel));
- NS_ENSURE_SUCCESS (rv, rv);
-
- g_free (title);
- g_free (primary);
- g_free (secondary);
-
- channel.swap (*_retval);
-
- return NS_OK;
-}
-
-nsresult
-EphyAboutModule::CreateRecoverPage(nsIURI *aRecoverURI,
- nsIChannel **_retval)
-{
- *_retval = nsnull;
-
- /* First parse the arguments */
- nsresult rv;
- nsCAutoString spec;
- rv = aRecoverURI->GetSpec (spec);
- NS_ENSURE_TRUE (NS_SUCCEEDED (rv), rv);
-
- nsCAutoString error, rawurl, url, charset, title;
- rv = ParseURL (spec.get (), error, rawurl, url, charset, title);
- if (NS_FAILED (rv)) return rv;
- if (rawurl.IsEmpty () || url.IsEmpty()) return NS_ERROR_FAILURE;
-
- nsCOMPtr<nsIURI> uri;
- rv = NS_NewURI(getter_AddRefs (uri), url, charset.get());
- NS_ENSURE_SUCCESS (rv, rv);
-
- char *secondary = g_markup_printf_escaped
- (_("The page “%s” in this tab was not fully loaded yet when "
- "the web browser crashed; it could have caused the crash."),
- url.get());
-
- nsCOMPtr<nsIChannel> channel;
- rv = WritePage (aRecoverURI, uri, uri, rawurl, title.get(),
- GTK_STOCK_DIALOG_INFO, title.get() /* as primary */,
- secondary, nsnull, nsnull, getter_AddRefs (channel));
- NS_ENSURE_SUCCESS (rv, rv);
-
- nsRefPtr<EphyRedirectChannel> redirectChannel (new EphyRedirectChannel (channel));
- if (!redirectChannel) return NS_ERROR_OUT_OF_MEMORY;
-
- g_free (secondary);
-
- NS_ADDREF(*_retval = redirectChannel);
-
- return NS_OK;
-}
-
-nsresult
-EphyAboutModule::WritePage(nsIURI *aOriginalURI,
- nsIURI *aURI,
- nsIURI *aChannelURI,
- const nsACString &aRawURL,
- const char *aTitle,
- const char *aStockIcon,
- const char *aPrimary,
- const char *aSecondary,
- const char *aTertiary,
- const char *aLinkIntro,
- nsIChannel **_retval)
-{
- *_retval = nsnull;
-
- nsresult rv;
- nsCOMPtr<nsIStorageStream> storageStream;
- rv = NS_NewStorageStream (16384, (PRUint32) -1, getter_AddRefs (storageStream));
- NS_ENSURE_SUCCESS (rv, rv);
-
- nsCOMPtr<nsIOutputStream> stream;
- rv = storageStream->GetOutputStream (0, getter_AddRefs (stream));
- NS_ENSURE_SUCCESS (rv, rv);
-
- char *language = g_strdup (pango_language_to_string (gtk_get_default_language ()));
- g_strdelimit (language, "_-@", '\0');
-
- Write (stream,
- "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n"
- "<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Strict//EN\" "
- "\"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd\">\n"
- "<html xmlns=\"http://www.w3.org/1999/xhtml\" lang=\"");
- Write (stream, language);
- Write (stream,
- "\" xml:lang=\"");
- Write (stream, language);
- Write (stream,
- "\">\n"
- "<head>\n"
- "<title>");
- Write (stream, aTitle);
- /* no favicon for now, it would pollute the favicon cache */
- /* "<link rel=\"icon\" type=\"image/png\" href=\"moz-icon://stock/gtk-dialog-error?size=16\" />\n" */
- Write (stream,
- "</title>\n"
- "<style type=\"text/css\">\n"
- "div#body {\n"
- "top: 12px;\n"
- "right: 12px;\n"
- "bottom: 12px;\n"
- "left: 12px;\n"
- "overflow: auto;\n"
-
- "background: -moz-dialog url('moz-icon://stock/");
- Write (stream, aStockIcon);
- Write (stream,
- "?size=dialog') no-repeat 12px 12px;\n"
- "color: -moz-dialogtext;\n"
- "font: message-box;\n"
- "border: 1px solid -moz-dialogtext;\n"
-
- "padding: 12px 12px 12px 72px;\n"
- "}\n"
-
- "h1 {\n"
- "margin: 0;\n"
- "font-size: 1.2em;\n"
- "}\n"
- "</style>\n"
- "</head>\n"
- "<body dir=\"");
- Write (stream,
- gtk_widget_get_default_direction () == GTK_TEXT_DIR_RTL ? "rtl" : "ltr");
- Write (stream,
- "\">\n"
- "<div id=\"body\">"
- "<h1>");
- Write (stream, aPrimary);
- Write (stream,
- "</h1>\n");
- if (aSecondary)
- {
- Write (stream, "<p>");
- Write (stream, aSecondary);
- if (aTertiary)
- {
- Write (stream, " ");
- Write (stream, aTertiary);
- }
- Write (stream, "</p>\n");
- }
-
- PRBool isHttp = PR_FALSE, isHttps = PR_FALSE;
- aURI->SchemeIs ("http", &isHttp);
- aURI->SchemeIs ("https", &isHttps);
- if (aLinkIntro && (isHttp || isHttps))
- {
- nsCString raw(aRawURL);
-
- Write (stream, "<p>");
- Write (stream, aLinkIntro);
- Write (stream, "<ul>\n");
- Write (stream, "<li><a href=\"http://www.google.com/search?q=cache:");
- Write (stream, raw.get());
- Write (stream, "\">");
- /* Translators: The text before the "|" is context to help you decide on
- * the correct translation. You MUST OMIT it in the translated string. */
- Write (stream, Q_("You may find an old version:|in the Google Cache"));
- Write (stream, "</a></li>\n");
-
- Write (stream, "<li><a href=\"http://web.archive.org/web/*/");
- Write (stream, raw.get());
- Write (stream, "\">");
- /* Translators: The text before the "|" is context to help you decide on
- * the correct translation. You MUST OMIT it in the translated string. */
- Write (stream, Q_("You may find an old version:|in the Internet Archive"));
- Write (stream, "</a></li>\n"
- "</ul>\n"
- "</p>");
- }
-
- Write (stream,
- "</div>\n"
- "</body>\n"
- "</html>\n");
-
- g_free (language);
-
- /* finish the rendering */
- nsCOMPtr<nsIInputStream> inputStream;
- rv = storageStream->NewInputStream (0, getter_AddRefs (inputStream));
- NS_ENSURE_SUCCESS (rv, rv);
-
- nsCOMPtr<nsIChannel> channel;
- rv = NS_NewInputStreamChannel (getter_AddRefs (channel),
- aChannelURI,
- inputStream,
- NS_LITERAL_CSTRING ("application/xhtml+xml"),
- NS_LITERAL_CSTRING ("utf-8"));
- NS_ENSURE_SUCCESS (rv, rv);
-
- rv = channel->SetOriginalURI (aOriginalURI);
- NS_ENSURE_SUCCESS (rv, rv);
-
- nsCOMPtr<nsIScriptSecurityManager> securityManager
- (do_GetService(NS_SCRIPTSECURITYMANAGER_CONTRACTID, &rv));
- NS_ENSURE_SUCCESS (rv, rv);
-
- nsCOMPtr<nsIPrincipal> principal;
- rv = securityManager->GetCodebasePrincipal (aOriginalURI, getter_AddRefs (principal));
- NS_ENSURE_SUCCESS (rv, rv);
-
- rv = channel->SetOwner(principal);
- NS_ENSURE_SUCCESS (rv, rv);
-
- channel.swap (*_retval);
-
- return NS_OK;
-}
-
-nsresult
-EphyAboutModule::Write(nsIOutputStream *aStream,
- const char *aText)
-{
- PRUint32 bytesWritten;
- return aStream->Write (aText, strlen (aText), &bytesWritten);
-}
diff --git a/embed/xulrunner/components/EphyAboutModule.h b/embed/xulrunner/components/EphyAboutModule.h
deleted file mode 100644
index 21a269c49..000000000
--- a/embed/xulrunner/components/EphyAboutModule.h
+++ /dev/null
@@ -1,65 +0,0 @@
-/*
- * Copyright © 2001 Matt Aubury, Philip Langdale
- * Copyright © 2004 Crispin Flowerday
- * Copyright © 2005 Christian Persch
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#ifndef EPHY_ABOUT_MODULE_H
-#define EPHY_ABOUT_MODULE_H
-
-#include <nsIAboutModule.h>
-
-/* a9aea13e-21de-4be8-a07e-a05f11658c55 */
-#define EPHY_ABOUT_MODULE_CID \
-{ 0xa9aea13e, 0x21de, 0x4be8, \
- { 0xa0, 0x7e, 0xa0, 0x5f, 0x11, 0x65, 0x8c, 0x55 } }
-
-#define EPHY_ABOUT_NETERROR_CONTRACTID NS_ABOUT_MODULE_CONTRACTID_PREFIX "neterror"
-#define EPHY_ABOUT_NETERROR_CLASSNAME "Epiphany about:neterror module"
-
-#define EPHY_ABOUT_EPIPHANY_CONTRACTID NS_ABOUT_MODULE_CONTRACTID_PREFIX "epiphany"
-#define EPHY_ABOUT_EPIPHANY_CLASSNAME "Epiphany about:epiphany module"
-#define EPHY_ABOUT_RECOVER_CONTRACTID NS_ABOUT_MODULE_CONTRACTID_PREFIX "recover"
-#define EPHY_ABOUT_RECOVER_CLASSNAME "Epiphany about:recover module"
-
-class nsIChannel;
-class nsIOutputStream;
-class nsIInputStreamChannel;
-class nsIURI;
-
-class EphyAboutModule : public nsIAboutModule
-{
- public:
- NS_DECL_ISUPPORTS
- NS_DECL_NSIABOUTMODULE
-
- EphyAboutModule();
- virtual ~EphyAboutModule();
-
- private:
- nsresult Redirect(const nsACString&, nsIChannel**);
- nsresult ParseURL(const char*, nsACString&, nsACString&, nsACString&, nsACString&, nsACString&);
- nsresult GetErrorMessage(nsIURI*, const char*, char**, char**, char**, char**, char**, char**);
- nsresult CreateErrorPage(nsIURI*, nsIChannel**);
- nsresult CreateRecoverPage(nsIURI*, nsIChannel**);
- nsresult WritePage(nsIURI*, nsIURI*, nsIURI*, const nsACString&, const char*, const char*, const char*, const char*, const char*, const char*, nsIChannel**);
- nsresult Write(nsIOutputStream*, const char*);
-};
-
-#endif /* EPHY_ABOUT_MODULE_H */
diff --git a/embed/xulrunner/components/EphyContentPolicy.cpp b/embed/xulrunner/components/EphyContentPolicy.cpp
deleted file mode 100644
index 7f8943687..000000000
--- a/embed/xulrunner/components/EphyContentPolicy.cpp
+++ /dev/null
@@ -1,244 +0,0 @@
-/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*-
- *
- * Copyright © 2003 Christian Persch
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include <nsStringGlue.h>
-
-#include <nsCOMPtr.h>
-#include <nsICategoryManager.h>
-#include <nsIDOMAbstractView.h>
-#include <nsIDOMDocument.h>
-#include <nsIDOMDocumentView.h>
-#include <nsIDOMNode.h>
-#include <nsIDOMWindow.h>
-#include <nsIURI.h>
-#include <nsServiceManagerUtils.h>
-#include <nsXPCOMCID.h>
-
-#include "eel-gconf-extensions.h"
-#include "ephy-adblock-manager.h"
-#include "ephy-debug.h"
-#include "ephy-embed-shell.h"
-#include "ephy-embed-single.h"
-
-#include "EphyUtils.h"
-
-#include "EphyContentPolicy.h"
-
-#define CONF_LOCKDOWN_DISABLE_UNSAFE_PROTOCOLS "/apps/epiphany/lockdown/disable_unsafe_protocols"
-#define CONF_LOCKDOWN_ADDITIONAL_SAFE_PROTOCOLS "/apps/epiphany/lockdown/additional_safe_protocols"
-
-NS_IMPL_ISUPPORTS1(EphyContentPolicy, nsIContentPolicy)
-
-EphyContentPolicy::EphyContentPolicy()
-{
- LOG ("EphyContentPolicy ctor (%p)", this);
-
- mLocked = eel_gconf_get_boolean (CONF_LOCKDOWN_DISABLE_UNSAFE_PROTOCOLS);
-
- mSafeProtocols = eel_gconf_get_string_list (CONF_LOCKDOWN_ADDITIONAL_SAFE_PROTOCOLS);
-}
-
-EphyContentPolicy::~EphyContentPolicy()
-{
- LOG ("EphyContentPolicy dtor (%p)", this);
-
- g_slist_foreach (mSafeProtocols, (GFunc) g_free, NULL);
- g_slist_free (mSafeProtocols);
-}
-
-GtkWidget *
-EphyContentPolicy::GetEmbedFromContext (nsISupports *aContext)
-{
- /*
- * aContext is either an nsIDOMWindow, an nsIDOMNode, or NULL. If it's
- * an nsIDOMNode, we need the nsIDOMWindow to get the EphyEmbed.
- */
- if (aContext == NULL) return NULL;
-
- nsCOMPtr<nsIDOMWindow> window;
-
- nsCOMPtr<nsIDOMNode> node (do_QueryInterface (aContext));
- if (node != NULL)
- {
- nsCOMPtr<nsIDOMDocument> domDocument;
-
- node->GetOwnerDocument (getter_AddRefs (domDocument));
- if (domDocument == NULL) return NULL; /* resource://... */
-
- nsCOMPtr<nsIDOMDocumentView> docView =
- do_QueryInterface (domDocument);
- NS_ENSURE_TRUE (docView, NULL);
-
- nsCOMPtr<nsIDOMAbstractView> view;
-
- docView->GetDefaultView (getter_AddRefs (view));
-
- window = do_QueryInterface (view);
- }
- else
- {
- window = do_QueryInterface (aContext);
- }
- NS_ENSURE_TRUE (window, NULL);
-
- GtkWidget *embed = EphyUtils::FindEmbed (window);
- if (!EPHY_IS_EMBED (embed)) return NULL;
-
- return embed;
-}
-
-NS_IMETHODIMP
-EphyContentPolicy::ShouldLoad(PRUint32 aContentType,
- nsIURI *aContentLocation,
- nsIURI *aRequestingLocation,
- nsISupports *aContext,
- const nsACString &aMimeTypeGuess,
- nsISupports *aExtra,
- PRInt16 *aDecision)
-{
- NS_ENSURE_ARG (aContentLocation);
- NS_ENSURE_ARG_POINTER (aDecision);
-
- *aDecision = nsIContentPolicy::ACCEPT;
-
- /* We have to always allow these, else forms and scrollbars break */
- PRBool isChrome = PR_FALSE, isResource = PR_FALSE;
- aContentLocation->SchemeIs ("chrome", &isChrome);
- aContentLocation->SchemeIs ("resource", &isResource);
- if (isChrome || isResource) return NS_OK;
-
- PRBool isHttps = PR_FALSE;
- aContentLocation->SchemeIs ("https", &isHttps);
- if (isHttps) return NS_OK;
-
- /* is this url allowed ? */
- nsCString contentSpec;
- aContentLocation->GetSpec (contentSpec);
-
- EphyAdBlockManager *adblock_manager =
- EPHY_ADBLOCK_MANAGER (ephy_embed_shell_get_adblock_manager (embed_shell));
-
- static PRBool kBlockType[nsIContentPolicy::TYPE_REFRESH + 1] = {
- PR_FALSE /* unused/unknown, don't block */,
- PR_TRUE /* TYPE_OTHER */,
- PR_TRUE /* TYPE_SCRIPT */,
- PR_TRUE /* TYPE_IMAGE */,
- PR_FALSE /* TYPE_STYLESHEET */,
- PR_TRUE /* TYPE_OBJECT */,
- PR_FALSE /* TYPE_DOCUMENT */,
- PR_TRUE /* TYPE_SUBDOCUMENT */,
- PR_TRUE /* TYPE_REFRESH */
- };
-
- if (kBlockType[aContentType < G_N_ELEMENTS (kBlockType) ? aContentType : 0])
- {
- GtkWidget *embed = GetEmbedFromContext (aContext);
-
- if (embed &&
- !ephy_adblock_manager_should_load (adblock_manager,
- EPHY_EMBED (embed),
- contentSpec.get (),
- AdUriCheckType (aContentType)))
- {
- *aDecision = nsIContentPolicy::REJECT_REQUEST;
-
- g_signal_emit_by_name (embed,
- "content-blocked",
- contentSpec.get ());
- return NS_OK;
- }
- }
-
- PRBool isHttp = PR_FALSE;
- aContentLocation->SchemeIs ("http", &isHttp);
- if (isHttp) return NS_OK;
-
- if (strcmp (contentSpec.get(), "about:blank") == 0) return NS_OK;
-
- nsCString contentScheme;
- aContentLocation->GetScheme (contentScheme);
-
- /* first general lockdown check */
- if (mLocked &&
- !g_slist_find_custom (mSafeProtocols, contentScheme.get(), (GCompareFunc) strcmp))
- {
- *aDecision = nsIContentPolicy::REJECT_REQUEST;
- }
-
- return NS_OK;
-}
-
-NS_IMETHODIMP
-EphyContentPolicy::ShouldProcess(PRUint32 aContentType,
- nsIURI *aContentLocation,
- nsIURI *aRequestingLocation,
- nsISupports *aContext,
- const nsACString &aMimeType,
- nsISupports *aExtra,
- PRInt16 *aDecision)
-{
- *aDecision = nsIContentPolicy::ACCEPT;
- return NS_OK;
-}
-
-
-/* static */ NS_METHOD
-EphyContentPolicy::Register (nsIComponentManager* aComponentManager,
- nsIFile* aPath,
- const char* aRegistryLocation,
- const char* aComponentType,
- const nsModuleComponentInfo* aInfo)
-{
- nsresult rv;
- nsCOMPtr<nsICategoryManager> catMan (do_GetService(NS_CATEGORYMANAGER_CONTRACTID, &rv));
- NS_ENSURE_SUCCESS (rv, rv);
-
- rv = catMan->AddCategoryEntry ("content-policy",
- EPHY_CONTENT_POLICY_CONTRACTID,
- EPHY_CONTENT_POLICY_CONTRACTID,
- PR_FALSE /* don't persist */,
- PR_TRUE /* replace */,
- nsnull);
- NS_ENSURE_SUCCESS (rv, rv);
-
- return rv;
-}
-
-/* static */ NS_METHOD
-EphyContentPolicy::Unregister (nsIComponentManager* aComponentManager,
- nsIFile* aPath,
- const char* aRegistryLocation,
- const nsModuleComponentInfo* aInfo)
-{
- nsresult rv;
- nsCOMPtr<nsICategoryManager> catMan (do_GetService(NS_CATEGORYMANAGER_CONTRACTID, &rv));
- NS_ENSURE_SUCCESS (rv, rv);
-
- rv = catMan->DeleteCategoryEntry ("content-policy",
- EPHY_CONTENT_POLICY_CONTRACTID,
- PR_FALSE /* don't persist */);
- NS_ENSURE_SUCCESS (rv, rv);
-
- return rv;
-}
diff --git a/embed/xulrunner/components/EphyContentPolicy.h b/embed/xulrunner/components/EphyContentPolicy.h
deleted file mode 100644
index 0bc68ced7..000000000
--- a/embed/xulrunner/components/EphyContentPolicy.h
+++ /dev/null
@@ -1,76 +0,0 @@
-/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*-
- *
- * Copyright © 2003 Christian Persch
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#ifndef EPHY_CONTENT_POLICY_H
-#define EPHY_CONTENT_POLICY_H
-
-#include <glib.h>
-#include <glib-object.h>
-#include <gtk/gtkwidget.h>
-
-#include <nsIContentPolicy.h>
-
-#include "ephy-embed.h"
-
-class nsIComponentManager;
-class nsIFile;
-struct nsModuleComponentInfo;
-
-#define EPHY_CONTENT_POLICY_CONTRACTID "@gnome.org/projects/epiphany/epiphany-content-policy;1"
-#define EPHY_CONTENT_POLICY_CLASSNAME "Epiphany Content Policy Class"
-
-#define EPHY_CONTENT_POLICY_CID \
-{ /* 6bb60b15-b7bd-4023-a19e-ab691bc3fb43 */ \
- 0x6bb60b15, \
- 0xb7bd, \
- 0x4023, \
- { 0xa1, 0x9e, 0xab, 0x69, 0x1b, 0xc3, 0xfb, 0x43 } \
-}
-
-class EphyContentPolicy : public nsIContentPolicy
-{
- public:
- NS_DECL_ISUPPORTS
- NS_DECL_NSICONTENTPOLICY
-
- EphyContentPolicy();
-
- static NS_METHOD Register (nsIComponentManager* aComponentManager,
- nsIFile* aPath,
- const char* aRegistryLocation,
- const char* aComponentType,
- const nsModuleComponentInfo* aInfo);
-
- static NS_METHOD Unregister (nsIComponentManager* aComponentManager,
- nsIFile* aPath,
- const char* aRegistryLocation,
- const nsModuleComponentInfo* aInfo);
-
- private:
- ~EphyContentPolicy();
-
- static GtkWidget *GetEmbedFromContext (nsISupports *aContext);
-
- gboolean mLocked;
- GSList *mSafeProtocols;
-};
-
-#endif
diff --git a/embed/xulrunner/components/EphyHistoryListener.cpp b/embed/xulrunner/components/EphyHistoryListener.cpp
deleted file mode 100644
index 5da2170e7..000000000
--- a/embed/xulrunner/components/EphyHistoryListener.cpp
+++ /dev/null
@@ -1,170 +0,0 @@
-/*
- * Copyright © 2004 Christian Persch
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include <nsStringGlue.h>
-
-#include <nsCOMPtr.h>
-#include <nsCURILoader.h>
-#include <nsIChannel.h>
-#include <nsIDocumentLoader.h>
-#include <nsIHttpChannel.h>
-#include <nsIRequest.h>
-#include <nsIRequestObserver.h>
-#include <nsISupportsUtils.h>
-#include <nsIURI.h>
-#include <nsIWebProgress.h>
-#include <nsNetCID.h>
-#include <nsServiceManagerUtils.h>
-
-#include "EphyUtils.h"
-
-#include "ephy-debug.h"
-
-#include "EphyHistoryListener.h"
-
-EphyHistoryListener::EphyHistoryListener ()
-{
- LOG ("EphyHistoryListener ctor");
-}
-
-EphyHistoryListener::~EphyHistoryListener ()
-{
- LOG ("EphyHistoryListener dtor");
-}
-
-nsresult
-EphyHistoryListener::Init (EphyHistory *aHistory)
-{
- mHistory = aHistory;
-
- nsresult rv;
- nsCOMPtr<nsIWebProgress> webProgress
- (do_GetService(NS_DOCUMENTLOADER_SERVICE_CONTRACTID, &rv));
- NS_ENSURE_TRUE (NS_SUCCEEDED (rv) && webProgress, rv);
-
- rv = webProgress->AddProgressListener
- (static_cast<nsIWebProgressListener*>(this),
- nsIWebProgress::NOTIFY_STATE_REQUEST);
-
- return rv;
-}
-
-NS_IMPL_ISUPPORTS2 (EphyHistoryListener,
- nsIWebProgressListener,
- nsISupportsWeakReference)
-
-/* void onStateChange (in nsIWebProgress aWebProgress, in nsIRequest aRequest, in long aStateFlags, in nsresult aStatus); */
-NS_IMETHODIMP
-EphyHistoryListener::OnStateChange (nsIWebProgress *aWebProgress,
- nsIRequest *aRequest,
- PRUint32 aStateFlags,
- nsresult aStatus)
-{
- nsresult rv = NS_OK;
-
- /* we only care about redirects */
- if (! (aStateFlags & nsIWebProgressListener::STATE_REDIRECTING))
- {
- return rv;
- }
-
- nsCOMPtr<nsIChannel> channel (do_QueryInterface (aRequest));
- nsCOMPtr<nsIHttpChannel> httpChannel (do_QueryInterface (channel));
- if (!httpChannel) return rv;
-
- PRUint32 status = 0;
- rv = httpChannel->GetResponseStatus (&status);
- if (rv == NS_ERROR_NOT_AVAILABLE) return NS_OK;
- NS_ENSURE_SUCCESS (rv, rv);
-
- /* we're only interested in 301 redirects (moved permanently) */
- if (status != 301) return NS_OK;
-
- nsCOMPtr<nsIURI> fromURI;
- rv = channel->GetURI (getter_AddRefs (fromURI));
- NS_ENSURE_TRUE (NS_SUCCEEDED (rv) && fromURI, rv);
-
- nsCString location;
- rv = httpChannel->GetResponseHeader
- (nsCString ("Location"), location);
- NS_ENSURE_TRUE (NS_SUCCEEDED (rv) && location.Length(), rv);
-
- nsCOMPtr<nsIURI> toURI;
- rv = EphyUtils::NewURI (getter_AddRefs (toURI), location,
- nsnull /* use origin charset of fromURI */, fromURI);
- NS_ENSURE_TRUE (NS_SUCCEEDED (rv) && toURI, rv);
-
- nsCString fromSpec, toSpec;
- rv = fromURI->GetSpec (fromSpec);
- rv |= toURI->GetSpec(toSpec);
- NS_ENSURE_SUCCESS (rv, rv);
-
- g_signal_emit_by_name (mHistory, "redirect",
- fromSpec.get(), toSpec.get());
-
- return rv;
-}
-
-/* void onProgressChange (in nsIWebProgress aWebProgress, in nsIRequest aRequest, in long aCurSelfProgress, in long aMaxSelfProgress, in long aCurTotalProgress, in long aMaxTotalProgress); */
-NS_IMETHODIMP
-EphyHistoryListener::OnProgressChange (nsIWebProgress *aWebProgress,
- nsIRequest *aRequest,
- PRInt32 aCurSelfProgress,
- PRInt32 aMaxSelfProgress,
- PRInt32 aCurTotalProgress,
- PRInt32 aMaxTotalProgress)
-{
- NS_NOTREACHED("notification excluded in AddProgressListener(...)");
- return NS_OK;
-}
-
-/* void onLocationChange (in nsIWebProgress aWebProgress, in nsIRequest aRequest, in nsIURI location); */
-NS_IMETHODIMP
-EphyHistoryListener::OnLocationChange (nsIWebProgress *aWebProgress,
- nsIRequest *aRequest,
- nsIURI *location)
-{
- NS_NOTREACHED("notification excluded in AddProgressListener(...)");
- return NS_OK;
-}
-
-/* void onStatusChange (in nsIWebProgress aWebProgress, in nsIRequest aRequest, in nsresult aStatus, in wstring aMessage); */
-NS_IMETHODIMP
-EphyHistoryListener::OnStatusChange (nsIWebProgress *aWebProgress,
- nsIRequest *aRequest,
- nsresult aStatus,
- const PRUnichar *aMessage)
-{
- NS_NOTREACHED("notification excluded in AddProgressListener(...)");
- return NS_OK;
-}
-
-/* void onSecurityChange (in nsIWebProgress aWebProgress, in nsIRequest aRequest, in unsigned long state); */
-NS_IMETHODIMP
-EphyHistoryListener::OnSecurityChange (nsIWebProgress *aWebProgress,
- nsIRequest *aRequest,
- PRUint32 state)
-{
- NS_NOTREACHED("notification excluded in AddProgressListener(...)");
- return NS_OK;
-}
diff --git a/embed/xulrunner/components/EphyHistoryListener.h b/embed/xulrunner/components/EphyHistoryListener.h
deleted file mode 100644
index 23f955f05..000000000
--- a/embed/xulrunner/components/EphyHistoryListener.h
+++ /dev/null
@@ -1,49 +0,0 @@
-/*
- * Copyright © 2004 Christian Persch
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#ifndef EPHY_REDIRECT_LISTENER_H
-#define EPHY_REDIRECT_LISTENER_H
-
-#include "ephy-history.h"
-
-#include <nsIWebProgressListener.h>
-#include <nsWeakReference.h>
-
-/* 6a9533c6-f068-4e63-8225-5feba0b54d6b */
-#define EPHY_REDIRECTLISTENER_CID \
-{ 0x6a9533c6, 0xf068, 0x4e63, { 0x82, 0x25, 0x5f, 0xeb, 0xa0, 0xb5, 0x4d, 0x6b } }
-#define EPHY_REDIRECTLISTENER_CLASSNAME "Epiphany Redirect Listener Class"
-
-class EphyHistoryListener : public nsIWebProgressListener,
- public nsSupportsWeakReference
-{
- public:
- EphyHistoryListener();
- virtual ~EphyHistoryListener();
-
- nsresult Init (EphyHistory *aHistory);
-
- NS_DECL_ISUPPORTS
- NS_DECL_NSIWEBPROGRESSLISTENER
- private:
- EphyHistory *mHistory;
-};
-
-#endif /* EPHY_REDIRECT_LISTENER_H */
diff --git a/embed/xulrunner/components/EphyRedirectChannel.cpp b/embed/xulrunner/components/EphyRedirectChannel.cpp
deleted file mode 100644
index af6dd2f91..000000000
--- a/embed/xulrunner/components/EphyRedirectChannel.cpp
+++ /dev/null
@@ -1,32 +0,0 @@
-/*
- * Copyright © 2005 Christian Persch
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include "EphyRedirectChannel.h"
-
-NS_IMPL_ISUPPORTS2 (EphyWrappedChannel, nsIRequest, nsIChannel)
-
-NS_IMETHODIMP
-EphyRedirectChannel::SetLoadFlags(nsLoadFlags aFlags)
-{
- return mChannel->SetLoadFlags (aFlags | LOAD_REPLACE);
-}
diff --git a/embed/xulrunner/components/EphyRedirectChannel.h b/embed/xulrunner/components/EphyRedirectChannel.h
deleted file mode 100644
index bcec1f1e5..000000000
--- a/embed/xulrunner/components/EphyRedirectChannel.h
+++ /dev/null
@@ -1,50 +0,0 @@
-/*
- * Copyright © 2005 Christian Persch
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#ifndef EPHY_REDIRECT_CHANNEL_H
-#define EPHY_REDIRECT_CHANNEL_H
-
-#include <nsCOMPtr.h>
-#include <nsIChannel.h>
-
-class EphyWrappedChannel : public nsIChannel
-{
- public:
- NS_DECL_ISUPPORTS
- NS_FORWARD_NSIREQUEST (mChannel->)
- NS_FORWARD_NSICHANNEL (mChannel->)
-
- EphyWrappedChannel (nsIChannel *aChannel) : mChannel (aChannel) { }
- virtual ~EphyWrappedChannel () { }
-
- protected:
- nsCOMPtr<nsIChannel> mChannel;
-};
-
-class EphyRedirectChannel : public EphyWrappedChannel
-{
- public:
- EphyRedirectChannel (nsIChannel *aChannel) : EphyWrappedChannel (aChannel) { }
- virtual ~EphyRedirectChannel () { }
-
- NS_IMETHOD SetLoadFlags (nsLoadFlags aFlags);
-};
-
-#endif /* !EPHY_REDIRECT_CHANNEL_H */
diff --git a/embed/xulrunner/components/EphySidebar.cpp b/embed/xulrunner/components/EphySidebar.cpp
deleted file mode 100644
index 1225e2d9a..000000000
--- a/embed/xulrunner/components/EphySidebar.cpp
+++ /dev/null
@@ -1,161 +0,0 @@
-/*
- * Copyright © 2002 Philip Langdale
- * Copyright © 2004 Crispin Flowerday
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include <nsStringGlue.h>
-
-#include <nsICategoryManager.h>
-#include <nsIClassInfoImpl.h>
-#include <nsIScriptNameSpaceManager.h>
-#include <nsMemory.h>
-#include <nsServiceManagerUtils.h>
-#include <nsXPCOMCID.h>
-
-#include "ephy-debug.h"
-#include "ephy-embed-shell.h"
-#include "ephy-embed-single.h"
-
-#include "EphySidebar.h"
-
-NS_IMPL_ISUPPORTS1_CI(EphySidebar, nsISidebar)
-
-EphySidebar::EphySidebar()
-{
-}
-
-EphySidebar::~EphySidebar()
-{
-}
-
-/* void addPanel (in wstring aTitle, in string aContentURL, in string aCustomizeURL); */
-NS_IMETHODIMP
-EphySidebar::AddPanel (const PRUnichar *aTitle,
- const char *aContentURL,
- const char *aCustomizeURL)
-{
- NS_ENSURE_ARG (aTitle);
- NS_ENSURE_ARG (aContentURL);
-
- nsCString title;
- EphyEmbedSingle *single;
-
- /* FIXME: length-limit string */
- NS_UTF16ToCString (nsDependentString(aTitle),
- NS_CSTRING_ENCODING_UTF8, title);
-
- LOG ("Adding sidebar, url=%s title=%s", aContentURL, title.get());
-
- single = EPHY_EMBED_SINGLE (ephy_embed_shell_get_embed_single (embed_shell));
-
- gboolean result = FALSE;
- g_signal_emit_by_name (single, "add-sidebar",
- aContentURL, title.get(), &result);
-
- return NS_OK;
-}
-
-/* void addPersistentPanel (in wstring aTitle, in string aContentURL, in string aCustomizeURL); */
-NS_IMETHODIMP
-EphySidebar::AddPersistentPanel (const PRUnichar *aTitle,
- const char *aContentURL,
- const char *aCustomizeURL)
-{
- return AddPanel (aTitle, aContentURL, aCustomizeURL);
-}
-
-/* void addSearchEngine (in string engineURL, in string iconURL, in wstring suggestedTitle, in wst
-ring suggestedCategory); */
-NS_IMETHODIMP
-EphySidebar::AddSearchEngine (const char *aEngineURL,
- const char *aIconURL,
- const PRUnichar *aSuggestedTitle,
- const PRUnichar *aSuggestedCategory)
-{
- NS_ENSURE_ARG (aSuggestedTitle);
- NS_ENSURE_ARG (aIconURL);
- NS_ENSURE_ARG (aEngineURL);
-
- nsCString title;
- EphyEmbedSingle *single;
-
- /* FIXME: length-limit string */
- NS_UTF16ToCString (nsDependentString(aSuggestedTitle),
- NS_CSTRING_ENCODING_UTF8, title);
-
- LOG ("Adding search engine, engineurl=%s iconurl=%s title=%s", aEngineURL, aIconURL, title.get());
-
- single = EPHY_EMBED_SINGLE (ephy_embed_shell_get_embed_single (embed_shell));
-
- gboolean result = FALSE;
- g_signal_emit_by_name (single, "add-search-engine",
- aEngineURL, aIconURL, title.get(), &result);
-
- return NS_OK;
-}
-
-/* void addMicrosummaryGenerator (in string generatorURL); */
-NS_IMETHODIMP
-EphySidebar::AddMicrosummaryGenerator (const char *generatorURL)
-{
- return NS_ERROR_NOT_IMPLEMENTED;
-}
-
-/* static */ NS_METHOD
-EphySidebar::Register (nsIComponentManager* aComponentManager,
- nsIFile* aPath,
- const char* aRegistryLocation,
- const char* aComponentType,
- const nsModuleComponentInfo* aInfo)
-{
- nsresult rv;
- nsCOMPtr<nsICategoryManager> catMan (do_GetService(NS_CATEGORYMANAGER_CONTRACTID, &rv));
- NS_ENSURE_SUCCESS (rv, rv);
-
- rv = catMan->AddCategoryEntry (JAVASCRIPT_GLOBAL_PROPERTY_CATEGORY,
- "sidebar",
- NS_SIDEBAR_CONTRACTID,
- PR_FALSE /* don't persist */,
- PR_TRUE /* replace */,
- nsnull);
- NS_ENSURE_SUCCESS (rv, rv);
-
- return rv;
-}
-
-/* static */ NS_METHOD
-EphySidebar::Unregister (nsIComponentManager* aComponentManager,
- nsIFile* aPath,
- const char* aRegistryLocation,
- const nsModuleComponentInfo* aInfo)
-{
- nsresult rv;
- nsCOMPtr<nsICategoryManager> catMan (do_GetService(NS_CATEGORYMANAGER_CONTRACTID, &rv));
- NS_ENSURE_SUCCESS (rv, rv);
-
- rv = catMan->DeleteCategoryEntry (JAVASCRIPT_GLOBAL_PROPERTY_CATEGORY,
- "sidebar",
- PR_FALSE /* don't persist */);
- NS_ENSURE_SUCCESS (rv, rv);
-
- return rv;
-}
diff --git a/embed/xulrunner/components/EphySidebar.h b/embed/xulrunner/components/EphySidebar.h
deleted file mode 100644
index 37efa0bf8..000000000
--- a/embed/xulrunner/components/EphySidebar.h
+++ /dev/null
@@ -1,66 +0,0 @@
-/*
- * Copyright © 2002 Philip Langdale
- * Copyright © 2004 Crispin Flowerday
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#ifndef EPHY_SIDEBAR_H
-#define EPHY_SIDEBAR_H
-
-#include <nsISidebar.h>
-
-class nsIComponentManager;
-class nsIFile;
-struct nsModuleComponentInfo;
-
-#define EPHY_SIDEBAR_CLASSNAME \
- "Epiphany's Sidebar Implementation"
-
-#define EPHY_SIDEBAR_CID \
-{ /* {50f13159-f9b9-44b3-b18e-6ee5d85a202a} */ \
- 0x50f13159, \
- 0xf9b9, \
- 0x44b3, \
- {0xb1, 0x8e, 0x6e, 0xe5, 0xd8, 0x5a, 0x20, 0x2a} \
-}
-
-class EphySidebar : public nsISidebar
-{
- public:
- NS_DECL_ISUPPORTS
- NS_DECL_NSISIDEBAR
-
- EphySidebar();
-
- static NS_METHOD Register (nsIComponentManager* aComponentManager,
- nsIFile* aPath,
- const char* aRegistryLocation,
- const char* aComponentType,
- const nsModuleComponentInfo* aInfo);
-
- static NS_METHOD Unregister (nsIComponentManager* aComponentManager,
- nsIFile* aPath,
- const char* aRegistryLocation,
- const nsModuleComponentInfo* aInfo);
-
- private:
- ~EphySidebar();
-};
-
-#endif /* ! EPHY_SIDEBAR_H */
-
diff --git a/embed/xulrunner/components/FilePicker.cpp b/embed/xulrunner/components/FilePicker.cpp
deleted file mode 100644
index 77335d4f5..000000000
--- a/embed/xulrunner/components/FilePicker.cpp
+++ /dev/null
@@ -1,453 +0,0 @@
-/*
- * Copyright © 2001 Philip Langdale
- * Copyright © 2003, 2004 Christian Persch
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include <glib/gconvert.h>
-#include <glib/gi18n.h>
-#include <gtk/gtkfilefilter.h>
-#include <gtk/gtkmessagedialog.h>
-#include <gtk/gtkstock.h>
-
-#include <nsStringGlue.h>
-
-#include <nsCOMPtr.h>
-#include <nsIDOMWindow.h>
-#include <nsIFileURL.h>
-#include <nsILocalFile.h>
-#include <nsIPromptService.h>
-#include <nsIServiceManager.h>
-#include <nsIURI.h>
-#include <nsNetCID.h>
-#include <nsComponentManagerUtils.h>
-#include <nsServiceManagerUtils.h>
-#include <nsXPCOMCID.h>
-
-#include "ephy-debug.h"
-#include "ephy-gui.h"
-#include "ephy-prefs.h"
-
-#include "AutoJSContextStack.h"
-#include "AutoWindowModalState.h"
-#include "EphyUtils.h"
-
-#include "FilePicker.h"
-
-NS_IMPL_ISUPPORTS1(GFilePicker, nsIFilePicker)
-
-GFilePicker::GFilePicker()
-: mDialog(nsnull)
-, mMode(nsIFilePicker::modeOpen)
-{
- LOG ("GFilePicker ctor (%p)", this);
-}
-
-GFilePicker::~GFilePicker()
-{
- LOG ("GFilePicker dtor (%p)", this);
-
- if (mDialog)
- {
- g_object_remove_weak_pointer (G_OBJECT (mDialog), (gpointer *) &mDialog);
- gtk_widget_destroy (GTK_WIDGET (mDialog));
- }
-}
-
-/* void init (in nsIDOMWindow parent, in AString title, in short mode); */
-NS_IMETHODIMP GFilePicker::Init(nsIDOMWindow *parent, const nsAString& title, PRInt16 mode)
-{
- LOG ("GFilePicker::Init");
-
- mParent = do_QueryInterface (parent);
-
- GtkWidget *gtkparent = EphyUtils::FindGtkParent (parent);
-
- NS_ENSURE_TRUE (gtkparent, NS_ERROR_FAILURE);
-
-
- nsCString cTitle;
-
- NS_UTF16ToCString (title, NS_CSTRING_ENCODING_UTF8, cTitle);
-
- mMode = mode;
-
- GtkFileChooserAction action = GTK_FILE_CHOOSER_ACTION_OPEN;
- switch (mode)
- {
- case nsIFilePicker::modeGetFolder:
- action = GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER;
- break;
- case nsIFilePicker::modeOpenMultiple:
- case nsIFilePicker::modeOpen:
- action = GTK_FILE_CHOOSER_ACTION_OPEN;
- break;
- case nsIFilePicker::modeSave:
- action = GTK_FILE_CHOOSER_ACTION_SAVE;
- break;
- default:
- g_assert_not_reached ();
- break;
- }
-
- mDialog = ephy_file_chooser_new (cTitle.get(), gtkparent, action,
- CONF_STATE_UPLOAD_DIR,
- EPHY_FILE_FILTER_NONE);
-
- if (parent)
- {
- gtk_window_group_add_window (ephy_gui_ensure_window_group (GTK_WINDOW (gtkparent)),
- GTK_WINDOW (mDialog));
- }
-
- if (mode == nsIFilePicker::modeOpenMultiple)
- {
- gtk_file_chooser_set_select_multiple (GTK_FILE_CHOOSER (mDialog), TRUE);
- }
- if (mMode == nsIFilePicker::modeSave)
- {
- gtk_file_chooser_set_do_overwrite_confirmation (GTK_FILE_CHOOSER (mDialog), TRUE);
- }
-
- g_object_add_weak_pointer (G_OBJECT (mDialog), (gpointer *) &mDialog);
-
- return NS_OK;
-}
-
-/* void appendFilters (in long filterMask); */
-NS_IMETHODIMP GFilePicker::AppendFilters(PRInt32 filterMask)
-{
- NS_ENSURE_TRUE (mDialog, NS_ERROR_FAILURE);
-
- LOG ("GFilePicker::AppendFilters mask=%d", filterMask);
-
- // http://lxr.mozilla.org/seamonkey/source/xpfe/components/filepicker/res/locale/en-US/filepicker.properties
- // http://lxr.mozilla.org/seamonkey/source/xpfe/components/filepicker/src/nsFilePicker.js line 131 ff
-
- if (filterMask & nsIFilePicker::filterAll)
- {
- ephy_file_chooser_add_pattern_filter (mDialog, _("All files"),
- "*", (char*) NULL);
- }
- if (filterMask & nsIFilePicker::filterHTML)
- {
- ephy_file_chooser_add_mime_filter (mDialog, _("Web pages"),
- "text/html",
- "application/xhtml+xml",
- "text/xml",
- (char *) NULL);
- }
- if (filterMask & nsIFilePicker::filterText)
- {
- ephy_file_chooser_add_pattern_filter (mDialog, _("Text files"),
- "*.txt", "*.text", NULL);
- }
- if (filterMask & nsIFilePicker::filterImages)
- {
- ephy_file_chooser_add_mime_filter (mDialog, _("Images"),
- "image/png",
- "image/jpeg",
- "image/gif",
- (char *) NULL);
- }
- if (filterMask & nsIFilePicker::filterXML)
- {
- ephy_file_chooser_add_pattern_filter (mDialog, _("XML files"),
- "*.xml", (char *) NULL);
- }
- if (filterMask & nsIFilePicker::filterXUL)
- {
- ephy_file_chooser_add_pattern_filter (mDialog, _("XUL files"),
- "*.xul", (char *) NULL);
- }
-
- return NS_OK;
-}
-
-/* void appendFilter (in AString title, in AString filter); */
-
-NS_IMETHODIMP GFilePicker::AppendFilter(const nsAString& title, const nsAString& filter)
-{
- NS_ENSURE_TRUE (mDialog, NS_ERROR_FAILURE);
-
- LOG ("GFilePicker::AppendFilter");
-
- if (!filter.Length()) return NS_ERROR_FAILURE;
-
- nsCString pattern;
- NS_UTF16ToCString (filter, NS_CSTRING_ENCODING_UTF8, pattern);
-
- char **patterns;
- patterns = g_strsplit (pattern.get(), ";", -1);
- if (!patterns) return NS_ERROR_FAILURE;
-
- GtkFileFilter *filth;
- filth = gtk_file_filter_new ();
-
- for (int i = 0; patterns[i] != NULL; i++)
- {
- gtk_file_filter_add_pattern (filth, g_strstrip (patterns[i]));
- }
-
- nsCString cTitle;
- NS_UTF16ToCString (title, NS_CSTRING_ENCODING_UTF8, cTitle);
-
- gtk_file_filter_set_name (filth, cTitle.get());
-
- gtk_file_chooser_add_filter (GTK_FILE_CHOOSER (mDialog), filth);
-
- g_strfreev (patterns);
-
- return NS_OK;
-}
-
-/* attribute AString defaultString; */
-NS_IMETHODIMP GFilePicker::GetDefaultString(nsAString& aDefaultString)
-{
- NS_ENSURE_TRUE (mDialog, NS_ERROR_FAILURE);
-
- LOG ("GFilePicker::GetDefaultString");
-
- aDefaultString = mDefaultString;
-
- return NS_OK;
-}
-
-NS_IMETHODIMP GFilePicker::SetDefaultString(const nsAString& aDefaultString)
-{
- NS_ENSURE_TRUE (mDialog, NS_ERROR_FAILURE);
-
- mDefaultString.Assign (aDefaultString);
-
- if (mMode == nsIFilePicker::modeSave)
- {
- nsCString defaultString;
- NS_UTF16ToCString (mDefaultString, NS_CSTRING_ENCODING_UTF8,
- defaultString);
-
- LOG ("GFilePicker::SetDefaultString %s", defaultString.get());
-
- if (!defaultString.Length()) return NS_ERROR_FAILURE;
-
- /* set_current_name takes UTF-8, not a filename */
- gtk_file_chooser_set_current_name
- (GTK_FILE_CHOOSER (mDialog), defaultString.get());
- }
-
- return NS_OK;
-}
-
-/* attribute AString defaultExtension; */
-NS_IMETHODIMP GFilePicker::GetDefaultExtension(nsAString& aDefaultExtension)
-{
- LOG ("GFilePicker::GetDefaultExtension");
-
- return NS_ERROR_NOT_IMPLEMENTED;
-}
-
-NS_IMETHODIMP GFilePicker::SetDefaultExtension(const nsAString& aDefaultExtension)
-{
- LOG ("GFilePicker::SetDefaultExtension");
-
- return NS_ERROR_NOT_IMPLEMENTED;
-}
-
-/* attribute long filterIndex; */
-NS_IMETHODIMP GFilePicker::GetFilterIndex(PRInt32 *aFilterIndex)
-{
- LOG ("GFilePicker::GetFilterIndex");
-
- return NS_ERROR_NOT_IMPLEMENTED;
-}
-
-NS_IMETHODIMP GFilePicker::SetFilterIndex(PRInt32 aFilterIndex)
-{
- LOG ("GFilePicker::SetFilterIndex index=%d", aFilterIndex);
-
- return NS_ERROR_NOT_IMPLEMENTED;
-}
-
-/* attribute nsILocalFile displayDirectory; */
-NS_IMETHODIMP GFilePicker::GetDisplayDirectory(nsILocalFile **aDisplayDirectory)
-{
- NS_ENSURE_TRUE (mDialog, NS_ERROR_FAILURE);
-
- LOG ("GFilePicker::GetDisplayDirectory");
-
- char *dir = gtk_file_chooser_get_current_folder (GTK_FILE_CHOOSER (mDialog));
-
- if (dir != NULL)
- {
- nsCOMPtr<nsILocalFile> file = do_CreateInstance (NS_LOCAL_FILE_CONTRACTID);
- file->InitWithNativePath (nsCString (dir));
- NS_IF_ADDREF (*aDisplayDirectory = file);
-
- g_free (dir);
- }
-
- return NS_OK;
-}
-
-NS_IMETHODIMP GFilePicker::SetDisplayDirectory(nsILocalFile *aDisplayDirectory)
-{
- NS_ENSURE_TRUE (mDialog, NS_ERROR_FAILURE);
-
- nsCString dir;
- aDisplayDirectory->GetNativePath (dir);
-
- LOG ("GFilePicker::SetDisplayDirectory to %s", dir.get());
-
- if (mDefaultString.Length() && mMode != nsIFilePicker::modeSave)
- {
- nsCString defaultString;
- NS_UTF16ToCString (mDefaultString, NS_CSTRING_ENCODING_NATIVE_FILESYSTEM,
- defaultString);
-
- char *filename = g_build_filename (dir.get(), defaultString.get(), (char *) NULL);
- LOG ("Setting filename to %s", filename);
- gtk_file_chooser_set_filename (GTK_FILE_CHOOSER (mDialog), filename);
- g_free (filename);
- }
- else
- {
- gtk_file_chooser_set_current_folder (GTK_FILE_CHOOSER (mDialog),
- dir.get());
- }
-
- return NS_OK;
-}
-
-/* readonly attribute nsILocalFile file; */
-NS_IMETHODIMP GFilePicker::GetFile(nsILocalFile **aFile)
-{
- NS_ENSURE_TRUE (mDialog, NS_ERROR_FAILURE);
-
- char *filename;
-
- LOG ("GFilePicker::GetFile");
-
- filename = gtk_file_chooser_get_filename (GTK_FILE_CHOOSER (mDialog));
-
- if (filename != NULL)
- {
- nsCOMPtr<nsILocalFile> file = do_CreateInstance (NS_LOCAL_FILE_CONTRACTID);
- file->InitWithNativePath (nsCString (filename));
- NS_IF_ADDREF (*aFile = file);
-
- g_free (filename);
- }
-
- return NS_OK;
-}
-
-/* readonly attribute nsIFileURL fileURL; */
-NS_IMETHODIMP GFilePicker::GetFileURL(nsIFileURL **aFileURL)
-{
- NS_ENSURE_TRUE (mDialog, NS_ERROR_FAILURE);
-
- LOG ("GFilePicker::GetFileURL");
-
- nsCOMPtr<nsILocalFile> file;
- GetFile (getter_AddRefs(file));
- NS_ENSURE_TRUE (file, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsIFileURL> fileURL = do_CreateInstance (NS_STANDARDURL_CONTRACTID);
- fileURL->SetFile(file);
- NS_IF_ADDREF(*aFileURL = fileURL);
-
- return NS_OK;
-}
-
-/* readonly attribute nsISimpleEnumerator files; */
-NS_IMETHODIMP GFilePicker::GetFiles(nsISimpleEnumerator * *aFiles)
-{
- // Not sure if we need to implement it at all, it's used nowhere
- // in mozilla, but I guess a javascript might call it?
-
- LOG ("GFilePicker::GetFiles");
-
- return NS_ERROR_NOT_IMPLEMENTED;
-}
-
-/* short show (); */
-NS_IMETHODIMP GFilePicker::Show(PRInt16 *_retval)
-{
- nsresult rv;
- AutoJSContextStack stack;
- rv = stack.Init ();
- if (NS_FAILED (rv)) return rv;
-
- AutoWindowModalState modelState (mParent);
- mParent = nsnull;
-
- LOG ("GFilePicker::Show");
-
- gtk_window_set_modal (GTK_WINDOW (mDialog), TRUE);
- gtk_window_set_destroy_with_parent (GTK_WINDOW (mDialog), FALSE);
-
- /* If there's just the "ALL" filter, it's no use showing the filters! */
- GSList *filters = gtk_file_chooser_list_filters (GTK_FILE_CHOOSER (mDialog));
- if (g_slist_length (filters) == 1)
- {
- GtkFileFilter *filter = GTK_FILE_FILTER (filters->data);
- const char *name = gtk_file_filter_get_name (filter);
-
- if (!name || strcmp (name, _("All files")) == 0)
- {
- gtk_file_chooser_remove_filter (GTK_FILE_CHOOSER (mDialog),
- filter);
- }
- }
- g_slist_free (filters);
-
- gtk_widget_show (GTK_WIDGET (mDialog));
-
- int response;
- char *filename = NULL;
-
- do
- {
- response = gtk_dialog_run (GTK_DIALOG (mDialog));
-
- g_free (filename);
- filename = gtk_file_chooser_get_filename (GTK_FILE_CHOOSER (mDialog));
-
- LOG ("GFilePicker::Show response=%d, filename=%s", response, filename);
- }
- while (response == GTK_RESPONSE_ACCEPT &&
- mMode == nsIFilePicker::modeSave &&
- !ephy_gui_check_location_writable (GTK_WIDGET (mDialog), filename));
-
- gtk_widget_hide (GTK_WIDGET (mDialog));
-
- if (response == GTK_RESPONSE_ACCEPT && filename != NULL)
- {
- *_retval = nsIFilePicker::returnOK;
- }
- else
- {
- *_retval = nsIFilePicker::returnCancel;
- }
-
- g_free (filename);
-
- return NS_OK;
-}
diff --git a/embed/xulrunner/components/FilePicker.h b/embed/xulrunner/components/FilePicker.h
deleted file mode 100644
index fa63c56b1..000000000
--- a/embed/xulrunner/components/FilePicker.h
+++ /dev/null
@@ -1,62 +0,0 @@
-/*
- * Copyright © 2001 Philip Langdale
- * Copyright © 2003 Christian Persch
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#ifndef EPHY_FILEPICKER_H
-#define EPHY_FILEPICKER_H
-
-#include <nsIFilePicker.h>
-
-class nsIDOMWindow;
-
-#include "ephy-file-chooser.h"
-
-#define G_FILEPICKER_CID \
-{ /* 3636dc79-0b42-4bad-8a3f-ae15d3671d17 */ \
- 0x3636dc79, \
- 0x0b42, \
- 0x4bad, \
- {0x8a, 0x3f, 0xae, 0x15, 0xd3, 0x67, 0x1d, 0x17} \
-}
-
-#define G_FILEPICKER_CONTRACTID "@mozilla.org/filepicker;1"
-#define G_FILEPICKER_CLASSNAME "Epiphany File Picker Implementation"
-
-class nsIFactory;
-
-extern nsresult NS_NewFilePickerFactory(nsIFactory** aFactory);
-
-class GFilePicker : public nsIFilePicker
-{
-public:
- NS_DECL_ISUPPORTS
- NS_DECL_NSIFILEPICKER
-
- GFilePicker();
- virtual ~GFilePicker();
-
-private:
- EphyFileChooser *mDialog;
- PRInt16 mMode;
- nsString mDefaultString;
- nsCOMPtr<nsIDOMWindow> mParent;
-};
-
-#endif
diff --git a/embed/xulrunner/components/GeckoCookiePromptService.cpp b/embed/xulrunner/components/GeckoCookiePromptService.cpp
deleted file mode 100644
index 722d9abd8..000000000
--- a/embed/xulrunner/components/GeckoCookiePromptService.cpp
+++ /dev/null
@@ -1,160 +0,0 @@
-/*
- * Copyright © 2003 Tommi Komulainen <tommi.komulainen@iki.fi>
- * Copyright © 2004, 2007 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License version 2
- * as published by the Free Software Foundation.
- *
- * 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include <glib/gi18n.h>
-
-#include <gtk/gtkbox.h>
-#include <gtk/gtkcheckbutton.h>
-#include <gtk/gtkdialog.h>
-#include <gtk/gtkmessagedialog.h>
-#include <gtk/gtkstock.h>
-#include <gtk/gtkwindow.h>
-
-#include <nsStringGlue.h>
-
-#include "ephy-debug.h"
-#include "ephy-gui.h"
-#include "ephy-stock-icons.h"
-
-#include "AutoJSContextStack.h"
-#include "AutoWindowModalState.h"
-#include "EphyUtils.h"
-
-#include "GeckoCookiePromptService.h"
-
-NS_IMPL_ISUPPORTS1 (GeckoCookiePromptService, nsICookiePromptService)
-
-GeckoCookiePromptService::GeckoCookiePromptService()
-{
- LOG ("GeckoCookiePromptService ctor [%p]", this);
-}
-
-GeckoCookiePromptService::~GeckoCookiePromptService()
-{
- LOG ("GeckoCookiePromptService dtor [%p]", this);
-}
-
-/* boolean cookieDialog (in nsIDOMWindow parent, in nsICookie cookie, in ACString hostname, in long cookiesFromHost, in boolean changingCookie, inout boolean checkValue); */
-NS_IMETHODIMP
-GeckoCookiePromptService::CookieDialog (nsIDOMWindow *aParent,
- nsICookie *aCookie,
- const nsACString &aHostname,
- PRInt32 aCookiesFromHost,
- PRBool aChangingCookie,
- PRBool *_checkValue,
- PRBool *_retval)
-{
- NS_ENSURE_ARG (aParent);
- NS_ENSURE_ARG (aCookie);
- NS_ENSURE_ARG_POINTER (_checkValue);
- NS_ENSURE_ARG_POINTER (_retval);
-
- // TODO short-circuit and accept session cookies as per preference
- // TODO until mozilla starts supporting it natively?
-
- GtkWidget *parent = EphyUtils::FindGtkParent (aParent);
- NS_ENSURE_TRUE(parent, NS_ERROR_INVALID_POINTER);
-
- nsresult rv;
- AutoJSContextStack stack;
- rv = stack.Init ();
- if (NS_FAILED (rv)) {
- return rv;
- }
-
- AutoWindowModalState modalState (aParent);
-
- nsCString host(aHostname);
-
- GtkWidget *dialog = gtk_message_dialog_new
- (GTK_WINDOW (parent),
- GTK_DIALOG_MODAL /* FIXME mozilla sucks! */,
- GTK_MESSAGE_QUESTION,
- GTK_BUTTONS_NONE,
- _("Accept cookie from %s?"),
- host.get());
- GtkWindow *window = GTK_WINDOW (dialog);
- GtkDialog *gdialog = GTK_DIALOG (dialog);
- GtkMessageDialog *message_dialog = GTK_MESSAGE_DIALOG (dialog);
-
- gtk_window_set_icon_name (window, EPHY_STOCK_EPHY);
- gtk_window_set_title (window, _("Accept Cookie?"));
-
- if (aChangingCookie) {
- gtk_message_dialog_format_secondary_text
- (message_dialog,
- _("The site wants to modify an existing cookie."));
- } else if (aCookiesFromHost == 0) {
- gtk_message_dialog_format_secondary_text
- (message_dialog,
- _("The site wants to set a cookie."));
- } else if (aCookiesFromHost == 1) {
- gtk_message_dialog_format_secondary_text
- (message_dialog,
- _("The site wants to set a second cookie."));
- } else {
- char *num_text = g_strdup_printf
- (ngettext ("You already have %d cookie from this site.",
- "You already have %d cookies from this site.",
- aCookiesFromHost),
- aCookiesFromHost);
-
- gtk_message_dialog_format_secondary_text
- (message_dialog,
- "The site %s wants to set another cookie. %s",
- host.get(), num_text);
- g_free (num_text);
- }
-
- GtkWidget *checkbutton;
- checkbutton = gtk_check_button_new_with_mnemonic
- (_("Apply this _decision to all cookies from this site"));
- gtk_widget_show (checkbutton);
- gtk_box_pack_start (GTK_BOX (ephy_gui_message_dialog_get_content_box (dialog)),
- checkbutton, FALSE, FALSE, 0);
-
- gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (checkbutton), *_checkValue);
-
- gtk_dialog_add_button (gdialog,
- _("_Reject"), GTK_RESPONSE_REJECT);
- gtk_dialog_add_button (gdialog,
- _("_Accept"), GTK_RESPONSE_ACCEPT);
- gtk_dialog_set_default_response (gdialog, GTK_RESPONSE_ACCEPT);
-
- int response = gtk_dialog_run (gdialog);
-
- if (response == GTK_RESPONSE_ACCEPT || response == GTK_RESPONSE_REJECT) {
- *_retval = (response == GTK_RESPONSE_ACCEPT);
- *_checkValue = gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (checkbutton));
- } else {
- /* if the dialog was closed, but no button was pressed,
- * consider it as 'Reject' but ignore the checkbutton
- */
- *_retval = PR_FALSE;
- *_checkValue = PR_FALSE;
- }
-
- gtk_widget_destroy (dialog);
-
- return NS_OK;
-}
diff --git a/embed/xulrunner/components/GeckoCookiePromptService.h b/embed/xulrunner/components/GeckoCookiePromptService.h
deleted file mode 100644
index 7092a2982..000000000
--- a/embed/xulrunner/components/GeckoCookiePromptService.h
+++ /dev/null
@@ -1,43 +0,0 @@
-/*
- * Copyright (C) 2003 Tommi Komulainen <tommi.komulainen@iki.fi>
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License version 2
- * as published by the Free Software Foundation.
- *
- * 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
- *
- * $Id$
- */
-
-#ifndef COOKIEPROMPTSERVICE_H
-#define COOKIEPROMPTSERVICE_H
-
-#include <nsICookiePromptService.h>
-
-/* 50766a18-0b34-41d9-8f6c-4612200e6556 */
-#define EPHY_COOKIEPROMPTSERVICE_CID \
- { 0x50766a18, 0x0b34, 0x41d9, { 0x8f, 0x6c, 0x46, 0x12, 0x20, 0x0e, 0x65, 0x56 } }
-
-#define EPHY_COOKIEPROMPTSERVICE_CLASSNAME "Epiphany Cookie Prompt Service"
-#define EPHY_COOKIEPROMPTSERVICE_CONTRACTID "@mozilla.org/embedcomp/cookieprompt-service;1"
-
-class GeckoCookiePromptService : public nsICookiePromptService {
- public:
- NS_DECL_ISUPPORTS
- NS_DECL_NSICOOKIEPROMPTSERVICE
-
- GeckoCookiePromptService();
-
- private:
- ~GeckoCookiePromptService();
-};
-
-#endif /* COOKIEPROMPTSERVICE_H */
diff --git a/embed/xulrunner/components/GeckoFormSigningDialog.cpp b/embed/xulrunner/components/GeckoFormSigningDialog.cpp
deleted file mode 100644
index 55b9d0d37..000000000
--- a/embed/xulrunner/components/GeckoFormSigningDialog.cpp
+++ /dev/null
@@ -1,158 +0,0 @@
-/*
- * Copyright © 2006 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include <glib.h>
-#include <glib/gi18n.h>
-#include <gtk/gtk.h>
-#include <glade/glade-xml.h>
-
-#include <nsStringGlue.h>
-
-#include <nsCOMPtr.h>
-#include <nsIDOMWindow.h>
-#include <nsIInterfaceRequestor.h>
-#include <nsIInterfaceRequestorUtils.h>
-
-#include "eel-gconf-extensions.h"
-#include "ephy-debug.h"
-#include "ephy-embed-shell.h"
-#include "ephy-file-helpers.h"
-#include "ephy-prefs.h"
-
-#include "AutoJSContextStack.h"
-#include "AutoWindowModalState.h"
-#include "EphyUtils.h"
-
-#include "GeckoFormSigningDialog.h"
-
-#define LITERAL(s) reinterpret_cast<const nsAString::char_type*>(NS_L(s))
-
-NS_IMPL_ISUPPORTS1 (GeckoFormSigningDialog,
- nsIFormSigningDialog)
-
-GeckoFormSigningDialog::GeckoFormSigningDialog()
-{
- LOG ("GeckoFormSigningDialog ctor [%p]", this);
-}
-
-GeckoFormSigningDialog::~GeckoFormSigningDialog()
-{
- LOG ("GeckoFormSigningDialog dtor [%p]", this);
-}
-
-/* nsIFormSigningDialog implementation */
-
-/* boolean confirmSignText (in nsIInterfaceRequestor ctxt,
- in AString host,
- in AString signText,
- [array, size_is (count)] in wstring certNickList,
- [array, size_is (count)] in wstring certDetailsList,
- in PRUint32 count,
- out PRInt32 selectedIndex,
- out AString password); */
-NS_IMETHODIMP
-GeckoFormSigningDialog::ConfirmSignText (nsIInterfaceRequestor *ctx,
- const nsAString & host,
- const nsAString & signText,
- const PRUnichar **certNickList,
- const PRUnichar **certDetailsList,
- PRUint32 count,
- PRInt32 *selectedIndex,
- nsAString &_password,
- PRBool *_cancelled)
-{
- /* FIXME: limit |signText| to a sensitlbe length (maybe 100k)? */
-
- nsresult rv;
- AutoJSContextStack stack;
- rv = stack.Init ();
- if (NS_FAILED (rv)) return rv;
-
- nsCOMPtr<nsIDOMWindow> parent (do_GetInterface (ctx));
- if (!parent) {
- parent = EphyJSUtils::GetDOMWindowFromCallContext ();
- g_print ("Fallback window %p\n", (void*)parent.get());
- }
- GtkWidget *gparent = EphyUtils::FindGtkParent (parent);
-
- AutoWindowModalState modalState (parent);
-
- GladeXML *gxml = glade_xml_new (ephy_file ("form-signing-dialog.glade"),
- "form_signing_dialog", NULL);
- g_return_val_if_fail (gxml, NS_ERROR_FAILURE);
-
- GtkWidget *dialog = glade_xml_get_widget (gxml, "form_signing_dialog");
- gtk_window_set_transient_for (GTK_WINDOW (dialog), GTK_WINDOW (gparent));
-
- GtkLabel *primary_label = GTK_LABEL (glade_xml_get_widget (gxml, "primary_label"));
- char *primary = g_strdup_printf (_("The web site “%s” requests that you sign the following text:"),
- NS_ConvertUTF16toUTF8 (host).get ());
- gtk_label_set_text (primary_label, primary);
- g_free (primary);
-
- GtkTextView *textview = GTK_TEXT_VIEW (glade_xml_get_widget (gxml, "textview"));
- NS_ConvertUTF16toUTF8 text (signText);
- gtk_text_buffer_set_text (gtk_text_view_get_buffer (textview),
- text.get (), text.Length ());
-
- GtkTable *table = GTK_TABLE (glade_xml_get_widget (gxml, "table"));
- GtkComboBox *combo = GTK_COMBO_BOX (gtk_combo_box_new_text ());
- for (PRUint32 i = 0; i < count; ++i) {
- gtk_combo_box_append_text (combo, NS_ConvertUTF16toUTF8 (certNickList[i]).get ());
- }
-
- gtk_combo_box_set_active (combo, 0);
- gtk_table_attach (table, GTK_WIDGET (combo), 1, 2, 0, 1,
- GtkAttachOptions (0), GtkAttachOptions (0), 0, 0);
- gtk_widget_show (GTK_WIDGET (combo));
-
- /* FIXME: Add "View Certificate" button */
-
- GtkEntry *password_entry = GTK_ENTRY (glade_xml_get_widget (gxml, "password_entry"));
-
- GtkWidget *button = gtk_dialog_add_button (GTK_DIALOG (dialog),
- GTK_STOCK_CANCEL,
- GTK_RESPONSE_CANCEL);
- gtk_dialog_add_button (GTK_DIALOG (dialog),
- _("_Sign text"),
- GTK_RESPONSE_ACCEPT);
- gtk_dialog_set_default_response (GTK_DIALOG (dialog), GTK_RESPONSE_REJECT);
- gtk_widget_grab_focus (button);
-
- /* FIXME: make Sign insensitive for some time (proportional to text length, with maximum?) */
-
- g_object_unref (gxml);
-
- int response = gtk_dialog_run (GTK_DIALOG (dialog));
-
- *_cancelled = response != GTK_RESPONSE_ACCEPT;
-
- if (response == GTK_RESPONSE_ACCEPT) {
- _password = NS_ConvertUTF8toUTF16 (gtk_entry_get_text (password_entry));
- *selectedIndex = gtk_combo_box_get_active (combo);
- }
-
- gtk_widget_destroy (dialog);
-
- return NS_OK;
-}
diff --git a/embed/xulrunner/components/GeckoFormSigningDialog.h b/embed/xulrunner/components/GeckoFormSigningDialog.h
deleted file mode 100644
index a4438e9d1..000000000
--- a/embed/xulrunner/components/GeckoFormSigningDialog.h
+++ /dev/null
@@ -1,42 +0,0 @@
-/*
- * Copyright © 2006 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#ifndef GECKO_FORMSIGNINGDIALOGS_H
-#define GECKO_FORMSIGNINGDIALOGS_H
-
-#include <nsIFormSigningDialog.h>
-
-/* 4e42a43e-fbc5-40cc-bcbb-8cbc4e2101eb */
-#define GECKO_FORMSIGNINGDIALOGS_CID \
-{ 0x4e42a43e, 0xfbc5, 0x40cc, { 0xbc, 0xbb, 0x8c, 0xbc, 0x4e, 0x21, 0x01, 0xeb } }
-
-#define GECKO_FORMSIGNINGDIALOGS_CLASSNAME "Gecko Form Signing Dialogs"
-
-class GeckoFormSigningDialog : public nsIFormSigningDialog
-{
- public:
- NS_DECL_ISUPPORTS
- NS_DECL_NSIFORMSIGNINGDIALOG
-
- GeckoFormSigningDialog();
- ~GeckoFormSigningDialog();
-};
-
-#endif /* GECKO_FORMSIGNINGDIALOGS_H */
diff --git a/embed/xulrunner/components/GeckoPrintService.cpp b/embed/xulrunner/components/GeckoPrintService.cpp
deleted file mode 100644
index ceab26809..000000000
--- a/embed/xulrunner/components/GeckoPrintService.cpp
+++ /dev/null
@@ -1,714 +0,0 @@
-/*
- * Copyright © 2006, 2007 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include <glib.h>
-#include <glib/gi18n.h>
-#include <gtk/gtkcheckbutton.h>
-#include <gtk/gtkdialog.h>
-#include <gtk/gtklabel.h>
-#include <gtk/gtkmessagedialog.h>
-#include <gtk/gtkprintunixdialog.h>
-#include <gtk/gtkstock.h>
-#include <gtk/gtkwindow.h>
-#include <glade/glade-xml.h>
-
-#include <nsStringGlue.h>
-
-#include <nsCOMPtr.h>
-#include <nsIDOMWindow.h>
-#include <nsIDOMWindowInternal.h>
-
-#include "eel-gconf-extensions.h"
-#include "ephy-debug.h"
-#include "ephy-embed-shell.h"
-#include "ephy-file-helpers.h"
-#include "ephy-gui.h"
-#include "ephy-prefs.h"
-#include "ephy-stock-icons.h"
-
-#include "AutoJSContextStack.h"
-#include "AutoWindowModalState.h"
-#include "EphyUtils.h"
-#include "GeckoPrintSession.h"
-
-#include "GeckoPrintService.h"
-
-/* Some printing keys */
-
-#define CONF_PRINT_BG_COLORS "/apps/epiphany/dialogs/print_background_colors"
-#define CONF_PRINT_BG_IMAGES "/apps/epiphany/dialogs/print_background_images"
-#define CONF_PRINT_COLOR "/apps/epiphany/dialogs/print_color"
-#define CONF_PRINT_DATE "/apps/epiphany/dialogs/print_date"
-#define CONF_PRINT_PAGE_NUMBERS "/apps/epiphany/dialogs/print_page_numbers"
-#define CONF_PRINT_PAGE_TITLE "/apps/epiphany/dialogs/print_page_title"
-#define CONF_PRINT_PAGE_URL "/apps/epiphany/dialogs/print_page_url"
-
-#define LITERAL(s) reinterpret_cast<const nsAString::char_type*>(NS_L(s))
-
-/* From nsIDeviceContext.h */
-#define NS_ERROR_GFX_PRINTER_BASE (1) /* adjustable :-) */
-#define NS_ERROR_GFX_PRINTER_ACCESS_DENIED \
- NS_ERROR_GENERATE_FAILURE(NS_ERROR_MODULE_GFX,NS_ERROR_GFX_PRINTER_BASE+5)
-#define NS_ERROR_GFX_PRINTER_NAME_NOT_FOUND \
- NS_ERROR_GENERATE_FAILURE(NS_ERROR_MODULE_GFX,NS_ERROR_GFX_PRINTER_BASE+4)
-
-NS_IMPL_ISUPPORTS1 (GeckoPrintService,
- nsIPrintingPromptService)
-
-GeckoPrintService::GeckoPrintService()
-{
- LOG ("GeckoPrintService ctor [%p]", this);
-}
-
-GeckoPrintService::~GeckoPrintService()
-{
- LOG ("GeckoPrintService dtor [%p]", this);
-}
-
-/* nsIPrintingPromptService implementation */
-
-/* void showPrintDialog (in nsIDOMWindow parent,
- in nsIWebBrowserPrint webBrowserPrint,
- in nsIPrintSettings printSettings); */
-NS_IMETHODIMP
-GeckoPrintService::ShowPrintDialog (nsIDOMWindow *aParent,
- nsIWebBrowserPrint *aWebBrowserPrint,
- nsIPrintSettings *aSettings)
-{
- /* Locked down? */
- if (eel_gconf_get_boolean (CONF_LOCKDOWN_DISABLE_PRINTING)) {
- return NS_ERROR_GFX_PRINTER_ACCESS_DENIED;
- }
-
- GeckoPrintSession *session = GeckoPrintSession::FromSettings (aSettings);
- NS_ENSURE_TRUE (session, NS_ERROR_INVALID_POINTER);
-
- /* Print settings changes disallowed, just translate the settings */
- if (eel_gconf_get_boolean (CONF_LOCKDOWN_DISABLE_PRINT_SETUP)) {
- return PrintUnattended (aParent, aSettings);
- }
-
- /* Not locked down, show the dialogue */
-
- nsresult rv;
-#if 0
- PRBool haveSelection = PR_FALSE;
- rv = aSettings->GetPrintOptions(nsIPrintSettings::kEnableSelectionRB, &haveSelection);
- NS_ENSURE_SUCCESS (rv, rv);
-#endif
-
- PRInt16 frameUI = nsIPrintSettings::kFrameEnableAll;
- rv = aSettings->GetHowToEnableFrameUI (&frameUI);
- NS_ENSURE_SUCCESS (rv, rv);
-
- GtkWidget *parent = EphyUtils::FindGtkParent (aParent);
- NS_ENSURE_TRUE(parent, NS_ERROR_INVALID_POINTER);
-
- AutoJSContextStack stack;
- rv = stack.Init ();
- if (NS_FAILED (rv)) {
- return rv;
- }
-
- AutoWindowModalState modalState (aParent);
-
- EphyEmbedShell *shell = ephy_embed_shell_get_default ();
-
- GladeXML *xml = glade_xml_new (ephy_file ("print.glade"),
- "print_dialog_custom_tab", NULL);
- if (!xml) {
- return NS_ERROR_FAILURE;
- }
-
- /* Build the custom tab */
- GtkWidget *custom_tab = glade_xml_get_widget (xml, "custom_tab_container");
- ephy_gui_connect_checkbutton_to_gconf (glade_xml_get_widget (xml, "print_bg_colors_checkbutton"), CONF_PRINT_BG_COLORS);
- ephy_gui_connect_checkbutton_to_gconf (glade_xml_get_widget (xml, "print_bg_images_checkbutton"), CONF_PRINT_BG_IMAGES);
- ephy_gui_connect_checkbutton_to_gconf (glade_xml_get_widget (xml, "print_date_checkbutton"), CONF_PRINT_DATE);
- ephy_gui_connect_checkbutton_to_gconf (glade_xml_get_widget (xml, "print_page_numbers_checkbutton"), CONF_PRINT_PAGE_NUMBERS);
- ephy_gui_connect_checkbutton_to_gconf (glade_xml_get_widget (xml, "print_page_title_checkbutton"), CONF_PRINT_PAGE_TITLE);
- ephy_gui_connect_checkbutton_to_gconf (glade_xml_get_widget (xml, "print_page_url_checkbutton"), CONF_PRINT_PAGE_URL);
-
- GtkWidget *frame_box = glade_xml_get_widget (xml, "frame_box");
- GtkWidget *print_frames_normal = glade_xml_get_widget (xml, "print_frames_normal");
- GtkWidget *print_frames_selected = glade_xml_get_widget (xml, "print_frames_selected");
- GtkWidget *print_frames_separately = glade_xml_get_widget (xml, "print_frames_separately");
-
- /* FIXME: store/load from pref */
- gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (print_frames_normal), TRUE);
-
- if (frameUI == nsIPrintSettings::kFrameEnableAll) {
- /* Allow all frame options */
- gtk_widget_set_sensitive (frame_box, TRUE);
- } else if (frameUI == nsIPrintSettings::kFrameEnableAsIsAndEach) {
- /* Allow all except "selected frame" */
- gtk_widget_set_sensitive (frame_box, TRUE);
- gtk_widget_set_sensitive (print_frames_selected, FALSE);
- /* Preselect this one, since the default above only prints _one page_ ! */
- gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (print_frames_separately), TRUE);
- }
-
- /* FIXME: this sucks! find some way to do all of this async! */
- GtkWidget *dialog = gtk_print_unix_dialog_new (NULL /* FIXME title */,
- GTK_WINDOW (parent));
- GtkPrintUnixDialog *print_dialog = GTK_PRINT_UNIX_DIALOG (dialog);
-
- GtkPrintCapabilities capabilities =
- GtkPrintCapabilities (GTK_PRINT_CAPABILITY_PAGE_SET |
- GTK_PRINT_CAPABILITY_COPIES |
- GTK_PRINT_CAPABILITY_COLLATE |
- GTK_PRINT_CAPABILITY_REVERSE |
- GTK_PRINT_CAPABILITY_SCALE |
- GTK_PRINT_CAPABILITY_GENERATE_PS |
- GTK_PRINT_CAPABILITY_GENERATE_PDF);
- gtk_print_unix_dialog_set_manual_capabilities (print_dialog, capabilities);
-
- gtk_print_unix_dialog_set_page_setup (print_dialog,
- ephy_embed_shell_get_page_setup (shell));
- gtk_print_unix_dialog_set_settings (print_dialog,
- ephy_embed_shell_get_print_settings (shell));
-
- /* Remove custom tab from its dummy window and put it in the print dialogue */
- g_object_ref_sink (custom_tab);
- gtk_container_remove (GTK_CONTAINER (custom_tab->parent), custom_tab);
- gtk_print_unix_dialog_add_custom_tab (print_dialog, custom_tab,
- gtk_label_new (_("Options"))); /* FIXME better name! */
- g_object_unref (custom_tab);
- g_object_unref (xml);
-
- gtk_window_set_icon_name (GTK_WINDOW (dialog), EPHY_STOCK_EPHY);
-
- int response = gtk_dialog_run (GTK_DIALOG (dialog));
- gtk_widget_hide (dialog);
-
- GtkPrinter *printer = gtk_print_unix_dialog_get_selected_printer (print_dialog);
-
- if (response != GTK_RESPONSE_OK || !printer) {
- gtk_widget_destroy (dialog);
-
- return NS_ERROR_ABORT;
- }
-
- PRInt16 printFrames = nsIPrintSettings::kNoFrames;
- if (frameUI != nsIPrintSettings::kFrameEnableNone) {
- if (gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (print_frames_normal))) {
- printFrames = nsIPrintSettings::kFramesAsIs;
- } else if (gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (print_frames_selected))) {
- printFrames = nsIPrintSettings::kSelectedFrame;
- } if (gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (print_frames_separately))) {
- printFrames = nsIPrintSettings::kEachFrameSep;
- }
- }
-
- GtkPageSetup *pageSetup = gtk_print_unix_dialog_get_page_setup (print_dialog); /* no reference owned */
- ephy_embed_shell_set_page_setup (shell, pageSetup);
-
- GtkPrintSettings *settings = gtk_print_unix_dialog_get_settings (print_dialog);
- ephy_embed_shell_set_print_settings (shell, settings);
-
- /* We copy the setup and settings so we can modify them to unset
- * options handled by gecko.
- */
- GtkPageSetup *pageSetupCopy = gtk_page_setup_copy (pageSetup);
- pageSetup = pageSetupCopy;
-
- GtkPrintSettings *settingsCopy = gtk_print_settings_copy (settings);
- g_object_unref (settings);
- settings = settingsCopy;
-
- rv = session->SetSettings (aSettings, settings, pageSetup, printer);
-
- /* Now translate the settings to nsIPrintSettings */
- if (NS_SUCCEEDED (rv)) {
- nsCString sourceFile;
- session->GetSourceFile (sourceFile);
- if (!sourceFile.IsEmpty ()) {
- rv = TranslateSettings (settings, pageSetup, printer, sourceFile, printFrames, PR_TRUE, aSettings);
- } else {
- rv = NS_ERROR_FAILURE;
- }
- }
-
- gtk_widget_destroy (dialog);
-
- g_object_unref (settings);
- g_object_unref (pageSetup);
-
- return rv;
-}
-
-/* void showProgress (in nsIDOMWindow parent,
- in nsIWebBrowserPrint webBrowserPrint,
- in nsIPrintSettings printSettings,
- in nsIObserver openDialogObserver,
- in boolean isForPrinting,
- out nsIWebProgressListener webProgressListener,
- out nsIPrintProgressParams printProgressParams,
- out boolean notifyOnOpen); */
-NS_IMETHODIMP
-GeckoPrintService::ShowProgress (nsIDOMWindow *aParent,
- nsIWebBrowserPrint *aWebBrowserPrint,
- nsIPrintSettings *aPrintSettings,
- nsIObserver *aOpenDialogObserver,
- PRBool aIsForPrinting,
- nsIWebProgressListener **_webProgressListener,
- nsIPrintProgressParams **_printProgressParams,
- PRBool *_notifyOnOpen)
-{
- /* Print preview */
- if (!aIsForPrinting) {
- return NS_OK;
- }
-
- nsresult rv;
- nsCOMPtr<nsIDOMWindowInternal> domWin (do_QueryInterface (aParent, &rv));
- NS_ENSURE_SUCCESS (rv, rv);
-
- nsCOMPtr<nsIPrintSession> session;
- rv = aPrintSettings->GetPrintSession (getter_AddRefs (session));
- NS_ENSURE_TRUE (NS_SUCCEEDED (rv) && session, nsnull);
-
- nsCOMPtr<nsIPrintProgress> progress (do_QueryInterface (session, &rv));
- NS_ENSURE_SUCCESS (rv, rv);
-
- /* Our print session implements those interfaces */
- rv = CallQueryInterface (session, _webProgressListener);
- rv |= CallQueryInterface (session, _printProgressParams);
- NS_ENSURE_SUCCESS (rv, rv);
-
- /* Setting this to PR_FALSE will make gecko immediately start printing
- * when we return from this function.
- * If we set this to PR_TRUE, we need to call aOpenDialogObserver::Observe
- * (topic, subject and data don't matter) when we're ready for printing.
- */
- *_notifyOnOpen = PR_FALSE;
-
- return progress->OpenProgressDialog (domWin, nsnull, nsnull, aOpenDialogObserver, _notifyOnOpen);
-}
-
-/* void showPageSetup (in nsIDOMWindow parent,
- in nsIPrintSettings printSettings,
- in nsIObserver aObs); */
-NS_IMETHODIMP GeckoPrintService::ShowPageSetup (nsIDOMWindow *aParent,
- nsIPrintSettings *aPrintSettings,
- nsIObserver *aObserver)
-{
- /* This function is never called from gecko code */
-#if 0
- /* Locked down? */
- if (eel_gconf_get_boolean (CONF_LOCKDOWN_DISABLE_PRINTING) ||
- eel_gconf_get_boolean (CONF_LOCKDOWN_DISABLE_PRINT_SETUP)) {
- return NS_ERROR_ABORT;
- }
-
- GtkWidget *parent = EphyUtils::FindGtkParent (aParent);
- NS_ENSURE_TRUE(parent, NS_ERROR_INVALID_POINTER);
-
- AutoJSContextStack stack;
- nsresult rv = stack.Init ();
- if (NS_FAILED (rv)) {
- return rv;
- }
-
- AutoWindowModalState modalState (aParent);
-
- EphyEmbedShell *shell = ephy_embed_shell_get_default ();
- GtkPageSetup *new_setup =
- gtk_print_run_page_setup_dialog (GTK_WINDOW (parent),
- ephy_embed_shell_get_page_setup (shell),
- ephy_embed_shell_get_print_settings (shell));
- if (new_setup) {
- ephy_embed_shell_set_page_setup (shell, new_setup);
- g_object_unref (new_setup);
- }
-
- /* FIXME do we need to notify aObserver somehow? */
- return NS_OK;
-#endif
- return NS_ERROR_NOT_IMPLEMENTED;
-}
-
-/* void showPrinterProperties (in nsIDOMWindow parent,
- in wstring printerName,
- in nsIPrintSettings printSettings); */
-NS_IMETHODIMP
-GeckoPrintService::ShowPrinterProperties (nsIDOMWindow *aParent,
- const PRUnichar *aPrinterName,
- nsIPrintSettings *aPrintSettings)
-{
- return NS_ERROR_NOT_IMPLEMENTED;
-}
-
-/* Private methods */
-
-#if 0
-typedef struct
-{
- GMainLoop *mainLoop;
- GtkPrinter *mPrinter;
- guint timeout;
- int response;
- guint cancelled : 1;
-} FindPrinterData;
-
-static void
-FreeFindPrinterData (FindPrinterData *data)
-{
- if (data->printer) {
- g_object_unref (data->printer);
- }
-}
-
-static void
-DialogResponseCallback (GtkWidget *aDialog,
- int aResponse,
- FindPrinterData *data)
-{
- data->response = aResponse;
- g_main_loop_quit (data->mainloop);
-}
-
-static void
-TimeoutCallback (FindPrinterData *data)
-{
- data->cancelled = TRUE;
- g_main_loop_quit (data->mainLoop);
- data->mainLoop = NULL;
- return FALSE;
-}
-
-static gboolean
-PrinterEnumerateCallback (GtkPrinter *aPrinter,
- FindPrinterData *data)
-{
- if (data->cancelled)
- return TRUE;
-
- if ((data->printerName &&
- strcmp (data->printerName, gtk_printer_get_name (aPrinter)) == 0) ||
- (!data->printerName &&
- gtk_printer_is_default (aPrinter))) {
- data->printer = g_object_ref (aPrinter);
- return TRUE;
- }
-
- return FALSE;
-}
-#endif
-
-nsresult
-GeckoPrintService::PrintUnattended (nsIDOMWindow *aParent,
- nsIPrintSettings *aPrintSettings)
-{
- return NS_ERROR_NOT_IMPLEMENTED;
-#if 0
- GtkWidget *parent = EphyUtils::FindGtkParent (aParent);
- NS_ENSURE_TRUE(parent, NS_ERROR_INVALID_POINTER);
-
- PRBool isCalledFromScript = EphyJSUtils::IsCalledFromScript ();
-
- nsresult rv;
- AutoJSContextStack stack;
- rv = stack.Init ();
- if (NS_FAILED (rv)) {
- return rv;
- }
-
- AutoWindowModalState modalState (aParent);
-
- EphyEmbedShell *shell = ephy_embed_shell_get_default ();
- GtkPrintSettings *settings = ephy_embed_shell_get_print_settings (shell);
- NS_ENSURE_TRUE (settings, NS_ERROR_FAILURE);
-
- const char *printer = gtk_print_settings_get (settings, GTK_PRINT_SETTINGS_PRINTER);
-#if 0
- if (!printer || !printer[0]) {
- return NS_ERROR_GFX_PRINTER_NAME_NOT_FOUND;
- }
-#endif
- /* We need to find the printer, so we need to run a mainloop.
- * If called from a script, give the user a way to cancel the print;
- * otherwise we'll just show a generic progress message.
- */
- GtkWidget *dialog;
- if (isCalledFromScript) {
- dialog = gtk_message_dialog_new (GTK_WINDOW (parent),
- GtkDialogFlags (0),
- GTK_MESSAGE_QUESTION,
- GTK_BUTTONS_CANCEL,
- "%s", _("Print this page?"));
- gtk_dialog_add_button (GTK_DIALOG (dialog), GTK_STOCK_PRINT,
- GTK_RESPONSE_ACCEPT);
- } else {
- dialog = gtk_message_dialog_new (GTK_WINDOW (parent),
- GtkDialogFlags (0),
- GTK_MESSAGE_QUESTION,
- GTK_BUTTONS_CANCEL,
- "%s", _("Preparing to print"));
- }
- gtk_dialog_set_default_response (GTK_DIALOG (dialog), GTK_RESPONSE_CANCEL);
- gtk_window_set_icon_name (GTK_WINDOW (dialog), EPHY_STOCK_EPHY);
- gtk_window_set_modal (GTK_WINDOW (dialog), TRUE);
-
- FindPrinterData *data = g_new0 (PrinterData, 1);
- data->dialog = dialog;
-
- g_signal_connect (dialog, "response",
- G_CALLBACK (DialogResponseCallback), data);
-
- /* Don't run forever */
- data->timeoutId = g_timeout_add (PRINTER_ENUMERATE_TIMEOUT,
- (GSourceFunc) EnumerateTimoutCallback,
- data);
- /* Enumerate printers until we find our printer */
- gtk_enumerate_printers ((GtkPrinterFunc) PrinterEnumerateCallback,
- data,
- (GDestroyNotify) EnumerateDestroyCallback, FALSE);
-
- /* Now run the mainloop */
- int response = gtk_dialog_run (GTK_DIALOG (dialog));
- Printer
- gtk_widget_destroy (dialog);
-
- if (response != GTK_RESPONSE_ACCEPT) {
- return NS_ERROR_ABORT;
- }
-
- nsCString sourceFile;
- session->GetSourceFile (sourceFile);
- if (!sourceFile.IsEmpty ()) {
- rv = TranslateSettings (settings,
- ephy_embed_shell_get_page_setup (shell),
- sourceFile, PR_TRUE, aSettings);
- } else {
- rv = NS_ERROR_FAILURE;
- }
-
- return rv;
- }
-#endif /* if 0 */
-}
-
-/* Static methods */
-
-/* static */ nsresult
-GeckoPrintService::TranslateSettings (GtkPrintSettings *aGtkSettings,
- GtkPageSetup *aPageSetup,
- GtkPrinter *aPrinter,
- const nsACString &aSourceFile,
- PRInt16 aPrintFrames,
- PRBool aIsForPrinting,
- nsIPrintSettings *aSettings)
-{
- NS_ENSURE_ARG (aPrinter);
- NS_ENSURE_ARG (aGtkSettings);
- NS_ENSURE_ARG (aPageSetup);
-
-#if 0
- /* Locked down? */
- if (gtk_print_settings_get_print_to_file (aGtkSettings) &&
- eel_gconf_get_boolean (CONF_LOCKDOWN_DISABLE_SAVE_TO_DISK)) {
- return NS_ERROR_GFX_PRINTER_ACCESS_DENIED;
- }
-#endif
-
- GtkPrintCapabilities capabilities = gtk_printer_get_capabilities (aPrinter);
-
- /* Initialisation */
- aSettings->SetIsInitializedFromPrinter (PR_FALSE); /* FIXME: PR_TRUE? */
- aSettings->SetIsInitializedFromPrefs (PR_FALSE); /* FIXME: PR_TRUE? */
- aSettings->SetPrintSilent (PR_FALSE);
- aSettings->SetShowPrintProgress (PR_TRUE);
-
- /* We always print PS to a file and then hand that off to gtk-print */
- aSettings->SetPrinterName (LITERAL ("PostScript/default"));
-
- if (aIsForPrinting) {
- aSettings->SetPrintToFile (PR_TRUE);
-
- nsString sourceFile;
- NS_CStringToUTF16 (aSourceFile,
- NS_CSTRING_ENCODING_NATIVE_FILESYSTEM,
- sourceFile);
-
- aSettings->SetToFileName (sourceFile.get ());
- } else {
- /* Otherwise mozilla will create the file nevertheless and
- * fail since we haven't set a name!
- */
- aSettings->SetPrintToFile (PR_FALSE);
- }
-
- /* This is the time between printing each page, in ms.
- * It 'gives the user more time to press cancel' !
- * We don't want any of this nonsense, so set this to a low value,
- * just enough to update the print dialogue.
- */
- aSettings->SetPrintPageDelay (50);
-
- if (aIsForPrinting) {
- NS_ENSURE_TRUE (aPrinter, NS_ERROR_FAILURE);
-
- const char *format = gtk_print_settings_get (aGtkSettings, GTK_PRINT_SETTINGS_OUTPUT_FILE_FORMAT);
- if (!format)
- format = "ps";
-
- if (strcmp (format, "pdf") == 0 &&
- gtk_printer_accepts_pdf (aPrinter)) {
- aSettings->SetOutputFormat (nsIPrintSettings::kOutputFormatPDF);
- } else if (strcmp (format, "ps") == 0 &&
- gtk_printer_accepts_ps (aPrinter)) {
- aSettings->SetOutputFormat (nsIPrintSettings::kOutputFormatPS);
- } else {
- g_warning ("Output format '%s' specified, but printer '%s' does not support it!",
- format, gtk_printer_get_name (aPrinter));
- return NS_ERROR_FAILURE;
- }
-
- int n_copies = gtk_print_settings_get_n_copies (aGtkSettings);
- if (n_copies <= 0)
- return NS_ERROR_FAILURE;
- if (capabilities & GTK_PRINT_CAPABILITY_COPIES) {
- aSettings->SetNumCopies (1);
- } else {
- /* We have to copy them ourself */
- aSettings->SetNumCopies (n_copies);
- gtk_print_settings_set_n_copies (aGtkSettings, 1);
- }
-
- gboolean reverse = gtk_print_settings_get_reverse (aGtkSettings);
- if (capabilities & GTK_PRINT_CAPABILITY_REVERSE) {
- aSettings->SetPrintReversed (PR_FALSE);
- } else {
- aSettings->SetPrintReversed (reverse);
- gtk_print_settings_set_reverse (aGtkSettings, FALSE);
- }
-
- GtkPageSet pageSet = gtk_print_settings_get_page_set (aGtkSettings);
- aSettings->SetPrintOptions (nsIPrintSettings::kPrintEvenPages,
- pageSet != GTK_PAGE_SET_ODD);
- aSettings->SetPrintOptions (nsIPrintSettings::kPrintEvenPages,
- pageSet != GTK_PAGE_SET_EVEN);
-
- GtkPrintPages printPages = gtk_print_settings_get_print_pages (aGtkSettings);
- switch (printPages) {
- case GTK_PRINT_PAGES_RANGES: {
- int numRanges = 0;
- GtkPageRange *pageRanges = gtk_print_settings_get_page_ranges (aGtkSettings, &numRanges);
- if (numRanges > 0) {
- /* FIXME: We can only support one range, ignore more ranges or raise error? */
- aSettings->SetPrintRange (nsIPrintSettings::kRangeSpecifiedPageRange);
- /* Gecko page numbers start at 1, while gtk page numbers start at 0 */
- aSettings->SetStartPageRange (pageRanges[0].start + 1);
- aSettings->SetEndPageRange (pageRanges[0].end + 1);
-
- g_free (pageRanges);
- break;
- }
- /* Fall-through to PAGES_ALL */
- }
- case GTK_PRINT_PAGES_CURRENT:
- /* not supported, fall through */
- case GTK_PRINT_PAGES_ALL:
- aSettings->SetPrintRange (nsIPrintSettings::kRangeAllPages);
- break;
- /* FIXME: we need some custom ranges here, "Selection" and "Focused Frame" */
- }
- } else {
- aSettings->SetPrintOptions (nsIPrintSettings::kPrintEvenPages, PR_TRUE);
- aSettings->SetPrintOptions (nsIPrintSettings::kPrintEvenPages, PR_TRUE);
- aSettings->SetPrintReversed (PR_FALSE);
- aSettings->SetPrintRange (nsIPrintSettings::kRangeAllPages);
- }
-
- /* And clear those in the settings, so the printer doesn't try to apply them too */
- gtk_print_settings_set_print_pages (aGtkSettings, GTK_PRINT_PAGES_ALL);
- gtk_print_settings_set_page_ranges (aGtkSettings, NULL, 0);
- gtk_print_settings_set_page_set (aGtkSettings, GTK_PAGE_SET_ALL);
-
- /* We must use the page setup here instead of the print settings, see gtk bug #485685 */
- switch (gtk_page_setup_get_orientation (aPageSetup)) {
- case GTK_PAGE_ORIENTATION_PORTRAIT:
- case GTK_PAGE_ORIENTATION_REVERSE_PORTRAIT: /* not supported */
- aSettings->SetOrientation (nsIPrintSettings::kPortraitOrientation);
- break;
- case GTK_PAGE_ORIENTATION_LANDSCAPE:
- case GTK_PAGE_ORIENTATION_REVERSE_LANDSCAPE: /* not supported */
- aSettings->SetOrientation (nsIPrintSettings::kLandscapeOrientation);
- break;
- }
-
- aSettings->SetPrintInColor (gtk_print_settings_get_use_color (aGtkSettings));
-
- aSettings->SetPaperSizeUnit(nsIPrintSettings::kPaperSizeMillimeters);
-
- GtkPaperSize *paperSize = gtk_page_setup_get_paper_size (aPageSetup);
- if (!paperSize) {
- return NS_ERROR_FAILURE;
- }
-
- aSettings->SetPaperSizeType (nsIPrintSettings::kPaperSizeDefined);
- aSettings->SetPaperWidth (gtk_paper_size_get_width (paperSize, GTK_UNIT_MM));
- aSettings->SetPaperHeight (gtk_paper_size_get_height (paperSize, GTK_UNIT_MM));
- aSettings->SetPaperName (NS_ConvertUTF8toUTF16 (gtk_paper_size_get_name (paperSize)).get ());
-
- /* Sucky mozilla wants margins in inch! */
- aSettings->SetMarginTop (gtk_page_setup_get_top_margin (aPageSetup, GTK_UNIT_INCH));
- aSettings->SetMarginBottom (gtk_page_setup_get_bottom_margin (aPageSetup, GTK_UNIT_INCH));
- aSettings->SetMarginLeft (gtk_page_setup_get_left_margin (aPageSetup, GTK_UNIT_INCH));
- aSettings->SetMarginRight (gtk_page_setup_get_right_margin (aPageSetup, GTK_UNIT_INCH));
-
- aSettings->SetHeaderStrLeft (eel_gconf_get_boolean (CONF_PRINT_PAGE_TITLE) ? LITERAL ("&T") : LITERAL (""));
- aSettings->SetHeaderStrCenter (LITERAL (""));
- aSettings->SetHeaderStrRight (eel_gconf_get_boolean (CONF_PRINT_PAGE_URL) ? LITERAL ("&U") : LITERAL (""));
- aSettings->SetFooterStrLeft (eel_gconf_get_boolean (CONF_PRINT_PAGE_NUMBERS) ? LITERAL ("&PT") : LITERAL (""));
- aSettings->SetFooterStrCenter (LITERAL (""));
- aSettings->SetFooterStrRight (eel_gconf_get_boolean (CONF_PRINT_DATE) ? LITERAL ("&D") : LITERAL (""));
-
- aSettings->SetPrintFrameType (aPrintFrames);
- aSettings->SetPrintFrameTypeUsage (nsIPrintSettings::kUseSettingWhenPossible);
-
- /* FIXME: only if GTK_PRINT_CAPABILITY_SCALE is not set? */
- aSettings->SetScaling (gtk_print_settings_get_scale (aGtkSettings) / 100.0);
- gtk_print_settings_set_scale (aGtkSettings, 1.0);
-
- aSettings->SetShrinkToFit (PR_FALSE); /* FIXME setting */
-
- aSettings->SetPrintBGColors (eel_gconf_get_boolean (CONF_PRINT_BG_COLORS) != FALSE);
- aSettings->SetPrintBGImages (eel_gconf_get_boolean (CONF_PRINT_BG_IMAGES) != FALSE);
-
- /* aSettings->SetPlexName (LITERAL ("default")); */
- /* aSettings->SetColorspace (LITERAL ("default")); */
- /* aSettings->SetResolutionName (LITERAL ("default")); */
- /* aSettings->SetDownloadFonts (PR_TRUE); */
-
- /* Unset those setting that we can handle, so they don't get applied
- * again for the print job.
- */
- /* gtk_print_settings_set_collate (aGtkSettings, FALSE); not yet */
- /* FIXME: Unset the orientation for the print job? */
- /* gtk_print_settings_set_orientation (aGtkSettings, GTK_PAGE_ORIENTATION_PORTRAIT); */
- /* FIXME: unset output format -> "ps" ? */
-
- return NS_OK;
-}
diff --git a/embed/xulrunner/components/GeckoPrintService.h b/embed/xulrunner/components/GeckoPrintService.h
deleted file mode 100644
index c2e21cf3e..000000000
--- a/embed/xulrunner/components/GeckoPrintService.h
+++ /dev/null
@@ -1,54 +0,0 @@
-/*
- * Copyright © 2006 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#ifndef GECKO_PRINT_SERVICE_H
-#define GECKO_PRINT_SERVICE_H
-
-#include <gtk/gtkpagesetup.h>
-#include <gtk/gtkprintsettings.h>
-#include <gtk/gtkprinter.h>
-
-#include <nsIPrintingPromptService.h>
-
-class nsIPrintSettings;
-
-/* 6a71ff30-7f4d-4d91-b71a-d5c9764b34be */
-#define GECKO_PRINT_SERVICE_IID \
-{ 0x6a71ff30, 0x7f4d, 0x4d91, \
- { 0xb7, 0x1a, 0xd5, 0xc9, 0x76, 0x4b, 0x34, 0xbe } }
-
-#define GECKO_PRINT_SERVICE_CLASSNAME "Gecko Print Service"
-
-class GeckoPrintService : public nsIPrintingPromptService
-{
-public:
- NS_DECL_ISUPPORTS
- NS_DECL_NSIPRINTINGPROMPTSERVICE
-
- GeckoPrintService();
- virtual ~GeckoPrintService();
-
- static nsresult TranslateSettings (GtkPrintSettings*, GtkPageSetup *, GtkPrinter *, const nsACString&, PRInt16, PRBool, nsIPrintSettings*);
-
-private:
- nsresult PrintUnattended (nsIDOMWindow *, nsIPrintSettings *);
-};
-
-#endif /* GECKO_PRINT_SERVICE_H */
diff --git a/embed/xulrunner/components/GeckoPrintSession.cpp b/embed/xulrunner/components/GeckoPrintSession.cpp
deleted file mode 100644
index e0c3b89e9..000000000
--- a/embed/xulrunner/components/GeckoPrintSession.cpp
+++ /dev/null
@@ -1,629 +0,0 @@
-/*
- * Copyright © 2006 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include <unistd.h>
-
-#include <glib/gi18n.h>
-#include <gtk/gtk.h>
-
-#include <nsStringGlue.h>
-
-#include <nsIDOMWindow.h>
-#include <nsIDOMWindowInternal.h>
-#include <nsIPrintSettings.h>
-
-#include "ephy-debug.h"
-#include "ephy-embed-shell.h"
-#include "ephy-file-helpers.h"
-
-#include "EphyUtils.h"
-
-#include "GeckoPrintSession.h"
-
-#define MAX_STRING_LENGTH 512
-
-GeckoPrintSession::GeckoPrintSession ()
-: mSettings(NULL)
-, mPageSetup(NULL)
-, mPrinter(NULL)
-, mJob(NULL)
-, mProgressDialog(NULL)
-, mTitleLabel(NULL)
-, mProgressBar(NULL)
-, mStartPrintIdleID(0)
-, mSourceFileIsTemp(PR_FALSE)
-, mDone(PR_FALSE)
-, mCancelled(PR_FALSE)
-{
- LOG ("GeckoPrintSession ctor [%p]", (void*) this);
-
- /* FIXME: connect to "prepare-close" ? */
- g_object_ref (ephy_embed_shell_get_default ());
-}
-
-GeckoPrintSession::~GeckoPrintSession ()
-{
- LOG ("GeckoPrintSession dtor [%p]", (void*) this);
-
- NS_ASSERTION (mStartPrintIdleID == 0, "Impossible");
-
- if (!mDone && !mCancelled) {
- Cancel ();
- }
- DestroyJob ();
-
- if (mSettings) {
- g_object_unref (mSettings);
- }
- if (mPageSetup) {
- g_object_unref (mPageSetup);
- }
- if (mPrinter) {
- g_object_unref (mPrinter);
- }
- if (mProgressDialog) {
- gtk_widget_destroy (mProgressDialog);
- }
- if (mSourceFileIsTemp) {
- unlink (mSourceFile.get ());
- }
-
- g_object_unref (ephy_embed_shell_get_default ());
-}
-
-void
-GeckoPrintSession::GetSourceFile (nsACString &aSource)
-{
- aSource.Assign (mSourceFile);
-}
-
-nsresult
-GeckoPrintSession::SetSettings (nsIPrintSettings *aPrintSettings,
- GtkPrintSettings *aSettings,
- GtkPageSetup *aPageSetup,
- GtkPrinter *aPrinter)
-{
- NS_ASSERTION (!mPrintSettings && !mSettings && !mPageSetup && !mPrinter, "Already have settings!");
-
- NS_ENSURE_ARG (aPrintSettings);
- NS_ENSURE_ARG (aSettings);
-
- mPrintSettings = aPrintSettings;
- mSettings = (GtkPrintSettings *) g_object_ref (aSettings);
-
- NS_ENSURE_ARG (aPageSetup);
- NS_ENSURE_ARG (aPrinter);
-
- mPageSetup = (GtkPageSetup *) g_object_ref (aPageSetup);
- mPrinter = (GtkPrinter *) g_object_ref (aPrinter);
-
-#if 0
- /* Compute the source file name */
- if (gtk_print_settings_get_print_to_file (mSettings)) {
- /* FIXME: support gnome-VFS uris here! */
- const char *fileURI = gtk_print_settings_get (aSettings, "export-uri");
- NS_ENSURE_TRUE (fileURI, NS_ERROR_FAILURE);
-
- char *fileName = g_filename_from_uri (fileURI, NULL, NULL);
- NS_ENSURE_TRUE (fileURI, NS_ERROR_FAILURE);
-
- mSourceFile.Assign (fileName);
- g_free (fileName);
- } else
-#endif
- {
- char *base, *tmpName;
-
- /* FIXME: use pure glib here (g_mkstemp)! */
- base = g_build_filename (ephy_file_tmp_dir (), "print-XXXXXX", (const char *) NULL);
- tmpName = ephy_file_tmp_filename (base, "ps");
- g_free (base);
-
- NS_ENSURE_TRUE (tmpName, NS_ERROR_FAILURE);
- mSourceFile.Assign (tmpName);
- g_free (tmpName);
-
- mSourceFileIsTemp = PR_TRUE;
- }
-
- return NS_OK;
-}
-
-/* static methods */
-
-/* static */ GeckoPrintSession *
-GeckoPrintSession::FromSettings (nsIPrintSettings *aSettings)
-{
- nsresult rv;
- nsCOMPtr<nsIPrintSession> session;
- rv = aSettings->GetPrintSession (getter_AddRefs (session));
- NS_ENSURE_TRUE (NS_SUCCEEDED (rv) && session, nsnull);
-
- /* this is ok since the caller holds a ref to the settings which hold a ref to the session */
- nsIPrintSession *sessionPtr = session.get();
- return static_cast<GeckoPrintSession*>(sessionPtr);
-}
-
-/* static functions */
-
-static void
-ReleaseSession (GeckoPrintSession *aSession)
-{
- NS_RELEASE (aSession);
-}
-
-static gboolean
-ProgressDeleteCallback (GtkDialog *aDialog)
-{
- gtk_dialog_response (aDialog, GTK_RESPONSE_DELETE_EVENT);
- return TRUE;
-}
-
-static void
-ProgressResponseCallback (GtkDialog *aDialog,
- int aResponse,
- GeckoPrintSession *aSession)
-{
- aSession->Cancel ();
-}
-
-static gboolean
-StartPrintIdleCallback (GeckoPrintSession *aSession)
-{
- aSession->StartPrinting ();
-
- return FALSE;
-}
-
-static void
-JobStatusChangedCallback (GtkPrintJob *aJob,
- GeckoPrintSession *aSession)
-{
- aSession->JobStatusChanged ();
-}
-
-static void
-JobCompletedCallback (GtkPrintJob *aJob,
- GeckoPrintSession *aSession,
- GError *aError)
-{
- aSession->JobDone ();
-
- if (aError) {
- aSession->JobError (aError->message);
- }
-}
-
-/* Private methods */
-
-void
-GeckoPrintSession::SetProgress (PRInt32 aCurrent,
- PRInt32 aMaximum)
-{
- NS_ENSURE_TRUE (mProgressDialog, );
-
- if (mCancelled) return;
-
- /* Mozilla is weird */
- if (aCurrent > aMaximum || (aCurrent == 100 && aMaximum == 100)) return;
-
- double fraction = 0.0;
- if (aMaximum > 0 && aCurrent >= 0) {
- char *text = g_strdup_printf (_("Page %d of %d"), aCurrent, aMaximum);
- gtk_progress_bar_set_text (GTK_PROGRESS_BAR (mProgressBar), text);
- g_free (text);
-
- fraction = (double) aCurrent / (double) aMaximum;
- }
-
- gtk_progress_bar_set_fraction (GTK_PROGRESS_BAR (mProgressBar), CLAMP (fraction, 0.0, 1.0));
-}
-
-void
-GeckoPrintSession::SetProgressText (const char *aText)
-{
- NS_ENSURE_TRUE (mProgressDialog, );
-
- gtk_progress_bar_set_text (GTK_PROGRESS_BAR (mProgressBar), aText);
-}
-
-void
-GeckoPrintSession::Cancel ()
-{
- SetProcessCanceledByUser (PR_TRUE);
-
- if (mProgressDialog) {
- gtk_dialog_set_response_sensitive (GTK_DIALOG (mProgressDialog),
- GTK_RESPONSE_CANCEL, FALSE);
-
- SetProgress (0, 0);
- SetProgressText (_("Cancelling print")); /* FIXME text! */
- }
-
- if (mJob) {
- /* FIXME: There's no way to cancel mJob! Bug #339323 */
- }
-}
-
-void
-GeckoPrintSession::StartPrinting ()
-{
- mStartPrintIdleID = 0;
-
- GError *error = NULL;
-
-#if 0
- /* FIXME: this could also be a print job to a file which was
- * printed to a temp file and now needs to be uploaded to its
- * final location with gnome-vfs.
- */
- if (gtk_print_settings_get_print_to_file (mSettings)) return;
-#endif
-
- NS_ENSURE_TRUE (mSettings && mPageSetup && mPrinter, );
-
- mJob = gtk_print_job_new (mTitle.get (),
- mPrinter,
- mSettings,
- mPageSetup);
- if (!gtk_print_job_set_source_file (mJob, mSourceFile.get (), &error)) {
- /* FIXME: error dialogue! */
- g_warning ("Couldn't set print job source: %s", error->message);
- g_error_free (error);
-
- g_object_unref (mJob);
- mJob = NULL;
-
- return;
- }
-
- g_signal_connect (mJob, "status-changed",
- G_CALLBACK (JobStatusChangedCallback), this);
-
- /* Keep us alive until the job is done! */
- NS_ADDREF_THIS ();
- gtk_print_job_send (mJob,
- (GtkPrintJobCompleteFunc) JobCompletedCallback,
- this,
- (GDestroyNotify) ReleaseSession);
-}
-
-void
-GeckoPrintSession::JobStatusChanged ()
-{
- NS_ENSURE_TRUE (mProgressDialog, );
-
- LOG ("print session %p status changed %d\n", this, gtk_print_job_get_status (mJob));
-
- /* FIXME: are any other status codes relevant info for the user? */
- if (gtk_print_job_get_status (mJob) == GTK_PRINT_STATUS_SENDING_DATA) {
- gtk_progress_bar_set_fraction (GTK_PROGRESS_BAR (mProgressBar), 0.75);
- /* FIXME text! */
- SetProgressText (_("Spooling..."));
- }
-}
-
-void
-GeckoPrintSession::JobError (const char *aErrorMessage)
-{
- LOG ("print job error: %s", aErrorMessage);
-
- /* FIXME better text */
- GtkWidget *dialog = gtk_message_dialog_new (NULL,
- GtkDialogFlags (0),
- GTK_MESSAGE_ERROR,
- GTK_BUTTONS_OK,
- _("Print error"));
- gtk_message_dialog_format_secondary_text (GTK_MESSAGE_DIALOG (dialog),
- "%s", aErrorMessage);
- g_signal_connect (dialog, "response",
- G_CALLBACK (gtk_widget_destroy), NULL);
-
- gtk_widget_show (dialog);
-}
-
-void
-GeckoPrintSession::JobDone ()
-{
- NS_ENSURE_TRUE (mProgressDialog, );
-
- mDone = PR_TRUE;
-
- gtk_widget_hide (mProgressDialog);
-
- DestroyJob ();
-}
-
-void
-GeckoPrintSession::DestroyJob ()
-{
- if (!mJob) return;
-
- g_signal_handlers_disconnect_by_func (mJob, (void*) JobStatusChangedCallback, this);
- g_object_unref (mJob);
- mJob = NULL;
-}
-
-void
-GeckoPrintSession::LaunchJobOnIdle ()
-{
- NS_ASSERTION (!mStartPrintIdleID, "Already started printing!");
-
- /* Don't send the job to the printer if the user cancelled the print */
- if (mCancelled) return;
-
- /* Keep us alive until the idle handler runs! */
- NS_ADDREF_THIS ();
- mStartPrintIdleID = g_idle_add_full (G_PRIORITY_DEFAULT_IDLE,
- (GSourceFunc) StartPrintIdleCallback,
- this,
- (GDestroyNotify) ReleaseSession);
-}
-
-/* XPCOM interfaces */
-
-NS_IMPL_THREADSAFE_ISUPPORTS5 (GeckoPrintSession,
- nsIPrintSession,
- nsIWebProgressListener,
- nsIPrintProgress,
- nsIPrintProgressParams,
- nsISupportsWeakReference)
-
-/* nsIPrintSession implementation */
-
-/* nsIWebProgressListener implementation */
-
-/* void onStateChange (in nsIWebProgress aWebProgress, in nsIRequest aRequest, in unsigned long aStateFlags, in nsresult aStatus); */
-NS_IMETHODIMP
-GeckoPrintSession::OnStateChange (nsIWebProgress *aWebProgress,
- nsIRequest *aRequest,
- PRUint32 aStateFlags,
- nsresult aStatus)
-{
- if (NS_SUCCEEDED (aStatus) &&
- aStateFlags & nsIWebProgressListener::STATE_IS_DOCUMENT) {
- if (aStateFlags & nsIWebProgressListener::STATE_START) {
- /* Printing starts now */
- SetProgress (0, 0);
- } else if ((aStateFlags & nsIWebProgressListener::STATE_STOP)) {
- /* Printing done, upload to printer */
- LaunchJobOnIdle ();
- }
- }
-
- return NS_OK;
-}
-
-/* void onProgressChange (in nsIWebProgress aWebProgress, in nsIRequest aRequest, in long aCurSelfProgress, in long aMaxSelfProgress, in long aCurTotalProgress, in long aMaxTotalProgress); */
-NS_IMETHODIMP
-GeckoPrintSession::OnProgressChange (nsIWebProgress *aWebProgress,
- nsIRequest *aRequest,
- PRInt32 aCurSelfProgress,
- PRInt32 aMaxSelfProgress,
- PRInt32 aCurTotalProgress,
- PRInt32 aMaxTotalProgress)
-{
- SetProgress (aCurTotalProgress, aMaxTotalProgress);
-
- return NS_OK;
-}
-
-/* void onLocationChange (in nsIWebProgress aWebProgress, in nsIRequest aRequest, in nsIURI aLocation); */
-NS_IMETHODIMP
-GeckoPrintSession::OnLocationChange (nsIWebProgress *aWebProgress,
- nsIRequest *aRequest,
- nsIURI *aLocation)
-{
- NS_ASSERTION (0, "OnLocationChange reached!");
- return NS_OK;
-}
-
-/* void onStatusChange (in nsIWebProgress aWebProgress, in nsIRequest aRequest, in nsresult aStatus, in wstring aMessage); */
-NS_IMETHODIMP
-GeckoPrintSession::OnStatusChange (nsIWebProgress *aWebProgress,
- nsIRequest *aRequest,
- nsresult aStatus,
- const PRUnichar *aMessage)
-{
- NS_ASSERTION (0, "OnStatusChange reached!");
- return NS_OK;
-}
-
-/* void onSecurityChange (in nsIWebProgress aWebProgress, in nsIRequest aRequest, in unsigned long aState); */
-NS_IMETHODIMP
-GeckoPrintSession::OnSecurityChange (nsIWebProgress *aWebProgress,
- nsIRequest *aRequest,
- PRUint32 aState)
-{
- NS_ASSERTION (0, "OnSecurityChange reached!");
- return NS_OK;
-}
-
-/* nsIPrintProgress implementation */
-
-/* void openProgressDialog (in nsIDOMWindowInternal parent, in string dialogURL, in nsISupports parameters, in nsIObserver openDialogObserver, out boolean notifyOnOpen); */
-NS_IMETHODIMP
-GeckoPrintSession::OpenProgressDialog (nsIDOMWindowInternal *aParent,
- const char *aDialogURL,
- nsISupports *aParameters,
- nsIObserver *aOpenDialogObserver,
- PRBool *_notifyOnOpen)
-{
- NS_ENSURE_STATE (!mProgressDialog);
-
- nsCOMPtr<nsIDOMWindow> domWindow (do_QueryInterface (aParent));
- GtkWidget *parent = EphyUtils::FindGtkParent (domWindow);
-
- GtkWidget *vbox, *hbox, *image;
-
- mProgressDialog = gtk_dialog_new ();
- GtkDialog *dialog = GTK_DIALOG (mProgressDialog);
-
- gtk_dialog_add_button (dialog, GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL);
-
- g_signal_connect (dialog, "delete-event",
- G_CALLBACK (ProgressDeleteCallback), NULL);
- g_signal_connect (dialog, "response",
- G_CALLBACK (ProgressResponseCallback), this);
-
- /* FIXME do we need transient? initially on top should suffice */
- gtk_window_set_transient_for (GTK_WINDOW (dialog),
- GTK_WINDOW (parent));
-
- gtk_dialog_set_has_separator (dialog, FALSE);
- gtk_window_set_resizable (GTK_WINDOW (dialog), FALSE);
- gtk_container_set_border_width (GTK_CONTAINER (dialog), 5);
- gtk_box_set_spacing (GTK_BOX (dialog->vbox), 14); /* 2 * 5 + 14 = 24 */
- gtk_box_set_spacing (GTK_BOX (dialog->action_area), 5);
-
- hbox = gtk_hbox_new (FALSE, 12);
- gtk_container_set_border_width (GTK_CONTAINER (hbox), 5);
- gtk_container_add (GTK_CONTAINER (dialog->vbox), hbox);
-
- image = gtk_image_new_from_stock (GTK_STOCK_PRINT, GTK_ICON_SIZE_DIALOG);
- gtk_misc_set_alignment (GTK_MISC (image), 0.5, 0.0);
- gtk_box_pack_start (GTK_BOX (hbox), image, FALSE, FALSE, 0);
-
- vbox = gtk_vbox_new (FALSE, 12);
- gtk_box_pack_start (GTK_BOX (hbox), vbox, TRUE, TRUE, 0);
-
- mTitleLabel = gtk_label_new (NULL);
- gtk_label_set_line_wrap (GTK_LABEL (mTitleLabel), TRUE);
- gtk_misc_set_alignment (GTK_MISC (mTitleLabel), 0.0, 0.0);
- gtk_box_pack_start (GTK_BOX (vbox), mTitleLabel, FALSE, FALSE, 0);
-
- mProgressBar = gtk_progress_bar_new ();
- gtk_box_pack_start (GTK_BOX (vbox), mProgressBar, FALSE, FALSE, 0);
-
- gtk_widget_show_all (hbox);
- gtk_window_present (GTK_WINDOW (dialog));
-
- *_notifyOnOpen = PR_FALSE;
-
- return NS_OK;
-}
-
-/* void closeProgressDialog (in boolean forceClose); */
-NS_IMETHODIMP
-GeckoPrintSession::CloseProgressDialog (PRBool forceClose)
-{
- return NS_OK;
-}
-
-/* void registerListener (in nsIWebProgressListener listener); */
-NS_IMETHODIMP
-GeckoPrintSession::RegisterListener (nsIWebProgressListener *listener)
-{
- return NS_OK;
-}
-
-/* void unregisterListener (in nsIWebProgressListener listener); */
-NS_IMETHODIMP
-GeckoPrintSession::UnregisterListener (nsIWebProgressListener *listener)
-{
- return NS_OK;
-}
-
-/* void doneIniting (); */
-NS_IMETHODIMP
-GeckoPrintSession::DoneIniting()
-{
- return NS_OK;
-}
-
-/* nsIPrompt getPrompter (); */
-NS_IMETHODIMP
-GeckoPrintSession::GetPrompter (nsIPrompt **_retval)
-{
- g_return_val_if_reached (NS_ERROR_NOT_IMPLEMENTED);
- return NS_ERROR_NOT_IMPLEMENTED;
-}
-
-/* attribute boolean processCanceledByUser; */
-NS_IMETHODIMP
-GeckoPrintSession::GetProcessCanceledByUser (PRBool *aProcessCanceledByUser)
-{
- *aProcessCanceledByUser = mCancelled;
- return NS_OK;
-}
-
-NS_IMETHODIMP
-GeckoPrintSession::SetProcessCanceledByUser (PRBool aProcessCanceledByUser)
-{
- mCancelled = aProcessCanceledByUser;
- if (mPrintSettings) {
- mPrintSettings->SetIsCancelled (aProcessCanceledByUser);
- }
-
- return NS_OK;
-}
-
-/* nsIPrintProgressParams implementation */
-
-/* attribute wstring docTitle; */
-NS_IMETHODIMP
-GeckoPrintSession::GetDocTitle (PRUnichar * *aDocTitle)
-{
- g_return_val_if_reached (NS_ERROR_NOT_IMPLEMENTED);
- return NS_ERROR_NOT_IMPLEMENTED;
-}
-
-NS_IMETHODIMP
-GeckoPrintSession::SetDocTitle (const PRUnichar * aDocTitle)
-{
- NS_ENSURE_STATE (mProgressDialog);
-
- char *converted = EphyUtils::ConvertUTF16toUTF8 (aDocTitle, MAX_STRING_LENGTH);
- if (converted) {
- mTitle.Assign (converted);
-
- char *title = g_strdup_printf (_("Printing “%s”"), converted);
- gtk_window_set_title (GTK_WINDOW (mProgressDialog), title);
- gtk_label_set_text (GTK_LABEL (mTitleLabel), title);
- g_free (converted);
- g_free (title);
- }
- return NS_OK;
-}
-
-/* attribute wstring docURL; */
-NS_IMETHODIMP
-GeckoPrintSession::GetDocURL (PRUnichar * *aDocURL)
-{
- g_return_val_if_reached (NS_ERROR_NOT_IMPLEMENTED);
- return NS_ERROR_NOT_IMPLEMENTED;
-}
-
-NS_IMETHODIMP
-GeckoPrintSession::SetDocURL (const PRUnichar * aDocURL)
-{
-#if 0
- NS_ENSURE_STATE (mJob);
-
- char *converted = EphyUtils::ConvertUTF16toUTF8 (aDocTitle, MAX_STRING_LENGTH);
- if (converted) {
- g_free (converted);
- }
-#endif
- return NS_OK;
-}
diff --git a/embed/xulrunner/components/GeckoPrintSession.h b/embed/xulrunner/components/GeckoPrintSession.h
deleted file mode 100644
index 027f01e23..000000000
--- a/embed/xulrunner/components/GeckoPrintSession.h
+++ /dev/null
@@ -1,94 +0,0 @@
-/*
- * Copyright © 2006 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#ifndef GECKO_PRINT_SESSION_H
-#define GECKO_PRINT_SESSION_H
-
-#include <nsCOMPtr.h>
-#include <nsIPrintSession.h>
-#include <nsIWebProgressListener.h>
-#include <nsIPrintProgress.h>
-#include <nsIPrintProgressParams.h>
-#include <nsWeakReference.h>
-
-#include <gtk/gtkwidget.h>
-#include <gtk/gtkprintjob.h>
-#include <gtk/gtkprinter.h>
-#include <gtk/gtkprintjob.h>
-
-class nsIPrintSettings;
-class nsIDOMWindow;
-
-/* 0940c973-97e7-476f-a612-4ed9473a0b36 */
-#define GECKO_PRINT_SESSION_IID \
-{ 0x0940c973, 0x97e7, 0x476f, \
- { 0xa6, 0x12, 0x4e, 0xd9, 0x47, 0x3a, 0x0b, 0x36 } }
-
-#define GECKO_PRINT_SESSION_CLASSNAME "Gecko Print Session"
-
-class GeckoPrintSession : public nsIPrintSession,
- public nsIPrintProgress,
- public nsIPrintProgressParams,
- public nsSupportsWeakReference
-{
- public:
- GeckoPrintSession();
- virtual ~GeckoPrintSession();
-
- NS_DECL_ISUPPORTS
- NS_DECL_NSIPRINTSESSION
- NS_DECL_NSIWEBPROGRESSLISTENER
- NS_DECL_NSIPRINTPROGRESS
- NS_DECL_NSIPRINTPROGRESSPARAMS
-
- nsresult SetSettings (nsIPrintSettings *, GtkPrintSettings*, GtkPageSetup*, GtkPrinter*);
- void GetSourceFile (nsACString&);
-
- static GeckoPrintSession *FromSettings (nsIPrintSettings *);
-
- void Cancel ();
- void StartPrinting ();
- void JobStatusChanged ();
- void JobDone ();
- void JobError (const char *);
-
- private:
- nsCOMPtr<nsIPrintSettings> mPrintSettings;
- GtkPrintSettings *mSettings;
- GtkPageSetup *mPageSetup;
- GtkPrinter *mPrinter;
- GtkPrintJob *mJob;
- GtkWidget *mProgressDialog;
- GtkWidget *mTitleLabel;
- GtkWidget *mProgressBar;
- nsCString mSourceFile;
- nsCString mTitle;
- guint mStartPrintIdleID;
- PRPackedBool mSourceFileIsTemp;
- PRPackedBool mDone;
- PRPackedBool mCancelled;
-
- void SetProgress (PRInt32, PRInt32);
- void SetProgressText (const char *);
- void LaunchJobOnIdle ();
- void DestroyJob ();
-};
-
-#endif /* GECKO_PRINT_SESSION_H */
diff --git a/embed/xulrunner/components/GeckoPromptService.cpp b/embed/xulrunner/components/GeckoPromptService.cpp
deleted file mode 100644
index 7e0abd251..000000000
--- a/embed/xulrunner/components/GeckoPromptService.cpp
+++ /dev/null
@@ -1,907 +0,0 @@
-/*
- * Copyright © 2005, 2006 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser 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.
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include <glib.h>
-#include <glib-object.h>
-#include <glib/gi18n.h>
-#include <gtk/gtk.h>
-
-#include <nsStringGlue.h>
-
-#include <nsCOMPtr.h>
-#include <nsIDOMWindow.h>
-#include <nsServiceManagerUtils.h>
-
-#include "gecko-embed.h"
-#include "gecko-embed-single.h"
-
-#include "ephy-embed-shell.h"
-
-#include "AutoJSContextStack.h"
-#include "AutoWindowModalState.h"
-#include "GeckoUtils.h"
-
-#include "GeckoPromptService.h"
-
-#define TIMEOUT 1000 /* ms */
-#define TIMEOUT_DATA_KEY "timeout"
-
-#define MAX_MESSAGE_LENGTH 512
-#define MAX_TITLE_LENGTH 256
-#define MAX_BUTTON_TEXT_LENGTH 128
-
-enum
-{
- RESPONSE_ABORT_SCRIPT = 42
-};
-
-class Prompter
-{
-public:
- Prompter (const char*, nsIDOMWindow*, const PRUnichar*, const PRUnichar*);
- ~Prompter();
-
- void AddStockButton (const char*, int);
- void AddButtonWithFlags (PRInt32, PRUint32, const PRUnichar*, PRUint32);
- void AddButtonsWithFlags (PRUint32, const PRUnichar*, const PRUnichar*, const PRUnichar*);
- void AddCheckbox (const PRUnichar*, PRBool*);
- void GetCheckboxState (PRBool *);
- void AddEntry (const char *, const PRUnichar *, PRBool);
- void GetText (PRUint32, PRUnichar **);
- void AddSelect (PRUint32, const PRUnichar **, PRInt32);
- void GetSelected (PRInt32*);
-
- PRInt32 Run (PRBool * = nsnull);
- void Show ();
-
- PRBool IsCalledFromScript ();
- void PerformScriptAbortion ();
-
- char *ConvertAndTruncateString (const PRUnichar *, PRInt32 = -1);
- char* ConvertAndEscapeButtonText (const PRUnichar *, PRInt32 = -1);
-
-private:
- nsCOMPtr<nsIDOMWindow> mWindow;
- GtkDialog *mDialog;
- GtkWidget *mVBox;
- GtkWidget *mCheck;
- GtkSizeGroup *mSizeGroup;
- GtkWidget *mEntries[2];
- GtkWidget *mCombo;
- PRInt32 mNumButtons;
- PRInt32 mNumEntries;
- PRInt32 mDefaultResponse;
- PRInt32 mUnaffirmativeResponse;
- PRInt32 mResponse;
- PRBool mSuccess;
- PRBool mDelay;
-};
-
-Prompter::Prompter (const char *aStock,
- nsIDOMWindow *aParent,
- const PRUnichar *aTitle,
- const PRUnichar *aText)
- : mWindow (aParent)
- , mDialog(nsnull)
- , mVBox(nsnull)
- , mCheck(nsnull)
- , mSizeGroup(nsnull)
- , mCombo(nsnull)
- , mNumButtons(0)
- , mNumEntries(0)
- , mDefaultResponse(GTK_RESPONSE_ACCEPT)
- , mUnaffirmativeResponse(0)
- , mResponse(GTK_RESPONSE_CANCEL)
- , mSuccess(PR_FALSE)
- , mDelay(PR_FALSE)
-{
- GtkWidget *parent, *hbox, *label, *image;
-
- g_object_ref (ephy_embed_shell_get_default ());
-
- mEntries[0] = mEntries[1] = nsnull;
-
- mDialog = GTK_DIALOG (gtk_dialog_new ());
- g_object_ref_sink (mDialog);
-
- char *title = NULL;
- if (aTitle)
- {
- title = ConvertAndTruncateString (aTitle, MAX_TITLE_LENGTH);
- }
-
- gtk_window_set_title (GTK_WINDOW (mDialog), title ? title : "");
- g_free (title);
-
- gtk_window_set_modal (GTK_WINDOW (mDialog), TRUE);
-
- parent = GeckoUtils::GetGtkWindowForDOMWindow (aParent);
- if (GTK_IS_WINDOW (parent))
- {
- gtk_window_set_transient_for (GTK_WINDOW (mDialog),
- GTK_WINDOW (parent));
- }
-
- gtk_dialog_set_has_separator (mDialog, FALSE);
- gtk_window_set_resizable (GTK_WINDOW (mDialog), FALSE);
- gtk_container_set_border_width (GTK_CONTAINER (mDialog), 5);
- gtk_box_set_spacing (GTK_BOX (mDialog->vbox), 14); /* 2 * 5 + 14 = 24 */
-
- hbox = gtk_hbox_new (FALSE, 12);
- gtk_container_set_border_width (GTK_CONTAINER (hbox), 5);
- gtk_container_add (GTK_CONTAINER (GTK_DIALOG (mDialog)->vbox), hbox);
-
- image = gtk_image_new_from_stock (aStock, GTK_ICON_SIZE_DIALOG);
- gtk_misc_set_alignment (GTK_MISC (image), 0.5, 0.0);
- gtk_box_pack_start (GTK_BOX (hbox), image, FALSE, FALSE, 0);
-
- mVBox = gtk_vbox_new (FALSE, 12);
- gtk_box_pack_start (GTK_BOX (hbox), mVBox, TRUE, TRUE, 0);
-
- char *text = NULL;
- if (aText)
- {
- text = ConvertAndTruncateString (aText, MAX_MESSAGE_LENGTH);
- }
-
- label = gtk_label_new (text);
- g_free (text);
-
- gtk_label_set_line_wrap (GTK_LABEL (label), TRUE);
- /* Guard against overlong nonbreakable text (exploit) */
- gtk_label_set_line_wrap_mode (GTK_LABEL (label), PANGO_WRAP_WORD_CHAR);
- gtk_label_set_selectable (GTK_LABEL (label), TRUE);
- gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.0);
-
- gtk_box_pack_start (GTK_BOX (mVBox), label, FALSE, FALSE, 0);
- gtk_widget_show (label);
-
- if (IsCalledFromScript ())
- {
- gtk_dialog_add_button (GTK_DIALOG (mDialog),
- _("_Abort Script"),
- RESPONSE_ABORT_SCRIPT);
- }
-
- gtk_widget_show (image);
- gtk_widget_show (mVBox);
- gtk_widget_show (hbox);
-}
-
-Prompter::~Prompter ()
-{
- if (mSizeGroup)
- {
- g_object_unref (mSizeGroup);
- }
-
- gtk_widget_destroy (GTK_WIDGET (mDialog));
- g_object_unref (mDialog);
-
- g_object_unref (ephy_embed_shell_get_default ());
-}
-
-void
-Prompter::AddStockButton (const char *aStock,
- int aResponse)
-{
- gtk_dialog_add_button (GTK_DIALOG (mDialog),
- aStock, aResponse);
- ++mNumButtons;
-}
-
-void
-Prompter::AddButtonWithFlags (PRInt32 aNum,
- PRUint32 aFlags,
- const PRUnichar *aText,
- PRUint32 aDefault)
-{
- if (aFlags == 0) return;
-
- const char *label = NULL;
- char *freeme = NULL;
- gboolean isAffirmative = FALSE;
- switch (aFlags)
- {
- case nsIPromptService::BUTTON_TITLE_OK:
- label = GTK_STOCK_OK;
- isAffirmative = TRUE;
- break;
-
- case nsIPromptService::BUTTON_TITLE_CANCEL:
- label = GTK_STOCK_CANCEL;
- break;
-
- case nsIPromptService::BUTTON_TITLE_YES:
- label = GTK_STOCK_YES;
- isAffirmative = TRUE;
- break;
-
- case nsIPromptService::BUTTON_TITLE_NO:
- label = GTK_STOCK_NO;
- break;
-
- case nsIPromptService::BUTTON_TITLE_SAVE:
- label = GTK_STOCK_SAVE;
- isAffirmative = TRUE;
- break;
-
- case nsIPromptService::BUTTON_TITLE_DONT_SAVE:
- label = _("Don't Save");
- break;
-
- case nsIPromptService::BUTTON_TITLE_REVERT:
- label = GTK_STOCK_REVERT_TO_SAVED;
- break;
-
- case nsIPromptService::BUTTON_TITLE_IS_STRING:
- default:
- label = freeme = ConvertAndEscapeButtonText (aText, MAX_BUTTON_TEXT_LENGTH);
- /* We can't tell, so assume it's affirmative */
- isAffirmative = TRUE;
- break;
- }
-
- if (label == NULL) return;
-
- gtk_dialog_add_button (mDialog, label, aNum);
- ++mNumButtons;
-
- if (isAffirmative && mDelay)
- {
- gtk_dialog_set_response_sensitive (mDialog, aNum, FALSE);
- }
-
- if (!isAffirmative)
- {
- mUnaffirmativeResponse = aNum;
- }
-
- if (aDefault)
- {
- mDefaultResponse = aNum;
- }
-
- g_free (freeme);
-}
-
-void
-Prompter::AddButtonsWithFlags (PRUint32 aFlags,
- const PRUnichar *aText0,
- const PRUnichar *aText1,
- const PRUnichar *aText2)
-{
- mDelay = (aFlags & nsIPromptService::BUTTON_DELAY_ENABLE) != 0;
- mDefaultResponse = -1;
-
- /* Reverse the order, on the assumption that what we passed is the
- * 'windows' button order, and we want HIG order.
- */
- AddButtonWithFlags (2, ((aFlags / nsIPromptService::BUTTON_POS_2) & 0xff), aText2,
- aFlags & nsIPromptService::BUTTON_POS_2_DEFAULT);
- AddButtonWithFlags (1, ((aFlags / nsIPromptService::BUTTON_POS_1) & 0xff), aText1,
- aFlags & nsIPromptService::BUTTON_POS_1_DEFAULT);
- AddButtonWithFlags (0, ((aFlags / nsIPromptService::BUTTON_POS_0) & 0xff), aText0,
- aFlags & nsIPromptService::BUTTON_POS_0_DEFAULT);
-
- /* If no default was set, use the 'rightmost' unaffirmative response.
- * This happens with the suite's password manager prompt.
- */
- if (mDefaultResponse == -1)
- {
- mDefaultResponse = mUnaffirmativeResponse;
- }
-}
-
-void
-Prompter::AddCheckbox (const PRUnichar *aText,
- PRBool *aState)
-{
- if (!aState || !aText) return;
-
- char *label = ConvertAndEscapeButtonText (aText, 2 * MAX_BUTTON_TEXT_LENGTH);
- mCheck = gtk_check_button_new_with_mnemonic (label);
- g_free (label);
-
- gtk_label_set_line_wrap (GTK_LABEL (GTK_BIN (mCheck)->child), TRUE);
- gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (mCheck), *aState);
- gtk_box_pack_start (GTK_BOX (mVBox), mCheck, FALSE, FALSE, 0);
- gtk_widget_show (mCheck);
-}
-
-void
-Prompter::GetCheckboxState (PRBool *aState)
-{
- if (!aState || !mCheck) return;
-
- *aState = gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (mCheck));
-}
-
-void
-Prompter::AddEntry (const char *aLabel,
- const PRUnichar *aValue,
- PRBool aIsPassword)
-{
- if (!mSizeGroup)
- {
- mSizeGroup = gtk_size_group_new (GTK_SIZE_GROUP_HORIZONTAL);
- }
-
- GtkWidget *hbox = gtk_hbox_new (FALSE, 12);
- gtk_box_pack_start (GTK_BOX (mVBox), hbox, FALSE, FALSE, 0);
-
- GtkWidget *label = nsnull;
- if (aLabel)
- {
- label = gtk_label_new_with_mnemonic (aLabel);
- gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5);
- gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, FALSE, 0);
- gtk_size_group_add_widget (mSizeGroup, label);
- }
-
- GtkWidget *entry = mEntries[mNumEntries++] = gtk_entry_new ();
- gtk_entry_set_visibility (GTK_ENTRY (entry), !aIsPassword);
- gtk_entry_set_activates_default(GTK_ENTRY (entry), TRUE);
-
- if (aValue)
- {
- nsCString cValue;
- NS_UTF16ToCString (nsDependentString(aValue),
- NS_CSTRING_ENCODING_UTF8, cValue);
-
- gtk_entry_set_text (GTK_ENTRY (entry), cValue.get());
- }
-
- if (label)
- {
- gtk_label_set_mnemonic_widget (GTK_LABEL (label), entry);
- }
-
- gtk_box_pack_start (GTK_BOX (hbox), entry, TRUE, TRUE, 0);
- gtk_widget_show_all (hbox);
-}
-
-void
-Prompter::GetText (PRUint32 aNum,
- PRUnichar **aValue)
-{
- if (!aValue || !mEntries[aNum]) return;
-
- const char *text = gtk_entry_get_text (GTK_ENTRY (mEntries[aNum]));
- if (!text) return;
-
- nsString value;
- NS_CStringToUTF16 (nsDependentCString (text),
- NS_CSTRING_ENCODING_UTF8, value);
-
- *aValue = NS_StringCloneData (value);
-}
-
-void
-Prompter::AddSelect (PRUint32 aCount,
- const PRUnichar **aList,
- PRInt32 aDefault)
-{
- mCombo = gtk_combo_box_new_text ();
-
- for (PRUint32 i = 0; i < aCount; i++)
- {
- /* FIXME: use "" instead in this case? */
- if (!aList[i] || !aList[i][0]) continue;
-
- nsCString cData;
- NS_UTF16ToCString (nsDependentString(aList[i]), NS_CSTRING_ENCODING_UTF8, cData);
-
- gtk_combo_box_append_text (GTK_COMBO_BOX (mCombo), cData.get());
- }
-
- gtk_combo_box_set_active (GTK_COMBO_BOX (mCombo), aDefault);
-
- gtk_box_pack_start (GTK_BOX (mVBox), mCombo, FALSE, FALSE, 0);
- gtk_widget_show (mCombo);
-}
-
-void
-Prompter::GetSelected (PRInt32 *aSelected)
-{
- if (!aSelected || !mCombo) return;
-
- *aSelected = gtk_combo_box_get_active (GTK_COMBO_BOX (mCombo));
-}
-
-static gboolean
-EnableResponse (GtkDialog *aDialog)
-{
- g_object_steal_data (G_OBJECT (aDialog), TIMEOUT_DATA_KEY);
-
- gtk_dialog_set_response_sensitive (aDialog, 0, TRUE);
- gtk_dialog_set_response_sensitive (aDialog, 1, TRUE);
- gtk_dialog_set_response_sensitive (aDialog, 2, TRUE);
-
- return FALSE;
-}
-
-static void
-RemoveTimeout (gpointer idptr)
-{
- guint timeout = GPOINTER_TO_UINT (idptr);
-
- g_return_if_fail (timeout != 0);
-
- g_source_remove (timeout);
-}
-
-PRInt32
-Prompter::Run (PRBool *aSuccess)
-{
-#if 0
- AutoEventQueue queue;
- if (NS_FAILED (queue.Init()))
- {
- if (aSuccess)
- {
- *aSuccess = PR_FALSE;
- }
- mSuccess = PR_FALSE;
-
- return GTK_RESPONSE_CANCEL;
- }
-#endif
-
- nsresult rv;
- AutoJSContextStack stack;
- rv = stack.Init ();
- if (NS_FAILED (rv)) return rv;
-
- AutoWindowModalState modalState (mWindow);
-
- if (mDelay)
- {
- guint timeout = g_timeout_add (TIMEOUT,
- (GSourceFunc) EnableResponse,
- mDialog);
- g_object_set_data_full (G_OBJECT (mDialog), TIMEOUT_DATA_KEY,
- GUINT_TO_POINTER (timeout),
- (GDestroyNotify) RemoveTimeout);
- }
-
- gtk_dialog_set_default_response (GTK_DIALOG (mDialog), mDefaultResponse);
-
- GtkWidget *widget = GTK_WIDGET (mDialog);
- gtk_widget_show (widget);
- mResponse = gtk_dialog_run (mDialog);
- gtk_widget_hide (widget);
-
- g_object_set_data (G_OBJECT (mDialog), TIMEOUT_DATA_KEY, NULL);
-
- mSuccess = (GTK_RESPONSE_ACCEPT == mResponse);
- if (aSuccess)
- {
- *aSuccess = mSuccess;
- }
-
- if (mResponse == RESPONSE_ABORT_SCRIPT)
- {
- PerformScriptAbortion ();
- }
-
- return mResponse;
-}
-
-static void
-DeletePrompter (gpointer aPromptPtr,
- GObject *aZombie)
-{
- Prompter *prompt = static_cast<Prompter*>(aPromptPtr);
-
- delete prompt;
-}
-
-void
-Prompter::Show ()
-{
- /* We don't need it anymore */
- mWindow = nsnull;
-
- gtk_window_set_modal (GTK_WINDOW (mDialog), FALSE);
-
- g_signal_connect (mDialog, "response",
- G_CALLBACK (gtk_widget_destroy), NULL);
- g_object_weak_ref (G_OBJECT (mDialog),
- (GWeakNotify) DeletePrompter,
- static_cast<gpointer>(this));
-
- gtk_widget_show (GTK_WIDGET (mDialog));
-}
-
-PRBool
-Prompter::IsCalledFromScript()
-{
-#if 0
- nsCOMPtr<nsIXPConnect> xpconnect (do_GetService (nsIXPConnect::GetCID()));
- NS_ENSURE_TRUE (xpconnect, PR_FALSE);
-
- nsresult rv;
- nsCOMPtr<nsIXPCNativeCallContext> ncc;
- rv = xpconnect->GetCurrentNativeCallContext (getter_AddRefs (ncc));
- NS_ENSURE_SUCCESS (rv, PR_FALSE);
-
- if (!ncc) return PR_FALSE;
-
- JSContext *cx = nsnull;
- rv = ncc->GetJSContext (&cx);
- g_print ("GetJSContext rv=%x, cx=%p\n", rv, cx);
-
- NS_ENSURE_SUCCESS (rv, PR_FALSE);
-
- return cx != nsnull;
-#endif
- return PR_FALSE;
-}
-
-void
-Prompter::PerformScriptAbortion()
-{
-#if 0
- /* FIXME: can we only stop the calling script, not all scripts in the context? */
-
- nsCOMPtr<nsIXPConnect> xpconnect (do_GetService (nsIXPConnect::GetCID()));
- NS_ENSURE_TRUE (xpconnect, );
-
- nsresult rv;
- nsCOMPtr<nsIXPCNativeCallContext> ncc;
- rv = xpconnect->GetCurrentNativeCallContext (getter_AddRefs (ncc));
- NS_ENSURE_SUCCESS (rv, );
- NS_ENSURE_TRUE (ncc, );
-
- JSContext *cx = nsnull;
- rv = ncc->GetJSContext (&cx);
- g_print ("GetJSContext rv=%x, cx=%p\n", rv, cx);
- NS_ENSURE_SUCCESS (rv, );
- NS_ENSURE_TRUE (cx, );
-
- g_print ("Would now disable scripts\n");
-// MozillaPrivate::SetScriptsEnabled (cx, PR_FALSE, PR_FALSE);
-#endif
-}
-
-char *
-Prompter::ConvertAndTruncateString (const PRUnichar *aText,
- PRInt32 aMaxLength)
-{
- if (aText == nsnull) return NULL;
-
- /* This depends on the assumption that
- * typeof(PRUnichar) == typeof (gunichar2) == uint16,
- * which should be pretty safe.
- */
- glong n_read = 0, n_written = 0;
- char *converted = g_utf16_to_utf8 ((gunichar2*) aText, aMaxLength,
- &n_read, &n_written, NULL);
- /* FIXME loop from the end while !g_unichar_isspace (char)? */
-
- return converted;
-}
-
-char *
-Prompter::ConvertAndEscapeButtonText(const PRUnichar *aText,
- PRInt32 aMaxLength)
-{
- char *converted = ConvertAndTruncateString (aText, aMaxLength);
- if (converted == NULL) return NULL;
-
- char *escaped = (char*) g_malloc (strlen (converted) + 1);
- char *q = escaped;
- for (const char *p = converted; *p; ++p, ++q)
- {
- if (*p == '&')
- {
- if (*(p+1) == '&')
- {
- *q = '&';
- ++p;
- }
- else
- {
- *q = '_';
- }
- }
- else
- {
- *q = *p;
- }
- }
-
- /* Null termination */
- *q = '\0';
-
- g_free (converted);
-
- return escaped;
-}
-
-NS_IMPL_ISUPPORTS2 (GeckoPromptService,
- nsIPromptService,
- nsINonBlockingAlertService)
-
-GeckoPromptService::GeckoPromptService()
-{
-}
-
-GeckoPromptService::~GeckoPromptService()
-{
-}
-
-/* nsIPromptService implementation */
-
-/* void alert (in nsIDOMWindow aParent, in wstring aDialogTitle, in wstring aText); */
-NS_IMETHODIMP
-GeckoPromptService::Alert (nsIDOMWindow *aParent,
- const PRUnichar *aDialogTitle,
- const PRUnichar *aText)
-{
- Prompter prompt (GTK_STOCK_DIALOG_INFO, aParent, aDialogTitle, aText);
- prompt.AddStockButton (GTK_STOCK_OK, GTK_RESPONSE_ACCEPT);
- prompt.Run ();
-
- return NS_OK;
-}
-
-/* void alertCheck (in nsIDOMWindow aParent, in wstring aDialogTitle, in wstring aText, in wstring aCheckMsg, inout boolean aCheckState); */
-NS_IMETHODIMP
-GeckoPromptService::AlertCheck (nsIDOMWindow *aParent,
- const PRUnichar *aDialogTitle,
- const PRUnichar *aText,
- const PRUnichar *aCheckMsg,
- PRBool *aCheckState)
-{
- Prompter prompt (GTK_STOCK_DIALOG_INFO, aParent, aDialogTitle, aText);
- prompt.AddStockButton (GTK_STOCK_OK, GTK_RESPONSE_ACCEPT);
- prompt.AddCheckbox (aCheckMsg, aCheckState);
-
- prompt.Run ();
- prompt.GetCheckboxState (aCheckState);
-
- return NS_OK;
-}
-
-/* boolean confirm (in nsIDOMWindow aParent, in wstring aDialogTitle, in wstring aText); */
-NS_IMETHODIMP
-GeckoPromptService::Confirm (nsIDOMWindow *aParent,
- const PRUnichar *aDialogTitle,
- const PRUnichar *aText,
- PRBool *_retval)
-{
- NS_ENSURE_ARG_POINTER (_retval);
-
- Prompter prompt (GTK_STOCK_DIALOG_QUESTION, aParent, aDialogTitle, aText);
- prompt.AddStockButton (GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL);
- prompt.AddStockButton (GTK_STOCK_OK, GTK_RESPONSE_ACCEPT);
- prompt.Run (_retval);
-
- return NS_OK;
-}
-
-/* boolean confirmCheck (in nsIDOMWindow aParent, in wstring aDialogTitle, in wstring aText, in wstring aCheckMsg, inout boolean aCheckState); */
-NS_IMETHODIMP
-GeckoPromptService::ConfirmCheck (nsIDOMWindow *aParent,
- const PRUnichar *aDialogTitle,
- const PRUnichar *aText,
- const PRUnichar *aCheckMsg,
- PRBool *aCheckState,
- PRBool *_retval)
-{
- NS_ENSURE_ARG_POINTER (_retval);
-
- Prompter prompt (GTK_STOCK_DIALOG_QUESTION, aParent, aDialogTitle, aText);
- prompt.AddStockButton (GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL);
- prompt.AddStockButton (GTK_STOCK_OK, GTK_RESPONSE_ACCEPT);
- prompt.AddCheckbox (aCheckMsg, aCheckState);
-
- prompt.Run (_retval);
- prompt.GetCheckboxState (aCheckState);
-
- return NS_OK;
-}
-
-/* PRInt32 confirmEx (in nsIDOMWindow aParent, in wstring aDialogTitle, in wstring aText, in unsigned long aButtonFlags, in wstring aButton0Title, in wstring aButton1Title, in wstring aButton2Title, in wstring aCheckMsg, inout boolean aCheckState); */
-NS_IMETHODIMP
-GeckoPromptService::ConfirmEx (nsIDOMWindow *aParent,
- const PRUnichar *aDialogTitle,
- const PRUnichar *aText,
- PRUint32 aButtonFlags,
- const PRUnichar *aButton0Title,
- const PRUnichar *aButton1Title,
- const PRUnichar *aButton2Title,
- const PRUnichar *aCheckMsg,
- PRBool *aCheckState,
- PRInt32 *_retval)
-{
- NS_ENSURE_ARG_POINTER (_retval);
-
- Prompter prompt (GTK_STOCK_DIALOG_QUESTION, aParent, aDialogTitle, aText);
- prompt.AddButtonsWithFlags (aButtonFlags, aButton0Title,
- aButton1Title, aButton2Title);
- prompt.AddCheckbox (aCheckMsg, aCheckState);
-
- *_retval = prompt.Run (nsnull);
- prompt.GetCheckboxState (aCheckState);
-
- return NS_OK;
-}
-
-/* boolean prompt (in nsIDOMWindow aParent, in wstring aDialogTitle, in wstring aText, inout wstring aValue, in wstring aCheckMsg, inout boolean aCheckState); */
-NS_IMETHODIMP
-GeckoPromptService::Prompt (nsIDOMWindow *aParent,
- const PRUnichar *aDialogTitle,
- const PRUnichar *aText,
- PRUnichar **aValue,
- const PRUnichar *aCheckMsg,
- PRBool *aCheckState,
- PRBool *_retval)
-{
- NS_ENSURE_ARG_POINTER (_retval);
- NS_ENSURE_ARG_POINTER (aValue);
-
- Prompter prompt (GTK_STOCK_DIALOG_QUESTION, aParent, aDialogTitle, aText);
- prompt.AddStockButton (GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL);
- prompt.AddStockButton (GTK_STOCK_OK, GTK_RESPONSE_ACCEPT);
- prompt.AddEntry (nsnull, *aValue, PR_FALSE);
- prompt.AddCheckbox (aCheckMsg, aCheckState);
-
- prompt.Run (_retval);
- prompt.GetText (0, aValue);
- prompt.GetCheckboxState (aCheckState);
-
- return NS_OK;
-}
-
-/* boolean promptUsernameAndPassword (in nsIDOMWindow aParent, in wstring aDialogTitle, in wstring aText, inout wstring aUsername, inout wstring aPassword, in wstring aCheckMsg, inout boolean aCheckState); */
-NS_IMETHODIMP
-GeckoPromptService::PromptUsernameAndPassword (nsIDOMWindow *aParent,
- const PRUnichar *aDialogTitle,
- const PRUnichar *aText,
- PRUnichar **aUsername,
- PRUnichar **aPassword,
- const PRUnichar *aCheckMsg,
- PRBool *aCheckState,
- PRBool *_retval)
-{
- NS_ENSURE_ARG_POINTER (_retval);
- NS_ENSURE_ARG_POINTER (aUsername);
- NS_ENSURE_ARG_POINTER (aPassword);
-
- Prompter prompt (GTK_STOCK_DIALOG_AUTHENTICATION, aParent, aDialogTitle, aText);
- prompt.AddStockButton (GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL);
- prompt.AddStockButton (GTK_STOCK_OK, GTK_RESPONSE_ACCEPT);
- prompt.AddEntry (_("_Username:"), *aUsername, PR_FALSE);
- prompt.AddEntry (_("_Password:"), *aPassword, PR_TRUE);
- prompt.AddCheckbox (aCheckMsg, aCheckState);
-
- prompt.Run (_retval);
- prompt.GetText (0, aUsername);
- prompt.GetText (1, aPassword);
- prompt.GetCheckboxState (aCheckState);
-
- return NS_OK;
-}
-
-/* boolean promptPassword (in nsIDOMWindow aParent, in wstring aDialogTitle, in wstring aText, inout wstring aPassword, in wstring aCheckMsg, inout boolean aCheckState); */
-NS_IMETHODIMP
-GeckoPromptService::PromptPassword (nsIDOMWindow *aParent,
- const PRUnichar *aDialogTitle,
- const PRUnichar *aText,
- PRUnichar **aPassword,
- const PRUnichar *aCheckMsg,
- PRBool *aCheckState,
- PRBool *_retval)
-{
- NS_ENSURE_ARG_POINTER (_retval);
- NS_ENSURE_ARG_POINTER (aPassword);
-
- Prompter prompt (GTK_STOCK_DIALOG_AUTHENTICATION, aParent, aDialogTitle, aText);
- prompt.AddStockButton (GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL);
- prompt.AddStockButton (GTK_STOCK_OK, GTK_RESPONSE_ACCEPT);
- prompt.AddEntry (_("_Password:"), *aPassword, PR_TRUE);
- prompt.AddCheckbox (aCheckMsg, aCheckState);
-
- // FIXME: Add a CAPSLOCK indicator?
-
- prompt.Run (_retval);
- prompt.GetText (0, aPassword);
- prompt.GetCheckboxState (aCheckState);
-
- return NS_OK;
-}
-
-/* boolean select (in nsIDOMWindow aParent, in wstring aDialogTitle, in wstring aText, in PRUint32 aCount, [array, size_is (aCount)] in wstring aSelectList, out long aOutSelection); */
-NS_IMETHODIMP
-GeckoPromptService::Select (nsIDOMWindow *aParent,
- const PRUnichar *aDialogTitle,
- const PRUnichar *aText,
- PRUint32 aCount,
- const PRUnichar **aSelectList,
- PRInt32 *aOutSelection,
- PRBool *_retval)
-{
- NS_ENSURE_ARG_POINTER (_retval);
- NS_ENSURE_ARG_POINTER (aOutSelection);
-
- Prompter prompt (GTK_STOCK_DIALOG_QUESTION, aParent, aDialogTitle, aText);
- prompt.AddStockButton (GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL);
- prompt.AddStockButton (GTK_STOCK_OK, GTK_RESPONSE_ACCEPT);
- prompt.AddSelect (aCount, aSelectList, *aOutSelection);
-
- prompt.Run (_retval);
- prompt.GetSelected (aOutSelection);
-
- return NS_OK;
-}
-
-/* nsIPromptService2 */
-
-/* boolean promptAuth (in nsIDOMWindow aParent, in nsIChannel aChannel, in PRUint32 level, in nsIAuthInformation authInfo, in wstring checkboxLabel, inout boolean checkValue); */
-NS_IMETHODIMP
-GeckoPromptService::PromptAuth (nsIDOMWindow *aParent,
- nsIChannel *aChannel,
- PRUint32 level,
- nsIAuthInformation *authInfo,
- const PRUnichar *checkboxLabel,
- PRBool *checkValue,
- PRBool *_retval)
-{
- return NS_ERROR_NOT_IMPLEMENTED;
-}
-
-/* nsICancelable asyncPromptAuth (in nsIDOMWindow aParent, in nsIChannel aChannel, in nsIAuthPromptCallback aCallback, in nsISupports aContext, in PRUint32 level, in nsIAuthInformation authInfo, in wstring checkboxLabel, inout boolean checkValue); */
-NS_IMETHODIMP
-GeckoPromptService::AsyncPromptAuth (nsIDOMWindow *aParent,
- nsIChannel *aChannel,
- nsIAuthPromptCallback *aCallback,
- nsISupports *aContext,
- PRUint32 level,
- nsIAuthInformation *authInfo,
- const PRUnichar *checkboxLabel,
- PRBool *checkValue,
- nsICancelable **_retval)
-{
- /* FIXME implement me */
- return NS_ERROR_NOT_IMPLEMENTED;
-}
-
-/* nsINonBlockingAlertService */
-
-/* showNonBlockingAlert (in nsIDOMWindow aParent, in wstring aDialogTitle, in wstring aText); */
-NS_IMETHODIMP
-GeckoPromptService::ShowNonBlockingAlert (nsIDOMWindow *aParent,
- const PRUnichar *aDialogTitle,
- const PRUnichar *aText)
-{
- Prompter *prompt = new Prompter (GTK_STOCK_DIALOG_INFO, aParent, aDialogTitle, aText);
- if (!prompt) return NS_ERROR_OUT_OF_MEMORY;
-
- prompt->AddStockButton (GTK_STOCK_OK, GTK_RESPONSE_ACCEPT);
- prompt->Show ();
-
- return NS_OK;
-}
diff --git a/embed/xulrunner/components/GeckoPromptService.h b/embed/xulrunner/components/GeckoPromptService.h
deleted file mode 100644
index ce48aded9..000000000
--- a/embed/xulrunner/components/GeckoPromptService.h
+++ /dev/null
@@ -1,48 +0,0 @@
-/*
- * Copyright © 2005, 2006 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser 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.
- *
- * $Id$
- */
-
-#ifndef GECKO_PROMPT_SERVICE_H
-#define GECKO_PROMPT_SERVICE_H
-
-#include <nsIPromptService.h>
-#include <nsIPromptService2.h>
-#include <nsINonBlockingAlertService.h>
-
-#define GECKO_PROMPT_SERVICE_CID \
-{ /* cadc6035-7c53-4039-823b-004a289d5eb2 */ \
- 0xcadc6035, 0x7c53, 0x4039, \
- { 0x82, 0x3b, 0x00, 0x4a, 0x28, 0x9d, 0x5e, 0xb2 } }
-
-#define GECKO_PROMPT_SERVICE_CLASSNAME "Gecko Prompt Service"
-
-class GeckoPromptService : public nsIPromptService2,
- public nsINonBlockingAlertService
-{
- public:
- NS_DECL_ISUPPORTS
- NS_DECL_NSIPROMPTSERVICE
- NS_DECL_NSIPROMPTSERVICE2
- NS_DECL_NSINONBLOCKINGALERTSERVICE
-
- GeckoPromptService();
- virtual ~GeckoPromptService();
-};
-
-#endif /* GECKO_PROMPT_SERVICE_H */
diff --git a/embed/xulrunner/components/GeckoSpellCheckEngine.cpp b/embed/xulrunner/components/GeckoSpellCheckEngine.cpp
deleted file mode 100644
index 0b1257b41..000000000
--- a/embed/xulrunner/components/GeckoSpellCheckEngine.cpp
+++ /dev/null
@@ -1,200 +0,0 @@
-/*
- * Copyright © 2006 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include <stdio.h>
-#include <stdlib.h>
-
-#include <nsStringGlue.h>
-
-#include <mozIPersonalDictionary.h>
-#include <nsMemory.h>
-
-#include "ephy-debug.h"
-
-#include "GeckoSpellCheckEngine.h"
-
-GeckoSpellCheckEngine::GeckoSpellCheckEngine ()
-{
- LOG ("GeckoSpellCheckEngine ctor [%p]", (void*) this);
- mSpeller = ephy_spell_check_get_default ();
-}
-
-GeckoSpellCheckEngine::~GeckoSpellCheckEngine ()
-{
- LOG ("GeckoSpellCheckEngine dtor [%p]", (void*) this);
- g_object_unref (mSpeller);
-}
-
-NS_IMPL_ISUPPORTS1 (GeckoSpellCheckEngine,
- mozISpellCheckingEngine)
-
-/* nsISpellCheckEngine implementation */
-
-/* attribute wstring dictionary; */
-NS_IMETHODIMP GeckoSpellCheckEngine::GetDictionary (PRUnichar * *aDictionary)
-{
- /* Gets the identifier of the current dictionary */
- char *code = ephy_spell_check_get_language (mSpeller);
- if (!code) {
- return NS_ERROR_FAILURE;
- }
-
- *aDictionary = ToNewUnicode (NS_ConvertUTF8toUTF16 (code));
- g_free (code);
-
- return NS_OK;
-}
-
-NS_IMETHODIMP GeckoSpellCheckEngine::SetDictionary (const PRUnichar * aDictionary)
-{
- return NS_OK;
-}
-
-/* readonly attribute wstring language; */
-NS_IMETHODIMP GeckoSpellCheckEngine::GetLanguage (PRUnichar * *aLanguage)
-{
- /* Gets the identifier of the current dictionary */
- char *code = ephy_spell_check_get_language (mSpeller);
- if (!code) {
- return NS_ERROR_FAILURE;
- }
-
- *aLanguage = ToNewUnicode (NS_ConvertUTF8toUTF16 (code));
- g_free (code);
-
- return NS_OK;
-}
-
-/* readonly attribute boolean providesPersonalDictionary; */
-NS_IMETHODIMP GeckoSpellCheckEngine::GetProvidesPersonalDictionary (PRBool *aProvidesPersonalDictionary)
-{
- *aProvidesPersonalDictionary = PR_FALSE;
- return NS_OK;
-}
-
-/* readonly attribute boolean providesWordUtils; */
-NS_IMETHODIMP GeckoSpellCheckEngine::GetProvidesWordUtils (PRBool *aProvidesWordUtils)
-{
- *aProvidesWordUtils = PR_FALSE;
- return NS_OK;
-}
-
-/* readonly attribute wstring name; */
-NS_IMETHODIMP GeckoSpellCheckEngine::GetName (PRUnichar * *aName)
-{
- /* It's fine to leave this unimplemented */
- return NS_ERROR_NOT_IMPLEMENTED;
-}
-
-/* readonly attribute wstring copyright; */
-NS_IMETHODIMP GeckoSpellCheckEngine::GetCopyright (PRUnichar * *aCopyright)
-{
- /* It's fine to leave this unimplemented */
- return NS_ERROR_NOT_IMPLEMENTED;
-}
-
-/* attribute mozIPersonalDictionary personalDictionary; */
-NS_IMETHODIMP GeckoSpellCheckEngine::GetPersonalDictionary (mozIPersonalDictionary * *aPersonalDictionary)
-{
- NS_IF_ADDREF (*aPersonalDictionary = mPersonalDictionary);
- return NS_OK;
-}
-
-NS_IMETHODIMP GeckoSpellCheckEngine::SetPersonalDictionary (mozIPersonalDictionary * aPersonalDictionary)
-{
- mPersonalDictionary = aPersonalDictionary;
- return NS_OK;
-}
-
-/* void getDictionaryList ([array, size_is (count)] out wstring dictionaries, out PRUint32 count); */
-NS_IMETHODIMP
-GeckoSpellCheckEngine::GetDictionaryList (PRUnichar ***_dictionaries,
- PRUint32 *_count)
-{
- *_count = 1;
- *_dictionaries = (PRUnichar **)nsMemory::Alloc(sizeof(PRUnichar *)); // only one entry
- *_dictionaries[0] = ToNewUnicode (NS_LITERAL_STRING ("en"));
- return NS_OK;
-}
-
-/* boolean check (in wstring word); */
-NS_IMETHODIMP GeckoSpellCheckEngine::Check (const PRUnichar *word,
- PRBool *_retval)
-{
- NS_ENSURE_STATE (mSpeller);
- NS_ENSURE_ARG (word);
-
- NS_ConvertUTF16toUTF8 converted (word);
-
- gboolean correct = FALSE;
- if (!ephy_spell_check_check_word (mSpeller,
- converted.get (),
- converted.Length (),
- &correct))
- return NS_ERROR_FAILURE;
-
- *_retval = correct != FALSE;
-
- return NS_OK;
-}
-
-/* void suggest (in wstring word, [array, size_is (count)] out wstring suggestions, out PRUint32 count); */
-NS_IMETHODIMP GeckoSpellCheckEngine::Suggest (const PRUnichar *word,
- PRUnichar ***_suggestions,
- PRUint32 *_count)
-{
-#if 0
- NS_ENSURE_STATE (mSpeller);
- NS_ENSURE_ARG (word);
-
- NS_ConvertUTF16toUTF8 converted (word);
-
- gsize count;
- char **suggestions = ephy_spell_check_get_suggestions (mSpeller,
- converted.get (),
- converted.Length (),
- &count);
-
- *_count = count;
- *_suggestions = nsnull;
-
- PRUnichar **array = nsnull;
- if (count > 0) {
- NS_ASSERTION (suggestions, "Count > 0 but suggestions are NULL?");
- array = (PRUnichar **) nsMemory::Alloc (count * sizeof (PRUnichar *));
- if (array) {
- *_suggestions = array;
-
- for (gsize i = 0; i < count; ++i) {
- NS_ConvertUTF8toUTF16 sugg (suggestions[i]);
- array[i] = ToNewUnicode (sugg);
- }
- }
-
- ephy_spell_check_free_suggestions (mSpeller, suggestions);
- }
-
- return array ? NS_OK : NS_ERROR_OUT_OF_MEMORY;
-#endif
- return NS_ERROR_NOT_IMPLEMENTED;
-}
diff --git a/embed/xulrunner/components/GeckoSpellCheckEngine.h b/embed/xulrunner/components/GeckoSpellCheckEngine.h
deleted file mode 100644
index b70f6c970..000000000
--- a/embed/xulrunner/components/GeckoSpellCheckEngine.h
+++ /dev/null
@@ -1,52 +0,0 @@
-/*
- * Copyright © 2006 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#ifndef GECKO_SPELL_CHECK_ENGINE_H
-#define GECKO_SPELL_CHECK_ENGINE_H
-
-#include <nsCOMPtr.h>
-#include <mozISpellCheckingEngine.h>
-
-#include "ephy-spell-check.h"
-
-class mozIPersonalDictionary;
-
-/* 26948b8b-d136-4a78-a9c5-3a145812b649 */
-#define GECKO_SPELL_CHECK_ENGINE_IID \
-{ 0x26948b8b, 0xd136, 0x4a78, { 0xa9, 0xc5, 0x3a, 0x14, 0x58, 0x12, 0xb6, 0x49 } }
-
-#define GECKO_SPELL_CHECK_ENGINE_CONTRACTID "@mozilla.org/spellchecker/myspell;1"
-#define GECKO_SPELL_CHECK_ENGINE_CLASSNAME "Gecko Print Settings"
-
-class GeckoSpellCheckEngine : public mozISpellCheckingEngine
-{
- public:
- GeckoSpellCheckEngine();
- virtual ~GeckoSpellCheckEngine();
-
- NS_DECL_ISUPPORTS
- NS_DECL_MOZISPELLCHECKINGENGINE
-
- private:
- nsCOMPtr<mozIPersonalDictionary> mPersonalDictionary;
- EphySpellCheck *mSpeller;
-};
-
-#endif /* GECKO_SPELL_CHECK_ENGINE_H */
diff --git a/embed/xulrunner/components/GlobalHistory.cpp b/embed/xulrunner/components/GlobalHistory.cpp
deleted file mode 100644
index a2fd79960..000000000
--- a/embed/xulrunner/components/GlobalHistory.cpp
+++ /dev/null
@@ -1,221 +0,0 @@
-/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */
-/*
- * Copyright © 2001, 2004 Philip Langdale
- * Copyright © 2004 Christian Persch
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include <nsStringGlue.h>
-
-#include <nsIURI.h>
-
-#include "ephy-embed-shell.h"
-
-#include "GlobalHistory.h"
-
-
-#define MAX_TITLE_LENGTH 2048
-#define MAX_URL_LENGTH 16384
-
-#ifdef HAVE_NSIGLOBALHISTORY3_H
-NS_IMPL_ISUPPORTS2 (MozGlobalHistory, nsIGlobalHistory2, nsIGlobalHistory3)
-#else
-NS_IMPL_ISUPPORTS1 (MozGlobalHistory, nsIGlobalHistory2)
-#endif /* HAVE_NSIGLOBALHISTORY3_H */
-
-MozGlobalHistory::MozGlobalHistory ()
-{
- mGlobalHistory = EPHY_HISTORY (ephy_embed_shell_get_global_history (embed_shell));
-
- mHistoryListener = new EphyHistoryListener ();
- mHistoryListener->Init (mGlobalHistory);
-}
-
-MozGlobalHistory::~MozGlobalHistory ()
-{
-}
-
-/* void addURI (in nsIURI aURI, in boolean aRedirect, in boolean aToplevel, in nsIURI aReferrer); */
-NS_IMETHODIMP MozGlobalHistory::AddURI(nsIURI *aURI,
- PRBool aRedirect,
- PRBool aToplevel,
- nsIURI *aReferrer)
-{
- nsresult rv;
-
- NS_ENSURE_ARG (aURI);
-
- // filter out unwanted URIs such as chrome: etc
- // The model is really if we don't know differently then add which basically
- // means we are suppose to try all the things we know not to allow in and
- // then if we don't bail go on and allow it in. But here lets compare
- // against the most common case we know to allow in and go on and say yes
- // to it.
-
- PRBool isHTTP = PR_FALSE, isHTTPS = PR_FALSE;
- rv = aURI->SchemeIs("http", &isHTTP);
- rv |= aURI->SchemeIs("https", &isHTTPS);
- NS_ENSURE_SUCCESS (rv, NS_ERROR_FAILURE);
-
- if (!isHTTP && !isHTTPS)
- {
- static const char *schemes[] = { "javascript",
- "data",
- "about",
- "chrome",
- "resource",
- "view-source" };
-
- for (PRUint32 i = 0; i < G_N_ELEMENTS (schemes); ++i)
- {
- PRBool result = PR_FALSE;
- if (NS_SUCCEEDED (aURI->SchemeIs (schemes[i], &result)) && result)
- {
- return NS_OK;
- }
- }
- }
-
- nsCString spec;
- rv = aURI->GetSpec(spec);
- NS_ENSURE_TRUE (NS_SUCCEEDED(rv) && spec.Length(), rv);
-
- if (spec.Length () > MAX_URL_LENGTH) return NS_OK;
-
- ephy_history_add_page (mGlobalHistory, spec.get(), aRedirect, aToplevel);
-
- return NS_OK;
-}
-
-/* boolean isVisited (in nsIURI aURI); */
-NS_IMETHODIMP MozGlobalHistory::IsVisited(nsIURI *aURI,
- PRBool *_retval)
-{
- NS_ENSURE_ARG (aURI);
-
- *_retval = PR_FALSE;
-
- nsCString spec;
- aURI->GetSpec(spec);
-
- if (spec.Length () > MAX_URL_LENGTH) return NS_OK;
-
- *_retval = ephy_history_is_page_visited (mGlobalHistory, spec.get());
-
- return NS_OK;
-}
-
-/* void setPageTitle (in nsIURI aURI, in AString aTitle); */
-NS_IMETHODIMP MozGlobalHistory::SetPageTitle(nsIURI *aURI,
- const nsAString & aTitle)
-{
- NS_ENSURE_ARG (aURI);
-
- nsCString spec;
- aURI->GetSpec(spec);
-
- if (spec.Length () > MAX_URL_LENGTH) return NS_OK;
-
- nsString uTitle (aTitle);
-
- /* This depends on the assumption that
- * typeof(PRUnichar) == typeof (gunichar2) == uint16,
- * which should be pretty safe.
- */
- glong n_read = 0, n_written = 0;
- char *converted = g_utf16_to_utf8 ((gunichar2*) uTitle.get(), MAX_TITLE_LENGTH,
- &n_read, &n_written, NULL);
- /* FIXME loop from the end while !g_unichar_isspace (char)? */
- if (converted == NULL) return NS_OK;
-
- ephy_history_set_page_title (mGlobalHistory, spec.get(), converted);
-
- g_free (converted);
-
- return NS_OK;
-}
-
-#ifdef HAVE_NSIGLOBALHISTORY3_H
-
-/* unsigned long getURIGeckoFlags(in nsIURI aURI); */
-NS_IMETHODIMP
-MozGlobalHistory::GetURIGeckoFlags(nsIURI *aURI,
- PRUint32* aFlags)
-{
- *aFlags = 0;
-
- nsCString spec;
- aURI->GetSpec(spec);
-
- if (spec.Length () > MAX_URL_LENGTH) return NS_OK;
-
- EphyNode *page = ephy_history_get_page (mGlobalHistory, spec.get());
-
- GValue value = { 0, };
- if (page != NULL &&
- ephy_node_get_property (page, EPHY_NODE_PAGE_PROP_GECKO_FLAGS, &value))
- {
- *aFlags = (PRUint32) (gulong) g_value_get_long (&value);
- g_value_unset (&value);
-
- return NS_OK;
- }
-
- return NS_ERROR_FAILURE;
-}
-
-/* void setURIGeckoFlags(in nsIURI aURI, in unsigned long aFlags); */
-NS_IMETHODIMP
-MozGlobalHistory::SetURIGeckoFlags(nsIURI *aURI,
- PRUint32 aFlags)
-{
- nsCString spec;
- aURI->GetSpec(spec);
-
- if (spec.Length () > MAX_URL_LENGTH) return NS_OK;
-
- EphyNode *page = ephy_history_get_page (mGlobalHistory, spec.get());
- if (page != NULL)
- {
- ephy_node_set_property_long (page,
- EPHY_NODE_PAGE_PROP_GECKO_FLAGS,
- aFlags);
- return NS_OK;
- }
-
- return NS_ERROR_FAILURE;
-}
-
-/* void addDocumentRedirect (in nsIChannel
- aOldChannel,
- in nsIChannel aNewChannel,
- in PRInt32 aFlags,
- in boolean aTopLevel); */
-NS_IMETHODIMP
-MozGlobalHistory::AddDocumentRedirect(nsIChannel *aOldChannel,
- nsIChannel *aNewChannel,
- PRInt32 aFlags,
- PRBool aTopLevel)
-{
- return NS_ERROR_NOT_IMPLEMENTED;
-}
-
-#endif /* HAVE_NSIGLOBALHISTORY3_H */
diff --git a/embed/xulrunner/components/GlobalHistory.h b/embed/xulrunner/components/GlobalHistory.h
deleted file mode 100644
index 8397874a0..000000000
--- a/embed/xulrunner/components/GlobalHistory.h
+++ /dev/null
@@ -1,68 +0,0 @@
-/*
- * Copyright © 2001, 2004 Philip Langdale
- * Copyright © 2004 Christian Persch
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#ifndef EPHY_GLOBAL_HISTORY_H
-#define EPHY_GLOBAL_HISTORY_H
-
-#ifdef HAVE_NSIGLOBALHISTORY3_H
-#include <nsIGlobalHistory3.h>
-#else
-#include <nsIGlobalHistory2.h>
-#endif /* HAVE_NSIGLOBALHISTORY3_H */
-
-#include <nsAutoPtr.h>
-#include <nsCOMPtr.h>
-
-#include "ephy-history.h"
-
-#include "EphyHistoryListener.h"
-
-#define EPHY_GLOBALHISTORY_CLASSNAME "Epiphany Global History Implementation"
-
-#define EPHY_GLOBALHISTORY_CID \
-{ 0xbe0c42c1, \
- 0x39d4, \
- 0x4271, \
- { 0xb7, 0x9e, 0xf7, 0xaa, 0x49, 0xeb, 0x6a, 0x15} \
-}
-
-#ifdef HAVE_NSIGLOBALHISTORY3_H
-class MozGlobalHistory: public nsIGlobalHistory3
-#else
-class MozGlobalHistory: public nsIGlobalHistory2
-#endif /* HAVE_NSIGLOBALHISTORY3_H */
-{
- public:
- MozGlobalHistory ();
- virtual ~MozGlobalHistory();
-
- NS_DECL_ISUPPORTS
- NS_DECL_NSIGLOBALHISTORY2
-#ifdef HAVE_NSIGLOBALHISTORY3_H
- NS_DECL_NSIGLOBALHISTORY3
-#endif /* HAVE_NSIGLOBALHISTORY3_H */
-
- private:
- EphyHistory *mGlobalHistory;
- nsRefPtr<EphyHistoryListener> mHistoryListener;
-};
-
-#endif /* EPHY_GLOBAL_HISTORY_H */
diff --git a/embed/xulrunner/components/GtkNSSClientAuthDialogs.cpp b/embed/xulrunner/components/GtkNSSClientAuthDialogs.cpp
deleted file mode 100644
index 12b74573f..000000000
--- a/embed/xulrunner/components/GtkNSSClientAuthDialogs.cpp
+++ /dev/null
@@ -1,284 +0,0 @@
-/*
- * GtkNSSClientAuthDialogs.cpp
- *
- * Copyright © 2003 Crispin Flowerday <gnome@flowerday.cx>
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include <glib/gi18n.h>
-#include <gtk/gtkcelllayout.h>
-#include <gtk/gtkcellrenderer.h>
-#include <gtk/gtkcellrenderertext.h>
-#include <gtk/gtkcombobox.h>
-#include <gtk/gtkdialog.h>
-#include <gtk/gtkexpander.h>
-#include <gtk/gtkhbox.h>
-#include <gtk/gtkimage.h>
-#include <gtk/gtklabel.h>
-#include <gtk/gtkliststore.h>
-#include <gtk/gtkmenuitem.h>
-#include <gtk/gtkoptionmenu.h>
-#include <gtk/gtkprogressbar.h>
-#include <gtk/gtkscrolledwindow.h>
-#include <gtk/gtkstock.h>
-#include <gtk/gtktextbuffer.h>
-#include <gtk/gtktextview.h>
-#include <gtk/gtktogglebutton.h>
-#include <gtk/gtktreemodel.h>
-#include <gtk/gtkvbox.h>
-
-#include <nsStringGlue.h>
-
-#include <nsIDOMWindow.h>
-#include <nsIInterfaceRequestor.h>
-#include <nsIInterfaceRequestorUtils.h>
-#include <nsIServiceManager.h>
-
-#include "ephy-debug.h"
-#include "ephy-gui.h"
-#include "ephy-state.h"
-#include "ephy-stock-icons.h"
-
-#include "AutoJSContextStack.h"
-#include "AutoWindowModalState.h"
-#include "EphyUtils.h"
-
-#include "GtkNSSClientAuthDialogs.h"
-
-GtkNSSClientAuthDialogs::GtkNSSClientAuthDialogs()
-{
- LOG ("GtkNSSClientAuthDialogs ctor (%p)", this);
-}
-
-
-GtkNSSClientAuthDialogs::~GtkNSSClientAuthDialogs()
-{
- LOG ("GtkNSSClientAuthDialogs dtor (%p)", this);
-}
-
-NS_IMPL_THREADSAFE_ISUPPORTS1 (GtkNSSClientAuthDialogs,
- nsIClientAuthDialogs)
-
-/**
- * Indent a widget according the HIG
- *
- * @returns: The new indented widget
- */
-static GtkWidget*
-higgy_indent_widget (GtkWidget *widget)
-{
- GtkWidget *hbox;
- GtkWidget *label;
-
- hbox = gtk_hbox_new (FALSE, 6);
-
- label = gtk_label_new ("");
- gtk_box_pack_start (GTK_BOX(hbox), label, FALSE, TRUE, 6);
- gtk_widget_show (label);
-
- gtk_box_pack_start (GTK_BOX(hbox), widget, TRUE, TRUE, 0);
-
- return hbox;
-}
-
-static void
-combo_changed_cb (GtkComboBox *combo, GtkTextView *textview)
-{
- GtkTreeModel *model;
- GtkTreeIter iter;
- GtkTextBuffer *buffer;
- int index;
-
- model = gtk_combo_box_get_model (combo);
- index = gtk_combo_box_get_active (combo);
- buffer = gtk_text_view_get_buffer (textview);
-
- if (gtk_tree_model_iter_nth_child (model, &iter, NULL, index))
- {
- char *text;
-
- gtk_tree_model_get (model, &iter, 1, &text, -1);
-
- gtk_text_buffer_set_text (buffer, text, -1);
-
- g_free (text);
- }
- else
- {
- gtk_text_buffer_set_text (buffer, "", -1);
- }
-}
-
-NS_IMETHODIMP
-GtkNSSClientAuthDialogs::ChooseCertificate (nsIInterfaceRequestor *ctx,
- const PRUnichar *cn,
- const PRUnichar *organization,
- const PRUnichar *issuer,
- const PRUnichar **certNickList,
- const PRUnichar **certDetailsList,
- PRUint32 count, PRInt32 *selectedIndex,
- PRBool *canceled)
-{
- GtkWidget *dialog, *label, *vbox, *textview;
- GtkWidget *details, *expander, *hbox, *image;
- GtkWidget *combo;
- GtkListStore *store;
- GtkTreeIter iter;
- GtkCellRenderer *renderer;
- char *msg, *markup_text;
- PRUint32 i;
-
- nsresult rv;
- AutoJSContextStack stack;
- rv = stack.Init ();
- if (NS_FAILED (rv)) return rv;
-
- nsCOMPtr<nsIDOMWindow> parent (do_GetInterface (ctx));
- GtkWindow *gparent = GTK_WINDOW (EphyUtils::FindGtkParent (parent));
-
- AutoWindowModalState modalState (parent);
-
- dialog = gtk_dialog_new_with_buttons ("",
- GTK_WINDOW (gparent),
- GTK_DIALOG_DESTROY_WITH_PARENT,
- GTK_STOCK_CANCEL,
- GTK_RESPONSE_CANCEL,
- _("_Select Certificate"),
- GTK_RESPONSE_OK,
- (char *) NULL);
-
- if (gparent)
- {
- gtk_window_group_add_window (ephy_gui_ensure_window_group (gparent),
- GTK_WINDOW (dialog));
- }
-
- gtk_window_set_icon_name (GTK_WINDOW (dialog), EPHY_STOCK_EPHY);
-
- gtk_dialog_set_has_separator (GTK_DIALOG (dialog), FALSE);
- gtk_window_set_resizable (GTK_WINDOW (dialog), FALSE);
- gtk_container_set_border_width (GTK_CONTAINER (dialog), 5);
- gtk_box_set_spacing (GTK_BOX(GTK_DIALOG (dialog)->vbox), 14); /* 24 = 2 * 5 + 14 */
- gtk_dialog_set_default_response (GTK_DIALOG (dialog), GTK_RESPONSE_OK);
-
- hbox = gtk_hbox_new (FALSE, 12);
- gtk_container_set_border_width (GTK_CONTAINER (hbox), 5);
- gtk_box_pack_start (GTK_BOX (GTK_DIALOG (dialog)->vbox), hbox, FALSE, FALSE, 0);
- gtk_widget_show (hbox);
-
- image = gtk_image_new_from_stock (GTK_STOCK_DIALOG_WARNING,
- GTK_ICON_SIZE_DIALOG);
- gtk_misc_set_alignment (GTK_MISC (image), 0.5, 0.0);
- gtk_box_pack_start (GTK_BOX (hbox), image, FALSE, FALSE, 0);
- gtk_widget_show (image);
-
- vbox = gtk_vbox_new (FALSE, 12);
- gtk_box_pack_start (GTK_BOX (hbox), vbox, TRUE, TRUE, 0);
- gtk_widget_show (vbox);
-
- label = gtk_label_new (NULL);
- gtk_label_set_use_markup (GTK_LABEL (label), TRUE);
- gtk_label_set_line_wrap (GTK_LABEL (label), TRUE);
- gtk_label_set_selectable (GTK_LABEL (label), TRUE);
- gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.0);
- gtk_widget_show (label);
- gtk_box_pack_start (GTK_BOX (vbox), label, FALSE, FALSE, 0);
-
- msg = g_markup_printf_escaped (_("Choose a certificate to present as identification to “%s”."),
- NS_ConvertUTF16toUTF8 (cn).get());
- markup_text = g_strdup_printf ("<span weight=\"bold\" size=\"larger\">%s</span>\n\n%s",
- _("Select a certificate to identify yourself."),
- msg);
- gtk_label_set_markup (GTK_LABEL (label), markup_text);
- g_free (msg);
- g_free (markup_text);
-
- /* Create and populate the combo */
- store = gtk_list_store_new (2, G_TYPE_STRING, G_TYPE_STRING);
- for (i = 0; i < count; i++)
- {
- gtk_list_store_append (store, &iter);
- gtk_list_store_set (store, &iter,
- 0, NS_ConvertUTF16toUTF8 (certNickList[i]).get(),
- 1, NS_ConvertUTF16toUTF8 (certDetailsList[i]).get(),
- -1);
- }
-
- combo = gtk_combo_box_new_with_model (GTK_TREE_MODEL (store));
- g_object_unref (store);
-
- renderer = gtk_cell_renderer_text_new ();
- gtk_cell_layout_pack_start (GTK_CELL_LAYOUT (combo), renderer, TRUE);
- gtk_cell_layout_set_attributes (GTK_CELL_LAYOUT (combo), renderer,
- "text", 0,
- (char *) NULL);
-
- gtk_widget_show (combo);
- gtk_box_pack_start (GTK_BOX (vbox), combo, FALSE, TRUE, 0);
-
- expander = gtk_expander_new_with_mnemonic (_("Certificate _Details"));
- ephy_state_add_expander (GTK_WIDGET (expander), "client-auth-dialog-expander", FALSE);
-
- gtk_widget_show (expander);
- gtk_box_pack_start (GTK_BOX(GTK_DIALOG(dialog)->vbox), expander, FALSE, FALSE, 0);
-
- /* Create the text box */
- textview = gtk_text_view_new ();
- gtk_text_view_set_editable (GTK_TEXT_VIEW (textview), FALSE);
- gtk_text_view_set_cursor_visible (GTK_TEXT_VIEW (textview), FALSE);
- gtk_text_view_set_wrap_mode (GTK_TEXT_VIEW (textview), GTK_WRAP_WORD);
- gtk_widget_set_size_request (GTK_WIDGET (textview), -1, 100);
- gtk_widget_show (textview);
-
- details = gtk_scrolled_window_new (NULL, NULL);
- gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (details), GTK_POLICY_AUTOMATIC,
- GTK_POLICY_AUTOMATIC);
- gtk_scrolled_window_set_shadow_type (GTK_SCROLLED_WINDOW (details), GTK_SHADOW_IN);
- gtk_container_add (GTK_CONTAINER (details), textview);
- gtk_widget_show (details);
-
- details = higgy_indent_widget (details);
- gtk_container_set_border_width (GTK_CONTAINER (details), 5);
- gtk_widget_show (details);
-
- gtk_container_add (GTK_CONTAINER (expander), details);
-
- g_signal_connect (G_OBJECT (combo), "changed",
- G_CALLBACK (combo_changed_cb),
- textview);
-
- gtk_combo_box_set_active (GTK_COMBO_BOX (combo), 0);
-
- /* run the dialog */
- int res = gtk_dialog_run (GTK_DIALOG (dialog));
- if (res == GTK_RESPONSE_OK)
- {
- *canceled = PR_FALSE;
- *selectedIndex = gtk_combo_box_get_active (GTK_COMBO_BOX (combo));
- }
- else
- {
- *canceled = PR_TRUE;
- }
-
- gtk_widget_destroy (dialog);
- return NS_OK;
-}
diff --git a/embed/xulrunner/components/GtkNSSClientAuthDialogs.h b/embed/xulrunner/components/GtkNSSClientAuthDialogs.h
deleted file mode 100644
index 0aa582700..000000000
--- a/embed/xulrunner/components/GtkNSSClientAuthDialogs.h
+++ /dev/null
@@ -1,45 +0,0 @@
-/*
- * Copyright © 2003 Crispin Flowerday <gnome@flowerday.cx>
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- *
- * $Id$
- */
-
-#ifndef GTKNSSCLIENTAUTHDIALOGS_H
-#define GTKNSSCLIENTAUTHDIALOGS_H 1
-
-#include <nsIClientAuthDialogs.h>
-
-// 55b3837e-dbde-4c24-9247-f328e3012485
-#define GTK_NSSCLIENTAUTHDIALOGS_CID \
- {0x55b3837e, 0xdbde, 0x4c24, {0x92, 0x47, 0xf3, 0x28, 0xe3, 0x01, 0x24, 0x85}}
-
-#define GTK_NSSCLIENTAUTHDIALOGS_CLASSNAME "Gtk NSS Client Auth Dialogs"
-
-class GtkNSSClientAuthDialogs
-: public nsIClientAuthDialogs
-{
-public:
- NS_DECL_ISUPPORTS
- NS_DECL_NSICLIENTAUTHDIALOGS
-
- GtkNSSClientAuthDialogs();
- virtual ~GtkNSSClientAuthDialogs();
-};
-
-
-#endif /* GTKNSSCLIENTAUTHDIALOGS_H */
diff --git a/embed/xulrunner/components/GtkNSSDialogs.cpp b/embed/xulrunner/components/GtkNSSDialogs.cpp
deleted file mode 100644
index 51581f8db..000000000
--- a/embed/xulrunner/components/GtkNSSDialogs.cpp
+++ /dev/null
@@ -1,1695 +0,0 @@
-/*
- * Copyright © 2003 Crispin Flowerday <gnome@flowerday.cx>
- * Copyright © 2006 Christian Persch
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-/*
- * This file provides Gtk implementations of the mozilla Certificate dialogs
- * such as the ones displayed when connecting to a site with a self-signed
- * or expired certificate.
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include <time.h>
-
-#include <glib/gi18n.h>
-#include <gtk/gtkalignment.h>
-#include <gtk/gtkbutton.h>
-#include <gtk/gtkcellrenderertext.h>
-#include <gtk/gtkcheckbutton.h>
-#include <gtk/gtkdialog.h>
-#include <gtk/gtkeditable.h>
-#include <gtk/gtkentry.h>
-#include <gtk/gtkhbox.h>
-#include <gtk/gtkimage.h>
-#include <gtk/gtklabel.h>
-#include <gtk/gtkmessagedialog.h>
-#include <gtk/gtkprogressbar.h>
-#include <gtk/gtksizegroup.h>
-#include <gtk/gtkstock.h>
-#include <gtk/gtktable.h>
-#include <gtk/gtktextbuffer.h>
-#include <gtk/gtktextview.h>
-#include <gtk/gtktogglebutton.h>
-#include <gtk/gtktreeselection.h>
-#include <gtk/gtktreestore.h>
-#include <gtk/gtktreeview.h>
-#include <gtk/gtkvbox.h>
-#include <gtk/gtkcombobox.h>
-#include <gconf/gconf-client.h>
-#include <glade/glade-xml.h>
-
-#include <nsStringGlue.h>
-
-#include <nsCOMPtr.h>
-#include <nsIArray.h>
-#include <nsIASN1Object.h>
-#include <nsIASN1Sequence.h>
-#include <nsICRLInfo.h>
-#include <nsIDOMWindow.h>
-#include <nsIInterfaceRequestor.h>
-#include <nsIInterfaceRequestorUtils.h>
-#include <nsIMutableArray.h>
-#include <nsIPKCS11ModuleDB.h>
-#include <nsIPKCS11Slot.h>
-#include <nsIPK11Token.h>
-#include <nsIPK11TokenDB.h>
-#include <nsIServiceManager.h>
-#include <nsISimpleEnumerator.h>
-#include <nsIX509CertDB.h>
-#include <nsIX509Cert.h>
-#include <nsIX509CertValidity.h>
-#include <nsMemory.h>
-#include <nsServiceManagerUtils.h>
-
-#ifdef HAVE_NSIMUTABLEARRAY_H
-#include <nsIMutableArray.h>
-#endif
-
-#include "ephy-file-helpers.h"
-#include "ephy-gui.h"
-#include "ephy-password-dialog.h"
-#include "ephy-stock-icons.h"
-
-#include "AutoJSContextStack.h"
-#include "AutoWindowModalState.h"
-#include "EphyUtils.h"
-
-#include "GtkNSSDialogs.h"
-
-NS_DEFINE_CID (kX509CertCID, NS_IX509CERT_IID);
-NS_DEFINE_CID (kASN1ObjectCID, NS_IASN1OBJECT_IID);
-
-enum
-{
- NSSDIALOG_RESPONSE_VIEW_CERT = 10
-};
-
-GtkNSSDialogs::GtkNSSDialogs ()
-{
-}
-
-GtkNSSDialogs::~GtkNSSDialogs ()
-{
-}
-
-NS_IMPL_THREADSAFE_ISUPPORTS5 (GtkNSSDialogs,
- nsICertificateDialogs,
- nsIBadCertListener,
- nsITokenPasswordDialogs,
- nsITokenDialogs,
- nsIDOMCryptoDialogs)
-
-/* There's also nsICertPickDialogs which is implemented in mozilla
- * but has no callers. So we don't implement it.
- * Same for nsIUserCertPicker which is only used in mailnews.
- */
-
-/**
- * Call the mozilla service to display a certificate
- */
-static void
-view_certificate (nsIInterfaceRequestor *ctx, nsIX509Cert *cert)
-{
- nsresult rv;
- nsCOMPtr<nsICertificateDialogs> certDialogs =
- do_GetService (NS_CERTIFICATEDIALOGS_CONTRACTID, &rv);
- NS_ENSURE_SUCCESS (rv, );
-
- certDialogs->ViewCert (ctx, cert);
-}
-
-/**
- * Indent a widget according the HIG
- *
- * @returns: The new indented widget
- */
-static GtkWidget*
-higgy_indent_widget (GtkWidget *widget)
-{
- GtkWidget *hbox;
- GtkWidget *label;
-
- hbox = gtk_hbox_new (FALSE, 6);
-
- label = gtk_label_new (NULL);
- gtk_box_pack_start (GTK_BOX(hbox), label, FALSE, TRUE, 6);
- gtk_widget_show (label);
-
- gtk_box_pack_start (GTK_BOX(hbox), widget, TRUE, TRUE, 0);
-
- return hbox;
-}
-
-/**
- * Setup up a dialog with the correct HIG'gy spacings, adding the content_widget
- */
-static void
-higgy_setup_dialog (GtkDialog *dialog, const gchar *stock_icon,
- GtkWidget **content_label,
- GtkWidget **content_vbox)
-{
- GtkWidget *hbox, *label, *image, *vbox;
-
- g_return_if_fail (GTK_IS_DIALOG (dialog));
- g_return_if_fail (content_label);
-
- gtk_dialog_set_has_separator (dialog, FALSE);
- gtk_window_set_resizable (GTK_WINDOW (dialog), FALSE);
- gtk_container_set_border_width (GTK_CONTAINER (dialog), 5);
-
- hbox = gtk_hbox_new (FALSE, 12);
- gtk_container_set_border_width (GTK_CONTAINER (hbox), 5);
- gtk_container_add (GTK_CONTAINER (GTK_DIALOG (dialog)->vbox), hbox);
-
- image = gtk_image_new_from_stock (stock_icon, GTK_ICON_SIZE_DIALOG);
- gtk_misc_set_alignment (GTK_MISC (image), 0.5, 0.0);
- gtk_box_pack_start (GTK_BOX (hbox), image, FALSE, FALSE, 0);
-
- vbox = gtk_vbox_new (FALSE, 12);
- gtk_box_pack_start (GTK_BOX (hbox), vbox, TRUE, TRUE, 0);
-
- label = gtk_label_new (NULL);
- gtk_label_set_use_markup (GTK_LABEL (label), TRUE);
- gtk_label_set_line_wrap (GTK_LABEL (label), TRUE);
- gtk_label_set_selectable (GTK_LABEL (label), TRUE);
- gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.0);
-
- gtk_box_pack_start (GTK_BOX (vbox), label, FALSE, FALSE, 0);
-
- gtk_widget_show (image);
- gtk_widget_show (vbox);
- gtk_widget_show (hbox);
- gtk_widget_show (label);
-
- /* Set up the spacing for the dialog internal widgets */
- gtk_box_set_spacing (GTK_BOX(dialog->vbox), 14); /* 24 = 2 * 5 + 14 */
-
- *content_label = label;
- if (content_vbox)
- {
- *content_vbox = vbox;
- }
-}
-
-
-/**
- * Display a dialog box, showing 'View Certificate', 'Cancel',
- * and 'Accept' buttons. Optionally a checkbox can be shown,
- * or the text can be NULL to avoid it being displayed
- *
- * @returns: GTK_RESPONSE_ACCEPT if the user clicked Accept
- */
-static gint
-display_cert_warning_box (nsIInterfaceRequestor *ctx,
- nsIX509Cert *cert,
- const char *markup_text,
- const char *checkbox_text,
- gboolean *checkbox_value,
- const char *affirmative_text)
-{
- GtkWidget *dialog, *label, *checkbox, *vbox, *button;
- int res;
-
- g_return_val_if_fail (markup_text, GTK_RESPONSE_CANCEL);
- g_return_val_if_fail (!checkbox_text || checkbox_value, GTK_RESPONSE_CANCEL);
-
- nsresult rv;
- AutoJSContextStack stack;
- rv = stack.Init ();
- if (NS_FAILED (rv)) return rv;
-
- /* NOTE: Due to a mozilla bug [https://bugzilla.mozilla.org/show_bug.cgi?id=306288],
- * we will always end up without a parent!
- */
- nsCOMPtr<nsIDOMWindow> parent (do_GetInterface (ctx));
- GtkWindow *gparent = GTK_WINDOW (EphyUtils::FindGtkParent (parent));
-
- AutoWindowModalState modalState (parent);
-
- dialog = gtk_dialog_new_with_buttons ("", gparent,
- GTK_DIALOG_DESTROY_WITH_PARENT,
- (char *) NULL);
- if (gparent)
- {
- gtk_window_group_add_window (ephy_gui_ensure_window_group (gparent),
- GTK_WINDOW (dialog));
- }
-
- gtk_dialog_set_has_separator (GTK_DIALOG (dialog), FALSE);
- gtk_window_set_icon_name (GTK_WINDOW (dialog), EPHY_STOCK_EPHY);
-
- higgy_setup_dialog (GTK_DIALOG (dialog),
- GTK_STOCK_DIALOG_WARNING, &label, &vbox);
-
- /* Add the buttons */
- gtk_dialog_add_button (GTK_DIALOG (dialog), _("_View Certificate"),
- NSSDIALOG_RESPONSE_VIEW_CERT);
-
- gtk_dialog_add_button (GTK_DIALOG (dialog), GTK_STOCK_CANCEL,
- GTK_RESPONSE_CANCEL);
-
- if (affirmative_text == NULL)
- {
- affirmative_text = _("_Accept");
- }
-
- button = gtk_dialog_add_button (GTK_DIALOG (dialog),
- affirmative_text,
- GTK_RESPONSE_ACCEPT);
- gtk_dialog_set_default_response (GTK_DIALOG (dialog), GTK_RESPONSE_ACCEPT);
-
- if (checkbox_text)
- {
- checkbox = gtk_check_button_new_with_mnemonic (checkbox_text);
- gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (checkbox),
- *checkbox_value);
-
- gtk_box_pack_start (GTK_BOX (vbox), checkbox, TRUE, TRUE, 0);
- }
- else
- {
- checkbox = 0;
- }
-
- /* We don't want focus on the checkbox */
- gtk_widget_grab_focus (button);
-
- gtk_label_set_markup (GTK_LABEL (label), markup_text);
- gtk_dialog_set_default_response (GTK_DIALOG (dialog), GTK_RESPONSE_ACCEPT);
- gtk_widget_show_all (dialog);
-
- while (1)
- {
- res = gtk_dialog_run (GTK_DIALOG (dialog));
- if (res == NSSDIALOG_RESPONSE_VIEW_CERT)
- {
- view_certificate (ctx, cert);
- continue;
- }
-
- break;
- }
-
- if (res == GTK_RESPONSE_ACCEPT && checkbox)
- {
- *checkbox_value = gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (checkbox));
- }
-
- gtk_widget_destroy (dialog);
- return res;
-}
-
-
-/* Helper functions */
-
-nsresult
-GtkNSSDialogs::GetTokenAndSlotFromName (const PRUnichar *aName,
- nsIPK11Token **aToken,
- nsIPKCS11Slot **aSlot)
-{
- nsresult rv = NS_ERROR_FAILURE;
- *aToken = nsnull;
- *aSlot = nsnull;
-
- nsCOMPtr<nsIPK11TokenDB> tokenDB = do_GetService("@mozilla.org/security/pk11tokendb;1");
- nsCOMPtr<nsIPKCS11ModuleDB> pkcs11DB = do_GetService("@mozilla.org/security/pkcs11moduledb;1");
- if (!tokenDB || !pkcs11DB) return rv;
-
- rv = tokenDB->FindTokenByName (aName, aToken);
- NS_ENSURE_TRUE (NS_SUCCEEDED (rv) && *aToken, rv);
-
- pkcs11DB->FindSlotByName (aName, aSlot);
-
- NS_ENSURE_TRUE (*aSlot, NS_ERROR_FAILURE);
-
-#ifdef GNOME_ENABLE_DEBUG
- /* Dump some info about this token */
- nsIPK11Token *token = *aToken;
- PRUnichar *tName, *tLabel, *tManID, *tHWVersion, *tFWVersion, *tSN;
- PRInt32 minPwdLen;
- PRBool needsInit, isHW, needsLogin, isFriendly;
-
- token->GetTokenName(&tName);
- token->GetTokenLabel(&tLabel);
- token->GetTokenManID(&tManID);
- token->GetTokenHWVersion(&tHWVersion);
- token->GetTokenFWVersion(&tFWVersion);
- token->GetTokenSerialNumber(&tSN);
- token->GetMinimumPasswordLength(&minPwdLen);
- token->GetNeedsUserInit(&needsInit);
- token->IsHardwareToken(&isHW);
- token->NeedsLogin(&needsLogin);
- token->IsFriendly(&isFriendly);
-
- g_print ("Token '%s' has \nName: %s\nLabel: %s\nManID: %s\nHWversion: %s\nFWVersion: %s\nSN: %s\n"
- "MinPwdLen: %d\nNeedsUserInit: %d\nIsHWToken: %d\nNeedsLogin: %d\nIsFriendly: %d\n\n",
- NS_ConvertUTF16toUTF8(aName).get(),
-
- NS_ConvertUTF16toUTF8(tName).get(),
- NS_ConvertUTF16toUTF8(tLabel).get(),
- NS_ConvertUTF16toUTF8(tManID).get(),
- NS_ConvertUTF16toUTF8(tHWVersion).get(),
- NS_ConvertUTF16toUTF8(tFWVersion).get(),
- NS_ConvertUTF16toUTF8(tSN).get(),
- minPwdLen,
- needsInit,
- isHW,
- needsLogin,
- isFriendly);
-
- nsIPKCS11Slot *slot = *aSlot;
- PRUnichar*slDesc;
- slot->GetDesc(&slDesc);
- g_print ("Slot description: %s\n", NS_ConvertUTF16toUTF8 (slDesc).get());
-#endif
-
- return NS_OK;
-}
-
-/* nsICertificateDialogs */
-
-NS_IMETHODIMP
-GtkNSSDialogs::ConfirmMismatchDomain (nsIInterfaceRequestor *ctx,
- const nsACString &targetURL,
- nsIX509Cert *cert, PRBool *_retval)
-{
- char *first, *second, *msg;
- int res;
-
- nsString commonName;
- cert->GetCommonName (commonName);
-
- NS_ConvertUTF16toUTF8 cCommonName (commonName);
-
- nsCString cTargetUrl (targetURL);
-
- first = g_markup_printf_escaped (_("The site “%s” returned security information for "
- "“%s”. It is possible that someone is intercepting "
- "your communication to obtain your confidential "
- "information."),
- cTargetUrl.get(), cCommonName.get());
-
- second = g_markup_printf_escaped (_("You should only accept the security information if you "
- "trust “%s” and “%s”."),
- cTargetUrl.get(), cCommonName.get());
-
- msg = g_strdup_printf ("<span weight=\"bold\" size=\"larger\">%s</span>\n\n%s\n\n%s",
- _("Accept incorrect security information?"),
- first, second);
-
- res = display_cert_warning_box (ctx, cert, msg, NULL, NULL, NULL);
-
- g_free (second);
- g_free (first);
- g_free (msg);
-
- *_retval = (res == GTK_RESPONSE_ACCEPT);
- return NS_OK;
-}
-
-
-NS_IMETHODIMP
-GtkNSSDialogs::ConfirmUnknownIssuer (nsIInterfaceRequestor *ctx,
- nsIX509Cert *cert, PRInt16 *outAddType,
- PRBool *_retval)
-{
- gboolean accept_perm = FALSE;
- char *secondary, *tertiary, *msg;
- int res;
-
- nsString commonName;
- cert->GetCommonName (commonName);
-
- NS_ConvertUTF16toUTF8 cCommonName (commonName);
-
- secondary = g_markup_printf_escaped
- (_("It was not possible to automatically trust “%s”. "
- "It is possible that someone is intercepting your "
- "communication to obtain your confidential information."),
- cCommonName.get());
-
- tertiary = g_markup_printf_escaped
- (_("You should only connect to the site if you are certain "
- "you are connected to “%s”."),
- cCommonName.get());
-
- msg = g_strdup_printf ("<span weight=\"bold\" size=\"larger\">%s</span>\n\n%s\n\n%s",
- _("Connect to untrusted site?"),
- secondary, tertiary);
-
- res = display_cert_warning_box (ctx, cert, msg,
- _("_Trust this security information from now on"),
- &accept_perm, _("Co_nnect"));
- g_free (tertiary);
- g_free (secondary);
- g_free (msg);
-
- if (res != GTK_RESPONSE_ACCEPT)
- {
- *_retval = PR_FALSE;
- *outAddType = UNINIT_ADD_FLAG;
- }
- else
- {
- if (accept_perm)
- {
- *_retval = PR_TRUE;
- *outAddType = ADD_TRUSTED_PERMANENTLY;
- }
- else
- {
- *_retval = PR_TRUE;
- *outAddType = ADD_TRUSTED_FOR_SESSION;
- }
- }
-
- return NS_OK;
-}
-
-
-/* boolean confirmCertExpired (in nsIInterfaceRequestor socketInfo,
- in nsIX509Cert cert); */
-NS_IMETHODIMP
-GtkNSSDialogs::ConfirmCertExpired (nsIInterfaceRequestor *ctx,
- nsIX509Cert *cert, PRBool *_retval)
-{
- nsresult rv;
- PRTime now = PR_Now();
- PRTime notAfter, notBefore, timeToUse;
- PRInt64 normalizedTime;
- time_t t;
- struct tm tm;
- char formattedDate[128];
- char *fdate;
- const char *primary, *text;
- char *secondary, *msg;
-
- *_retval = PR_FALSE;
-
- nsCOMPtr<nsIX509CertValidity> validity;
- rv = cert->GetValidity (getter_AddRefs(validity));
- if (NS_FAILED(rv)) return rv;
-
- rv = validity->GetNotAfter (&notAfter);
- if (NS_FAILED(rv)) return rv;
-
- rv = validity->GetNotBefore (&notBefore);
- if (NS_FAILED(rv)) return rv;
-
- if (LL_CMP(now, >, notAfter))
- {
- primary = _("Accept expired security information?");
- /* Translators: first %s is a hostname, second %s is a time/date */
- text = _("The security information for “%s” "
- "expired on %s.");
- timeToUse = notAfter;
- }
- else
- {
- primary = _("Accept not yet valid security information?");
- /* Translators: first %s is a hostname, second %s is a time/date */
- text = _("The security information for “%s” isn't valid until %s.");
- timeToUse = notBefore;
- }
-
- nsString commonName;
- cert->GetCommonName (commonName);
-
- NS_ConvertUTF16toUTF8 cCommonName (commonName);
-
- LL_DIV (normalizedTime, timeToUse, PR_USEC_PER_SEC);
- LL_L2UI (t, normalizedTime);
- /* To translators: this a time format that is used while displaying the
- * expiry or start date of an SSL certificate, for the format see
- * strftime(3) */
- strftime (formattedDate, sizeof(formattedDate), _("%a %d %b %Y"),
- localtime_r (&t, &tm));
- /* FIXME! this isn't actually correct, LC_CTIME codeset could be different than locale codeset! */
- fdate = g_locale_to_utf8 (formattedDate, -1, NULL, NULL, NULL);
-
- secondary = g_markup_printf_escaped (text, cCommonName.get(), fdate);
-
- msg = g_strdup_printf ("<span weight=\"bold\" size=\"larger\">%s</span>\n\n%s\n\n%s",
- primary, secondary,
- _("You should ensure that your computer's time is correct."));
-
- int res = display_cert_warning_box (ctx, cert, msg, NULL, NULL, NULL);
-
- g_free (fdate);
- g_free (msg);
- g_free (secondary);
-
- *_retval = (res == GTK_RESPONSE_ACCEPT);
-
- return NS_OK;
-}
-
-/* void notifyCrlNextupdate (in nsIInterfaceRequestor socketInfo,
- in AUTF8String targetURL,
- in nsIX509Cert cert); */
-NS_IMETHODIMP
-GtkNSSDialogs::NotifyCrlNextupdate (nsIInterfaceRequestor *ctx,
- const nsACString & targetURL,
- nsIX509Cert *cert)
-{
- nsCOMPtr<nsIDOMWindow> parent = do_GetInterface (ctx);
- GtkWidget *gparent = EphyUtils::FindGtkParent (parent);
-
- nsCString cTargetUrl (targetURL);
-
- nsString commonName;
- cert->GetCommonName (commonName);
-
- GtkWidget *dialog = gtk_message_dialog_new
- (GTK_WINDOW (gparent),
- GTK_DIALOG_DESTROY_WITH_PARENT,
- GTK_MESSAGE_ERROR,
- GTK_BUTTONS_OK,
- _("Cannot establish connection to “%s”"),
- cTargetUrl.get ());
-
- gtk_message_dialog_format_secondary_text
- (GTK_MESSAGE_DIALOG (dialog),
- _("The certificate revocation list (CRL) from “%s” "
- "needs to be updated.\n\n"
- "Please ask your system administrator for assistance."),
- NS_ConvertUTF16toUTF8 (commonName).get ());
- gtk_window_set_icon_name (GTK_WINDOW (dialog), EPHY_STOCK_EPHY);
-
- g_signal_connect (dialog, "response",
- (GCallback) gtk_widget_destroy, NULL);
-
- gtk_widget_show_all (dialog);
- return NS_OK;
-}
-
-NS_IMETHODIMP
-GtkNSSDialogs::ConfirmDownloadCACert(nsIInterfaceRequestor *ctx,
- nsIX509Cert *cert,
- PRUint32 *_trust,
- PRBool *_retval)
-{
- GtkWidget *dialog, *label;
- char *msg, *primary;
-
- nsresult rv;
- AutoJSContextStack stack;
- rv = stack.Init ();
- if (NS_FAILED (rv)) return rv;
-
- nsCOMPtr<nsIDOMWindow> parent (do_GetInterface (ctx));
- GtkWindow *gparent = GTK_WINDOW (EphyUtils::FindGtkParent (parent));
-
- AutoWindowModalState modalState (parent);
-
- dialog = gtk_dialog_new_with_buttons (_("Trust new Certificate Authority?"), gparent,
- GTK_DIALOG_DESTROY_WITH_PARENT,
- _("_View Certificate"),
- NSSDIALOG_RESPONSE_VIEW_CERT,
- GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL,
- _("_Trust CA"), GTK_RESPONSE_ACCEPT,
- (char *) NULL);
-
- if (gparent)
- {
- gtk_window_group_add_window (ephy_gui_ensure_window_group (gparent),
- GTK_WINDOW (dialog));
- }
-
- gtk_window_set_icon_name (GTK_WINDOW (dialog), EPHY_STOCK_EPHY);
-
- higgy_setup_dialog (GTK_DIALOG (dialog), GTK_STOCK_DIALOG_WARNING,
- &label, NULL);
- gtk_dialog_set_default_response (GTK_DIALOG (dialog), GTK_RESPONSE_ACCEPT);
-
- nsString commonName;
- cert->GetCommonName (commonName);
-
- NS_ConvertUTF16toUTF8 cCommonName (commonName);
-
- primary = g_markup_printf_escaped (_("Trust new Certificate Authority “%s” to identify web sites?"),
- cCommonName.get());
-
- msg = g_strdup_printf ("<span weight=\"bold\" size=\"larger\">%s</span>\n\n%s",
- primary,
- _("Before trusting a Certificate Authority (CA) you should "
- "verify the certificate is authentic."));
- gtk_label_set_markup (GTK_LABEL (label), msg);
- g_free (primary);
- g_free (msg);
-
- gtk_widget_show_all (dialog);
- int ret;
-
- while (1)
- {
- ret = gtk_dialog_run (GTK_DIALOG (dialog));
- if (ret == NSSDIALOG_RESPONSE_VIEW_CERT)
- {
- view_certificate (ctx, cert);
- continue;
- }
-
- break;
- }
-
- if (ret != GTK_RESPONSE_ACCEPT)
- {
- *_retval = PR_FALSE;
- }
- else
- {
- if (ret == GTK_RESPONSE_ACCEPT)
- {
- *_trust |= nsIX509CertDB::TRUSTED_SSL;
- }
- else
- {
- *_trust = nsIX509CertDB::UNTRUSTED;
- }
-
- *_retval = PR_TRUE;
- }
- gtk_widget_destroy (dialog);
-
- return NS_OK;
-}
-
-
-NS_IMETHODIMP
-GtkNSSDialogs::NotifyCACertExists (nsIInterfaceRequestor *ctx)
-{
- GtkWidget *dialog, *label;
- char * msg;
-
- nsCOMPtr<nsIDOMWindow> parent = do_GetInterface (ctx);
- GtkWindow *gparent = GTK_WINDOW (EphyUtils::FindGtkParent (parent));
-
- dialog = gtk_dialog_new_with_buttons ("", gparent,
- GTK_DIALOG_DESTROY_WITH_PARENT,
- GTK_STOCK_OK,
- GTK_RESPONSE_OK,
- (char *) NULL);
-
- if (gparent)
- {
- gtk_window_group_add_window (ephy_gui_ensure_window_group (gparent),
- GTK_WINDOW (dialog));
- }
-
- gtk_window_set_icon_name (GTK_WINDOW (dialog), EPHY_STOCK_EPHY);
-
- higgy_setup_dialog (GTK_DIALOG (dialog), GTK_STOCK_DIALOG_ERROR,
- &label, NULL);
-
- msg = g_strdup_printf ("<span weight=\"bold\" size=\"larger\">%s</span>\n\n%s",
- _("Certificate already exists."),
- _("The certificate has already been imported."));
- gtk_label_set_markup (GTK_LABEL (label), msg);
- g_free (msg);
-
- g_signal_connect (G_OBJECT (dialog),
- "response",
- (GCallback)gtk_widget_destroy, NULL);
-
- gtk_widget_show_all (dialog);
- return NS_OK;
-}
-
-/* FIXME: This interface sucks! There is way to know the name of the certificate! */
-NS_IMETHODIMP
-GtkNSSDialogs::SetPKCS12FilePassword(nsIInterfaceRequestor *ctx,
- nsAString &_password,
- PRBool *_retval)
-{
- GtkWidget *dialog;
- char *msg;
-
- nsresult rv;
- AutoJSContextStack stack;
- rv = stack.Init ();
- if (NS_FAILED (rv)) return rv;
-
- nsCOMPtr<nsIDOMWindow> parent (do_GetInterface (ctx));
- GtkWidget *gparent = EphyUtils::FindGtkParent (parent);
-
- AutoWindowModalState modalState (parent);
-
- dialog = ephy_password_dialog_new (gparent,
- _("Select Password"),
- EphyPasswordDialogFlags(EPHY_PASSWORD_DIALOG_FLAGS_SHOW_NEW_PASSWORD |
- EPHY_PASSWORD_DIALOG_FLAGS_SHOW_QUALITY_METER));
- gtk_window_set_modal (GTK_WINDOW (dialog), TRUE);
- gtk_window_set_destroy_with_parent (GTK_WINDOW (dialog), TRUE);
-
- /* FIXME: set accept button text to (_("_Back Up Certificate") ?
- * That's not actually correct, since this function is also called from other places!
- */
-
- msg = g_markup_printf_escaped (_("Select a password to protect this certificate"));
- gtk_message_dialog_set_markup (GTK_MESSAGE_DIALOG (dialog), msg);
- g_free (msg);
-
- int response = gtk_dialog_run (GTK_DIALOG (dialog));
- gtk_widget_hide (dialog);
-
- if (response == GTK_RESPONSE_ACCEPT)
- {
- const char *text = ephy_password_dialog_get_new_password (EPHY_PASSWORD_DIALOG (dialog));
- g_return_val_if_fail (text != NULL, NS_ERROR_FAILURE);
- NS_CStringToUTF16 (nsDependentCString (text),
- NS_CSTRING_ENCODING_UTF8, _password);
- }
-
- *_retval = response == GTK_RESPONSE_ACCEPT;
-
- gtk_widget_destroy (dialog);
-
- return NS_OK;
-}
-
-NS_IMETHODIMP
-GtkNSSDialogs::GetPKCS12FilePassword(nsIInterfaceRequestor *ctx,
- nsAString &_password,
- PRBool *_retval)
-{
- g_print ("GtkNSSDialogs::GetPKCS12FilePassword\n");
-
- nsresult rv;
- AutoJSContextStack stack;
- rv = stack.Init ();
- if (NS_FAILED (rv)) return rv;
-
- nsCOMPtr<nsIDOMWindow> parent (do_GetInterface (ctx));
- GtkWidget *gparent = EphyUtils::FindGtkParent (parent);
-
- AutoWindowModalState modalState (parent);
-
- GtkWidget *dialog = ephy_password_dialog_new
- (gparent,
- "",
- EphyPasswordDialogFlags (EPHY_PASSWORD_DIALOG_FLAGS_SHOW_PASSWORD));
- EphyPasswordDialog *password_dialog = EPHY_PASSWORD_DIALOG (dialog);
- /* FIXME: set accept button text to _("I_mport Certificate") ? */
-
- gtk_window_set_destroy_with_parent (GTK_WINDOW (dialog), TRUE);
-
- /* FIXME: mozilla sucks, no way to get the name of the certificate / cert file! */
- char *msg = g_markup_printf_escaped (_("Enter the password for this certificate"));
- gtk_message_dialog_set_markup (GTK_MESSAGE_DIALOG (dialog), msg);
- g_free (msg);
-
- int response = gtk_dialog_run (GTK_DIALOG (dialog));
-
- if (response == GTK_RESPONSE_ACCEPT)
- {
- const char *pwd = ephy_password_dialog_get_password (password_dialog);
- NS_CStringToUTF16 (nsDependentCString (pwd),
- NS_CSTRING_ENCODING_UTF8, _password);
- }
-
- *_retval = response == GTK_RESPONSE_ACCEPT;
-
- gtk_widget_destroy (dialog);
-
- return NS_OK;
-}
-
-
-static void
-set_table_row (GtkWidget *table,
- int& row,
- const char *title,
- const char *text)
-{
- GtkWidget *header, *label;
- char *bold;
-
- if (text == NULL || text[0] == 0) return;
-
- bold = g_markup_printf_escaped ("<b>%s</b>", title);
- header = gtk_label_new (bold);
- g_free (bold);
-
- gtk_label_set_use_markup (GTK_LABEL (header), TRUE);
- gtk_misc_set_alignment (GTK_MISC (header), 0, 0);
- gtk_widget_show (header);
- gtk_table_attach (GTK_TABLE (table), header, 0, 1, row, row+1,
- GTK_FILL, GTK_FILL, 0, 0);
-
- label = gtk_label_new (text);
- gtk_misc_set_alignment (GTK_MISC (label), 0, 0);
- gtk_label_set_selectable (GTK_LABEL (label), TRUE);
- gtk_label_set_ellipsize (GTK_LABEL (label), PANGO_ELLIPSIZE_END);
- gtk_label_set_max_width_chars (GTK_LABEL (label), 48);
- gtk_widget_show (label);
- gtk_table_attach_defaults (GTK_TABLE (table), label, 1, 2, row, row+1);
-
- row++;
-}
-
-NS_IMETHODIMP
-GtkNSSDialogs::CrlImportStatusDialog(nsIInterfaceRequestor *ctx, nsICRLInfo *crl)
-{
-
- GtkWidget *dialog, *label, *table, *vbox;
- nsresult rv;
- char *msg;
-
- nsCOMPtr<nsIDOMWindow> parent = do_GetInterface (ctx);
- GtkWidget *gparent = EphyUtils::FindGtkParent (parent);
-
- dialog = gtk_dialog_new_with_buttons ("",
- GTK_WINDOW (gparent),
- GTK_DIALOG_DESTROY_WITH_PARENT,
- GTK_STOCK_OK, GTK_RESPONSE_OK,
- (char *) NULL);
-
- gtk_window_set_icon_name (GTK_WINDOW (dialog), EPHY_STOCK_EPHY);
- gtk_window_set_title (GTK_WINDOW (dialog), _("Certificate Revocation List Imported"));
-
- /* Needed because gparent == NULL always because of mozilla sucks */
- gtk_window_set_skip_pager_hint (GTK_WINDOW (dialog), TRUE);
- gtk_window_set_skip_taskbar_hint (GTK_WINDOW (dialog), TRUE);
-
- higgy_setup_dialog (GTK_DIALOG (dialog), GTK_STOCK_DIALOG_INFO,
- &label, &vbox);
-
- msg = g_strdup_printf ("<span weight=\"bold\" size=\"larger\">%s</span>",
- _("Certificate Revocation List (CRL) successfully imported"));
- gtk_label_set_markup (GTK_LABEL (label), msg);
- g_free (msg);
-
- table = gtk_table_new (2, 3, FALSE);
- gtk_table_set_row_spacings (GTK_TABLE (table), 6);
- gtk_table_set_col_spacings (GTK_TABLE (table), 12);
-
- nsString org, orgUnit, nextUpdate;
- rv = crl->GetOrganization (org);
- if (NS_FAILED(rv)) return rv;
-
- rv = crl->GetOrganizationalUnit (orgUnit);
- if (NS_FAILED(rv)) return rv;
-
- rv = crl->GetNextUpdateLocale (nextUpdate);
- if (NS_FAILED(rv)) return rv;
-
- int row = 0;
- set_table_row (table, row, _("Organization:"), NS_ConvertUTF16toUTF8 (org).get ());
-
- set_table_row (table, row, _("Unit:"), NS_ConvertUTF16toUTF8 (orgUnit).get ());
-
- set_table_row (table, row, _("Next Update:"), NS_ConvertUTF16toUTF8 (nextUpdate).get ());
-
- gtk_box_pack_start (GTK_BOX (vbox), table, FALSE, FALSE, 0);
-
- gtk_widget_show_all (dialog);
- g_signal_connect (G_OBJECT (dialog),
- "response",
- (GCallback)gtk_widget_destroy, NULL);
-
- gtk_widget_show_all (dialog);
- return NS_OK;
-}
-
-/**
- * Help function to fill in the labels on the General tab
- */
-static void
-set_label_cert_attribute (GladeXML* gxml, const char* label_id, nsAString &value)
-{
- GtkWidget *label;
- label = glade_xml_get_widget (gxml, label_id);
-
- g_return_if_fail (GTK_IS_LABEL (label));
-
- if (!value.Length()) {
- gtk_label_set_use_markup (GTK_LABEL (label), TRUE);
- char *msg = g_strdup_printf ("<i>&lt;%s&gt;</i>",
- _("Not part of certificate"));
- gtk_label_set_markup (GTK_LABEL (label), msg);
- g_free (msg);
- }
- else
- {
- gtk_label_set_use_markup (GTK_LABEL (label), FALSE);
- gtk_label_set_text (GTK_LABEL (label), NS_ConvertUTF16toUTF8 (value).get());
- }
-}
-
-
-/**
- * Do that actual filling in of the certificate tree
- */
-static gboolean
-fill_cert_chain_tree (GtkTreeView *treeview, nsIArray *certChain)
-{
- nsresult rv;
- GtkTreeModel * model = gtk_tree_view_get_model (treeview);
-
- GtkTreeIter parent;
- PRUint32 numCerts;
- rv = certChain->GetLength (&numCerts);
- if (NS_FAILED(rv) || numCerts < 1) return FALSE;
-
- for (int i = (int)numCerts-1 ; i >= 0; i--)
- {
- nsCOMPtr<nsIX509Cert> nsCert;
- rv = certChain->QueryElementAt (i, kX509CertCID,
- getter_AddRefs(nsCert));
- if (NS_FAILED(rv)) return FALSE;
-
- GtkTreeIter iter;
- gtk_tree_store_append (GTK_TREE_STORE (model), &iter,
- (i == (int)numCerts-1) ? NULL : &parent);
-
- nsString value;
- rv = nsCert->GetCommonName (value);
- if (NS_FAILED(rv)) return FALSE;
-
- NS_ConvertUTF16toUTF8 cValue (value);
-
- nsIX509Cert *nsCertP = nsCert;
- if (value.Length())
- {
- gtk_tree_store_set (GTK_TREE_STORE(model), &iter,
- 0, cValue.get(),
- 1, nsCertP,
- -1);
- }
- else
- {
- char * title;
- rv = nsCert->GetWindowTitle (&title);
- if (NS_FAILED(rv)) return FALSE;
-
- gtk_tree_store_set (GTK_TREE_STORE(model),
- &iter, 0, title, 1, nsCertP, -1);
- nsMemory::Free (title);
- }
- parent = iter;
- }
- gtk_tree_view_expand_all (GTK_TREE_VIEW (treeview));
-
- /* And select the last entry, and scroll the view so it's visible */
- GtkTreeSelection *select = gtk_tree_view_get_selection (treeview);
- GtkTreePath *path = gtk_tree_model_get_path (model, &parent);
- gtk_tree_selection_select_path (select, path);
- gtk_tree_view_scroll_to_cell (treeview, path, NULL, TRUE, 0.5, 0.0);
- gtk_tree_path_free (path);
-
- return TRUE;
-}
-
-/**
- * Add an ASN object to the treeview, recursing if the object was a
- * sequence
- */
-static void
-add_asn1_object_to_tree(GtkTreeModel *model, nsIASN1Object *object, GtkTreeIter *parent)
-{
- nsString dispNameU;
- object->GetDisplayName(dispNameU);
-
- GtkTreeIter iter;
- gtk_tree_store_append (GTK_TREE_STORE (model), &iter, parent);
-
- gtk_tree_store_set (GTK_TREE_STORE(model), &iter,
- 0, NS_ConvertUTF16toUTF8 (dispNameU).get(),
- 1, object,
- -1);
-
- nsCOMPtr<nsIASN1Sequence> sequence(do_QueryInterface(object));
- if (!sequence) return;
-
- nsCOMPtr<nsIMutableArray> asn1Objects;
- sequence->GetASN1Objects(getter_AddRefs(asn1Objects));
-
- PRUint32 numObjects;
- asn1Objects->GetLength(&numObjects);
- if (!asn1Objects) return;
-
- for (PRUint32 i = 0; i < numObjects ; i++)
- {
- nsCOMPtr<nsIASN1Object> currObject;
- asn1Objects->QueryElementAt (i, kASN1ObjectCID,
- getter_AddRefs (currObject));
- add_asn1_object_to_tree (model, currObject, &iter);
- }
-}
-
-
-/**
- * Update the "Certificate Fields" treeview when a different cert
- * is selected in the hierarchy text view
- */
-static void
-cert_chain_tree_view_selection_changed_cb (GtkTreeSelection *selection,
- GtkWidget* tree_view)
-{
- GtkTreeIter iter;
- nsIX509Cert *nsCert;
- nsresult rv;
- GtkTreeModel * model;
-
- if (gtk_tree_selection_get_selected (selection, &model, &iter))
- {
- gtk_tree_model_get (model, &iter, 1, &nsCert, -1);
-
- nsCOMPtr<nsIASN1Object> object;
- rv = nsCert->GetASN1Structure (getter_AddRefs(object));
- if (NS_FAILED(rv)) return;
-
- model = gtk_tree_view_get_model (GTK_TREE_VIEW (tree_view));
- gtk_tree_store_clear (GTK_TREE_STORE (model));
- add_asn1_object_to_tree (model, object, NULL);
-
- gtk_tree_view_expand_all (GTK_TREE_VIEW (tree_view));
- }
-}
-
-/**
- * When the "Certificate Field" treeview is changed, update the
- * text_view to display the value of the currently selected field
- */
-static void
-field_tree_view_selection_changed_cb (GtkTreeSelection *selection,
- GtkWidget* text_view)
-{
- GtkTreeIter iter;
- GtkTreeModel *model;
- GtkTextBuffer * text_buffer =
- gtk_text_view_get_buffer (GTK_TEXT_VIEW (text_view));
-
- if (gtk_tree_selection_get_selected (selection, &model, &iter))
- {
- nsIASN1Object *object;
-
- gtk_tree_model_get (model, &iter, 1, &object, -1);
-
- nsString dispValU;
- object->GetDisplayValue(dispValU);
-
- gtk_text_buffer_set_text (text_buffer, NS_ConvertUTF16toUTF8 (dispValU).get(), -1);
- }
- else
- {
- gtk_text_buffer_set_text (text_buffer, "", 0);
- }
-}
-
-/**
- * Setup the various treeviews, the textview, and fill the treeviews
- */
-static gboolean
-setup_view_cert_tree (GtkWidget *dialog, GladeXML*gxml, nsIArray *certChain)
-{
- GtkCellRenderer *renderer;
- GtkWidget *chain_tree_view, *field_tree_view, *text_view;
- PangoFontDescription *monospace_font_desc;
- GConfClient *conf_client;
- char *monospace_font;
-
- chain_tree_view = glade_xml_get_widget (gxml, "treeview_cert_chain");
- field_tree_view = glade_xml_get_widget (gxml, "treeview_cert_info");
- text_view = glade_xml_get_widget (gxml, "textview_field_value");
-
- /* Setup the certificate chain view */
- GtkTreeStore *store = gtk_tree_store_new (2,
- G_TYPE_STRING,
- G_TYPE_POINTER);
- gtk_tree_view_set_model (GTK_TREE_VIEW (chain_tree_view), GTK_TREE_MODEL (store));
- g_object_unref (store);
-
-
- renderer = gtk_cell_renderer_text_new ();
- gtk_tree_view_insert_column_with_attributes (GTK_TREE_VIEW (chain_tree_view),
- 0, "Certificate",
- renderer,
- "text", 0,
- (char *) NULL);
-
- GtkTreeSelection *select = gtk_tree_view_get_selection (GTK_TREE_VIEW (chain_tree_view));
- gtk_tree_selection_set_mode (select, GTK_SELECTION_SINGLE);
-
- g_signal_connect (G_OBJECT (select), "changed",
- G_CALLBACK (cert_chain_tree_view_selection_changed_cb),
- field_tree_view);
-
- /* Setup the certificate field view */
- store = gtk_tree_store_new (2,
- G_TYPE_STRING,
- G_TYPE_POINTER);
- gtk_tree_view_set_model (GTK_TREE_VIEW (field_tree_view), GTK_TREE_MODEL (store));
- g_object_unref (store);
-
-
- gtk_tree_view_insert_column_with_attributes (GTK_TREE_VIEW (field_tree_view),
- 0, "Certificate Field",
- renderer,
- "text", 0,
- (char *) NULL);
-
- select = gtk_tree_view_get_selection (GTK_TREE_VIEW (field_tree_view));
- gtk_tree_selection_set_mode (select, GTK_SELECTION_SINGLE);
-
- g_signal_connect (G_OBJECT (select), "changed",
- G_CALLBACK (field_tree_view_selection_changed_cb),
- text_view);
-
- /* Get the text_view displaying a propertional font
- *
- * Pick up the monospace font from desktop preferences */
- conf_client = gconf_client_get_default ();
- monospace_font = gconf_client_get_string (conf_client,
- "/desktop/gnome/interface/monospace_font_name", NULL);
- if (monospace_font)
- {
- monospace_font_desc = pango_font_description_from_string (monospace_font);
- gtk_widget_modify_font (text_view, monospace_font_desc);
- pango_font_description_free (monospace_font_desc);
- }
- g_object_unref (conf_client);
-
- /* And fill the certificate chain tree */
- return fill_cert_chain_tree (GTK_TREE_VIEW (chain_tree_view), certChain);
-}
-
-/* void viewCert (in nsIX509Cert cert); */
-NS_IMETHODIMP
-GtkNSSDialogs::ViewCert(nsIInterfaceRequestor *ctx,
- nsIX509Cert *cert)
-{
- GtkWidget *dialog, *widget;
- GladeXML *gxml;
- nsString value;
- PRUint32 verifystate, count;
- PRUnichar ** usage;
- GtkSizeGroup * sizegroup;
-
- nsresult rv;
- AutoJSContextStack stack;
- rv = stack.Init ();
- if (NS_FAILED (rv)) return rv;
-
- gxml = glade_xml_new (ephy_file ("certificate-dialogs.glade"),
- "viewcert_dialog", NULL);
- g_return_val_if_fail (gxml != NULL, NS_ERROR_FAILURE);
-
- dialog = glade_xml_get_widget (gxml, "viewcert_dialog");
- g_return_val_if_fail (dialog != NULL, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsIDOMWindow> parent (do_GetInterface (ctx));
- GtkWindow *gparent = GTK_WINDOW (EphyUtils::FindGtkParent (parent));
-
- AutoWindowModalState modalState (parent);
-
- if (gparent)
- {
- gtk_window_set_transient_for (GTK_WINDOW(dialog), GTK_WINDOW(gparent));
- gtk_window_group_add_window (ephy_gui_ensure_window_group (GTK_WINDOW (gparent)),
- GTK_WINDOW (dialog));
- gtk_window_set_destroy_with_parent (GTK_WINDOW (dialog), TRUE);
- }
-
- gtk_window_set_icon_name (GTK_WINDOW (dialog), EPHY_STOCK_EPHY);
-
- gtk_window_set_title (GTK_WINDOW (dialog), _("Certificate Properties"));
- gtk_dialog_set_default_response (GTK_DIALOG (dialog), GTK_RESPONSE_CLOSE);
-
- /* Set up the GtkSizeGroup so that the columns line up */
- sizegroup = gtk_size_group_new (GTK_SIZE_GROUP_HORIZONTAL);
- widget = glade_xml_get_widget (gxml, "label_size1");
- gtk_size_group_add_widget (sizegroup, widget);
- widget = glade_xml_get_widget (gxml, "label_size2");
- gtk_size_group_add_widget (sizegroup, widget);
- widget = glade_xml_get_widget (gxml, "label_size3");
- gtk_size_group_add_widget (sizegroup, widget);
- widget = glade_xml_get_widget (gxml, "label_size4");
- gtk_size_group_add_widget (sizegroup, widget);
- g_object_unref (sizegroup);
-
- rv = cert->GetUsagesArray (FALSE, &verifystate, &count, &usage);
- if (NS_FAILED(rv)) return rv;
-
- const char * text;
- switch (verifystate)
- {
- case nsIX509Cert::VERIFIED_OK:
- text = _("This certificate has been verified for the following uses:");
- break;
- case nsIX509Cert::CERT_REVOKED:
- text = _("Could not verify this certificate because it has been revoked.");
- break;
- case nsIX509Cert::CERT_EXPIRED:
- text = _("Could not verify this certificate because it has expired.");
- break;
- case nsIX509Cert::CERT_NOT_TRUSTED:
- text = _("Could not verify this certificate because it is not trusted.");
- break;
- case nsIX509Cert::ISSUER_NOT_TRUSTED:
- text = _("Could not verify this certificate because the issuer is not trusted.");
- break;
- case nsIX509Cert::ISSUER_UNKNOWN:
- text = _("Could not verify this certificate because the issuer is unknown.");
- break;
- case nsIX509Cert::INVALID_CA:
- text = _("Could not verify this certificate because the CA certificate is invalid.");
- break;
- case nsIX509Cert::NOT_VERIFIED_UNKNOWN:
- case nsIX509Cert::USAGE_NOT_ALLOWED:
- default:
- text = _("Could not verify this certificate for unknown reasons.");
- }
-
- char *vmsg = g_strdup_printf ("<b>%s</b>", text);
- widget = glade_xml_get_widget (gxml, "label_verify_text");
- g_return_val_if_fail (GTK_IS_LABEL (widget), NS_ERROR_FAILURE);
- gtk_label_set_markup (GTK_LABEL (widget), vmsg);
- g_free (vmsg);
-
- if (count > 0)
- {
- GtkWidget *vbox = gtk_vbox_new (FALSE, 3);
- GtkWidget *indent;
- for (PRUint32 i = 0 ; i < count ; i++)
- {
- GtkWidget *label = gtk_label_new (NS_ConvertUTF16toUTF8 (usage[i]).get());
- gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5);
- gtk_box_pack_start (GTK_BOX (vbox), label, FALSE, FALSE, 0);
- nsMemory::Free (usage[i]);
- }
- nsMemory::Free (usage);
- indent = higgy_indent_widget (vbox);
- widget = glade_xml_get_widget (gxml, "vbox_validity");
- g_return_val_if_fail (GTK_IS_BOX (widget), NS_ERROR_FAILURE);
-
- gtk_box_pack_start (GTK_BOX (widget), indent, FALSE, FALSE, 0);
- }
-
- cert->GetCommonName (value);
- set_label_cert_attribute (gxml, "label_cn", value);
-
- cert->GetOrganization (value);
- set_label_cert_attribute (gxml, "label_o", value);
-
- cert->GetOrganizationalUnit (value);
- set_label_cert_attribute (gxml, "label_ou", value);
-
- cert->GetSerialNumber (value);
- set_label_cert_attribute (gxml, "label_serial", value);
-
- rv = cert->GetIssuerCommonName (value);
- if (NS_FAILED(rv)) return rv;
- set_label_cert_attribute (gxml, "label_issuer_cn", value);
-
- cert->GetIssuerOrganization (value);
- set_label_cert_attribute (gxml, "label_issuer_o", value);
-
- cert->GetIssuerOrganizationUnit (value);
- set_label_cert_attribute (gxml, "label_issuer_ou", value);
-
- nsCOMPtr<nsIX509CertValidity> validity;
- rv = cert->GetValidity (getter_AddRefs(validity));
- if (NS_FAILED(rv)) return rv;
-
- rv = validity->GetNotAfterLocalDay (value);
- if (NS_FAILED(rv)) return rv;
- set_label_cert_attribute (gxml, "label_notafter", value);
-
- rv = validity->GetNotBeforeLocalDay (value);
- if (NS_FAILED(rv)) return rv;
- set_label_cert_attribute (gxml, "label_notbefore", value);
-
- cert->GetSha1Fingerprint (value);
- set_label_cert_attribute (gxml, "label_sha_print", value);
-
- cert->GetMd5Fingerprint (value);
- set_label_cert_attribute (gxml, "label_md5_print", value);
-
- /* Hold a reference to each certificate in the chain while the
- * dialog is displayed, this holds the reference for the ASN
- * objects as well */
-
- nsCOMPtr<nsIArray> certChain;
- rv = cert->GetChain (getter_AddRefs(certChain));
- if (NS_FAILED(rv)) return rv;
-
- gboolean ret = setup_view_cert_tree (dialog, gxml, certChain);
- if (ret == FALSE) return NS_ERROR_FAILURE;
-
- g_object_unref (gxml);
-
- gtk_widget_show_all (dialog);
-
- int res;
- while (1)
- {
- res = gtk_dialog_run (GTK_DIALOG (dialog));
- if (res == GTK_RESPONSE_HELP)
- {
- ephy_gui_help (GTK_WINDOW (dialog), "epiphany", "using-certificate-viewer");
- continue;
- }
- break;
- }
-
- gtk_widget_destroy (dialog);
- return NS_OK;
-}
-
-/* nsITokenPasswordDialogs */
-
-/* NOTE: This interface totally sucks, see https://bugzilla.mozilla.org/show_bug.cgi?id=306993 */
-
-/* void setPassword (in nsIInterfaceRequestor ctx, in wstring tokenName, out boolean canceled); */
-NS_IMETHODIMP
-GtkNSSDialogs::SetPassword(nsIInterfaceRequestor *aCtx,
- const PRUnichar *aTokenName,
- PRBool *aCancelled)
-{
- NS_ENSURE_ARG_POINTER(aCancelled);
-
- nsresult rv;
- nsCOMPtr<nsIPK11Token> token;
- nsCOMPtr<nsIPKCS11Slot> slot;
- rv = GetTokenAndSlotFromName (aTokenName, getter_AddRefs (token),
- getter_AddRefs (slot));
- NS_ENSURE_SUCCESS (rv, rv);
- NS_ENSURE_TRUE (token && slot, NS_ERROR_FAILURE);
-
- AutoJSContextStack stack;
- rv = stack.Init ();
- if (NS_FAILED (rv)) return rv;
-
- PRUint32 status = nsIPKCS11Slot::SLOT_UNINITIALIZED;
- slot->GetStatus (&status);
-
- nsCOMPtr<nsIDOMWindow> parent (do_GetInterface (aCtx));
- GtkWidget *gparent = EphyUtils::FindGtkParent (parent);
-
- AutoWindowModalState modalState (parent);
-
- EphyPasswordDialogFlags flags =
- EphyPasswordDialogFlags (EPHY_PASSWORD_DIALOG_FLAGS_SHOW_NEW_PASSWORD |
- EPHY_PASSWORD_DIALOG_FLAGS_SHOW_QUALITY_METER);
- if (status != nsIPKCS11Slot::SLOT_UNINITIALIZED)
- flags = EphyPasswordDialogFlags (flags | EPHY_PASSWORD_DIALOG_FLAGS_SHOW_PASSWORD);
-
- GtkWidget *dialog = ephy_password_dialog_new
- (gparent,
- _("Change Token Password"),
- flags);
- EphyPasswordDialog *password_dialog = EPHY_PASSWORD_DIALOG (dialog);
-
- char *message;
- if (status == nsIPKCS11Slot::SLOT_UNINITIALIZED) {
- message = g_markup_printf_escaped (_("Choose a password for the “%s” token"),
- NS_ConvertUTF16toUTF8 (aTokenName).get ());
- } else {
- message = g_markup_printf_escaped (_("Change the password for the “%s” token"),
- NS_ConvertUTF16toUTF8 (aTokenName).get ());
- }
-
- gtk_message_dialog_set_markup (GTK_MESSAGE_DIALOG (dialog),
- message);
- g_free (message);
-
- int response;
- nsString oldPassword;
- PRBool pwdOk, needsLogin;
- do {
- response = gtk_dialog_run (GTK_DIALOG (dialog));
-
- if (status != nsIPKCS11Slot::SLOT_UNINITIALIZED)
- {
- const char *pwd = ephy_password_dialog_get_password (password_dialog);
- oldPassword = NS_ConvertUTF8toUTF16 (pwd);
- }
- } while (response == GTK_RESPONSE_OK &&
- status != nsIPKCS11Slot::SLOT_UNINITIALIZED &&
- NS_SUCCEEDED (token->NeedsLogin (&needsLogin)) && needsLogin &&
- NS_SUCCEEDED (token->CheckPassword (oldPassword.get (), &pwdOk) &&
- !pwdOk));
-
- if (response == GTK_RESPONSE_ACCEPT)
- {
- const char *pwd = ephy_password_dialog_get_new_password (password_dialog);
-
- NS_ConvertUTF8toUTF16 newPassword (pwd);
-
- if (status == nsIPKCS11Slot::SLOT_UNINITIALIZED)
- {
- rv = token->InitPassword (newPassword.get ());
- }
- else
- {
- rv = token->ChangePassword (oldPassword.get (),
- newPassword.get ());
- }
- }
- else
- {
- rv = NS_OK;
- }
-
- gtk_widget_destroy (GTK_WIDGET (dialog));
-
- *aCancelled = response != GTK_RESPONSE_ACCEPT;
-
- return rv;
-}
-
-/* void getPassword (in nsIInterfaceRequestor ctx, in wstring tokenName, out wstring password, out boolean canceled); */
-NS_IMETHODIMP
-GtkNSSDialogs::GetPassword(nsIInterfaceRequestor *aCtx,
- const PRUnichar *aTokenName,
- PRUnichar **aPassword,
- PRBool *aCancelled)
-{
- NS_ENSURE_ARG_POINTER(aCancelled);
-
- nsresult rv;
- nsCOMPtr<nsIPK11Token> token;
- nsCOMPtr<nsIPKCS11Slot> slot;
- rv = GetTokenAndSlotFromName (aTokenName, getter_AddRefs (token),
- getter_AddRefs (slot));
- NS_ENSURE_SUCCESS (rv, rv);
- NS_ENSURE_TRUE (token && slot, NS_ERROR_FAILURE);
-
- AutoJSContextStack stack;
- rv = stack.Init ();
- if (NS_FAILED (rv)) return rv;
-
- nsCOMPtr<nsIDOMWindow> parent (do_GetInterface (aCtx));
- GtkWidget *gparent = EphyUtils::FindGtkParent (parent);
-
- AutoWindowModalState modalState (parent);
-
- EphyPasswordDialogFlags flags =
- EphyPasswordDialogFlags (EPHY_PASSWORD_DIALOG_FLAGS_SHOW_PASSWORD);
-
- GtkWidget *dialog = ephy_password_dialog_new
- (gparent,
- _("Get Token Password"), /* FIXME */
- flags);
- EphyPasswordDialog *password_dialog = EPHY_PASSWORD_DIALOG (dialog);
-
- /* Translators: A "token" is something that enables the user to authenticate himself or
- * prove his credentials. This can be either a hardware device (e.g. a smart-card), or
- * a data file (e.g. a cryptographic certificate).
- */
- char *message = g_markup_printf_escaped (_("Please enter the password for the “%s” token"),
- NS_ConvertUTF16toUTF8 (aTokenName).get ());
- gtk_message_dialog_set_markup (GTK_MESSAGE_DIALOG (dialog),
- message);
- g_free (message);
-
- int response = gtk_dialog_run (GTK_DIALOG (dialog));
-
- if (response == GTK_RESPONSE_ACCEPT)
- {
- const char *pwd = ephy_password_dialog_get_password (password_dialog);
- *aPassword = NS_StringCloneData (NS_ConvertUTF8toUTF16 (pwd));
- }
-
- gtk_widget_destroy (GTK_WIDGET (dialog));
-
- *aCancelled = response != GTK_RESPONSE_ACCEPT;
-
- return NS_OK;
-}
-
-/* nsITokenDialogs */
-
-static void
-SelectionChangedCallback (GtkComboBox *combo,
- GtkDialog *dialog)
-{
- int active = gtk_combo_box_get_active (combo);
- gtk_dialog_set_response_sensitive (dialog, GTK_RESPONSE_ACCEPT, active >= 0);
-}
-
-/* void ChooseToken (in nsIInterfaceRequestor ctx,
- [array, size_is (count)] in wstring tokenNameList,
- in unsigned long count,
- out wstring tokenName,
- out boolean canceled); */
-NS_IMETHODIMP
-GtkNSSDialogs::ChooseToken (nsIInterfaceRequestor *aContext,
- const PRUnichar **tokenNameList,
- PRUint32 count,
- PRUnichar **_tokenName,
- PRBool *_cancelled)
-{
- NS_ENSURE_ARG (tokenNameList);
- NS_ENSURE_ARG (count);
-
- nsresult rv;
- AutoJSContextStack stack;
- rv = stack.Init ();
- if (NS_FAILED (rv)) return rv;
-
- /* Didn't you know it? MOZILLA SUCKS! ChooseToken is always called with |aContext| == NULL! See
- * http://bonsai.mozilla.org/cvsblame.cgi?file=mozilla/security/manager/ssl/src/nsKeygenHandler.cpp&rev=1.39&mark=346#346
- * Need to investigate if we it's always called directly from code called from JS, in which case we
- * can use EphyJSUtils::GetDOMWindowFromCallContext.
- */
- nsCOMPtr<nsIDOMWindow> parent (do_GetInterface (aContext));
- GtkWidget *gparent = EphyUtils::FindGtkParent (parent);
-
- AutoWindowModalState modalState (parent);
-
- GtkWidget *dialog = gtk_message_dialog_new
- (GTK_WINDOW (gparent),
- GTK_DIALOG_DESTROY_WITH_PARENT,
- GTK_MESSAGE_OTHER,
- GTK_BUTTONS_CANCEL,
- _("Please select a token:"));
-
- gtk_window_set_icon_name (GTK_WINDOW (dialog), EPHY_STOCK_EPHY);
-
- GtkWidget *combo = gtk_combo_box_new_text ();
- for (PRUint32 i = 0; i < count; ++i) {
- gtk_combo_box_append_text (GTK_COMBO_BOX (combo),
- NS_ConvertUTF16toUTF8 (tokenNameList[i]).get ());
- }
- gtk_combo_box_set_active (GTK_COMBO_BOX (combo), -1);
- g_signal_connect (combo, "changed",
- G_CALLBACK (SelectionChangedCallback), dialog);
-
- /* FIXME: View Cert button? */
-
- GtkWidget *vbox = GTK_MESSAGE_DIALOG (dialog)->label->parent;
- gtk_box_pack_start (GTK_BOX (vbox), combo, FALSE, FALSE, 0);
-
- gtk_dialog_add_button (GTK_DIALOG (dialog),
- _("_Select"),
- GTK_RESPONSE_ACCEPT);
-
- gtk_dialog_set_default_response (GTK_DIALOG (dialog), GTK_RESPONSE_REJECT);
-
- int response = gtk_dialog_run (GTK_DIALOG (dialog));
- int selected = gtk_combo_box_get_active (GTK_COMBO_BOX (combo));
-
- gtk_widget_destroy (dialog);
-
- *_cancelled = response != GTK_RESPONSE_ACCEPT;
-
- if (response == GTK_RESPONSE_ACCEPT) {
- NS_ENSURE_TRUE (selected >= 0 && selected < (int) count, NS_ERROR_FAILURE);
- *_tokenName = NS_StringCloneData (nsDependentString (tokenNameList[selected]));
- }
-
- return NS_OK;
-}
-
-/* nsIDOMCryptoDialogs */
-
-/* Note: this interface sucks! See https://bugzilla.mozilla.org/show_bug.cgi?id=341914 */
-
-/* boolean ConfirmKeyEscrow (in nsIX509Cert escrowAuthority); */
-NS_IMETHODIMP
-GtkNSSDialogs::ConfirmKeyEscrow (nsIX509Cert *aEscrowAuthority,
- PRBool *_retval)
-{
- NS_ENSURE_ARG (aEscrowAuthority);
-
- nsresult rv;
- AutoJSContextStack stack;
- rv = stack.Init ();
- if (NS_FAILED (rv)) return rv;
-
-#if 0
- nsCOMPtr<nsIDOMWindow> parent (do_GetInterface (aCtx));
-#endif
- nsCOMPtr<nsIDOMWindow> parent (EphyJSUtils::GetDOMWindowFromCallContext ());
- GtkWidget *gparent = EphyUtils::FindGtkParent (parent);
-
- AutoWindowModalState modalState (parent);
-
- /* FIXME: is that guaranteed to be non-empty? */
- nsString commonName;
- aEscrowAuthority->GetCommonName (commonName);
-
- GtkWidget *dialog = gtk_message_dialog_new
- (GTK_WINDOW (gparent),
- GTK_DIALOG_DESTROY_WITH_PARENT,
- GTK_MESSAGE_WARNING /* QUESTION really but it's also a strong warnings... */,
- GTK_BUTTONS_NONE,
- _("Escrow the secret key?"));
-
- /* FIXME: If I understand the documentation of generateCRMFRequest
- * correctly, key escrow is never used for signing keys (if it were,
- * we'd have to warn that the cert authority can forge your signature
- * too).
- */
- gtk_message_dialog_format_secondary_text
- (GTK_MESSAGE_DIALOG (dialog),
- _("The certificate authority “%s” requests that you give it a copy "
- "of the newly generated secret key.\n\n"
- "This will enable the certificate authority read any "
- "communications encrypted with this key "
- "without your knowledge or consent.\n\n"
- "It is strongly recommended not to allow it."),
- NS_ConvertUTF16toUTF8 (commonName).get ());
-
- gtk_window_set_icon_name (GTK_WINDOW (dialog), EPHY_STOCK_EPHY);
-
- GtkWidget *button = gtk_dialog_add_button (GTK_DIALOG (dialog),
- _("_Reject"),
- GTK_RESPONSE_REJECT);
- gtk_dialog_add_button (GTK_DIALOG (dialog),
- _("_Allow"),
- GTK_RESPONSE_ACCEPT);
- /* FIXME: View Cert button? */
-
- gtk_dialog_set_default_response (GTK_DIALOG (dialog), GTK_RESPONSE_REJECT);
- gtk_widget_grab_focus (button);
-
- int response = gtk_dialog_run (GTK_DIALOG (dialog));
- gtk_widget_destroy (dialog);
-
- *_retval = response == GTK_RESPONSE_ACCEPT;
-
- return NS_OK;
-}
diff --git a/embed/xulrunner/components/GtkNSSDialogs.h b/embed/xulrunner/components/GtkNSSDialogs.h
deleted file mode 100644
index 2edd1ffbe..000000000
--- a/embed/xulrunner/components/GtkNSSDialogs.h
+++ /dev/null
@@ -1,61 +0,0 @@
-/*
- * Copyright © 2003 Crispin Flowerday <gnome@flowerday.cx>
- * Copyright © 2006 Christian Persch
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#ifndef GTKNSSDIALOGS_H
-#define GTKNSSDIALOGS_H 1
-
-#include <nsIBadCertListener.h>
-#include <nsICertificateDialogs.h>
-#include <nsITokenPasswordDialogs.h>
-#include <nsITokenDialogs.h>
-#include <nsIDOMCryptoDialogs.h>
-
-class nsIPK11Token;
-class nsIPKCS11Slot;
-
-/* 7a50a10d-9425-4e12-84b1-5822edacd8ce */
-#define GTK_NSSDIALOGS_CID \
- {0x7a50a10d, 0x9425, 0x4e12, {0x84, 0xb1, 0x58, 0x22, 0xed, 0xac, 0xd8, 0xce}}
-
-#define GTK_NSSDIALOGS_CLASSNAME "Gtk NSS Dialogs"
-
-class GtkNSSDialogs : public nsIBadCertListener,
- public nsICertificateDialogs,
- public nsITokenPasswordDialogs,
- public nsITokenDialogs,
- public nsIDOMCryptoDialogs
-{
- public:
- NS_DECL_ISUPPORTS
- NS_DECL_NSIBADCERTLISTENER
- NS_DECL_NSICERTIFICATEDIALOGS
- NS_DECL_NSITOKENPASSWORDDIALOGS
- NS_DECL_NSITOKENDIALOGS
- NS_DECL_NSIDOMCRYPTODIALOGS
-
- GtkNSSDialogs();
- virtual ~GtkNSSDialogs();
-
- private:
- nsresult GetTokenAndSlotFromName(const PRUnichar*, nsIPK11Token**, nsIPKCS11Slot**);
-};
-
-#endif /* GTKNSSDIALOGS_H */
diff --git a/embed/xulrunner/components/GtkNSSKeyPairDialogs.cpp b/embed/xulrunner/components/GtkNSSKeyPairDialogs.cpp
deleted file mode 100644
index ac3afdfde..000000000
--- a/embed/xulrunner/components/GtkNSSKeyPairDialogs.cpp
+++ /dev/null
@@ -1,216 +0,0 @@
-/*
- * GtkNSSKeyPairDialogs.cpp
- *
- * Copyright © 2003 Crispin Flowerday <gnome@flowerday.cx>
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-/*
- * This file provides Gtk implementations of the mozilla Generating Key Pair
- * dialogs.
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include <glib/gi18n.h>
-#include <gtk/gtkdialog.h>
-#include <gtk/gtkhbox.h>
-#include <gtk/gtkimage.h>
-#include <gtk/gtklabel.h>
-#include <gtk/gtkmain.h>
-#include <gtk/gtkprogressbar.h>
-#include <gtk/gtkstock.h>
-#include <gtk/gtkvbox.h>
-
-#include <nsIDOMWindow.h>
-#include <nsIInterfaceRequestor.h>
-#include <nsIInterfaceRequestorUtils.h>
-#include <nsIKeygenThread.h>
-#include <nsIObserver.h>
-#include <nsIServiceManager.h>
-
-#include "ephy-debug.h"
-#include "ephy-gui.h"
-#include "ephy-stock-icons.h"
-
-#include "AutoJSContextStack.h"
-#include "AutoWindowModalState.h"
-#include "EphyUtils.h"
-
-#include "GtkNSSKeyPairDialogs.h"
-
-GtkNSSKeyPairDialogs::GtkNSSKeyPairDialogs ()
-{
- LOG ("GtkNSSKeyPairDialogs ctor (%p)", this);
-}
-
-GtkNSSKeyPairDialogs::~GtkNSSKeyPairDialogs ()
-{
- LOG ("GtkNSSKeyPairDialogs dtor (%p)", this);
-}
-
-NS_IMPL_THREADSAFE_ISUPPORTS1 (GtkNSSKeyPairDialogs,
- nsIGeneratingKeypairInfoDialogs)
-
-class KeyPairObserver : public nsIObserver
-{
-public:
- NS_DECL_NSIOBSERVER
- NS_DECL_ISUPPORTS
-
- KeyPairObserver() : close_called (FALSE) {};
- virtual ~KeyPairObserver() {};
-
- gboolean close_called;
-};
-
-NS_IMPL_ISUPPORTS1 (KeyPairObserver, nsIObserver);
-
-NS_IMETHODIMP KeyPairObserver::Observe (nsISupports *aSubject, const char *aTopic,
- const PRUnichar *aData)
-{
- close_called = TRUE;
- return NS_OK;
-}
-
-/* ------------------------------------------------------------ */
-static void
-begin_busy (GtkWidget *widget)
-{
- static GdkCursor *cursor = NULL;
-
- if (cursor == NULL) cursor = gdk_cursor_new (GDK_WATCH);
-
- if (!GTK_WIDGET_REALIZED (widget)) gtk_widget_realize (GTK_WIDGET(widget));
-
- gdk_window_set_cursor (GTK_WIDGET (widget)->window, cursor);
-
- /* Eek! FIXME: AutoJSContextStack! */
- while (gtk_events_pending ()) gtk_main_iteration ();
-}
-
-static void
-end_busy (GtkWidget *widget)
-{
- gdk_window_set_cursor (GTK_WIDGET(widget)->window, NULL);
-}
-
-
-struct KeyPairInfo
-{
- GtkWidget *progress;
- GtkWidget *dialog;
- KeyPairObserver *helper;
-};
-
-
-static gboolean
-generating_timeout_cb (KeyPairInfo *info)
-{
- gtk_progress_bar_pulse (GTK_PROGRESS_BAR (info->progress));
-
- if (info->helper->close_called)
- {
- gtk_dialog_response (GTK_DIALOG (info->dialog), GTK_RESPONSE_OK);
- }
- return TRUE;
-}
-
-
-/* void displayGeneratingKeypairInfo (in nsIInterfaceRequestor ctx,
- in nsIKeygenThread runnable); */
-NS_IMETHODIMP
-GtkNSSKeyPairDialogs::DisplayGeneratingKeypairInfo (nsIInterfaceRequestor *ctx,
- nsIKeygenThread *runnable)
-{
- GtkWidget *dialog, *progress, *label, *vbox;
- gint timeout_id;
-
- nsresult rv;
- AutoJSContextStack stack;
- rv = stack.Init ();
- if (NS_FAILED (rv)) return rv;
-
- nsCOMPtr<nsIDOMWindow> parent = do_GetInterface (ctx);
- GtkWindow *gparent = GTK_WINDOW (EphyUtils::FindGtkParent (parent));
-
- AutoWindowModalState modalState (parent);
-
- dialog = gtk_dialog_new_with_buttons ("", gparent,
- GTK_DIALOG_DESTROY_WITH_PARENT, (char *) NULL);
-
- if (gparent)
- {
- gtk_window_group_add_window (ephy_gui_ensure_window_group (gparent),
- GTK_WINDOW (dialog));
- }
-
- gtk_window_set_icon_name (GTK_WINDOW (dialog), EPHY_STOCK_EPHY);
-
- gtk_dialog_set_has_separator (GTK_DIALOG (dialog), FALSE);
- gtk_window_set_resizable (GTK_WINDOW (dialog), FALSE);
- gtk_container_set_border_width (GTK_CONTAINER (dialog), 5);
-
- vbox = gtk_vbox_new (FALSE, 12);
- gtk_container_set_border_width (GTK_CONTAINER (vbox), 5);
- gtk_box_pack_start (GTK_BOX(GTK_DIALOG(dialog)->vbox), vbox, TRUE, TRUE, 0);
-
- label = gtk_label_new (NULL);
- gtk_label_set_use_markup (GTK_LABEL (label), TRUE);
- gtk_label_set_line_wrap (GTK_LABEL (label), TRUE);
- gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.0);
- gtk_box_pack_start (GTK_BOX (vbox), label, TRUE, TRUE, 0);
-
- char *msg = g_strdup_printf ("<span weight=\"bold\" size=\"larger\">%s</span>\n\n%s",
- _("Generating Private Key."),
- _("Please wait while a new private key is "
- "generated. This process could take a few minutes." ));
- gtk_label_set_markup (GTK_LABEL(label), msg);
- g_free (msg);
-
- progress = gtk_progress_bar_new ();
- gtk_box_pack_start (GTK_BOX (vbox), progress, TRUE, TRUE, 0);
-
- /* Create a helper class that just waits for close events
- * from the other thread */
- nsCOMPtr<KeyPairObserver> helper = new KeyPairObserver;
-
- KeyPairInfo callback_data = { progress, dialog, helper };
- timeout_id = g_timeout_add (100, (GSourceFunc)generating_timeout_cb, &callback_data);
-
- gtk_widget_show_all (dialog);
- gtk_widget_hide (GTK_DIALOG (dialog)->action_area);
-
- begin_busy (dialog);
- runnable->StartKeyGeneration (helper);
- int res = gtk_dialog_run (GTK_DIALOG (dialog));
- if (res != GTK_RESPONSE_OK && helper->close_called == FALSE)
- {
- /* Ignore the already_closed flag, our nsIDOMWindowInterna::Close
- * function just sets a flag, it doesn't close the window, so we
- * dont have a race condition */
- PRBool already_closed = FALSE;
- runnable->UserCanceled (&already_closed);
- }
-
- g_source_remove (timeout_id);
- end_busy (dialog);
- gtk_widget_destroy (dialog);
- return NS_OK;
-}
diff --git a/embed/xulrunner/components/GtkNSSKeyPairDialogs.h b/embed/xulrunner/components/GtkNSSKeyPairDialogs.h
deleted file mode 100644
index f4b92d9e1..000000000
--- a/embed/xulrunner/components/GtkNSSKeyPairDialogs.h
+++ /dev/null
@@ -1,45 +0,0 @@
-/*
- * Copyright © 2003 Crispin Flowerday <gnome@flowerday.cx>
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- *
- * $Id$
- */
-
-#ifndef GTKNSSKEYPAIRDIALOGS_H
-#define GTKNSSKEYPAIRDIALOGS_H 1
-
-#include <nsIGenKeypairInfoDlg.h>
-
-// 6a8b1aff-ae8b-4751-982e-4ce5ad544100
-#define GTK_NSSKEYPAIRDIALOGS_CID \
- {0x6a8b1aff, 0xae8b, 0x4751, {0x98, 0x2e, 0x4c, 0xe5, 0xad, 0x54, 0x41, 0x10}}
-
-#define GTK_NSSKEYPAIRDIALOGS_CLASSNAME "Gtk NSS Key Pair Dialogs"
-
-class GtkNSSKeyPairDialogs
-: public nsIGeneratingKeypairInfoDialogs
-{
-public:
- NS_DECL_ISUPPORTS
- NS_DECL_NSIGENERATINGKEYPAIRINFODIALOGS
-
- GtkNSSKeyPairDialogs();
- virtual ~GtkNSSKeyPairDialogs();
-};
-
-
-#endif /* GTKNSSKEYPAIRDIALOGS_H */
diff --git a/embed/xulrunner/components/GtkNSSSecurityWarningDialogs.cpp b/embed/xulrunner/components/GtkNSSSecurityWarningDialogs.cpp
deleted file mode 100644
index 08f5e664a..000000000
--- a/embed/xulrunner/components/GtkNSSSecurityWarningDialogs.cpp
+++ /dev/null
@@ -1,285 +0,0 @@
-/* ***** BEGIN LICENSE BLOCK *****
- * Version: MPL 1.1/GPL 2.0/LGPL 2.1
- *
- * The contents of this file are subject to the Mozilla Public License Version
- * 1.1 (the "License"); you may not use this file except in compliance with
- * the License. You may obtain a copy of the License at
- * http://www.mozilla.org/MPL/
- *
- * Software distributed under the License is distributed on an "AS IS" basis,
- * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
- * for the specific language governing rights and limitations under the
- * License.
- *
- * The Original Code is mozilla.org code.
- *
- * The Initial Developer of the Original Code is
- * Netscape Communications Corporation.
- * Portions created by the Initial Developer are Copyright © 2001
- * the Initial Developer. All Rights Reserved.
- *
- * Contributor(s):
- * Terry Hayes <thayes@netscape.com>
- * Javier Delgadillo <javi@netscape.com>
- *
- * Alternatively, the contents of this file may be used under the terms of
- * either the GNU General Public License Version 2 or later (the "GPL"), or
- * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
- * in which case the provisions of the GPL or the LGPL are applicable instead
- * of those above. If you wish to allow use of your version of this file only
- * under the terms of either the GPL or the LGPL, and not to allow others to
- * use your version of this file under the terms of the MPL, indicate your
- * decision by deleting the provisions above and replace them with the notice
- * and other provisions required by the GPL or the LGPL. If you do not delete
- * the provisions above, a recipient may use your version of this file under
- * the terms of any one of the MPL, the GPL or the LGPL.
- *
- * ***** END LICENSE BLOCK *****
- *
- * Copyright © 2005 Christian Persch
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include <glib/gi18n.h>
-#include <gtk/gtkbox.h>
-#include <gtk/gtkdialog.h>
-#include <gtk/gtkhbox.h>
-#include <gtk/gtklabel.h>
-#include <gtk/gtkvbox.h>
-
-#include "ephy-stock-icons.h"
-
-#include <nsCOMPtr.h>
-#include <nsIDOMWindow.h>
-#include <nsIInterfaceRequestor.h>
-#include <nsIInterfaceRequestorUtils.h>
-#include <nsIPrefBranch.h>
-#include <nsIPrefService.h>
-#include <nsIServiceManager.h>
-#include <nsServiceManagerUtils.h>
-
-#include "AutoJSContextStack.h"
-#include "AutoWindowModalState.h"
-#include "EphyUtils.h"
-
-#include "GtkNSSSecurityWarningDialogs.h"
-
-NS_IMPL_THREADSAFE_ISUPPORTS1 (GtkNSSSecurityWarningDialogs, nsISecurityWarningDialogs)
-
-#define ENTER_SITE_PREF "security.warn_entering_secure"
-#define WEAK_SITE_PREF "security.warn_entering_weak"
-#define MIXEDCONTENT_PREF "security.warn_viewing_mixed"
-#define INSECURE_SUBMIT_PREF "security.warn_submit_insecure"
-
-GtkNSSSecurityWarningDialogs::GtkNSSSecurityWarningDialogs()
-{
-}
-
-GtkNSSSecurityWarningDialogs::~GtkNSSSecurityWarningDialogs()
-{
-}
-
-NS_IMETHODIMP
-GtkNSSSecurityWarningDialogs::ConfirmEnteringSecure (nsIInterfaceRequestor *aContext,
- PRBool *_retval)
-{
- DoDialog (aContext,
- ENTER_SITE_PREF,
- GTK_MESSAGE_INFO,
- GTK_BUTTONS_OK,
- GTK_RESPONSE_OK,
- _("Security Notice"),
- _("This page is loaded over a secure connection"),
- _("For secure pages, the address entry has a distinct "
- "color and a locked padlock icon is displayed.\n\n"
- "The padlock icon in the statusbar also indicates "
- "whether a page is secure."),
- nsnull, _retval);
-
- *_retval = PR_TRUE;
- return NS_OK;
-}
-
-NS_IMETHODIMP
-GtkNSSSecurityWarningDialogs::ConfirmEnteringWeak (nsIInterfaceRequestor *aContext,
- PRBool *_retval)
-{
- DoDialog (aContext,
- WEAK_SITE_PREF,
- GTK_MESSAGE_WARNING,
- GTK_BUTTONS_OK,
- GTK_RESPONSE_OK,
- _("Security Warning"),
- _("This page is loaded over a low security connection"),
- _("Any information you see or enter on this page could "
- "easily be intercepted by a third party."),
- nsnull, _retval);
-
- *_retval = PR_TRUE;
- return NS_OK;
-}
-
-NS_IMETHODIMP
-GtkNSSSecurityWarningDialogs::ConfirmLeavingSecure (nsIInterfaceRequestor *aContext,
- PRBool *_retval)
-{
- /* don't prompt */
- *_retval = PR_TRUE;
- return NS_OK;
-}
-
-NS_IMETHODIMP
-GtkNSSSecurityWarningDialogs::ConfirmMixedMode (nsIInterfaceRequestor *aContext,
- PRBool *_retval)
-{
- DoDialog (aContext,
- MIXEDCONTENT_PREF,
- GTK_MESSAGE_WARNING,
- GTK_BUTTONS_OK,
- GTK_RESPONSE_OK,
- _("Security Warning"),
- _("Some parts of this page are loaded over an insecure connection"),
- _("Some information you see or enter will be sent over an insecure "
- "connection, and could easily be intercepted by a third party."),
- nsnull, _retval);
-
- *_retval = PR_TRUE;
- return NS_OK;
-}
-
-NS_IMETHODIMP
-GtkNSSSecurityWarningDialogs::ConfirmPostToInsecure (nsIInterfaceRequestor *aContext,
- PRBool* _retval)
-{
- DoDialog (aContext,
- INSECURE_SUBMIT_PREF,
- GTK_MESSAGE_WARNING,
- GTK_BUTTONS_CANCEL,
- GTK_RESPONSE_ACCEPT,
- _("Security Warning"),
- _("Send this information over an insecure connection?"),
- _("The information you have entered will be sent over an "
- "insecure connection, and could easily be intercepted "
- "by a third party."),
- _("_Send"),
- _retval);
-
- return NS_OK;
-}
-
-NS_IMETHODIMP
-GtkNSSSecurityWarningDialogs::ConfirmPostToInsecureFromSecure (nsIInterfaceRequestor *aContext,
- PRBool* _retval)
-{
- DoDialog (aContext,
- nsnull, /* No preference for this one - it's too important */
- GTK_MESSAGE_WARNING,
- GTK_BUTTONS_CANCEL,
- GTK_RESPONSE_CANCEL,
- _("Security Warning"),
- _("Send this information over an insecure connection?"),
- _("Although this page was loaded over a secure connection, "
- "the information you have entered will be sent over an "
- "insecure connection, and could easily be intercepted by "
- "a third party."),
- _("_Send"),
- _retval);
-
- return NS_OK;
-}
-
-void
-GtkNSSSecurityWarningDialogs::DoDialog (nsIInterfaceRequestor *aContext,
- const char *aPrefName,
- GtkMessageType aType,
- GtkButtonsType aButtons,
- int aDefaultResponse,
- const char *aTitle,
- const char *aPrimary,
- const char *aSecondary,
- const char *aButtonText,
- PRBool *_retval)
-{
- *_retval = PR_FALSE;
-
- nsresult rv;
- PRBool show = PR_TRUE;
- nsCOMPtr<nsIPrefBranch> prefBranch
- (do_GetService (NS_PREFSERVICE_CONTRACTID));
- if (prefBranch && aPrefName)
- {
- rv = prefBranch->GetBoolPref (aPrefName, &show);
- if (NS_FAILED(rv)) show = PR_TRUE;
- }
-
- char *showOncePref = NULL;
- PRBool showOnce = PR_FALSE;
- if (!show && prefBranch && aPrefName)
- {
- showOncePref = g_strconcat (aPrefName, ".show_once", (char *) NULL);
- rv = prefBranch->GetBoolPref (showOncePref, &showOnce);
- if (NS_FAILED (rv)) showOnce = PR_FALSE;
- }
-
- if (!show && !showOnce)
- {
- g_free (showOncePref);
- *_retval = PR_TRUE;
- return;
- }
-
- /* On 1.8.0, domWin will be always nsnull, because of
- * https://bugzilla.mozilla.org/show_bug.cgi?id=277587
- */
- nsCOMPtr<nsIDOMWindow> domWin (do_GetInterface (aContext));
- GtkWidget *parent = EphyUtils::FindGtkParent (domWin);
-
- AutoJSContextStack stack;
- rv = stack.Init ();
- if (NS_FAILED (rv)) return;
-
- AutoWindowModalState modalState (domWin);
-
- GtkWidget *dialog = gtk_message_dialog_new (GTK_WINDOW (parent),
- GTK_DIALOG_MODAL, aType,
- aButtons, aPrimary);
-
- if (parent && GTK_WINDOW (parent)->group)
- {
- gtk_window_group_add_window (GTK_WINDOW (parent)->group,
- GTK_WINDOW (dialog));
- }
-
- if (aSecondary)
- {
- gtk_message_dialog_format_secondary_text
- (GTK_MESSAGE_DIALOG (dialog), aSecondary);
- }
-
- if (aButtonText)
- {
- gtk_dialog_add_button (GTK_DIALOG (dialog), aButtonText,
- GTK_RESPONSE_ACCEPT);
- }
-
- gtk_dialog_set_default_response (GTK_DIALOG (dialog), aDefaultResponse);
-
- gtk_window_set_title (GTK_WINDOW (dialog), aTitle);
- gtk_window_set_icon_name (GTK_WINDOW (dialog), EPHY_STOCK_EPHY);
-
- int response = gtk_dialog_run (GTK_DIALOG (dialog));
- gtk_widget_destroy (dialog);
-
- *_retval = (response == GTK_RESPONSE_ACCEPT || response == GTK_RESPONSE_OK);
-
- if (prefBranch && showOncePref && showOnce && *_retval)
- {
- prefBranch->SetBoolPref (showOncePref, PR_FALSE);
- }
-
- g_free (showOncePref);
-}
diff --git a/embed/xulrunner/components/GtkNSSSecurityWarningDialogs.h b/embed/xulrunner/components/GtkNSSSecurityWarningDialogs.h
deleted file mode 100644
index a84ea6585..000000000
--- a/embed/xulrunner/components/GtkNSSSecurityWarningDialogs.h
+++ /dev/null
@@ -1,83 +0,0 @@
-/* ***** BEGIN LICENSE BLOCK *****
- * Version: MPL 1.1/GPL 2.0/LGPL 2.1
- *
- * The contents of this file are subject to the Mozilla Public License Version
- * 1.1 (the "License"); you may not use this file except in compliance with
- * the License. You may obtain a copy of the License at
- * http://www.mozilla.org/MPL/
- *
- * Software distributed under the License is distributed on an "AS IS" basis,
- * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
- * for the specific language governing rights and limitations under the
- * License.
- *
- * The Original Code is mozilla.org code.
- *
- * The Initial Developer of the Original Code is
- * Netscape Communications Corporation.
- * Portions created by the Initial Developer are Copyright © 2001
- * the Initial Developer. All Rights Reserved.
- *
- * Contributor(s):
- * Terry Hayes <thayes@netscape.com>
- * Javier Delgadillo <javi@netscape.com>
- *
- * Alternatively, the contents of this file may be used under the terms of
- * either the GNU General Public License Version 2 or later (the "GPL"), or
- * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
- * in which case the provisions of the GPL or the LGPL are applicable instead
- * of those above. If you wish to allow use of your version of this file only
- * under the terms of either the GPL or the LGPL, and not to allow others to
- * use your version of this file under the terms of the MPL, indicate your
- * decision by deleting the provisions above and replace them with the notice
- * and other provisions required by the GPL or the LGPL. If you do not delete
- * the provisions above, a recipient may use your version of this file under
- * the terms of any one of the MPL, the GPL or the LGPL.
- *
- * ***** END LICENSE BLOCK *****
- *
- * Copyright © 2005 Christian Persch
- *
- * $Id$
- */
-
-#ifndef GTK_NSSSECURITYDIALOGS_H
-#define GTK_NSSSECURITYDIALOGS_H
-
-#include <gtk/gtkmessagedialog.h>
-
-#include <nsISecurityWarningDialogs.h>
-
-#define GTK_NSSSECURITYWARNINGDIALOGS_CLASSNAME "Epiphany Security Warning Dialogs Class"
-#define GTK_NSSSECURITYWARNINGDIALOGS_CID \
-{ \
- /* 1f5eac0a-d7e3-4f8e-b4d5-7240f7cba269 */ \
- 0x1f5eac0a, \
- 0xd7e3, \
- 0x4f8e, \
- { 0xb4, 0xd5, 0x72, 0x40, 0xf7, 0xcb, 0xa2, 0x69 } \
-}
-
-class GtkNSSSecurityWarningDialogs : public nsISecurityWarningDialogs
-{
-public:
- NS_DECL_ISUPPORTS
- NS_DECL_NSISECURITYWARNINGDIALOGS
-
- GtkNSSSecurityWarningDialogs();
- virtual ~GtkNSSSecurityWarningDialogs();
-
-protected:
- void DoDialog (nsIInterfaceRequestor *aContext,
- const char *aPrefName,
- GtkMessageType aType,
- GtkButtonsType aButtons,
- int aDefaultResponse,
- const char *aTitle,
- const char *aPrimary,
- const char *aSecondary,
- const char *aButtonText,
- PRBool *_retval);
-};
-
-#endif /* !GTK_NSSSECURITYDIALOGS_H */
diff --git a/embed/xulrunner/components/Makefile.am b/embed/xulrunner/components/Makefile.am
deleted file mode 100644
index ee48b74ff..000000000
--- a/embed/xulrunner/components/Makefile.am
+++ /dev/null
@@ -1,104 +0,0 @@
-NULL =
-
-noinst_LTLIBRARIES = libephycomponents.la
-
-libephycomponents_la_SOURCES = \
- ContentHandler.cpp \
- ContentHandler.h \
- EphyAboutModule.cpp \
- EphyAboutModule.h \
- EphyContentPolicy.cpp \
- EphyContentPolicy.h \
- EphyHistoryListener.cpp \
- EphyHistoryListener.h \
- EphyRedirectChannel.cpp \
- EphyRedirectChannel.h \
- EphySidebar.cpp \
- EphySidebar.h \
- GeckoCookiePromptService.cpp \
- GeckoCookiePromptService.h \
- GeckoFormSigningDialog.cpp \
- GeckoFormSigningDialog.h \
- GeckoPrintService.cpp \
- GeckoPrintService.h \
- GeckoPrintSession.cpp \
- GeckoPrintSession.h \
- GeckoPromptService.cpp \
- GeckoPromptService.h \
- GlobalHistory.cpp \
- GlobalHistory.h \
- MozDownload.cpp \
- MozDownload.h \
- MozRegisterComponents.cpp \
- MozRegisterComponents.h \
- $(NULL)
-
-# if ENABLE_FILEPICKER
-# libephycomponents_la_SOURCES += \
-# FilePicker.cpp \
-# FilePicker.h
-# endif
-
-# NOTE & FIXME: Most of these are GPL not LGPL
-# if HAVE_MOZILLA_PSM
-libephycomponents_la_SOURCES += \
- GtkNSSClientAuthDialogs.cpp \
- GtkNSSClientAuthDialogs.h \
- GtkNSSDialogs.cpp \
- GtkNSSDialogs.h \
- GtkNSSKeyPairDialogs.cpp \
- GtkNSSKeyPairDialogs.h \
- GtkNSSSecurityWarningDialogs.cpp\
- GtkNSSSecurityWarningDialogs.h
-# endif
-
-# if ENABLE_SPELLCHECKER
-libephycomponents_la_SOURCES += \
- GeckoSpellCheckEngine.cpp \
- GeckoSpellCheckEngine.h
-# endif
-
-libephycomponents_la_CPPFLAGS = \
- -I$(top_srcdir)/lib \
- -I$(top_srcdir)/embed \
- -I$(top_srcdir) \
- -I$(top_srcdir)/embed/xulrunner/src \
- -I$(top_srcdir)/embed/xulrunner/embed \
- -I$(top_srcdir)/embed/xulrunner/utils \
- -I$(top_builddir)/embed/xulrunner/src \
- -I$(top_builddir)/embed/xulrunner/embed \
- -DSHARE_DIR=\"$(pkgdatadir)\" \
- -DPLUGINDIR=\"$(libdir)/epiphany/$(EPIPHANY_MAJOR)/plugins\" \
- -DMOZILLA_HOME=\"$(LIBXUL_LIBDIR)\" \
- -DMOZILLA_PREFIX=\"$(LIBXUL_PREFIX)\" \
- -DMOZILLA_NATIVE_PLUGINSDIR=\"$(libdir)/mozilla/plugins\" \
- -DUA_VERSION=\"$(EPIPHANY_UA_VERSION)\" \
- -DALLOW_PRIVATE_API \
- $(LIBXUL_CXXCPPFLAGS) \
- $(LIBXUL_INCLUDES) \
- $(AM_CPPFLAGS)
-
-libephycomponents_la_CXXFLAGS = \
- $(LIBXUL_CXXFLAGS) \
- $(GTK_CFLAGS) \
- $(GTKPRINT_CFLAGS) \
- $(GNOMEVFS_CFLAGS) \
- $(GCONF_CFLAGS) \
- $(GLADE_CFLAGS) \
- $(GNOME_CFLAGS) \
- $(AM_CXXFLAGS)
-
-libephycomponents_la_LDFLAGS = \
- $(AM_LDFLAGS)
-
-libephycomponents_la_LIBADD = \
- $(top_builddir)/embed/xulrunner/utils/libephyxulrunnerutils.la \
- $(top_builddir)/embed/xulrunner/src/libgnomegeckoembed.la \
- $(top_builddir)/embed/xulrunner/embed/libephyxulrunnerembed.la \
- $(LIBXUL_LIBS)
-
-CLEANFILES =
- $(NULL)
-
-EXTRA_DIST = \
- $(NULL)
diff --git a/embed/xulrunner/components/MozDownload.cpp b/embed/xulrunner/components/MozDownload.cpp
deleted file mode 100644
index b079b83b3..000000000
--- a/embed/xulrunner/components/MozDownload.cpp
+++ /dev/null
@@ -1,824 +0,0 @@
-/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
-/* ***** BEGIN LICENSE BLOCK *****
- * Version: MPL 1.1/GPL 2.0/LGPL 2.1
- *
- * The contents of this file are subject to the Mozilla Public License Version
- * 1.1 (the "License"); you may not use this file except in compliance with
- * the License. You may obtain a copy of the License at
- * http://www.mozilla.org/MPL/
- *
- * Software distributed under the License is distributed on an "AS IS" basis,
- * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
- * for the specific language governing rights and limitations under the
- * License.
- *
- * The Original Code is mozilla.org code.
- *
- * The Initial Developer of the Original Code is
- * Netscape Communications Corporation.
- * Portions created by the Initial Developer are Copyright © 2002
- * the Initial Developer. All Rights Reserved.
- *
- * Contributor(s):
- * Conrad Carlen <ccarlen@netscape.com>
- *
- * Adapted for epiphany by Marco Pesenti Gritti <marco@gnome.org>
- *
- * Alternatively, the contents of this file may be used under the terms of
- * either the GNU General Public License Version 2 or later (the "GPL"), or
- * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
- * in which case the provisions of the GPL or the LGPL are applicable instead
- * of those above. If you wish to allow use of your version of this file only
- * under the terms of either the GPL or the LGPL, and not to allow others to
- * use your version of this file under the terms of the MPL, indicate your
- * decision by deleting the provisions above and replace them with the notice
- * and other provisions required by the GPL or the LGPL. If you do not delete
- * the provisions above, a recipient may use your version of this file under
- * the terms of any one of the MPL, the GPL or the LGPL.
- *
- * ***** END LICENSE BLOCK *****
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include <stdlib.h>
-
-#include <glib/gi18n.h>
-#include <gio/gdesktopappinfo.h>
-#include <gio/gio.h>
-
-#include <nsStringGlue.h>
-
-#include <nsComponentManagerUtils.h>
-#include <nsICancelable.h>
-#include <nsIChannel.h>
-#include <nsIDOMDocument.h>
-#include <nsIFileURL.h>
-#include <nsIIOService.h>
-#include <nsILocalFile.h>
-#include <nsIMIMEInfo.h>
-#include <nsIMIMEService.h>
-#include <nsIObserver.h>
-#include <nsIRequest.h>
-#include <nsIURI.h>
-#include <nsIWritablePropertyBag2.h>
-#include <nsIWebBrowserPersist.h>
-
-#include <nsMemory.h>
-#include <nsNetError.h>
-#include <nsServiceManagerUtils.h>
-
-#include "EphyBadCertRejector.h"
-#include "EphyUtils.h"
-
-#include "eel-gconf-extensions.h"
-#include "ephy-debug.h"
-#include "ephy-file-helpers.h"
-#include "ephy-prefs.h"
-#include "mozilla-download.h"
-
-#include "MozDownload.h"
-
-/* Minimum time between progress updates */
-#define PROGRESS_RATE 500000 /* microsec */
-
-const char* const persistContractID = "@mozilla.org/embedding/browser/nsWebBrowserPersist;1";
-
-MozDownload::MozDownload() :
- mTotalProgress(-1),
- mCurrentProgress(0),
- mMaxSize(-1),
- mAddToRecent(PR_TRUE),
- mStatus(NS_OK),
- mEmbedPersist(nsnull),
- mDownloadState(EPHY_DOWNLOAD_INITIALISING)
-{
- LOG ("MozDownload ctor (%p)", (void *) this);
-}
-
-MozDownload::~MozDownload()
-{
- LOG ("MozDownload dtor (%p)", (void *) this);
-
- NS_ASSERTION (!mEphyDownload, "MozillaDownload still alive!");
-}
-
-NS_IMPL_ISUPPORTS4 (MozDownload,
- nsIWebProgressListener,
- nsIWebProgressListener2,
- nsITransfer,
- nsIInterfaceRequestor)
-
-nsresult
-MozDownload::InitForEmbed (nsIURI *aSource, nsIURI *aTarget, const nsAString &aDisplayName,
- nsIMIMEInfo *aMIMEInfo, PRTime aStartTime, nsILocalFile *aTempFile,
- nsICancelable *aCancelable, MozillaEmbedPersist *aEmbedPersist,
- PRInt64 aMaxSize)
-{
- mEmbedPersist = aEmbedPersist;
- mMaxSize = aMaxSize;
- return Init (aSource, aTarget, aDisplayName, aMIMEInfo, aStartTime, aTempFile, aCancelable);
-}
-
-/* void init (in nsIURI aSource, in nsIURI aTarget, in AString aDisplayName, in nsIMIMEInfo aMIMEInfo, in PRTime startTime, in nsILocalFile aTempFile, in nsICancelable aCancelable); */
-NS_IMETHODIMP
-MozDownload::Init (nsIURI *aSource,
- nsIURI *aTarget,
- const nsAString &aDisplayName,
- nsIMIMEInfo *aMIMEInfo,
- PRTime aStartTime,
- nsILocalFile *aTempFile,
- nsICancelable *aCancelable)
-{
- PRBool addToView = PR_TRUE;
-
- if (mEmbedPersist)
- {
- EphyEmbedPersistFlags flags;
-
- flags = ephy_embed_persist_get_flags (EPHY_EMBED_PERSIST (mEmbedPersist));
-
- addToView = !(flags & EPHY_EMBED_PERSIST_NO_VIEW);
- }
-
- mSource = aSource;
- mDestination = aTarget;
- mStartTime = aStartTime;
- mTotalProgress = 0;
- mCurrentProgress = 0;
- mPercentComplete = 0;
- mInterval = PROGRESS_RATE;
- mLastUpdate = mStartTime;
- mMIMEInfo = aMIMEInfo;
- mAddToRecent = addToView;
-
- /* This will create a refcount cycle, which needs to be broken in ::OnStateChange */
- mCancelable = aCancelable;
-
- if (addToView)
- {
- DownloaderView *dview;
- dview = EPHY_DOWNLOADER_VIEW
- (ephy_embed_shell_get_downloader_view (embed_shell));
- mEphyDownload = mozilla_download_new (this);
- g_object_add_weak_pointer (G_OBJECT (mEphyDownload),
- (gpointer *) &mEphyDownload);
- downloader_view_add_download (dview, mEphyDownload);
- g_object_unref (mEphyDownload);
- }
- else
- {
- mEphyDownload = nsnull;
- }
-
- return NS_OK;
-}
-
-NS_IMETHODIMP
-MozDownload::GetSource(nsIURI **aSource)
-{
- NS_ENSURE_ARG_POINTER(aSource);
- NS_IF_ADDREF(*aSource = mSource);
-
- return NS_OK;
-}
-
-NS_IMETHODIMP
-MozDownload::GetTargetFile (nsILocalFile** aTargetFile)
-{
- nsresult rv;
-
- nsCOMPtr<nsIFileURL> fileURL = do_QueryInterface(mDestination, &rv);
- if (NS_FAILED(rv)) return rv;
-
- nsCOMPtr<nsIFile> file;
- rv = fileURL->GetFile(getter_AddRefs(file));
- if (NS_SUCCEEDED(rv))
- rv = CallQueryInterface(file, aTargetFile);
- return rv;
-}
-
-NS_IMETHODIMP
-MozDownload::GetPercentComplete(PRInt32 *aPercentComplete)
-{
- NS_ENSURE_ARG_POINTER(aPercentComplete);
- *aPercentComplete = mPercentComplete;
-
- return NS_OK;
-}
-
-NS_IMETHODIMP
-MozDownload::GetTotalProgress(PRInt64 *aTotalProgress)
-{
- NS_ENSURE_ARG_POINTER(aTotalProgress);
- *aTotalProgress = mTotalProgress;
-
- return NS_OK;
-}
-
-NS_IMETHODIMP
-MozDownload::GetCurrentProgress(PRInt64 *aCurrentProgress)
-{
- NS_ENSURE_ARG_POINTER(aCurrentProgress);
- *aCurrentProgress = mCurrentProgress;
-
- return NS_OK;
-}
-
-NS_IMETHODIMP
-MozDownload::GetState(EphyDownloadState *aDownloadState)
-{
- NS_ENSURE_ARG_POINTER(aDownloadState);
- *aDownloadState = mDownloadState;
-
- return NS_OK;
-}
-
-NS_IMETHODIMP
-MozDownload::GetElapsedTime(PRInt64 *aElapsedTime)
-{
- NS_ENSURE_ARG_POINTER(aElapsedTime);
- *aElapsedTime = PR_Now() - mStartTime;
-
- return NS_OK;
-}
-
-NS_IMETHODIMP
-MozDownload::GetMIMEInfo(nsIMIMEInfo **aMIMEInfo)
-{
- NS_ENSURE_ARG_POINTER(aMIMEInfo);
- NS_IF_ADDREF(*aMIMEInfo = mMIMEInfo);
-
- return NS_OK;
-}
-
-NS_IMETHODIMP
-MozDownload::OnStateChange (nsIWebProgress *aWebProgress, nsIRequest *aRequest,
- PRUint32 aStateFlags, nsresult aStatus)
-{
- nsresult rv;
-
- if (NS_FAILED(aStatus) && NS_SUCCEEDED(mStatus))
- mStatus = aStatus;
-
- if (aStateFlags & STATE_START)
- {
- mDownloadState = EPHY_DOWNLOAD_DOWNLOADING;
-
- if (mEphyDownload)
- {
- g_signal_emit_by_name (mEphyDownload, "changed");
- }
- }
-
- /* We will get this even in the event of a cancel */
- /* Due to a mozilla bug [https://bugzilla.mozilla.org/show_bug.cgi?id=304353],
- * we'll only get STATE_STOP if we're driven from external app handler; elsewhere
- * we get STATE_STOP | STATE_IS_NETWORK | STATE_IS_REQUEST. So check first if
- * STATE_IS_REQUEST is set.
- */
- /* Be careful that download is only completed when STATE_IS_NETWORK is set
- * and many lonely STOP events may be triggered before.
- */
-#ifdef GNOME_ENABLE_DEBUG
-{
- nsCString spec;
- if (mSource) mSource->GetSpec(spec);
-
- LOG ("url %s, status %x, state %x (is-stop:%s, is-network:%s, is-request:%s)",
- spec.get(), aStatus, aStateFlags,
- aStateFlags & STATE_STOP ? "t" : "f",
- aStateFlags & STATE_IS_NETWORK ? "t" : "f",
- aStateFlags & STATE_IS_REQUEST ? "t" : "f");
-}
-#endif
-
- if (((aStateFlags & STATE_IS_REQUEST) &&
- (aStateFlags & STATE_IS_NETWORK) &&
- (aStateFlags & STATE_STOP)) ||
- aStateFlags == STATE_STOP)
- {
- LOG ("STATE_STOP");
-
- /* Keep us alive */
- nsCOMPtr<nsITransfer> kungFuDeathGrip(this);
-
- mDownloadState = NS_SUCCEEDED (aStatus) ? EPHY_DOWNLOAD_COMPLETED : EPHY_DOWNLOAD_FAILED;
- if (mEphyDownload)
- {
- g_signal_emit_by_name (mEphyDownload, "changed");
- }
-
- /* break refcount cycle */
- mCancelable = nsnull;
-
- nsCString destSpec;
- nsCString mimeType;
-
- mDestination->GetSpec (destSpec);
-
- if (NS_SUCCEEDED (aStatus) && mMIMEInfo)
- {
- rv = mMIMEInfo->GetMIMEType (mimeType);
- NS_ENSURE_SUCCESS (rv, NS_ERROR_FAILURE);
- }
-
- if (mAddToRecent)
- {
- ephy_file_add_recent_item (destSpec.get(), mimeType.get());
- }
-
- if (mEmbedPersist)
- {
- if (NS_SUCCEEDED (aStatus))
- {
- mozilla_embed_persist_completed (mEmbedPersist);
- }
- else
- {
- mozilla_embed_persist_cancelled (mEmbedPersist);
- }
- }
- else if (NS_SUCCEEDED (aStatus))
- {
- /* see http://bugzilla.gnome.org/show_bug.cgi?id=456945 */
-#if 1 //def HAVE_GECKO_1_9
- // FIXMEchpe fix this!
- return NS_OK;
-#else
- GDesktopAppInfo *helperApp;
- NS_ENSURE_TRUE (mMIMEInfo, NS_ERROR_FAILURE);
-
- nsString description;
- mMIMEInfo->GetApplicationDescription (description);
-
- nsCString cDesc;
- NS_UTF16ToCString (description, NS_CSTRING_ENCODING_UTF8, cDesc);
-
- /* HACK we use the application description to decide
- if we have to open the saved file */
- if (g_str_has_prefix (cDesc.get(), "gnome-default:"))
- {
- /* Format gnome-default:<usertime>:<helperapp id> */
- char **str = g_strsplit (cDesc.get(), ":", -1);
- g_return_val_if_fail (g_strv_length (str) == 3, NS_ERROR_FAILURE);
-
- char *end;
- guint32 user_time = strtoul (str[1], &end, 0);
-
- helperApp = g_desktop_app_info_new (str[2]);
- if (!helperApp) return NS_ERROR_FAILURE;
-
- nsCString aDest;
- rv = mDestination->GetSpec (aDest);
- NS_ENSURE_SUCCESS (rv, NS_ERROR_FAILURE);
-
- GFile* file;
- GList* list = NULL;
-
- file = g_file_new_for_uri (destSpec.get ());
- list = g_list_append (list, file);
- ephy_file_launch_application (G_APP_INFO (helperApp), list, user_time, NULL);
-
- g_list_free (list);
- g_object_unref (file);
- g_strfreev (str);
- }
- else if (g_str_has_prefix (cDesc.get(), "gnome-browse-to-file:"))
- {
- /* Format gnome-browse-to-file:<usertime> */
- char **str = g_strsplit (cDesc.get(), ":", -1);
- g_return_val_if_fail (g_strv_length (str) == 2, NS_ERROR_FAILURE);
-
- char *end;
- guint32 user_time = strtoul (str[1], &end, 0);
-
- nsCString aDest;
- rv = mDestination->GetSpec (aDest);
- NS_ENSURE_SUCCESS (rv, NS_ERROR_FAILURE);
-
- GFile *dest;
-
- dest = g_file_new_for_uri (dest);
- ephy_file_browse_to (dest, user_time);
-
- g_object_unref (dest);
- g_strfreev (str);
- }
-#endif /* HAVE_GECKO_1_9 */
- }
- }
-
- return NS_OK;
-}
-
-NS_IMETHODIMP
-MozDownload::OnProgressChange (nsIWebProgress *aWebProgress,
- nsIRequest *aRequest,
- PRInt32 aCurSelfProgress,
- PRInt32 aMaxSelfProgress,
- PRInt32 aCurTotalProgress,
- PRInt32 aMaxTotalProgress)
-{
- return OnProgressChange64 (aWebProgress, aRequest,
- aCurSelfProgress, aMaxSelfProgress,
- aCurTotalProgress, aMaxTotalProgress);
-}
-
-/* void onProgressChange64 (in nsIWebProgress aWebProgress, in nsIRequest aRequest, in long long aCurSelfProgress, in long long aMaxSelfProgress, in long long aCurTotalProgress,
- in long long aMaxTotalProgress); */
-NS_IMETHODIMP
-MozDownload::OnProgressChange64 (nsIWebProgress *aWebProgress,
- nsIRequest *aRequest,
- PRInt64 aCurSelfProgress,
- PRInt64 aMaxSelfProgress,
- PRInt64 aCurTotalProgress,
- PRInt64 aMaxTotalProgress)
-{
- if (mMaxSize >= 0 &&
- ((aMaxTotalProgress > 0 && mMaxSize < aMaxTotalProgress) ||
- mMaxSize < aCurTotalProgress))
- {
- Cancel ();
- }
-
- if (!mRequest)
- mRequest = aRequest;
-
- PRInt64 now = PR_Now ();
-
- if ((now - mLastUpdate < mInterval) &&
- (aMaxTotalProgress == -1 || aCurTotalProgress < aMaxTotalProgress))
- return NS_OK;
-
- mLastUpdate = now;
-
- if (aMaxTotalProgress <= 0)
- {
- mPercentComplete = -1;
- }
- else
- {
- /* Make sure not to round up, so we don't display 100% unless
- * it's really finished!
- */
- mPercentComplete = (PRInt32)(((float)aCurTotalProgress / (float)aMaxTotalProgress) * 100.0);
- }
-
- mTotalProgress = aMaxTotalProgress;
- mCurrentProgress = aCurTotalProgress;
-
- if (mEphyDownload)
- {
- g_signal_emit_by_name (mEphyDownload, "changed");
- }
-
- return NS_OK;
-}
-
-/* boolean onRefreshAttempted (in nsIWebProgress aWebProgress, in nsIURI aRefreshURI, in long aDelay, in boolean aSameURI); */
-NS_IMETHODIMP
-MozDownload::OnRefreshAttempted(nsIWebProgress *aWebProgress,
- nsIURI *aUri,
- PRInt32 aDelay,
- PRBool aSameUri,
- PRBool *allowRefresh)
-{
- *allowRefresh = PR_TRUE;
- return NS_OK;
-}
-
-NS_IMETHODIMP
-MozDownload::OnLocationChange (nsIWebProgress *aWebProgress, nsIRequest *aRequest, nsIURI *location)
-{
- return NS_OK;
-}
-
-NS_IMETHODIMP
-MozDownload::OnStatusChange (nsIWebProgress *aWebProgress, nsIRequest *aRequest,
- nsresult aStatus, const PRUnichar *aMessage)
-{
- return NS_OK;
-}
-
-NS_IMETHODIMP
-MozDownload::OnSecurityChange (nsIWebProgress *aWebProgress, nsIRequest *aRequest, PRUint32 state)
-{
- return NS_OK;
-}
-
-/* void getInterface (in nsIIDRef uuid, [iid_is (uuid), retval] out nsQIResult result); */
-NS_IMETHODIMP
-MozDownload::GetInterface(const nsIID & uuid, void * *result)
-{
- if (uuid.Equals (NS_GET_IID (nsIBadCertListener)) &&
- mEmbedPersist)
- {
- EphyEmbedPersistFlags flags;
-
- g_object_get (mEmbedPersist, "flags", &flags, (char *) NULL);
-
- if (flags & EPHY_EMBED_PERSIST_NO_CERTDIALOGS)
- {
- nsIBadCertListener *badCertRejector = new EphyBadCertRejector ();
- if (!badCertRejector) return NS_ERROR_OUT_OF_MEMORY;
-
- *result = badCertRejector;
- NS_ADDREF (badCertRejector);
-
- return NS_OK;
- }
- }
-
- return NS_ERROR_NO_INTERFACE;
-}
-
-void
-MozDownload::Cancel()
-{
- if (mDownloadState != EPHY_DOWNLOAD_DOWNLOADING &&
- mDownloadState != EPHY_DOWNLOAD_PAUSED)
- {
- return;
- }
-
- if (mCancelable)
- {
- /* FIXME: error code? */
- mCancelable->Cancel (NS_BINDING_ABORTED);
- }
-}
-
-void
-MozDownload::Pause()
-{
- if (mRequest)
- {
- mRequest->Suspend ();
- mDownloadState = EPHY_DOWNLOAD_PAUSED;
- }
-}
-
-void
-MozDownload::Resume()
-{
- if (mRequest)
- {
- mRequest->Resume ();
- mDownloadState = EPHY_DOWNLOAD_DOWNLOADING;
- }
-}
-
-nsresult InitiateMozillaDownload (nsIDOMDocument *domDocument, nsIURI *sourceURI,
- nsILocalFile* inDestFile, const char *contentType,
- nsIURI* inOriginalURI, MozillaEmbedPersist *embedPersist,
- nsIInputStream *postData, nsISupports *aCacheKey,
- PRInt64 aMaxSize)
-{
- nsresult rv = NS_OK;
-
- EphyEmbedPersistFlags ephy_flags;
- ephy_flags = ephy_embed_persist_get_flags (EPHY_EMBED_PERSIST (embedPersist));
-
- if (!ephy_embed_persist_get_dest (EPHY_EMBED_PERSIST (embedPersist)))
- {
- nsCString cPath;
- inDestFile->GetNativePath (cPath);
-
- ephy_embed_persist_set_dest (EPHY_EMBED_PERSIST (embedPersist),
- cPath.get());
- }
-
- nsCOMPtr<nsIMIMEService> mimeService (do_GetService ("@mozilla.org/mime;1"));
- nsCOMPtr<nsIMIMEInfo> mimeInfo;
- if (mimeService)
- {
- mimeService->GetFromTypeAndExtension (nsCString(contentType),
- nsCString(),
- getter_AddRefs (mimeInfo));
- }
-
- PRBool isHTML = (contentType &&
- (strcmp (contentType, "text/html") == 0 ||
- strcmp (contentType, "text/xml") == 0 ||
- strcmp (contentType, "application/xhtml+xml") == 0));
-
- nsCOMPtr<nsIWebBrowserPersist> webPersist (do_CreateInstance(persistContractID, &rv));
- NS_ENSURE_SUCCESS (rv, rv);
-
- PRInt64 timeNow = PR_Now();
-
- nsString fileDisplayName;
- inDestFile->GetLeafName(fileDisplayName);
-
- nsCOMPtr<nsIIOService> ioService;
- rv = EphyUtils::GetIOService (getter_AddRefs (ioService));
- NS_ENSURE_SUCCESS (rv, rv);
-
- nsCOMPtr<nsIURI> destURI;
- ioService->NewFileURI (inDestFile, getter_AddRefs(destURI));
-
- MozDownload *downloader = new MozDownload ();
- /* dlListener attaches to its progress dialog here, which gains ownership */
- /* FIXME is that still true? */
- rv = downloader->InitForEmbed (inOriginalURI, destURI, fileDisplayName,
- mimeInfo, timeNow, nsnull, webPersist, embedPersist, aMaxSize);
- NS_ENSURE_SUCCESS (rv, rv);
-
- rv = webPersist->SetProgressListener (downloader);
- NS_ENSURE_SUCCESS (rv, rv);
-
- PRInt32 flags = nsIWebBrowserPersist::PERSIST_FLAGS_REPLACE_EXISTING_FILES;
-
- if (!domDocument && !isHTML && !(ephy_flags & EPHY_EMBED_PERSIST_COPY_PAGE) &&
- !(ephy_flags & EPHY_EMBED_PERSIST_DO_CONVERSION))
- {
- flags |= nsIWebBrowserPersist::PERSIST_FLAGS_NO_CONVERSION;
- }
- if (ephy_flags & EPHY_EMBED_PERSIST_COPY_PAGE)
- {
- flags |= nsIWebBrowserPersist::PERSIST_FLAGS_FROM_CACHE;
- }
- webPersist->SetPersistFlags(flags);
-
- /* Create a new tagged channel if we need to block cookies from server */
- if (ephy_flags & EPHY_EMBED_PERSIST_NO_COOKIES)
- {
- nsCOMPtr<nsIChannel> tmpChannel;
- rv = ioService->NewChannelFromURI (sourceURI, getter_AddRefs (tmpChannel));
- NS_ENSURE_SUCCESS (rv, rv);
-
- nsCOMPtr<nsIWritablePropertyBag2> props = do_QueryInterface(tmpChannel);
- rv = props->SetPropertyAsBool (NS_LITERAL_STRING("epiphany-blocking-cookies"), PR_TRUE);
- NS_ENSURE_SUCCESS (rv, rv);
-
- rv = webPersist->SaveChannel (tmpChannel, inDestFile);
- }
- else if (!domDocument || !isHTML || ephy_flags & EPHY_EMBED_PERSIST_COPY_PAGE)
- {
- rv = webPersist->SaveURI (sourceURI, aCacheKey, nsnull,
- postData, nsnull, inDestFile);
- }
- else
- {
- PRInt32 encodingFlags = 0;
- nsCOMPtr<nsILocalFile> filesFolder;
-
- /**
- * Construct a directory path to hold the associated files; mozilla
- * will create the directory as needed.
- */
-
- nsCString cPath;
- inDestFile->GetNativePath (cPath);
-
- char *basename = g_path_get_basename (cPath.get());
- char *dirname = g_path_get_dirname (cPath.get());
- char *dot_pos = strchr (basename, '.');
- if (dot_pos)
- {
- *dot_pos = 0;
- }
- /* translators: this is the directory name to store auxilary files when saving html files */
- char *new_basename = g_strdup_printf (_("%s Files"), basename);
- char *new_path = g_build_filename (dirname, new_basename, NULL);
- g_free (new_basename);
- g_free (basename);
- g_free (dirname);
-
- filesFolder = do_CreateInstance ("@mozilla.org/file/local;1");
- filesFolder->InitWithNativePath (nsCString(new_path));
-
- g_free (new_path);
-
- rv = webPersist->SaveDocument (domDocument, inDestFile, filesFolder,
- contentType, encodingFlags, 80);
- }
-
- return rv;
-}
-
-static char*
-GetFilePath (const char *filename)
-{
- const char *home_dir;
- char *download_dir, *path;
-
- download_dir = ephy_file_get_downloads_dir ();
-
- if (ephy_ensure_dir_exists (download_dir, NULL))
- {
- path = g_build_filename (download_dir, filename, (char *) NULL);
- }
- else
- {
- home_dir = g_get_home_dir ();
- path = g_build_filename (home_dir ? home_dir : "/", filename, (char *) NULL);
- }
- g_free (download_dir);
-
- return path;
-}
-
-static const char*
-file_is_compressed (const char *filename)
-{
- int i;
- static const char * const compression[] = {".gz", ".bz2", ".Z", ".lz", NULL};
-
- for (i = 0; compression[i] != NULL; i++)
- {
- if (g_str_has_suffix (filename, compression[i]))
- return compression[i];
- }
-
- return NULL;
-}
-
-static const char*
-parse_extension (const char *filename)
-{
- const char *compression;
-
- compression = file_is_compressed (filename);
-
- /* If the file is compressed we might have a double extension */
- if (compression != NULL)
- {
- int i;
- static const char * const extensions[] = {"tar", "ps", "xcf", "dvi", "txt", "text", NULL};
-
- for (i = 0; extensions[i] != NULL; i++)
- {
- char *suffix;
- suffix = g_strdup_printf (".%s%s", extensions[i],
- compression);
-
- if (g_str_has_suffix (filename, suffix))
- {
- char *p;
-
- p = g_strrstr (filename, suffix);
- g_free (suffix);
-
- return p;
- }
-
- g_free (suffix);
- }
- }
-
- /* default case */
- return g_strrstr (filename, ".");
-}
-
-nsresult BuildDownloadPath (const char *defaultFileName, nsILocalFile **_retval)
-{
- char *path;
-
- path = GetFilePath (defaultFileName);
-
- if (g_file_test (path, G_FILE_TEST_EXISTS))
- {
- int i = 1;
- const char *dot_pos;
- char *serial = NULL;
- GString *tmp_path;
- gssize position;
-
- dot_pos = parse_extension (defaultFileName);
- if (dot_pos)
- {
- position = dot_pos - defaultFileName;
- }
- else
- {
- position = strlen (defaultFileName);
- }
- tmp_path = g_string_new (NULL);
-
- do {
- g_free (path);
- g_string_assign (tmp_path, defaultFileName);
- serial = g_strdup_printf ("(%d)", i++);
- g_string_insert (tmp_path, position, serial);
- g_free (serial);
- path = GetFilePath (tmp_path->str);
-
- } while (g_file_test (path, G_FILE_TEST_EXISTS));
-
- g_string_free (tmp_path, TRUE);
- }
-
- nsCOMPtr <nsILocalFile> destFile (do_CreateInstance(NS_LOCAL_FILE_CONTRACTID));
- NS_ENSURE_TRUE (destFile, NS_ERROR_FAILURE);
-
- destFile->InitWithNativePath (nsCString (path));
- g_free (path);
-
- NS_IF_ADDREF (*_retval = destFile);
- return NS_OK;
-}
diff --git a/embed/xulrunner/components/MozDownload.h b/embed/xulrunner/components/MozDownload.h
deleted file mode 100644
index 27fef41c7..000000000
--- a/embed/xulrunner/components/MozDownload.h
+++ /dev/null
@@ -1,153 +0,0 @@
-/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
-/* ***** BEGIN LICENSE BLOCK *****
- * Version: MPL 1.1/GPL 2.0/LGPL 2.1
- *
- * The contents of this file are subject to the Mozilla Public License Version
- * 1.1 (the "License"); you may not use this file except in compliance with
- * the License. You may obtain a copy of the License at
- * http://www.mozilla.org/MPL/
- *
- * Software distributed under the License is distributed on an "AS IS" basis,
- * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
- * for the specific language governing rights and limitations under the
- * License.
- *
- * The Original Code is mozilla.org code.
- *
- * The Initial Developer of the Original Code is
- * Netscape Communications Corporation.
- * Portions created by the Initial Developer are Copyright © 2002
- * the Initial Developer. All Rights Reserved.
- *
- * Contributor(s):
- * Conrad Carlen <ccarlen@netscape.com>
- *
- * Alternatively, the contents of this file may be used under the terms of
- * either the GNU General Public License Version 2 or later (the "GPL"), or
- * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
- * in which case the provisions of the GPL or the LGPL are applicable instead
- * of those above. If you wish to allow use of your version of this file only
- * under the terms of either the GPL or the LGPL, and not to allow others to
- * use your version of this file under the terms of the MPL, indicate your
- * decision by deleting the provisions above and replace them with the notice
- * and other provisions required by the GPL or the LGPL. If you do not delete
- * the provisions above, a recipient may use your version of this file under
- * the terms of any one of the MPL, the GPL or the LGPL.
- *
- * ***** END LICENSE BLOCK *****
- *
- * $Id$
- */
-
-#ifndef MozDownload_h__
-#define MozDownload_h__
-
-#include <libgnomevfs/gnome-vfs-mime-handlers.h>
-
-#include <nsCOMPtr.h>
-#include <nsIInterfaceRequestor.h>
-#include <nsITransfer.h>
-#include <nsIWebProgressListener.h>
-
-#include "mozilla-embed-persist.h"
-#include "downloader-view.h"
-#include "ephy-download.h"
-#include "ephy-embed-shell.h"
-
-class nsICancelable;
-class nsIDOMDocument;
-class nsIInputStream;
-class nsILocalFile;
-class nsIMIMEInfo;
-class nsIObserver;
-class nsIRequest;
-class nsIURI;
-class nsIWebBrowserPersist;
-
-/* MozDownload
- Holds information used to display a single download in the UI. This object is
- created in one of two ways:
- (1) By nsExternalHelperAppHandler when Gecko encounters a MIME type which
- it doesn't itself handle. In this case, the notifications sent to
- nsIDownload are controlled by nsExternalHelperAppHandler.
- (2) By the embedding app's file saving code when saving a web page or a link
- target. See CHeaderSniffer.cpp. In this case, the notifications sent to
- nsIDownload are controlled by the implementation of nsIWebBrowserPersist.
-*/
-
-#define MOZ_DOWNLOAD_CID \
-{ /* d2a2f743-f126-4f1f-1234-d4e50490f112 */ \
- 0xd2a2f743, \
- 0xf126, \
- 0x4f1f, \
- {0x12, 0x34, 0xd4, 0xe5, 0x04, 0x90, 0xf1, 0x12} \
-}
-
-#define MOZ_DOWNLOAD_CLASSNAME "Ephy's Download Progress Dialog"
-
-nsresult InitiateMozillaDownload (nsIDOMDocument *domDocument, nsIURI *sourceUri,
- nsILocalFile* inDestFile, const char *contentType,
- nsIURI* inOriginalURI, MozillaEmbedPersist *embedPersist,
- nsIInputStream *postData, nsISupports *aCacheKey,
- PRInt64 aMaxSize);
-nsresult BuildDownloadPath (const char *defaultFileName, nsILocalFile **_retval);
-
-class MozDownload : public nsITransfer,
- public nsIInterfaceRequestor
-{
-public:
- MozDownload();
- virtual ~MozDownload();
-
- NS_DECL_ISUPPORTS
- NS_DECL_NSIWEBPROGRESSLISTENER
- NS_DECL_NSIWEBPROGRESSLISTENER2
- NS_DECL_NSITRANSFER
- NS_DECL_NSIINTERFACEREQUESTOR
-
- nsresult GetMIMEInfo (nsIMIMEInfo **aMIMEInfo);
- nsresult GetTargetFile (nsILocalFile **aFile);
- nsresult GetSource(nsIURI * *aSource);
- nsresult GetPercentComplete(PRInt32 *aPercentComplete);
-
- virtual void Cancel();
- virtual void Pause();
- virtual void Resume();
-
- nsresult GetState (EphyDownloadState *aDownloadState);
- nsresult GetCurrentProgress (PRInt64 *aCurrentProgress);
- nsresult GetTotalProgress (PRInt64 *aTProgress);
- nsresult GetElapsedTime (PRInt64 *aTProgress);
-
- nsresult InitForEmbed (nsIURI *aSource, nsIURI *aTarget,
- const nsAString &aDisplayName, nsIMIMEInfo *aMIMEInfo,
- PRTime aStartTime, nsILocalFile *aTempFile,
- nsICancelable *aCancelable, MozillaEmbedPersist *aEmbedPersist,
- PRInt64 aMaxSize);
-
-protected:
- nsCOMPtr<nsIURI> mSource;
- nsCOMPtr<nsIURI> mDestination;
-
- nsCOMPtr<nsIMIMEInfo> mMIMEInfo;
- PRTime mStartTime;
- PRTime mLastUpdate;
- PRInt64 mElapsed;
- PRInt32 mInterval;
- PRInt32 mPercentComplete;
- PRInt64 mTotalProgress;
- PRInt64 mCurrentProgress;
- PRInt64 mMaxSize;
- PRBool mAddToRecent;
-
- nsresult mStatus;
-
- nsCOMPtr<nsICancelable> mCancelable;
- nsCOMPtr<nsIRequest> mRequest;
- EphyDownload *mEphyDownload;
- DownloaderView *mDownloaderView;
- MozillaEmbedPersist *mEmbedPersist;
- EphyDownloadState mDownloadState;
-};
-
-#endif // MozDownload_h__
diff --git a/embed/xulrunner/components/MozRegisterComponents.cpp b/embed/xulrunner/components/MozRegisterComponents.cpp
deleted file mode 100644
index 0ff0014d7..000000000
--- a/embed/xulrunner/components/MozRegisterComponents.cpp
+++ /dev/null
@@ -1,330 +0,0 @@
-/*
- * Copyright © 2001,2002,2003 Philip Langdale
- * Copyright © 2003 Marco Pesenti Gritti
- * Copyright © 2004, 2005, 2006, 2007 Christian Persch
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include <glib/gmessages.h>
-
-#include <nsStringGlue.h>
-
-#include <nsComponentManagerUtils.h>
-#include <nsCOMPtr.h>
-#include <nsCURILoader.h>
-#include <nsDocShellCID.h>
-#include <nsICategoryManager.h>
-#include <nsIClassInfoImpl.h>
-#include <nsIComponentManager.h>
-#include <nsIComponentRegistrar.h>
-#include <nsIGenericFactory.h>
-#include <nsILocalFile.h>
-#include <nsIScriptNameSpaceManager.h>
-#include <nsIServiceManager.h>
-#include <nsMemory.h>
-#include <nsNetCID.h>
-#include <nsServiceManagerUtils.h>
-
-#define HAVE_MOZILLA_PSM
-
-#ifdef HAVE_MOZILLA_PSM
-#include <nsISecureBrowserUI.h>
-#endif
-
-#include "ContentHandler.h"
-#include "EphyAboutModule.h"
-#include "EphyContentPolicy.h"
-#include "EphySidebar.h"
-#include "GeckoCookiePromptService.h"
-#include "GeckoPrintService.h"
-#include "GeckoPrintSession.h"
-#include "GeckoPromptService.h"
-#include "GlobalHistory.h"
-#include "MozDownload.h"
-
-#ifdef ENABLE_FILEPICKER
-#include "FilePicker.h"
-#endif
-
-#ifdef ENABLE_SPELLCHECKER
-#include "GeckoSpellCheckEngine.h"
-#endif
-
-#ifdef HAVE_MOZILLA_PSM
-#include "GtkNSSClientAuthDialogs.h"
-#include "GtkNSSDialogs.h"
-#include "GtkNSSKeyPairDialogs.h"
-#include "GtkNSSSecurityWarningDialogs.h"
-#include "GeckoFormSigningDialog.h"
-#endif
-
-NS_GENERIC_FACTORY_CONSTRUCTOR(EphyAboutModule)
-NS_GENERIC_FACTORY_CONSTRUCTOR(EphyContentPolicy)
-NS_GENERIC_FACTORY_CONSTRUCTOR(EphySidebar)
-NS_GENERIC_FACTORY_CONSTRUCTOR(GContentHandler)
-NS_GENERIC_FACTORY_CONSTRUCTOR(GeckoCookiePromptService)
-NS_GENERIC_FACTORY_CONSTRUCTOR(GeckoPrintService)
-NS_GENERIC_FACTORY_CONSTRUCTOR(GeckoPrintSession)
-NS_GENERIC_FACTORY_CONSTRUCTOR(GeckoPromptService)
-NS_GENERIC_FACTORY_CONSTRUCTOR(MozDownload)
-NS_GENERIC_FACTORY_CONSTRUCTOR(MozGlobalHistory)
-
-#ifdef ENABLE_FILEPICKER
-NS_GENERIC_FACTORY_CONSTRUCTOR(GFilePicker)
-#endif
-
-#ifdef ENABLE_SPELLCHECKER
-NS_GENERIC_FACTORY_CONSTRUCTOR(GeckoSpellCheckEngine)
-#endif
-
-#ifdef HAVE_MOZILLA_PSM
-NS_GENERIC_FACTORY_CONSTRUCTOR(GtkNSSClientAuthDialogs)
-NS_GENERIC_FACTORY_CONSTRUCTOR(GtkNSSDialogs)
-NS_GENERIC_FACTORY_CONSTRUCTOR(GtkNSSKeyPairDialogs)
-NS_GENERIC_FACTORY_CONSTRUCTOR(GtkNSSSecurityWarningDialogs)
-NS_GENERIC_FACTORY_CONSTRUCTOR(GeckoFormSigningDialog)
-#endif
-
-#define XPINSTALL_CONTRACTID NS_CONTENT_HANDLER_CONTRACTID_PREFIX "application/x-xpinstall"
-
-/* class information */
-NS_DECL_CLASSINFO(EphySidebar)
-
-/* FIXME: uninstall XPI handler */
-
-static const nsModuleComponentInfo sAppComps[] = {
- {
- MOZ_DOWNLOAD_CLASSNAME,
- MOZ_DOWNLOAD_CID,
-#ifdef NS_TRANSFER_CONTRACTID
- NS_TRANSFER_CONTRACTID,
-#else
- NS_DOWNLOAD_CONTRACTID,
-#endif
- MozDownloadConstructor
- },
-#ifdef ENABLE_FILEPICKER
- {
- G_FILEPICKER_CLASSNAME,
- G_FILEPICKER_CID,
- G_FILEPICKER_CONTRACTID,
- GFilePickerConstructor
- },
-#endif
-#ifdef HAVE_MOZILLA_PSM
- {
- GTK_NSSCLIENTAUTHDIALOGS_CLASSNAME,
- GTK_NSSCLIENTAUTHDIALOGS_CID,
- NS_CLIENTAUTHDIALOGS_CONTRACTID,
- GtkNSSClientAuthDialogsConstructor
- },
- {
- GTK_NSSDIALOGS_CLASSNAME,
- GTK_NSSDIALOGS_CID,
- NS_BADCERTLISTENER_CONTRACTID,
- GtkNSSDialogsConstructor
- },
- {
- GTK_NSSDIALOGS_CLASSNAME,
- GTK_NSSDIALOGS_CID,
- NS_CERTIFICATEDIALOGS_CONTRACTID,
- GtkNSSDialogsConstructor
- },
- {
- GTK_NSSDIALOGS_CLASSNAME,
- GTK_NSSDIALOGS_CID,
- NS_DOMCRYPTODIALOGS_CONTRACTID,
- GtkNSSDialogsConstructor
- },
- {
- GTK_NSSDIALOGS_CLASSNAME,
- GTK_NSSDIALOGS_CID,
- NS_TOKENDIALOGS_CONTRACTID,
- GtkNSSDialogsConstructor
- },
- {
- GTK_NSSDIALOGS_CLASSNAME,
- GTK_NSSDIALOGS_CID,
- NS_TOKENPASSWORDSDIALOG_CONTRACTID,
- GtkNSSDialogsConstructor
- },
- {
- GTK_NSSKEYPAIRDIALOGS_CLASSNAME,
- GTK_NSSKEYPAIRDIALOGS_CID,
- NS_GENERATINGKEYPAIRINFODIALOGS_CONTRACTID,
- GtkNSSKeyPairDialogsConstructor
- },
- {
- GTK_NSSSECURITYWARNINGDIALOGS_CLASSNAME,
- GTK_NSSSECURITYWARNINGDIALOGS_CID,
- NS_SECURITYWARNINGDIALOGS_CONTRACTID,
- GtkNSSSecurityWarningDialogsConstructor
- },
- {
- GECKO_FORMSIGNINGDIALOGS_CLASSNAME,
- GECKO_FORMSIGNINGDIALOGS_CID,
- NS_FORMSIGNINGDIALOG_CONTRACTID,
- GeckoFormSigningDialogConstructor
- },
-#endif /* HAVE_MOZILLA_PSM */
- {
- NS_IHELPERAPPLAUNCHERDLG_CLASSNAME,
- G_CONTENTHANDLER_CID,
- NS_IHELPERAPPLAUNCHERDLG_CONTRACTID,
- GContentHandlerConstructor
- },
- {
- EPHY_GLOBALHISTORY_CLASSNAME,
- EPHY_GLOBALHISTORY_CID,
- NS_GLOBALHISTORY2_CONTRACTID,
- MozGlobalHistoryConstructor
- },
- {
- GECKO_PRINT_SERVICE_CLASSNAME,
- GECKO_PRINT_SERVICE_IID,
- "@mozilla.org/embedcomp/printingprompt-service;1",
- GeckoPrintServiceConstructor
- },
- {
- GECKO_PRINT_SESSION_CLASSNAME,
- GECKO_PRINT_SESSION_IID,
- "@mozilla.org/gfx/printsession;1",
- GeckoPrintSessionConstructor
- },
- {
- EPHY_CONTENT_POLICY_CLASSNAME,
- EPHY_CONTENT_POLICY_CID,
- EPHY_CONTENT_POLICY_CONTRACTID,
- EphyContentPolicyConstructor,
- EphyContentPolicy::Register,
- EphyContentPolicy::Unregister
- },
- {
- EPHY_SIDEBAR_CLASSNAME,
- EPHY_SIDEBAR_CID,
- NS_SIDEBAR_CONTRACTID,
- EphySidebarConstructor,
- EphySidebar::Register,
- EphySidebar::Unregister,
- nsnull /* no factory destructor */,
- NS_CI_INTERFACE_GETTER_NAME(EphySidebar),
- nsnull /* no language helper */,
- &NS_CLASSINFO_NAME(EphySidebar),
- nsIClassInfo::DOM_OBJECT
- },
- {
- EPHY_ABOUT_EPIPHANY_CLASSNAME,
- EPHY_ABOUT_MODULE_CID,
- EPHY_ABOUT_EPIPHANY_CONTRACTID,
- EphyAboutModuleConstructor
- },
- {
- EPHY_ABOUT_RECOVER_CLASSNAME,
- EPHY_ABOUT_MODULE_CID,
- EPHY_ABOUT_RECOVER_CONTRACTID,
- EphyAboutModuleConstructor
- },
- {
- EPHY_ABOUT_NETERROR_CLASSNAME,
- EPHY_ABOUT_MODULE_CID,
- EPHY_ABOUT_NETERROR_CONTRACTID,
- EphyAboutModuleConstructor
- },
- {
- GECKO_PROMPT_SERVICE_CLASSNAME,
- GECKO_PROMPT_SERVICE_CID,
- "@mozilla.org/embedcomp/prompt-service;1",
- GeckoPromptServiceConstructor
- },
- {
- GECKO_PROMPT_SERVICE_CLASSNAME,
- GECKO_PROMPT_SERVICE_CID,
- "@mozilla.org/embedcomp/nbalert-service;1",
- GeckoPromptServiceConstructor
- },
-#ifdef ENABLE_SPELLCHECKER
- {
- GECKO_SPELL_CHECK_ENGINE_CLASSNAME,
- GECKO_SPELL_CHECK_ENGINE_IID,
- GECKO_SPELL_CHECK_ENGINE_CONTRACTID,
- GeckoSpellCheckEngineConstructor
- },
-#endif /* ENABLE_SPELLCHECK */
- {
- EPHY_COOKIEPROMPTSERVICE_CLASSNAME,
- EPHY_COOKIEPROMPTSERVICE_CID,
- EPHY_COOKIEPROMPTSERVICE_CONTRACTID,
- GeckoCookiePromptServiceConstructor
- }
-};
-
-gboolean
-mozilla_register_components (void)
-{
- gboolean ret = TRUE;
- nsresult rv;
-
- nsCOMPtr<nsIComponentRegistrar> cr;
- NS_GetComponentRegistrar(getter_AddRefs(cr));
- NS_ENSURE_TRUE (cr, FALSE);
-
- nsCOMPtr<nsIComponentManager> cm;
- NS_GetComponentManager (getter_AddRefs (cm));
- NS_ENSURE_TRUE (cm, FALSE);
-
- for (guint i = 0; i < G_N_ELEMENTS (sAppComps); i++)
- {
- nsCOMPtr<nsIGenericFactory> componentFactory;
- rv = NS_NewGenericFactory(getter_AddRefs(componentFactory),
- &(sAppComps[i]));
- if (NS_FAILED(rv) || !componentFactory)
- {
- g_warning ("Failed to make a factory for %s\n", sAppComps[i].mDescription);
-
- ret = FALSE;
- continue; // don't abort registering other components
- }
-
- rv = cr->RegisterFactory(sAppComps[i].mCID,
- sAppComps[i].mDescription,
- sAppComps[i].mContractID,
- componentFactory);
- if (NS_FAILED(rv))
- {
- g_warning ("Failed to register %s\n", sAppComps[i].mDescription);
-
- ret = FALSE;
- }
-
- if (sAppComps[i].mRegisterSelfProc)
- {
- rv = sAppComps[i].mRegisterSelfProc (cm, nsnull, nsnull, nsnull, &sAppComps[i]);
-
- if (NS_FAILED (rv))
- {
- g_warning ("Failed to register-self for %s\n", sAppComps[i].mDescription);
- ret = FALSE;
- }
- }
- }
-
- return ret;
-}
diff --git a/embed/xulrunner/components/MozRegisterComponents.h b/embed/xulrunner/components/MozRegisterComponents.h
deleted file mode 100644
index e8e086f3b..000000000
--- a/embed/xulrunner/components/MozRegisterComponents.h
+++ /dev/null
@@ -1,28 +0,0 @@
-/*
- * Copyright © 2001 Philip Langdale
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#ifndef MOZREGISTERCOMPONENTS_H
-#define MOZREGISTERCOMPONENTS_H
-
-#include <glib.h>
-
-gboolean mozilla_register_components (void);
-
-#endif /* MOZREGISTERCOMPONENTS_H */
diff --git a/embed/xulrunner/data/Makefile.am b/embed/xulrunner/data/Makefile.am
deleted file mode 100644
index 4c6763b2c..000000000
--- a/embed/xulrunner/data/Makefile.am
+++ /dev/null
@@ -1,2 +0,0 @@
-pkgconfigdir = $(libdir)/pkgconfig
-pkgconfig_DATA = gnome-gecko-embed-$(GGE_API_VERSION).pc
diff --git a/embed/xulrunner/data/gnome-gecko-embed.pc.in b/embed/xulrunner/data/gnome-gecko-embed.pc.in
deleted file mode 100644
index c9887651b..000000000
--- a/embed/xulrunner/data/gnome-gecko-embed.pc.in
+++ /dev/null
@@ -1,11 +0,0 @@
-prefix=@prefix@
-exec_prefix=@exec_prefix@
-libdir=@libdir@
-includedir=@includedir@
-
-Name: GNOME Gecko Embed Library
-Description: GNOME Gecko Embed Library
-Version: @GGE_VERSION@
-Requires: gtk+-2.0, @GECKO@-xpcom
-Libs: -L${libdir}
-Cflags: -I${includedir}
diff --git a/embed/xulrunner/embed/EphyBrowser.cpp b/embed/xulrunner/embed/EphyBrowser.cpp
deleted file mode 100644
index e57dd58d8..000000000
--- a/embed/xulrunner/embed/EphyBrowser.cpp
+++ /dev/null
@@ -1,1612 +0,0 @@
-/*
- * Copyright © 2000-2004 Marco Pesenti Gritti
- * Copyright © 2003, 2004, 2005 Christian Persch
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include <unistd.h>
-
-#include <nsStringGlue.h>
-
-#include <nsIChannel.h>
-#include <nsICommandManager.h>
-#include <nsIContentViewer.h>
-#include <nsIDocCharset.h>
-#include <nsIDocShellTreeItem.h>
-#include <nsIDocShellTreeNode.h>
-#include <nsIDocShellTreeOwner.h>
-#include <nsIDOM3Document.h>
-#include <nsIDOMAbstractView.h>
-#include <nsIDOMAbstractView.h>
-#include <nsIDOMCSSPrimitiveValue.h>
-#include <nsIDOMCSSStyleDeclaration.h>
-#include <nsIDOMCSSStyleDeclaration.h>
-#include <nsIDOMCSSValue.h>
-#include <nsIDOMDocument.h>
-#include <nsIDOMDocumentView.h>
-#include <nsIDOMDocumentView.h>
-#include <nsIDOMElement.h>
-#include <nsIDOMEvent.h>
-#include <nsIDOMEventTarget.h>
-#include <nsIDOMHTMLCollection.h>
-#include <nsIDOMHTMLDocument.h>
-#include <nsIDOMHTMLDocument.h>
-#include <nsIDOMHTMLElement.h>
-#include <nsIDOMHTMLFormElement.h>
-#include <nsIDOMHTMLInputElement.h>
-#include <nsIDOMHTMLTextAreaElement.h>
-#include <nsIDOMKeyEvent.h>
-#include <nsIDOMMouseEvent.h>
-#include <nsIDOMNode.h>
-#include <nsIDOMNSEvent.h>
-#include <nsIDOMNSEventTarget.h>
-#include <nsIDOMPopupBlockedEvent.h>
-#include <nsIDOMViewCSS.h>
-#include <nsIDOMWindow2.h>
-#include <nsIDOMXMLDocument.h>
-#include <nsIHistoryEntry.h>
-#include <nsIInterfaceRequestor.h>
-#include <nsIInterfaceRequestorUtils.h>
-#include <nsIPrintSettings.h>
-#include <nsIPrintSettingsService.h>
-#include <nsIScriptSecurityManager.h>
-#include <nsIServiceManager.h>
-#include <nsISHEntry.h>
-#include <nsISHistory.h>
-#include <nsISHistoryInternal.h>
-#include <nsISimpleEnumerator.h>
-#include <nsIURI.h>
-#include <nsIWebBrowserFocus.h>
-#include <nsIWebBrowserPrint.h>
-#include <nsIWebPageDescriptor.h>
-#include <nsMemory.h>
-#include <nsServiceManagerUtils.h>
-
-#ifdef HAVE_MOZILLA_PSM
-#include <nsICertificateDialogs.h>
-#include <nsISSLStatus.h>
-#include <nsISSLStatusProvider.h>
-#include <nsITransportSecurityInfo.h>
-#include <nsIX509Cert.h>
-#endif
-
-#ifdef ALLOW_PRIVATE_API
-#include <nsIContentPolicy.h>
-#include <nsIDocShell.h>
-#include <nsIDOMWindowInternal.h>
-#include <nsIImageDocument.h>
-#include <nsIMarkupDocumentViewer.h>
-#endif
-
-#include "gecko-embed.h"
-#include "gecko-embed-private.h"
-
-#include "ephy-debug.h"
-#include "ephy-embed.h"
-#include "ephy-embed-shell.h"
-#include "ephy-string.h"
-#include "ephy-zoom.h"
-#include "mozilla-embed-event.h"
-#include "mozilla-embed.h"
-
-#include "AutoJSContextStack.h"
-#include "EphyUtils.h"
-#include "EventContext.h"
-#include "GeckoPrintService.h"
-
-#include "EphyBrowser.h"
-
-NS_IMPL_ISUPPORTS1(EphyEventListener, nsIDOMEventListener)
-
-NS_IMETHODIMP
-EphyDOMLinkEventListener::HandleEvent (nsIDOMEvent* aDOMEvent)
-{
- nsCOMPtr<nsIDOMEventTarget> eventTarget;
- aDOMEvent->GetTarget(getter_AddRefs(eventTarget));
-
- nsCOMPtr<nsIDOMElement> linkElement (do_QueryInterface (eventTarget));
- if (!linkElement) return NS_ERROR_FAILURE;
-
- nsresult rv;
- nsString value;
- rv = linkElement->GetAttribute (NS_LITERAL_STRING ("rel"), value);
- if (NS_FAILED (rv)) return NS_ERROR_FAILURE;
-
- nsCString rel;
- NS_UTF16ToCString (value, NS_CSTRING_ENCODING_UTF8, rel);
-
- if (g_ascii_strcasecmp (rel.get(), "SHORTCUT ICON") == 0 ||
- g_ascii_strcasecmp (rel.get(), "ICON") == 0)
- {
- nsCOMPtr<nsIDOMDocument> domDoc;
- linkElement->GetOwnerDocument(getter_AddRefs(domDoc));
- NS_ENSURE_TRUE (domDoc, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsIDOMDocumentView> docView (do_QueryInterface (domDoc));
- NS_ENSURE_TRUE (docView, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsIDOMAbstractView> abstractView;
- docView->GetDefaultView (getter_AddRefs (abstractView));
-
- nsCOMPtr<nsIDOMWindow> domWin (do_QueryInterface (abstractView));
- NS_ENSURE_TRUE (domWin, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsIDOMWindow> topDomWin;
- domWin->GetTop (getter_AddRefs (topDomWin));
-
- nsCOMPtr<nsISupports> domWinAsISupports (do_QueryInterface (domWin));
- nsCOMPtr<nsISupports> topDomWinAsISupports (do_QueryInterface (topDomWin));
- /* disallow subframes to set favicon */
- if (domWinAsISupports != topDomWinAsISupports) return NS_OK;
-
- nsCOMPtr<nsIURI> docUri;
- rv = GetDocURI (linkElement, getter_AddRefs (docUri));
- NS_ENSURE_TRUE (NS_SUCCEEDED (rv) && docUri, NS_ERROR_FAILURE);
-
- rv = linkElement->GetAttribute (NS_LITERAL_STRING ("href"), value);
- if (NS_FAILED (rv) || !value.Length()) return NS_ERROR_FAILURE;
-
- nsCString cLink;
- NS_UTF16ToCString (value, NS_CSTRING_ENCODING_UTF8, cLink);
-
- nsCString faviconUrl;
- rv = docUri->Resolve (cLink, faviconUrl);
- NS_ENSURE_SUCCESS (rv, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsIURI> favUri;
- EphyUtils::NewURI (getter_AddRefs (favUri), faviconUrl);
- NS_ENSURE_TRUE (favUri, NS_ERROR_FAILURE);
-
- /* Only proceed for http favicons. Bug #312291 */
- PRBool isHttp = PR_FALSE, isHttps = PR_FALSE;
- favUri->SchemeIs ("http", &isHttp);
- favUri->SchemeIs ("https", &isHttps);
- if (!isHttp && !isHttps) return NS_OK;
-
- /* check if load is allowed */
- nsCOMPtr<nsIScriptSecurityManager> secMan
- (do_GetService("@mozilla.org/scriptsecuritymanager;1"));
- /* refuse if we can't check */
- NS_ENSURE_TRUE (secMan, NS_OK);
-
- rv = secMan->CheckLoadURI(docUri, favUri,
- nsIScriptSecurityManager::STANDARD);
- /* failure means it didn't pass the security check */
- if (NS_FAILED (rv)) return NS_OK;
-
- /* security check passed, now check with content policy */
- nsCOMPtr<nsIContentPolicy> policy =
- do_GetService("@mozilla.org/layout/content-policy;1");
- /* refuse if we can't check */
- NS_ENSURE_TRUE (policy, NS_OK);
-
- linkElement->GetAttribute (NS_LITERAL_STRING ("type"), value);
-
- nsCString cTypeVal;
- NS_UTF16ToCString (value, NS_CSTRING_ENCODING_UTF8, cTypeVal);
-
- PRInt16 decision = 0;
- rv = policy->ShouldLoad (nsIContentPolicy::TYPE_IMAGE,
- favUri, docUri, eventTarget,
- cTypeVal, nsnull,
- &decision);
- NS_ENSURE_SUCCESS (rv, NS_ERROR_FAILURE);
- if (decision != nsIContentPolicy::ACCEPT) return NS_OK;
-
- /* Hide password part */
- nsCString user;
- favUri->GetUsername (user);
- favUri->SetUserPass (user);
-
- nsCString spec;
- favUri->GetSpec (spec);
-
- /* ok, we accept this as a valid favicon for this site */
- g_signal_emit_by_name (mOwner->mEmbed, "ge_favicon", spec.get());
- }
- else if (g_ascii_strcasecmp (rel.get (), "search") == 0)
- {
- linkElement->GetAttribute (NS_LITERAL_STRING ("type"), value);
-
- nsCString cTypeVal;
- NS_UTF16ToCString (value, NS_CSTRING_ENCODING_UTF8, cTypeVal);
-
- if (g_ascii_strcasecmp (cTypeVal.get (),
- "application/opensearchdescription+xml") == 0)
- {
- rv = linkElement->GetAttribute (NS_LITERAL_STRING ("href"), value);
- if (NS_FAILED (rv) || !value.Length()) return NS_ERROR_FAILURE;
-
- nsCString cLink;
- NS_UTF16ToCString (value, NS_CSTRING_ENCODING_UTF8, cLink);
-
- nsCOMPtr<nsIURI> docUri;
- rv = GetDocURI (linkElement, getter_AddRefs (docUri));
- NS_ENSURE_TRUE (NS_SUCCEEDED (rv) && docUri, NS_ERROR_FAILURE);
-
- nsCString resolvedLink;
- rv = docUri->Resolve (cLink, resolvedLink);
- NS_ENSURE_SUCCESS (rv, NS_ERROR_FAILURE);
-
- linkElement->GetAttribute (NS_LITERAL_STRING ("title"), value);
-
- nsCString cTitle;
- NS_UTF16ToCString (value, NS_CSTRING_ENCODING_UTF8, cTitle);
-
- g_signal_emit_by_name (mOwner->mEmbed, "ge_search_link",
- cTypeVal.get(), cTitle.get(), resolvedLink.get());
- }
- }
- else if (g_ascii_strcasecmp (rel.get (), "alternate") == 0)
- {
- linkElement->GetAttribute (NS_LITERAL_STRING ("type"), value);
-
- nsCString cTypeVal;
- NS_UTF16ToCString (value, NS_CSTRING_ENCODING_UTF8, cTypeVal);
-
- if (g_ascii_strcasecmp (cTypeVal.get (), "application/rss+xml") == 0 ||
- g_ascii_strcasecmp (cTypeVal.get (), "application/atom+xml") == 0)
- {
- rv = linkElement->GetAttribute (NS_LITERAL_STRING ("href"), value);
- if (NS_FAILED (rv) || !value.Length()) return NS_ERROR_FAILURE;
-
- nsCString cLink;
- NS_UTF16ToCString (value, NS_CSTRING_ENCODING_UTF8, cLink);
-
- nsCOMPtr<nsIURI> docUri;
- rv = GetDocURI (linkElement, getter_AddRefs (docUri));
- NS_ENSURE_TRUE (NS_SUCCEEDED (rv) && docUri, NS_ERROR_FAILURE);
-
- /* Hide password part */
- nsCString user;
- docUri->GetUsername (user);
- docUri->SetUserPass (user);
-
- nsCString resolvedLink;
- rv = docUri->Resolve (cLink, resolvedLink);
- NS_ENSURE_SUCCESS (rv, NS_ERROR_FAILURE);
-
- linkElement->GetAttribute (NS_LITERAL_STRING ("title"), value);
-
- nsCString cTitle;
- NS_UTF16ToCString (value, NS_CSTRING_ENCODING_UTF8, cTitle);
-
- g_signal_emit_by_name (mOwner->mEmbed, "ge_feed_link",
- cTypeVal.get(), cTitle.get(), resolvedLink.get());
- }
- }
-
- return NS_OK;
-}
-
-NS_IMETHODIMP
-EphyMiscDOMEventsListener::HandleEvent (nsIDOMEvent* aDOMEvent)
-{
- /* make sure the event is trusted */
- nsCOMPtr<nsIDOMNSEvent> nsEvent (do_QueryInterface (aDOMEvent));
- NS_ENSURE_TRUE (nsEvent, NS_ERROR_FAILURE);
- PRBool isTrusted = PR_FALSE;
- nsEvent->GetIsTrusted (&isTrusted);
- if (!isTrusted) return NS_OK;
-
- nsresult rv;
- nsString type;
- rv = aDOMEvent->GetType (type);
- NS_ENSURE_SUCCESS (rv, rv);
-
- nsCString cType;
- NS_UTF16ToCString (type, NS_CSTRING_ENCODING_UTF8, cType);
-
- if (g_ascii_strcasecmp (cType.get(), "DOMContentLoaded") == 0)
- {
- g_signal_emit_by_name (mOwner->mEmbed, "dom_content_loaded",
- (gpointer)aDOMEvent);
- }
- else if (g_ascii_strcasecmp (cType.get(), "DOMWindowClose") == 0)
- {
- gboolean prevent = FALSE;
-
- g_signal_emit_by_name (mOwner->mEmbed, "close-request", &prevent);
-
- if (prevent)
- {
- aDOMEvent->PreventDefault ();
- }
- }
-
- return NS_OK;
-}
-
-nsresult
-EphyDOMLinkEventListener::GetDocURI (nsIDOMElement *aElement,
- nsIURI **aDocURI)
-{
- nsCOMPtr<nsIDOMDocument> domDoc;
- aElement->GetOwnerDocument (getter_AddRefs(domDoc));
-
- nsCOMPtr<nsIDOM3Document> doc (do_QueryInterface (domDoc));
- NS_ENSURE_TRUE (doc, NS_ERROR_FAILURE);
-
- nsresult rv;
- nsString spec;
- rv = doc->GetDocumentURI (spec);
- NS_ENSURE_SUCCESS (rv, rv);
-
- nsCString encoding;
- rv = mOwner->GetEncoding (encoding);
- NS_ENSURE_SUCCESS (rv, rv);
-
- return EphyUtils::NewURI (aDocURI, spec, encoding.get());
-}
-
-NS_IMETHODIMP
-EphyPopupBlockEventListener::HandleEvent (nsIDOMEvent * aDOMEvent)
-{
- nsCOMPtr<nsIDOMPopupBlockedEvent> popupEvent =
- do_QueryInterface (aDOMEvent);
- NS_ENSURE_TRUE (popupEvent, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsIURI> popupWindowURI;
- popupEvent->GetPopupWindowURI (getter_AddRefs (popupWindowURI));
-
- nsCString popupWindowURIString;
- nsresult rv;
-
- if (popupWindowURI)
- {
- rv = popupWindowURI->GetSpec (popupWindowURIString);
- NS_ENSURE_SUCCESS (rv, NS_ERROR_FAILURE);
- }
-
- nsString popupWindowFeatures;
- rv = popupEvent->GetPopupWindowFeatures (popupWindowFeatures);
- NS_ENSURE_SUCCESS (rv, NS_ERROR_FAILURE);
-
- nsCString popupWindowFeaturesString;
- NS_UTF16ToCString (popupWindowFeatures,
- NS_CSTRING_ENCODING_UTF8,
- popupWindowFeaturesString);
-
- nsCString popupWindowNameString;
- nsString popupWindowName;
- rv = popupEvent->GetPopupWindowName (popupWindowName);
- NS_ENSURE_SUCCESS (rv, NS_ERROR_FAILURE);
-
- NS_UTF16ToCString (popupWindowName,
- NS_CSTRING_ENCODING_UTF8,
- popupWindowNameString);
-
- g_signal_emit_by_name(mOwner->mEmbed, "ge-popup-blocked",
- popupWindowURI == NULL ? NULL : popupWindowURIString.get(),
- popupWindowNameString.get(),
- popupWindowFeaturesString.get());
-
- return NS_OK;
-}
-
-NS_IMETHODIMP
-EphyModalAlertEventListener::HandleEvent (nsIDOMEvent * aDOMEvent)
-{
- NS_ENSURE_TRUE (mOwner, NS_ERROR_FAILURE);
-
- nsresult rv;
- nsString type;
- rv = aDOMEvent->GetType (type);
- NS_ENSURE_SUCCESS (rv, rv);
-
- nsCString cType;
- NS_UTF16ToCString (type, NS_CSTRING_ENCODING_UTF8, cType);
-
- LOG ("ModalAlertListener event %s", cType.get());
-
- if (strcmp (cType.get(), "DOMWillOpenModalDialog") == 0)
- {
- gboolean retval = FALSE;
- g_signal_emit_by_name (mOwner->mEmbed, "ge-modal-alert", &retval);
-
- /* suppress alert */
- if (retval)
- {
- aDOMEvent->PreventDefault ();
- aDOMEvent->StopPropagation();
- }
- }
- else if (strcmp (cType.get(), "DOMModalDialogClosed") == 0)
- {
- g_signal_emit_by_name (mOwner->mEmbed, "ge-modal-alert-closed");
- }
-
- return NS_OK;
-}
-
-NS_IMETHODIMP
-EphyDOMScrollEventListener::HandleEvent (nsIDOMEvent * aEvent)
-{
- nsresult rv;
- nsCOMPtr<nsIDOMMouseEvent> mouseEvent (do_QueryInterface (aEvent, &rv));
- NS_ENSURE_SUCCESS (rv, rv);
-
- PRBool isAlt = PR_FALSE, isControl = PR_FALSE, isShift = PR_FALSE;
- mouseEvent->GetAltKey (&isAlt);
- mouseEvent->GetCtrlKey (&isControl);
- mouseEvent->GetShiftKey (&isShift);
- /* GetMetaKey is always false on gtk2 mozilla */
-
- if (isControl && !isAlt && !isShift)
- {
- PRInt32 detail = 0;
- mouseEvent->GetDetail(&detail);
-
- float zoom;
- rv = mOwner->GetZoom (&zoom);
- NS_ENSURE_SUCCESS (rv, rv);
-
- zoom = ephy_zoom_get_changed_zoom_level (zoom, detail > 0 ? 1 : detail < 0 ? -1 : 0);
- rv = mOwner->SetZoom (zoom);
- if (NS_SUCCEEDED (rv))
- {
- g_signal_emit_by_name (mOwner->mEmbed, "ge_zoom_change", zoom);
- }
-
- /* we consumed the event */
- aEvent->PreventDefault();
- }
-
- return NS_OK;
-}
-
-NS_IMPL_ISUPPORTS1(EphyContextMenuListener, nsIDOMContextMenuListener)
-
-NS_IMETHODIMP
-EphyContextMenuListener::ContextMenu (nsIDOMEvent* aDOMEvent)
-{
- nsCOMPtr<nsIDOMMouseEvent> mouseEvent = do_QueryInterface(aDOMEvent);
- NS_ENSURE_TRUE (mouseEvent, NS_ERROR_FAILURE);
-
- MozillaEmbedEvent *info;
- info = mozilla_embed_event_new (static_cast<gpointer>(aDOMEvent));
-
- nsresult rv;
- EventContext context;
- context.Init (mOwner);
- rv = context.GetMouseEventInfo (mouseEvent, MOZILLA_EMBED_EVENT (info));
-
- /* Don't do any magic handling if we can't actually show the context
- * menu, this can happen for XUL pages (e.g. about:config)
- */
- if (NS_FAILED (rv))
- {
- g_object_unref (info);
- return NS_OK;
- }
-
- if (info->button == 0)
- {
- /* Translate relative coordinates to absolute values, and try
- * to avoid covering links by adding a little offset
- */
- int x, y;
- gdk_window_get_origin (GTK_WIDGET (mOwner->mEmbed)->window, &x, &y);
- info->x += x + 6;
- info->y += y + 6;
-
- // Set the keycode to something sensible
- info->keycode = nsIDOMKeyEvent::DOM_VK_CONTEXT_MENU;
- }
-
- if (info->modifier == GDK_CONTROL_MASK)
- {
- info->context = EPHY_EMBED_CONTEXT_DOCUMENT;
- }
-
- gboolean retval = FALSE;
- nsCOMPtr<nsIDOMDocument> domDoc;
- rv = context.GetTargetDocument (getter_AddRefs(domDoc));
- if (NS_SUCCEEDED(rv))
- {
- mOwner->PushTargetDocument (domDoc);
-
- g_signal_emit_by_name (mOwner->mEmbed, "ge_context_menu",
- info, &retval);
-
- mOwner->PopTargetDocument ();
- }
-
- /* We handled the event, block javascript calls */
- if (retval)
- {
- aDOMEvent->PreventDefault();
- aDOMEvent->StopPropagation();
- }
-
- g_object_unref (info);
-
- return NS_OK;
-}
-
-NS_IMETHODIMP
-EphyContextMenuListener::HandleEvent (nsIDOMEvent* aDOMEvent)
-{
- return NS_ERROR_NOT_IMPLEMENTED;
-}
-
-EphyBrowser::EphyBrowser ()
-: mDOMLinkEventListener(nsnull)
-, mMiscDOMEventsListener(nsnull)
-, mDOMScrollEventListener(nsnull)
-, mPopupBlockEventListener(nsnull)
-, mModalAlertListener(nsnull)
-, mContextMenuListener(nsnull)
-, mInitialized(PR_FALSE)
-{
- LOG ("EphyBrowser ctor (%p)", this);
-}
-
-EphyBrowser::~EphyBrowser ()
-{
- LOG ("EphyBrowser dtor (%p)", this);
-}
-
-nsresult EphyBrowser::Init (GeckoEmbed *mozembed)
-{
- if (mInitialized) return NS_OK;
-
- mEmbed = GTK_WIDGET (mozembed);
-
- gecko_embed_get_nsIWebBrowser (mozembed,
- getter_AddRefs(mWebBrowser));
- NS_ENSURE_TRUE (mWebBrowser, NS_ERROR_FAILURE);
-
- mWebBrowserFocus = do_QueryInterface (mWebBrowser);
- NS_ENSURE_TRUE (mWebBrowserFocus, NS_ERROR_FAILURE);
-
- mWebBrowser->GetContentDOMWindow (getter_AddRefs (mDOMWindow));
- NS_ENSURE_TRUE (mDOMWindow, NS_ERROR_FAILURE);
-
- /* This will instantiate an about:blank doc if necessary */
- nsresult rv;
- nsCOMPtr<nsIDOMDocument> domDocument;
- rv = mDOMWindow->GetDocument (getter_AddRefs (domDocument));
- NS_ENSURE_SUCCESS (rv, NS_ERROR_FAILURE);
-
- mDOMLinkEventListener = new EphyDOMLinkEventListener(this);
- if (!mDOMLinkEventListener) return NS_ERROR_OUT_OF_MEMORY;
-
- mMiscDOMEventsListener = new EphyMiscDOMEventsListener(this);
- if (!mMiscDOMEventsListener) return NS_ERROR_OUT_OF_MEMORY;
-
- mDOMScrollEventListener = new EphyDOMScrollEventListener(this);
- if (!mDOMScrollEventListener) return NS_ERROR_OUT_OF_MEMORY;
-
- mPopupBlockEventListener = new EphyPopupBlockEventListener(this);
- if (!mPopupBlockEventListener) return NS_ERROR_OUT_OF_MEMORY;
-
- mModalAlertListener = new EphyModalAlertEventListener (this);
- if (!mModalAlertListener) return NS_ERROR_OUT_OF_MEMORY;
-
- mContextMenuListener = new EphyContextMenuListener(this);
- if (!mContextMenuListener) return NS_ERROR_OUT_OF_MEMORY;
-
- rv = GetListener();
- NS_ENSURE_SUCCESS (rv, NS_ERROR_FAILURE);
-
- rv = AttachListeners();
- NS_ENSURE_SUCCESS (rv, NS_ERROR_FAILURE);
-
-#ifdef HAVE_MOZILLA_PSM
- nsCOMPtr<nsIDocShell> docShell (do_GetInterface (mWebBrowser, &rv));
- NS_ENSURE_SUCCESS (rv, rv);
-
- rv = docShell->GetSecurityUI (getter_AddRefs (mSecurityInfo));
- if (!mSecurityInfo)
- {
- g_warning ("Failed to get nsISecureBrowserUI!\n");
- }
- NS_ENSURE_SUCCESS (rv, rv);
-#endif /* HAVE_MOZILLA_PSM */
-
- mInitialized = PR_TRUE;
-
- return NS_OK;
-}
-
-nsresult
-EphyBrowser::GetListener (void)
-{
- if (mEventTarget) return NS_ERROR_FAILURE;
-
- nsCOMPtr<nsIDOMWindow> domWindowExternal;
- mWebBrowser->GetContentDOMWindow (getter_AddRefs(domWindowExternal));
-
- nsCOMPtr<nsIDOMWindow2> domWindow (do_QueryInterface (domWindowExternal));
- NS_ENSURE_TRUE (domWindow, NS_ERROR_FAILURE);
-
- domWindow->GetWindowRoot (getter_AddRefs(mEventTarget));
- NS_ENSURE_TRUE (mEventTarget, NS_ERROR_FAILURE);
-
- return NS_OK;
-}
-
-nsresult
-EphyBrowser::AttachListeners(void)
-{
- NS_ENSURE_TRUE (mEventTarget, NS_ERROR_FAILURE);
-
- nsresult rv;
- nsCOMPtr<nsIDOMNSEventTarget> target (do_QueryInterface (mEventTarget, &rv));
- NS_ENSURE_SUCCESS (rv, rv);
-
- rv = target->AddEventListener(NS_LITERAL_STRING ("DOMLinkAdded"),
- mDOMLinkEventListener, PR_FALSE, PR_FALSE);
- rv |= target->AddEventListener(NS_LITERAL_STRING ("DOMContentLoaded"),
- mMiscDOMEventsListener, PR_FALSE, PR_FALSE);
- rv |= target->AddEventListener(NS_LITERAL_STRING ("DOMWindowClose"),
- mMiscDOMEventsListener, PR_FALSE, PR_FALSE);
- rv |= target->AddEventListener(NS_LITERAL_STRING ("DOMMouseScroll"),
- mDOMScrollEventListener, PR_TRUE /* capture */, PR_FALSE);
- rv |= target->AddEventListener(NS_LITERAL_STRING ("DOMPopupBlocked"),
- mPopupBlockEventListener, PR_FALSE, PR_FALSE);
- rv |= target->AddEventListener(NS_LITERAL_STRING ("DOMWillOpenModalDialog"),
- mModalAlertListener, PR_TRUE, PR_FALSE);
- rv |= target->AddEventListener(NS_LITERAL_STRING ("DOMModalDialogClosed"),
- mModalAlertListener, PR_TRUE, PR_FALSE);
- rv |= target->AddEventListener(NS_LITERAL_STRING ("contextmenu"),
- mContextMenuListener, PR_TRUE /* capture */, PR_FALSE);
- NS_ENSURE_SUCCESS (rv, rv);
-
- return NS_OK;
-}
-
-nsresult
-EphyBrowser::DetachListeners(void)
-{
- if (!mEventTarget) return NS_OK;
-
- nsresult rv;
- rv = mEventTarget->RemoveEventListener(NS_LITERAL_STRING ("DOMLinkAdded"),
- mDOMLinkEventListener, PR_FALSE);
- rv |= mEventTarget->RemoveEventListener(NS_LITERAL_STRING ("DOMContentLoaded"),
- mMiscDOMEventsListener, PR_FALSE);
- rv |= mEventTarget->RemoveEventListener(NS_LITERAL_STRING ("DOMWindowClose"),
- mMiscDOMEventsListener, PR_FALSE);
- rv |= mEventTarget->RemoveEventListener(NS_LITERAL_STRING ("DOMMouseScroll"),
- mDOMScrollEventListener, PR_TRUE); /* capture */
- rv |= mEventTarget->RemoveEventListener(NS_LITERAL_STRING ("DOMPopupBlocked"),
- mPopupBlockEventListener, PR_FALSE);
- rv |= mEventTarget->RemoveEventListener(NS_LITERAL_STRING ("DOMWillOpenModalDialog"),
- mModalAlertListener, PR_TRUE);
- rv |= mEventTarget->RemoveEventListener(NS_LITERAL_STRING ("DOMModalDialogClosed"),
- mModalAlertListener, PR_TRUE);
- rv |= mEventTarget->RemoveEventListener(NS_LITERAL_STRING ("contextmenu"),
- mContextMenuListener, PR_TRUE /* capture */);
- NS_ENSURE_SUCCESS (rv, NS_ERROR_FAILURE);
-
- return NS_OK;
-}
-
-nsresult EphyBrowser::Print ()
-{
- NS_ENSURE_TRUE (mWebBrowser, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsIWebBrowserPrint> print(do_GetInterface(mWebBrowser));
- NS_ENSURE_TRUE (print, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsIPrintSettingsService> printSettingsService
- (do_GetService("@mozilla.org/gfx/printsettings-service;1"));
- NS_ENSURE_STATE (printSettingsService);
-
- nsCOMPtr<nsIPrintSettings> settings;
- printSettingsService->GetNewPrintSettings (getter_AddRefs (settings));
- NS_ENSURE_STATE (settings);
-
- nsresult rv;
- AutoJSContextStack stack;
- rv = stack.Init ();
- NS_ENSURE_SUCCESS (rv, rv);
-
- return print->Print (settings, nsnull);
-}
-
-nsresult EphyBrowser::SetPrintPreviewMode (PRBool previewMode)
-{
- nsresult rv;
-
- NS_ENSURE_TRUE (mWebBrowser, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsIWebBrowserPrint> print (do_GetInterface (mWebBrowser));
- NS_ENSURE_STATE (print);
-
- if (previewMode)
- {
- nsCOMPtr<nsIPrintSettingsService> printSettingsService
- (do_GetService("@mozilla.org/gfx/printsettings-service;1"));
- NS_ENSURE_STATE (printSettingsService);
-
- nsCOMPtr<nsIPrintSettings> settings;
- printSettingsService->GetNewPrintSettings (getter_AddRefs (settings));
- NS_ENSURE_STATE (settings);
-
- EphyEmbedShell *shell = ephy_embed_shell_get_default ();
- rv = GeckoPrintService::TranslateSettings (ephy_embed_shell_get_print_settings (shell),
- ephy_embed_shell_get_page_setup (shell),
- NULL,
- nsCString(),
- nsIPrintSettings::kFramesAsIs,
- PR_FALSE,
- settings);
-
- if (NS_SUCCEEDED (rv))
- {
- rv = print->PrintPreview (settings, mDOMWindow, nsnull);
- }
- }
- else
- {
- PRBool isPreview = PR_FALSE;
-
- rv = print->GetDoingPrintPreview(&isPreview);
- NS_ENSURE_SUCCESS (rv, NS_ERROR_FAILURE);
-
- if (isPreview)
- {
- rv = print->ExitPrintPreview();
- }
- }
-
- return rv;
-}
-
-nsresult EphyBrowser::PrintPreviewNumPages (int *numPages)
-{
- NS_ENSURE_TRUE (mWebBrowser, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsIWebBrowserPrint> print(do_GetInterface(mWebBrowser));
- NS_ENSURE_TRUE (print, NS_ERROR_FAILURE);
-
- return print->GetPrintPreviewNumPages(numPages);
-}
-
-nsresult EphyBrowser::PrintPreviewNavigate(PRInt16 navType, PRInt32 pageNum)
-{
- NS_ENSURE_TRUE (mWebBrowser, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsIWebBrowserPrint> print(do_GetInterface(mWebBrowser));
- NS_ENSURE_TRUE (print, NS_ERROR_FAILURE);
-
- return print->PrintPreviewNavigate(navType, pageNum);
-}
-
-nsresult EphyBrowser::GetSHistory (nsISHistory **aSHistory)
-{
- NS_ENSURE_TRUE (mWebBrowser, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsIWebNavigation> ContentNav = do_QueryInterface (mWebBrowser);
- NS_ENSURE_TRUE (ContentNav, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsISHistory> SessionHistory;
- ContentNav->GetSessionHistory (getter_AddRefs (SessionHistory));
- NS_ENSURE_TRUE (SessionHistory, NS_ERROR_FAILURE);
-
- *aSHistory = SessionHistory.get();
- NS_IF_ADDREF (*aSHistory);
-
- return NS_OK;
-}
-
-nsresult EphyBrowser::CopySHistory (EphyBrowser *dest, PRBool copy_back,
- PRBool copy_forward, PRBool copy_current)
-{
- nsresult rv;
-
- nsCOMPtr<nsISHistory> h_src;
- GetSHistory (getter_AddRefs(h_src));
- NS_ENSURE_TRUE (h_src, NS_ERROR_FAILURE);
-
- PRInt32 count, index;
- h_src->GetCount (&count);
- h_src->GetIndex (&index);
-
- nsCOMPtr<nsISHistory> h_dest;
- dest->GetSHistory (getter_AddRefs (h_dest));
- NS_ENSURE_TRUE (h_dest, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsISHistoryInternal> hi_dest = do_QueryInterface (h_dest);
- NS_ENSURE_TRUE (hi_dest, NS_ERROR_FAILURE);
-
- if (count)
- {
- nsCOMPtr<nsIHistoryEntry> he;
- nsCOMPtr<nsISHEntry> she, dhe;
-
- for (PRInt32 i = (copy_back ? 0 : index + 1);
- i < (copy_forward ? count : index + 1);
- i++)
- {
- rv = h_src->GetEntryAtIndex (i, PR_FALSE,
- getter_AddRefs (he));
- NS_ENSURE_SUCCESS (rv, rv);
-
- she = do_QueryInterface (he);
- NS_ENSURE_TRUE (she, NS_ERROR_FAILURE);
-
- rv = she->Clone(getter_AddRefs (dhe));
- NS_ENSURE_SUCCESS (rv, rv);
-
- rv = hi_dest->AddEntry (dhe, PR_TRUE);
- NS_ENSURE_SUCCESS (rv, rv);
- }
-
- if (copy_current)
- {
- nsCOMPtr<nsIWebNavigation> wn_dest = do_QueryInterface (dest->mWebBrowser);
- NS_ENSURE_TRUE (wn_dest, NS_ERROR_FAILURE);
-
- rv = wn_dest->GotoIndex(index);
- if (!NS_SUCCEEDED(rv)) return NS_ERROR_FAILURE;
- }
- }
-
- return NS_OK;
-}
-
-nsresult EphyBrowser::Destroy ()
-{
- DetachListeners ();
-
- mWebBrowser = nsnull;
- mDOMWindow = nsnull;
- mEventTarget = nsnull;
- mEmbed = nsnull;
-
- mInitialized = PR_FALSE;
-
- return NS_OK;
-}
-
-nsresult EphyBrowser::GoToHistoryIndex (PRInt16 index)
-{
- NS_ENSURE_TRUE (mWebBrowser, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsIWebNavigation> ContentNav = do_QueryInterface (mWebBrowser);
- NS_ENSURE_TRUE (ContentNav, NS_ERROR_FAILURE);
-
- return ContentNav->GotoIndex (index);
-}
-
-nsresult EphyBrowser::SetZoom (float aZoom)
-{
- NS_ENSURE_TRUE (mWebBrowser, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsIContentViewer> contentViewer;
- GetContentViewer (getter_AddRefs(contentViewer));
- NS_ENSURE_TRUE (contentViewer, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsIMarkupDocumentViewer> mdv = do_QueryInterface(contentViewer);
- NS_ENSURE_TRUE (mdv, NS_ERROR_FAILURE);
-
- return mdv->SetTextZoom (aZoom);
-}
-
-nsresult EphyBrowser::GetContentViewer (nsIContentViewer **aViewer)
-{
- NS_ENSURE_TRUE (mWebBrowser, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsIDocShell> ourDocShell(do_GetInterface(mWebBrowser));
- NS_ENSURE_TRUE (ourDocShell, NS_ERROR_FAILURE);
-
- return ourDocShell->GetContentViewer(aViewer);
-}
-
-nsresult EphyBrowser::GetZoom (float *aZoom)
-{
- NS_ENSURE_TRUE (mWebBrowser, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsIContentViewer> contentViewer;
- GetContentViewer (getter_AddRefs(contentViewer));
- NS_ENSURE_TRUE (contentViewer, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsIMarkupDocumentViewer> mdv = do_QueryInterface(contentViewer);
- NS_ENSURE_TRUE (mdv, NS_ERROR_FAILURE);
-
- return mdv->GetTextZoom (aZoom);
-}
-
-nsresult
-EphyBrowser::ScrollLines (PRInt32 aNumLines)
-{
- nsCOMPtr<nsIDOMWindow> DOMWindow;
-
- mWebBrowserFocus->GetFocusedWindow (getter_AddRefs(DOMWindow));
- if (!DOMWindow)
- {
- DOMWindow = mDOMWindow;
- }
- NS_ENSURE_TRUE (DOMWindow, NS_ERROR_FAILURE);
-
- return DOMWindow->ScrollByLines (aNumLines);
-}
-
-nsresult
-EphyBrowser::ScrollPages (PRInt32 aNumPages)
-{
- nsCOMPtr<nsIDOMWindow> DOMWindow;
-
- mWebBrowserFocus->GetFocusedWindow (getter_AddRefs(DOMWindow));
- if (!DOMWindow)
- {
- DOMWindow = mDOMWindow;
- }
- NS_ENSURE_TRUE (DOMWindow, NS_ERROR_FAILURE);
-
- return DOMWindow->ScrollByPages (aNumPages);
-}
-
-nsresult
-EphyBrowser::ScrollPixels (PRInt32 aDeltaX,
- PRInt32 aDeltaY)
-{
- nsCOMPtr<nsIDOMWindow> DOMWindow;
-
- mWebBrowserFocus->GetFocusedWindow (getter_AddRefs(DOMWindow));
- if (!DOMWindow)
- {
- DOMWindow = mDOMWindow;
- }
- NS_ENSURE_TRUE (DOMWindow, NS_ERROR_FAILURE);
-
- return DOMWindow->ScrollBy (aDeltaX, aDeltaY);
-}
-
-nsresult
-EphyBrowser::GetDocument (nsIDOMDocument **aDOMDocument)
-{
- return mDOMWindow->GetDocument (aDOMDocument);
-}
-
-nsresult
-EphyBrowser::GetTargetDocument (nsIDOMDocument **aDOMDocument)
-{
- NS_ENSURE_TRUE (mWebBrowser, NS_ERROR_FAILURE);
-
- /* Use the current target document */
- if (mTargetDocument)
- {
- *aDOMDocument = mTargetDocument.get();
-
- NS_IF_ADDREF(*aDOMDocument);
-
- return NS_OK;
- }
-
- /* Use the focused document */
- nsresult rv;
- nsCOMPtr<nsIDOMWindow> DOMWindow;
- rv = mWebBrowserFocus->GetFocusedWindow (getter_AddRefs(DOMWindow));
- if (NS_SUCCEEDED (rv) && DOMWindow)
- {
- return DOMWindow->GetDocument (aDOMDocument);
- }
-
- /* Use the main document */
- return mDOMWindow->GetDocument (aDOMDocument);
-}
-
-nsresult EphyBrowser::GetSHInfo (PRInt32 *count, PRInt32 *index)
-{
- NS_ENSURE_TRUE (mWebBrowser, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsISHistory> SessionHistory;
- GetSHistory (getter_AddRefs(SessionHistory));
- NS_ENSURE_TRUE (SessionHistory, NS_ERROR_FAILURE);
-
- SessionHistory->GetCount (count);
- SessionHistory->GetIndex (index);
-
- return NS_OK;
-}
-
-nsresult EphyBrowser::GetSHTitleAtIndex (PRInt32 index, PRUnichar **title)
-{
- NS_ENSURE_TRUE (mWebBrowser, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsISHistory> SessionHistory;
- GetSHistory (getter_AddRefs(SessionHistory));
- NS_ENSURE_TRUE (SessionHistory, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsIHistoryEntry> he;
- SessionHistory->GetEntryAtIndex (index, PR_FALSE,
- getter_AddRefs (he));
- NS_ENSURE_TRUE (he, NS_ERROR_FAILURE);
-
- nsresult rv;
- rv = he->GetTitle (title);
- NS_ENSURE_TRUE (NS_SUCCEEDED (rv) && title, NS_ERROR_FAILURE);
-
- return NS_OK;
-}
-
-nsresult EphyBrowser::GetSHUrlAtIndex (PRInt32 index, nsACString &url)
-{
- NS_ENSURE_TRUE (mWebBrowser, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsISHistory> SessionHistory;
- GetSHistory (getter_AddRefs(SessionHistory));
- NS_ENSURE_TRUE (SessionHistory, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsIHistoryEntry> he;
- SessionHistory->GetEntryAtIndex (index, PR_FALSE,
- getter_AddRefs (he));
- NS_ENSURE_TRUE (he, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsIURI> uri;
- he->GetURI (getter_AddRefs(uri));
- NS_ENSURE_TRUE (uri, NS_ERROR_FAILURE);
-
- nsresult rv;
- rv = uri->GetSpec(url);
- NS_ENSURE_TRUE (NS_SUCCEEDED (rv) && url.Length(), NS_ERROR_FAILURE);
-
- return NS_OK;
-}
-
-nsresult EphyBrowser::GetPageDescriptor(nsISupports **aPageDescriptor)
-{
- NS_ENSURE_TRUE (mWebBrowser, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsIDocShell> ds = do_GetInterface (mWebBrowser);
-
- nsCOMPtr<nsIWebPageDescriptor> wpd = do_QueryInterface (ds);
- NS_ENSURE_TRUE (wpd, NS_ERROR_FAILURE);
-
- *aPageDescriptor = wpd.get();
- NS_IF_ADDREF (*aPageDescriptor);
-
- return NS_OK;
-}
-
-nsresult EphyBrowser::GetDOMWindow (nsIDOMWindow **aDOMWindow)
-{
- NS_ENSURE_TRUE (mWebBrowser, NS_ERROR_FAILURE);
-
- NS_IF_ADDREF (*aDOMWindow = mDOMWindow);
-
- return NS_OK;
-}
-
-nsresult EphyBrowser::GetDocumentURI (nsIURI **aURI)
-{
- if (!mDOMWindow) return NS_ERROR_NOT_INITIALIZED;
-
- nsresult rv;
- nsCOMPtr<nsIWebNavigation> webNav (do_GetInterface (mDOMWindow, &rv));
- NS_ENSURE_SUCCESS (rv, rv);
-
- return webNav->GetCurrentURI (aURI);
-}
-
-nsresult EphyBrowser::GetTargetDocumentURI (nsIURI **aURI)
-{
- if (!mWebBrowser) return NS_ERROR_NOT_INITIALIZED;
-
- nsCOMPtr<nsIDOMDocument> domDoc;
- GetTargetDocument (getter_AddRefs(domDoc));
- NS_ENSURE_TRUE (domDoc, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsIDOMDocumentView> docView (do_QueryInterface (domDoc));
- NS_ENSURE_TRUE (docView, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsIDOMAbstractView> abstractView;
- docView->GetDefaultView (getter_AddRefs (abstractView));
- NS_ENSURE_TRUE (abstractView, NS_ERROR_FAILURE);
- /* the abstract view is really the DOM window */
-
- nsresult rv;
- nsCOMPtr<nsIWebNavigation> webNav (do_GetInterface (abstractView, &rv));
- NS_ENSURE_SUCCESS (rv, rv);
-
- return webNav->GetCurrentURI (aURI);
-}
-
-nsresult EphyBrowser::ForceEncoding (const char *encoding)
-{
- NS_ENSURE_TRUE (mWebBrowser, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsIContentViewer> contentViewer;
- GetContentViewer (getter_AddRefs(contentViewer));
- NS_ENSURE_TRUE (contentViewer, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsIMarkupDocumentViewer> mdv = do_QueryInterface(contentViewer);
- NS_ENSURE_TRUE (mdv, NS_ERROR_FAILURE);
-
- return mdv->SetForceCharacterSet (nsCString(encoding));
-}
-
-nsresult EphyBrowser::GetEncoding (nsACString &encoding)
-{
- NS_ENSURE_TRUE (mWebBrowser, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsIDocCharset> docCharset = do_GetInterface (mWebBrowser);
- NS_ENSURE_TRUE (docCharset, NS_ERROR_FAILURE);
-
- char *charset;
- docCharset->GetCharset (&charset);
- encoding = charset;
- nsMemory::Free (charset);
-
- return NS_OK;
-}
-
-nsresult EphyBrowser::GetForcedEncoding (nsACString &encoding)
-{
- NS_ENSURE_TRUE (mWebBrowser, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsIContentViewer> contentViewer;
- GetContentViewer (getter_AddRefs(contentViewer));
- NS_ENSURE_TRUE (contentViewer, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsIMarkupDocumentViewer> mdv = do_QueryInterface(contentViewer);
- NS_ENSURE_TRUE (mdv, NS_ERROR_FAILURE);
-
- nsresult rv;
- rv = mdv->GetForceCharacterSet (encoding);
- NS_ENSURE_SUCCESS (rv, NS_ERROR_FAILURE);
-
- return NS_OK;
-}
-
-nsresult EphyBrowser::PushTargetDocument (nsIDOMDocument *domDoc)
-{
- mTargetDocument = domDoc;
-
- return NS_OK;
-}
-
-nsresult EphyBrowser::PopTargetDocument ()
-{
- mTargetDocument = nsnull;
-
- return NS_OK;
-}
-
-nsresult EphyBrowser::DoCommand (const char *command)
-{
- NS_ENSURE_TRUE (mWebBrowser, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsICommandManager> cmdManager;
- cmdManager = do_GetInterface (mWebBrowser);
- NS_ENSURE_TRUE (cmdManager, NS_ERROR_FAILURE);
-
- return cmdManager->DoCommand (command, nsnull, nsnull);
-}
-
-nsresult EphyBrowser::GetCommandState (const char *command, PRBool *enabled)
-{
- NS_ENSURE_TRUE (mWebBrowser, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsICommandManager> cmdManager;
- cmdManager = do_GetInterface (mWebBrowser);
- NS_ENSURE_TRUE (cmdManager, NS_ERROR_FAILURE);
-
- return cmdManager->IsCommandEnabled (command, nsnull, enabled);
-}
-
-#define NUM_MODIFIED_TEXTFIELDS_REQUIRED 2
-
-PRBool
-EphyBrowser::CompareFormsText (nsAString &aDefaultText, nsAString &aUserText)
-{
- if (aDefaultText.Length() != aUserText.Length())
- {
- return FALSE;
- }
-
- /* Mozilla Bug 218277, 195946 and others */
- const PRUnichar *text = aDefaultText.BeginReading();
- for (PRUint32 i = 0; i < aDefaultText.Length(); i++)
- {
- if (text[i] == 0xa0)
- {
- aDefaultText.Replace (i, 1, ' ');
- }
- }
-
- return (memcmp (aDefaultText.BeginReading(),
- aUserText.BeginReading(),
- aUserText.Length() * sizeof (PRUnichar)) == 0);
-}
-
-nsresult EphyBrowser::GetDocumentHasModifiedForms (nsIDOMDocument *aDomDoc, PRUint32 *aNumTextFields, PRBool *aHasTextArea)
-{
- nsCOMPtr<nsIDOMHTMLDocument> htmlDoc = do_QueryInterface(aDomDoc);
- /* it's okay not to be a HTML doc (happens for XUL documents, like about:config) */
- if (!htmlDoc) return NS_OK;
-
- nsCOMPtr<nsIDOMHTMLCollection> forms;
- htmlDoc->GetForms (getter_AddRefs (forms));
- if (!forms) return NS_OK; /* it's ok not to have any forms */
-
- nsCOMPtr<nsIDOMDocumentView> docView (do_QueryInterface (aDomDoc));
- nsCOMPtr<nsIDOMViewCSS> defaultCSSView;
- if (docView)
- {
- nsCOMPtr<nsIDOMAbstractView> defaultView;
- docView->GetDefaultView (getter_AddRefs (defaultView));
- defaultCSSView = do_QueryInterface (defaultView);
- }
-
- const PRUnichar visibilityLiteral[] = { 'v', 'i', 's', 'i', 'b', 'i', 'l', 'i', 't', 'y', '\0' };
- const PRUnichar visibleLiteral[] = { 'v', 'i', 's', 'i', 'b', 'l', 'e', '\0' };
- nsString visibilityAttr(visibilityLiteral);
- nsString visibleAttr(visibleLiteral);
- nsString EmptyString;
- nsCOMPtr<nsIDOMCSSStyleDeclaration> computedStyle;
- nsCOMPtr<nsIDOMCSSValue> cssValue;
- nsCOMPtr<nsIDOMCSSPrimitiveValue> primitiveValue;
-
- PRUint32 formNum;
- forms->GetLength (&formNum);
-
- /* check all forms */
- for (PRUint32 formIndex = 0; formIndex < formNum; formIndex++)
- {
- nsCOMPtr<nsIDOMNode> formNode;
- forms->Item (formIndex, getter_AddRefs (formNode));
- if (!formNode) continue;
-
- nsCOMPtr<nsIDOMHTMLFormElement> formElement = do_QueryInterface (formNode);
- if (!formElement) continue;
-
- PRBool isVisible = PR_FALSE;
- nsresult rv;
- computedStyle = nsnull;
-
- /* Check defaultCSSView for NULL, see bug #327764 */
- if (defaultCSSView &&
- NS_SUCCEEDED (defaultCSSView->GetComputedStyle (formElement, EmptyString,
- getter_AddRefs (computedStyle))) &&
- computedStyle)
- {
- rv = computedStyle->GetPropertyCSSValue(visibilityAttr, getter_AddRefs (cssValue));
- if (NS_SUCCEEDED (rv) && cssValue)
- {
- nsString value;
- rv = cssValue->GetCssText (value);
- if (NS_SUCCEEDED (rv) && value.Length ())
- {
- /* what to do for "collapse" and "inherit" values? */
- isVisible = CompareFormsText (value, visibleAttr);
- }
- }
- }
-
- if (!isVisible)
- {
- LOG ("Form node %p is invisible\n", formNode.get());
- continue;
- }
-
- nsCOMPtr<nsIDOMHTMLCollection> formElements;
- formElement->GetElements (getter_AddRefs (formElements));
- if (!formElements) continue;
-
- PRUint32 elementNum;
- formElements->GetLength (&elementNum);
-
- /* check all input elements in the form for user input */
- for (PRUint32 elementIndex = 0; elementIndex < elementNum; elementIndex++)
- {
- nsCOMPtr<nsIDOMNode> domNode;
- formElements->Item (elementIndex, getter_AddRefs (domNode));
- if (!domNode) continue;
-
- nsCOMPtr<nsIDOMElement> domElement (do_QueryInterface (domNode));
- if (!domElement) continue;
-
- isVisible = PR_FALSE;
- computedStyle = nsnull;
- /* Check defaultCSSView for NULL, see bug #327764 */
- if (defaultCSSView &&
- NS_SUCCEEDED (defaultCSSView->GetComputedStyle (domElement, EmptyString,
- getter_AddRefs (computedStyle))) &&
- computedStyle)
- {
- rv = computedStyle->GetPropertyCSSValue(visibilityAttr, getter_AddRefs (cssValue));
- if (NS_SUCCEEDED (rv) && cssValue)
- {
- nsString value;
- rv = cssValue->GetCssText (value);
- if (NS_SUCCEEDED (rv) && value.Length ())
- {
- /* what to do for "collapse" and "inherit" values? */
- isVisible = CompareFormsText (value, visibleAttr);
- }
- }
- }
-
- if (!isVisible)
- {
- LOG("Form node %p element %p is invisible\n", formNode.get(), domNode.get());
- continue;
- }
-
- nsCOMPtr<nsIDOMHTMLTextAreaElement> areaElement = do_QueryInterface (domNode);
- if (areaElement)
- {
- PRBool isDisabled = PR_TRUE;
- areaElement->GetDisabled (&isDisabled);
- if (isDisabled)
- {
- LOG ("Form node %p element %p [textarea] is disabled\n", formNode.get(), areaElement.get());
- continue;
- }
-
- nsString defaultText, userText;
- areaElement->GetDefaultValue (defaultText);
- areaElement->GetValue (userText);
-
- if (!CompareFormsText (defaultText, userText))
- {
- *aHasTextArea = PR_TRUE;
- return NS_OK;
- }
-
- continue;
- }
-
- nsCOMPtr<nsIDOMHTMLInputElement> inputElement = do_QueryInterface(domNode);
- if (!inputElement) continue;
-
- PRBool isDisabled = PR_TRUE;
- inputElement->GetDisabled (&isDisabled);
- if (isDisabled)
- {
- LOG ("Form node %p element %p [input] is disabled\n", formNode.get(), inputElement.get());
- continue;
- }
-
- nsString type;
- inputElement->GetType(type);
-
- nsCString cType;
- NS_UTF16ToCString (type, NS_CSTRING_ENCODING_UTF8, cType);
-
- if (g_ascii_strcasecmp (cType.get(), "text") == 0)
- {
- nsString defaultText, userText;
- PRInt32 max_length;
- inputElement->GetDefaultValue (defaultText);
- inputElement->GetValue (userText);
- inputElement->GetMaxLength (&max_length);
-
- /* There are forms for which defaultValue is longer than
- * userValue. Mozilla consider this not a bug [see WONTFIXed
- * bug 232057], but we need to check for this here.
- */
- if (defaultText.Length() > (PRUint32)max_length)
- {
- defaultText.Cut (max_length, PR_UINT32_MAX);
- }
-
- if (!CompareFormsText (defaultText, userText))
- {
- (*aNumTextFields)++;
- if (*aNumTextFields >= NUM_MODIFIED_TEXTFIELDS_REQUIRED)
- {
- return NS_OK;
- }
- }
- }
- }
- }
-
- return NS_OK;
-}
-
-nsresult EphyBrowser::GetHasModifiedForms (PRBool *modified)
-{
- *modified = PR_FALSE;
-
- NS_ENSURE_TRUE (mWebBrowser, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsIDocShell> rootDocShell = do_GetInterface (mWebBrowser);
- NS_ENSURE_TRUE (rootDocShell, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsISimpleEnumerator> enumerator;
- rootDocShell->GetDocShellEnumerator(nsIDocShellTreeItem::typeContent,
- nsIDocShell::ENUMERATE_FORWARDS,
- getter_AddRefs(enumerator));
- NS_ENSURE_TRUE (enumerator, NS_ERROR_FAILURE);
-
- PRBool hasMore;
- PRBool hasTextArea = PR_FALSE;
- PRUint32 numTextFields = 0;
- while (NS_SUCCEEDED(enumerator->HasMoreElements(&hasMore)) && hasMore)
- {
- nsCOMPtr<nsISupports> element;
- enumerator->GetNext (getter_AddRefs(element));
- if (!element) continue;
-
- nsCOMPtr<nsIDocShell> docShell = do_QueryInterface (element);
- if (!docShell) continue;
-
- nsCOMPtr<nsIContentViewer> contentViewer;
- docShell->GetContentViewer (getter_AddRefs(contentViewer));
- if (!contentViewer) continue;
-
- nsCOMPtr<nsIDOMDocument> domDoc;
- contentViewer->GetDOMDocument (getter_AddRefs (domDoc));
-
- nsresult rv;
- rv = GetDocumentHasModifiedForms (domDoc, &numTextFields, &hasTextArea);
- if (NS_SUCCEEDED (rv) &&
- (numTextFields >= NUM_MODIFIED_TEXTFIELDS_REQUIRED || hasTextArea))
- {
- *modified = PR_TRUE;
- break;
- }
- }
-
- return NS_OK;
-}
-
-nsresult
-EphyBrowser::GetSecurityInfo (PRUint32 *aState, nsACString &aDescription)
-{
-#ifdef HAVE_MOZILLA_PSM
- NS_ENSURE_TRUE (mSecurityInfo, NS_ERROR_FAILURE);
-
- nsresult rv;
- rv = mSecurityInfo->GetState (aState);
- NS_ENSURE_SUCCESS (rv, NS_ERROR_FAILURE);
-
- nsString tooltip;
- rv = mSecurityInfo->GetTooltipText (tooltip);
- NS_ENSURE_SUCCESS (rv, NS_ERROR_FAILURE);
-
- NS_UTF16ToCString (tooltip,
- NS_CSTRING_ENCODING_UTF8, aDescription);
-
- return NS_OK;
-#else
- return NS_ERROR_NOT_IMPLEMENTED;
-#endif
-}
-
-nsresult
-EphyBrowser::ShowCertificate ()
-{
-#ifdef HAVE_MOZILLA_PSM
- NS_ENSURE_TRUE (mSecurityInfo, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsISSLStatusProvider> statusProvider (do_QueryInterface (mSecurityInfo));
- NS_ENSURE_TRUE (statusProvider, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsISSLStatus> SSLStatus;
- statusProvider->GetSSLStatus (getter_AddRefs (SSLStatus));
- NS_ENSURE_TRUE (SSLStatus, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsIX509Cert> serverCert;
- SSLStatus->GetServerCert (getter_AddRefs (serverCert));
- NS_ENSURE_TRUE (serverCert, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsICertificateDialogs> certDialogs (do_GetService (NS_CERTIFICATEDIALOGS_CONTRACTID));
- NS_ENSURE_TRUE (certDialogs, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsIInterfaceRequestor> requestor(do_QueryInterface (mDOMWindow));
-
- return certDialogs->ViewCert (requestor, serverCert);
-#else
- return NS_OK;
-#endif
-}
-
-EphyEmbedDocumentType
-EphyBrowser::GetDocumentType ()
-{
- EphyEmbedDocumentType type = EPHY_EMBED_DOCUMENT_OTHER;
-
- NS_ENSURE_TRUE (mDOMWindow, type);
-
- nsresult rv;
- nsCOMPtr<nsIDOMDocument> domDoc;
- rv = GetDocument (getter_AddRefs (domDoc));
- NS_ENSURE_SUCCESS (rv, type);
-
- nsCOMPtr<nsIDOMHTMLDocument> htmlDoc (do_QueryInterface (domDoc));
- nsCOMPtr<nsIDOMXMLDocument> xmlDoc (do_QueryInterface (domDoc));
- nsCOMPtr<nsIImageDocument> imgDoc (do_QueryInterface (domDoc));
-
- if (xmlDoc)
- {
- type = EPHY_EMBED_DOCUMENT_XML;
- }
- else if (imgDoc)
- {
- type = EPHY_EMBED_DOCUMENT_IMAGE;
- }
- else if (htmlDoc)
- {
- type = EPHY_EMBED_DOCUMENT_HTML;
- }
-
- return type;
-}
-
-nsresult
-EphyBrowser::Close ()
-{
- nsCOMPtr<nsIDOMWindowInternal> domWin (do_QueryInterface (mDOMWindow));
- NS_ENSURE_TRUE (domWin, NS_ERROR_FAILURE);
-
- return domWin->Close();
-}
-
-nsresult
-EphyBrowser::GetPIDOMWindow(nsPIDOMWindow **aPIWin)
-{
- *aPIWin = nsnull;
-
- // get the private DOM window
- nsCOMPtr<nsPIDOMWindow> domWindowPrivate = do_QueryInterface(mDOMWindow);
-
- // and the root window for that DOM window
- *aPIWin = domWindowPrivate->GetPrivateRoot();
-
- if (*aPIWin)
- {
- NS_ADDREF(*aPIWin);
- return NS_OK;
- }
-
- return NS_ERROR_FAILURE;
-
-}
-
-nsresult
-EphyBrowser::LoadURI(const char *aURI,
- PRUint32 aLoadFlags,
- nsIURI *aReferrer)
-{
- nsString uURI;
- nsresult rv = NS_OK;
-
- NS_CStringToUTF16 (nsCString (aURI), NS_CSTRING_ENCODING_UTF8, uURI);
-
- if (uURI.Length() == 0) return NS_OK;
-
- nsCOMPtr<nsIWebNavigation> contentNav = do_QueryInterface (mWebBrowser);
- NS_ENSURE_TRUE (contentNav, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsPIDOMWindow> piWin;
- rv = GetPIDOMWindow(getter_AddRefs(piWin));
- NS_ENSURE_SUCCESS (rv, rv);
-
- nsAutoPopupStatePusher popupStatePusher(piWin, openAllowed);
-
- rv = contentNav->LoadURI(uURI.get(), // URI string
- aLoadFlags, // Load flags
- aReferrer, // Referring URI
- nsnull, // Post data
- nsnull); // extra headers
-
- return rv;
-}
-
diff --git a/embed/xulrunner/embed/EphyBrowser.h b/embed/xulrunner/embed/EphyBrowser.h
deleted file mode 100644
index 1f23d2a73..000000000
--- a/embed/xulrunner/embed/EphyBrowser.h
+++ /dev/null
@@ -1,223 +0,0 @@
-/*
- * Copyright © 2000-2004 Marco Pesenti Gritti
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#ifndef EPHY_BROWSER_H
-#define EPHY_BROWSER_H
-
-#include "ephy-embed.h"
-#include <gtk/gtkwidget.h>
-
-#include <nsCOMPtr.h>
-#include <nsIDOMContextMenuListener.h>
-#include <nsIDOMDocument.h>
-#include <nsIDOMEventListener.h>
-#include <nsIDOMEventTarget.h>
-#include <nsIDOMWindow.h>
-#include <nsIRequest.h>
-#include <nsISHistory.h>
-#include <nsIWebBrowserFocus.h>
-#include <nsIWebBrowser.h>
-#include <nsIWebNavigation.h>
-#include <nsPIDOMWindow.h>
-
-#ifdef ALLOW_PRIVATE_API
-#include <nsIContentViewer.h>
-#endif
-
-#ifdef HAVE_MOZILLA_PSM
-#include <nsISecureBrowserUI.h>
-#endif
-
-#include "gecko-embed.h"
-
-class EphyBrowser;
-
-class EphyEventListener : public nsIDOMEventListener
-{
-public:
- NS_DECL_ISUPPORTS
-
- // nsIDOMEventListener
- NS_IMETHOD HandleEvent(nsIDOMEvent* aEvent) = 0;
-
- EphyEventListener(EphyBrowser *aOwner) : mOwner(aOwner) { };
- virtual ~EphyEventListener() { };
-
-protected:
- EphyBrowser *mOwner;
-};
-
-class EphyDOMLinkEventListener : public EphyEventListener
-{
-public:
- NS_IMETHOD HandleEvent(nsIDOMEvent* aEvent);
-
- EphyDOMLinkEventListener(EphyBrowser *aOwner) : EphyEventListener(aOwner) { };
-private:
- nsresult GetDocURI (nsIDOMElement *aElement,
- nsIURI **aDocURI);
-
-};
-
-class EphyPopupBlockEventListener : public EphyEventListener
-{
-public:
- NS_IMETHOD HandleEvent(nsIDOMEvent* aEvent);
-
- EphyPopupBlockEventListener(EphyBrowser *aOwner) : EphyEventListener(aOwner) { };
-};
-
-class EphyModalAlertEventListener : public EphyEventListener
-{
-public:
- NS_IMETHOD HandleEvent(nsIDOMEvent* aEvent);
-
- EphyModalAlertEventListener(EphyBrowser *aOwner) : EphyEventListener(aOwner) { };
-};
-
-class EphyMiscDOMEventsListener : public EphyEventListener
-{
-public:
- NS_IMETHOD HandleEvent(nsIDOMEvent* aEvent);
-
- EphyMiscDOMEventsListener(EphyBrowser *aOwner) : EphyEventListener(aOwner) { };
-};
-
-class EphyDOMScrollEventListener : public EphyEventListener
-{
-public:
- NS_IMETHOD HandleEvent(nsIDOMEvent* aEvent);
-
- EphyDOMScrollEventListener(EphyBrowser *aOwner) : EphyEventListener(aOwner) { };
-};
-
-class EphyContextMenuListener : public nsIDOMContextMenuListener
-{
-public:
- NS_DECL_ISUPPORTS
-
- // nsIDOMContextMenuListener
- NS_IMETHOD ContextMenu(nsIDOMEvent *aEvent);
- NS_IMETHOD HandleEvent(nsIDOMEvent *aEvent);
-
- EphyContextMenuListener(EphyBrowser *aOwner) : mOwner(aOwner) { };
- virtual ~EphyContextMenuListener() { };
-
-protected:
- EphyBrowser *mOwner;
-};
-
-class EphyBrowser
-{
-friend class EphyEventListener;
-friend class EphyDOMLinkEventListener;
-friend class EphyMiscDOMEventsListener;
-friend class EphyDOMScrollEventListener;
-friend class EphyPopupBlockEventListener;
-friend class EphyModalAlertEventListener;
-friend class EphyContextMenuListener;
-public:
- EphyBrowser();
- ~EphyBrowser();
-
- nsresult Init (GeckoEmbed *mozembed);
- nsresult Destroy (void);
-
- nsresult DoCommand (const char *command);
- nsresult GetCommandState (const char *command, PRBool *enabled);
-
- nsresult SetZoom (float aTextZoom);
- nsresult GetZoom (float *aTextZoom);
-
- nsresult ScrollLines (PRInt32 aNumLines);
- nsresult ScrollPages (PRInt32 aNumPages);
- nsresult ScrollPixels (PRInt32 aDeltaX, PRInt32 aDeltaY);
-
- nsresult Print ();
- nsresult SetPrintPreviewMode (PRBool previewMode);
- nsresult PrintPreviewNumPages (int *numPages);
- nsresult PrintPreviewNavigate(PRInt16 navType, PRInt32 pageNum);
-
- nsresult GetPageDescriptor(nsISupports **aPageDescriptor);
-
- nsresult GetSHInfo (PRInt32 *count, PRInt32 *index);
- nsresult GetSHTitleAtIndex (PRInt32 index, PRUnichar **title);
- nsresult GetSHUrlAtIndex (PRInt32 index, nsACString &url);
- nsresult GoToHistoryIndex (PRInt16 index);
-
- nsresult ForceEncoding (const char *encoding);
- nsresult GetEncoding (nsACString &encoding);
- nsresult GetForcedEncoding (nsACString &encoding);
-
- nsresult PushTargetDocument (nsIDOMDocument *domDoc);
- nsresult PopTargetDocument ();
-
- nsresult GetDocument (nsIDOMDocument **aDOMDocument);
- nsresult GetTargetDocument (nsIDOMDocument **aDOMDocument);
- nsresult GetDocumentURI (nsIURI **aURI);
- nsresult GetTargetDocumentURI (nsIURI **aURI);
- nsresult GetDOMWindow (nsIDOMWindow **window);
- nsresult GetPIDOMWindow(nsPIDOMWindow **aPIWin);
-
- nsresult GetHasModifiedForms (PRBool *modified);
-
- nsresult GetSecurityInfo (PRUint32 *aState, nsACString &aDescription);
- nsresult ShowCertificate ();
-
- nsresult CopySHistory (EphyBrowser *dest, PRBool copy_back,
- PRBool copy_forward, PRBool copy_current);
-
- nsresult Close ();
-
- nsresult LoadURI(const char *aURI,
- PRUint32 aLoadFlags = nsIWebNavigation::LOAD_FLAGS_NONE,
- nsIURI *aURI = nsnull);
-
- EphyEmbedDocumentType GetDocumentType ();
-
- nsCOMPtr<nsIWebBrowser> mWebBrowser;
-private:
- GtkWidget *mEmbed;
-
- nsCOMPtr<nsIWebBrowserFocus> mWebBrowserFocus;
- nsCOMPtr<nsIDOMDocument> mTargetDocument;
- nsCOMPtr<nsIDOMEventTarget> mEventTarget;
- nsCOMPtr<nsIDOMWindow> mDOMWindow;
- EphyDOMLinkEventListener *mDOMLinkEventListener;
- EphyMiscDOMEventsListener *mMiscDOMEventsListener;
- EphyDOMScrollEventListener *mDOMScrollEventListener;
- EphyPopupBlockEventListener *mPopupBlockEventListener;
- EphyModalAlertEventListener *mModalAlertListener;
- EphyContextMenuListener *mContextMenuListener;
- PRBool mInitialized;
-#ifdef HAVE_MOZILLA_PSM
- nsCOMPtr<nsISecureBrowserUI> mSecurityInfo;
-#endif
-
- nsresult GetListener (void);
- nsresult AttachListeners (void);
- nsresult DetachListeners (void);
- nsresult GetSHistory (nsISHistory **aSHistory);
- nsresult GetContentViewer (nsIContentViewer **aViewer);
- nsresult GetDocumentHasModifiedForms (nsIDOMDocument *aDomDoc, PRUint32 *aNumTextFields, PRBool *aHasTextArea);
- PRBool CompareFormsText (nsAString &aDefaultText, nsAString &aUserText);
-};
-
-#endif /* !EPHY_BROWSER_H */
diff --git a/embed/xulrunner/embed/EphyDirectoryProvider.cpp b/embed/xulrunner/embed/EphyDirectoryProvider.cpp
deleted file mode 100644
index f33e4b576..000000000
--- a/embed/xulrunner/embed/EphyDirectoryProvider.cpp
+++ /dev/null
@@ -1,101 +0,0 @@
-/*
- * Copyright © 2006 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include <string.h>
-
-#include <nsStringGlue.h>
-
-#include <nsAppDirectoryServiceDefs.h>
-#include <nsCOMPtr.h>
-#include <nsEnumeratorUtils.h>
-#include <nsIDirectoryService.h>
-#include <nsIIOService.h>
-#include <nsILocalFile.h>
-#include <nsISupportsArray.h>
-#include <nsIToolkitChromeRegistry.h>
-#include <nsNetUtil.h>
-
-#include "EphyDirectoryProvider.h"
-
-NS_IMPL_ISUPPORTS2 (EphyDirectoryProvider,
- nsIDirectoryServiceProvider,
- nsIDirectoryServiceProvider2)
-
-
-/* nsIFile getFile (in string prop, out PRBool persistent); */
-NS_IMETHODIMP
-EphyDirectoryProvider::GetFile (const char *prop,
- PRBool *persistent,
- nsIFile **_retval)
-{
- return NS_ERROR_FAILURE;
-}
-
-/* nsISimpleEnumerator getFiles (in string prop); */
-NS_IMETHODIMP
-EphyDirectoryProvider::GetFiles (const char *prop,
- nsISimpleEnumerator **_retval)
-{
- nsresult rv = NS_ERROR_FAILURE;
-
- if (prop && strcmp (prop, NS_CHROME_MANIFESTS_FILE_LIST) == 0)
- {
- nsCOMPtr<nsILocalFile> manifestDir;
- rv = NS_NewNativeLocalFile (nsDependentCString(SHARE_DIR "/chrome"), PR_TRUE,
- getter_AddRefs (manifestDir));
- NS_ENSURE_SUCCESS (rv, rv);
-
- nsCOMPtr<nsISupports> element (do_QueryInterface (manifestDir, &rv));
- NS_ENSURE_SUCCESS (rv, rv);
-
- /* FIXME: this sucks!
- * When we don't implement a directory service provider,
- * the chrome registry takes its manifests files from the
- * app chrome dir; but it doesn't append this dir when
- * we do provide our own (additional) chrome manifest dirs!
- * http://lxr.mozilla.org/seamonkey/source/chrome/src/nsChromeRegistry.cpp#1147
- */
- nsCOMPtr<nsIProperties> dirServ (do_GetService(NS_DIRECTORY_SERVICE_CONTRACTID, &rv));
- NS_ENSURE_SUCCESS (rv, rv);
-
- nsCOMPtr<nsIFile> chromeDir;
- rv = dirServ->Get (NS_APP_CHROME_DIR, NS_GET_IID (nsIFile),
- getter_AddRefs (chromeDir));
- NS_ENSURE_SUCCESS (rv, rv);
-
- nsCOMPtr<nsISupportsArray> array;
- rv = NS_NewISupportsArray (getter_AddRefs (array));
- NS_ENSURE_SUCCESS (rv, rv);
-
- rv = array->AppendElement (manifestDir);
- rv |= array->AppendElement (chromeDir);
- NS_ENSURE_SUCCESS (rv, rv);
-
- rv = NS_NewArrayEnumerator (_retval, array);
- NS_ENSURE_SUCCESS (rv, rv);
-
- rv = NS_SUCCESS_AGGREGATE_RESULT;
- }
-
- return rv;
-}
diff --git a/embed/xulrunner/embed/EphyDirectoryProvider.h b/embed/xulrunner/embed/EphyDirectoryProvider.h
deleted file mode 100644
index ca66f9d4d..000000000
--- a/embed/xulrunner/embed/EphyDirectoryProvider.h
+++ /dev/null
@@ -1,37 +0,0 @@
-/*
- * Copyright © 2006 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#ifndef EPHY_DIRECTORY_PROVIDER_H
-#define EPHY_DIRECTORY_PROVIDER_H
-
-#include <nsIDirectoryService.h>
-
-class EphyDirectoryProvider : public nsIDirectoryServiceProvider2
-{
- public:
- NS_DECL_ISUPPORTS
- NS_DECL_NSIDIRECTORYSERVICEPROVIDER
- NS_DECL_NSIDIRECTORYSERVICEPROVIDER2
-
- EphyDirectoryProvider() { }
- virtual ~EphyDirectoryProvider() { }
-};
-
-#endif /* EPHY_DIRECTORY_PROVIDER_H */
diff --git a/embed/xulrunner/embed/EphyFind.cpp b/embed/xulrunner/embed/EphyFind.cpp
deleted file mode 100644
index 8f5377362..000000000
--- a/embed/xulrunner/embed/EphyFind.cpp
+++ /dev/null
@@ -1,222 +0,0 @@
-/*
- * Copyright © 2005 Christian Persch
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include <glib.h>
-
-#include <nsStringGlue.h>
-
-#include <nsComponentManagerUtils.h>
-#include <nsCOMPtr.h>
-#include <nsIDocShell.h>
-#include <nsIDOMAbstractView.h>
-#include <nsIDOMDocumentEvent.h>
-#include <nsIDOMDocument.h>
-#include <nsIDOMDocumentView.h>
-#include <nsIDOMElement.h>
-#include <nsIDOMEvent.h>
-#include <nsIDOMEventTarget.h>
-#include <nsIDOMHTMLAnchorElement.h>
-#include <nsIDOMKeyEvent.h>
-#include <nsIDOMNode.h>
-#include <nsIDOMWindow.h>
-#include <nsIInterfaceRequestorUtils.h>
-#include <nsISelectionController.h>
-#include <nsISelectionDisplay.h>
-#include <nsITypeAheadFind.h>
-#include <nsIWebBrowserFocus.h>
-#include <nsIWebBrowser.h>
-#include <nsServiceManagerUtils.h>
-
-#include "gecko-embed-private.h"
-
-#include "ephy-debug.h"
-
-#include "EphyFind.h"
-
-#define NS_TYPEAHEADFIND_CONTRACTID "@mozilla.org/typeaheadfind;1"
-
-static const PRUnichar kKeyEvents[] = { 'K', 'e', 'y', 'E', 'v', 'e', 'n', 't', 's', '\0' };
-static const PRUnichar kKeyPress[] = { 'k', 'e', 'y', 'p', 'r', 'e', 's', 's', '\0' };
-
-EphyFind::EphyFind ()
-: mCurrentEmbed(nsnull)
-, mAttention(PR_FALSE)
-{
- LOG ("EphyFind ctor [%p]", this);
-}
-
-EphyFind::~EphyFind ()
-{
- LOG ("EphyFind dtor [%p]", this);
-}
-
-nsresult
-EphyFind::SetEmbed (EphyEmbed *aEmbed)
-{
- nsresult rv = NS_OK;
- if (aEmbed == mCurrentEmbed) return rv;
-
- SetSelectionAttention (PR_FALSE);
-
- mCurrentEmbed = nsnull;
- mWebBrowser = nsnull;
-
- rv = NS_ERROR_FAILURE;
- gecko_embed_get_nsIWebBrowser (GECKO_EMBED (aEmbed),
- getter_AddRefs (mWebBrowser));
- NS_ENSURE_TRUE (mWebBrowser, rv);
-
- nsCOMPtr<nsIDocShell> docShell (do_GetInterface (mWebBrowser, &rv));
- NS_ENSURE_SUCCESS (rv, rv);
-
- if (!mFinder) {
- mFinder = do_CreateInstance (NS_TYPEAHEADFIND_CONTRACTID, &rv);
- NS_ENSURE_SUCCESS (rv, rv);
-
- rv = mFinder->Init (docShell);
-#if 0 // FIXME def HAVE_GECKO_1_9
-// mFinder->SetSelectionModeAndRepaint (nsISelectionController::SELECTION_ON);
-#endif
- } else {
- rv = mFinder->SetDocShell (docShell);
- }
- NS_ENSURE_SUCCESS (rv, rv);
-
- mCurrentEmbed = aEmbed;
-
- return rv;
-}
-
-void
-EphyFind::SetFindProperties (const char *aSearchString,
- PRBool aCaseSensitive)
-{
- if (!mFinder) return;
-
- mFinder->SetCaseSensitive (aCaseSensitive);
- /* search string is set on ::Find */
-}
-
-void
-EphyFind::SetSelectionAttention (PRBool aAttention)
-{
- if (aAttention == mAttention) return;
-
- mAttention = aAttention;
-
- PRInt16 display;
- if (aAttention) {
- display = nsISelectionController::SELECTION_ATTENTION;
- } else {
- display = nsISelectionController::SELECTION_ON;
- }
-
- if (mFinder) {
- mFinder->SetSelectionModeAndRepaint (display);
- }
-}
-
-EphyEmbedFindResult
-EphyFind::Find (const char *aSearchString,
- PRBool aLinksOnly)
-{
- if (!mFinder) return EPHY_EMBED_FIND_NOTFOUND;
-
- nsString uSearchString;
- NS_CStringToUTF16 (nsCString (aSearchString ? aSearchString : ""),
- NS_CSTRING_ENCODING_UTF8, uSearchString);
-
- SetSelectionAttention (PR_TRUE);
-
- nsresult rv;
- PRUint16 found = nsITypeAheadFind::FIND_NOTFOUND;
- rv = mFinder->Find (uSearchString, aLinksOnly, &found);
-
- return (EphyEmbedFindResult) found;
-}
-
-EphyEmbedFindResult
-EphyFind::FindAgain (PRBool aForward,
- PRBool aLinksOnly)
-{
- if (!mFinder) return EPHY_EMBED_FIND_NOTFOUND;
-
- SetSelectionAttention (PR_TRUE);
-
- nsresult rv;
- PRUint16 found = nsITypeAheadFind::FIND_NOTFOUND;
- rv = mFinder->FindAgain (!aForward, aLinksOnly, &found);
-
- return (EphyEmbedFindResult) found;
-}
-
-PRBool
-EphyFind::ActivateLink (GdkModifierType aMask)
-{
- nsresult rv;
- nsCOMPtr<nsIDOMElement> link;
- rv = mFinder->GetFoundLink (getter_AddRefs (link));
- if (NS_FAILED (rv) || !link) return FALSE;
-
- nsCOMPtr<nsIDOMDocument> doc;
- rv = link->GetOwnerDocument (getter_AddRefs (doc));
- NS_ENSURE_TRUE (doc, FALSE);
-
- nsCOMPtr<nsIDOMDocumentView> docView (do_QueryInterface (doc));
- NS_ENSURE_TRUE (docView, FALSE);
-
- nsCOMPtr<nsIDOMAbstractView> abstractView;
- docView->GetDefaultView (getter_AddRefs (abstractView));
- NS_ENSURE_TRUE (abstractView, FALSE);
-
- nsCOMPtr<nsIDOMDocumentEvent> docEvent (do_QueryInterface (doc));
- NS_ENSURE_TRUE (docEvent, FALSE);
-
- nsCOMPtr<nsIDOMEvent> event;
- rv = docEvent->CreateEvent (nsString(kKeyEvents), getter_AddRefs (event));
- NS_ENSURE_SUCCESS (rv, FALSE);
-
- nsCOMPtr<nsIDOMKeyEvent> keyEvent (do_QueryInterface (event));
- NS_ENSURE_TRUE (keyEvent, FALSE);
-
- rv = keyEvent->InitKeyEvent (nsString (kKeyPress),
- PR_TRUE /* bubble */,
- PR_TRUE /* cancelable */,
- abstractView,
- (aMask & GDK_CONTROL_MASK) != 0,
- (aMask & GDK_MOD1_MASK) != 0 /* Alt */,
- (aMask & GDK_SHIFT_MASK) != 0,
- /* FIXME when we upgrade to gtk 2.10 */
- PR_FALSE /* Meta */,
- nsIDOMKeyEvent::DOM_VK_RETURN,
- 0);
- NS_ENSURE_SUCCESS (rv, FALSE);
-
- nsCOMPtr<nsIDOMEventTarget> target (do_QueryInterface (link));
- NS_ENSURE_TRUE (target, FALSE);
-
- PRBool defaultPrevented = PR_FALSE;
- rv = target->DispatchEvent (event, &defaultPrevented);
-
- return NS_SUCCEEDED (rv) && defaultPrevented;
-}
diff --git a/embed/xulrunner/embed/EphyFind.h b/embed/xulrunner/embed/EphyFind.h
deleted file mode 100644
index 34c30517d..000000000
--- a/embed/xulrunner/embed/EphyFind.h
+++ /dev/null
@@ -1,60 +0,0 @@
-/*
- * Copyright © 2005 Christian Persch
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#ifndef TYPEAHEADFIND_H
-#define TYPEAHEADFIND_H
-
-#include <gdk/gdktypes.h>
-
-class nsITypeAheadFind;
-class nsIWebBrowser;
-class nsIWebBrowserFind;
-
-#include <nsCOMPtr.h>
-
-#include "ephy-embed.h"
-#include "ephy-embed-find.h"
-
-class EphyFind
-{
- public:
- EphyFind ();
- ~EphyFind ();
-
- nsresult SetEmbed (EphyEmbed *aEmbed);
- void SetFindProperties (const char *aSearchString,
- PRBool aCaseSensitive);
- void SetSelectionAttention (PRBool aAttention);
- EphyEmbedFindResult Find (const char *aSearchString,
- PRBool aLinksOnly);
- EphyEmbedFindResult FindAgain (PRBool aForward,
- PRBool aLinksOnly);
- PRBool ActivateLink (GdkModifierType aMask);
-
- private:
- EphyEmbed *mCurrentEmbed;
-
- nsCOMPtr<nsIWebBrowser> mWebBrowser;
-
- nsCOMPtr<nsITypeAheadFind> mFinder;
- PRPackedBool mAttention;
-};
-
-#endif /* !TYPEAHEADFIND_H */
diff --git a/embed/xulrunner/embed/EphyHeaderSniffer.cpp b/embed/xulrunner/embed/EphyHeaderSniffer.cpp
deleted file mode 100644
index 1429ef02e..000000000
--- a/embed/xulrunner/embed/EphyHeaderSniffer.cpp
+++ /dev/null
@@ -1,441 +0,0 @@
-/* ***** BEGIN LICENSE BLOCK *****
- * Version: MPL 1.1/GPL 2.0/LGPL 2.1
- *
- * The contents of this file are subject to the Mozilla Public License Version
- * 1.1 (the "License"); you may not use this file except in compliance with
- * the License. You may obtain a copy of the License at
- * http://www.mozilla.org/MPL/
- *
- * Software distributed under the License is distributed on an "AS IS" basis,
- * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
- * for the specific language governing rights and limitations under the
- * License.
- *
- * The Original Code is Chimera code.
- *
- * The Initial Developer of the Original Code is
- * Netscape Communications Corporation.
- * Portions created by the Initial Developer are Copyright © 2002
- * the Initial Developer. All Rights Reserved.
- *
- * Contributor(s):
- * David Hyatt <hyatt@netscape.com>
- * Simon Fraser <sfraser@netscape.com>
- *
- * Alternatively, the contents of this file may be used under the terms of
- * either the GNU General Public License Version 2 or later (the "GPL"), or
- * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
- * in which case the provisions of the GPL or the LGPL are applicable instead
- * of those above. If you wish to allow use of your version of this file only
- * under the terms of either the GPL or the LGPL, and not to allow others to
- * use your version of this file under the terms of the MPL, indicate your
- * decision by deleting the provisions above and replace them with the notice
- * and other provisions required by the GPL or the LGPL. If you do not delete
- * the provisions above, a recipient may use your version of this file under
- * the terms of any one of the MPL, the GPL or the LGPL.
- *
- * ***** END LICENSE BLOCK *****
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include <glib/gi18n.h>
-
-#include <nsStringGlue.h>
-
-#include <nsComponentManagerUtils.h>
-#include <nsIChannel.h>
-#include <nsIDOMDocument.h>
-#include <nsIDOMHTMLDocument.h>
-#include <nsIDownload.h>
-#include <nsIHttpChannel.h>
-#include <nsIInputStream.h>
-#include <nsILocalFile.h>
-#include <nsIMIMEHeaderParam.h>
-#include <nsIMIMEInfo.h>
-#include <nsIMIMEService.h>
-#include <nsIPrefService.h>
-#include <nsIPromptService.h>
-#include <nsIURI.h>
-#include <nsIURL.h>
-#include <nsIWebBrowserPersist.h>
-#include <nsIWindowWatcher.h>
-#include <nsServiceManagerUtils.h>
-#include <nsXPCOMCID.h>
-
-#include "eel-gconf-extensions.h"
-#include "ephy-debug.h"
-#include "ephy-file-chooser.h"
-#include "ephy-gui.h"
-#include "ephy-prefs.h"
-
-#include "EphyBadCertRejector.h"
-#include "MozDownload.h"
-
-#include "EphyHeaderSniffer.h"
-
-EphyHeaderSniffer::EphyHeaderSniffer (nsIWebBrowserPersist* aPersist, MozillaEmbedPersist *aEmbedPersist,
- nsIFile* aFile, nsIURI* aURL, nsIDOMDocument* aDocument, nsIInputStream* aPostData,
- EphyEmbedSingle *single)
-: mPersist(aPersist)
-, mEmbedPersist(aEmbedPersist)
-, mTmpFile(aFile)
-, mURL(aURL)
-, mOriginalURI(nsnull)
-, mDocument(aDocument)
-, mPostData(aPostData)
-{
- LOG ("EphyHeaderSniffer ctor (%p)", this);
-
- nsCOMPtr<nsIWindowWatcher> watcher
- (do_GetService("@mozilla.org/embedcomp/window-watcher;1"));
- if (!watcher) return;
-
- watcher->GetNewAuthPrompter (nsnull, getter_AddRefs (mAuthPrompt));
-
- mSingle = single;
- g_object_add_weak_pointer (G_OBJECT (mSingle),
- (gpointer *)&mSingle);
-}
-
-EphyHeaderSniffer::~EphyHeaderSniffer()
-{
- LOG ("EphyHeaderSniffer dtor (%p)", this);
-
- if (mSingle)
- {
- g_object_remove_weak_pointer (G_OBJECT (mSingle),
- (gpointer *)&mSingle);
- }
-}
-
-NS_IMPL_ISUPPORTS3 (EphyHeaderSniffer,
- nsIWebProgressListener,
- nsIInterfaceRequestor,
- nsIAuthPrompt)
-
-NS_IMETHODIMP
-EphyHeaderSniffer::HandleContent ()
-{
- gboolean handled = FALSE;
- nsCString uriSpec;
-
- if (mPostData || !mSingle) return NS_ERROR_FAILURE;
-
- mURL->GetSpec (uriSpec);
-
- g_signal_emit_by_name (mSingle, "handle_content", mContentType.get(),
- uriSpec.get(), &handled);
-
- return handled ? NS_OK : NS_ERROR_FAILURE;
-}
-
-NS_IMETHODIMP
-EphyHeaderSniffer::OnStateChange (nsIWebProgress *aWebProgress, nsIRequest *aRequest, PRUint32 aStateFlags,
- PRUint32 aStatus)
-{
- if (aStateFlags & nsIWebProgressListener::STATE_START)
- {
- /* be sure to keep it alive while we save since it owns
- us as a listener and keep ourselves alive */
- nsCOMPtr<nsIWebBrowserPersist> kungFuDeathGrip(mPersist);
- nsCOMPtr<nsIWebProgressListener> kungFuSuicideGrip(this);
-
- nsresult rv;
- nsCOMPtr<nsIChannel> channel = do_QueryInterface(aRequest, &rv);
- if (!channel) return rv;
- channel->GetContentType(mContentType);
-
- nsCOMPtr<nsIURI> origURI;
- channel->GetOriginalURI(getter_AddRefs(origURI));
-
- nsCOMPtr<nsIHttpChannel> httpChannel(do_QueryInterface(channel));
- if (httpChannel)
- {
- httpChannel->GetResponseHeader(nsCString("content-disposition"),
- mContentDisposition);
- }
-
- mPersist->CancelSave();
-
- PRBool exists;
- mTmpFile->Exists(&exists);
- if (exists)
- {
- mTmpFile->Remove(PR_FALSE);
- }
-
- rv = HandleContent ();
- if (NS_SUCCEEDED (rv)) return NS_OK;
-
- rv = PerformSave(origURI);
- if (NS_FAILED(rv))
- {
- /* FIXME put up some UI */
-
- }
- }
-
- return NS_OK;
-}
-
-NS_IMETHODIMP
-EphyHeaderSniffer::OnProgressChange (nsIWebProgress *aWebProgress,
- nsIRequest *aRequest,
- PRInt32 aCurSelfProgress,
- PRInt32 aMaxSelfProgress,
- PRInt32 aCurTotalProgress,
- PRInt32 aMaxTotalProgress)
-{
- return NS_OK;
-}
-
-NS_IMETHODIMP
-EphyHeaderSniffer::OnLocationChange (nsIWebProgress *aWebProgress,
- nsIRequest *aRequest,
- nsIURI *location)
-{
- return NS_OK;
-}
-
-NS_IMETHODIMP
-EphyHeaderSniffer::OnStatusChange (nsIWebProgress *aWebProgress,
- nsIRequest *aRequest,
- nsresult aStatus,
- const PRUnichar *aMessage)
-{
- return NS_OK;
-}
-
-NS_IMETHODIMP
-EphyHeaderSniffer::OnSecurityChange (nsIWebProgress *aWebProgress, nsIRequest *aRequest, PRUint32 state)
-{
- return NS_OK;
-}
-
-/* void getInterface (in nsIIDRef uuid, [iid_is (uuid), retval] out nsQIResult result); */
-NS_IMETHODIMP
-EphyHeaderSniffer::GetInterface(const nsIID & uuid, void * *result)
-{
- if (uuid.Equals (NS_GET_IID (nsIBadCertListener)) &&
- mEmbedPersist)
- {
- EphyEmbedPersistFlags flags;
-
- g_object_get (mEmbedPersist, "flags", &flags, (char *) NULL);
-
- if (flags & EPHY_EMBED_PERSIST_NO_CERTDIALOGS)
- {
- EphyBadCertRejector *badCertRejector = new EphyBadCertRejector ();
- if (!badCertRejector) return NS_ERROR_OUT_OF_MEMORY;
-
- *result = static_cast<nsIBadCertListener*>(badCertRejector);
- NS_ADDREF (badCertRejector);
-
- return NS_OK;
- }
- }
-
- return NS_ERROR_NO_INTERFACE;
-}
-
-static void
-filechooser_response_cb (GtkWidget *dialog,
- gint response,
- EphyHeaderSniffer* sniffer)
-{
- if (response == GTK_RESPONSE_ACCEPT)
- {
- char *filename;
-
- filename = gtk_file_chooser_get_filename (GTK_FILE_CHOOSER (dialog));
-
- if (ephy_gui_check_location_writable (dialog, filename) == FALSE)
- {
- g_free (filename);
- return;
- }
-
- nsCOMPtr<nsILocalFile> destFile = do_CreateInstance (NS_LOCAL_FILE_CONTRACTID);
- if (destFile)
- {
- destFile->InitWithNativePath (nsCString (filename));
-
- sniffer->InitiateDownload (destFile);
- }
-
- g_free (filename);
- }
-
- // FIXME how to inform user of failed save ?
-
- gtk_widget_destroy (GTK_WIDGET (dialog));
-}
-
-nsresult EphyHeaderSniffer::PerformSave (nsIURI* inOriginalURI)
-{
- nsresult rv;
- EphyEmbedPersistFlags flags;
- PRBool askDownloadDest;
-
- mOriginalURI = inOriginalURI;
-
- flags = ephy_embed_persist_get_flags (EPHY_EMBED_PERSIST (mEmbedPersist));
- askDownloadDest = flags & EPHY_EMBED_PERSIST_ASK_DESTINATION;
-
- nsString defaultFileName;
-
- if (!defaultFileName.Length() && mContentDisposition.Length())
- {
- /* 1 Use the HTTP header suggestion. */
- nsCOMPtr<nsIMIMEHeaderParam> mimehdrpar =
- do_GetService("@mozilla.org/network/mime-hdrparam;1");
-
- if (mimehdrpar)
- {
- nsCString fallbackCharset;
- if (mURL)
- {
- mURL->GetOriginCharset(fallbackCharset);
- }
-
- nsString fileName;
-
- rv = mimehdrpar->GetParameter (mContentDisposition, "filename",
- fallbackCharset, PR_TRUE, nsnull,
- fileName);
- if (NS_FAILED(rv) || !fileName.Length())
- {
- rv = mimehdrpar->GetParameter (mContentDisposition, "name",
- fallbackCharset, PR_TRUE, nsnull,
- fileName);
- }
-
- if (NS_SUCCEEDED(rv) && fileName.Length())
- {
- defaultFileName = fileName;
- }
- }
- }
-
- if (!defaultFileName.Length())
- {
- /* 2 For file URLs, use the file name. */
-
- nsCOMPtr<nsIURL> url(do_QueryInterface(mURL));
- if (url)
- {
- nsCString fileNameCString;
- url->GetFileName(fileNameCString);
- NS_CStringToUTF16 (fileNameCString, NS_CSTRING_ENCODING_UTF8,
- defaultFileName);
- }
- }
-
- if (!defaultFileName.Length() && mDocument)
- {
- /* 3 Use the title of the document. */
-
- nsCOMPtr<nsIDOMHTMLDocument> htmlDoc(do_QueryInterface(mDocument));
- if (htmlDoc)
- {
- htmlDoc->GetTitle(defaultFileName);
- }
- }
-
- if (!defaultFileName.Length() && mURL)
- {
- /* 4 Use the host. */
- nsCString hostName;
- mURL->GetHost(hostName);
- NS_CStringToUTF16 (hostName, NS_CSTRING_ENCODING_UTF8,
- defaultFileName);
- }
-
- /* 5 One last case to handle about:blank and other untitled pages. */
- if (!defaultFileName.Length())
- {
- NS_CStringToUTF16 (nsCString(_("Untitled")),
- NS_CSTRING_ENCODING_UTF8, defaultFileName);
- }
-
- /* Validate the file name to ensure legality. */
- nsCString cDefaultFileName;
- NS_UTF16ToCString (defaultFileName, NS_CSTRING_ENCODING_UTF8,
- cDefaultFileName);
- char *default_name = g_strdup (cDefaultFileName.get());
- default_name = g_strdelimit (default_name, "/\\:", ' ');
-
- const char *key;
- key = ephy_embed_persist_get_persist_key (EPHY_EMBED_PERSIST (mEmbedPersist));
-
- /* FIXME: do better here by using nsITextToSubURI service, like in
- * http://lxr.mozilla.org/seamonkey/source/xpfe/communicator/resources/content/contentAreaUtils.js#763
- */
- char *filename;
- filename = g_uri_unescape_string (default_name, NULL);
-
- if (!g_utf8_validate (filename, -1, NULL))
- {
- g_free (filename);
- filename = g_strdup (default_name);
- }
-
- g_free (default_name);
-
- if (askDownloadDest)
- {
- EphyFileChooser *dialog;
- GtkWindow *window;
- const char *title;
- guint32 user_time;
-
- title = ephy_embed_persist_get_fc_title (EPHY_EMBED_PERSIST (mEmbedPersist));
- window = ephy_embed_persist_get_fc_parent (EPHY_EMBED_PERSIST (mEmbedPersist));
-
- user_time = ephy_embed_persist_get_user_time (EPHY_EMBED_PERSIST (mEmbedPersist));
- if (user_time == 0)
- {
- g_warning ("EphyHeaderSniffer::PerformSave without valid user time!\n");
- }
-
- dialog = ephy_file_chooser_new (title ? title: _("Save"),
- GTK_WIDGET (window),
- GTK_FILE_CHOOSER_ACTION_SAVE,
- key ? key : CONF_STATE_SAVE_DIR,
- EPHY_FILE_FILTER_ALL_SUPPORTED);
- gtk_file_chooser_set_do_overwrite_confirmation (GTK_FILE_CHOOSER (dialog), TRUE);
-
- gtk_file_chooser_set_current_name (GTK_FILE_CHOOSER (dialog),
- filename);
-
- g_signal_connect (dialog, "response",
- G_CALLBACK (filechooser_response_cb), this);
-
- ephy_gui_window_update_user_time (GTK_WIDGET (dialog), user_time);
- gtk_widget_show (GTK_WIDGET (dialog));
-
- g_free (filename);
- return NS_OK;
- }
- /* FIXME: how to inform user of failed save ? */
-
- nsCOMPtr<nsILocalFile> destFile;
- BuildDownloadPath (filename, getter_AddRefs (destFile));
- g_free (filename);
- NS_ENSURE_TRUE (destFile, NS_ERROR_FAILURE);
-
- return InitiateDownload (destFile);
-}
-
-nsresult EphyHeaderSniffer::InitiateDownload (nsILocalFile *aDestFile)
-{
- LOG ("Initiating download");
-
- return InitiateMozillaDownload (mDocument, mURL, aDestFile,
- mContentType.get(), mOriginalURI, mEmbedPersist,
- mPostData, nsnull, -1);
-}
diff --git a/embed/xulrunner/embed/EphyHeaderSniffer.h b/embed/xulrunner/embed/EphyHeaderSniffer.h
deleted file mode 100644
index ec73c3164..000000000
--- a/embed/xulrunner/embed/EphyHeaderSniffer.h
+++ /dev/null
@@ -1,95 +0,0 @@
-/* ***** BEGIN LICENSE BLOCK *****
- * Version: MPL 1.1/GPL 2.0/LGPL 2.1
- *
- * The contents of this file are subject to the Mozilla Public License Version
- * 1.1 (the "License"); you may not use this file except in compliance with
- * the License. You may obtain a copy of the License at
- * http://www.mozilla.org/MPL/
- *
- * Software distributed under the License is distributed on an "AS IS" basis,
- * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
- * for the specific language governing rights and limitations under the
- * License.
- *
- * The Original Code is Chimera code.
- *
- * The Initial Developer of the Original Code is
- * Netscape Communications Corporation.
- * Portions created by the Initial Developer are Copyright © 2002
- * the Initial Developer. All Rights Reserved.
- *
- * Contributor(s):
- * David Hyatt <hyatt@netscape.com>
- * Simon Fraser <sfraser@netscape.com>
- *
- * Alternatively, the contents of this file may be used under the terms of
- * either the GNU General Public License Version 2 or later (the "GPL"), or
- * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
- * in which case the provisions of the GPL or the LGPL are applicable instead
- * of those above. If you wish to allow use of your version of this file only
- * under the terms of either the GPL or the LGPL, and not to allow others to
- * use your version of this file under the terms of the MPL, indicate your
- * decision by deleting the provisions above and replace them with the notice
- * and other provisions required by the GPL or the LGPL. If you do not delete
- * the provisions above, a recipient may use your version of this file under
- * the terms of any one of the MPL, the GPL or the LGPL.
- *
- * ***** END LICENSE BLOCK *****
- *
- * $Id$
- */
-
-#ifndef EPHY_HEADER_SNIFFER_H
-#define EPHY_HEADER_SNIFFER_H
-
-class nsIDOMDocument;
-class nsIFile;
-class nsIInputStream;
-class nsILocalFile;
-class nsIURI;
-class nsIWebBrowserPersist;
-
-#include <nsCOMPtr.h>
-#include <nsIAuthPrompt.h>
-#include <nsIInterfaceRequestor.h>
-#include <nsIWebProgressListener.h>
-
-#include "mozilla-embed-persist.h"
-#include "ephy-embed-single.h"
-
-class EphyHeaderSniffer : public nsIWebProgressListener,
- public nsIInterfaceRequestor,
- public nsIAuthPrompt
-{
-public:
- EphyHeaderSniffer (nsIWebBrowserPersist* aPersist, MozillaEmbedPersist *aEmbedPersist,
- nsIFile* aFile, nsIURI* aURL, nsIDOMDocument* aDocument,
- nsIInputStream* aPostData, EphyEmbedSingle *single);
- virtual ~EphyHeaderSniffer ();
-
- NS_DECL_ISUPPORTS
- NS_DECL_NSIWEBPROGRESSLISTENER
- NS_FORWARD_SAFE_NSIAUTHPROMPT(mAuthPrompt)
- NS_DECL_NSIINTERFACEREQUESTOR
-
- nsresult InitiateDownload (nsILocalFile *aDestFile);
-
-protected:
- nsresult PerformSave (nsIURI* inOriginalURI);
- nsresult HandleContent ();
-
-private:
- nsIWebBrowserPersist* mPersist; /* Weak. It owns us as a listener. */
- MozillaEmbedPersist *mEmbedPersist;
- EphyEmbedSingle *mSingle;
- nsCOMPtr<nsIFile> mTmpFile;
- nsCOMPtr<nsIURI> mURL;
- nsCOMPtr<nsIURI> mOriginalURI;
- nsCOMPtr<nsIDOMDocument> mDocument;
- nsCOMPtr<nsIInputStream> mPostData;
- nsCString mContentType;
- nsCString mContentDisposition;
- nsCOMPtr<nsIAuthPrompt> mAuthPrompt;
-};
-
-#endif /* !EPHY_HEADER_SNIFFER_H */
diff --git a/embed/xulrunner/embed/EphySingle.cpp b/embed/xulrunner/embed/EphySingle.cpp
deleted file mode 100644
index c6ac0be44..000000000
--- a/embed/xulrunner/embed/EphySingle.cpp
+++ /dev/null
@@ -1,394 +0,0 @@
-/*
- * Copyright © 2003 Christian Persch
- * Copyright © 2003 Marco Pesenti Gritti
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include <nsStringGlue.h>
-
-#include <nsICookie.h>
-#include <nsICookie2.h>
-#include <nsICookieManager.h>
-#include <nsIHttpChannel.h>
-#include <nsIObserverService.h>
-#include <nsIPermission.h>
-#include <nsIPermissionManager.h>
-#include <nsIPropertyBag2.h>
-#include <nsIServiceManager.h>
-#include <nsIURI.h>
-#include <nsServiceManagerUtils.h>
-#include <nsWeakReference.h>
-
-#ifdef ALLOW_PRIVATE_API
-#include <nsIIDNService.h>
-#endif
-
-#include "ephy-debug.h"
-
-#include "EphySingle.h"
-
-NS_IMPL_ISUPPORTS1(EphySingle, nsIObserver)
-
-EphySingle::EphySingle()
-: mOwner(nsnull)
-, mIsOnline(PR_TRUE) /* nsIOService doesn't send an initial notification, assume we start on-line */
-{
- LOG ("EphySingle ctor");
-}
-
-nsresult
-EphySingle::Init (EphyEmbedSingle *aOwner)
-{
- mObserverService = do_GetService ("@mozilla.org/observer-service;1");
- NS_ENSURE_TRUE (mObserverService, NS_ERROR_FAILURE);
-
- nsresult rv;
- rv = mObserverService->AddObserver (this, "cookie-changed", PR_FALSE);
- rv |= mObserverService->AddObserver (this, "cookie-rejected", PR_FALSE);
- rv |= mObserverService->AddObserver (this, "perm-changed", PR_FALSE);
- rv |= mObserverService->AddObserver (this, "network:offline-status-changed", PR_FALSE);
- rv |= mObserverService->AddObserver (this, "signonChanged", PR_FALSE);
- rv |= mObserverService->AddObserver (this, "http-on-examine-response", PR_FALSE);
- rv |= mObserverService->AddObserver (this, "http-on-modify-request", PR_FALSE);
- NS_ENSURE_SUCCESS (rv, NS_ERROR_FAILURE);
-
- mOwner = aOwner;
-
- LOG ("EphySingle::Init");
-
- return NS_OK;
-}
-
-nsresult
-EphySingle::Detach ()
-{
- LOG ("EphySingle::Detach");
-
- if (mObserverService)
- {
- mObserverService->RemoveObserver (this, "cookie-changed");
- mObserverService->RemoveObserver (this, "cookie-rejected");
- mObserverService->RemoveObserver (this, "perm-changed");
- mObserverService->RemoveObserver (this, "signonChanged");
- mObserverService->RemoveObserver (this, "network:offline-status-changed");
- mObserverService->RemoveObserver (this, "http-on-examine-response");
- mObserverService->RemoveObserver (this, "http-on-modify-request");
-
-#if 1
- /* HACK: Work around https://bugzilla.mozilla.org/show_bug.cgi?id=292699 */
- mObserverService->NotifyObservers(nsnull, "profile-change-net-teardown", nsnull);
-#endif
- }
-
- return NS_OK;
-}
-
-EphySingle::~EphySingle()
-{
- LOG ("EphySingle dtor");
-
- mOwner = nsnull;
-}
-
-nsresult
-EphySingle::EmitCookieNotification (const char *name,
- nsISupports *aSubject)
-{
- LOG ("EmitCookieNotification %s", name);
-
- nsCOMPtr<nsICookie> cookie = do_QueryInterface (aSubject);
- NS_ENSURE_TRUE (cookie, NS_ERROR_FAILURE);
-
- EphyCookie *info = mozilla_cookie_to_ephy_cookie (cookie);
-
- g_signal_emit_by_name (EPHY_COOKIE_MANAGER (mOwner), name, info);
-
- ephy_cookie_free (info);
-
- return NS_OK;
-}
-
-nsresult
-EphySingle::EmitPermissionNotification (const char *name,
- nsISupports *aSubject)
-{
- LOG ("EmitPermissionNotification %s", name);
-
- nsCOMPtr<nsIPermission> perm = do_QueryInterface (aSubject);
- NS_ENSURE_TRUE (perm, NS_ERROR_FAILURE);
-
- EphyPermissionInfo *info =
- mozilla_permission_to_ephy_permission (perm);
-
- g_signal_emit_by_name (EPHY_PERMISSION_MANAGER (mOwner), name, info);
-
- ephy_permission_info_free (info);
-
- return NS_OK;
-}
-
-nsresult
-EphySingle::ExamineCookies (nsISupports *aSubject)
-{
- PRBool isBlockingCookiesChannel = PR_FALSE;
-
- nsCOMPtr<nsIPropertyBag2> props (do_QueryInterface(aSubject));
- if (props &&
- NS_SUCCEEDED (props->GetPropertyAsBool(
- NS_LITERAL_STRING("epiphany-blocking-cookies"),
- &isBlockingCookiesChannel)) &&
- isBlockingCookiesChannel)
- {
- nsCOMPtr<nsIHttpChannel> httpChannel (do_QueryInterface(aSubject));
-
- if (httpChannel)
- httpChannel->SetRequestHeader(NS_LITERAL_CSTRING("Cookie"),
- EmptyCString(), PR_FALSE);
- }
-
- return NS_OK;
-}
-
-nsresult
-EphySingle::ExamineResponse (nsISupports *aSubject)
-{
- return ExamineCookies (aSubject);
-}
-
-nsresult
-EphySingle::ExamineRequest (nsISupports *aSubject)
-{
- return ExamineCookies (aSubject);
-}
-
-/* void observe (in nsISupports aSubject, in string aTopic, in wstring aData); */
-NS_IMETHODIMP EphySingle::Observe(nsISupports *aSubject,
- const char *aTopic,
- const PRUnichar *aData)
-{
- nsresult rv = NS_OK;
-
- LOG ("EphySingle::Observe topic %s", aTopic);
-
- if (strcmp (aTopic, "http-on-examine-response") == 0)
- {
- rv = ExamineResponse (aSubject);
- }
- else if (strcmp (aTopic, "http-on-modify-request") == 0)
- {
- rv = ExamineRequest (aSubject);
- }
- else if (strcmp (aTopic, "cookie-changed") == 0)
- {
- /* "added" */
- if (aData[0] == 'a')
- {
- rv = EmitCookieNotification ("cookie-added", aSubject);
- }
- /* "deleted" */
- else if (aData[0] == 'd')
- {
- rv = EmitCookieNotification ("cookie-deleted", aSubject);
- }
- /* "changed" */
- else if (aData[0] == 'c' && aData[1] == 'h')
- {
- rv = EmitCookieNotification ("cookie-changed", aSubject);
- }
- /* "cleared" */
- else if (aData[0] == 'c' && aData[1] == 'l')
- {
- LOG ("EphySingle::cookie-changed::cleared");
-
- g_signal_emit_by_name (EPHY_COOKIE_MANAGER (mOwner), "cookies-cleared");
- }
- else
- {
- g_warning ("EphySingle unexpected data!\n");
- rv = NS_ERROR_FAILURE;
- }
- }
- else if (strcmp (aTopic, "cookie-rejected") == 0)
- {
- LOG ("EphySingle::cookie-rejected");
-
- nsCOMPtr<nsIURI> uri = do_QueryInterface (aSubject);
- if (uri)
- {
- nsCString spec;
- uri->GetSpec (spec);
-
- g_signal_emit_by_name (EPHY_COOKIE_MANAGER (mOwner), "cookie-rejected", spec.get());
- }
- else
- {
- rv = NS_ERROR_FAILURE;
- }
- }
- else if (strcmp (aTopic, "perm-changed") == 0)
- {
- /* "added" */
- if (aData[0] == 'a')
- {
- rv = EmitPermissionNotification ("permission-added", aSubject);
- }
- /* "deleted" */
- else if (aData[0] == 'd')
- {
- rv = EmitPermissionNotification ("permission-deleted", aSubject);
- }
- /* "changed" */
- else if (aData[0] == 'c' && aData[1] == 'h')
- {
- rv = EmitPermissionNotification ("permission-changed", aSubject);
- }
- /* "cleared" */
- else if (aData[0] == 'c' && aData[1] == 'l')
- {
- LOG ("EphySingle::perm-changed::cleared");
-
- g_signal_emit_by_name (EPHY_PERMISSION_MANAGER (mOwner), "permissions-cleared");
- }
- else
- {
- g_warning ("EphySingle unexpected data!\n");
- rv = NS_ERROR_FAILURE;
- }
- }
- else if (strcmp (aTopic, "signonChanged") == 0)
- {
- /* aData can be PRUnichar[] "signons", "rejects", "nocaptures" and "nopreviews" */
- if (aData[0] == 's')
- {
- g_signal_emit_by_name (mOwner, "passwords-changed");
- }
- }
- else if (strcmp (aTopic, "network:offline-status-changed") == 0)
- {
- /* aData is either (PRUnichar[]) "offline" or "online" */
- mIsOnline = (aData && aData[0] == 'o' && aData[1] == 'n');
-
- g_object_notify (G_OBJECT (mOwner), "network-status");
- }
- else
- {
- g_warning ("EphySingle observed unknown topic '%s'!\n", aTopic);
- rv = NS_ERROR_FAILURE;
- }
-
- LOG ("EphySingle::Observe %s", NS_SUCCEEDED (rv) ? "success" : "FAILURE");
-
- return rv;
-}
-
-EphyCookie *
-mozilla_cookie_to_ephy_cookie (nsICookie *cookie)
-{
- EphyCookie *info;
-
- nsCString transfer;
-
- cookie->GetHost (transfer);
-
- nsCOMPtr<nsIIDNService> idnService
- (do_GetService ("@mozilla.org/network/idn-service;1"));
- NS_ENSURE_TRUE (idnService, nsnull);
-
- nsCString decoded;
- /* ToUTF8 never fails, no need to check return value */
- idnService->ConvertACEtoUTF8 (transfer, decoded);
-
- info = ephy_cookie_new ();
- info->domain = g_strdup (decoded.get());
-
- cookie->GetName (transfer);
- info->name = g_strdup (transfer.get());
- cookie->GetValue (transfer);
- info->value = g_strdup (transfer.get());
- cookie->GetPath (transfer);
- info->path = g_strdup (transfer.get());
-
- PRBool isSecure;
- cookie->GetIsSecure (&isSecure);
- info->is_secure = isSecure != PR_FALSE;
-
- PRUint64 dateTime;
- cookie->GetExpires (&dateTime);
- info->expires = dateTime;
-
- nsCOMPtr<nsICookie2> cookie2 = do_QueryInterface (cookie);
- NS_ENSURE_TRUE (cookie2, info);
-
- PRBool isSession;
- cookie2->GetIsSession (&isSession);
- info->is_session = isSession != PR_FALSE;
-
- if (!isSession)
- {
- PRInt64 expiry;
- cookie2->GetExpiry (&expiry);
- info->real_expires = expiry;
- }
-
- PRBool isHttpOnly = PR_FALSE;
- cookie2->GetIsHttpOnly (&isHttpOnly);
- info->is_http_only = isHttpOnly != PR_FALSE;
-
- return info;
-}
-
-EphyPermissionInfo *
-mozilla_permission_to_ephy_permission (nsIPermission *perm)
-{
- nsresult rv;
- nsCString type;
- rv = perm->GetType(type);
- NS_ENSURE_SUCCESS (rv, NULL);
-
- PRUint32 cap;
- perm->GetCapability(&cap);
- EphyPermission permission;
- switch (cap)
- {
- case nsIPermissionManager::ALLOW_ACTION:
- permission = EPHY_PERMISSION_ALLOWED;
- break;
- case nsIPermissionManager::DENY_ACTION:
- permission = EPHY_PERMISSION_DENIED;
- break;
- case nsIPermissionManager::UNKNOWN_ACTION:
- default :
- permission = EPHY_PERMISSION_DEFAULT;
- break;
- }
-
- nsCString host;
- perm->GetHost(host);
-
- nsCOMPtr<nsIIDNService> idnService
- (do_GetService ("@mozilla.org/network/idn-service;1"));
- NS_ENSURE_TRUE (idnService, nsnull);
-
- nsCString decodedHost;
- idnService->ConvertACEtoUTF8 (host, decodedHost);
-
- return ephy_permission_info_new (decodedHost.get(), type.get(), permission);
-}
diff --git a/embed/xulrunner/embed/EphySingle.h b/embed/xulrunner/embed/EphySingle.h
deleted file mode 100644
index f30d7340a..000000000
--- a/embed/xulrunner/embed/EphySingle.h
+++ /dev/null
@@ -1,67 +0,0 @@
-/*
- * Copyright © 2003 Christian Persch
- * Copyright © 2003 Marco Pesenti Gritti
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#ifndef EPHY_SINGLE_H
-#define EPHY_SINGLE_H
-
-#include <nsCOMPtr.h>
-#include <nsIObserver.h>
-#include <nsIObserverService.h>
-
-#include "ephy-cookie-manager.h"
-#include "ephy-embed-single.h"
-#include "ephy-permission-manager.h"
-
-class nsICookie;
-class nsIPermission;
-
-class EphySingle : public nsIObserver
-{
-public:
- NS_DECL_ISUPPORTS
- NS_DECL_NSIOBSERVER
-
- EphySingle();
- virtual ~EphySingle();
-
- nsresult Init (EphyEmbedSingle *aOwner);
- nsresult Detach ();
-
- PRBool IsOnline() { return mIsOnline; }
-
-protected:
- nsresult EmitCookieNotification (const char *name, nsISupports *aSubject);
- nsresult EmitPermissionNotification (const char *name, nsISupports *aSubject);
- nsresult ExamineResponse (nsISupports *aSubject);
- nsresult ExamineRequest (nsISupports *aSubject);
- nsresult ExamineCookies (nsISupports *aSubject);
-
-private:
- nsCOMPtr<nsIObserverService> mObserverService;
- EphyEmbedSingle *mOwner;
- PRBool mIsOnline;
-};
-
-EphyCookie *mozilla_cookie_to_ephy_cookie (nsICookie *cookie);
-
-EphyPermissionInfo *mozilla_permission_to_ephy_permission (nsIPermission *perm);
-
-#endif
diff --git a/embed/xulrunner/embed/EventContext.cpp b/embed/xulrunner/embed/EventContext.cpp
deleted file mode 100644
index 6943775c3..000000000
--- a/embed/xulrunner/embed/EventContext.cpp
+++ /dev/null
@@ -1,1105 +0,0 @@
-/*
- * Copyright © 2000-2004 Marco Pesenti Gritti
- * Copyright © 2003, 2004 Christian Persch
- * Copyright © 2004 Crispin Flowerday
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include <gdk/gdkkeysyms.h>
-
-#include <nsStringGlue.h>
-
-#include <nsComponentManagerUtils.h>
-#include <nsIDOM3Node.h>
-#include <nsIDOMAbstractView.h>
-#include <nsIDOMCharacterData.h>
-#include <nsIDOMCSSPrimitiveValue.h>
-#include <nsIDOMCSSStyleDeclaration.h>
-#include <nsIDOMDocument.h>
-#include <nsIDOMDocumentView.h>
-#include <nsIDOMElementCSSInlineStyle.h>
-#include <nsIDOMElement.h>
-#include <nsIDOMEvent.h>
-#include <nsIDOMEventTarget.h>
-#include <nsIDOMEventTarget.h>
-#include <nsIDOMHTMLAnchorElement.h>
-#include <nsIDOMHTMLAreaElement.h>
-#include <nsIDOMHTMLBodyElement.h>
-#include <nsIDOMHTMLButtonElement.h>
-#include <nsIDOMHTMLEmbedElement.h>
-#include <nsIDOMHTMLImageElement.h>
-#include <nsIDOMHTMLInputElement.h>
-#include <nsIDOMHTMLIsIndexElement.h>
-#include <nsIDOMHTMLLabelElement.h>
-#include <nsIDOMHTMLLegendElement.h>
-#include <nsIDOMHTMLMapElement.h>
-#include <nsIDOMHTMLObjectElement.h>
-#include <nsIDOMHTMLSelectElement.h>
-#include <nsIDOMHTMLTextAreaElement.h>
-#include <nsIDOMKeyEvent.h>
-#include <nsIDOMMouseEvent.h>
-#include <nsIDOMNode.h>
-#include <nsIDOMNodeList.h>
-#include <nsIDOMNSHTMLDocument.h>
-#include <nsIDOMNSUIEvent.h>
-#include <nsIInterfaceRequestor.h>
-#include <nsIInterfaceRequestorUtils.h>
-#include <nsIServiceManager.h>
-#include <nsIURI.h>
-
-#ifdef ALLOW_PRIVATE_API
-#include <nsIDOMNSEvent.h>
-#include <nsIDOMNSHTMLElement.h>
-#include <nsIDOMViewCSS.h>
-#include <nsIDOMViewCSS.h>
-#include <nsIDOMXULDocument.h>
-#include <nsITextToSubURI.h>
-#endif
-
-#include "ephy-debug.h"
-
-#include "EphyBrowser.h"
-#include "EphyUtils.h"
-
-#include "EventContext.h"
-
-
-#define KEY_CODE 256
-
-EventContext::EventContext ()
-{
- LOG ("EventContext ctor [%p]", this);
-}
-
-EventContext::~EventContext ()
-{
- LOG ("EventContext dtor [%p]", this);
-}
-
-nsresult EventContext::Init (EphyBrowser *browser)
-{
- mBrowser = browser;
- mDOMDocument = nsnull;
-
- return NS_OK;
-}
-
-nsresult EventContext::GatherTextUnder (nsIDOMNode* aNode, nsAString& aResult)
-{
- nsString text;
- nsCOMPtr<nsIDOMNode> node;
- aNode->GetFirstChild(getter_AddRefs(node));
- PRUint32 depth = 1;
-
- while (node && depth)
- {
- nsCOMPtr<nsIDOMCharacterData> charData(do_QueryInterface(node));
- PRUint16 nodeType;
-
- node->GetNodeType(&nodeType);
- if (charData && nodeType == nsIDOMNode::TEXT_NODE)
- {
- /* Add this text to our collection. */
- text += ' ';
- nsString data;
- charData->GetData(data);
- text += data;
- }
- else
- {
- nsCOMPtr<nsIDOMHTMLImageElement> img(do_QueryInterface(node));
- if (img)
- {
- nsString altText;
- img->GetAlt(altText);
- if (altText.Length())
- {
- text = altText;
- break;
- }
- }
- }
-
- /* Find the next node to test. */
- PRBool hasChildNodes;
- node->HasChildNodes(&hasChildNodes);
- if (hasChildNodes)
- {
- nsCOMPtr<nsIDOMNode> temp = node;
- temp->GetFirstChild(getter_AddRefs(node));
- depth++;
- }
- else
- {
- nsCOMPtr<nsIDOMNode> nextSibling;
- node->GetNextSibling(getter_AddRefs(nextSibling));
- if (nextSibling)
- {
- node = nextSibling;
- }
- else
- {
- nsCOMPtr<nsIDOMNode> parentNode;
- node->GetParentNode(getter_AddRefs(parentNode));
- if (!parentNode)
- {
- node = nsnull;
- }
- else
- {
- parentNode->GetNextSibling(getter_AddRefs(nextSibling));
- node = nextSibling;
- depth--;
- }
- }
- }
- }
-
- /* FIXME we should trim spaces here */
-
- aResult = text;
-
- return NS_OK;
-}
-
-/* FIXME: we should resolve against the element's base, not the document's base */
-nsresult EventContext::ResolveBaseURL (const nsAString &relurl, nsACString &url)
-{
- nsCString cRelURL;
- NS_UTF16ToCString (relurl, NS_CSTRING_ENCODING_UTF8, cRelURL);
-
- return mBaseURI->Resolve (cRelURL, url);
-}
-
-nsresult EventContext::Unescape (const nsACString &aEscaped, nsACString &aUnescaped)
-{
- if (!aEscaped.Length()) return NS_ERROR_FAILURE;
-
- nsCOMPtr<nsITextToSubURI> escaper
- (do_CreateInstance ("@mozilla.org/intl/texttosuburi;1"));
- NS_ENSURE_TRUE (escaper, NS_ERROR_FAILURE);
-
- nsresult rv;
- nsCString encoding;
- rv = mBrowser->GetEncoding (encoding);
- NS_ENSURE_SUCCESS (rv, NS_ERROR_FAILURE);
-
- nsString unescaped;
- rv = escaper->UnEscapeURIForUI (encoding, aEscaped, unescaped);
- NS_ENSURE_TRUE (NS_SUCCEEDED (rv) && unescaped.Length(), NS_ERROR_FAILURE);
-
- NS_UTF16ToCString (unescaped, NS_CSTRING_ENCODING_UTF8, aUnescaped);
-
- return NS_OK;
-}
-
-nsresult EventContext::GetEventContext (nsIDOMEventTarget *EventTarget,
- MozillaEmbedEvent *info)
-{
- nsresult rv;
-
- const PRUnichar hrefLiteral[] = {'h', 'r', 'e', 'f', '\0'};
- const PRUnichar imgLiteral[] = {'i', 'm', 'g', '\0'};
- const PRUnichar typeLiteral[] = {'t', 'y', 'p', 'e', '\0'};
- const PRUnichar xlinknsLiteral[] = {'h', 't', 't', 'p', ':', '/', '/','w',
- 'w', 'w', '.', 'w', '3', '.', 'o', 'r',
- 'g', '/', '1', '9', '9', '9', '/', 'x',
- 'l', 'i', 'n', 'k', '\0'};
- const PRUnichar bodyLiteral[] = { 'b', 'o', 'd', 'y', '\0' };
-
- mEmbedEvent = info;
-
- info->context = EPHY_EMBED_CONTEXT_DOCUMENT;
-
- nsCOMPtr<nsIDOMNode> node = do_QueryInterface(EventTarget, &rv);
- if (NS_FAILED(rv) || !node) return NS_ERROR_FAILURE;
-
- /* Is page xul ? then do not display context menus
- * FIXME I guess there is an easier way ... */
- /* From philipl: This test needs to be here otherwise we
- * arrogantly assume we can QI to a HTMLElement, which is
- * not true for xul content. */
-
- nsCOMPtr<nsIDOMDocument> domDoc;
- rv = node->GetOwnerDocument(getter_AddRefs(domDoc));
- if (NS_FAILED(rv) || !domDoc) return NS_ERROR_FAILURE;
-
- nsCOMPtr<nsIDOMXULDocument> xul_document = do_QueryInterface(domDoc);
- if (xul_document)
- {
- info->context = EPHY_EMBED_CONTEXT_NONE;
- return NS_ERROR_FAILURE;
- }
-
- mDOMDocument = domDoc;
-
- rv = mBrowser->GetEncoding (mCharset);
- NS_ENSURE_SUCCESS (rv, rv);
-
- /* Get base URI and CSS view */
- nsCOMPtr<nsIDOMDocumentView> docView (do_QueryInterface (domDoc));
- NS_ENSURE_TRUE (docView, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsIDOMAbstractView> abstractView;
- docView->GetDefaultView (getter_AddRefs (abstractView));
- NS_ENSURE_TRUE (abstractView, NS_ERROR_FAILURE);
- /* the abstract view is really the DOM window */
-
- mViewCSS = do_QueryInterface (abstractView);
- NS_ENSURE_TRUE (mViewCSS, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsIWebNavigation> webNav (do_GetInterface (abstractView, &rv));
- NS_ENSURE_SUCCESS (rv, rv);
-
- rv = webNav->GetCurrentURI (getter_AddRefs (mBaseURI));
- NS_ENSURE_SUCCESS (rv, rv);
-
- // Now we know that the page isn't a xul window, we can try and
- // do something useful with it.
-
- PRUint16 type;
- rv = node->GetNodeType(&type);
- if (NS_FAILED(rv)) return NS_ERROR_FAILURE;
-
- PRBool has_image = PR_FALSE;
-
- nsCOMPtr<nsIDOMHTMLElement> element = do_QueryInterface(node);
- if ((nsIDOMNode::ELEMENT_NODE == type) && element)
- {
- nsString uTag;
- rv = element->GetLocalName(uTag);
- if (NS_FAILED(rv)) return NS_ERROR_FAILURE;
-
- nsCString tag;
- NS_UTF16ToCString (uTag, NS_CSTRING_ENCODING_UTF8, tag);
-
- if (g_ascii_strcasecmp (tag.get(), "img") == 0)
- {
- nsString img;
- nsCOMPtr <nsIDOMHTMLImageElement> image =
- do_QueryInterface(node, &rv);
- if (NS_FAILED(rv) || !image) return NS_ERROR_FAILURE;
-
- rv = image->GetSrc (img);
- if (NS_FAILED(rv)) return NS_ERROR_FAILURE;
-
- SetStringProperty ("image", img);
- info->context |= EPHY_EMBED_CONTEXT_IMAGE;
- has_image = PR_TRUE;
- }
- else if (g_ascii_strcasecmp (tag.get(), "area") == 0)
- {
- nsCOMPtr <nsIDOMHTMLAreaElement> area =
- do_QueryInterface(node, &rv);
- if (NS_FAILED(rv) || !area) return NS_ERROR_FAILURE;
-
- // Parent node is the map itself
- nsCOMPtr<nsIDOMNode> parentNode;
- node->GetParentNode (getter_AddRefs(parentNode));
-
- nsCOMPtr <nsIDOMHTMLMapElement> map =
- do_QueryInterface(parentNode, &rv);
- if (NS_FAILED(rv) || !area) return NS_ERROR_FAILURE;
-
- nsString mapName;
- rv = map->GetName (mapName);
- if (NS_FAILED(rv)) return NS_ERROR_FAILURE;
-
- // Now we are searching for all the images with a usemap attribute
- nsCOMPtr<nsIDOMNodeList> imgs;
- rv = mDOMDocument->GetElementsByTagName (nsString(imgLiteral),
- getter_AddRefs (imgs));
- if (NS_FAILED(rv)) return NS_ERROR_FAILURE;
-
- PRUint32 imgs_count;
- rv = imgs->GetLength (&imgs_count);
- if (NS_FAILED (rv)) return NS_ERROR_FAILURE;
-
- for (PRUint32 i = 0; i < imgs_count; i++)
- {
- nsCOMPtr<nsIDOMNode> aNode;
- rv = imgs->Item (i, getter_AddRefs (aNode));
- if (NS_FAILED (rv)) continue;
-
- nsCOMPtr<nsIDOMHTMLImageElement> img =
- do_QueryInterface(aNode, &rv);
- if (NS_FAILED(rv) || !img) continue;
-
- nsString imgMapName;
- rv = img->GetUseMap (imgMapName);
- if (NS_FAILED (rv)) continue;
-
- // usemap always starts with #
- imgMapName.Cut (0,1);
-
- // Check if the current image is attached to the map we are looking for
- if (imgMapName.Equals(mapName))
- {
- nsString imgSrc;
- rv = img->GetSrc (imgSrc);
- if (NS_FAILED(rv)) continue;
-
- SetStringProperty ("image", imgSrc);
- info->context |= EPHY_EMBED_CONTEXT_IMAGE;
- has_image = PR_TRUE;
-
- break;
- }
- }
- }
- else if (g_ascii_strcasecmp (tag.get(), "input") == 0)
- {
- CheckInput (node);
- }
- else if (g_ascii_strcasecmp (tag.get(), "textarea") == 0)
- {
- info->context |= EPHY_EMBED_CONTEXT_INPUT;
- }
- else if (g_ascii_strcasecmp (tag.get(), "object") == 0)
- {
- nsCOMPtr<nsIDOMHTMLObjectElement> object;
- object = do_QueryInterface (node);
- if (!element) return NS_ERROR_FAILURE;
-
- nsString value;
- object->GetType(value);
-
- nsCString cValue;
- NS_UTF16ToCString (value, NS_CSTRING_ENCODING_UTF8, cValue);
-
- // MIME types are always lower case
- if (g_str_has_prefix (cValue.get(), "image/"))
- {
- nsString img;
-
- rv = object->GetData (img);
- if (NS_FAILED(rv)) return NS_ERROR_FAILURE;
-
- nsCString cImg;
- rv = ResolveBaseURL (img, cImg);
- if (NS_FAILED (rv)) return NS_ERROR_FAILURE;
-
- SetStringProperty ("image", cImg.get());
- info->context |= EPHY_EMBED_CONTEXT_IMAGE;
- has_image = PR_TRUE;
- }
- else
- {
- info->context = EPHY_EMBED_CONTEXT_NONE;
- return NS_OK;
- }
- }
- else if (g_ascii_strcasecmp (tag.get(), "html") == 0)
- {
- /* Clicked on part of the page without a <body>, so
- * look for a background image in the body tag */
- nsCOMPtr<nsIDOMNodeList> nodeList;
-
- rv = mDOMDocument->GetElementsByTagName (nsString(bodyLiteral),
- getter_AddRefs (nodeList));
- if (NS_SUCCEEDED (rv) && nodeList)
- {
- nsCOMPtr<nsIDOMNode> bodyNode;
- nodeList->Item (0, getter_AddRefs (bodyNode));
-
- nsString cssurl;
- rv = GetCSSBackground (bodyNode, cssurl);
- if (NS_SUCCEEDED (rv))
- {
- nsCString bgimg;
- rv = ResolveBaseURL (cssurl, bgimg);
- if (NS_FAILED (rv))
- return NS_ERROR_FAILURE;
-
- SetStringProperty ("image", bgimg.get());
- info->context |= EPHY_EMBED_CONTEXT_IMAGE;
- has_image = PR_TRUE;
- }
- }
- }
- }
-
- /* Is page framed ? */
- PRBool framed;
- IsPageFramed (node, &framed);
- SetIntProperty ("framed_page", framed);
-
- /* Bubble out, looking for items of interest */
- while (node)
- {
- nsCOMPtr <nsIDOMElement> dom_elem = do_QueryInterface(node);
- if (dom_elem)
- {
- nsString value;
- dom_elem->GetAttributeNS (nsString(xlinknsLiteral),
- nsString(typeLiteral), value);
-
- nsCString cValue;
- NS_UTF16ToCString (value, NS_CSTRING_ENCODING_UTF8, cValue);
-
- if (g_ascii_strcasecmp (cValue.get(), "simple") == 0)
- {
- info->context |= EPHY_EMBED_CONTEXT_LINK;
- dom_elem->GetAttributeNS (nsString(xlinknsLiteral),
- nsString(hrefLiteral), value);
-
- SetURIProperty (node, "link", value);
- CheckLinkScheme (value);
- }
- }
-
- rv = node->GetNodeType(&type);
- if (NS_FAILED(rv)) return NS_ERROR_FAILURE;
-
- element = do_QueryInterface(node);
- if ((nsIDOMNode::ELEMENT_NODE == type) && element)
- {
- nsString uTag;
- rv = element->GetLocalName(uTag);
- if (NS_FAILED(rv)) return NS_ERROR_FAILURE;
-
- nsCString tag;
- NS_UTF16ToCString (uTag, NS_CSTRING_ENCODING_UTF8, tag);
-
- /* Link */
- if (g_ascii_strcasecmp (tag.get(), "a") == 0)
- {
- nsString tmp;
-
- rv = GatherTextUnder (node, tmp);
- if (NS_SUCCEEDED(rv))
- SetStringProperty ("linktext", tmp);
-
- nsCOMPtr <nsIDOMHTMLAnchorElement> anchor =
- do_QueryInterface(node);
-
- nsCString href;
- anchor->GetHref (tmp);
- NS_UTF16ToCString (tmp, NS_CSTRING_ENCODING_UTF8, href);
-
- if (g_str_has_prefix (href.get(), "mailto:"))
- {
- /* cut "mailto:" */
- href.Cut (0, 7);
-
- char *str = g_strdup (href.get());
- g_strdelimit (str, "?", '\0');
-
- nsCString unescapedHref;
- rv = Unescape (nsCString(str), unescapedHref);
- if (NS_SUCCEEDED (rv) && unescapedHref.Length())
- {
- SetStringProperty ("email", unescapedHref.get());
- info->context |= EPHY_EMBED_CONTEXT_EMAIL_LINK;
- }
- g_free (str);
- }
-
- if (anchor && tmp.Length())
- {
- info->context |= EPHY_EMBED_CONTEXT_LINK;
-
- SetURIProperty (node, "link", tmp);
- CheckLinkScheme (tmp);
- rv = anchor->GetHreflang (tmp);
- if (NS_SUCCEEDED(rv))
- SetStringProperty ("link_lang", tmp);
- rv = anchor->GetTarget (tmp);
- if (NS_SUCCEEDED(rv))
- SetStringProperty ("link_target", tmp);
- rv = anchor->GetRel (tmp);
- if (NS_SUCCEEDED(rv))
- SetStringProperty ("link_rel", tmp);
- rv = anchor->GetRev (tmp);
- if (NS_SUCCEEDED(rv))
- SetStringProperty ("link_rev", tmp);
- rv = element->GetTitle (tmp);
- if (NS_SUCCEEDED(rv))
- SetStringProperty ("link_title", tmp);
- rv = anchor->GetType (tmp);
- if (NS_SUCCEEDED(rv))
- SetStringProperty ("link_type", tmp);
-
- nsCString linkType;
- NS_UTF16ToCString (tmp, NS_CSTRING_ENCODING_UTF8, linkType);
-
- if (g_ascii_strcasecmp (linkType.get(), "text/smartbookmark") == 0)
- {
- SetIntProperty ("link_is_smart", TRUE);
-
- nsCOMPtr<nsIDOMNode> childNode;
- node->GetFirstChild (getter_AddRefs(childNode));
- if (childNode)
- {
- nsCOMPtr <nsIDOMHTMLImageElement> image =
- do_QueryInterface(childNode, &rv);
-
- if (image)
- {
- nsString img;
- rv = image->GetSrc (img);
- if (!NS_FAILED(rv))
- {
- SetStringProperty ("image", img);
- }
- }
- }
- }
- else
- {
- SetIntProperty ("link_is_smart", FALSE);
- }
- }
-
- }
- else if (g_ascii_strcasecmp (tag.get(), "option") == 0)
- {
- info->context = EPHY_EMBED_CONTEXT_NONE;
- return NS_OK;
- }
- else if (g_ascii_strcasecmp (tag.get(), "area") == 0)
- {
- info->context |= EPHY_EMBED_CONTEXT_LINK;
- nsCOMPtr <nsIDOMHTMLAreaElement> area =
- do_QueryInterface(node, &rv);
- if (NS_SUCCEEDED(rv) && area)
- {
- nsString href;
- rv = area->GetHref (href);
- if (NS_FAILED(rv))
- return NS_ERROR_FAILURE;
-
- SetURIProperty (node, "link", href);
- CheckLinkScheme (href);
- }
- }
- else if (g_ascii_strcasecmp (tag.get(), "input") == 0)
- {
- CheckInput (node);
- }
- else if (g_ascii_strcasecmp (tag.get(), "textarea") == 0)
- {
- info->context |= EPHY_EMBED_CONTEXT_INPUT;
- }
-
- if (!has_image)
- {
- nsString cssurl;
- rv = GetCSSBackground (node, cssurl);
- if (NS_SUCCEEDED (rv))
- {
- nsCString bgimg;
-
- rv = ResolveBaseURL (cssurl, bgimg);
- if (NS_FAILED (rv))
- return NS_ERROR_FAILURE;
- SetStringProperty ("image", bgimg.get());
- info->context |= EPHY_EMBED_CONTEXT_IMAGE;
- has_image = PR_TRUE;
- }
- }
- }
-
- nsCOMPtr<nsIDOMNode> parentNode;
- node->GetParentNode (getter_AddRefs(parentNode));
- node = parentNode;
- }
-
- return NS_OK;
-}
-
-nsresult EventContext::GetCSSBackground (nsIDOMNode *node, nsAString& url)
-{
- if (!mViewCSS) return NS_ERROR_NOT_INITIALIZED;
-
- nsresult rv;
-
- const PRUnichar bgimage[] = {'b', 'a', 'c', 'k', 'g', 'r', 'o', 'u', 'n', 'd',
- '-', 'i', 'm', 'a', 'g', 'e', '\0'};
-
- nsCOMPtr<nsIDOMElement> element = do_QueryInterface (node);
- NS_ENSURE_TRUE (element, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsIDOMCSSStyleDeclaration> decl;
- mViewCSS->GetComputedStyle (element, nsString(),
- getter_AddRefs (decl));
- NS_ENSURE_TRUE (decl, NS_ERROR_FAILURE);
-
- nsCOMPtr<nsIDOMCSSValue> CSSValue;
- decl->GetPropertyCSSValue (nsString(bgimage),
- getter_AddRefs (CSSValue));
-
- nsCOMPtr<nsIDOMCSSPrimitiveValue> primitiveValue =
- do_QueryInterface (CSSValue);
- if (!primitiveValue) return NS_ERROR_FAILURE;
-
- PRUint16 type;
- rv = primitiveValue->GetPrimitiveType (&type);
- NS_ENSURE_SUCCESS (rv, NS_ERROR_FAILURE);
-
- if (type != nsIDOMCSSPrimitiveValue::CSS_URI) return NS_ERROR_FAILURE;
-
- rv = primitiveValue->GetStringValue (url);
- NS_ENSURE_SUCCESS (rv, NS_ERROR_FAILURE);
-
- return NS_OK;
-}
-
-nsresult EventContext::GetTargetCoords (nsIDOMEventTarget *aTarget, PRInt32 *aX, PRInt32 *aY)
-{
- /* Calculate the node coordinates relative to the widget origin */
- nsCOMPtr<nsIDOMNSHTMLElement> elem (do_QueryInterface(aTarget));
-
- PRInt32 x = 0, y = 0;
- while (elem)
- {
- PRInt32 val;
- elem->GetOffsetTop(&val); y += val;
- elem->GetScrollTop(&val); y -= val;
- elem->GetOffsetLeft(&val); x += val;
- elem->GetScrollLeft(&val); x -= val;
-
- nsCOMPtr<nsIDOMElement> parent;
- elem->GetOffsetParent (getter_AddRefs (parent));
- elem = do_QueryInterface(parent);
- }
-
- *aX = x;
- *aY = y;
-
- return NS_OK;
-}
-
-nsresult EventContext::GetMouseEventInfo (nsIDOMMouseEvent *aMouseEvent, MozillaEmbedEvent *info)
-{
- /* FIXME: casting 32-bit guint* to PRUint16* below will break on big-endian */
- PRUint16 btn = 1729;
- aMouseEvent->GetButton (&btn);
-
- switch (btn)
- {
- /* mozilla's button counting is one-off from gtk+'s */
- case 0:
- info->button = 1;
- break;
- case 1:
- info->button = 2;
- break;
- case 2:
- info->button = 3;
- break;
-
- case (PRUint16) -1:
- /* when the user submits a form with Return, mozilla synthesises
- * a _mouse_ click event with btn=65535 (-1).
- */
- default:
- info->button = 0;
- break;
- }
-
- if (info->button != 0)
- {
- /* OTOH, casting only between (un)signedness is safe */
- aMouseEvent->GetScreenX ((PRInt32*)&info->x);
- aMouseEvent->GetScreenY ((PRInt32*)&info->y);
- }
- else /* this is really a keyboard event */
- {
- nsCOMPtr<nsIDOMEventTarget> eventTarget;
- aMouseEvent->GetTarget (getter_AddRefs (eventTarget));
-
- GetTargetCoords (eventTarget, (PRInt32*)&info->x, (PRInt32*)&info->y);
- }
-
- /* be sure we are not clicking on the scroolbars */
-
- nsCOMPtr<nsIDOMNSEvent> nsEvent = do_QueryInterface(aMouseEvent);
- if (!nsEvent) return NS_ERROR_FAILURE;
-
-#ifdef MOZ_NSIDOMNSEVENT_GETISTRUSTED
- /* make sure the event is trusted */
- PRBool isTrusted = PR_FALSE;
- nsEvent->GetIsTrusted (&isTrusted);
- if (!isTrusted) return NS_ERROR_UNEXPECTED;
-#endif /* MOZ_NSIDOMNSEVENT_GETISTRUSTED */
-
- nsresult rv;
- nsCOMPtr<nsIDOMEventTarget> OriginalTarget;
- rv = nsEvent->GetOriginalTarget(getter_AddRefs(OriginalTarget));
- if (NS_FAILED (rv) || !OriginalTarget) return NS_ERROR_FAILURE;
-
- nsCOMPtr<nsIDOMNode> OriginalNode = do_QueryInterface(OriginalTarget);
- if (!OriginalNode) return NS_ERROR_FAILURE;
-
- nsString nodename;
- OriginalNode->GetNodeName(nodename);
- nsCString cNodeName;
- NS_UTF16ToCString (nodename, NS_CSTRING_ENCODING_UTF8, cNodeName);
-
- if (g_ascii_strcasecmp (cNodeName.get(), "xul:scrollbarbutton") == 0 ||
- g_ascii_strcasecmp (cNodeName.get(), "xul:thumb") == 0 ||
- g_ascii_strcasecmp (cNodeName.get(), "xul:vbox") == 0 ||
- g_ascii_strcasecmp (cNodeName.get(), "xul:spacer") == 0 ||
- g_ascii_strcasecmp (cNodeName.get(), "xul:slider") == 0)
- return NS_ERROR_FAILURE;
-
- nsCOMPtr<nsIDOMEventTarget> EventTarget;
- rv = aMouseEvent->GetTarget(getter_AddRefs(EventTarget));
- if (NS_FAILED (rv) || !EventTarget) return NS_ERROR_FAILURE;
-
- rv = GetEventContext (EventTarget, info);
- if (NS_FAILED (rv)) return rv;
-
- /* Get the modifier */
-
- PRBool mod_key;
-
- info->modifier = 0;
-
- aMouseEvent->GetAltKey(&mod_key);
- if (mod_key) info->modifier |= GDK_MOD1_MASK;
-
- aMouseEvent->GetShiftKey(&mod_key);
- if (mod_key) info->modifier |= GDK_SHIFT_MASK;
-
- /* no need to check GetMetaKey, it's always PR_FALSE,
- * see widget/src/gtk2/nsWindow.cpp:InitMouseEvent
- */
-
- aMouseEvent->GetCtrlKey(&mod_key);
- if (mod_key) info->modifier |= GDK_CONTROL_MASK;
-
- return NS_OK;
-}
-
-nsresult EventContext::GetKeyEventInfo (nsIDOMKeyEvent *aKeyEvent, MozillaEmbedEvent *info)
-{
-#ifdef MOZ_NSIDOMNSEVENT_GETISTRUSTED
- /* make sure the event is trusted */
- nsCOMPtr<nsIDOMNSEvent> nsEvent (do_QueryInterface (aKeyEvent));
- NS_ENSURE_TRUE (nsEvent, NS_ERROR_FAILURE);
-
- PRBool isTrusted = PR_FALSE;
- nsEvent->GetIsTrusted (&isTrusted);
- if (!isTrusted) return NS_ERROR_UNEXPECTED;
-#endif /* MOZ_NSIDOMNSEVENT_GETISTRUSTED */
-
-
- info->button = 0;
-
- nsresult rv;
- PRUint32 keyCode;
- rv = aKeyEvent->GetKeyCode(&keyCode);
- if (NS_FAILED(rv)) return rv;
- info->keycode = keyCode;
-
- nsCOMPtr<nsIDOMEventTarget> target;
- rv = aKeyEvent->GetTarget(getter_AddRefs(target));
- if (NS_FAILED(rv) || !target) return NS_ERROR_FAILURE;
-
- GetTargetCoords (target, (PRInt32*)&info->x, (PRInt32*)&info->y);
-
- /* Context */
- rv = GetEventContext (target, info);
- if (NS_FAILED(rv)) return rv;
-
- /* Get the modifier */
-
- PRBool mod_key;
-
- info->modifier = 0;
-
- aKeyEvent->GetAltKey(&mod_key);
- if (mod_key) info->modifier |= GDK_MOD1_MASK;
-
- aKeyEvent->GetShiftKey(&mod_key);
- if (mod_key) info->modifier |= GDK_SHIFT_MASK;
-
- aKeyEvent->GetMetaKey(&mod_key);
- if (mod_key) info->modifier |= GDK_MOD2_MASK;
-
- aKeyEvent->GetCtrlKey(&mod_key);
- if (mod_key) info->modifier |= GDK_CONTROL_MASK;
-
- return NS_OK;
-}
-
-nsresult EventContext::IsPageFramed (nsIDOMNode *node, PRBool *Framed)
-{
- nsresult rv;
-
- nsCOMPtr<nsIDOMDocument> mainDocument;
- rv = mBrowser->GetDocument (getter_AddRefs(mainDocument));
- if (NS_FAILED (rv) || !mainDocument) return NS_ERROR_FAILURE;
-
- nsCOMPtr<nsIDOMDocument> nodeDocument;
- rv = node->GetOwnerDocument (getter_AddRefs(nodeDocument));
- if (NS_FAILED (rv) || !nodeDocument) return NS_ERROR_FAILURE;
-
- *Framed = (mainDocument != nodeDocument);
-
- return NS_OK;
-}
-
-nsresult EventContext::GetTargetDocument (nsIDOMDocument **domDoc)
-{
- if (!mDOMDocument) return NS_ERROR_FAILURE;
-
- *domDoc = mDOMDocument.get();
-
- NS_IF_ADDREF(*domDoc);
-
- return NS_OK;
-}
-
-nsresult EventContext::CheckInput (nsIDOMNode *aNode)
-{
- const PRUnichar typeLiteral[] = { 't', 'y', 'p', 'e', '\0' };
-
- nsCOMPtr<nsIDOMElement> element;
- element = do_QueryInterface (aNode);
- if (!element) return NS_ERROR_FAILURE;
-
- nsString uValue;
- element->GetAttribute (nsString(typeLiteral), uValue);
-
- nsCString value;
- NS_UTF16ToCString (uValue, NS_CSTRING_ENCODING_UTF8, value);
-
- if (g_ascii_strcasecmp (value.get(), "image") == 0)
- {
- mEmbedEvent->context |= EPHY_EMBED_CONTEXT_IMAGE;
- nsCOMPtr<nsIDOMHTMLInputElement> input;
- input = do_QueryInterface (aNode);
- if (!input) return NS_ERROR_FAILURE;
-
- nsresult rv;
- nsString img;
- rv = input->GetSrc (img);
- if (NS_FAILED(rv)) return NS_ERROR_FAILURE;
-
- nsCString cImg;
- rv = ResolveBaseURL (img, cImg);
- if (NS_FAILED(rv)) return NS_ERROR_FAILURE;
- SetStringProperty ("image", cImg.get());
- }
- else if (g_ascii_strcasecmp (value.get(), "radio") != 0 &&
- g_ascii_strcasecmp (value.get(), "submit") != 0 &&
- g_ascii_strcasecmp (value.get(), "reset") != 0 &&
- g_ascii_strcasecmp (value.get(), "hidden") != 0 &&
- g_ascii_strcasecmp (value.get(), "button") != 0 &&
- g_ascii_strcasecmp (value.get(), "checkbox") != 0)
- {
- mEmbedEvent->context |= EPHY_EMBED_CONTEXT_INPUT;
-
- if (g_ascii_strcasecmp (value.get(), "password") == 0)
- {
- mEmbedEvent->context |= EPHY_EMBED_CONTEXT_INPUT_PASSWORD;
- }
- }
-
- return NS_OK;
-}
-
-nsresult EventContext::CheckLinkScheme (const nsAString &link)
-{
- nsCOMPtr<nsIURI> uri;
- EphyUtils::NewURI (getter_AddRefs (uri), link);
- if (!uri) return NS_ERROR_FAILURE;
-
- nsresult rv;
- nsCString scheme;
- rv = uri->GetScheme (scheme);
- if (NS_FAILED (rv)) return NS_ERROR_FAILURE;
-
- if (g_ascii_strcasecmp (scheme.get(), "http") == 0 ||
- g_ascii_strcasecmp (scheme.get(), "https") == 0 ||
- g_ascii_strcasecmp (scheme.get(), "ftp") == 0 ||
- g_ascii_strcasecmp (scheme.get(), "file") == 0 ||
- g_ascii_strcasecmp (scheme.get(), "smb") == 0 ||
- g_ascii_strcasecmp (scheme.get(), "sftp") == 0 ||
- g_ascii_strcasecmp (scheme.get(), "ssh") == 0 ||
- g_ascii_strcasecmp (scheme.get(), "data") == 0 ||
- g_ascii_strcasecmp (scheme.get(), "resource") == 0 ||
- g_ascii_strcasecmp (scheme.get(), "about") == 0 ||
- g_ascii_strcasecmp (scheme.get(), "gopher") == 0)
- {
- SetIntProperty ("link-has-web-scheme", TRUE);
- }
-
- return NS_OK;
-}
-
-nsresult EventContext::SetIntProperty (const char *name, int value)
-{
-
- GValue *val = g_new0 (GValue, 1);
-
- g_value_init (val, G_TYPE_INT);
-
- g_value_set_int (val, value);
-
- mozilla_embed_event_set_property (mEmbedEvent, name, val);
-
- return NS_OK;
-}
-
-nsresult EventContext::SetStringProperty (const char *name, const char *value)
-{
- GValue *val = g_new0 (GValue, 1);
-
- g_value_init (val, G_TYPE_STRING);
-
- g_value_set_string (val, value);
-
- mozilla_embed_event_set_property (mEmbedEvent, name, val);
-
- return NS_OK;
-}
-
-nsresult EventContext::SetStringProperty (const char *name, const nsAString &value)
-{
- nsCString cValue;
- NS_UTF16ToCString (value, NS_CSTRING_ENCODING_UTF8, cValue);
- return SetStringProperty (name, cValue.get());
-}
-
-nsresult EventContext::SetURIProperty (nsIDOMNode *node, const char *name, const nsACString &value)
-{
- nsresult rv;
- nsCOMPtr<nsIURI> uri;
- rv = EphyUtils::NewURI (getter_AddRefs (uri), value, mCharset.Length () ? mCharset.get() : nsnull, mBaseURI);
- if (NS_SUCCEEDED (rv) && uri)
- {
- /* Hide password part */
- nsCString user;
- uri->GetUsername (user);
- uri->SetUserPass (user);
-
- nsCString spec;
- uri->GetSpec (spec);
- rv = SetStringProperty (name, spec.get());
- }
- else
- {
- rv = SetStringProperty (name, nsCString(value).get());
- }
-
- return rv;
-}
-
-nsresult EventContext::SetURIProperty (nsIDOMNode *node, const char *name, const nsAString &value)
-{
- nsCString cValue;
- NS_UTF16ToCString (value, NS_CSTRING_ENCODING_UTF8, cValue);
- return SetURIProperty (node, name, cValue);
-}
-
-/* static */
-PRBool
-EventContext::CheckKeyPress (nsIDOMKeyEvent *aEvent)
-{
- PRBool retval = PR_FALSE;
-
- /* make sure the event is trusted */
- nsCOMPtr<nsIDOMNSEvent> nsEvent (do_QueryInterface (aEvent));
- NS_ENSURE_TRUE (nsEvent, retval);
- PRBool isTrusted = PR_FALSE;
- nsEvent->GetIsTrusted (&isTrusted);
- if (!isTrusted) return retval;
-
- /* check for alt/ctrl */
- PRBool isCtrl = PR_FALSE, isAlt = PR_FALSE;
- aEvent->GetCtrlKey (&isCtrl);
- aEvent->GetAltKey (&isAlt);
- if (isCtrl || isAlt) return retval;
-
- nsCOMPtr<nsIDOMNSUIEvent> uiEvent (do_QueryInterface (aEvent));
- NS_ENSURE_TRUE (uiEvent, retval);
-
- /* check for already handled event */
- PRBool isPrevented = PR_FALSE;
- uiEvent->GetPreventDefault (&isPrevented);
- if (isPrevented) return retval;
-
- /* check for form controls */
- nsresult rv;
- nsCOMPtr<nsIDOMEventTarget> target;
- rv = aEvent->GetTarget (getter_AddRefs (target));
- NS_ENSURE_SUCCESS (rv, retval);
-
- nsCOMPtr<nsIDOMHTMLInputElement> inputElement (do_QueryInterface (target));
- if (inputElement)
- {
- nsString type;
- inputElement->GetType (type);
-
- nsCString (cType);
- NS_UTF16ToCString (type, NS_CSTRING_ENCODING_UTF8, cType);
-
- if (g_ascii_strcasecmp (cType.get(), "text") == 0 ||
- g_ascii_strcasecmp (cType.get(), "password") == 0 ||
- g_ascii_strcasecmp (cType.get(), "file") == 0) return retval;
- }
-
- nsCOMPtr<nsIDOMHTMLTextAreaElement> textArea;
- nsCOMPtr<nsIDOMHTMLSelectElement> selectElement;
- nsCOMPtr<nsIDOMHTMLIsIndexElement> indexElement;
- nsCOMPtr<nsIDOMHTMLObjectElement> objectElement;
- nsCOMPtr<nsIDOMHTMLEmbedElement> embedElement;
-
- if ((textArea = do_QueryInterface (target)) ||
- (selectElement = do_QueryInterface (target)) ||
- (indexElement = do_QueryInterface (target)) ||
- (objectElement = do_QueryInterface (target)) ||
- (embedElement = do_QueryInterface (target))) return retval;
-
- /* check for design mode */
- nsCOMPtr<nsIDOMNode> node (do_QueryInterface (target, &rv));
- NS_ENSURE_SUCCESS (rv, PR_FALSE);
-
- nsCOMPtr<nsIDOMDocument> doc;
- rv = node->GetOwnerDocument (getter_AddRefs (doc));
- NS_ENSURE_SUCCESS (rv, retval);
-
- nsCOMPtr<nsIDOMXULDocument> xul_document (do_QueryInterface(doc, &rv));
- if (xul_document) return retval;
-
- nsCOMPtr<nsIDOMNSHTMLDocument> htmlDoc (do_QueryInterface (doc));
- if (htmlDoc)
- {
- nsString uDesign;
- rv = htmlDoc->GetDesignMode (uDesign);
- NS_ENSURE_SUCCESS (rv, retval);
-
- nsCString design;
- NS_UTF16ToCString (uDesign, NS_CSTRING_ENCODING_UTF8, design);
-
- retval = g_ascii_strcasecmp (design.get(), "on") != 0;
- }
- else
- {
- retval = PR_TRUE;
- }
-
- return retval;
-}
diff --git a/embed/xulrunner/embed/EventContext.h b/embed/xulrunner/embed/EventContext.h
deleted file mode 100644
index ddffcf1fc..000000000
--- a/embed/xulrunner/embed/EventContext.h
+++ /dev/null
@@ -1,78 +0,0 @@
-/*
- * Copyright © 2000-2004 Marco Pesenti Gritti
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#ifndef EVENT_CONTEXT_H
-#define EVENT_CONTEXT_H
-
-#include "ephy-embed.h"
-#include "mozilla-embed-event.h"
-
-class EphyBrowser;
-class nsIDOMDocument;
-class nsIDOMEvent;
-class nsIDOMEventTarget;
-class nsIDOMHTMLAnchorElement;
-class nsIDOMHTMLAreaElement;
-class nsIDOMHTMLBodyElement;
-class nsIDOMKeyEvent;
-class nsIDOMMouseEvent;
-class nsIDOMNode;
-class nsIDOMViewCSS;
-class nsIURI;
-
-class EventContext
-{
-public:
- EventContext();
- ~EventContext();
-
- nsresult Init (EphyBrowser *wrapper);
- nsresult GetMouseEventInfo (nsIDOMMouseEvent *event, MozillaEmbedEvent *info);
- nsresult GetKeyEventInfo (nsIDOMKeyEvent *event, MozillaEmbedEvent *info);
- nsresult GetTargetDocument (nsIDOMDocument **domDoc);
-
- static PRBool CheckKeyPress (nsIDOMKeyEvent *aEvent);
-
-private:
- EphyBrowser *mBrowser;
- MozillaEmbedEvent *mEmbedEvent;
- nsCOMPtr<nsIDOMDocument> mDOMDocument;
- nsCOMPtr<nsIDOMViewCSS> mViewCSS;
- nsCOMPtr<nsIURI> mBaseURI;
- nsCString mCharset;
-
- nsresult GetTargetCoords (nsIDOMEventTarget *aTarget, PRInt32 *aX, PRInt32 *aY);
- nsresult GatherTextUnder (nsIDOMNode* aNode, nsAString& aResult);
- nsresult ResolveBaseURL (const nsAString &relurl, nsACString &url);
- nsresult Unescape (const nsACString &aEscaped, nsACString &aUnescaped);
- nsresult GetEventContext (nsIDOMEventTarget *EventTarget,
- MozillaEmbedEvent *info);
- nsresult GetCSSBackground (nsIDOMNode *node, nsAString& url);
- nsresult IsPageFramed (nsIDOMNode *node, PRBool *Framed);
- nsresult CheckInput (nsIDOMNode *node);
- nsresult CheckLinkScheme (const nsAString &link);
- nsresult SetIntProperty (const char *name, int value);
- nsresult SetStringProperty (const char *name, const char *value);
- nsresult SetStringProperty (const char *name, const nsAString &value);
- nsresult SetURIProperty (nsIDOMNode *node, const char *name, const nsAString &value);
- nsresult SetURIProperty (nsIDOMNode *node, const char *name, const nsACString &value);
-};
-
-#endif
diff --git a/embed/xulrunner/embed/Makefile.am b/embed/xulrunner/embed/Makefile.am
deleted file mode 100644
index 124054a0a..000000000
--- a/embed/xulrunner/embed/Makefile.am
+++ /dev/null
@@ -1,57 +0,0 @@
-noinst_LTLIBRARIES = libephyxulrunnerembed.la
-
-libephyxulrunnerembed_la_SOURCES = \
- EphyDirectoryProvider.cpp \
- EphyDirectoryProvider.h \
- EphyHeaderSniffer.cpp \
- EphyHeaderSniffer.h \
- EphyBrowser.cpp \
- EphyBrowser.h \
- EphyFind.cpp \
- EphyFind.h \
- EphySingle.cpp \
- EphySingle.h \
- EventContext.cpp \
- EventContext.h \
- mozilla-download.cpp \
- mozilla-download.h \
- mozilla-embed.cpp \
- mozilla-embed.h \
- mozilla-embed-event.cpp \
- mozilla-embed-event.h \
- mozilla-embed-find.cpp \
- mozilla-embed-find.h \
- mozilla-embed-persist.cpp \
- mozilla-embed-persist.h \
- mozilla-embed-single.cpp \
- mozilla-embed-single.h \
- mozilla-notifiers.cpp \
- mozilla-notifiers.h
-
-libephyxulrunnerembed_la_CPPFLAGS = \
- -I$(top_srcdir)/lib \
- -I$(top_srcdir)/embed \
- -I$(top_srcdir)/embed/xulrunner/src \
- -I$(top_srcdir)/embed/xulrunner/utils \
- -I$(top_srcdir)/embed/xulrunner/components \
- -I$(top_builddir)/embed/xulrunner/src \
- -DSHARE_DIR=\"$(pkgdatadir)\" \
- -DPLUGINDIR=\"$(libdir)/epiphany/$(EPIPHANY_MAJOR)/plugins\" \
- -DMOZILLA_HOME=\"$(LIBXUL_LIBDIR)\" \
- -DMOZILLA_PREFIX=\"$(LIBXUL_PREFIX)\" \
- -DMOZILLA_NATIVE_PLUGINSDIR=\"$(libdir)/mozilla/plugins\" \
- -DUA_VERSION=\"$(EPIPHANY_UA_VERSION)\" \
- -DALLOW_PRIVATE_API \
- -DLIBXUL_LIBDIR="\"$(LIBXUL_LIBDIR)\"" \
- $(LIBXUL_CXXCPPFLAGS) \
- $(LIBXUL_INCLUDES) \
- $(AM_CPPFLAGS)
-
-libephyxulrunnerembed_la_CXXFLAGS = \
- $(LIBXUL_CXXFLAGS) \
- $(DEPENDENCIES_CFLAGS) \
- $(AM_CXXFLAGS)
-
-libephyxulrunnerembed_la_LIBADD = \
- $(top_builddir)/embed/xulrunner/utils/libephyxulrunnerutils.la \
- $(top_builddir)/embed/xulrunner/src/libgnomegeckoembed.la
diff --git a/embed/xulrunner/embed/mozilla-download.cpp b/embed/xulrunner/embed/mozilla-download.cpp
deleted file mode 100644
index 063093402..000000000
--- a/embed/xulrunner/embed/mozilla-download.cpp
+++ /dev/null
@@ -1,313 +0,0 @@
-/*
- * Copyright © 2003 Xan Lopez
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include <nsStringGlue.h>
-
-#include <nsILocalFile.h>
-#include <nsIMIMEInfo.h>
-#include <nsIURI.h>
-#include <nsMemory.h>
-
-#include "ephy-debug.h"
-
-#include "MozDownload.h"
-
-#include "mozilla-download.h"
-
-static void mozilla_download_class_init (MozillaDownloadClass *klass);
-static void mozilla_download_init (MozillaDownload *ges);
-static void mozilla_download_finalize (GObject *object);
-
-enum
-{
- PROP_0,
- PROP_MOZDOWNLOAD
-};
-
-struct _MozillaDownloadPrivate
-{
- MozDownload *moz_download;
-};
-
-#define MOZILLA_DOWNLOAD_GET_PRIVATE(object)(G_TYPE_INSTANCE_GET_PRIVATE ((object), MOZILLA_TYPE_DOWNLOAD, MozillaDownloadPrivate))
-
-static GObjectClass *parent_class = NULL;
-
-GType
-mozilla_download_get_type (void)
-{
- static GType type = 0;
-
- if (G_UNLIKELY (type == 0))
- {
- const GTypeInfo our_info =
- {
- sizeof (MozillaDownloadClass),
- NULL, /* base_init */
- NULL, /* base_finalize */
- (GClassInitFunc) mozilla_download_class_init,
- NULL, /* class_finalize */
- NULL, /* class_data */
- sizeof (MozillaDownload),
- 0, /* n_preallocs */
- (GInstanceInitFunc) mozilla_download_init
- };
-
- type = g_type_register_static (EPHY_TYPE_DOWNLOAD,
- "MozillaDownload",
- &our_info, (GTypeFlags)0);
- }
-
- return type;
-}
-
-static char *
-impl_get_target (EphyDownload *download)
-{
- nsCOMPtr<nsILocalFile> targetFile;
- MozDownload *mozDownload;
-
- mozDownload = MOZILLA_DOWNLOAD (download)->priv->moz_download;
-
- mozDownload->GetTargetFile (getter_AddRefs (targetFile));
-
- nsCString tempPathStr;
- targetFile->GetNativePath (tempPathStr);
-
- return g_strdup (tempPathStr.get ());
-}
-
-static char *
-impl_get_source (EphyDownload *download)
-{
- nsCOMPtr<nsIURI> uri;
- MozDownload *mozDownload;
- nsCString spec;
-
- mozDownload = MOZILLA_DOWNLOAD (download)->priv->moz_download;
-
- mozDownload->GetSource (getter_AddRefs (uri));
- uri->GetSpec (spec);
-
- return g_strdup (spec.get());
-}
-
-static gint64
-impl_get_current_progress (EphyDownload *download)
-{
- MozDownload *mozDownload;
- PRInt64 progress;
-
- mozDownload = MOZILLA_DOWNLOAD (download)->priv->moz_download;
-
- mozDownload->GetCurrentProgress (&progress);
-
- return progress;
-}
-
-static EphyDownloadState
-impl_get_state (EphyDownload *download)
-{
- MozDownload *mozDownload;
- EphyDownloadState state;
-
- mozDownload = MOZILLA_DOWNLOAD (download)->priv->moz_download;
-
- mozDownload->GetState (&state);
-
- return state;
-}
-
-static gint64
-impl_get_total_progress (EphyDownload *download)
-{
- MozDownload *mozDownload;
- PRInt64 progress;
-
- mozDownload = MOZILLA_DOWNLOAD (download)->priv->moz_download;
-
- mozDownload->GetTotalProgress (&progress);
-
- return progress;
-}
-
-static int
-impl_get_percent (EphyDownload *download)
-{
- MozDownload *mozDownload;
- PRInt32 percent;
-
- mozDownload = MOZILLA_DOWNLOAD (download)->priv->moz_download;
-
- mozDownload->GetPercentComplete (&percent);
-
- return percent;
-}
-
-static gint64
-impl_get_elapsed_time (EphyDownload *download)
-{
- MozDownload *mozDownload;
- PRInt64 elapsed;
-
- mozDownload = MOZILLA_DOWNLOAD (download)->priv->moz_download;
-
- mozDownload->GetElapsedTime (&elapsed);
-
- return elapsed / 1000000;
-}
-
-static char*
-impl_get_mime (EphyDownload *download)
-{
- MozDownload *mozDownload;
- nsCOMPtr<nsIMIMEInfo> mime;
- nsCString mimeType;
-
- mozDownload = MOZILLA_DOWNLOAD (download)->priv->moz_download;
-
- mozDownload->GetMIMEInfo (getter_AddRefs(mime));
- if (!mime) return g_strdup ("application/octet-stream");
-
- mime->GetMIMEType(mimeType);
-
- return g_strdup (mimeType.get());
-}
-
-static void
-impl_cancel (EphyDownload *download)
-{
- MOZILLA_DOWNLOAD (download)->priv->moz_download->Cancel ();
-}
-
-static void
-impl_pause (EphyDownload *download)
-{
- MOZILLA_DOWNLOAD (download)->priv->moz_download->Pause ();
-}
-
-static void
-impl_resume (EphyDownload *download)
-{
- MOZILLA_DOWNLOAD (download)->priv->moz_download->Resume ();
-}
-
-static void
-mozilla_download_finalize (GObject *object)
-{
- MozillaDownload *download = MOZILLA_DOWNLOAD (object);
-
- NS_RELEASE (download->priv->moz_download);
-
- LOG ("MozillaDownload %p finalised", object);
-
- G_OBJECT_CLASS (parent_class)->finalize (object);
-}
-
-static void
-mozilla_download_set_property (GObject *object,
- guint prop_id,
- const GValue *value,
- GParamSpec *pspec)
-{
- MozillaDownload *download = MOZILLA_DOWNLOAD (object);
-
- switch (prop_id)
- {
- case PROP_MOZDOWNLOAD:
- MozDownload *moz_download;
-
- moz_download = (MozDownload *)g_value_get_pointer (value);
- NS_ADDREF (moz_download);
- download->priv->moz_download = moz_download;
- break;
- }
-}
-
-static void
-mozilla_download_get_property (GObject *object,
- guint prop_id,
- GValue *value,
- GParamSpec *pspec)
-{
- MozillaDownload *download = MOZILLA_DOWNLOAD (object);
-
- switch (prop_id)
- {
- case PROP_MOZDOWNLOAD:
- g_value_set_pointer (value, download->priv->moz_download);
- break;
- }
-}
-
-static void
-mozilla_download_class_init (MozillaDownloadClass *klass)
-{
- GObjectClass *object_class = G_OBJECT_CLASS (klass);
- EphyDownloadClass *download_class = EPHY_DOWNLOAD_CLASS (klass);
-
- parent_class = (GObjectClass *) g_type_class_peek_parent (klass);
-
- object_class->finalize = mozilla_download_finalize;
- object_class->set_property = mozilla_download_set_property;
- object_class->get_property = mozilla_download_get_property;
-
- download_class->get_elapsed_time = impl_get_elapsed_time;
- download_class->get_current_progress = impl_get_current_progress;
- download_class->get_total_progress = impl_get_total_progress;
- download_class->get_percent = impl_get_percent;
- download_class->get_target = impl_get_target;
- download_class->get_source = impl_get_source;
- download_class->get_state = impl_get_state;
- download_class->get_mime = impl_get_mime;
- download_class->cancel = impl_cancel;
- download_class->pause = impl_pause;
- download_class->resume = impl_resume;
-
- g_type_class_add_private (klass, sizeof (MozillaDownloadPrivate));
-
- g_object_class_install_property (object_class,
- PROP_MOZDOWNLOAD,
- g_param_spec_pointer ("mozilla-download",
- "Mozilla Download",
- "Mozilla Download",
- (GParamFlags)
- (G_PARAM_READWRITE | G_PARAM_STATIC_NAME | G_PARAM_STATIC_NICK | G_PARAM_STATIC_BLURB |
- G_PARAM_CONSTRUCT_ONLY)));
-}
-
-static void
-mozilla_download_init (MozillaDownload *download)
-{
- LOG ("MozillaDownload %p initialising", download);
-
- download->priv = MOZILLA_DOWNLOAD_GET_PRIVATE (download);
-}
-
-EphyDownload *
-mozilla_download_new (MozDownload *download)
-{
- return EPHY_DOWNLOAD (g_object_new (MOZILLA_TYPE_DOWNLOAD,
- "mozilla-download", download,
- NULL));
-}
diff --git a/embed/xulrunner/embed/mozilla-download.h b/embed/xulrunner/embed/mozilla-download.h
deleted file mode 100644
index 071ec31af..000000000
--- a/embed/xulrunner/embed/mozilla-download.h
+++ /dev/null
@@ -1,61 +0,0 @@
-/*
- * Copyright © 2000, 2001, 2002 Marco Pesenti Gritti
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#ifndef MOZILLA_DOWNLOAD_H
-#define MOZILLA_DOWNLOAD_H
-
-#include <glib.h>
-#include <glib-object.h>
-
-#include "ephy-download.h"
-
-G_BEGIN_DECLS
-
-#define MOZILLA_TYPE_DOWNLOAD (mozilla_download_get_type ())
-#define MOZILLA_DOWNLOAD(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), MOZILLA_TYPE_DOWNLOAD, MozillaDownload))
-#define MOZILLA_DOWNLOAD_CLASS(k) (G_TYPE_CHECK_CLASS_CAST((k), MOZILLA_TYPE_DOWNLOAD, MozillaDownloadClass))
-#define MOZILLA_IS_DOWNLOAD(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), MOZILLA_TYPE_DOWNLOAD))
-#define MOZILLA_IS_DOWNLOAD_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE ((k), MOZILLA_TYPE_DOWNLOAD))
-#define MOZILLA_DOWNLOAD_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS ((o), MOZILLA_TYPE_DOWNLOAD, MozillaDownloadClass))
-
-typedef struct _MozillaDownloadClass MozillaDownloadClass;
-typedef struct _MozillaDownload MozillaDownload;
-typedef struct _MozillaDownloadPrivate MozillaDownloadPrivate;
-
-class MozDownload;
-
-struct _MozillaDownload
-{
- EphyDownload parent;
- MozillaDownloadPrivate *priv;
-};
-
-struct _MozillaDownloadClass
-{
- EphyDownloadClass parent_class;
-};
-
-GType mozilla_download_get_type (void);
-
-EphyDownload *mozilla_download_new (MozDownload *download);
-
-G_END_DECLS
-
-#endif
diff --git a/embed/xulrunner/embed/mozilla-embed-event.cpp b/embed/xulrunner/embed/mozilla-embed-event.cpp
deleted file mode 100644
index 53b57886f..000000000
--- a/embed/xulrunner/embed/mozilla-embed-event.cpp
+++ /dev/null
@@ -1,221 +0,0 @@
-/*
- * Copyright © 2000-2003 Marco Pesenti Gritti
- * Copyright © 2004 Christian Persch
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include <glib/ghash.h>
-
-#include <nsCOMPtr.h>
-#include <nsIDOMEvent.h>
-
-#include "ephy-debug.h"
-
-#include "mozilla-embed-event.h"
-
-#define MOZILLA_EMBED_EVENT_GET_PRIVATE(object)(G_TYPE_INSTANCE_GET_PRIVATE ((object), MOZILLA_TYPE_EMBED_EVENT, MozillaEmbedEventPrivate))
-
-struct _MozillaEmbedEventPrivate
-{
- nsIDOMEvent* dom_event;
- GHashTable *props;
-};
-
-static void mozilla_embed_event_class_init (MozillaEmbedEventClass *klass);
-static void mozilla_embed_event_init (MozillaEmbedEvent *event);
-static void ephy_embed_event_iface_init (EphyEmbedEventIface *iface);
-
-static GObjectClass *parent_class = NULL;
-
-GType
-mozilla_embed_event_get_type (void)
-{
- static GType type = 0;
-
- if (G_UNLIKELY (type == 0))
- {
- const GTypeInfo our_info =
- {
- sizeof (MozillaEmbedEventClass),
- NULL, /* base_init */
- NULL, /* base_finalize */
- (GClassInitFunc) mozilla_embed_event_class_init,
- NULL, /* class_finalize */
- NULL, /* class_data */
- sizeof (MozillaEmbedEvent),
- 0, /* n_preallocs */
- (GInstanceInitFunc) mozilla_embed_event_init
- };
-
- const GInterfaceInfo embed_event_info =
- {
- (GInterfaceInitFunc) ephy_embed_event_iface_init,
- NULL,
- NULL
- };
-
- type = g_type_register_static (G_TYPE_OBJECT,
- "MozillaEmbedEvent",
- &our_info, (GTypeFlags) 0);
-
- g_type_add_interface_static (type,
- EPHY_TYPE_EMBED_EVENT,
- &embed_event_info);
- }
-
- return type;
-}
-
-MozillaEmbedEvent *
-mozilla_embed_event_new (gpointer dom_event)
-{
- MozillaEmbedEvent *event;
-
- event = MOZILLA_EMBED_EVENT (g_object_new (MOZILLA_TYPE_EMBED_EVENT, NULL));
-
- event->priv->dom_event = static_cast<nsIDOMEvent*>(dom_event);
- NS_IF_ADDREF (event->priv->dom_event);
-
- return event;
-}
-
-void
-mozilla_embed_event_set_property (MozillaEmbedEvent *event,
- const char *name,
- GValue *value)
-{
- char *value_content = g_strdup_value_contents (value);
- LOG ("embed event %p set property \"%s\" to %s", event, name, value_content);
- g_free (value_content);
-
- g_hash_table_insert (event->priv->props,
- g_strdup (name),
- value);
-}
-
-static EphyEmbedEventContext
-impl_get_context (EphyEmbedEvent *event)
-{
- return (EphyEmbedEventContext) ((MozillaEmbedEvent *) event)->context;
-}
-
-static guint
-impl_get_button (EphyEmbedEvent *event)
-{
- return ((MozillaEmbedEvent *) event)->button;
-}
-
-static guint
-impl_get_modifier (EphyEmbedEvent *event)
-{
- return ((MozillaEmbedEvent *) event)->modifier;
-}
-
-static void
-impl_get_coordinates (EphyEmbedEvent *event,
- guint *x,
- guint *y)
-{
- *x = ((MozillaEmbedEvent *) event)->x;
- *y = ((MozillaEmbedEvent *) event)->y;
-}
-
-static const GValue*
-impl_get_property (EphyEmbedEvent *event,
- const char *name)
-{
- return (const GValue *) g_hash_table_lookup (((MozillaEmbedEvent *) event)->priv->props, name);
-}
-
-static gboolean
-impl_has_property (EphyEmbedEvent *event,
- const char *name)
-{
- gpointer tmp;
-
- tmp = g_hash_table_lookup (((MozillaEmbedEvent *) event)->priv->props, name);
-
- return tmp != NULL;
-}
-
-static gpointer
-impl_get_dom_event (EphyEmbedEvent *event)
-{
- return static_cast<gpointer>(((MozillaEmbedEvent *) event)->priv->dom_event);
-}
-
-static void
-free_g_value (gpointer value)
-{
- g_value_unset ((GValue *) value);
- g_free (value);
-}
-
-static void
-mozilla_embed_event_init (MozillaEmbedEvent *event)
-{
- event->priv = MOZILLA_EMBED_EVENT_GET_PRIVATE (event);
-
- LOG ("MozillaEmbedEvent %p initialising", event);
-
- event->priv->dom_event = nsnull;
- event->priv->props = g_hash_table_new_full (g_str_hash, g_str_equal,
- g_free, free_g_value);
-}
-
-static void
-mozilla_embed_event_finalize (GObject *object)
-{
- MozillaEmbedEvent *event = MOZILLA_EMBED_EVENT (object);
-
- g_hash_table_destroy (event->priv->props);
-
- NS_IF_RELEASE (event->priv->dom_event);
- event->priv->dom_event = nsnull;
-
- LOG ("MozillaEmbedEvent %p finalised", object);
-
- G_OBJECT_CLASS (parent_class)->finalize (object);
-}
-
-static void
-ephy_embed_event_iface_init (EphyEmbedEventIface *iface)
-{
- iface->get_context = impl_get_context;
- iface->get_button = impl_get_button;
- iface->get_modifier = impl_get_modifier;
- iface->get_coordinates = impl_get_coordinates;
- iface->get_property = impl_get_property;
- iface->has_property = impl_has_property;
- iface->get_dom_event = impl_get_dom_event;
-}
-
-static void
-mozilla_embed_event_class_init (MozillaEmbedEventClass *klass)
-{
- GObjectClass *object_class = G_OBJECT_CLASS (klass);
-
- parent_class = (GObjectClass *) g_type_class_peek_parent (klass);
-
- object_class->finalize = mozilla_embed_event_finalize;
-
- g_type_class_add_private (object_class, sizeof (MozillaEmbedEventPrivate));
-}
diff --git a/embed/xulrunner/embed/mozilla-embed-event.h b/embed/xulrunner/embed/mozilla-embed-event.h
deleted file mode 100644
index 4306bef67..000000000
--- a/embed/xulrunner/embed/mozilla-embed-event.h
+++ /dev/null
@@ -1,74 +0,0 @@
-/*
- * Copyright © 2000-2003 Marco Pesenti Gritti
- * Copyright © 2004 Christian Persch
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#ifndef MOZILLA_EMBED_EVENT_H
-#define MOZILLA_EMBED_EVENT_H
-
-#include <glib.h>
-#include <glib-object.h>
-
-#include "ephy-embed-event.h"
-
-G_BEGIN_DECLS
-
-#define MOZILLA_TYPE_EMBED_EVENT (mozilla_embed_event_get_type ())
-#define MOZILLA_EMBED_EVENT(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), MOZILLA_TYPE_EMBED_EVENT, MozillaEmbedEvent))
-#define MOZILLA_EMBED_EVENT_CLASS(k) (G_TYPE_CHECK_CLASS_CAST((k), MOZILLA_TYPE_EMBED_EVENT, MozillaEmbedEventClass))
-#define MOZILLA_IS_EMBED_EVENT(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), MOZILLA_TYPE_EMBED_EVENT))
-#define MOZILLA_IS_EMBED_EVENT_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE ((k), MOZILLA_TYPE_EMBED_EVENT))
-#define MOZILLA_EMBED_EVENT_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS ((o), MOZILLA_TYPE_EMBED_EVENT, MozillaEmbedEventClass))
-
-typedef struct _MozillaEmbedEventClass MozillaEmbedEventClass;
-typedef struct _MozillaEmbedEvent MozillaEmbedEvent;
-typedef struct _MozillaEmbedEventPrivate MozillaEmbedEventPrivate;
-
-struct _MozillaEmbedEventClass
-{
- GObjectClass parent_class;
-};
-
-struct _MozillaEmbedEvent
-{
- GObject parent;
-
- /*< private >*/
- MozillaEmbedEventPrivate *priv;
-
- /*< private >*/ /* public to the embed implementation */
- guint button;
- guint context;
- guint modifier;
- guint x;
- guint y;
- guint keycode;
-};
-
-GType mozilla_embed_event_get_type (void);
-
-MozillaEmbedEvent *mozilla_embed_event_new (gpointer dom_event);
-
-void mozilla_embed_event_set_property (MozillaEmbedEvent *event,
- const char *name,
- GValue *value);
-
-G_END_DECLS
-
-#endif
diff --git a/embed/xulrunner/embed/mozilla-embed-find.cpp b/embed/xulrunner/embed/mozilla-embed-find.cpp
deleted file mode 100644
index 6b2d60676..000000000
--- a/embed/xulrunner/embed/mozilla-embed-find.cpp
+++ /dev/null
@@ -1,198 +0,0 @@
-/*
- * Copyright © 2000-2004 Marco Pesenti Gritti
- * Copyright © 2003, 2004 Christian Persch
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include "ephy-debug.h"
-#include "ephy-embed-find.h"
-#include "ephy-embed-shell.h"
-
-#include "EphyFind.h"
-
-#include "mozilla-embed-find.h"
-
-#define MOZILLA_EMBED_FIND_GET_PRIVATE(object)(G_TYPE_INSTANCE_GET_PRIVATE ((object), MOZILLA_TYPE_EMBED_FIND, MozillaEmbedFindPrivate))
-
-struct _MozillaEmbedFindPrivate
-{
- EphyFind *find;
-};
-
-static GObjectClass *parent_class = NULL;
-
-static void
-impl_set_embed (EphyEmbedFind *efind,
- EphyEmbed *embed)
-{
- MozillaEmbedFind *find = MOZILLA_EMBED_FIND (efind);
- MozillaEmbedFindPrivate *priv = find->priv;
-
- priv->find->SetEmbed (embed);
-}
-
-static void
-impl_set_properties (EphyEmbedFind *efind,
- const char *find_string,
- gboolean case_sensitive)
-{
- MozillaEmbedFind *find = MOZILLA_EMBED_FIND (efind);
- MozillaEmbedFindPrivate *priv = find->priv;
-
- priv->find->SetFindProperties (find_string, case_sensitive);
-}
-
-static EphyEmbedFindResult
-impl_find (EphyEmbedFind *efind,
- const char *find_string,
- gboolean links_only)
-{
- MozillaEmbedFind *find = MOZILLA_EMBED_FIND (efind);
- MozillaEmbedFindPrivate *priv = find->priv;
-
- return priv->find->Find (find_string, links_only);
-}
-
-static EphyEmbedFindResult
-impl_find_again (EphyEmbedFind *efind,
- gboolean forward,
- gboolean links_only)
-{
- MozillaEmbedFind *find = MOZILLA_EMBED_FIND (efind);
- MozillaEmbedFindPrivate *priv = find->priv;
-
- return priv->find->FindAgain (forward, links_only);
-}
-
-static void
-impl_set_selection (EphyEmbedFind *efind,
- gboolean attention)
-{
- MozillaEmbedFind *find = MOZILLA_EMBED_FIND (efind);
- MozillaEmbedFindPrivate *priv = find->priv;
-
- priv->find->SetSelectionAttention (attention);
-}
-
-static gboolean
-impl_activate_link (EphyEmbedFind *efind,
- GdkModifierType mask)
-{
- MozillaEmbedFind *find = MOZILLA_EMBED_FIND (efind);
- MozillaEmbedFindPrivate *priv = find->priv;
-
- return priv->find->ActivateLink (mask);
-}
-
-static void
-ephy_find_iface_init (EphyEmbedFindIface *iface)
-{
- iface->set_embed = impl_set_embed;
- iface->set_properties = impl_set_properties;
- iface->find = impl_find;
- iface->find_again = impl_find_again;
- iface->set_selection = impl_set_selection;
- iface->activate_link = impl_activate_link;
-}
-
-static void
-mozilla_embed_find_init (MozillaEmbedFind *find)
-{
- find->priv = MOZILLA_EMBED_FIND_GET_PRIVATE (find);
- find->priv->find = new EphyFind ();
-}
-
-static GObject *
-mozilla_embed_find_constructor (GType type, guint n_construct_properties,
- GObjectConstructParam *construct_params)
-{
- g_object_ref (embed_shell);
-
- /* we depend on single because of mozilla initialization */
- ephy_embed_shell_get_embed_single (embed_shell);
-
- return parent_class->constructor (type, n_construct_properties,
- construct_params);
-}
-
-static void
-mozilla_embed_find_finalize (GObject *object)
-{
- MozillaEmbedFind *find = MOZILLA_EMBED_FIND (object);
-
- delete find->priv->find;
-
- parent_class->finalize (object);
-
- g_object_unref (embed_shell);
-}
-
-static void
-mozilla_embed_find_class_init (MozillaEmbedFindClass *klass)
-{
- GObjectClass *object_class = G_OBJECT_CLASS (klass);
-
- parent_class = (GObjectClass *) g_type_class_peek_parent (klass);
-
- object_class->constructor = mozilla_embed_find_constructor;
- object_class->finalize = mozilla_embed_find_finalize;
-
- g_type_class_add_private (object_class, sizeof (MozillaEmbedFindPrivate));
-}
-
-GType
-mozilla_embed_find_get_type (void)
-{
- static GType type = 0;
-
- if (G_UNLIKELY (type == 0))
- {
- const GTypeInfo our_info =
- {
- sizeof (MozillaEmbedFindClass),
- NULL, /* base_init */
- NULL, /* base_finalize */
- (GClassInitFunc) mozilla_embed_find_class_init,
- NULL,
- NULL, /* class_data */
- sizeof (MozillaEmbedFind),
- 0, /* n_preallocs */
- (GInstanceInitFunc) mozilla_embed_find_init
- };
-
- const GInterfaceInfo find_info =
- {
- (GInterfaceInitFunc) ephy_find_iface_init,
- NULL,
- NULL
- };
-
- type = g_type_register_static (G_TYPE_OBJECT,
- "MozillaEmbedFind",
- &our_info,
- (GTypeFlags)0);
- g_type_add_interface_static (type,
- EPHY_TYPE_EMBED_FIND,
- &find_info);
- }
-
- return type;
-}
diff --git a/embed/xulrunner/embed/mozilla-embed-find.h b/embed/xulrunner/embed/mozilla-embed-find.h
deleted file mode 100644
index 1291f3795..000000000
--- a/embed/xulrunner/embed/mozilla-embed-find.h
+++ /dev/null
@@ -1,57 +0,0 @@
-/*
- * Copyright © 2000-2004 Marco Pesenti Gritti
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#ifndef MOZILLA_EMBED_FIND_H
-#define MOZILLA_EMBED_FIND_H
-
-#include <glib.h>
-#include <glib-object.h>
-
-G_BEGIN_DECLS
-
-#define MOZILLA_TYPE_EMBED_FIND (mozilla_embed_find_get_type ())
-#define MOZILLA_EMBED_FIND(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), MOZILLA_TYPE_EMBED_FIND, MozillaEmbedFind))
-#define MOZILLA_EMBED_FIND_CLASS(k) (G_TYPE_CHECK_CLASS_CAST((k), MOZILLA_TYPE_EMBED_FIND, MozillaEmbedFindClass))
-#define MOZILLA_IS_EMBED_FIND(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), MOZILLA_TYPE_EMBED_FIND))
-#define MOZILLA_IS_EMBED_FIND_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE ((k), MOZILLA_TYPE_EMBED_FIND))
-#define MOZILLA_EMBED_FIND_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS ((o), MOZILLA_TYPE_EMBED_FIND, MozillaEmbedFindClass))
-
-typedef struct _MozillaEmbedFindClass MozillaEmbedFindClass;
-typedef struct _MozillaEmbedFind MozillaEmbedFind;
-typedef struct _MozillaEmbedFindPrivate MozillaEmbedFindPrivate;
-
-struct _MozillaEmbedFind
-{
- GObject parent_instance;
-
- /*< private >*/
- MozillaEmbedFindPrivate *priv;
-};
-
-struct _MozillaEmbedFindClass
-{
- GObjectClass parent_class;
-};
-
-GType mozilla_embed_find_get_type (void);
-
-G_END_DECLS
-
-#endif
diff --git a/embed/xulrunner/embed/mozilla-embed-persist.cpp b/embed/xulrunner/embed/mozilla-embed-persist.cpp
deleted file mode 100644
index 804028e8e..000000000
--- a/embed/xulrunner/embed/mozilla-embed-persist.cpp
+++ /dev/null
@@ -1,416 +0,0 @@
-/*
- * Copyright © 2000, 2001, 2002 Marco Pesenti Gritti
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include <stddef.h>
-
-#include <nsStringGlue.h>
-
-#include <nsCOMPtr.h>
-#include <nsComponentManagerUtils.h>
-#include <nsCWebBrowserPersist.h>
-#include <nsICacheEntryDescriptor.h>
-#include <nsICacheService.h>
-#include <nsICacheSession.h>
-#include <nsIDOMSerializer.h>
-#include <nsIFile.h>
-#include <nsIHistoryEntry.h>
-#include <nsIInputStream.h>
-#include <nsIIOService.h>
-#include <nsILocalFile.h>
-#include <nsISHEntry.h>
-#include <nsIURI.h>
-#include <nsIWebBrowserPersist.h>
-#include <nsNetCID.h>
-#include <nsNetError.h>
-#include <nsServiceManagerUtils.h>
-#include <nsXPCOM.h>
-
-#include "EphyBrowser.h"
-#include "EphyHeaderSniffer.h"
-#include "EphyUtils.h"
-#include "MozDownload.h"
-
-#include "ephy-debug.h"
-#include "ephy-embed-shell.h"
-#include "ephy-file-helpers.h"
-#include "mozilla-embed.h"
-
-#include "mozilla-embed-persist.h"
-
-static void
-mozilla_embed_persist_class_init (MozillaEmbedPersistClass *klass);
-static void
-mozilla_embed_persist_init (MozillaEmbedPersist *ges);
-static void
-mozilla_embed_persist_finalize (GObject *object);
-
-#define MOZILLA_EMBED_PERSIST_GET_PRIVATE(object)(G_TYPE_INSTANCE_GET_PRIVATE ((object), MOZILLA_TYPE_EMBED_PERSIST, MozillaEmbedPersistPrivate))
-
-struct MozillaEmbedPersistPrivate
-{
- nsCOMPtr<nsIWebBrowserPersist> mPersist;
-};
-
-static GObjectClass *parent_class = NULL;
-
-GType
-mozilla_embed_persist_get_type (void)
-{
- static GType type = 0;
-
- if (G_UNLIKELY (type == 0))
- {
- const GTypeInfo our_info =
- {
- sizeof (MozillaEmbedPersistClass),
- NULL, /* base_init */
- NULL, /* base_finalize */
- (GClassInitFunc) mozilla_embed_persist_class_init,
- NULL, /* class_finalize */
- NULL, /* class_data */
- sizeof (MozillaEmbedPersist),
- 0, /* n_preallocs */
- (GInstanceInitFunc) mozilla_embed_persist_init
- };
-
- type = g_type_register_static (EPHY_TYPE_EMBED_PERSIST,
- "MozillaEmbedPersist",
- &our_info, (GTypeFlags) 0);
- }
-
- return type;
-}
-
-static void
-mozilla_embed_persist_init (MozillaEmbedPersist *persist)
-{
- persist->priv = MOZILLA_EMBED_PERSIST_GET_PRIVATE (persist);
-
- persist->priv->mPersist = do_CreateInstance (NS_WEBBROWSERPERSIST_CONTRACTID);
-}
-
-static void
-mozilla_embed_persist_finalize (GObject *object)
-{
- MozillaEmbedPersist *persist = MOZILLA_EMBED_PERSIST (object);
-
- persist->priv->mPersist = nsnull;
-
- G_OBJECT_CLASS (parent_class)->finalize (object);
-}
-
-void
-mozilla_embed_persist_completed (MozillaEmbedPersist *persist)
-{
- g_signal_emit_by_name (persist, "completed");
- g_object_unref (persist);
-}
-
-void
-mozilla_embed_persist_cancelled (MozillaEmbedPersist *persist)
-{
- g_signal_emit_by_name (persist, "cancelled");
- g_object_unref (persist);
-}
-
-static void
-impl_cancel (EphyEmbedPersist *persist)
-{
- nsCOMPtr<nsIWebBrowserPersist> bpersist =
- MOZILLA_EMBED_PERSIST (persist)->priv->mPersist;
- nsCOMPtr<nsICancelable> cancelable (do_QueryInterface (bpersist));
- if (cancelable)
- {
- cancelable->Cancel (NS_BINDING_ABORTED);
- }
-
- g_object_unref (persist);
-}
-
-static gboolean
-impl_save (EphyEmbedPersist *persist)
-{
- nsresult rv;
- char *filename;
- char *uri;
- gint64 max_size;
- EphyEmbed *embed;
- EphyEmbedPersistFlags flags;
- EphyEmbedSingle *single;
-
- single = EPHY_EMBED_SINGLE (ephy_embed_shell_get_embed_single (embed_shell));
-
- g_object_ref (persist);
-
- g_object_get (persist,
- "source", &uri,
- "dest", &filename,
- "flags", &flags,
- "embed", &embed,
- "max_size", &max_size,
- (char *) NULL);
-
- g_return_val_if_fail (!(flags & EPHY_EMBED_PERSIST_COPY_PAGE)
- || embed != NULL, FALSE);
-
- EphyBrowser *browser = NULL;
- if (embed)
- {
- browser = (EphyBrowser *) _mozilla_embed_get_ephy_browser (MOZILLA_EMBED(embed));
-
- g_object_unref (embed);
-
- NS_ENSURE_TRUE (browser, FALSE);
- }
- /* we must have one of uri or browser */
- g_assert (browser != NULL || uri != NULL);
-
- /* Get the uri to save to */
- nsCOMPtr<nsIURI> inURI;
- if (uri)
- {
- /* FIXME: origin charset!! */
- rv = EphyUtils::NewURI (getter_AddRefs(inURI), nsCString(uri));
- NS_ENSURE_SUCCESS (rv, FALSE);
- }
- else
- {
- rv = browser->GetDocumentURI (getter_AddRefs (inURI));
- NS_ENSURE_SUCCESS (rv, FALSE);
- }
-
- /* Get post data */
- nsCOMPtr<nsIInputStream> postData;
- /* FIXME: don't do this on COPY_PAGE to ensure we don't end up reposting? */
- if (browser)
- {
- PRInt32 sindex;
-
- nsCOMPtr<nsIWebNavigation> webNav(do_QueryInterface(browser->mWebBrowser));
- nsCOMPtr<nsISHistory> sessionHistory;
- webNav->GetSessionHistory(getter_AddRefs(sessionHistory));
- nsCOMPtr<nsIHistoryEntry> entry;
- sessionHistory->GetIndex(&sindex);
- sessionHistory->GetEntryAtIndex(sindex, PR_FALSE, getter_AddRefs(entry));
- nsCOMPtr<nsISHEntry> shEntry(do_QueryInterface(entry));
- if (shEntry)
- {
- shEntry->GetPostData(getter_AddRefs(postData));
- }
- }
-
- /* Get the DOM document if a uri is not specified */
- nsCOMPtr<nsIDOMDocument> DOMDocument;
- if (!uri)
- {
- if (flags & EPHY_EMBED_PERSIST_MAINDOC)
- {
- browser->GetDocument (getter_AddRefs(DOMDocument));
- }
- else
- {
- browser->GetTargetDocument (getter_AddRefs(DOMDocument));
- }
- NS_ENSURE_TRUE (DOMDocument, FALSE);
- }
-
-
- /* Get the current page descriptor */
- nsCOMPtr<nsISupports> cacheDescriptor;
- if (browser)
- {
- browser->GetPageDescriptor(getter_AddRefs (cacheDescriptor));
- }
-
- /* Try to get a descriptor from the cache session */
- /* FIXME: what about https?? */
- PRBool isHttp = PR_FALSE, isHttps = PR_FALSE;
- if (!cacheDescriptor &&
- (flags & EPHY_EMBED_PERSIST_FROM_CACHE) &&
- inURI &&
- ((NS_SUCCEEDED (inURI->SchemeIs ("http", &isHttp)) && isHttp) ||
- (NS_SUCCEEDED (inURI->SchemeIs ("https", &isHttps)) && isHttps )))
- {
- nsCOMPtr<nsICacheService> cacheService
- (do_GetService(NS_CACHESERVICE_CONTRACTID));
- if (cacheService)
- {
- nsCOMPtr<nsICacheSession> cacheSession;
- rv = cacheService->CreateSession ("HTTP",
- nsICache::STORE_ANYWHERE,
- PR_TRUE,
- getter_AddRefs (cacheSession));
- if (NS_SUCCEEDED (rv) && cacheSession)
- {
- nsCOMPtr<nsICacheEntryDescriptor> descriptor;
-
- nsCString spec;
- inURI->GetSpec (spec);
-
- rv = cacheSession->OpenCacheEntry
- (spec,
- nsICache::ACCESS_READ,
- PR_FALSE, getter_AddRefs (descriptor));
-
- cacheDescriptor = do_QueryInterface (descriptor);
-
- LOG ("Getting cache descriptor for '%s' rv=%x", spec.get(), rv);
- }
- }
- }
-
- LOG ("Cache descriptor %p", cacheDescriptor.get());
-
- /* if we have COPY_PAGE, we *need* to have a page descriptor, else we'll re-fetch
- * the page, which will possibly give a different page than the original which we
- * need for view source
- */
- NS_ENSURE_TRUE (!(flags & EPHY_EMBED_PERSIST_COPY_PAGE) || cacheDescriptor, FALSE);
-
- if (filename == NULL || filename[0] == '\0')
- {
- /* Get a temp filename to save to */
- char *tmp_filename, *base;
- base = g_build_filename (g_get_tmp_dir (), "sav-XXXXXX", (char *) NULL);
- tmp_filename = ephy_file_tmp_filename (base, "html");
- g_free (base);
- if (tmp_filename == NULL) return FALSE;
-
- nsCOMPtr<nsILocalFile> tmpFile = do_CreateInstance (NS_LOCAL_FILE_CONTRACTID);
- NS_ENSURE_TRUE (tmpFile, FALSE);
-
- tmpFile->InitWithNativePath (nsCString (tmp_filename));
- g_free (tmp_filename);
-
- /* Create an header sniffer and do the save */
- nsCOMPtr<nsIWebBrowserPersist> webPersist =
- MOZILLA_EMBED_PERSIST (persist)->priv->mPersist;
- NS_ENSURE_TRUE (webPersist, FALSE);
-
- EphyHeaderSniffer* sniffer = new EphyHeaderSniffer
- (webPersist, MOZILLA_EMBED_PERSIST (persist),
- tmpFile, inURI, DOMDocument, postData, single);
- if (!sniffer) return FALSE;
-
- webPersist->SetProgressListener(sniffer);
- rv = webPersist->SaveURI(inURI, cacheDescriptor, nsnull /* FIXME: Referrer */, nsnull, nsnull, tmpFile);
- if (NS_FAILED (rv)) return FALSE;
- }
- else
- {
- /* Filename to save to */
- nsCOMPtr<nsILocalFile> destFile;
- NS_NewNativeLocalFile (nsCString(filename),
- PR_TRUE, getter_AddRefs(destFile));
- NS_ENSURE_TRUE (destFile, FALSE);
-
- rv = InitiateMozillaDownload (DOMDocument, inURI, destFile,
- nsnull, inURI, MOZILLA_EMBED_PERSIST (persist),
- postData, cacheDescriptor, max_size);
- if (NS_FAILED (rv)) return FALSE;
- }
-
- g_free (uri);
- g_free (filename);
-
- return TRUE;
-}
-
-static char *
-impl_to_string (EphyEmbedPersist *persist)
-{
- EphyEmbed *embed;
- nsCOMPtr<nsIDOMDocument> DOMDocument;
- EphyEmbedPersistFlags flags;
- EphyBrowser *browser;
- nsresult rv = NS_OK;
-
- g_object_ref (persist);
-
- g_object_get (persist,
- "flags", &flags,
- "embed", &embed,
- (char *) NULL);
- g_object_unref (persist);
- g_return_val_if_fail (embed != NULL, NULL);
-
- browser = (EphyBrowser *) _mozilla_embed_get_ephy_browser (MOZILLA_EMBED(embed));
- g_return_val_if_fail (browser != NULL, NULL);
-
- if (flags & EPHY_EMBED_PERSIST_MAINDOC)
- {
- rv = browser->GetDocument (getter_AddRefs(DOMDocument));
- }
- else
- {
- rv = browser->GetTargetDocument (getter_AddRefs(DOMDocument));
- }
-
- nsCString cOutString;
- nsCOMPtr<nsIDOMNode> node = do_QueryInterface(DOMDocument);
- if (node)
- {
- nsString outString;
- nsCOMPtr<nsIDOMSerializer> serializer;
- serializer = do_CreateInstance(NS_XMLSERIALIZER_CONTRACTID, &rv);
- if (serializer)
- {
- serializer->SerializeToString(node, outString);
-
- NS_UTF16ToCString (outString, NS_CSTRING_ENCODING_UTF8, cOutString);
- }
- }
-
- g_object_unref (embed);
-
- return g_strdup (cOutString.get());
-}
-
-static GObject *
-mozilla_embed_persist_constructor (GType type, guint n_construct_properties,
- GObjectConstructParam *construct_params)
-{
- /* this will ensure that mozilla is started up */
- ephy_embed_shell_get_embed_single (embed_shell);
-
- return parent_class->constructor (type, n_construct_properties,
- construct_params);
-}
-
-static void
-mozilla_embed_persist_class_init (MozillaEmbedPersistClass *klass)
-{
- GObjectClass *object_class = G_OBJECT_CLASS (klass);
- EphyEmbedPersistClass *persist_class = EPHY_EMBED_PERSIST_CLASS (klass);
-
- parent_class = (GObjectClass *) g_type_class_peek_parent (klass);
-
- object_class->finalize = mozilla_embed_persist_finalize;
- object_class->constructor = mozilla_embed_persist_constructor;
-
- persist_class->save = impl_save;
- persist_class->cancel = impl_cancel;
- persist_class->to_string = impl_to_string;
-
- g_type_class_add_private (object_class, sizeof(MozillaEmbedPersistPrivate));
-}
diff --git a/embed/xulrunner/embed/mozilla-embed-persist.h b/embed/xulrunner/embed/mozilla-embed-persist.h
deleted file mode 100644
index edcb1eb53..000000000
--- a/embed/xulrunner/embed/mozilla-embed-persist.h
+++ /dev/null
@@ -1,63 +0,0 @@
-/*
- * Copyright © 2000-2003 Marco Pesenti Gritti
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#ifndef MOZILLA_EMBED_PERSIST_H
-#define MOZILLA_EMBED_PERSIST_H
-
-#include <glib.h>
-#include <glib-object.h>
-
-#include "ephy-embed-persist.h"
-
-G_BEGIN_DECLS
-
-#define MOZILLA_TYPE_EMBED_PERSIST (mozilla_embed_persist_get_type ())
-#define MOZILLA_EMBED_PERSIST(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), MOZILLA_TYPE_EMBED_PERSIST, MozillaEmbedPersist))
-#define MOZILLA_EMBED_PERSIST_CLASS(k) (G_TYPE_CHECK_CLASS_CAST((k), MOZILLA_TYPE_EMBED_PERSIST, MozillaEmbedPersistClass))
-#define MOZILLA_IS_EMBED_PERSIST(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), MOZILLA_TYPE_EMBED_PERSIST))
-#define MOZILLA_IS_EMBED_PERSIST_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE ((k), MOZILLA_TYPE_EMBED_PERSIST))
-#define MOZILLA_EMBED_PERSIST_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS ((o), MOZILLA_TYPE_EMBED_PERSIST, MozillaEmbedPersistClass))
-
-typedef struct MozillaEmbedPersistClass MozillaEmbedPersistClass;
-typedef struct MozillaEmbedPersist MozillaEmbedPersist;
-typedef struct MozillaEmbedPersistPrivate MozillaEmbedPersistPrivate;
-
-struct MozillaEmbedPersist
-{
- EphyEmbedPersist parent;
-
- /*< private >*/
- MozillaEmbedPersistPrivate *priv;
-};
-
-struct MozillaEmbedPersistClass
-{
- EphyEmbedPersistClass parent_class;
-};
-
-GType mozilla_embed_persist_get_type (void);
-
-void mozilla_embed_persist_completed (MozillaEmbedPersist *persist);
-
-void mozilla_embed_persist_cancelled (MozillaEmbedPersist *persist);
-
-G_END_DECLS
-
-#endif
diff --git a/embed/xulrunner/embed/mozilla-embed-single.cpp b/embed/xulrunner/embed/mozilla-embed-single.cpp
deleted file mode 100644
index d5c3974e2..000000000
--- a/embed/xulrunner/embed/mozilla-embed-single.cpp
+++ /dev/null
@@ -1,1389 +0,0 @@
-/* vim:set ts=8 noet sw=8:
- * Copyright © 2000-2004 Marco Pesenti Gritti
- * Copyright © 2003 Robert Marcano
- * Copyright © 2003, 2004, 2005, 2006 Christian Persch
- * Copyright © 2005 Crispin Flowerday
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-
-#include "config.h"
-
-#include <stdlib.h>
-
-#include <glib.h>
-#include <glib/gi18n.h>
-#include <gio/gio.h>
-
-#include <nsStringGlue.h>
-
-#include <nsComponentManagerUtils.h>
-#include <nsCOMPtr.h>
-#include <nsCPasswordManager.h>
-#include <nsICookie2.h>
-#include <nsICookieManager.h>
-#include <nsICookieManager.h>
-#include <nsIFile.h>
-#include <nsIIOService.h>
-#include <nsILocalFile.h>
-#include <nsIPermission.h>
-#include <nsIPermissionManager.h>
-#include <nsIPrefService.h>
-#include <nsIStyleSheetService.h>
-#include <nsISupportsPrimitives.h>
-#include <nsIURI.h>
-#include <nsIWindowWatcher.h>
-#include <nsMemory.h>
-#include <nsServiceManagerUtils.h>
-
-#ifdef HAVE_MOZILLA_PSM
-#include <nsIX509Cert.h>
-#include <nsIX509CertDB.h>
-#endif
-
-#ifdef ALLOW_PRIVATE_API
-#include <nsICacheService.h>
-#include <nsIFontEnumerator.h>
-#include <nsIHttpAuthManager.h>
-#include <nsIIDNService.h>
-#include <nsNetCID.h>
-#endif /* ALLOW_PRIVATE_API */
-
-#include <nsILoginInfo.h>
-#include <nsILoginManager.h>
-
-#define XPCOM_GLUE
-#include <nsXPCOMGlue.h>
-
-#include "gecko-init.h"
-#include "gecko-init-internal.h"
-#include "gecko-embed.h"
-#include "gecko-embed-single.h"
-
-#include "ephy-file-helpers.h"
-#include "eel-gconf-extensions.h"
-#include "ephy-certificate-manager.h"
-#include "ephy-cookie-manager.h"
-#include "ephy-debug.h"
-#include "ephy-embed-prefs.h"
-#include "ephy-embed-shell.h"
-#include "ephy-file-helpers.h"
-#include "ephy-langs.h"
-#include "ephy-password-manager.h"
-#include "ephy-permission-manager.h"
-#include "ephy-string.h"
-#include "mozilla-embed.h"
-#include "mozilla-notifiers.h"
-#include "mozilla-x509-cert.h"
-
-#include "EphyBrowser.h"
-#include "EphyDirectoryProvider.h"
-#include "EphySingle.h"
-#include "EphyUtils.h"
-#include "MozRegisterComponents.h"
-
-#include "mozilla-embed-single.h"
-
-#include "AutoJSContextStack.h"
-
-#define MOZILLA_PROFILE_DIR "/mozilla"
-#define MOZILLA_PROFILE_NAME "epiphany"
-#define MOZILLA_PROFILE_FILE "prefs.js"
-#define DEFAULT_PROFILE_FILE SHARE_DIR"/default-prefs.js"
-
-#define USER_CSS_LOAD_DELAY 500 /* ms */
-
-#define MOZILLA_EMBED_SINGLE_GET_PRIVATE(object)(G_TYPE_INSTANCE_GET_PRIVATE ((object), MOZILLA_TYPE_EMBED_SINGLE, MozillaEmbedSinglePrivate))
-
-struct MozillaEmbedSinglePrivate
-{
- char *user_prefs;
-
- EphySingle *mSingleObserver;
-
- char *user_css_file;
- guint user_css_enabled_notifier_id;
- EphyFileMonitor *user_css_file_monitor;
- guint user_css_enabled : 1;
-
- guint online : 1;
-};
-
-enum
-{
- PROP_0,
- PROP_NETWORK_STATUS
-};
-
-static void mozilla_embed_single_class_init (MozillaEmbedSingleClass *klass);
-static void ephy_embed_single_iface_init (EphyEmbedSingleIface *iface);
-static void ephy_cookie_manager_iface_init (EphyCookieManagerIface *iface);
-static void ephy_password_manager_iface_init (EphyPasswordManagerIface *iface);
-static void ephy_permission_manager_iface_init (EphyPermissionManagerIface *iface);
-static void mozilla_embed_single_init (MozillaEmbedSingle *ges);
-
-#ifdef ENABLE_CERTIFICATE_MANAGER
-static void ephy_certificate_manager_iface_init (EphyCertificateManagerIface *iface);
-#endif
-
-/* Some compilers (like gcc 2.95) don't support preprocessor directives inside macros,
- so we have to duplicate the whole thing */
-
-#ifdef ENABLE_CERTIFICATE_MANAGER
-G_DEFINE_TYPE_WITH_CODE (MozillaEmbedSingle, mozilla_embed_single, G_TYPE_OBJECT,
- G_IMPLEMENT_INTERFACE (EPHY_TYPE_EMBED_SINGLE,
- ephy_embed_single_iface_init)
- G_IMPLEMENT_INTERFACE (EPHY_TYPE_COOKIE_MANAGER,
- ephy_cookie_manager_iface_init)
- G_IMPLEMENT_INTERFACE (EPHY_TYPE_PASSWORD_MANAGER,
- ephy_password_manager_iface_init)
- G_IMPLEMENT_INTERFACE (EPHY_TYPE_CERTIFICATE_MANAGER,
- ephy_certificate_manager_iface_init)
- G_IMPLEMENT_INTERFACE (EPHY_TYPE_PERMISSION_MANAGER,
- ephy_permission_manager_iface_init))
-#else
-G_DEFINE_TYPE_WITH_CODE (MozillaEmbedSingle, mozilla_embed_single, G_TYPE_OBJECT,
- G_IMPLEMENT_INTERFACE (EPHY_TYPE_EMBED_SINGLE,
- ephy_embed_single_iface_init)
- G_IMPLEMENT_INTERFACE (EPHY_TYPE_COOKIE_MANAGER,
- ephy_cookie_manager_iface_init)
- G_IMPLEMENT_INTERFACE (EPHY_TYPE_PASSWORD_MANAGER,
- ephy_password_manager_iface_init)
- G_IMPLEMENT_INTERFACE (EPHY_TYPE_PERMISSION_MANAGER,
- ephy_permission_manager_iface_init))
-#endif
-
-static gboolean
-mozilla_set_default_prefs (MozillaEmbedSingle *mes)
-{
- nsCOMPtr<nsIPrefService> prefService;
-
- prefService = do_GetService (NS_PREFSERVICE_CONTRACTID);
- NS_ENSURE_TRUE (prefService, FALSE);
-
- /* read our predefined default prefs */
- nsresult rv;
- nsCOMPtr<nsILocalFile> file;
- NS_NewNativeLocalFile(nsCString(DEFAULT_PROFILE_FILE),
- PR_TRUE, getter_AddRefs(file));
- if (!file) return FALSE;
-
- rv = prefService->ReadUserPrefs (file);
- if (NS_FAILED(rv))
- {
- g_warning ("failed to read default preferences, error: %x", rv);
- return FALSE;
- }
-
- nsCOMPtr<nsIPrefBranch> pref;
- prefService->GetBranch ("", getter_AddRefs(pref));
- NS_ENSURE_TRUE (pref, FALSE);
-
- /* We do this before reading the user pref file so that the user
- * still can overwrite this pref.
- * We don't use the default-prefs.js file since that cannot be
- * localised (see bug #144909).
- */
- /* translators: this is the URL that searches from the location
- * entry get directed to. The search terms will be _appended_ to it,
- * in url-escaped UTF-8; that means that if you're choosing google,
- * the 'q=' part needs to come last.
- */
- pref->SetCharPref ("keyword.URL", _("http://www.google.com/search?ie=UTF-8&oe=UTF-8&q="));
-
- /* Load the default user preferences as well. This also makes the
- prefs to be saved in the user's prefs.js file, instead of messing up
- our global defaults file. */
- rv = prefService->ReadUserPrefs (nsnull);
- if (NS_FAILED(rv))
- {
- g_warning ("failed to read user preferences, error: %x", rv);
- }
-
- pref->SetCharPref ("general.useragent.extra.epiphany", "Epiphany/" UA_VERSION);
-
- /* Unset old prefs, otherwise they end up in the user agent string too */
- pref->ClearUserPref ("general.useragent.vendor");
- pref->ClearUserPref ("general.useragent.vendorSub");
-
- /* Don't open ftp uris with an external handler if one is setup */
- pref->SetBoolPref ("network.protocol-handler.external.ftp", PR_FALSE);
-
- return TRUE;
-}
-
-static void
-mozilla_embed_single_new_window_orphan_cb (GeckoEmbedSingle *moz_single,
- GeckoEmbed **newEmbed,
- guint chrome_mask,
- EphyEmbedSingle *single)
-{
- GeckoEmbedChromeFlags chrome = (GeckoEmbedChromeFlags) chrome_mask;
- EphyEmbed *new_embed = NULL;
- EphyEmbedChrome mask;
-
- if (chrome_mask & GECKO_EMBED_FLAG_OPENASCHROME)
- {
- *newEmbed = _mozilla_embed_new_xul_dialog ();
- return;
- }
-
- mask = _mozilla_embed_translate_chrome (chrome);
-
- g_signal_emit_by_name (single, "new-window", NULL, mask,
- &new_embed);
-
- /* it's okay not to have a new embed */
- if (new_embed != NULL)
- {
- gecko_embed_set_chrome_mask (GECKO_EMBED (new_embed), chrome);
-
- *newEmbed = GECKO_EMBED (new_embed);
- }
-}
-
-static GList *
-mozilla_init_plugin_add_unique_path (GList *list,
- const char *path)
-{
- GList *l;
- char *canon;
-
- if (path == NULL)
- return list;
-
- canon = ephy_string_canonicalize_pathname (path);
-
- for (l = list; l != NULL; l = l->next) {
- if (g_str_equal (list->data, canon) != FALSE) {
- /* The path is already in the list */
- g_free (canon);
- return list;
- }
- }
- return g_list_prepend (list, canon);
-}
-
-static GList *
-mozilla_init_plugin_add_unique_paths (GList *list,
- const char *path)
-{
- char **paths;
- guint i;
-
- if (path == NULL)
- return list;
-
- paths = g_strsplit (path, ":", -1);
- if (paths == NULL)
- return list;
- for (i = 0; paths[i] != NULL; i++) {
- list = mozilla_init_plugin_add_unique_path (list, paths[i]);
- }
- g_strfreev (paths);
- return list;
-}
-
-static void
-mozilla_init_plugin_path ()
-{
- GList *list, *l;
- GString *path;
-
- list = NULL;
- list = mozilla_init_plugin_add_unique_paths (list,
- g_getenv ("MOZ_PLUGIN_PATH"));
- list = mozilla_init_plugin_add_unique_path (list,
- MOZILLA_PREFIX "/lib/mozilla/plugins");
- list = mozilla_init_plugin_add_unique_path (list,
- MOZILLA_HOME "/plugins");
- list = mozilla_init_plugin_add_unique_path (list,
- MOZILLA_NATIVE_PLUGINSDIR);
-#ifdef HAVE_PRIVATE_PLUGINS
- list = mozilla_init_plugin_add_unique_path (list, PLUGINDIR);
-#endif
-
- list = g_list_reverse (list);
- path = g_string_new ((const char *) list->data);
- g_free (list->data);
- l = list->next;
- for (; l != NULL; l = l->next) {
- path = g_string_append_c (path, ':');
- path = g_string_append (path, (const char *) l->data);
- g_free (l->data);
- }
- g_list_free (list);
-
- g_setenv ("MOZ_PLUGIN_PATH", path->str, TRUE);
- g_string_free (path, TRUE);
-}
-
-static void
-mozilla_init_single (MozillaEmbedSingle *mes)
-{
- GeckoEmbedSingle *single;
-
- /* get single */
- single = gecko_embed_single_get ();
- if (single == NULL)
- {
- g_warning ("Failed to get singleton embed object!\n");
- return;
- }
-
- /* allow creation of orphan windows */
- g_signal_connect (G_OBJECT (single), "new_window_orphan",
- G_CALLBACK (mozilla_embed_single_new_window_orphan_cb),
- mes);
-}
-
-#if defined(MOZ_NSIXULCHROMEREGISTRY_SELECTSKIN) || defined(HAVE_CHROME_NSICHROMEREGISTRYSEA_H)
-static nsresult
-getUILang (nsAString& aUILang)
-{
- nsresult rv;
-
- nsCOMPtr<nsILocaleService> localeService = do_GetService (NS_LOCALESERVICE_CONTRACTID);
- if (!localeService)
- {
- g_warning ("Could not get locale service!\n");
- return NS_ERROR_FAILURE;
- }
-
- rv = localeService->GetLocaleComponentForUserAgent (aUILang);
-
- if (NS_FAILED (rv))
- {
- g_warning ("Could not determine locale!\n");
- return NS_ERROR_FAILURE;
- }
-
- return NS_OK;
-}
-#endif
-
-static void
-mozilla_init_observer (MozillaEmbedSingle *single)
-{
- EphySingle *es;
-
- es = new EphySingle ();
- NS_ADDREF (single->priv->mSingleObserver = es);
-
- nsresult rv;
- rv = es->Init (EPHY_EMBED_SINGLE (single));
- if (NS_FAILED (rv))
- {
- g_warning ("Failed to initialise EphySingle!\n");
- return;
- }
-}
-
-static void
-user_css_register (MozillaEmbedSingle *single)
-{
- MozillaEmbedSinglePrivate *priv = single->priv;
-
- nsresult rv;
- nsCOMPtr<nsILocalFile> file;
- rv = NS_NewNativeLocalFile (nsDependentCString (priv->user_css_file),
- PR_TRUE, getter_AddRefs (file));
- NS_ENSURE_SUCCESS (rv, );
-
- PRBool exists = PR_FALSE;
- rv = file->Exists (&exists);
- if (NS_FAILED (rv) || !exists) return;
-
- nsCOMPtr<nsIURI> uri;
- rv = EphyUtils::NewFileURI (getter_AddRefs (uri), file);
- NS_ENSURE_SUCCESS (rv, );
-
- nsCOMPtr<nsIStyleSheetService> service
- (do_GetService ("@mozilla.org/content/style-sheet-service;1", &rv));
- NS_ENSURE_SUCCESS (rv, );
-
- PRBool isRegistered = PR_FALSE;
- rv = service->SheetRegistered (uri, nsIStyleSheetService::USER_SHEET,
- &isRegistered);
- if (NS_SUCCEEDED (rv) && isRegistered)
- {
- rv = service->UnregisterSheet (uri, nsIStyleSheetService::USER_SHEET);
- }
-
- rv = service->LoadAndRegisterSheet (uri, nsIStyleSheetService::AGENT_SHEET);
- if (NS_FAILED (rv))
- {
- g_warning ("Registering the user stylesheet failed (rv=%x)!\n", rv);
- }
-}
-
-static void
-user_css_unregister (MozillaEmbedSingle *single)
-{
- MozillaEmbedSinglePrivate *priv = single->priv;
-
- nsresult rv;
- nsCOMPtr<nsILocalFile> file;
- rv = NS_NewNativeLocalFile (nsDependentCString (priv->user_css_file),
- PR_TRUE, getter_AddRefs (file));
- NS_ENSURE_SUCCESS (rv, );
-
- nsCOMPtr<nsIURI> uri;
- rv = EphyUtils::NewFileURI (getter_AddRefs (uri), file);
- NS_ENSURE_SUCCESS (rv, );
-
- nsCOMPtr<nsIStyleSheetService> service
- (do_GetService ("@mozilla.org/content/style-sheet-service;1", &rv));
- NS_ENSURE_SUCCESS (rv, );
-
- PRBool isRegistered = PR_FALSE;
- rv = service->SheetRegistered (uri, nsIStyleSheetService::USER_SHEET,
- &isRegistered);
- if (NS_SUCCEEDED (rv) && isRegistered)
- {
- rv = service->UnregisterSheet (uri, nsIStyleSheetService::USER_SHEET);
- }
- if (NS_FAILED (rv))
- {
- g_warning ("Unregistering the user stylesheet failed (rv=%x)!\n", rv);
- }
-}
-
-static void
-user_css_file_monitor_changed_cb (GFileMonitor *file_monitor,
- GFile *file,
- GFile *other_file,
- gint event_type,
- MozillaEmbedSingle *single)
-{
- LOG ("Reregistering the user style sheet");
-
- if (event_type == G_FILE_MONITOR_EVENT_DELETED)
- {
- user_css_unregister (single);
- }
- else
- {
- user_css_register (single);
- }
-}
-
-static void
-user_css_enabled_notify (GConfClient *client,
- guint cnxn_id,
- GConfEntry *entry,
- MozillaEmbedSingle *single)
-{
- MozillaEmbedSinglePrivate *priv = single->priv;
- guint enabled;
-
- enabled = eel_gconf_get_boolean (CONF_USER_CSS_ENABLED) != FALSE;
- if (priv->user_css_enabled == enabled) return;
-
- LOG ("User stylesheet enabled: %s", enabled ? "t" : "f");
-
- priv->user_css_enabled = enabled;
-
- if (enabled)
- {
- GFile *file;
-
- user_css_register (single);
-
- file = g_file_new_for_path (priv->user_css_file);
-
- g_assert (priv->user_css_file_monitor == NULL);
- priv->user_css_file_monitor =
- g_file_monitor_file (file,
- G_FILE_MONITOR_NONE,
- NULL, NULL);
- g_file_monitor_set_rate_limit (priv->user_css_file_monitor,
- USER_CSS_LOAD_DELAY);
- g_signal_connect (priv->user_css_file_monitor, "changed",
- G_CALLBACK (user_css_file_monitor_changed_cb),
- single);
- g_object_unref (file);
- }
- else
- {
- if (priv->user_css_file_monitor != NULL)
- {
- g_file_monitor_cancel (priv->user_css_file_monitor);
- priv->user_css_file_monitor = NULL;
- }
-
- user_css_unregister (single);
- }
-}
-
-static void
-mozilla_stylesheet_init (MozillaEmbedSingle *single)
-{
- MozillaEmbedSinglePrivate *priv = single->priv;
-
- priv->user_css_file = g_build_filename (ephy_dot_dir (),
- USER_STYLESHEET_FILENAME,
- (char *) NULL);
-
- user_css_enabled_notify (NULL, 0, NULL, single);
- priv->user_css_enabled_notifier_id =
- eel_gconf_notification_add
- (CONF_USER_CSS_ENABLED,
- (GConfClientNotifyFunc) user_css_enabled_notify,
- single);
-}
-
-static void
-mozilla_stylesheet_shutdown (MozillaEmbedSingle *single)
-{
- MozillaEmbedSinglePrivate *priv = single->priv;
-
- if (priv->user_css_enabled_notifier_id != 0)
- {
- eel_gconf_notification_remove (priv->user_css_enabled_notifier_id);
- priv->user_css_enabled_notifier_id = 0;
- }
-
- if (priv->user_css_file_monitor != NULL)
- {
- ephy_file_monitor_cancel (priv->user_css_file_monitor);
- priv->user_css_file_monitor = NULL;
- }
-
- if (priv->user_css_file != NULL)
- {
- g_free (priv->user_css_file);
- priv->user_css_file = NULL;
- }
-}
-
-static gboolean
-impl_init (EphyEmbedSingle *esingle)
-{
- MozillaEmbedSingle *single = MOZILLA_EMBED_SINGLE (esingle);
- char *profile_path;
-
- g_setenv ("MOZILLA_POSTSCRIPT_ENABLED", "1", TRUE);
- g_unsetenv ("MOZILLA_POSTSCRIPT_PRINTER_LIST");
-
- NS_LogInit ();
-
- /* Pre initialization */
- mozilla_init_plugin_path ();
-
- profile_path = g_build_filename (ephy_dot_dir (),
- MOZILLA_PROFILE_DIR,
- (char *) NULL);
-
-// gecko_embed_set_comp_path (MOZILLA_HOME);
-
- /* FIXMEchpe remove this hack! */
- g_setenv ("GRE_HOME", LIBXUL_LIBDIR, TRUE);
-
- static const GREVersionRange greVersion = {
- "1.9a", PR_TRUE,
- "2", PR_TRUE
- };
-
- char xpcomPath[PATH_MAX];
-
- nsresult rv = GRE_GetGREPathWithProperties(&greVersion, 1, nsnull, 0,
- xpcomPath, sizeof(xpcomPath));
- if (NS_FAILED(rv)) {
- fprintf(stderr, "Couldn't find a compatible GRE.\n");
- return 1;
- }
-
- rv = XPCOMGlueStartup(xpcomPath);
- if (NS_FAILED(rv)) {
- fprintf(stderr, "Couldn't start XPCOM.");
- return 1;
- }
-
- char *lastSlash = strrchr(xpcomPath, '/');
- if (lastSlash)
- *lastSlash = '\0';
-
-
- nsCOMPtr<nsIDirectoryServiceProvider> dp = new EphyDirectoryProvider ();
- if (!dp) return FALSE;
-
- if (!gecko_init_with_params (xpcomPath,
- profile_path,
- MOZILLA_PROFILE_NAME,
- dp)) {
- g_free (profile_path);
- g_warning ("Failed to init gecko!\n");
- return FALSE;
- }
-
- g_free (profile_path);
-
- mozilla_register_components ();
-
- mozilla_init_single (single);
-
- if (!mozilla_set_default_prefs (single))
- {
- return FALSE;
- }
-
- START_PROFILER ("Mozilla prefs notifiers")
- mozilla_notifiers_init ();
- STOP_PROFILER ("Mozilla prefs notifiers")
-
- mozilla_init_observer (single);
-
- mozilla_stylesheet_init (single);
-
- return TRUE;
-}
-
-static void
-prepare_close_cb (EphyEmbedShell *shell)
-{
- GValue value = { 0, };
-
- /* To avoid evil web sites posing an alert and thus inhibiting
- * shutdown, we just turn off javascript! :)
- */
- g_value_init (&value, G_TYPE_BOOLEAN);
- g_value_set_boolean (&value, FALSE);
- mozilla_pref_set ("javascript.enabled", &value);
- g_value_unset (&value);
-}
-
-static void
-mozilla_embed_single_init (MozillaEmbedSingle *mes)
-{
- mes->priv = MOZILLA_EMBED_SINGLE_GET_PRIVATE (mes);
-
- mes->priv->user_prefs =
- g_build_filename (ephy_dot_dir (),
- MOZILLA_PROFILE_DIR,
- MOZILLA_PROFILE_NAME,
- MOZILLA_PROFILE_FILE,
- (char *) NULL);
-
- g_signal_connect_object (embed_shell, "prepare-close",
- G_CALLBACK (prepare_close_cb), mes,
- (GConnectFlags) 0);
-}
-
-static void
-mozilla_embed_single_dispose (GObject *object)
-{
- MozillaEmbedSingle *single = MOZILLA_EMBED_SINGLE (object);
- MozillaEmbedSinglePrivate *priv = single->priv;
-
- mozilla_stylesheet_shutdown (single);
-
- if (priv->mSingleObserver)
- {
- priv->mSingleObserver->Detach ();
- NS_RELEASE (priv->mSingleObserver);
- priv->mSingleObserver = nsnull;
- }
-
- G_OBJECT_CLASS (mozilla_embed_single_parent_class)->dispose (object);
-}
-
-static void
-mozilla_embed_single_finalize (GObject *object)
-{
- MozillaEmbedSingle *mes = MOZILLA_EMBED_SINGLE (object);
-
- /* Destroy EphyEmbedSingle before because some
- * services depend on xpcom */
- G_OBJECT_CLASS (mozilla_embed_single_parent_class)->finalize (object);
-
- mozilla_notifiers_shutdown ();
-
- gecko_shutdown ();
-
- XPCOMGlueShutdown ();
-
- NS_LogTerm ();
-
- g_free (mes->priv->user_prefs);
-}
-
-static void
-impl_clear_cache (EphyEmbedSingle *shell)
-{
- nsCOMPtr<nsICacheService> cacheService =
- do_GetService (NS_CACHESERVICE_CONTRACTID);
- if (!cacheService) return;
-
- cacheService->EvictEntries (nsICache::STORE_ANYWHERE);
-}
-
-static void
-impl_clear_auth_cache (EphyEmbedSingle *shell)
-{
- nsCOMPtr<nsIHttpAuthManager> authManager =
- do_GetService (NS_HTTPAUTHMANAGER_CONTRACTID);
- if (!authManager) return;
-
- authManager->ClearAll();
-}
-
-static void
-impl_set_network_status (EphyEmbedSingle *single,
- gboolean online)
-{
- nsCOMPtr<nsIIOService> io = do_GetService(NS_IOSERVICE_CONTRACTID);
- if (!io) return;
-
- io->SetOffline (!online);
-}
-
-static gboolean
-impl_get_network_status (EphyEmbedSingle *esingle)
-{
- MozillaEmbedSingle *single = MOZILLA_EMBED_SINGLE (esingle);
- MozillaEmbedSinglePrivate *priv = single->priv;
-
- NS_ENSURE_TRUE (priv->mSingleObserver, TRUE);
-
- nsCOMPtr<nsIIOService> io = do_GetService(NS_IOSERVICE_CONTRACTID);
- if (!io) return FALSE; /* no way to check the state, assume offline */
-
- PRBool isOffline;
- nsresult rv;
- rv = io->GetOffline(&isOffline);
- NS_ENSURE_SUCCESS (rv, FALSE);
-
- PRBool isOnline = !isOffline;
- PRBool reallyOnline = priv->mSingleObserver->IsOnline ();
-
- g_return_val_if_fail (reallyOnline == isOnline, TRUE);
-
- return !isOffline;
-}
-
-static const char*
-impl_get_backend_name (EphyEmbedSingle *esingle)
-{
- /* If you alter the return values here, remember to update
- * the docs in ephy-embed-single.c
- */
- return "gecko-1.9";
-}
-
-static GList *
-impl_get_font_list (EphyEmbedSingle *shell,
- const char *langGroup)
-{
- nsresult rv;
- PRUint32 fontCount;
- PRUnichar **fontArray;
- GList *l = NULL;
-
- nsCOMPtr<nsIFontEnumerator> mozFontEnumerator;
- mozFontEnumerator = do_CreateInstance("@mozilla.org/gfx/fontenumerator;1");
- NS_ENSURE_TRUE (mozFontEnumerator, NULL);
-
- rv = mozFontEnumerator->EnumerateFonts (langGroup, nsnull,
- &fontCount, &fontArray);
- NS_ENSURE_SUCCESS (rv, NULL);
-
- for (PRUint32 i = 0; i < fontCount; i++)
- {
- char *gFontString;
-
- nsCString tmp;
- NS_UTF16ToCString (nsString(fontArray[i]),
- NS_CSTRING_ENCODING_UTF8, tmp);
- gFontString = g_strdup (tmp.get());
- l = g_list_prepend (l, gFontString);
- nsMemory::Free (fontArray[i]);
- }
-
- nsMemory::Free (fontArray);
-
- return g_list_reverse (l);
-}
-
-static GList *
-impl_list_cookies (EphyCookieManager *manager)
-{
- nsresult rv;
- GList *cookies = NULL;
-
- nsCOMPtr<nsICookieManager> cookieManager =
- do_GetService (NS_COOKIEMANAGER_CONTRACTID);
- if (!cookieManager) return NULL;
-
- nsCOMPtr<nsISimpleEnumerator> cookieEnumerator;
- cookieManager->GetEnumerator (getter_AddRefs(cookieEnumerator));
- NS_ENSURE_TRUE (cookieEnumerator, NULL);
-
- PRBool enumResult;
- for (cookieEnumerator->HasMoreElements(&enumResult) ;
- enumResult == PR_TRUE ;
- cookieEnumerator->HasMoreElements(&enumResult))
- {
- nsCOMPtr<nsICookie> keks;
- rv = cookieEnumerator->GetNext (getter_AddRefs(keks));
- if (NS_FAILED (rv) || !keks) continue;
-
- EphyCookie *cookie = mozilla_cookie_to_ephy_cookie (keks);
- if (!cookie) continue;
-
- cookies = g_list_prepend (cookies, cookie);
- }
-
- return cookies;
-}
-
-static void
-impl_remove_cookie (EphyCookieManager *manager,
- const EphyCookie *cookie)
-{
- nsCOMPtr<nsICookieManager> cookieManager =
- do_GetService (NS_COOKIEMANAGER_CONTRACTID);
- if (!cookieManager) return;
-
- nsCOMPtr<nsIIDNService> idnService
- (do_GetService ("@mozilla.org/network/idn-service;1"));
- NS_ENSURE_TRUE (idnService, );
-
- nsresult rv;
- nsCString host;
- rv = idnService->ConvertUTF8toACE (nsCString(cookie->domain), host);
- NS_ENSURE_SUCCESS (rv, );
-
- cookieManager->Remove (host,
- nsCString(cookie->name),
- nsCString(cookie->path),
- PR_FALSE /* block */);
-}
-
-static void
-impl_clear_cookies (EphyCookieManager *manager)
-{
- nsCOMPtr<nsICookieManager> cookieManager =
- do_GetService (NS_COOKIEMANAGER_CONTRACTID);
- if (!cookieManager) return;
-
- cookieManager->RemoveAll ();
-}
-
-static GList *
-impl_list_passwords (EphyPasswordManager *manager)
-{
- GList *passwords = NULL;
-
- nsresult rv;
- nsCOMPtr<nsILoginManager> loginManager (do_GetService (NS_LOGINMANAGER_CONTRACTID));
- g_return_val_if_fail (loginManager, NULL);
- if (!loginManager)
- return NULL;
-
- nsCOMPtr<nsIIDNService> idnService
- (do_GetService ("@mozilla.org/network/idn-service;1"));
- NS_ENSURE_TRUE (idnService, NULL);
-
- /* What a broken, stupid API */
- PRUint32 count = 0;
- nsILoginInfo **logins = nsnull;
- rv = loginManager->GetAllLogins (&count, &logins);
- g_return_val_if_fail (NS_SUCCEEDED (rv), NULL);
- if (NS_FAILED (rv))
- return NULL;
-
- for (PRUint32 i = 0; i < count; ++i)
- {
- nsString hostName;
- rv = logins[i]->GetHostname (hostName);
- if (NS_FAILED (rv))
- continue;
-
- NS_ConvertUTF16toUTF8 cHostName (hostName);
-
- nsCString host;
- idnService->ConvertACEtoUTF8 (cHostName, host);
-
- nsString userName;
- rv = logins[i]->GetUsername (userName);
- if (NS_FAILED (rv))
- continue;
-
- NS_ConvertUTF16toUTF8 cUserName (userName);
-
-#if 0
- rv = nsPassword->GetPassword (unicodeName);
- if (NS_FAILED (rv)) continue;
-
- nsCString userPassword;
- NS_UTF16ToCString (unicodeName,
- NS_CSTRING_ENCODING_UTF8, userPassword);
-#endif
-
- EphyPasswordInfo *p = g_new0 (EphyPasswordInfo, 1);
-
- p->host = g_strdup (cHostName.get());
- p->username = g_strdup (cUserName.get());
- p->password = NULL; /* FIXME */
-
- passwords = g_list_prepend (passwords, p);
- }
-
- NS_FREE_XPCOM_ISUPPORTS_POINTER_ARRAY(count, logins);
-
- return passwords;
-}
-
-static void
-impl_remove_password (EphyPasswordManager *manager,
- EphyPasswordInfo *info)
-{
-#if 0
- /* FIXMEchpe RemoveLogin only works if we have the original nsILoginInfo */
-
- nsresult rv;
- nsCOMPtr<nsILoginManager> loginManager =
- do_GetService (NS_LOGINMANAGER_CONTRACTID);
- g_return_val_if_fail (NS_SUCCEEDED (rv), NULL);
- if (!loginManager)
- return NULL;
-
- nsCOMPtr<nsILoginInfo> login (do_CreateInstance (NS_LOGININFO_CONTRACTID));
- if (!login)
- return;
-
- nsCOMPtr<nsIIDNService> idnService
- (do_GetService ("@mozilla.org/network/idn-service;1"));
- NS_ENSURE_TRUE (idnService, );
-
- nsresult rv;
- nsCString host;
- rv = idnService->ConvertUTF8toACE (nsCString(info->host), host);
- NS_ENSURE_SUCCESS (rv, );
-
- nsString userName;
- NS_CStringToUTF16 (nsCString(info->username),
- NS_CSTRING_ENCODING_UTF8, userName);
- rv = loginManager->RemoveLogin (login);
- if (NS_FAILED (rv))
- return;
-#endif
-}
-
-static void
-impl_remove_all_passwords (EphyPasswordManager *manager)
-{
- nsresult rv;
- nsCOMPtr<nsILoginManager> loginManager =
- do_GetService (NS_LOGINMANAGER_CONTRACTID);
- g_return_val_if_fail (NS_SUCCEEDED (rv), NULL);
- if (!loginManager)
- return NULL;
-
- nsCOMPtr<nsIIDNService> idnService
- (do_GetService ("@mozilla.org/network/idn-service;1"));
- NS_ENSURE_TRUE (idnService, );
-
- rv = loginManager->RemoveAllLogins ();
- if (NS_FAILED (rv))
- return;
-}
-
-static void
-impl_add_password (EphyPasswordManager *manager,
- EphyPasswordInfo *info)
-{
- /* unused */
-}
-
-static void
-impl_permission_manager_add (EphyPermissionManager *manager,
- const char *host,
- const char *type,
- EphyPermission permission)
-{
- /* can only set allow or deny */
- g_return_if_fail (permission != EPHY_PERMISSION_DEFAULT);
- g_return_if_fail (type != NULL && type[0] != '\0');
-
- nsCOMPtr<nsIPermissionManager> pm
- (do_GetService (NS_PERMISSIONMANAGER_CONTRACTID));
- if (!pm) return;
-
- nsCOMPtr<nsIURI> uri;
- EphyUtils::NewURI(getter_AddRefs(uri), nsCString(host));
- if (!uri) return;
-
- gboolean allow = (permission == EPHY_PERMISSION_ALLOWED);
-
- pm->Add (uri, type,
- allow ? (PRUint32) nsIPermissionManager::ALLOW_ACTION :
- (PRUint32) nsIPermissionManager::DENY_ACTION);
-}
-
-static void
-impl_permission_manager_remove (EphyPermissionManager *manager,
- const char *host,
- const char *type)
-{
- nsCOMPtr<nsIPermissionManager> pm
- (do_GetService (NS_PERMISSIONMANAGER_CONTRACTID));
- if (!pm) return;
-
- pm->Remove (nsCString (host), type);
-}
-
-static void
-impl_permission_manager_clear (EphyPermissionManager *manager)
-{
- nsCOMPtr<nsIPermissionManager> pm
- (do_GetService (NS_PERMISSIONMANAGER_CONTRACTID));
- if (!pm) return;
-
- pm->RemoveAll ();
-}
-
-EphyPermission
-impl_permission_manager_test (EphyPermissionManager *manager,
- const char *host,
- const char *type)
-{
- g_return_val_if_fail (type != NULL && type[0] != '\0', EPHY_PERMISSION_DEFAULT);
-
- nsCOMPtr<nsIPermissionManager> pm
- (do_GetService (NS_PERMISSIONMANAGER_CONTRACTID));
- if (!pm) return EPHY_PERMISSION_DEFAULT;
-
- nsCOMPtr<nsIURI> uri;
- EphyUtils::NewURI(getter_AddRefs(uri), nsCString (host));
- if (!uri) return EPHY_PERMISSION_DEFAULT;
-
- nsresult rv;
- PRUint32 action;
- rv = pm->TestPermission (uri, type, &action);
- NS_ENSURE_SUCCESS (rv, EPHY_PERMISSION_DEFAULT);
-
- EphyPermission permission;
-
- switch (action)
- {
- case nsIPermissionManager::ALLOW_ACTION:
- permission = EPHY_PERMISSION_ALLOWED;
- break;
- case nsIPermissionManager::DENY_ACTION:
- permission = EPHY_PERMISSION_DENIED;
- break;
- case nsIPermissionManager::UNKNOWN_ACTION:
- default:
- permission = EPHY_PERMISSION_DEFAULT;
- break;
- }
-
- return permission;
-}
-
-GList *
-impl_permission_manager_list (EphyPermissionManager *manager,
- const char *type)
-{
- GList *list = NULL;
-
- nsCOMPtr<nsIPermissionManager> pm
- (do_GetService (NS_PERMISSIONMANAGER_CONTRACTID));
- if (!pm) return NULL;
-
- nsCOMPtr<nsISimpleEnumerator> pe;
- pm->GetEnumerator(getter_AddRefs(pe));
- NS_ENSURE_TRUE (pe, NULL);
-
- PRBool hasMore;
- while (NS_SUCCEEDED (pe->HasMoreElements (&hasMore)) && hasMore)
- {
- nsCOMPtr<nsISupports> element;
- pe->GetNext (getter_AddRefs (element));
-
- nsCOMPtr<nsIPermission> perm (do_QueryInterface (element));
- if (!perm) continue;
-
- nsresult rv;
- nsCString str;
- rv = perm->GetType(str);
- if (NS_FAILED (rv)) continue;
-
- if (strcmp (str.get(), type) == 0)
- {
- EphyPermissionInfo *info =
- mozilla_permission_to_ephy_permission (perm);
-
- if (info != NULL)
- {
- list = g_list_prepend (list, info);
- }
- }
- }
-
- return list;
-}
-
-static GtkWidget *
-impl_open_window (EphyEmbedSingle *single,
- EphyEmbed *parent,
- const char *address,
- const char *name,
- const char *features)
-{
- nsresult rv;
- AutoJSContextStack stack;
- rv = stack.Init ();
- if (NS_FAILED (rv)) return NULL;
-
- nsCOMPtr<nsIDOMWindow> domWindow;
- if (parent)
- {
- EphyBrowser *browser;
-
- browser = (EphyBrowser *) _mozilla_embed_get_ephy_browser (MOZILLA_EMBED(parent));
- g_return_val_if_fail (browser != NULL, NULL);
-
- browser->GetDOMWindow (getter_AddRefs (domWindow));
- }
-
- nsCOMPtr<nsIWindowWatcher> wWatch(do_GetService ("@mozilla.org/embedcomp/window-watcher;1"));
- nsCOMPtr<nsIDOMWindow> newWindow;
- wWatch->OpenWindow (domWindow, address, name, features, nsnull,
- getter_AddRefs (newWindow));
-
- return EphyUtils::FindEmbed (newWindow);
-}
-
-#ifdef ENABLE_CERTIFICATE_MANAGER
-
-static gboolean
-impl_remove_certificate (EphyCertificateManager *manager,
- EphyX509Cert *cert)
-{
- nsresult rv;
-
- nsCOMPtr<nsIX509CertDB> certDB;
- certDB = do_GetService (NS_X509CERTDB_CONTRACTID);
- if (!certDB) return FALSE;
-
- nsCOMPtr<nsIX509Cert> mozCert;
- rv = mozilla_x509_cert_get_mozilla_cert (MOZILLA_X509_CERT (cert),
- getter_AddRefs (mozCert));
- if (NS_FAILED (rv)) return FALSE;
-
- rv = certDB->DeleteCertificate (mozCert);
- if (NS_FAILED (rv)) return FALSE;
-
- return TRUE;
-}
-
-#define NICK_DELIMITER PRUnichar('\001')
-
-static GList *
-retrieveCerts (PRUint32 type)
-{
- nsresult rv;
-
- nsCOMPtr<nsIX509CertDB> certDB;
- certDB = do_GetService (NS_X509CERTDB_CONTRACTID);
- if (!certDB) return NULL;
-
- PRUint32 count;
- PRUnichar **certNameList = NULL;
-
- rv = certDB->FindCertNicknames (NULL, type, &count, &certNameList);
- if (NS_FAILED (rv)) return NULL;
-
- LOG("Certificates found: %i", count);
-
- GList *list = NULL;
- for (PRUint32 i = 0; i < count; i++)
- {
- /* HACK HACK, this is EVIL, the string for each cert is:
- <DELIMITER>nicknameOrEmailAddress<DELIMITER>dbKey
- So we need to chop off the dbKey to look it up in the database.
-
- https://bugzilla.mozilla.org/show_bug.cgi?id=214742
- */
- nsCString full_string;
- NS_UTF16ToCString (nsString(certNameList[i]),
- NS_CSTRING_ENCODING_UTF8, full_string);
-
- const char *key = full_string.get();
- char *pos = strrchr (key, NICK_DELIMITER);
- if (!pos) continue;
-
- nsCOMPtr<nsIX509Cert> mozilla_cert;
- rv = certDB->FindCertByDBKey (pos, NULL, getter_AddRefs (mozilla_cert));
- if (NS_FAILED (rv)) continue;
-
- MozillaX509Cert *cert = mozilla_x509_cert_new (mozilla_cert);
- list = g_list_prepend (list, cert);
- }
-
- NS_FREE_XPCOM_ALLOCATED_POINTER_ARRAY (count, certNameList);
- return list;
-}
-
-static GList *
-impl_get_certificates (EphyCertificateManager *manager,
- EphyX509CertType type)
-{
- int moz_type = nsIX509Cert::USER_CERT;
- switch (type)
- {
- case PERSONAL_CERTIFICATE:
- moz_type = nsIX509Cert::USER_CERT;
- break;
- case SERVER_CERTIFICATE:
- moz_type = nsIX509Cert::SERVER_CERT;
- break;
- case CA_CERTIFICATE:
- moz_type = nsIX509Cert::CA_CERT;
- break;
- }
- return retrieveCerts (moz_type);
-}
-
-static gboolean
-impl_import (EphyCertificateManager *manager,
- const gchar *file)
-{
- nsresult rv;
- nsCOMPtr<nsIX509CertDB> certDB;
- certDB = do_GetService (NS_X509CERTDB_CONTRACTID);
- if (!certDB) return FALSE;
-
- nsCOMPtr<nsILocalFile> localFile;
- localFile = do_CreateInstance (NS_LOCAL_FILE_CONTRACTID);
-
- // TODO Is this correct ?
- nsString path;
- NS_CStringToUTF16 (nsCString(file),
- NS_CSTRING_ENCODING_UTF8, path);
-
-
- localFile->InitWithPath (path);
- rv = certDB->ImportPKCS12File(NULL, localFile);
- if (NS_FAILED (rv)) return FALSE;
-
- return TRUE;
-}
-
-#endif /* ENABLE_CERTIFICATE_MANAGER */
-
-static void
-mozilla_embed_single_get_property (GObject *object,
- guint prop_id,
- GValue *value,
- GParamSpec *pspec)
-{
- EphyEmbedSingle *single = EPHY_EMBED_SINGLE (object);
-
- switch (prop_id)
- {
- case PROP_NETWORK_STATUS:
- g_value_set_boolean (value, ephy_embed_single_get_network_status (single));
- break;
- }
-}
-
-static void
-mozilla_embed_single_set_property (GObject *object,
- guint prop_id,
- const GValue *value,
- GParamSpec *pspec)
-{
- EphyEmbedSingle *single = EPHY_EMBED_SINGLE (object);
-
- switch (prop_id)
- {
- case PROP_NETWORK_STATUS:
- ephy_embed_single_set_network_status (single, g_value_get_boolean (value));
- break;
- }
-}
-static void
-mozilla_embed_single_class_init (MozillaEmbedSingleClass *klass)
-{
- GObjectClass *object_class = G_OBJECT_CLASS (klass);
-
- object_class->dispose = mozilla_embed_single_dispose;
- object_class->finalize = mozilla_embed_single_finalize;
- object_class->get_property = mozilla_embed_single_get_property;
- object_class->set_property = mozilla_embed_single_set_property;
-
- g_object_class_override_property (object_class, PROP_NETWORK_STATUS, "network-status");
-
- g_type_class_add_private (object_class, sizeof (MozillaEmbedSinglePrivate));
-}
-
-static void
-ephy_embed_single_iface_init (EphyEmbedSingleIface *iface)
-{
- iface->init = impl_init;
- iface->clear_cache = impl_clear_cache;
- iface->clear_auth_cache = impl_clear_auth_cache;
- iface->set_network_status = impl_set_network_status;
- iface->get_network_status = impl_get_network_status;
- iface->get_font_list = impl_get_font_list;
- iface->open_window = impl_open_window;
- iface->get_backend_name = impl_get_backend_name;
-}
-
-static void
-ephy_cookie_manager_iface_init (EphyCookieManagerIface *iface)
-{
- iface->list = impl_list_cookies;
- iface->remove = impl_remove_cookie;
- iface->clear = impl_clear_cookies;
-}
-
-static void
-ephy_password_manager_iface_init (EphyPasswordManagerIface *iface)
-{
- iface->add = impl_add_password;
- iface->remove = impl_remove_password;
- iface->list = impl_list_passwords;
-}
-
-static void
-ephy_permission_manager_iface_init (EphyPermissionManagerIface *iface)
-{
- iface->add = impl_permission_manager_add;
- iface->remove = impl_permission_manager_remove;
- iface->clear = impl_permission_manager_clear;
- iface->test = impl_permission_manager_test;
- iface->list = impl_permission_manager_list;
-}
-
-#ifdef ENABLE_CERTIFICATE_MANAGER
-
-static void
-ephy_certificate_manager_iface_init (EphyCertificateManagerIface *iface)
-{
- iface->get_certificates = impl_get_certificates;
- iface->remove_certificate = impl_remove_certificate;
- iface->import = impl_import;
-}
-
-#endif /* ENABLE_CERTIFICATE_MANAGER */
diff --git a/embed/xulrunner/embed/mozilla-embed-single.h b/embed/xulrunner/embed/mozilla-embed-single.h
deleted file mode 100644
index 960b6eb5b..000000000
--- a/embed/xulrunner/embed/mozilla-embed-single.h
+++ /dev/null
@@ -1,57 +0,0 @@
-/*
- * Copyright © 2000-2003 Marco Pesenti Gritti
- * Copyright © 2003 Christian Persch
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#ifndef MOZILLA_EMBED_SINGLE_H
-#define MOZILLA_EMBED_SINGLE_H
-
-#include <glib-object.h>
-
-G_BEGIN_DECLS
-
-#define MOZILLA_TYPE_EMBED_SINGLE (mozilla_embed_single_get_type ())
-#define MOZILLA_EMBED_SINGLE(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), MOZILLA_TYPE_EMBED_SINGLE, MozillaEmbedSingle))
-#define MOZILLA_EMBED_SINGLE_CLASS(k) (G_TYPE_CHECK_CLASS_CAST((k), MOZILLA_TYPE_EMBED_SINGLE, MozillaEmbedSingleClass))
-#define MOZILLA_IS_EMBED_SINGLE(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), MOZILLA_TYPE_EMBED_SINGLE))
-#define MOZILLA_IS_EMBED_SINGLE_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE ((k), MOZILLA_TYPE_EMBED_SINGLE))
-#define MOZILLA_EMBED_SINGLE_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS ((o), MOZILLA_TYPE_EMBED_SINGLE, MozillaEmbedSingleClass))
-
-typedef struct MozillaEmbedSingle MozillaEmbedSingle;
-typedef struct MozillaEmbedSingleClass MozillaEmbedSingleClass;
-typedef struct MozillaEmbedSinglePrivate MozillaEmbedSinglePrivate;
-
-struct MozillaEmbedSingle
-{
- GObject parent;
-
- /*< private >*/
- MozillaEmbedSinglePrivate *priv;
-};
-
-struct MozillaEmbedSingleClass
-{
- GObjectClass parent_class;
-};
-
-GType mozilla_embed_single_get_type (void);
-
-G_END_DECLS
-
-#endif
diff --git a/embed/xulrunner/embed/mozilla-embed.cpp b/embed/xulrunner/embed/mozilla-embed.cpp
deleted file mode 100644
index 6a4aa7b48..000000000
--- a/embed/xulrunner/embed/mozilla-embed.cpp
+++ /dev/null
@@ -1,1271 +0,0 @@
-/*
- * Copyright © 2000-2004 Marco Pesenti Gritti
- * Copyright © 2003, 2004 Christian Persch
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include <nsStringGlue.h>
-
-#include <nsIDOMKeyEvent.h>
-#include <nsIDOMMouseEvent.h>
-#include <nsIRequest.h>
-#include <nsIURI.h>
-#include <nsIWebNavigation.h>
-#include <nsIWebProgressListener.h>
-#include <nsMemory.h>
-
-#include "EphyBrowser.h"
-#include "EphyUtils.h"
-#include "EventContext.h"
-
-#include "gecko-dom-event.h"
-#include "gecko-dom-event-internal.h"
-
-#include "ephy-command-manager.h"
-#include "ephy-debug.h"
-#include "ephy-embed-shell.h"
-#include "ephy-embed-single.h"
-#include "ephy-string.h"
-#include "mozilla-embed-event.h"
-
-#include "mozilla-embed.h"
-
-static void mozilla_embed_class_init (MozillaEmbedClass *klass);
-static void mozilla_embed_init (MozillaEmbed *gs);
-static void mozilla_embed_destroy (GtkObject *object);
-static void mozilla_embed_finalize (GObject *object);
-static void ephy_embed_iface_init (EphyEmbedIface *iface);
-
-static void mozilla_embed_location_changed_cb (GeckoEmbed *embed,
- MozillaEmbed *membed);
-static void mozilla_embed_net_state_all_cb (GeckoEmbed *embed,
- const char *aURI,
- gint state,
- guint status,
- MozillaEmbed *membed);
-static gboolean mozilla_embed_dom_mouse_click_cb(GeckoEmbed *embed,
- GeckoDOMEvent *dom_event,
- MozillaEmbed *membed);
-static gboolean mozilla_embed_dom_mouse_down_cb (GeckoEmbed *embed,
- GeckoDOMEvent *dom_event,
- MozillaEmbed *membed);
-static gboolean mozilla_embed_dom_key_press_cb (GeckoEmbed *embed,
- GeckoDOMEvent *dom_event,
- MozillaEmbed *membed);
-static void mozilla_embed_new_window_cb (GeckoEmbed *embed,
- GeckoEmbed **newEmbed,
- guint chrome_mask,
- MozillaEmbed *membed);
-static void mozilla_embed_security_change_cb (GeckoEmbed *embed,
- gpointer request,
- PRUint32 state,
- MozillaEmbed *membed);
-static EphyEmbedSecurityLevel mozilla_embed_security_level (PRUint32 state);
-
-#define MOZILLA_EMBED_GET_PRIVATE(object)(G_TYPE_INSTANCE_GET_PRIVATE ((object), MOZILLA_TYPE_EMBED, MozillaEmbedPrivate))
-
-typedef enum
-{
- MOZILLA_EMBED_LOAD_STARTED,
- MOZILLA_EMBED_LOAD_REDIRECTING,
- MOZILLA_EMBED_LOAD_LOADING,
- MOZILLA_EMBED_LOAD_STOPPED
-} MozillaEmbedLoadState;
-
-struct MozillaEmbedPrivate
-{
- EphyBrowser *browser;
- MozillaEmbedLoadState load_state;
-};
-
-#define WINDOWWATCHER_CONTRACTID "@mozilla.org/embedcomp/window-watcher;1"
-
-static GObjectClass *parent_class = NULL;
-
-static void
-impl_manager_do_command (EphyCommandManager *manager,
- const char *command)
-{
- MozillaEmbedPrivate *mpriv = MOZILLA_EMBED(manager)->priv;
-
- mpriv->browser->DoCommand (command);
-}
-
-static gboolean
-impl_manager_can_do_command (EphyCommandManager *manager,
- const char *command)
-{
- MozillaEmbedPrivate *mpriv = MOZILLA_EMBED(manager)->priv;
- nsresult rv;
- PRBool enabled;
-
- rv = mpriv->browser->GetCommandState (command, &enabled);
-
- return NS_SUCCEEDED (rv) ? enabled : FALSE;
-}
-
-static void
-ephy_command_manager_iface_init (EphyCommandManagerIface *iface)
-{
- iface->do_command = impl_manager_do_command;
- iface->can_do_command = impl_manager_can_do_command;
-}
-
-GType
-mozilla_embed_get_type (void)
-{
- static GType type = 0;
-
- if (G_UNLIKELY (type == 0))
- {
- const GTypeInfo our_info =
- {
- sizeof (MozillaEmbedClass),
- NULL, /* base_init */
- NULL, /* base_finalize */
- (GClassInitFunc) mozilla_embed_class_init,
- NULL,
- NULL, /* class_data */
- sizeof (MozillaEmbed),
- 0, /* n_preallocs */
- (GInstanceInitFunc) mozilla_embed_init
- };
-
- const GInterfaceInfo embed_info =
- {
- (GInterfaceInitFunc) ephy_embed_iface_init,
- NULL,
- NULL
- };
-
- const GInterfaceInfo ephy_command_manager_info =
- {
- (GInterfaceInitFunc) ephy_command_manager_iface_init,
- NULL,
- NULL
- };
-
- type = g_type_register_static (GECKO_TYPE_EMBED,
- "MozillaEmbed",
- &our_info,
- (GTypeFlags)0);
- g_type_add_interface_static (type,
- EPHY_TYPE_EMBED,
- &embed_info);
- g_type_add_interface_static (type,
- EPHY_TYPE_COMMAND_MANAGER,
- &ephy_command_manager_info);
- }
-
- return type;
-}
-
-static void
-mozilla_embed_grab_focus (GtkWidget *widget)
-{
- GtkWidget *child;
-
- child = gtk_bin_get_child (GTK_BIN (widget));
-
- if (child != NULL)
- {
- gtk_widget_grab_focus (child);
- }
- else
- {
- g_warning ("Need to realize the embed before grabbing focus!\n");
- }
-}
-
-static void
-impl_close (EphyEmbed *embed)
-{
- MozillaEmbedPrivate *mpriv = MOZILLA_EMBED (embed)->priv;
-
- mpriv->browser->Close ();
-}
-
-static void
-mozilla_embed_realize (GtkWidget *widget)
-{
- MozillaEmbedPrivate *mpriv = MOZILLA_EMBED (widget)->priv;
-
- GTK_WIDGET_CLASS (parent_class)->realize (widget);
-
- /* Initialise our helper class */
- nsresult rv;
- rv = mpriv->browser->Init (GECKO_EMBED (widget));
- if (NS_FAILED (rv))
- {
- g_warning ("EphyBrowser initialization failed for %p\n", widget);
- return;
- }
-}
-
-static GObject *
-mozilla_embed_constructor (GType type, guint n_construct_properties,
- GObjectConstructParam *construct_params)
-{
- g_object_ref (embed_shell);
-
- /* we depend on single because of mozilla initialization */
- ephy_embed_shell_get_embed_single (embed_shell);
-
- return parent_class->constructor (type, n_construct_properties,
- construct_params);
-}
-
-static void
-mozilla_embed_class_init (MozillaEmbedClass *klass)
-{
- GObjectClass *object_class = G_OBJECT_CLASS (klass);
- GtkObjectClass *gtk_object_class = GTK_OBJECT_CLASS (klass);
- GtkWidgetClass *widget_class = GTK_WIDGET_CLASS (klass);
-
- parent_class = (GObjectClass *) g_type_class_peek_parent (klass);
-
- object_class->constructor = mozilla_embed_constructor;
- object_class->finalize = mozilla_embed_finalize;
-
- gtk_object_class->destroy = mozilla_embed_destroy;
-
- widget_class->grab_focus = mozilla_embed_grab_focus;
- widget_class->realize = mozilla_embed_realize;
-
- g_type_class_add_private (object_class, sizeof(MozillaEmbedPrivate));
-}
-
-static void
-mozilla_embed_init (MozillaEmbed *embed)
-{
- embed->priv = MOZILLA_EMBED_GET_PRIVATE (embed);
- embed->priv->browser = new EphyBrowser ();
-
- g_signal_connect_object (embed, "location",
- G_CALLBACK (mozilla_embed_location_changed_cb),
- embed, (GConnectFlags) 0);
- g_signal_connect_object (embed, "net_state_all",
- G_CALLBACK (mozilla_embed_net_state_all_cb),
- embed, (GConnectFlags) 0);
- g_signal_connect_object (embed, "dom_mouse_click",
- G_CALLBACK (mozilla_embed_dom_mouse_click_cb),
- embed, (GConnectFlags) 0);
- g_signal_connect_object (embed, "dom_mouse_down",
- G_CALLBACK (mozilla_embed_dom_mouse_down_cb),
- embed, (GConnectFlags) 0);
- g_signal_connect_object (embed, "dom-key-press",
- G_CALLBACK (mozilla_embed_dom_key_press_cb),
- embed, (GConnectFlags) 0);
- g_signal_connect_object (embed, "new_window",
- G_CALLBACK (mozilla_embed_new_window_cb),
- embed, (GConnectFlags) 0);
- g_signal_connect_object (embed, "security_change",
- G_CALLBACK (mozilla_embed_security_change_cb),
- embed, (GConnectFlags) 0);
-}
-
-gpointer
-_mozilla_embed_get_ephy_browser (MozillaEmbed *embed)
-{
- g_return_val_if_fail (embed->priv->browser != NULL, NULL);
-
- return embed->priv->browser;
-}
-
-static void
-mozilla_embed_destroy (GtkObject *object)
-{
- MozillaEmbed *embed = MOZILLA_EMBED (object);
-
- if (embed->priv->browser)
- {
- embed->priv->browser->Destroy();
- }
-
- GTK_OBJECT_CLASS (parent_class)->destroy (object);
-}
-
-static void
-mozilla_embed_finalize (GObject *object)
-{
- MozillaEmbed *embed = MOZILLA_EMBED (object);
-
- if (embed->priv->browser)
- {
- delete embed->priv->browser;
- embed->priv->browser = nsnull;
- }
-
- G_OBJECT_CLASS (parent_class)->finalize (object);
-
- g_object_unref (embed_shell);
-}
-
-static void
-impl_load_url (EphyEmbed *embed,
- const char *url)
-{
- gecko_embed_load_url (GECKO_EMBED (embed), url);
-}
-
-static char * impl_get_location (EphyEmbed *embed, gboolean toplevel);
-
-static void
-impl_load (EphyEmbed *embed,
- const char *url,
- EphyEmbedLoadFlags flags,
- EphyEmbed *preview_embed)
-{
- EphyBrowser *browser;
-
- browser = MOZILLA_EMBED(embed)->priv->browser;
- g_return_if_fail (browser != NULL);
-
- nsCOMPtr<nsIURI> uri;
- if (preview_embed != NULL)
- {
- EphyBrowser *pbrowser;
-
- pbrowser = MOZILLA_EMBED(preview_embed)->priv->browser;
- if (pbrowser != NULL)
- {
- pbrowser->GetDocumentURI (getter_AddRefs (uri));
- }
- }
-
- if (flags & EPHY_EMBED_LOAD_FLAGS_ALLOW_THIRD_PARTY_FIXUP)
- {
- browser->LoadURI (url, nsIWebNavigation::LOAD_FLAGS_ALLOW_THIRD_PARTY_FIXUP, uri);
- }
- else
- {
- browser->LoadURI (url, nsIWebNavigation::LOAD_FLAGS_NONE, uri);
- }
-}
-
-static void
-impl_stop_load (EphyEmbed *embed)
-{
- gecko_embed_stop_load (GECKO_EMBED(embed));
-}
-
-static gboolean
-impl_can_go_back (EphyEmbed *embed)
-{
- return gecko_embed_can_go_back (GECKO_EMBED(embed));
-}
-
-static gboolean
-impl_can_go_forward (EphyEmbed *embed)
-{
- return gecko_embed_can_go_forward (GECKO_EMBED(embed));
-}
-
-static gboolean
-mozilla_embed_get_uri_parent (MozillaEmbed *membed,
- const char *aUri,
- nsCString &aParent)
-{
- nsresult rv;
- nsCString encoding;
- rv = membed->priv->browser->GetEncoding (encoding);
- if (NS_FAILED (rv)) return FALSE;
-
- nsCOMPtr<nsIURI> uri;
- rv = EphyUtils::NewURI (getter_AddRefs(uri), nsCString(aUri), encoding.get());
- if (NS_FAILED(rv) || !uri) return FALSE;
-
- /* Don't support going 'up' with chrome url's, mozilla handily
- * fixes them up for us, so it doesn't work properly, see
- * rdf/chrome/src/nsChromeProtocolHandler.cpp::NewURI()
- * (the Canonify() call)
- */
- nsCString scheme;
- rv = uri->GetScheme (scheme);
- if (NS_FAILED(rv) || !scheme.Length()) return FALSE;
- if (strcmp (scheme.get(), "chrome") == 0) return FALSE;
-
- nsCString path;
- rv = uri->GetPath(path);
- if (NS_FAILED(rv) || !path.Length()) return FALSE;
- if (strcmp (path.get (), "/") == 0) return FALSE;
-
- const char *slash = strrchr (path.BeginReading(), '/');
- if (!slash) return FALSE;
-
- if (slash[1] == '\0')
- {
- /* ends with a slash - a directory, go to parent */
- rv = uri->Resolve (nsCString(".."), aParent);
- }
- else
- {
- /* it's a file, go to the directory */
- rv = uri->Resolve (nsCString("."), aParent);
- }
-
- return NS_SUCCEEDED (rv);
-}
-
-static gboolean
-impl_can_go_up (EphyEmbed *embed)
-{
- MozillaEmbed *membed = MOZILLA_EMBED (embed);
- char *address;
- gboolean result;
-
- address = ephy_embed_get_location (embed, TRUE);
- if (address == NULL) return FALSE;
-
- nsCString parent;
- result = mozilla_embed_get_uri_parent (membed, address, parent);
- g_free (address);
-
- return result;
-}
-
-static GSList *
-impl_get_go_up_list (EphyEmbed *embed)
-{
- MozillaEmbed *membed = MOZILLA_EMBED (embed);
- GSList *l = NULL;
- char *address, *s;
-
- address = ephy_embed_get_location (embed, TRUE);
- if (address == NULL) return NULL;
-
- s = address;
- nsCString parent;
- while (mozilla_embed_get_uri_parent (membed, s, parent))
- {
- s = g_strdup (parent.get());
- l = g_slist_prepend (l, s);
- }
-
- g_free (address);
-
- return g_slist_reverse (l);
-}
-
-static void
-impl_go_back (EphyEmbed *embed)
-{
- gecko_embed_go_back (GECKO_EMBED(embed));
-}
-
-static void
-impl_go_forward (EphyEmbed *embed)
-{
- gecko_embed_go_forward (GECKO_EMBED(embed));
-}
-
-static void
-impl_go_up (EphyEmbed *embed)
-{
- MozillaEmbed *membed = MOZILLA_EMBED (embed);
- char *uri;
-
- uri = ephy_embed_get_location (embed, TRUE);
- if (uri == NULL) return;
-
- gboolean rv;
- nsCString parent_uri;
- rv = mozilla_embed_get_uri_parent (membed, uri, parent_uri);
- g_free (uri);
-
- g_return_if_fail (rv != FALSE);
-
- ephy_embed_load_url (embed, parent_uri.get ());
-}
-
-static char *
-impl_get_title (EphyEmbed *embed)
-{
- return gecko_embed_get_title (GECKO_EMBED (embed));
-}
-
-static char *
-impl_get_link_message (EphyEmbed *embed)
-{
- return gecko_embed_get_link_message (GECKO_EMBED (embed));
-}
-
-static char *
-impl_get_js_status (EphyEmbed *embed)
-{
- return gecko_embed_get_js_status (GECKO_EMBED (embed));
-}
-
-static char *
-impl_get_location (EphyEmbed *embed,
- gboolean toplevel)
-{
- MozillaEmbedPrivate *mpriv = MOZILLA_EMBED(embed)->priv;
- nsresult rv;
-
- nsCOMPtr<nsIURI> uri;
- if (toplevel)
- {
- rv = mpriv->browser->GetDocumentURI (getter_AddRefs (uri));
- }
- else
- {
- rv = mpriv->browser->GetTargetDocumentURI (getter_AddRefs (uri));
- }
-
- if (NS_FAILED (rv)) return NULL;
-
- nsCOMPtr<nsIURI> furi;
- rv = uri->Clone (getter_AddRefs (furi));
- /* Some nsIURI impls return NS_OK even though they didn't put anything in the outparam!! */
- if (NS_FAILED (rv) || !furi) furi.swap(uri);
-
- /* Hide password part */
- nsCString user;
- furi->GetUsername (user);
- furi->SetUserPass (user);
-
- nsCString url;
- furi->GetSpec (url);
-
- return url.Length() ? g_strdup (url.get()) : NULL;
-}
-
-static void
-impl_reload (EphyEmbed *embed,
- gboolean force)
-{
- guint32 mflags = GECKO_EMBED_FLAG_RELOADNORMAL;
-
- if (force)
- {
- mflags = GECKO_EMBED_FLAG_RELOADBYPASSPROXYANDCACHE;
- }
-
- gecko_embed_reload (GECKO_EMBED(embed), mflags);
-}
-
-static void
-impl_set_zoom (EphyEmbed *embed,
- float zoom)
-{
- EphyBrowser *browser;
- nsresult rv;
-
- g_return_if_fail (zoom > 0.0);
-
- browser = MOZILLA_EMBED(embed)->priv->browser;
- g_return_if_fail (browser != NULL);
-
- rv = browser->SetZoom (zoom);
-
- if (NS_SUCCEEDED (rv))
- {
- g_signal_emit_by_name (embed, "ge_zoom_change", zoom);
- }
-}
-
-static float
-impl_get_zoom (EphyEmbed *embed)
-{
- MozillaEmbedPrivate *mpriv = MOZILLA_EMBED(embed)->priv;
- float f;
-
- nsresult rv;
- rv = mpriv->browser->GetZoom (&f);
-
- if (NS_SUCCEEDED (rv))
- {
- return f;
- }
-
- return 1.0;
-}
-
-static void
-impl_scroll_lines (EphyEmbed *embed,
- int num_lines)
-{
- MozillaEmbedPrivate *mpriv = MOZILLA_EMBED(embed)->priv;
-
- mpriv->browser->ScrollLines (num_lines);
-}
-
-static void
-impl_scroll_pages (EphyEmbed *embed,
- int num_pages)
-{
- MozillaEmbedPrivate *mpriv = MOZILLA_EMBED(embed)->priv;
-
- mpriv->browser->ScrollPages (num_pages);
-}
-
-static void
-impl_scroll_pixels (EphyEmbed *embed,
- int dx,
- int dy)
-{
- MozillaEmbedPrivate *mpriv = MOZILLA_EMBED(embed)->priv;
-
- mpriv->browser->ScrollPixels (dx, dy);
-}
-
-static int
-impl_shistory_n_items (EphyEmbed *embed)
-{
- MozillaEmbedPrivate *mpriv = MOZILLA_EMBED(embed)->priv;
- nsresult rv;
- int count, index;
-
- rv = mpriv->browser->GetSHInfo (&count, &index);
-
- return NS_SUCCEEDED(rv) ? count : 0;
-}
-
-static void
-impl_shistory_get_nth (EphyEmbed *embed,
- int nth,
- gboolean is_relative,
- char **aUrl,
- char **aTitle)
-{
- nsresult rv;
- nsCString url;
- PRUnichar *title;
- MozillaEmbedPrivate *mpriv = MOZILLA_EMBED(embed)->priv;
-
- if (is_relative)
- {
- nth += ephy_embed_shistory_get_pos (embed);
- }
-
- rv = mpriv->browser->GetSHUrlAtIndex(nth, url);
-
- *aUrl = (NS_SUCCEEDED (rv) && url.Length()) ? g_strdup(url.get()) : NULL;
-
- rv = mpriv->browser->GetSHTitleAtIndex(nth, &title);
-
- if (title)
- {
- nsCString cTitle;
- NS_UTF16ToCString (nsString(title),
- NS_CSTRING_ENCODING_UTF8, cTitle);
- *aTitle = g_strdup (cTitle.get());
- nsMemory::Free (title);
- }
- else
- {
- *aTitle = NULL;
- }
-}
-
-static int
-impl_shistory_get_pos (EphyEmbed *embed)
-{
- MozillaEmbedPrivate *mpriv = MOZILLA_EMBED(embed)->priv;
- nsresult rv;
- int count, index;
-
- rv = mpriv->browser->GetSHInfo (&count, &index);
-
- return NS_SUCCEEDED(rv) ? index : 0;
-}
-
-static void
-impl_shistory_go_nth (EphyEmbed *embed,
- int nth)
-{
- MozillaEmbedPrivate *mpriv = MOZILLA_EMBED(embed)->priv;
-
- mpriv->browser->GoToHistoryIndex (nth);
-}
-
-static void
-impl_shistory_copy (EphyEmbed *source,
- EphyEmbed *dest,
- gboolean copy_back,
- gboolean copy_forward,
- gboolean copy_current)
-{
- MozillaEmbedPrivate *spriv = MOZILLA_EMBED(source)->priv;
- MozillaEmbedPrivate *dpriv = MOZILLA_EMBED(dest)->priv;
-
- spriv->browser->CopySHistory(dpriv->browser, copy_back,
- copy_forward, copy_current);
-}
-
-static void
-impl_get_security_level (EphyEmbed *embed,
- EphyEmbedSecurityLevel *level,
- char **description)
-{
- MozillaEmbedPrivate *mpriv = MOZILLA_EMBED (embed)->priv;
-
- if (level) *level = EPHY_EMBED_STATE_IS_UNKNOWN;
- if (description) *description = NULL;
-
- nsresult rv;
- PRUint32 state;
- nsCString desc;
- rv = mpriv->browser->GetSecurityInfo (&state, desc);
- if (NS_FAILED (rv)) return;
-
- if (level) *level = mozilla_embed_security_level (state);
- if (description) *description = g_strdup (desc.get());
-}
-
-static void
-impl_show_page_certificate (EphyEmbed *embed)
-{
- MozillaEmbedPrivate *mpriv = MOZILLA_EMBED (embed)->priv;
-
- mpriv->browser->ShowCertificate ();
-}
-
-static void
-impl_print (EphyEmbed *embed)
-{
- MozillaEmbedPrivate *mpriv = MOZILLA_EMBED(embed)->priv;
-
- mpriv->browser->Print ();
-}
-
-static void
-impl_set_print_preview_mode (EphyEmbed *embed, gboolean preview_mode)
-{
- MozillaEmbedPrivate *mpriv = MOZILLA_EMBED(embed)->priv;
-
- mpriv->browser->SetPrintPreviewMode (preview_mode);
-}
-
-static int
-impl_print_preview_n_pages (EphyEmbed *embed)
-{
- MozillaEmbedPrivate *mpriv = MOZILLA_EMBED(embed)->priv;
- nsresult rv;
- int num;
-
- rv = mpriv->browser->PrintPreviewNumPages(&num);
-
- return NS_SUCCEEDED (rv) ? num : 0;
-}
-
-static void
-impl_print_preview_navigate (EphyEmbed *embed,
- EphyEmbedPrintPreviewNavType type,
- int page)
-{
- MozillaEmbedPrivate *mpriv = MOZILLA_EMBED(embed)->priv;
-
- mpriv->browser->PrintPreviewNavigate(type, page);
-}
-
-static void
-impl_set_encoding (EphyEmbed *embed,
- const char *encoding)
-{
- MozillaEmbedPrivate *mpriv = MOZILLA_EMBED(embed)->priv;
- nsresult rv;
- nsCString currEnc;
-
- g_return_if_fail (encoding != NULL);
-
- rv = mpriv->browser->GetEncoding (currEnc);
- if (NS_FAILED (rv)) return;
-
- if (strcmp (currEnc.get(), encoding) != 0 ||
- encoding[0] == '\0' && !ephy_embed_has_automatic_encoding (embed))
- {
- rv = mpriv->browser->ForceEncoding (encoding);
- if (NS_FAILED (rv)) return;
- }
-
- gecko_embed_reload (GECKO_EMBED (embed),
- GECKO_EMBED_FLAG_RELOADCHARSETCHANGE);
-}
-
-static char *
-impl_get_encoding (EphyEmbed *embed)
-{
- MozillaEmbedPrivate *mpriv = MOZILLA_EMBED(embed)->priv;
- nsresult rv;
- nsCString encoding;
-
- rv = mpriv->browser->GetEncoding (encoding);
-
- if (NS_FAILED (rv) || !encoding.Length())
- {
- return NULL;
- }
-
- return g_strdup (encoding.get());
-}
-
-static gboolean
-impl_has_automatic_encoding (EphyEmbed *embed)
-{
- MozillaEmbedPrivate *mpriv = MOZILLA_EMBED(embed)->priv;
- nsresult rv;
- nsCString encoding;
-
- rv = mpriv->browser->GetForcedEncoding (encoding);
-
- if (NS_FAILED (rv) || !encoding.Length())
- {
- return TRUE;
- }
-
- return FALSE;
-}
-
-static gboolean
-impl_has_modified_forms (EphyEmbed *embed)
-{
- MozillaEmbedPrivate *mpriv = MOZILLA_EMBED(embed)->priv;
- nsresult rv;
-
- PRBool modified;
- rv = mpriv->browser->GetHasModifiedForms (&modified);
-
- return NS_SUCCEEDED (rv) ? modified : FALSE;
-}
-
-static void
-mozilla_embed_location_changed_cb (GeckoEmbed *embed,
- MozillaEmbed *membed)
-{
- char *location;
-
- location = gecko_embed_get_location (embed);
- g_signal_emit_by_name (membed, "ge-location", location);
- g_free (location);
-}
-
-static void
-update_load_state (MozillaEmbed *membed, gint state)
-{
- MozillaEmbedPrivate *priv = membed->priv;
-
- if (state & GECKO_EMBED_FLAG_IS_DOCUMENT &&
- state & (GECKO_EMBED_FLAG_START | GECKO_EMBED_FLAG_STOP))
- {
- g_signal_emit_by_name (membed, "ge-document-type",
- priv->browser->GetDocumentType ());
- }
-
- if (state & GECKO_EMBED_FLAG_RESTORING &&
- priv->load_state == MOZILLA_EMBED_LOAD_STARTED)
- {
- priv->load_state = MOZILLA_EMBED_LOAD_LOADING;
-
- char *address;
- address = gecko_embed_get_location (GECKO_EMBED (membed));
- g_signal_emit_by_name (membed, "ge-content-change", address);
- g_free (address);
- }
-
- if (state & GECKO_EMBED_FLAG_IS_NETWORK)
- {
- if (state & GECKO_EMBED_FLAG_START)
- {
- priv->load_state = MOZILLA_EMBED_LOAD_STARTED;
- }
- else if (state & GECKO_EMBED_FLAG_STOP)
- {
- priv->load_state = MOZILLA_EMBED_LOAD_STOPPED;
- }
- }
- else if (state & GECKO_EMBED_FLAG_START &&
- state & GECKO_EMBED_FLAG_IS_REQUEST)
- {
- if (priv->load_state == MOZILLA_EMBED_LOAD_REDIRECTING)
- {
- priv->load_state = MOZILLA_EMBED_LOAD_STARTED;
- }
- else if (priv->load_state != MOZILLA_EMBED_LOAD_LOADING)
- {
- priv->load_state = MOZILLA_EMBED_LOAD_LOADING;
-
- char *address;
- address = gecko_embed_get_location (GECKO_EMBED (membed));
- g_signal_emit_by_name (membed, "ge_content_change", address);
- g_free (address);
- }
- }
- else if (state & GECKO_EMBED_FLAG_REDIRECTING &&
- priv->load_state == MOZILLA_EMBED_LOAD_STARTED)
- {
- priv->load_state = MOZILLA_EMBED_LOAD_REDIRECTING;
- }
-}
-
-static void
-mozilla_embed_net_state_all_cb (GeckoEmbed *embed, const char *aURI,
- gint state, guint status,
- MozillaEmbed *membed)
-{
- EphyEmbedNetState estate = EPHY_EMBED_STATE_UNKNOWN;
- int i;
-
- struct
- {
- guint state;
- EphyEmbedNetState embed_state;
- }
- conversion_map [] =
- {
- { GECKO_EMBED_FLAG_START, EPHY_EMBED_STATE_START },
- { GECKO_EMBED_FLAG_STOP, EPHY_EMBED_STATE_STOP },
- { GECKO_EMBED_FLAG_REDIRECTING, EPHY_EMBED_STATE_REDIRECTING },
- { GECKO_EMBED_FLAG_TRANSFERRING, EPHY_EMBED_STATE_TRANSFERRING },
- { GECKO_EMBED_FLAG_NEGOTIATING, EPHY_EMBED_STATE_NEGOTIATING },
- { GECKO_EMBED_FLAG_IS_REQUEST, EPHY_EMBED_STATE_IS_REQUEST },
- { GECKO_EMBED_FLAG_IS_DOCUMENT, EPHY_EMBED_STATE_IS_DOCUMENT },
- { GECKO_EMBED_FLAG_IS_NETWORK, EPHY_EMBED_STATE_IS_NETWORK },
- { GECKO_EMBED_FLAG_RESTORING, EPHY_EMBED_STATE_RESTORING },
- { 0, EPHY_EMBED_STATE_UNKNOWN }
- };
-
- for (i = 0; conversion_map[i].state != 0; i++)
- {
- if (state & conversion_map[i].state)
- {
- estate = (EphyEmbedNetState) (estate | conversion_map[i].embed_state);
- }
- }
-
- update_load_state (membed, state);
-
- g_signal_emit_by_name (membed, "ge_net_state", aURI, /* FIXME: (gulong) */ estate);
-}
-
-static gboolean
-mozilla_embed_emit_mouse_signal (MozillaEmbed *embed,
- GeckoDOMEvent *dom_event,
- const char *signal_name)
-{
- MozillaEmbedPrivate *mpriv = embed->priv;
- MozillaEmbedEvent *info;
- EventContext event_context;
- gint return_value = FALSE;
- nsresult rv;
-
- if (dom_event == NULL) return FALSE;
-
- nsCOMPtr<nsIDOMEvent> domEvent (gecko_dom_event_get_I (dom_event));
- nsCOMPtr<nsIDOMMouseEvent> ev (do_QueryInterface (domEvent));
- NS_ENSURE_TRUE (ev, FALSE);
- nsCOMPtr<nsIDOMEvent> dev = do_QueryInterface (ev);
- NS_ENSURE_TRUE (dev, FALSE);
-
- info = mozilla_embed_event_new (static_cast<gpointer>(dev));
-
- event_context.Init (mpriv->browser);
- rv = event_context.GetMouseEventInfo (ev, MOZILLA_EMBED_EVENT (info));
- if (NS_FAILED (rv))
- {
- g_object_unref (info);
- return FALSE;
- }
-
- nsCOMPtr<nsIDOMDocument> domDoc;
- rv = event_context.GetTargetDocument (getter_AddRefs(domDoc));
- if (NS_SUCCEEDED (rv))
- {
- mpriv->browser->PushTargetDocument (domDoc);
-
- g_signal_emit_by_name (embed, signal_name,
- info, &return_value);
- mpriv->browser->PopTargetDocument ();
- }
-
- g_object_unref (info);
-
- return return_value;
-}
-
-static gboolean
-mozilla_embed_dom_mouse_click_cb (GeckoEmbed *embed,
- GeckoDOMEvent *dom_event,
- MozillaEmbed *membed)
-{
- return mozilla_embed_emit_mouse_signal (membed, dom_event,
- "ge_dom_mouse_click");
-}
-
-static gboolean
-mozilla_embed_dom_mouse_down_cb (GeckoEmbed *embed,
- GeckoDOMEvent *dom_event,
- MozillaEmbed *membed)
-{
- return mozilla_embed_emit_mouse_signal (membed, dom_event,
- "ge_dom_mouse_down");
-}
-
-static gint
-mozilla_embed_dom_key_press_cb (GeckoEmbed *embed,
- GeckoDOMEvent *dom_event,
- MozillaEmbed *membed)
-{
- gint retval = FALSE;
-
- if (dom_event == NULL) return FALSE;
-
- nsCOMPtr<nsIDOMEvent> domEvent (gecko_dom_event_get_I (dom_event));
- nsCOMPtr<nsIDOMKeyEvent> ev (do_QueryInterface (domEvent));
- NS_ENSURE_TRUE (ev, FALSE);
-
- if (!EventContext::CheckKeyPress (ev)) return FALSE;
-
- GdkEvent *event = gtk_get_current_event ();
- if (event == NULL) return FALSE; /* shouldn't happen! */
-
- g_return_val_if_fail (GDK_KEY_PRESS == event->type, FALSE);
-
- g_signal_emit_by_name (embed, "ge-search-key-press", event, &retval);
-
- gdk_event_free (event);
-
- return retval;
-}
-
-EphyEmbedChrome
-_mozilla_embed_translate_chrome (GeckoEmbedChromeFlags flags)
-{
- static const struct
- {
- guint mozilla_flag;
- guint ephy_flag;
- }
- conversion_map [] =
- {
- { GECKO_EMBED_FLAG_MENUBARON, EPHY_EMBED_CHROME_MENUBAR },
- { GECKO_EMBED_FLAG_TOOLBARON, EPHY_EMBED_CHROME_TOOLBAR },
- { GECKO_EMBED_FLAG_STATUSBARON, EPHY_EMBED_CHROME_STATUSBAR },
- { GECKO_EMBED_FLAG_PERSONALTOOLBARON, EPHY_EMBED_CHROME_BOOKMARKSBAR },
- };
-
- guint mask = 0, i;
-
- for (i = 0; i < G_N_ELEMENTS (conversion_map); i++)
- {
- if (flags & conversion_map[i].mozilla_flag)
- {
- mask |= conversion_map[i].ephy_flag;
- }
- }
-
- return (EphyEmbedChrome) mask;
-}
-
-static void
-mozilla_embed_new_window_cb (GeckoEmbed *embed,
- GeckoEmbed **newEmbed,
- guint chrome_mask,
- MozillaEmbed *membed)
-{
- GeckoEmbedChromeFlags chrome = (GeckoEmbedChromeFlags) chrome_mask;
- EphyEmbed *new_embed = NULL;
- GObject *single;
- EphyEmbedChrome mask;
-
- if (chrome & GECKO_EMBED_FLAG_OPENASCHROME)
- {
- *newEmbed = _mozilla_embed_new_xul_dialog ();
- return;
- }
-
- mask = _mozilla_embed_translate_chrome (chrome);
-
- single = ephy_embed_shell_get_embed_single (embed_shell);
- g_signal_emit_by_name (single, "new-window", embed, mask,
- &new_embed);
-
- g_assert (new_embed != NULL);
-
- gecko_embed_set_chrome_mask (GECKO_EMBED (new_embed), chrome);
-
- g_signal_emit_by_name (membed, "ge-new-window", new_embed);
-
- *newEmbed = GECKO_EMBED (new_embed);
-}
-
-static void
-mozilla_embed_security_change_cb (GeckoEmbed *embed,
- gpointer requestptr,
- PRUint32 state,
- MozillaEmbed *membed)
-{
- g_signal_emit_by_name (membed, "ge_security_change",
- mozilla_embed_security_level (state));
-}
-
-static EphyEmbedSecurityLevel
-mozilla_embed_security_level (PRUint32 state)
-{
- EphyEmbedSecurityLevel level;
-
- switch (state)
- {
- case nsIWebProgressListener::STATE_IS_INSECURE:
- level = EPHY_EMBED_STATE_IS_INSECURE;
- break;
- case nsIWebProgressListener::STATE_IS_BROKEN:
- level = EPHY_EMBED_STATE_IS_BROKEN;
- break;
- case nsIWebProgressListener::STATE_IS_SECURE|
- nsIWebProgressListener::STATE_SECURE_HIGH:
- level = EPHY_EMBED_STATE_IS_SECURE_HIGH;
- break;
- case nsIWebProgressListener::STATE_IS_SECURE|
- nsIWebProgressListener::STATE_SECURE_MED:
- level = EPHY_EMBED_STATE_IS_SECURE_MED;
- break;
- case nsIWebProgressListener::STATE_IS_SECURE|
- nsIWebProgressListener::STATE_SECURE_LOW:
- level = EPHY_EMBED_STATE_IS_SECURE_LOW;
- break;
- default:
- level = EPHY_EMBED_STATE_IS_UNKNOWN;
- break;
- }
- return level;
-}
-
-static void
-ephy_embed_iface_init (EphyEmbedIface *iface)
-{
- iface->load_url = impl_load_url;
- iface->load = impl_load;
- iface->stop_load = impl_stop_load;
- iface->can_go_back = impl_can_go_back;
- iface->can_go_forward =impl_can_go_forward;
- iface->can_go_up = impl_can_go_up;
- iface->get_go_up_list = impl_get_go_up_list;
- iface->go_back = impl_go_back;
- iface->go_forward = impl_go_forward;
- iface->go_up = impl_go_up;
- iface->get_title = impl_get_title;
- iface->get_location = impl_get_location;
- iface->get_link_message = impl_get_link_message;
- iface->get_js_status = impl_get_js_status;
- iface->reload = impl_reload;
- iface->set_zoom = impl_set_zoom;
- iface->get_zoom = impl_get_zoom;
- iface->scroll_lines = impl_scroll_lines;
- iface->scroll_pages = impl_scroll_pages;
- iface->scroll_pixels = impl_scroll_pixels;
- iface->shistory_n_items = impl_shistory_n_items;
- iface->shistory_get_nth = impl_shistory_get_nth;
- iface->shistory_get_pos = impl_shistory_get_pos;
- iface->shistory_go_nth = impl_shistory_go_nth;
- iface->shistory_copy = impl_shistory_copy;
- iface->get_security_level = impl_get_security_level;
- iface->show_page_certificate = impl_show_page_certificate;
- iface->close = impl_close;
- iface->set_encoding = impl_set_encoding;
- iface->get_encoding = impl_get_encoding;
- iface->has_automatic_encoding = impl_has_automatic_encoding;
- iface->print = impl_print;
- iface->set_print_preview_mode = impl_set_print_preview_mode;
- iface->print_preview_n_pages = impl_print_preview_n_pages;
- iface->print_preview_navigate = impl_print_preview_navigate;
- iface->has_modified_forms = impl_has_modified_forms;
-}
-
-static void
-xul_visibility_cb (GtkWidget *embed, gboolean visibility, GtkWidget *window)
-{
- if (visibility)
- {
- gtk_widget_show (window);
- }
- else
- {
- gtk_widget_hide (window);
- }
-}
-
-static void
-xul_size_to_cb (GtkWidget *embed, gint width, gint height, gpointer dummy)
-{
- gtk_widget_set_size_request (embed, width, height);
-}
-
-static void
-xul_new_window_cb (GeckoEmbed *embed,
- GeckoEmbed **retval,
- guint chrome_mask,
- gpointer dummy)
-{
- g_assert (chrome_mask & GECKO_EMBED_FLAG_OPENASCHROME);
-
- *retval = _mozilla_embed_new_xul_dialog ();
-}
-
-static void
-xul_title_cb (GeckoEmbed *embed,
- GtkWindow *window)
-{
- char *title;
-
- title = gecko_embed_get_title (embed);
- gtk_window_set_title (window, title);
- g_free (title);
-}
-
-GeckoEmbed *
-_mozilla_embed_new_xul_dialog (void)
-{
- GtkWidget *window, *embed;
-
- g_object_ref (embed_shell);
-
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
- g_object_set_data_full (G_OBJECT (window), "EmbedShellRef",
- embed_shell,
- (GDestroyNotify) g_object_unref);
- g_signal_connect_object (embed_shell, "prepare_close",
- G_CALLBACK (gtk_widget_destroy), window,
- (GConnectFlags) G_CONNECT_SWAPPED);
-
- embed = gecko_embed_new ();
- gtk_widget_show (embed);
- gtk_container_add (GTK_CONTAINER (window), embed);
-
- g_signal_connect_object (embed, "destroy_browser",
- G_CALLBACK (gtk_widget_destroy),
- window, G_CONNECT_SWAPPED);
- g_signal_connect_object (embed, "visibility",
- G_CALLBACK (xul_visibility_cb),
- window, (GConnectFlags) 0);
- g_signal_connect_object (embed, "size_to",
- G_CALLBACK (xul_size_to_cb),
- NULL, (GConnectFlags) 0);
- g_signal_connect_object (embed, "new_window",
- G_CALLBACK (xul_new_window_cb),
- NULL, (GConnectFlags) 0);
- g_signal_connect_object (embed, "title",
- G_CALLBACK (xul_title_cb),
- window, (GConnectFlags) 0);
-
- return GECKO_EMBED (embed);
-}
diff --git a/embed/xulrunner/embed/mozilla-embed.h b/embed/xulrunner/embed/mozilla-embed.h
deleted file mode 100644
index be03cd6c3..000000000
--- a/embed/xulrunner/embed/mozilla-embed.h
+++ /dev/null
@@ -1,66 +0,0 @@
-/*
- * Copyright © 2000-2004 Marco Pesenti Gritti
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#ifndef MOZILLA_EMBED_H
-#define MOZILLA_EMBED_H
-
-#include <glib.h>
-#include <glib-object.h>
-
-#include "gecko-embed.h"
-#include "gecko-embed-types.h"
-
-#include "ephy-embed.h"
-
-G_BEGIN_DECLS
-
-#define MOZILLA_TYPE_EMBED (mozilla_embed_get_type ())
-#define MOZILLA_EMBED(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), MOZILLA_TYPE_EMBED, MozillaEmbed))
-#define MOZILLA_EMBED_CLASS(k) (G_TYPE_CHECK_CLASS_CAST((k), MOZILLA_TYPE_EMBED, MozillaEmbedClass))
-#define MOZILLA_IS_EMBED(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), MOZILLA_TYPE_EMBED))
-#define MOZILLA_IS_EMBED_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE ((k), MOZILLA_TYPE_EMBED))
-#define MOZILLA_EMBED_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS ((o), MOZILLA_TYPE_EMBED, MozillaEmbedClass))
-
-typedef struct MozillaEmbed MozillaEmbed;
-typedef struct MozillaEmbedPrivate MozillaEmbedPrivate;
-
-struct MozillaEmbed
-{
- GeckoEmbed parent_instance;
-
- /*< private >*/
- MozillaEmbedPrivate *priv;
-};
-
-typedef GeckoEmbedClass MozillaEmbedClass;
-
-GType mozilla_embed_get_type (void);
-
-/* The following are private to the embed implementation */
-
-gpointer _mozilla_embed_get_ephy_browser (MozillaEmbed *embed);
-
-GeckoEmbed *_mozilla_embed_new_xul_dialog (void);
-
-EphyEmbedChrome _mozilla_embed_translate_chrome (GeckoEmbedChromeFlags flags);
-
-G_END_DECLS
-
-#endif
diff --git a/embed/xulrunner/embed/mozilla-notifiers.cpp b/embed/xulrunner/embed/mozilla-notifiers.cpp
deleted file mode 100644
index fbd8dd766..000000000
--- a/embed/xulrunner/embed/mozilla-notifiers.cpp
+++ /dev/null
@@ -1,1257 +0,0 @@
-/*
-* Copyright © 2000 Nate Case
-* Copyright © 2000-2004 Marco Pesenti Gritti
-* Copyright © 2003, 2004 Christian Persch
-*
-* 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
-*
-* $Id$
-*/
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include <stdio.h>
-#include <stdlib.h>
-#include <string.h>
-
-#include <glib/gi18n.h>
-#include <gdk/gdkx.h>
-#include <gtk/gtksettings.h>
-
-#include <nsCOMPtr.h>
-#include <nsIPrefService.h>
-#include <nsIServiceManager.h>
-#include <nsMemory.h>
-#include <nsServiceManagerUtils.h>
-
-#include "eel-gconf-extensions.h"
-#include "ephy-debug.h"
-#include "ephy-embed-prefs.h"
-#include "ephy-embed-shell.h"
-#include "ephy-encodings.h"
-#include "ephy-langs.h"
-#include "ephy-node.h"
-#include "ephy-prefs.h"
-
-#include "mozilla-notifiers.h"
-
-/* define to migrate epiphany 1.0 font preferences */
-#define MIGRATE_PIXEL_SIZE
-
-#define MAX_FONT_SIZE 128
-
-/* Keeps the list of the notifiers we installed for mozilla prefs */
-/* to be able to remove them when exiting */
-static GList *notifiers = NULL;
-static nsIPrefBranch *gPrefBranch;
-
-typedef struct
-{
- char *gconf_key;
- char *mozilla_pref;
- PrefValueTransformFunc func;
- gpointer user_data;
- guint cnxn_id;
-} PrefData;
-
-static void
-free_pref_data (PrefData *data)
-{
- g_free (data->gconf_key);
- g_free (data->mozilla_pref);
-
- g_slice_free (PrefData, data);
-}
-
-static gboolean
-transform_accept_languages_list (GConfEntry *gcentry,
- GValue *value,
- gpointer user_data)
-{
- GConfValue *gcvalue;
- GArray *array;
- GSList *languages, *l;
- char **langs;
-
- gcvalue = gconf_entry_get_value (gcentry);
- if (gcvalue == NULL ||
- gcvalue->type != GCONF_VALUE_LIST ||
- gconf_value_get_list_type (gcvalue) != GCONF_VALUE_STRING) return FALSE;
-
- languages = gconf_value_get_list (gcvalue);
-
- array = g_array_new (TRUE, FALSE, sizeof (char *));
-
- for (l = languages; l != NULL; l = l->next)
- {
- const char *lang;
-
- lang = gconf_value_get_string ((GConfValue *) l->data);
-
- if (lang != NULL && strcmp (lang, "system") == 0)
- {
- ephy_langs_append_languages (array);
- }
- else if (lang != NULL && lang[0] != '\0')
- {
- char *str;
- str = g_ascii_strdown (lang, -1);
- g_array_append_val (array, str);
- }
- }
-
- ephy_langs_sanitise (array);
-
- langs = (char **) g_array_free (array, FALSE);
-
- g_value_init (value, G_TYPE_STRING);
- g_value_take_string (value, g_strjoinv (",", langs));
-
- g_strfreev (langs);
-
- return TRUE;
-}
-
-static gboolean
-transform_cache_size (GConfEntry *gcentry,
- GValue *value,
- gpointer user_data)
-{
- GConfValue *gcvalue;
-
- gcvalue = gconf_entry_get_value (gcentry);
- if (gcvalue == NULL ||
- gcvalue->type != GCONF_VALUE_INT) return FALSE;
-
- g_value_init (value, G_TYPE_INT);
- g_value_set_int (value, gconf_value_get_int (gcvalue) * 1024);
-
- return TRUE;
-}
-
-static gboolean
-transform_cookies_accept_mode (GConfEntry *gcentry,
- GValue *value,
- gpointer user_data)
-
-{
- GConfValue *gcvalue;
- const char *mode;
- int mozilla_mode = 0;
-
- gcvalue = gconf_entry_get_value (gcentry);
- if (gcvalue == NULL ||
- gcvalue->type != GCONF_VALUE_STRING) return FALSE;
-
- mode = gconf_value_get_string (gcvalue);
- if (mode == NULL) return FALSE;
-
- if (strcmp (mode, "anywhere") == 0)
- {
- mozilla_mode = 0;
- }
- else if (strcmp (mode, "current site") == 0)
- {
- mozilla_mode = 1;
- }
- else if (strcmp (mode, "nowhere") == 0)
- {
- mozilla_mode = 2;
- }
-
- g_value_init (value, G_TYPE_INT);
- g_value_set_int (value, mozilla_mode);
-
- return TRUE;
-}
-
-static gboolean
-transform_encoding (GConfEntry *gcentry,
- GValue *value,
- gpointer user_data)
-{
- GConfValue *gcvalue;
- EphyEncodings *encodings;
- EphyNode *node;
- const char *code;
- gboolean is_autodetector;
-
- gcvalue = gconf_entry_get_value (gcentry);
- if (gcvalue == NULL ||
- gcvalue->type != GCONF_VALUE_STRING) return FALSE;
-
- code = gconf_value_get_string (gcvalue);
- if (code == NULL) return FALSE;
-
- encodings = EPHY_ENCODINGS (ephy_embed_shell_get_encodings (embed_shell));
- node = ephy_encodings_get_node (encodings, code, FALSE);
- if (node == NULL) return FALSE;
-
- is_autodetector = ephy_node_get_property_boolean (node, EPHY_NODE_ENCODING_PROP_IS_AUTODETECTOR);
- if (is_autodetector != GPOINTER_TO_INT (user_data)) return FALSE;
-
- g_value_init (value, G_TYPE_STRING);
- g_value_set_string (value, code);
-
- return TRUE;
-}
-
-static gboolean
-transform_image_animation_mode (GConfEntry *gcentry,
- GValue *value,
- gpointer user_data)
-
-{
- GConfValue *gcvalue;
- const char *mode;
-
- gcvalue = gconf_entry_get_value (gcentry);
- if (gcvalue == NULL ||
- gcvalue->type != GCONF_VALUE_STRING) return FALSE;
-
- mode = gconf_value_get_string (gcvalue);
- if (mode == NULL) return FALSE;
-
- if (strcmp (mode, "disabled") == 0)
- {
- mode = "none";
- }
-
- g_value_init (value, G_TYPE_STRING);
- g_value_set_string (value, mode);
-
- return TRUE;
-}
-
-static gboolean
-transform_proxy_ignore_list (GConfEntry *gcentry,
- GValue *value,
- gpointer user_data)
-{
- GConfValue *gcvalue;
- GArray *array;
- GSList *hosts, *l;
- char **strings;
-
- gcvalue = gconf_entry_get_value (gcentry);
- if (gcvalue == NULL ||
- gcvalue->type != GCONF_VALUE_LIST ||
- gconf_value_get_list_type (gcvalue) != GCONF_VALUE_STRING) return FALSE;
-
- hosts = gconf_value_get_list (gcvalue);
-
- array = g_array_new (TRUE, FALSE, sizeof (char *));
-
- for (l = hosts; l != NULL; l = l->next)
- {
- const char *host;
-
- host = gconf_value_get_string ((GConfValue *) l->data);
-
- if (host != NULL && host[0] != '\0')
- {
- g_array_append_val (array, host);
- }
- }
-
- strings = (char **) g_array_free (array, FALSE);
-
- g_value_init (value, G_TYPE_STRING);
- g_value_take_string (value, g_strjoinv (",", strings));
-
- /* the strings themselves are const */
- g_free (strings);
-
- return TRUE;
-}
-
-static gboolean
-transform_proxy_mode (GConfEntry *gcentry,
- GValue *value,
- gpointer user_data)
-{
- GConfValue *gcvalue;
- const char *mode;
- int mozilla_mode = 0;
-
- gcvalue = gconf_entry_get_value (gcentry);
- if (gcvalue == NULL ||
- gcvalue->type != GCONF_VALUE_STRING) return FALSE;
-
- mode = gconf_value_get_string (gcvalue);
- if (mode == NULL) return FALSE;
-
- if (strcmp (mode, "manual") == 0)
- {
- mozilla_mode = 1;
- }
- else if (strcmp (mode, "auto") == 0)
- {
- mozilla_mode = 2;
- }
-
- g_value_init (value, G_TYPE_INT);
- g_value_set_int (value, mozilla_mode);
-
- return TRUE;
-}
-
-static gboolean
-transform_use_own_fonts (GConfEntry *gcentry,
- GValue *value,
- gpointer user_data)
-{
- GConfValue *gcvalue;
-
- gcvalue = gconf_entry_get_value (gcentry);
- if (gcvalue == NULL ||
- gcvalue->type != GCONF_VALUE_BOOL) return FALSE;
-
- g_value_init (value, G_TYPE_INT);
- g_value_set_int (value, gconf_value_get_bool (gcvalue) ? 0 : 1);
-
- return TRUE;
-}
-
-extern "C" gboolean
-mozilla_notifier_transform_bool (GConfEntry *gcentry,
- GValue *value,
- gpointer user_data)
-{
- GConfValue *gcvalue;
-
- gcvalue = gconf_entry_get_value (gcentry);
- if (gcvalue == NULL ||
- gcvalue->type != GCONF_VALUE_BOOL) return FALSE;
-
- g_value_init (value, G_TYPE_BOOLEAN);
- g_value_set_boolean (value, gconf_value_get_bool (gcvalue));
-
- return TRUE;
-}
-
-extern "C" gboolean
-mozilla_notifier_transform_bool_invert (GConfEntry *gcentry,
- GValue *value,
- gpointer user_data)
-{
- GConfValue *gcvalue;
-
- gcvalue = gconf_entry_get_value (gcentry);
- if (gcvalue == NULL ||
- gcvalue->type != GCONF_VALUE_BOOL) return FALSE;
-
- g_value_init (value, G_TYPE_BOOLEAN);
- g_value_set_boolean (value, !gconf_value_get_bool (gcvalue));
-
- return TRUE;
-}
-
-extern "C" gboolean
-mozilla_notifier_transform_int (GConfEntry *gcentry,
- GValue *value,
- gpointer user_data)
-{
- GConfValue *gcvalue;
-
- gcvalue = gconf_entry_get_value (gcentry);
- if (gcvalue == NULL ||
- gcvalue->type != GCONF_VALUE_INT) return FALSE;
-
- g_value_init (value, G_TYPE_INT);
- g_value_set_int (value, gconf_value_get_int (gcvalue));
-
- return TRUE;
-}
-
-extern "C" gboolean
-mozilla_notifier_transform_string (GConfEntry *gcentry,
- GValue *value,
- gpointer user_data)
-{
- GConfValue *gcvalue;
- const char *str;
-
- gcvalue = gconf_entry_get_value (gcentry);
- if (gcvalue == NULL ||
- gcvalue->type != GCONF_VALUE_STRING) return FALSE;
-
- str = gconf_value_get_string (gcvalue);
- if (str == NULL) return FALSE;
-
- g_value_init (value, G_TYPE_STRING);
- g_value_set_string (value, str);
-
- return TRUE;
-}
-
-static const PrefData notifier_entries[] =
-{
- { CONF_BROWSE_WITH_CARET,
- "accessibility.browsewithcaret",
- mozilla_notifier_transform_bool },
- { CONF_NETWORK_CACHE_SIZE,
- "browser.cache.disk.capacity",
- transform_cache_size },
- { CONF_RENDERING_USE_OWN_COLORS,
- "browser.display.use_document_colors",
- mozilla_notifier_transform_bool_invert },
- { CONF_RENDERING_USE_OWN_FONTS,
- "browser.display.use_document_fonts",
- transform_use_own_fonts },
- { CONF_SECURITY_ALLOW_POPUPS,
- "dom.disable_open_during_load",
- mozilla_notifier_transform_bool_invert },
- { CONF_DISPLAY_SMOOTHSCROLL,
- "general.smoothScroll",
- mozilla_notifier_transform_bool },
- { CONF_IMAGE_ANIMATION_MODE,
- "image.animation_mode",
- transform_image_animation_mode },
- { CONF_RENDERING_LANGUAGE,
- "intl.accept_languages",
- transform_accept_languages_list },
- { CONF_LANGUAGE_DEFAULT_ENCODING,
- "intl.charset.default",
- transform_encoding,
- GINT_TO_POINTER (FALSE) },
- { CONF_LANGUAGE_AUTODETECT_ENCODING,
- "intl.charset.detector",
- transform_encoding,
- GINT_TO_POINTER (TRUE) },
- { CONF_SECURITY_JAVA_ENABLED,
- "security.enable_java",
- mozilla_notifier_transform_bool },
- { CONF_SECURITY_JAVASCRIPT_ENABLED,
- "javascript.enabled",
- mozilla_notifier_transform_bool },
- { CONF_NETWORK_PROXY_AUTO_URL,
- "network.proxy.autoconfig_url",
- mozilla_notifier_transform_string },
- { CONF_NETWORK_HTTP_PROXY,
- "network.proxy.http",
- mozilla_notifier_transform_string },
- { CONF_NETWORK_HTTP_PROXY_PORT,
- "network.proxy.http_port",
- mozilla_notifier_transform_int },
- { CONF_NETWORK_FTP_PROXY,
- "network.proxy.ftp",
- mozilla_notifier_transform_string },
- { CONF_NETWORK_FTP_PROXY_PORT,
- "network.proxy.ftp_port",
- mozilla_notifier_transform_int },
- { CONF_NETWORK_SSL_PROXY,
- "network.proxy.ssl",
- mozilla_notifier_transform_string },
- { CONF_NETWORK_SSL_PROXY_PORT,
- "network.proxy.ssl_port",
- mozilla_notifier_transform_int },
- { CONF_NETWORK_SOCKS_PROXY,
- "network.proxy.socks",
- mozilla_notifier_transform_string },
- { CONF_NETWORK_SOCKS_PROXY_PORT,
- "network.proxy.socks_port",
- mozilla_notifier_transform_int },
- { CONF_NETWORK_PROXY_IGNORE_HOSTS,
- "network.proxy.no_proxies_on",
- transform_proxy_ignore_list },
- { CONF_NETWORK_PROXY_MODE,
- "network.proxy.type",
- transform_proxy_mode },
- { CONF_SECURITY_COOKIES_ACCEPT,
- "network.cookie.cookieBehavior",
- transform_cookies_accept_mode },
- { CONF_PRIVACY_REMEMBER_PASSWORDS,
- "signon.rememberSignons",
- mozilla_notifier_transform_bool }
-};
-
-gboolean
-mozilla_pref_set (const char *pref,
- const GValue *value)
-{
- NS_ENSURE_TRUE (gPrefBranch, FALSE);
-
- g_return_val_if_fail (pref != NULL, FALSE);
- g_return_val_if_fail (value != NULL, FALSE);
-
- nsresult rv;
- PRInt32 prefType;
- rv = gPrefBranch->GetPrefType (pref, &prefType);
- if (NS_FAILED (rv))
- {
- /* probably just an unset pref */
- prefType = nsIPrefBranch::PREF_INVALID;
- rv = NS_OK;
- }
-
- switch (G_VALUE_TYPE (value))
- {
- case G_TYPE_INT:
- {
- if (prefType != nsIPrefBranch::PREF_INT &&
- prefType != nsIPrefBranch::PREF_INVALID)
- break;
-
- PRInt32 old_value = 0;
- PRInt32 new_value = g_value_get_int (value);
- rv = gPrefBranch->GetIntPref (pref, &old_value);
- if (NS_FAILED (rv) || old_value != new_value)
- {
- rv = gPrefBranch->SetIntPref (pref, new_value);
- }
- break;
- }
- case G_TYPE_BOOLEAN:
- {
- if (prefType != nsIPrefBranch::PREF_BOOL &&
- prefType != nsIPrefBranch::PREF_INVALID)
- break;
-
- PRBool old_value = PR_FALSE;
- PRBool new_value = g_value_get_boolean (value);
- rv = gPrefBranch->GetBoolPref (pref, &old_value);
- if (NS_FAILED (rv) || old_value != new_value)
- {
- rv = gPrefBranch->SetBoolPref (pref, new_value);
- }
- break;
- }
- case G_TYPE_STRING:
- {
- if (prefType != nsIPrefBranch::PREF_STRING &&
- prefType != nsIPrefBranch::PREF_INVALID)
- break;
-
- const char *new_value = g_value_get_string (value);
- if (new_value == NULL)
- {
- rv = gPrefBranch->ClearUserPref (pref);
- }
- else
- {
- char *old_value = nsnull;
-
- rv = gPrefBranch->GetCharPref (pref, &old_value);
- if (NS_FAILED (rv) ||
- old_value == nsnull ||
- strcmp (old_value, new_value) != 0)
- {
- rv = gPrefBranch->SetCharPref (pref, new_value);
- }
-
- if (old_value)
- {
- nsMemory::Free (old_value);
- }
- }
- break;
- }
- default:
- g_return_val_if_reached (FALSE);
- rv = NS_ERROR_FAILURE;
- break;
- }
-
- return NS_SUCCEEDED (rv) != PR_FALSE;
-}
-
-static void
-notify_cb (GConfClient *client,
- guint cnxn_id,
- GConfEntry *gcentry,
- PrefData *data)
-{
- GValue value = { 0, };
-
- g_return_if_fail (gcentry != NULL);
- g_assert (data != NULL);
-
- if (data->func (gcentry, &value, data->user_data))
- {
- mozilla_pref_set (data->mozilla_pref, &value);
- g_value_unset (&value);
- }
- else
- {
- /* Reset the pref */
- NS_ENSURE_TRUE (gPrefBranch, );
- gPrefBranch->ClearUserPref (data->mozilla_pref);
- }
-}
-
-extern "C" guint
-mozilla_notifier_add (const char *gconf_key,
- const char *mozilla_pref,
- PrefValueTransformFunc func,
- gpointer user_data)
-{
- GConfClient *client;
- PrefData *data;
- GError *error = NULL;
- guint cnxn_id;
-
- g_return_val_if_fail (gconf_key != NULL, 0);
- g_return_val_if_fail (mozilla_pref != NULL, 0);
- g_return_val_if_fail (func, 0);
-
- client = eel_gconf_client_get_global ();
- g_return_val_if_fail (client != NULL, 0);
-
- data = g_slice_new (PrefData);
- data->gconf_key = g_strdup (gconf_key);
- data->mozilla_pref = g_strdup (mozilla_pref);
- data->func = func;
- data->user_data = user_data;
-
- cnxn_id = gconf_client_notify_add (client, gconf_key,
- (GConfClientNotifyFunc) notify_cb,
- data, (GFreeFunc) free_pref_data,
- &error);
- if (eel_gconf_handle_error (&error))
- {
- if (cnxn_id != EEL_GCONF_UNDEFINED_CONNECTION)
- {
- gconf_client_notify_remove (client, cnxn_id);
- }
-
- return 0;
- }
-
- data->cnxn_id = cnxn_id;
- notifiers = g_list_prepend (notifiers, data);
-
- gconf_client_notify (client, gconf_key);
-
- return cnxn_id;
-}
-
-static int
-find_data (const PrefData *a,
- gconstpointer idptr)
-{
- return a->cnxn_id != GPOINTER_TO_UINT (idptr);
-}
-
-extern "C" void
-mozilla_notifier_remove (guint id)
-{
- GList *l;
-
- g_return_if_fail (id != 0);
-
- l = g_list_find_custom (notifiers, GUINT_TO_POINTER (id),
- (GCompareFunc) find_data);
- g_return_if_fail (l != NULL);
-
- notifiers = g_list_delete_link (notifiers, l);
- eel_gconf_notification_remove (id);
-}
-
-#ifdef MIGRATE_PIXEL_SIZE
-
-#define INT_ROUND(a) gint((a) + 0.5f)
-
-/**
-* This function gets the dpi in the same way that mozilla gets the dpi,
-* this allows us to convert from pixels to points easily
-*/
-static gint
-mozilla_get_dpi ()
-{
- GtkSettings* settings = gtk_settings_get_default ();
- gint dpi = 0;
-
- /* Use the gdk-xft-dpi setting if it is set */
- if (g_object_class_find_property (G_OBJECT_GET_CLASS (G_OBJECT (settings)),
- "gtk-xft-dpi"))
- {
- g_object_get (G_OBJECT (settings), "gtk-xft-dpi", &dpi, (char *) NULL);
- if (dpi) return INT_ROUND (dpi / PANGO_SCALE);
- }
-
- /* Fall back to what xft thinks it is */
- char *val = XGetDefault (GDK_DISPLAY (), "Xft", "dpi");
- if (val)
- {
- char *e;
- double d = strtod(val, &e);
- if (e != val) return INT_ROUND (d);
- }
-
- /* Fall back to calculating manually from the gdk screen settings */
- float screenWidthIn = float (gdk_screen_width_mm()) / 25.4f;
- return INT_ROUND (gdk_screen_width() / screenWidthIn);
-}
-
-static void
-migrate_font_gconf_key (const char *pixel_key,
- const char *point_key)
-{
- int size;
-
- size = eel_gconf_get_integer (pixel_key);
-
- if (size > 0)
- {
- /* Use doubles to get more accurate arithmetic */
- double dpi = (double) mozilla_get_dpi ();
- double value = (double) eel_gconf_get_integer (pixel_key);
- gint point = INT_ROUND ((value * 72) / dpi);
-
- eel_gconf_set_integer (point_key, point);
- }
-}
-
-#endif
-
-static gboolean
-parse_pango_font (const char *font,
- char **name,
- int *size)
-{
- PangoFontMask mask = (PangoFontMask) (PANGO_FONT_MASK_FAMILY | PANGO_FONT_MASK_SIZE);
-
- PangoFontDescription *desc = pango_font_description_from_string (font);
- if (desc == NULL) return FALSE;
-
- if ((pango_font_description_get_set_fields (desc) & mask) != mask)
- {
- pango_font_description_free (desc);
- return FALSE;
- }
-
- *size = PANGO_PIXELS (pango_font_description_get_size (desc));
- *name = g_strdup (pango_font_description_get_family (desc));
-
- pango_font_description_free (desc);
-
- LOG ("Parsed pango font description '%s' -> name:%s, size:%d",
- font, *name ? *name : "-", *size);
-
- return *name != NULL && *size > 0;
-}
-
-typedef struct
-{
- guint cnxn_id;
- char **font_name_prefs;
- char **font_size_prefs;
- char *font_name;
- int font_size;
-} DesktopFontData;
-
-static gboolean
-transform_font_name (GConfEntry *gcentry,
- GValue *value,
- gpointer user_data)
-{
- DesktopFontData *data = (DesktopFontData *) user_data;
- GConfValue *gcvalue;
- const char *font_name;
-
- gcvalue = gconf_entry_get_value (gcentry);
- if (gconf_entry_get_is_default (gcentry) ||
- gcvalue == NULL ||
- gcvalue->type != GCONF_VALUE_STRING)
- {
- font_name = data->font_name;
- }
- else
- {
- font_name = gconf_value_get_string (gcvalue);
- if ((font_name == NULL || font_name[0] == '\0'))
- {
- font_name = data->font_name;
- }
- }
-
- LOG ("%s value for key '%s'",
- gconf_entry_get_is_default (gcentry) ? "default" : "NON-default",
- gconf_entry_get_key (gcentry));
-
- if (font_name == NULL) return FALSE;
-
- LOG ("Inferred font name '%s' for key '%s'",
- font_name, gconf_entry_get_key (gcentry));
-
- g_value_init (value, G_TYPE_STRING);
- g_value_set_string (value, font_name);
-
- return TRUE;
-}
-
-static gboolean
-transform_font_size (GConfEntry *gcentry,
- GValue *value,
- gpointer user_data)
-{
- DesktopFontData *data = (DesktopFontData *) user_data;
- GConfValue *gcvalue;
- int size = 0;
-
- gcvalue = gconf_entry_get_value (gcentry);
- if (gconf_entry_get_is_default (gcentry) ||
- gcvalue == NULL ||
- gcvalue->type != GCONF_VALUE_INT)
- {
- size = data->font_size;
- }
- else
- {
- size = gconf_value_get_int (gcvalue);
- }
-
- if (size <= 0 || size > MAX_FONT_SIZE) return FALSE;
-
- g_value_init (value, G_TYPE_INT);
- g_value_set_int (value, size);
-
- return TRUE;
-}
-
-static void
-notify_desktop_font_cb (GConfClient *client,
- guint cnxn_id,
- GConfEntry *gcentry,
- DesktopFontData *data)
-{
- GConfValue *gcvalue;
- char *name = NULL;
- int size = 0, i;
-
- gcvalue = gconf_entry_get_value (gcentry);
- if (gcvalue != NULL &&
- gcvalue->type == GCONF_VALUE_STRING &&
- parse_pango_font (gconf_value_get_string (gcvalue), &name, &size))
- {
- LOG ("Desktop font %s -> name=%s, size=%d",
- gconf_entry_get_key (gcentry), name, size);
-
- g_free (data->font_name);
- data->font_name = name;
- data->font_size = size;
- }
- else
- {
- g_free (name);
-
- g_free (data->font_name);
- data->font_name = NULL;
- data->font_size = 0;
- }
-
- for (i = 0; data->font_name_prefs[i] != NULL; ++i)
- {
- gconf_client_notify (client, data->font_name_prefs[i]);
- }
- for (i = 0; data->font_size_prefs[i] != NULL; ++i)
- {
- gconf_client_notify (client, data->font_size_prefs[i]);
- }
-}
-
-typedef struct
-{
- guint cnxn_id;
- char **prefs;
- int size;
-} MinimumFontSizeData;
-
-static gboolean
-transform_minimum_font_size (GConfEntry *gcentry,
- GValue *value,
- gpointer user_data)
-{
- MinimumFontSizeData *data = (MinimumFontSizeData *) user_data;
- GConfValue *gcvalue;
- int size = 0;
-
- gcvalue = gconf_entry_get_value (gcentry);
- if (gcvalue == NULL ||
- gcvalue->type != GCONF_VALUE_INT)
- {
- size = data->size;
- }
- else
- {
- size = MAX (gconf_value_get_int (gcvalue),
- data->size);
- }
-
- if (size <= 0) return FALSE;
-
- g_value_init (value, G_TYPE_INT);
- g_value_set_int (value, size);
-
- return TRUE;
-}
-
-static void
-notify_minimum_size_cb (GConfClient *client,
- guint cnxn_id,
- GConfEntry *entry,
- MinimumFontSizeData *data)
-{
- GConfValue *gcvalue;
- int i;
-
- data->size = 0;
-
- gcvalue = gconf_entry_get_value (entry);
- /* happens on initial notify if the key doesn't exist */
- if (gcvalue != NULL &&
- gcvalue->type == GCONF_VALUE_INT)
- {
- data->size = gconf_value_get_int (gcvalue);
- data->size = MAX (data->size, 0);
- }
-
- LOG ("Minimum font size now %d", data->size);
-
- for (i = 0; data->prefs[i] != NULL; ++i)
- {
- gconf_client_notify (client, data->prefs[i]);
- }
-}
-
-static DesktopFontData *desktop_font_data;
-static MinimumFontSizeData *minimum_font_size_data;
-
-static void
-mozilla_font_notifiers_init (void)
-{
- static const char *types [] = { "variable", "monospace" };
- const EphyFontsLanguageInfo *font_languages;
- guint n_font_languages, i;
-
- eel_gconf_monitor_add ("/desktop/gnome/interface");
-
- font_languages = ephy_font_languages ();
- n_font_languages = ephy_font_n_languages ();
-
- desktop_font_data = g_new0 (DesktopFontData, 2);
- desktop_font_data[0].font_name_prefs = g_new0 (char*, n_font_languages + 1);
- desktop_font_data[0].font_size_prefs = g_new0 (char*, n_font_languages + 1);
- desktop_font_data[1].font_name_prefs = g_new0 (char*, n_font_languages + 1);
- desktop_font_data[1].font_size_prefs = g_new0 (char*, n_font_languages + 1);
-
- desktop_font_data[0].cnxn_id =
- eel_gconf_notification_add (CONF_DESKTOP_FONT_VARIABLE,
- (GConfClientNotifyFunc) notify_desktop_font_cb,
- &desktop_font_data[0]);
- eel_gconf_notify (CONF_DESKTOP_FONT_VARIABLE);
-
- desktop_font_data[1].cnxn_id =
- eel_gconf_notification_add (CONF_DESKTOP_FONT_MONOSPACE,
- (GConfClientNotifyFunc) notify_desktop_font_cb,
- &desktop_font_data[1]);
- eel_gconf_notify (CONF_DESKTOP_FONT_MONOSPACE);
-
- minimum_font_size_data = g_new0 (MinimumFontSizeData, 1);
- minimum_font_size_data->prefs = g_new0 (char*, n_font_languages + 1);
-
- minimum_font_size_data->cnxn_id =
- eel_gconf_notification_add (CONF_RENDERING_FONT_MIN_SIZE,
- (GConfClientNotifyFunc) notify_minimum_size_cb,
- minimum_font_size_data);
- eel_gconf_notify (CONF_RENDERING_FONT_MIN_SIZE);
-
-#ifdef MIGRATE_PIXEL_SIZE
- gboolean migrate_size;
-
- migrate_size = (eel_gconf_get_integer (CONF_SCHEMA_VERSION)
- < EPIPHANY_SCHEMA_VERSION);
- if (migrate_size)
- {
- eel_gconf_set_integer (CONF_SCHEMA_VERSION, EPIPHANY_SCHEMA_VERSION);
- }
-#endif
-
- for (i=0; i < n_font_languages; i++)
- {
- const char *code = font_languages[i].code;
- guint k;
- char key[255], pref[255];
-#ifdef MIGRATE_PIXEL_SIZE
- char old_key[255];
-#endif
-
- for (k = 0; k < G_N_ELEMENTS (types); k++)
- {
- g_snprintf (key, sizeof (key), "%s_%s_%s",
- CONF_RENDERING_FONT, types[k], code);
- g_snprintf (pref, sizeof (pref), "font.name.%s.%s",
- types[k], code);
-
- desktop_font_data[k].font_name_prefs[i] = g_strdup (key);
-
- mozilla_notifier_add (key, pref,
- transform_font_name,
- &desktop_font_data[k]);
- }
-
-#ifdef MIGRATE_PIXEL_SIZE
- if (migrate_size)
- {
- char *type;
-
- type = eel_gconf_get_string (CONF_RENDERING_FONT_TYPE_OLD);
- if (type && (strcmp (type, "serif") == 0 ||
- strcmp (type, "sans-serif") == 0))
- {
- char *family;
-
- g_snprintf (old_key, sizeof (old_key), "%s_%s_%s",
- CONF_RENDERING_FONT, type, code);
- g_snprintf (key, sizeof (key), "%s_%s_%s",
- CONF_RENDERING_FONT, "variable", code);
-
- family = eel_gconf_get_string (old_key);
- if (family)
- {
- eel_gconf_set_string (key, family);
- g_free (family);
- }
- }
-
- g_free (type);
- }
-#endif
-
- /* FIXME is it "minimum-size" or "min-size" !!? */
- g_snprintf (key, sizeof (key), "%s_%s",
- CONF_RENDERING_FONT_MIN_SIZE, code);
- g_snprintf (pref, sizeof (pref), "font.minimum-size.%s", code);
-
- minimum_font_size_data->prefs[i] = g_strdup (key);
-
- mozilla_notifier_add (key, pref, transform_minimum_font_size,
- minimum_font_size_data);
-
-#ifdef MIGRATE_PIXEL_SIZE
- if (migrate_size)
- {
- g_snprintf (old_key, sizeof (key), "%s_%s",
- CONF_RENDERING_FONT_MIN_SIZE_OLD, code);
- migrate_font_gconf_key (old_key, key);
- }
-#endif
-
- g_snprintf (key, sizeof (key), "%s_%s",
- CONF_RENDERING_FONT_FIXED_SIZE, code);
- g_snprintf (pref, sizeof (pref), "font.size.fixed.%s", code);
-
- desktop_font_data[1].font_size_prefs[i] = g_strdup (key);
- mozilla_notifier_add (key, pref, transform_font_size,
- &desktop_font_data[1]);
-
-#ifdef MIGRATE_PIXEL_SIZE
- if (migrate_size)
- {
- g_snprintf (old_key, sizeof (old_key), "%s_%s",
- CONF_RENDERING_FONT_FIXED_SIZE_OLD, code);
- migrate_font_gconf_key (old_key, key);
- }
-#endif
-
- g_snprintf (key, sizeof (key), "%s_%s",
- CONF_RENDERING_FONT_VAR_SIZE, code);
- g_snprintf (pref, sizeof (pref), "font.size.variable.%s", code);
-
- desktop_font_data[0].font_size_prefs[i] = g_strdup (key);
- mozilla_notifier_add (key, pref, transform_font_size,
- &desktop_font_data[0]);
-
-#ifdef MIGRATE_PIXEL_SIZE
- if (migrate_size)
- {
- g_snprintf (old_key, sizeof (old_key), "%s_%s",
- CONF_RENDERING_FONT_VAR_SIZE_OLD, code);
- migrate_font_gconf_key (old_key, key);
- }
-#endif
- }
-}
-
-static void
-mozilla_font_notifiers_shutdown (void)
-{
- eel_gconf_monitor_remove ("/desktop/gnome/interface");
-
- eel_gconf_notification_remove (desktop_font_data[0].cnxn_id);
- eel_gconf_notification_remove (desktop_font_data[1].cnxn_id);
- eel_gconf_notification_remove (minimum_font_size_data->cnxn_id);
-
- g_free (desktop_font_data[0].font_name);
- g_free (desktop_font_data[1].font_name);
-
- g_strfreev (desktop_font_data[0].font_name_prefs);
- g_strfreev (desktop_font_data[0].font_size_prefs);
- g_strfreev (desktop_font_data[1].font_name_prefs);
- g_strfreev (desktop_font_data[1].font_size_prefs);
- g_strfreev (minimum_font_size_data->prefs);
-
- g_free (desktop_font_data);
- g_free (minimum_font_size_data);
-}
-
-#if 0
-static void
-notify_generic_cb (GConfClient *client,
- guint cnxn_id,
- GConfEntry *gcentry,
- gpointer data)
-{
- GConfValue *gcvalue;
- const char *key, *pref;
- static const gsize len = strlen ("/apps/epiphany/web/gecko_prefs/");
- GValue value = { 0, };
-
- key = gconf_entry_get_key (gcentry);
- if (!key || strlen (key) <= len) return;
-
- pref = key + len;
-
- gcvalue = gconf_entry_get_value (gcentry);
- if (!gcvalue) return;
-
- switch (gcvalue->type)
- {
- case GCONF_VALUE_STRING:
- g_value_init (&value, G_TYPE_STRING);
- g_value_set_static_string (&value, gconf_value_get_string (gcvalue));
- break;
- case GCONF_VALUE_INT:
- g_value_init (&value, G_TYPE_INT);
- g_value_set_int (&value, gconf_value_get_int (gcvalue));
- break;
- case GCONF_VALUE_BOOL:
- g_value_init (&value, G_TYPE_BOOLEAN);
- g_value_set_boolean (&value, gconf_value_get_bool (gcvalue));
- break;
- /* case GCONF_VALUE_INVALID: */
- /* case GCONF_VALUE_FLOAT: */
- /* case GCONF_VALUE_SCHEMA: */
- /* case GCONF_VALUE_LIST: */
- /* case GCONF_VALUE_PAIR: */
- default:
- g_warning ("Unsupported value type for key '%s'\n", key);
- return;
- }
-
- g_assert (G_IS_VALUE (&value));
- mozilla_pref_set (pref, &value);
- g_value_unset (&value);
-}
-
-static void
-mozilla_generic_notifier_init (void)
-{
- GConfClient *client;
- GError *error = NULL;
- guint cnxn_id;
- PrefData *data;
- GSList *list, *l;
-
- client = eel_gconf_client_get_global ();
-
- cnxn_id = gconf_client_notify_add (client, "/apps/epiphany/web/gecko_prefs",
- (GConfClientNotifyFunc) notify_generic_cb,
- NULL, NULL, &error);
- if (eel_gconf_handle_error (&error))
- {
- if (cnxn_id != EEL_GCONF_UNDEFINED_CONNECTION)
- {
- gconf_client_notify_remove (client, cnxn_id);
- }
-
- return;
- }
-
- data = g_slice_new0 (PrefData);
- data->cnxn_id = cnxn_id;
- notifiers = g_list_prepend (notifiers, data);
-
- list = gconf_client_all_entries (client, "/apps/epiphany/web/gecko_prefs", NULL);
- for (l = list; l != NULL; l = l->next)
- {
- GConfEntry *gcentry = (GConfEntry *) l->data;
-
- notify_generic_cb (client, cnxn_id, gcentry, NULL);
- gconf_entry_unref (gcentry);
- }
- g_slist_free (list);
-}
-#endif
-
-extern "C" gboolean
-mozilla_notifiers_init (void)
-{
- guint i;
-
- eel_gconf_monitor_add ("/apps/epiphany/web");
- eel_gconf_monitor_add ("/system/proxy");
- eel_gconf_monitor_add ("/system/http_proxy");
-
- /* the pref service conveniently implements the root pref branch */
- gPrefBranch = nsnull;
- nsresult rv = CallGetService (NS_PREFSERVICE_CONTRACTID, &gPrefBranch);
- if (NS_FAILED (rv) || !gPrefBranch)
- {
- g_warning ("Failed to get the pref service!\n");
- return FALSE;
- }
-
-#if 0
- /* First init the generic notifier, so our regular prefs override prefs set there */
- mozilla_generic_notifier_init ();
-#endif
-
- for (i = 0; i < G_N_ELEMENTS (notifier_entries); i++)
- {
- mozilla_notifier_add (notifier_entries[i].gconf_key,
- notifier_entries[i].mozilla_pref,
- notifier_entries[i].func,
- notifier_entries[i].user_data);
- }
-
- mozilla_font_notifiers_init ();
-
- return TRUE;
-}
-
-static void
-remove_notification (PrefData *data)
-{
- eel_gconf_notification_remove (data->cnxn_id);
-}
-
-extern "C" void
-mozilla_notifiers_shutdown (void)
-{
- NS_IF_RELEASE (gPrefBranch);
- gPrefBranch = nsnull;
-
- mozilla_font_notifiers_shutdown ();
-
- eel_gconf_monitor_remove ("/apps/epiphany/web");
- eel_gconf_monitor_remove ("/system/proxy");
- eel_gconf_monitor_remove ("/system/http_proxy");
-
- g_list_foreach (notifiers, (GFunc) remove_notification, NULL);
- g_list_free (notifiers);
-}
diff --git a/embed/xulrunner/embed/mozilla-notifiers.h b/embed/xulrunner/embed/mozilla-notifiers.h
deleted file mode 100644
index d1fe6d7aa..000000000
--- a/embed/xulrunner/embed/mozilla-notifiers.h
+++ /dev/null
@@ -1,58 +0,0 @@
-/*
- * Copyright © 2000 Nate Case
- * Copyright © 2000-2004 Marco Pesenti Gritti
- * Copyright © 2003, 2004 Christian Persch
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#ifndef MOZILLA_NOTIFIERS_H
-#define MOZILLA_NOTIFIERS_H
-
-#include <glib.h>
-#include <glib-object.h>
-#include <gconf/gconf.h>
-
-G_BEGIN_DECLS
-
-typedef gboolean (* PrefValueTransformFunc) (GConfEntry*, GValue*, gpointer);
-
-gboolean mozilla_notifier_transform_bool (GConfEntry*, GValue*, gpointer);
-
-gboolean mozilla_notifier_transform_bool_invert (GConfEntry*, GValue*, gpointer);
-
-gboolean mozilla_notifier_transform_int (GConfEntry*, GValue*, gpointer);
-
-gboolean mozilla_notifier_transform_string (GConfEntry*, GValue*, gpointer);
-
-guint mozilla_notifier_add (const char *gconf_key,
- const char *mozilla_pref,
- PrefValueTransformFunc func,
- gpointer user_data);
-
-void mozilla_notifier_remove (guint id);
-
-gboolean mozilla_pref_set (const char *pref,
- const GValue *value);
-
-gboolean mozilla_notifiers_init (void);
-
-void mozilla_notifiers_shutdown (void);
-
-G_END_DECLS
-
-#endif
diff --git a/embed/xulrunner/src/EmbedContentListener.cpp b/embed/xulrunner/src/EmbedContentListener.cpp
deleted file mode 100644
index 08de47631..000000000
--- a/embed/xulrunner/src/EmbedContentListener.cpp
+++ /dev/null
@@ -1,159 +0,0 @@
-/*
- * Copyright © Christopher Blizzard
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser 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.
- *
- * ---------------------------------------------------------------------------
- * Derived from Mozilla.org code, which had the following attributions:
- *
- * The Original Code is mozilla.org code.
- *
- * The Initial Developer of the Original Code is
- * Christopher Blizzard. Portions created by Christopher Blizzard are Copyright © Christopher Blizzard. All Rights Reserved.
- * Portions created by the Initial Developer are Copyright © 2001
- * the Initial Developer. All Rights Reserved.
- *
- * Contributor(s):
- * Christopher Blizzard <blizzard@mozilla.org>
- * ---------------------------------------------------------------------------
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include <strings.h>
-
-#include "nsIURI.h"
-#include <nsMemory.h>
-
-#include "EmbedContentListener.h"
-#include "GeckoBrowser.h"
-#include "gecko-embed-signals.h"
-
-#include "nsServiceManagerUtils.h"
-#include "nsIWebNavigationInfo.h"
-#include "nsDocShellCID.h"
-
-EmbedContentListener::EmbedContentListener(void)
-{
- mOwner = nsnull;
-}
-
-EmbedContentListener::~EmbedContentListener()
-{
-}
-
-NS_IMPL_ISUPPORTS2(EmbedContentListener,
- nsIURIContentListener,
- nsISupportsWeakReference)
-
-nsresult
-EmbedContentListener::Init(GeckoBrowser *aOwner)
-{
- mOwner = aOwner;
- return NS_OK;
-}
-
-NS_IMETHODIMP
-EmbedContentListener::OnStartURIOpen(nsIURI *aURI,
- PRBool *aAbortOpen)
-{
- nsresult rv;
-
- nsEmbedCString specString;
- rv = aURI->GetSpec(specString);
-
- if (NS_FAILED(rv))
- return rv;
-
- gboolean retval = FALSE;
- g_signal_emit (mOwner->mOwningWidget,
- gecko_embed_signals[OPEN_URI], 0,
- specString.get(), &retval);
-
- *aAbortOpen = retval != FALSE;
-
- return NS_OK;
-}
-
-NS_IMETHODIMP
-EmbedContentListener::DoContent(const char *aContentType,
- PRBool aIsContentPreferred,
- nsIRequest *aRequest,
- nsIStreamListener **aContentHandler,
- PRBool *aAbortProcess)
-{
- return NS_ERROR_NOT_IMPLEMENTED;
-}
-
-NS_IMETHODIMP
-EmbedContentListener::IsPreferred(const char *aContentType,
- char **aDesiredContentType,
- PRBool *aCanHandleContent)
-{
- return CanHandleContent(aContentType, PR_TRUE, aDesiredContentType,
- aCanHandleContent);
-}
-
-NS_IMETHODIMP
-EmbedContentListener::CanHandleContent(const char *aContentType,
- PRBool aIsContentPreferred,
- char **aDesiredContentType,
- PRBool *_retval)
-{
- *_retval = PR_FALSE;
- *aDesiredContentType = nsnull;
-
- if (aContentType) {
- nsCOMPtr<nsIWebNavigationInfo> webNavInfo(
- do_GetService(NS_WEBNAVIGATION_INFO_CONTRACTID));
- if (webNavInfo) {
- PRUint32 canHandle;
- nsresult rv =
- webNavInfo->IsTypeSupported(nsDependentCString(aContentType),
- mOwner ? mOwner->mNavigation.get() : nsnull,
- &canHandle);
- NS_ENSURE_SUCCESS(rv, rv);
- *_retval = (canHandle != nsIWebNavigationInfo::UNSUPPORTED);
- }
- }
- return NS_OK;
-}
-
-NS_IMETHODIMP
-EmbedContentListener::GetLoadCookie(nsISupports **aLoadCookie)
-{
- return NS_ERROR_NOT_IMPLEMENTED;
-}
-
-NS_IMETHODIMP
-EmbedContentListener::SetLoadCookie(nsISupports *aLoadCookie)
-{
- return NS_ERROR_NOT_IMPLEMENTED;
-}
-
-NS_IMETHODIMP
-EmbedContentListener::GetParentContentListener(nsIURIContentListener **aParent)
-{
- return NS_ERROR_NOT_IMPLEMENTED;
-}
-
-NS_IMETHODIMP
-EmbedContentListener::SetParentContentListener(nsIURIContentListener *aParent)
-{
- return NS_ERROR_NOT_IMPLEMENTED;
-}
diff --git a/embed/xulrunner/src/EmbedContentListener.h b/embed/xulrunner/src/EmbedContentListener.h
deleted file mode 100644
index 427d8263e..000000000
--- a/embed/xulrunner/src/EmbedContentListener.h
+++ /dev/null
@@ -1,63 +0,0 @@
-/*
- * Copyright © Christopher Blizzard
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser 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.
- *
- * ---------------------------------------------------------------------------
- * Derived from Mozilla.org code, which had the following attributions:
- *
- * The Original Code is mozilla.org code.
- *
- * The Initial Developer of the Original Code is
- * Christopher Blizzard. Portions created by Christopher Blizzard are Copyright © Christopher Blizzard. All Rights Reserved.
- * Portions created by the Initial Developer are Copyright © 2001
- * the Initial Developer. All Rights Reserved.
- *
- * Contributor(s):
- * Christopher Blizzard <blizzard@mozilla.org>
- * ---------------------------------------------------------------------------
- *
- * $Id$
- */
-
-#ifndef __EmbedContentListener_h
-#define __EmbedContentListener_h
-
-#include <nsIURIContentListener.h>
-#include <nsWeakReference.h>
-
-class GeckoBrowser;
-
-class EmbedContentListener : public nsIURIContentListener,
- public nsSupportsWeakReference
-{
- public:
-
- EmbedContentListener();
- virtual ~EmbedContentListener();
-
- nsresult Init (GeckoBrowser *aOwner);
-
- NS_DECL_ISUPPORTS
-
- NS_DECL_NSIURICONTENTLISTENER
-
- private:
-
- GeckoBrowser *mOwner;
-
-};
-
-#endif /* __EmbedContentListener_h */
diff --git a/embed/xulrunner/src/EmbedEventListener.cpp b/embed/xulrunner/src/EmbedEventListener.cpp
deleted file mode 100644
index 0d51764dc..000000000
--- a/embed/xulrunner/src/EmbedEventListener.cpp
+++ /dev/null
@@ -1,183 +0,0 @@
-/*
- * Copyright © Christopher Blizzard
- * Copyright © 2006 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser 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.
- *
- * ---------------------------------------------------------------------------
- * Derived from Mozilla.org code, which had the following attributions:
- *
- * The Original Code is mozilla.org code.
- *
- * The Initial Developer of the Original Code is
- * Christopher Blizzard. Portions created by Christopher Blizzard are Copyright © Christopher Blizzard. All Rights Reserved.
- * Portions created by the Initial Developer are Copyright © 2001
- * the Initial Developer. All Rights Reserved.
- *
- * Contributor(s):
- * Christopher Blizzard <blizzard@mozilla.org>
- * ---------------------------------------------------------------------------
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include <nsCOMPtr.h>
-#include <nsIDOMMouseEvent.h>
-
-#include "nsIDOMKeyEvent.h"
-#include "nsIDOMUIEvent.h"
-
-#include "EmbedEventListener.h"
-#include "GeckoBrowser.h"
-
-#include "gecko-embed-signals.h"
-#include "gecko-dom-event.h"
-#include "gecko-dom-event-internal.h"
-#include "gecko-dom-event-private.h"
-
-EmbedEventListener::EmbedEventListener(GeckoBrowser *aOwner)
- : mOwner(aOwner)
-{
-}
-
-EmbedEventListener::~EmbedEventListener()
-{
-}
-
-NS_IMPL_ADDREF(EmbedEventListener)
-NS_IMPL_RELEASE(EmbedEventListener)
-NS_INTERFACE_MAP_BEGIN(EmbedEventListener)
- NS_INTERFACE_MAP_ENTRY_AMBIGUOUS(nsISupports, nsIDOMKeyListener)
- NS_INTERFACE_MAP_ENTRY_AMBIGUOUS(nsIDOMEventListener, nsIDOMKeyListener)
- NS_INTERFACE_MAP_ENTRY(nsIDOMKeyListener)
- NS_INTERFACE_MAP_ENTRY(nsIDOMMouseListener)
- NS_INTERFACE_MAP_ENTRY(nsIDOMUIListener)
- NS_INTERFACE_MAP_ENTRY(nsIDOMContextMenuListener)
-NS_INTERFACE_MAP_END
-
-inline NS_METHOD
-EmbedEventListener::Emit(nsIDOMEvent *aDOMEvent,
- GeckoEmbedSignals signal,
- GeckoDOMEventType type)
-{
- if (!aDOMEvent)
- return NS_OK;
-
- // g_print ("Emitting signal '%s'\n", g_signal_name (gecko_embed_signals[signal]));
-
- /* Check if there are any handlers connected */
- if (!g_signal_has_handler_pending (mOwner->mOwningWidget,
- gecko_embed_signals[signal],
- 0, FALSE /* FIXME: correct? */)) {
- return NS_OK;
- }
-
- GeckoDOMEvent event;
- GECKO_DOM_EVENT_STATIC_INIT (event, aDOMEvent);
-
- gboolean retval = FALSE;
- g_signal_emit (mOwner->mOwningWidget,
- gecko_embed_signals[signal], 0,
- (GeckoDOMEvent*) &event, &retval);
- if (retval) {
- aDOMEvent->StopPropagation();
- aDOMEvent->PreventDefault();
- }
-
- GECKO_DOM_EVENT_STATIC_DEINIT (event);
-
- return NS_OK;
-}
-
-NS_IMETHODIMP
-EmbedEventListener::KeyDown(nsIDOMEvent* aDOMEvent)
-{
- return Emit(aDOMEvent, DOM_KEY_DOWN, TYPE_KEY_EVENT);
-}
-
-NS_IMETHODIMP
-EmbedEventListener::KeyPress(nsIDOMEvent* aDOMEvent)
-{
- return Emit(aDOMEvent, DOM_KEY_PRESS, TYPE_KEY_EVENT);
-}
-
-NS_IMETHODIMP
-EmbedEventListener::KeyUp(nsIDOMEvent* aDOMEvent)
-{
- return Emit(aDOMEvent, DOM_KEY_UP, TYPE_KEY_EVENT);
-}
-
-NS_IMETHODIMP
-EmbedEventListener::MouseDown(nsIDOMEvent* aDOMEvent)
-{
- return Emit(aDOMEvent, DOM_MOUSE_DOWN, TYPE_MOUSE_EVENT);
-}
-
-NS_IMETHODIMP
-EmbedEventListener::MouseUp(nsIDOMEvent* aDOMEvent)
-{
- return Emit(aDOMEvent, DOM_MOUSE_UP, TYPE_MOUSE_EVENT);
-}
-
-NS_IMETHODIMP
-EmbedEventListener::MouseClick(nsIDOMEvent* aDOMEvent)
-{
- return Emit(aDOMEvent, DOM_MOUSE_CLICK, TYPE_MOUSE_EVENT);
-}
-
-NS_IMETHODIMP
-EmbedEventListener::MouseDblClick(nsIDOMEvent* aDOMEvent)
-{
- return Emit(aDOMEvent, DOM_MOUSE_DOUBLE_CLICK, TYPE_MOUSE_EVENT);
-}
-
-NS_IMETHODIMP
-EmbedEventListener::MouseOver(nsIDOMEvent* aDOMEvent)
-{
- return Emit(aDOMEvent, DOM_MOUSE_OVER, TYPE_MOUSE_EVENT);
-}
-
-NS_IMETHODIMP
-EmbedEventListener::MouseOut(nsIDOMEvent* aDOMEvent)
-{
- return Emit(aDOMEvent, DOM_MOUSE_OUT, TYPE_MOUSE_EVENT);
-}
-
-NS_IMETHODIMP
-EmbedEventListener::FocusIn(nsIDOMEvent* aDOMEvent)
-{
- return Emit(aDOMEvent, DOM_FOCUS_IN, TYPE_UI_EVENT);
-}
-
-NS_IMETHODIMP
-EmbedEventListener::FocusOut(nsIDOMEvent* aDOMEvent)
-{
- return Emit(aDOMEvent, DOM_FOCUS_OUT, TYPE_UI_EVENT);
-}
-
-NS_IMETHODIMP
-EmbedEventListener::Activate(nsIDOMEvent* aDOMEvent)
-{
- return Emit(aDOMEvent, DOM_ACTIVATE, TYPE_UI_EVENT);
-}
-
-NS_IMETHODIMP
-EmbedEventListener::ContextMenu(nsIDOMEvent* aDOMEvent)
-{
- return Emit(aDOMEvent, DOM_CONTEXT_MENU, TYPE_MOUSE_EVENT);
-}
diff --git a/embed/xulrunner/src/EmbedEventListener.h b/embed/xulrunner/src/EmbedEventListener.h
deleted file mode 100644
index e1ea99d31..000000000
--- a/embed/xulrunner/src/EmbedEventListener.h
+++ /dev/null
@@ -1,102 +0,0 @@
-/*
- * Copyright © Christopher Blizzard
- * Copyright © 2006 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser 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.
- *
- * ---------------------------------------------------------------------------
- * Derived from Mozilla.org code, which had the following attributions:
- *
- * The Original Code is mozilla.org code.
- *
- * The Initial Developer of the Original Code is
- * Christopher Blizzard. Portions created by Christopher Blizzard are Copyright © Christopher Blizzard. All Rights Reserved.
- * Portions created by the Initial Developer are Copyright © 2001
- * the Initial Developer. All Rights Reserved.
- *
- * Contributor(s):
- * Christopher Blizzard <blizzard@mozilla.org>
- * ---------------------------------------------------------------------------
- *
- * $Id$
- */
-
-#ifndef __EmbedEventListener_h
-#define __EmbedEventListener_h
-
-#include <nsIDOMKeyListener.h>
-#include <nsIDOMMouseListener.h>
-#include <nsIDOMUIListener.h>
-#include <nsIDOMContextMenuListener.h>
-
-#include <gecko-embed-signals.h>
-
-class GeckoBrowser;
-
-class EmbedEventListener : public nsIDOMKeyListener,
- public nsIDOMMouseListener,
- public nsIDOMUIListener,
- public nsIDOMContextMenuListener
-{
- public:
-
- EmbedEventListener(GeckoBrowser *aOwner);
- virtual ~EmbedEventListener();
-
- NS_DECL_ISUPPORTS
-
- // nsIDOMEventListener
-
- NS_IMETHOD HandleEvent(nsIDOMEvent* aEvent) { return NS_OK; }
-
- // nsIDOMKeyListener
-
- NS_IMETHOD KeyDown(nsIDOMEvent* aDOMEvent);
- NS_IMETHOD KeyUp(nsIDOMEvent* aDOMEvent);
- NS_IMETHOD KeyPress(nsIDOMEvent* aDOMEvent);
-
- // nsIDOMMouseListener
-
- NS_IMETHOD MouseDown(nsIDOMEvent* aDOMEvent);
- NS_IMETHOD MouseUp(nsIDOMEvent* aDOMEvent);
- NS_IMETHOD MouseClick(nsIDOMEvent* aDOMEvent);
- NS_IMETHOD MouseDblClick(nsIDOMEvent* aDOMEvent);
- NS_IMETHOD MouseOver(nsIDOMEvent* aDOMEvent);
- NS_IMETHOD MouseOut(nsIDOMEvent* aDOMEvent);
-
- // nsIDOMUIListener
-
- NS_IMETHOD Activate(nsIDOMEvent* aDOMEvent);
- NS_IMETHOD FocusIn(nsIDOMEvent* aDOMEvent);
- NS_IMETHOD FocusOut(nsIDOMEvent* aDOMEvent);
-
- // nsIDOMContextMenuListener
- NS_IMETHOD ContextMenu(nsIDOMEvent *aDOMEvent);
-
- private:
- GeckoBrowser *mOwner;
-
- enum GeckoDOMEventType {
- TYPE_KEY_EVENT,
- TYPE_MOUSE_EVENT,
- TYPE_UI_EVENT
- };
-
- NS_METHOD Emit(nsIDOMEvent *aDOMEvent,
- GeckoEmbedSignals signal,
- GeckoDOMEventType);
-};
-
-#endif /* __EmbedEventListener_h */
diff --git a/embed/xulrunner/src/EmbedProgress.cpp b/embed/xulrunner/src/EmbedProgress.cpp
deleted file mode 100644
index 1f1cd0e2b..000000000
--- a/embed/xulrunner/src/EmbedProgress.cpp
+++ /dev/null
@@ -1,224 +0,0 @@
-/*
- * Copyright © Christopher Blizzard
- * Copyright © 2006 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser 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.
- *
- * ---------------------------------------------------------------------------
- * Derived from Mozilla.org code, which had the following attributions:
- *
- * The Original Code is mozilla.org code.
- *
- * The Initial Developer of the Original Code is
- * Christopher Blizzard. Portions created by Christopher Blizzard are Copyright © Christopher Blizzard. All Rights Reserved.
- * Portions created by the Initial Developer are Copyright © 2001
- * the Initial Developer. All Rights Reserved.
- *
- * Contributor(s):
- * Christopher Blizzard <blizzard@mozilla.org>
- * ---------------------------------------------------------------------------
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include "EmbedProgress.h"
-
-#include <nsIChannel.h>
-#include <nsIWebProgress.h>
-#include <nsIDOMWindow.h>
-
-#include "nsIURI.h"
-#include "nsMemory.h"
-
-#include "gecko-embed-types.h"
-
-#include "gecko-embed-signals.h"
-
-EmbedProgress::EmbedProgress()
-: mOwner(nsnull)
-{
-}
-
-EmbedProgress::~EmbedProgress()
-{
-}
-
-/* FIXME implement nsIWebProgressListener2 */
-NS_IMPL_ISUPPORTS2(EmbedProgress,
- nsIWebProgressListener,
- nsISupportsWeakReference)
-
-nsresult
-EmbedProgress::Init(GeckoBrowser *aOwner)
-{
- mOwner = aOwner;
- return NS_OK;
-}
-
-NS_IMETHODIMP
-EmbedProgress::OnStateChange(nsIWebProgress *aWebProgress,
- nsIRequest *aRequest,
- PRUint32 aStateFlags,
- nsresult aStatus)
-{
- // give the widget a chance to attach any listeners
- mOwner->ContentStateChange();
- // if we've got the start flag, emit the signal
- if ((aStateFlags & GECKO_EMBED_FLAG_IS_NETWORK) &&
- (aStateFlags & GECKO_EMBED_FLAG_START))
- {
- g_signal_emit (mOwner->mOwningWidget, gecko_embed_signals[NET_START], 0);
- }
-
- nsCOMPtr<nsIChannel> channel = do_QueryInterface(aRequest);
- if (!channel) return NS_ERROR_FAILURE;
-
- nsCOMPtr<nsIURI> requestURI;
- channel->GetURI(getter_AddRefs(requestURI));
- if (!requestURI) return NS_ERROR_FAILURE;
-
- if (IsCurrentURI(requestURI))
- {
- // for people who know what they are doing
- g_signal_emit (mOwner->mOwningWidget,
- gecko_embed_signals[NET_STATE], 0,
- aStateFlags, aStatus);
- }
-
- nsEmbedCString uriString;
- requestURI->GetSpec(uriString);
- g_signal_emit (mOwner->mOwningWidget, gecko_embed_signals[NET_STATE_ALL], 0,
- uriString.get(), (gint)aStateFlags, (gint)aStatus);
- // and for stop, too
- if ((aStateFlags & GECKO_EMBED_FLAG_IS_NETWORK) &&
- (aStateFlags & GECKO_EMBED_FLAG_STOP))
- {
- g_signal_emit (mOwner->mOwningWidget, gecko_embed_signals[NET_STOP], 0);
- // let our owner know that the load finished
- mOwner->ContentFinishedLoading();
- }
-
- return NS_OK;
-}
-
-NS_IMETHODIMP
-EmbedProgress::OnProgressChange(nsIWebProgress *aWebProgress,
- nsIRequest *aRequest,
- PRInt32 aCurSelfProgress,
- PRInt32 aMaxSelfProgress,
- PRInt32 aCurTotalProgress,
- PRInt32 aMaxTotalProgress)
-{
- nsCOMPtr<nsIChannel> channel = do_QueryInterface(aRequest);
- if (!channel) return NS_ERROR_FAILURE;
-
- nsCOMPtr<nsIURI> requestURI;
- channel->GetURI(getter_AddRefs(requestURI));
- if (!requestURI) return NS_ERROR_FAILURE;
-
- // is it the same as the current uri?
- if (IsCurrentURI(requestURI)) {
- g_signal_emit (mOwner->mOwningWidget,
- gecko_embed_signals[PROGRESS], 0,
- aCurTotalProgress, aMaxTotalProgress);
- }
-
- nsEmbedCString uriString;
- requestURI->GetSpec(uriString);
- g_signal_emit (mOwner->mOwningWidget,
- gecko_embed_signals[PROGRESS_ALL], 0,
- uriString.get(),
- aCurTotalProgress, aMaxTotalProgress);
- return NS_OK;
-}
-
-NS_IMETHODIMP
-EmbedProgress::OnLocationChange(nsIWebProgress *aWebProgress,
- nsIRequest *aRequest,
- nsIURI *aLocation)
-{
- nsEmbedCString newURI;
- NS_ENSURE_ARG_POINTER(aLocation);
- aLocation->GetSpec(newURI);
-
- // Make sure that this is the primary frame change and not
- // just a subframe.
- PRBool isSubFrameLoad = PR_FALSE;
- if (aWebProgress) {
- nsCOMPtr<nsIDOMWindow> domWindow;
- nsCOMPtr<nsIDOMWindow> topDomWindow;
-
- aWebProgress->GetDOMWindow(getter_AddRefs(domWindow));
-
- // get the root dom window
- if (domWindow)
- domWindow->GetTop(getter_AddRefs(topDomWindow));
-
- if (domWindow != topDomWindow)
- isSubFrameLoad = PR_TRUE;
- }
-
- if (!isSubFrameLoad) {
- mOwner->SetURI(newURI.get());
- g_signal_emit (mOwner->mOwningWidget, gecko_embed_signals[LOCATION], 0);
- }
-
- return NS_OK;
-}
-
-NS_IMETHODIMP
-EmbedProgress::OnStatusChange(nsIWebProgress *aWebProgress,
- nsIRequest *aRequest,
- nsresult aStatus,
- const PRUnichar *aMessage)
-{
- // need to make a copy so we can safely cast to a void *
- nsEmbedString message(aMessage);
- PRUnichar *tmpString = NS_StringCloneData(message);
-
- g_signal_emit (mOwner->mOwningWidget,
- gecko_embed_signals[STATUS_CHANGE], 0,
- static_cast<void *>(aRequest),
- static_cast<int>(aStatus),
- static_cast<void *>(tmpString));
-
- nsMemory::Free(tmpString);
-
- return NS_OK;
-}
-
-NS_IMETHODIMP
-EmbedProgress::OnSecurityChange(nsIWebProgress *aWebProgress,
- nsIRequest *aRequest,
- PRUint32 aState)
-{
- g_signal_emit (mOwner->mOwningWidget,
- gecko_embed_signals[SECURITY_CHANGE], 0,
- static_cast<void *>(aRequest),
- aState);
- return NS_OK;
-}
-
-PRBool
-EmbedProgress::IsCurrentURI(nsIURI *aURI)
-{
- nsEmbedCString spec;
- aURI->GetSpec(spec);
-
- return strcmp(mOwner->mURI.get(), spec.get()) == 0;
-}
diff --git a/embed/xulrunner/src/EmbedProgress.h b/embed/xulrunner/src/EmbedProgress.h
deleted file mode 100644
index ca4d2187f..000000000
--- a/embed/xulrunner/src/EmbedProgress.h
+++ /dev/null
@@ -1,63 +0,0 @@
-/*
- * Copyright © Christopher Blizzard
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser 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.
- *
- * ---------------------------------------------------------------------------
- * Derived from Mozilla.org code, which had the following attributions:
- *
- * The Original Code is mozilla.org code.
- *
- * The Initial Developer of the Original Code is
- * Christopher Blizzard. Portions created by Christopher Blizzard are Copyright © Christopher Blizzard. All Rights Reserved.
- * Portions created by the Initial Developer are Copyright © 2001
- * the Initial Developer. All Rights Reserved.
- *
- * Contributor(s):
- * Christopher Blizzard <blizzard@mozilla.org>
- * ---------------------------------------------------------------------------
- *
- * $Id$
- */
-
-#ifndef __EmbedProgress_h
-#define __EmbedProgress_h
-
-#include <nsIWebProgressListener.h>
-#include <nsWeakReference.h>
-#include <nsIURI.h>
-#include "GeckoBrowser.h"
-
-class EmbedProgress : public nsIWebProgressListener,
- public nsSupportsWeakReference
-{
- public:
- EmbedProgress();
- virtual ~EmbedProgress();
-
- nsresult Init(GeckoBrowser *aOwner);
-
- NS_DECL_ISUPPORTS
-
- NS_DECL_NSIWEBPROGRESSLISTENER
-
- private:
-
- GeckoBrowser *mOwner;
-
- PRBool IsCurrentURI(nsIURI *aURI);
-};
-
-#endif /* __EmbedProgress_h */
diff --git a/embed/xulrunner/src/EmbedStream.cpp b/embed/xulrunner/src/EmbedStream.cpp
deleted file mode 100644
index c6c2778e0..000000000
--- a/embed/xulrunner/src/EmbedStream.cpp
+++ /dev/null
@@ -1,311 +0,0 @@
-/*
- * Copyright © Christopher Blizzard
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser 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.
- *
- * ---------------------------------------------------------------------------
- * Derived from Mozilla.org code, which had the following attributions:
- *
- * The Original Code is mozilla.org code.
- *
- * The Initial Developer of the Original Code is
- * Christopher Blizzard. Portions created by Christopher Blizzard are Copyright © Christopher Blizzard. All Rights Reserved.
- * Portions created by the Initial Developer are Copyright © 2001
- * the Initial Developer. All Rights Reserved.
- *
- * Contributor(s):
- * Christopher Blizzard <blizzard@mozilla.org>
- * ---------------------------------------------------------------------------
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include <config.h>
-
-#include <nsIPipe.h>
-#include <nsIInputStream.h>
-#include <nsIOutputStream.h>
-#include <nsIContentViewerContainer.h>
-#include <nsIDocumentLoaderFactory.h>
-#include <nsNetUtil.h>
-#include <prmem.h>
-
-#include "nsXPCOMCID.h"
-#include "nsICategoryManager.h"
-
-#include "nsIContentViewer.h"
-
-#include "EmbedStream.h"
-#include "EmbedPrivate.h"
-#include "EmbedWindow.h"
-#include "nsReadableUtils.h"
-
-// nsIInputStream interface
-
-NS_IMPL_ISUPPORTS1(EmbedStream, nsIInputStream)
-
-EmbedStream::EmbedStream()
-{
- mOwner = nsnull;
- mOffset = 0;
- mDoingStream = PR_FALSE;
-}
-
-EmbedStream::~EmbedStream()
-{
-}
-
-void
-EmbedStream::InitOwner(EmbedPrivate *aOwner)
-{
- mOwner = aOwner;
-}
-
-NS_METHOD
-EmbedStream::Init(void)
-{
- nsresult rv = NS_OK;
-
- nsCOMPtr<nsIInputStream> bufInStream;
- nsCOMPtr<nsIOutputStream> bufOutStream;
-
- rv = NS_NewPipe(getter_AddRefs(bufInStream),
- getter_AddRefs(bufOutStream));
-
- if (NS_FAILED(rv)) return rv;
-
- mInputStream = bufInStream;
- mOutputStream = bufOutStream;
- return NS_OK;
-}
-
-NS_METHOD
-EmbedStream::OpenStream(const char *aBaseURI, const char *aContentType)
-{
- NS_ENSURE_ARG_POINTER(aBaseURI);
- NS_ENSURE_ARG_POINTER(aContentType);
-
- nsresult rv = NS_OK;
-
- // if we're already doing a stream then close the current one
- if (mDoingStream)
- CloseStream();
-
- // set our state
- mDoingStream = PR_TRUE;
-
- // initialize our streams
- rv = Init();
- if (NS_FAILED(rv))
- return rv;
-
- // get the content area of our web browser
- nsCOMPtr<nsIWebBrowser> browser;
- mOwner->mWindow->GetWebBrowser(getter_AddRefs(browser));
-
- // get the viewer container
- nsCOMPtr<nsIContentViewerContainer> viewerContainer;
- viewerContainer = do_GetInterface(browser);
-
- // create a new uri object
- nsCOMPtr<nsIURI> uri;
- nsCAutoString spec(aBaseURI);
- rv = NS_NewURI(getter_AddRefs(uri), spec.get());
-
- if (NS_FAILED(rv))
- return rv;
-
- // create a new load group
- rv = NS_NewLoadGroup(getter_AddRefs(mLoadGroup), nsnull);
- if (NS_FAILED(rv))
- return rv;
-
- // create a new input stream channel
- rv = NS_NewInputStreamChannel(getter_AddRefs(mChannel), uri,
- static_cast<nsIInputStream *>(this),
- nsDependentCString(aContentType),
- EmptyCString());
- if (NS_FAILED(rv))
- return rv;
-
- // set the channel's load group
- rv = mChannel->SetLoadGroup(mLoadGroup);
- if (NS_FAILED(rv))
- return rv;
-
- // find a document loader for this content type
-
- nsXPIDLCString docLoaderContractID;
- nsCOMPtr<nsICategoryManager> catMan(do_GetService(NS_CATEGORYMANAGER_CONTRACTID, &rv));
- if (NS_FAILED(rv))
- return rv;
- rv = catMan->GetCategoryEntry("Gecko-Content-Viewers", aContentType,
- getter_Copies(docLoaderContractID));
- if (NS_FAILED(rv))
- return rv;
-
- nsCOMPtr<nsIDocumentLoaderFactory> docLoaderFactory;
- docLoaderFactory = do_GetService(docLoaderContractID.get(), &rv);
- if (NS_FAILED(rv))
- return rv;
-
- // ok, create an instance of the content viewer for that command and
- // mime type
- nsCOMPtr<nsIContentViewer> contentViewer;
- rv = docLoaderFactory->CreateInstance("view", mChannel, mLoadGroup,
- aContentType, viewerContainer,
- nsnull,
- getter_AddRefs(mStreamListener),
- getter_AddRefs(contentViewer));
- if (NS_FAILED(rv))
- return rv;
-
- // set the container viewer container for this content view
- rv = contentViewer->SetContainer(viewerContainer);
- if (NS_FAILED(rv))
- return rv;
-
- // embed this sucker
- rv = viewerContainer->Embed(contentViewer, "view", nsnull);
- if (NS_FAILED(rv))
- return rv;
-
- // start our request
- nsCOMPtr<nsIRequest> request = do_QueryInterface(mChannel);
- rv = mStreamListener->OnStartRequest(request, NULL);
- if (NS_FAILED(rv))
- return rv;
-
- return NS_OK;
-}
-
-NS_METHOD
-EmbedStream::AppendToStream(const char *aData, gint32 aLen)
-{
- nsresult rv;
-
- // append the data
- rv = Append(aData, aLen);
- if (NS_FAILED(rv))
- return rv;
-
- // notify our listeners
- nsCOMPtr<nsIRequest> request = do_QueryInterface(mChannel);
- rv = mStreamListener->OnDataAvailable(request,
- NULL,
- static_cast<nsIInputStream *>(this),
- mOffset, /* offset */
- aLen); /* len */
- // move our counter
- mOffset += aLen;
- if (NS_FAILED(rv))
- return rv;
-
- return NS_OK;
-}
-
-NS_METHOD
-EmbedStream::CloseStream(void)
-{
- nsresult rv = NS_OK;
-
- NS_ENSURE_STATE(mDoingStream);
- mDoingStream = PR_FALSE;
-
- nsCOMPtr<nsIRequest> request = do_QueryInterface(mChannel, &rv);
- if (NS_FAILED(rv))
- goto loser;
-
- rv = mStreamListener->OnStopRequest(request, NULL, NS_OK);
- if (NS_FAILED(rv))
- return rv;
-
- loser:
- mLoadGroup = nsnull;
- mChannel = nsnull;
- mStreamListener = nsnull;
- mOffset = 0;
-
- return rv;
-}
-
-NS_METHOD
-EmbedStream::Append(const char *aData, PRUint32 aLen)
-{
- nsresult rv = NS_OK;
- PRUint32 bytesWritten = 0;
- rv = mOutputStream->Write(aData, aLen, &bytesWritten);
- if (NS_FAILED(rv))
- return rv;
-
- NS_ASSERTION(bytesWritten == aLen,
- "underlying byffer couldn't handle the write");
- return rv;
-}
-
-NS_IMETHODIMP
-EmbedStream::Available(PRUint32 *_retval)
-{
- return mInputStream->Available(_retval);
-}
-
-NS_IMETHODIMP
-EmbedStream::Read(char * aBuf, PRUint32 aCount, PRUint32 *_retval)
-{
- return mInputStream->Read(aBuf, aCount, _retval);
-}
-
-NS_IMETHODIMP EmbedStream::Close(void)
-{
- return mInputStream->Close();
-}
-
-NS_IMETHODIMP
-EmbedStream::ReadSegments(nsWriteSegmentFun aWriter, void * aClosure,
- PRUint32 aCount, PRUint32 *_retval)
-{
- char *readBuf = (char *)nsMemory::Alloc(aCount);
- PRUint32 nBytes;
-
- if (!readBuf)
- return NS_ERROR_OUT_OF_MEMORY;
-
- nsresult rv = mInputStream->Read(readBuf, aCount, &nBytes);
-
- *_retval = 0;
-
- if (NS_SUCCEEDED(rv)) {
- PRUint32 writeCount = 0;
- rv = aWriter(this, aClosure, readBuf, 0, nBytes, &writeCount);
-
- // XXX writeCount may be less than nBytes!! This is the wrong
- // way to synthesize ReadSegments.
- NS_ASSERTION(writeCount == nBytes, "data loss");
-
- // errors returned from the writer end here!
- rv = NS_OK;
- }
-
- nsMemory::Free(readBuf);
-
- return rv;
-}
-
-NS_IMETHODIMP
-EmbedStream::IsNonBlocking(PRBool *aNonBlocking)
-{
- return mInputStream->IsNonBlocking(aNonBlocking);
-}
diff --git a/embed/xulrunner/src/EmbedStream.h b/embed/xulrunner/src/EmbedStream.h
deleted file mode 100644
index bf734e134..000000000
--- a/embed/xulrunner/src/EmbedStream.h
+++ /dev/null
@@ -1,79 +0,0 @@
-/*
- * Copyright © Christopher Blizzard
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser 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.
- *
- * ---------------------------------------------------------------------------
- * Derived from Mozilla.org code, which had the following attributions:
- *
- * The Original Code is mozilla.org code.
- *
- * The Initial Developer of the Original Code is
- * Christopher Blizzard. Portions created by Christopher Blizzard are Copyright © Christopher Blizzard. All Rights Reserved.
- * Portions created by the Initial Developer are Copyright © 2001
- * the Initial Developer. All Rights Reserved.
- *
- * Contributor(s):
- * Christopher Blizzard <blizzard@mozilla.org>
- * ---------------------------------------------------------------------------
- *
- * $Id$
- */
-
-#include <nsISupports.h>
-#include <nsCOMPtr.h>
-#include <nsIOutputStream.h>
-#include <nsIInputStream.h>
-#include <nsILoadGroup.h>
-#include <nsIChannel.h>
-#include <nsIStreamListener.h>
-
-class EmbedPrivate;
-
-class EmbedStream : public nsIInputStream
-{
- public:
-
- EmbedStream();
- virtual ~EmbedStream();
-
- void InitOwner (EmbedPrivate *aOwner);
- NS_METHOD Init (void);
-
- NS_METHOD OpenStream (const char *aBaseURI, const char *aContentType);
- NS_METHOD AppendToStream (const char *aData, PRInt32 aLen);
- NS_METHOD CloseStream (void);
-
- NS_METHOD Append (const char *aData, PRUint32 aLen);
-
- // nsISupports
- NS_DECL_ISUPPORTS
- // nsIInputStream
- NS_DECL_NSIINPUTSTREAM
-
- private:
- nsCOMPtr<nsIOutputStream> mOutputStream;
- nsCOMPtr<nsIInputStream> mInputStream;
-
- nsCOMPtr<nsILoadGroup> mLoadGroup;
- nsCOMPtr<nsIChannel> mChannel;
- nsCOMPtr<nsIStreamListener> mStreamListener;
-
- PRUint32 mOffset;
- PRBool mDoingStream;
-
- EmbedPrivate *mOwner;
-
-};
diff --git a/embed/xulrunner/src/EmbedWindow.cpp b/embed/xulrunner/src/EmbedWindow.cpp
deleted file mode 100644
index 436d6065b..000000000
--- a/embed/xulrunner/src/EmbedWindow.cpp
+++ /dev/null
@@ -1,467 +0,0 @@
-/*
- * Copyright © Christopher Blizzard
- * Copyright © 2006 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser 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.
- *
- * ---------------------------------------------------------------------------
- * Derived from Mozilla.org code, which had the following attributions:
- *
- * The Original Code is mozilla.org code.
- *
- * The Initial Developer of the Original Code is
- * Christopher Blizzard. Portions created by Christopher Blizzard are Copyright © Christopher Blizzard. All Rights Reserved.
- * Portions created by the Initial Developer are Copyright © 2001
- * the Initial Developer. All Rights Reserved.
- *
- * Contributor(s):
- * Christopher Blizzard <blizzard@mozilla.org>
- * ---------------------------------------------------------------------------
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include <config.h>
-
-#include <nsCWebBrowser.h>
-#include <nsIComponentManager.h>
-#include <nsComponentManagerUtils.h>
-#include <nsIDocShellTreeItem.h>
-#include "nsIWidget.h"
-
-#include "EmbedWindow.h"
-#include "GeckoBrowser.h"
-
-#include "gecko-embed-signals.h"
-
-GtkWidget *EmbedWindow::sTipWindow = nsnull;
-
-EmbedWindow::EmbedWindow(void)
-{
- mOwner = nsnull;
- mVisibility = PR_FALSE;
- mIsModal = PR_FALSE;
-}
-
-EmbedWindow::~EmbedWindow(void)
-{
- ExitModalEventLoop(PR_FALSE);
-}
-
-nsresult
-EmbedWindow::Init(GeckoBrowser *aOwner)
-{
- // save our owner for later
- mOwner = aOwner;
-
- // create our nsIWebBrowser object and set up some basic defaults.
- mWebBrowser = do_CreateInstance(NS_WEBBROWSER_CONTRACTID);
- if (!mWebBrowser)
- return NS_ERROR_FAILURE;
-
- mWebBrowser->SetContainerWindow(static_cast<nsIWebBrowserChrome *>(this));
-
- nsCOMPtr<nsIDocShellTreeItem> item = do_QueryInterface(mWebBrowser);
- item->SetItemType(nsIDocShellTreeItem::typeContentWrapper);
-
- return NS_OK;
-}
-
-nsresult
-EmbedWindow::CreateWindow(void)
-{
- nsresult rv;
- GtkWidget *ownerAsWidget = GTK_WIDGET(mOwner->mOwningWidget);
-
- // Get the base window interface for the web browser object and
- // create the window.
- mBaseWindow = do_QueryInterface(mWebBrowser);
- rv = mBaseWindow->InitWindow(GTK_WIDGET(mOwner->mOwningWidget),
- nsnull,
- 0, 0,
- ownerAsWidget->allocation.width,
- ownerAsWidget->allocation.height);
- if (NS_FAILED(rv))
- return rv;
-
- rv = mBaseWindow->Create();
- if (NS_FAILED(rv))
- return rv;
-
- return NS_OK;
-}
-
-void
-EmbedWindow::ReleaseChildren(void)
-{
- ExitModalEventLoop(PR_FALSE);
-
- mBaseWindow->Destroy();
- mBaseWindow = 0;
- mWebBrowser = 0;
-}
-
-// nsISupports
-
-NS_IMPL_ADDREF(EmbedWindow)
-NS_IMPL_RELEASE(EmbedWindow)
-
-NS_INTERFACE_MAP_BEGIN(EmbedWindow)
- NS_INTERFACE_MAP_ENTRY_AMBIGUOUS(nsISupports, nsIWebBrowserChrome)
- NS_INTERFACE_MAP_ENTRY(nsIWebBrowserChrome)
- NS_INTERFACE_MAP_ENTRY(nsIWebBrowserChromeFocus)
- NS_INTERFACE_MAP_ENTRY(nsIEmbeddingSiteWindow)
- NS_INTERFACE_MAP_ENTRY(nsITooltipListener)
- NS_INTERFACE_MAP_ENTRY(nsIInterfaceRequestor)
-NS_INTERFACE_MAP_END
-
-// nsIWebBrowserChrome
-
-NS_IMETHODIMP
-EmbedWindow::SetStatus(PRUint32 aStatusType, const PRUnichar *aStatus)
-{
- switch (aStatusType) {
- case STATUS_SCRIPT:
- {
- mJSStatus = aStatus;
- g_signal_emit (mOwner->mOwningWidget, gecko_embed_signals[JS_STATUS], 0);
- }
- break;
- case STATUS_SCRIPT_DEFAULT:
- // Gee, that's nice.
- break;
- case STATUS_LINK:
- {
- mLinkMessage = aStatus;
- g_signal_emit (mOwner->mOwningWidget, gecko_embed_signals[LINK_MESSAGE], 0);
- }
- break;
- }
- return NS_OK;
-}
-
-NS_IMETHODIMP
-EmbedWindow::GetWebBrowser(nsIWebBrowser **aWebBrowser)
-{
- *aWebBrowser = mWebBrowser;
- NS_IF_ADDREF(*aWebBrowser);
- return NS_OK;
-}
-
-NS_IMETHODIMP
-EmbedWindow::SetWebBrowser(nsIWebBrowser *aWebBrowser)
-{
- mWebBrowser = aWebBrowser;
- return NS_OK;
-}
-
-NS_IMETHODIMP
-EmbedWindow::GetChromeFlags(PRUint32 *aChromeFlags)
-{
- *aChromeFlags = mOwner->mChromeMask;
- return NS_OK;
-}
-
-NS_IMETHODIMP
-EmbedWindow::SetChromeFlags(PRUint32 aChromeFlags)
-{
- mOwner->SetChromeMask(aChromeFlags);
- return NS_OK;
-}
-
-NS_IMETHODIMP
-EmbedWindow::DestroyBrowserWindow(void)
-{
- // mark the owner as destroyed so it won't emit events anymore.
- mOwner->mIsDestroyed = PR_TRUE;
-
- g_signal_emit (mOwner->mOwningWidget, gecko_embed_signals[DESTROY_BROWSER], 0);
- return NS_OK;
-}
-
-NS_IMETHODIMP
-EmbedWindow::SizeBrowserTo(PRInt32 aCX, PRInt32 aCY)
-{
- g_signal_emit (mOwner->mOwningWidget, gecko_embed_signals[SIZE_TO], 0, aCX, aCY);
-
- return NS_OK;
-}
-
-NS_IMETHODIMP
-EmbedWindow::ShowAsModal(void)
-{
- mIsModal = PR_TRUE;
- GtkWidget *toplevel;
- toplevel = gtk_widget_get_toplevel(GTK_WIDGET(mOwner->mOwningWidget));
- gtk_grab_add(toplevel);
- gtk_main();
- return NS_OK;
-}
-
-NS_IMETHODIMP
-EmbedWindow::IsWindowModal(PRBool *_retval)
-{
- *_retval = mIsModal;
- return NS_OK;
-}
-
-NS_IMETHODIMP
-EmbedWindow::ExitModalEventLoop(nsresult aStatus)
-{
- if (mIsModal) {
- GtkWidget *toplevel;
- toplevel = gtk_widget_get_toplevel(GTK_WIDGET(mOwner->mOwningWidget));
- gtk_grab_remove(toplevel);
- mIsModal = PR_FALSE;
- gtk_main_quit();
- }
- return NS_OK;
-}
-
-// nsIWebBrowserChromeFocus
-
-NS_IMETHODIMP
-EmbedWindow::FocusNextElement()
-{
- GtkWidget *toplevel;
- toplevel = gtk_widget_get_toplevel(GTK_WIDGET(mOwner->mOwningWidget));
- if (!GTK_WIDGET_TOPLEVEL(toplevel))
- return NS_OK;
-
- g_signal_emit_by_name (toplevel, "move_focus", GTK_DIR_TAB_FORWARD);
-
- return NS_OK;
-}
-
-NS_IMETHODIMP
-EmbedWindow::FocusPrevElement()
-{
- GtkWidget *toplevel;
- toplevel = gtk_widget_get_toplevel(GTK_WIDGET(mOwner->mOwningWidget));
- if (!GTK_WIDGET_TOPLEVEL(toplevel))
- return NS_OK;
-
- g_signal_emit_by_name (toplevel, "move_focus", GTK_DIR_TAB_BACKWARD);
-
- return NS_OK;
-}
-
-// nsIEmbeddingSiteWindow
-
-NS_IMETHODIMP
-EmbedWindow::SetDimensions(PRUint32 aFlags, PRInt32 aX, PRInt32 aY,
- PRInt32 aCX, PRInt32 aCY)
-{
- if (aFlags & nsIEmbeddingSiteWindow::DIM_FLAGS_POSITION &&
- (aFlags & (nsIEmbeddingSiteWindow::DIM_FLAGS_SIZE_INNER |
- nsIEmbeddingSiteWindow::DIM_FLAGS_SIZE_OUTER))) {
- return mBaseWindow->SetPositionAndSize(aX, aY, aCX, aCY, PR_TRUE);
- }
- else if (aFlags & nsIEmbeddingSiteWindow::DIM_FLAGS_POSITION) {
- return mBaseWindow->SetPosition(aX, aY);
- }
- else if (aFlags & (nsIEmbeddingSiteWindow::DIM_FLAGS_SIZE_INNER |
- nsIEmbeddingSiteWindow::DIM_FLAGS_SIZE_OUTER)) {
- return mBaseWindow->SetSize(aCX, aCY, PR_TRUE);
- }
- return NS_ERROR_INVALID_ARG;
-}
-
-NS_IMETHODIMP
-EmbedWindow::GetDimensions(PRUint32 aFlags, PRInt32 *aX,
- PRInt32 *aY, PRInt32 *aCX, PRInt32 *aCY)
-{
- if (aFlags & nsIEmbeddingSiteWindow::DIM_FLAGS_POSITION &&
- (aFlags & (nsIEmbeddingSiteWindow::DIM_FLAGS_SIZE_INNER |
- nsIEmbeddingSiteWindow::DIM_FLAGS_SIZE_OUTER))) {
- return mBaseWindow->GetPositionAndSize(aX, aY, aCX, aCY);
- }
- else if (aFlags & nsIEmbeddingSiteWindow::DIM_FLAGS_POSITION) {
- return mBaseWindow->GetPosition(aX, aY);
- }
- else if (aFlags & (nsIEmbeddingSiteWindow::DIM_FLAGS_SIZE_INNER |
- nsIEmbeddingSiteWindow::DIM_FLAGS_SIZE_OUTER)) {
- return mBaseWindow->GetSize(aCX, aCY);
- }
- return NS_ERROR_INVALID_ARG;
-}
-
-NS_IMETHODIMP
-EmbedWindow::SetFocus(void)
-{
- // XXX might have to do more here.
- return mBaseWindow->SetFocus();
-}
-
-NS_IMETHODIMP
-EmbedWindow::GetTitle(PRUnichar **aTitle)
-{
- *aTitle = NS_StringCloneData(mTitle);
- return NS_OK;
-}
-
-NS_IMETHODIMP
-EmbedWindow::SetTitle(const PRUnichar *aTitle)
-{
- mTitle = aTitle;
- g_signal_emit (mOwner->mOwningWidget, gecko_embed_signals[TITLE], 0);
-
- return NS_OK;
-}
-
-NS_IMETHODIMP
-EmbedWindow::GetSiteWindow(void **aSiteWindow)
-{
- GtkWidget *ownerAsWidget (GTK_WIDGET(mOwner->mOwningWidget));
- *aSiteWindow = static_cast<void *>(ownerAsWidget);
- return NS_OK;
-}
-
-NS_IMETHODIMP
-EmbedWindow::GetVisibility(PRBool *aVisibility)
-{
- // Work around the problem that sometimes the window
- // is already visible even though mVisibility isn't true
- // yet.
- *aVisibility = mVisibility ||
- (!mOwner->mIsChrome &&
- mOwner->mOwningWidget &&
- GTK_WIDGET_MAPPED(mOwner->mOwningWidget));
- return NS_OK;
-}
-
-NS_IMETHODIMP
-EmbedWindow::SetVisibility(PRBool aVisibility)
-{
- // We always set the visibility so that if it's chrome and we finish
- // the load we know that we have to show the window.
- mVisibility = aVisibility;
-
- // if this is a chrome window and the chrome hasn't finished loading
- // yet then don't show the window yet.
- if (mOwner->mIsChrome && !mOwner->mChromeLoaded)
- return NS_OK;
-
- g_signal_emit (mOwner->mOwningWidget, gecko_embed_signals[VISIBILITY], 0,
- aVisibility);
- return NS_OK;
-}
-
-// nsITooltipListener
-
-static gboolean
-tooltips_paint_window (GtkWidget *window)
-{
- // draw tooltip style border around the text
- gtk_paint_flat_box (window->style, window->window,
- GTK_STATE_NORMAL, GTK_SHADOW_OUT,
- NULL, window, "tooltip",
- 0, 0,
- window->allocation.width, window->allocation.height);
-
- return FALSE;
-}
-
-NS_IMETHODIMP
-EmbedWindow::OnShowTooltip(PRInt32 aXCoords, PRInt32 aYCoords,
- const PRUnichar *aTipText)
-{
- nsEmbedCString tipText;
-
- NS_UTF16ToCString(nsEmbedString(aTipText),
- NS_CSTRING_ENCODING_UTF8, tipText);
-
- if (sTipWindow)
- gtk_widget_destroy(sTipWindow);
-
- // get the root origin for this content window
- nsCOMPtr<nsIWidget> mainWidget;
- mBaseWindow->GetMainWidget(getter_AddRefs(mainWidget));
- GdkWindow *window;
- window = static_cast<GdkWindow *>
- (mainWidget->GetNativeData(NS_NATIVE_WINDOW));
- gint root_x, root_y;
- gdk_window_get_origin(window, &root_x, &root_y);
-
- // XXX work around until I can get pink to figure out why
- // tooltips vanish if they show up right at the origin of the
- // cursor.
- root_y += 10;
-
- sTipWindow = gtk_window_new(GTK_WINDOW_POPUP);
- gtk_widget_set_app_paintable(sTipWindow, TRUE);
- gtk_window_set_policy(GTK_WINDOW(sTipWindow), FALSE, FALSE, TRUE);
- // needed to get colors + fonts etc correctly
- gtk_widget_set_name(sTipWindow, "gtk-tooltips");
-
- // set up the popup window as a transient of the widget.
- GtkWidget *toplevel_window;
- toplevel_window = gtk_widget_get_toplevel(GTK_WIDGET(mOwner->mOwningWidget));
- if (!GTK_WINDOW(toplevel_window)) {
- NS_ERROR("no gtk window in hierarchy!\n");
- return NS_ERROR_FAILURE;
- }
- gtk_window_set_transient_for(GTK_WINDOW(sTipWindow),
- GTK_WINDOW(toplevel_window));
-
- // realize the widget
- gtk_widget_realize(sTipWindow);
-
- g_signal_connect (G_OBJECT(sTipWindow), "expose-event",
- G_CALLBACK(tooltips_paint_window), NULL);
-
- // set up the label for the tooltip
- GtkWidget *label = gtk_label_new(tipText.get());
- // wrap automatically
- gtk_label_set_line_wrap(GTK_LABEL(label), TRUE);
- gtk_container_add(GTK_CONTAINER(sTipWindow), label);
- gtk_container_set_border_width(GTK_CONTAINER(sTipWindow), 4);
- // set the coords for the widget
- gtk_widget_set_uposition(sTipWindow, aXCoords + root_x,
- aYCoords + root_y);
-
- // and show it.
- gtk_widget_show_all(sTipWindow);
-
- return NS_OK;
-}
-
-NS_IMETHODIMP
-EmbedWindow::OnHideTooltip(void)
-{
- if (sTipWindow)
- gtk_widget_destroy(sTipWindow);
- sTipWindow = NULL;
- return NS_OK;
-}
-
-// nsIInterfaceRequestor
-
-NS_IMETHODIMP
-EmbedWindow::GetInterface(const nsIID &aIID, void** aInstancePtr)
-{
- nsresult rv;
-
- rv = QueryInterface(aIID, aInstancePtr);
-
- // pass it up to the web browser object
- if (NS_FAILED(rv) || !*aInstancePtr) {
- nsCOMPtr<nsIInterfaceRequestor> ir = do_QueryInterface(mWebBrowser);
- return ir->GetInterface(aIID, aInstancePtr);
- }
-
- return rv;
-}
diff --git a/embed/xulrunner/src/EmbedWindow.h b/embed/xulrunner/src/EmbedWindow.h
deleted file mode 100644
index e03164d7e..000000000
--- a/embed/xulrunner/src/EmbedWindow.h
+++ /dev/null
@@ -1,97 +0,0 @@
-/*
- * Copyright © Christopher Blizzard
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser 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.
- *
- * ---------------------------------------------------------------------------
- * Derived from Mozilla.org code, which had the following attributions:
- *
- * The Original Code is mozilla.org code.
- *
- * The Initial Developer of the Original Code is
- * Christopher Blizzard. Portions created by Christopher Blizzard are Copyright © Christopher Blizzard. All Rights Reserved.
- * Portions created by the Initial Developer are Copyright © 2001
- * the Initial Developer. All Rights Reserved.
- *
- * Contributor(s):
- * Christopher Blizzard <blizzard@mozilla.org>
- * ---------------------------------------------------------------------------
- *
- * $Id$
- */
-
-#ifndef __EmbedWindow_h
-#define __EmbedWindow_h
-
-#include <nsEmbedString.h>
-#include <nsIWebBrowserChrome.h>
-#include <nsIWebBrowserChromeFocus.h>
-#include <nsIEmbeddingSiteWindow.h>
-#include <nsITooltipListener.h>
-#include <nsISupports.h>
-#include <nsIWebBrowser.h>
-#include <nsIBaseWindow.h>
-#include <nsIInterfaceRequestor.h>
-#include <nsCOMPtr.h>
-
-#include <gtk/gtk.h>
-
-class GeckoBrowser;
-
-class EmbedWindow : public nsIWebBrowserChrome,
- public nsIWebBrowserChromeFocus,
- public nsIEmbeddingSiteWindow,
- public nsITooltipListener,
- public nsIInterfaceRequestor
-{
-
- public:
-
- EmbedWindow();
- virtual ~EmbedWindow();
-
- nsresult Init (GeckoBrowser *aOwner);
- nsresult CreateWindow (void);
- void ReleaseChildren (void);
-
- NS_DECL_ISUPPORTS
-
- NS_DECL_NSIWEBBROWSERCHROME
-
- NS_DECL_NSIWEBBROWSERCHROMEFOCUS
-
- NS_DECL_NSIEMBEDDINGSITEWINDOW
-
- NS_DECL_NSITOOLTIPLISTENER
-
- NS_DECL_NSIINTERFACEREQUESTOR
-
- nsEmbedString mTitle;
- nsEmbedString mJSStatus;
- nsEmbedString mLinkMessage;
-
- nsCOMPtr<nsIBaseWindow> mBaseWindow; // [OWNER]
-
-private:
-
- GeckoBrowser *mOwner;
- nsCOMPtr<nsIWebBrowser> mWebBrowser; // [OWNER]
- static GtkWidget *sTipWindow;
- PRBool mVisibility;
- PRBool mIsModal;
-
-};
-
-#endif /* __EmbedWindow_h */
diff --git a/embed/xulrunner/src/EmbedWindowCreator.cpp b/embed/xulrunner/src/EmbedWindowCreator.cpp
deleted file mode 100644
index e27f0ca37..000000000
--- a/embed/xulrunner/src/EmbedWindowCreator.cpp
+++ /dev/null
@@ -1,108 +0,0 @@
-/*
- * Copyright © Christopher Blizzard
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser 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.
- *
- * ---------------------------------------------------------------------------
- * Derived from Mozilla.org code, which had the following attributions:
- *
- * The Original Code is mozilla.org code.
- *
- * The Initial Developer of the Original Code is
- * Christopher Blizzard. Portions created by Christopher Blizzard are Copyright © Christopher Blizzard. All Rights Reserved.
- * Portions created by the Initial Developer are Copyright © 2001
- * the Initial Developer. All Rights Reserved.
- *
- * Contributor(s):
- * Christopher Blizzard <blizzard@mozilla.org>
- * ---------------------------------------------------------------------------
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include "EmbedWindowCreator.h"
-#include "GeckoBrowser.h"
-#include "GeckoSingle.h"
-#include "EmbedWindow.h"
-
-#include "gecko-embed-private.h"
-#include "gecko-embed-single-private.h"
-#include "gecko-embed-signals.h"
-
-EmbedWindowCreator::EmbedWindowCreator(void)
-{
-}
-
-EmbedWindowCreator::~EmbedWindowCreator()
-{
-}
-
-NS_IMPL_ISUPPORTS1(EmbedWindowCreator, nsIWindowCreator)
-
-NS_IMETHODIMP
-EmbedWindowCreator::CreateChromeWindow(nsIWebBrowserChrome *aParent,
- PRUint32 aChromeFlags,
- nsIWebBrowserChrome **_retval)
-{
- NS_ENSURE_ARG_POINTER(_retval);
-
- GeckoEmbed *newEmbed = nsnull;
-
- // No parent? Ask via the singleton object instead.
- if (!aParent) {
- gecko_embed_single_create_window(&newEmbed,
- (guint)aChromeFlags);
- }
- else {
- // Find the GeckoBrowser object for this web browser chrome object.
- GeckoBrowser *browser = GeckoSingle::FindPrivateForBrowser(aParent);
-
- if (!browser)
- return NS_ERROR_FAILURE;
-
- g_signal_emit (browser->mOwningWidget, gecko_embed_signals[NEW_WINDOW], 0,
- &newEmbed, (guint) aChromeFlags);
-
- }
-
- // check to make sure that we made a new window
- if (!newEmbed)
- return NS_ERROR_FAILURE;
-
- // The window _must_ be realized before we pass it back to the
- // function that created it. Functions that create new windows
- // will do things like GetDocShell() and the widget has to be
- // realized before that can happen.
- gtk_widget_realize(GTK_WIDGET(newEmbed));
-
- GeckoBrowser *newGeckoBrowser = gecko_embed_get_GeckoBrowser (newEmbed);
-
- // set the chrome flag on the new window if it's a chrome open
- if (aChromeFlags & nsIWebBrowserChrome::CHROME_OPENAS_CHROME)
- newGeckoBrowser->mIsChrome = PR_TRUE;
-
- *_retval = static_cast<nsIWebBrowserChrome *>
- ((newGeckoBrowser->mWindow));
-
- if (*_retval) {
- NS_ADDREF(*_retval);
- return NS_OK;
- }
-
- return NS_ERROR_FAILURE;
-}
diff --git a/embed/xulrunner/src/EmbedWindowCreator.h b/embed/xulrunner/src/EmbedWindowCreator.h
deleted file mode 100644
index 9c4e9daa5..000000000
--- a/embed/xulrunner/src/EmbedWindowCreator.h
+++ /dev/null
@@ -1,51 +0,0 @@
-/*
- * Copyright © Christopher Blizzard
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser 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.
- *
- * ---------------------------------------------------------------------------
- * Derived from Mozilla.org code, which had the following attributions:
- *
- * The Original Code is mozilla.org code.
- *
- * The Initial Developer of the Original Code is
- * Christopher Blizzard. Portions created by Christopher Blizzard are Copyright © Christopher Blizzard. All Rights Reserved.
- * Portions created by the Initial Developer are Copyright © 2001
- * the Initial Developer. All Rights Reserved.
- *
- * Contributor(s):
- * Christopher Blizzard <blizzard@mozilla.org>
- * ---------------------------------------------------------------------------
- *
- * $Id$
- */
-
-#ifndef __EmbedWindowCreator_h
-#define __EmbedWindowCreator_h
-
-#include <nsIWindowCreator.h>
-
-class EmbedWindowCreator : public nsIWindowCreator
-{
- public:
- EmbedWindowCreator();
- virtual ~EmbedWindowCreator();
-
- NS_DECL_ISUPPORTS
- NS_DECL_NSIWINDOWCREATOR
-
-};
-
-#endif /* __EmbedWindowCreator_h */
diff --git a/embed/xulrunner/src/GeckoBrowser.cpp b/embed/xulrunner/src/GeckoBrowser.cpp
deleted file mode 100644
index f4facf0ff..000000000
--- a/embed/xulrunner/src/GeckoBrowser.cpp
+++ /dev/null
@@ -1,676 +0,0 @@
-/*
- * Copyright © Christopher Blizzard
- * Copyright © 2006 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser 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.
- *
- * ---------------------------------------------------------------------------
- * Derived from Mozilla.org code, which had the following attributions:
- *
- * The Original Code is mozilla.org code.
- *
- * The Initial Developer of the Original Code is
- * Christopher Blizzard. Portions created by Christopher Blizzard are Copyright © Christopher Blizzard. All Rights Reserved.
- * Portions created by the Initial Developer are Copyright © 2001
- * the Initial Developer. All Rights Reserved.
- *
- * Contributor(s):
- * Christopher Blizzard <blizzard@mozilla.org>
- * ---------------------------------------------------------------------------
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include "nsIDocShell.h"
-#include "nsIWebProgress.h"
-#include "nsIWebBrowserStream.h"
-#include "nsIWebBrowserFocus.h"
-#include "nsIWidget.h"
-#include <stdlib.h>
-
-// for NS_APPSHELL_CID
-#include "nsWidgetsCID.h"
-
-// for do_GetInterface
-#include "nsIInterfaceRequestor.h"
-// for do_CreateInstance
-#include "nsIComponentManager.h"
-
-// for initializing our window watcher service
-#include "nsIWindowWatcher.h"
-
-#include "nsILocalFile.h"
-#include "nsEmbedAPI.h"
-
-// all of the crap that we need for event listeners
-// and when chrome windows finish loading
-#include "nsIDOMWindow.h"
-#include "nsPIDOMWindow.h"
-#include "nsIDOMWindowInternal.h"
-
-// For seting scrollbar visibilty
-#include <nsIDOMBarProp.h>
-
-// for the focus hacking we need to do
-#include "nsIFocusController.h"
-
-// for profiles
-#define STANDALONE_PROFILEDIRSERVICE
-#include "nsProfileDirServiceProvider.h"
-
-// app component registration
-#include "nsIGenericFactory.h"
-#include "nsIComponentRegistrar.h"
-
-// all of our local includes
-#include "GeckoBrowser.h"
-#include "EmbedWindow.h"
-#include "EmbedProgress.h"
-#include "EmbedContentListener.h"
-#include "EmbedEventListener.h"
-#include "EmbedWindowCreator.h"
-
-#ifdef MOZ_ACCESSIBILITY_ATK
-#include "nsIAccessibilityService.h"
-#include "nsIAccessible.h"
-#include "nsIDOMDocument.h"
-#endif
-
-#include "GeckoSingle.h"
-
-GeckoBrowser::GeckoBrowser(void)
- : mOwningWidget(nsnull)
- , mWindow(nsnull)
- , mProgress(nsnull)
- , mContentListener(nsnull)
- , mEventListener(nsnull)
- , mChromeMask(nsIWebBrowserChrome::CHROME_ALL)
- , mIsChrome(PR_FALSE)
- , mChromeLoaded(PR_FALSE)
- , mListenersAttached(PR_FALSE)
- , mMozWindowWidget(nsnull)
- , mIsDestroyed(PR_FALSE)
-{
- GeckoSingle::AddBrowser(this);
-}
-
-GeckoBrowser::~GeckoBrowser()
-{
- GeckoSingle::RemoveBrowser(this);
-}
-
-nsresult
-GeckoBrowser::Init(GeckoEmbed *aOwningWidget)
-{
- // are we being re-initialized?
- if (mOwningWidget)
- return NS_OK;
-
- // hang on with a reference to the owning widget
- mOwningWidget = aOwningWidget;
-
- // Create our embed window, and create an owning reference to it and
- // initialize it. It is assumed that this window will be destroyed
- // when we go out of scope.
- mWindow = new EmbedWindow();
- mWindowGuard = static_cast<nsIWebBrowserChrome *>(mWindow);
- mWindow->Init(this);
-
- // Create our progress listener object, make an owning reference,
- // and initialize it. It is assumed that this progress listener
- // will be destroyed when we go out of scope.
- mProgress = new EmbedProgress();
- mProgressGuard = static_cast<nsIWebProgressListener *>
- (mProgress);
- mProgress->Init(this);
-
- // Create our content listener object, initialize it and attach it.
- // It is assumed that this will be destroyed when we go out of
- // scope.
- mContentListener = new EmbedContentListener();
- mContentListenerGuard = static_cast<nsISupports*>(static_cast<nsIURIContentListener*>(mContentListener));
- mContentListener->Init(this);
-
- // Create our key listener object and initialize it. It is assumed
- // that this will be destroyed before we go out of scope.
- mEventListener = new EmbedEventListener(this);
- mEventListenerGuard =
- static_cast<nsISupports *>(static_cast<nsIDOMKeyListener *>
- (mEventListener));
-
- return NS_OK;
-}
-
-nsresult
-GeckoBrowser::Realize(PRBool *aAlreadyRealized)
-{
-
- *aAlreadyRealized = PR_FALSE;
-
- // Have we ever been initialized before? If so then just reparent
- // from the offscreen window.
- if (mMozWindowWidget) {
- gtk_widget_reparent(mMozWindowWidget, GTK_WIDGET(mOwningWidget));
- *aAlreadyRealized = PR_TRUE;
- return NS_OK;
- }
-
- // Get the nsIWebBrowser object for our embedded window.
- nsCOMPtr<nsIWebBrowser> webBrowser;
- mWindow->GetWebBrowser(getter_AddRefs(webBrowser));
-
- // get a handle on the navigation object
- mNavigation = do_QueryInterface(webBrowser);
-
- // Create our session history object and tell the navigation object
- // to use it. We need to do this before we create the web browser
- // window.
- mSessionHistory = do_CreateInstance(NS_SHISTORY_CONTRACTID);
- mNavigation->SetSessionHistory(mSessionHistory);
-
- // create the window
- mWindow->CreateWindow();
-
- // bind the progress listener to the browser object
- nsCOMPtr<nsISupportsWeakReference> supportsWeak;
- supportsWeak = do_QueryInterface(mProgressGuard);
- nsCOMPtr<nsIWeakReference> weakRef;
- supportsWeak->GetWeakReference(getter_AddRefs(weakRef));
- webBrowser->AddWebBrowserListener(weakRef,
- NS_GET_IID (nsIWebProgressListener));
-
- // set ourselves as the parent uri content listener
- nsCOMPtr<nsIURIContentListener> uriListener;
- uriListener = do_QueryInterface(mContentListenerGuard);
- webBrowser->SetParentURIContentListener(uriListener);
-
- // save the window id of the newly created window
- nsCOMPtr<nsIWidget> mozWidget;
- mWindow->mBaseWindow->GetMainWidget(getter_AddRefs(mozWidget));
- // get the native drawing area
- GdkWindow *tmp_window =
- static_cast<GdkWindow *>
- (mozWidget->GetNativeData(NS_NATIVE_WINDOW));
- // and, thanks to superwin we actually need the parent of that.
- // FIXME is this true on gtk2 widget?
- tmp_window = gdk_window_get_parent(tmp_window);
- // save the widget ID - it should be the mozarea of the window.
- gpointer data = nsnull;
- gdk_window_get_user_data(tmp_window, &data);
- mMozWindowWidget = static_cast<GtkWidget *>(data);
-
- // Apply the current chrome mask
- ApplyChromeMask();
-
- return NS_OK;
-}
-
-void
-GeckoBrowser::Unrealize(void)
-{
- // reparent to our offscreen window
- GeckoSingle::ReparentToOffscreen(mMozWindowWidget);
-}
-
-void
-GeckoBrowser::Show(void)
-{
- // Get the nsIWebBrowser object for our embedded window.
- nsCOMPtr<nsIWebBrowser> webBrowser;
- mWindow->GetWebBrowser (getter_AddRefs (webBrowser));
-
- // and set the visibility on the thing
- nsCOMPtr<nsIBaseWindow> baseWindow (do_QueryInterface (webBrowser));
- baseWindow->SetVisibility(PR_TRUE);
-}
-
-void
-GeckoBrowser::Hide(void)
-{
- // Get the nsIWebBrowser object for our embedded window.
- nsCOMPtr<nsIWebBrowser> webBrowser;
- mWindow->GetWebBrowser (getter_AddRefs (webBrowser));
-
- // and set the visibility on the thing
- nsCOMPtr<nsIBaseWindow> baseWindow (do_QueryInterface (webBrowser));
- baseWindow->SetVisibility (PR_FALSE);
-}
-
-void
-GeckoBrowser::Resize(PRUint32 aWidth, PRUint32 aHeight)
-{
- mWindow->SetDimensions(nsIEmbeddingSiteWindow::DIM_FLAGS_POSITION |
- nsIEmbeddingSiteWindow::DIM_FLAGS_SIZE_INNER,
- 0, 0, aWidth, aHeight);
-}
-
-void
-GeckoBrowser::Destroy(void)
-{
- // This flag might have been set from
- // EmbedWindow::DestroyBrowserWindow() as well if someone used a
- // window.close() or something or some other script action to close
- // the window. No harm setting it again.
- mIsDestroyed = PR_TRUE;
-
- // Get the nsIWebBrowser object for our embedded window.
- nsCOMPtr<nsIWebBrowser> webBrowser;
- mWindow->GetWebBrowser(getter_AddRefs(webBrowser));
-
- // Release our progress listener
- nsCOMPtr<nsISupportsWeakReference> supportsWeak
- (do_QueryInterface(mProgressGuard));
- nsCOMPtr<nsIWeakReference> weakRef;
- supportsWeak->GetWeakReference(getter_AddRefs(weakRef));
- webBrowser->RemoveWebBrowserListener(weakRef,
- NS_GET_IID (nsIWebProgressListener));
- weakRef = nsnull;
- supportsWeak = nsnull;
-
- // Release our content listener
- webBrowser->SetParentURIContentListener(nsnull);
- mContentListenerGuard = nsnull;
- mContentListener = nsnull;
-
- // Now that we have removed the listener, release our progress
- // object
- mProgressGuard = nsnull;
- mProgress = nsnull;
-
- // detach our event listeners and release the event receiver
- DetachListeners();
-
- mEventTarget = nsnull;
-
- // destroy our child window
- mWindow->ReleaseChildren();
-
- // release navigation
- mNavigation = nsnull;
-
- // release session history
- mSessionHistory = nsnull;
-
- mOwningWidget = nsnull;
-
- mMozWindowWidget = 0;
-}
-
-void
-GeckoBrowser::Reload(PRUint32 reloadFlags)
-{
- /* Use the session history if it is available, this
- * allows framesets to reload correctly */
- nsCOMPtr<nsIWebNavigation> wn (do_QueryInterface(mSessionHistory));
-
- if (!wn)
- wn = mNavigation;
-
- NS_ENSURE_TRUE (wn, );
-
- wn->Reload(reloadFlags);
-}
-
-void
-GeckoBrowser::ApplyChromeMask()
-{
- if (mWindow) {
- nsCOMPtr<nsIWebBrowser> webBrowser;
- mWindow->GetWebBrowser(getter_AddRefs(webBrowser));
-
- nsCOMPtr<nsIDOMWindow> domWindow;
- webBrowser->GetContentDOMWindow(getter_AddRefs(domWindow));
- if (domWindow) {
-
- nsCOMPtr<nsIDOMBarProp> scrollbars;
- domWindow->GetScrollbars(getter_AddRefs(scrollbars));
- if (scrollbars) {
-
- scrollbars->SetVisible
- (mChromeMask & nsIWebBrowserChrome::CHROME_SCROLLBARS ?
- PR_TRUE : PR_FALSE);
- }
- }
- }
-}
-
-
-void
-GeckoBrowser::SetChromeMask(PRUint32 aChromeMask)
-{
- mChromeMask = aChromeMask;
-
- ApplyChromeMask();
-}
-
-void
-GeckoBrowser::SetURI(const char *aURI)
-{
- mURI = aURI;
-}
-
-void
-GeckoBrowser::LoadCurrentURI(void)
-{
- if (mURI.Length()) {
- nsCOMPtr<nsPIDOMWindow> piWin;
- GetPIDOMWindow(getter_AddRefs(piWin));
- nsAutoPopupStatePusher popupStatePusher(piWin, openAllowed);
-
- nsEmbedString uri;
- NS_CStringToUTF16(mURI, NS_CSTRING_ENCODING_UTF8, uri);
- mNavigation->LoadURI(uri.get(), // URI string
- nsIWebNavigation::LOAD_FLAGS_NONE, // Load flags
- nsnull, // Referring URI
- nsnull, // Post data
- nsnull); // extra headers
- }
-}
-
-#if 0
-nsresult
-GeckoBrowser::OpenStream(const char *aBaseURI, const char *aContentType)
-{
- nsCOMPtr<nsIWebBrowser> webBrowser;
- mWindow->GetWebBrowser(getter_AddRefs(webBrowser));
-
- nsCOMPtr<nsIWebBrowserStream> wbStream = do_QueryInterface(webBrowser);
- if (!wbStream) return NS_ERROR_FAILURE;
-
- return wbStream->OpenStream(aBaseURI, aContentType);
-}
-
-nsresult
-GeckoBrowser::AppendToStream(const char *aData, PRInt32 aLen)
-{
- // Attach listeners to this document since in some cases we don't
- // get updates for content added this way.
- ContentStateChange();
-
- nsCOMPtr<nsIWebBrowser> webBrowser;
- mWindow->GetWebBrowser(getter_AddRefs(webBrowser));
-
- nsCOMPtr<nsIWebBrowserStream> wbStream = do_QueryInterface(webBrowser);
- if (!wbStream) return NS_ERROR_FAILURE;
-
- return wbStream->AppendToStream(aData, aLen);
-}
-
-nsresult
-GeckoBrowser::CloseStream(void)
-{
- nsCOMPtr<nsIWebBrowser> webBrowser;
- mWindow->GetWebBrowser(getter_AddRefs(webBrowser));
-
- nsCOMPtr<nsIWebBrowserStream> wbStream = do_QueryInterface(webBrowser);
- if (!wbStream) return NS_ERROR_FAILURE;
-
- return wbStream->CloseStream();
-}
-#endif
-
-void
-GeckoBrowser::ContentStateChange(void)
-{
-
- // we don't attach listeners to chrome
- if (mListenersAttached && !mIsChrome)
- return;
-
- GetListener();
-
- if (!mEventTarget)
- return;
-
- AttachListeners();
-
-}
-
-void
-GeckoBrowser::ContentFinishedLoading(void)
-{
- if (mIsChrome) {
- // We're done loading.
- mChromeLoaded = PR_TRUE;
-
- // get the web browser
- nsCOMPtr<nsIWebBrowser> webBrowser;
- mWindow->GetWebBrowser(getter_AddRefs(webBrowser));
-
- // get the content DOM window for that web browser
- nsCOMPtr<nsIDOMWindow> domWindow;
- webBrowser->GetContentDOMWindow(getter_AddRefs(domWindow));
- if (!domWindow) {
- NS_WARNING("no dom window in content finished loading\n");
- return;
- }
-
- // resize the content
- domWindow->SizeToContent();
-
- // and since we're done loading show the window, assuming that the
- // visibility flag has been set.
- PRBool visibility;
- mWindow->GetVisibility(&visibility);
- if (visibility)
- mWindow->SetVisibility(PR_TRUE);
- }
-}
-
-void
-GeckoBrowser::ChildFocusIn(void)
-{
- if (mIsDestroyed)
- return;
-
- nsresult rv;
- nsCOMPtr<nsIWebBrowser> webBrowser;
- rv = mWindow->GetWebBrowser(getter_AddRefs(webBrowser));
- if (NS_FAILED(rv))
- return;
-
- nsCOMPtr<nsIWebBrowserFocus> webBrowserFocus(do_QueryInterface(webBrowser));
- if (!webBrowserFocus)
- return;
-
- webBrowserFocus->Activate();
-}
-
-void
-GeckoBrowser::ChildFocusOut(void)
-{
- if (mIsDestroyed)
- return;
-
- nsresult rv;
- nsCOMPtr<nsIWebBrowser> webBrowser;
- rv = mWindow->GetWebBrowser(getter_AddRefs(webBrowser));
- if (NS_FAILED(rv))
- return;
-
- nsCOMPtr<nsIWebBrowserFocus> webBrowserFocus(do_QueryInterface(webBrowser));
- if (!webBrowserFocus)
- return;
-
- webBrowserFocus->Deactivate();
-}
-
-// Get the event listener for the chrome event handler.
-
-void
-GeckoBrowser::GetListener(void)
-{
- if (mEventTarget)
- return;
-
- nsCOMPtr<nsPIDOMWindow> piWin;
- GetPIDOMWindow(getter_AddRefs(piWin));
-
- if (!piWin)
- return;
-
- mEventTarget = do_QueryInterface(piWin->GetChromeEventHandler());
-}
-
-// attach key and mouse event listeners
-
-void
-GeckoBrowser::AttachListeners(void)
-{
- if (!mEventTarget || mListenersAttached)
- return;
-
- nsIDOMEventListener *eventListener =
- static_cast<nsIDOMEventListener *>
- (static_cast<nsIDOMKeyListener *>(mEventListener));
-
- // add the key listener
- nsresult rv;
- rv = mEventTarget->AddEventListenerByIID(eventListener,
- NS_GET_IID(nsIDOMKeyListener));
- if (NS_FAILED(rv)) {
- NS_WARNING("Failed to add key listener\n");
- return;
- }
-
- rv = mEventTarget->AddEventListenerByIID(eventListener,
- NS_GET_IID(nsIDOMMouseListener));
- if (NS_FAILED(rv)) {
- NS_WARNING("Failed to add mouse listener\n");
- return;
- }
-
- rv = mEventTarget->AddEventListenerByIID(eventListener,
- NS_GET_IID(nsIDOMUIListener));
- if (NS_FAILED(rv)) {
- NS_WARNING("Failed to add UI listener\n");
- return;
- }
-
- rv = mEventTarget->AddEventListenerByIID(eventListener,
- NS_GET_IID(nsIDOMContextMenuListener));
- if (NS_FAILED(rv)) {
- NS_WARNING("Failed to add context menu listener\n");
- return;
- }
-
- // ok, all set.
- mListenersAttached = PR_TRUE;
-}
-
-void
-GeckoBrowser::DetachListeners(void)
-{
- if (!mListenersAttached || !mEventTarget)
- return;
-
- nsIDOMEventListener *eventListener =
- static_cast<nsIDOMEventListener *>
- (static_cast<nsIDOMKeyListener *>(mEventListener));
-
- nsresult rv;
- rv = mEventTarget->RemoveEventListenerByIID(eventListener,
- NS_GET_IID(nsIDOMKeyListener));
- if (NS_FAILED(rv)) {
- NS_WARNING("Failed to remove key listener\n");
- return;
- }
-
- rv =
- mEventTarget->RemoveEventListenerByIID(eventListener,
- NS_GET_IID(nsIDOMMouseListener));
- if (NS_FAILED(rv)) {
- NS_WARNING("Failed to remove mouse listener\n");
- return;
- }
-
- rv = mEventTarget->RemoveEventListenerByIID(eventListener,
- NS_GET_IID(nsIDOMUIListener));
- if (NS_FAILED(rv)) {
- NS_WARNING("Failed to remove UI listener\n");
- return;
- }
-
- rv = mEventTarget->RemoveEventListenerByIID(eventListener,
- NS_GET_IID(nsIDOMContextMenuListener));
- if (NS_FAILED(rv)) {
- NS_WARNING("Failed to remove context menu listener\n");
- return;
- }
-
- mListenersAttached = PR_FALSE;
-}
-
-nsresult
-GeckoBrowser::GetPIDOMWindow(nsPIDOMWindow **aPIWin)
-{
- *aPIWin = nsnull;
-
- // get the web browser
- nsCOMPtr<nsIWebBrowser> webBrowser;
- mWindow->GetWebBrowser(getter_AddRefs(webBrowser));
-
- // get the content DOM window for that web browser
- nsCOMPtr<nsIDOMWindow> domWindow;
- webBrowser->GetContentDOMWindow(getter_AddRefs(domWindow));
- if (!domWindow)
- return NS_ERROR_FAILURE;
-
- // get the private DOM window
- nsCOMPtr<nsPIDOMWindow> domWindowPrivate = do_QueryInterface(domWindow);
- // and the root window for that DOM window
- *aPIWin = domWindowPrivate->GetPrivateRoot();
-
- if (*aPIWin) {
- NS_ADDREF(*aPIWin);
- return NS_OK;
- }
-
- return NS_ERROR_FAILURE;
-}
-
-#ifdef MOZ_ACCESSIBILITY_ATK
-// FIXME does this REALLY work with frames?
-void *
-GeckoBrowser::GetAtkObjectForCurrentDocument()
-{
- if (!mNavigation)
- return nsnull;
-
- nsCOMPtr<nsIAccessibilityService> accService =
- do_GetService("@mozilla.org/accessibilityService;1");
- if (accService) {
- //get current document
- nsCOMPtr<nsIDOMDocument> domDoc;
- mNavigation->GetDocument(getter_AddRefs(domDoc));
- NS_ENSURE_TRUE(domDoc, nsnull);
-
- nsCOMPtr<nsIDOMNode> domNode(do_QueryInterface(domDoc));
- NS_ENSURE_TRUE(domNode, nsnull);
-
- nsCOMPtr<nsIAccessible> acc;
- accService->GetAccessibleFor(domNode, getter_AddRefs(acc));
- NS_ENSURE_TRUE(acc, nsnull);
-
- void *atkObj = nsnull;
- if (NS_SUCCEEDED(acc->GetNativeInterface(&atkObj)))
- return atkObj;
- }
- return nsnull;
-}
-#endif /* MOZ_ACCESSIBILITY_ATK */
diff --git a/embed/xulrunner/src/GeckoBrowser.h b/embed/xulrunner/src/GeckoBrowser.h
deleted file mode 100644
index 0d7a86af3..000000000
--- a/embed/xulrunner/src/GeckoBrowser.h
+++ /dev/null
@@ -1,159 +0,0 @@
-/*
- * Copyright © Christopher Blizzard
- * Copyright © 2006 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser 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.
- *
- * ---------------------------------------------------------------------------
- * Derived from Mozilla.org code, which had the following attributions:
- *
- * The Original Code is mozilla.org code.
- *
- * The Initial Developer of the Original Code is
- * Christopher Blizzard. Portions created by Christopher Blizzard are Copyright © Christopher Blizzard. All Rights Reserved.
- * Portions created by the Initial Developer are Copyright © 2001
- * the Initial Developer. All Rights Reserved.
- *
- * Contributor(s):
- * Christopher Blizzard <blizzard@mozilla.org>
- * ---------------------------------------------------------------------------
- *
- * $Id$
- */
-
-#ifndef __GeckoBrowser_h
-#define __GeckoBrowser_h
-
-#include <nsCOMPtr.h>
-#include <nsEmbedString.h>
-#include <nsIWebNavigation.h>
-#include <nsISHistory.h>
-// for our one function that gets the GeckoBrowser via the chrome
-// object.
-#include <nsIWebBrowserChrome.h>
-#include <nsIAppShell.h>
-#include <nsPIDOMEventTarget.h>
-// app component registration
-#include <nsIGenericFactory.h>
-#include <nsIComponentRegistrar.h>
-
-#include "gecko-embed.h"
-
-class EmbedProfile;
-class EmbedProgress;
-class EmbedWindow;
-class EmbedContentListener;
-class EmbedEventListener;
-
-class nsPIDOMWindow;
-class nsIDirectoryServiceProvider;
-class nsProfileDirServiceProvider;
-
-class GeckoBrowser {
-
- public:
-
- GeckoBrowser();
- ~GeckoBrowser();
-
- nsresult Init (GeckoEmbed *aOwningWidget);
- nsresult Realize (PRBool *aAlreadRealized);
- void Unrealize (void);
- void Show (void);
- void Hide (void);
- void Resize (PRUint32 aWidth, PRUint32 aHeight);
- void Destroy (void);
- void SetURI (const char *aURI);
- void LoadCurrentURI (void);
- void Reload (PRUint32 reloadFlags);
-
- void SetChromeMask (PRUint32 chromeMask);
- void ApplyChromeMask ();
-
- nsresult OpenStream (const char *aBaseURI, const char *aContentType);
- nsresult AppendToStream (const char *aData, PRInt32 aLen);
- nsresult CloseStream (void);
-
- // This is an upcall that will come from the progress listener
- // whenever there is a content state change. We need this so we can
- // attach event listeners.
- void ContentStateChange (void);
-
- // This is an upcall from the progress listener when content is
- // finished loading. We have this so that if it's chrome content
- // that we can size to content properly and show ourselves if
- // visibility is set.
- void ContentFinishedLoading(void);
-
- // these let the widget code know when the toplevel window gets and
- // looses focus.
- void TopLevelFocusIn (void);
- void TopLevelFocusOut(void);
-
- // these are when the widget itself gets focus in and focus out
- // events
- void ChildFocusIn (void);
- void ChildFocusOut(void);
-
-#ifdef MOZ_ACCESSIBILITY_ATK
- void *GetAtkObjectForCurrentDocument();
-#endif
-
- GeckoEmbed *mOwningWidget;
-
- // all of the objects that we own
- EmbedWindow *mWindow;
- nsCOMPtr<nsISupports> mWindowGuard;
- EmbedProgress *mProgress;
- nsCOMPtr<nsISupports> mProgressGuard;
- EmbedContentListener *mContentListener;
- nsCOMPtr<nsISupports> mContentListenerGuard;
- EmbedEventListener *mEventListener;
- nsCOMPtr<nsISupports> mEventListenerGuard;
-
- nsCOMPtr<nsIWebNavigation> mNavigation;
- nsCOMPtr<nsISHistory> mSessionHistory;
-
- // our event receiver
- nsCOMPtr<nsPIDOMEventTarget> mEventTarget;
-
- // the currently loaded uri
- nsEmbedCString mURI;
-
- // chrome mask
- PRUint32 mChromeMask;
- // is this a chrome window?
- PRBool mIsChrome;
- // has the chrome finished loading?
- PRBool mChromeLoaded;
- // saved window ID for reparenting later
- GtkWidget *mMozWindowWidget;
- // has someone called Destroy() on us?
- PRBool mIsDestroyed;
-
- private:
-
- // is the chrome listener attached yet?
- PRBool mListenersAttached;
-
- void GetListener (void);
- void AttachListeners (void);
- void DetachListeners (void);
-
- // this will get the PIDOMWindow for this widget
- nsresult GetPIDOMWindow (nsPIDOMWindow **aPIWin);
-};
-
-#endif /* __GeckoBrowser_h */
diff --git a/embed/xulrunner/src/GeckoSingle.cpp b/embed/xulrunner/src/GeckoSingle.cpp
deleted file mode 100644
index beb4b245a..000000000
--- a/embed/xulrunner/src/GeckoSingle.cpp
+++ /dev/null
@@ -1,122 +0,0 @@
-/*
- * Copyright © Christopher Blizzard
- * Copyright © 2006 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser 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.
- *
- * ---------------------------------------------------------------------------
- * Derived from Mozilla.org code, which had the following attributions:
- *
- * The Original Code is mozilla.org code.
- *
- * The Initial Developer of the Original Code is
- * Christopher Blizzard. Portions created by Christopher Blizzard are Copyright © Christopher Blizzard. All Rights Reserved.
- * Portions created by the Initial Developer are Copyright © 2001
- * the Initial Developer. All Rights Reserved.
- *
- * Contributor(s):
- * Christopher Blizzard <blizzard@mozilla.org>
- * ---------------------------------------------------------------------------
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include <config.h>
-
-#include <stdlib.h>
-#include "nsIDocShell.h"
-#include "nsIWebProgress.h"
-#include "nsIWebBrowserStream.h"
-#include "nsIWidget.h"
-
-// all of our local includes
-#include "GeckoSingle.h"
-#include "EmbedWindow.h"
-#include "gecko-init.h"
-#include "gecko-init-private.h"
-
-GSList *GeckoSingle::sWindowList = nsnull;
-PRUint32 GeckoSingle::sWidgetCount = 0;
-
-GeckoSingle::GeckoSingle()
-{
-}
-
-GeckoSingle::~GeckoSingle()
-{
-}
-
-/* static */
-GeckoBrowser *
-GeckoSingle::FindPrivateForBrowser(nsIWebBrowserChrome *aBrowser)
-{
- // This function doesn't get called very often at all ( only when
- // creating a new window ) so it's OK to walk the list of open
- // windows.
- for (GSList *l = sWindowList; l != NULL; l = l->next) {
- GeckoBrowser *tmpPrivate = static_cast<GeckoBrowser *>(l->data);
- // get the browser object for that window
- nsIWebBrowserChrome *chrome = static_cast<nsIWebBrowserChrome *>
- (tmpPrivate->mWindow);
- if (chrome == aBrowser)
- return tmpPrivate;
- }
-
- return nsnull;
-}
-
-/* static */
-void
-GeckoSingle::ReparentToOffscreen (GtkWidget* aWidget)
-{
- gecko_reparent_to_offscreen (aWidget);
-}
-
-/* static */
-void
-GeckoSingle::AddBrowser(GeckoBrowser *aBrowser)
-{
- PushStartup();
- sWindowList = g_slist_prepend (sWindowList, aBrowser);
-}
-
-/* static */
-void
-GeckoSingle::RemoveBrowser(GeckoBrowser *aBrowser)
-{
- sWindowList = g_slist_remove (sWindowList, aBrowser);
- PopStartup();
-}
-
-/* static */
-void
-GeckoSingle::PushStartup()
-{
- GeckoSingle::sWidgetCount++;
-}
-
-/* static */
-void
-GeckoSingle::PopStartup()
-{
- GeckoSingle::sWidgetCount--;
- if (GeckoSingle::sWidgetCount == 0) {
- gecko_shutdown();
-#ifdef XPCOM_GLUE
- XPCOMGlueShutdown();
-#endif
- }
-}
diff --git a/embed/xulrunner/src/GeckoSingle.h b/embed/xulrunner/src/GeckoSingle.h
deleted file mode 100644
index 7654d9a9d..000000000
--- a/embed/xulrunner/src/GeckoSingle.h
+++ /dev/null
@@ -1,97 +0,0 @@
-/*
- * Copyright © Christopher Blizzard
- * Copyright © 2006 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser 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.
- *
- * ---------------------------------------------------------------------------
- * Derived from Mozilla.org code, which had the following attributions:
- *
- * The Original Code is mozilla.org code.
- *
- * The Initial Developer of the Original Code is
- * Christopher Blizzard. Portions created by Christopher Blizzard are Copyright © Christopher Blizzard. All Rights Reserved.
- * Portions created by the Initial Developer are Copyright © 2001
- * the Initial Developer. All Rights Reserved.
- *
- * Contributor(s):
- * Christopher Blizzard <blizzard@mozilla.org>
- * ---------------------------------------------------------------------------
- *
- * $Id$
- */
-
-#ifndef __GeckoSingle_h
-#define __GeckoSingle_h
-
-#include <nsCOMPtr.h>
-#include <nsEmbedString.h>
-#include <nsIWebNavigation.h>
-#include <nsISHistory.h>
-// for our one function that gets the GeckoSingle via the chrome
-// object.
-#include <nsIWebBrowserChrome.h>
-#include <nsIAppShell.h>
-// app component registration
-#include <nsIGenericFactory.h>
-#include <nsIComponentRegistrar.h>
-
-#include "gecko-embed-single.h"
-#include "gecko-embed.h"
-
-#include "GeckoBrowser.h"
-
-class EmbedProfile;
-class EmbedProgress;
-class EmbedWindow;
-class EmbedContentListener;
-class EmbedEventListener;
-
-class nsPIDOMWindow;
-class nsIDirectoryServiceProvider;
-class nsProfileDirServiceProvider;
-
-class GeckoSingle
-{
- friend class GeckoBrowser;
-
- public:
-
- GeckoSingle();
- ~GeckoSingle();
-
- static void PushStartup ();
- static void PopStartup ();
-
- // static GeckoSingle* GetInstance();
-
- // This function will find the specific GeckoBrowser object for a
- // given nsIWebBrowserChrome.
- static GeckoBrowser *FindPrivateForBrowser(nsIWebBrowserChrome *aBrowser);
-
- // the number of widgets that have been created
- static PRUint32 sWidgetCount;
- // the list of application-specific components to register
- static const nsModuleComponentInfo *sAppComps;
- static int sNumAppComps;
- // the list of all open windows
- static GSList *sWindowList;
-
- static void ReparentToOffscreen (GtkWidget *aWidget);
- static void AddBrowser (GeckoBrowser *aBrowser);
- static void RemoveBrowser (GeckoBrowser *aBrowser);
-};
-
-#endif /* __GeckoSingle_h */
diff --git a/embed/xulrunner/src/Makefile.am b/embed/xulrunner/src/Makefile.am
deleted file mode 100644
index 0d205386a..000000000
--- a/embed/xulrunner/src/Makefile.am
+++ /dev/null
@@ -1,132 +0,0 @@
-NULL =
-
-MARSHALERS = gecko-embed-marshal.h gecko-embed-marshal.cpp
-TYPES_SOURCES = gecko-embed-type-builtins.h gecko-embed-type-builtins.cpp
-
-BUILT_SOURCES= $(MARSHALERS) $(TYPES_SOURCES)
-
-gecko-embed-marshal.cpp: gecko-embed-marshal.list
- $(GLIB_GENMARSHAL) --prefix=gecko_embed_marshal $< --header --body > $@
-
-gecko-embed-marshal.h: gecko-embed-marshal.list
- $(GLIB_GENMARSHAL) --prefix=gecko_embed_marshal $< --header > $@
-
-TYPES_H_FILES = \
- gecko-embed-types.h \
- $(NULL)
-
-stamp_files = \
- stamp-gecko-embed-type-builtins.cpp \
- stamp-gecko-embed-type-builtins.h \
- $(NULL)
-
-gecko-embed-type-builtins.cpp: stamp-gecko-embed-type-builtins.cpp Makefile
- @true
-stamp-gecko-embed-type-builtins.cpp: Makefile $(TYPES_H_FILES)
- $(GLIB_MKENUMS) \
- --fhead "#include \"gecko-embed-type-builtins.h\"\n\n" \
- --fprod "\n/* enumerations from \"@filename@\" */" \
- --fprod "\n#include \"@filename@\"" \
- --vhead "GType\n@enum_name@_get_type (void)\n{\n" \
- --vhead " static GType type = 0;\n\n" \
- --vhead " if (G_UNLIKELY (type == 0))\n {\n" \
- --vhead " static const G@Type@Value _@enum_name@_values[] = {" \
- --vprod " { @VALUENAME@, \"@VALUENAME@\", \"@valuenick@\" }," \
- --vtail " { 0, NULL, NULL }\n };\n\n" \
- --vtail " type = g_@type@_register_static (\"@EnumName@\", _@enum_name@_values);\n }\n\n" \
- --vtail " return type;\n}\n\n" \
- $(filter-out $<,$^) > xgen-$(@F) \
- && ( cmp -s xgen-$(@F) $(@F:stamp-%=%) || cp xgen-$(@F) $(@F:stamp-%=%) ) \
- && rm -f xgen-$(@F) \
- && echo timestamp > $(@F)
-
-gecko-embed-type-builtins.h: stamp-gecko-embed-type-builtins.h Makefile
- @true
-stamp-gecko-embed-type-builtins.h: Makefile $(TYPES_H_FILES)
- $(GLIB_MKENUMS) \
- --fhead "#ifndef GECKO_TYPE_BUILTINS_H\n" \
- --fhead "#define GECKO_TYPE_BUILTINS_H 1\n\n" \
- --fhead "#include <glib-object.h>\n\n" \
- --fhead "G_BEGIN_DECLS\n\n" \
- --ftail "G_END_DECLS\n\n" \
- --ftail "#endif /* GECKO_TYPE_BUILTINS_H */\n" \
- --fprod "\n/* --- @filename@ --- */" \
- --eprod "#define GECKO_TYPE_@ENUMSHORT@ @enum_name@_get_type()\n" \
- --eprod "GType @enum_name@_get_type (void);\n" \
- $(filter-out $<,$^) > xgen-$(@F) \
- && ( cmp -s xgen-$(@F) $(@F:stamp-%=%) || cp xgen-$(@F) $(@F:stamp-%=%) ) \
- && rm -f xgen-$(@F) \
- && echo timestamp > $(@F)
-
-noinst_LTLIBRARIES = libgnomegeckoembed.la
-
-libgnomegeckoembed_la_SOURCES = \
- $(MARSHALERS) \
- $(TYPES_SOURCES) \
- gecko-dom-event.cpp \
- gecko-dom-event.h \
- gecko-dom-event-internal.h \
- gecko-dom-event-private.h \
- gecko-embed.cpp \
- gecko-embed.h \
- gecko-embed-private.h \
- gecko-embed-signals.h \
- gecko-embed-single.cpp \
- gecko-embed-single.h \
- gecko-embed-single-private.h \
- gecko-embed-types.h \
- gecko-init.cpp \
- gecko-init.h \
- gecko-init-internal.h \
- gecko-init-private.h \
- EmbedContentListener.cpp \
- EmbedContentListener.h \
- EmbedEventListener.cpp \
- EmbedEventListener.h \
- EmbedProgress.cpp \
- EmbedProgress.h \
- EmbedWindow.cpp \
- EmbedWindowCreator.cpp \
- EmbedWindowCreator.h \
- EmbedWindow.h \
- GeckoBrowser.cpp \
- GeckoBrowser.h \
- GeckoSingle.cpp \
- GeckoSingle.h \
- $(NULL)
-
-libgnomegeckoembed_la_CPPFLAGS = \
- -I$(top_srcdir)/embed/xulrunner/utils \
- $(LIBXUL_CXXCPPFLAGS) \
- $(LIBXUL_INCLUDES) \
- $(AM_CPPFLAGS)
-
-# -DDEBUG \
-# -DXPCOM_GLUE
-#-DMOZILLA_STRICT_API
-
-libgnomegeckoembed_la_CXXFLAGS = \
- $(LIBXUL_CXXFLAGS) \
- $(GTK_CFLAGS) \
- $(AM_CXXFLAGS)
-
-libgnomegeckoembed_la_LDFLAGS = \
- $(AM_LDFLAGS)
-
-libgnomegeckoembed_la_LIBADD = \
- $(LIBXUL_LIBS)
-
-gnomegeckoembedincludedir = $(includedir)/gnome-gecko-embed-0.0
-gnomegeckoembedinclude_HEADERS =
-
-gnomegeckoembedsubincludedir = $(includedir)/gnome-gecko-embed-0.0/gecko-embed
-gnomegeckoembedsubinclude_HEADERS =
-
-CLEANFILES = \
- $(stamp_files) \
- $(BUILT_SOURCES) \
- $(NULL)
-
-EXTRA_DIST = \
- gecko-embed-marshal.list \
- $(NULL)
diff --git a/embed/xulrunner/src/gecko-dom-event-internal.h b/embed/xulrunner/src/gecko-dom-event-internal.h
deleted file mode 100644
index 2d0309bd9..000000000
--- a/embed/xulrunner/src/gecko-dom-event-internal.h
+++ /dev/null
@@ -1,28 +0,0 @@
-/*
- * Copyright © 2006 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser 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.
- *
- * $Id$
- */
-
-#ifndef GECKO_DOM_EVENT_INTERNAL_H
-#define GECKO_DOM_EVENT_INTERNAL_H
-
-class nsIDOMEvent;
-
-nsIDOMEvent * gecko_dom_event_get_I (GeckoDOMEvent *);
-
-#endif
diff --git a/embed/xulrunner/src/gecko-dom-event-private.h b/embed/xulrunner/src/gecko-dom-event-private.h
deleted file mode 100644
index 995f8cec0..000000000
--- a/embed/xulrunner/src/gecko-dom-event-private.h
+++ /dev/null
@@ -1,38 +0,0 @@
-/*
- * Copyright © 2006 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser 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.
- *
- * $Id$
- */
-
-#ifndef GECKO_DOM_EVENT_PRIVATE_H
-#define GECKO_DOM_EVENT_PRIVATE_H
-
-struct _GeckoDOMEvent {
- nsIDOMEvent *mEvent;
-};
-
-class nsIDOMEvent;
-
-#define GECKO_DOM_EVENT_STATIC_INIT(aEvent,aDOMEvent) \
-{ aEvent.mEvent = aDOMEvent; }
-
-#define GECKO_DOM_EVENT_STATIC_DEINIT(aEvent) \
-{ }
-
-GeckoDOMEvent *gecko_dom_event_new (nsIDOMEvent *);
-
-#endif
diff --git a/embed/xulrunner/src/gecko-dom-event.cpp b/embed/xulrunner/src/gecko-dom-event.cpp
deleted file mode 100644
index 3eb81929e..000000000
--- a/embed/xulrunner/src/gecko-dom-event.cpp
+++ /dev/null
@@ -1,78 +0,0 @@
-/*
- * Copyright © 2006 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser 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.
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include "gecko-dom-event.h"
-#include "gecko-dom-event-internal.h"
-#include "gecko-dom-event-private.h"
-
-#include <nsIDOMEvent.h>
-
-/* GType implementation */
-
-GType
-gecko_dom_event_get_type (void)
-{
- static GType type = 0;
-
- if (G_UNLIKELY (type == 0)) {
- type = g_boxed_type_register_static
- ("GeckoDOMEvent",
- (GBoxedCopyFunc) gecko_dom_event_copy,
- (GBoxedFreeFunc) gecko_dom_event_free);
- }
-
- return type;
-}
-
-/* Public API */
-
-GeckoDOMEvent *
-gecko_dom_event_new (nsIDOMEvent *aEvent)
-{
- /* FIXME use slice alloc */
- GeckoDOMEvent *event = g_new (GeckoDOMEvent, 1);
-
- NS_ADDREF (event->mEvent = aEvent);
-
- return event;
-}
-
-GeckoDOMEvent *
-gecko_dom_event_copy (GeckoDOMEvent *aEvent)
-{
- return gecko_dom_event_new (aEvent->mEvent);
-}
-
-void
-gecko_dom_event_free (GeckoDOMEvent *aEvent)
-{
- NS_RELEASE (aEvent->mEvent);
- /* FIXME slice alloc */
- g_free (aEvent);
-}
-
-nsIDOMEvent *
-gecko_dom_event_get_I (GeckoDOMEvent *aEvent)
-{
- return aEvent->mEvent;
-}
diff --git a/embed/xulrunner/src/gecko-dom-event.h b/embed/xulrunner/src/gecko-dom-event.h
deleted file mode 100644
index ee1a40768..000000000
--- a/embed/xulrunner/src/gecko-dom-event.h
+++ /dev/null
@@ -1,40 +0,0 @@
-/*
- * Copyright © 2006 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser 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.
- *
- * $Id$
- */
-
-#ifndef GECKO_DOM_EVENT_H
-#define GECKO_DOM_EVENT_H
-
-#include <glib-object.h>
-
-G_BEGIN_DECLS
-
-#define GECKO_TYPE_DOM_EVENT (gecko_dom_event_get_type ())
-
-typedef struct _GeckoDOMEvent GeckoDOMEvent;
-
-GType gecko_dom_event_get_type (void);
-
-GeckoDOMEvent * gecko_dom_event_copy (GeckoDOMEvent *);
-
-void gecko_dom_event_free (GeckoDOMEvent *);
-
-G_END_DECLS
-
-#endif
diff --git a/embed/xulrunner/src/gecko-embed-marshal.list b/embed/xulrunner/src/gecko-embed-marshal.list
deleted file mode 100644
index f32b027a6..000000000
--- a/embed/xulrunner/src/gecko-embed-marshal.list
+++ /dev/null
@@ -1,10 +0,0 @@
-BOOLEAN:BOXED
-BOOLEAN:POINTER
-BOOLEAN:STRING
-VOID:INT,INT
-VOID:INT,UINT
-VOID:OBJECT,UINT
-VOID:POINTER,INT,POINTER
-VOID:POINTER,UINT
-VOID:STRING,INT,INT
-VOID:STRING,INT,UINT
diff --git a/embed/xulrunner/src/gecko-embed-private.h b/embed/xulrunner/src/gecko-embed-private.h
deleted file mode 100644
index 8f3fcae09..000000000
--- a/embed/xulrunner/src/gecko-embed-private.h
+++ /dev/null
@@ -1,54 +0,0 @@
-/*
- * Copyright © Christopher Blizzard
- * Copyright © 2006 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser 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.
- *
- * ---------------------------------------------------------------------------
- * Derived from Mozilla.org code, which had the following attributions:
- *
- * The Original Code is mozilla.org code.
- *
- * The Initial Developer of the Original Code is
- * Christopher Blizzard. Portions created by Christopher Blizzard are Copyright © Christopher Blizzard. All Rights Reserved.
- * Portions created by the Initial Developer are Copyright © 2001
- * the Initial Developer. All Rights Reserved.
- *
- * Contributor(s):
- * Christopher Blizzard <blizzard@mozilla.org>
- * ---------------------------------------------------------------------------
- *
- * $Id$
- */
-
-#ifndef gecko_embed_private_h
-#define gecko_embed_private_h
-
-#include "gecko-embed.h"
-
-class nsIWebBrowser;
-class GeckoBrowser;
-
-G_BEGIN_DECLS
-
-extern void gecko_embed_get_nsIWebBrowser (GeckoEmbed *embed,
- nsIWebBrowser **retval);
-
-extern GeckoBrowser* gecko_embed_get_GeckoBrowser (GeckoEmbed *embed);
-
-
-G_END_DECLS
-
-#endif /* gecko_embed_private_h */
diff --git a/embed/xulrunner/src/gecko-embed-signals.h b/embed/xulrunner/src/gecko-embed-signals.h
deleted file mode 100644
index d5d67b351..000000000
--- a/embed/xulrunner/src/gecko-embed-signals.h
+++ /dev/null
@@ -1,82 +0,0 @@
-/*
- * Copyright © Christopher Blizzard
- * Copyright © 2006 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser 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.
- *
- * ---------------------------------------------------------------------------
- * Derived from Mozilla.org code, which had the following attributions:
- *
- * The Original Code is mozilla.org code.
- *
- * The Initial Developer of the Original Code is
- * Christopher Blizzard. Portions created by Christopher Blizzard are Copyright © Christopher Blizzard. All Rights Reserved.
- * Portions created by the Initial Developer are Copyright © 2001
- * the Initial Developer. All Rights Reserved.
- *
- * Contributor(s):
- * Christopher Blizzard <blizzard@mozilla.org>
- * ---------------------------------------------------------------------------
- *
- * $Id$
- */
-
-#ifndef gecko_embed_signals_h
-#define gecko_embed_signals_h
-
-#include <glib.h>
-
-G_BEGIN_DECLS
-
-typedef enum {
- DOM_KEY_DOWN,
- DOM_KEY_PRESS,
- DOM_KEY_UP,
- DOM_MOUSE_DOWN,
- DOM_MOUSE_UP,
- DOM_MOUSE_CLICK,
- DOM_MOUSE_DOUBLE_CLICK,
- DOM_MOUSE_OVER,
- DOM_MOUSE_OUT,
- DOM_ACTIVATE,
- DOM_FOCUS_IN,
- DOM_FOCUS_OUT,
- DOM_CONTEXT_MENU,
-
- LINK_MESSAGE,
- JS_STATUS,
- LOCATION,
- TITLE,
- PROGRESS,
- PROGRESS_ALL,
- NET_STATE,
- NET_STATE_ALL,
- NET_START,
- NET_STOP,
- NEW_WINDOW,
- VISIBILITY,
- DESTROY_BROWSER,
- OPEN_URI,
- SIZE_TO,
- SECURITY_CHANGE,
- STATUS_CHANGE,
- LAST_EMBED_SIGNAL
-} GeckoEmbedSignals;
-
-extern guint gecko_embed_signals[LAST_EMBED_SIGNAL];
-
-G_END_DECLS
-
-#endif /* gecko_embed_signals_h */
diff --git a/embed/xulrunner/src/gecko-embed-single-private.h b/embed/xulrunner/src/gecko-embed-single-private.h
deleted file mode 100644
index df2202da3..000000000
--- a/embed/xulrunner/src/gecko-embed-single-private.h
+++ /dev/null
@@ -1,59 +0,0 @@
-/*
- * Copyright © Christopher Blizzard
- * Copyright © 2006 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser 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.
- *
- * ---------------------------------------------------------------------------
- * Derived from Mozilla.org code, which had the following attributions:
- *
- * The Original Code is mozilla.org code.
- *
- * The Initial Developer of the Original Code is
- * Christopher Blizzard. Portions created by Christopher Blizzard are Copyright © Christopher Blizzard. All Rights Reserved.
- * Portions created by the Initial Developer are Copyright © 2001
- * the Initial Developer. All Rights Reserved.
- *
- * Contributor(s):
- * Christopher Blizzard <blizzard@mozilla.org>
- * ---------------------------------------------------------------------------
- *
- * $Id$
- */
-
-#ifndef gecko_embed_single_private_h
-#define gecko_embed_single_private_h
-
-#include "gecko-embed-single.h"
-
-class GeckoSingle;
-class nsIDirectoryServiceProvider;
-struct nsModuleComponentInfo;
-
-G_BEGIN_DECLS
-
-extern GeckoSingle* gecko_embed_single_get_GeckoSingle (void);
-
-extern void gecko_embed_single_set_directory_service_provider (nsIDirectoryServiceProvider *aProvider);
-
-extern void gecko_embed_single_set_app_components (const nsModuleComponentInfo *aComps,
- int aNumComps);
-
-extern void gecko_embed_single_create_window (GeckoEmbed **aNewEmbed,
- guint aChromeFlags);
-
-G_END_DECLS
-
-#endif /* gecko_embed_single_private_h */
diff --git a/embed/xulrunner/src/gecko-embed-single.cpp b/embed/xulrunner/src/gecko-embed-single.cpp
deleted file mode 100644
index a38558147..000000000
--- a/embed/xulrunner/src/gecko-embed-single.cpp
+++ /dev/null
@@ -1,182 +0,0 @@
-/*
- * Copyright © Christopher Blizzard
- * Copyright © Ramiro Estrugo
- * Copyright © 2006 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser 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.
- *
- * ---------------------------------------------------------------------------
- * Derived from Mozilla.org code, which had the following attributions:
- *
- * The Original Code is mozilla.org code.
- *
- * The Initial Developer of the Original Code is
- * Christopher Blizzard. Portions created by Christopher Blizzard are Copyright © Christopher Blizzard. All Rights Reserved.
- * Portions created by the Initial Developer are Copyright © 2001
- * the Initial Developer. All Rights Reserved.
- *
- * Contributor(s):
- * Christopher Blizzard <blizzard@mozilla.org>
- * Ramiro Estrugo <ramiro@eazel.com>
- * ---------------------------------------------------------------------------
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include "gecko-embed-single.h"
-#include "gecko-embed-private.h"
-#include "gecko-embed-signals.h"
-#include "gecko-embed-marshal.h"
-
-#include "GeckoSingle.h"
-
-#define GECKO_EMBED_SINGLE_GET_PRIVATE(object)(G_TYPE_INSTANCE_GET_PRIVATE ((object), GECKO_TYPE_EMBED_SINGLE, GeckoEmbedSinglePrivate))
-
-struct _GeckoEmbedSinglePrivate
-{
- GeckoSingle *single;
-};
-
-enum
-{
- NEW_WINDOW_ORPHAN,
- LAST_SINGLE_SIGNAL
-};
-
-static guint gecko_embed_single_signals[LAST_SINGLE_SIGNAL] = { 0 };
-
-static void gecko_embed_single_class_init (GeckoEmbedSingleClass *klass);
-static void gecko_embed_single_init (GeckoEmbedSingle *embed);
-
-static GObjectClass *parent_class = NULL;
-
-GType
-gecko_embed_single_get_type(void)
-{
- static GType type = 0;
-
- if (!type)
- {
- const GTypeInfo info =
- {
- sizeof (GeckoEmbedSingleClass),
- NULL, /* base_init */
- NULL, /* base_finalize */
- (GClassInitFunc) gecko_embed_single_class_init,
- NULL,
- NULL, /* class_data */
- sizeof (GeckoEmbedSingle),
- 0, /* n_preallocs */
- (GInstanceInitFunc) gecko_embed_single_init
- };
-
- type = g_type_register_static (G_TYPE_OBJECT, "GeckoEmbedSingle",
- &info, (GTypeFlags) 0);
- }
-
- return type;
-}
-
-GeckoEmbedSingle *
-gecko_embed_single_get (void)
-{
- static GeckoEmbedSingle *single = NULL;
-
- if (!single)
- {
- single = GECKO_EMBED_SINGLE (g_object_new (GECKO_TYPE_EMBED_SINGLE, NULL));
-
- g_object_add_weak_pointer (G_OBJECT (single), (gpointer *) &single);
- }
-
- return single;
-}
-
-extern "C" void
-gecko_embed_single_create_window (GeckoEmbed **aNewEmbed,
- guint aChromeFlags)
-{
- GeckoEmbedSingle *single = gecko_embed_single_get ();
-
- *aNewEmbed = nsnull;
-
- if (!single)
- return;
-
- g_signal_emit (single, gecko_embed_single_signals[NEW_WINDOW_ORPHAN], 0,
- (void **) aNewEmbed, aChromeFlags);
-}
-
-void
-gecko_embed_single_push_startup(void)
-{
- GeckoEmbedSingle *single = gecko_embed_single_get ();
-
- single->priv->single->PushStartup();
-}
-
-void
-gecko_embed_single_pop_startup(void)
-{
- GeckoEmbedSingle *single = gecko_embed_single_get ();
-
- single->priv->single->PopStartup();
-}
-
-static void
-gecko_embed_single_init(GeckoEmbedSingle *embed)
-{
- embed->priv = GECKO_EMBED_SINGLE_GET_PRIVATE (embed);
-
- embed->priv->single = new GeckoSingle ();
-}
-
-static void
-gecko_embed_single_finalize (GObject *object)
-{
- GeckoEmbedSingle *single = GECKO_EMBED_SINGLE (object);
-
- delete single->priv->single;
- single->priv->single = nsnull;
-
- G_OBJECT_CLASS (parent_class)->finalize (object);
-}
-
-static void
-gecko_embed_single_class_init (GeckoEmbedSingleClass *klass)
-{
- GObjectClass *object_class = G_OBJECT_CLASS (klass);
-
- parent_class = (GObjectClass *) g_type_class_peek_parent (klass);
-
- object_class->finalize = gecko_embed_single_finalize;
-
- gecko_embed_single_signals[NEW_WINDOW] =
- g_signal_new ("new_window_orphan",
- GECKO_TYPE_EMBED_SINGLE,
- G_SIGNAL_RUN_FIRST,
- G_STRUCT_OFFSET (GeckoEmbedSingleClass, new_window_orphan),
- NULL, NULL,
- gecko_embed_marshal_VOID__OBJECT_UINT,
- G_TYPE_NONE,
- 2,
- G_TYPE_OBJECT,
- G_TYPE_UINT);
-
- g_type_class_add_private (object_class, sizeof (GeckoEmbedSinglePrivate));
-}
diff --git a/embed/xulrunner/src/gecko-embed-single.h b/embed/xulrunner/src/gecko-embed-single.h
deleted file mode 100644
index 66554f68b..000000000
--- a/embed/xulrunner/src/gecko-embed-single.h
+++ /dev/null
@@ -1,88 +0,0 @@
-/*
- * Copyright © Christopher Blizzard
- * Copyright © Ramiro Estrugo
- * Copyright © 2006 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser 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.
- *
- * ---------------------------------------------------------------------------
- * Derived from Mozilla.org code, which had the following attributions:
- *
- * The Original Code is mozilla.org code.
- *
- * The Initial Developer of the Original Code is
- * Christopher Blizzard. Portions created by Christopher Blizzard are Copyright © Christopher Blizzard. All Rights Reserved.
- * Portions created by the Initial Developer are Copyright © 2001
- * the Initial Developer. All Rights Reserved.
- *
- * Contributor(s):
- * Christopher Blizzard <blizzard@mozilla.org>
- * Ramiro Estrugo <ramiro@eazel.com>
- * ---------------------------------------------------------------------------
- *
- * $Id$
- */
-
-#ifndef gecko_embed_single_h
-#define gecko_embed_single_h
-
-#include "gecko-embed-type-builtins.h"
-#include <glib-object.h>
-
-G_BEGIN_DECLS
-
-#define GECKO_TYPE_EMBED_SINGLE (gecko_embed_single_get_type())
-#define GECKO_EMBED_SINGLE(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), GECKO_TYPE_EMBED_SINGLE, GeckoEmbedSingle))
-#define GECKO_EMBED_SINGLE_CLASS(k) (G_TYPE_CHECK_CLASS_CAST((k), GECKO_TYPE_EMBED_SINGLE, GeckoEmbedSingleClass))
-#define GECKO_IS_EMBED_SINGLE(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), GECKO_TYPE_EMBED_SINGLE))
-#define GECKO_IS_EMBED_SINGLE_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE ((k), GECKO_TYPE_EMBED_SINGLE))
-#define GECKO_EMBED_SINGLE_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS ((o), GECKO_TYPE_EMBED_SINGLE, GeckoEmbedSingleClass))
-
-typedef struct _GeckoEmbedSingle GeckoEmbedSingle;
-typedef struct _GeckoEmbedSinglePrivate GeckoEmbedSinglePrivate;
-typedef struct _GeckoEmbedSingleClass GeckoEmbedSingleClass;
-
-/* circular dependency */
-#include "gecko-embed.h"
-
-struct _GeckoEmbedSingle
-{
- GObject parent_instance;
-
- /*< private >*/
- GeckoEmbedSinglePrivate *priv;
-};
-
-struct _GeckoEmbedSingleClass
-{
- GObjectClass parent_class;
-
- void (* new_window_orphan) (GeckoEmbedSingle *single,
- GeckoEmbed **newEmbed,
- guint chromemask);
-};
-
-GType gecko_embed_single_get_type (void);
-
-GeckoEmbedSingle *gecko_embed_single_get (void);
-
-void gecko_embed_single_push_startup (void);
-
-void gecko_embed_single_pop_startup (void);
-
-
-G_END_DECLS
-
-#endif /* gecko_embed_single_h */
diff --git a/embed/xulrunner/src/gecko-embed-types.h b/embed/xulrunner/src/gecko-embed-types.h
deleted file mode 100644
index c0cb1b71e..000000000
--- a/embed/xulrunner/src/gecko-embed-types.h
+++ /dev/null
@@ -1,118 +0,0 @@
-/*
- * Copyright © Christopher Blizzard
- * Copyright © 2006 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser 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.
- *
- * ---------------------------------------------------------------------------
- * Derived from Mozilla.org code, which had the following attributions:
- *
- * The Original Code is mozilla.org code.
- *
- * The Initial Developer of the Original Code is
- * Christopher Blizzard. Portions created by Christopher Blizzard are Copyright © Christopher Blizzard. All Rights Reserved.
- * Portions created by the Initial Developer are Copyright © 2001
- * the Initial Developer. All Rights Reserved.
- *
- * Contributor(s):
- * Christopher Blizzard <blizzard@mozilla.org>
- * Ramiro Estrugo <ramiro@eazel.com>
- * ---------------------------------------------------------------------------
- *
- * $Id$
- */
-
-#ifndef __GECKO_EMBED_TYPES_H__
-#define __GECKO_EMBED_TYPES_H__
-
-#include <glib-object.h>
-#include "gecko-embed-type-builtins.h"
-
-G_BEGIN_DECLS
-
-/* These are straight out of nsIWebProgressListener.h */
-
-typedef enum
-{
- GECKO_EMBED_FLAG_START = 1U << 0,
- GECKO_EMBED_FLAG_REDIRECTING = 1U << 1,
- GECKO_EMBED_FLAG_TRANSFERRING = 1U << 2,
- GECKO_EMBED_FLAG_NEGOTIATING = 1U << 3,
- GECKO_EMBED_FLAG_STOP = 1U << 4,
-
- GECKO_EMBED_FLAG_IS_REQUEST = 1U << 16,
- GECKO_EMBED_FLAG_IS_DOCUMENT = 1U << 17,
- GECKO_EMBED_FLAG_IS_NETWORK = 1U << 18,
- GECKO_EMBED_FLAG_IS_WINDOW = 1U << 19,
-
- GECKO_EMBED_FLAG_RESTORING = 1U << 24,
-} GeckoEmbedProgressFlags;
-
-/* These are from various networking headers */
-
-typedef enum
-{
- /* NS_ERROR_UNKNOWN_HOST */
- GECKO_EMBED_STATUS_FAILED_DNS = 2152398878U,
- /* NS_ERROR_CONNECTION_REFUSED */
- GECKO_EMBED_STATUS_FAILED_CONNECT = 2152398861U,
- /* NS_ERROR_NET_TIMEOUT */
- GECKO_EMBED_STATUS_FAILED_TIMEOUT = 2152398862U,
- /* NS_BINDING_ABORTED */
- GECKO_EMBED_STATUS_FAILED_USERCANCELED = 2152398850U
-} GeckoEmbedStatusEnum;
-
-/* These used to be straight out of nsIWebNavigation.h until the API
- changed. Now there's a mapping table that maps these values to the
- internal values. */
-
-typedef enum
-{
- GECKO_EMBED_FLAG_RELOADNORMAL = 0,
- GECKO_EMBED_FLAG_RELOADBYPASSCACHE = 1,
- GECKO_EMBED_FLAG_RELOADBYPASSPROXY = 2,
- GECKO_EMBED_FLAG_RELOADBYPASSPROXYANDCACHE = 3,
- GECKO_EMBED_FLAG_RELOADCHARSETCHANGE = 4
-} GeckoEmbedReloadFlags;
-
-/* These are straight out of nsIWebBrowserChrome.h */
-
-typedef enum
-{
- GECKO_EMBED_FLAG_DEFAULTCHROME = 1U << 0,
- GECKO_EMBED_FLAG_WINDOWBORDERSON = 1U << 1,
- GECKO_EMBED_FLAG_WINDOWCLOSEON = 1U << 2,
- GECKO_EMBED_FLAG_WINDOWRESIZEON = 1U << 3,
- GECKO_EMBED_FLAG_MENUBARON = 1U << 4,
- GECKO_EMBED_FLAG_TOOLBARON = 1U << 5,
- GECKO_EMBED_FLAG_LOCATIONBARON = 1U << 6,
- GECKO_EMBED_FLAG_STATUSBARON = 1U << 7,
- GECKO_EMBED_FLAG_PERSONALTOOLBARON = 1U << 8,
- GECKO_EMBED_FLAG_SCROLLBARSON = 1U << 9,
- GECKO_EMBED_FLAG_TITLEBARON = 1U << 10,
- GECKO_EMBED_FLAG_EXTRACHROMEON = 1U << 11,
- GECKO_EMBED_FLAG_ALLCHROME = 1U << 12,
- GECKO_EMBED_FLAG_WINDOWRAISED = 1U << 25,
- GECKO_EMBED_FLAG_WINDOWLOWERED = 1U << 26,
- GECKO_EMBED_FLAG_CENTERSCREEN = 1U << 27,
- GECKO_EMBED_FLAG_DEPENDENT = 1U << 28,
- GECKO_EMBED_FLAG_MODAL = 1U << 29,
- GECKO_EMBED_FLAG_OPENASDIALOG = 1U << 30,
- GECKO_EMBED_FLAG_OPENASCHROME = 1U << 31,
-} GeckoEmbedChromeFlags;
-
-G_END_DECLS
-
-#endif /* !__GECKO_EMBED_TYPES_H__ */
diff --git a/embed/xulrunner/src/gecko-embed.cpp b/embed/xulrunner/src/gecko-embed.cpp
deleted file mode 100644
index 6ad9a3ae4..000000000
--- a/embed/xulrunner/src/gecko-embed.cpp
+++ /dev/null
@@ -1,1029 +0,0 @@
-/*
- * Copyright © Christopher Blizzard
- * Copyright © Ramiro Estrugo
- * Copyright © 2006 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser 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.
- *
- * ---------------------------------------------------------------------------
- * Derived from Mozilla.org code, which had the following attributions:
- *
- * The Original Code is mozilla.org code.
- *
- * The Initial Developer of the Original Code is
- * Christopher Blizzard. Portions created by Christopher Blizzard are Copyright © Christopher Blizzard. All Rights Reserved.
- * Portions created by the Initial Developer are Copyright © 2001
- * the Initial Developer. All Rights Reserved.
- *
- * Contributor(s):
- * Christopher Blizzard <blizzard@mozilla.org>
- * Ramiro Estrugo <ramiro@eazel.com>
- * ---------------------------------------------------------------------------
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include "gecko-embed.h"
-#include "gecko-embed-private.h"
-#include "gecko-embed-signals.h"
-#include "gecko-embed-marshal.h"
-#include "gecko-embed-single.h"
-#include "gecko-embed-types.h"
-
-#include "gecko-dom-event.h"
-
-#include "GeckoBrowser.h"
-#include "EmbedWindow.h"
-
-#ifdef XPCOM_GLUE
-#include "nsXPCOMGlue.h"
-#endif
-
-// so we can do our get_nsIWebBrowser later...
-#include <nsIWebBrowser.h>
-
-#include <stdio.h>
-
-#define GET_OBJECT_CLASS_TYPE(x) G_OBJECT_CLASS_TYPE(x)
-
-class nsIDirectoryServiceProvider;
-
-// class and instance initialization
-
-static void gecko_embed_class_init (GeckoEmbedClass *klass);
-static void gecko_embed_init (GeckoEmbed *embed);
-
-// GtkObject methods
-
-static void gecko_embed_destroy(GtkObject *object);
-
-// GtkWidget methods
-
-static void gecko_embed_realize(GtkWidget *widget);
-
-static void gecko_embed_unrealize(GtkWidget *widget);
-
-static void gecko_embed_size_allocate(GtkWidget *widget, GtkAllocation *allocation);
-
-static void gecko_embed_map(GtkWidget *widget);
-
-static void gecko_embed_unmap(GtkWidget *widget);
-
-#ifdef MOZ_ACCESSIBILITY_ATK
-static AtkObject* gecko_embed_get_accessible (GtkWidget *widget);
-#endif
-
-static gint handle_child_focus_in(GtkWidget *aWidget,
- GdkEventFocus *aGdkFocusEvent,
- GeckoEmbed *aEmbed);
-
-static gint handle_child_focus_out(GtkWidget *aWidget,
- GdkEventFocus *aGdkFocusEvent,
- GeckoEmbed *aEmbed);
-
-static PRInt32 sWidgetCount;
-
-// globals for this type of widget
-
-static GtkBinClass *parent_class;
-
-guint gecko_embed_signals[LAST_EMBED_SIGNAL] = { 0 };
-
-// GtkObject + class-related functions
-
-#define GECKO_EMBED_GET_PRIVATE(object)(G_TYPE_INSTANCE_GET_PRIVATE ((object), GECKO_TYPE_EMBED, GeckoEmbedPrivate))
-
-struct _GeckoEmbedPrivate
-{
- GeckoBrowser *browser;
-};
-
-GType
-gecko_embed_get_type(void)
-{
- static GType type = 0;
-
- if (!type)
- {
- const GTypeInfo info =
- {
- sizeof (GeckoEmbedClass),
- NULL, /* base_init */
- NULL, /* base_finalize */
- (GClassInitFunc) gecko_embed_class_init,
- NULL,
- NULL, /* class_data */
- sizeof (GeckoEmbed),
- 0, /* n_preallocs */
- (GInstanceInitFunc) gecko_embed_init
- };
-
- type = g_type_register_static (GTK_TYPE_BIN, "GeckoEmbed",
- &info, (GTypeFlags) 0);
- }
-
- return type;
-}
-
-
-/* GObject methods */
-
-#define GET_BROWSER(x) (((GeckoEmbed *) x)->priv->browser)
-
-// FIXME split in dispose and finalize
-static void
-gecko_embed_destroy(GtkObject *object)
-{
- GeckoEmbed *embed = GECKO_EMBED (object);
- GeckoBrowser *browser = GET_BROWSER (object);
-
- if (browser) {
-
- // Destroy the widget only if it's been Init()ed.
- if(browser->mMozWindowWidget != 0) {
- browser->Destroy();
- }
-
- delete browser;
- embed->priv->browser = NULL;
- }
-
- gecko_embed_single_pop_startup();
-}
-
-// GtkWidget methods
-
-static void
-gecko_embed_realize(GtkWidget *widget)
-{
- GeckoEmbed *embed = GECKO_EMBED (widget);
- GeckoEmbedPrivate *priv = embed->priv;
- GeckoBrowser *browser = GET_BROWSER (widget);
- GtkWidget *toplevel = gtk_widget_get_toplevel (widget);
- GdkWindowAttr attributes;
- int attributes_mask;
-
- GTK_WIDGET_SET_FLAGS(widget, GTK_REALIZED);
-
- attributes.window_type = GDK_WINDOW_CHILD;
- attributes.x = widget->allocation.x;
- attributes.y = widget->allocation.y;
- attributes.width = widget->allocation.width;
- attributes.height = widget->allocation.height;
- attributes.wclass = GDK_INPUT_OUTPUT;
- attributes.visual = gtk_widget_get_visual (widget);
- attributes.colormap = gtk_widget_get_colormap (widget);
- attributes.event_mask = gtk_widget_get_events (widget) | GDK_EXPOSURE_MASK;
-
- attributes_mask = GDK_WA_X | GDK_WA_Y | GDK_WA_VISUAL | GDK_WA_COLORMAP;
-
- widget->window = gdk_window_new (gtk_widget_get_parent_window (widget),
- &attributes, attributes_mask);
- gdk_window_set_user_data (widget->window, embed);
-
- widget->style = gtk_style_attach (widget->style, widget->window);
- gtk_style_set_background (widget->style, widget->window, GTK_STATE_NORMAL);
-
- // initialize the window
- nsresult rv;
- rv = browser->Init(embed);
- g_return_if_fail(NS_SUCCEEDED(rv));
-
- PRBool alreadyRealized = PR_FALSE;
- rv = browser->Realize(&alreadyRealized);
- g_return_if_fail(NS_SUCCEEDED(rv));
-
- // if we're already realized we don't need to hook up to anything below
- if (alreadyRealized)
- return;
-
- browser->LoadCurrentURI();
-
- GtkWidget *child_widget = GTK_BIN (widget)->child;
- g_signal_connect_object (child_widget, "focus_in_event",
- G_CALLBACK (handle_child_focus_in), embed,
- (GConnectFlags) 0);
- g_signal_connect_object (child_widget, "focus_out_event",
- G_CALLBACK (handle_child_focus_out), embed,
- (GConnectFlags) 0);
-#if 0
- // connect to the focus out event for the child
- gtk_signal_connect_while_alive(GTK_OBJECT(child_widget),
- "focus_out_event",
- GTK_SIGNAL_FUNC(handle_child_focus_out),
- embed,
- GTK_OBJECT(child_widget));
- gtk_signal_connect_while_alive(GTK_OBJECT(child_widget),
- "focus_in_event",
- GTK_SIGNAL_FUNC(handle_child_focus_in),
- embed,
- GTK_OBJECT(child_widget));
-#endif
-}
-
-static void
-gecko_embed_unrealize(GtkWidget *widget)
-{
- GeckoEmbed *embed = GECKO_EMBED (widget);
- GeckoEmbedPrivate *priv = embed->priv;
- GeckoBrowser *browser = GET_BROWSER (widget);
- GtkWidget *toplevel = gtk_widget_get_toplevel (widget);
-
- if (browser) {
- browser->Unrealize();
- }
-
- if (GTK_WIDGET_CLASS(parent_class)->unrealize)
- GTK_WIDGET_CLASS(parent_class)->unrealize (widget);
-}
-
-static void
-gecko_embed_size_allocate (GtkWidget *widget,
- GtkAllocation *allocation)
-{
- GeckoEmbed *embed = GECKO_EMBED (widget);
- GeckoBrowser *browser = GET_BROWSER (widget);
-
- widget->allocation = *allocation;
-
- if (GTK_WIDGET_REALIZED(widget))
- {
- gdk_window_move_resize(widget->window,
- allocation->x, allocation->y,
- allocation->width, allocation->height);
-
- browser->Resize(allocation->width, allocation->height);
- }
-}
-
-static void
-gecko_embed_map (GtkWidget *widget)
-{
- GeckoEmbed *embed = GECKO_EMBED (widget);
- GeckoBrowser *browser = GET_BROWSER (widget);
-
- GTK_WIDGET_SET_FLAGS(widget, GTK_MAPPED);
-
- browser->Show();
-
- gdk_window_show(widget->window);
-
-}
-
-static void
-gecko_embed_unmap (GtkWidget *widget)
-{
- GeckoEmbed *embed = GECKO_EMBED (widget);
- GeckoBrowser *browser = GET_BROWSER (widget);
-
- GTK_WIDGET_UNSET_FLAGS(widget, GTK_MAPPED);
-
- gdk_window_hide(widget->window);
-
- browser->Hide();
-}
-
-#ifdef MOZ_ACCESSIBILITY_ATK
-static AtkObject*
-gecko_embed_get_accessible (GtkWidget *widget)
-{
- GeckoEmbed *embed = GECKO_EMBED (widget);
- GeckoBrowser *browser = GET_BROWSER (widget);
-
- return static_cast<AtkObject *>
- (browser->GetAtkObjectForCurrentDocument());
-}
-#endif /* MOZ_ACCESSIBILITY_ATK */
-
-static gint
-handle_child_focus_in (GtkWidget *aWidget,
- GdkEventFocus *aGdkFocusEvent,
- GeckoEmbed *aEmbed)
-{
- GeckoBrowser *browser = GET_BROWSER (aEmbed);
-
- browser->ChildFocusIn();
-
- return FALSE;
-}
-
-static gint
-handle_child_focus_out (GtkWidget *aWidget,
- GdkEventFocus *aGdkFocusEvent,
- GeckoEmbed *aEmbed)
-{
- GeckoBrowser *browser = GET_BROWSER (aEmbed);
-
- browser->ChildFocusOut();
-
- return FALSE;
-}
-
-// Widget methods
-
-void
-gecko_embed_load_url (GeckoEmbed *embed,
- const char *url)
-{
- GeckoBrowser *browser;
-
- g_return_if_fail(embed != NULL);
- g_return_if_fail(GECKO_IS_EMBED(embed));
-
- browser = GET_BROWSER (embed);
-
- browser->SetURI(url);
-
- // If the widget is realized, load the URI. If it isn't then we
- // will load it later.
- if (GTK_WIDGET_REALIZED(embed))
- browser->LoadCurrentURI();
-}
-
-void
-gecko_embed_stop_load (GeckoEmbed *embed)
-{
- GeckoBrowser *browser;
-
- g_return_if_fail(GECKO_IS_EMBED(embed));
-
- browser = GET_BROWSER (embed);
-
- if (browser->mNavigation)
- browser->mNavigation->Stop(nsIWebNavigation::STOP_ALL);
-}
-
-gboolean
-gecko_embed_can_go_back (GeckoEmbed *embed)
-{
- PRBool retval = PR_FALSE;
- GeckoBrowser *browser;
-
- g_return_val_if_fail (GECKO_IS_EMBED(embed), FALSE);
-
- browser = GET_BROWSER (embed);
-
- if (browser->mNavigation)
- browser->mNavigation->GetCanGoBack(&retval);
- return retval;
-}
-
-gboolean
-gecko_embed_can_go_forward (GeckoEmbed *embed)
-{
- PRBool retval = PR_FALSE;
- GeckoBrowser *browser;
-
- g_return_val_if_fail (GECKO_IS_EMBED(embed), FALSE);
-
- browser = GET_BROWSER (embed);
-
- if (browser->mNavigation)
- browser->mNavigation->GetCanGoForward(&retval);
- return retval;
-}
-
-void
-gecko_embed_go_back (GeckoEmbed *embed)
-{
- GeckoBrowser *browser;
-
- g_return_if_fail (GECKO_IS_EMBED(embed));
-
- browser = GET_BROWSER (embed);
-
- if (browser->mNavigation)
- browser->mNavigation->GoBack();
-}
-
-void
-gecko_embed_go_forward (GeckoEmbed *embed)
-{
- GeckoBrowser *browser;
-
- g_return_if_fail (GECKO_IS_EMBED(embed));
-
- browser = GET_BROWSER (embed);
-
- if (browser->mNavigation)
- browser->mNavigation->GoForward();
-}
-
-void
-gecko_embed_render_data (GeckoEmbed *embed, const char *data,
- guint32 len, const char *base_uri,
- const char *mime_type)
-{
- GeckoBrowser *browser;
-
- g_return_if_fail (GECKO_IS_EMBED(embed));
-
- browser = GET_BROWSER (embed);
-
-#if 0
- browser->OpenStream(base_uri, mime_type);
- browser->AppendToStream(data, len);
- browser->CloseStream();
-#endif
-}
-
-void
-gecko_embed_open_stream (GeckoEmbed *embed, const char *base_uri,
- const char *mime_type)
-{
- GeckoBrowser *browser;
-
- g_return_if_fail (GECKO_IS_EMBED(embed));
- g_return_if_fail (GTK_WIDGET_REALIZED(GTK_WIDGET(embed)));
-
- browser = GET_BROWSER (embed);
-
-#if 0
- browser->OpenStream(base_uri, mime_type);
-#endif
-}
-
-void gecko_embed_append_data (GeckoEmbed *embed, const char *data,
- guint32 len)
-{
- GeckoBrowser *browser;
-
- g_return_if_fail (GECKO_IS_EMBED(embed));
- g_return_if_fail (GTK_WIDGET_REALIZED(GTK_WIDGET(embed)));
-
- browser = GET_BROWSER (embed);
-#if 0
- browser->AppendToStream(data, len);
-#endif
-}
-
-void
-gecko_embed_close_stream (GeckoEmbed *embed)
-{
- GeckoBrowser *browser;
-
- g_return_if_fail (GECKO_IS_EMBED(embed));
- g_return_if_fail (GTK_WIDGET_REALIZED(GTK_WIDGET(embed)));
-
- browser = GET_BROWSER (embed);
-#if 0
- browser->CloseStream();
-#endif
-}
-
-char *
-gecko_embed_get_link_message (GeckoEmbed *embed)
-{
- char *retval = nsnull;
- GeckoBrowser *browser;
- nsEmbedCString tmpCString;
-
- g_return_val_if_fail (GECKO_IS_EMBED(embed), (char *)NULL);
-
- browser = GET_BROWSER (embed);
-
- if (browser->mWindow) {
- NS_UTF16ToCString(browser->mWindow->mLinkMessage,
- NS_CSTRING_ENCODING_UTF8, tmpCString);
- retval = g_strdup(tmpCString.get());
- }
-
- return retval;
-}
-
-char *
-gecko_embed_get_js_status (GeckoEmbed *embed)
-{
- char *retval = nsnull;
- GeckoBrowser *browser;
- nsEmbedCString tmpCString;
-
- g_return_val_if_fail (GECKO_IS_EMBED(embed), (char *)NULL);
-
- browser = GET_BROWSER (embed);
-
- if (browser->mWindow) {
- NS_UTF16ToCString(browser->mWindow->mJSStatus,
- NS_CSTRING_ENCODING_UTF8, tmpCString);
- retval = g_strdup(tmpCString.get());
- }
-
- return retval;
-}
-
-char *
-gecko_embed_get_title (GeckoEmbed *embed)
-{
- char *retval = nsnull;
- GeckoBrowser *browser;
- nsEmbedCString tmpCString;
-
- g_return_val_if_fail (GECKO_IS_EMBED(embed), (char *)NULL);
-
- browser = GET_BROWSER (embed);
-
- if (browser->mWindow) {
- NS_UTF16ToCString(browser->mWindow->mTitle,
- NS_CSTRING_ENCODING_UTF8, tmpCString);
- retval = g_strdup(tmpCString.get());
- }
-
- return retval;
-}
-
-char *
-gecko_embed_get_location (GeckoEmbed *embed)
-{
- char *retval = nsnull;
- GeckoBrowser *browser;
-
- g_return_val_if_fail (GECKO_IS_EMBED(embed), (char *)NULL);
-
- browser = GET_BROWSER (embed);
-
- if (browser->mURI.Length()) {
- retval = g_strdup(browser->mURI.get());
- }
-
- return retval;
-}
-
-void
-gecko_embed_reload (GeckoEmbed *embed,
- gint32 flags)
-{
- GeckoBrowser *browser;
-
- g_return_if_fail (GECKO_IS_EMBED(embed));
-
- browser = GET_BROWSER (embed);
-
- PRUint32 reloadFlags = 0;
-
- // map the external API to the internal web navigation API.
- switch (flags) {
- case GECKO_EMBED_FLAG_RELOADNORMAL:
- reloadFlags = 0;
- break;
- case GECKO_EMBED_FLAG_RELOADBYPASSCACHE:
- reloadFlags = nsIWebNavigation::LOAD_FLAGS_BYPASS_CACHE;
- break;
- case GECKO_EMBED_FLAG_RELOADBYPASSPROXY:
- reloadFlags = nsIWebNavigation::LOAD_FLAGS_BYPASS_PROXY;
- break;
- case GECKO_EMBED_FLAG_RELOADBYPASSPROXYANDCACHE:
- reloadFlags = (nsIWebNavigation::LOAD_FLAGS_BYPASS_PROXY |
- nsIWebNavigation::LOAD_FLAGS_BYPASS_CACHE);
- break;
- case GECKO_EMBED_FLAG_RELOADCHARSETCHANGE:
- reloadFlags = nsIWebNavigation::LOAD_FLAGS_CHARSET_CHANGE;
- break;
- default:
- reloadFlags = 0;
- break;
- }
-
- browser->Reload(reloadFlags);
-}
-
-void
-gecko_embed_set_chrome_mask (GeckoEmbed *embed,
- guint32 flags)
-{
- GeckoBrowser *browser;
-
- g_return_if_fail (GECKO_IS_EMBED(embed));
-
- browser = GET_BROWSER (embed);
-
- browser->SetChromeMask(flags);
-}
-
-guint32
-gecko_embed_get_chrome_mask (GeckoEmbed *embed)
-{
- GeckoBrowser *browser;
-
- g_return_val_if_fail (GECKO_IS_EMBED(embed), 0);
-
- browser = GET_BROWSER (embed);
-
- return browser->mChromeMask;
-}
-
-void
-gecko_embed_get_nsIWebBrowser (GeckoEmbed *embed,
- nsIWebBrowser **retval)
-{
- GeckoBrowser *browser;
- *retval = nsnull;
-
- g_return_if_fail (GECKO_IS_EMBED (embed));
-
- browser = GET_BROWSER (embed);
-
- if (browser->mWindow)
- browser->mWindow->GetWebBrowser(retval);
-}
-
-GeckoBrowser *
-gecko_embed_get_GeckoBrowser (GeckoEmbed *embed)
-{
- g_return_val_if_fail (GECKO_IS_EMBED (embed), nsnull);
-
- return GET_BROWSER (embed);
-}
-
-static void
-gecko_embed_init (GeckoEmbed *embed)
-{
- embed->priv = GECKO_EMBED_GET_PRIVATE (embed);
-
- embed->priv->browser = new GeckoBrowser();
- g_return_if_fail (embed->priv->browser);
-
- gtk_widget_set_name (GTK_WIDGET (embed), "gecko_embed");
-
- GTK_WIDGET_UNSET_FLAGS(GTK_WIDGET(embed), GTK_NO_WINDOW);
-}
-
-static void
-gecko_embed_class_init (GeckoEmbedClass *klass)
-{
- GtkObjectClass *object_class = GTK_OBJECT_CLASS (klass); // FIXME GObject
- GtkWidgetClass *widget_class = GTK_WIDGET_CLASS (klass);
- GtkContainerClass *container_class = GTK_CONTAINER_CLASS (klass);
-
- parent_class = (GtkBinClass *) g_type_class_peek_parent (klass);
-
- object_class->destroy = gecko_embed_destroy;
-
- widget_class->realize = gecko_embed_realize;
- widget_class->unrealize = gecko_embed_unrealize;
- widget_class->size_allocate = gecko_embed_size_allocate;
- widget_class->map = gecko_embed_map;
- widget_class->unmap = gecko_embed_unmap;
-
-#ifdef MOZ_ACCESSIBILITY_ATK
- widget_class->get_accessible = gecko_embed_get_accessible;
-#endif
-
- GType dom_param_types[1] = { GECKO_TYPE_DOM_EVENT | G_SIGNAL_TYPE_STATIC_SCOPE };
-
- gecko_embed_signals[DOM_KEY_DOWN] =
- g_signal_newv ("dom-key-down",
- GECKO_TYPE_EMBED,
- (GSignalFlags) (G_SIGNAL_RUN_FIRST | G_SIGNAL_RUN_LAST),
- NULL,
- g_signal_accumulator_true_handled, NULL,
- gecko_embed_marshal_BOOLEAN__BOXED,
- G_TYPE_BOOLEAN,
- G_N_ELEMENTS (dom_param_types),
- dom_param_types);
-
- gecko_embed_signals[DOM_KEY_PRESS] =
- g_signal_newv ("dom-key-press",
- GECKO_TYPE_EMBED,
- (GSignalFlags) (G_SIGNAL_RUN_FIRST | G_SIGNAL_RUN_LAST),
- NULL,
- g_signal_accumulator_true_handled, NULL,
- gecko_embed_marshal_BOOLEAN__BOXED,
- G_TYPE_BOOLEAN,
- G_N_ELEMENTS (dom_param_types),
- dom_param_types);
-
- gecko_embed_signals[DOM_KEY_UP] =
- g_signal_newv ("dom-key-up",
- GECKO_TYPE_EMBED,
- (GSignalFlags) (G_SIGNAL_RUN_FIRST | G_SIGNAL_RUN_LAST),
- NULL,
- g_signal_accumulator_true_handled, NULL,
- gecko_embed_marshal_BOOLEAN__BOXED,
- G_TYPE_BOOLEAN,
- G_N_ELEMENTS (dom_param_types),
- dom_param_types);
-
- gecko_embed_signals[DOM_MOUSE_DOWN] =
- g_signal_newv ("dom-mouse-down",
- GECKO_TYPE_EMBED,
- (GSignalFlags) (G_SIGNAL_RUN_FIRST | G_SIGNAL_RUN_LAST),
- NULL,
- g_signal_accumulator_true_handled, NULL,
- gecko_embed_marshal_BOOLEAN__BOXED,
- G_TYPE_BOOLEAN,
- G_N_ELEMENTS (dom_param_types),
- dom_param_types);
-
- gecko_embed_signals[DOM_MOUSE_UP] =
- g_signal_newv ("dom-mouse-up",
- GECKO_TYPE_EMBED,
- (GSignalFlags) (G_SIGNAL_RUN_FIRST | G_SIGNAL_RUN_LAST),
- NULL,
- g_signal_accumulator_true_handled, NULL,
- gecko_embed_marshal_BOOLEAN__BOXED,
- G_TYPE_BOOLEAN,
- G_N_ELEMENTS (dom_param_types),
- dom_param_types);
-
- gecko_embed_signals[DOM_MOUSE_CLICK] =
- g_signal_newv ("dom-mouse-click",
- GECKO_TYPE_EMBED,
- (GSignalFlags) (G_SIGNAL_RUN_FIRST | G_SIGNAL_RUN_LAST),
- NULL,
- g_signal_accumulator_true_handled, NULL,
- gecko_embed_marshal_BOOLEAN__BOXED,
- G_TYPE_BOOLEAN,
- G_N_ELEMENTS (dom_param_types),
- dom_param_types);
-
- gecko_embed_signals[DOM_MOUSE_DOUBLE_CLICK] =
- g_signal_newv ("dom-mouse-dbl-click",
- GECKO_TYPE_EMBED,
- (GSignalFlags) (G_SIGNAL_RUN_FIRST | G_SIGNAL_RUN_LAST),
- NULL,
- g_signal_accumulator_true_handled, NULL,
- gecko_embed_marshal_BOOLEAN__BOXED,
- G_TYPE_BOOLEAN,
- G_N_ELEMENTS (dom_param_types),
- dom_param_types);
-
- gecko_embed_signals[DOM_MOUSE_OVER] =
- g_signal_newv ("dom-mouse-over",
- GECKO_TYPE_EMBED,
- (GSignalFlags) (G_SIGNAL_RUN_FIRST | G_SIGNAL_RUN_LAST),
- NULL,
- g_signal_accumulator_true_handled, NULL,
- gecko_embed_marshal_BOOLEAN__BOXED,
- G_TYPE_BOOLEAN,
- G_N_ELEMENTS (dom_param_types),
- dom_param_types);
-
- gecko_embed_signals[DOM_MOUSE_OUT] =
- g_signal_newv ("dom-mouse-out",
- GECKO_TYPE_EMBED,
- (GSignalFlags) (G_SIGNAL_RUN_FIRST | G_SIGNAL_RUN_LAST),
- NULL,
- g_signal_accumulator_true_handled, NULL,
- gecko_embed_marshal_BOOLEAN__BOXED,
- G_TYPE_BOOLEAN,
- G_N_ELEMENTS (dom_param_types),
- dom_param_types);
-
- gecko_embed_signals[DOM_MOUSE_OUT] =
- g_signal_newv ("dom-focus-in",
- GECKO_TYPE_EMBED,
- (GSignalFlags) (G_SIGNAL_RUN_FIRST | G_SIGNAL_RUN_LAST),
- NULL,
- g_signal_accumulator_true_handled, NULL,
- gecko_embed_marshal_BOOLEAN__BOXED,
- G_TYPE_BOOLEAN,
- G_N_ELEMENTS (dom_param_types),
- dom_param_types);
-
- gecko_embed_signals[DOM_MOUSE_OUT] =
- g_signal_newv ("dom-focus-out",
- GECKO_TYPE_EMBED,
- (GSignalFlags) (G_SIGNAL_RUN_FIRST | G_SIGNAL_RUN_LAST),
- NULL,
- g_signal_accumulator_true_handled, NULL,
- gecko_embed_marshal_BOOLEAN__BOXED,
- G_TYPE_BOOLEAN,
- G_N_ELEMENTS (dom_param_types),
- dom_param_types);
-
- gecko_embed_signals[DOM_MOUSE_OUT] =
- g_signal_newv ("dom-activate",
- GECKO_TYPE_EMBED,
- (GSignalFlags) (G_SIGNAL_RUN_FIRST | G_SIGNAL_RUN_LAST),
- NULL,
- g_signal_accumulator_true_handled, NULL,
- gecko_embed_marshal_BOOLEAN__BOXED,
- G_TYPE_BOOLEAN,
- G_N_ELEMENTS (dom_param_types),
- dom_param_types);
-
- gecko_embed_signals[DOM_CONTEXT_MENU] =
- g_signal_newv ("dom-context-menu",
- GECKO_TYPE_EMBED,
- (GSignalFlags) (G_SIGNAL_RUN_FIRST | G_SIGNAL_RUN_LAST),
- NULL,
- g_signal_accumulator_true_handled, NULL,
- gecko_embed_marshal_BOOLEAN__BOXED,
- G_TYPE_BOOLEAN,
- G_N_ELEMENTS (dom_param_types),
- dom_param_types);
-
- gecko_embed_signals[OPEN_URI] =
- g_signal_new ("open_uri",
- GECKO_TYPE_EMBED,
- (GSignalFlags) (G_SIGNAL_RUN_FIRST | G_SIGNAL_RUN_LAST),
- G_STRUCT_OFFSET (GeckoEmbedClass, open_uri),
- g_signal_accumulator_true_handled, NULL,
- gecko_embed_marshal_BOOLEAN__STRING,
- G_TYPE_BOOLEAN,
- 1,
- G_TYPE_STRING);
-
- gecko_embed_signals[NET_START] =
- g_signal_new ("net_start",
- GECKO_TYPE_EMBED,
- (GSignalFlags) (G_SIGNAL_RUN_FIRST | G_SIGNAL_RUN_LAST),
- G_STRUCT_OFFSET (GeckoEmbedClass, net_start),
- NULL, NULL,
- g_cclosure_marshal_VOID__VOID,
- G_TYPE_NONE,
- 0);
-
- gecko_embed_signals[NET_STOP] =
- g_signal_new ("net_stop",
- GECKO_TYPE_EMBED,
- (GSignalFlags) (G_SIGNAL_RUN_FIRST | G_SIGNAL_RUN_LAST),
- G_STRUCT_OFFSET (GeckoEmbedClass, net_stop),
- NULL, NULL,
- g_cclosure_marshal_VOID__VOID,
- G_TYPE_NONE,
- 0);
-
- gecko_embed_signals[NET_STATE] =
- g_signal_new ("net_state",
- GECKO_TYPE_EMBED,
- (GSignalFlags) (G_SIGNAL_RUN_FIRST | G_SIGNAL_RUN_LAST),
- G_STRUCT_OFFSET (GeckoEmbedClass, net_state),
- NULL, NULL,
- gecko_embed_marshal_VOID__INT_UINT,
- G_TYPE_NONE,
- 2,
- G_TYPE_INT,
- G_TYPE_UINT);
-
- gecko_embed_signals[NET_STATE_ALL] =
- g_signal_new ("net_state_all",
- GECKO_TYPE_EMBED,
- (GSignalFlags) (G_SIGNAL_RUN_FIRST | G_SIGNAL_RUN_LAST),
- G_STRUCT_OFFSET (GeckoEmbedClass, net_state_all),
- NULL, NULL,
- gecko_embed_marshal_VOID__STRING_INT_UINT,
- G_TYPE_NONE,
- 3,
- G_TYPE_STRING,
- G_TYPE_INT,
- G_TYPE_UINT); // static scope? to avoid string copy? or G_TYPE_POINTER as 1st?
-
- gecko_embed_signals[PROGRESS] =
- g_signal_new ("progress",
- GECKO_TYPE_EMBED,
- (GSignalFlags) (G_SIGNAL_RUN_FIRST | G_SIGNAL_RUN_LAST),
- G_STRUCT_OFFSET (GeckoEmbedClass, progress),
- NULL, NULL,
- gecko_embed_marshal_VOID__INT_INT,
- G_TYPE_NONE,
- 2,
- G_TYPE_INT,
- G_TYPE_INT);
-
- gecko_embed_signals[PROGRESS_ALL] =
- g_signal_new ("progress_all",
- GECKO_TYPE_EMBED,
- (GSignalFlags) (G_SIGNAL_RUN_FIRST | G_SIGNAL_RUN_LAST),
- G_STRUCT_OFFSET (GeckoEmbedClass, progress_all),
- NULL, NULL,
- gecko_embed_marshal_VOID__STRING_INT_INT,
- G_TYPE_NONE,
- 3,
- G_TYPE_STRING,
- G_TYPE_INT,
- G_TYPE_INT); // static scope?
-
- gecko_embed_signals[SECURITY_CHANGE] =
- g_signal_new ("security_change",
- GECKO_TYPE_EMBED,
- (GSignalFlags) (G_SIGNAL_RUN_FIRST | G_SIGNAL_RUN_LAST),
- G_STRUCT_OFFSET (GeckoEmbedClass, security_change),
- NULL, NULL,
- gecko_embed_marshal_VOID__POINTER_UINT,
- G_TYPE_NONE,
- 2,
- G_TYPE_POINTER,
- G_TYPE_UINT);
-
- gecko_embed_signals[STATUS_CHANGE] =
- g_signal_new ("status_change",
- GECKO_TYPE_EMBED,
- (GSignalFlags) (G_SIGNAL_RUN_FIRST | G_SIGNAL_RUN_LAST),
- G_STRUCT_OFFSET (GeckoEmbedClass, status_change),
- NULL, NULL,
- gecko_embed_marshal_VOID__POINTER_INT_POINTER,
- G_TYPE_NONE,
- 3,
- G_TYPE_POINTER,
- G_TYPE_INT,
- G_TYPE_POINTER);
-
- gecko_embed_signals[LINK_MESSAGE] =
- g_signal_new ("link_message",
- GECKO_TYPE_EMBED,
- (GSignalFlags) (G_SIGNAL_RUN_FIRST | G_SIGNAL_RUN_LAST),
- G_STRUCT_OFFSET (GeckoEmbedClass, link_message),
- NULL, NULL,
- g_cclosure_marshal_VOID__VOID,
- G_TYPE_NONE,
- 0);
-
- gecko_embed_signals[JS_STATUS] =
- g_signal_new ("js_status",
- GECKO_TYPE_EMBED,
- (GSignalFlags) (G_SIGNAL_RUN_FIRST | G_SIGNAL_RUN_LAST),
- G_STRUCT_OFFSET (GeckoEmbedClass, js_status_message),
- NULL, NULL,
- g_cclosure_marshal_VOID__VOID,
- G_TYPE_NONE,
- 0);
-
- gecko_embed_signals[LOCATION] =
- g_signal_new ("location",
- GECKO_TYPE_EMBED,
- (GSignalFlags) (G_SIGNAL_RUN_FIRST | G_SIGNAL_RUN_LAST),
- G_STRUCT_OFFSET (GeckoEmbedClass, location),
- NULL, NULL,
- g_cclosure_marshal_VOID__VOID,
- G_TYPE_NONE,
- 0);
-
- gecko_embed_signals[TITLE] =
- g_signal_new ("title",
- GECKO_TYPE_EMBED,
- (GSignalFlags) (G_SIGNAL_RUN_FIRST | G_SIGNAL_RUN_LAST),
- G_STRUCT_OFFSET (GeckoEmbedClass, title),
- NULL, NULL,
- g_cclosure_marshal_VOID__VOID,
- G_TYPE_NONE,
- 0);
-
- gecko_embed_signals[VISIBILITY] =
- g_signal_new ("visibility",
- GECKO_TYPE_EMBED,
- (GSignalFlags) (G_SIGNAL_RUN_FIRST | G_SIGNAL_RUN_LAST),
- G_STRUCT_OFFSET (GeckoEmbedClass, visibility),
- NULL, NULL,
- g_cclosure_marshal_VOID__BOOLEAN,
- G_TYPE_NONE,
- 1,
- G_TYPE_BOOLEAN);
-
- gecko_embed_signals[DESTROY_BROWSER] =
- g_signal_new ("destroy_browser",
- GECKO_TYPE_EMBED,
- (GSignalFlags) (G_SIGNAL_RUN_FIRST | G_SIGNAL_RUN_LAST),
- G_STRUCT_OFFSET (GeckoEmbedClass, destroy_browser),
- NULL, NULL,
- g_cclosure_marshal_VOID__VOID,
- G_TYPE_NONE,
- 0);
-
- gecko_embed_signals[SIZE_TO] =
- g_signal_new ("size_to",
- GECKO_TYPE_EMBED,
- (GSignalFlags) (G_SIGNAL_RUN_FIRST | G_SIGNAL_RUN_LAST),
- G_STRUCT_OFFSET (GeckoEmbedClass, size_to),
- NULL, NULL,
- gecko_embed_marshal_VOID__INT_INT,
- G_TYPE_NONE,
- 2,
- G_TYPE_INT,
- G_TYPE_INT);
-
- gecko_embed_signals[NEW_WINDOW] =
- g_signal_new ("new_window",
- GECKO_TYPE_EMBED,
- (GSignalFlags) (G_SIGNAL_RUN_FIRST | G_SIGNAL_RUN_LAST),
- G_STRUCT_OFFSET (GeckoEmbedClass, new_window),
- NULL, NULL,
- gecko_embed_marshal_VOID__OBJECT_UINT,
- G_TYPE_NONE,
- 2,
- G_TYPE_OBJECT,
- G_TYPE_UINT);
-
- g_type_class_add_private (object_class, sizeof (GeckoEmbedPrivate));
-}
-
-GtkWidget *
-gecko_embed_new (void)
-{
- return GTK_WIDGET (g_object_new (GECKO_TYPE_EMBED, NULL));
-}
diff --git a/embed/xulrunner/src/gecko-embed.h b/embed/xulrunner/src/gecko-embed.h
deleted file mode 100644
index 8aec90bc2..000000000
--- a/embed/xulrunner/src/gecko-embed.h
+++ /dev/null
@@ -1,151 +0,0 @@
-/*
- * Copyright © Christopher Blizzard
- * Copyright © Ramiro Estrugo
- * Copyright © 2006 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser 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.
- *
- * ---------------------------------------------------------------------------
- * Derived from Mozilla.org code, which had the following attributions:
- *
- * The Original Code is mozilla.org code.
- *
- * The Initial Developer of the Original Code is
- * Christopher Blizzard. Portions created by Christopher Blizzard are Copyright © Christopher Blizzard. All Rights Reserved.
- * Portions created by the Initial Developer are Copyright © 2001
- * the Initial Developer. All Rights Reserved.
- *
- * Contributor(s):
- * Christopher Blizzard <blizzard@mozilla.org>
- * Ramiro Estrugo <ramiro@eazel.com>
- * ---------------------------------------------------------------------------
- *
- * $Id$
- */
-
-#ifndef gecko_embed_h
-#define gecko_embed_h
-
-#include <stddef.h>
-#include <gtk/gtk.h>
-
-G_BEGIN_DECLS
-
-#define GECKO_TYPE_EMBED (gecko_embed_get_type())
-#define GECKO_EMBED(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), GECKO_TYPE_EMBED, GeckoEmbed))
-#define GECKO_EMBED_CLASS(k) (G_TYPE_CHECK_CLASS_CAST((k), GECKO_TYPE_EMBED, GeckoEmbedClass))
-#define GECKO_IS_EMBED(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), GECKO_TYPE_EMBED))
-#define GECKO_IS_EMBED_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE ((k), GECKO_TYPE_EMBED))
-#define GECKO_EMBED_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS ((o), GECKO_TYPE_EMBED, GeckoEmbedClass))
-
-typedef struct _GeckoEmbed GeckoEmbed;
-typedef struct _GeckoEmbedPrivate GeckoEmbedPrivate;
-typedef struct _GeckoEmbedClass GeckoEmbedClass;
-
-struct _GeckoEmbed
-{
- GtkBin parent_instance;
-
- /*< private >*/
- GeckoEmbedPrivate *priv;
-};
-
-struct _GeckoEmbedClass
-{
- GtkBinClass parent_class;
-
- /* Signals */
-
- /* Network */
- gboolean (* open_uri) (GeckoEmbed *embed, const char *aURI);
- void (* net_start) (GeckoEmbed *embed);
- void (* net_stop) (GeckoEmbed *embed);
- void (* net_state) (GeckoEmbed *embed, int state, guint status);
- void (* net_state_all) (GeckoEmbed *embed, const char *aURI,
- int state, guint status);
- void (* progress) (GeckoEmbed *embed, int curprogress,
- int maxprogress);
- void (* progress_all) (GeckoEmbed *embed, const char *aURI,
- int curprogress, int maxprogress);
- void (* security_change) (GeckoEmbed *embed, gpointer request,
- guint state);
- void (* status_change) (GeckoEmbed *embed, gpointer request,
- int status, gpointer message);
-
- /* Document */
- void (* link_message) (GeckoEmbed *embed);
- void (* js_status_message) (GeckoEmbed *embed);
- void (* location) (GeckoEmbed *embed);
- void (* title) (GeckoEmbed *embed);
- void (* visibility) (GeckoEmbed *embed, gboolean visibility);
- void (* destroy_browser) (GeckoEmbed *embed);
- void (* size_to) (GeckoEmbed *embed, int width, int height);
-
-
- /* misc. */
- void (* new_window) (GeckoEmbed *embed, GeckoEmbed **newEmbed,
- guint chromemask);
-
- /* reserved for future use */
- void (* reserved_0) (void);
- void (* reserved_1) (void);
- void (* reserved_2) (void);
- void (* reserved_3) (void);
- void (* reserved_4) (void);
- void (* reserved_5) (void);
- void (* reserved_6) (void);
- void (* reserved_7) (void);
- void (* reserved_8) (void);
- void (* reserved_9) (void);
- void (* reserved_a) (void);
- void (* reserved_b) (void);
- void (* reserved_c) (void);
- void (* reserved_d) (void);
- void (* reserved_e) (void);
- void (* reserved_f) (void);
-};
-
-GType gecko_embed_get_type (void);
-GtkWidget *gecko_embed_new (void);
-void gecko_embed_load_url (GeckoEmbed *embed,
- const char *url);
-void gecko_embed_stop_load (GeckoEmbed *embed);
-gboolean gecko_embed_can_go_back (GeckoEmbed *embed);
-gboolean gecko_embed_can_go_forward (GeckoEmbed *embed);
-void gecko_embed_go_back (GeckoEmbed *embed);
-void gecko_embed_go_forward (GeckoEmbed *embed);
-void gecko_embed_render_data (GeckoEmbed *embed,
- const char *data,
- guint32 len,
- const char *base_uri,
- const char *mime_type);
-void gecko_embed_open_stream (GeckoEmbed *embed,
- const char *base_uri,
- const char *mime_type);
-void gecko_embed_append_data (GeckoEmbed *embed,
- const char *data, guint32 len);
-void gecko_embed_close_stream (GeckoEmbed *embed);
-char *gecko_embed_get_link_message (GeckoEmbed *embed);
-char *gecko_embed_get_js_status (GeckoEmbed *embed);
-char *gecko_embed_get_title (GeckoEmbed *embed);
-char *gecko_embed_get_location (GeckoEmbed *embed);
-void gecko_embed_reload (GeckoEmbed *embed, gint32 flags);
-void gecko_embed_set_chrome_mask (GeckoEmbed *embed,
- guint32 flags);
-guint32 gecko_embed_get_chrome_mask (GeckoEmbed *embed);
-
-G_END_DECLS
-
-#endif /* gecko_embed_h */
diff --git a/embed/xulrunner/src/gecko-init-internal.h b/embed/xulrunner/src/gecko-init-internal.h
deleted file mode 100644
index 551b4bd45..000000000
--- a/embed/xulrunner/src/gecko-init-internal.h
+++ /dev/null
@@ -1,30 +0,0 @@
-/* ***** BEGIN LICENSE BLOCK *****
- * Copyright © 2006 Xan Lopez <xan@gnome.org>
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 2.1 of the License, or (at your option) any later version.
- *
- * This library 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
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with this library; if not, write to the Free Software
- * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
- * USA
- *
- * $Id$
- * ***** END LICENSE BLOCK ***** */
-
-#ifndef __gecko_init_internal_h
-#define __gecko_init_internal_h
-
-#include <gtk/gtk.h>
-#include "nsIDirectoryService.h"
-
-extern gboolean gecko_init_with_params (const char *, const char*, const char*, nsIDirectoryServiceProvider*);
-
-#endif
diff --git a/embed/xulrunner/src/gecko-init-private.h b/embed/xulrunner/src/gecko-init-private.h
deleted file mode 100644
index b4cc34bfb..000000000
--- a/embed/xulrunner/src/gecko-init-private.h
+++ /dev/null
@@ -1,33 +0,0 @@
-/* ***** BEGIN LICENSE BLOCK *****
- * Copyright © 2006 Xan Lopez <xan@gnome.org>
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 2.1 of the License, or (at your option) any later version.
- *
- * This library 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
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with this library; if not, write to the Free Software
- * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
- * USA
- *
- * $Id$
- * ***** END LICENSE BLOCK ***** */
-
-#ifndef __gecko_init_private_h
-#define __gecko_init_private_h
-
-#include <gtk/gtk.h>
-
-G_BEGIN_DECLS
-
-void gecko_reparent_to_offscreen (GtkWidget*);
-
-G_END_DECLS
-
-#endif
diff --git a/embed/xulrunner/src/gecko-init.cpp b/embed/xulrunner/src/gecko-init.cpp
deleted file mode 100644
index c7954bff3..000000000
--- a/embed/xulrunner/src/gecko-init.cpp
+++ /dev/null
@@ -1,372 +0,0 @@
-/*
- * Copyright © Christopher Blizzard
- * Copyright © 2006 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser 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.
- *
- * ---------------------------------------------------------------------------
- * Derived from Mozilla.org code, which had the following attributions:
- *
- * The Original Code is mozilla.org code.
- *
- * The Initial Developer of the Original Code is
- * Christopher Blizzard. Portions created by Christopher Blizzard are Copyright © Christopher Blizzard. All Rights Reserved.
- * Portions created by the Initial Developer are Copyright © 2001
- * the Initial Developer. All Rights Reserved.
- *
- * Contributor(s):
- * Christopher Blizzard <blizzard@mozilla.org>
- * ---------------------------------------------------------------------------
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include <config.h>
-
-#include <stdlib.h>
-
-#include "GeckoSingle.h"
-
-#include "nsIDocShell.h"
-#include "nsIWebProgress.h"
-#include "nsIWebBrowserStream.h"
-#include "nsIWidget.h"
-#include "nsIDirectoryService.h"
-#include "nsAppDirectoryServiceDefs.h"
-
-// for NS_APPSHELL_CID
-#include "nsWidgetsCID.h"
-
-// for do_GetInterface
-#include "nsIInterfaceRequestor.h"
-// for do_CreateInstance
-#include "nsIComponentManager.h"
-
-// for initializing our window watcher service
-#include "nsIWindowWatcher.h"
-
-#include "nsILocalFile.h"
-#include "nsXULAppAPI.h"
-
-// all of the crap that we need for event listeners
-// and when chrome windows finish loading
-#include "nsIDOMWindow.h"
-#include "nsPIDOMWindow.h"
-#include "nsIDOMWindowInternal.h"
-
-// For seting scrollbar visibilty
-#include <nsIDOMBarProp.h>
-
-// for the focus hacking we need to do
-#include "nsIFocusController.h"
-
-// app component registration
-#include "nsIGenericFactory.h"
-#include "nsIComponentRegistrar.h"
-
-// all of our local includes
-#include "gecko-init.h"
-#include "GeckoSingle.h"
-#include "EmbedWindow.h"
-#include "EmbedProgress.h"
-#include "EmbedContentListener.h"
-#include "EmbedEventListener.h"
-#include "EmbedWindowCreator.h"
-
-#ifdef MOZ_ACCESSIBILITY_ATK
-#include "nsIAccessibilityService.h"
-#include "nsIAccessible.h"
-#include "nsIDOMDocument.h"
-#endif
-
-#include <nsServiceManagerUtils.h>
-#include "nsXPCOMGlue.h"
-
-#include "gecko-init.h"
-#include "gecko-init-private.h"
-#include "gecko-init-internal.h"
-
-GtkWidget *sOffscreenWindow = 0;
-GtkWidget *sOffscreenFixed = 0;
-nsILocalFile *sProfileDir = nsnull;
-nsISupports *sProfileLock = nsnull;
-nsIDirectoryServiceProvider* sAppFileLocProvider;
-
-class GTKEmbedDirectoryProvider : public nsIDirectoryServiceProvider2
-{
- public:
- NS_DECL_ISUPPORTS_INHERITED
- NS_DECL_NSIDIRECTORYSERVICEPROVIDER
- NS_DECL_NSIDIRECTORYSERVICEPROVIDER2
-};
-
-static const GTKEmbedDirectoryProvider kDirectoryProvider;
-
-NS_IMPL_QUERY_INTERFACE2(GTKEmbedDirectoryProvider,
- nsIDirectoryServiceProvider,
- nsIDirectoryServiceProvider2)
-
-NS_IMETHODIMP_(nsrefcnt)
-GTKEmbedDirectoryProvider::AddRef()
-{
- return 2;
-}
-
-NS_IMETHODIMP_(nsrefcnt)
-GTKEmbedDirectoryProvider::Release()
-{
- return 1;
-}
-
-NS_IMETHODIMP
-GTKEmbedDirectoryProvider::GetFile(const char *aKey, PRBool *aPersist,
- nsIFile* *aResult)
-{
- if (sAppFileLocProvider) {
- nsresult rv = sAppFileLocProvider->GetFile(aKey, aPersist,
- aResult);
- if (NS_SUCCEEDED(rv))
- return rv;
- }
-
- if (sProfileDir && !strcmp(aKey, NS_APP_USER_PROFILE_50_DIR)) {
- *aPersist = PR_TRUE;
- return sProfileDir->Clone(aResult);
- }
-
- return NS_ERROR_FAILURE;
-}
-
-NS_IMETHODIMP
-GTKEmbedDirectoryProvider::GetFiles(const char *aKey,
- nsISimpleEnumerator* *aResult)
-{
- nsCOMPtr<nsIDirectoryServiceProvider2>
- dp2(do_QueryInterface(sAppFileLocProvider));
-
- if (!dp2)
- return NS_ERROR_FAILURE;
-
- return dp2->GetFiles(aKey, aResult);
-}
-
-/* static */
-nsresult
-RegisterAppComponents(void)
-{
- nsCOMPtr<nsIComponentRegistrar> cr;
- nsresult rv = NS_GetComponentRegistrar(getter_AddRefs(cr));
- NS_ENSURE_SUCCESS(rv, rv);
-
- nsCOMPtr<nsIComponentManager> cm;
- rv = NS_GetComponentManager (getter_AddRefs (cm));
- NS_ENSURE_SUCCESS (rv, rv);
-
-#if 0
- for (int i = 0; i < sNumAppComps; ++i) {
- nsCOMPtr<nsIGenericFactory> componentFactory;
- rv = NS_NewGenericFactory(getter_AddRefs(componentFactory),
- &(sAppComps[i]));
- if (NS_FAILED(rv)) {
- NS_WARNING("Unable to create factory for component");
- continue; // don't abort registering other components
- }
-
- rv = cr->RegisterFactory(sAppComps[i].mCID, sAppComps[i].mDescription,
- sAppComps[i].mContractID, componentFactory);
- NS_ASSERTION(NS_SUCCEEDED(rv), "Unable to register factory for component");
-
- // Call the registration hook of the component, if any
- if (sAppComps[i].mRegisterSelfProc) {
- rv = sAppComps[i].mRegisterSelfProc(cm, nsnull, nsnull, nsnull,
- &(sAppComps[i]));
- NS_ASSERTION(NS_SUCCEEDED(rv), "Unable to self-register component");
- }
- }
-#endif
-
- return rv;
-}
-
-/* static */
-nsresult
-StartupProfile (const char* aProfileDir, const char* aProfileName)
-{
- /* Running without profile */
- if (!aProfileDir || !aProfileName)
- return NS_OK;
-
- if (sProfileDir && GeckoSingle::sWidgetCount != 0) {
- NS_ERROR("Cannot change profile directory during run!");
- return NS_ERROR_ALREADY_INITIALIZED;
- }
-
- nsresult rv;
- nsCOMPtr<nsILocalFile> profileDir;
- rv = NS_NewNativeLocalFile (nsDependentCString (aProfileDir), PR_TRUE,
- &sProfileDir);
- if (NS_FAILED (rv))
- return rv;
-
- if (aProfileName) {
- rv = sProfileDir->AppendNative (nsDependentCString (aProfileName));
- if (NS_FAILED (rv))
- return rv; // FIXMEchpe release sProfileDir
- }
-
- rv = XRE_LockProfileDirectory (sProfileDir, &sProfileLock);
- if (NS_FAILED (rv))
- return rv; // FIXMEchpe release sProfileDir
-
- if (GeckoSingle::sWidgetCount)
- XRE_NotifyProfile();
-
- return NS_OK;
-}
-
-gboolean
-gecko_init ()
-{
- return gecko_init_with_params (nsnull, nsnull, nsnull, nsnull);
-}
-
-gboolean
-gecko_init_with_profile (const char *aGREPath,
- const char* aProfileDir,
- const char* aProfileName)
-{
- return gecko_init_with_params (aGREPath, aProfileDir, aProfileName, nsnull);
-}
-
-gboolean
-gecko_init_with_params (const char *aGREPath,
- const char* aProfileDir,
- const char* aProfileName,
- nsIDirectoryServiceProvider* aAppFileLocProvider)
-{
- nsresult rv;
- nsCOMPtr<nsILocalFile> binDir;
-
-#if 0 //def XPCOM_GLUE
- const char* xpcomLocation = GRE_GetXPCOMPath();
-
- // Startup the XPCOM Glue that links us up with XPCOM.
- nsresult rv = XPCOMGlueStartup(xpcomLocation);
- if (NS_FAILED(rv)) return;
-#endif
-
- NS_IF_ADDREF (sAppFileLocProvider = aAppFileLocProvider);
-
- /* FIrst try to lock the profile */
- rv = StartupProfile (aProfileDir, aProfileName);
- if (NS_FAILED (rv))
- return FALSE;
-
- const char* aCompPath = g_getenv("GECKO_HOME");
-
- if (aCompPath) {
- rv = NS_NewNativeLocalFile(nsEmbedCString(aCompPath), PR_TRUE, getter_AddRefs(binDir));
- NS_ENSURE_SUCCESS(rv,false);
- }
-
- if (!aGREPath)
- aGREPath = getenv("MOZILLA_FIVE_HOME");
-
- if (!aGREPath)
- return FALSE;
-
- nsCOMPtr<nsILocalFile> greDir;
- rv = NS_NewNativeLocalFile (nsDependentCString (aGREPath), PR_TRUE,
- getter_AddRefs (greDir));
- if (NS_FAILED(rv))
- return FALSE;
-
- rv = XRE_InitEmbedding(greDir, binDir,
- const_cast<GTKEmbedDirectoryProvider*> (&kDirectoryProvider),
- nsnull, nsnull);
- if (NS_FAILED (rv))
- return FALSE;
-
- if (sProfileDir)
- XRE_NotifyProfile();
-
- rv = RegisterAppComponents();
- NS_ASSERTION(NS_SUCCEEDED(rv), "Warning: Failed to register app components.\n");
-
- // create our local object
- EmbedWindowCreator *creator = new EmbedWindowCreator();
- nsCOMPtr<nsIWindowCreator> windowCreator =
- static_cast<nsIWindowCreator *>(creator);
-
- // Attach it via the watcher service
- nsCOMPtr<nsIWindowWatcher> watcher (do_GetService(NS_WINDOWWATCHER_CONTRACTID));
- if (watcher)
- watcher->SetWindowCreator(windowCreator);
-
- return true;
-}
-
-/* static */
-void
-EnsureOffscreenWindow(void)
-{
- if (sOffscreenWindow)
- return;
-
- sOffscreenWindow = gtk_window_new (GTK_WINDOW_TOPLEVEL);
- gtk_widget_realize (sOffscreenWindow);
- sOffscreenFixed = gtk_fixed_new();
- gtk_container_add (GTK_CONTAINER (sOffscreenWindow), sOffscreenFixed);
- gtk_widget_realize (sOffscreenFixed);
-}
-
-/* static */
-void
-gecko_reparent_to_offscreen(GtkWidget *aWidget)
-{
- EnsureOffscreenWindow();
-
- gtk_widget_reparent(aWidget, sOffscreenFixed);
-}
-
-/* static */
-void
-DestroyOffscreenWindow(void)
-{
- if (!sOffscreenWindow)
- return;
- gtk_widget_destroy(sOffscreenWindow);
- sOffscreenWindow = nsnull;
- sOffscreenFixed = nsnull;
-}
-
-void
-gecko_shutdown()
-{
- // destroy the offscreen window
- DestroyOffscreenWindow();
-
- NS_IF_RELEASE (sProfileDir);
-
- // shut down XPCOM/Embedding
- XRE_TermEmbedding();
-
- // we no longer need a reference to the DirectoryServiceProvider
- NS_IF_RELEASE (sAppFileLocProvider);
-
- /* FIXMchpe before or after TermEmbedding?? */
- NS_IF_RELEASE (sProfileLock);
-}
diff --git a/embed/xulrunner/src/gecko-init.h b/embed/xulrunner/src/gecko-init.h
deleted file mode 100644
index ee66f0ea4..000000000
--- a/embed/xulrunner/src/gecko-init.h
+++ /dev/null
@@ -1,35 +0,0 @@
-/* ***** BEGIN LICENSE BLOCK *****
- * Copyright © 2006 Xan Lopez <xan@gnome.org>
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 2.1 of the License, or (at your option) any later version.
- *
- * This library 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
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with this library; if not, write to the Free Software
- * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
- * USA
- *
- * $Id$
- * ***** END LICENSE BLOCK ***** */
-
-#ifndef __gecko_init_h
-#define __gecko_init_h
-
-#include <gtk/gtk.h>
-
-G_BEGIN_DECLS
-
-gboolean gecko_init ();
-gboolean gecko_init_with_profile (const char *, const char*, const char*);
-void gecko_shutdown ();
-
-G_END_DECLS
-
-#endif
diff --git a/embed/xulrunner/tests/Makefile.am b/embed/xulrunner/tests/Makefile.am
deleted file mode 100644
index cee264947..000000000
--- a/embed/xulrunner/tests/Makefile.am
+++ /dev/null
@@ -1,30 +0,0 @@
-bin_PROGRAMS = testgeckoembed
-
-NULL =
-
-testgeckoembed_SOURCES = \
- testgeckoembed.cpp
-
-testgeckoembed_CPPFLAGS = \
- -I$(top_srcdir) \
- -I$(top_srcdir)/embed/xulrunner/src \
- -I$(top_builddir)/embed/xulrunner/src \
- $(LIBXUL_CXXCPPFLAGS) \
- $(LIBXUL_INCLUDES) \
- -DGECKO_HOME=\"$(LIBXUL_PREFIX)\" \
- $(AM_CPPFLAGS)
-
-testgeckoembed_CXXFLAGS = \
- $(LIBXUL_CXXFLAGS) \
- $(GTK_CFLAGS) \
- $(AM_CXXFLAGS)
-
-testgeckoembed_LDFLAGS = \
- -R$(LIBXUL_LIBDIR) \
- $(AM_LDFLAGS)
-
-testgeckoembed_LDADD = \
- $(top_builddir)/embed/xulrunner/src/libgnomegeckoembed-0.0.la \
- $(LIBXUL_LIBS) \
- $(GTK_LIBS) \
- $(NULL)
diff --git a/embed/xulrunner/tests/TestGtkEmbedNotebook.cpp b/embed/xulrunner/tests/TestGtkEmbedNotebook.cpp
deleted file mode 100644
index 1891ca06b..000000000
--- a/embed/xulrunner/tests/TestGtkEmbedNotebook.cpp
+++ /dev/null
@@ -1,49 +0,0 @@
-#include <gtk/gtk.h>
-#include <gtkmozembed.h>
-int main(int argc, char *argv[])
-{
- GtkWidget *window;
- GtkWidget *label;
- GtkWidget *mozembed;
- GtkWidget *container;
- char *url;
-
- gtk_init(&argc, &argv);
-
- window = gtk_window_new(GTK_WINDOW_TOPLEVEL);
-
- container = gtk_notebook_new();
- mozembed = gtk_moz_embed_new();
- label = gtk_label_new("Can you see this message?\n"
- "Once you switch to mozembed page "
- "you never see this message.");
-
- gtk_signal_connect(GTK_OBJECT(mozembed), "destroy",
- GTK_SIGNAL_FUNC(gtk_main_quit),
-NULL);
-
- gtk_container_add(GTK_CONTAINER(window), container);
-
- gtk_notebook_append_page(GTK_NOTEBOOK(container),
- label,
- gtk_label_new("gtk label"));
-
- gtk_notebook_append_page(GTK_NOTEBOOK(container),
- mozembed,
- gtk_label_new("mozembed"));
-
-
-
-
- gtk_widget_set_usize(window, 400, 300);
- gtk_widget_show(mozembed);
- gtk_widget_show(label);
- gtk_widget_show_all(window);
-
- url = (argc > 1) ? argv[1] : (char *)"localhost";
- gtk_moz_embed_load_url(GTK_MOZ_EMBED(mozembed), url);
-
- gtk_main();
-
- return 0;
-}
diff --git a/embed/xulrunner/tests/testgeckoembed.cpp b/embed/xulrunner/tests/testgeckoembed.cpp
deleted file mode 100644
index eb96b623f..000000000
--- a/embed/xulrunner/tests/testgeckoembed.cpp
+++ /dev/null
@@ -1,1145 +0,0 @@
-/*
- * Copyright © Christopher Blizzard
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser 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.
- *
- * ---------------------------------------------------------------------------
- * Derived from Mozilla.org code, which had the following attributions:
- *
- * The Original Code is mozilla.org code.
- *
- * The Initial Developer of the Original Code is
- * Christopher Blizzard. Portions created by Christopher Blizzard are Copyright © Christopher Blizzard. All Rights Reserved.
- * Portions created by the Initial Developer are Copyright © 2001
- * the Initial Developer. All Rights Reserved.
- *
- * Contributor(s):
- * Christopher Blizzard <blizzard@mozilla.org>
- * ---------------------------------------------------------------------------
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include <config.h>
-
-#include "gecko-init.h"
-#include "gecko-embed.h"
-#include "gecko-embed-single.h"
-#include "gecko-dom-event.h"
-#include "gecko-dom-event-internal.h"
-#include "gecko-embed-types.h"
-
-#include <gtk/gtk.h>
-#include <stdio.h>
-#include <string.h>
-#include <stdlib.h>
-
-// mozilla specific headers
-#include "nsIDOMKeyEvent.h"
-#include "nsIDOMMouseEvent.h"
-#include "nsIDOMUIEvent.h"
-
-#include <nsStringGlue.h>
-#include <nsCOMPtr.h>
-
-#define XPCOM_GLUE
-#include <nsXPCOMGlue.h>
-
-typedef struct _TestGeckoBrowser {
- GtkWidget *topLevelWindow;
- GtkWidget *topLevelVBox;
- GtkWidget *menuBar;
- GtkWidget *fileMenuItem;
- GtkWidget *fileMenu;
- GtkWidget *fileOpenNewBrowser;
- GtkWidget *fileStream;
- GtkWidget *fileClose;
- GtkWidget *fileQuit;
- GtkWidget *toolbarHBox;
- GtkWidget *toolbar;
- GtkWidget *backButton;
- GtkWidget *stopButton;
- GtkWidget *forwardButton;
- GtkWidget *reloadButton;
- GtkWidget *urlEntry;
- GtkWidget *mozEmbed;
- GtkWidget *progressAreaHBox;
- GtkWidget *progressBar;
- GtkWidget *statusAlign;
- GtkWidget *statusBar;
- const char *statusMessage;
- int loadPercent;
- int bytesLoaded;
- int maxBytesLoaded;
- char *tempMessage;
- gboolean menuBarOn;
- gboolean toolBarOn;
- gboolean locationBarOn;
- gboolean statusBarOn;
-
-} TestGeckoBrowser;
-
-// the list of browser windows currently open
-GList *browser_list = g_list_alloc();
-
-static TestGeckoBrowser *new_gecko_browser (guint32 chromeMask);
-static void set_browser_visibility (TestGeckoBrowser *browser,
- gboolean visibility);
-
-static int num_browsers = 0;
-
-// callbacks from the UI
-static void back_clicked_cb (GtkButton *button,
- TestGeckoBrowser *browser);
-static void stop_clicked_cb (GtkButton *button,
- TestGeckoBrowser *browser);
-static void forward_clicked_cb (GtkButton *button,
- TestGeckoBrowser *browser);
-static void reload_clicked_cb (GtkButton *button,
- TestGeckoBrowser *browser);
-static void url_activate_cb (GtkEditable *widget,
- TestGeckoBrowser *browser);
-static void menu_open_new_cb (GtkMenuItem *menuitem,
- TestGeckoBrowser *browser);
-static void menu_stream_cb (GtkMenuItem *menuitem,
- TestGeckoBrowser *browser);
-static void menu_close_cb (GtkMenuItem *menuitem,
- TestGeckoBrowser *browser);
-static void menu_quit_cb (GtkMenuItem *menuitem,
- TestGeckoBrowser *browser);
-static gboolean delete_cb (GtkWidget *widget, GdkEventAny *event,
- TestGeckoBrowser *browser);
-static void destroy_cb (GtkWidget *widget,
- TestGeckoBrowser *browser);
-
-// callbacks from the widget
-static void location_changed_cb (GeckoEmbed *embed, TestGeckoBrowser *browser);
-static void title_changed_cb (GeckoEmbed *embed, TestGeckoBrowser *browser);
-static void load_started_cb (GeckoEmbed *embed, TestGeckoBrowser *browser);
-static void load_finished_cb (GeckoEmbed *embed, TestGeckoBrowser *browser);
-static void net_state_change_cb (GeckoEmbed *embed, gint flags,
- guint status, TestGeckoBrowser *browser);
-static void net_state_change_all_cb (GeckoEmbed *embed, const char *uri,
- gint flags, guint status,
- TestGeckoBrowser *browser);
-static void progress_change_cb (GeckoEmbed *embed, gint cur, gint max,
- TestGeckoBrowser *browser);
-static void progress_change_all_cb (GeckoEmbed *embed, const char *uri,
- gint cur, gint max,
- TestGeckoBrowser *browser);
-static void link_message_cb (GeckoEmbed *embed, TestGeckoBrowser *browser);
-static void js_status_cb (GeckoEmbed *embed, TestGeckoBrowser *browser);
-static void new_window_cb (GeckoEmbed *embed,
- GeckoEmbed **retval, guint chromemask,
- TestGeckoBrowser *browser);
-static void visibility_cb (GeckoEmbed *embed,
- gboolean visibility,
- TestGeckoBrowser *browser);
-static void destroy_brsr_cb (GeckoEmbed *embed, TestGeckoBrowser *browser);
-static gint open_uri_cb (GeckoEmbed *embed, const char *uri,
- TestGeckoBrowser *browser);
-static void size_to_cb (GeckoEmbed *embed, gint width,
- gint height, TestGeckoBrowser *browser);
-static gboolean dom_key_down_cb (GeckoEmbed *, GeckoDOMEvent *event,
- TestGeckoBrowser *browser);
-static gboolean dom_key_press_cb (GeckoEmbed *, GeckoDOMEvent *event,
- TestGeckoBrowser *browser);
-static gboolean dom_key_up_cb (GeckoEmbed *, GeckoDOMEvent *event,
- TestGeckoBrowser *browser);
-static gboolean dom_mouse_down_cb (GeckoEmbed *, GeckoDOMEvent *event,
- TestGeckoBrowser *browser);
-static gboolean dom_mouse_up_cb (GeckoEmbed *, GeckoDOMEvent *event,
- TestGeckoBrowser *browser);
-static gboolean dom_mouse_click_cb (GeckoEmbed *, GeckoDOMEvent *event,
- TestGeckoBrowser *browser);
-static gboolean dom_mouse_dbl_click_cb (GeckoEmbed *embed,
- GeckoDOMEvent *event,
- TestGeckoBrowser *browser);
-static gboolean dom_mouse_over_cb (GeckoEmbed *, GeckoDOMEvent *event,
- TestGeckoBrowser *browser);
-static gboolean dom_mouse_out_cb (GeckoEmbed *, GeckoDOMEvent *event,
- TestGeckoBrowser *browser);
-static gboolean dom_activate_cb (GeckoEmbed *, GeckoDOMEvent *event,
- TestGeckoBrowser *browser);
-static gboolean dom_focus_in_cb (GeckoEmbed *, GeckoDOMEvent *event,
- TestGeckoBrowser *browser);
-static gboolean dom_focus_out_cb (GeckoEmbed *, GeckoDOMEvent *event,
- TestGeckoBrowser *browser);
-static gboolean dom_context_menu_cb (GeckoEmbed *, GeckoDOMEvent *event,
- TestGeckoBrowser *browser);
-
-// callbacks from the singleton object
-static void new_window_orphan_cb (GeckoEmbedSingle *embed,
- GeckoEmbed **retval, guint chromemask,
- gpointer data);
-
-// some utility functions
-static void update_status_bar_text (TestGeckoBrowser *browser);
-static void update_temp_message (TestGeckoBrowser *browser,
- const char *message);
-static void update_nav_buttons (TestGeckoBrowser *browser);
-
-int
-main(int argc, char **argv)
-{
- //g_setenv ("MOZILLA_FIVE_HOME", GECKO_HOME, FALSE);
-
- gtk_init(&argc, &argv);
-
- static const GREVersionRange greVersion = {
- "1.9a", PR_TRUE,
- "2", PR_TRUE
- };
-
- char xpcomPath[PATH_MAX];
-
- nsresult rv = GRE_GetGREPathWithProperties(&greVersion, 1, nsnull, 0,
- xpcomPath, sizeof(xpcomPath));
- if (NS_FAILED(rv)) {
- fprintf(stderr, "Couldn't find a compatible GRE.\n");
- return 1;
- }
-
- rv = XPCOMGlueStartup(xpcomPath);
- if (NS_FAILED(rv)) {
- fprintf(stderr, "Couldn't start XPCOM.");
- return 1;
- }
-
- char *lastSlash = strrchr(xpcomPath, '/');
- if (lastSlash)
- *lastSlash = '\0';
-
-
- char *home_path;
- char *full_path;
- home_path = getenv("HOME");
- if (!home_path) {
- fprintf(stderr, "Failed to get HOME\n");
- exit(1);
- }
-
-
- full_path = g_strdup_printf("%s/%s", home_path, ".TestGtkEmbed");
-
- if (!gecko_init_with_profile (xpcomPath, full_path, "TestGtkEmbed")) {
- fprintf(stderr, "Failed gecko_init_with_profile\n");
- exit(1);
- }
-
- // get the singleton object and hook up to its new window callback
- // so we can create orphaned windows.
-
- GeckoEmbedSingle *single;
-
- single = gecko_embed_single_get();
- if (!single) {
- fprintf(stderr, "Failed to get singleton embed object!\n");
- exit(1);
- }
-
- g_signal_connect (single, "new-window-orphan",
- G_CALLBACK (new_window_orphan_cb), NULL);
-
-
- TestGeckoBrowser *browser = new_gecko_browser(GECKO_EMBED_FLAG_DEFAULTCHROME);
-
- // set our minimum size
- gtk_widget_set_usize(browser->mozEmbed, 400, 400);
-
- set_browser_visibility(browser, TRUE);
-
- if (argc > 1)
- gecko_embed_load_url(GECKO_EMBED(browser->mozEmbed), argv[1]);
-
- gtk_main();
-
- gecko_shutdown ();
-}
-
-static TestGeckoBrowser *
-new_gecko_browser(guint32 chromeMask)
-{
- guint32 actualChromeMask = chromeMask;
- TestGeckoBrowser *browser = 0;
-
- num_browsers++;
-
- browser = g_new0(TestGeckoBrowser, 1);
-
- browser_list = g_list_prepend(browser_list, browser);
-
- browser->menuBarOn = FALSE;
- browser->toolBarOn = FALSE;
- browser->locationBarOn = FALSE;
- browser->statusBarOn = FALSE;
-
- g_print("new_gecko_browser\n");
-
-// if (chromeMask == GECKO_EMBED_FLAG_DEFAULTCHROME)
-// actualChromeMask = GECKO_EMBED_FLAG_ALLCHROME;
-
- /* FIXMEchpe find out WHY the chrome masks we get from gecko as so weird */
- actualChromeMask = 0xffffffff;
-
- if (actualChromeMask & GECKO_EMBED_FLAG_MENUBARON)
- {
- browser->menuBarOn = TRUE;
- g_print("\tmenu bar\n");
- }
- if (actualChromeMask & GECKO_EMBED_FLAG_TOOLBARON)
- {
- browser->toolBarOn = TRUE;
- g_print("\ttool bar\n");
- }
- if (actualChromeMask & GECKO_EMBED_FLAG_LOCATIONBARON)
- {
- browser->locationBarOn = TRUE;
- g_print("\tlocation bar\n");
- }
- if (actualChromeMask & GECKO_EMBED_FLAG_STATUSBARON)
- {
- browser->statusBarOn = TRUE;
- g_print("\tstatus bar\n");
- }
-
- // create our new toplevel window
- browser->topLevelWindow = gtk_window_new(GTK_WINDOW_TOPLEVEL);
- // new vbox
- browser->topLevelVBox = gtk_vbox_new(FALSE, 0);
- // add it to the toplevel window
- gtk_container_add(GTK_CONTAINER(browser->topLevelWindow),
- browser->topLevelVBox);
- // create our menu bar
- browser->menuBar = gtk_menu_bar_new();
- // create the file menu
- browser->fileMenuItem = gtk_menu_item_new_with_label("File");
- browser->fileMenu = gtk_menu_new();
- gtk_menu_item_set_submenu (GTK_MENU_ITEM(browser->fileMenuItem),
- browser->fileMenu);
-
- browser->fileOpenNewBrowser =
- gtk_menu_item_new_with_label("Open New Browser");
- gtk_menu_append(GTK_MENU(browser->fileMenu),
- browser->fileOpenNewBrowser);
-
- browser->fileStream =
- gtk_menu_item_new_with_label("Test Stream");
- gtk_menu_append(GTK_MENU(browser->fileMenu),
- browser->fileStream);
-
- browser->fileClose =
- gtk_menu_item_new_with_label("Close");
- gtk_menu_append(GTK_MENU(browser->fileMenu),
- browser->fileClose);
-
- browser->fileQuit =
- gtk_menu_item_new_with_label("Quit");
- gtk_menu_append(GTK_MENU(browser->fileMenu),
- browser->fileQuit);
-
- // append it
- gtk_menu_bar_append(GTK_MENU_BAR(browser->menuBar), browser->fileMenuItem);
-
- // add it to the vbox
- gtk_box_pack_start(GTK_BOX(browser->topLevelVBox),
- browser->menuBar,
- FALSE, // expand
- FALSE, // fill
- 0); // padding
- // create the hbox that will contain the toolbar and the url text entry bar
- browser->toolbarHBox = gtk_hbox_new(FALSE, 0);
- // add that hbox to the vbox
- gtk_box_pack_start(GTK_BOX(browser->topLevelVBox),
- browser->toolbarHBox,
- FALSE, // expand
- FALSE, // fill
- 0); // padding
- // new horiz toolbar with buttons + icons
- browser->toolbar = gtk_toolbar_new();
- gtk_toolbar_set_orientation(GTK_TOOLBAR(browser->toolbar),
- GTK_ORIENTATION_HORIZONTAL);
- gtk_toolbar_set_style(GTK_TOOLBAR(browser->toolbar),
- GTK_TOOLBAR_BOTH);
-
- // add it to the hbox
- gtk_box_pack_start(GTK_BOX(browser->toolbarHBox), browser->toolbar,
- FALSE, // expand
- FALSE, // fill
- 0); // padding
- // new back button
- browser->backButton =
- gtk_toolbar_append_item(GTK_TOOLBAR(browser->toolbar),
- "Back",
- "Go Back",
- "Go Back",
- 0, // XXX replace with icon
- GTK_SIGNAL_FUNC(back_clicked_cb),
- browser);
- // new stop button
- browser->stopButton =
- gtk_toolbar_append_item(GTK_TOOLBAR(browser->toolbar),
- "Stop",
- "Stop",
- "Stop",
- 0, // XXX replace with icon
- GTK_SIGNAL_FUNC(stop_clicked_cb),
- browser);
- // new forward button
- browser->forwardButton =
- gtk_toolbar_append_item(GTK_TOOLBAR(browser->toolbar),
- "Forward",
- "Forward",
- "Forward",
- 0, // XXX replace with icon
- GTK_SIGNAL_FUNC(forward_clicked_cb),
- browser);
- // new reload button
- browser->reloadButton =
- gtk_toolbar_append_item(GTK_TOOLBAR(browser->toolbar),
- "Reload",
- "Reload",
- "Reload",
- 0, // XXX replace with icon
- GTK_SIGNAL_FUNC(reload_clicked_cb),
- browser);
- // create the url text entry
- browser->urlEntry = gtk_entry_new();
- // add it to the hbox
- gtk_box_pack_start(GTK_BOX(browser->toolbarHBox), browser->urlEntry,
- TRUE, // expand
- TRUE, // fill
- 0); // padding
- // create our new gtk moz embed widget
- browser->mozEmbed = gecko_embed_new();
- // add it to the toplevel vbox
- gtk_box_pack_start(GTK_BOX(browser->topLevelVBox), browser->mozEmbed,
- TRUE, // expand
- TRUE, // fill
- 0); // padding
- // create the new hbox for the progress area
- browser->progressAreaHBox = gtk_hbox_new(FALSE, 0);
- // add it to the vbox
- gtk_box_pack_start(GTK_BOX(browser->topLevelVBox), browser->progressAreaHBox,
- FALSE, // expand
- FALSE, // fill
- 0); // padding
- // create our new progress bar
- browser->progressBar = gtk_progress_bar_new();
- // add it to the hbox
- gtk_box_pack_start(GTK_BOX(browser->progressAreaHBox), browser->progressBar,
- FALSE, // expand
- FALSE, // fill
- 0); // padding
-
- // create our status area and the alignment object that will keep it
- // from expanding
- browser->statusAlign = gtk_alignment_new(0, 0, 1, 1);
- gtk_widget_set_usize(browser->statusAlign, 1, -1);
- // create the status bar
- browser->statusBar = gtk_statusbar_new();
- gtk_container_add(GTK_CONTAINER(browser->statusAlign), browser->statusBar);
- // add it to the hbox
- gtk_box_pack_start(GTK_BOX(browser->progressAreaHBox), browser->statusAlign,
- TRUE, // expand
- TRUE, // fill
- 0); // padding
- // by default none of the buttons are marked as sensitive.
- gtk_widget_set_sensitive(browser->backButton, FALSE);
- gtk_widget_set_sensitive(browser->stopButton, FALSE);
- gtk_widget_set_sensitive(browser->forwardButton, FALSE);
- gtk_widget_set_sensitive(browser->reloadButton, FALSE);
-
- // catch the destruction of the toplevel window
- gtk_signal_connect(GTK_OBJECT(browser->topLevelWindow), "delete_event",
- GTK_SIGNAL_FUNC(delete_cb), browser);
-
- // hook up the activate signal to the right callback
- gtk_signal_connect(GTK_OBJECT(browser->urlEntry), "activate",
- GTK_SIGNAL_FUNC(url_activate_cb), browser);
-
- // hook up to the open new browser activation
- gtk_signal_connect(GTK_OBJECT(browser->fileOpenNewBrowser), "activate",
- GTK_SIGNAL_FUNC(menu_open_new_cb), browser);
- // hook up to the stream test
- gtk_signal_connect(GTK_OBJECT(browser->fileStream), "activate",
- GTK_SIGNAL_FUNC(menu_stream_cb), browser);
- // close this window
- gtk_signal_connect(GTK_OBJECT(browser->fileClose), "activate",
- GTK_SIGNAL_FUNC(menu_close_cb), browser);
- // quit the application
- gtk_signal_connect(GTK_OBJECT(browser->fileQuit), "activate",
- GTK_SIGNAL_FUNC(menu_quit_cb), browser);
-
- // hook up the location change to update the urlEntry
- gtk_signal_connect(GTK_OBJECT(browser->mozEmbed), "location",
- GTK_SIGNAL_FUNC(location_changed_cb), browser);
- // hook up the title change to update the window title
- gtk_signal_connect(GTK_OBJECT(browser->mozEmbed), "title",
- GTK_SIGNAL_FUNC(title_changed_cb), browser);
- // hook up the start and stop signals
- gtk_signal_connect(GTK_OBJECT(browser->mozEmbed), "net_start",
- GTK_SIGNAL_FUNC(load_started_cb), browser);
- gtk_signal_connect(GTK_OBJECT(browser->mozEmbed), "net_stop",
- GTK_SIGNAL_FUNC(load_finished_cb), browser);
- // hook up to the change in network status
- gtk_signal_connect(GTK_OBJECT(browser->mozEmbed), "net_state",
- GTK_SIGNAL_FUNC(net_state_change_cb), browser);
- gtk_signal_connect(GTK_OBJECT(browser->mozEmbed), "net_state_all",
- GTK_SIGNAL_FUNC(net_state_change_all_cb), browser);
- // hookup to changes in progress
- gtk_signal_connect(GTK_OBJECT(browser->mozEmbed), "progress",
- GTK_SIGNAL_FUNC(progress_change_cb), browser);
- gtk_signal_connect(GTK_OBJECT(browser->mozEmbed), "progress_all",
- GTK_SIGNAL_FUNC(progress_change_all_cb), browser);
- // hookup to changes in over-link message
- gtk_signal_connect(GTK_OBJECT(browser->mozEmbed), "link_message",
- GTK_SIGNAL_FUNC(link_message_cb), browser);
- // hookup to changes in js status message
- gtk_signal_connect(GTK_OBJECT(browser->mozEmbed), "js_status",
- GTK_SIGNAL_FUNC(js_status_cb), browser);
- // hookup to see whenever a new window is requested
- gtk_signal_connect(GTK_OBJECT(browser->mozEmbed), "new_window",
- GTK_SIGNAL_FUNC(new_window_cb), browser);
- // hookup to any requested visibility changes
- gtk_signal_connect(GTK_OBJECT(browser->mozEmbed), "visibility",
- GTK_SIGNAL_FUNC(visibility_cb), browser);
- // hookup to the signal that says that the browser requested to be
- // destroyed
- gtk_signal_connect(GTK_OBJECT(browser->mozEmbed), "destroy_browser",
- GTK_SIGNAL_FUNC(destroy_brsr_cb), browser);
- // hookup to the signal that is called when someone clicks on a link
- // to load a new uri
- gtk_signal_connect(GTK_OBJECT(browser->mozEmbed), "open_uri",
- GTK_SIGNAL_FUNC(open_uri_cb), browser);
- // this signal is emitted when there's a request to change the
- // containing browser window to a certain height, like with width
- // and height args for a window.open in javascript
- gtk_signal_connect(GTK_OBJECT(browser->mozEmbed), "size_to",
- GTK_SIGNAL_FUNC(size_to_cb), browser);
- // key event signals
- gtk_signal_connect(GTK_OBJECT(browser->mozEmbed), "dom_key_down",
- GTK_SIGNAL_FUNC(dom_key_down_cb), browser);
- gtk_signal_connect(GTK_OBJECT(browser->mozEmbed), "dom_key_press",
- GTK_SIGNAL_FUNC(dom_key_press_cb), browser);
- gtk_signal_connect(GTK_OBJECT(browser->mozEmbed), "dom_key_up",
- GTK_SIGNAL_FUNC(dom_key_up_cb), browser);
- gtk_signal_connect(GTK_OBJECT(browser->mozEmbed), "dom_mouse_down",
- GTK_SIGNAL_FUNC(dom_mouse_down_cb), browser);
- gtk_signal_connect(GTK_OBJECT(browser->mozEmbed), "dom_mouse_up",
- GTK_SIGNAL_FUNC(dom_mouse_up_cb), browser);
- gtk_signal_connect(GTK_OBJECT(browser->mozEmbed), "dom_mouse_click",
- GTK_SIGNAL_FUNC(dom_mouse_click_cb), browser);
- gtk_signal_connect(GTK_OBJECT(browser->mozEmbed), "dom_mouse_dbl_click",
- GTK_SIGNAL_FUNC(dom_mouse_dbl_click_cb), browser);
- gtk_signal_connect(GTK_OBJECT(browser->mozEmbed), "dom_mouse_over",
- GTK_SIGNAL_FUNC(dom_mouse_over_cb), browser);
- gtk_signal_connect(GTK_OBJECT(browser->mozEmbed), "dom_mouse_out",
- GTK_SIGNAL_FUNC(dom_mouse_out_cb), browser);
- gtk_signal_connect(GTK_OBJECT(browser->mozEmbed), "dom_activate",
- GTK_SIGNAL_FUNC(dom_activate_cb), browser);
- gtk_signal_connect(GTK_OBJECT(browser->mozEmbed), "dom_focus_in",
- GTK_SIGNAL_FUNC(dom_focus_in_cb), browser);
- gtk_signal_connect(GTK_OBJECT(browser->mozEmbed), "dom_focus_out",
- GTK_SIGNAL_FUNC(dom_focus_out_cb), browser);
- g_signal_connect(browser->mozEmbed, "dom-context-menu",
- GTK_SIGNAL_FUNC(dom_context_menu_cb), browser);
- // hookup to when the window is destroyed
- gtk_signal_connect(GTK_OBJECT(browser->mozEmbed), "destroy",
- GTK_SIGNAL_FUNC(destroy_cb), browser);
-
- // set the chrome type so it's stored in the object
- gecko_embed_set_chrome_mask(GECKO_EMBED(browser->mozEmbed),
- actualChromeMask);
-
- gtk_widget_show_all (browser->topLevelVBox);
-
- return browser;
-}
-
-void
-set_browser_visibility (TestGeckoBrowser *browser, gboolean visibility)
-{
- if (!visibility)
- {
- gtk_widget_hide(browser->topLevelWindow);
- return;
- }
-
- if (browser->menuBarOn)
- gtk_widget_show_all(browser->menuBar);
- else
- gtk_widget_hide_all(browser->menuBar);
-
- // since they are on the same line here...
- if (browser->toolBarOn || browser->locationBarOn)
- gtk_widget_show_all(browser->toolbarHBox);
- else
- gtk_widget_hide_all(browser->toolbarHBox);
-
- if (browser->statusBarOn)
- gtk_widget_show_all(browser->progressAreaHBox);
- else
- gtk_widget_hide_all(browser->progressAreaHBox);
-
- gtk_widget_show(browser->mozEmbed);
- gtk_widget_show(browser->topLevelVBox);
- gtk_widget_show(browser->topLevelWindow);
-}
-
-void
-back_clicked_cb (GtkButton *button, TestGeckoBrowser *browser)
-{
- gecko_embed_go_back(GECKO_EMBED(browser->mozEmbed));
-}
-
-void
-stop_clicked_cb (GtkButton *button, TestGeckoBrowser *browser)
-{
- g_print("stop_clicked_cb\n");
- gecko_embed_stop_load(GECKO_EMBED(browser->mozEmbed));
-}
-
-void
-forward_clicked_cb (GtkButton *button, TestGeckoBrowser *browser)
-{
- g_print("forward_clicked_cb\n");
- gecko_embed_go_forward(GECKO_EMBED(browser->mozEmbed));
-}
-
-void
-reload_clicked_cb (GtkButton *button, TestGeckoBrowser *browser)
-{
- g_print("reload_clicked_cb\n");
- GdkModifierType state = (GdkModifierType)0;
- gint x, y;
- gdk_window_get_pointer(NULL, &x, &y, &state);
-
- gecko_embed_reload(GECKO_EMBED(browser->mozEmbed),
- (state & GDK_SHIFT_MASK) ?
- GECKO_EMBED_FLAG_RELOADBYPASSCACHE :
- GECKO_EMBED_FLAG_RELOADNORMAL);
-}
-
-void
-stream_clicked_cb (GtkButton *button, TestGeckoBrowser *browser)
-{
- const char *data;
- const char *data2;
- data = "<html>Hi";
- data2 = " there</html>\n";
- g_print("stream_clicked_cb\n");
- gecko_embed_open_stream(GECKO_EMBED(browser->mozEmbed),
- "file://", "text/html");
- gecko_embed_append_data(GECKO_EMBED(browser->mozEmbed),
- data, strlen(data));
- gecko_embed_append_data(GECKO_EMBED(browser->mozEmbed),
- data2, strlen(data2));
- gecko_embed_close_stream(GECKO_EMBED(browser->mozEmbed));
-}
-
-void
-url_activate_cb (GtkEditable *widget, TestGeckoBrowser *browser)
-{
- gchar *text = gtk_editable_get_chars(widget, 0, -1);
- g_print("loading url %s\n", text);
- gecko_embed_load_url(GECKO_EMBED(browser->mozEmbed), text);
- g_free(text);
-}
-
-void
-menu_open_new_cb (GtkMenuItem *menuitem, TestGeckoBrowser *browser)
-{
- g_print("opening new browser.\n");
- TestGeckoBrowser *newBrowser =
- new_gecko_browser(GECKO_EMBED_FLAG_DEFAULTCHROME);
- gtk_widget_set_usize(newBrowser->mozEmbed, 400, 400);
- set_browser_visibility(newBrowser, TRUE);
-}
-
-void
-menu_stream_cb (GtkMenuItem *menuitem, TestGeckoBrowser *browser)
-{
- g_print("menu_stream_cb\n");
- const char *data;
- const char *data2;
- data = "<html>Hi";
- data2 = " there</html>\n";
- g_print("stream_clicked_cb\n");
- gecko_embed_open_stream(GECKO_EMBED(browser->mozEmbed),
- "file://", "text/html");
- gecko_embed_append_data(GECKO_EMBED(browser->mozEmbed),
- data, strlen(data));
- gecko_embed_append_data(GECKO_EMBED(browser->mozEmbed),
- data2, strlen(data2));
- gecko_embed_close_stream(GECKO_EMBED(browser->mozEmbed));
-}
-
-void
-menu_close_cb (GtkMenuItem *menuitem, TestGeckoBrowser *browser)
-{
- gtk_widget_destroy(browser->topLevelWindow);
-}
-
-void
-menu_quit_cb (GtkMenuItem *menuitem, TestGeckoBrowser *browser)
-{
- TestGeckoBrowser *tmpBrowser;
- GList *tmp_list = browser_list;
- tmpBrowser = (TestGeckoBrowser *)tmp_list->data;
- while (tmpBrowser) {
- tmp_list = tmp_list->next;
- gtk_widget_destroy(tmpBrowser->topLevelWindow);
- tmpBrowser = (TestGeckoBrowser *)tmp_list->data;
- }
-}
-
-gboolean
-delete_cb(GtkWidget *widget, GdkEventAny *event, TestGeckoBrowser *browser)
-{
- g_print("delete_cb\n");
- gtk_widget_destroy(widget);
- return TRUE;
-}
-
-void
-destroy_cb (GtkWidget *widget, TestGeckoBrowser *browser)
-{
- GList *tmp_list;
- g_print("destroy_cb\n");
- num_browsers--;
- tmp_list = g_list_find(browser_list, browser);
- browser_list = g_list_remove_link(browser_list, tmp_list);
- if (browser->tempMessage)
- g_free(browser->tempMessage);
- if (num_browsers == 0)
- gtk_main_quit();
-}
-
-void
-location_changed_cb (GeckoEmbed *embed, TestGeckoBrowser *browser)
-{
- char *newLocation;
- int newPosition = 0;
- g_print("location_changed_cb\n");
- newLocation = gecko_embed_get_location(embed);
- if (newLocation)
- {
- gtk_editable_delete_text(GTK_EDITABLE(browser->urlEntry), 0, -1);
- gtk_editable_insert_text(GTK_EDITABLE(browser->urlEntry),
- newLocation, strlen(newLocation), &newPosition);
- g_free(newLocation);
- }
- else
- g_print("failed to get location!\n");
- // always make sure to clear the tempMessage. it might have been
- // set from the link before a click and we wouldn't have gotten the
- // callback to unset it.
- update_temp_message(browser, 0);
- // update the nav buttons on a location change
- update_nav_buttons(browser);
-}
-
-void
-title_changed_cb (GeckoEmbed *embed, TestGeckoBrowser *browser)
-{
- char *newTitle;
- g_print("title_changed_cb\n");
- newTitle = gecko_embed_get_title(embed);
- if (newTitle)
- {
- gtk_window_set_title(GTK_WINDOW(browser->topLevelWindow), newTitle);
- g_free(newTitle);
- }
-
-}
-
-void
-load_started_cb (GeckoEmbed *embed, TestGeckoBrowser *browser)
-{
- g_print("load_started_cb\n");
- gtk_widget_set_sensitive(browser->stopButton, TRUE);
- gtk_widget_set_sensitive(browser->reloadButton, FALSE);
- browser->loadPercent = 0;
- browser->bytesLoaded = 0;
- browser->maxBytesLoaded = 0;
- update_status_bar_text(browser);
-}
-
-void
-load_finished_cb (GeckoEmbed *embed, TestGeckoBrowser *browser)
-{
- g_print("load_finished_cb\n");
- gtk_widget_set_sensitive(browser->stopButton, FALSE);
- gtk_widget_set_sensitive(browser->reloadButton, TRUE);
- browser->loadPercent = 0;
- browser->bytesLoaded = 0;
- browser->maxBytesLoaded = 0;
- update_status_bar_text(browser);
- gtk_progress_set_percentage(GTK_PROGRESS(browser->progressBar), 0);
-}
-
-
-void
-net_state_change_cb (GeckoEmbed *embed, gint flags, guint status,
- TestGeckoBrowser *browser)
-{
- g_print("net_state_change_cb %d\n", flags);
- if (flags & GECKO_EMBED_FLAG_IS_REQUEST) {
- if (flags & GECKO_EMBED_FLAG_REDIRECTING)
- browser->statusMessage = "Redirecting to site...";
- else if (flags & GECKO_EMBED_FLAG_TRANSFERRING)
- browser->statusMessage = "Transferring data from site...";
- else if (flags & GECKO_EMBED_FLAG_NEGOTIATING)
- browser->statusMessage = "Waiting for authorization...";
- }
-
- if (status == GECKO_EMBED_STATUS_FAILED_DNS)
- browser->statusMessage = "Site not found.";
- else if (status == GECKO_EMBED_STATUS_FAILED_CONNECT)
- browser->statusMessage = "Failed to connect to site.";
- else if (status == GECKO_EMBED_STATUS_FAILED_TIMEOUT)
- browser->statusMessage = "Failed due to connection timeout.";
- else if (status == GECKO_EMBED_STATUS_FAILED_USERCANCELED)
- browser->statusMessage = "User canceled connecting to site.";
-
- if (flags & GECKO_EMBED_FLAG_IS_DOCUMENT) {
- if (flags & GECKO_EMBED_FLAG_START)
- browser->statusMessage = "Loading site...";
- else if (flags & GECKO_EMBED_FLAG_STOP)
- browser->statusMessage = "Done.";
- }
-
- update_status_bar_text(browser);
-
-}
-
-void net_state_change_all_cb (GeckoEmbed *embed, const char *uri,
- gint flags, guint status,
- TestGeckoBrowser *browser)
-{
- // g_print("net_state_change_all_cb %s %d %d\n", uri, flags, status);
-}
-
-void progress_change_cb (GeckoEmbed *embed, gint cur, gint max,
- TestGeckoBrowser *browser)
-{
- g_print("progress_change_cb cur %d max %d\n", cur, max);
-
- // avoid those pesky divide by zero errors
- if (max < 1)
- {
- gtk_progress_set_activity_mode(GTK_PROGRESS(browser->progressBar), FALSE);
- browser->loadPercent = 0;
- browser->bytesLoaded = cur;
- browser->maxBytesLoaded = 0;
- update_status_bar_text(browser);
- }
- else
- {
- browser->bytesLoaded = cur;
- browser->maxBytesLoaded = max;
- if (cur > max)
- browser->loadPercent = 100;
- else
- browser->loadPercent = (cur * 100) / max;
- update_status_bar_text(browser);
- gtk_progress_set_percentage(GTK_PROGRESS(browser->progressBar), browser->loadPercent / 100.0);
- }
-
-}
-
-void progress_change_all_cb (GeckoEmbed *embed, const char *uri,
- gint cur, gint max,
- TestGeckoBrowser *browser)
-{
- //g_print("progress_change_all_cb %s cur %d max %d\n", uri, cur, max);
-}
-
-void
-link_message_cb (GeckoEmbed *embed, TestGeckoBrowser *browser)
-{
- char *message;
- g_print("link_message_cb\n");
- message = gecko_embed_get_link_message(embed);
- if (!message || !*message)
- update_temp_message(browser, 0);
- else
- update_temp_message(browser, message);
- if (message)
- g_free(message);
-}
-
-void
-js_status_cb (GeckoEmbed *embed, TestGeckoBrowser *browser)
-{
- char *message;
- g_print("js_status_cb\n");
- message = gecko_embed_get_js_status(embed);
- if (!message || !*message)
- update_temp_message(browser, 0);
- else
- update_temp_message(browser, message);
- if (message)
- g_free(message);
-}
-
-void
-new_window_cb (GeckoEmbed *embed, GeckoEmbed **newEmbed, guint chromemask, TestGeckoBrowser *browser)
-{
- g_print("new_window_cb\n");
- g_print("embed is %p chromemask is %d\n", (void *)embed, chromemask);
- TestGeckoBrowser *newBrowser = new_gecko_browser(chromemask);
- gtk_widget_set_usize(newBrowser->mozEmbed, 400, 400);
- *newEmbed = GECKO_EMBED(newBrowser->mozEmbed);
- g_print("new browser is %p\n", (void *)*newEmbed);
-}
-
-void
-visibility_cb (GeckoEmbed *embed, gboolean visibility, TestGeckoBrowser *browser)
-{
- g_print("visibility_cb %d\n", visibility);
- set_browser_visibility(browser, visibility);
-}
-
-void
-destroy_brsr_cb (GeckoEmbed *embed, TestGeckoBrowser *browser)
-{
- g_print("destroy_brsr_cb\n");
- gtk_widget_destroy(browser->topLevelWindow);
-}
-
-gint
-open_uri_cb (GeckoEmbed *embed, const char *uri, TestGeckoBrowser *browser)
-{
- g_print("open_uri_cb %s\n", uri);
-
- // interrupt this test load
- if (!strcmp(uri, "http://people.redhat.com/blizzard/monkeys.txt"))
- return TRUE;
- // don't interrupt anything
- return FALSE;
-}
-
-void
-size_to_cb (GeckoEmbed *embed, gint width, gint height,
- TestGeckoBrowser *browser)
-{
- g_print("*** size_to_cb %d %d\n", width, height);
- gtk_widget_set_usize(browser->mozEmbed, width, height);
-}
-
-gboolean dom_key_down_cb (GeckoEmbed *embed,
- GeckoDOMEvent *gecko_event,
- TestGeckoBrowser *browser)
-{
- nsIDOMEvent *domevent = gecko_dom_event_get_I (gecko_event);
- nsCOMPtr<nsIDOMKeyEvent> event (do_QueryInterface (domevent));
-
- PRUint32 keyCode = 0;
- // g_print("dom_key_down_cb\n");
- event->GetKeyCode(&keyCode);
- // g_print("key code is %d\n", keyCode);
- return NS_OK;
-}
-
-gboolean dom_key_press_cb (GeckoEmbed *embed,
- GeckoDOMEvent *gecko_event,
- TestGeckoBrowser *browser)
-{
- nsIDOMEvent *domevent = gecko_dom_event_get_I (gecko_event);
- nsCOMPtr<nsIDOMKeyEvent> event (do_QueryInterface (domevent));
-
- PRUint32 keyCode = 0;
- // g_print("dom_key_press_cb\n");
- event->GetCharCode(&keyCode);
- // g_print("char code is %d\n", keyCode);
- return NS_OK;
-}
-
-gboolean dom_key_up_cb (GeckoEmbed *embed,
- GeckoDOMEvent *gecko_event,
- TestGeckoBrowser *browser)
-{
- nsIDOMEvent *domevent = gecko_dom_event_get_I (gecko_event);
- nsCOMPtr<nsIDOMKeyEvent> event (do_QueryInterface (domevent));
-
- PRUint32 keyCode = 0;
- // g_print("dom_key_up_cb\n");
- event->GetKeyCode(&keyCode);
- // g_print("key code is %d\n", keyCode);
- return NS_OK;
-}
-
-gboolean dom_mouse_down_cb (GeckoEmbed *embed,
- GeckoDOMEvent *gecko_event,
- TestGeckoBrowser *browser)
-{
- // g_print("dom_mouse_down_cb\n");
- return NS_OK;
- }
-
-gboolean dom_mouse_up_cb (GeckoEmbed *embed,
- GeckoDOMEvent *gecko_event,
- TestGeckoBrowser *browser)
-{
- // g_print("dom_mouse_up_cb\n");
- return NS_OK;
-}
-
-gboolean dom_mouse_click_cb (GeckoEmbed *embed,
- GeckoDOMEvent *gecko_event,
- TestGeckoBrowser *browser)
-{
- nsIDOMEvent *domevent = gecko_dom_event_get_I (gecko_event);
- nsCOMPtr<nsIDOMMouseEvent> event (do_QueryInterface (domevent));
-
- // g_print("dom_mouse_click_cb\n");
- PRUint16 button;
- event->GetButton(&button);
- printf("button was %d\n", button);
- return NS_OK;
-}
-
-gboolean dom_mouse_dbl_click_cb (GeckoEmbed *embed,
- GeckoDOMEvent *gecko_event,
- TestGeckoBrowser *browser)
-{
- // g_print("dom_mouse_dbl_click_cb\n");
- return NS_OK;
-}
-
-gboolean dom_mouse_over_cb (GeckoEmbed *embed,
- GeckoDOMEvent *gecko_event,
- TestGeckoBrowser *browser)
-{
- //g_print("dom_mouse_over_cb\n");
- return NS_OK;
-}
-
-gboolean dom_mouse_out_cb (GeckoEmbed *embed,
- GeckoDOMEvent *gecko_event,
- TestGeckoBrowser *browser)
-{
- //g_print("dom_mouse_out_cb\n");
- return NS_OK;
-}
-
-gboolean dom_activate_cb (GeckoEmbed *embed,
- GeckoDOMEvent *gecko_event,
- TestGeckoBrowser *browser)
-{
- //g_print("dom_activate_cb\n");
- return NS_OK;
-}
-
-gboolean dom_focus_in_cb (GeckoEmbed *embed,
- GeckoDOMEvent *gecko_event,
- TestGeckoBrowser *browser)
-{
- //g_print("dom_focus_in_cb\n");
- return NS_OK;
-}
-
-gboolean dom_focus_out_cb (GeckoEmbed *embed,
- GeckoDOMEvent *gecko_event,
- TestGeckoBrowser *browser)
-{
- //g_print("dom_focus_out_cb\n");
- return NS_OK;
-}
-
-gboolean dom_context_menu_cb (GeckoEmbed *embed,
- GeckoDOMEvent *gecko_event,
- TestGeckoBrowser *browser)
-{
- g_print("dom_context_menu_cb\n");
- return NS_OK;
-}
-
-void new_window_orphan_cb (GeckoEmbedSingle *embed,
- GeckoEmbed **retval, guint chromemask,
- gpointer data)
-{
- g_print("new_window_orphan_cb\n");
- g_print("chromemask is %d\n", chromemask);
- TestGeckoBrowser *newBrowser = new_gecko_browser(chromemask);
- *retval = GECKO_EMBED(newBrowser->mozEmbed);
- g_print("new browser is %p\n", (void *)*retval);
-}
-
-// utility functions
-
-void
-update_status_bar_text(TestGeckoBrowser *browser)
-{
- gchar message[256];
-
- gtk_statusbar_pop(GTK_STATUSBAR(browser->statusBar), 1);
- if (browser->tempMessage)
- gtk_statusbar_push(GTK_STATUSBAR(browser->statusBar), 1, browser->tempMessage);
- else
- {
- if (browser->loadPercent)
- {
- g_snprintf(message, 255, "%s (%d%% complete, %d bytes of %d loaded)", browser->statusMessage, browser->loadPercent, browser->bytesLoaded, browser->maxBytesLoaded);
- }
- else if (browser->bytesLoaded)
- {
- g_snprintf(message, 255, "%s (%d bytes loaded)", browser->statusMessage, browser->bytesLoaded);
- }
- else if (browser->statusMessage == NULL)
- {
- g_snprintf(message, 255, " ");
- }
- else
- {
- g_snprintf(message, 255, "%s", browser->statusMessage);
- }
- gtk_statusbar_push(GTK_STATUSBAR(browser->statusBar), 1, message);
- }
-}
-
-void
-update_temp_message(TestGeckoBrowser *browser, const char *message)
-{
- if (browser->tempMessage)
- g_free(browser->tempMessage);
- if (message)
- browser->tempMessage = g_strdup(message);
- else
- browser->tempMessage = 0;
- // now that we've updated the temp message, redraw the status bar
- update_status_bar_text(browser);
-}
-
-
-void
-update_nav_buttons (TestGeckoBrowser *browser)
-{
- gboolean can_go_back;
- gboolean can_go_forward;
- can_go_back = gecko_embed_can_go_back(GECKO_EMBED(browser->mozEmbed));
- can_go_forward = gecko_embed_can_go_forward(GECKO_EMBED(browser->mozEmbed));
- if (can_go_back)
- gtk_widget_set_sensitive(browser->backButton, TRUE);
- else
- gtk_widget_set_sensitive(browser->backButton, FALSE);
- if (can_go_forward)
- gtk_widget_set_sensitive(browser->forwardButton, TRUE);
- else
- gtk_widget_set_sensitive(browser->forwardButton, FALSE);
- }
diff --git a/embed/xulrunner/utils/AutoJSContextStack.cpp b/embed/xulrunner/utils/AutoJSContextStack.cpp
deleted file mode 100644
index 9c918fc3b..000000000
--- a/embed/xulrunner/utils/AutoJSContextStack.cpp
+++ /dev/null
@@ -1,48 +0,0 @@
-/*
- * Copyright © 2006 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser 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.
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include "AutoJSContextStack.h"
-
-#include <nsIServiceManager.h>
-#include <nsServiceManagerUtils.h>
-
-AutoJSContextStack::~AutoJSContextStack()
-{
- if (mStack) {
- JSContext* cx;
- mStack->Pop (&cx);
-
- NS_ASSERTION(cx == nsnull, "We pushed a null context but popped a non-null context!?");
- }
-}
-
-nsresult
-AutoJSContextStack::Init()
-{
- nsresult rv;
- mStack = do_GetService ("@mozilla.org/js/xpc/ContextStack;1", &rv);
- if (NS_FAILED (rv))
- return rv;
-
- return mStack->Push (nsnull);
-}
diff --git a/embed/xulrunner/utils/AutoJSContextStack.h b/embed/xulrunner/utils/AutoJSContextStack.h
deleted file mode 100644
index 5294e7d4e..000000000
--- a/embed/xulrunner/utils/AutoJSContextStack.h
+++ /dev/null
@@ -1,41 +0,0 @@
-/*
- * Copyright © 2006 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser 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.
- *
- * $Id$
- */
-
-#ifndef AUTO_JSCONTEXTSTACK_H
-#define AUTO_JSCONTEXTSTACK_H
-
-struct JSContext;
-
-#include <nsCOMPtr.h>
-#include <nsIJSContextStack.h>
-
-class AutoJSContextStack
-{
- public:
- AutoJSContextStack () { }
- ~AutoJSContextStack ();
-
- nsresult Init ();
-
- private:
- nsCOMPtr<nsIJSContextStack> mStack;
-};
-
-#endif
diff --git a/embed/xulrunner/utils/AutoWindowModalState.cpp b/embed/xulrunner/utils/AutoWindowModalState.cpp
deleted file mode 100644
index 79fb2c15a..000000000
--- a/embed/xulrunner/utils/AutoWindowModalState.cpp
+++ /dev/null
@@ -1,43 +0,0 @@
-/*
- * Copyright © 2006 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include "AutoWindowModalState.h"
-
-AutoWindowModalState::AutoWindowModalState (nsIDOMWindow *aWindow)
-{
- if (aWindow) {
- mWindow = do_QueryInterface (aWindow);
- NS_ASSERTION (mWindow, "Should have a window here!");
- }
-
- if (mWindow) {
- mWindow->EnterModalState ();
- }
-}
-
-AutoWindowModalState::~AutoWindowModalState()
-{
- if (mWindow) {
- mWindow->LeaveModalState ();
- }
-}
diff --git a/embed/xulrunner/utils/AutoWindowModalState.h b/embed/xulrunner/utils/AutoWindowModalState.h
deleted file mode 100644
index 557865799..000000000
--- a/embed/xulrunner/utils/AutoWindowModalState.h
+++ /dev/null
@@ -1,38 +0,0 @@
-/*
- * Copyright © 2006 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#ifndef AUTO_WINDOWMODALSTATE_H
-#define AUTO_WINDOWMODALSTATE_H
-
-#include <nsCOMPtr.h>
-#include <nsPIDOMWindow.h>
-
-class AutoWindowModalState
-{
- public:
- AutoWindowModalState (nsIDOMWindow *);
- ~AutoWindowModalState ();
-
- private:
-
- nsCOMPtr<nsPIDOMWindow> mWindow;
-};
-
-#endif
diff --git a/embed/xulrunner/utils/EphyBadCertRejector.cpp b/embed/xulrunner/utils/EphyBadCertRejector.cpp
deleted file mode 100644
index 5aad7d92f..000000000
--- a/embed/xulrunner/utils/EphyBadCertRejector.cpp
+++ /dev/null
@@ -1,68 +0,0 @@
-/*
- * Copyright © 2005 Christian Persch
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include "EphyBadCertRejector.h"
-
-NS_IMPL_THREADSAFE_ISUPPORTS1 (EphyBadCertRejector, nsIBadCertListener)
-
-/* boolean confirmUnknownIssuer (in nsIInterfaceRequestor socketInfo, in nsIX509Cert cert, out short certAddType); */
-NS_IMETHODIMP
-EphyBadCertRejector::ConfirmUnknownIssuer(nsIInterfaceRequestor *socketInfo,
- nsIX509Cert *cert,
- PRInt16 *certAddType,
- PRBool *_retval)
-{
- *certAddType = nsIBadCertListener::UNINIT_ADD_FLAG;
- *_retval = PR_FALSE;
- return NS_OK;
-}
-
-/* boolean confirmMismatchDomain (in nsIInterfaceRequestor socketInfo, in AUTF8String targetURL, in nsIX509Cert cert); */
-NS_IMETHODIMP
-EphyBadCertRejector::ConfirmMismatchDomain(nsIInterfaceRequestor *socketInfo,
- const nsACString & targetURL,
- nsIX509Cert *cert,
- PRBool *_retval)
-{
- *_retval = PR_FALSE;
- return NS_OK;
-}
-
-/* boolean confirmCertExpired (in nsIInterfaceRequestor socketInfo, in nsIX509Cert cert); */
-NS_IMETHODIMP
-EphyBadCertRejector::ConfirmCertExpired(nsIInterfaceRequestor *socketInfo,
- nsIX509Cert *cert,
- PRBool *_retval)
-{
- *_retval = PR_FALSE;
- return NS_OK;
-}
-
-/* void notifyCrlNextupdate (in nsIInterfaceRequestor socketInfo, in AUTF8String targetURL, in nsIX509Cert cert); */
-NS_IMETHODIMP
-EphyBadCertRejector::NotifyCrlNextupdate(nsIInterfaceRequestor *socketInfo,
- const nsACString & targetURL,
- nsIX509Cert *cert)
-{
- return NS_OK;
-}
diff --git a/embed/xulrunner/utils/EphyBadCertRejector.h b/embed/xulrunner/utils/EphyBadCertRejector.h
deleted file mode 100644
index dcab75c6c..000000000
--- a/embed/xulrunner/utils/EphyBadCertRejector.h
+++ /dev/null
@@ -1,36 +0,0 @@
-/*
- * Copyright © 2005 Christian Persch
- *
- * 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, 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 Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#ifndef EPHY_BAD_CERT_REJECTOR_H
-#define EPHY_BAD_CERT_REJECTOR_H
-
-#include <nsIBadCertListener.h>
-
-class EphyBadCertRejector : public nsIBadCertListener
-{
- public:
- NS_DECL_ISUPPORTS
- NS_DECL_NSIBADCERTLISTENER
-
- EphyBadCertRejector () { }
- ~EphyBadCertRejector () { }
-};
-
-#endif
diff --git a/embed/xulrunner/utils/EphyUtils.cpp b/embed/xulrunner/utils/EphyUtils.cpp
deleted file mode 100644
index a433294c8..000000000
--- a/embed/xulrunner/utils/EphyUtils.cpp
+++ /dev/null
@@ -1,203 +0,0 @@
-/*
- * Copyright © 2004 Marco Pesenti Gritti
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include <nsStringGlue.h>
-
-#include <nsCOMPtr.h>
-#include <nsDOMJSUtils.h> /* for GetScriptContextFromJSContext */
-#include <nsIDOMWindow.h>
-#include <nsIEmbeddingSiteWindow.h>
-#include <nsIFile.h>
-#include <nsIIOService.h>
-#include <nsIScriptContext.h>
-#include <nsIScriptGlobalObject.h>
-#include <nsIServiceManager.h>
-#include <nsIURI.h>
-#include <nsIWebBrowserChrome.h>
-#include <nsIWindowWatcher.h>
-#include <nsIXPConnect.h>
-#include <nsPIDOMWindow.h>
-#include <nsServiceManagerUtils.h>
-#include <nsXPCOM.h>
-
-#include "EphyUtils.h"
-
-nsresult
-EphyUtils::GetIOService (nsIIOService **ioService)
-{
- nsresult rv;
-
- nsCOMPtr<nsIServiceManager> mgr;
- NS_GetServiceManager (getter_AddRefs (mgr));
- if (!mgr) return NS_ERROR_FAILURE;
-
- rv = mgr->GetServiceByContractID ("@mozilla.org/network/io-service;1",
- NS_GET_IID (nsIIOService),
- (void **)ioService);
- return rv;
-}
-
-nsresult
-EphyUtils::NewURI (nsIURI **result,
- const nsAString &spec,
- const char *charset,
- nsIURI *baseURI)
-{
- nsCString cSpec;
- NS_UTF16ToCString (spec, NS_CSTRING_ENCODING_UTF8, cSpec);
-
- return NewURI (result, cSpec, charset, baseURI);
-}
-
-nsresult
-EphyUtils::NewURI (nsIURI **result,
- const nsACString &spec,
- const char *charset,
- nsIURI *baseURI)
-{
- nsresult rv;
- nsCOMPtr<nsIIOService> ioService;
- rv = EphyUtils::GetIOService (getter_AddRefs (ioService));
- NS_ENSURE_SUCCESS (rv, rv);
-
- return ioService->NewURI (spec, charset, baseURI, result);
-}
-
-nsresult
-EphyUtils::NewFileURI (nsIURI **result,
- nsIFile *spec)
-{
- nsresult rv;
- nsCOMPtr<nsIIOService> ioService;
- rv = EphyUtils::GetIOService (getter_AddRefs (ioService));
- NS_ENSURE_SUCCESS (rv, rv);
-
- return ioService->NewFileURI (spec, result);
-}
-
-GtkWidget *
-EphyUtils::FindEmbed (nsIDOMWindow *aDOMWindow)
-{
- if (!aDOMWindow) return nsnull;
-
- nsCOMPtr<nsIWindowWatcher> wwatch
- (do_GetService("@mozilla.org/embedcomp/window-watcher;1"));
- NS_ENSURE_TRUE (wwatch, nsnull);
-
- /* this DOM window may belong to some inner frame, we need
- * to get the topmost DOM window to get the embed
- */
- nsCOMPtr<nsIDOMWindow> topWindow;
- aDOMWindow->GetTop (getter_AddRefs (topWindow));
- if (!topWindow) return nsnull;
-
- nsCOMPtr<nsIWebBrowserChrome> windowChrome;
- wwatch->GetChromeForWindow (topWindow, getter_AddRefs(windowChrome));
- NS_ENSURE_TRUE (windowChrome, nsnull);
-
- nsCOMPtr<nsIEmbeddingSiteWindow> window (do_QueryInterface(windowChrome));
- NS_ENSURE_TRUE (window, nsnull);
-
- nsresult rv;
- GtkWidget *mozembed;
- rv = window->GetSiteWindow ((void **)&mozembed);
- NS_ENSURE_SUCCESS (rv, nsnull);
-
- return mozembed;
-}
-
-GtkWidget *
-EphyUtils::FindGtkParent (nsIDOMWindow *aDOMWindow)
-{
- GtkWidget *embed = FindEmbed (aDOMWindow);
- if (!embed) return nsnull;
-
- GtkWidget *toplevel = gtk_widget_get_toplevel (GTK_WIDGET (embed));
- if (!GTK_WIDGET_TOPLEVEL (toplevel)) return nsnull;
-
- return toplevel;
-}
-
-char *
-EphyUtils::ConvertUTF16toUTF8 (const PRUnichar *aText,
- PRInt32 aMaxLength)
-{
- if (aText == nsnull) return NULL;
-
- /* This depends on the assumption that
- * typeof(PRUnichar) == typeof (gunichar2) == uint16,
- * which should be pretty safe.
- */
- glong n_read = 0, n_written = 0;
- char *converted = g_utf16_to_utf8 ((gunichar2*) aText, aMaxLength,
- &n_read, &n_written, NULL);
- /* FIXME loop from the end while !g_unichar_isspace (char)? */
-
- return converted;
-}
-
-/* This isn't completely accurate: if you do window.prompt in one window, then
- * call this in another window, it still returns TRUE ! Those are the wonders
- * of recursive mainloops :-(
- */
-PRBool
-EphyJSUtils::IsCalledFromScript ()
-{
- nsresult rv;
- nsCOMPtr<nsIXPConnect> xpc(do_GetService(nsIXPConnect::GetCID(), &rv));
- NS_ENSURE_SUCCESS (rv, PR_FALSE);
-
- nsCOMPtr<nsIXPCNativeCallContext> ncc;
- rv = xpc->GetCurrentNativeCallContext (getter_AddRefs (ncc));
- NS_ENSURE_SUCCESS(rv, PR_FALSE);
-
- return nsnull != ncc;
-}
-
-/* NOTE: Only call this when we're SURE that we're called directly from JS! */
-nsIDOMWindow *
-EphyJSUtils::GetDOMWindowFromCallContext ()
-{
- nsresult rv;
- nsCOMPtr<nsIXPConnect> xpc (do_GetService(nsIXPConnect::GetCID(), &rv));
- NS_ENSURE_SUCCESS (rv, nsnull);
-
- nsCOMPtr<nsIXPCNativeCallContext> ncc;
- rv = xpc->GetCurrentNativeCallContext (getter_AddRefs (ncc));
- NS_ENSURE_SUCCESS (rv, nsnull);
-
- JSContext *cx = nsnull;
- rv = ncc->GetJSContext(&cx);
- NS_ENSURE_TRUE (NS_SUCCEEDED (rv) && cx, nsnull);
-
- nsIScriptContext* scriptContext = GetScriptContextFromJSContext (cx);
- if (!scriptContext) return nsnull;
-
- nsIScriptGlobalObject *globalObject = scriptContext->GetGlobalObject();
- if (!globalObject) return nsnull;
-
- nsCOMPtr<nsPIDOMWindow> piWindow (do_QueryInterface (globalObject));
- if (!piWindow) return nsnull;
-
- return piWindow->GetOuterWindow ();
-}
diff --git a/embed/xulrunner/utils/EphyUtils.h b/embed/xulrunner/utils/EphyUtils.h
deleted file mode 100644
index 65b1edb04..000000000
--- a/embed/xulrunner/utils/EphyUtils.h
+++ /dev/null
@@ -1,66 +0,0 @@
-/*
- * Copyright © 2004 Marco Pesenti Gritti
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#ifndef EPHY_UTILS_H
-#define EPHY_UTILS_H
-
-#include <nscore.h>
-
-#include <gtk/gtkwidget.h>
-
-class nsACString;
-class nsAString;
-class nsIDOMWindow;
-class nsIFile;
-class nsIIOService;
-class nsIURI;
-
-namespace EphyUtils
-{
- nsresult GetIOService (nsIIOService **ioService);
-
- nsresult NewURI (nsIURI **result,
- const nsAString &spec,
- const char *charset = nsnull,
- nsIURI *baseURI = nsnull);
-
- nsresult NewURI (nsIURI **result,
- const nsACString &spec,
- const char *charset = nsnull,
- nsIURI *baseURI = nsnull);
-
- nsresult NewFileURI (nsIURI **result,
- nsIFile *spec);
-
- GtkWidget *FindEmbed (nsIDOMWindow *aDOMWindow);
-
- GtkWidget *FindGtkParent (nsIDOMWindow *aDOMWindow);
-
- char * ConvertUTF16toUTF8 (const PRUnichar*, PRInt32);
-}
-
-namespace EphyJSUtils
-{
- PRBool IsCalledFromScript ();
-
- /* not addref'd! */ nsIDOMWindow* GetDOMWindowFromCallContext ();
-}
-
-#endif
diff --git a/embed/xulrunner/utils/GeckoUtils.cpp b/embed/xulrunner/utils/GeckoUtils.cpp
deleted file mode 100644
index c71fce4ba..000000000
--- a/embed/xulrunner/utils/GeckoUtils.cpp
+++ /dev/null
@@ -1,87 +0,0 @@
-/*
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser 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.
- *
- * The Original Code is mozilla.org code.
- *
- * The Initial Developer of the Original Code is
- * Netscape Communications Corporation.
- * Portions created by the Initial Developer are Copyright © 2003
- * the Initial Developer. All Rights Reserved.
- *
- * Contributor(s):
- * Brian Ryner <bryner@brianryner.com>
- *
- * $Id$
- */
-
-#include <xpcom-config.h>
-#include "config.h"
-
-#include "GeckoUtils.h"
-
-#include "gecko-embed.h"
-
-#include <nsCOMPtr.h>
-#include <nsIDOMWindow.h>
-#include <nsIWindowWatcher.h>
-#include <nsIWebBrowserChrome.h>
-#include <nsIEmbeddingSiteWindow.h>
-#include <nsIServiceManager.h>
-#include <nsServiceManagerUtils.h>
-
-GtkWidget *
-GeckoUtils::GetGeckoEmbedForDOMWindow (nsIDOMWindow * aDOMWindow)
-{
- if (!aDOMWindow)
- return NULL;
-
- /* Get the toplevel DOM window, in case this window is a frame */
- nsCOMPtr<nsIDOMWindow> domWin;
- aDOMWindow->GetTop (getter_AddRefs (domWin));
- if (!domWin)
- return NULL;
-
- nsCOMPtr< nsIWindowWatcher> wwatch
- (do_GetService ("@mozilla.org/embedcomp/window-watcher;1"));
- NS_ENSURE_TRUE (wwatch, NULL);
-
- nsCOMPtr<nsIWebBrowserChrome> chrome;
- wwatch->GetChromeForWindow (domWin, getter_AddRefs (chrome));
-
- nsCOMPtr <nsIEmbeddingSiteWindow> siteWindow (do_QueryInterface (chrome));
- if (!siteWindow)
- return NULL;
-
- GtkWidget *widget;
- siteWindow->GetSiteWindow ((void **) &widget);
- if (!widget || !GECKO_IS_EMBED (widget))
- return NULL;
-
- return widget;
-}
-
-GtkWidget *
-GeckoUtils::GetGtkWindowForDOMWindow (nsIDOMWindow * aDOMWindow)
-{
- GtkWidget *embed = GeckoUtils::GetGeckoEmbedForDOMWindow (aDOMWindow);
- if (!embed)
- return NULL;
-
- GtkWidget *gtkWin = gtk_widget_get_toplevel (embed);
- if (!GTK_WIDGET_TOPLEVEL (gtkWin))
- return NULL;
-
- return gtkWin;
-}
diff --git a/embed/xulrunner/utils/GeckoUtils.h b/embed/xulrunner/utils/GeckoUtils.h
deleted file mode 100644
index 05012e6b2..000000000
--- a/embed/xulrunner/utils/GeckoUtils.h
+++ /dev/null
@@ -1,34 +0,0 @@
-/*
- * Copyright © 2006 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser 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.
- *
- * $Id$
- */
-
-#ifndef GECKO_UTILS_H
-#define GECKO_UTILS_H
-
-#include <gtk/gtkwidget.h>
-
-class nsIDOMWindow;
-
-namespace GeckoUtils
-{
- GtkWidget* GetGeckoEmbedForDOMWindow (nsIDOMWindow*);
- GtkWidget* GetGtkWindowForDOMWindow (nsIDOMWindow*);
-}
-
-#endif
diff --git a/embed/xulrunner/utils/Makefile.am b/embed/xulrunner/utils/Makefile.am
deleted file mode 100644
index a66ecf054..000000000
--- a/embed/xulrunner/utils/Makefile.am
+++ /dev/null
@@ -1,43 +0,0 @@
-NULL =
-
-noinst_LTLIBRARIES = libephyxulrunnerutils.la
-
-libephyxulrunnerutils_la_SOURCES = \
- AutoJSContextStack.cpp \
- AutoJSContextStack.h \
- AutoWindowModalState.cpp \
- AutoWindowModalState.h \
- EphyBadCertRejector.cpp \
- EphyBadCertRejector.h \
- EphyUtils.cpp \
- EphyUtils.h \
- GeckoUtils.cpp \
- GeckoUtils.h \
- ggeAutoModalDialog.cpp \
- ggeAutoModalDialog.h \
- ggeAutoSurvivalArea.cpp \
- ggeAutoSurvivalArea.h \
- $(NULL)
-
-libephyxulrunnerutils_la_CPPFLAGS = \
- -I$(top_srcdir)/embed/xulrunner/src \
- $(LIBXUL_CXXCPPFLAGS) \
- $(LIBXUL_INCLUDES) \
- $(AM_CPPFLAGS)
-
-libephyxulrunnerutils_la_CXXFLAGS = \
- $(LIBXUL_CXXFLAGS) \
- $(GTK_CFLAGS) \
- $(AM_CXXFLAGS)
-
-libephyxulrunnerutils_la_LDFLAGS = \
- $(AM_LDFLAGS)
-
-libephyxulrunnerutils_la_LIBADD = \
- $(LIBXUL_LIBS)
-
-CLEANFILES =
- $(NULL)
-
-EXTRA_DIST = \
- $(NULL)
diff --git a/embed/xulrunner/utils/ggeAutoModalDialog.cpp b/embed/xulrunner/utils/ggeAutoModalDialog.cpp
deleted file mode 100644
index 761e871d9..000000000
--- a/embed/xulrunner/utils/ggeAutoModalDialog.cpp
+++ /dev/null
@@ -1,189 +0,0 @@
-/*
- * Copyright © 2006 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * Some code taken from mozilla/embedding/components/windowwatcher/src/nsPromptService.cpp
- * which was under MPL/LGPL/GPL tri-licence and is here being used under the licence above.
- * Original notice:
- *
- * The Original Code is mozilla.org code.
- *
- * The Initial Developer of the Original Code is
- * Netscape Communications Corporation.
- * Portions created by the Initial Developer are Copyright (C) 2001
- * the Initial Developer. All Rights Reserved.
- */
-
-#include <xpcom-config.h>
-#include <config.h>
-
-struct JSContext; /* Just so we don't need to include a bunch of JS headers */
-
-#include <nsIDOMDocumentEvent.h>
-#include <nsIDOMDocument.h>
-#include <nsIDOMEvent.h>
-#include <nsIDOMEventTarget.h>
-#include <nsIJSContextStack.h>
-#include <nsIPrivateDOMEvent.h>
-#include <nsPIDOMWindow.h>
-#include <nsServiceManagerUtils.h>
-#include <nsThreadUtils.h>
-
-#include <gtk/gtkdialog.h>
-
-#include "ggeAutoModalDialog.h"
-
-ggeAutoModalDialog::ggeAutoModalDialog (nsIDOMWindow *aWindow,
- PRBool aNotifyDOM)
- : mWindow (aWindow),
- mPWindow (do_QueryInterface (aWindow)),
- mStack (do_GetService ("@mozilla.org/js/xpc/ContextStack;1")),
- mDefaultEnabled (DispatchEvent ("DOMWillOpenModalDialog", aNotifyDOM)),
- mContextPushed (PR_FALSE),
- mModalStateSet (PR_FALSE)
-{
- /* First we check whether we should show the dialogue at all */
- if (aNotifyDOM) {
- if (!mDefaultEnabled) {
- return;
- }
- }
-
- if (mStack) {
- mContextPushed = NS_SUCCEEDED (mStack->Push (nsnull));
- }
-
- if (mWindow) {
- NS_ASSERTION (mPWindow, "Should have a window here!");
-
- mPWindow->EnterModalState ();
- mModalStateSet = PR_TRUE;
- }
-}
-
-ggeAutoModalDialog::~ggeAutoModalDialog ()
-{
- if (mModalStateSet) {
- NS_ASSERTION (mPWindow, "Should have a window here!");
- mPWindow->LeaveModalState ();
- }
-
- if (mContextPushed) {
- NS_ASSERTION (mStack, "Should have a stack!");
-
- JSContext* cx;
- mStack->Pop (&cx);
-
- NS_ASSERTION(cx == nsnull, "We pushed a null context but popped a non-null context!?");
- }
-
-}
-
-/* static */ void PR_CALLBACK
-ggeAutoModalDialog::ResponseCallback (GtkWidget *aDialog,
- int aResponse,
- void *aData)
-{
- ggeAutoModalDialog *obj = reinterpret_cast<ggeAutoModalDialog*>(aData);
-
- gtk_widget_hide (aDialog);
- obj->mResponse = aResponse;
- obj->mContinueModalLoop = PR_FALSE;
-}
-
-/* static */ gboolean PR_CALLBACK
-ggeAutoModalDialog::DeleteCallback (GtkWidget *aDialog,
- void *aEvent,
- void *aData)
-{
- gtk_dialog_response (GTK_DIALOG (aDialog), GTK_RESPONSE_DELETE_EVENT);
- return TRUE;
-}
-
-void
-ggeAutoModalDialog::Run (GtkWidget *aDialog)
-{
- NS_ASSERTION (ShouldShow(), "Calling ::Run on a prevented dialogue!");
-
- /* Do NOT use gtk_dialog_run here, since it blocks the network thread!
- * See https://bugzilla.mozilla.org/show_bug.cgi?id=338225
- */
-
- // Reset popup state while opening a modal dialog, and firing
- // events about the dialog, to prevent the current state from
- // being active the whole time a modal dialog is open.
- nsAutoPopupStatePusher popupStatePusher (mPWindow, openAbused);
-
- mDialog = aDialog;
- g_object_ref_sink (mDialog);
- mResponse = GTK_RESPONSE_DELETE_EVENT;
-
- gulong responseHandler = g_signal_connect (mDialog, "response",
- G_CALLBACK (ResponseCallback),
- reinterpret_cast<void*>(this));
- gulong deleteHandler = g_signal_connect (mDialog, "delete-event",
- G_CALLBACK (DeleteCallback),
- reinterpret_cast<void*>(this));
-
- nsCOMPtr<nsIThread> thread (do_GetCurrentThread ());
- NS_ASSERTION (thread, "No UI thread?");
-
- mContinueModalLoop = PR_TRUE;
- while (mContinueModalLoop) {
- if (!NS_ProcessNextEvent (thread))
- break;
- }
-
- g_signal_handler_disconnect (mDialog, responseHandler);
- g_signal_handler_disconnect (mDialog, deleteHandler);
- /* FIXME */
- g_object_unref (mDialog);
- mDialog = NULL;
-}
-
-PRBool
-ggeAutoModalDialog::DispatchEvent (const char *aEventName,
- PRBool aDoNotify)
-{
- if (!mWindow || !aDoNotify) {
- return PR_TRUE;
- }
-
- nsCOMPtr<nsIDOMDocument> domdoc;
- mWindow->GetDocument (getter_AddRefs (domdoc));
-
- nsCOMPtr<nsIDOMDocumentEvent> docevent (do_QueryInterface (domdoc));
- nsCOMPtr<nsIDOMEvent> event;
-
- PRBool defaultActionEnabled = PR_TRUE;
-
- if (docevent) {
- docevent->CreateEvent (NS_LITERAL_STRING ("Events"), getter_AddRefs (event));
-
- nsCOMPtr<nsIPrivateDOMEvent> privateEvent (do_QueryInterface (event));
- if (privateEvent) {
- event->InitEvent (NS_ConvertASCIItoUTF16 (aEventName), PR_TRUE, PR_TRUE);
-
- privateEvent->SetTrusted(PR_TRUE);
-
- nsCOMPtr<nsIDOMEventTarget> target (do_QueryInterface (mWindow));
-
- target->DispatchEvent (event, &defaultActionEnabled);
- }
- }
-
- return defaultActionEnabled;
-}
diff --git a/embed/xulrunner/utils/ggeAutoModalDialog.h b/embed/xulrunner/utils/ggeAutoModalDialog.h
deleted file mode 100644
index 07299b609..000000000
--- a/embed/xulrunner/utils/ggeAutoModalDialog.h
+++ /dev/null
@@ -1,70 +0,0 @@
-/*
- * Copyright © 2006 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * $Id$
- */
-
-#ifndef GGE_AUTOMODALDIALOG_H
-#define GGE_AUTOMODALDIALOG_H
-
-#include <nsCOMPtr.h>
-
-#include <gtk/gtkwidget.h>
-
-class nsPIDOMWindow;
-class nsIJSContextStack;
-
-/**
- * ggeAutoModalDialog:
- * A stack-based helper class for modal GTK+ dialogues.
- *
- * You MUST check ::ShouldShow() before showing the dialogue!
- */
-class ggeAutoModalDialog
-{
- public:
- ggeAutoModalDialog (nsIDOMWindow *,
- PRBool aNotifyDOM = PR_TRUE);
- ~ggeAutoModalDialog ();
-
- PRBool ShouldShow () { return mDefaultEnabled && mContextPushed; }
-
- void Run (GtkWidget *aDialog);
- int Response () { return mResponse; }
-
- private:
- // stack only please
- void *operator new (size_t) CPP_THROW_NEW;
-
- PRBool DispatchEvent (const char*, PRBool);
-
- static void PR_CALLBACK ResponseCallback (GtkWidget*, int, void*);
- static gboolean PR_CALLBACK DeleteCallback (GtkWidget*, void*, void*);
-
- nsCOMPtr<nsIDOMWindow> mWindow;
- nsCOMPtr<nsPIDOMWindow> mPWindow;
- nsCOMPtr<nsIJSContextStack> mStack;
-
- GtkWidget *mDialog;
- int mResponse;
- PRPackedBool mDefaultEnabled;
- PRPackedBool mContextPushed;
- PRPackedBool mModalStateSet;
- PRPackedBool mContinueModalLoop;
-};
-
-#endif
diff --git a/embed/xulrunner/utils/ggeAutoSurvivalArea.cpp b/embed/xulrunner/utils/ggeAutoSurvivalArea.cpp
deleted file mode 100644
index 0344edabe..000000000
--- a/embed/xulrunner/utils/ggeAutoSurvivalArea.cpp
+++ /dev/null
@@ -1,42 +0,0 @@
-/*
- * Copyright © 2007 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser 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 <xpcom-config.h>
-#include <config.h>
-
-#include <nsIAppStartup.h>
-#include <nsIServiceManager.h>
-#include <nsServiceManagerUtils.h>
-#include <nsXPFEComponentsCID.h>
-
-#include "ggeAutoSurvivalArea.h"
-
-ggeAutoSurvivalArea::ggeAutoSurvivalArea()
- : mAppStartup (do_GetService (NS_APPSTARTUP_CONTRACTID))
-{
- if (mAppStartup) {
- mAppStartup->EnterLastWindowClosingSurvivalArea ();
- }
-}
-
-ggeAutoSurvivalArea::~ggeAutoSurvivalArea()
-{
- if (mAppStartup) {
- mAppStartup->ExitLastWindowClosingSurvivalArea ();
- }
-}
diff --git a/embed/xulrunner/utils/ggeAutoSurvivalArea.h b/embed/xulrunner/utils/ggeAutoSurvivalArea.h
deleted file mode 100644
index 10b9a07e5..000000000
--- a/embed/xulrunner/utils/ggeAutoSurvivalArea.h
+++ /dev/null
@@ -1,44 +0,0 @@
-/*
- * Copyright © 2007 Christian Persch
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1, 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser 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 GGE_AUTOSURVIVALAREA_H
-#define GGE_AUTOSURVIVALAREA_H
-
-#include <nsCOMPtr.h>
-
-class nsIAppStartup;
-
-/**
- * ggeAutoSurvivalArea:
- *
- * A helper class that has to be used whenever a window being open
- * should prevent the application from shutting down. (Only needed for
- * non-DOM windows.)
- * Use on the stack or on the heap.
- */
-
-class ggeAutoSurvivalArea {
- public:
- ggeAutoSurvivalArea ();
- ~ggeAutoSurvivalArea ();
-
- private:
- nsCOMPtr<nsIAppStartup> mAppStartup;
-};
-
-#endif /* !GGE_AUTOSURVIVALAREA_H */