Difference between revisions of "HowTo Compile In Slackware"

From AMule Project FAQ
Jump to: navigation, search
(Hint for updating)
m (Added note about minimum requirements and brief howto using SlackBuild)
 
(13 intermediate revisions by 2 users not shown)
Line 1: Line 1:
<h1>Installing [[aMule]] on [http://www.slackware.com Slackware]</h1>
+
<center>
 +
[[HowTo_Compile_In_Slackware|English]] |
 +
[[HowTo_Compile_In_Slackware-fr|Fran&ccedil;ais]] |
 +
[[HowTo_Compile_In_Slackware-it|Italiano]]
 +
</center>
  
<h1><font color=red>Someone should check how recent this Article is, and update it for 2.1.3 or better 2.2.0</font></h1>
+
<h1>Installing [[aMule]] 2.2.* on [http://www.slackware.com Slackware] 12.*</h1>
  
<center><h2>by ''Mike (servnov)''</h2></center>
+
'''NOTE''': you will need super-user (usually ''root'') access to complete [[aMule]] install/uninstallation/update, also consider using [http://asic-linux.com.mx/~izto/checkinstall checkinstall] installed to manage packages.
<center><h4>wisecrackin' added by DexterF</h4></center>
+
  
'''NOTE''': you will need super-user (usually ''root'') access to complete [[aMule]] install/uninstallation/update, further you should have at least checkinstall installed.
+
<h2>Installation requirements</h2>
  
 +
In order to compile aMule 2.2.* on Slackware 12.* you need the following packages. Package version suggested are those provided for the Slackware 12.* or is the minimum version tested:
 +
* geoip >= 1.4.4 (from http://slacky.eu)
 +
* libupnp 1.6.6 (if you want to use the UPnP feature, get the tarball from http://pupnp.sf.net)
 +
* cryptopp 5.5.2 (from http://slacky.eu)
 +
* wxWidgets >= 2.8.* (http://www.wxwidgets.org or a precompiled package from http://www.slacky.eu)
 +
* '''If using Slackware 12.0''' upgrade package gcc with >= 4.2.3-i486-1 (http://packages.slackware.it)
 +
* '''If using Slackware 12.0''' upgrade package gcc-g++ with >= 4.2.3-i486-1 (http://packages.slackware.it)
 +
* (''optional'') ccache-2.4-i486-1 package if you want to speedup compiling
  
== Installation ==
 
  
=== Installing [[wxWidgets|wxGTK]] ===
+
The minimum GCC version declared into the file docs/INSTALL appears to be obsolete as I encountered
 +
the following error:
  
:Download [[wxWidgets|wxGTK]] sources (.tar.gz packages) from
+
<code>amule: /usr/lib/libstdc++.so.6: version `GLIBCXX_3.4.9' not found (required by amule)</code>
:www.wxwidgets.org, latest is 2.6.2 as of 21st of Dec 05
+
  
:''tar -xzvf wxGTK*''
 
:''cd wxGTK*''
 
:''./configure --prefix=/usr --enable-unicode''
 
:''make''
 
  
: After make finishes, it's about time to install the new files.
+
Other packages - system libs rather strictly aMule related - that are needed: these are mentioned
: ''Usually'' this is done by becomming root and invoking
+
at the end of the configure summary of aMule.
  
: # make install
+
* regex system
 +
* libintl system
 +
* libpng 1.2.18
 +
* libgd 2.0.35
 +
* zlib 1.2.3
  
: ''But:'' even better, use checkinstall or read up on how to
+
<h2>aMule prepackaged binaries</h2>
: properly make Slackware packages on slackwiki.org.
+
Provided your system satisfies the above mentioned requirements, grab a pre-built [http://www.slackware.com Slackware] package from [http://www.linuxpackages.net/search_view.php?by=name&name=amule&ver= linuxpackages.net] and install it (as root) with:
: checkinstall and selfmade packages can be handled by slackware's package
+
:''# installpkg aMule-x.y.z.tgz''
: tools, which make upgrading and removing old cruft from previous  
+
 
: installs a breeze.
+
or if you simply need to upgrade the package:
: If the Slackwiki howto is a little too much for, stick to checkinstall for
+
 
: the moment: become root
+
:''# upgradepkg aMule-x.y.z.tgz''
 +
 
 +
Type ''amule'' in a shell to lauch or in [http://www.kde.org KDE] (similar in [http://www.gnome.org GNOME]) go to Kstart->Internet->aMule
 +
 
 +
If you want to ''remove'' aMule simply run:
 +
 
 +
:''# removepkg aMule-x.y.z.tgz''
 +
 
 +
<h2>Compiling aMule</h2>
 +
 
 +
* First install/upgrade the above mentioned packages. Then compile '''cryptopp''' (no special flags required) and aMule with the following flags (for a feature-complete installation):
 +
 
 +
:''$ ./configure --with-denoise-level=3 --enable-optimize --enable-verbose --enable-geoip --enable-wxcas --enable-amule-gui --enable-amulecmd --enable-amule-daemon --enable-alc --enable-alcc --enable-cas --disable-debug --enable-ccache --enable-webserver''
 +
:''$ make''
 +
:''$ su <insert password>''
 +
:''# make install''
 +
 
 +
Even better, you can use checkinstall or read up on how to properly make Slackware packages on slackwiki.org. Checkinstall and selfmade packages can be handled by Slackware's package tools, which make upgrading and removing old cruft from previous installs a breeze. If the Slackwiki howto is a little too much for, stick to checkinstall for the moment:
 +
 
 +
: become root
  
 
: ''$ su -''
 
: ''$ su -''
Line 40: Line 69:
 
: ''# checkinstall''
 
: ''# checkinstall''
  
: Just answer the questions and you're done.  
+
: Just answer the questions and you're done.
  
 +
<h3>Installing [[wxBase]] (Optional)</h3>
  
=== Installing [[wxBase]] (Optional) ===
+
If you downloaded [[wxWidgets|wxGTK]] earlier than version 2.5 and you are planning to use [[aMule]] with command line interface (such as [[aMuleCMD]], [[aMuleWeb]], [[aMuled]], etc), then you you should install [[wxBase]]. In any other case, there's no need at all.
  
:'''If you downloaded [[wxWidgets|wxGTK]] earlier than version 2.5 and you are planning to use [[aMule]] with command line interface (such as [[aMuleCMD]], [[aMuleWeb]], [[aMuled]], etc), then you you should install [[wxBase]]. In any other case, there's no need at all.'''
+
Download [[wxBase]] sources (.tar.gz packages) from http://www.amule-project.net or http://www.amule.org and do the following:
  
:Download [[wxBase]] sources (.tar.gz packages) from http://www.amule-project.net or http://www.amule.org and do the following:
+
:''$ tar -xzvf wxBase*''
 +
:''$ cd wxBase*''
 +
:''$ ./configure''
 +
:''$ make''
 +
:''$ su <insert password>''
 +
:''# make install''
  
:''tar -xzvf wxBase*''
+
* Then compile '''aMule'''. Run the "configure" with the parameters specified above.
:''cd wxBase*''
+
:''./configure''
+
:''make''
+
: #the following command '''must''' be run as super-user (usually ''root''):
+
:''make install''
+
  
=== Installing [[aMule]] ===
+
* If you are satisfied of the summary that is shown, run:
  
:Grab pre-built [http://www.slackware.com Slackware] package from [http://www.linuxpackages.net/search_view.php?by=name&name=amule&ver= linuxpackages.net].
+
:$ make
  
:''installpkg aMule-2.0.0rc7-i686-1.tgz'' (or whatever the newest version is)
+
:If you have a multi-core CPU you can speedup the compilation adding the parameter "-j" according to the number of logical/phisical CPUs detected on your system, example for a dual-core CPU:
  
:That's all!
+
:$ make -j 2
 +
 +
* If no error arise, you can run (as root):
  
:Type ''amule'' in a shell to lauch or in [http://www.kde.org KDE] (similar in [http://www.gnome.org GNOME]) go to Kstart->Internet->aMule
+
:<code># make install</code>
 +
 +
* Finally run the "amule" executable:
  
== Updating ==
+
:$ amule &
  
:The following command will remove the old [[aMule]] package and install the new version:
+
<h2>Building a Slackware package</h2>
  
:''upgradepkg aMule-2.0.0rc7-i686-1.tgz''
+
The steps I followed to build a package change just a little.
  
=== Compiling aMule from src ===  
+
* First I have installed aMule in a different, dedicated path in order to check the results, i.e. adding the following parameter to the configure script:
 +
:--prefix=/home/''$(whoami)''/tmp/amule/usr
 +
 +
:Remember to append "/usr" at the end of the path.
  
: Sometimes you might feel an urge to go cvs or simply don't want
+
* After installing ("make && make install"), strip down all the binaries with the following command in order to squeeze package size (a lot!):
: to use prepackaged binaries because of paranoia, the packagers
+
:$ cd /home/$(whoami)/tmp/amule/usr/bin
: are dodos or whatever.
+
:$ for i in alc alcc amule amulecmd amuled amulegui amuleweb cas ed2k wxcas; do strip $i; done
 +
:$ cd ../..
 +
:$ md install
 +
:$ cd install
  
:Download a src tarball at amule.org.
+
:Here edit "''slack-required''" and "''slack-desc''" files according to SlackBuild guidelines. I was lazy and just copied them from another recent Slackware aMule package (changing the relevant requirements).
:tar xzvf or tar xjvf the tarball.
+
:Enter the dir
+
: I use this configure call:
+
:./configure --enable-amule-daemon --enable-amulecmd \
+
:--enable-amulecmdgui --enable-webserver --enable-amule-gui \
+
:--enable-cas --enable-alcc --enable-kad-compile --prefix=/usr
+
  
:this will give you the core, the monolithic, the webserver,
+
* Then create the package:
:the stats program, the link handler, and... about everything.
+
  
:after that, run ''make'' and in the lucky case it finishes without
+
:<code>$ cd ..</code>
:errors, follow installation instructions from wxGTK above.  
+
:<code>$ ls</code>
 +
:<code>install usr</code>
 +
:<code>$ makepkg aMule-x.y.z.tgz</code>
  
 +
* Test your build and then notify the forum posting the ed2k link (set to ''release'' priority the file) ;-)
  
== Uninstallation ==
+
<h4>Building using a Slackbuild script</h4>
  
:The following command will remove [[aMule]]:
+
An alternate method to build a package is done by using a [http://slackbuilds.org SlackBuild] script. You can get download one from [http://slackbuilds.org/repository/12.2/network/aMule the repository] or [http://slackbuilds.org/guidelines create one] if not available.
  
:''removepkg aMule''
+
Once the build package script is downloaded, explode it in a directory. Copy the source tarball in the same directory, and edit the file ''aMule.SlackBuild'' according to your needs (namely the compiling options and the version of aMule you're compiling).
  
== Final note ==
+
Then impersonate ''root'' and execute the bash script:
  
You can even get [[wxBase]] and [[wxWidgets|wxGTK]] .tgz [http://www.slackware.com Slackware] packages and install them with 'installpkg'. Using the [http://www.slackware.com Slackware] package manager saves time during installation and makes upgrading easy.
+
:''# sh aMule.SlackBuild
You can also type 'pkgtool' as root and then search for the packages you have downloaded and install and/or remove packages.  
+
  
Enjoy the hard work [[aMule]] [[AMule_devs|developers]] have done and continue to do!
+
When the scripts finishes you will find the new package in the directory desired. That's all!
  
Just remember you will need [[wxBase]] and [[wxWidgets|wxGTK]] installed even when using [http://www.slackware.com Slackware] package.
+
<h2>Final note</h2>
  
----
+
Enjoy the hard work [[aMule]] [[AMule_devs|developers]] have done and continue to do!
 
+
Hope this helps.
+
  
 
Catch me on [[IRC]] at [irc://irc.freenode.net irc.freenode.com] channel [irc://irc.freenode.net/amule #amule] nick '''servnov'''.
 
Catch me on [[IRC]] at [irc://irc.freenode.net irc.freenode.com] channel [irc://irc.freenode.net/amule #amule] nick '''servnov'''.
 +
 +
Or post your questions on the [http://forum.amule.org forum].

Latest revision as of 21:36, 5 January 2009

English | Français | Italiano

Installing aMule 2.2.* on Slackware 12.*

NOTE: you will need super-user (usually root) access to complete aMule install/uninstallation/update, also consider using checkinstall installed to manage packages.

Installation requirements

In order to compile aMule 2.2.* on Slackware 12.* you need the following packages. Package version suggested are those provided for the Slackware 12.* or is the minimum version tested:


The minimum GCC version declared into the file docs/INSTALL appears to be obsolete as I encountered the following error:

amule: /usr/lib/libstdc++.so.6: version `GLIBCXX_3.4.9' not found (required by amule)


Other packages - system libs rather strictly aMule related - that are needed: these are mentioned at the end of the configure summary of aMule.

  • regex system
  • libintl system
  • libpng 1.2.18
  • libgd 2.0.35
  • zlib 1.2.3

aMule prepackaged binaries

Provided your system satisfies the above mentioned requirements, grab a pre-built Slackware package from linuxpackages.net and install it (as root) with:

# installpkg aMule-x.y.z.tgz

or if you simply need to upgrade the package:

# upgradepkg aMule-x.y.z.tgz

Type amule in a shell to lauch or in KDE (similar in GNOME) go to Kstart->Internet->aMule

If you want to remove aMule simply run:

# removepkg aMule-x.y.z.tgz

Compiling aMule

  • First install/upgrade the above mentioned packages. Then compile cryptopp (no special flags required) and aMule with the following flags (for a feature-complete installation):
$ ./configure --with-denoise-level=3 --enable-optimize --enable-verbose --enable-geoip --enable-wxcas --enable-amule-gui --enable-amulecmd --enable-amule-daemon --enable-alc --enable-alcc --enable-cas --disable-debug --enable-ccache --enable-webserver
$ make
$ su <insert password>
# make install

Even better, you can use checkinstall or read up on how to properly make Slackware packages on slackwiki.org. Checkinstall and selfmade packages can be handled by Slackware's package tools, which make upgrading and removing old cruft from previous installs a breeze. If the Slackwiki howto is a little too much for, stick to checkinstall for the moment:

become root
$ su -
then just call
# checkinstall
Just answer the questions and you're done.

Installing wxBase (Optional)

If you downloaded wxGTK earlier than version 2.5 and you are planning to use aMule with command line interface (such as aMuleCMD, aMuleWeb, aMuled, etc), then you you should install wxBase. In any other case, there's no need at all.

Download wxBase sources (.tar.gz packages) from http://www.amule-project.net or http://www.amule.org and do the following:

$ tar -xzvf wxBase*
$ cd wxBase*
$ ./configure
$ make
$ su <insert password>
# make install
  • Then compile aMule. Run the "configure" with the parameters specified above.
  • If you are satisfied of the summary that is shown, run:
$ make
If you have a multi-core CPU you can speedup the compilation adding the parameter "-j" according to the number of logical/phisical CPUs detected on your system, example for a dual-core CPU:
$ make -j 2
  • If no error arise, you can run (as root):
# make install
  • Finally run the "amule" executable:
$ amule &

Building a Slackware package

The steps I followed to build a package change just a little.

  • First I have installed aMule in a different, dedicated path in order to check the results, i.e. adding the following parameter to the configure script:
--prefix=/home/$(whoami)/tmp/amule/usr
Remember to append "/usr" at the end of the path.
  • After installing ("make && make install"), strip down all the binaries with the following command in order to squeeze package size (a lot!):
$ cd /home/$(whoami)/tmp/amule/usr/bin
$ for i in alc alcc amule amulecmd amuled amulegui amuleweb cas ed2k wxcas; do strip $i; done
$ cd ../..
$ md install
$ cd install
Here edit "slack-required" and "slack-desc" files according to SlackBuild guidelines. I was lazy and just copied them from another recent Slackware aMule package (changing the relevant requirements).
  • Then create the package:
$ cd ..
$ ls
install usr
$ makepkg aMule-x.y.z.tgz
  • Test your build and then notify the forum posting the ed2k link (set to release priority the file) ;-)

Building using a Slackbuild script

An alternate method to build a package is done by using a SlackBuild script. You can get download one from the repository or create one if not available.

Once the build package script is downloaded, explode it in a directory. Copy the source tarball in the same directory, and edit the file aMule.SlackBuild according to your needs (namely the compiling options and the version of aMule you're compiling).

Then impersonate root and execute the bash script:

# sh aMule.SlackBuild

When the scripts finishes you will find the new package in the directory desired. That's all!

Final note

Enjoy the hard work aMule developers have done and continue to do!

Catch me on IRC at irc.freenode.com channel #amule nick servnov.

Or post your questions on the forum.