tell Makefile.PL how to store an rpath under aix
[rrdtool.git] / src / Makefile.Win32
index 04e4037..39e5ede 100644 (file)
@@ -1,11 +1,6 @@
-# Gnu Makefile for Win32 target * 04-Jan-2006\r
+# Gnu Makefile for Win32 target * 29-Jan-2006\r
 # for use with MingW32 gcc or Metrowerks CodeWarrior compiler\r
-# use with: make -f Makefile.Win32 [all|clean|dist] [BINEXT=cgi]\r
-\r
-# What to build\r
-ifndef BINEXT\r
-BINEXT = exe\r
-endif\r
+# use with: make -f Makefile.Win32 [all|clean|dist]\r
 \r
 DESCR  = Round Robin Database Tool\r
 COPYR  = Copyright (c) 1997-2006 by Tobias Oetiker\r
@@ -13,21 +8,27 @@ COPYR        = Copyright (c) 1997-2006 by Tobias Oetiker
 WWWURL = http://www.rrdtool.org/\r
 ICON   = ../favicon.ico\r
 \r
+# Set the default font used in graphs.\r
+ifndef RRD_DEFAULT_FONT\r
+RRD_DEFAULT_FONT = "arial.ttf"\r
+#RRD_DEFAULT_FONT = "DejaVuSansMono-Roman.ttf"\r
+#RRD_DEFAULT_FONT = "VeraMono.ttf"\r
+endif\r
+\r
 # Vertical label angle: 90.0 (default) or 270.0\r
 RRDGRAPH_YLEGEND_ANGLE = 90.0\r
 \r
+# Set to one if you want to have piecharts.\r
+WITH_PIECHART = 1\r
+\r
 # Edit the path below to point to your install destination.\r
-INSTDIR        = c:/mrtg/rrd\r
+INSTDIR        = c:/rrdtool\r
 \r
 # Base for the lib sources\r
 ifndef LIBBASE\r
 LIBBASE        = ../..\r
 endif\r
-# All library code is statically linked to avoid problems with other lib NLMs. \r
-# Edit the path below to point to your libgd sources or set environment var.\r
-ifndef LIBGD\r
-LIBGD  = $(LIBBASE)/gd-2.0.15\r
-endif\r
+# All library code is statically linked to avoid problems with other lib DLLs. \r
 # Edit the path below to point to your libpng sources or set environment var.\r
 ifndef LIBPNG\r
 LIBPNG = $(LIBBASE)/libpng-1.2.8\r
@@ -50,6 +51,9 @@ ifndef LIBCGI
 LIBCGI = $(LIBBASE)/cgilib-0.5\r
 endif\r
 \r
+# whatever...\r
+NO_NULL_REALLOC = 1\r
+\r
 # The following line defines your compiler.\r
 ifdef METROWERKS\r
        CC = mwcc\r
@@ -59,6 +63,9 @@ endif
 # RM   = rm -f\r
 CP     = cp -afv\r
 \r
+ZIP    = zip -qzR9\r
+ARCHIVE        = rrdtool-$(RRD_VERSION_STR)-w32.zip\r
+\r
 # must be equal to DEBUG or NDEBUG\r
 DB     = NDEBUG\r
 # DB   = DEBUG\r
@@ -81,18 +88,22 @@ ifeq ($(CC),mwcc)
 LD     = mwld\r
 RC     = mwwinrc\r
 LDFLAGS        = -nostdlib\r
+AR     = $(LD)\r
+ARFLAGS        = -type library -w nocmdline $(OBJS) -o\r
 LIBEXT = lib\r
 LIBPATH        += -lr "$(METROWERKS)/MSL" -lr "$(METROWERKS)/Win32-x86 Support"\r
 LDLIBS += -lkernel32.lib -luser32.lib\r
 LDLIBS += -lMSL_Runtime_x86.lib -lMSL_C_x86.lib -lMSL_Extras_x86.lib\r
 RCFLAGS        =\r
-CFLAGS += -gccinc -msgstyle gcc -inline off -opt nointrinsics -inst mmx -proc 586\r
+CFLAGS += -nostdinc -gccinc -msgstyle gcc -inline off -opt nointrinsics -proc 586\r
 CFLAGS += -ir "$(METROWERKS)/MSL" -ir "$(METROWERKS)/Win32-x86 Support"\r
