From f4e447871bb0a84c71943b73344b987529567cea Mon Sep 17 00:00:00 2001 From: John Mark Bell Date: Tue, 16 Sep 2003 20:02:55 +0000 Subject: [project @ 2003-09-16 20:02:55 by jmb] Add dynamically created About page. Accessed via about: svn path=/import/netsurf/; revision=294 --- !NetSurf/About/About,faf | 35 ++++++ !NetSurf/About/animlib,ff9 | Bin 0 -> 1544 bytes !NetSurf/About/libcurl,ff9 | Bin 0 -> 15300 bytes !NetSurf/About/libpng,b60 | Bin 0 -> 2399 bytes !NetSurf/About/libxml,b60 | Bin 0 -> 4899 bytes !NetSurf/About/nslogo,b60 | Bin 0 -> 13366 bytes !NetSurf/About/openssl,695 | Bin 0 -> 2063 bytes !NetSurf/Resources/en/Messages | 2 +- makefile | 2 +- riscos/about.c | 275 +++++++++++++++++++++++++++++++++++++++++ riscos/about.h | 14 +++ riscos/gui.c | 10 +- 12 files changed, 335 insertions(+), 3 deletions(-) create mode 100644 !NetSurf/About/About,faf create mode 100644 !NetSurf/About/animlib,ff9 create mode 100644 !NetSurf/About/libcurl,ff9 create mode 100644 !NetSurf/About/libpng,b60 create mode 100644 !NetSurf/About/libxml,b60 create mode 100644 !NetSurf/About/nslogo,b60 create mode 100644 !NetSurf/About/openssl,695 create mode 100644 riscos/about.c create mode 100644 riscos/about.h diff --git a/!NetSurf/About/About,faf b/!NetSurf/About/About,faf new file mode 100644 index 000000000..f8709c820 --- /dev/null +++ b/!NetSurf/About/About,faf @@ -0,0 +1,35 @@ + +NetSurf makes use of the following libraries:
 
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
zlib 1.1.4Copyright © 1995-2002 Jean-loup Gailly and Mark Adler.
libpng 1.2.5
libpng logo
Copyright © 1995, 1996 Guy Eric Schalnat, Group 42, Inc.;
Copyright © 1996, 1997 Andreas Dilger;
Copyright © 1998-2002 Glenn Randers-Pehrson.
animlib 6.11
animlib logo
Copyright © 1997-2000 Peter Hartley.
libcurl 7.10.7
libcurl logo
Copyright © 1998-2003 Daniel Stenberg.
libxml 2.5.4
libxml logo
Copyright © 1998-2002 Daniel Veillard.
OpenSSL 0.9.7b
openssl logo
This product includes software developed by the OpenSSL Project for use in the OpenSSL Toolkit (http://www.openssl.org/). +
This product includes cryptographic software written by Eric Young (eay@cryptsoft.com).
+
\ No newline at end of file diff --git a/!NetSurf/About/animlib,ff9 b/!NetSurf/About/animlib,ff9 new file mode 100644 index 000000000..32efefe62 Binary files /dev/null and b/!NetSurf/About/animlib,ff9 differ diff --git a/!NetSurf/About/libcurl,ff9 b/!NetSurf/About/libcurl,ff9 new file mode 100644 index 000000000..4e9c44775 Binary files /dev/null and b/!NetSurf/About/libcurl,ff9 differ diff --git a/!NetSurf/About/libpng,b60 b/!NetSurf/About/libpng,b60 new file mode 100644 index 000000000..49798c8ed Binary files /dev/null and b/!NetSurf/About/libpng,b60 differ diff --git a/!NetSurf/About/libxml,b60 b/!NetSurf/About/libxml,b60 new file mode 100644 index 000000000..f7605f6a6 Binary files /dev/null and b/!NetSurf/About/libxml,b60 differ diff --git a/!NetSurf/About/nslogo,b60 b/!NetSurf/About/nslogo,b60 new file mode 100644 index 000000000..9dc185593 Binary files /dev/null and b/!NetSurf/About/nslogo,b60 differ diff --git a/!NetSurf/About/openssl,695 b/!NetSurf/About/openssl,695 new file mode 100644 index 000000000..3d3c90c9f Binary files /dev/null and b/!NetSurf/About/openssl,695 differ diff --git a/!NetSurf/Resources/en/Messages b/!NetSurf/Resources/en/Messages index 5635197f5..a5b548f82 100644 --- a/!NetSurf/Resources/en/Messages +++ b/!NetSurf/Resources/en/Messages @@ -1,4 +1,5 @@ # English messages for NetSurf +Version:0.01 # Menus NetSurf:NetSurf @@ -27,4 +28,3 @@ Downloaded:Download complete, %lu bytes Not2xx:Server returned an error - diff --git a/makefile b/makefile index bce724106..97e15f910 100644 --- a/makefile +++ b/makefile @@ -13,7 +13,7 @@ OBJECTS_COMMON = cache.o content.o fetch.o fetchcache.o other.o \ OBJECTS = $(OBJECTS_COMMON) \ browser.o netsurf.o \ dialog.o download.o gif.o gui.o jpeg.o menus.o png.o theme.o plugin.o \ - options.o filetype.o font.o uri.o htmlredraw.o sprite.o draw.o + options.o filetype.o font.o uri.o htmlredraw.o sprite.o draw.o about.o OBJECTS_DEBUG = $(OBJECTS_COMMON) \ netsurfd.o \ optionsd.o filetyped.o fontd.o diff --git a/riscos/about.c b/riscos/about.c new file mode 100644 index 000000000..1becfdb17 --- /dev/null +++ b/riscos/about.c @@ -0,0 +1,275 @@ +/* + * 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 John M Bell + */ + +/** \file + * About page creation. + * Dynamically creates the about page, scanning for available plugin information. + */ + +#include +#include +#include +#include +#include /* for __unixify */ + +#include "netsurf/riscos/about.h" +#include "netsurf/utils/log.h" +#include "netsurf/utils/messages.h" +#include "netsurf/utils/utils.h" + +#include "oslib/osargs.h" +#include "oslib/osfile.h" +#include "oslib/osfind.h" +#include "oslib/osfscontrol.h" + +static const char *version = "%s (%s %s %s)"; /**< version string prototype */ +static const char *pabouthdr = "About NetSurf
\"Netsurf
 

NetSurf %s

Copyright © 2002, 2003 NetSurf Developers.
 

"; /**< About page header */ +static const char *pabtplghd = "The following plugins are installed on your system:
 
"; /**< Plugin table header */ +static const char *paboutpl1 = ""; /**< Plugin entry without image */ +static const char *paboutpl2 = "";/**< Plugin entry with image (filename=nn) */ +static const char *paboutpl3 = ""; /**< Plugin entry with image (filename=nnwwwwhhhh) */ +static const char *pabtplgft = "
%s%s
%s
\"%s\"
%s
%s
\"%s\"
%s
"; /**< Plugin table footer */ +static const char *paboutftr = ""; /**< Page footer */ + +/** The about page */ +struct about_page { + + char *header; /**< page header */ + char *browser; /**< browser details */ + char *plghead; /**< plugin header */ + struct plugd *plugd; /**< plugin details list */ + char *plgfoot; /**< plugin footer */ + char *footer; /**< page footer */ +}; + +/** A set of plugin details */ +struct plugd { + + char *details; /**< plugin details */ + struct plugd *next; /**< next plugin details */ +}; + +struct plugd *new_plugin(struct plugd *pd, char* details); +char* populate_version(void); + +/** + * Fills in the version string. + * The release version is defined in the Messages file. + */ +char *populate_version(void) { + + char *p; + char *day; + char *mon; + char *year; + char *temp = xcalloc(12, sizeof(char)); + char *ret = xcalloc(20, sizeof(char)); + + sprintf(temp, "%s", __DATE__); + p = strchr(temp, ' '); + *p = 0; + mon = strdup(temp); + day = p+1; + p = strchr(day, ' '); + *p = 0; + year = p+1; + + sprintf(ret, version, messages_get("Version"), day, mon, year); + + xfree(temp); + + return ret; +} + +/** + * Adds a plugin's details to the head of the linked list of plugin details + * Returns the new head of the list + */ +struct plugd *new_plugin(struct plugd *pd, char* details) { + + struct plugd *np = xcalloc(1, sizeof(*np)); + + np->details = 0; + np->details = details; + + np->next = pd; + return np; +} + +/** + * Creates the about page and stores it in .WWW.Netsurf + */ +void about_create(void) { + + struct about_page *abt; + struct plugd *temp; + FILE *fp; + char *buf, *val, var[20], *ptype, *pdetails, *fname, *furl, *p, *leafname; + int i, nofiles, j, w, h, size; + os_fw fh; + os_error *e; + + abt = (struct about_page*)xcalloc(1, sizeof(*abt)); + abt->plugd = 0; + + /* Page header */ + buf = xcalloc(strlen(pabouthdr) + 20, sizeof(char)); + sprintf(buf, pabouthdr, populate_version()); + abt->header = xstrdup(buf); + xfree(buf); + + /* browser details */ + xosfile_read_stamped_no_path(".About.About",0,0,0,&i,0,0); + fp = fopen(".About.About", "r"); + buf = xcalloc((unsigned int)i + 10, sizeof(char)); + fread(buf, sizeof(char), (unsigned int)i, fp); + fclose(fp); + abt->browser = xstrdup(buf); + xfree(buf); + + /* plugin header */ + abt->plghead = xstrdup(pabtplghd); + + /* plugin footer */ + abt->plgfoot = xstrdup(pabtplgft); + + /* Page footer */ + abt->footer = xstrdup(paboutftr); + + /* plugins registered */ + for (i=0; i!=4096; i++) { + sprintf(var, "Plugin$About_%3.3x", i); + + if ((val = getenv(var)) != 0) { + /* Plugin Name */ + sprintf(var, "Plugin$Type_%3.3x", i); + ptype = getenv(var); + + buf = xcalloc(strlen(val) + 20, sizeof(char)); + /* count files which match .About* */ + sprintf(buf, "%s.About*", val); + xosfscontrol_count(buf,0,0,0,0,0,0,&nofiles); + + for (j=0; j!=nofiles; j++) { + /* get plugin details */ + if (j == 0) { + sprintf(buf, "%s.About", val); + } + else { + sprintf(buf, "%s.About%2.2d", val, j); + } + e = xosfile_read_stamped_no_path(buf,0,0,0,&size,0,0); + + /* If only one file, name can be "About" or "About00" */ + if((e && j == 0) || size < 0) { + sprintf(buf, "%s.About%2.2d", val, j); + e = xosfile_read_stamped_no_path(buf,0,0,0,&size,0,0); + } + /* ok, no file found. try again */ + if(e || size < 0) { + continue; + } + + /* read contents of file */ + fp = fopen(buf, "r"); + pdetails = xcalloc((unsigned int)size + 10, sizeof(char)); + fread(pdetails, sizeof(char), (unsigned int)size, fp); + fclose(fp); + + /* now see if there's an image to display */ + sprintf(buf, "%s.%2.2d", val, j); + e = xosfile_read_stamped_no_path(buf,0,0,0,&size,0,0); + + if(e || size < 0) { + sprintf(buf, "%s.%2.2d*", val, j); + e = xosfile_read_stamped_no_path(buf,0,0,0,&size,0,0); + + if(e || size < 0) { + /* Type 1: no image file */ + furl = xcalloc(strlen(paboutpl1) + strlen(ptype) + strlen(pdetails) + 10, sizeof(char)); + sprintf(furl, paboutpl1, ptype, pdetails); + abt->plugd = new_plugin(abt->plugd, furl); + xfree(pdetails); + continue; + } + else { + /* Type 3: image file with name xxwwwwhhhh */ + /* get actual file name - isn't there an easier way? */ + fname = xcalloc(strlen(buf)+40, sizeof(char)); + xosfind_openinw(osfind_NO_PATH, buf, 0, &fh); + xosargs_read_pathw(fh, fname, (int)strlen(buf)+10,0); + xosfind_closew(fh); + + furl = xcalloc(strlen(fname) + 20, sizeof(char)); + + /* grab leafname and get width and height */ + p = strrchr(fname, '.'); + leafname = xstrdup(p); + h = atoi(leafname+7); + leafname[7] = 0; + w = atoi(leafname+3); + + /* convert to URL */ + __unixify(fname, 0, furl, strlen(fname)+20, 0); + sprintf(fname, "file://%s", furl); + xfree(furl); + + furl = xcalloc(strlen(paboutpl3) + strlen(ptype) + strlen(fname) + strlen(pdetails) + 10, sizeof(char)); + sprintf(furl, paboutpl3, ptype, fname, ptype, w, h, pdetails); + abt->plugd = new_plugin(abt->plugd, furl); + xfree(fname); + xfree(pdetails); + continue; + } + } + else { + /* Type 2: image file with name xx */ + /* convert RO path to url */ + fname = xcalloc(strlen(buf) + 10, sizeof(char)); + furl = xcalloc(strlen(buf) + 10, sizeof(char)); + __unixify(buf, 0, furl, strlen(buf) + 10, 0); + sprintf(fname, "file://%s", furl); + xfree(furl); + + furl = xcalloc(strlen(paboutpl2) + strlen(ptype) + strlen(fname) + strlen(pdetails) + 10, sizeof(char)); + sprintf(furl, paboutpl2, ptype, fname, ptype, pdetails); + abt->plugd = new_plugin(abt->plugd, furl); + xfree(fname); + xfree(pdetails); + } + } + if (buf != 0) { + xfree(buf); + } + } + } + + /* write file */ + xosfile_create_dir(".WWW", 77); + xosfile_create_dir(".WWW.NetSurf", 77); + + fp = fopen(".WWW.Netsurf.About", "w+"); + fprintf(fp, "%s", abt->header); + fprintf(fp, "%s", abt->browser); + fprintf(fp, "%s", abt->plghead); + while (abt->plugd != 0) { + fprintf(fp, "%s", abt->plugd->details); + temp = abt->plugd; + abt->plugd = abt->plugd->next; + xfree(temp); + } + fprintf(fp, "%s", abt->plgfoot); + fprintf(fp, "%s", abt->footer); + fclose(fp); + + xosfile_set_type(".WWW.NetSurf.About", 0xfaf); + + xfree(abt); + + return; +} + diff --git a/riscos/about.h b/riscos/about.h new file mode 100644 index 000000000..cdcdcc885 --- /dev/null +++ b/riscos/about.h @@ -0,0 +1,14 @@ +/* + * 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 John M Bell + */ + +#ifndef _NETSURF_RISCOS_ABOUT_H_ +#define _NETSURF_RISCOS_ABOUT_H_ + +void about_create(void); + +#endif + diff --git a/riscos/gui.c b/riscos/gui.c index 39764a7d9..5636a528a 100644 --- a/riscos/gui.c +++ b/riscos/gui.c @@ -26,6 +26,7 @@ #include "netsurf/desktop/options.h" #include "netsurf/render/font.h" #include "netsurf/render/html.h" +#include "netsurf/riscos/about.h" #include "netsurf/riscos/gui.h" #include "netsurf/riscos/plugin.h" #include "netsurf/riscos/theme.h" @@ -1377,7 +1378,14 @@ void ro_gui_keypress(wimp_key* key) xfree(g->data.browser.bw->url); g->data.browser.bw->url = NULL; } - browser_window_open_location(g->data.browser.bw, g->url); + if (strcasecmp(g->url, "about:") == 0) { + about_create(); + browser_window_open_location(g->data.browser.bw, + "file:///%3CWimp$ScrapDir%3E/WWW/NetSurf/About"); + } + else { + browser_window_open_location(g->data.browser.bw, g->url); + } return; } else if (key->c == wimp_KEY_F8) -- cgit v1.2.3