source: general/graphlib/harfbuzz.xml@ 1118ba1

12.0 12.1 kea ken/TL2024 ken/tuningfonts lazarus lxqt plabs/newcss python3.11 qt5new rahul/power-profiles-daemon renodr/vulkan-addition trunk xry111/llvm18 xry111/xf86-video-removal
Last change on this file since 1118ba1 was 1118ba1, checked in by Bruce Dubbs <bdubbs@…>, 13 months ago

Update to harfbuzz-7.2.0.

  • Property mode set to 100644
File size: 10.9 KB
RevLine 
[32e13498]1<?xml version="1.0" encoding="ISO-8859-1"?>
2<!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
3 "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
4 <!ENTITY % general-entities SYSTEM "../../general.ent">
5 %general-entities;
6
[0d7900a]7 <!ENTITY harfbuzz-download-http
[d2f49a6]8 "https://github.com/harfbuzz/harfbuzz/releases/download/&harfbuzz-version;/harfbuzz-&harfbuzz-version;.tar.xz">
[32e13498]9 <!ENTITY harfbuzz-download-ftp " ">
[1118ba1]10 <!ENTITY harfbuzz-md5sum "7c81b2fb11eebda7e597cd3bbf0d4527">
[b3a11f45]11 <!ENTITY harfbuzz-size "18 MB">
[1118ba1]12 <!ENTITY harfbuzz-buildsize "149 MB (with tests)">
13 <!ENTITY harfbuzz-time "0.7 SBU (Using parallelism=4; with tests)">
[32e13498]14]>
15
[8374093]16<sect1 id="harfbuzz" xreflabel="HarfBuzz-&harfbuzz-version;">
[32e13498]17 <?dbhtml filename="harfbuzz.html"?>
18
19
[8374093]20 <title>HarfBuzz-&harfbuzz-version;</title>
[32e13498]21
22 <indexterm zone="harfbuzz">
[8374093]23 <primary sortas="a-HarfBuzz">HarfBuzz</primary>
[32e13498]24 </indexterm>
25
26 <sect2 role="package">
27 <title>Introduction to Harfbuzz</title>
28
29 <para>
[8374093]30 The <application>HarfBuzz</application> package contains an OpenType text
[32e13498]31 shaping engine.
32 </para>
33
[429b408]34 &lfs113_checked;
[32e13498]35
36 <bridgehead renderas="sect3">Package Information</bridgehead>
37 <itemizedlist spacing="compact">
38 <listitem>
39 <para>
40 Download (HTTP): <ulink url="&harfbuzz-download-http;"/>
41 </para>
42 </listitem>
43 <listitem>
44 <para>
45 Download (FTP): <ulink url="&harfbuzz-download-ftp;"/>
46 </para>
47 </listitem>
48 <listitem>
49 <para>
50 Download MD5 sum: &harfbuzz-md5sum;
51 </para>
52 </listitem>
53 <listitem>
54 <para>
55 Download size: &harfbuzz-size;
56 </para>
57 </listitem>
58 <listitem>
59 <para>
60 Estimated disk space required: &harfbuzz-buildsize;
61 </para>
62 </listitem>
63 <listitem>
64 <para>
65 Estimated build time: &harfbuzz-time;
66 </para>
67 </listitem>
68 </itemizedlist>
69
[8374093]70 <bridgehead renderas="sect3">HarfBuzz Dependencies</bridgehead>
[32e13498]71
72 <bridgehead renderas="sect4">Recommended</bridgehead>
73 <para role="recommended">
[39291c7]74 <xref linkend="gobject-introspection"/> (required if building GNOME),
[dccc4d4]75 <xref linkend="glib2"/> (required for Pango),
[f62b93bb]76 <xref role="first" linkend="graphite2"/> (required for building
[8558044]77 <xref role="nodep" linkend="texlive"/> or
[f62b93bb]78 <xref role="nodep" linkend="libreoffice"/> with system harfbuzz),
[572553b]79 <xref linkend="icu"/>, and
[13df334]80 <xref role="first" linkend="freetype2"/>
[572553b]81 (after <xref role="nodep" linkend="harfbuzz"/> is installed, reinstall
82 <xref role="nodep" linkend="freetype2"/>)
[32e13498]83 </para>
84
85 <bridgehead renderas="sect4">Optional</bridgehead>
86 <para role="optional">
[a0484a14]87 <xref linkend="cairo"/> (circular: build cairo and all its recommended
88 dependencies, including harfbuzz, first, then rebuild harfbuzz if the
89 cairo backend is needed),
[b9f03437]90 <xref linkend="git"/>,
[92e3023]91 <xref linkend="gtk-doc"/>,
[1ea4deb]92 <ulink url="https://pypi.org/project/FontTools/">FontTools</ulink>
[48771ae]93 (Python 3 module, for the test suite), and
[92e3023]94 <ulink url="https://www.colm.net/open-source/ragel/">ragel</ulink>
[32e13498]95 </para>
96
97 <warning>
98 <para>
99 Recommended dependencies are not strictly required to build
100 the package. However, you might not get expected results at
101 runtime if you don't install them. Please do not report bugs
102 with this package if you <emphasis>have not</emphasis>
103 installed the recommended dependencies.
104 </para>
105 </warning>
106
107 <para condition="html" role="usernotes">
108 User Notes: <ulink url="&blfs-wiki;/harfbuzz"/>
109 </para>
110 </sect2>
111
112 <sect2 role="installation">
[8374093]113 <title>Installation of HarfBuzz</title>
[32e13498]114
115 <para>
[8374093]116 Install <application>HarfBuzz</application> by running the following
[32e13498]117 commands:
118 </para>
119
[9b8c04ed]120<screen><userinput>mkdir build &amp;&amp;
121cd build &amp;&amp;
122
[91318eb]123meson setup .. \
124 --prefix=/usr \
125 --buildtype=release \
126 -Dgraphite2=enabled &amp;&amp;
[9b8c04ed]127ninja</userinput></screen>
[32e13498]128
129 <para>
[9b8c04ed]130 To test the results, issue: <command>ninja test</command>.
[9db393f1]131 </para>
[32e13498]132
133 <para>
134 Now, as the <systemitem class="username">root</systemitem> user:
135 </para>
136
[9b8c04ed]137<screen role="root"><userinput>ninja install</userinput></screen>
[32e13498]138 </sect2>
139
[1e4ca8bb]140 <sect2 role="commands">
141 <title>Command Explanations</title>
142
[20f070d8]143 <xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
144 href="../../xincludes/meson-buildtype-release.xml"/>
145
[1e4ca8bb]146 <para>
[b1ff43b]147 <parameter>-Dgraphite2=enabled</parameter>: This switch enables
[8b8a6c4]148 <application>Graphite2</application> support, which is required for
[6121fe5]149 building <xref linkend="texlive"/> or <xref linkend="libreoffice"/>
150 with system harfbuzz.
[1e4ca8bb]151 </para>
[b1ff43b]152<!--
[9b8c04ed]153 <para>
[5c14fb68]154 <parameter>-Dbenchmark=disabled</parameter>: This switch disables
155 downloading and building the <application>google-benchmark</application>
156 subproject, which requires <xref linkend="git"/>, and is of no
[2c87187]157 use for non developers.
[9b8c04ed]158 </para>
[b1ff43b]159-->
[ee98f114]160 <para>
[1eb2916]161 <option>-Ddocs=disabled</option>: If <xref linkend="gtk-doc"/> is
162 installed, the documentation is built and installed. This switch
163 prevents that.
[ee98f114]164 </para>
165
[1e4ca8bb]166 </sect2>
167
[32e13498]168 <sect2 role="content">
169 <title>Contents</title>
170
171 <segmentedlist>
172 <segtitle>Installed Programs</segtitle>
[f82ac3f]173 <segtitle>Installed Libraries</segtitle>
174 <segtitle>Installed Directories</segtitle>
[32e13498]175
176 <seglistitem>
177 <seg>
[429b408]178 hb-info,
179 hb-ot-shape-closure,
180 hb-shape,
181 hb-subset, and
182 hb-view (only if Cairo is installed)
[32e13498]183 </seg>
184 <seg>
[429b408]185 libharfbuzz.so,
186 libharfbuzz-cairo.so (only if Cairo is installed),
187 libharfbuzz-gobject.so,
188 libharfbuzz-icu.so, and
[41e68a2d]189 libharfbuzz-subset.so
[32e13498]190 </seg>
191 <seg>
[221df934]192 /usr/include/harbuzz,
193 /usr/lib/cmake/harfbuzz, and
194 /usr/share/gtk-doc/html/harfbuzz (optional)
[32e13498]195 </seg>
196 </seglistitem>
197 </segmentedlist>
198
199 <variablelist>
200 <bridgehead renderas="sect3">Short Descriptions</bridgehead>
201 <?dbfo list-presentation="list"?>
202 <?dbhtml list-presentation="table"?>
[c7d631c]203
[429b408]204 <varlistentry id="hb-info">
205 <term><command>hb-info</command></term>
206 <listitem>
207 <para>
208 is used for gathering information about fonts installed on the
209 system
210 </para>
211 <indexterm zone="harfbuzz hb-info">
212 <primary sortas="b-hb-info">hb-info</primary>
213 </indexterm>
214 </listitem>
215 </varlistentry>
216
[0d12bbe]217 <varlistentry id="hb-ot-shape-closure">
218 <term><command>hb-ot-shape-closure</command></term>
219 <listitem>
220 <para>
221 gives the set of characters contained in a string, represented as
222 single characters and/or single character names. Example:
[c7d631c]223 <command>hb-ot-shape-closure
[4c24eb0a]224 /usr/share/fonts/dejavu/DejaVuSans.ttf "Hello World."</command>
[0d12bbe]225 </para>
226 <indexterm zone="harfbuzz hb-ot-shape-closure">
227 <primary sortas="b-hb-ot-shape-closure">hb-ot-shape-closure</primary>
228 </indexterm>
229 </listitem>
230 </varlistentry>
[32e13498]231
232 <varlistentry id="hb-shape">
233 <term><command>hb-shape</command></term>
234 <listitem>
235 <para>
[4c24eb0a]236 is used for the conversion of text strings into positioned glyphs
[32e13498]237 </para>
238 <indexterm zone="harfbuzz hb-shape">
239 <primary sortas="b-hb-shape">hb-shape</primary>
240 </indexterm>
241 </listitem>
242 </varlistentry>
[18f18c2]243
244 <varlistentry id="hb-subset">
245 <term><command>hb-subset</command></term>
246 <listitem>
247 <para>
[4c24eb0a]248 is used to create subsets of fonts, and display text using them
[18f18c2]249 </para>
250 <indexterm zone="harfbuzz hb-subset">
251 <primary sortas="b-hb-subset">hb-subset</primary>
252 </indexterm>
253 </listitem>
254 </varlistentry>
[c7d631c]255
[0d12bbe]256 <varlistentry id="hb-view">
257 <term><command>hb-view</command></term>
258 <listitem>
259 <para>
[f1ae52ff]260 displays a graphical view of a string shape using a
[8558044]261 particular font as a set of glyphs. The output format is
262 automatically defined by the file extension, the supported ones
[f1ae52ff]263 being ansi/png/svg/pdf/ps/eps. For example:
[c7d631c]264 <command>hb-view --output-file=hello.png
[4c24eb0a]265 /usr/share/fonts/dejavu/DejaVuSans.ttf "Hello World."</command>
[0d12bbe]266 </para>
267 <indexterm zone="harfbuzz hb-view">
268 <primary sortas="b-hb-view">hb-view</primary>
269 </indexterm>
270 </listitem>
271 </varlistentry>
[32e13498]272
273 <varlistentry id="libharfbuzz">
274 <term><filename class="libraryfile">libharfbuzz.so</filename></term>
275 <listitem>
276 <para>
[4c24eb0a]277 is the HarfBuzz text shaping library
[32e13498]278 </para>
279 <indexterm zone="harfbuzz libharfbuzz">
280 <primary sortas="c-libharfbuzz">libharfbuzz.so</primary>
281 </indexterm>
282 </listitem>
283 </varlistentry>
[0d7900a]284
[429b408]285 <varlistentry id="libharfbuzz-cairo">
286 <term><filename class="libraryfile">libharfbuzz-cairo.so</filename></term>
287 <listitem>
288 <para>
289 provides Cairo integration for the Harfbuzz text shaping library
290 </para>
291 <indexterm zone="harfbuzz libharfbuzz-cairo">
292 <primary sortas="c-libharfbuzz-cairo">libharfbuzz-cairo</primary>
293 </indexterm>
294 </listitem>
295 </varlistentry>
296
[8374093]297 <varlistentry id="libharfbuzz-gobject">
298 <term><filename class="libraryfile">libharfbuzz-gobject.so</filename></term>
299 <listitem>
300 <para>
[4c24eb0a]301 provides GObject integration for the HarfBuzz text shaping library
[8374093]302 </para>
303 <indexterm zone="harfbuzz libharfbuzz-gobject">
304 <primary sortas="c-libharfbuzz-gobject">libharfbuzz-gobject.so</primary>
305 </indexterm>
306 </listitem>
307 </varlistentry>
308
309 <varlistentry id="libharfbuzz-icu">
310 <term><filename class="libraryfile">libharfbuzz-icu.so</filename></term>
311 <listitem>
312 <para>
[4c24eb0a]313 provides ICU integration for the HarfBuzz text shaping library
[8374093]314 </para>
315 <indexterm zone="harfbuzz libharfbuzz-icu">
316 <primary sortas="c-libharfbuzz-icu">libharfbuzz-icu.so</primary>
317 </indexterm>
318 </listitem>
319 </varlistentry>
320
[429b408]321 <varlistentry id="libharfbuzz-subset">
322 <term><filename class="libraryfile">libharfbuzz-subset.so</filename></term>
323 <listitem>
324 <para>
325 provides API functions for performing subsetting operations on font
326 files
327 </para>
328 <indexterm zone="harfbuzz libharfbuzz-subset">
329 <primary sortas="c-libharfbuzz-subset">libharfbuzz-subset.so</primary>
330 </indexterm>
331 </listitem>
332 </varlistentry>
333
[32e13498]334 </variablelist>
[0d7900a]335
[32e13498]336 </sect2>
[0d7900a]337
[32e13498]338</sect1>
Note: See TracBrowser for help on using the repository browser.