-# makefile.mak - makefile for MS NMAKE
-# $Id: makefile,v 1.44 2002-07-25 14:19:18 adam Exp $
+# Copyright (C) 1994-2003, Index Data
+# All rights reserved.
+# $Id: makefile,v 1.65 2003-10-02 06:30:45 adam Exp $
#
# Programmed by
# HL: Heikki Levanto, Index Data
#
-# Log at the end of the file
-#
-# Missing
-# - Move MS-C's whatnots into win direcotry
-# - The TCL script produces C and H files in the same dir as the
-# ASN files. H's are copied to INCL, C's are left there.
-# They should be produced into OBJ...
-#
-# Envoronment problems
-# - You need to have the proper path and environment for VC set
-# up. There is a bat file VCVARS32.BAT that sets most of it up
-# for you. You can find this somewhere near DevStudio\VC\BIN
-# - RegSvr32 must also be along the path, often in WINDOWS\SYSTEM
-# - TCL has to be available too, if compiling for NEW_Z3950
###########################################################
############### Parameters
###########################################################
-DEBUG=1 # 0 for release, 1 for debug
+DEBUG=0 # 0 for release, 1 for debug
-# expat
-HAVE_EXPAT=1
-EXPAT_DIR= c:\Expat-1.95.4
+# TCL
+TCL="C:\Tcl\bin\tclsh84.exe"
+#TCL="C:\Program Files\Tcl\bin\tclsh83.exe"
+HAVE_TCL=1
-# iconv
+# iconv charcter conversion utility
HAVE_ICONV=1
-ICONV_DIR = c:\libiconv-1.7.0.1
+ICONV_DIR = c:\iconv-1.8.win32
-# TCL
-TCL="C:\Tcl\bin\tclsh83.exe"
-HAVE_TCL=1
+# libxml2
+HAVE_LIBXML2=1
+LIBXML2_DIR=c:\libxml2-2.5.10.win32
+
+# WIN32 binaries libxml2 & iconv from here:
+# http://www.zlatkovic.com/projects/libxml/binaries.html
+
+# bison
+HAVE_BISON=1
+BISON=bison
default: all
-all: dirs generate dll client ztest zoomsh
+all: dirs generate dll client ztest zoomsh cqlprog iconv libxml2
NSIS="c:\program files\nsis\makensis-bz2.exe"
############### Directories
###########################################################
# The current directory is supposed to be something like
-# ..../Yaz/Win, everything is relative to that
-ROOTDIR=.. # The home of Yaz
+# ..../yaz/win, everything is relative to that
+ROOTDIR=.. # The home of yaz
INCLDIR=$(ROOTDIR)\include # our includes
LIBDIR=$(ROOTDIR)\lib # We produce .lib, .exp etc there
ILLDIR=$(SRCDIR)\ill
CCLDIR=$(SRCDIR)\ccl
ZOOMDIR=$(SRCDIR)\zoom
+CQLDIR=$(SRCDIR)\cql
+
CLIENTDIR=$(SRCDIR)\CLIENT
SERVERDIR=$(SRCDIR)\SERVER
############### Targets - what to make
###########################################################
-
-DLL=$(BINDIR)\Yaz.dll
-IMPLIB=$(LIBDIR)\Yaz.lib
+DLL=$(BINDIR)\yaz.dll
+IMPLIB=$(LIBDIR)\yaz.lib
CLIENT=$(BINDIR)\yaz-client.exe
ZOOMSH=$(BINDIR)\zoomsh.exe
ZOOMTST7=$(BINDIR)\zoomtst7.exe
ZOOMTST8=$(BINDIR)\zoomtst8.exe
+CQL2PQF=$(BINDIR)\cql2pqf.exe
+CQL2XCQL=$(BINDIR)\cql2xcql.exe
+
# shortcut names defined here
dll : $(DLL)
client: $(CLIENT)
zoomsh: $(ZOOMSH) $(ZOOMTST1) $(ZOOMTST2) $(ZOOMTST3) \
$(ZOOMTST4) $(ZOOMTST5) $(ZOOMTST6) $(ZOOMTST7) $(ZOOMTST8)
+cqlprog: $(CQL2PQF) $(CQL2XCQL)
+
###########################################################
############### Compiler and linker options
###########################################################
/D HAVE_ICONV_H=1 \
/I"$(ICONV_DIR)\include"
ICONV_LIB= \
- $(ICONV_DIR)\lib\iconv.lib
+ "$(ICONV_DIR)\lib\iconv.lib"
+iconv: $(BINDIR)\iconv.dll
+
+$(BINDIR)\iconv.dll:
+ copy "$(ICONV_DIR)\lib\iconv.dll" $(BINDIR)
!else
ICONV_DEF= \
/D HAVE_ICONV_H=0
ICONV_LIB=
+iconv:
+
!endif
-!if $(HAVE_EXPAT)
-EXPAT_DEF= \
- /D HAVE_EXPAT_H=1 \
- /I"$(EXPAT_DIR)\source\lib"
-EXPAT_LIB= \
- "$(EXPAT_DIR)\libs\libexpat.lib"
+!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)\libxml2.dll:
+ copy "$(LIBXML2_DIR)\lib\libxml2.dll" $(BINDIR)
!else
-EXPAT_DEF= \
- /D HAVE_EXPAT_H=0
-EXPAT_LIB=
+LIBXML2_LIB=
+LIBXML2_DEF=/D HAVE_XML2=0
+libxml2:
+
!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 \
$(ICONV_DEF) \
- $(EXPAT_DEF) \
+ $(LIBXML2_DEF) \
/D "_WINDOWS" \
/D "WIN32" \
+ /D "HAVE_WCHAR_H=1" \
/FR"$(OBJDIR)\\" \
/Fo"$(OBJDIR)\\" \
/Fd"$(OBJDIR)\\"
LINK_LIBS= kernel32.lib user32.lib gdi32.lib \
advapi32.lib uuid.lib \
wsock32.lib advapi32.lib \
- $(ICONV_LIB) $(EXPAT_LIB)
+ $(ICONV_LIB) $(LIBXML2_LIB)
COMMON_LNK_OPTIONS= /nologo \
/subsystem:windows \
ZOOMSH_LINK_OPTIONS = /subsystem:console
SERVER_LINK_OPTIONS = -lib
ZTEST_LINK_OPTIONS = /subsystem:console
+CQL2PQF_LINK_OPTIONS = /subsystem:console
+CQL2XCQL_LINK_OPTIONS = /subsystem:console
+
-COMMON_TCL_OPTIONS= ..\util\yaz-comp -I$(INCLDIR) -i yaz
+COMMON_TCL_OPTIONS= ..\util\yaz-asncomp -I$(INCLDIR) -i yaz
# Final opt variables
!if $(DEBUG)
YAZ_ZOOMTST8_OBJS = \
$(OBJDIR)\zoomtst8.obj
+YAZ_CQL2PQF_OBJS = \
+ $(OBJDIR)\cql2pqf.obj
+YAZ_CQL2XCQL_OBJS = \
+ $(OBJDIR)\cql2xcql.obj
+
YAZ_SERVER_OBJS= \
"$(OBJDIR)\eventl.obj" \
"$(OBJDIR)\requestq.obj" \
$(OBJDIR)\odr_util.obj
YAZ_UTIL_OBJS= \
+ $(OBJDIR)\version.obj \
$(OBJDIR)\atoin.obj \
$(OBJDIR)\log.obj \
$(OBJDIR)\marcdisp.obj \
$(OBJDIR)\tpath.obj \
$(OBJDIR)\wrbuf.obj \
$(OBJDIR)\xmalloc.obj \
- $(OBJDIR)\matchstr.obj
+ $(OBJDIR)\matchstr.obj \
+ $(OBJDIR)\siconv.obj \
+ $(OBJDIR)\marc8.obj
YAZ_ZUTIL_OBJS= \
$(OBJDIR)\diagbib1.obj \
$(OBJDIR)\otherinfo.obj \
$(OBJDIR)\sortspec.obj \
$(OBJDIR)\z3950oid.obj \
- $(OBJDIR)\charneg.obj
-
-
-YAZ_RET_OBJS= \
- $(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_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)\d1_if.obj\
- $(OBJDIR)\d1_expat.obj
-
+ $(OBJDIR)\charneg.obj \
+ $(OBJDIR)\grs1disp.obj \
+ $(OBJDIR)\opacdisp.obj \
+ $(OBJDIR)\zgdu.obj \
+ $(OBJDIR)\soap.obj \
+ $(OBJDIR)\srw.obj \
+ $(OBJDIR)\zoom-c.obj \
+ $(OBJDIR)\zoom-opt.obj
Z3950_OBJS= \
$(OBJDIR)\z-date.obj\
$(OBJDIR)\zes-pset.obj \
$(OBJDIR)\zes-update0.obj \
$(OBJDIR)\prt-ext.obj \
- $(OBJDIR)\z-charneg.obj
+ $(OBJDIR)\z-charneg.obj \
+ $(OBJDIR)\z-mterm2.obj \
+ $(OBJDIR)\z-oclcui.obj
ILL_OBJS= \
$(OBJDIR)\ill-get.obj\
$(OBJDIR)\ill-core.obj\
$(OBJDIR)\item-req.obj
-YAZ_ZOOM_OBJS = \
- $(OBJDIR)\zoom-c.obj \
- $(OBJDIR)\zoom-opt.obj
+YAZ_CQL_OBJS = \
+ $(OBJDIR)\cql.obj \
+ $(OBJDIR)\cqlstdio.obj \
+ $(OBJDIR)\cqlstring.obj \
+ $(OBJDIR)\cqltransform.obj \
+ $(OBJDIR)\cqlutil.obj \
+ $(OBJDIR)\cqlstrer.obj \
+ $(OBJDIR)\xcqlutil.obj
-COMMON_YAZ_OBJS= \
+YAZ_OBJS =\
$(YAZ_UTIL_OBJS) \
$(YAZ_ODR_OBJS) \
$(YAZ_COMSTACK_OBJS) \
+ $(Z3950_OBJS) \
+ $(ILL_OBJS) \
$(YAZ_ZUTIL_OBJS) \
$(YAZ_CCL_OBJS) \
- $(YAZ_RET_OBJS) \
- $(YAZ_SERVER_OBJS) \
- $(YAZ_ZOOM_OBJS)
-
-YAZ_OBJS= \
- $(Z3950_OBJS) \
- $(ILL_OBJS) \
- $(COMMON_YAZ_OBJS)
+ $(YAZ_CQL_OBJS) \
+ $(YAZ_SERVER_OBJS)
DLL_OBJS= $(YAZ_OBJS)
CHARNEG_H_FILES = $(INCLDIR)\yaz\z-charneg.h
CHARNEG_C_FILES = $(Z3950_C_DIR)\z-charneg.c
+# Files generated from mterm2.asn
+MTERM2_H_FILES = $(INCLDIR)\yaz\z-mterm2.h
+MTERM2_C_FILES = $(Z3950_C_DIR)\z-mterm2.c
+
+# Files generated from mterm2.asn
+OCLCUI_H_FILES = $(INCLDIR)\yaz\z-oclcui.h
+OCLCUI_C_FILES = $(Z3950_C_DIR)\z-oclcui.c
+
# Files created from z3950v3.asn
Z3950V3_H_FILES= \
$(INCLDIR)\yaz\z-accdes1.h \
ILL_CORE_FILES= $(ILL_CORE_C_FILES) $(ILL_CORE_H_FILES)
ITEM_REQ_FILES= $(ITEM_REQ_C_FILES) $(ITEM_REQ_H_FILES)
CHARNEG_FILES = $(CHARNEG_C_FILES) $(CHARNEG_H_FILES)
+MTERM2_FILES = $(MTERM2_C_FILES) $(MTERM2_H_FILES)
+OCLCUI_FILES = $(OCLCUI_C_FILES) $(OCLCUI_H_FILES)
GENERATED_C_FILES= \
$(Z3950V3_C_FILES) \
$(UNIVRES_C_FILES) \
$(DATETIME_C_FILES) \
$(ESADMIN_C_FILES) \
- $(CHARNEG_C_FILES)
+ $(CHARNEG_C_FILES) \
+ $(MTERM2_C_FILES) \
+ $(OCLCUI_C_FILES)
GENERATED_H_FILES= \
$(Z3950V3_H_FILES) \
$(UNIVRES_H_FILES) \
$(DATETIME_H_FILES) \
$(ESADMIN_H_FILES) \
- $(CHARNEG_H_FILES)
+ $(CHARNEG_H_FILES) \
+ $(MTERM2_H_FILES) \
+ $(OCLCUI_H_FILES)
generated_files: \
$(GENERATED_H_FILES) \
{$(SRCDIR)}.cpp{$(OBJDIR)}.obj:
@$(CPP) $(COPT) $<
-# Yaz client
+# yaz client
{$(CLIENTDIR)}.c{$(OBJDIR)}.obj:
@$(CPP) $(COPT) $< /D"_CONSOLE"
{$(ZOOMDIR)}.c{$(OBJDIR)}.obj:
$(CPP) $(COPT) $<
+{$(CQLDIR)}.c{$(OBJDIR)}.obj:
+ $(CPP) $(COPT) $<
+
############### ASN-generated files
!if $(HAVE_TCL)
$(TCL) $(TCLOPT) -d z.tcl charneg-3.asn
@cd $(WINDIR)
+$(MTERM2_FILES): $(Z3950DIR)\mterm2.asn
+ @cd $(Z3950DIR)
+ $(TCL) $(TCLOPT) -d z.tcl mterm2.asn
+ @cd $(WINDIR)
+
+$(OCLCUI_FILES): $(Z3950DIR)\oclcui.asn
+ @cd $(Z3950DIR)
+ $(TCL) $(TCLOPT) -d z.tcl oclcui.asn
+ @cd $(WINDIR)
+
$(ILL_CORE_FILES): $(ILLDIR)\ill9702.asn
@cd $(ILLDIR)
$(TCL) $(TCLOPT) -d ill.tcl ill9702.asn
$(TCL) $(TCLOPT) -d ill.tcl item-req.asn
@cd $(WINDIR)
+$(UTILDIR)\marc8.c: $(UTILDIR)\charconv.sgm
+ @cd $(UTILDIR)
+ $(TCL) charconv.tcl -p marc8 -s 50 charconv.sgm -o marc8.c
+
!endif
+!if $(HAVE_BISON)
+$(CQLDIR)\cql.c: $(CQLDIR)\cql.y
+ @cd $(CQLDIR)
+ $(BISON) -y -p cql_ -o cql.c cql.y
+
+!endif
###########################################################
############### Resources
/out:$(ZOOMTST8)
<<
+$(CQL2PQF) : "$(BINDIR)" $(YAZ_CQL2PQF_OBJS)
+ @echo Linking $(CQL2PQF)
+ $(LINK) @<<
+ $(LNKOPT)
+ $(CQL2PQF_LINK_OPTIONS)
+ $(LINK_LIBS)
+ $(IMPLIB)
+ $(YAZ_CQL2PQF_OBJS)
+ /pdb:"$(LIBDIR)\cql2pqf.pdb"
+ /map:"$(LIBDIR)\cql2pqf.map"
+ /out:$(CQL2PQF)
+<<
+
+$(CQL2XCQL) : "$(BINDIR)" $(YAZ_CQL2XCQL_OBJS)
+ @echo Linking $(CQL2XCQL)
+ $(LINK) @<<
+ $(LNKOPT)
+ $(CQL2XCQL_LINK_OPTIONS)
+ $(LINK_LIBS)
+ $(IMPLIB)
+ $(YAZ_CQL2XCQL_OBJS)
+ /pdb:"$(LIBDIR)\cql2xcql.pdb"
+ /map:"$(LIBDIR)\cql2xcql.map"
+ /out:$(CQL2XCQL)
+<<
+
$(ZTEST) : "$(BINDIR)" $(ZTEST_OBJS) $(DLL)
@echo Linking the ztest $(ZTEST)
$(LINK) @<<
/out:$(ZTEST)
<<
-
# note that this links a lib, so it uses completely different options.
###########################################################
-del $(BINDIR)\*.exe
-del $(BINDIR)\*.dll
-del $(TMPDIR)\*.
-
-del $(LIBDIR)\*.MAP
-
-del $(LIBDIR)\*.LIB
-del $(OBJDIR)\*.OBJ
realclean: clean
+ -del $(CQLDIR)\cql.c
-del $(Z3950_C_DIR)\z*.c
-del $(INCLDIR)\yaz\z-accdes1.h
-del $(INCLDIR)\yaz\z-core.h
###########################################################
#
# $Log: makefile,v $
-# Revision 1.44 2002-07-25 14:19:18 adam
+# Revision 1.65 2003-10-02 06:30:45 adam
+# Quote ICONV_DIR/LIBXML2_DIR as suggested by Michael Freidgeim
+#
+# Revision 1.64 2003/09/04 18:52:02 adam
+# Minor changes. Use libxml-2.5.10
+#
+# Revision 1.63 2003/07/25 11:11:19 adam
+# Change order of compilation to reflect Unix AM.
+#
+# Revision 1.62 2003/07/19 13:48:49 adam
+# makefile updated for oclcui.asn
+#
+# Revision 1.61 2003/07/15 08:26:26 adam
+# opacdisp.obj
+#
+# Revision 1.60 2003/06/11 18:37:10 adam
+# Dont use charconv_cjk.xml
+#
+# Revision 1.59 2003/06/03 09:11:13 adam
+# WIN32 updates
+#
+# Revision 1.58 2003/06/02 13:44:54 adam
+# Added cqlstrer to win makefile
+#
+# Revision 1.57 2003/05/27 21:12:23 adam
+# YAZ ASN.1 compiler renamed from yaz-comp to yaz-asncomp
+#
+# Revision 1.56 2003/05/23 10:41:26 adam
+# WIN32 updates
+#
+# Revision 1.55 2003/02/18 21:27:53 adam
+# CQL w/bison on WIN32
+#
+# Revision 1.54 2003/02/18 09:11:50 adam
+# Prepare for external utilties: iconv, libxml2 on WIN32
+#
+# Revision 1.53 2003/02/17 22:34:39 adam
+# WIN32 updates
+#
+# Revision 1.52 2002/12/16 14:06:34 adam
+# WIN32 updates for marc8.c
+#
+# Revision 1.51 2002/12/05 12:16:39 adam
+# yaz_strerror. WIN32 updates for mterm2.asn
+#
+# Revision 1.50 2002/10/24 12:14:01 heikki
+# Using a default path to find tcl
+#
+# Revision 1.49 2002/10/22 13:49:53 adam
+# data1 gone
+#
+# Revision 1.48 2002/10/22 10:32:46 adam
+# New source grs1disp.c
+#
+# Revision 1.47 2002/09/06 20:04:49 adam
+# debug=0
+#
+# Revision 1.46 2002/08/30 11:28:01 adam
+# Remove EXPAT reader
+#
+# Revision 1.45 2002/08/27 22:33:30 adam
+# siconv added
+#
+# Revision 1.44 2002/07/25 14:19:18 adam
# EXPAT support on WIN32
#
# Revision 1.43 2002/07/25 13:45:30 adam