-# Gnu Makefile for Win32 target * 14-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
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
# 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
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
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
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$(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
$(EOLIST)\r
endif\r
\r
-CGIOBJS = \\r
+CGILIBOBJS = \\r
$(OBJDIR)/cgi.o \\r
$(OBJDIR)/cookies.o \\r
$(EOLIST)\r
ARTLIBOBJS = \\r
$(patsubst $(LIBART)/libart_lgpl/%.c,$(OBJDIR)/%.o,$(wildcard $(LIBART)/libart_lgpl/art_*.c))\r
\r
-OBJS = $(RRDLIBOBJS) $(XLIBOBJS) $(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
+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\r
- -$(RM) $(OBJDIR)/*.o $(OBJDIR)/$(TARGET).map $(OBJDIR)/$(TARGET).ncv\r
- -$(RM) $(OBJDIR)/$(TARGET).def $(OBJDIR)/$(TARGET).res\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
@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
@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
@echo $(DL)#define RRDGRAPH_YLEGEND_ANGLE $(RRDGRAPH_YLEGEND_ANGLE)$(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)MRTG rrdtool version $(RRD_VERSION_STR)$(DL) >> $@\r
- @echo $(DL)Please download the complete RRD package for$(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