From fa98e3d76ada300d69e04816bfe15b2d560c9f7d Mon Sep 17 00:00:00 2001 From: Vincent Sanders Date: Tue, 15 Feb 2011 23:18:10 +0000 Subject: [PATCH] add about: fetcher rename fetchers to be more sensible svn path=/trunk/netsurf/; revision=11692 --- Makefile.sources | 6 +- content/fetch.c | 7 +- content/fetchers/about.c | 315 ++++++++++++++++++++++ content/fetchers/about.h | 28 ++ content/fetchers/{fetch_curl.c => curl.c} | 2 +- content/fetchers/{fetch_curl.h => curl.h} | 0 content/fetchers/{fetch_data.c => data.c} | 2 +- content/fetchers/{fetch_data.h => data.h} | 0 content/fetchers/{fetch_file.c => file.c} | 2 +- content/fetchers/{fetch_file.h => file.h} | 0 gtk/gui.c | 2 +- 11 files changed, 355 insertions(+), 9 deletions(-) create mode 100644 content/fetchers/about.c create mode 100644 content/fetchers/about.h rename content/fetchers/{fetch_curl.c => curl.c} (99%) rename content/fetchers/{fetch_curl.h => curl.h} (100%) rename content/fetchers/{fetch_data.c => data.c} (99%) rename content/fetchers/{fetch_data.h => data.h} (100%) rename content/fetchers/{fetch_file.c => file.c} (99%) rename content/fetchers/{fetch_file.h => file.h} (100%) diff --git a/Makefile.sources b/Makefile.sources index b948557b7..a8e18e1c0 100644 --- a/Makefile.sources +++ b/Makefile.sources @@ -4,8 +4,9 @@ # Included by main makefile -- indicates generic sources for every build. # -S_CONTENT := content.c dirlist.c fetch.c hlcache.c llcache.c urldb.c \ - fetchers/fetch_curl.c fetchers/fetch_data.c fetchers/fetch_file.c +S_CONTENT := content.c dirlist.c fetch.c hlcache.c llcache.c urldb.c + +S_FETCHERS := curl.c data.c file.c about.c S_CSS := css.c dump.c internal.c select.c utils.c @@ -22,6 +23,7 @@ S_DESKTOP := cookies.c history_global_core.c hotlist.c knockout.c \ # S_COMMON are sources common to all builds S_COMMON := $(addprefix content/,$(S_CONTENT)) \ + $(addprefix content/fetchers/,$(S_FETCHERS)) \ $(addprefix css/,$(S_CSS)) \ $(addprefix render/,$(S_RENDER)) \ $(addprefix utils/,$(S_UTILS)) \ diff --git a/content/fetch.c b/content/fetch.c index a90568b1b..b07964861 100644 --- a/content/fetch.c +++ b/content/fetch.c @@ -38,9 +38,9 @@ #include "utils/config.h" #include "content/fetch.h" -#include "content/fetchers/fetch_curl.h" -#include "content/fetchers/fetch_data.h" -#include "content/fetchers/fetch_file.h" +#include "content/fetchers/curl.h" +#include "content/fetchers/data.h" +#include "content/fetchers/file.h" #include "content/urldb.h" #include "desktop/netsurf.h" #include "desktop/options.h" @@ -111,6 +111,7 @@ void fetch_init(void) fetch_curl_register(); fetch_data_register(); fetch_file_register(); + fetch_about_register(); fetch_active = false; } diff --git a/content/fetchers/about.c b/content/fetchers/about.c new file mode 100644 index 000000000..c0507aaa4 --- /dev/null +++ b/content/fetchers/about.c @@ -0,0 +1,315 @@ +/* + * Copyright 2011 Vincent Sanders + * + * This file is part of NetSurf. + * + * NetSurf 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; version 2 of the License. + * + * NetSurf 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, see . + */ + +/* about: URL handling. Based on the data fetcher by Rob Kendrick */ + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include "utils/config.h" +#include "content/dirlist.h" +#include "content/fetch.h" +#include "content/fetchers/about.h" +#include "content/urldb.h" +#include "desktop/netsurf.h" +#include "desktop/options.h" +#include "utils/log.h" +#include "utils/messages.h" +#include "utils/url.h" +#include "utils/utils.h" +#include "utils/ring.h" + +struct fetch_about_context; + +typedef bool (*fetch_about_handler)(struct fetch_about_context *); + +/** Context for an about fetch */ +struct fetch_about_context { + struct fetch_about_context *r_next, *r_prev; + + struct fetch *fetchh; /**< Handle for this fetch */ + + bool aborted; /**< Flag indicating fetch has been aborted */ + bool locked; /**< Flag indicating entry is already entered */ + + char *url; /**< The full url the fetch refers to */ + + fetch_about_handler handler; +}; + +static struct fetch_about_context *ring = NULL; + +/** issue fetch callbacks with locking */ +static inline bool fetch_about_send_callback(fetch_msg msg, + struct fetch_about_context *ctx, const void *data, + unsigned long size, fetch_error_code errorcode) +{ + ctx->locked = true; + fetch_send_callback(msg, ctx->fetchh, data, size, errorcode); + ctx->locked = false; + + return ctx->aborted; +} + +static bool fetch_about_send_header(struct fetch_about_context *ctx, + const char *fmt, ...) +{ + char header[64]; + va_list ap; + + va_start(ap, fmt); + + vsnprintf(header, sizeof header, fmt, ap); + + va_end(ap); + + fetch_about_send_callback(FETCH_HEADER, ctx, header, strlen(header), + FETCH_ERROR_NO_ERROR); + + return ctx->aborted; +} + + + + +static bool fetch_about_blank_handler(struct fetch_about_context *ctx) +{ + char buffer[2]; + int code = 200; + + /* content is going to return ok */ + fetch_set_http_code(ctx->fetchh, code); + + /* content type */ + if (fetch_about_send_header(ctx, "Content-Type: text/html")) + goto fetch_about_blank_handler_aborted; + + buffer[0] = ' '; + buffer[1] = 0; + if (fetch_about_send_callback(FETCH_DATA, ctx, buffer, strlen(buffer), + FETCH_ERROR_NO_ERROR)) + goto fetch_about_blank_handler_aborted; + + fetch_about_send_callback(FETCH_FINISHED, ctx, 0, 0, + FETCH_ERROR_NO_ERROR); + + return true; + +fetch_about_blank_handler_aborted: + return false; +} + +static const char *authors[] = { + "John-Mark Bell", "James Bursa", "Michael Drake", + "Rob Kendrick", "Adrian Lees", "Vincent Sanders", + "Daniel Silverstone", "Richard Wilson", NULL +}; + +static bool fetch_about_credits_handler(struct fetch_about_context *ctx) +{ + char buffer[4096]; + int code = 200; + int slen; + int auth_loop = 0; + + /* content is going to return ok */ + fetch_set_http_code(ctx->fetchh, code); + + /* content type */ + if (fetch_about_send_header(ctx, "Content-Type: text/html")) + goto fetch_about_credits_handler_aborted; + + slen = snprintf(buffer, sizeof buffer, + "NetSurf Browser Credits" + "

