mirror of
https://github.com/netsurf-browser/netsurf
synced 2024-11-29 01:33:16 +03:00
361fcf507a
Update url checking to use fetch_can_fetch Fix non null-termination of strings in URL broadcast messages. svn path=/import/netsurf/; revision=701
103 lines
2.4 KiB
C
103 lines
2.4 KiB
C
/*
|
|
* This file is part of NetSurf, http://netsurf.sourceforge.net/
|
|
* Licensed under the GNU General Public License,
|
|
* http://www.opensource.org/licenses/gpl-license
|
|
* Copyright 2003 Rob Jackson <jacko@xms.ms>
|
|
*/
|
|
|
|
#include <stdbool.h>
|
|
#include <stdio.h>
|
|
#include <string.h>
|
|
#include "oslib/uri.h"
|
|
#include "oslib/wimp.h"
|
|
#include "netsurf/utils/config.h"
|
|
#include "netsurf/desktop/browser.h"
|
|
#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)
|
|
{
|
|
uri_h uri_handle;
|
|
char* uri_requested;
|
|
|
|
struct browser_window* bw;
|
|
int uri_length;
|
|
|
|
uri_handle = uri_message->handle;
|
|
|
|
LOG(("URI message... %s, handle = %d", uri_message->uri,
|
|
(int)uri_message->handle));
|
|
|
|
if ( (strspn(uri_message->uri, "http://") != strlen("http://")) &&
|
|
(strspn(uri_message->uri, "https://") != strlen("https://")) &&
|
|
(strspn(uri_message->uri, "file:/") != strlen("file:/")) )
|
|
return;
|
|
|
|
else LOG(("URI message deemed relevant"));
|
|
|
|
uri_message->your_ref = uri_message->my_ref;
|
|
uri_message->action = message_URI_PROCESS_ACK;
|
|
|
|
xwimp_send_message(wimp_USER_MESSAGE_ACKNOWLEDGE,
|
|
(wimp_message*)uri_message,
|
|
uri_message->sender);
|
|
|
|
xuri_request_uri(0, 0, 0, uri_handle, &uri_length);
|
|
uri_requested = xcalloc((unsigned int)uri_length, sizeof(char));
|
|
|
|
if (uri_requested == NULL)
|
|
return;
|
|
|
|
xuri_request_uri(0, uri_requested, uri_length, uri_handle, NULL);
|
|
|
|
browser_window_create(uri_requested);
|
|
|
|
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
|