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