source: xsoft/graphweb/firefox.xml@ 7b8b68dd

10.0 10.1 11.0 11.1 11.2 11.3 12.0 12.1 7.10 7.5 7.6 7.6-blfs 7.6-systemd 7.7 7.8 7.9 8.0 8.1 8.2 8.3 8.4 9.0 9.1 basic bdubbs/svn elogind gnome kde5-13430 kde5-14269 kde5-14686 kea ken/TL2024 ken/inkscape-core-mods ken/tuningfonts krejzi/svn lazarus lxqt nosym perl-modules plabs/newcss plabs/python-mods python3.11 qt5new rahul/power-profiles-daemon renodr/vulkan-addition systemd-11177 systemd-13485 trunk upgradedb xry111/intltool xry111/llvm18 xry111/soup3 xry111/test-20220226 xry111/xf86-video-removal
Last change on this file since 7b8b68dd was 7b8b68dd, checked in by Igor Živković <igor@…>, 11 years ago

firefox actually requires the rtp plugin from gst-plugins-good package to play h264/mp4 videos

git-svn-id: svn://svn.linuxfromscratch.org/BLFS/trunk/BOOK@11872 af4574ff-66df-0310-9fd7-8a98e5e911e0

  • Property mode set to 100644
File size: 16.0 KB
Line 
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
7 <!ENTITY firefox-download-http
8 "http://releases.mozilla.org/pub/mozilla.org/firefox/releases/&firefox-version;/source/firefox-&firefox-version;.source.tar.bz2">
9 <!ENTITY firefox-download-ftp
10 "ftp://ftp.mozilla.org/pub/mozilla.org/firefox/releases/&firefox-version;/source/firefox-&firefox-version;.source.tar.bz2">
11 <!ENTITY firefox-md5sum "06a4c0fe8d3a979aea2fce8d0fdbf328">
12 <!ENTITY firefox-size "115 MB">
13 <!ENTITY firefox-buildsize "4.9 GB (48 MB installed) (or 814 MB and 4.6 MB if using Xulrunner)">
14 <!ENTITY firefox-time "58 SBU (0.47 SBU if using Xulrunner)">
15]>
16
17<sect1 id="firefox" xreflabel="Firefox-&firefox-version;">
18 <?dbhtml filename="firefox.html" ?>
19
20 <sect1info>
21 <othername>$LastChangedBy$</othername>
22 <date>$Date$</date>
23 </sect1info>
24
25 <title>Firefox-&firefox-version;</title>
26
27 <indexterm zone="firefox">
28 <primary sortas="a-Firefox">Firefox</primary>
29 </indexterm>
30
31 <sect2 role="package">
32 <title>Introduction to Firefox</title>
33
34 <para>
35 <application>Firefox</application> is a stand-alone browser based on the
36 <application>Mozilla</application> codebase.
37 </para>
38
39 &lfs74_checked;
40
41 <bridgehead renderas="sect3">Package Information</bridgehead>
42 <itemizedlist spacing="compact">
43 <listitem>
44 <para>
45 Download (HTTP): <ulink url="&firefox-download-http;"/>
46 </para>
47 </listitem>
48 <listitem>
49 <para>
50 Download (FTP): <ulink url="&firefox-download-ftp;"/>
51 </para>
52 </listitem>
53 <listitem>
54 <para>
55 Download MD5 sum: &firefox-md5sum;
56 </para>
57 </listitem>
58 <listitem>
59 <para>
60 Download size: &firefox-size;
61 </para>
62 </listitem>
63 <listitem>
64 <para>
65 Estimated disk space required: &firefox-buildsize;
66 </para>
67 </listitem>
68 <listitem>
69 <para>
70 Estimated build time: &firefox-time;
71 </para>
72 </listitem>
73 </itemizedlist>
74
75 <bridgehead renderas="sect3">Additional Downloads</bridgehead>
76 <itemizedlist spacing='compact'>
77 <listitem>
78 <para>Recommended patch: <ulink
79 url="&patch-root;/firefox-&firefox-version;-search_box_fix-1.patch"/></para>
80 </listitem>
81 </itemizedlist>
82
83 <bridgehead renderas="sect3">Firefox Dependencies</bridgehead>
84
85 <bridgehead renderas="sect4">Required</bridgehead>
86 <para role="required">
87 <xref linkend="alsa-lib"/>,
88 <xref linkend="gtk2"/>,
89 <xref linkend="zip"/>, and
90 <xref linkend="unzip"/>
91 </para>
92
93 <bridgehead renderas="sect4">Recommended</bridgehead>
94 <para role="recommended">
95 <xref linkend="libevent"/>,
96 <xref linkend="libvpx"/>,
97 <xref linkend="nspr"/>,
98 <xref linkend="nss"/>,
99 <xref linkend="sqlite"/> and
100 <xref linkend="yasm"/>
101 </para>
102
103 <note>
104 <para>
105 If you don't install recommended dependencies,
106 then internal copies of those packages will
107 be used. They might be tested to work, but
108 they can be out of date or contain security
109 holes.
110 </para>
111 </note>
112
113 <bridgehead renderas="sect4">Optional</bridgehead>
114 <para role="optional">
115 <xref linkend="curl"/>,
116 <xref linkend="dbus-glib"/>,
117 <xref linkend="doxygen"/>,
118 <xref linkend="gst-plugins-good"/>,
119 <ulink url="http://hunspell.sourceforge.net/">Hunspell</ulink>,
120 <xref linkend="libnotify"/>,
121 <xref linkend="startup-notification"/>,
122 <xref linkend="wget"/>,
123 <xref linkend="wireless_tools"/> and
124 <xref linkend="xulrunner"/>
125 </para>
126
127 <para condition="html" role="usernotes">
128 User Notes: <ulink url="&blfs-wiki;/firefox"/>
129 </para>
130 </sect2>
131
132 <sect2 role="installation">
133 <title>Installation of Firefox</title>
134
135 <para>
136 There are two major methods for building
137 <application>Firefox</application>. In the standard case, the entire suite
138 of libraries is built and installed. In the other, most of the system is
139 built using the procedures found in <xref linkend="xulrunner"/>. This is
140 advantageous if you are planning to build other related packages such as
141 <xref linkend="icedtea-web"/>. With either build method, you need to run
142 the main build procedure below with the appropriate options in the
143 <filename>mozconfig</filename> file. Then use the appropriate install
144 instructions depending on the chosen build method.
145 </para>
146
147 <para>
148 The configuration of <application>Firefox</application> is accomplished by
149 creating a <filename>mozconfig</filename> file containing the desired
150 configuration options. A default <filename>mozconfig</filename> is created
151 below. To see the entire list of available configuration options (and an
152 abbreviated description of each one), issue <command>./configure
153 --help</command>. You may also wish to review the entire file and
154 uncomment any other desired options.
155 Create the file by issuing the following command:
156 </para>
157
158<screen><userinput>cat &gt; mozconfig &lt;&lt; "EOF"
159# If you have a multicore machine, firefox will now use all the cores by
160# default. Exceptionally, you can reduce the number of cores, e.g. to 1,
161# by uncommenting the next line and setting a valid number of CPU cores.
162#mk_add_options MOZ_MAKE_FLAGS="-j1"
163
164# If you have installed DBus-Glib comment out this line:
165ac_add_options --disable-dbus
166
167# If you have installed wireless-tools comment out this line:
168ac_add_options --disable-necko-wifi
169
170# If you have installed libnotify comment out this line:
171ac_add_options --disable-libnotify
172
173# GStreamer is necessary for H.264 video playback in HTML5 Video Player;
174# to be enabled, also remember to set "media.gstreamer.enabled" to "true"
175# in about:config. If you have installed GStreamer comment out this line:
176ac_add_options --disable-gstreamer
177
178# Uncomment these lines if you have installed optional dependencies:
179#ac_add_options --enable-system-hunspell
180#ac_add_options --enable-startup-notification
181
182# Uncomment this line if you compiled Cairo with --enable-tee switch and want
183# to use it instead of the bundled one:
184#ac_add_options --enable-system-cairo
185
186# If you have not installed Yasm then uncomment this line:
187#ac_add_options --disable-webm
188
189# If you have installed xulrunner uncomment the next two ac_add_options lines
190# and check that the sdk will be set by running pkg-config in a subshell
191# and has not become hardcoded or empty when you created this file
192#ac_add_options --with-system-libxul
193#ac_add_options --with-libxul-sdk=$(pkg-config --variable=sdkdir libxul)
194
195# Comment out following options if you have not installed
196# recommended dependencies:
197ac_add_options --enable-system-sqlite
198ac_add_options --with-system-libevent
199ac_add_options --with-system-libvpx
200ac_add_options --with-system-nspr
201ac_add_options --with-system-nss
202
203# It is recommended not to touch anything below this line
204ac_add_options --prefix=/usr
205ac_add_options --enable-application=browser
206
207ac_add_options --disable-crashreporter
208ac_add_options --disable-installer
209ac_add_options --disable-updater
210ac_add_options --disable-debug
211ac_add_options --disable-tests
212
213ac_add_options --enable-optimize
214ac_add_options --enable-strip
215ac_add_options --enable-install-strip
216
217ac_add_options --enable-gio
218ac_add_options --enable-official-branding
219ac_add_options --enable-safe-browsing
220ac_add_options --enable-url-classifier
221
222ac_add_options --enable-system-ffi
223ac_add_options --enable-system-pixman
224
225ac_add_options --with-pthreads
226
227ac_add_options --with-system-bz2
228ac_add_options --with-system-jpeg
229ac_add_options --with-system-png
230ac_add_options --with-system-zlib
231
232mk_add_options MOZ_OBJDIR=@TOPSRCDIR@/firefox-build-dir
233EOF</userinput></screen>
234
235 <para>
236 If you are building against an already installed <application>Xulrunner</application>
237 apply the patch:
238 </para>
239
240<screen><userinput>patch -Np1 -i ../firefox-&firefox-version;-search_box_fix-1.patch</userinput></screen>
241
242 <para>
243 Compile <application>Firefox</application> by issuing the following
244 commands:
245 </para>
246
247<screen><userinput>sed -i 's@ ""@@' browser/base/Makefile.in &amp;&amp;
248make -f client.mk</userinput></screen>
249
250 <para>
251 This package does not come with a test suite.
252 </para>
253
254 <para>
255 If you have <emphasis>not</emphasis> linked
256 <application>Firefox</application> against an installed
257 <application>Xulrunner</application>:
258 </para>
259
260<screen><userinput>make -C firefox-build-dir/browser/installer</userinput></screen>
261
262 <para>
263 Now, as the <systemitem class="username">root</systemitem> user, if you
264 have <emphasis>not</emphasis> linked <application>Firefox</application>
265 against an installed <application>Xulrunner</application>, install the
266 package:
267 </para>
268
269<screen role="root"><userinput>rm -rf /usr/lib/firefox-&firefox-version; &amp;&amp;
270mkdir /usr/lib/firefox-&firefox-version; &amp;&amp;
271
272tar -xvf firefox-build-dir/dist/firefox-&firefox-version;.en-US.linux-$(uname -m).tar.bz2 \
273 -C /usr/lib/firefox-&firefox-version; --strip-components=1 &amp;&amp;
274chown -R -v root:root /usr/lib/firefox-&firefox-version; &amp;&amp;
275
276ln -sfv ../lib/firefox-&firefox-version;/firefox /usr/bin &amp;&amp;
277
278mkdir -pv /usr/lib/mozilla/plugins &amp;&amp;
279ln -sfv ../mozilla/plugins /usr/lib/firefox-&firefox-version;</userinput></screen>
280
281 <para>
282 If you <emphasis>have</emphasis> linked against an already installed
283 <application>Xulrunner</application>, as the
284 <systemitem class="username">root</systemitem> user:
285 </para>
286
287<screen role="root"><userinput>make -C firefox-build-dir install &amp;&amp;
288ln -sfv ../lib/firefox-&firefox-version;/firefox /usr/bin &amp;&amp;
289ln -sfv ../xulrunner-&firefox-version; /usr/lib/firefox-&firefox-version;/xulrunner &amp;&amp;
290
291mkdir -pv /usr/lib/mozilla/plugins &amp;&amp;
292ln -sfv ../mozilla/plugins /usr/lib/firefox-&firefox-version;</userinput></screen>
293
294 <bridgehead renderas="sect3" id="npapi-firefox" xreflabel="Firefox">
295 NPAPI Headers
296 </bridgehead>
297
298 <para>
299 The above instructions just install the parts you need to run
300 <application>Firefox</application>. If you want to compile
301 <xref linkend="gnash"/>, the open source version of Flash, copy some
302 headers that Gnash needs into /usr/include, as the
303 <systemitem class="username">root</systemitem> user:
304 </para>
305
306<screen role="root"><userinput>rm -rf /usr/include/npapi &amp;&amp;
307mkdir -v /usr/include/npapi &amp;&amp;
308cp -v dom/plugins/base/*.h /usr/include/npapi</userinput></screen>
309
310 <note>
311 <para>
312 You don't need to install the headers if you have built
313 <application>Firefox</application> against
314 <application>Xulrunner</application>.
315 </para>
316 </note>
317
318 </sect2>
319
320 <sect2 role="commands">
321 <title>Command Explanations</title>
322
323 <para>
324 <command>sed -i 's@ ""@@' browser/base/Makefile.in</command>: This sed
325 removes an unprintable control character from the title bar.
326 </para>
327
328 <para>
329 <command>make -f client.mk ...</command>: Mozilla products are packaged to
330 allow the use of a configuration file which can be used to pass the
331 configuration settings to the <command>configure</command> command.
332 <command>make</command> uses the <filename>client.mk</filename> file to
333 get initial configuration and setup parameters.
334 </para>
335
336 <para>
337 <command>make -C firefox-build-dir/browser/installer</command>: this
338 creates a <application>Firefox</application> tarball similar to the ones
339 you can download from Mozilla.
340 </para>
341
342 <para>
343 <command>tar -xfv firefox-build-dir/dist ...</command>: This untars
344 <application>Firefox</application> in /usr/lib. The
345 <option>--strip-components=1</option> option removes the leading
346 'firefox' directory from the filenames, allowing us to untar it
347 into a versioned directory.
348 </para>
349
350 <para>
351 <command>make -C firefox-build-dir install</command>: This runs
352 <command>make install</command> in firefox-build-dir.
353 </para>
354
355 <para>
356 <command>ln -sfv ... /usr/bin/firefox</command>: This puts a symbolic link
357 to the <command>firefox</command> executable in your <envar>PATH</envar>
358 variable.
359 </para>
360
361 <para>
362 <command>mkdir -p /usr/lib/mozilla/plugins</command>: This checks
363 that <filename class="directory">/usr/lib/mozilla/plugins</filename>
364 exists.
365 </para>
366
367 <para>
368 <command>ln -sv ... /usr/lib/firefox-&firefox-version;</command>: This
369 command creates a symbolic link to
370 <filename class="directory">/usr/lib/mozilla/plugins</filename>. It's not
371 really needed, as <application>Firefox</application> checks
372 <filename class="directory">/usr/lib/mozilla/plugins</filename> by
373 default, but the symbolic link is made to keep all the plugins installed in
374 one folder.
375 </para>
376
377 </sect2>
378
379 <sect2 role="configuration">
380 <title>Configuring Firefox</title>
381
382 <para>
383 If you deleted the <option>--disable-webm</option> option from your
384 <filename>mozconfig</filename>, your <application>Firefox</application>
385 can play most YouTube videos without the need for the flash plugin. To
386 enable this, go to <ulink url="http://www.youtube.com/html5"/> and click
387 on 'Join the HTML5 Trial' (needs cookies enabled).
388 </para>
389
390 <para>
391 If you use a desktop environment like <application>Gnome</application> or
392 <application>KDE</application> you may like to create a
393 <filename>firefox.desktop</filename> file so that
394 <application>Firefox</application> appears in the panel's menus. If you
395 didn't enable startup-notification in your mozconfig change the
396 StartupNotify line to false. As the
397 <systemitem class="username">root</systemitem> user:
398 </para>
399
400<screen role="root"><userinput>mkdir -pv /usr/share/applications &amp;&amp;
401mkdir -pv /usr/share/pixmaps &amp;&amp;
402
403cat &gt; /usr/share/applications/firefox.desktop &lt;&lt; "EOF" &amp;&amp;
404<literal>[Desktop Entry]
405Encoding=UTF-8
406Name=Firefox Web Browser
407Comment=Browse the World Wide Web
408GenericName=Web Browser
409Exec=firefox %u
410Terminal=false
411Type=Application
412Icon=firefox
413Categories=GNOME;GTK;Network;WebBrowser;
414MimeType=text/html;text/xml;application/xhtml+xml;application/vnd.mozilla.xul+xml;text/mml;x-scheme-handler/http;x-scheme-handler/https;
415StartupNotify=true</literal>
416EOF
417
418ln -sfv /usr/lib/firefox-&firefox-version;/browser/icons/mozicon128.png \
419 /usr/share/pixmaps/firefox.png</userinput></screen>
420
421 </sect2>
422
423 <sect2 role="content">
424 <title>Contents</title>
425
426 <segmentedlist>
427 <segtitle>Installed Programs</segtitle>
428 <segtitle>Installed Libraries</segtitle>
429 <segtitle>Installed Directories</segtitle>
430
431 <seglistitem>
432 <seg>
433 firefox
434 </seg>
435 <seg>
436 Numerous libraries, browser components, plugins, extensions, and
437 helper modules installed in
438 <filename class="directory">/usr/lib/firefox-&firefox-version;</filename>
439 </seg>
440 <seg>
441 /usr/include/npapi and
442 /usr/lib/firefox-&firefox-version;
443 </seg>
444 </seglistitem>
445 </segmentedlist>
446
447 <variablelist>
448 <bridgehead renderas="sect3">Short Descriptions</bridgehead>
449 <?dbfo list-presentation="list"?>
450 <?dbhtml list-presentation="table"?>
451
452 <varlistentry id="firefox-prog">
453 <term><command>firefox</command></term>
454 <listitem>
455 <para>
456 is a <application>GTK+ 2</application> internet browser that uses the
457 Mozilla Gecko rendering engine.
458 </para>
459 <indexterm zone="firefox firefox-prog">
460 <primary sortas="b-firefox">firefox</primary>
461 </indexterm>
462 </listitem>
463 </varlistentry>
464
465 </variablelist>
466
467 </sect2>
468
469</sect1>
Note: See TracBrowser for help on using the repository browser.