X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/df801fc6d47a2915768ba386d4b406249e2f56a9..3352cfffbcaa61094ddadc2811c8186ae31c2960:/src/makevc.env diff --git a/src/makevc.env b/src/makevc.env index 03945f4db1..78ed7bb272 100644 --- a/src/makevc.env +++ b/src/makevc.env @@ -8,7 +8,15 @@ # !include -WXVERSION=22_0 +# read version numbers +!include "version.mak" +WXVERSION=$(wxMAJOR_VERSION)$(wxMINOR_VERSION)$(wxRELEASE_NUMBER_IFUNSTABLE) + +!if "$(RM)" == "" +RM= erase +!endif + +# WIN95 means "all systems newer than Win95", i.e. Win9x and NT 4+ WIN95=1 !if "$(WIN95)" == "0" @@ -18,7 +26,7 @@ WIN95=1 APPVER=3.50 WINVERSION=-DWINVER=0x0350 # Generic WIN32 !else -APPVER=3.50 # 4.0 +APPVER=4.0 # This means 'enable Windows 95 features' (in wxWindows and in VC++ 4.0). WINVERSION=-DWINVER=0x0400 /D__WIN95__ !endif @@ -33,11 +41,12 @@ SRCSUFF=cpp WAITFLAG=/w # If you set wxUSE_IOSTREAMH to 0, remove -Dtry=__try -Dexcept=__except -Dleave=__leave -Dfinally=__finally -#WINFLAGS=-c -W3 -DCRTAPI1=_cdecl -DCRTAPI2=_cdecl -nologo -D_X86_=1 -DWIN32 -D__WIN32__ $(WINVERSION) -WINFLAGS=-c -W3 -nologo -DWIN32 -D__WIN32__ -D_WINDOWS $(WINVERSION) +#WINFLAGS=-c -W3 -DCRTAPI1=_cdecl -DCRTAPI2=_cdecl -nologo -D_X86_=1 -DWIN32 -D__WIN32__ $(WINVERSION) -DSTRICT +WINFLAGS=-c -W3 -nologo -DWIN32 -D__WIN32__ -D_WINDOWS $(WINVERSION) -DSTRICT WINLINKFLAGS=/INCREMENTAL:NO /NOLOGO -machine:$(CPU) -subsystem:windows,$(APPVER) +BASELINKFLAGS=/INCREMENTAL:NO /NOLOGO -machine:$(CPU) -subsystem:console,$(APPVER) WINLIBS=kernel32.lib user32.lib gdi32.lib comdlg32.lib winspool.lib winmm.lib shell32.lib oldnames.lib\ - 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 + comctl32.lib odbc32.lib ole32.lib oleaut32.lib uuid.lib rpcrt4.lib advapi32.lib wsock32.lib # libci.lib # libci.lib required for VC++ 4.2 # Set a WXWIN environment variable be the path to your WXWIN directory WXDIR=$(WXWIN) @@ -94,6 +103,14 @@ EXTRADLLFLAGS= EXTRADLLFLAGS=$(EXTRADLLFLAGS) /DNOMAIN !endif +!ifndef UNICODE +UNICODE=0 +!endif + +!ifndef MSLU +MSLU=0 +!endif + !ifndef FINAL FINAL=0 DEBUG=1 @@ -113,17 +130,26 @@ NOPCH=0 # wx$(WXVERSION) (DLL release), wx$(WXVERSION)d (DLL debug) !if "$(WXMAKINGDLL)" == "1" || "$(WXUSINGDLL)" == "1" -WXLIBNAME=wx$(WXVERSION) +WXLIBNAME=wxmsw$(WXVERSION) !else -WXLIBNAME=wx +WXLIBNAME=wxmsw !endif !if "$(NEW_WXLIBNAME)" != "" WXLIBNAME=$(NEW_WXLIBNAME) !endif +!if "$(UNICODE)" == "1" +UNIEXT=u +WXLIBNAME=$(WXLIBNAME)$(UNIEXT) +!endif + !if "$(FINAL)" == "1" D=Release +!else if "$(FINAL)" == "hybrid" +D=Hybrid +LIBEXT=h +WXLIBNAME=$(WXLIBNAME)$(LIBEXT) !else guilibsdll= oldnames.lib kernel32.lib \ ws2_32.lib mswsock.lib advapi32.lib user32.lib \ @@ -133,18 +159,45 @@ LIBEXT=d WXLIBNAME=$(WXLIBNAME)$(LIBEXT) !endif +!if "$(wxUSE_GUI)" == "0" +WXLIBNAME=wxBase +D=Base$(D) +WXLIBNAME=$(WXLIBNAME)$(UNIEXT)$(LIBEXT) +!endif + +!if "$(UNICODE)" == "1" +D=$(D)Unicode +!endif + +INCEXT=$(UNIEXT)$(LIBEXT) + !if "$(WXMAKINGDLL)" == "1" || "$(WXUSINGDLL)" == "1" D=$(D)DLL +INCEXT=dll$(INCEXT) +!endif + +#---------------------------------------------------------------------- +# MSLU == Microsoft Layer for Unicode +# See MSDN or the Platform SDK docs for details +!if "$(MSLU)" == "1" +MSLU_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 +MSLU_LIBS=$(MSLU_FLAGS) unicows.lib !endif WXLIB=$(WXDIR)\lib\$(WXLIBNAME).lib -INC=-I$(WXINC) -I$(WXDIR)/contrib/include -I$(WXDIR)/src/png -I$(WXDIR)/src/zlib -I$(WXDIR)/src/jpeg -I$(WXDIR)/src/tiff $(EXTRAINC) +!if "$(wxUSE_GUI)" == "0" +INCTEMP=$(EXTRAINC) -I$(WXDIR)/lib/base$(INCEXT) +!else +INCTEMP=$(EXTRAINC) -I$(WXDIR)/lib/msw$(INCEXT) +!endif -!if "$(WXUSINGDLL)" == "1" -LIBS = $(EXTRALIBS) $(WXLIB) $(WINLIBS) +INC=$(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 + +!if "$(WXUSINGDLL)" == "1" || "$(wxUSE_GUI)" == "0" +LIBS = $(MSLU_LIBS) $(EXTRALIBS) $(WXLIB) $(WINLIBS) $(WXDIR)\lib\regex$(LIBEXT).lib $(WXDIR)\lib\zlib$(LIBEXT).lib !else -LIBS = $(EXTRALIBS) $(WXLIB) $(WINLIBS) $(WXDIR)\lib\png$(LIBEXT).lib $(WXDIR)\lib\zlib$(LIBEXT).lib $(WXDIR)\lib\jpeg$(LIBEXT).lib $(WXDIR)\lib\tiff$(LIBEXT).lib $(WXDIR)\lib\xpm$(LIBEXT).lib +LIBS = $(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 !endif MAKEPRECOMP=/YcWX/WXPREC.H @@ -156,6 +209,13 @@ OPT = /Od /Gy DEBUG_FLAGS= /Zi /D__WXDEBUG__ # /DDEBUG=1 # /FR LINK_DEBUG_FLAGS=-debug:full -debugtype:cv # /PDB:NONE _CRTFLAG=/MDd + +!else if "$(FINAL)" == "hybrid" +OPT = /Ox /Gy +DEBUG_FLAGS= /D__WXDEBUG__ /D__NO_VC_CRTDBG__ +LINK_DEBUG_FLAGS=/RELEASE +_CRTFLAG=/MD + !else # /O1 - smallest code # /O2 - fastest code @@ -165,6 +225,7 @@ LINK_DEBUG_FLAGS=/RELEASE _CRTFLAG=/MD !endif + !if "$(CRTFLAG)" == "" CRTFLAG=$(_CRTFLAG) !endif @@ -176,34 +237,46 @@ PCH= PRECOMP= MAKEPRECOMP= !else -PCH=wxvc.pch -PRECOMP=/YuWX/WXPREC.H /Fp$(WXDIR)\src\msw\$D\$(PCH) /Fd$(WXDIR)\src\msw\$D\vc60.pdb + +!if "$(wxUSE_GUI)" == "0" +PCH=wxBase.pch +!else +PCH=wxWindows.pch +!endif + +PRECOMP=/YuWX/WXPREC.H /Fp$(WXDIR)\$D\$(PCH) /Fd$(WXDIR)\$D\vc60.pdb MAKEPRECOMP=/YcWX/WXPREC.H !endif -CPPFLAGS=$(WINFLAGS) $(DEBUG_FLAGS) $(PRECOMP) $(EXTRAFLAGS) /D__WXMSW__ $(INC) $(OPT) $(EXTRADLLFLAGS) $(CRTFLAG) /D__WINDOWS__ /GX /DSTRICT $(OVERRIDEFLAGS) + + +CPPFLAGS=$(WINFLAGS) $(DEBUG_FLAGS) $(PRECOMP) $(EXTRAFLAGS) /D__WXMSW__ $(INC) $(OPT) $(EXTRADLLFLAGS) $(CRTFLAG) /D__WINDOWS__ /GX- $(OVERRIDEFLAGS) # If you don't include wxprec.h, use CPPFLAGS2 -CPPFLAGS2=$(WINFLAGS) $(DEBUG_FLAGS) /D__WXMSW__ $(INC) $(EXTRAFLAGS) $(OPT) $(EXTRADLLFLAGS) $(CRTFLAG) /D__WINDOWS__ /GX /DSTRICT $(OVERRIDEFLAGS) +CPPFLAGS2=$(WINFLAGS) $(DEBUG_FLAGS) /D__WXMSW__ $(INC) $(EXTRAFLAGS) $(OPT) $(EXTRADLLFLAGS) $(CRTFLAG) /D__WINDOWS__ /GX- $(OVERRIDEFLAGS) +!if "$(wxUSE_GUI)" == "0" +LINKFLAGS=$(LINK_DEBUG_FLAGS) $(BASELINKFLAGS) +!else LINKFLAGS=$(LINK_DEBUG_FLAGS) $(WINLINKFLAGS) -entry:WinMainCRTStartup +!endif DUMMY=dummy !else !if "$(WXMAKINGDLL)" == "1" -PCH=wxvc.pch +PCH=wxWindows.pch DUMMY=dummydll !else -PCH=wxvc.pch +PCH=wxWindows.pch DUMMY=dummy !endif -PRECOMP=/YuWX/WXPREC.H /Fp$(WXDIR)\src\msw\$D\$(PCH) /Fd$(WXDIR)\lib\$(WXLIBNAME).pdb +PRECOMP=/YuWX/WXPREC.H /Fp$(WXDIR)\$D\$(PCH) /Fd$(WXDIR)\lib\$(WXLIBNAME).pdb CPPFLAGS=$(WINFLAGS) $(DEBUG_FLAGS) $(PRECOMP) $(EXTRAFLAGS) /D__WXMSW__ $(INC) $(OPT) /D_DLL $(CRTFLAG) $(EXTRADLLFLAGS) /D_WINDOWS /D__WINDOWS__ /D_WINDLL CPPFLAGS2=$(WINFLAGS) $(DEBUG_FLAGS) /D__WXMSW__ $(INC) $(EXTRAFLAGS) $(OPT) /D_DLL $(CRTFLAG) $(EXTRADLLFLAGS) /D_WINDOWS /D__WINDOWS__ /D_WINDLL LINKFLAGS=$(LINK_DEBUG_FLAGS) -machine:i386 -subsystem:windows,$(APPVER) -dll # -entry:_DllMainCRTStartup$(DLLENTRY) !endif -DUMMYOBJ=$(WXDIR)\src\msw\$D\$(DUMMY).obj +DUMMYOBJ=$(WXDIR)\$D\$(DUMMY).obj .c.obj: cl @<< @@ -215,11 +288,14 @@ $(CPPFLAGS2) /Fo$@ /c $< $(CPPFLAGS2) /Fo$@ /c $< << +#use CPPFLAGS2 so as not to use precompiled headers +{}.c{$D}.obj: + cl @<< +$(CPPFLAGS2) /Fo$@ /c $< +<< + {}.cpp{$D}.obj: cl @<< $(CPPFLAGS) /Fo$@ /c /Tp $< << -$(D) : - mkdir $(D) -