Skip to content

Latest commit

 

History

History
221 lines (141 loc) · 7.81 KB

README.md

File metadata and controls

221 lines (141 loc) · 7.81 KB

foponts project

Table of contents

About

foponts is a simple configuration file for using in conjunction with Apache FOP. Its aim is to produce pretty looking .pdf files using only free OFL-licensed fonts to avoid any patent- or/and license-related issues.

BTW, if you are not aware about what Apache FOP is suitable for, check out its FAQ.

foponts is for anyone who creates .pdf files using Apache FOP. It's specially designed and highly recommended for everyone working with DocBook/XML files and who wants to get a predictable result without any hassle.

foponts is strongly recommended when:

  • you are not sure about fonts you are using and/or have and feel uncomfortable with any patent-related issues with fonts within your documents;
  • you want to be sure that you use fonts that are free to use anywhere, where OFL license allows you to do (in fact, you can use these fonts virtually everywhere);
  • you are using Cyrillic characters in your documents or deal with cyrillic documents only (i.e. work with documents in Russian) and want to get a .pdf files without any hassle - you are boring to get a document full of #### signs instead of actual Cyrillic characters.

Installation

Prerequisites

  1. Any machine (PC, Mac, headless server, ...) with OS, that supports Java.
  2. Java (JRE) 1.6 or newer installed and working. Check if Java is installed correctly:
$ java -version
  1. Apache FOP 2.1 or newer. You can get the latest FOP from official download page. Check if APache FOP is installed correctly:
$ fop -version
  1. Git - to clone the repo.
  2. Any utility (or web browser) - to download files (wget is recommended).
  3. Any utility that can extract bzipped tar (.tar.bz2) archives.
  4. Any .fo file (document) you need to get a .pdf file from. You have to have a serif, sans-serif and monospace font families within your .fo file.

NOTE 1: To check how foponts works, a sample .fo file is provided within a docbook-samples directory (direct link to a sample file

NOTE 2: Due to samples, used in this project, are the core of another project, docbook-samples directory is provided as a git submodule within a current project.

Installation modes and steps

About installation modes

There are 2 installation modes of the foponts:

  • All on-premises (AOP) mode - you will have all files on your computer or server. This mode assumes you take foponts and appropriate fonts, either from fonts publishers websites, or from the foponts author's website in a single all-in-one .tar.bz2 archive.

  • Fonts on demand (FOD) mode - you take only foponts and store it on your machine. All fonts that are needed to render your files will be dowloaded on demand from the author's website every time you will render a documents using Apache FOP and foponts.

NOTE 1: FOD mode may descrease rendering speed, because all fonts used in a certain document are downloaded through the internet every time a document is rendered.

NOTE 2: There are no hidden links or other obstructive stuff with a font files. All fonts from the author's website are available using direct plain URLs. See related FAQ topic.

Installation in AOP mode

  1. Create a directory, where you want to store the project:
$ mkdir foponts-pdf-generation
  1. Change a directory to the created one:
$ cd foponts-pdf-generation
  1. Get the archive from the author's website with all fonts included:
$ wget http://www.singlesourcing.ru/pub/foponts/dist/foponts-fonts.tar.bz2
  1. Extract archive content to the created folder:
$ tar -xjf foponts-fonts.tar.bz2
  1. Get the foponts project:
$ git clone --recursive https://github.com/eduardtibet/foponts.git

NOTE: You have to use --recursive option, because the directory with samples is a separate author's project and is included as a git submodule here!

  1. Change a directory to the foponts project:
$ cd foponts
  1. foponts is initially configured to run in a FOD mode, so use your favorite text editor to change the default value of a <font-base> element in foponts.xml file to the actual local path to a directory with downloaded fonts:

Default:

<font-base>http://www.singlesourcing.ru/pub/foponts/foponts-fonts/</font-base>

How you could change it (a sample):

<font-base>/home/[your_user_directory]/foponts-pdf-generation/foponts-fonts/</font-base>

NOTE: Trailing slash is a must thing here!

Installation in FOD mode

  1. Create a directory, where you want to store a foponts:
$ mkdir foponts-pdf-generation
  1. Change directory to the created one:
$ cd foponts-pdf-generation
  1. Get the foponts project:
$ git clone --recursive https://github.com/eduardtibet/foponts.git

NOTE: You have to use --recursive option, because the directory with a samples is a separate author's project and is included as a git submodule here!

  1. Change a directory to the foponts project:
$ cd foponts
  1. Check that you have a stable internet connection, due to all required fonts will be downloaded on demand.

Usage

To your reference, this readme and all procedures within it assumes the following directory structure:

foponts-pdf-generation
  |
  /foponts
  |  |
  |  /docbook-samples
  |     |
  |     /stdf
  /foponts-fonts *(in case you use AOP mode)*

To use foponts project to generate a .pdf file from your .fo file:

  1. Run FOP with the following command line (an example below shown how to generate a .pdf from a project's sample .fo file):
$ fop -c foponts.xml -fo docbook-samples/stdf/stdf_manual.fo -pdf docbook-samples/stdf/stdf_manual.pdf
  1. Look at the result by opening the generated stdf_manual.pdf file (or any other generated file of your own) in your favorite PDF viewer:
$ xpdf docbook-samples/stdf/stdf_manual.pdf

You can compare the result with the reference file, generated by the author of foponts. It can be downloaded from:

$ wget http://www.singlesourcing.ru/pub/docbook-samples/stdf/stdf_manual.pdf

FAQ

See FAQ.

Roadmap

See TODO.

Contributing

It fully depends on a type of your contribution:

  1. If you found a bug or have any amazing RFE - just create an issue.
  2. If you want to add new features to foponts - just fork foponts project, make any alternation you want and create a pull request.

Authors

  • Eduard Tibet eduardtibet - initial work based on the stock Apache FOP configuration file. See the original file if you are interested in.

License

This project is licensed under the Apache License 2.0 - see the LICENSE for more details.