-#CFLAGS        += -w on,nounused,nounusedexpr # -ansi strict\r
+CFLAGS += -w on,nounused,nounusedexpr # -ansi strict\r
 else\r
 LD     = gcc\r
 RC     = windres\r
 LDFLAGS        = -s\r
+AR     = ar\r
+ARFLAGS        = -cq\r
 LIBEXT = a\r
 RCFLAGS        = -I rc -O coff -i\r
 CFLAGS += -fno-strict-aliasing -Wall -Wno-unused # -pedantic\r
@@ -102,18 +113,15 @@ ifndef COPYR
        COPYR = Copyright (c) 2006 The Open Source Community.\r
 endif\r
 ifndef DESCR\r
-       DESCR = $(TARGET) Command Extension\r
+       DESCR = $(notdir $(@:.rc=)) Command Extension\r
 endif\r
 DESCR += - $(CC) build\r
 \r
-INCLUDES += -I. -I$(LIBGD) -I$(LIBPNG) -I$(LIBFT2)/include -I$(LIBART) -I$(ZLIBSDK)\r
-ifeq ($(BINEXT),cgi)\r
-INCLUDES += -I$(LIBCGI)\r
-endif\r
+INCLUDES += -I. -I$(LIBPNG) -I$(LIBFT2)/include -I$(LIBART) -I$(ZLIBSDK) -I$(LIBCGI)\r
 \r
 CFLAGS += $(INCLUDES)\r
 \r
-vpath %.c . $(LIBGD) $(LIBPNG) $(LIBART)/libart_lgpl $(ZLIBSDK) $(LIBCGI)\r
+vpath %.c . $(LIBPNG) $(LIBART)/libart_lgpl $(ZLIBSDK) $(LIBCGI)\r
 \r
 RRDLIBOBJS     = \\r
        $(OBJDIR)/rrd_afm.o \\r
@@ -140,7 +148,7 @@ RRDLIBOBJS  = \
        $(OBJDIR)/rrd_update.o \\r
        $(OBJDIR)/rrd_version.o \\r
        $(OBJDIR)/rrd_xport.o \\r
-       $(OBJDIR)/rrd_not_thread_safe.o \\r
+       $(OBJDIR)/rrd_thread_safe_nt.o \\r
        $(EOLIST)\r
 \r
 XLIBOBJS       = \\r
@@ -153,20 +161,6 @@ XLIBOBJS   = \
        $(OBJDIR)/strftime.o \\r
        $(EOLIST)\r
 \r
-GD2LIBOBJS     = \\r
-       $(OBJDIR)/gd.o \\r
-       $(OBJDIR)/gd_io.o \\r
-       $(OBJDIR)/gd_io_dp.o \\r
-       $(OBJDIR)/gd_io_file.o \\r
-       $(OBJDIR)/gd_io_ss.o \\r
-       $(OBJDIR)/gd_png.o \\r
-       $(OBJDIR)/gd_ss.o \\r
-       $(OBJDIR)/gdcache.o \\r
-       $(OBJDIR)/gdfonts.o \\r
-       $(OBJDIR)/gdhelpers.o \\r
-       $(OBJDIR)/gdtables.o \\r
-       $(EOLIST)\r
-\r
 PNGLIBOBJS     = \\r
        $(OBJDIR)/png.o \\r
        $(OBJDIR)/pngerror.o \\r
@@ -210,7 +204,7 @@ ZLIBOBJS    += \
        $(EOLIST)\r
 endif\r
 \r
-CGIOBJS        = \\r
+CGILIBOBJS     = \\r
        $(OBJDIR)/cgi.o \\r
        $(OBJDIR)/cookies.o \\r
        $(EOLIST)\r
@@ -218,33 +212,42 @@ CGIOBJS   = \
 ARTLIBOBJS     = \\r
        $(patsubst $(LIBART)/libart_lgpl/%.c,$(OBJDIR)/%.o,$(wildcard $(LIBART)/libart_lgpl/art_*.c))\r
 \r
