This third example is the package nzbget.
NZBget is for downloading from Usenet servers using nzb-files. This package requires the libxml2 library which is already part of Freetz.
This package worked on my 7270v3, but didn’t go as far as creating a
config file and download something, just executed nzbget
and
nzbget -v
.
During compile time of NZBget we need to have the library include files, and the compiled library available. An option is to download the libxml2 source files, and first compile the library, but we can just as well let Freetz do that work for us.
Compile an image with at least libxml2 selected:
cd ~/freetz-trunk/
make menuconfig
Shared libraries ---> XML & XSLT ---> [X] libxml2 (libxml2.so)
make
Verify the library file and include files are available:
ls /home/freetz/freetz-trunk/toolchain/target/include/libxml2/
ls -la /home/freetz/freetz-trunk/toolchain/target/lib/libxml2*
The first ls should show the sub-directory libxml
, and the second ls a
number of lines with one being `libxml2.so.2.9.1’ (or later), a a few
symlinks pointing to this file.
Now lets manual compile this application.
mkdir nzbget
cd ~/freetz-trunk-11230/nzbget/
wget http://sourceforge.net/projects/nzbget/files/nzbget-11.0.tar.gz
tar xfvz nzbget-11.0.tar.gz
cd nzbget-11.0
less README
export CC="mipsel-linux-gcc"
export CXX="mipsel-linux-uclibc-g++-wrapper"
export PATH=/home/freetz/freetz-trunk/toolchain/target/bin/:$PATH
export LIBS="-L~/freetz-trunk/libxml2/libxml2-2.9.1/builds/usr/lib/"
export CPPFLAGS="-I~/freetz-trunk/libxml2/libxml2-2.9.1/builds/usr/include/"
export libxml2_CFLAGS=/home/freetz/freetz-trunk/toolchain/target/include/libxml2/
export libxml2_LIBS=/home/freetz/freetz-trunk/toolchain/target/lib/
./configure \
--prefix=/usr \
--build=i686-pc-linux-gnu \
--host=mipsel-linux \
--with-libxml2-includes=/home/freetz/freetz-trunk/toolchain/target/include/libxml2/ \
--with-libxml2-libraries=/home/freetz/freetz-trunk/toolchain/target/lib/ \
--disable-curses \
--disable-parcheck \
--disable-tls \
--disable-gzip
vi ParCoordinator.cpp
add the following line somewhere between the existing include lines, e.g. somewhere above line 38 (but not between an if/endif):
#include <ctype.h>
make
ls -la nzbget *
file nzbget *
mipsel-linux-strip nzbget
ls -la nzbget *
file nzbget *
^*^ Optional, to see the impact of stripping. The file command should also show the executable is a MIPS executable.
Next you might want to see that “make clean
” properly works for this
package. This will remove all generated files.
(For packages involving a .config file you might want to save that file
to a save location, because make clean often will also delete this file.
But this is not applicable for nzbget.)
cd ~/freetz-trunk/nzbget/nzbget-11.0/
make clean
The Freetz environment makes use of “make clean
” of each package to
remove all generated files during compiling.
So testing this with this manual created package should give an idea
what happens giving a “make clean
” within Freetz.
In this example we will create the directory and file structure ourself.
For each new package a directory under ~/freetz-trunk/make/ should be created with a minimum of two files:
`--make
`--<package-name>
|-- Config.in
`-- <package-name>.mk
Optional there are more directories and files in case e.g. patches are needed.
Lets create the directory structure and the two files for NZBget:\
cd /home/freetz/freetz-trunk/
mkdir -p ~/freetz-trunk/make/nzbget/patches/
vi ~/freetz-trunk/make/nzbget/Config.in
config FREETZ_PACKAGE_NZBGET
bool "nzbget 11.0"
select FREETZ_LIB_libxml2
default n
help
NZBGet is a cross-platform binary newsgrabber for nzb files, written in C++.
It supports client/server mode, automatic par-check/-repair and web-interface.
NZBGet requires low system resources and runs great on routers, NAS-devices and media players.
The indents should be replaced with tabs.
vi ~/freetz-trunk/make/nzbget/nzbget.mk
$(call PKG_INIT_BIN, 11.0)
$(PKG)_SOURCE:=$(pkg)-$($(PKG)_VERSION).tar.gz
$(PKG)_HASH:=4f00039cc36e50fe68fc75e37b5a0406
$(PKG)_SITE:=http://sourceforge.net/projects/$(pkg)/files/
$(PKG)_BINARY:=$($(PKG)_DIR)/nzbget
$(PKG)_TARGET_BINARY:=$($(PKG)_DEST_DIR)/usr/bin/nzbget
$(PKG)_CATEGORY:=Unstable
$(PKG)_DEPENDS_ON += libxml2
$(PKG)_CONFIGURE_OPTIONS += --with-libxml2-includes=$(TARGET_TOOLCHAIN_STAGING_DIR)/include/libxml2/
$(PKG)_CONFIGURE_OPTIONS += --with-libxml2-libraries=$(TARGET_TOOLCHAIN_STAGING_DIR)/lib/
$(PKG)_CONFIGURE_OPTIONS += --disable-curses
$(PKG)_CONFIGURE_OPTIONS += --disable-parcheck
$(PKG)_CONFIGURE_OPTIONS += --disable-tls
$(PKG)_CONFIGURE_OPTIONS += --disable-gzip
$(PKG_SOURCE_DOWNLOAD)
$(PKG_UNPACKED)
$(PKG_CONFIGURED_CONFIGURE)
$($(PKG)_BINARY): $($(PKG)_DIR)/.configured
$(SUBMAKE) -C $(NZBGET_DIR) \
CXX="$(TARGET_CXX)"
$($(PKG)_TARGET_BINARY): $($(PKG)_BINARY)
$(INSTALL_BINARY_STRIP)
$(pkg):
$(pkg)-precompiled: $($(PKG)_TARGET_BINARY)
$(pkg)-clean:
-$(SUBMAKE) -C $(NZBGET_DIR) clean
$(pkg)-uninstall:
$(RM) $(NZBGET_TARGET_BINARY)
$(PKG_FINISH)
The indents should be replaced with tabs.
We also need to add a small patch file to add the one missing include.
vi make/nzbget/patches/100-ParCoordinator_ctype.h.patch
diff -dur ParCoordinator.cpp.orig ParCoordinator.cpp
--- ParCoordinator.cpp.orig 2013-11-18 23:46:41.720138807 +0100
+++ ParCoordinator.cpp 2013-11-18 23:47:18.700129701 +0100
@@ -35,6 +35,7 @@
#include <string.h>
#include <stdio.h>
#include <stdarg.h>
+#include <ctype.h>
#ifdef WIN32
#include <direct.h>
#else
Like normal with creating an image execute make menuconfig
and select
your router model and all options and packages to be included.
The newly added package is located in:
Packages ---> Unstable ---> [*] nzbget 11.0
. Also select an additional
library that is needed for nzbget:
Shared libraries ---> C++ ---> [*] uClibc++ (libuClibc++-0.2.3.so)
.
If you manually created this package you might need a
rm /home/freetz/freetz-trunk/source/target-mipsel_gcc-4.6.4_uClibc-0.9.32.1/config.cache
or make distclean
. And also be aware that the exports are still there,
this can be easily solved with a reboot.
After exiting, create the package with make
.
Lets see if “make clean
” works as expected. This should bring the
state back to like it was before the “make
” command.
cd ~/freetz-trunk/
make clean
In order to create a file which displays the changes which would be needed in freetz to add your package, issue the following commands:
svn add make/nzbget
svn diff ./make > patchfile
In our case “patchfile” may be called “nzbget”. Please note that there is no need for an extension here. You may only need an extension (e.g. .txt) for uploading it in the IPPF, because else it would not be recognized as a valid file for upload.
In addition you could even create a ready (and compressed) package of the two files which you had edited above:
tar cfz nzbget.tar.gz make/nzbget --exclude .svn
tar tfz nzbget.tar.gz