source: xsoft/graphweb/seamonkey.xml@ 17bf961

12.0 12.1 ken/TL2024 ken/tuningfonts lazarus plabs/newcss python3.11 rahul/power-profiles-daemon renodr/vulkan-addition trunk xry111/llvm18
Last change on this file since 17bf961 was c5f66519, checked in by Douglas R. Reno <renodr@…>, 11 months ago

Update to seamonkey-2.53.17 (Security Update)

  • 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 seamonkey-download-http "&mozilla-http;/seamonkey/releases/&seamonkey-version;/source/seamonkey-&seamonkey-version;.source.tar.xz">
8 <!ENTITY seamonkey-download-ftp " ">
9 <!ENTITY seamonkey-md5sum "5fd91a88005c2cc2a3ba4addfb5ff35e">
10 <!ENTITY seamonkey-size "254 MB">
11 <!ENTITY seamonkey-buildsize "4.4 GB (159 MB installed)">
12 <!ENTITY seamonkey-time "11 SBU (with parallelism=4)">
13]>
14
15<sect1 id="seamonkey" xreflabel="SeaMonkey-&seamonkey-version;">
16 <?dbhtml filename="seamonkey.html" ?>
17
18
19 <title>SeaMonkey-&seamonkey-version;</title>
20
21 <indexterm zone="seamonkey">
22 <primary sortas="a-SeaMonkey">SeaMonkey</primary>
23 </indexterm>
24
25 <sect2 role="package">
26 <title>Introduction to SeaMonkey</title>
27
28 <para>
29 <application>SeaMonkey</application> is a browser suite, a descendant
30 of <application>Netscape</application>. It includes the browser,
31 composer, mail and news clients, and an IRC client.
32 </para>
33
34 <para>
35 It is the community-driven follow-on to the Mozilla Application Suite,
36 created after Mozilla decided to focus on separate applications for
37 browsing and e-mail. Those applications are
38 <xref linkend="firefox"/> and <xref linkend="thunderbird"/>.
39 </para>
40
41 &lfs113_checked;
42
43 <bridgehead renderas="sect3">Package Information</bridgehead>
44 <itemizedlist spacing="compact">
45 <listitem>
46 <para>
47 Download (HTTP): <ulink url="&seamonkey-download-http;"/>
48 </para>
49 </listitem>
50 <listitem>
51 <para>
52 Download (FTP): <ulink url="&seamonkey-download-ftp;"/>
53 </para>
54 </listitem>
55 <listitem>
56 <para>
57 Download MD5 sum: &seamonkey-md5sum;
58 </para>
59 </listitem>
60 <listitem>
61 <para>
62 Download size: &seamonkey-size;
63 </para>
64 </listitem>
65 <listitem>
66 <para>
67 Estimated disk space required: &seamonkey-buildsize;
68 </para>
69 </listitem>
70 <listitem>
71 <para>
72 Estimated build time: &seamonkey-time;
73 </para>
74 </listitem>
75 </itemizedlist>
76
77<!--
78 <bridgehead renderas="sect3">Additional Downloads</bridgehead>
79 <itemizedlist spacing="compact">
80 <listitem>
81 <para>
82 Required patch:
83 <ulink url="&patch-root;/seamonkey-&seamonkey-version;-upstream_fixes-1.patch"/>
84 </para>
85 </listitem>
86 </itemizedlist>
87-->
88
89 <note>
90 <para>
91 The tarball
92 <emphasis>seamonkey-&seamonkey-version;.source.tar.xz</emphasis> will
93 untar to <emphasis>seamonkey-&seamonkey-version;</emphasis> directory.
94 </para>
95 </note>
96
97 <bridgehead renderas="sect3">SeaMonkey Dependencies</bridgehead>
98
99 <bridgehead renderas="sect4">Required</bridgehead>
100 <para role="required">
101 <xref linkend="autoconf213"/>,
102 <xref linkend="cbindgen"/>,
103 <xref linkend="gtk3"/>,
104 <xref linkend="nodejs"/>,
105 <xref linkend="python2"/>,
106 <xref linkend="unzip"/>,
107 <xref linkend="yasm"/>, and
108 <xref linkend="zip"/>
109 </para>
110
111 <bridgehead renderas="sect4">Recommended</bridgehead>
112 <para role="recommended">
113 <xref linkend="icu"/>,
114 <xref linkend="libevent"/>,
115 <!--<xref linkend="libvpx"/>, Causes build failures similar to Firefox -->
116 <xref linkend="libwebp"/>,
117 <xref linkend="llvm"/> (with clang),
118 <xref linkend="nasm"/>,
119 <xref linkend="nspr"/>,
120 <xref linkend="nss"/>, and
121 <xref linkend="pulseaudio"/>
122 <!-- <xref linkend="sqlite"/> system version no longer supported -->
123 </para>
124<!--
125 <bridgehead renderas="sect4">Optional</bridgehead>
126 <para role="optional">
127 <xref linkend="sqlite"/> (not recommended due to potential
128 security concerns)
129 </para>
130-->
131 <note>
132 <para>
133 If you don't install recommended dependencies, then internal copies of
134 those packages will be used. They might be tested to work, but they can
135 be out of date or contain security holes.
136 </para>
137 </note>
138
139 <bridgehead renderas="sect4">Optional</bridgehead>
140 <para role="optional">
141 <xref linkend="alsa-lib"/>,
142 <!--<xref linkend="curl"/>,-->
143 <xref linkend="dbus-glib"/>,
144 <!--<xref linkend="doxygen"/>,-->
145 <xref linkend="GConf"/>,
146 <!--<xref linkend="gst10-plugins-base"/> (and other plugins, only for tests),-->
147 <!--<xref linkend="openjdk"/>, Not seen in logs -->
148 <xref linkend="startup-notification"/>,
149 <xref linkend="valgrind"/>,
150 <xref linkend="wget"/>,
151 <xref linkend="wireless_tools"/>,
152 <ulink url="https://hunspell.sourceforge.net/">Hunspell</ulink>, and
153 <ulink url="https://facebook.github.io/watchman/">Watchman</ulink>
154 </para>
155
156 <para condition="html" role="usernotes">
157 Editor Notes: <ulink url="&blfs-wiki;/seamonkey"/>
158 </para>
159
160 </sect2>
161
162 <sect2 role="installation">
163 <title>Installation of SeaMonkey</title>
164
165 <para>
166 The configuration of <application>SeaMonkey</application> is accomplished
167 by creating a <filename>mozconfig</filename> file containing the desired
168 configuration options. A default <filename>mozconfig</filename> file is
169 created below. To see the entire list of available configuration options
170 (and an abbreviated description of each one), issue
171 <command>./configure --help</command>. You may also wish to review the
172 entire file and uncomment any other desired options. Create the file by
173 issuing the following command:
174 </para>
175
176<screen><?dbfo keep-together="auto"?><userinput>cat &gt; mozconfig &lt;&lt; "EOF"
177<literal># If you have a multicore machine, all cores will be used
178
179# If you have installed DBus-Glib comment out this line:
180ac_add_options --disable-dbus
181
182# If you have installed dbus-glib, and you have installed (or will install)
183# wireless-tools, and you wish to use geolocation web services, comment out
184# this line
185ac_add_options --disable-necko-wifi
186
187# Uncomment these lines if you have installed optional dependencies:
188#ac_add_options --enable-system-hunspell
189#ac_add_options --enable-startup-notification
190
191# Uncomment the following option if you have not installed PulseAudio
192#ac_add_options --disable-pulseaudio
193# and uncomment this if you installed alsa-lib instead of PulseAudio
194#ac_add_options --enable-alsa
195
196# Comment out following option if you have gconf installed
197ac_add_options --disable-gconf
198<!-- comments cause a blank line, following was for icu in the past
199 seems OK with icu-60, seamonkey-2.49
200 line below was with comment and explanation
201# Use the internal version of icu due to execution problems-->
202# Comment out following options if you have not installed
203# recommended dependencies:
204ac_add_options --with-system-icu
205ac_add_options --with-system-libevent
206ac_add_options --with-system-nspr
207ac_add_options --with-system-nss
208ac_add_options --with-system-webp
209
210# Disabling debug symbols makes the build much smaller and a little
211# faster. Comment this if you need to run a debugger. Note: This is
212# required for compilation on i686.
213ac_add_options --disable-debug-symbols
214
215# The elf-hack is reported to cause failed installs (after successful builds)
216# on some machines. It is supposed to improve startup time and it shrinks
217# libxul.so by a few MB - comment this if you know your machine is not affected.
218ac_add_options --disable-elf-hack
219
220# Seamonkey has some additional features that are not turned on by default,
221# such as an IRC client, calendar, and DOM Inspector. The DOM Inspector
222# aids with designing web pages. Comment these options if you do not
223# desire these features.
224ac_add_options --enable-calendar
225ac_add_options --enable-dominspector
226ac_add_options --enable-irc
227
228# The BLFS editors recommend not changing anything below this line:
229ac_add_options --prefix=/usr
230ac_add_options --enable-application=comm/suite
231
232ac_add_options --disable-crashreporter
233ac_add_options --disable-updater
234ac_add_options --disable-tests
235
236# rust-simd does not compile with recent versions of rust.
237# It is disabled in recent versions of firefox
238ac_add_options --disable-rust-simd
239
240ac_add_options --enable-optimize="-O2"
241ac_add_options --enable-strip
242ac_add_options --enable-install-strip
243ac_add_options --enable-official-branding
244
245# The option to use system cairo was removed in 2.53.9.
246ac_add_options --enable-system-ffi
247ac_add_options --enable-system-pixman
248
249ac_add_options --with-system-bz2
250ac_add_options --with-system-jpeg
251ac_add_options --with-system-png
252ac_add_options --with-system-zlib</literal>
253EOF</userinput></screen>
254
255 <note>
256 <xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
257 href="../../xincludes/mozshm.xml"/>
258 <xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
259 href="../../xincludes/mozmach.xml"/>
260 </note>
261
262<!--
263 <para>
264 First remove an obsolete flag in python code, that has been removed
265 in python-3.11:
266 </para>
267
268<screen><userinput>grep -rl \'rU\' | xargs sed -i "s/'rU'/'r'/"</userinput></screen>
269-->
270<!--
271 <para>
272 Next, work around a problem in the Python virtual environment:
273 </para>
274
275<screen><userinput>sed -i "/if sys.executable !=/i\ open(join(bin_dir, 'pyvenv.cfg'), 'w').close()" \
276 third_party/python/virtualenv/virtualenv.py</userinput></screen>
277-->
278
279 <para>
280 Fix a problem with the bundled 'distro' python module:
281 </para>
282
283<screen><userinput>sed -e '1012 s/stderr=devnull/stderr=subprocess.DEVNULL/' \
284 -e '1013 s/OSError/(OSError, subprocess.CalledProcessError)/' \
285 -i third_party/python/distro/distro.py</userinput></screen>
286
287 <para>
288 Compile <application>SeaMonkey</application> by running the following
289 commands:
290 </para>
291
292<screen><userinput>export CC=clang CXX=clang++ &amp;&amp;
293./mach configure &amp;&amp;
294./mach build</userinput></screen>
295
296
297 <!-- comment this since llvm must have been installed for rust
298 <note>
299 <para>
300 The CC and CXX variables above are only needed if
301 <xref linkend="llvm"/> is installed and you do not want to use clang.
302 </para>
303 </note>-->
304
305 <para>
306 This package does not come with a test suite.
307 </para>
308
309 <para>
310 Install <application>SeaMonkey</application> by issuing the following
311 commands as the <systemitem class="username">root</systemitem> user:
312 </para>
313
314
315<screen role="root"><userinput>./mach install &amp;&amp;
316chown -R 0:0 /usr/lib/seamonkey &amp;&amp;
317
318cp -v $(find -name seamonkey.1 | head -n1) /usr/share/man/man1</userinput></screen>
319
320 </sect2>
321
322 <sect2 role="commands">
323 <title>Command Explanations</title>
324
325 <para>
326 <command>export CC=clang CXX=clang++</command>:
327 With the introduction of <application>gcc-12</application>, many
328 more warnings are generated when compiling mozilla applications
329 and that results in a much slower, and larger, build. Furthermore,
330 building with GCC on i?86 is currently broken.
331 Although upstream mozilla code defaults to using
332 <application>llvm</application> unless overridden, the older configure
333 code in <application>SeaMonkey</application> defaults to gcc.
334 </para>
335
336 <para>
337 <command>./mach configure</command>: This validates
338 the supplied dependencies and the <filename>mozconfig</filename>.
339 <!--This is run twice because problems with mach will cause it to fail the
340 first time.-->
341 </para>
342
343 <para>
344 <option>./mach build --verbose</option>: Use this alternative if you
345 need details of which files are being compiled, together with any C or
346 C++ flags being used. But do not add '--verbose' to the install command,
347 it is not accepted there.
348 </para>
349
350 <para>
351 <option>./mach build -jN</option>: The build should, by default, use
352 all the online CPU cores. If using all the cores causes the build to swap
353 because you have insufficient memory, using fewer cores can be faster.
354 </para>
355
356 </sect2>
357
358 <sect2 role="configuration">
359 <title>Configuring SeaMonkey</title>
360
361 <para>
362 For installing various <application>SeaMonkey</application> add-ons, refer
363 to <ulink url="https://addons.thunderbird.net/en-US/seamonkey/">Add-ons
364 for Seamonkey</ulink>.
365 </para>
366
367 <para>
368 Along with using the <quote>Preferences</quote> menu to configure
369 <application>SeaMonkey</application>'s options and preferences to suit
370 individual tastes, finer grain control of many options is only available
371 using a tool not available from the general menu system. To access this
372 tool, you'll need to open a browser window and enter
373 <systemitem role="url">about:config</systemitem> in the address bar. This
374 will display a list of the configuration preferences and information
375 related to each one. You can use the <quote>Search:</quote> bar to enter
376 search criteria and narrow down the listed items. Changing a preference
377 can be done using two methods. One, if the preference has a boolean value
378 (True/False), simply double-click on the preference to toggle the value
379 and two, for other preferences simply right-click on the desired line,
380 choose <quote>Modify</quote> from the menu and change the value. Creating
381 new preference items is accomplished in the same way, except choose
382 <quote>New</quote> from the menu and provide the desired data into the
383 fields when prompted.
384 </para>
385
386<!-- The URL no longer exists.
387 <tip>
388 <para>
389 There is a multitude of configuration parameters you can tweak to
390 customize <application>SeaMonkey</application>. A very extensive list of
391 these parameters can be found at
392 <ulink url="http://preferential.mozdev.org/preferences.html"/>.
393 </para>
394 </tip>
395-->
396 <para>
397 If you use a desktop environment like <application>Gnome</application> or
398 <application>KDE</application> you may wish to create a
399 <filename>seamonkey.desktop</filename> file so that
400 <application>SeaMonkey</application> appears in the panel's menus. If you
401 didn't enable <application>Startup-Notification</application> in your
402 mozconfig change the StartupNotify line to false. As the
403 <systemitem class="username">root</systemitem> user:
404 </para>
405
406<screen role="root"><userinput>mkdir -pv /usr/share/{applications,pixmaps} &amp;&amp;
407
408cat &gt; /usr/share/applications/seamonkey.desktop &lt;&lt; "EOF"
409<literal>[Desktop Entry]
410Encoding=UTF-8
411Type=Application
412Name=SeaMonkey
413Comment=The Mozilla Suite
414Icon=seamonkey
415Exec=seamonkey
416Categories=Network;GTK;Application;Email;Browser;WebBrowser;News;
417StartupNotify=true
418Terminal=false</literal>
419EOF
420
421ln -sfv /usr/lib/seamonkey/chrome/icons/default/default128.png \
422 /usr/share/pixmaps/seamonkey.png</userinput></screen>
423 </sect2>
424
425 <sect2 role="content">
426 <title>Contents</title>
427
428 <segmentedlist>
429 <segtitle>Installed Programs</segtitle>
430 <segtitle>Installed Libraries</segtitle>
431 <segtitle>Installed Directory</segtitle>
432
433 <seglistitem>
434 <seg>seamonkey</seg>
435 <seg>
436 Numerous libraries, browser, and email/newsgroup components, plugins,
437 extensions, and helper modules installed in
438 <filename class="directory">/usr/lib/seamonkey</filename>
439 </seg>
440 <seg>
441 /usr/lib/seamonkey
442 </seg>
443 </seglistitem>
444 </segmentedlist>
445
446 <variablelist>
447 <bridgehead renderas="sect3">Short Descriptions</bridgehead>
448 <?dbfo list-presentation="list"?>
449 <?dbhtml list-presentation="table"?>
450
451 <varlistentry id="seamonkey-prog">
452 <term><command>seamonkey</command></term>
453 <listitem>
454 <para>
455 is the Mozilla browser/email/newsgroup/chat client suite
456 </para>
457 <indexterm zone="seamonkey seamonkey-prog">
458 <primary sortas="b-seamonkey">seamonkey</primary>
459 </indexterm>
460 </listitem>
461 </varlistentry>
462 </variablelist>
463 </sect2>
464
465</sect1>
Note: See TracBrowser for help on using the repository browser.