-OBJS   = $(RRDLIBOBJS) $(XLIBOBJS) $(GD2LIBOBJS) $(PNGLIBOBJS) $(ARTLIBOBJS) $(ZLIBOBJS)\r
-\r
-ifeq ($(BINEXT),cgi)\r
-OBJS   += $(CGIOBJS) $(OBJDIR)/rrd_cgi.o\r
-TARGET = rrdcgi\r
-else\r
-OBJS   += $(OBJDIR)/rrd_tool.o\r
-TARGET = rrdtool\r
-endif\r
+OBJS   := $(RRDLIBOBJS) $(XLIBOBJS) $(PNGLIBOBJS) $(ARTLIBOBJS) $(ZLIBOBJS)\r
+OBJCGI := $(OBJS) $(CGILIBOBJS) $(OBJDIR)/rrd_cgi.o\r
+OBJTOOL        := $(OBJS) $(OBJDIR)/rrd_tool.o\r
 \r
 LDLIBS += $(LIBFT2)/objs/freetype.$(LIBEXT)\r
 \r
 \r
-all: $(OBJDIR) config.h $(OBJDIR)/$(TARGET).$(BINEXT)\r
+all: rrdtool rrdcgi\r
 \r
-dist: all\r
-       -$(RM) $(OBJDIR)/*.o $(OBJDIR)/$(TARGET).map $(OBJDIR)/$(TARGET).ncv\r
-       -$(RM) $(OBJDIR)/$(TARGET).def $(OBJDIR)/$(TARGET).res\r
+rrdtool: $(OBJDIR) config.h $(OBJDIR)/rrdtool.exe\r
+rrdcgi: $(OBJDIR) config.h $(OBJDIR)/rrdcgi.exe\r
+librrd: $(OBJDIR) config.h $(OBJDIR)/librrd.$(LIBEXT)\r
+\r
+dist: all $(OBJDIR)/readme.txt\r
+       -$(RM) $(OBJDIR)/*.o $(OBJDIR)/*.map $(OBJDIR)/*.ncv\r
+       -$(RM) $(OBJDIR)/*.def $(OBJDIR)/*.res $(OBJDIR)/*.rc\r
+       -$(RM) $(OBJDIR)/version.inc\r
+       @-$(CP) ../CHANGES $(OBJDIR)\r
+       @-$(CP) ../COPYING $(OBJDIR)\r
+       @-$(CP) ../COPYRIGHT $(OBJDIR)\r
+       @-$(CP) ../NEWS $(OBJDIR)\r
+       @-$(CP) ../README $(OBJDIR)\r
+       @echo Creating $(ARCHIVE)\r
+       @$(ZIP) $(ARCHIVE) $(OBJDIR)/* < $(OBJDIR)/readme.txt\r
 \r
 install: all\r
        @[ -d $(INSTDIR) ] || mkdir $(INSTDIR)\r
-       @$(CP) $(TARGET).$(BINEXT) $(INSTDIR)\r
+       @$(CP) $(OBJDIR)/*.exe $(INSTDIR)\r
 \r
 clean:\r
        -$(RM) -r $(OBJDIR)\r
        -$(RM) config.h\r
 \r
+cleandist: clean\r
+       -$(RM) $(ARCHIVE)\r
+\r
 $(OBJDIR):\r
        @mkdir $(OBJDIR)\r
 \r
@@ -256,11 +259,21 @@ $(OBJDIR)/%.o: %.c
        @echo Compiling $<\r
        @$(CC) $(CFLAGS) -c $< -o $@\r
 \r
-$(OBJDIR)/$(TARGET).$(BINEXT): $(OBJS) $(OBJDIR)/$(TARGET).res\r
+$(OBJDIR)/rrdcgi.exe: $(OBJCGI) $(OBJDIR)/rrdcgi.res\r
        @echo Linking $@\r
        @-$(RM) $@\r
        @$(LD) $(LDFLAGS) $^ -o $@ $(LIBPATH) $(LDLIBS)\r
 \r
+$(OBJDIR)/rrdtool.exe: $(OBJTOOL) $(OBJDIR)/rrdtool.res\r
+       @echo Linking $@\r
+       @-$(RM) $@\r
+       @$(LD) $(LDFLAGS) $^ -o $@ $(LIBPATH) $(LDLIBS)\r
+\r
+$(OBJDIR)/librrd.$(LIBEXT): $(OBJS)\r
+       @echo Creating $@\r
+       @-$(RM) $@\r
+       @$(AR) $(ARFLAGS) $@ $^\r
+\r
 $(OBJDIR)/%.res: $(OBJDIR)/%.rc\r
        @echo Creating $@\r
        @$(RC) $(RCFLAGS) $< -o $@\r
@@ -281,13 +294,13 @@ $(OBJDIR)/%.rc: Makefile.Win32 $(OBJDIR)/version.inc
        @echo     BEGIN >> $@\r
        @echo       VALUE "LegalCopyright","$(COPYR)\0" >> $@\r
 #      @echo       VALUE "CompanyName","$(COMPANY)\0" >> $@\r
-       @echo       VALUE "ProductName","$(TARGET).$(BINEXT)\0" >> $@\r
+       @echo       VALUE "ProductName","$(notdir $(@:.rc=.exe))\0" >> $@\r
        @echo       VALUE "ProductVersion","$(RRD_VERSION_STR)\0" >> $@\r
        @echo       VALUE "License","Released under GPL.\0" >> $@\r
        @echo       VALUE "FileDescription","$(DESCR)\0" >> $@\r
        @echo       VALUE "FileVersion","$(RRD_VERSION_STR)\0" >> $@\r
-       @echo       VALUE "InternalName","$(TARGET)\0" >> $@\r
-       @echo       VALUE "OriginalFilename","$(TARGET).$(BINEXT)\0" >> $@\r
+       @echo       VALUE "InternalName","$(notdir $(@:.rc=))\0" >> $@\r
+       @echo       VALUE "OriginalFilename","$(notdir $(@:.rc=.exe))\0" >> $@\r
 ifdef WWWURL\r
        @echo       VALUE "WWW","$(WWWURL)\0" >> $@\r
 endif\r
@@ -342,7 +355,7 @@ config.h: Makefile.Win32 $(OBJDIR)/version.inc
        @echo $(DL)#define HAVE_STRLCAT 1$(DL) >> $@\r
        @echo $(DL)#define HAVE_STRLCPY 1$(DL) >> $@\r
        @echo $(DL)#define HAVE_STRSTR 1$(DL) >> $@\r
-       @echo $(DL)#define HAVE_SYS_PARAM_H 1$(DL) >> $@\r
+#      @echo $(DL)#define HAVE_SYS_PARAM_H 1$(DL) >> $@\r
        @echo $(DL)#define HAVE_SYS_SELECT_H 1$(DL) >> $@\r
        @echo $(DL)#define HAVE_SYS_STAT_H 1$(DL) >> $@\r
        @echo $(DL)#define HAVE_SYS_TIME_H 1$(DL) >> $@\r
@@ -353,8 +366,25 @@ config.h: Makefile.Win32 $(OBJDIR)/version.inc
        @echo $(DL)#define TIME_WITH_SYS_TIME 1$(DL) >> $@\r
        @echo $(DL)#define HAVE_ZLIB_H 1$(DL) >> $@\r
        @echo $(DL)#define HAVE_LIBZ 1$(DL) >> $@\r
+ifdef NO_NULL_REALLOC\r
+       @echo $(DL)#define NO_NULL_REALLOC 1$(DL) >> $@\r
+       @echo $(DL)#define rrd_realloc(a,b) ( (a) == NULL ? malloc( (b) ) : realloc( (a) , (b) ))$(DL) >> $@\r
+else\r
        @echo $(DL)#define rrd_realloc(a,b) realloc((a), (b))$(DL) >> $@\r
+endif\r
        @echo $(DL)#define RRDGRAPH_YLEGEND_ANGLE $(RRDGRAPH_YLEGEND_ANGLE)$(DL) >> $@\r
-       @echo $(DL)#define RRD_DEFAULT_FONT "arial.ttf"$(DL) >> $@\r
+       @echo $(DL)#define RRD_DEFAULT_FONT $(RRD_DEFAULT_FONT)$(DL) >> $@\r
+       @echo $(DL)#define strftime strftime_$(DL) >> $@\r
+ifdef WITH_PIECHART\r
+       @echo $(DL)#define WITH_PIECHART 1$(DL) >> $@\r
+endif\r
+\r
+$(OBJDIR)/readme.txt: Makefile.Win32\r
+       @echo Creating $@\r
+       @echo $(DL)This is a binary distribution for Win32 platform.$(DL) > $@\r
+       @echo $(DL)RRDTool version $(RRD_VERSION_STR)$(DL) >> $@\r
+       @echo $(DL)Please download the complete RRDTool package for$(DL) >> $@\r
+       @echo $(DL)any further documentation:$(DL) >> $@\r
+       @echo $(DL)http://www.rrdtool.org/$(DL) >> $@\r
 \r
 \r