X-Git-Url: http://git.indexdata.com/?p=idzebra-moved-to-github.git;a=blobdiff_plain;f=win%2Fmakefile;h=2d73d8c22ef6d85341c501bc1c42d0b7acaa34c8;hp=a304a4068ed58dda08129275ad012aee42220377;hb=27d70cebc8400fd364453a6bf9445531a66872d9;hpb=02cb6d6ffea2b80351aea040f29053bddebeae0c diff --git a/win/makefile b/win/makefile index a304a40..2d73d8c 100644 --- a/win/makefile +++ b/win/makefile @@ -1,31 +1,67 @@ -# Z'mbol/Zebra makefile for MS NMAKE -# $Id: makefile,v 1.8 2002-03-14 18:41:59 adam Exp $ +# Zebra makefile for MS NMAKE ########################################################### ############### Parameters ########################################################### -DEBUG=1 # 0 for release, 1 for debug -ZMBOL=1 +DEBUG=0 # 0 for release, 1 for debug +USE_MANIFEST = 0 -default: all +# TCL is optional - ONLY needed for source straight from Git +TCL=tclsh +#TCL="C:\Tcl\bin\tclsh85.exe" +HAVE_TCL=1 -all: dirs zebralib zserver zindex +# EXPAT is optional. It's required for grs.xml-filters. +HAVE_EXPAT=1 +EXPAT_DIR=c:\Program files (x86)\Expat 2.0.1 -########################################################### -############### Directories -########################################################### +# iconv is optional +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.28.win32 + +# libxml2. Used by libxslt +HAVE_LIBXML2=1 +LIBXML2_DIR=c:\libxml2-2.9.2.win32 + +# ICU support +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 generate expat iconv 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 Z'mbol +ROOTDIR=.. # The home of zebra # YAZ include files, libraries, etc. -YAZDIR=$(ROOTDIR)\..\YAZ -YAZINCL=$(YAZDIR)\include -YAZLIB=$(YAZDIR)\lib\yaz.lib -YAZLIBS=$(YAZLIB) +YAZDIR=$(ROOTDIR)\..\yaz # or \program files\yaz + YAZBINDIR=$(YAZDIR)\bin -YAZDLL=$(YAZBINDIR)\yaz.dll +!if $(DEBUG) +YAZLIB="$(YAZDIR)\lib\yaz5d.lib" +!if $(HAVE_ICU) +YAZLIB=$(YAZLIB) "$(YAZDIR)\lib\yaz_icu5d.lib" +!endif +YAZ_DLL_SOURCE="$(YAZBINDIR)\yaz5d.dll" +YAZ_DLL_TARGET="$(BINDIR)\yaz5d.dll" +!else +YAZLIB="$(YAZDIR)\lib\yaz5.lib" +!if $(HAVE_ICU) +YAZLIB=$(YAZLIB) "$(YAZDIR)\lib\yaz_icu5.lib" +!endif +YAZ_DLL_SOURCE="$(YAZBINDIR)\yaz5.dll" +YAZ_DLL_TARGET="$(BINDIR)\yaz5.dll" +!endif # BZIP2 settings. Uncomment and specify if you wish to use LIBBZIP2. # (C) 1996-1999 Julian Seward http://www.bzip2.org @@ -39,7 +75,11 @@ INCLDIR=$(ROOTDIR)\include # our includes 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 @@ -48,12 +88,11 @@ BFILEDIR=$(SRCDIR)\BFILE DFADIR=$(SRCDIR)\DFA DICTDIR=$(SRCDIR)\DICT ISAMSDIR=$(SRCDIR)\ISAMS -ISAMDIR=$(SRCDIR)\ISAM ISAMCDIR=$(SRCDIR)\ISAMC -RECCTRLDIR=$(SRCDIR)\RECCTRL +ISAMBDIR=$(SRCDIR)\ISAMB RSETDIR=$(SRCDIR)\RSET UTILDIR=$(SRCDIR)\UTIL -APITESTDIR=$(SRCDIR)\APITEST +DATA1DIR=$(SRCDIR)\DATA1 # Force temp files in a local temp, easier to clean # when nmake crashes and leaves a lot of rubbish behind @@ -61,42 +100,138 @@ TMPDIR=$(ROOTDIR)\win\tmp TMP=$(TMPDIR) TEMP=$(TMPDIR) -########################################################### -############### Targets - what to make -########################################################### +# NSIS +NSIS="c:\program files (x86)\nsis\makensis.exe" -ZEBRALIB=$(LIBDIR)\zebra.lib -!if $(ZMBOL) -ZSERVER=$(BINDIR)\zmbolsrv.exe -ZINDEX=$(BINDIR)\zmbolidx.exe +dist: + nmake DEBUG=1 clean + nmake DEBUG=0 clean + nmake DEBUG=0 + $(NSIS) zebra.nsi + +nsis: + $(NSIS) zebra.nsi + +# Targets - what to make + +!if $(DEBUG) +DLL=$(BINDIR)\idzebrad.dll +IMPLIB=$(LIBDIR)\idzebrad.lib !else -ZSERVER=$(BINDIR)\zebrasrv.exe -ZINDEX=$(BINDIR)\zebraidx.exe +DLL=$(BINDIR)\idzebra.dll +IMPLIB=$(LIBDIR)\idzebra.lib !endif -APITEST=$(BINDIR)\apitest.exe + +ZSERVER=$(BINDIR)\zebrasrv.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)\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) + copy $(EXPAT_DLL_SOURCE) $(EXPAT_DLL_TARGET) +!else +EXPAT_DEF= /D HAVE_EXPAT_H=0 +EXPAT_LIB= +EXPAT_DLL_SOURCE= +EXPAT_DLL_TARGET= +expat: +!endif + +!if $(HAVE_ICONV) +ICONV_DEF= /D HAVE_ICONV_H=1 /I"$(ICONV_DIR)\include" +ICONV_LIB= $(ICONV_DIR)\lib\iconv.lib +iconv: $(BINDIR)\iconv.dll + +$(BINDIR)\iconv.dll: + 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=/DYAZ_HAVE_XML2=1 /D HAVE_XML2=1 /I"$(LIBXML2_DIR)\include\libxml2" +!else +LIBXML2_LIB= +LIBXML2_DEF=/D HAVE_XML2=0 +!endif + +!if $(HAVE_LIBXSLT) +LIBXSLT_LIB="$(LIBXSLT_DIR)\lib\libxslt.lib" +LIBXSLT_DEF=/D HAVE_XSLT=1 /I"$(LIBXSLT_DIR)\include" +!else +LIBXSLT_LIB= +LIBXSLT_DEF=/D HAVE_XSLT=0 + +!endif + +!if $(HAVE_ICU) +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_LIBS= +!endif + +!if $(HAVE_LIBXSLT) +MOD_ALVIS_OBJS= $(OBJDIR)\mod_alvis.obj +MOD_ALVIS_CFLAGS=/DIDZEBRA_STATIC_ALVIS=1 + +MOD_DOM_OBJS= $(OBJDIR)\mod_dom.obj +MOD_DOM_CFLAGS=/DIDZEBRA_STATIC_DOM=1 +!else +MOD_ALVIS_OBJS= +MOD_ALVIS_CFLAGS= + +MOD_DOM_OBJS= +MOD_DOM_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 \ + /DYAZ_USE_NEW_LOG=1 \ + /D"_CRT_SECURE_NO_DEPRECATE" \ + /D"_CRT_NONSTDC_NO_DEPRECATE" \ /D "WIN32" \ - /D"_CONSOLE" /D"_MBCS" \ + $(ICONV_DEF) \ + $(EXPAT_DEF) \ + $(LIBXML2_DEF) \ + $(LIBXSLT_DEF) \ + $(ICU_DEF) \ /FR"$(OBJDIR)\\" \ /Fo"$(OBJDIR)\\" \ /Fd"$(OBJDIR)\\" \ - /D"ZMBOL=$(ZMBOL)" \ + /DDEFAULT_PROFILE_PATH=0 \ + /DDEFAULT_MODULE_PATH=0 \ + /DIDZEBRA_STATIC_GRS_SGML=1 \ + /DIDZEBRA_STATIC_TEXT=1 \ + /DIDZEBRA_STATIC_GRS_XML=1 \ + /DIDZEBRA_STATIC_GRS_REGX=1 \ + /DIDZEBRA_STATIC_GRS_MARC=1 \ + /DIDZEBRA_STATIC_GRS_DANBIB=1 \ + $(MOD_ALVIS_CFLAGS) \ + $(MOD_DOM_CFLAGS) \ + /DIDZEBRA_STATIC_SAFARI=1 \ $(BZIP2DEF) COMMON_C_INCLUDES= \ @@ -105,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 @@ -131,26 +266,28 @@ 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 +!if $(USE_MANIFEST) +MT=mt.exe /nologo +!else +MT=echo +!endif -COMMON_LNK_OPTIONS= /nologo \ - /machine:i386 \ - /incremental:no +# wsock32.lib advapi32.lib \ -# /subsystem:windows \ +LINK_LIBS= kernel32.lib advapi32.lib \ + $(ICONV_LIB) $(EXPAT_LIB) $(LIBXML2_LIB) $(LIBXSLT_LIB) $(ICU_LIBS) + +COMMON_LNK_OPTIONS= /nologo /machine:i386 /incremental:no DEBUG_LNK_OPTIONS= /debug -RELEASE_LNK_OPTIONS= /pdb:none +RELEASE_LNK_OPTIONS= + +ZEBRALIB_LINK_OPTIONS= -lib -ZEBRALIB_LINK_OPTIONS = -lib +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) @@ -166,234 +303,248 @@ RCOPT= $(COMMON_RC_OPTIONS) $(RELEASE_RC_OPTIONS) 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: $(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 # 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 -!if $(ZMBOL) -ZMBOLLIB_OBJS= \ - $(OBJDIR)\isam.obj \ - $(OBJDIR)\isamc.obj \ - $(OBJDIR)\isamd.obj \ - $(OBJDIR)\isutil.obj \ - $(OBJDIR)\memory.obj \ - $(OBJDIR)\merge.obj \ - $(OBJDIR)\merge-d.obj \ - $(OBJDIR)\physical.obj \ - $(OBJDIR)\rootblk.obj -!else -ZMBOLLIB_OBJS= -!endif ZEBRALIB_OBJS= \ - $(ZMBOLLIB_OBJS) \ - $(OBJDIR)\zebra-lock.obj \ + $(MOD_ALVIS_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)\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)\exit.obj \ + $(OBJDIR)\extract.obj \ + $(OBJDIR)\flock.obj \ $(OBJDIR)\imalloc.obj \ + $(OBJDIR)\inline.obj \ $(OBJDIR)\insert.obj \ $(OBJDIR)\invstat.obj \ - $(OBJDIR)\kcompare.obj \ - $(OBJDIR)\lockidx.obj \ - $(OBJDIR)\locksrv.obj \ - $(OBJDIR)\lockutil.obj \ + $(OBJDIR)\isamb.obj \ + $(OBJDIR)\isamc.obj \ + $(OBJDIR)\isams.obj \ + $(OBJDIR)\isam_methods.obj \ + $(OBJDIR)\it_key.obj \ + $(OBJDIR)\kcontrol.obj \ + $(OBJDIR)\key_block.obj \ + $(OBJDIR)\kinput.obj \ + $(OBJDIR)\limit.obj \ $(OBJDIR)\lookgrep.obj \ $(OBJDIR)\lookup.obj \ $(OBJDIR)\lookupec.obj \ - $(OBJDIR)\marcread.obj \ + $(OBJDIR)\marcomp.obj \ + $(OBJDIR)\mod_grs_marc.obj \ + $(OBJDIR)\merge.obj \ $(OBJDIR)\mfile.obj \ $(OBJDIR)\open.obj \ + $(OBJDIR)\orddict.obj \ $(OBJDIR)\passwddb.obj \ $(OBJDIR)\rank1.obj \ - $(OBJDIR)\readfile.obj \ + $(OBJDIR)\ranksimilarity.obj \ + $(OBJDIR)\rankstatic.obj \ $(OBJDIR)\recctrl.obj \ $(OBJDIR)\recgrs.obj \ + $(OBJDIR)\records.obj \ $(OBJDIR)\recindex.obj \ - $(OBJDIR)\recstat.obj \ - $(OBJDIR)\rectext.obj \ - $(OBJDIR)\regxread.obj \ + $(OBJDIR)\reckeys.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)\rsisam.obj \ + $(OBJDIR)\rset_isam.obj \ + $(OBJDIR)\rsisamb.obj \ $(OBJDIR)\rsisamc.obj \ - $(OBJDIR)\rsm_or.obj \ + $(OBJDIR)\rsisams.obj \ + $(OBJDIR)\rsmultiandor.obj \ $(OBJDIR)\rsnull.obj \ + $(OBJDIR)\rsprox.obj \ $(OBJDIR)\rstemp.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)\stream.obj \ + $(OBJDIR)\strmap.obj \ + $(OBJDIR)\su_codec.obj \ $(OBJDIR)\trunc.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)\zrpn.obj \ - $(OBJDIR)\zsets.obj \ - $(OBJDIR)\isams.obj \ - $(OBJDIR)\rsisamd.obj \ - $(OBJDIR)\dir.obj \ - $(OBJDIR)\dirs.obj \ - $(OBJDIR)\extract.obj \ - $(OBJDIR)\kinput.obj \ - $(OBJDIR)\rsisams.obj \ - $(OBJDIR)\trav.obj - -ALL_OBJS=\ - $(ZEBRALIB_OBJS) \ - $(ZEBRAIDX_OBJS) \ - $(APITEST_OBJS) \ - $(ZSERVER_OBJS) - -########################################################### -############### Compiling -########################################################### + $(OBJDIR)\zint.obj \ + $(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) $< + $(CPP) $(COPT) $< {$(BFILEDIR)}.c{$(OBJDIR)}.obj: - @$(CPP) $(COPT) $< + $(CPP) $(COPT) $< {$(DFADIR)}.c{$(OBJDIR)}.obj: - @$(CPP) $(COPT) $< + $(CPP) $(COPT) $< {$(DICTDIR)}.c{$(OBJDIR)}.obj: - @$(CPP) $(COPT) $< + $(CPP) $(COPT) $< {$(ISAMSDIR)}.c{$(OBJDIR)}.obj: - @$(CPP) $(COPT) $< - -{$(ISAMDIR)}.c{$(OBJDIR)}.obj: - @$(CPP) $(COPT) $< + $(CPP) $(COPT) $< {$(ISAMCDIR)}.c{$(OBJDIR)}.obj: - @$(CPP) $(COPT) $< + $(CPP) $(COPT) $< -{$(RECCTRLDIR)}.c{$(OBJDIR)}.obj: - @$(CPP) $(COPT) $< +{$(ISAMBDIR)}.c{$(OBJDIR)}.obj: + $(CPP) $(COPT) $< {$(RSETDIR)}.c{$(OBJDIR)}.obj: - @$(CPP) $(COPT) $< + $(CPP) $(COPT) $< {$(UTILDIR)}.c{$(OBJDIR)}.obj: - @$(CPP) $(COPT) $< + $(CPP) $(COPT) $< -{$(APITESTDIR)}.c{$(OBJDIR)}.obj: - @$(CPP) $(COPT) $< +{$(DATA1DIR)}.c{$(OBJDIR)}.obj: + $(CPP) $(COPT) $< +# Linking -########################################################### -############### Linking -########################################################### +$(ZSERVER) : "$(BINDIR)" $(ZSERVER_OBJS) $(IMPLIB) + $(LINK_PROGRAM) $(ZSERVER_OBJS) /out:$@ + $(MT) -manifest $@.manifest -outputresource:$@;1 -$(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:$@ + $(MT) -manifest $@.manifest -outputresource:$@;1 + +$(TSTFLOCK) : "$(BINDIR)" $(TSTFLOCK_OBJS) $(IMPLIB) + $(LINK_PROGRAM) $(TSTFLOCK_OBJS) /out:$@ + $(MT) -manifest $@.manifest -outputresource:$@;1 + +# Resources +RES=$(OBJDIR)\zebra.res +RC=$(WINDIR)\zebra.rc + +RSC=rc.exe +!if $(DEBUG) +RSOPT=/d_DEBUG +!else +RSOPT=/d_NDEBUG +!endif -########################################################### -############### Special operations -########################################################### + +$(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:$@ \ + $(YAZLIB) \ + /implib:"$(IMPLIB)" \ + /map:"$(LIBDIR)\idzebra.map" + $(MT) -manifest $@.manifest -outputresource:$@;2 + +# Other rules clean: -del $(OBJDIR)\*.obj -del $(OBJDIR)\*.sbr -del $(BINDIR)\*.exe + -del $(BINDIR)\*.dll -del $(TMPDIR)\*. - -del $(ZEBRALIB) + -del $(LIBDIR)\*.lib -########### check directories and create if needed dirs: $(OBJDIR) $(WINDIR) $(LIBDIR) $(BINDIR) $(TMPDIR) $(OBJDIR) $(WINDIR) $(LIBDIR) $(BINDIR) $(TMPDIR): - if not exist "$@/$(NUL)" mkdir "$@" + if not exist "$@/$(NUL)" mkdir "$@" -########################################################### -############### Explicit dependencies -########################################################### +yaz: $(YAZ_DLL_TARGET) -# $(ALL_OBJS): makefile +$(YAZ_DLL_TARGET) : $(YAZ_DLL_SOURCE) +# copy "$(YAZBINDIR)\*.dll.manifest" $(BINDIR) + copy "$(YAZBINDIR)\*.dll" $(BINDIR) -# force recompilation of everything, if makefile changed -###########################################################