summaryrefslogtreecommitdiff
path: root/desktop/browser.c
diff options
context:
space:
mode:
authorJohn Mark Bell <jmb@netsurf-browser.org>2004-04-02 00:41:10 +0000
committerJohn Mark Bell <jmb@netsurf-browser.org>2004-04-02 00:41:10 +0000
commit9454b8bca10f2ac8e224b9d60d71355b36194555 (patch)
tree746b528194b91da4180252db1f929e8b9abf2caa /desktop/browser.c
parentadc05e5240fc9062c6b3ecb92f1bb1f59f0951c3 (diff)
downloadnetsurf-9454b8bca10f2ac8e224b9d60d71355b36194555.tar.gz
netsurf-9454b8bca10f2ac8e224b9d60d71355b36194555.tar.bz2
[project @ 2004-04-02 00:41:10 by jmb]
Try to use external apps for URI schemes we don't understand (eg mailto:) svn path=/import/netsurf/; revision=698
Diffstat (limited to 'desktop/browser.c')
-rw-r--r--desktop/browser.c14
1 files changed, 12 insertions, 2 deletions
diff --git a/desktop/browser.c b/desktop/browser.c
index 8735a7ca2..149f5a2e2 100644
--- a/desktop/browser.c
+++ b/desktop/browser.c
@@ -162,16 +162,26 @@ void browser_window_go_post(struct browser_window *bw, const char *url,
browser_window_set_status(bw, messages_get("Loading"));
bw->history_add = history_add;
bw->time0 = clock();
- if (strncmp(url2, "about:", 6) == 0)
+ if (strncmp(url2, "about:", 6) == 0) {
c = about_create(url2, browser_window_callback, bw, 0,
gui_window_get_width(bw->window), 0);
- else
+ }
+ /* check that we can handle the URL - just http/https/file for now */
+ else if (strncmp(url2, "http:", 5) != 0 && strncmp(url2, "https:", 6) != 0 &&
+ strncmp(url2, "file:", 5) != 0) {
+ gui_launch_url(url2);
+ browser_window_set_status(bw, messages_get("LaunchURL"));
+ free(url2);
+ return;
+ }
+ else {
c = fetchcache(url2, 0,
browser_window_callback, bw, 0,
gui_window_get_width(bw->window), 0,
false,
post_urlenc, post_multipart,
true);
+ }
free(url2);
if (!c) {
browser_window_set_status(bw, messages_get("FetchFailed"));