source: xsoft/graphweb/seamonkey.xml@ 0945dd2d

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 0945dd2d was 0945dd2d, checked in by Douglas R. Reno <renodr@…>, 15 months ago

Fix building Seamonkey with LLVM-16.

See Ticket #17852

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