source: x/lib/cairo.xml@ 72f9881e

11.2 11.3 12.0 12.1 12.2 gimp3 kea ken/TL2024 ken/inkscape-core-mods ken/tuningfonts lazarus lxqt plabs/newcss plabs/python-mods python3.11 qt5new rahul/power-profiles-daemon renodr/vulkan-addition trunk xry111/for-12.3 xry111/llvm18 xry111/soup3 xry111/spidermonkey128 xry111/xf86-video-removal
Last change on this file since 72f9881e was 35a179c8, checked in by Xi Ruoyao <xry111@…>, 2 years ago

cairo: fix the description for the sed removing "PTR"

/usr/include/ansidecl.h says "This file is part of the GNU C Library",
but it's actually installed by Binutils.

Ref: https://archlinux.org/packages/core/x86_64/binutils/files/, and the
timestamp on my system.

  • Property mode set to 100644
File size: 10.4 KB
RevLine 
[bb41bc7]1<?xml version="1.0" encoding="ISO-8859-1"?>
[6732c094]2<!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
3 "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
[bb41bc7]4 <!ENTITY % general-entities SYSTEM "../../general.ent">
5 %general-entities;
6
[a5fe42a]7 <!ENTITY cairo-download-http "&gnome-download-http;/cairo/&cairo-minor;/cairo-&cairo-version;.tar.xz">
8 <!--<!ENTITY cairo-download-http "https://www.cairographics.org/snapshots/cairo-&cairo-version;.tar.xz">
9 <!ENTITY cairo-download-http "&sources-anduin-http;/cairo/cairo-&cairo-version;.tar.xz">-->
[97ccf511]10 <!ENTITY cairo-download-ftp " ">
[3c51a6e]11 <!ENTITY cairo-md5sum "c5a6f255af72a2e5faa8e6a53dd882e2">
12 <!ENTITY cairo-size "33 MB">
13 <!ENTITY cairo-buildsize "137 MB">
14 <!ENTITY cairo-time "0.4 SBU (Using parallelism=4)">
[bb41bc7]15]>
16
[a2912ff]17<sect1 id="cairo" xreflabel="Cairo-&cairo-version;">
[bb41bc7]18 <?dbhtml filename="cairo.html"?>
19
20 <sect1info>
21 <date>$Date$</date>
22 </sect1info>
23
[a2912ff]24 <title>Cairo-&cairo-version;</title>
[bb41bc7]25
26 <indexterm zone="cairo">
[a2912ff]27 <primary sortas="a-Cairo">Cairo</primary>
[bb41bc7]28 </indexterm>
29
30 <sect2 role="package">
[4db1ba6]31 <title>Introduction to Cairo</title>
[bb41bc7]32
[521cea0]33 <para>
34 <application>Cairo</application> is a 2D graphics library with support for
35 multiple output devices. Currently supported output targets include the
36 <application>X</application> Window System, win32, image buffers,
37 PostScript, PDF and SVG. Experimental backends include OpenGL, Quartz and
[68d01360]38 XCB file output. <application>Cairo</application> is designed to produce
39 consistent output on all output media while taking advantage of display
40 hardware acceleration when available (e.g., through the X Render
41 Extension). The <application>Cairo</application> API provides operations
42 similar to the drawing operators of PostScript and PDF. Operations in
[521cea0]43 <application>Cairo</application> include stroking and filling cubic
44 B&eacute;zier splines, transforming and compositing translucent images,
45 and antialiased text rendering. All drawing operations can be transformed
46 by any
47 <ulink url="http://en.wikipedia.org/wiki/Affine_transformation">affine
48 transformation</ulink> (scale, rotation, shear, etc.).
49 </para>
[bb41bc7]50
[519aed4]51 &lfs111_checked;
[3af39b1]52
[bb41bc7]53 <bridgehead renderas="sect3">Package Information</bridgehead>
54 <itemizedlist spacing="compact">
55 <listitem>
[521cea0]56 <para>
57 Download (HTTP): <ulink url="&cairo-download-http;"/>
58 </para>
59 </listitem>
60 <listitem>
61 <para>
62 Download (FTP): <ulink url="&cairo-download-ftp;"/>
63 </para>
[bb41bc7]64 </listitem>
65 <listitem>
[521cea0]66 <para>
67 Download MD5 sum: &cairo-md5sum;
68 </para>
[bb41bc7]69 </listitem>
70 <listitem>
[521cea0]71 <para>
72 Download size: &cairo-size;
73 </para>
[bb41bc7]74 </listitem>
75 <listitem>
[521cea0]76 <para>
77 Estimated disk space required: &cairo-buildsize;
78 </para>
[bb41bc7]79 </listitem>
80 <listitem>
[521cea0]81 <para>
82 Estimated build time: &cairo-time;
83 </para>
[bb41bc7]84 </listitem>
[521cea0]85 </itemizedlist>
86
[4db1ba6]87 <bridgehead renderas="sect3">Cairo Dependencies</bridgehead>
[bb41bc7]88
89 <bridgehead renderas="sect4">Required</bridgehead>
[b8a081c]90 <para role="required">
[1cfd61d]91 <xref linkend="libpng"/> and
[b0ae5b7]92 <xref linkend="pixman"/>
[4db1ba6]93 </para>
94
[f575476]95 <bridgehead renderas="sect4">Recommended</bridgehead>
[4db1ba6]96 <para role="recommended">
[1cfd61d]97 <xref linkend="fontconfig"/>,
[3df8ea47]98 <xref linkend="glib2"/> (required for most GUIs), and
[a2912ff]99 <xref linkend="xorg7-lib"/>
[b8a081c]100 </para>
[bc9c1def]101
[bb41bc7]102 <bridgehead renderas="sect4">Optional</bridgehead>
[b8a081c]103 <para role="optional">
104 <xref linkend="cogl"/>,
[11d14a27]105 <xref linkend="gs"/>,
106 <xref linkend="gtk3"/> and <xref linkend="gtk2"/>,
[b8a081c]107 <xref linkend="gtk-doc"/>,
[521cea0]108 <xref linkend="libdrm"/>,
[11d14a27]109 <xref linkend="librsvg"/>,
[f68e46f]110 <xref linkend="libxml2"/>,
[652b18b]111 <xref linkend="lzo"/>,
[7a395d1]112 <xref linkend="mesa"/>,
[11d14a27]113 <xref linkend="poppler"/>,
[f68e46f]114 <xref linkend="qt5"/>,
[ae629f3]115 <xref linkend="valgrind"/>,
[8763a1da]116 <ulink url="http://pkgs.fedoraproject.org/repo/pkgs/directfb/">DirectFB</ulink>,
[11d14a27]117 <ulink url="https://github.com/rillian/jbig2dec/">jbig2dec</ulink>,
118 <ulink url="https://www.freedesktop.org/wiki/Software/libspectre/">libspectre</ulink>,
119 <ulink url="https://skia.org/">Skia</ulink>, and
[a5592158]120 <ulink url="http://download.qt.io/archive/qt/4.8/">Qt4</ulink>.
[b8a081c]121 </para>
[6e08fa52]122
[baac59c]123 <note>
124 <para>
125 There is a circular dependency between cairo and harfbuzz.
126 If cairo is built before harfbuzz, it is necessary to rebuild cairo
127 after harfbuzz in order to build pango.
128 </para>
129 </note>
[e641675]130
[521cea0]131 <para condition="html" role="usernotes">
132 User Notes: <ulink url="&blfs-wiki;/cairo"/>
133 </para>
[bb41bc7]134 </sect2>
135
136 <sect2 role="installation">
[4db1ba6]137 <title>Installation of Cairo</title>
[bb41bc7]138
[35a179c8]139 <!-- /usr/include/ansidecl.h says "This file is part of the GNU C
140 Library", but it's actually installed by Binutils. -->
[ba3b0498]141 <para>
[35a179c8]142 Adapt this package for Binutils-2.39 or later:
[ba3b0498]143 </para>
144
145<screen><userinput>sed 's/PTR/void */' -i util/cairo-trace/lookup-symbol.c</userinput></screen>
146
[521cea0]147 <para>
148 Install <application>Cairo</application> by running the following
149 commands:
150 </para>
[bb41bc7]151
[a2ce753]152<screen><userinput>./configure --prefix=/usr \
[9ad08f8]153 --disable-static \
154 --enable-tee &amp;&amp;
[bb41bc7]155make</userinput></screen>
156
[f575476]157 <para>
158 This package does not have a working testsuite.
[a2ce753]159 <!-- The test suite can be run with 'make check', but 488 tests fail and
160 59 tests pass. This seems to be due to minute changes in the expected
161 output, similar to librsvg's tests. Since it's a huge chunk of the tests,
162 let's keep it as "broken" for now.-->
[521cea0]163 </para>
[bb41bc7]164
[521cea0]165 <para>
166 Now, as the <systemitem class="username">root</systemitem> user:
167 </para>
[bb41bc7]168
169<screen role="root"><userinput>make install</userinput></screen>
170 </sect2>
171
[15a4fb4c]172 <sect2 role="commands">
173 <title>Command Explanations</title>
174
[a2ce753]175<!-- Not needed with 1.17.4
[e24dbc2]176 <para>
[1ea3b96]177 <parameter>autoreconf -fv</parameter>: This prevents
[e24dbc2]178 <command>configure</command> ending in error with the current version
179 of <application>automake</application> because the AM_INIT_AUTOMAKE
180 definitions came from a previous version.
181 </para>
[a2ce753]182-->
[e24dbc2]183
[7251b1d]184 <para>
[8558044]185 <parameter>--enable-tee</parameter>: This switch enables the
186 experimental tee surface backend which is required if using
[11d14a27]187 system-installed <application>Cairo</application> with Mozilla applications.
[7251b1d]188 </para>
189
[a98acfe7]190 <xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
191 href="../../xincludes/static-libraries.xml"/>
[827336dc]192
[74520e8]193 <para>
[11d14a27]194 <option>--enable-xlib-xcb</option>: This switch enables several
[5ec23d4]195 experimental Xlib/XCB functions used by some window managers.
[74520e8]196 </para>
197
[521cea0]198 <para>
[f575476]199 <option>--enable-gl</option>: This switch enables
200 <application>Cairo</application>'s experimental
201 <application>OpenGL</application> surface which
202 is required for <application>Wayland</application>
[a98acfe7]203 compositor and some other packages that are not
204 part of BLFS.
[521cea0]205 </para>
[bc9c1def]206
[f25b2c03]207<!--<xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
[a2912ff]208 href="../../xincludes/gtk-doc-rebuild.xml"/>
[f25b2c03]209 NOTE: For this version, no docs are installed by default -->
210
211 <para>
212 <option>--enable-gtk-doc</option>: Use this parameter if GTK-Doc is
213 installed and you wish to create and install the documentation.
214 </para>
[a2912ff]215
[15a4fb4c]216 </sect2>
217
[bb41bc7]218 <sect2 role="content">
219 <title>Contents</title>
220
221 <segmentedlist>
222 <segtitle>Installed Programs</segtitle>
[742b99e]223 <segtitle>Installed Libraries</segtitle>
[bb41bc7]224 <segtitle>Installed Directories</segtitle>
225
226 <seglistitem>
[b8a081c]227 <seg>
[a2ce753]228 cairo-trace
[b8a081c]229 </seg>
230 <seg>
[4db1ba6]231 libcairo.so, libcairo-gobject.so and
232 libcairo-script-interpreter.so
[b8a081c]233 </seg>
234 <seg>
[49a38a1]235 /usr/{include,lib,share/gtk-doc/html}/cairo
[b8a081c]236 </seg>
[bb41bc7]237 </seglistitem>
238 </segmentedlist>
239
240 <variablelist>
241 <bridgehead renderas="sect3">Short Descriptions</bridgehead>
242 <?dbfo list-presentation="list"?>
243 <?dbhtml list-presentation="table"?>
244
[a2ce753]245<!--
[298fee30]246 <varlistentry id="cairo-sphinx">
247 <term><command>cairo-sphinx</command></term>
248 <listitem>
249 <para>
[4c24eb0a]250 is an internal utility for regression analysis
[298fee30]251 </para>
252 <indexterm zone="cairo cairo-sphinx">
253 <primary sortas="b-cairo-sphinx">cairo-sphinx</primary>
254 </indexterm>
255 </listitem>
256 </varlistentry>
[a2ce753]257-->
[298fee30]258
[827336dc]259 <varlistentry id="cairo-trace">
260 <term><command>cairo-trace</command></term>
261 <listitem>
[521cea0]262 <para>
263 generates a log of all calls made by an application to
[4c24eb0a]264 <application>Cairo</application>
[521cea0]265 </para>
[827336dc]266 <indexterm zone="cairo cairo-trace">
267 <primary sortas="b-cairo-trace">cairo-trace</primary>
268 </indexterm>
269 </listitem>
270 </varlistentry>
271
[bb41bc7]272 <varlistentry id="libcairo">
[f575476]273 <term><filename class="libraryfile">libcairo.so</filename></term>
[bb41bc7]274 <listitem>
[521cea0]275 <para>
276 contains the 2D graphics functions required for rendering to the
[4c24eb0a]277 various output targets
[521cea0]278 </para>
[bb41bc7]279 <indexterm zone="cairo libcairo">
[4db1ba6]280 <primary sortas="c-libcairo">libcairo.so</primary>
[bb41bc7]281 </indexterm>
282 </listitem>
283 </varlistentry>
284
[827336dc]285 <varlistentry id="libcairo-gobject">
[7ca0e36]286 <term><filename class="libraryfile">libcairo-gobject.so</filename></term>
[827336dc]287 <listitem>
[521cea0]288 <para>
289 contains functions that integrate
[8558044]290 <application>Cairo</application> with
[4c24eb0a]291 <application>Glib</application>'s GObject type system
[521cea0]292 </para>
[827336dc]293 <indexterm zone="cairo libcairo-gobject">
[4db1ba6]294 <primary sortas="c-libcairo-gobject">libcairo-gobject.so</primary>
[827336dc]295 </indexterm>
296 </listitem>
297 </varlistentry>
298
299 <varlistentry id="libcairo-script-interpreter">
[7ca0e36]300 <term><filename class="libraryfile">libcairo-script-interpreter.so</filename></term>
[827336dc]301 <listitem>
[521cea0]302 <para>
303 contains the script interpreter functions for executing and
[4c24eb0a]304 manipulating <application>Cairo</application> execution traces
[521cea0]305 </para>
[827336dc]306 <indexterm zone="cairo libcairo-script-interpreter">
[4db1ba6]307 <primary sortas="c-libcairo-script-interpreter">libcairo-script-interpreter.so</primary>
[827336dc]308 </indexterm>
309 </listitem>
310 </varlistentry>
[a2912ff]311
[bb41bc7]312 </variablelist>
[a2912ff]313
[bb41bc7]314 </sect2>
[a2912ff]315
[bb41bc7]316</sect1>
Note: See TracBrowser for help on using the repository browser.