From fd1235d007331368f081bfaff0b0eecafc23b25b Mon Sep 17 00:00:00 2001 From: Michiel Broek Date: Sat, 21 Aug 2004 13:20:00 +0000 Subject: [PATCH] Fixed thumbnail support --- ChangeLog | 8 ++++++++ mbfido/mbfcheck.c | 6 +++--- mbfido/mbfindex.c | 26 ++++++++++++++++++-------- 3 files changed, 29 insertions(+), 11 deletions(-) diff --git a/ChangeLog b/ChangeLog index 98e6346e..b3f22e00 100644 --- a/ChangeLog +++ b/ChangeLog @@ -6,6 +6,8 @@ v0.61.4 11-Aug-2004 upgrade: If you have BBBS uplinks and use automatic uplink requests then change the setup of these nodes in screen 7.10. + Run "mbfile check" and then "mbfile index". This fixes the + thumbnails if supported by your system. libnodelist.a: Removed some debug logging. @@ -29,6 +31,12 @@ v0.61.4 11-Aug-2004 mbfile: The html index now uses html named character entities on the area names on the main index page. + With html index creation if the convert program for the + thumbnails failed, the html pages were wrong. + The thumbnails were created from the 8.3 name but the url was + created to the LFN. Depending on the settings of your apache + server you would see the thumbnails or not. + The check for wrong thumbnails changed from LFN to 8.3 names. mbindex: Fixed compiling pointlists where on the Boss line there is no diff --git a/mbfido/mbfcheck.c b/mbfido/mbfcheck.c index ad3408e3..9938e605 100644 --- a/mbfido/mbfcheck.c +++ b/mbfido/mbfcheck.c @@ -430,12 +430,12 @@ void CheckArea(long Area) } /* - * It could be that there is a thumbnail made of the LFN. + * It could be that there is a thumbnail made of the 8.3 filename */ tname = calloc(PATH_MAX, sizeof(char)); - sprintf(tname, "%s/.%s", area.Path, fdb.LName); + sprintf(tname, "%s/.%s", area.Path, fdb.Name); if (file_exist(tname, R_OK) == 0) { - Syslog('+', "Removing thumbnail %s", tname); + Syslog('+', "Removing wrong 8.3 thumbnail %s", tname); iErrors++; unlink(tname); } diff --git a/mbfido/mbfindex.c b/mbfido/mbfindex.c index 4155e831..f1a99ac4 100644 --- a/mbfido/mbfindex.c +++ b/mbfido/mbfindex.c @@ -499,7 +499,7 @@ void HtmlIndex(char *Lang) { FILE *pAreas, *fa, *fb = NULL, *fm, *fi = NULL; unsigned long i, iAreas, KSize = 0L, aSize = 0; - int AreaNr = 0, j, k, x = 0; + int AreaNr = 0, j, k, x = 0, isthumb; int aTotal = 0, inArea = 0, filenr; char *sAreas, *fn; char linebuf[1024], outbuf[1024], desc[6400], namebuf[1024]; @@ -632,20 +632,30 @@ void HtmlIndex(char *Lang) * check if a thumbnail file exists. If not try to * create a thumbnail file to add to the html listing. */ + isthumb = FALSE; if (strstr(fdb.LName, ".gif") || strstr(fdb.LName, ".jpg") || strstr(fdb.LName, ".GIF") || strstr(fdb.LName, ".JPG")) { - sprintf(linebuf, "%s/%s", area.Path, fdb.Name); - sprintf(outbuf, "%s/.%s", area.Path, fdb.Name); + sprintf(linebuf, "%s/%s", area.Path, fdb.LName); + sprintf(outbuf, "%s/.%s", area.Path, fdb.LName); if (file_exist(outbuf, R_OK)) { - if ((j = execute_str(CFG.www_convert, linebuf, outbuf, + if (strlen(CFG.www_convert)) { + if ((execute_str(CFG.www_convert, linebuf, outbuf, (char *)"/dev/null", (char *)"/dev/null", (char *)"/dev/null"))) { - Syslog('+', "Failed to create thumbnail for %s, rc=% d", fdb.Name, j); + Syslog('+', "Failed to create thumbnail for %s", fdb.LName); + } else { + chmod(outbuf, 0644); + isthumb = TRUE; + } } else { - chmod(outbuf, 0644); + Syslog('+', "No convert program to create thumbnail %s", outbuf); } + } else { + isthumb = TRUE; } - sprintf(outbuf, "%s/%s%s/%s", CFG.www_url, CFG.www_link2ftp, - area.Path+strlen(CFG.ftp_base), fdb.LName); + } + sprintf(outbuf, "%s/%s%s/%s", CFG.www_url, CFG.www_link2ftp, + area.Path+strlen(CFG.ftp_base), fdb.LName); + if (isthumb) { sprintf(linebuf, "%s/%s%s/.%s", CFG.www_url, CFG.www_link2ftp, area.Path+strlen(CFG.ftp_base), fdb.LName); MacroVars("fghi", "dsss", 1, outbuf, fdb.LName, linebuf);