[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
This commit is contained in:
John Mark Bell 2004-04-02 00:41:10 +00:00
parent adc05e5240
commit 9454b8bca1
7 changed files with 135 additions and 5 deletions

View File

@ -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"));

View File

@ -55,6 +55,8 @@ void gui_gadget_combo(struct browser_window* bw, struct form_control* g, unsigne
void gui_window_place_caret(gui_window *g, int x, int y, int height);
void gui_launch_url(char *url);
void warn_user(const char *warning);
#endif

View File

@ -61,7 +61,7 @@ gui_window *over_window = 0; /**< Window which the pointer is over. */
bool gui_reformat_pending = false; /**< Some windows have been resized,
and should be reformatted. */
gui_drag_type gui_current_drag_type;
static wimp_t task_handle; /**< RISC OS wimp task handle. */
wimp_t task_handle; /**< RISC OS wimp task handle. */
static clock_t gui_last_poll; /**< Time of last wimp_poll. */
osspriteop_area *pointers; /**< Sprite area containing pointer data */
gui_pointer_shape curr_pointer; /**< Current shape of the pointer */
@ -74,6 +74,7 @@ static const wimp_MESSAGE_LIST(26) task_messages = { {
message_MENU_WARNING,
#ifdef WITH_URI
message_URI_PROCESS,
message_URI_RETURN_RESULT,
#endif
#ifdef WITH_URL
message_INET_SUITE_OPEN_URL,
@ -544,6 +545,15 @@ void gui_window_set_pointer(gui_pointer_shape shape)
curr_pointer = shape;
}
void gui_launch_url(char *url) {
/* Try ant broadcast first */
if (!ro_url_broadcast(url))
/* then uri */
if (!ro_uri_launch(url))
/* then ant load */
ro_url_load(url);
}
/**
* Handle Redraw_Window_Request events.
@ -734,12 +744,22 @@ void ro_gui_user_message(wimp_event_no event, wimp_message *message)
#ifdef WITH_URI
case message_URI_PROCESS:
ro_uri_message_received(message);
if (event != wimp_USER_MESSAGE_ACKNOWLEDGE)
ro_uri_message_received(message);
break;
case message_URI_RETURN_RESULT:
if (event == wimp_USER_MESSAGE_ACKNOWLEDGE)
ro_uri_bounce(message);
break;
#endif
#ifdef WITH_URL
case message_INET_SUITE_OPEN_URL:
ro_url_message_received(message);
if (event == wimp_USER_MESSAGE_ACKNOWLEDGE) {
ro_url_bounce(message);
}
else {
ro_url_message_received(message);
}
break;
#endif
#ifdef WITH_PLUGIN

View File

@ -5,6 +5,7 @@
* Copyright 2003 Rob Jackson <jacko@xms.ms>
*/
#include <stdbool.h>
#include <stdio.h>
#include <string.h>
#include "oslib/uri.h"
@ -14,12 +15,17 @@
#include "netsurf/riscos/theme.h"
#include "netsurf/desktop/gui.h"
#include "netsurf/riscos/gui.h"
#include "netsurf/riscos/url_protocol.h"
#include "netsurf/utils/log.h"
#include "netsurf/utils/utils.h"
#ifdef WITH_URI
void ro_uri_message_received(uri_full_message_process*);
bool ro_uri_launch(char *uri);
void ro_uri_bounce(uri_full_message_return_result*);
extern wimp_t task_handle;
void ro_uri_message_received(uri_full_message_process* uri_message)
@ -61,4 +67,36 @@ void ro_uri_message_received(uri_full_message_process* uri_message)
xfree(uri_requested);
}
bool ro_uri_launch(char *uri) {
uri_h uri_handle;
wimp_t handle_task;
uri_dispatch_flags returned;
os_error *e;
e = xuri_dispatch(0, uri, task_handle, &returned, &handle_task, &uri_handle);
if (e || returned & 1) {
return false;
}
return true;
}
void ro_uri_bounce(uri_full_message_return_result *message) {
char uri_buf[512];
os_error *e;
if ((message->flags & 1) == 0) return;
e = xuri_request_uri(0, uri_buf, sizeof uri_buf, message->handle, 0);
if (e) return;
ro_url_load(uri_buf);
return;
}
#endif

View File

@ -11,5 +11,7 @@
#include "oslib/wimp.h"
void ro_uri_message_received(wimp_message *message);
bool ro_uri_launch(char *uri);
void ro_uri_bounce(wimp_message *message);
#endif

View File

@ -15,6 +15,7 @@
#include "netsurf/riscos/theme.h"
#include "netsurf/desktop/gui.h"
#include "netsurf/riscos/gui.h"
#include "netsurf/riscos/uri.h"
#include "netsurf/riscos/url_protocol.h"
#include "netsurf/utils/log.h"
#include "netsurf/utils/utils.h"
@ -125,3 +126,57 @@ char *read_string_value(os_string_value string, char *msg) {
if(string.offset > 256) return string.pointer;
return &msg[string.offset];
}
bool ro_url_broadcast(char *url) {
inetsuite_full_message_open_url_direct message;
os_error *e;
int len = (strlen(url)>235) ? 235 : strlen(url);
message.size = (((20+len-1)+3) & ~3);
message.your_ref = 0;
message.action = message_INET_SUITE_OPEN_URL;
*message.url = 0;
strncat(message.url, url, 235);
e = xwimp_send_message(wimp_USER_MESSAGE_RECORDED,
(wimp_message*)&message, 0);
if (e) {
return false;
}
return true;
}
bool ro_url_load(char *url) {
char url_buf[512];
char *colon;
os_error *e;
colon = strchr(url, ':');
if (!colon) return false;
strcpy(url_buf, "Alias$URLOpen_");
strncat(url_buf, url, colon-url);
if (!getenv(url_buf)) return false;
strcat(url_buf, " ");
strncat(url_buf, url, 512-strlen(url_buf)-1);
e = xwimp_start_task(url_buf+5, 0);
if (e) {
return false;
}
return true;
}
void ro_url_bounce(wimp_message *message) {
inetsuite_message_open_url *url_message = (inetsuite_message_open_url*)&message->data;
/* ant broadcast bounced -> try uri broadcast / load */
ro_uri_launch(url_message->url);
}

View File

@ -11,5 +11,8 @@
#include "oslib/wimp.h"
void ro_url_message_received(wimp_message *message);
bool ro_url_broadcast(char *url);
bool ro_url_load(char *url);
void ro_url_bounce(wimp_message *message);
#endif