NetSurf Browser Credits

" + "

Authors

" + "
    "); + + while (authors[auth_loop] != NULL) { + slen += snprintf(buffer + slen, sizeof buffer - slen, + "
  • %s
  • ", authors[auth_loop]); + auth_loop++; + } + + slen += snprintf(buffer + slen, sizeof buffer - slen, + "
"); + + if (fetch_about_send_callback(FETCH_DATA, ctx, buffer, slen, + FETCH_ERROR_NO_ERROR)) + goto fetch_about_credits_handler_aborted; + + fetch_about_send_callback(FETCH_FINISHED, ctx, 0, 0, + FETCH_ERROR_NO_ERROR); + + return true; + +fetch_about_credits_handler_aborted: + return false; +} + +struct about_handlers { + const char *name; + fetch_about_handler handler; +}; + +struct about_handlers about_handler_list[] = { + { "credits", fetch_about_credits_handler }, + { "blank", fetch_about_blank_handler } /* The default */ +}; + +#define about_handler_list_len (sizeof(about_handler_list) / sizeof(struct about_handlers)) + +/** callback to initialise the about fetcher. */ +static bool fetch_about_initialise(const char *scheme) +{ + return true; +} + +/** callback to initialise the about fetcher. */ +static void fetch_about_finalise(const char *scheme) +{ +} + +/** callback to set up a about fetch context. */ +static void * +fetch_about_setup(struct fetch *fetchh, + const char *url, + bool only_2xx, + const char *post_urlenc, + const struct fetch_multipart_data *post_multipart, + const char **headers) +{ + struct fetch_about_context *ctx; + unsigned int handler_loop; + struct url_components urlcomp; + + ctx = calloc(1, sizeof(*ctx)); + if (ctx == NULL) + return NULL; + + url_get_components(url, &urlcomp); + + for (handler_loop = 0; + handler_loop < about_handler_list_len; + handler_loop++) { + ctx->handler = about_handler_list[handler_loop].handler; + if (strcmp(about_handler_list[handler_loop].name, urlcomp.path) == 0) + break; + } + + url_destroy_components(&urlcomp); + + ctx->fetchh = fetchh; + + RING_INSERT(ring, ctx); + + return ctx; +} + +/** callback to free a about fetch */ +static void fetch_about_free(void *ctx) +{ + struct fetch_about_context *c = ctx; + free(c->url); + RING_REMOVE(ring, c); + free(ctx); +} + +/** callback to start a about fetch */ +static bool fetch_about_start(void *ctx) +{ + return true; +} + +/** callback to abort a about fetch */ +static void fetch_about_abort(void *ctx) +{ + struct fetch_about_context *c = ctx; + + /* To avoid the poll loop having to deal with the fetch context + * disappearing from under it, we simply flag the abort here. + * The poll loop itself will perform the appropriate cleanup. + */ + c->aborted = true; +} + + +/** callback to poll for additional about fetch contents */ +static void fetch_about_poll(const char *scheme) +{ + struct fetch_about_context *c, *next; + + if (ring == NULL) return; + + /* Iterate over ring, processing each pending fetch */ + c = ring; + do { + /* Take a copy of the next pointer as we may destroy + * the ring item we're currently processing */ + next = c->r_next; + + /* Ignore fetches that have been flagged as locked. + * This allows safe re-entrant calls to this function. + * Re-entrancy can occur if, as a result of a callback, + * the interested party causes fetch_poll() to be called + * again. + */ + if (c->locked == true) { + continue; + } + + /* Only process non-aborted fetches */ + if (c->aborted == false) { + /* about fetches can be processed in one go */ + c->handler(c); + } + + + fetch_remove_from_queues(c->fetchh); + fetch_free(c->fetchh); + + /* Advance to next ring entry, exiting if we've reached + * the start of the ring or the ring has become empty + */ + } while ( (c = next) != ring && ring != NULL); +} + +void fetch_about_register(void) +{ + fetch_add_fetcher("about", + fetch_about_initialise, + fetch_about_setup, + fetch_about_start, + fetch_about_abort, + fetch_about_free, + fetch_about_poll, + fetch_about_finalise); +} diff --git a/content/fetchers/about.h b/content/fetchers/about.h new file mode 100644 index 000000000..f22be6a5d --- /dev/null +++ b/content/fetchers/about.h @@ -0,0 +1,28 @@ +/* + * Copyright 2011 Vincent Sanders + * + * This file is part of NetSurf. + * + * NetSurf 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; version 2 of the License. + * + * NetSurf 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, see . + */ + +/** \file + * about: URL method handler + */ + +#ifndef NETSURF_CONTENT_FETCHERS_FETCH_ABOUT_H +#define NETSURF_CONTENT_FETCHERS_FETCH_ABOUT_H + +void fetch_about_register(void); + +#endif diff --git a/content/fetchers/fetch_curl.c b/content/fetchers/curl.c similarity index 99% rename from content/fetchers/fetch_curl.c rename to content/fetchers/curl.c index 1b0af6d68..2d5f29a10 100644 --- a/content/fetchers/fetch_curl.c +++ b/content/fetchers/curl.c @@ -40,7 +40,7 @@ #include "utils/config.h" #include #include "content/fetch.h" -#include "content/fetchers/fetch_curl.h" +#include "content/fetchers/curl.h" #include "content/urldb.h" #include "desktop/netsurf.h" #include "desktop/options.h" diff --git a/content/fetchers/fetch_curl.h b/content/fetchers/curl.h similarity index 100% rename from content/fetchers/fetch_curl.h rename to content/fetchers/curl.h diff --git a/content/fetchers/fetch_data.c b/content/fetchers/data.c similarity index 99% rename from content/fetchers/fetch_data.c rename to content/fetchers/data.c index a58c971bf..2396a797b 100644 --- a/content/fetchers/fetch_data.c +++ b/content/fetchers/data.c @@ -29,7 +29,7 @@ #include "utils/config.h" #include "content/fetch.h" -#include "content/fetchers/fetch_data.h" +#include "content/fetchers/data.h" #include "content/urldb.h" #include "desktop/netsurf.h" #include "desktop/options.h" diff --git a/content/fetchers/fetch_data.h b/content/fetchers/data.h similarity index 100% rename from content/fetchers/fetch_data.h rename to content/fetchers/data.h diff --git a/content/fetchers/fetch_file.c b/content/fetchers/file.c similarity index 99% rename from content/fetchers/fetch_file.c rename to content/fetchers/file.c index e8a1f38c5..2f69fe583 100644 --- a/content/fetchers/fetch_file.c +++ b/content/fetchers/file.c @@ -37,7 +37,7 @@ #include "utils/config.h" #include "content/dirlist.h" #include "content/fetch.h" -#include "content/fetchers/fetch_file.h" +#include "content/fetchers/file.h" #include "content/urldb.h" #include "desktop/netsurf.h" #include "desktop/options.h" diff --git a/content/fetchers/fetch_file.h b/content/fetchers/file.h similarity index 100% rename from content/fetchers/fetch_file.h rename to content/fetchers/file.h diff --git a/gtk/gui.c b/gtk/gui.c index 8a92f83dc..fd2116f21 100644 --- a/gtk/gui.c +++ b/gtk/gui.c @@ -42,7 +42,7 @@ #include "content/content.h" #include "content/fetch.h" -#include "content/fetchers/fetch_curl.h" +#include "content/fetchers/curl.h" #include "content/hlcache.h" #include "content/urldb.h" #include "desktop/browser.h"