summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: b68abb4)
raw | patch | inline | side by side (parent: b68abb4)
author | oetiker <oetiker@a5681a0c-68f1-0310-ab6d-d61299d08faa> | |
Sat, 8 Dec 2007 16:57:04 +0000 (16:57 +0000) | ||
committer | oetiker <oetiker@a5681a0c-68f1-0310-ab6d-d61299d08faa> | |
Sat, 8 Dec 2007 16:57:04 +0000 (16:57 +0000) |
* isinf and isnan definitions fixed
* check if rt must be linked
* ordering must be read write in getopt
* updated build instructions
git-svn-id: svn://svn.oetiker.ch/rrdtool/trunk/program@1251 a5681a0c-68f1-0310-ab6d-d61299d08faa
* check if rt must be linked
* ordering must be read write in getopt
* updated build instructions
git-svn-id: svn://svn.oetiker.ch/rrdtool/trunk/program@1251 a5681a0c-68f1-0310-ab6d-d61299d08faa
configure.ac | patch | blob | history | |
doc/rrdbuild.pod | patch | blob | history | |
src/rrd_getopt.c | patch | blob | history |
diff --git a/configure.ac b/configure.ac
index 27718fbcae9ab18652f8bbf342253213caa1395d..101520f5d05d1fd5a8f77f3be9a66231c9fb9b94 100644 (file)
--- a/configure.ac
+++ b/configure.ac
/* for Solaris */
#if (! defined(HAVE_ISINF) && defined(HAVE_FPCLASS))
# define HAVE_ISINF 1
+# ifdef isinf
+# undef isinf /* confuse autoconf */
+# endif
# define isinf(a) (fpclass(a) == FP_NINF || fpclass(a) == FP_PINF)
#endif
/* solaris 10 it defines isnan such that only forte can compile it ... bad bad */
#if (defined(HAVE_ISNAN) && defined(isnan) && defined(HAVE_FPCLASS))
-# undef isnan
+# undef isnan /* confuse autoconf to NOT remove this */
# define isnan(a) (fpclass(a) == FP_SNAN || fpclass(a) == FP_QNAN)
#endif
dnl Checks for libraries.
AC_CHECK_FUNC(acos, , AC_CHECK_LIB(m, acos))
+
dnl add pic flag in any case this makes sure all our code is relocatable
eval `./libtool --config | grep pic_flag`
CFLAGS="$CFLAGS $pic_flag"
AC_CHECK_FUNCS(tzset mbstowcs opendir readdir chdir chroot getuid setlocale strerror strerror_r snprintf vsnprintf fpclass class fp_class isnan memmove strchr mktime getrusage gettimeofday)
-dnl Could use these to know if we need to provide a prototype
-dnl AC_CHECK_DECLS(fdatasync, [], [], [#include <unistd.h>])
dnl XXX: dunno about windows.. add AC_CHECK_FUNCS(munmap) there too?
if test "x$enable_mmap" = "xyes"; then
)
AC_LANG_POP(C)
+dnl Could use these to know if we need to provide a prototype
+dnl AC_CHECK_DECLS(fdatasync, [], [], [#include <unistd.h>])
+
+dnl solaris has fdatasync in the librt
+
+AC_CHECK_FUNC(fdatasync, [], AC_CHECK_LIB(rt, fdatasync, [LIBS="${LIBS} -lrt"],[]))
+
+
CONFIGURE_PART(Find 3rd-Party Libraries)
diff --git a/doc/rrdbuild.pod b/doc/rrdbuild.pod
index 9ca238bd7e3c0e499cca302e8268d4a6546fc8c6..f364aa2448799e35957c295b83cb7597a057a219 100644 (file)
--- a/doc/rrdbuild.pod
+++ b/doc/rrdbuild.pod
This document will tell you about all the necessary steps to get going.
+These instructions assume you are using a bash shell. If you use csh/tcsh,
+then you can either type 'bash' to switch to bash for the compilation or if
+you know what you are doing just replace replace the export bits with
+setenv.
+
+We further assume that your copies of B<tar> and B<make> are actually B<GNU
+tar> and B<GNU make> respectively. It could be that they are installed as
+B<gtar> and B<gmake> on your system.
+
=head2 Building
Before you start to build RRDtool, you have to decide two things:
cd $BUILD_DIR
Lets first assume you already have all the necessary libraries
-pre-installed. Note that these instructions assume that your copies of
-B<tar> and B<make> are actually B<GNU tar> and B<GNU make> respectively. It
-could be that they are installed as B<gtar> and B<gmake> on your system.
-
+pre-installed.
wget http://oss.oetiker.ch/rrdtool/pub/rrdtool-1.2.99907080300.tar.gz
- tar zxf rrdtool-1.2.99907080300.tar.gz
+ gunzip -c rrdtool-1.2.99907080300.tar.gz | tar xf -
cd rrdtool-1.2.99907080300
./configure --prefix=$INSTALL_DIR && make && make install
Some libraries want to know where other libraries are. For this to work,
set the following environamen variable
- export PKG_CONFIG_PATH=${INSTALLDIR}/lib/pkgconfig
+ export PKG_CONFIG_PATH=${INSTALL_DIR}/lib/pkgconfig
+ export PATH=$INSTALL_DIR/bin:$PATH
-or in tcsh
+If you have GNUmake installed and it is not called 'make',
+then do
- setenv PKG_CONFIG_PATH ${INSTALLDIR}/lib/pkgconfig
+ export MAKE=gmake
+ export GNUMAKE=gmake
+otherwhise just do
+
+ export MAKE=make
+
+
=item Building zlib
Chances are very high that you already have that on your system ...
cd $BUILD_DIR
wget http://oss.oetiker.ch/rrdtool/pub/libs/zlib-1.2.3.tar.gz
- tar zxf zlib-1.2.3.tar.gz
+ gunzip -c zlib-1.2.3.tar.gz | tar xf -
cd zlib-1.2.3
- env CFLAGS="-O3 -fPIC" ./configure --prefix=$INSTALL_DIR
- make
- make install
+ ./configure --prefix=$INSTALL_DIR CFLAGS="-O3 -fPIC"
+ $MAKE
+ $MAKE install
=item Building libpng
cd $BUILD_DIR
wget http://oss.oetiker.ch/rrdtool/pub/libs/libpng-1.2.18.tar.gz
- tar zxvf libpng-1.2.18.tar.gz
+ gunzip -c libpng-1.2.18.tar.gz | tar xf -
cd libpng-1.2.10
env CFLAGS="-O3 -fPIC" ./configure --prefix=$INSTALL_DIR
- make
- make install
+ $MAKE
+ $MAKE install
=item Building freetype
cd $BUILD_DIR
wget http://oss.oetiker.ch/rrdtool/pub/libs/freetype-2.3.5.tar.gz
- tar zxvf freetype-2.3.5.tar.gz
+ gunzip -c freetype-2.3.5.tar.gz | tar xf -
cd freetype-2.3.5
- env CFLAGS="-O3 -fPIC" \
- ./configure --prefix=$INSTALL_DIR
- make
- make install
+ ./configure --prefix=$INSTALL_DIR CFLAGS="-O3 -fPIC"
+ $MAKE (or gmake)
+ $MAKE install (or gmake install)
If you run into problems building freetype on Solaris, you may want to try to
-add the following at the end of the configure line:
+add the following at the start the configure line:
- GNUMAKE=gmake EGREP=egrep
+ env GNUMAKE=gmake EGREP=egrep
=item Building fontconfig
cd $BUILD_DIR
wget http://oss.oetiker.ch/rrdtool/pub/libs/fontconfig-2.4.2.tar.gz
- tar zxvf fontconfig-2.4.2.tar.gz
+ gunzip -c fontconfig-2.4.2.tar.gz | tar xf -
cd fontconfig-2.4.2
- env CFLAGS="-O3 -fPIC" ./configure --prefix=$INSTALL_DIR
- make
- make install
+ ./configure --prefix=$INSTALL_DIR CFLAGS="-O3 -fPIC"
+ $MAKE
+ $MAKE install
=item Building Cairo
cd $BUILD_DIR
wget http://oss.oetiker.ch/rrdtool/pub/libs/cairo-1.4.10.tar.gz
- tar zxvf cairo-1.4.10.tar.gz
+ gunzip -c cairo-1.4.10.tar.gz | tar xf -
cd cairo-1.4.10
- env CFLAGS="-O3 -fPIC" ./configure --prefix=$INSTALL_DIR \
+ ./configure --prefix=$INSTALL_DIR \
--enable-xlib=no \
--enable-xlib-render=no \
- --enable-win32=no
- make
- make install
+ --enable-win32=no \
+ CFLAGS="-O3 -fPIC"
+ $MAKE
+ $MAKE install
=item Building Glib
cd $BUILD_DIR
wget http://oss.oetiker.ch/rrdtool/pub/libs/glib-2.12.13.tar.gz
- tar zxvf glib-2.12.13.tar.gz
+ gunzip -c glib-2.12.13.tar.gz | tar xf -
cd glib-2.12.13
- env CFLAGS="-O3 -fPIC" ./configure --prefix=$INSTALL_DIR
- make
- make install
+ ./configure --prefix=$INSTALL_DIR CFLAGS="-O3 -fPIC"
+ $MAKE
+ $MAKE install
=item Building Pango
cd $BUILD_DIR
wget http://oss.oetiker.ch/rrdtool/pub/libs/pango-1.17.5.tar.gz
- tar zxvf pango-1.17.5.tar.gz
+ gunzip -c pango-1.17.5.tar.gz | tar xf -
cd pango-1.17.5
- env CFLAGS="-O3 -fPIC" ./configure --prefix=$INSTALL_DIR
- make
- make install
+ ./configure --prefix=$INSTALL_DIR CFLAGS="-O3 -fPIC"
+ $MAKE
+ $MAKE install
=back
you tell configure where it should be looking for libraries and include
files. This is done via environment variables. Depending on the shell you
are running, the syntax for setting environment variables is different.
-Under csh/tcsh you use:
-
- setenv CPPFLAGS -I$INSTALL_DIR/include
- setenv LDFLAGS "-L$INSTALL_DIR/lib -R$INSTALL_DIR/lib"
- setenv CFLAGS -O3
-
-If you are running bash/sh/ash/ksh/zsh use this:
CPPFLAGS=-I$INSTALL_DIR/include
LDFLAGS="-R$INSTALL_DIR/lib -L$INSTALL_DIR/lib"
cd $BUILD_DIR/rrdtool-1.2.99907080300
./configure --prefix=$INSTALL_DIR --disable-tcl --disable-python
- make clean
- make
- make install
+ $MAKE clean
+ $MAKE
+ $MAKE install
SOLARIS HINT: if you want to build the perl module for the native perl (the
one shipping with solaris) you will need the sun forte compiler installed on
diff --git a/src/rrd_getopt.c b/src/rrd_getopt.c
index d03b456e8297cc8d7446c848b56fa77ef9c8578a..706a67ab8b3ec3fbd8f781ec85bf0639ef2109db 100644 (file)
--- a/src/rrd_getopt.c
+++ b/src/rrd_getopt.c
of the value of `ordering'. In the case of RETURN_IN_ORDER, only
`--' can cause `getopt' to return -1 with `optind' != ARGC. */
-static const enum {
+static enum {
REQUIRE_ORDER, PERMUTE, RETURN_IN_ORDER
} ordering;