# Zebra makefile for MS NMAKE
-# $Id: makefile,v 1.35 2005-05-13 09:41:59 adam Exp $
+# $Id: makefile,v 1.54 2006-08-14 18:12:35 adam Exp $
###########################################################
############### Parameters
# iconv is optional
HAVE_ICONV=1
-ICONV_DIR=c:\iconv-1.9.1.win32
+ICONV_DIR=c:\iconv-1.9.2.win32
+
+# libxslt. For alvis
+HAVE_LIBXSLT=1
+LIBXSLT_DIR=c:\libxslt-1.1.17.win32
+
+# libxml2. Used by libxslt
+HAVE_LIBXML2=1
+LIBXML2_DIR=c:\libxml2-2.6.26.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
-all: dirs iconv zebralib zserver zindex
+all: dirs expat iconv libxml2 libxslt yaz dll zserver zebraidx tstflock
-###########################################################
-############### Directories
-###########################################################
+# 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
-YAZLIB=$(YAZDIR)\lib\yaz.lib
YAZLIBS=$(YAZLIB)
YAZBINDIR=$(YAZDIR)\bin
+!if $(DEBUG)
+YAZLIB=$(YAZDIR)\lib\yazd.lib
+YAZ_DLL_SOURCE=$(YAZBINDIR)\yazd.dll
+YAZ_DLL_TARGET=$(BINDIR)\yazd.dll
+!else
+YAZLIB=$(YAZDIR)\lib\yaz.lib
YAZ_DLL_SOURCE=$(YAZBINDIR)\yaz.dll
YAZ_DLL_TARGET=$(BINDIR)\yaz.dll
+!endif
# BZIP2 settings. Uncomment and specify if you wish to use LIBBZIP2.
# (C) 1996-1999 Julian Seward <jseward@acm.org> http://www.bzip2.org
LIBDIR=$(ROOTDIR)\lib # We produce .lib, .exp etc there
BINDIR=$(ROOTDIR)\bin # We produce exes and dlls there
WINDIR=$(ROOTDIR)\win # all these Win make things
+!if $(DEBUG)
+OBJDIR=$(WINDIR)\dobj # where we store intermediate files
+!else
OBJDIR=$(WINDIR)\obj # where we store intermediate files
+!endif
UNIXDIR=$(ROOTDIR)\unix # corresponding unix things
SRCDIR=$(ROOTDIR) # for the case we move them under src
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)\idzebrad.lib
+!else
+DLL=$(BINDIR)\idzebra.dll
+IMPLIB=$(LIBDIR)\idzebra.lib
+!endif
+
+ZEBRA_RES=$(OBJDIR)\idzebra.res
-ZEBRALIB=$(LIBDIR)\zebra.lib
ZSERVER=$(BINDIR)\zebrasrv.exe
-ZINDEX=$(BINDIR)\zebraidx.exe
-APITEST=$(BINDIR)\apitest.exe
+ZEBRAIDX=$(BINDIR)\zebraidx.exe
+TSTFLOCK=$(BINDIR)\tstflock.exe
# shortcut names defined here
-zebralib: $(ZEBRALIB)
-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: $(EXPAT_DLL_TARGET)
+
$(EXPAT_DLL_TARGET) : $(EXPAT_DLL_SOURCE)
copy $(EXPAT_DLL_SOURCE) $(EXPAT_DLL_TARGET)
!else
EXPAT_LIB=
EXPAT_DLL_SOURCE=
EXPAT_DLL_TARGET=
+expat:
!endif
!if $(HAVE_ICONV)
iconv: $(BINDIR)\iconv.dll
$(BINDIR)\iconv.dll:
- copy "$(ICONV_DIR)\lib\iconv.dll" $(BINDIR)
+ copy "$(ICONV_DIR)\bin\iconv.dll" $(BINDIR)
!else
ICONV_DEF= /D HAVE_ICONV_H=0
ICONV_LIB=
iconv:
!endif
+!if $(HAVE_LIBXML2)
+LIBXML2_LIB="$(LIBXML2_DIR)\lib\libxml2.lib"
+LIBXML2_DEF=/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)
+
+!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_LIBXSLT)
+MOD_ALVIS_OBJS= $(OBJDIR)\alvis.obj
+MOD_ALVIS_CFLAGS=/DIDZEBRA_STATIC_ALVIS=1
+!else
+MOD_ALVIS_OBJS=
+MOD_ALVIS_CFLAGS=
+!endif
+
### C and CPP compiler (the same thing)
# Note: $(CPP) has already been defined in the environment
# (if you set things up right!)
COMMON_C_OPTIONS= \
- /nologo /W3 /GX /FD /c \
+ /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) \
/FR"$(OBJDIR)\\" \
/Fo"$(OBJDIR)\\" \
/Fd"$(OBJDIR)\\" \
/DIDZEBRA_STATIC_GRS_XML=1 \
/DIDZEBRA_STATIC_GRS_REGX=1 \
/DIDZEBRA_STATIC_GRS_MARC=1 \
+ /DIDZEBRA_STATIC_GRS_DANBIB=1 \
+ $(MOD_ALVIS_CFLAGS) \
+ /DIDZEBRA_STATIC_SAFARI=1 \
$(BZIP2DEF)
COMMON_C_INCLUDES= \
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)
+ wsock32.lib advapi32.lib \
+ $(ICONV_LIB) $(EXPAT_LIB) $(LIBXML2_LIB) $(LIBXSLT_LIB)
COMMON_LNK_OPTIONS= /nologo /machine:i386 /incremental:no
ZEBRALIB_LINK_OPTIONS= -lib
-ZSERVER_LINK_OPTIONS= /subsystem:console
-ZINDEX_LINK_OPTIONS= /subsystem:console
-APITEST_LINK_OPTIONS= /subsystem:console
+DLL_LINK_OPTIONS= /dll
+
+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) \
+ $(YAZLIBS) \
+ $(BZIP2LIB) \
+ $(LINK_LIBS)
+# 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
ZEBRAIDX_OBJS= \
$(OBJDIR)\main.obj
-APITEST_OBJS= \
- $(OBJDIR)\apitest.obj
+TSTFLOCK_OBJS= \
+ $(OBJDIR)\tstflock.obj
ZEBRALIB_OBJS= \
- $(OBJDIR)\isamc.obj \
- $(OBJDIR)\merge.obj \
- $(OBJDIR)\zebra-lock.obj \
+ $(MOD_ALVIS_OBJS) \
+ $(OBJDIR)\atoi_zn.obj \
$(OBJDIR)\attribute.obj \
+ $(OBJDIR)\attrfind.obj \
$(OBJDIR)\bfile.obj \
$(OBJDIR)\bset.obj \
$(OBJDIR)\cfile.obj \
$(OBJDIR)\charmap.obj \
- $(OBJDIR)\atoi_zn.obj \
$(OBJDIR)\close.obj \
$(OBJDIR)\commit.obj \
$(OBJDIR)\compact.obj \
+ $(OBJDIR)\d1_absyn.obj \
+ $(OBJDIR)\d1_attset.obj \
+ $(OBJDIR)\d1_doespec.obj \
+ $(OBJDIR)\d1_espec.obj \
+ $(OBJDIR)\d1_expout.obj \
+ $(OBJDIR)\d1_grs.obj \
+ $(OBJDIR)\d1_handle.obj \
+ $(OBJDIR)\d1_if.obj \
+ $(OBJDIR)\d1_map.obj \
+ $(OBJDIR)\d1_marc.obj \
+ $(OBJDIR)\d1_prtree.obj \
+ $(OBJDIR)\d1_read.obj \
+ $(OBJDIR)\d1_soif.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)\dclose.obj \
$(OBJDIR)\dcompact.obj \
$(OBJDIR)\delete.obj \
$(OBJDIR)\dfa.obj \
+ $(OBJDIR)\dir.obj \
$(OBJDIR)\dirent.obj \
+ $(OBJDIR)\dirs.obj \
$(OBJDIR)\dopen.obj \
$(OBJDIR)\drdwr.obj \
+ $(OBJDIR)\extract.obj \
$(OBJDIR)\imalloc.obj \
+ $(OBJDIR)\inline.obj \
$(OBJDIR)\insert.obj \
$(OBJDIR)\invstat.obj \
+ $(OBJDIR)\isamb.obj \
+ $(OBJDIR)\isamc.obj \
+ $(OBJDIR)\isams.obj \
$(OBJDIR)\kcompare.obj \
- $(OBJDIR)\lockutil.obj \
+ $(OBJDIR)\kcontrol.obj \
+ $(OBJDIR)\kinput.obj \
+ $(OBJDIR)\limit.obj \
+ $(OBJDIR)\flock.obj \
$(OBJDIR)\lookgrep.obj \
$(OBJDIR)\lookup.obj \
$(OBJDIR)\lookupec.obj \
- $(OBJDIR)\marcread.obj \
$(OBJDIR)\marcomp.obj \
- $(OBJDIR)\inline.obj \
+ $(OBJDIR)\marcread.obj \
+ $(OBJDIR)\merge.obj \
$(OBJDIR)\mfile.obj \
$(OBJDIR)\open.obj \
+ $(OBJDIR)\orddict.obj \
$(OBJDIR)\passwddb.obj \
- $(OBJDIR)\zvrank.obj \
$(OBJDIR)\rank1.obj \
- $(OBJDIR)\readfile.obj \
+ $(OBJDIR)\ranksimilarity.obj \
+ $(OBJDIR)\rankstatic.obj \
$(OBJDIR)\recctrl.obj \
$(OBJDIR)\recgrs.obj \
$(OBJDIR)\recindex.obj \
+ $(OBJDIR)\reckeys.obj \
$(OBJDIR)\recstat.obj \
$(OBJDIR)\rectext.obj \
$(OBJDIR)\regxread.obj \
- $(OBJDIR)\xmlread.obj \
- $(OBJDIR)\danbibr.obj \
$(OBJDIR)\res.obj \
$(OBJDIR)\retrieve.obj \
+ $(OBJDIR)\rsbetween.obj \
$(OBJDIR)\rsbool.obj \
$(OBJDIR)\rset.obj \
+ $(OBJDIR)\rsisamb.obj \
$(OBJDIR)\rsisamc.obj \
+ $(OBJDIR)\rsisams.obj \
$(OBJDIR)\rsmultiandor.obj \
$(OBJDIR)\rsnull.obj \
+ $(OBJDIR)\rsprox.obj \
$(OBJDIR)\rstemp.obj \
+ $(OBJDIR)\safari.obj \
$(OBJDIR)\scan.obj \
$(OBJDIR)\set.obj \
$(OBJDIR)\sgmlread.obj \
+ $(OBJDIR)\snippet.obj \
$(OBJDIR)\sortidx.obj \
$(OBJDIR)\states.obj \
$(OBJDIR)\symtab.obj \
+ $(OBJDIR)\update_path.obj \
+ $(OBJDIR)\update_file.obj \
$(OBJDIR)\trunc.obj \
+ $(OBJDIR)\xmlread.obj \
+ $(OBJDIR)\xpath.obj \
+ $(OBJDIR)\zebra-lock.obj \
$(OBJDIR)\zebraapi.obj \
$(OBJDIR)\zebramap.obj \
- $(OBJDIR)\zint.obj \
$(OBJDIR)\zinfo.obj \
+ $(OBJDIR)\zint.obj \
$(OBJDIR)\zrpn.obj \
- $(OBJDIR)\zsets.obj \
- $(OBJDIR)\isams.obj \
- $(OBJDIR)\isamb.obj \
- $(OBJDIR)\rsisamb.obj \
- $(OBJDIR)\rsbetween.obj \
- $(OBJDIR)\rsprox.obj \
- $(OBJDIR)\dir.obj \
- $(OBJDIR)\dirs.obj \
- $(OBJDIR)\extract.obj \
- $(OBJDIR)\kinput.obj \
- $(OBJDIR)\rsisams.obj \
- $(OBJDIR)\trav.obj \
- $(OBJDIR)\d1_absyn.obj \
- $(OBJDIR)\d1_attset.obj \
- $(OBJDIR)\d1_doespec.obj \
- $(OBJDIR)\d1_espec.obj \
- $(OBJDIR)\d1_expout.obj \
- $(OBJDIR)\d1_grs.obj \
- $(OBJDIR)\d1_handle.obj \
- $(OBJDIR)\d1_if.obj \
- $(OBJDIR)\d1_map.obj \
- $(OBJDIR)\d1_marc.obj \
- $(OBJDIR)\d1_prtree.obj \
- $(OBJDIR)\d1_read.obj \
- $(OBJDIR)\d1_soif.obj \
- $(OBJDIR)\d1_sumout.obj \
- $(OBJDIR)\d1_sutrs.obj \
- $(OBJDIR)\d1_tagset.obj \
- $(OBJDIR)\d1_varset.obj \
- $(OBJDIR)\d1_write.obj \
- $(OBJDIR)\xpath.obj \
- $(OBJDIR)\kcontrol.obj \
- $(OBJDIR)\limit.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)
+ $(LINK_PROGRAM) \
+ $(ZSERVER_OBJS) \
+ /out:$(ZSERVER)
-$(ZSERVER) : "$(BINDIR)" $(ZSERVER_OBJS) $(ZEBRALIB) $(YAZLIBS)
- @echo Linking the server $(ZSERVER)
- $(LINK) @<<
- $(LNKOPT)
- $(ZSERVER_LINK_OPTIONS)
- /out:$(ZSERVER)
- $(YAZLIBS)
- $(ZEBRALIB)
- $(BZIP2LIB)
- $(LINK_LIBS)
- $(ZSERVER_OBJS)
-<<
-
-$(ZINDEX) : "$(BINDIR)" $(ZEBRAIDX_OBJS) $(ZEBRALIB) $(YAZLIBS)
- @echo Linking the indexer $(ZINDEX)
- $(LINK) @<<
- $(LNKOPT)
- $(ZINDEX_LINK_OPTIONS)
- /out:$(ZINDEX)
- $(YAZLIBS)
- $(ZEBRALIB)
- $(BZIP2LIB)
- $(LINK_LIBS)
- $(ZEBRAIDX_OBJS)
-<<
-
-$(APITEST) : "$(BINDIR)" $(APITEST_OBJS) $(ZEBRALIB) $(YAZLIBS)
- @echo Linking the test program $(APITEST)
- $(LINK) @<<
- $(LNKOPT)
- $(APITEST_LINK_OPTIONS)
- /out:$(APITEST)
- $(YAZLIBS)
- $(ZEBRALIB)
- $(BZIP2LIB)
- $(LINK_LIBS)
- $(APITEST_OBJS)
-<<
-
-$(ZEBRALIB) : "$(BINDIR)" $(ZEBRALIB_OBJS)
- @echo Linking library $(ZEBRALIB)
- $(LINK) $(ZEBRALIB_LINK_OPTIONS) @<<
- /nologo
- $(ZEBRALIB_OBJS)
- /out:$(ZEBRALIB)
-<<
+$(ZEBRAIDX) : "$(BINDIR)" $(ZEBRAIDX_OBJS) $(IMPLIB)
+ $(LINK_PROGRAM) \
+ $(ZEBRAIDX_OBJS) \
+ /out:$(ZEBRAIDX)
-###########################################################
-############### Special operations
-###########################################################
+$(TSTFLOCK) : "$(BINDIR)" $(TSTFLOCK_OBJS) $(IMPLIB)
+ $(LINK_PROGRAM) \
+ $(TSTFLOCK_OBJS) \
+ /out:$(TSTFLOCK)
+
+$(DLL) $(IMPLIB): "$(BINDIR)" $(ZEBRALIB_OBJS)
+ $(LINK) \
+ $(LNKOPT) \
+ $(LINK_LIBS) \
+ $(DLL_LINK_OPTIONS) \
+ $(ZEBRALIB_OBJS) \
+ /out:$(DLL) \
+ $(YAZLIBS) \
+ /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) \
- $(EXPAT_DLL_TARGET) $(YAZ_DLL_TARGET)
+dirs: $(OBJDIR) $(WINDIR) $(LIBDIR) $(BINDIR) $(TMPDIR)
$(OBJDIR) $(WINDIR) $(LIBDIR) $(BINDIR) $(TMPDIR):
- if not exist "$@/$(NUL)" mkdir "$@"
+ if not exist "$@/$(NUL)" mkdir "$@"
+
+yaz: $(YAZ_DLL_TARGET)
$(YAZ_DLL_TARGET) : $(YAZ_DLL_SOURCE)
+# copy $(YAZBINDIR)\*.dll.manifest $(BINDIR)
copy $(YAZBINDIR)\*.dll $(BINDIR)
-###########################################################
-############### Explicit dependencies
-###########################################################
-
-# $(ALL_OBJS): makefile
-# force recompilation of everything, if makefile changed
-
-###########################################################