X-Git-Url: http://git.indexdata.com/?p=idzebra-moved-to-github.git;a=blobdiff_plain;f=win%2Fmakefile;h=2d73d8c22ef6d85341c501bc1c42d0b7acaa34c8;hp=06e8f15da80064686f60f1b41229b854afdfb07b;hb=27d70cebc8400fd364453a6bf9445531a66872d9;hpb=1d0216216cbc58d92173a9da209fb5ce8559e584 diff --git a/win/makefile b/win/makefile index 06e8f15..2d73d8c 100644 --- a/win/makefile +++ b/win/makefile @@ -1,42 +1,42 @@ # Zebra makefile for MS NMAKE -# $Id: makefile,v 1.75 2008-01-18 11:33:36 adam Exp $ ########################################################### ############### Parameters ########################################################### DEBUG=0 # 0 for release, 1 for debug +USE_MANIFEST = 0 + +# TCL is optional - ONLY needed for source straight from Git +TCL=tclsh +#TCL="C:\Tcl\bin\tclsh85.exe" +HAVE_TCL=1 # EXPAT is optional. It's required for grs.xml-filters. HAVE_EXPAT=1 -EXPAT_DIR=c:\Program files\Expat 2.0.1 +EXPAT_DIR=c:\Program files (x86)\Expat 2.0.1 # iconv is optional -HAVE_ICONV=1 +HAVE_ICONV=0 ICONV_DIR=c:\iconv-1.9.2.win32 # libxslt. For mod_dom and mod_alvis HAVE_LIBXSLT=1 -LIBXSLT_DIR=c:\libxslt-1.1.24.win32 +LIBXSLT_DIR=c:\libxslt-1.1.28.win32 # libxml2. Used by libxslt HAVE_LIBXML2=1 -LIBXML2_DIR=c:\libxml2-2.7.1.win32 - -# zlib compression. Used by libxml2 -ZLIB_DIR = c:\zlib-1.2.3.win32 - -# get WIN32 binaries libxml2 & iconv & zlib from here: -# http://www.zlatkovic.com/libxml.en.html +LIBXML2_DIR=c:\libxml2-2.9.2.win32 # ICU support -# get icu libraries from http://www.icu-project.org HAVE_ICU=1 ICU_DIR=c:\icu - +ICU_LIB=$(ICU_DIR)\lib +ICU_BIN=$(ICU_DIR)\bin +ICU_INCLUDE=$(ICU_DIR)\include default: all -all: dirs expat iconv libxml2 libxslt icu yaz dll zserver zebraidx tstflock +all: dirs generate expat iconv yaz dll zserver zebraidx tstflock # Directories # The current directory is supposed to be something like @@ -48,19 +48,19 @@ YAZDIR=$(ROOTDIR)\..\yaz # or \program files\yaz YAZBINDIR=$(YAZDIR)\bin !if $(DEBUG) -YAZLIB="$(YAZDIR)\lib\yaz3d.lib" +YAZLIB="$(YAZDIR)\lib\yaz5d.lib" !if $(HAVE_ICU) -YAZLIB=$(YAZLIB) "$(YAZDIR)\lib\yaz_icu3d.lib" +YAZLIB=$(YAZLIB) "$(YAZDIR)\lib\yaz_icu5d.lib" !endif -YAZ_DLL_SOURCE="$(YAZBINDIR)\yaz3d.dll" -YAZ_DLL_TARGET="$(BINDIR)\yaz3d.dll" +YAZ_DLL_SOURCE="$(YAZBINDIR)\yaz5d.dll" +YAZ_DLL_TARGET="$(BINDIR)\yaz5d.dll" !else -YAZLIB="$(YAZDIR)\lib\yaz3.lib" +YAZLIB="$(YAZDIR)\lib\yaz5.lib" !if $(HAVE_ICU) -YAZLIB=$(YAZLIB) "$(YAZDIR)\lib\yaz_icu3.lib" +YAZLIB=$(YAZLIB) "$(YAZDIR)\lib\yaz_icu5.lib" !endif -YAZ_DLL_SOURCE="$(YAZBINDIR)\yaz3.dll" -YAZ_DLL_TARGET="$(BINDIR)\yaz3.dll" +YAZ_DLL_SOURCE="$(YAZBINDIR)\yaz5.dll" +YAZ_DLL_TARGET="$(BINDIR)\yaz5.dll" !endif # BZIP2 settings. Uncomment and specify if you wish to use LIBBZIP2. @@ -101,7 +101,7 @@ TMP=$(TMPDIR) TEMP=$(TMPDIR) # NSIS -NSIS="c:\program files\nsis\makensis.exe" +NSIS="c:\program files (x86)\nsis\makensis.exe" dist: nmake DEBUG=1 clean @@ -166,52 +166,27 @@ iconv: !if $(HAVE_LIBXML2) LIBXML2_LIB="$(LIBXML2_DIR)\lib\libxml2.lib" -LIBXML2_DEF=/DYAZ_HAVE_XML2=1 /D HAVE_XML2=1 /I"$(LIBXML2_DIR)\include" -libxml2: $(BINDIR)\libxml2.dll $(BINDIR)\zlib1.dll - -$(BINDIR)\libxml2.dll: - copy "$(LIBXML2_DIR)\bin\libxml2.dll" $(BINDIR) - -$(BINDIR)\zlib1.dll: - copy "$(ZLIB_DIR)\bin\zlib1.dll" $(BINDIR) - +LIBXML2_DEF=/DYAZ_HAVE_XML2=1 /D HAVE_XML2=1 /I"$(LIBXML2_DIR)\include\libxml2" !else LIBXML2_LIB= LIBXML2_DEF=/D HAVE_XML2=0 -libxml2: - !endif !if $(HAVE_LIBXSLT) LIBXSLT_LIB="$(LIBXSLT_DIR)\lib\libxslt.lib" LIBXSLT_DEF=/D HAVE_XSLT=1 /I"$(LIBXSLT_DIR)\include" -libxslt: $(BINDIR)\libxslt.dll - -$(BINDIR)\libxslt.dll: - copy "$(LIBXSLT_DIR)\bin\libxslt.dll" $(BINDIR) - !else LIBXSLT_LIB= LIBXSLT_DEF=/D HAVE_XSLT=0 -libxslt: !endif !if $(HAVE_ICU) -ICU_DEF= /DYAZ_HAVE_ICU=1 /I"$(ICU_DIR)\include" -ICU_LIB= $(ICU_DIR)\lib\icudt.lib $(ICU_DIR)\lib\icuin.lib $(ICU_DIR)\lib\icuuc.lib -icu: $(BINDIR)\icudt40.dll $(BINDIR)\icuin40.dll $(BINDIR)\icuuc40.dll - -$(BINDIR)\icudt40.dll: - copy "$(ICU_DIR)\bin\icudt40.dll" $(BINDIR) -$(BINDIR)\icuin40.dll: - copy "$(ICU_DIR)\bin\icuin40.dll" $(BINDIR) -$(BINDIR)\icuuc40.dll: - copy "$(ICU_DIR)\bin\icuuc40.dll" $(BINDIR) +ICU_DEF= /DYAZ_HAVE_ICU=1 /I"$(ICU_INCLUDE)" +ICU_LIBS= $(ICU_LIB)\icudt.lib $(ICU_LIB)\icuin.lib $(ICU_LIB)\icuuc.lib !else ICU_DEF= /DYAZ_HAVE_ICU=0 -ICU_LIB= -icu: +ICU_LIBS= !endif !if $(HAVE_LIBXSLT) @@ -234,11 +209,10 @@ MOD_DOM_CFLAGS= COMMON_C_OPTIONS= \ /nologo /W3 /EHsc /FD /c \ - /D "WIN32" \ - /D"_CONSOLE" /D"_MBCS" \ /DYAZ_USE_NEW_LOG=1 \ /D"_CRT_SECURE_NO_DEPRECATE" \ /D"_CRT_NONSTDC_NO_DEPRECATE" \ + /D "WIN32" \ $(ICONV_DEF) \ $(EXPAT_DEF) \ $(LIBXML2_DEF) \ @@ -266,11 +240,11 @@ COMMON_C_INCLUDES= \ $(BZIP2INCLUDE) DEBUG_C_OPTIONS= \ - /D "_DEBUG" \ - /MDd /Od /YX /Zi /Gm + /D "_DEBUG" \ + /MDd /Od /Zi /Gm -RELEASE_C_OPTIONS= \ - /D "NDEBUG" \ +RELEASE_C_OPTIONS= \ + /D "NDEBUG" \ /MD /O2 # /W3 = warning level @@ -292,11 +266,16 @@ RELEASE_C_OPTIONS= \ ### Linker options LINK=link.exe -LINK_LIBS= kernel32.lib user32.lib gdi32.lib winspool.lib \ - comdlg32.lib advapi32.lib shell32.lib ole32.lib \ - oleaut32.lib uuid.lib odbc32.lib odbccp32.lib \ - wsock32.lib advapi32.lib \ - $(ICONV_LIB) $(EXPAT_LIB) $(LIBXML2_LIB) $(LIBXSLT_LIB) $(ICU_LIB) +!if $(USE_MANIFEST) +MT=mt.exe /nologo +!else +MT=echo +!endif + +# wsock32.lib advapi32.lib \ + +LINK_LIBS= kernel32.lib advapi32.lib \ + $(ICONV_LIB) $(EXPAT_LIB) $(LIBXML2_LIB) $(LIBXSLT_LIB) $(ICU_LIBS) COMMON_LNK_OPTIONS= /nologo /machine:i386 /incremental:no @@ -332,6 +311,14 @@ LINK_PROGRAM= $(LINK) \ $(BZIP2LIB) \ $(LINK_LIBS) + +# Generated sources +generate: $(INCLDIR)\idzebra\version.h + +$(INCLDIR)\idzebra\version.h: $(ROOTDIR)/IDMETA + @cd $(ROOTDIR)\util + $(TCL) mk_version.tcl $(ROOTDIR)/IDMETA $(INCLDIR)\idzebra\version.h + # Source and object modules # Note: Ordinary source files are not specified here at # all, make finds them in suitable dirs. The object modules @@ -500,19 +487,16 @@ ZEBRALIB_OBJS= \ # Linking $(ZSERVER) : "$(BINDIR)" $(ZSERVER_OBJS) $(IMPLIB) - $(LINK_PROGRAM) \ - $(ZSERVER_OBJS) \ - /out:$(ZSERVER) + $(LINK_PROGRAM) $(ZSERVER_OBJS) /out:$@ + $(MT) -manifest $@.manifest -outputresource:$@;1 $(ZEBRAIDX) : "$(BINDIR)" $(ZEBRAIDX_OBJS) $(IMPLIB) - $(LINK_PROGRAM) \ - $(ZEBRAIDX_OBJS) \ - /out:$(ZEBRAIDX) + $(LINK_PROGRAM) $(ZEBRAIDX_OBJS) /out:$@ + $(MT) -manifest $@.manifest -outputresource:$@;1 $(TSTFLOCK) : "$(BINDIR)" $(TSTFLOCK_OBJS) $(IMPLIB) - $(LINK_PROGRAM) \ - $(TSTFLOCK_OBJS) \ - /out:$(TSTFLOCK) + $(LINK_PROGRAM) $(TSTFLOCK_OBJS) /out:$@ + $(MT) -manifest $@.manifest -outputresource:$@;1 # Resources RES=$(OBJDIR)\zebra.res @@ -536,10 +520,11 @@ $(DLL) $(IMPLIB): "$(BINDIR)" $(ZEBRALIB_OBJS) $(RES) $(DLL_LINK_OPTIONS) \ $(ZEBRALIB_OBJS) \ $(RES) \ - /out:$(DLL) \ + /out:$@ \ $(YAZLIB) \ /implib:"$(IMPLIB)" \ - /map:"$(LIBDIR)\idzebra.map" \ + /map:"$(LIBDIR)\idzebra.map" + $(MT) -manifest $@.manifest -outputresource:$@;2 # Other rules