In the case of multiple resource directories, the default ResourceFileName procedure retrieves either a path to the first avaliable resource, or if the resource is not available it returns a path starting with GenericResourceDir. Consequently Postscript installers of Postscript resources will overwrite an existing resource or add a new one to the first resource directory. To look up fonts, after exhausting the search method described in the next section , it concatenates together.
Ghostscript has a slightly different way to find the file containing a font with a given name. See the documentation of fonts for details. Then, when Ghostscript needs to find a font that isn't already loaded into memory, it goes through a series of steps.
CID fonts e. Chinese, Japanese and Korean are found using a different method. SGI in place of Fontmap or Fontmap. It says: "15 files, 15 scanned, 0 new fonts". We think this problem has been fixed in Ghostscript version 6. See Fontmap. Sol instead. Also, on Solaris 2. The fonts Sun distributes on Solaris 2. These paths may not be exactly right for your installation; if the indicated directory doesn't contain files whose names are familiar font names like Courier and Helvetica, you may wish to ask your system administrator where to find these fonts.
Adobe Acrobat comes with a set of fourteen Type 1 fonts, on Unix typically in a directory called There is no particular reason to use these instead of the corresponding fonts in the Ghostscript distribution which are of just as good quality , except to save about a megabyte of disk space, but the installation documentation explains how to do it on Unix.
CID fonts are PostScript resources containing a large number of glyphs e. Please refer to the PostScript Language Reference, third edition, for details.
CID font resources are a different kind of PostScript resource from fonts. In particular, they cannot be used as regular fonts. CID font resources must first be combined with a CMap resource, which defines specific codes for glyphs, before it can be used as a font.
This allows the reuse of a collection of glyphs with different encodings. Another method is possible using the composefont operator. They are not found using Font lookup on the search path or font path.
In general, it is highly recommended that CIDFonts used in the creation of PDF jobs should be embedded or available to Ghostscript as CIDFont resources, this ensures that the character set, and typeface style are as intended by the author. In cases where the original CIDFont is not available, the next best option is to provide Ghostscript with a mapping to a suitable alternative CIDFont - see below for details on how this is achieved.
As shipped, this uses the DroidSansFallback. This font contains a large number of glyphs covering several languages, but it is not comprehensive. There is, therefore, a chance that glyphs may be wrong, or missing in the output when this fallback is used.
As with any font containing large numbers of glyphs, DroidSansFallback. The build system will cope with the file being removed, and the initialization code will avoid adding the internal fall back mapping if the file is missing.
If DroidSansFallback. As the name suggests, this will result in all the glyphs from a missing CIDFont being replaced with a simple bullet point. This type of generic fall back CIDFont substitution can be very useful for viewing and proofing jobs, but may not be appropriate for a "production" workflow, where it is expected that only the original font should be used.
The file forms a table of records, each of which should use one of three formats, explained below. Note that the default Ghostscript build includes such configuration and resource files in a rom file system built into the executable. So, to ensure your changes have an effect, you should do one of the following: rebuild the executable; use the "-I" command line option to add the directory containing your modified file to Ghostscript's search path; or, finally, build Ghostscript to use disk based resources.
Please pay attention that both them must be designed for same character collection. The trailing semicolon and the space before it are both required. If the array consists of 2 elements, the first element is a string, which specifies Ordering ; the second element is a number, which specifies Supplement. If the array consists of 3 elements, the first element is a string, which specifies Registry ; the second element is a string, which specifies Ordering ; the third element is a number, which specifies Supplement.
The TrueType font must contain enough characters to cover an Adobe character collection, which is specified in Ordering and used in documents.
The script can also be run separately e. Note that the font file path uses Postscript syntax. Because of this, backslashes in the paths must be represented as a double backslash. This can complicate substitutions for fonts with non-Roman names. This cannot be used directly in a cidfmap file because the xx notation in names is a PDF-only encoding. Instead, try something like:. This lets you specify a name using any sequence of bytes through the encodings available for Postscript strings.
There is no reliable way to generate a character ordering for truetype fonts. The 7. This is replaced in the 8. As a workaround the PDF interpreter applies an additional substitution method when a requested CID font resource is not embedded and it is not available. The latter may look some confusing for a font name, but we keep it for compatibility with older Ghostscript versions, which do so due to a historical reason.
If the CID font file is not embedded, the Adobe-Identity record depends on the document and a correct record isn't possible when a document refers to multiple Far East languages. In the latter case add individual records for specific CID font names used in the document.
Ghostscript can make use of Truetype fonts with a Unicode character set. To do so, you should generate a NOTE: non-standard! The resulting output will be compliant with the spec unlike the input. Ghostscript currently doesn't do a very good job of deleting temporary files if it exits because of an error; you may have to delete them manually from time to time.
The original PostScript language specification, while not stating a specific word sise, defines 'typical' limits which make it clear that it was intended to run as a bit environment. Ghostscript was originally coded that way, and the heritage remains within the code base. This is the only real purpose in adding support for large integers, however since that time, we have made some efforts to allow for the use of bit words; in particular the use of integers, but also lifting the 64K limit on strings and arrays, among other areas.
Even when the build supports bit words, you should be aware that there are areas of Ghostscript which do not support bit values. Sometimes these are dependent on the build and other times they are inherent in the architecture of Ghostscript the graphics library does not support bit co-ordinates in device space for example, and most likely never will. Note that the extended support for bit word size can be disabled by executing 'true. The Ghostscript distribution includes some Unix shell scripts to use with Ghostscript in different environments.
These are all user-contributed code, so if you have questions, please contact the user identified in the file, not Artifex Software.
For instance,. If the "directory" name ends with a closing square bracket " ] ", it is taken to refer to a real directory, for instance. To preserve the case of switches, quote them like this:. If you are using on an X Windows display, you can set it up with the node name and network transport, for instance.
When passing options to ghostcript through a batch file wrapper such as ps2pdf. For example:. There is also an older version for MS Windows called just gswin32 that provides its own window for the interactive postscript prompt. For printer devices, the default output is the default printer. This can be modified as follows. Invoking Ghostscript from the command prompt in Windows is supported by the Windows executable described above.
In addition to the device parameters recognized by all devices , Ghostscript's X driver provides parameters to adjust its performance. Users will rarely need to modify these. Note that these are parameters to be set with the -d switch in the command line e.
Xdefaults file. Because of bugs in the SCO Unix kernel, Ghostscript will not work if you select direct screen output and also allow it to write messages on the console. If you are using direct screen output, redirect Ghostscript's terminal output to a file.
Because Ghostscript must initialize the PostScript environment before executing the commands specified by this option it should be specified after other setup options.
Specifically this option 'bind's all operations and sets the systemdict to readonly. Note that by "library files" here we mean all the files identified using the search rule under " How Ghostscript finds files " above: Ghostscript's own initialization files, fonts, and files named on the command line.
This means that -p can do the job of both -d and -s. Broadly, only use -p if you cannot set what you want using -s or -d. Also, internally, after setting an parameter with -p we perform an initgraphics operation. This is required to allow changes in parameters such as HWResolution to take effect. This means that attempting to use -p other than at the start of a page is liable to give unexpected results. However, device parameters set this way PageSize , Margins , etc. As noted above, -d and -s define initial values for PostScript names.
Some of these names are parameters that control the interpreter or the graphics engine. Otherwise, images are rendered using the nearest neighbour scaling Bresenham's line algorithm through the image, plotting the closest texture coord at each pixel. When downscaling this results in some source pixels not appearing at all in the destination. When upscaling, each source pixels will cover at least one destination pixel. This allows for a performance vs.
Every source pixel will contribute partially to the destination pixels. Computationally, image interpolation is much more demanding than without interpolation lots of floating point muliplies and adds for every output pixel vs simple integer additions, subtractions, and shifts.
In all but special cases image interpolation uses a Mitchell filter function to scale the contributions for each output pixel. When upscaling, every output pixel ends up being the weighted sum of 16 input pixels, When downscaling more source pixels will contribute to the interpolated pixels. Every source pixel has some effect on the output pixels. Note that because of the way antialiasing blends the edges of shapes into the background when they are drawn some files that rely on joining separate filled polygons together to cover an area may not render as expected with GraphicsAlphaBits at 2 or 4.
Further note; because this feature relies upon rendering the input it is incompatible, and will generate an error on attempted use, with any of the vector output devices.
PCL andPostScript cannot be handled in ths way, and so all the pages must be interpreted. Pages are scaled to fit the requested number horizontally and vertically, maintaining the aspect ratio.
If the scaling selected for fitting the nested pages leaves space horizontally on the master page, the blank area will be added to the left and right of the entire row of nested pages. If the fit results in vertical space, the blank area will be added above and below all of the rows. If there are any nested pages on the master page, the partially filled master page will be output. Printer devices typically reallocate their memory whenever the transparency use of a page changes from one page having transparency, to the next page not having transparency, or vice versa.
This would cause problems with Nup, possibly leading to lost or corrupt pages in the output. To avoid this, the Nup device changes the parameters of the page to always set the PageUsesTransparency flag.
While this should be entirely transparent for the user and not cause extra transparency blending operations during the standard rendering processes for most devices, it may cause devices to use the clist rather than PageMode. Useful only for compatibility with Adobe printers for loading some obsolete fonts. This may be useful in environments without a file system. This may be useful for debugging. This may be needed if the platform fonts look undesirably different from the scalable fonts. This may be needed to ensure consistent rendering on the platforms with different fonts, for instance, during regression testing.
Specifies alternate name or names for the Fontmap file. Note that the names are separated by " : " on Unix systems, by " ; " on MS Windows systems, and by " , " on VMS systems, just as for search paths. Also, in this case, the font returned by findfont is the actual font named fontname , not a copy of the font with its FontName changed to the requested one. The font specified fontname will be embedded instead, limiting all future users of the document to the same approximate rendering.
The value is platform dependent. It must end with a directory separator. Adobe specifies GenericResourceDir to be an absolute path to a single resource directory. Ghostscript instead maintains multiple resource directories and uses an extended method for finding resources, which is explained in "Finding PostScript Level 2 resources". Due to the extended search method, Ghostscript uses GenericResourceDir only as a default directory for resources being not installed.
Therefore GenericResourceDir may be considered as a place where new resources to be installed. The default implementation of the function ResourceFileName uses GenericResourceDir when 1 it is an absolute path, or 2 the resource file is absent.
The extended search method does not call ResourceFileName. Pages can be printed in reverse or normal order, or selected pages, including all even or all odd, and multiple collated copies can be produced. Since pages are saved until the flush command, pages can be printed multiple times, in any order.
Note that not all spot color overprint cases can be accurately simulated with a CMYK only device. For example, a case where you have a spot color overprinted with CMYK colors will be indistiguishable from a case where you have spot color equivalent CMYK colorants overprinted with CMYK colors, even though they may need to show significantly different overprint simulations. If this option is included in the command line, source device color values e.
In addition, if the output device color model matches the output intent color model, then the destination ICC profile will be the output intent ICC profile. If there is a mismatch between the device color model and the output intent, the output intent profile will be used as a proofing profile, since that is the intended rendering.
It is possible to specify a particular output intent where int is an integer a value of 0 is the same as not specifying a number. Probing of the output intents for a particular file is possible using extractICCprofiles. Finally, note that the ICC profile member entry is an option in the output intent dictionary. In these cases, the output intent specifies a registry and a standard profile e.
Ghostscript will not make use of these output intents. Instead, if desired, these standard profiles should be used with the commands specified above e. Because its possible as of PDF 2. Instead this option takes a string, which is first compared against the OutputConditionIdentifier in each OutputIntent in the array.
If the OutputConditionIdentifier is not a standard identifier then it should be Custom and the UseOutputIntent string will be matched against the value of the Info key instead. If the current directory is the first path a test is made for the iccprofiles directory. Next, the remaining paths with the string Resource in it are tested. The prefix up to the path separator character preceding the string Resource, concatenated with the string iccprofiles is used and if this exists, then this path will be used for ICCProfilesDir.
Example usage is: gs This mode should be used with caution, and. Enables access controls on files. Access controls fall into three categories, files from which Ghostscript is permitted to read, ones to which it is permitted to write, and ones over which it has "control" i. These access controls apply to all files accessed via Ghostscript's internal interface to the C library file handling. Whilst we have taken considerable pains to ensure that all the code we maintain as well as the so called "contrib" devices, that are devices included in our release packages, but not strictly maintained by the Ghostscript development team uses this interface, we have no control over thirdparty code.
It relied on restricting the function of setpagedevice to avoid the device code from being manipulated into opening arbitrary files. The application of the file permissions was done within the internal context of the Postscript interpreter, and some other aspects of the Postscript restrictions were applied in the Postscript environment. With so many of the feature's capabilities relying on the Postscript context and environment, by using other Ghostscript specific features maliciously, the restrictions could be overridden.
Whilst the path storage and application of the permissions is implemented entirely in C, it is still possible for Postscript to add and remove paths from the permissions lists see. An incompatibility exists between the pre Previously, it was possible to do the equivalent of: save.
This is no longer the case. After the call to. As the 9. Path matching is very simple: it is case sensitive, and we do not implement full featured "globbing" or regular expression matching such complexity would significantly and negatively impact performance. Similarly, you cannot grant permission through one symlink, and then reference a file directly, or through an alternative symlink - again, the matching will fail. This is a change in behaviour compared to the old code which, on Windows, was case in sensitive.
This is in recognition of changes in Windows behaviour, in that it now supports although does not enforce case sensitivity. Similarly, paths read during initialisation from Fontmap , cidfmap , and the platform specific font file enumeration e. It is included for now in case any users find a case where the 9. It means such users can keep working until we have assessed the issue, and distributed a solution. This mode also sets the. Ghostscript attempts to find an optimum balance between speed and memory consumption, but there are some cases in which you may get a very large speedup by telling Ghostscript to use more memory.
Please note that this discussion relates to devices which produce a bitmap format as the output. These parameters have no effect on the vector devices, such as pdfwrite.
All devices may use a display list "clist" and use banding when rendering PDF 1. This prevents allocation of excessively large amounts of memory for the transparency buffer stack. The number of threads should generally be set to the number of available processor cores for best throughput. This can also be useful in processing large documents when using a high-level vector output device like pdfwrite that maintains significant internal state.
For pattern tiles that are very large, Ghostscript uses an internal display list memory based clist , but this can slow things down. The current default threshold is 8Mb -- pattern tiles larger than this will be cached as clist rather than bitmap tiles. There are several debugging switches that are detected by the interpreter. These switches are available whether or not Ghostscript was built with the DEBUG macro defined to the compiler refer to building a debugging configuration.
Previous to 8. Now there are several debugging flags to allow more selective debugging information to be printed containing only what is needed to investigate particular areas.
The -Z and -T switches apply only if the interpreter was built for a debugging configuration. In the table below, the first column is a debugging switch, the second is an equivalent switch if any and the third is its usage. The following switch affects what is printed, but does not select specific items for printing:. All the short form flags for -Z have an equivalent long form. Future flags may be added with a long form only due to all the short form flags being used already.
Visual Trace allows to view internal Ghostscript data in a graphical form while execution of C code. Special instructions to be inserted into C code for generating the output. Client application rasterizes it into a window. Currently the rasterization is implemented for Windows only, in clients gswin There are two important incompletenesses of the implementation :.
The graphical output uses a hardcoded scale. An advanced client would provide a scale option via user interface. Breaks are not implemented in the client. If you need a step-by-step view, you should use an interactive C debugger to delay execution at breakpoints. The table here lists them by name and size. A guide to international paper sizes can be found at. In this environment, the relevant section of the resource file should look like this:.
Please ignore issues about UFST if you haven't got it. Important note: Third-party font renderers may be incompatible with devices that can embed fonts in their output such as pdfwrite , because such renderers may store fonts in a form from which Ghostscript cannot get the necessary information for embedding, for example, the Microtype fonts supplied with the UFST.
Connect and share knowledge within a single location that is structured and easy to search. I get unreadable cyrillic glyphs in output. You need to use a font which contains Cyrillic glyphs. The simplest solution is to embed a soft font in the PCL.
Otherwise you could try defining a different Courier font by editing fontmap. If you want to try that you will need to find a version of Courier which contains the Cyrillic glyphs, since you are presumably using Windows, you could try using the Windows version of Courier. Stack Overflow for Teams — Collaborate and share knowledge with a private group. Create a free Team What is Teams? Collectives on Stack Overflow. Learn more. Asked 2 years, 5 months ago. Active 2 years, 5 months ago.
Is there a standardized algorithm for doing so? Is there any other advice available for accomplishing this task? We've investaged this many times and in the end always revert to using other tools. We keep investigating as we are a development shop who uses and understands all elements of PCL to great detail.
If you are not really familure with PCL it will be daunting task. One of the major issues is that overtime, printers have become, for the most part, tollerent of malformed PCL and as such, creating something that follows the rules to the letter of the law is not always sufficient.
If; however, you have control over the PCL, you may be able to work it out with some amount of success. I don't mean to turn you off of this and I realize that you've come here looking for a programming answer but I have to say, this is a far from simple task and there are no 'standarized algorithms' for this that I'm aware of. If this is designed to be a tool to work alongside of somehting else you are building I'd highly recommend looking at these guys:. This is by far the most complete set of tools Windows for handling this.
There are a few others but, based on our extensive use of PCL and conversion tools over the years, this is the only one that work all the time. This is also an excellent product with has one big benefit, deployment is simple. Some of the other tools have complex software installations. This solution is very easy for us to deploy as a feature in an application. It's also faster then any tools we've tested to date at least with the PCL that we generate from our apps which is quite complex as they include specialized fonts and macros.
It's now called GhostPDL. This means you could build their language switching binary from their sources. While it worked for me whenever I needed it, Ghostscript developers recommend to stop using the language switching binary since it's 'almost non-supported' -- see KenS' comment to this answer and instead switch to using the explicit binaries pcl6.
Stack Overflow for Teams — Collaborate and share knowledge with a private group. Create a free Team What is Teams? Collectives on Stack Overflow. Learn more. Asked 12 years, 10 months ago.
0コメント