X-Git-Url: http://git.indexdata.com/?p=yaz-moved-to-github.git;a=blobdiff_plain;f=win%2Fmakefile;h=e9198758105ff61ca229e00c282e0e56f8413991;hp=e5c0e2d3d4c674c0117647a44ad7da38898d8444;hb=0e835ef58f6a0939626e6911a730945f81fa2e2f;hpb=f1d9f7b3b3ba4e39f261f9b820dad51b8754549c diff --git a/win/makefile b/win/makefile index e5c0e2d..e919875 100644 --- a/win/makefile +++ b/win/makefile @@ -1,5 +1,5 @@ # makefile.mak - makefile for MS NMAKE -# $Id: makefile,v 1.35 2002-03-16 10:26:57 adam Exp $ +# $Id: makefile,v 1.54 2003-02-18 09:11:50 adam Exp $ # # Programmed by # HL: Heikki Levanto, Index Data @@ -18,6 +18,7 @@ # 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 +# - You may have to edit the path to tcl below ########################################################### ############### Parameters @@ -25,11 +26,27 @@ DEBUG=0 # 0 for release, 1 for debug +# TCL +#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 + default: all -all: dirs yaz_date_h generate dll client ztest zoomsh +all: dirs generate dll client ztest zoomsh iconv libxml2 -NSIS="c:\program files\nsis\makensis.exe" +NSIS="c:\program files\nsis\makensis-bz2.exe" nsis: all $(NSIS) yaz.nsi @@ -76,14 +93,12 @@ TMP=$(TMPDIR) ############### Targets - what to make ########################################################### - DLL=$(BINDIR)\Yaz.dll IMPLIB=$(LIBDIR)\Yaz.lib CLIENT=$(BINDIR)\yaz-client.exe ZOOMSH=$(BINDIR)\zoomsh.exe ZTEST=$(BINDIR)\yaz-ztest.exe -YAZ_DATE_H=$(INCLDIR)\yaz\yaz-date.h ZOOMTST1=$(BINDIR)\zoomtst1.exe ZOOMTST2=$(BINDIR)\zoomtst2.exe @@ -102,12 +117,42 @@ ztest: $(ZTEST) zoomsh: $(ZOOMSH) $(ZOOMTST1) $(ZOOMTST2) $(ZOOMTST3) \ $(ZOOMTST4) $(ZOOMTST5) $(ZOOMTST6) $(ZOOMTST7) $(ZOOMTST8) -yaz_date_h: $(YAZ_DATE_H) - ########################################################### ############### Compiler and linker options ########################################################### +!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)\lib\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=/D HAVE_XML2=1 /I"$(LIBXML2_DIR)\include" +libxml2: $(BINDIR)\libxml2.dll + +$(BINDIR)\libxml2.dll: + copy $(LIBXML2_DIR)\lib\libxml2.dll $(BINDIR) +!else +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 @@ -115,10 +160,11 @@ yaz_date_h: $(YAZ_DATE_H) COMMON_C_OPTIONS= \ /nologo /W3 /GX /FD /c \ - /D "YAZ_MODULE_ill=1" \ - /D "YAZ_MODULE_ccl=1" \ + $(ICONV_DEF) \ + $(LIBXML2_DEF) \ /D "_WINDOWS" \ /D "WIN32" \ + /D "HAVE_WCHAR_H=1" \ /FR"$(OBJDIR)\\" \ /Fo"$(OBJDIR)\\" \ /Fd"$(OBJDIR)\\" @@ -156,7 +202,8 @@ LINK=link.exe LINK_LIBS= kernel32.lib user32.lib gdi32.lib \ advapi32.lib uuid.lib \ - wsock32.lib advapi32.lib + wsock32.lib advapi32.lib \ + $(ICONV_LIB) $(LIBXML2_LIB) COMMON_LNK_OPTIONS= /nologo \ /subsystem:windows \ @@ -173,10 +220,6 @@ ZOOMSH_LINK_OPTIONS = /subsystem:console SERVER_LINK_OPTIONS = -lib ZTEST_LINK_OPTIONS = /subsystem:console -# TCL -TCL="C:\Program Files\Tcl\bin\tclsh83.exe" -HAVE_TCL=1 - COMMON_TCL_OPTIONS= ..\util\yaz-comp -I$(INCLDIR) -i yaz # Final opt variables @@ -239,6 +282,7 @@ YAZ_SERVER_OBJS= \ "$(OBJDIR)\tcpdchk.obj" ZTEST_OBJS= \ + "$(OBJDIR)\read-marc.obj" \ "$(OBJDIR)\read-grs.obj" \ "$(OBJDIR)\ztest.obj" @@ -296,7 +340,9 @@ YAZ_UTIL_OBJS= \ $(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 \ @@ -306,28 +352,12 @@ YAZ_ZUTIL_OBJS= \ $(OBJDIR)\yaz-ccl.obj \ $(OBJDIR)\otherinfo.obj \ $(OBJDIR)\sortspec.obj \ - $(OBJDIR)\z3950oid.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)\z3950oid.obj \ + $(OBJDIR)\charneg.obj \ + $(OBJDIR)\grs1disp.obj \ + $(OBJDIR)\zgdu.obj \ + $(OBJDIR)\soap.obj \ + $(OBJDIR)\srw.obj Z3950_OBJS= \ $(OBJDIR)\z-date.obj\ @@ -357,7 +387,8 @@ Z3950_OBJS= \ $(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\ @@ -374,14 +405,13 @@ COMMON_YAZ_OBJS= \ $(YAZ_COMSTACK_OBJS) \ $(YAZ_ZUTIL_OBJS) \ $(YAZ_CCL_OBJS) \ - $(YAZ_RET_OBJS) \ $(YAZ_SERVER_OBJS) \ $(YAZ_ZOOM_OBJS) YAZ_OBJS= \ - $(COMMON_YAZ_OBJS) \ $(Z3950_OBJS) \ - $(ILL_OBJS) + $(ILL_OBJS) \ + $(COMMON_YAZ_OBJS) DLL_OBJS= $(YAZ_OBJS) @@ -419,6 +449,10 @@ ESADMIN_C_FILES = $(Z3950_C_DIR)\zes-admin.c 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 \ @@ -471,6 +505,7 @@ Z3950V3_FILES= $(Z3950V3_C_FILES) $(Z3950V3_H_FILES) 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) \ @@ -478,7 +513,8 @@ GENERATED_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) \ @@ -486,7 +522,8 @@ GENERATED_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) \ @@ -550,11 +587,6 @@ generated_files: \ !if $(HAVE_TCL) -$(YAZ_DATE_H): - @cd .. - $(TCL) util\cvs-date.tcl include\yaz\yaz-date.h - @cd win - $(Z3950V3_FILES): $(Z3950DIR)\z3950v3.asn @cd $(Z3950DIR) $(TCL) $(TCLOPT) -d z.tcl z3950v3.asn @@ -585,6 +617,11 @@ $(CHARNEG_FILES): $(Z3950DIR)\charneg-3.asn $(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 @@ -595,6 +632,10 @@ $(ITEM_REQ_FILES): $(ILLDIR)\item-req.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 @@ -793,23 +834,22 @@ $(ZTEST) : "$(BINDIR)" $(ZTEST_OBJS) $(DLL) ############## clean clean: - del $(BINDIR)\*.exe - del $(BINDIR)\*.dll - del $(TMPDIR)\*. + -del $(BINDIR)\*.exe + -del $(BINDIR)\*.dll + -del $(TMPDIR)\*. - del $(LIBDIR)\*.MAP + -del $(LIBDIR)\*.MAP - del $(LIBDIR)\*.LIB - del $(OBJDIR)\*.OBJ + -del $(LIBDIR)\*.LIB + -del $(OBJDIR)\*.OBJ realclean: clean - del $(Z3950_C_DIR)\*.c - del $(Z3950_C_DIR)\*.h - del $(INCLDIR)\yaz\z-accdes1.h - del $(INCLDIR)\yaz\z-core.h - del $(DATETIME_H_FILES) - del $(UNIVRES_H_FILES) - del $(ESUPDATE_H_FILES) + -del $(Z3950_C_DIR)\z*.c + -del $(INCLDIR)\yaz\z-accdes1.h + -del $(INCLDIR)\yaz\z-core.h + -del $(DATETIME_H_FILES) + -del $(UNIVRES_H_FILES) + -del $(ESUPDATE_H_FILES) # Because DOS del will only accept one file name to delete, # the _H_ files work only on sets that have just one file. @@ -841,7 +881,66 @@ $(ILL_OBJS): $(ILL_CORE_FILES) $(ITEM_REQ_FILES) ########################################################### # # $Log: makefile,v $ -# Revision 1.35 2002-03-16 10:26:57 adam +# 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 +# iconv.dll +# +# Revision 1.42 2002/06/05 21:11:00 adam +# NSIS bz2 +# +# Revision 1.41 2002/06/04 08:29:53 adam +# ignore errors on del. +# +# Revision 1.40 2002/06/02 21:34:45 adam +# Remove --enable-module option +# +# Revision 1.39 2002/05/31 08:48:06 adam +# Changed SectionIns for NSIS v1.98 +# +# Revision 1.38 2002/05/18 09:52:37 oleg +# Added support of CharacterSetandLanguageNegotiation-3 +# modele (based on Z_PrivateCharacterSet_externallySpecified) at the client +# side. +# +# Revision 1.37 2002/05/17 12:48:30 adam +# Use __stdcall convention for ZOOM on WIN32 +# +# Revision 1.36 2002/03/18 21:33:48 adam +# MARC records embedded in C code for test server +# +# Revision 1.35 2002/03/16 10:26:57 adam # Added NSIS rules (nmake nsis). # # Revision 1.34 2002/02/12 15:59:12 adam