From bb6c7b9233b16dc1c6cdce2c316c0b1d62751331 Mon Sep 17 00:00:00 2001 From: kramm Date: Sat, 12 Jun 2004 16:06:52 +0000 Subject: [PATCH] Added Win32 support. --- pdf2swf/pdf2swf.cc | 73 +++++++++++++++++++++++++++++++++++++++++----------- 1 file changed, 58 insertions(+), 15 deletions(-) diff --git a/pdf2swf/pdf2swf.cc b/pdf2swf/pdf2swf.cc index 285e2a7..f50c7ce 100644 --- a/pdf2swf/pdf2swf.cc +++ b/pdf2swf/pdf2swf.cc @@ -28,6 +28,9 @@ #ifdef HAVE_DIRENT_H #include #endif +#ifdef HAVE_SYS_STAT_H +#include +#endif #include "../lib/args.h" #include "SWFOutputDev.h" #include "t1lib.h" @@ -35,6 +38,14 @@ extern "C" { #include "log.h" } +#ifndef WIN32 +#define FONTDIR SWFTOOLS_DATADIR "/fonts" +#define SWFDIR SWFTOOLS_DATADIR "/swfs" +#else +#define FONTDIR "C:\\pdf2swf\\fonts" +#define SWFDIR "C:\\pdf2swf\\swfs" +#endif + static char * outputname = 0; static int loglevel = 3; static char * pagerange = 0; @@ -172,14 +183,14 @@ int args_callback_option(char*name,char*val) { else if (!strcmp(name, "l")) { char buf[256]; - sprintf(buf, "%s/swfs/default_loader.swf", SWFTOOLS_DATADIR); + sprintf(buf, "%s/default_loader.swf", SWFDIR); preloader = strdup(buf); return 0; } else if (!strcmp(name, "b")) { char buf[256]; - sprintf(buf, "%s/swfs/default_viewer.swf", SWFTOOLS_DATADIR); + sprintf(buf, "%s/default_viewer.swf", SWFDIR); viewer = strdup(buf); return 0; } @@ -191,7 +202,7 @@ int args_callback_option(char*name,char*val) { } else { - systemf("ls %s/swfs/*_loader.swf", SWFTOOLS_DATADIR); + systemf("ls %s/*_loader.swf", SWFDIR); if(!system_quiet) printf("\n"); exit(1); @@ -206,7 +217,7 @@ int args_callback_option(char*name,char*val) { } else { - systemf("ls %s/swfs/*_viewer.swf", SWFTOOLS_DATADIR); + systemf("ls %s/*_viewer.swf", SWFDIR); if(!system_quiet) printf("\n"); exit(1); @@ -337,7 +348,8 @@ void addfontdir(FILE*database, char* dirname, int*numfonts, char*searchpath) strcat(searchpath, ":"); strcat(searchpath, dirname); } - msg(" Adding %s to search path\n", dirname); + if(!numfonts) + msg(" Adding %s to search path\n", dirname); DIR*dir = opendir(dirname); if(!dir) { @@ -365,12 +377,24 @@ void addfontdir(FILE*database, char* dirname, int*numfonts, char*searchpath) if(database && type==1) { char buf[256],a; FILE*fi; +#ifdef WIN32 + sprintf(buf, "%s\\%s", dirname,name); +#else sprintf(buf, "%s/%s", dirname,name); +#endif fi = fopen(buf, "rb"); if(!fi || !fread(&a,1,1,fi)) { msg(" Couldn't read from %s", buf); } - fprintf(database, "%s\n", buf); + +#ifdef WIN32 +/* might also work for all other systems, but we *need* it for win32 */ + if(!strncmp(buf, FONTDIR, strlen(FONTDIR))) + fprintf(database, "%s\n", buf+strlen(FONTDIR)); + else +#endif + fprintf(database, "%s\n", buf); + msg(" Found font %s\n", buf); fclose(fi); } @@ -408,6 +432,17 @@ int main(int argn, char *argv[]) int numfonts = 0; int t; char t1searchpath[1024]; + +#if defined(WIN32) && defined(HAVE_STAT) && defined(HAVE_SYS_STAT_H) + FILE*test = fopen(FONTDIR "\\d050000l.afm", "rb"); + if(!test) { + fprintf(stderr, "Couldn't find file " FONTDIR "\\d050000l.afm- pdf2swf not installed properly? OS says:\n"); + perror("open"); + exit(1); + } + fclose(test); +#endif + #ifdef HAVE_SRAND48 srand48(time(0)); #else @@ -446,7 +481,7 @@ int main(int argn, char *argv[]) exit(0); } - msg(" reading font files from %s/fonts\n", SWFTOOLS_DATADIR); + msg(" reading font files from %s\n", FONTDIR); //TODO: use tempnam here. Check if environment already contains a //T1LIB_CONFIG. putenv( "T1LIB_CONFIG=/tmp/t1lib.config.tmp"); @@ -458,19 +493,21 @@ int main(int argn, char *argv[]) } t1searchpath[0] = 0; #ifdef HAVE_DIRENT_H - sprintf(buf, "%s/fonts",SWFTOOLS_DATADIR); // pass 1 - addfontdir(0, buf, &numfonts, 0); + addfontdir(0, FONTDIR, &numfonts, 0); for(t=0;t --preloader option without --viewer option doesn't make very much sense."); - ret = systemf("swfcombine `swfdump -r %s` %s/swfs/PreLoaderTemplate.swf loader=%s movie=%s -o %s", - preloader, SWFTOOLS_DATADIR, preloader, outputname, outputname); + ret = systemf("swfcombine `swfdump -r %s` %s/PreLoaderTemplate.swf loader=%s movie=%s -o %s", + preloader, SWFDIR, preloader, outputname, outputname); if(!system_quiet) printf("\n"); } if(preloader && viewer) { systemf("swfcombine %s viewport=%s -o __tmp__.swf", viewer, outputname, outputname); - systemf("swfcombine `swfdump -XY %s` `swfdump -r %s` %s/swfs/PreLoaderTemplate.swf loader=%s movie=__tmp__.swf -o %s", - outputname, preloader, SWFTOOLS_DATADIR, preloader, outputname); + systemf("swfcombine `swfdump -XY %s` `swfdump -r %s` %s/PreLoaderTemplate.swf loader=%s movie=__tmp__.swf -o %s", + outputname, preloader, SWFDIR, preloader, outputname); systemf("rm __tmp__.swf"); } -- 1.7.10.4