1 # makefile.vc -- -*- Makefile -*-
3 # Microsoft Visual C++ makefile for use with nmake.exe v1.62+ (VC++ 5.0+)
5 # This makefile is based upon the Tcl 8.4 Makefile.vc and modified to
6 # make it suitable as a general package makefile. Look for the word EDIT
7 # which marks sections that may need modification. As a minumum you will
8 # need to change the PROJECT, DOTVERSION and DLLOBJS variables to values
9 # relevant to your package.
11 # See the file "license.terms" for information on usage and redistribution
12 # of this file, and for a DISCLAIMER OF ALL WARRANTIES.
14 # Copyright (c) 1995-1996 Sun Microsystems, Inc.
15 # Copyright (c) 1998-2000 Ajuba Solutions.
16 # Copyright (c) 2001 ActiveState Corporation.
17 # Copyright (c) 2001-2002 David Gravereaux.
18 # Copyright (c) 2003 Pat Thoyts
20 #-------------------------------------------------------------------------
21 # RCS: @(#)$Id: makefile.vc,v 1.4 2004/07/26 08:22:05 patthoyts Exp $
22 #-------------------------------------------------------------------------
24 !if !defined(MSDEVDIR) && !defined(MSVCDIR) && !defined(VCINSTALLDIR) && !defined(MSSDK) && !defined(WINDOWSSDKDIR)
26 You will need to run vcvars32.bat from Developer Studio, first, to setup^
27 the environment. Jump to this line to read the new instructions.
31 #------------------------------------------------------------------------------
32 # HOW TO USE this makefile:
34 # 1) It is now necessary to have %MSVCDir% set in the environment. This is
35 # used as a check to see if vcvars32.bat had been run prior to running
36 # nmake or during the installation of Microsoft Visual C++, MSVCDir had
37 # been set globally and the PATH adjusted. Either way is valid.
39 # You'll need to run vcvars32.bat contained in the MsDev's vc(98)/bin
40 # directory to setup the proper environment, if needed, for your current
41 # setup. This is a needed bootstrap requirement and allows the swapping of
42 # different environments to be easier.
44 # 2) To use the Platform SDK (not expressly needed), run setenv.bat after
45 # vcvars32.bat according to the instructions for it. This can also turn on
46 # the 64-bit compiler, if your SDK has it.
49 # all -- Builds everything.
50 # <project> -- Builds the project (eg: nmake sample)
51 # test -- Builds and runs the test suite.
52 # install -- Installs the built binaries and libraries to $(INSTALLDIR)
53 # in an appropriate subdirectory.
54 # clean/realclean/distclean -- varying levels of cleaning.
56 # 4) Macros usable on the commandline:
58 # Sets where to install Tcl from the built binaries.
59 # C:\Progra~1\Tcl is assumed when not specified.
61 # OPTS=static,msvcrt,staticpkg,threads,symbols,profile,loimpact,none
62 # Sets special options for the core. The default is for none.
63 # Any combination of the above may be used (comma separated).
64 # 'none' will over-ride everything to nothing.
66 # static = Builds a static library of the core instead of a
67 # dll. The shell will be static (and large), as well.
68 # msvcrt = Effects the static option only to switch it from
69 # using libcmt(d) as the C runtime [by default] to
70 # msvcrt(d). This is useful for static embedding
72 # staticpkg = Effects the static option only to switch
73 # tclshXX.exe to have the dde and reg extension linked
75 # threads = Turns on full multithreading support.
76 # thrdalloc = Use the thread allocator (shared global free pool).
77 # symbols = Adds symbols for step debugging.
78 # profile = Adds profiling hooks. Map file is assumed.
79 # loimpact = Adds a flag for how NT treats the heap to keep memory
80 # in use, low. This is said to impact alloc performance.
82 # STATS=memdbg,compdbg,none
83 # Sets optional memory and bytecode compiler debugging code added
84 # to the core. The default is for none. Any combination of the
85 # above may be used (comma separated). 'none' will over-ride
86 # everything to nothing.
88 # memdbg = Enables the debugging memory allocator.
89 # compdbg = Enables byte compilation logging.
91 # MACHINE=(IX86|IA64|ALPHA)
92 # Set the machine type used for the compiler, linker, and
93 # resource compiler. This hook is needed to tell the tools
94 # when alternate platforms are requested. IX86 is the default
99 # Hooks to allow the intermediate and output directories to be
100 # changed. $(OUT_DIR) is assumed to be
101 # $(BINROOT)\(Release|Debug) based on if symbols are requested.
102 # $(TMP_DIR) will de $(OUT_DIR)\<buildtype> by default.
105 # Reads the tests requested to be run from this file.
107 # CFG_ENCODING=encoding
108 # name of encoding for configuration information. Defaults
113 # Basic syntax of calling nmake looks like this:
114 # nmake [-nologo] -f makefile.vc [target|macrodef [target|macrodef] [...]]
116 # Standard (no frills)
117 # c:\tcl_src\win\>c:\progra~1\micros~1\vc98\bin\vcvars32.bat
118 # Setting environment for using Microsoft Visual C++ tools.
119 # c:\tcl_src\win\>nmake -f makefile.vc all
120 # c:\tcl_src\win\>nmake -f makefile.vc install INSTALLDIR=c:\progra~1\tcl
123 # c:\tcl_src\win\>c:\progra~1\micros~1\vc98\bin\vcvars32.bat
124 # Setting environment for using Microsoft Visual C++ tools.
125 # c:\tcl_src\win\>c:\progra~1\platfo~1\setenv.bat /pre64 /RETAIL
126 # Targeting Windows pre64 RETAIL
127 # c:\tcl_src\win\>nmake -f makefile.vc MACHINE=IA64
129 #------------------------------------------------------------------------------
130 #==============================================================================
131 ###############################################################################
132 #------------------------------------------------------------------------------
134 !if !exist("makefile.vc")
136 You must run this makefile only from the directory it is in.^
137 Please `cd` to its location first.
141 #-------------------------------------------------------------------------
142 # Project specific information (EDIT)
144 # You should edit this with the name and version of your project. This
145 # information is used to generate the name of the package library and
146 # it's install location.
148 # For example, the sample extension is going to build sample04.dll and
149 # would install it into $(INSTALLDIR)\lib\sample04
151 # You need to specify the object files that need to be linked into your
154 #-------------------------------------------------------------------------
159 # nmakehelp -V <file> <tag> will search the file for tag, skips until a
160 # number and returns all character until a character not in [0-9.ab]
163 !if [echo REM = This file is generated from Makefile.vc > versions.vc]
165 # get project version from row "AC_INIT([sqlite], [3.x.y])"
166 !if [echo DOTVERSION = \>> versions.vc] \
167 && [nmakehlp -V ..\configure.ac AC_INIT >> versions.vc]
169 !include "versions.vc"
171 VERSION = $(DOTVERSION:.=)
172 STUBPREFIX = $(PROJECT)stub
174 #-------------------------------------------------------------------------
175 # Target names and paths ( shouldn't need changing )
176 #-------------------------------------------------------------------------
181 PRJIMPLIB = $(OUT_DIR)\$(PROJECT)$(VERSION)$(SUFX).lib
182 PRJLIBNAME = $(PROJECT).$(EXT)
183 PRJLIB = $(OUT_DIR)\$(PRJLIBNAME)
185 PRJSTUBLIBNAME = $(STUBPREFIX)$(VERSION).lib
186 PRJSTUBLIB = $(OUT_DIR)\$(PRJSTUBLIBNAME)
188 ### Make sure we use backslash only.
189 PRJ_INSTALL_DIR = $(_INSTALLDIR)\$(PROJECT)$(DOTVERSION)
190 LIB_INSTALL_DIR = $(PRJ_INSTALL_DIR)
191 BIN_INSTALL_DIR = $(PRJ_INSTALL_DIR)
192 DOC_INSTALL_DIR = $(PRJ_INSTALL_DIR)
193 SCRIPT_INSTALL_DIR = $(PRJ_INSTALL_DIR)
194 INCLUDE_INSTALL_DIR = $(_TCLDIR)\include
196 ### The following paths CANNOT have spaces in them.
197 GENERICDIR = $(ROOT)\generic
199 LIBDIR = $(ROOT)\library
201 TOOLSDIR = $(ROOT)\tools
202 COMPATDIR = $(ROOT)\compat
204 ### Figure out where the primary source code file(s) is/are.
205 !if exist("$(ROOT)\..\..\sqlite3.c") && exist("$(ROOT)\..\..\src\tclsqlite.c")
206 SQL_INCLUDES = -I"$(ROOT)\..\.."
207 SQLITE_SRCDIR = $(ROOT)\..\..
208 TCLSQLITE_SRCDIR = $(ROOT)\..\..\src
209 DLLOBJS = $(TMP_DIR)\sqlite3.obj $(TMP_DIR)\tclsqlite.obj
211 TCLSQLITE_SRCDIR = $(ROOT)\generic
212 DLLOBJS = $(TMP_DIR)\tclsqlite3.obj
215 #---------------------------------------------------------------------
217 #---------------------------------------------------------------------
221 ### This cranks the optimization level to maximize speed
226 !else if "$(MACHINE)" == "IA64"
227 ### Warnings are too many, can't support warnings into errors.
230 cdebug = -Z7 -WX -Od -GZ
233 ### Declarations common to all compiler options
234 cflags = -nologo -c -W3 -D_CRT_SECURE_NO_WARNINGS -YX -Fp$(TMP_DIR)^\
250 INCLUDES = $(SQL_INCLUDES) $(TCL_INCLUDES) -I"$(WINDIR)" \
251 -I"$(GENERICDIR)" -I"$(ROOT)\.."
252 BASE_CLFAGS = $(cflags) $(cdebug) $(crt) $(INCLUDES) \
253 -DSQLITE_3_SUFFIX_ONLY=1 -DSQLITE_ENABLE_RTREE=1 \
254 -DSQLITE_ENABLE_FTS3=1 -DSQLITE_OMIT_DEPRECATED=1 \
255 -DSQLITE_ENABLE_FTS4=1 \
256 -DSQLITE_ENABLE_FTS5=1 \
257 -DSQLITE_3_SUFFIX_ONLY=1 \
258 -DSQLITE_ENABLE_RTREE=1 \
259 -DSQLITE_ENABLE_GEOPOLY=1 \
260 -DSQLITE_ENABLE_MATH_FUNCTIONS=1 \
261 -DSQLITE_ENABLE_DESERIALIZE=1 \
262 -DSQLITE_ENABLE_DBPAGE_VTAB=1 \
263 -DSQLITE_ENABLE_BYTECODE_VTAB=1 \
264 -DSQLITE_ENABLE_DBSTAT_VTAB=1
266 CON_CFLAGS = $(cflags) $(cdebug) $(crt) -DCONSOLE -DSQLITE_ENABLE_FTS3=1
267 TCL_CFLAGS = -DBUILD_sqlite -DUSE_TCL_STUBS \
268 -DPACKAGE_VERSION="\"$(DOTVERSION)\"" $(BASE_CLFAGS) \
271 #---------------------------------------------------------------------
273 #---------------------------------------------------------------------
276 ldebug = -debug:full -debugtype:cv
278 ldebug = -release -opt:ref -opt:icf,3
281 ### Declarations common to all linker options
282 lflags = -nologo -machine:$(MACHINE) $(ldebug)
285 lflags = $(lflags) -profile
288 !if $(ALIGN98_HACK) && !$(STATIC_BUILD)
289 ### Align sections for PE size savings.
290 lflags = $(lflags) -opt:nowin98
291 !else if !$(ALIGN98_HACK) && $(STATIC_BUILD)
292 ### Align sections for speed in loading by choosing the virtual page size.
293 lflags = $(lflags) -align:4096
297 lflags = $(lflags) -ws:aggressive
300 dlllflags = $(lflags) -dll
301 conlflags = $(lflags) -subsystem:console
302 guilflags = $(lflags) -subsystem:windows
303 baselibs = $(TCLSTUBLIB)
305 #---------------------------------------------------------------------
307 #---------------------------------------------------------------------
309 !IF "$(TESTPAT)" != ""
310 TESTFLAGS = $(TESTFLAGS) -file $(TESTPAT)
313 #---------------------------------------------------------------------
314 # Project specific targets (EDIT)
315 #---------------------------------------------------------------------
317 all: setup $(PROJECT)
318 $(PROJECT): setup $(PRJLIB)
319 install: install-binaries install-libraries install-docs
321 # Tests need to ensure we load the right dll file we
322 # have to handle the output differently on Win9x.
324 !if "$(OS)" == "Windows_NT" || "$(MSVCDIR)" == "IDE"
325 test: setup $(PROJECT)
326 set TCL_LIBRARY=$(ROOT)/library
330 set argv "$(TESTFLAGS)"
334 test: setup $(PROJECT)
335 echo Please wait while the test results are collected
336 set TCL_LIBRARY=$(ROOT)/library
337 $(TCLSH) << >tests.log
340 set argv "$(TESTFLAGS)"
343 type tests.log | more
347 @if not exist $(OUT_DIR)\nul mkdir $(OUT_DIR)
348 @if not exist $(TMP_DIR)\nul mkdir $(TMP_DIR)
350 $(PRJLIB): $(DLLOBJS)
351 $(link32) $(dlllflags) -out:$@ $(baselibs) @<<
356 $(PRJSTUBLIB): $(PRJSTUBOBJS)
357 $(lib32) -nologo -out:$@ $(PRJSTUBOBJS)
359 #---------------------------------------------------------------------
361 #---------------------------------------------------------------------
363 $(TMP_DIR)\sqlite3.obj: $(SQLITE_SRCDIR)\sqlite3.c
364 $(cc32) $(TCL_CFLAGS) -DBUILD_$(PROJECT) -Fo$(TMP_DIR)\ \
365 -c $(SQLITE_SRCDIR)\sqlite3.c
367 $(TMP_DIR)\tclsqlite.obj: $(TCLSQLITE_SRCDIR)\tclsqlite.c
368 $(cc32) $(TCL_CFLAGS) -DBUILD_$(PROJECT) -Fo$(TMP_DIR)\ \
369 -c $(TCLSQLITE_SRCDIR)\tclsqlite.c
371 $(TMP_DIR)\tclsqlite3.obj: $(TCLSQLITE_SRCDIR)\tclsqlite3.c
372 $(cc32) $(TCL_CFLAGS) -DBUILD_$(PROJECT) -Fo$(TMP_DIR)\ \
373 -c $(TCLSQLITE_SRCDIR)\tclsqlite3.c
375 {$(WINDIR)}.rc{$(TMP_DIR)}.res:
376 $(rc32) -fo $@ -r -i "$(GENERICDIR)" -D__WIN32__ \
391 #---------------------------------------------------------------------
392 # Installation. (EDIT)
394 # You may need to modify this section to reflect the final distribution
395 # of your files and possibly to generate documentation.
397 #---------------------------------------------------------------------
400 @echo Installing binaries to '$(SCRIPT_INSTALL_DIR)'
401 @if not exist "$(SCRIPT_INSTALL_DIR)" mkdir "$(SCRIPT_INSTALL_DIR)"
402 @$(CPY) $(PRJLIB) "$(SCRIPT_INSTALL_DIR)" >NUL
405 @echo Installing libraries to '$(SCRIPT_INSTALL_DIR)'
406 @if exist $(LIBDIR) $(CPY) $(LIBDIR)\*.tcl "$(SCRIPT_INSTALL_DIR)"
407 @echo Installing package index in '$(SCRIPT_INSTALL_DIR)'
408 @type << >"$(SCRIPT_INSTALL_DIR)\pkgIndex.tcl"
409 package ifneeded $(PROJECT) $(DOTVERSION) \
410 [list load [file join $$dir $(PRJLIBNAME)] sqlite3]
414 @echo Installing documentation files to '$(DOC_INSTALL_DIR)'
415 @if exist $(DOCDIR) $(CPY) $(DOCDIR)\*.n "$(DOC_INSTALL_DIR)"
417 #---------------------------------------------------------------------
419 #---------------------------------------------------------------------
422 @if exist $(TMP_DIR)\nul $(RMDIR) $(TMP_DIR)
423 @if exist $(WINDIR)\version.vc del $(WINDIR)\version.vc
426 @if exist $(OUT_DIR)\nul $(RMDIR) $(OUT_DIR)
429 @if exist $(WINDIR)\nmakehlp.exe del $(WINDIR)\nmakehlp.exe
430 @if exist $(WINDIR)\nmakehlp.obj del $(WINDIR)\nmakehlp.obj