TTF2UFM_CONVERT(1) TTF2UFM Font Converter TTF2UFM_CONVERT(1)

ttf2ufm_convert - convenience font conversion script

ttf2ufm_convert [config-file]

`Convert' is the master conversion script provided with ttf2ufm. When installed into a public directory it's named `ttf2ufm_convert' to avoid name collisions with the other programs.

If the configuration file is not specified as an argument then the file `"convert.cfg"' in the current directory is used. This file contains a set of configuration variables. The distribution contains a sample file file `"convert.cfg.sample"'. Please copy it to `"convert.cfg"', look inside it and change the configuration variables. The more stable configuration variables, such as the path names of the scripts and encoding files are located in `"convert"' itself, they are automatically updated when installing ttf2ufm.

Put all the TTF fonts you want to convert into some directory (this may be just the directory that already contains all the Windows fonts on a mounted FAT filesystem). If you have fonts in different source encoding then put the fonts in each of the encodings into a separate directory. Up to 10 source directories are supported. If you (in a rather unlikely case) have more source directories then you can make two separate runs of the converter, converting up to 10 directories at a time.

The variables in the configuration file are:

The next few parameters control the general behavior of the converter. They default values are set to something reasonable.

The following parameters are used to locate the other scripts and configuration files. By default the scripts do a bit of guessing for them: they search in the ttf2ufm installation directory if ttf2ufm was installed or otherwise suppose that you are running `"convert"' with `"scripts"' subdirectory being the current directory.

Besides that a few parameters are built into the `"convert"' script itself. You probably won't need to change them:

"T1ASM", "TTF2UFM", "TRANS", "T1FDIR", "FORCEISO" - paths to the other script

Also there are a few parameters controlling the installation of fonts for Ghostscript. Please look at their description in the Ghostscript section of documentation or in the ttf2ufm_x2gs(1) manual page before running `"convert"'. If these parameters are set, `"convert"' will call the `"x2gs"' script automatically to install the newly converted fonts in Ghostscript.

After creating the configuration file run the `"convert"' script. Look at the result and the log file in "DSTDIR".

Add the directory with newly converted fonts to the configuration of X server or font server. For most of the systems this step is very straightforward. For HP-UX it's rather tricky and poorly documented, so the file FONTS.hpux gives a short description.

If you don't have the privileges of the root user, you still can configure your private font server. Just use some non-standard port number (see FONTS.hpux for an example, exept that you won't need all the HP-related stuff on any other system).

  • One catch is that the X11 Type 1 font library has a rather low limit on the font size. Because of this the fonts with more complicated outlines and the enabled hint substitution may not fit into this limit. The same applies to the fonts with very complicated outlines or with very many glyphs (especially the fonts with over 256 glyphs). So you will need to excercise caution with these options if you plan using these fonts with X11. Some vendors such as HP provide the Type 1 implementation licensed from Adobe which should have no such problem.

    But there is a solution even for the generic X11. A patch located in the subdirectory `"app/X11"' fixes this problem as well as some other minor problems. Its description is provided in app/X11/README.

    To fix the X11 font library, you have to get the X11 sources. I can recommend the ftp sites of the XFree86 project ftp://ftp.xfree86.org or of the Open Group ftp://ftp.x.org. This patch was made on the sources of XFree86 so you may have better success with applying it to the XFree86 distribution. After you have got the sources, make sure that you can compile them. Then apply the patch as described. Make sure that it was applied properly. Compile the sources again (actually, you need only the fonts library, the fonts server, and possibly the X server). It would be prudent now to save your old font library, font server and, possibly, X server. Then install the new recently compiled versions of these files. Of course, if you know someone who already has compiled these files for the same OS as yours, you can just copy the binary fles from him.

    Alas, building the X11 system from the source code is not the easiest thing in the world and if you have no experience it can be quite difficult. In this case just avoid the aforementioned features or check each converted font to make sure that it works properly.

  • The Type1 font library from the standard X11 distribution does not work on HP-UX (at least, up to 10.01). The font server supplied with HP-UX up to 10.01 is also broken. Starting from HP-UX 10.20 (I don't know about 10.10) they supply a proprietary font library and the converted fonts work fine with it, provided that they are configured properly (see the file FONTS.hpux).
  • The "fonts.scale" files created by the older versions of the "ttf2ufm" installation program (up to release 3.1) have conflicted with the language definitions of the "Xfsft" font server and parts of it included into XFree86. To overcome this incompatibility the never versions creats the "fonts.scale" file describing all the fonts as belonging to the "adobe-fontspecific" encoding and the "fonts.alias" file with the proper names. The drawback of this solution is that "xlsfonts" gives the list of twice more fonts. But as a side effect the option "ENFORCEISO" in `"convert.cfg"' is not required for X11 any more.
  • The conversion script has no support for Eastern multi-plane fonts. Contribution of such a support would be welcome.
December 31, 2003 version 3.4.4