122 lines
3.9 KiB
Plaintext
122 lines
3.9 KiB
Plaintext
Due to our use of `libtool' to generate and install the FreeType 2
|
|
libraries on Unix systems, as well as other historical events, it is
|
|
generally very difficult to know precisely which release of the font
|
|
engine is installed on a given system.
|
|
|
|
This file tries to explain why and to document ways to properly detect
|
|
FreeType on Unix.
|
|
|
|
|
|
1. Version and Release numbers
|
|
------------------------------
|
|
|
|
For each new public release of FreeType 2, there are generally *three*
|
|
distinct `version' numbers to consider:
|
|
|
|
* The official FreeType 2 release number, like 2.3.1 or 2.4.10.
|
|
|
|
* The libtool (and Unix) specific version number, like 13.0.7. This
|
|
is what `freetype-config --version' returns.
|
|
|
|
* The platform-specific shared object number, used for example when
|
|
the library is installed as `/usr/lib/libfreetype.so.6.7.1'.
|
|
|
|
The platform-specific number is, unsurprisingly, platform-specific and
|
|
varies with the operating system you are using (several variants of
|
|
Linux, FreeBSD, Solaris, etc.). You should thus _never_ use it, even
|
|
for simple tests.
|
|
|
|
The libtool-specific number does not equal the release number but is
|
|
tied to it.
|
|
|
|
The release number is available at *compile* time through the following
|
|
macros defined in FT_FREETYPE_H:
|
|
|
|
- FREETYPE_MAJOR: major release number
|
|
- FREETYPE_MINOR: minor release number
|
|
- FREETYPE_PATCH: patch release number
|
|
|
|
See below for a small autoconf fragment.
|
|
|
|
The release number is also available at *runtime* through the
|
|
`FT_Library_Version' API.
|
|
|
|
|
|
2. History
|
|
----------
|
|
|
|
The following table gives, for all releases since 2.3.0, the
|
|
corresponding libtool number, as well as the shared object number found
|
|
on _most_ systems, but not all of them:
|
|
|
|
|
|
release libtool so
|
|
-------------------------------
|
|
2.4.11 16.0.10 6.10.0
|
|
2.4.10 15.0.9 6.9.0
|
|
2.4.9 14.1.8 6.8.1
|
|
2.4.8 14.0.8 6.8.0
|
|
2.4.7 13.2.7 6.7.2
|
|
2.4.6 13.1.7 6.7.1
|
|
2.4.5 13.0.7 6.7.0
|
|
2.4.4 12.2.6 6.6.2
|
|
2.4.3 12.1.6 6.6.1
|
|
2.4.2 12.0.6 6.6.0
|
|
2.4.1 11.1.5 6.5.1
|
|
2.4.0 11.0.5 6.5.0
|
|
2.3.12 10.0.4 6.4.0
|
|
2.3.11 9.22.3 6.3.22
|
|
2.3.10 9.21.3 6.3.21
|
|
2.3.9 9.20.3 6.3.20
|
|
2.3.8 9.19.3 6.3.19
|
|
2.3.7 9.18.3 6.3.18
|
|
2.3.6 9.17.3 6.3.17
|
|
2.3.5 9.16.3 6.3.16
|
|
2.3.4 9.15.3 6.3.15
|
|
2.3.3 9.14.3 6.3.14
|
|
2.3.2 9.13.3 6.3.13
|
|
2.3.1 9.12.3 6.3.12
|
|
2.3.0 9.11.3 6.3.11
|
|
|
|
|
|
3. Autoconf Code Fragment
|
|
-------------------------
|
|
|
|
Lars Clausen contributed the following autoconf fragment to detect which
|
|
version of FreeType is installed on a system. This one tests for a
|
|
version that is at least 2.0.9; you should change it to check against
|
|
other release numbers.
|
|
|
|
|
|
AC_MSG_CHECKING([whether FreeType version is 2.0.9 or higher])
|
|
old_CPPFLAGS="$CPPFLAGS"
|
|
CPPFLAGS=`freetype-config --cflags`
|
|
AC_TRY_CPP([
|
|
|
|
#include <ft2build.h>
|
|
#include FT_FREETYPE_H
|
|
#if (FREETYPE_MAJOR*1000 + FREETYPE_MINOR)*1000 + FREETYPE_PATCH < 2000009
|
|
#error Freetype version too low.
|
|
#endif
|
|
],
|
|
[AC_MSG_RESULT(yes)
|
|
FREETYPE_LIBS=`freetype-config --libs`
|
|
AC_SUBST(FREETYPE_LIBS)
|
|
AC_DEFINE(HAVE_FREETYPE,1,[Define if you have the FreeType2 library])
|
|
CPPFLAGS="$old_CPPFLAGS"],
|
|
[AC_MSG_ERROR([Need FreeType library version 2.0.9 or higher])])
|
|
|
|
------------------------------------------------------------------------
|
|
|
|
Copyright 2002-2012 by
|
|
David Turner, Robert Wilhelm, and Werner Lemberg.
|
|
|
|
This file is part of the FreeType project, and may only be used,
|
|
modified, and distributed under the terms of the FreeType project
|
|
license, LICENSE.TXT. By continuing to use, modify, or distribute this
|
|
file you indicate that you have read the license and understand and
|
|
accept it fully.
|
|
|
|
|
|
--- end of VERSION.DLL ---
|