Patches for DLL compilation & libtiff

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@5348 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Guillermo Rodriguez Garcia 2000-01-12 01:11:04 +00:00
parent 0b2dadd342
commit eafef53a5f

View File

@ -89,6 +89,20 @@ WXDIR = ../..
# this central makefile.
include $(WXDIR)/src/makeg95.env
# DLL Name, if building wxWindows as a DLL.
ifdef WXMAKINGDLL
WXDLL = $(WXDIR)/lib/wx$(WXVERSION).dll
WXDEF = wx$(WXVERSION).def
DLL_EXTRA_LIBS = $(WXDIR)/lib/libzlib.a \
$(WXDIR)/lib/libpng.a $(WXDIR)/lib/libjpeg.a \
$(WXDIR)/lib/libxpm.a $(WXDIR)/lib/libtiff.a
DLL_LDFLAGS = -L$(WXDIR)/lib
DLL_LDLIBS = -mwindows -lcomctl32 -lctl3d32 -lole32 -loleaut32 \
-luuid -lrpcrt4 -lodbc32 -lwinmm \
-lwsock32 $(DLL_EXTRA_LIBS) \
-lstdc++
endif
# Subordinate library possibilities
EXTRAOBJS=
@ -96,24 +110,26 @@ EXTRAOBJS=
GENDIR = $(WXDIR)/src/generic
COMMDIR = $(WXDIR)/src/common
HTMLDIR = $(WXDIR)/src/html
XPMDIR = $(WXDIR)/src/xpm
ZLIBDIR = $(WXDIR)/src/zlib
PNGDIR = $(WXDIR)/src/png
JPEGDIR = $(WXDIR)/src/jpeg
ZLIBDIR = $(WXDIR)/src/zlib
XPMDIR = $(WXDIR)/src/xpm
TIFFDIR = $(WXDIR)/src/tiff
OLEDIR = $(WXDIR)/src/msw/ole
MSWDIR = $(WXDIR)/src/msw
XPMLIB = $(WXDIR)/lib/libxpm.a
PNGLIB = $(WXDIR)/lib/libpng.a
ZLIBLIB = $(WXDIR)/lib/libzlib.a
PNGLIB = $(WXDIR)/lib/libpng.a
JPEGLIB = $(WXDIR)/lib/libjpeg.a
XPMLIB = $(WXDIR)/lib/libxpm.a
TIFFLIB = $(WXDIR)/lib/libtiff.a
DOCDIR = $(WXDIR)\docs
DOCDIR = $(WXDIR)/docs
# Only use the WIN32 wxDirDialog if we have a recent
# version of Mingw32
ifeq ($(MINGW32),1)
ifeq ($(MINGW32VERSION),2.95)
ifneq "$(findstring 2.95, $(MINGW32VERSION))" ""
DIRDLGOBJ = $(MSWDIR)/dirdlg.$(OBJSUFF)
else
DIRDLGOBJ = $(GENDIR)/dirdlgg.$(OBJSUFF)
@ -232,8 +248,42 @@ XPMOBJS = $(XPMDIR)/crbuffri.o\
$(XPMDIR)/simx.o $(XPMDIR)/wrffrdat.o\
$(XPMDIR)/wrffrp.o $(XPMDIR)/wrffri.o
TIFFOBJS = $(TIFFDIR)/tif_aux.o \
$(TIFFDIR)/tif_close.o \
$(TIFFDIR)/tif_codec.o \
$(TIFFDIR)/tif_compress.o \
$(TIFFDIR)/tif_dir.o \
$(TIFFDIR)/tif_dirinfo.o \
$(TIFFDIR)/tif_dirread.o \
$(TIFFDIR)/tif_dirwrite.o \
$(TIFFDIR)/tif_dumpmode.o \
$(TIFFDIR)/tif_error.o \
$(TIFFDIR)/tif_fax3.o \
$(TIFFDIR)/tif_fax3sm.o \
$(TIFFDIR)/tif_flush.o \
$(TIFFDIR)/tif_getimage.o \
$(TIFFDIR)/tif_jpeg.o \
$(TIFFDIR)/tif_luv.o \
$(TIFFDIR)/tif_lzw.o \
$(TIFFDIR)/tif_next.o \
$(TIFFDIR)/tif_open.o \
$(TIFFDIR)/tif_packbits.o \
$(TIFFDIR)/tif_pixarlog.o \
$(TIFFDIR)/tif_predict.o \
$(TIFFDIR)/tif_print.o \
$(TIFFDIR)/tif_read.o \
$(TIFFDIR)/tif_strip.o \
$(TIFFDIR)/tif_swab.o \
$(TIFFDIR)/tif_thunder.o \
$(TIFFDIR)/tif_tile.o \
$(TIFFDIR)/tif_version.o \
$(TIFFDIR)/tif_warning.o \
$(TIFFDIR)/tif_win32.o \
$(TIFFDIR)/tif_write.o \
$(TIFFDIR)/tif_zip.o
ifeq ($(MINGW32),1)
ifeq ($(MINGW32VERSION),2.95)
ifneq "$(findstring 2.95, $(MINGW32VERSION))" ""
OBJECTS = $(MSWOBJS) $(COMMONOBJS) $(GENERICOBJS) $(HTMLOBJS) $(DIRDLGOBJ) $(ADVANCEDOBJS)
else
OBJECTS = $(MSWOBJS) $(COMMONOBJS) $(GENERICOBJS) $(HTMLOBJS) $(DIRDLGOBJ)
@ -242,12 +292,59 @@ else
OBJECTS = $(MSWOBJS) $(COMMONOBJS) $(GENERICOBJS) $(HTMLOBJS) $(DIRDLGOBJ)
endif
all: $(OBJECTS) $(WXLIB) $(ZLIBLIB) $(JPEGLIB) $(PNGLIB) $(XPMLIB)
all: $(OBJECTS) $(WXLIB) $(ZLIBLIB) $(PNGLIB) $(JPEGLIB) $(XPMLIB) $(TIFFLIB)
ifndef WXMAKINGDLL
$(WXLIB): $(OBJECTS) $(EXTRAOBJS)
ar $(AROPTIONS) $@ $(EXTRAOBJS) $(OBJECTS)
$(RANLIB) $@
else
# The new linker is a few orders of magnitude faster than the old way
# of creating DLLs.
ifeq "$(strip $(LD_SUPPORTS_SHARED))" "yes"
$(WXDLL): $(OBJECTS) $(EXTRAOBJS)
$(CC) -shared -o $@ \
-Wl,--output-def,$(WXDEF) \
-Wl,--out-implib,$(WXLIB) \
$(OBJECTS) $(EXTRAOBJS) \
$(DLL_LDFLAGS) $(DLL_LDLIBS)
else
ifeq ($(MINGW32),1)
DLL_ENTRY = _DllMainCRTStartup@12
else
DLL_ENTRY = __cygwin_dll_entry@12
endif
LD_STUFF = $(OBJECTS) $(EXTRAOBJS) -Wl,-e,$(DLL_ENTRY) \
$(DLL_LDFLAGS) $(DLL_LDLIBS) #-Wl,--image-base=0x66000000
DLL_STUFF = --as=$(AS) --dllname $(notdir $(WXDLL)) \
--def $(WXDEF) \
--base-file wx.base --output-exp wx.exp
$(WXDEF) $(WXLIB): $(OBJECTS) $(EXTRAOBJS)
$(DLLTOOL) --output-def $@ --output-lib $(WXLIB) \
--dllname $(notdir $(WXDLL)) \
$(OBJECTS) $(EXTRAOBJS) $(DLL_EXTRA_LIBS)
$(WXDLL): $(OBJECTS) $(EXTRAOBJS) $(WXDEF)
$(CC) -mdll -Wl,--base-file,wx.base -s -o $@ $(LD_STUFF)
$(DLLTOOL) $(DLL_STUFF)
$(CC) -mdll -Wl,--base-file,wx.base wx.exp -s -o $@ $(LD_STUFF)
$(DLLTOOL) $(DLL_STUFF)
$(CC) -mdll wx.exp -o $@ $(LD_STUFF)
-$(RM) wx.base
-$(RM) wx.exp
endif
endif
$(ZLIBLIB): $(ZLIBOBJS)
ar $(AROPTIONS) $@ $(ZLIBOBJS)
$(RANLIB) $@
@ -264,16 +361,21 @@ $(XPMLIB): $(XPMOBJS)
ar $(AROPTIONS) $@ $(XPMOBJS)
$(RANLIB) $@
$(TIFFLIB): $(TIFFOBJS)
ar $(AROPTIONS) $@ $(TIFFOBJS)
$(RANLIB) $@
$(OBJECTS): $(WXINC)/wx/defs.h $(WXINC)/wx/object.h $(WXINC)/wx/setup.h
$(COMMDIR)/y_tab.$(OBJSUFF): $(COMMDIR)/y_tab.c $(COMMDIR)/lex_yy.c
$(CCLEX) -c $(CPPFLAGS) -DUSE_DEFINE -DYY_USE_PROTOS -o $@ $(COMMDIR)/y_tab.c
$(COMMDIR)/y_tab.c: $(COMMDIR)/dosyacc.c
$(COPY) ..\\common\\dosyacc.c ..\\common\\y_tab.c
$(COPY) ../common/dosyacc.c ../common/y_tab.c
$(COMMDIR)/lex_yy.c: $(COMMDIR)/doslex.c
$(COPY) ..\\common\\doslex.c ..\\common\\lex_yy.c
$(COPY) ../common/doslex.c ../common/lex_yy.c
# Replace lex with flex if you run into compilation
# problems with lex_yy.c. See also note about LEX_SCANNER
@ -317,14 +419,28 @@ clean:
-$(RM) ../generic/*.o
-$(RM) ../generic/*.bak
-$(RM) ../html/*.o
-$(RM) ../png/*.o
-$(RM) ../png/*.bak
-$(RM) ../zlib/*.o
-$(RM) ../zlib/*.bak
-$(RM) ../png/*.o
-$(RM) ../png/*.bak
-$(RM) ../jpeg/*.o
-$(RM) ../jpeg/*.bak
-$(RM) ../xpm/*.o
-$(RM) ../xpm/*.bak
-$(RM) ../../lib/libwx.a
-$(RM) ../tiff/*.o
-$(RM) ../tiff/*.bak
-$(RM) $(WXLIB)
ifdef WXMAKINGDLL
-$(RM) $(WXDLL)
-$(RM) $(WXDEF)
ifneq "$(strip $(LD_SUPPORTS_SHARED))" "yes"
-$(RM) wx.base
-$(RM) wx.exp
endif
endif
cleanall: clean