-# makefile.mak - makefile for MS NMAKE
-# $Id: makefile,v 1.45 2002-08-27 22:33:30 adam Exp $
+# Copyright (C) 1994-2003, Index Data
+# All rights reserved.
+# $Id: makefile,v 1.55 2003-02-18 21:27:53 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
-
-# expat
-HAVE_EXPAT=0
-EXPAT_DIR= c:\Expat-1.95.4
-
-# iconv
-HAVE_ICONV=0
-ICONV_DIR = c:\libiconv-1.7.0.1
+DEBUG=0 # 0 for release, 1 for debug
# TCL
-TCL="C:\program files\Tcl\bin\tclsh83.exe"
+#TCL="C:\Tcl\bin\tclsh83.exe"
+TCL="C:\Program Files\Tcl\bin\tclsh83.exe"
HAVE_TCL=1
+# iconv charcter conversion utility
+HAVE_ICONV=1
+ICONV_DIR = c:\iconv-1.8.win32
+
+# libxml2
+HAVE_LIBXML2=1
+LIBXML2_DIR=c:\libxml2-2.5.3.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"
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
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
###########################################################
/I"$(ICONV_DIR)\include"
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
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)\wrbuf.obj \
$(OBJDIR)\xmalloc.obj \
$(OBJDIR)\matchstr.obj \
- $(OBJDIR)\siconv.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)\zgdu.obj \
+ $(OBJDIR)\soap.obj \
+ $(OBJDIR)\srw.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
ILL_OBJS= \
$(OBJDIR)\ill-get.obj\
$(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)\xcqlutil.obj
+
COMMON_YAZ_OBJS= \
$(YAZ_UTIL_OBJS) \
$(YAZ_ODR_OBJS) \
$(YAZ_COMSTACK_OBJS) \
$(YAZ_ZUTIL_OBJS) \
$(YAZ_CCL_OBJS) \
- $(YAZ_RET_OBJS) \
$(YAZ_SERVER_OBJS) \
- $(YAZ_ZOOM_OBJS)
+ $(YAZ_ZOOM_OBJS) \
+ $(YAZ_CQL_OBJS)
YAZ_OBJS= \
$(Z3950_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 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)
GENERATED_C_FILES= \
$(Z3950V3_C_FILES) \
$(UNIVRES_C_FILES) \
$(DATETIME_C_FILES) \
$(ESADMIN_C_FILES) \
- $(CHARNEG_C_FILES)
+ $(CHARNEG_C_FILES) \
+ $(MTERM2_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)
generated_files: \
$(GENERATED_H_FILES) \
{$(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)
+
$(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 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.45 2002-08-27 22:33:30 adam
+# 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