# Zebra makefile for MS NMAKE
-# $Id: makefile,v 1.46 2006-05-19 17:28:55 adam Exp $
###########################################################
############### Parameters
DEBUG=0 # 0 for release, 1 for debug
+# TCL is optional - ONLY needed for source straight from Git
+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:\Expat-1.95.8
+EXPAT_DIR=c:\Program files\Expat 2.0.1
# iconv is optional
HAVE_ICONV=1
-ICONV_DIR=c:\iconv-1.9.1.win32
+ICONV_DIR=c:\iconv-1.9.2.win32
-# libxslt. For xslt+alvis
+# libxslt. For mod_dom and mod_alvis
HAVE_LIBXSLT=1
-LIBXSLT_DIR=c:\libxslt-1.1.14.win32
+LIBXSLT_DIR=c:\libxslt-1.1.24.win32
# libxml2. Used by libxslt
HAVE_LIBXML2=1
-LIBXML2_DIR=c:\libxml2-2.6.20.win32
+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
-default: all
+# ICU support
+# get icu libraries from http://www.icu-project.org
+HAVE_ICU=1
+ICU_DIR=c:\icu
-all: dirs expat iconv libxml2 libxslt yaz dll zserver zindex
-###########################################################
-############### Directories
-###########################################################
+default: all
+all: dirs generate expat iconv libxml2 libxslt icu yaz dll zserver zebraidx tstflock
+
+# Directories
# The current directory is supposed to be something like
# ..../Zebra/Win, everything is relative to that
ROOTDIR=.. # The home of zebra
# YAZ include files, libraries, etc.
-YAZDIR=$(ROOTDIR)\..\YAZ
-YAZINCL=$(YAZDIR)\include
-YAZLIBS=$(YAZLIB)
+YAZDIR=$(ROOTDIR)\..\yaz # or \program files\yaz
+
YAZBINDIR=$(YAZDIR)\bin
!if $(DEBUG)
-YAZLIB=$(YAZDIR)\lib\yazd.lib
-YAZ_DLL_SOURCE=$(YAZBINDIR)\yazd.dll
-YAZ_DLL_TARGET=$(BINDIR)\yazd.dll
+YAZLIB="$(YAZDIR)\lib\yaz3d.lib"
+!if $(HAVE_ICU)
+YAZLIB=$(YAZLIB) "$(YAZDIR)\lib\yaz_icu3d.lib"
+!endif
+YAZ_DLL_SOURCE="$(YAZBINDIR)\yaz3d.dll"
+YAZ_DLL_TARGET="$(BINDIR)\yaz3d.dll"
!else
-YAZLIB=$(YAZDIR)\lib\yaz.lib
-YAZ_DLL_SOURCE=$(YAZBINDIR)\yaz.dll
-YAZ_DLL_TARGET=$(BINDIR)\yaz.dll
+YAZLIB="$(YAZDIR)\lib\yaz3.lib"
+!if $(HAVE_ICU)
+YAZLIB=$(YAZLIB) "$(YAZDIR)\lib\yaz_icu3.lib"
+!endif
+YAZ_DLL_SOURCE="$(YAZBINDIR)\yaz3.dll"
+YAZ_DLL_TARGET="$(BINDIR)\yaz3.dll"
!endif
# BZIP2 settings. Uncomment and specify if you wish to use LIBBZIP2.
DFADIR=$(SRCDIR)\DFA
DICTDIR=$(SRCDIR)\DICT
ISAMSDIR=$(SRCDIR)\ISAMS
-ISAMDIR=$(SRCDIR)\ISAM
ISAMCDIR=$(SRCDIR)\ISAMC
ISAMBDIR=$(SRCDIR)\ISAMB
-RECCTRLDIR=$(SRCDIR)\RECCTRL
RSETDIR=$(SRCDIR)\RSET
UTILDIR=$(SRCDIR)\UTIL
DATA1DIR=$(SRCDIR)\DATA1
-APITESTDIR=$(SRCDIR)\APITEST
# Force temp files in a local temp, easier to clean
# when nmake crashes and leaves a lot of rubbish behind
nsis:
$(NSIS) zebra.nsi
-###########################################################
-############### Targets - what to make
-###########################################################
+# Targets - what to make
!if $(DEBUG)
DLL=$(BINDIR)\idzebrad.dll
IMPLIB=$(LIBDIR)\idzebra.lib
!endif
-ZEBRA_RES=$(OBJDIR)\idzebra.res
-
ZSERVER=$(BINDIR)\zebrasrv.exe
-ZINDEX=$(BINDIR)\zebraidx.exe
-APITEST=$(BINDIR)\apitest.exe
+ZEBRAIDX=$(BINDIR)\zebraidx.exe
TSTFLOCK=$(BINDIR)\tstflock.exe
# shortcut names defined here
-zindex: $(ZINDEX)
+zebraidx: $(ZEBRAIDX)
zserver: $(ZSERVER)
-apitest: $(APITEST)
tstflock: $(TSTFLOCK)
dll: $(DLL)
-###########################################################
-############### Compiler and linker options
-###########################################################
+
+# External libs and modules (enabled or disabled)
!if $(HAVE_EXPAT)
EXPAT_DEF= /D HAVE_EXPAT_H=1 /I"$(EXPAT_DIR)\source\lib"
-EXPAT_LIB= "$(EXPAT_DIR)\libs\libexpat.lib"
-EXPAT_DLL_SOURCE= "$(EXPAT_DIR)\libs\libexpat.dll"
-EXPAT_DLL_TARGET="$(BINDIR)\libexpat.dll"
+EXPAT_LIB= "$(EXPAT_DIR)\bin\libexpat.lib"
+EXPAT_DLL_SOURCE= "$(EXPAT_DIR)\bin\libexpat.dll"
+EXPAT_DLL_TARGET= "$(BINDIR)\libexpat.dll"
expat: $(EXPAT_DLL_TARGET)
$(EXPAT_DLL_TARGET) : $(EXPAT_DLL_SOURCE)
!if $(HAVE_LIBXML2)
LIBXML2_LIB="$(LIBXML2_DIR)\lib\libxml2.lib"
-LIBXML2_DEF=/D HAVE_XML2=1 /I"$(LIBXML2_DIR)\include"
+LIBXML2_DEF=/DYAZ_HAVE_XML2=1 /D HAVE_XML2=1 /I"$(LIBXML2_DIR)\include"
libxml2: $(BINDIR)\libxml2.dll $(BINDIR)\zlib1.dll
$(BINDIR)\libxml2.dll:
!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)
+!else
+ICU_DEF= /DYAZ_HAVE_ICU=0
+ICU_LIB=
+icu:
+!endif
+
!if $(HAVE_LIBXSLT)
-MOD_ALVIS_OBJS= $(OBJDIR)\alvis.obj
+MOD_ALVIS_OBJS= $(OBJDIR)\mod_alvis.obj
MOD_ALVIS_CFLAGS=/DIDZEBRA_STATIC_ALVIS=1
-MOD_XSLT_OBJS= $(OBJDIR)\xslt.obj
-MOD_XSLT_CFLAGS=/DIDZEBRA_STATIC_XSLT=1
+
+MOD_DOM_OBJS= $(OBJDIR)\mod_dom.obj
+MOD_DOM_CFLAGS=/DIDZEBRA_STATIC_DOM=1
!else
MOD_ALVIS_OBJS=
MOD_ALVIS_CFLAGS=
-MOD_XSLT_OBJS=
-MOD_XSLT_CFLAGS=
+
+MOD_DOM_OBJS=
+MOD_DOM_CFLAGS=
!endif
### C and CPP compiler (the same thing)
/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" \
$(ICONV_DEF) \
$(EXPAT_DEF) \
$(LIBXML2_DEF) \
$(LIBXSLT_DEF) \
+ $(ICU_DEF) \
/FR"$(OBJDIR)\\" \
/Fo"$(OBJDIR)\\" \
/Fd"$(OBJDIR)\\" \
/DIDZEBRA_STATIC_GRS_MARC=1 \
/DIDZEBRA_STATIC_GRS_DANBIB=1 \
$(MOD_ALVIS_CFLAGS) \
- $(MOD_XSLT_CFLAGS) \
+ $(MOD_DOM_CFLAGS) \
/DIDZEBRA_STATIC_SAFARI=1 \
$(BZIP2DEF)
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)
+ $(ICONV_LIB) $(EXPAT_LIB) $(LIBXML2_LIB) $(LIBXSLT_LIB) $(ICU_LIB)
COMMON_LNK_OPTIONS= /nologo /machine:i386 /incremental:no
DLL_LINK_OPTIONS= /dll
-ZSERVER_LINK_OPTIONS= /subsystem:console
-ZINDEX_LINK_OPTIONS= /subsystem:console
-APITEST_LINK_OPTIONS= /subsystem:console
+CLIENT_LINK_OPTIONS= /subsystem:console
# Final opt variables
!if $(DEBUG)
LNKOPT= $(COMMON_LNK_OPTIONS) $(RELEASE_LNK_OPTIONS) $(LNK_LIBS)
!endif
-###########################################################
-############### Source and object modules
-###########################################################
+LINK_PROGRAM= $(LINK) \
+ $(LNKOPT) \
+ $(CLIENT_LINK_OPTIONS) \
+ $(IMPLIB) \
+ $(YAZLIB) \
+ $(BZIP2LIB) \
+ $(LINK_LIBS)
+
+
+# Generated sources
+generate: $(INCLDIR)\idzebra\version.h
+
+$(INCLDIR)\idzebra\version.h:
+ @cd $(ROOTDIR)\util
+ $(TCL) mk_version.tcl $(ROOTDIR)/configure.ac $(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
# need to be specified, though
ZSERVER_OBJS= \
- $(OBJDIR)\zserver.obj
+ $(OBJDIR)\zebrasrv.obj
ZEBRAIDX_OBJS= \
- $(OBJDIR)\main.obj
-APITEST_OBJS= \
- $(OBJDIR)\apitest.obj
+ $(OBJDIR)\zebraidx.obj
TSTFLOCK_OBJS= \
$(OBJDIR)\tstflock.obj
ZEBRALIB_OBJS= \
$(MOD_ALVIS_OBJS) \
- $(MOD_XSLT_OBJS) \
+ $(MOD_DOM_OBJS) \
$(OBJDIR)\atoi_zn.obj \
$(OBJDIR)\attribute.obj \
$(OBJDIR)\attrfind.obj \
$(OBJDIR)\bfile.obj \
$(OBJDIR)\bset.obj \
$(OBJDIR)\cfile.obj \
+ $(OBJDIR)\check_res.obj \
$(OBJDIR)\charmap.obj \
$(OBJDIR)\close.obj \
$(OBJDIR)\commit.obj \
$(OBJDIR)\d1_sumout.obj \
$(OBJDIR)\d1_sutrs.obj \
$(OBJDIR)\d1_tagset.obj \
+ $(OBJDIR)\d1_utils.obj \
$(OBJDIR)\d1_varset.obj \
$(OBJDIR)\d1_write.obj \
- $(OBJDIR)\danbibr.obj \
$(OBJDIR)\dclose.obj \
$(OBJDIR)\dcompact.obj \
$(OBJDIR)\delete.obj \
$(OBJDIR)\dirs.obj \
$(OBJDIR)\dopen.obj \
$(OBJDIR)\drdwr.obj \
+ $(OBJDIR)\exit.obj \
$(OBJDIR)\extract.obj \
+ $(OBJDIR)\flock.obj \
$(OBJDIR)\imalloc.obj \
$(OBJDIR)\inline.obj \
$(OBJDIR)\insert.obj \
$(OBJDIR)\isamb.obj \
$(OBJDIR)\isamc.obj \
$(OBJDIR)\isams.obj \
- $(OBJDIR)\kcompare.obj \
+ $(OBJDIR)\isam_methods.obj \
+ $(OBJDIR)\it_key.obj \
$(OBJDIR)\kcontrol.obj \
+ $(OBJDIR)\key_block.obj \
$(OBJDIR)\kinput.obj \
$(OBJDIR)\limit.obj \
- $(OBJDIR)\flock.obj \
$(OBJDIR)\lookgrep.obj \
$(OBJDIR)\lookup.obj \
$(OBJDIR)\lookupec.obj \
$(OBJDIR)\marcomp.obj \
- $(OBJDIR)\marcread.obj \
+ $(OBJDIR)\mod_grs_marc.obj \
$(OBJDIR)\merge.obj \
$(OBJDIR)\mfile.obj \
$(OBJDIR)\open.obj \
$(OBJDIR)\rankstatic.obj \
$(OBJDIR)\recctrl.obj \
$(OBJDIR)\recgrs.obj \
+ $(OBJDIR)\records.obj \
$(OBJDIR)\recindex.obj \
$(OBJDIR)\reckeys.obj \
- $(OBJDIR)\recstat.obj \
- $(OBJDIR)\rectext.obj \
- $(OBJDIR)\regxread.obj \
+ $(OBJDIR)\mod_text.obj \
+ $(OBJDIR)\mod_grs_regx.obj \
$(OBJDIR)\res.obj \
$(OBJDIR)\retrieve.obj \
+ $(OBJDIR)\rpnscan.obj \
+ $(OBJDIR)\rpnsearch.obj \
$(OBJDIR)\rsbetween.obj \
$(OBJDIR)\rsbool.obj \
$(OBJDIR)\rset.obj \
+ $(OBJDIR)\rset_isam.obj \
$(OBJDIR)\rsisamb.obj \
$(OBJDIR)\rsisamc.obj \
$(OBJDIR)\rsisams.obj \
$(OBJDIR)\rsnull.obj \
$(OBJDIR)\rsprox.obj \
$(OBJDIR)\rstemp.obj \
- $(OBJDIR)\safari.obj \
+ $(OBJDIR)\mod_safari.obj \
$(OBJDIR)\scan.obj \
$(OBJDIR)\set.obj \
- $(OBJDIR)\sgmlread.obj \
+ $(OBJDIR)\mod_grs_sgml.obj \
$(OBJDIR)\snippet.obj \
$(OBJDIR)\sortidx.obj \
$(OBJDIR)\states.obj \
- $(OBJDIR)\symtab.obj \
- $(OBJDIR)\trav.obj \
+ $(OBJDIR)\stream.obj \
+ $(OBJDIR)\strmap.obj \
+ $(OBJDIR)\su_codec.obj \
$(OBJDIR)\trunc.obj \
- $(OBJDIR)\xmlread.obj \
+ $(OBJDIR)\untrans.obj \
+ $(OBJDIR)\update_path.obj \
+ $(OBJDIR)\update_file.obj \
+ $(OBJDIR)\version.obj \
+ $(OBJDIR)\mod_grs_xml.obj \
$(OBJDIR)\xpath.obj \
+ $(OBJDIR)\zaptterm.obj \
$(OBJDIR)\zebra-lock.obj \
$(OBJDIR)\zebraapi.obj \
$(OBJDIR)\zebramap.obj \
$(OBJDIR)\zinfo.obj \
$(OBJDIR)\zint.obj \
- $(OBJDIR)\zrpn.obj \
- $(OBJDIR)\zsets.obj \
- $(OBJDIR)\zvrank.obj
-
-ALL_OBJS=\
- $(ZEBRALIB_OBJS) \
- $(ZEBRAIDX_OBJS) \
- $(APITEST_OBJS) \
- $(ZSERVER_OBJS)
-
-###########################################################
-############### Compiling
-###########################################################
+ $(OBJDIR)\zsets.obj
+# Compiling
# Note: This defines where to look for the necessary
# source files. Funny way of doing it, but it works.
-{$(SRCDIR)}.cpp{$(OBJDIR)}.obj:
- $(CPP) $(COPT) $<
-
-{$(SRCDIR)}.c{$(OBJDIR)}.obj:
- $(CPP) $(COPT) $<
-
-# ZebraLib
{$(INDEXDIR)}.c{$(OBJDIR)}.obj:
$(CPP) $(COPT) $<
{$(ISAMSDIR)}.c{$(OBJDIR)}.obj:
$(CPP) $(COPT) $<
-{$(ISAMDIR)}.c{$(OBJDIR)}.obj:
- $(CPP) $(COPT) $<
-
{$(ISAMCDIR)}.c{$(OBJDIR)}.obj:
$(CPP) $(COPT) $<
{$(ISAMBDIR)}.c{$(OBJDIR)}.obj:
$(CPP) $(COPT) $<
-{$(RECCTRLDIR)}.c{$(OBJDIR)}.obj:
- $(CPP) $(COPT) $<
-
{$(RSETDIR)}.c{$(OBJDIR)}.obj:
$(CPP) $(COPT) $<
{$(DATA1DIR)}.c{$(OBJDIR)}.obj:
$(CPP) $(COPT) $<
-{$(APITESTDIR)}.c{$(OBJDIR)}.obj:
- $(CPP) $(COPT) $<
-
-###########################################################
-############### Linking
-###########################################################
+# Linking
$(ZSERVER) : "$(BINDIR)" $(ZSERVER_OBJS) $(IMPLIB)
- @echo Linking the server $(ZSERVER)
- $(LINK) @<<
- $(LNKOPT)
- $(ZSERVER_LINK_OPTIONS)
- /out:$(ZSERVER)
- $(IMPLIB)
- $(YAZLIBS)
- $(BZIP2LIB)
- $(LINK_LIBS)
- $(ZSERVER_OBJS)
-<<
-
-$(ZINDEX) : "$(BINDIR)" $(ZEBRAIDX_OBJS) $(IMPLIB)
- @echo Linking the indexer $(ZINDEX)
- $(LINK) @<<
- $(LNKOPT)
- $(ZINDEX_LINK_OPTIONS)
- /out:$(ZINDEX)
- $(IMPLIB)
- $(YAZLIBS)
- $(BZIP2LIB)
- $(LINK_LIBS)
- $(ZEBRAIDX_OBJS)
-<<
-
-$(APITEST) : "$(BINDIR)" $(APITEST_OBJS) $(YAZLIBS)
- @echo Linking the test program $(APITEST)
- $(LINK) @<<
- $(LNKOPT)
- $(APITEST_LINK_OPTIONS)
- /out:$(APITEST)
- $(IMPLIB)
- $(YAZLIBS)
- $(BZIP2LIB)
- $(LINK_LIBS)
- $(APITEST_OBJS)
-<<
-
-$(TSTFLOCK) : "$(BINDIR)" $(TSTFLOCK_OBJS) $(IMPLIB)
- @echo Linking $(TSTFLOCK)
- $(LINK) @<<
- $(LNKOPT)
- $(TSTFLOCK_LINK_OPTIONS)
+ $(LINK_PROGRAM) \
+ $(ZSERVER_OBJS) \
+ /out:$(ZSERVER)
+
+$(ZEBRAIDX) : "$(BINDIR)" $(ZEBRAIDX_OBJS) $(IMPLIB)
+ $(LINK_PROGRAM) \
+ $(ZEBRAIDX_OBJS) \
+ /out:$(ZEBRAIDX)
+
+$(TSTFLOCK) : "$(BINDIR)" $(TSTFLOCK_OBJS) $(IMPLIB)
+ $(LINK_PROGRAM) \
+ $(TSTFLOCK_OBJS) \
/out:$(TSTFLOCK)
- $(IMPLIB)
- $(YAZLIBS)
- $(BZIP2LIB)
- $(LINK_LIBS)
- $(TSTFLOCK_OBJS)
-<<
-
-
-$(DLL) $(IMPLIB): "$(BINDIR)" $(ZEBRALIB_OBJS)
- @echo Linking the dll $(DLL)
- $(LINK) @<<
- $(LNKOPT)
- $(LINK_LIBS)
- $(DLL_LINK_OPTIONS)
- $(ZEBRALIB_OBJS)
- /out:$(DLL)
- $(YAZLIBS)
- /implib:"$(IMPLIB)"
- /map:"$(LIBDIR)\idzebra.map"
-<<
-###########################################################
-############### Special operations
-###########################################################
+# Resources
+RES=$(OBJDIR)\zebra.res
+RC=$(WINDIR)\zebra.rc
+
+RSC=rc.exe
+!if $(DEBUG)
+RSOPT=/d_DEBUG
+!else
+RSOPT=/d_NDEBUG
+!endif
+
+
+$(RES): $(RC)
+ $(RSC) $(RSOPT) /I"../include" /I"$(YAZDIR)\include" /fo"$(RES)" $(RC)
+
+$(DLL) $(IMPLIB): "$(BINDIR)" $(ZEBRALIB_OBJS) $(RES)
+ $(LINK) \
+ $(LNKOPT) \
+ $(LINK_LIBS) \
+ $(DLL_LINK_OPTIONS) \
+ $(ZEBRALIB_OBJS) \
+ $(RES) \
+ /out:$(DLL) \
+ $(YAZLIB) \
+ /implib:"$(IMPLIB)" \
+ /map:"$(LIBDIR)\idzebra.map" \
+
+# Other rules
clean:
-del $(OBJDIR)\*.obj
-del $(OBJDIR)\*.sbr
-del $(BINDIR)\*.exe
+ -del $(BINDIR)\*.dll
-del $(TMPDIR)\*.
-del $(LIBDIR)\*.lib
-########### check directories and create if needed
dirs: $(OBJDIR) $(WINDIR) $(LIBDIR) $(BINDIR) $(TMPDIR)
$(OBJDIR) $(WINDIR) $(LIBDIR) $(BINDIR) $(TMPDIR):
yaz: $(YAZ_DLL_TARGET)
$(YAZ_DLL_TARGET) : $(YAZ_DLL_SOURCE)
- copy $(YAZBINDIR)\*.dll $(BINDIR)
+# copy "$(YAZBINDIR)\*.dll.manifest" $(BINDIR)
+ copy "$(YAZBINDIR)\*.dll" $(BINDIR)
-###########################################################
-############### Explicit dependencies
-###########################################################
-# $(ALL_OBJS): makefile
-
-# force recompilation of everything, if makefile changed
-
-###########################################################