NMAKE makefile: Compile with YAZ 5
[idzebra-moved-to-github.git] / win / makefile
index 7795534..be3d740 100644 (file)
@@ -1,27 +1,31 @@
 # Zebra makefile for MS NMAKE
-# $Id: makefile,v 1.39 2006-02-09 09:20:23 adam Exp $
  
 ###########################################################
 ############### Parameters 
 ###########################################################
 
-DEBUG=1   # 0 for release, 1 for debug
+DEBUG=0   # 0 for release, 1 for debug
+USE_MANIFEST = 1
+
+# 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.26.win32
 
 # libxml2. Used by libxslt
 HAVE_LIBXML2=1
-LIBXML2_DIR=c:\libxml2-2.6.20.win32
+LIBXML2_DIR=c:\libxml2-2.7.6.win32
 
 # zlib compression.  Used by libxml2
 ZLIB_DIR = c:\zlib-1.2.3.win32
@@ -29,30 +33,38 @@ 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\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\yaz.lib
-YAZ_DLL_SOURCE=$(YAZBINDIR)\yaz.dll
-YAZ_DLL_TARGET=$(BINDIR)\yaz.dll
+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.
@@ -80,14 +92,11 @@ BFILEDIR=$(SRCDIR)\BFILE
 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
@@ -107,9 +116,7 @@ dist:
 nsis:
        $(NSIS) zebra.nsi
 
-###########################################################
-############### Targets - what to make
-###########################################################
+# Targets - what to make
 
 !if $(DEBUG)
 DLL=$(BINDIR)\idzebrad.dll
@@ -119,26 +126,23 @@ DLL=$(BINDIR)\idzebra.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)
@@ -166,7 +170,7 @@ iconv:
 
 !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:
@@ -197,18 +201,52 @@ 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)\icudt42.dll $(BINDIR)\icuin42.dll $(BINDIR)\icuuc42.dll
+
+$(BINDIR)\icudt42.dll:
+         copy "$(ICU_DIR)\bin\icudt42.dll" $(BINDIR)
+$(BINDIR)\icuin42.dll:
+         copy "$(ICU_DIR)\bin\icuin42.dll" $(BINDIR)
+$(BINDIR)\icuuc42.dll:
+         copy "$(ICU_DIR)\bin\icuuc42.dll" $(BINDIR)
+!else
+ICU_DEF=  /DYAZ_HAVE_ICU=0
+ICU_LIB=
+icu:
+!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)\\"         \
@@ -220,8 +258,8 @@ COMMON_C_OPTIONS=          \
   /DIDZEBRA_STATIC_GRS_REGX=1 \
   /DIDZEBRA_STATIC_GRS_MARC=1 \
   /DIDZEBRA_STATIC_GRS_DANBIB=1 \
-  /DIDZEBRA_STATIC_ALVIS=1 \
-  /DIDZEBRA_STATIC_XSLT=1 \
+  $(MOD_ALVIS_CFLAGS) \
+  $(MOD_DOM_CFLAGS) \
   /DIDZEBRA_STATIC_SAFARI=1 \
   $(BZIP2DEF)
 
@@ -231,11 +269,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
@@ -257,11 +295,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)
+!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_LIB)
 
 COMMON_LNK_OPTIONS= /nologo /machine:i386 /incremental:no
 
@@ -273,9 +316,7 @@ 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)
@@ -291,29 +332,45 @@ 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
 
 ZEBRALIB_OBJS= \
-       $(OBJDIR)\alvis.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 \
@@ -334,9 +391,9 @@ ZEBRALIB_OBJS= \
        $(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 \
@@ -346,7 +403,9 @@ ZEBRALIB_OBJS= \
        $(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 \
@@ -354,35 +413,40 @@ ZEBRALIB_OBJS= \
        $(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)\lockutil.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)\orddict.obj \
        $(OBJDIR)\passwddb.obj \
        $(OBJDIR)\rank1.obj \
+       $(OBJDIR)\ranksimilarity.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 \
@@ -390,48 +454,35 @@ ZEBRALIB_OBJS= \
        $(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)\xslt.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) $< 
 
@@ -447,18 +498,12 @@ ALL_OBJS=\
 {$(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) $< 
 
@@ -468,77 +513,58 @@ ALL_OBJS=\
 {$(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)
-<<
-
-$(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"  
-<<
+       $(LINK_PROGRAM) $(ZSERVER_OBJS)  /out:$@
+       $(MT) -manifest $@.manifest -outputresource:$@;1
+
+$(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 $(LIBDIR)\*.lib
 
-########### check directories and create if needed
 dirs: $(OBJDIR) $(WINDIR) $(LIBDIR) $(BINDIR) $(TMPDIR)
 
 $(OBJDIR) $(WINDIR) $(LIBDIR) $(BINDIR) $(TMPDIR):
@@ -547,14 +573,7 @@ $(OBJDIR) $(WINDIR) $(LIBDIR) $(BINDIR) $(TMPDIR):
 yaz: $(YAZ_DLL_TARGET)
 
 $(YAZ_DLL_TARGET) : $(YAZ_DLL_SOURCE)
-       copy $(YAZBINDIR)\*.dll $(BINDIR)
-
-###########################################################
-############### Explicit dependencies
-###########################################################
+#      copy "$(YAZBINDIR)\*.dll.manifest" $(BINDIR)
+       copy "$(YAZBINDIR)\*.dll" $(BINDIR)
 
-# $(ALL_OBJS): makefile
 
-# force recompilation of everything, if makefile changed
-
-###########################################################