removed parameter_t
[swftools.git] / lib / pdf / pdf.cc
index f651e58..885ebbf 100644 (file)
@@ -19,9 +19,6 @@ static int ppm_dpi = 0;
 static int multiply = 1;
 static char* global_page_range = 0;
 
-static parameter_t* device_config = 0;
-static parameter_t* device_config_next = 0;
-
 static int globalparams_count=0;
 
 typedef struct _pdf_page_info
@@ -100,14 +97,10 @@ void render2(gfxpage_t*page, gfxdevice_t*dev)
         dev->setparameter(dev, "protect", "1");
     }
     
-    /* pass global parameters to output device */
-    parameter_t*p = device_config;
-    while(p) {
-       dev->setparameter(dev, p->name, p->value);
-       p = p->next;
-    }
     pi->doc->displayPage((OutputDev*)pi->outputDev, page->nr, zoom*multiply, zoom*multiply, /*rotate*/0, true, true, /*doLinks*/(int)1);
     pi->doc->processLinks((OutputDev*)pi->outputDev, page->nr);
+    pi->outputDev->finishPage();
+
     pi->outputDev->setDevice(0);
     if(pi->middev) {
        gfxdevice_rescale_setdevice(pi->middev, 0x00000000);
@@ -194,10 +187,6 @@ gfxpage_t* pdf_doc_getpage(gfxdocument_t*doc, int page)
 
     if(page < 1 || page > doc->num_pages)
         return 0;
-    if(di->nocopy) {
-        msg("<error> PDF disallows copying.");
-        return 0;
-    }
     
     gfxpage_t* pdf_page = (gfxpage_t*)malloc(sizeof(gfxpage_t));
     pdf_page_internal_t*pi= (pdf_page_internal_t*)malloc(sizeof(pdf_page_internal_t));
@@ -291,33 +280,6 @@ char* pdf_doc_getinfo(gfxdocument_t*doc, const char*name)
     return 0;
 }
 
-
-static void storeDeviceParameter(const char*name, const char*value)
-{
-    parameter_t*o = device_config;
-    while(o) {
-        if(!strcmp(name, o->name)) {
-            /* overwrite old value */
-            free(o->value);
-            o->value = strdup(value);
-            return;
-        }
-        o = o->next;
-    }
-    parameter_t*p = new parameter_t();
-    p->name = strdup(name);
-    p->value = strdup(value);
-    p->next = 0;
-
-    if(device_config_next) {
-       device_config_next->next = p;
-       device_config_next = p;
-    } else {
-       device_config = p;
-       device_config_next = p;
-    }
-}
-
 typedef struct _gfxsource_internal
 {
     int config_bitmap_optimizing;
@@ -332,7 +294,7 @@ static void pdf_set_parameter(gfxsource_t*src, const char*name, const char*value
         addGlobalFontDir(value);
     } else if(!strcmp(name, "pages")) {
        global_page_range = strdup(value);
-    } else if(!strncmp(name, "font", strlen("font"))) {
+    } else if(!strncmp(name, "font", strlen("font")) && name[4]!='q') {
        addGlobalFont(value);
     } else if(!strncmp(name, "languagedir", strlen("languagedir"))) {
         addGlobalLanguageDir(value);
@@ -360,13 +322,20 @@ static void pdf_set_parameter(gfxsource_t*src, const char*name, const char*value
     } else if(!strcmp(name, "multiply")) {
         multiply = atoi(value);
     } else if(!strcmp(name, "help")) {
-       printf("\nPDF device global parameters:\n");
-       printf("fontdir=<dir>   a directory with additional fonts\n");
-       printf("font=<filename> an dditional font filename\n");
-       printf("pages=<range>   the range of pages to convert (example: pages=1-100,210-)\n");
-       printf("zoom=<dpi>      the resultion (default: 72)\n");
+       printf("fontdir=<dir>       a directory with additional fonts\n");
+       printf("font=<filename>     an additional font filename\n");
+       printf("pages=<range>       the range of pages to convert (example: pages=1-100,210-)\n");
+       printf("zoom=<dpi>          the resultion (default: 72)\n");
+       printf("bitmap              Convert everything to bitmaps\n");
+       printf("poly2bitmap         Convert graphics to bitmaps\n");
+       printf("languagedir=<dir>   Add an xpdf language directory\n");
+       printf("multiply=<times>    Render everything at <times> the resolution\n");
+       printf("breakonwarning=0/1  Abort conversion if graphic objects are found which\n");
+       printf("                    are not 100%% supported\n");
+       printf("transparent=0/1     Make output file transparent (alpha background)\n");
+       printf("extrafontdata=0/1   Store Type3 characters and capture characters\n");
+       printf("fontquality=1..100  Curve approximation quality of the fonts\n");
     }  
-    storeDeviceParameter(name,value);
 }
 
 static gfxdocument_t*pdf_open(gfxsource_t*src, const char*filename)
@@ -450,13 +419,6 @@ static gfxdocument_t*pdf_open(gfxsource_t*src, const char*filename)
        i->outputDev = (CommonOutputDev*)outputDev;
     }
 
-    /* pass global parameters to PDF driver*/
-    parameter_t*p = device_config;
-    while(p) {
-       i->outputDev->setParameter(p->name, p->value);
-       p = p->next;
-    }
-
     i->middev = 0;
     if(multiply>1) {
        i->middev = (gfxdevice_t*)malloc(sizeof(gfxdevice_t));
@@ -481,13 +443,8 @@ void pdf_destroy(gfxsource_t*src)
     gfxsource_internal_t*i = (gfxsource_internal_t*)src->internal;
     free(src->internal);src->internal=0;
     
-    parameter_t*p = device_config;
-    while(p) {
-       parameter_t*next = p->next;
-       p->next = 0;free(p);
-       p = next;
-    }
     delete globalParams;globalParams = 0;
+    free(src);
 }
 
 gfxsource_t*gfxsource_pdf_create()