X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;ds=sidebyside;f=createpdf.pl;h=249b217e5afddc80fee5fdcb5db144009d40bbb9;hb=21a49ee529ac296e177815c8def6d53579644bea;hp=6147e7e1938fd63b811658f41fced6ad985f6853;hpb=68190899b23c04803979149c4752bafb3cb0f4fb;p=webpdf diff --git a/createpdf.pl b/createpdf.pl index 6147e7e..249b217 100755 --- a/createpdf.pl +++ b/createpdf.pl @@ -57,10 +57,15 @@ if ($cgi->param('preset') eq 'screen') { if ($url =~ /^http/i) { $outname = "web.pdf"; + my @options = ("-f"); + + if (defined($cgi->param('color'))) { + push @options, "-c"; + } # Render through Gecko $ENV{'DISPLAY'} = $pdfweb::config::xserver; - system("gnome-web-print", $url, "$pdfweb::config::outputdir/$pdf_filename.ps"); + system("gnome-web-print", @options, $url, "$pdfweb::config::outputdir/$pdf_filename.ps"); system("gs $pdfopts -dCompatbilityLevel=1.4 -dNOPAUSE -dPATCH -sDEVICE=pdfwrite -dSAFER -sOutputFile=output/$pdf_filename -c '.setpdfwrite $psopts' -f - < $pdfweb::config::outputdir/$pdf_filename.ps >&2"); } elsif ($filename =~ /(.*)\.(?:e?ps|pdf)$/i) { $outname = "$1.pdf"; @@ -155,6 +160,24 @@ EOF my $size = -s "output/$pdf_filename"; +if (defined($size) && $size > 0) { + # Make a thumbnail from the finished PDF, for later reference. (Output to + # stdout is so we make sure we get only the first page; it's the simplest + # hack I can find offhand. :-) ) + system("convert -resize 192x192 output/$pdf_filename png:- | convert png:- png:- > output/$pdf_filename.png"); + open DESC, ">output/$pdf_filename.desc"; + + if ($url =~ /^http/i) { + $url =~ tr/\n//d; + print DESC "$url\n"; + } else { + $filename =~ tr/\n//d; + print DESC "$filename\n"; + } + + close DESC; +} + (my $sanitized_outname = $outname) =~ tr/a-zA-Z0-9. -/_/c; print "Content-type: application/pdf\n";