]> git.saurik.com Git - wxWidgets.git/blame - src/makeg95.env
Compile fix for the iPaq. No idea why.
[wxWidgets.git] / src / makeg95.env
CommitLineData
75515c52 1#
2bda0e17
KB
2# makeg95.env
3# Common makefile settings for wxWindows programs
014e19de 4# This file is included by all the other makefiles, thus changes
2bda0e17 5# made here take effect everywhere (except where overriden).
f3ef286f 6# The settings are for GnuWin32-derived compilers, i.e. Cygwin and Mingw32.
2bda0e17 7#
102f951d
GRG
8# Customize this file to match your own settings.
9#
75515c52
GRG
10# CVS_ID: $Id$
11#
f3ef286f 12
74afbadc
JS
13# If using Cygwin beta, set this to 0.
14# If using Mingw32 or Cygwin 1.0 or later, set this to 1.
741f371c 15MINGW32=1
1a7f3062
JS
16
17# Set to the version you have
fe5de1ea
JS
18#MINGW32VERSION=2.95
19MINGW32VERSION=3.0
2bda0e17 20
75515c52 21# If building DLL, the version
9f24e0b5 22WXVERSION=233
b3bd664a
MB
23
24ifndef UNICODE
c448540d
MB
25 UNICODE=0
26endif
27
28ifndef FINAL
29 FINAL=0
30endif
31
32ifndef wxUSE_GUI
33 wxUSE_GUI=1
b3bd664a 34endif
75515c52
GRG
35
36# Say yes if you have a "modern" linker that supports --shared option.
37# Note that you're probably going to wait forever for dlltool/gcc/etc
38# to build the DLL, so you should really use a newer linker that
39# supports --shared.
40LD_SUPPORTS_SHARED=yes
41
102f951d
GRG
42# Set to the appropriate remove command (must support forward slashes)
43# You can get a suitable rm.exe from ports/mingw32/extra.zip on the ftp site.
014e19de 44RM=rm -f
6474416b 45
102f951d 46# Set to the appropriate copy command (must support forward slashes)
a20a10fe
JS
47# You can get a suitable cp.exe from ports/mingw32/extra.zip on the ftp site.
48COPY=cp
01dba85a 49
2bda0e17
KB
50########################## Compiler ##################################
51
52# C++ compiler
f3ef286f
JS
53# Put a comment before --pipe for Cygwin, remove comment for Mingw32 2.95
54
46c0c2dc
MB
55# _GCC295 means GCC is GCC 2.95
56# _GCC3 mans GCC is 3.x or better (can actually just be 3.1 or better
57# for Cygwin/MinGW)
5991550a
MB
58ifneq (,$(findstring 2.95, $(MINGW32VERSION)))
59 _GCC295=1
60endif
61ifneq (,$(findstring 3., $(MINGW32VERSION)))
62 _GCC3=1
63endif
46c0c2dc 64
f3ef286f 65ifeq ($(MINGW32),1)
46c0c2dc 66 ifneq "$(_GCC295)$(_GCC3)" ""
9aacdd48
JS
67 ifeq ($(_GCC3),1)
68 CC = gcc --pipe
69 else
70 CC = gcc --pipe -fvtable-thunks
71 endif
1a7f3062 72 else
741258ea 73 CC = gcc
1a7f3062 74 endif
f3ef286f 75else
741258ea 76 CC = gcc
f3ef286f 77endif
2bda0e17
KB
78
79# C compiler for pure C programs
2bda0e17
KB
80CCC = $(CC)
81
82# Compiler used for LEX generated C
741258ea 83CCLEX=gcc
2bda0e17 84
102f951d
GRG
85# This shouldn't be needed as make is supposed to define this
86# variable itself. Uncomment it if your make complains.
87#MAKE=make
2bda0e17 88
102f951d 89# LEX (currently unused)
8870c26e 90LEX=flex # -t -L
2bda0e17 91
102f951d 92# YACC (currently unused)
2662e49e
RR
93YACC=byacc
94#YACC=bison
2bda0e17 95
57c208c5 96# Settings for Cyginw/Mingw32
102f951d
GRG
97# Some versions of windres cannot cope with the --preprocessor
98# option. Uncomment the RCPREPROCESSOR line below if yours can.
741258ea 99RESCOMP=windres
57c208c5
JS
100RCINPUTSWITCH=-i
101RCOUTPUTSWITCH=-o
102RCINCSWITCH=--include-dir
103RCDEFSWITCH=--define
9f334bea
JS
104# Note that this can cause windres to fail (Win95/98 problem?)
105# but commenting out RCPREPROCESSOR then does the trick.
106#RCPREPROCESSOR=--preprocessor "$(CC) -c -E -xc-header -DRC_INVOKED"
2bda0e17 107
f4bfe7e0
JS
108# Don't make this too long (e.g. by adding contrib/include/wx) because it will
109# truncate the command line
53fdeb16
JS
110# Note: --use-temp-file removed since Mingw32 2.95.2 doesn't recognise it
111RESFLAGS=$(RCPREPROCESSOR) $(RCINCSWITCH) $(WXDIR)/include $(RCEXTRAINC) $(RCDEFSWITCH) __WIN32__ $(RCDEFSWITCH) __WIN95__ $(RCDEFSWITCH) __GNUWIN32__
2bda0e17 112
75515c52 113# Needed to build a DLL if your linker does not support --shared option.
741258ea
MB
114AS = as
115DLLTOOL = dlltool
75515c52 116
2bda0e17
KB
117########################## Compiler flags #############################
118
119# Miscellaneous compiler options
172fde4f 120# GRG: the __MINGW32__ option is not needed anymore
d8c72298 121# add "-DHAVE_W32API_H" if you have w32api >= 0.5
172fde4f 122OPTIONS = -DSTRICT # -D__MINGW32__
2bda0e17 123
a0b9e27f
MB
124# Add "-mthreads" if you want to have threads under mingw32
125COMMON_THREADFLAGS =
126
2bda0e17 127# Debugging information
c448540d
MB
128ifeq ($(FINAL),0)
129 DEBUGFLAGS = -g -D__WXDEBUG__
130endif
2bda0e17 131
2bda0e17
KB
132WIN95=1
133
134ifeq ($(WIN95),0)
135# With 3.50, Win95 will use your existing icons to show smaller ones.
136# With 4.0, you'll have to follow Win95 procedures for icons or you'll get the
137# default Windows icon.
138APPVER=3.50
139WINVERSION=-DWINVER=0x0350 -D__GNUWIN32__ -D__WIN32__ # Generic WIN32
140else
102f951d 141APPVER=4.0 # 3.50
2bda0e17
KB
142# This means 'enable Windows 95 features' (in wxWindows and in VC++ 4.0).
143WINVERSION=-DWINVER=0x0400 -D__WIN95__ -D__GNUWIN32__ -D__WIN32__
144endif
145
146CPU=i386
147
148# Suffixes
149OBJSUFF=o
150SRCSUFF=cpp
151LIBPREFIX=lib
152LIBSUFF=a
153EXESUFF=.exe
154RESSUFF=res
155RSCSUFF=rsc
156
157# Warnings
2bda0e17
KB
158WARN = -Wall
159
c448540d
MB
160# build wxbase/wxMSW
161ifeq ($(wxUSE_GUI),1)
162 TOOLKIT=msw
163 GUI = -D__WXMSW__ -D__WINDOWS__
164else
165 TOOLKIT=base
166 GUI = -D__WXMSW__ -D__WINDOWS__ -DwxUSE_GUI=0
167endif
168
2bda0e17 169
75515c52
GRG
170# According to Guillermo Rodriguez Garcia <guille@iies.es>, the
171# -fno-pcc-struct-return option is needed to make the standard div()
172# function work - otherwise it returns absolutely incorrect results
173# which breaks the wxImage class. This is true at least for
174# mingw32-gcc2.8.1, don't know about others.
c448540d
MB
175ifeq ($(FINAL),1)
176 OPT = -fno-pcc-struct-return -O2 -fno-rtti -fno-exceptions
177else
178 OPT = -fno-pcc-struct-return -fno-rtti -fno-exceptions
179endif
2bda0e17
KB
180
181# Options for ar archiver
182# AROPTIONS = crs # For IRIX and Solaris (both SYSVR4).
741258ea 183AR = ar
2bda0e17 184AROPTIONS = ruv
741258ea 185RANLIB = ranlib
2bda0e17 186
b4fe5125
JS
187# Extra compiler libraries
188COMPLIBS=
2bda0e17
KB
189
190# Compiler or system-specific include paths
48d1144b 191COMPPATHS=
2bda0e17 192
2bda0e17
KB
193########################## Directories ###############################
194
ae090fdb 195OLELIBS=-lole32 -loleaut32 -luuid
c448540d
MB
196BASELIBS=-lstdc++ -lgcc -lodbc32 -lwsock32
197ifeq ($(wxUSE_GUI),1)
198 WINLIBS= $(BASELIBS) \
199 -lwinspool -lwinmm -lshell32 \
200 -lcomctl32 -lctl3d32 -lodbc32 -ladvapi32 \
201 -lodbc32 -lwsock32 -lopengl32 -lglu32 $(OLELIBS) # -loldnames
202else
203 WINLIBS=$(BASELIBS)
204endif
b4fe5125
JS
205
206#WINLIBS=-lstdc++ -lgcc \
207# -lwinspool -lwinmm -lshell32 \
208# -lcomctl32 -lctl3d32 -lodbc32 -ladvapi32 -lwsock32 # -loldnames
2bda0e17
KB
209
210# Shouldn't need to change these...
6a570331
RR
211WXSRC=$(WXDIR)/src/msw
212WXINC=$(WXDIR)/include
213WXBASESRC=$(WXDIR)/src/common
f3ef286f 214
014e19de 215GNUWIN32EXTRA=-I$(WXDIR)/include/wx/msw/gnuwin32
1a7f3062
JS
216
217ifeq ($(MINGW32),1)
75515c52 218 ifneq "$(findstring 2.95, $(MINGW32VERSION))" ""
1a7f3062
JS
219 GNUWIN32EXTRA=
220 endif
221endif
222
f6a35171 223#ifeq ($(MINGW32),1)
9d8c2f41 224#INC = -I$(WXINC) -I$(WXDIR)/contrib/include -I$(WXDIR)/src/png -I$(WXDIR)/src/jpeg -I$(WXDIR)/src/zlib -I$(WXDIR)/src/tiff $(EXTRAINC) $(COMPPATHS)
f6a35171 225#else
c448540d 226INC = -I$(WXDIR)/lib/$(TOOLKIT)$(INCEXT) -I$(WXINC) -I$(WXDIR)/contrib/include -I$(WXDIR)/src/regex -I$(WXDIR)/src/png -I$(WXDIR)/src/jpeg -I$(WXDIR)/src/zlib -I$(WXDIR)/src/tiff $(EXTRAINC) $(COMPPATHS) -I$(WXDIR)/include/wx/msw/gnuwin32
f6a35171 227#endif
f3ef286f 228
6a570331 229RCLFLAGS=-cpp "cpp -lang-c++ -DWIN32 -D_WIN32 -DRCL_INVOKED -I$(WXWIN)/include"
2bda0e17 230
75515c52
GRG
231ifdef WXUSINGDLL
232 # png, jpeg, etc are exported from wx dll, so skip and save on link time.
711df835 233 LIBS = $(EXTRALIBS) $(WXLIB) $(WINLIBS) $(COMPLIBS)
75515c52 234else
08e0d1cc 235 LIBS = $(EXTRALIBS) $(WXLIB) -lregex -lpng -ljpeg -lzlib -ltiff $(WINLIBS) $(COMPLIBS)
75515c52 236endif
2bda0e17
KB
237
238WINFLAGS=-D_X86_=1 -DWIN32 -D_WIN32 $(WINVERSION)
239
240#for windows 95
241XINCLUDE=$(WINFLAGS)
242XLIB=$(LIBS)
243LDLIBS = $(LIBS)
244
245# Directory for object files (don't change)
dbda9e86 246# OBJDIR = objects$(GUISUFFIX)
881eba2c 247OBJDIR = .
2bda0e17 248
c448540d
MB
249ifeq ($(FINAL),1)
250 DEBEXT=
251else
252 DEBEXT=d
253endif
254
b3bd664a
MB
255ifeq ($(UNICODE),1)
256 UNIEXT=u
257else
258 UNIEXT=
259endif
260
261ifeq ($(WXMAKINGDLL)$(WXUSINGDLL),)
c448540d 262 INCEXT=$(UNIEXT)$(DEBEXT)
b3bd664a 263else
c448540d 264 INCEXT=dll$(UNIEXT)$(DEBEXT)
b3bd664a
MB
265endif
266
c448540d
MB
267WXLIB=$(WXDIR)/lib/$(LIBPREFIX)wx$(TOOLKIT)$(UNIEXT)$(DEBEXT).$(LIBSUFF)
268
75515c52
GRG
269ifdef WXMAKINGDLL
270 EXTRADLLFLAGS = -DWXMAKINGDLL=1 -D_DLL=1 -D_WINDLL=1
c448540d 271 WXLIB=$(WXDIR)/lib/$(LIBPREFIX)wx$(TOOLKIT)$(WXVERSION)$(UNIEXT)$(DEBEXT).$(LIBSUFF)
75515c52
GRG
272endif
273
274ifdef WXUSINGDLL
275 EXTRADLLFLAGS = -DWXUSINGDLL=1
c448540d 276 WXLIB=$(WXDIR)/lib/$(LIBPREFIX)wx$(TOOLKIT)$(WXVERSION)$(UNIEXT)$(DEBEXT).$(LIBSUFF)
75515c52
GRG
277endif
278
279
2bda0e17 280# You shouldn't need to change these...
a0b9e27f
MB
281CPPFLAGS = $(XINCLUDE) $(INC) $(COMMON_THREADFLAGS) $(OPTIONS) $(GUI) $(DEBUGFLAGS) $(WARN) $(OPT) $(EXTRACPPFLAGS) $(EXTRADLLFLAGS)
282CFLAGS = $(XINCLUDE) $(INC) $(COMMON_THREADFLAGS) $(OPTIONS) $(GUI) $(DEBUGFLAGS) $(WARN) $(OPT) $(EXTRACFLAGS) -DWIN32_LEAN_AND_MEAN
c448540d
MB
283ifeq ($(wxUSE_GUI),1)
284 WINDOWSLDFLAGS=-Wl,--subsystem,windows -mwindows
285endif
a0b9e27f 286LDFLAGS = $(WINDOWSLDFLAGS) $(COMMON_THREADFLAGS) -L$(WXDIR)/lib -L$(WXDIR)/contrib/lib $(EXTRALDFLAGS)
2bda0e17 287
e828e4f7 288.SUFFIXES: .rc .$(RESSUFF) .$(RSCSUFF) .cpp .cxx .c
2bda0e17
KB
289
290.c.o:
72c0d7d7 291 $(CC) -c $(CFLAGS) -o $@ $*.c
2bda0e17 292
e828e4f7
GRG
293.cxx.o:
294 $(CC) -c $(CPPFLAGS) -o $@ $*.cxx
295
9b97ee33
GRG
296.$(SRCSUFF).$(OBJSUFF):
297 $(CC) -c $(CPPFLAGS) -o $@ $*.$(SRCSUFF)
298
2bda0e17 299
e828e4f7 300