]> git.saurik.com Git - wxWidgets.git/blame_incremental - src/makevc.env
Made wxFileDialog PDA friendlier.
[wxWidgets.git] / src / makevc.env
... / ...
CommitLineData
1#
2# File: makevc.env
3# Author: Ulrich Leodolter
4# Created: Wed May 17 08:36:42 1995
5# Updated:
6#
7# MSVC++ 32-bit makefile include file
8#
9!include <ntwin32.mak>
10
11!if "$(RM)" == ""
12RM= erase
13!endif
14
15WXVERSION=233
16WIN95=1
17
18!if "$(WIN95)" == "0"
19# With 3.50, Win95 will use your existing icons to show smaller ones.
20# With 4.0, you'll have to follow Win95 procedures for icons or you'll get the
21# default Windows icon.
22APPVER=3.50
23WINVERSION=-DWINVER=0x0350 # Generic WIN32
24!else
25APPVER=3.50 # 4.0
26# This means 'enable Windows 95 features' (in wxWindows and in VC++ 4.0).
27WINVERSION=-DWINVER=0x0400 /D__WIN95__
28!endif
29
30# On Alpha machines, change to CPU=ALPHA
31CPU=i386
32
33# Suffixes
34OBJSUFF=obj
35SRCSUFF=cpp
36
37WAITFLAG=/w
38
39# If you set wxUSE_IOSTREAMH to 0, remove -Dtry=__try -Dexcept=__except -Dleave=__leave -Dfinally=__finally
40#WINFLAGS=-c -W3 -DCRTAPI1=_cdecl -DCRTAPI2=_cdecl -nologo -D_X86_=1 -DWIN32 -D__WIN32__ $(WINVERSION) -DSTRICT
41WINFLAGS=-c -W3 -nologo -DWIN32 -D__WIN32__ -D_WINDOWS $(WINVERSION) -DSTRICT
42WINLINKFLAGS=/INCREMENTAL:NO /NOLOGO -machine:$(CPU) -subsystem:windows,$(APPVER)
43BASELINKFLAGS=/INCREMENTAL:NO /NOLOGO -machine:$(CPU) -subsystem:console,$(APPVER)
44WINLIBS=kernel32.lib user32.lib gdi32.lib comdlg32.lib winspool.lib winmm.lib shell32.lib oldnames.lib\
45 comctl32.lib ctl3d32.lib odbc32.lib ole32.lib oleaut32.lib uuid.lib rpcrt4.lib advapi32.lib wsock32.lib # libci.lib # libci.lib required for VC++ 4.2
46
47# Set a WXWIN environment variable be the path to your WXWIN directory
48WXDIR=$(WXWIN)
49
50WXSRC=$(WXDIR)\src\msw
51WXINC=$(WXDIR)\include
52WXBASESRC=$(WXDIR)\src\common
53
54#####################################################################
55# These are the possible DLL/non-DLL usages:
56#
57# Type _DLL/_WINDLL WXUSINGDLL WXMAKINGDLL Library
58#--------------------------------------------------------------------
59# Normal application - - - wx.lib
60#
61# wxWin as DLL Defined - Defined wx$(WXVERSION).lib
62#
63# App using wxWin DLL - Defined - wx$(WXVERSION).lib
64#
65# App built as one DLL Defined - - wx.lib
66#
67######################################################################
68#
69# Compiling your app:
70#--------------------
71# when compiling an app to use the DLL version of wxWindows
72# (but not to be a DLL itself), set WXUSINGDLL to 1 in your
73# makefile just before including ntwxwin.mak.
74# To compile wxWin _and_ app itself as a DLL, set DLL to 1
75# in ntwxwin.mak, and do not set WXUSINGDLL.
76#
77# Compiling wxWindows:
78#---------------------
79# Use the dll target to compile wxWindows as DLL; then make 'pch'
80# to generate a precompiled header for your apps to use. BUG: must compile without
81# wxExpr (USE_WX_RESOURCES = 0) for this to link properly. Don't know why yet.
82# Use the dllapp target to compile wxWindows for making a DLL app (not implemented yet)
83
84#DLL=0
85
86!if "$(WXUSINGDLL)" == "1"
87EXTRADLLFLAGS=/DWXUSINGDLL=1
88!endif
89
90!if "$(WXMAKINGDLL)" == "1"
91EXTRADLLFLAGS=/DWXMAKINGDLL=1
92!endif
93
94!if "$(WXMAKINGDLL)" == "0" && "$(DLL)" == "1"
95EXTRADLLFLAGS=
96!endif
97
98!if "$(NOMAIN)" == "1"
99EXTRADLLFLAGS=$(EXTRADLLFLAGS) /DNOMAIN
100!endif
101
102!ifndef UNICODE
103UNICODE=0
104!endif
105
106!ifndef MSLU
107MSLU=0
108!endif
109
110!ifndef FINAL
111FINAL=0
112DEBUG=1
113!endif
114
115!ifndef DLL
116DLL=0
117!endif
118
119# Set this to 1 if you don't want to use precompiled headers
120!ifndef NOPCH
121NOPCH=0
122!endif
123
124# This sets 'D' to a suitable directory name
125# for this kind of build, and WXLIBNAME to one of wx (static release), wxd (static debug),
126# wx$(WXVERSION) (DLL release), wx$(WXVERSION)d (DLL debug)
127
128!if "$(WXMAKINGDLL)" == "1" || "$(WXUSINGDLL)" == "1"
129WXLIBNAME=wxmsw$(WXVERSION)
130!else
131WXLIBNAME=wxmsw
132!endif
133
134!if "$(NEW_WXLIBNAME)" != ""
135WXLIBNAME=$(NEW_WXLIBNAME)
136!endif
137
138!if "$(UNICODE)" == "1"
139UNIEXT=u
140WXLIBNAME=$(WXLIBNAME)$(UNIEXT)
141!endif
142
143!if "$(FINAL)" == "1"
144D=Release
145!else if "$(FINAL)" == "hybrid"
146D=Hybrid
147LIBEXT=h
148WXLIBNAME=$(WXLIBNAME)$(LIBEXT)
149!else
150guilibsdll= oldnames.lib kernel32.lib \
151 ws2_32.lib mswsock.lib advapi32.lib user32.lib \
152 gdi32.lib comdlg32.lib winspool.lib
153D=Debug
154LIBEXT=d
155WXLIBNAME=$(WXLIBNAME)$(LIBEXT)
156!endif
157
158!if "$(wxUSE_GUI)" == "0"
159WXLIBNAME=wxBase
160D=Base$(D)
161WXLIBNAME=$(WXLIBNAME)$(UNIEXT)$(LIBEXT)
162!endif
163
164!if "$(UNICODE)" == "1"
165D=$(D)Unicode
166!endif
167
168INCEXT=$(UNIEXT)$(LIBEXT)
169
170!if "$(WXMAKINGDLL)" == "1" || "$(WXUSINGDLL)" == "1"
171D=$(D)DLL
172INCEXT=dll$(INCEXT)
173!endif
174
175#----------------------------------------------------------------------
176# MSLU == Microsoft Layer for Unicode
177# See MSDN or the Platform SDK docs for details
178!if "$(MSLU)" == "1"
179MSLU_FLAGS=/nod:kernel32.lib /nod:advapi32.lib /nod:user32.lib /nod:gdi32.lib /nod:shell32.lib /nod:comdlg32.lib /nod:version.lib /nod:mpr.lib /nod:rasapi32.lib /nod:winmm.lib /nod:winspool.lib /nod:vfw32.lib /nod:secur32.lib /nod:oleacc.lib /nod:oledlg.lib /nod:sensapi.lib
180MSLU_LIBS=$(MSLU_FLAGS) unicows.lib
181!endif
182
183WXLIB=$(WXDIR)\lib\$(WXLIBNAME).lib
184
185!if "$(wxUSE_GUI)" == "0"
186INCTEMP=$(EXTRAINC) -I$(WXDIR)/lib/base$(INCEXT)
187!else
188INCTEMP=$(EXTRAINC) -I$(WXDIR)/lib/msw$(INCEXT)
189!endif
190
191INC=$(INCTEMP) -I$(WXINC) -I$(WXDIR)/contrib/include -I$(WXDIR)/src/regex -I$(WXDIR)/src/png -I$(WXDIR)/src/zlib -I$(WXDIR)/src/jpeg -I$(WXDIR)/src/tiff
192
193!if "$(WXUSINGDLL)" == "1" || "$(wxUSE_GUI)" == "0"
194LIBS = $(MSLU_LIBS) $(EXTRALIBS) $(WXLIB) $(WINLIBS) $(WXDIR)\lib\regex$(LIBEXT).lib $(WXDIR)\lib\zlib$(LIBEXT).lib
195!else
196LIBS = $(MSLU_LIBS) $(EXTRALIBS) $(WXLIB) $(WINLIBS) $(WXDIR)\lib\regex$(LIBEXT).lib $(WXDIR)\lib\png$(LIBEXT).lib $(WXDIR)\lib\zlib$(LIBEXT).lib $(WXDIR)\lib\jpeg$(LIBEXT).lib $(WXDIR)\lib\tiff$(LIBEXT).lib
197!endif
198
199MAKEPRECOMP=/YcWX/WXPREC.H
200OPTIONS=
201
202!if "$(FINAL)" == "0"
203OPT = /Od /Gy
204# ***N.B.*** to save space/time, comment out /FR to avoid browse info (.sbr files) being generated
205DEBUG_FLAGS= /Zi /D__WXDEBUG__ # /DDEBUG=1 # /FR
206LINK_DEBUG_FLAGS=-debug:full -debugtype:cv # /PDB:NONE
207_CRTFLAG=/MDd
208
209!else if "$(FINAL)" == "hybrid"
210OPT = /Od /Gy
211DEBUG_FLAGS= /Zi /D__WXDEBUG__ /D__NO_VC_CRTDBG__
212LINK_DEBUG_FLAGS=-debug:full -debugtype:cv
213_CRTFLAG=/MD
214
215!else
216# /O1 - smallest code
217# /O2 - fastest code
218OPT = /O1 # /O2 # /Od
219DEBUG_FLAGS=
220LINK_DEBUG_FLAGS=/RELEASE
221_CRTFLAG=/MD
222!endif
223
224
225!if "$(CRTFLAG)" == ""
226CRTFLAG=$(_CRTFLAG)
227!endif
228
229!if "$(DLL)" == "0"
230
231!if "$(NOPCH)" == "1"
232PCH=
233PRECOMP=
234MAKEPRECOMP=
235!else
236
237!if "$(wxUSE_GUI)" == "0"
238PCH=wxBase.pch
239!else
240PCH=wxWindows.pch
241!endif
242
243PRECOMP=/YuWX/WXPREC.H /Fp$(WXDIR)\$D\$(PCH) /Fd$(WXDIR)\$D\vc60.pdb
244MAKEPRECOMP=/YcWX/WXPREC.H
245!endif
246
247
248
249CPPFLAGS=$(WINFLAGS) $(DEBUG_FLAGS) $(PRECOMP) $(EXTRAFLAGS) /D__WXMSW__ $(INC) $(OPT) $(EXTRADLLFLAGS) $(CRTFLAG) /D__WINDOWS__ /GX- $(OVERRIDEFLAGS)
250# If you don't include wxprec.h, use CPPFLAGS2
251CPPFLAGS2=$(WINFLAGS) $(DEBUG_FLAGS) /D__WXMSW__ $(INC) $(EXTRAFLAGS) $(OPT) $(EXTRADLLFLAGS) $(CRTFLAG) /D__WINDOWS__ /GX- $(OVERRIDEFLAGS)
252!if "$(wxUSE_GUI)" == "0"
253LINKFLAGS=$(LINK_DEBUG_FLAGS) $(BASELINKFLAGS)
254!else
255LINKFLAGS=$(LINK_DEBUG_FLAGS) $(WINLINKFLAGS) -entry:WinMainCRTStartup
256!endif
257DUMMY=dummy
258
259!else
260
261!if "$(WXMAKINGDLL)" == "1"
262PCH=wxWindows.pch
263DUMMY=dummydll
264!else
265PCH=wxWindows.pch
266DUMMY=dummy
267!endif
268
269PRECOMP=/YuWX/WXPREC.H /Fp$(WXDIR)\$D\$(PCH) /Fd$(WXDIR)\lib\$(WXLIBNAME).pdb
270CPPFLAGS=$(WINFLAGS) $(DEBUG_FLAGS) $(PRECOMP) $(EXTRAFLAGS) /D__WXMSW__ $(INC) $(OPT) /D_DLL $(CRTFLAG) $(EXTRADLLFLAGS) /D_WINDOWS /D__WINDOWS__ /D_WINDLL
271CPPFLAGS2=$(WINFLAGS) $(DEBUG_FLAGS) /D__WXMSW__ $(INC) $(EXTRAFLAGS) $(OPT) /D_DLL $(CRTFLAG) $(EXTRADLLFLAGS) /D_WINDOWS /D__WINDOWS__ /D_WINDLL
272LINKFLAGS=$(LINK_DEBUG_FLAGS) -machine:i386 -subsystem:windows,$(APPVER) -dll # -entry:_DllMainCRTStartup$(DLLENTRY)
273!endif
274
275DUMMYOBJ=$(WXDIR)\$D\$(DUMMY).obj
276
277.c.obj:
278 cl @<<
279$(CPPFLAGS2) /Fo$@ /c $<
280<<
281
282.cpp.obj:
283 cl @<<
284$(CPPFLAGS2) /Fo$@ /c $<
285<<
286
287#use CPPFLAGS2 so as not to use precompiled headers
288{}.c{$D}.obj:
289 cl @<<
290$(CPPFLAGS2) /Fo$@ /c $<
291<<
292
293{}.cpp{$D}.obj:
294 cl @<<
295$(CPPFLAGS) /Fo$@ /c /Tp $<
296<<
297