-# Z'mbol/Zebra makefile for MS NMAKE
-# $Id: makefile,v 1.9 2002-03-21 10:31:54 adam Exp $
+# Zebra makefile for MS NMAKE
+# $Id: makefile,v 1.17 2002-09-03 12:22:21 adam Exp $
###########################################################
############### Parameters
###########################################################
-DEBUG=1 # 0 for release, 1 for debug
-ZMBOL=1
+DEBUG=0 # 0 for release, 1 for debug
+
+# EXPAT is optional. It's required for grs.xml-filters.
+HAVE_EXPAT=1
+EXPAT_DIR= c:\Expat-1.95.4
+
+# iconv is optional
+HAVE_ICONV=0
+ICONV_DIR = c:\libiconv-1.7.0.1
default: all
###########################################################
# 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
YAZLIB=$(YAZDIR)\lib\yaz.lib
YAZLIBS=$(YAZLIB)
YAZBINDIR=$(YAZDIR)\bin
-YAZDLL=$(YAZBINDIR)\yaz.dll
+YAZ_DLL_SOURCE=$(YAZBINDIR)\yaz.dll
+YAZ_DLL_TARGET=$(BINDIR)\yaz.dll
# BZIP2 settings. Uncomment and specify if you wish to use LIBBZIP2.
# (C) 1996-1999 Julian Seward <jseward@acm.org> http://www.bzip2.org
ISAMSDIR=$(SRCDIR)\ISAMS
ISAMDIR=$(SRCDIR)\ISAM
ISAMCDIR=$(SRCDIR)\ISAMC
+ISAMBDIR=$(SRCDIR)\ISAMB
RECCTRLDIR=$(SRCDIR)\RECCTRL
RSETDIR=$(SRCDIR)\RSET
UTILDIR=$(SRCDIR)\UTIL
###########################################################
ZEBRALIB=$(LIBDIR)\zebra.lib
-!if $(ZMBOL)
-ZSERVER=$(BINDIR)\zmbolsrv.exe
-ZINDEX=$(BINDIR)\zmbolidx.exe
-!else
ZSERVER=$(BINDIR)\zebrasrv.exe
ZINDEX=$(BINDIR)\zebraidx.exe
-!endif
APITEST=$(BINDIR)\apitest.exe
# shortcut names defined here
############### Compiler and linker options
###########################################################
+!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_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=
+!endif
+
+!if $(HAVE_ICONV)
+ICONV_DEF= /D HAVE_ICONV_H=1 /I"$(ICONV_DIR)\include"
+ICONV_LIB= $(ICONV_DIR)\lib\iconv.lib
+!else
+ICONV_DEF= /D HAVE_ICONV_H=0
+ICONV_LIB=
+!endif
+
### C and CPP compiler (the same thing)
# Note: $(CPP) has already been defined in the environment
# (if you set things up right!)
/nologo /W3 /GX /FD /c \
/D "WIN32" \
/D"_CONSOLE" /D"_MBCS" \
+ $(ICONV_DEF) \
+ $(EXPAT_DEF) \
/FR"$(OBJDIR)\\" \
/Fo"$(OBJDIR)\\" \
/Fd"$(OBJDIR)\\" \
- /D"ZMBOL=$(ZMBOL)" \
$(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
+ wsock32.lib advapi32.lib $(ICONV_LIB) $(EXPAT_LIB)
COMMON_LNK_OPTIONS= /nologo \
/machine:i386 \
APITEST_OBJS= \
$(OBJDIR)\apitest.obj
-!if $(ZMBOL)
-ZMBOLLIB_OBJS= \
+ZEBRALIB_OBJS= \
$(OBJDIR)\isam.obj \
$(OBJDIR)\isamc.obj \
$(OBJDIR)\isamd.obj \
$(OBJDIR)\merge.obj \
$(OBJDIR)\merge-d.obj \
$(OBJDIR)\physical.obj \
- $(OBJDIR)\rootblk.obj
-!else
-ZMBOLLIB_OBJS=
-!endif
-ZEBRALIB_OBJS= \
- $(ZMBOLLIB_OBJS) \
+ $(OBJDIR)\rootblk.obj \
$(OBJDIR)\zebra-lock.obj \
$(OBJDIR)\attribute.obj \
$(OBJDIR)\bfile.obj \
$(OBJDIR)\recstat.obj \
$(OBJDIR)\rectext.obj \
$(OBJDIR)\regxread.obj \
+ $(OBJDIR)\xmlread.obj \
$(OBJDIR)\res.obj \
$(OBJDIR)\retrieve.obj \
$(OBJDIR)\rsbool.obj \
$(OBJDIR)\zrpn.obj \
$(OBJDIR)\zsets.obj \
$(OBJDIR)\isams.obj \
+ $(OBJDIR)\isamb.obj \
$(OBJDIR)\rsisamd.obj \
+ $(OBJDIR)\rsisamb.obj \
+ $(OBJDIR)\rsbetween.obj \
$(OBJDIR)\dir.obj \
$(OBJDIR)\dirs.obj \
$(OBJDIR)\extract.obj \
# source files. Funny way of doing it, but it works.
{$(SRCDIR)}.cpp{$(OBJDIR)}.obj:
- @$(CPP) $(COPT) $<
+ $(CPP) $(COPT) $<
{$(SRCDIR)}.c{$(OBJDIR)}.obj:
- @$(CPP) $(COPT) $<
+ $(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) $<
+ $(CPP) $(COPT) $<
{$(ISAMDIR)}.c{$(OBJDIR)}.obj:
- @$(CPP) $(COPT) $<
+ $(CPP) $(COPT) $<
{$(ISAMCDIR)}.c{$(OBJDIR)}.obj:
- @$(CPP) $(COPT) $<
+ $(CPP) $(COPT) $<
+
+{$(ISAMBDIR)}.c{$(OBJDIR)}.obj:
+ $(CPP) $(COPT) $<
{$(RECCTRLDIR)}.c{$(OBJDIR)}.obj:
- @$(CPP) $(COPT) $<
+ $(CPP) $(COPT) $<
{$(RSETDIR)}.c{$(OBJDIR)}.obj:
- @$(CPP) $(COPT) $<
+ $(CPP) $(COPT) $<
{$(UTILDIR)}.c{$(OBJDIR)}.obj:
- @$(CPP) $(COPT) $<
+ $(CPP) $(COPT) $<
{$(APITESTDIR)}.c{$(OBJDIR)}.obj:
- @$(CPP) $(COPT) $<
-
+ $(CPP) $(COPT) $<
###########################################################
############### Linking
-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)
+dirs: $(OBJDIR) $(WINDIR) $(LIBDIR) $(BINDIR) $(TMPDIR) \
+ $(EXPAT_DLL_TARGET) $(YAZ_DLL_TARGET)
$(OBJDIR) $(WINDIR) $(LIBDIR) $(BINDIR) $(TMPDIR):
if not exist "$@/$(NUL)" mkdir "$@"
+$(YAZ_DLL_TARGET) : $(YAZ_DLL_SOURCE)
+ copy $(YAZ_DLL_SOURCE) $(YAZ_DLL_TARGET)
+
###########################################################
############### Explicit dependencies
###########################################################