Epspdf and epspdftk 1 Usage 1.1 Overview 1.2 Viewing 1.3 Conversion options 1.4 Converting 1.5 The configuration screen 1.5.1 Configuring viewers 1.5.2 Options for converting to pdf 1.5.3 Options for converting to PostScript 2 Command-line usage 2.1 Option summary 3 Notes on PostScript and pdf 3.1 Bitmapped and vector 3.2 Font embedding 3.3 Eps preview headers 3.4 Bounding- and other boxes 3.5 Orientation 3.6 Exporting PostScript or pdf from Windows programs 4 Bitmapped graphics for LaTeX and pdflatex 4.1 Linux 4.2 Mac OS 4.3 Windows 5 Troubleshooting 5.1 No options for output format visible 5.2 Ghostscript stackunderflow error 5.3 Error message mentioning failure of pdf_crop 5.4 Wrong boundingbox (.eps or .ps output) 5.5 Part of the graphic gets cut off 5.6 Fonts look ugly 5.7 The page has been converted to a bitmap 5.8 Temporary files are not removed 5.9 Resources for troubleshooting Appendix A Requirements Appendix B Change history B.1 Version 0.6.5.1 B.2 Version 0.6.5 B.3 Version 0.6.4 B.4 Version 0.6 B.5 Version 0.5 B.6 Version 0.4 Epspdf and epspdftk ******************* This manual is for epspdf and epspdftk, version 0.6.5.1. Copyright © 2006-2023 Siep Kroonenberg. Copying and distribution of this file, with or without modification, are permitted in any medium without royalty provided the copyright notice and this notice are preserved. This file is offered as-is, without any warranty. 1 Usage ******* 1.1 Overview ============ Epspdftk is a GUI program that converts files between eps, pdf and general PostScript in any direction. It lets you interactively select a file, set conversion options, and save in the same of another format. A configuration screen offers some additional conversion options. 1.2 Viewing =========== The View button at the bottom of the screen invokes an external viewer. Windows and Mac OS: Epspdftk simply tries to use the default Open command. Under Linux the PostScript- and pdf viewers are configurable; see *note The configuration screen::. The View button is grayed if epspdf thinks that there is no previewer for the current file. 1.3 Conversion options ====================== • Grayscaling • Compute tight boundingbox. This option is only available if a single page is converted. • Page selection. The only possibilities are selecting a single page or selecting all pages. Converting to eps implies selecting a single page. Note. For general PostScript files, there is no quick way to determine the number of pages, so the program may not check beforehand whether you picked an existing page. If you don’t like that, convert the entire document to pdf first – which will be done behind the scenes anyway. Specifying options such as grayscaling or page selection may require a multistep conversion. 1.4 Converting ============== The Convert and save... button calls up a file save dialog. After a successful conversion, the result becomes the new current file, so you can judge the result by pressing the View button again – if epspdftk thinks that there is a suitable viewer. 1.5 The configuration screen ============================ Epspdftk also has a configuration screen. The settings here are preserved between sessions. 1.5.1 Configuring viewers ------------------------- Under Unix, the preferred PostScript- and pdf viewers can be configured in this screen. Epspdf looks for a number of PostScript- and pdf viewers, from which you can select one, but you can also enter one manually. Some viewers require a plugin for eps and PostScript. The GUI does not check whether such a plugin is actually installed. For Windows and Mac OS there is no such configuration option. Epspdf will use the program associated with the file type, which can be configured outside of epspdf. 1.5.2 Options for converting to pdf ----------------------------------- Double-check the setting “Target use” under “Conversion to pdf”. “prepress” is for pdfs which are going to be printed commercially. The options prepress, printer and default will try to embed all fonts. Often, printshops insist on this. On the other hand, you may prefer “screen” if file size is a concern. See also the Ghostscript documentation, in particular Use.htm and VectorDevices.htm. Specifying anything other than “default” may cause an additional conversion step and possibly also loss of high-level structure. As to pdf versions: this is a trade-off between more features for higher versions and better compatibility for lower versions. Versions below 1.4 do not support transparency. Converting a page or graphic with transparencies to version 1.3 will probably result in the whole page or graphic getting rasterized. For prepress use, consult your printshop or publisher. Otherwise leave the pdf version at “default”. 1.5.3 Options for converting to PostScript ------------------------------------------ For conversion to plain or Encapsulated PostScript, pdftops sometimes does a better job of preserving fonts than Ghostscript. Under Windows, current versions of both MiKTeX and TeX Live include pdftops. Still, you may opt not to use pdftops even if it is available, in which case Ghostscript will be used instead. 2 Command-line usage ******************** epspdf.tlu is the backend of epspdftk, but it can also be used standalone. It shares configuration settings with epspdftk.tcl. The first parameter of the epspdftk GUI program is interpreted as startup directory for the file browser. Epspdf itself has a more elaborate command-line interface. Below, we assume that there is a suitable wrapper or symlink for epspdf on your searchpath. This is the case if you installed epspdf as a TeX Live- or MiKTeX package. Basic usage of epspdf itself: epspdf [OPTIONS] INFILE [OUTFILE] 2.1 Option summary ================== Typing ‘epspdf --help’ gives you the following summary: $ epspdf --help Epspdf version 0.6.5.1 Copyright (c) 2006-2023 Siep Kroonenberg Convert between [e]ps and pdf formats Usage: epspdf[.tlu] [options] infile [outfile] Default for outfile is file.pdf if infile is file.eps or file.ps Default for outfile is file.eps if infile is file.pdf -p, --page, --pagenumber PNUM Page number; must be a positive integer -g, --grey, --gray, -G, --GREY, --GRAY Convert to grayscale -b, --bbox, --BoundingBox Compute tight boundingbox -T, --target TARGET One of screen, ebook, printer, prepress or default -N, --pdfversion VERSION One of 1.2, 1.3, 1.4, 1.5, 1.6, 1.7 or default -U Use pdftops if available -I Reverses the above -s, --save Save some settings to configuration file -i, --info Info: display detected filetype and exit -d Debug: do not remove temp files -v, --version Display version info and exit -h, --help Display this help message and exit 3 Notes on PostScript and pdf ***************************** 3.1 Bitmapped and vector ======================== Pictures can be described either in terms of pixels, or more abstractly, in terms of geometric shapes, fonts and text. Bitmapped or pixel-based graphics are appropriate for photographs and screenshots, but less so for diagrams and spreadsheet-generated graphics. A file in PostScript- or pdf format can contain both types of graphic data. Vector graphics can be freely scaled without losing sharpness or becoming pixellated. If bitmapped graphics are enlarged too much, individual pixels become apparent. With low-resolution bitmaps this happens sooner than with high-resolution bitmaps, but high-resolution bitmaps have (much) larger file sizes, and take longer to process. So avoid converting vector to bitmap. However, converting from bitmap to vector is also best avoided, since it is very hard to do well. Epspdf usually avoids conversion from vector to bitmap and never converts the other way. With the screen- and ebook “Target use” option, included bitmaps tend to be downsampled, i.e. reduced to a lower resolution. 3.2 Font embedding ================== When converting to pdf, Ghostscript handles font embedding differently depending on the “Target use” option. According to the Ghostscript documentation, it embeds all fonts without exception for all targets except “screen”, for which standard fonts such as Times may be omitted. 3.3 Eps preview headers ======================= Preview headers are quietly stripped from eps files. These preview headers are used by e.g. desktop-publishing software to represent eps files on screen without having to interpret the PostScript code itself. Epspdf has no option to preserve or add them. 3.4 Bounding- and other boxes ============================= A PostScript file may have a page size and a boundingbox defined. A pdf file may have a mediabox, a trimbox and various other boxes. Ghostscript by itself normally converts the PostScript page – which is anchored at (0,0) – to the pdf mediabox. Conversion to pdf usually translates the bottom-left corner to the (0,0) origin and sets the ...box to the size of the graphic. Anything outside the ...box should be cut off. 3.5 Orientation =============== Ghostscript may not be able to determine the right orientation of a PostScript- or pdf file. This may result in part of a graphic being cut off after conversion or even everything falling outside the page / mediabox / boundingbox. 3.6 Exporting PostScript or pdf from Windows programs ===================================================== Microsoft Office 2010 can now export to pdf, either the entire document or a selection. This removes a major headache for Windows users. Windows 10 also includes a pdf printer. As a last resort on earlier Windows versions, you can “print” to a PostScript file. From some programs, you can print a selection. A suitable driver which comes with Windows is Generic / MS Publisher Color Printer. Pay attention to the printer properties: choose “Outline” for font downloading and avoid the “Optimize for speed” setting for PostScript Output Option. In my tests, “Encapsulated PostScript” did not look very promising either. Try e.g. “Archive” instead. These options can be found under the Advanced button. 4 Bitmapped graphics for LaTeX and pdflatex ******************************************* pdflatex can use graphics in .png format (best for screenshots) and .jpg format (best for photographs) directly. However, for LaTeX you are stuck with .eps format. Tips for converting to .eps: 4.1 Linux ========= _sam2p_ This command-line bitmap-to-PostScript/pdf conversion utility is available from and may already be packaged for your distribution. It produces very small files: ‘sam2p image.png image.eps’ _ImageMagick/convert_ ‘convert’ from the ImageMagick package is a command-line utility: ‘convert image.png image.eps’ _The GIMP_ This is the premier open source image editing program. It is often pre-installed on Linux, and is also available for other platforms. The GIMP can save in eps- and pdf format. 4.2 Mac OS ========== Mac OS’s built-in Preview application can read most bitmapped formats and save them as pdf or PostScript. In fact, in many cases it is an excellent alternative to epspdf. 4.3 Windows =========== I know of no built-in facility for converting bitmaps to eps or pdf, apart from “printing” to PostScript or pdf. However, many image editors can convert to eps or pdf. A couple of command-line utilities: sam2p image.png image.eps or bmeps -c image.png image.eps sam2p is distributed with TeX Live (Windows only), bmeps both with TeX Live and with MikTeX. Without the ‘-c’ option, bmeps produces a grayscale image. It produces larger files than sam2p. With TeX Live, you can convert to eps by right-clicking an image in Windows Explorer and “open” with _bitmap2eps_, which uses sam2p or bmeps in the background. 5 Troubleshooting ***************** 5.1 No options for output format visible ======================================== Widen the window, to make the output format radio buttons visible. 5.2 Ghostscript stackunderflow error ==================================== Some Ghostscript versions, _e.g._ 9.10, have an error in color handling when converting to pdf: selecting “printer” as target may lead to an error ‘stackunderflow in .setdistillerparams’. If you run into this, use the “default” or “prepress” target instead. 5.3 Error message mentioning failure of pdf_crop ================================================ Problably, the luatex format has not been generated. Fix this with TeX Live Manager or with the MiKTeX Console. 5.4 Wrong boundingbox (.eps or .ps output) ========================================== This may be a bug in pdftops. Do not use pdftops (epspdftk: see configuration screen; command-line epspdf: use the “-I” option) 5.5 Part of the graphic gets cut off ==================================== If the PostScript file was generated with the old Windows PostScript driver, experiment with the PostScript Output option. Don’t choose Optimize for Speed. 5.6 Fonts look ugly =================== If Ghostscript has to do the conversion from pdf to ps then text may not remain text, but may be replaced by bitmaps. Newer Ghostscript versions tend to do better in this respect than older ones, but as to preserving fonts, the pdftops utility may still handle more cases. It is part of the xpdf suite and of the Poppler utilities. 5.7 The page has been converted to a bitmap =========================================== The usual cause is that the page contains features such as transparency which are not supported by the target format. Otherwise, set pdf target use and target version both to “default” to avoid unnecessary conversions: ‘-T default -N default’ 5.8 Temporary files are not removed =================================== • Command-line: make sure that you did not specify the option ‘-d’. • Epspdftk GUI: make sure that ‘Remove temp files’ is checked. • Windows: this platform is notorious for excessive file locking. I already inserted a Windows-specific delay before attempting to delete the temporary files, but this is not always enough. However, you should have no trouble removing temporary files manually. 5.9 Resources for troubleshooting ================================= Logfile. The GUI has a button for viewing log output. This same output is also written to a file ‘epspdf.log’. For Linux/Unix/Mac Mac OS this is in a subdirectory .epspdf of your home directory; for Windows it is in a subdirectory epspdf of ‘%APPDATA%’. This APPDATA directory may be ‘c:\Users\YOUR USER NAME\AppData\Roaming’. Type echo %APPDATA% in a Command Prompt window to find out which. The logfile lists all epspdf calls and all Ghostscript- and pdftops calls plus error information. Temporary files. The temporary files may give clues as well. Uncheck the button “Remove temp files”, or for the command-line version, give a -d parameter to keep the temporary files. Check the log(file) as to which temporary files have been created. Ghostscript- and pdftops documentation. For Ghostscript, the most important files are VectorDevices.htm and Use.htm. For pdftops, type ‘pdftops -h’. For Unix, there is also a man page, and for Windows there is a file pdftops.txt in the distribution zip. TeX Live includes the man page in pdf format: pdftops.pdf. Appendix A Requirements *********************** Epspdftk consists of a GUI front end and a command-line back end. The command-line component, which can be used separately from the front end, requires ghostscript and a not too old TeX installation with luatex. It may further benefit from the presence of pdftops. MiKTeX and TeX Live for Windows meet these requirements out of the box. The front end requires a Tcl/Tk installation, or at least a tclkit runtime. TeX Live for Windows contains either a tclkit runtime or a minimal Tcl/Tk installation since late 2018, and epspdftk as a TeX Live package will make use of it. The minimum version is 8.5. At the time of writing, this front end does not work under MiKTeX; I do not know why not. The alternative epspdf-setup package for Windows with an embedded Tcl/Tk runtime and an installer has been withdrawn, since it was only useful on MiKTeX. Appendix B Change history ************************* B.1 Version 0.6.5.1 =================== Epspdf: An erroneous and unnecessary check for writability, with possible security implications, has been removed. For MiKTeX, os.execute replaces os.spawn invocations, since os.spawn gave trouble in my tests on MiKTeX. B.2 Version 0.6.5 ================= Epspdf: Compatibility change for ghostscript 9.50 and later. Epspdftk: improvements to viewer selection; does not impact Windows or MacOS. A few updates to the manual, mostly for the troubleshooting section. B.3 Version 0.6.4 ================= Compatibility changes for luatex 1.9 and later. The location of pdftops is no longer configurable; it is only searched for on the searchpath. Some corner cases should be handled more successfully. The GUI now requires Tcl/Tk version 8.5 or higher. On Windows, epspdf.tlu is now invoked via a batchfile. This should prevent black console windows popping up. B.4 Version 0.6 =============== The command-line backend component has been rewritten in texlua and therefore no longer needs an external scripting language. Grayscaling is now done by Ghostscript’s color options for pdf output. This also works for bitmaps. Croppping of pdfs is now accomplished by running luatex on a suitable wrapper file (same method as Heiko Oberdiek’s pdfcrop). Such a conversion preserves advanced features which might otherwise get lost. I no longer try to provide an AppleScript wrapper. The current version has no provisions for custom Ghostscript- or pdftops parameters. The corresponding command-line options are accepted but have no effect. B.5 Version 0.5 =============== The GUI has been rewritten in Tcl/Tk, removing the dependence on the Ruby/Tk interface library. The Windows installer now installs a small Ruby subset and the standard epspdf distribution, but with epspdftk.tcl replaced with a starpack: a single executable containing ‘epspdftk.tcl’ and a Tcl/Tk runtime. See . Epspdf now uses its own subdirectory for both the logfile and the configuration file. For Linux/Unix/Mac OS this is ‘$HOME/.epspdf’, for Windows it is ‘%APPDATA%\epspdf’. On all supported platforms, settings are stored in the file ‘config’ in this directory. Under Windows, the registry is no longer used for this. A button has been added to view log output. There is a second new button “Remove temp files”, which is normally checked, causing temporary files to be deleted after each conversion. Unchecking this button may be useful for troubleshooting. In previous versions, temporary files were deleted at the end of the entire epspdftk session but that has become less practical now that the GUI and epspdf itself have become two separate programs. The “Open with...” option for Windows has been dropped for technical reasons. The “–version” option now prints the version string instead of setting the desired pdf version. The “–info” option now also prints the number of pages for pdf files. B.6 Version 0.4 =============== Hi-res boundingboxes are now supported. By default, conversion from eps to pdf now uses the hires boundingbox as “page” to determine the page dimensions of the pdf file. Other conversions preserve or generate a hires boundingbox. Under Windows, the new version looks for an installed TeX and will use its private Ghostscript if it cannot find a separately installed Ghostscript. TeX Live’s pdftops, being on the searchpath, will be used unless epspdf finds another copy first. There is now a “-v” (lowercase) option to print the version string.