Import Tcl-code 8.6.8
This commit is contained in:
636
win/makefile.vc
636
win/makefile.vc
@@ -1,7 +1,6 @@
|
||||
#-------------------------------------------------------------
|
||||
# makefile.vc --
|
||||
#------------------------------------------------------------- -*- makefile -*-
|
||||
#
|
||||
# Microsoft Visual C++ makefile for use with nmake.exe v1.62+ (VC++ 5.0+)
|
||||
# Microsoft Visual C++ makefile for building Tcl with nmake
|
||||
#
|
||||
# See the file "license.terms" for information on usage and redistribution
|
||||
# of this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||
@@ -11,37 +10,16 @@
|
||||
# Copyright (c) 2001-2005 ActiveState Corporation.
|
||||
# Copyright (c) 2001-2004 David Gravereaux.
|
||||
# Copyright (c) 2003-2008 Pat Thoyts.
|
||||
# Copyright (c) 2017 Ashok P. Nadkarni
|
||||
#------------------------------------------------------------------------------
|
||||
|
||||
# Check to see we are configured to build with MSVC (MSDEVDIR, MSVCDIR or
|
||||
# VCINSTALLDIR) or with the MS Platform SDK (MSSDK or WindowsSDKDir)
|
||||
!if !defined(MSDEVDIR) && !defined(MSVCDIR) && !defined(VCINSTALLDIR) && !defined(MSSDK) && !defined(WINDOWSSDKDIR)
|
||||
MSG = ^
|
||||
You need to run vcvars32.bat from Developer Studio or setenv.bat from the^
|
||||
Platform SDK first to setup the environment. Jump to this line to read^
|
||||
the build instructions.
|
||||
!error $(MSG)
|
||||
!endif
|
||||
|
||||
#------------------------------------------------------------------------------
|
||||
# HOW TO USE this makefile:
|
||||
# General usage:
|
||||
# nmake [-nologo] -f makefile.vc [TARGET|MACRODEF [TARGET|MACRODEF] [...]]
|
||||
#
|
||||
# 1) It is now necessary to have MSVCDir, MSDevDir or MSSDK set in the
|
||||
# environment. This is used as a check to see if vcvars32.bat had been
|
||||
# run prior to running nmake or during the installation of Microsoft
|
||||
# Visual C++, MSVCDir had been set globally and the PATH adjusted.
|
||||
# Either way is valid.
|
||||
# For MACRODEF, see TIP 477 (https://core.tcl.tk/tips/doc/trunk/tip/477.md)
|
||||
# or examine Sections 6-8 in rules.vc.
|
||||
#
|
||||
# You'll need to run vcvars32.bat contained in the MsDev's vc(98)/bin
|
||||
# directory to setup the proper environment, if needed, for your
|
||||
# current setup. This is a needed bootstrap requirement and allows the
|
||||
# swapping of different environments to be easier.
|
||||
#
|
||||
# 2) To use the Platform SDK (not expressly needed), run setenv.bat after
|
||||
# vcvars32.bat according to the instructions for it. This can also
|
||||
# turn on the 64-bit compiler, if your SDK has it.
|
||||
#
|
||||
# 3) Targets are:
|
||||
# Possible values of TARGET are:
|
||||
# release -- Builds the core, the shell and the dlls. (default)
|
||||
# dlls -- Just builds the windows extensions
|
||||
# shell -- Just builds the shell and the core.
|
||||
@@ -61,154 +39,83 @@ the build instructions.
|
||||
# troff manual pages found in $(ROOT)\doc. You need to
|
||||
# have installed the HTML Help Compiler package from Microsoft
|
||||
# to produce the .chm file.
|
||||
# winhelp -- (deprecated) Builds the windows .hlp file for Tcl from
|
||||
# the troff man files found in $(ROOT)\doc. This type of
|
||||
# help file is deprecated by Microsoft in favour of html
|
||||
# help files (.chm)
|
||||
#
|
||||
# 4) Macros usable on the commandline:
|
||||
# INSTALLDIR=<path>
|
||||
# Sets where to install Tcl from the built binaries.
|
||||
# C:\Progra~1\Tcl is assumed when not specified.
|
||||
# The steps to setup a Visual C++ environment depend on which
|
||||
# version of Visual Studio and/or the Windows SDK you are building
|
||||
# against and are not described here. The simplest method is generally
|
||||
# to start a command shell using one of the short cuts installed by
|
||||
# Visual Studio/Windows SDK for the appropriate target architecture.
|
||||
#
|
||||
# OPTS=loimpact,msvcrt,nothreads,pdbs,profile,static,staticpkg,symbols,thrdalloc,tclalloc,unchecked,none
|
||||
# Sets special options for the core. The default is for none.
|
||||
# Any combination of the above may be used (comma separated).
|
||||
# 'none' will over-ride everything to nothing.
|
||||
# NOTE: For older (Visual C++ 6 or the 2003 SDK), to use the Platform
|
||||
# SDK (not expressly needed), run setenv.bat after
|
||||
# vcvars32.bat according to the instructions for it. This can also
|
||||
# turn on the 64-bit compiler, if your SDK has it.
|
||||
#
|
||||
# loimpact = Adds a flag for how NT treats the heap to keep memory
|
||||
# in use, low. This is said to impact alloc performance.
|
||||
# msvcrt = Affects the static option only to switch it from
|
||||
# using libcmt(d) as the C runtime [by default] to
|
||||
# msvcrt(d). This is useful for static embedding
|
||||
# support.
|
||||
# nothreads= Turns off full multithreading support.
|
||||
# pdbs = Build detached symbols for release builds.
|
||||
# profile = Adds profiling hooks. Map file is assumed.
|
||||
# static = Builds a static library of the core instead of a
|
||||
# dll. The static library will contain the dde and reg
|
||||
# extensions. External applications who want to use
|
||||
# this, need to link with the stub library as well as
|
||||
# the static Tcl library.The shell will be static (and
|
||||
# large), as well.
|
||||
# staticpkg = Affects the static option only to switch
|
||||
# tclshXX.exe to have the dde and reg extension linked
|
||||
# inside it.
|
||||
# symbols = Debug build. Links to the debug C runtime, disables
|
||||
# optimizations and creates pdb symbols files.
|
||||
# thrdalloc = Use the thread allocator (shared global free pool)
|
||||
# This is the default on threaded builds.
|
||||
# tclalloc = Use the old non-thread allocator
|
||||
# unchecked= Allows a symbols build to not use the debug
|
||||
# enabled runtime (msvcrt.dll not msvcrtd.dll
|
||||
# or libcmt.lib not libcmtd.lib).
|
||||
#
|
||||
# STATS=compdbg,memdbg,none
|
||||
# Sets optional memory and bytecode compiler debugging code added
|
||||
# to the core. The default is for none. Any combination of the
|
||||
# above may be used (comma separated). 'none' will over-ride
|
||||
# everything to nothing.
|
||||
#
|
||||
# compdbg = Enables byte compilation logging.
|
||||
# memdbg = Enables the debugging memory allocator.
|
||||
#
|
||||
# CHECKS=64bit,fullwarn,nodep,none
|
||||
# Sets special macros for checking compatability.
|
||||
#
|
||||
# 64bit = Enable 64bit portability warnings (if available)
|
||||
# fullwarn = Builds with full compiler and link warnings enabled.
|
||||
# Very verbose.
|
||||
# nodep = Turns off compatability macros to ensure the core
|
||||
# isn't being built with deprecated functions.
|
||||
#
|
||||
# MACHINE=(ALPHA|AMD64|IA64|IX86)
|
||||
# Set the machine type used for the compiler, linker, and
|
||||
# resource compiler. This hook is needed to tell the tools
|
||||
# when alternate platforms are requested. IX86 is the default
|
||||
# when not specified. If the CPU environment variable has been
|
||||
# set (ie: recent Platform SDK) then MACHINE is set from CPU.
|
||||
#
|
||||
# TMP_DIR=<path>
|
||||
# OUT_DIR=<path>
|
||||
# Hooks to allow the intermediate and output directories to be
|
||||
# changed. $(OUT_DIR) is assumed to be
|
||||
# $(BINROOT)\(Release|Debug) based on if symbols are requested.
|
||||
# $(TMP_DIR) will de $(OUT_DIR)\<buildtype> by default.
|
||||
#
|
||||
# TESTPAT=<file>
|
||||
# Reads the tests requested to be run from this file.
|
||||
#
|
||||
# CFG_ENCODING=encoding
|
||||
# name of encoding for configuration information. Defaults
|
||||
# to cp1252
|
||||
#
|
||||
# 5) Examples:
|
||||
#
|
||||
# Basic syntax of calling nmake looks like this:
|
||||
# nmake [-nologo] -f makefile.vc [target|macrodef [target|macrodef] [...]]
|
||||
#
|
||||
# Standard (no frills)
|
||||
# c:\tcl_src\win\>c:\progra~1\micros~1\vc98\bin\vcvars32.bat
|
||||
# Setting environment for using Microsoft Visual C++ tools.
|
||||
# Examples:
|
||||
# c:\tcl_src\win\>nmake -f makefile.vc release
|
||||
# c:\tcl_src\win\>nmake -f makefile.vc test
|
||||
# c:\tcl_src\win\>nmake -f makefile.vc install INSTALLDIR=c:\progra~1\tcl
|
||||
# c:\tcl_src\win\>nmake -f makefile.vc release OPTS=pdbs
|
||||
# c:\tcl_src\win\>nmake -f makefile.vc release OPTS=symbols
|
||||
#
|
||||
# Building for Win64
|
||||
# c:\tcl_src\win\>c:\progra~1\micros~1\vc98\bin\vcvars32.bat
|
||||
# Setting environment for using Microsoft Visual C++ tools.
|
||||
# c:\tcl_src\win\>c:\progra~1\platfo~1\setenv.bat /pre64 /RETAIL
|
||||
# Targeting Windows pre64 RETAIL
|
||||
# c:\tcl_src\win\>nmake -f makefile.vc MACHINE=IA64
|
||||
#
|
||||
#------------------------------------------------------------------------------
|
||||
#==============================================================================
|
||||
###############################################################################
|
||||
|
||||
# NOTE:
|
||||
# Before modifying this file, check whether the modification is applicable
|
||||
# to building extensions as well and if so, modify rules.vc instead.
|
||||
|
||||
# //==================================================================\\
|
||||
# >>[ -> Do not modify below this line. <- ]<<
|
||||
# >>[ Please, use the commandline macros to modify how Tcl is built. ]<<
|
||||
# >>[ If you need more features, send us a patch for more macros. ]<<
|
||||
# \\==================================================================//
|
||||
|
||||
|
||||
###############################################################################
|
||||
#==============================================================================
|
||||
#------------------------------------------------------------------------------
|
||||
|
||||
!if !exist("makefile.vc")
|
||||
MSG = ^
|
||||
You must run this makefile only from the directory it is in.^
|
||||
Please `cd` to its location first.
|
||||
!error $(MSG)
|
||||
!endif
|
||||
|
||||
# The PROJECT macro is used by rules.vc for generating appropriate
|
||||
# macros and rules.
|
||||
PROJECT = tcl
|
||||
|
||||
# Default target to build if no target is specified. If unspecified, the
|
||||
# rules.vc file will set up "all" as the target.
|
||||
DEFAULT_BUILD_TARGET = release
|
||||
|
||||
# We want to use our own resource file, not the standard template one.
|
||||
RCFILE = tcl.rc
|
||||
|
||||
# The rules.vc file does most of the hard work in terms of defining
|
||||
# the build configuration, macros, output directories etc.
|
||||
!include "rules.vc"
|
||||
|
||||
STUBPREFIX = $(PROJECT)stub
|
||||
# Tcl version info based on macros set up by rules.vc
|
||||
DOTVERSION = $(TCL_MAJOR_VERSION).$(TCL_MINOR_VERSION)
|
||||
VERSION = $(TCL_MAJOR_VERSION)$(TCL_MINOR_VERSION)
|
||||
|
||||
# We need versions of various core packages to generate appropriate
|
||||
# file names during installation.
|
||||
!if [echo REM = This file is generated from makefile.vc > versions.vc]
|
||||
!endif
|
||||
!if [echo PKG_HTTP_VER = \>> versions.vc] \
|
||||
&& [nmakehlp -V ..\library\http\pkgIndex.tcl http >> versions.vc]
|
||||
!endif
|
||||
!if [echo PKG_TCLTEST_VER = \>> versions.vc] \
|
||||
&& [nmakehlp -V ..\library\tcltest\pkgIndex.tcl tcltest >> versions.vc]
|
||||
!endif
|
||||
!if [echo PKG_MSGCAT_VER = \>> versions.vc] \
|
||||
&& [nmakehlp -V ..\library\msgcat\pkgIndex.tcl msgcat >> versions.vc]
|
||||
!endif
|
||||
!if [echo PKG_PLATFORM_VER = \>> versions.vc] \
|
||||
&& [nmakehlp -V ..\library\platform\pkgIndex.tcl "platform " >> versions.vc]
|
||||
!endif
|
||||
!if [echo PKG_SHELL_VER = \>> versions.vc] \
|
||||
&& [nmakehlp -V ..\library\platform\pkgIndex.tcl "platform::shell" >> versions.vc]
|
||||
!endif
|
||||
!if [echo PKG_DDE_VER = \>> versions.vc] \
|
||||
&& [nmakehlp -V ..\library\dde\pkgIndex.tcl "dde " >> versions.vc]
|
||||
!endif
|
||||
!if [echo PKG_REG_VER =\>> versions.vc] \
|
||||
&& [nmakehlp -V ..\library\reg\pkgIndex.tcl registry >> versions.vc]
|
||||
!endif
|
||||
|
||||
!include versions.vc
|
||||
|
||||
DDEDOTVERSION = 1.4
|
||||
DDEVERSION = $(DDEDOTVERSION:.=)
|
||||
|
||||
REGDOTVERSION = 1.3
|
||||
REGVERSION = $(REGDOTVERSION:.=)
|
||||
|
||||
BINROOT = $(MAKEDIR) # originally .
|
||||
ROOT = $(MAKEDIR)\.. # originally ..
|
||||
|
||||
TCLIMPLIB = $(OUT_DIR)\$(PROJECT)$(VERSION)$(SUFX).lib
|
||||
TCLLIBNAME = $(PROJECT)$(VERSION)$(SUFX).$(EXT)
|
||||
TCLLIB = $(OUT_DIR)\$(TCLLIBNAME)
|
||||
|
||||
TCLSTUBLIBNAME = $(STUBPREFIX)$(VERSION).lib
|
||||
TCLSTUBLIB = $(OUT_DIR)\$(TCLSTUBLIBNAME)
|
||||
|
||||
TCLSHNAME = $(PROJECT)sh$(VERSION)$(SUFX).exe
|
||||
TCLSH = $(OUT_DIR)\$(TCLSHNAME)
|
||||
|
||||
TCLREGLIBNAME = $(PROJECT)reg$(REGVERSION)$(SUFX:t=).$(EXT)
|
||||
TCLREGLIB = $(OUT_DIR)\$(TCLREGLIBNAME)
|
||||
|
||||
@@ -218,22 +125,6 @@ TCLDDELIB = $(OUT_DIR)\$(TCLDDELIBNAME)
|
||||
TCLTEST = $(OUT_DIR)\$(PROJECT)test.exe
|
||||
CAT32 = $(OUT_DIR)\cat32.exe
|
||||
|
||||
# Can we run what we build? IX86 runs on all architectures.
|
||||
!ifndef TCLSH_NATIVE
|
||||
!if "$(MACHINE)" == "IX86" || "$(MACHINE)" == "$(NATIVE_ARCH)"
|
||||
TCLSH_NATIVE = $(TCLSH)
|
||||
!else
|
||||
!error You must explicitly set TCLSH_NATIVE for cross-compilation
|
||||
!endif
|
||||
!endif
|
||||
|
||||
### Make sure we use backslash only.
|
||||
LIB_INSTALL_DIR = $(_INSTALLDIR)\lib
|
||||
BIN_INSTALL_DIR = $(_INSTALLDIR)\bin
|
||||
DOC_INSTALL_DIR = $(_INSTALLDIR)\doc
|
||||
SCRIPT_INSTALL_DIR = $(_INSTALLDIR)\lib\tcl$(DOTVERSION)
|
||||
INCLUDE_INSTALL_DIR = $(_INSTALLDIR)\include
|
||||
|
||||
TCLSHOBJS = \
|
||||
$(TMP_DIR)\tclAppInit.obj \
|
||||
!if !$(STATIC_BUILD)
|
||||
@@ -454,113 +345,18 @@ TCLSTUBOBJS = \
|
||||
$(TMP_DIR)\tclTomMathStubLib.obj \
|
||||
$(TMP_DIR)\tclOOStubLib.obj
|
||||
|
||||
### The following paths CANNOT have spaces in them.
|
||||
COMPATDIR = $(ROOT)\compat
|
||||
DOCDIR = $(ROOT)\doc
|
||||
GENERICDIR = $(ROOT)\generic
|
||||
### The following paths CANNOT have spaces in them as they appear on
|
||||
### the left side of implicit rules.
|
||||
TOMMATHDIR = $(ROOT)\libtommath
|
||||
TOOLSDIR = $(ROOT)\tools
|
||||
WINDIR = $(ROOT)\win
|
||||
PKGSDIR = $(ROOT)\pkgs
|
||||
|
||||
#---------------------------------------------------------------------
|
||||
# Compile flags
|
||||
#---------------------------------------------------------------------
|
||||
# Additional include and C macro definitions for the implicit rules
|
||||
# defined in rules.vc
|
||||
PRJ_INCLUDES = -I"$(TOMMATHDIR)"
|
||||
PRJ_DEFINES = -DTCL_TOMMATH -DMP_PREC=4 -Dinline=__inline -DHAVE_ZLIB=1 -D_CRT_SECURE_NO_DEPRECATE -D_CRT_NONSTDC_NO_DEPRECATE
|
||||
|
||||
!if !$(DEBUG)
|
||||
!if $(OPTIMIZING)
|
||||
### This cranks the optimization level to maximize speed
|
||||
cdebug = -O2 $(OPTIMIZATIONS)
|
||||
!else
|
||||
cdebug =
|
||||
!endif
|
||||
!if $(SYMBOLS)
|
||||
cdebug = $(cdebug) -Zi
|
||||
!endif
|
||||
!else if "$(MACHINE)" == "IA64" || "$(MACHINE)" == "AMD64"
|
||||
### Warnings are too many, can't support warnings into errors.
|
||||
cdebug = -Zi -Od $(DEBUGFLAGS)
|
||||
!else
|
||||
cdebug = -Zi -WX $(DEBUGFLAGS)
|
||||
!endif
|
||||
|
||||
### Declarations common to all compiler options
|
||||
cwarn = $(WARNINGS) -D _CRT_SECURE_NO_DEPRECATE -D _CRT_NONSTDC_NO_DEPRECATE
|
||||
cflags = -nologo -c $(COMPILERFLAGS) $(cwarn) -Fp$(TMP_DIR)^\
|
||||
|
||||
!if $(MSVCRT)
|
||||
!if $(DEBUG) && !$(UNCHECKED)
|
||||
crt = -MDd
|
||||
!else
|
||||
crt = -MD
|
||||
!endif
|
||||
!else
|
||||
!if $(DEBUG) && !$(UNCHECKED)
|
||||
crt = -MTd
|
||||
!else
|
||||
crt = -MT
|
||||
!endif
|
||||
!endif
|
||||
|
||||
TCL_INCLUDES = -I"$(WINDIR)" -I"$(GENERICDIR)" -I"$(TOMMATHDIR)"
|
||||
TCL_DEFINES = -DTCL_TOMMATH -DMP_PREC=4 -Dinline=__inline -DHAVE_ZLIB=1
|
||||
BASE_CFLAGS = $(cflags) $(cdebug) $(crt) $(TCL_INCLUDES) $(TCL_DEFINES)
|
||||
CON_CFLAGS = $(cflags) $(cdebug) $(crt) -DCONSOLE
|
||||
TCL_CFLAGS = $(BASE_CFLAGS) $(OPTDEFINES)
|
||||
STUB_CFLAGS = $(cflags) $(cdebug) $(OPTDEFINES)
|
||||
|
||||
|
||||
#---------------------------------------------------------------------
|
||||
# Link flags
|
||||
#---------------------------------------------------------------------
|
||||
|
||||
!if $(DEBUG)
|
||||
ldebug = -debug -debugtype:cv
|
||||
!else
|
||||
ldebug = -release -opt:ref -opt:icf,3
|
||||
!if $(SYMBOLS)
|
||||
ldebug = $(ldebug) -debug -debugtype:cv
|
||||
!endif
|
||||
!endif
|
||||
|
||||
### Declarations common to all linker options
|
||||
lflags = -nologo -machine:$(MACHINE) $(LINKERFLAGS) $(ldebug)
|
||||
|
||||
!if $(PROFILE)
|
||||
lflags = $(lflags) -profile
|
||||
!endif
|
||||
|
||||
!if $(MSVCRT) && !($(DEBUG) && !$(UNCHECKED)) && $(VCVERSION) >= 1900
|
||||
lflags = $(lflags) -nodefaultlib:libucrt.lib
|
||||
!endif
|
||||
|
||||
!if $(ALIGN98_HACK) && !$(STATIC_BUILD)
|
||||
### Align sections for PE size savings.
|
||||
lflags = $(lflags) -opt:nowin98
|
||||
!else if !$(ALIGN98_HACK) && $(STATIC_BUILD)
|
||||
### Align sections for speed in loading by choosing the virtual page size.
|
||||
lflags = $(lflags) -align:4096
|
||||
!endif
|
||||
|
||||
!if $(LOIMPACT)
|
||||
lflags = $(lflags) -ws:aggressive
|
||||
!endif
|
||||
|
||||
dlllflags = $(lflags) -dll
|
||||
conlflags = $(lflags) -subsystem:console
|
||||
guilflags = $(lflags) -subsystem:windows
|
||||
|
||||
baselibs = netapi32.lib kernel32.lib user32.lib advapi32.lib userenv.lib ws2_32.lib
|
||||
# Avoid 'unresolved external symbol __security_cookie' errors.
|
||||
# c.f. http://support.microsoft.com/?id=894573
|
||||
!if "$(MACHINE)" == "IA64" || "$(MACHINE)" == "AMD64"
|
||||
!if $(VCVERSION) > 1399 && $(VCVERSION) < 1500
|
||||
baselibs = $(baselibs) bufferoverflowU.lib
|
||||
!endif
|
||||
!endif
|
||||
!if $(MSVCRT) && !($(DEBUG) && !$(UNCHECKED)) && $(VCVERSION) >= 1900
|
||||
baselibs = $(baselibs) ucrt.lib
|
||||
!endif
|
||||
# Additional Link libraries needed beyond those in rules.vc
|
||||
PRJ_LIBS = netapi32.lib user32.lib userenv.lib ws2_32.lib
|
||||
|
||||
#---------------------------------------------------------------------
|
||||
# TclTest flags
|
||||
@@ -582,23 +378,15 @@ dlls: setup $(TCLREGLIB) $(TCLDDELIB)
|
||||
all: setup $(TCLSH) $(TCLSTUBLIB) dlls $(CAT32) pkgs
|
||||
tcltest: setup $(TCLTEST) dlls $(CAT32)
|
||||
install: install-binaries install-libraries install-docs install-pkgs
|
||||
setup: default-setup
|
||||
|
||||
test: test-core test-pkgs
|
||||
test-core: setup $(TCLTEST) dlls $(CAT32)
|
||||
set TCL_LIBRARY=$(ROOT:\=/)/library
|
||||
!if "$(OS)" == "Windows_NT" || "$(MSVCDIR)" == "IDE"
|
||||
$(DEBUGGER) $(TCLTEST) "$(ROOT:\=/)/tests/all.tcl" $(TESTFLAGS) -loadfile <<
|
||||
package ifneeded dde 1.4.0 [list load "$(TCLDDELIB:\=/)" dde]
|
||||
package ifneeded registry 1.3.2 [list load "$(TCLREGLIB:\=/)" registry]
|
||||
<<
|
||||
!else
|
||||
@echo Please wait while the tests are collected...
|
||||
$(TCLTEST) "$(ROOT:\=/)/tests/all.tcl" $(TESTFLAGS) -loadfile << > tests.log
|
||||
package ifneeded dde 1.4.0 "$(TCLDDELIB:\=/)" dde]
|
||||
package ifneeded registry 1.3.2 "$(TCLREGLIB:\=/)" registry]
|
||||
<<
|
||||
type tests.log | more
|
||||
!endif
|
||||
|
||||
runtest: setup $(TCLTEST) dlls $(CAT32)
|
||||
set TCL_LIBRARY=$(ROOT:\=/)/library
|
||||
@@ -608,55 +396,51 @@ runshell: setup $(TCLSH) dlls
|
||||
set TCL_LIBRARY=$(ROOT:\=/)/library
|
||||
$(DEBUGGER) $(TCLSH) $(SCRIPT)
|
||||
|
||||
setup:
|
||||
@if not exist $(OUT_DIR)\nul mkdir $(OUT_DIR)
|
||||
@if not exist $(TMP_DIR)\nul mkdir $(TMP_DIR)
|
||||
|
||||
!if !$(STATIC_BUILD)
|
||||
$(TCLIMPLIB): $(TCLLIB)
|
||||
!endif
|
||||
!if $(STATIC_BUILD)
|
||||
|
||||
$(TCLLIB): $(TCLOBJS)
|
||||
!if $(STATIC_BUILD)
|
||||
$(lib32) -nologo $(LINKERFLAGS) -out:$@ @<<
|
||||
$(LIBCMD) @<<
|
||||
$**
|
||||
<<
|
||||
|
||||
!else
|
||||
$(link32) $(dlllflags) -base:@$(WINDIR)\coffbase.txt,tcl -out:$@ \
|
||||
$(baselibs) @<<
|
||||
|
||||
$(TCLLIB): $(TCLOBJS)
|
||||
$(DLLCMD) @<<
|
||||
$**
|
||||
<<
|
||||
$(_VC_MANIFEST_EMBED_DLL)
|
||||
!endif
|
||||
$(TCLIMPLIB): $(TCLLIB)
|
||||
|
||||
!endif # $(STATIC_BUILD)
|
||||
|
||||
|
||||
$(TCLSTUBLIB): $(TCLSTUBOBJS)
|
||||
$(lib32) -nologo $(LINKERFLAGS) -nodefaultlib -out:$@ $(TCLSTUBOBJS)
|
||||
$(LIBCMD) -nodefaultlib $(TCLSTUBOBJS)
|
||||
|
||||
$(TCLSH): $(TCLSHOBJS) $(TCLSTUBLIB) $(TCLIMPLIB)
|
||||
$(link32) $(conlflags) -stack:2300000 -out:$@ $(baselibs) $**
|
||||
$(CONEXECMD) -stack:2300000 $**
|
||||
$(_VC_MANIFEST_EMBED_EXE)
|
||||
|
||||
$(TCLTEST): $(TCLTESTOBJS) $(TCLSTUBLIB) $(TCLIMPLIB)
|
||||
$(link32) $(conlflags) -stack:2300000 -out:$@ $(baselibs) $**
|
||||
$(CONEXECMD) -stack:2300000 $**
|
||||
$(_VC_MANIFEST_EMBED_EXE)
|
||||
|
||||
!if $(STATIC_BUILD)
|
||||
$(TCLDDELIB): $(TMP_DIR)\tclWinDde.obj
|
||||
$(lib32) -nologo $(LINKERFLAGS) -out:$@ $**
|
||||
$(LIBCMD) $**
|
||||
!else
|
||||
$(TCLDDELIB): $(TMP_DIR)\tclWinDde.obj $(TCLSTUBLIB)
|
||||
$(link32) $(dlllflags) -base:@$(WINDIR)\coffbase.txt,tcldde -out:$@ \
|
||||
$** $(baselibs)
|
||||
$(DLLCMD) $**
|
||||
$(_VC_MANIFEST_EMBED_DLL)
|
||||
!endif
|
||||
|
||||
!if $(STATIC_BUILD)
|
||||
$(TCLREGLIB): $(TMP_DIR)\tclWinReg.obj
|
||||
$(lib32) -nologo $(LINKERFLAGS) -out:$@ $**
|
||||
$(LIBCMD) $**
|
||||
!else
|
||||
$(TCLREGLIB): $(TMP_DIR)\tclWinReg.obj $(TCLSTUBLIB)
|
||||
$(link32) $(dlllflags) -base:@$(WINDIR)\coffbase.txt,tclreg -out:$@ \
|
||||
$** $(baselibs)
|
||||
$(DLLCMD) $**
|
||||
$(_VC_MANIFEST_EMBED_DLL)
|
||||
!endif
|
||||
|
||||
@@ -693,9 +477,8 @@ clean-pkgs:
|
||||
)
|
||||
|
||||
$(CAT32): $(WINDIR)\cat.c
|
||||
$(cc32) $(CON_CFLAGS) -Fo$(TMP_DIR)\ $?
|
||||
$(link32) $(conlflags) -out:$@ -stack:16384 $(TMP_DIR)\cat.obj \
|
||||
$(baselibs)
|
||||
$(cc32) $(cflags) $(crt) -D_CRT_NONSTDC_NO_DEPRECATE -DCONSOLE -Fo$(TMP_DIR)\ $?
|
||||
$(CONEXECMD) -stack:16384 $(TMP_DIR)\cat.obj
|
||||
$(_VC_MANIFEST_EMBED_EXE)
|
||||
|
||||
#---------------------------------------------------------------------
|
||||
@@ -733,11 +516,14 @@ gentommath_h:
|
||||
# Build the Windows HTML help file.
|
||||
#---------------------------------------------------------------------
|
||||
|
||||
# NOTE: you can define HHC on the command-line to override this
|
||||
!ifndef HHC
|
||||
HHC=""%ProgramFiles%\HTML Help Workshop\hhc.exe""
|
||||
# NOTE: you can define HHC on the command-line to override this.
|
||||
# nmake does not set macro values if already set on the command line.
|
||||
!if defined(PROCESSOR_ARCHITECTURE) && "$(PROCESSOR_ARCHITECTURE)" == "AMD64"
|
||||
HHC="%ProgramFiles(x86)%\HTML Help Workshop\hhc.exe"
|
||||
!else
|
||||
HHC="%ProgramFiles%\HTML Help Workshop\hhc.exe"
|
||||
!endif
|
||||
HTMLDIR=$(ROOT)\html
|
||||
HTMLDIR=$(OUT_DIR)\html
|
||||
HTMLBASE=TclTk$(VERSION)
|
||||
HHPFILE=$(HTMLDIR)\$(HTMLBASE).hhp
|
||||
CHMFILE=$(HTMLDIR)\$(HTMLBASE).chm
|
||||
@@ -745,100 +531,53 @@ CHMFILE=$(HTMLDIR)\$(HTMLBASE).chm
|
||||
htmlhelp: chmsetup $(CHMFILE)
|
||||
|
||||
$(CHMFILE): $(DOCDIR)\*
|
||||
@$(TCLSH) $(TOOLSDIR)\tcltk-man2html.tcl
|
||||
@$(TCLSH) $(TOOLSDIR)\tcltk-man2html.tcl "--htmldir=$(HTMLDIR)"
|
||||
@echo Compiling HTML help project
|
||||
@$(HHC) <<$(HHPFILE) >NUL
|
||||
-"$(HHC)" <<$(HHPFILE) >NUL
|
||||
[OPTIONS]
|
||||
Compatibility=1.1 or later
|
||||
Compiled file=$(HTMLBASE).chm
|
||||
Default topic=contents.htm
|
||||
Display compile progress=no
|
||||
Error log file=$(HTMLBASE).log
|
||||
Full-text search=Yes
|
||||
Language=0x409 English (United States)
|
||||
Title=Tcl/Tk $(DOT_VERSION) Help
|
||||
Title=Tcl/Tk $(DOTVERSION) Help
|
||||
[FILES]
|
||||
contents.htm
|
||||
docs.css
|
||||
Keywords
|
||||
TclCmd
|
||||
TclLib
|
||||
TkCmd
|
||||
TkLib
|
||||
UserCmd
|
||||
Keywords\*.htm
|
||||
TclCmd\*.htm
|
||||
TclLib\*.htm
|
||||
TkCmd\*.htm
|
||||
TkLib\*.htm
|
||||
UserCmd\*.htm
|
||||
<<
|
||||
|
||||
chmsetup:
|
||||
@if not exist $(HTMLDIR)\nul mkdir $(HTMLDIR)
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
# Build the old-style Windows .hlp file
|
||||
#-------------------------------------------------------------------------
|
||||
|
||||
TCLHLPBASE = $(PROJECT)$(VERSION)
|
||||
HELPFILE = $(OUT_DIR)\$(TCLHLPBASE).hlp
|
||||
HELPCNT = $(OUT_DIR)\$(TCLHLPBASE).cnt
|
||||
DOCTMP_DIR = $(OUT_DIR)\$(PROJECT)_docs
|
||||
HELPRTF = $(DOCTMP_DIR)\$(PROJECT).rtf
|
||||
MAN2HELP = $(DOCTMP_DIR)\man2help.tcl
|
||||
MAN2HELP2 = $(DOCTMP_DIR)\man2help2.tcl
|
||||
INDEX = $(DOCTMP_DIR)\index.tcl
|
||||
BMP = $(DOCTMP_DIR)\feather.bmp
|
||||
BMP_NOPATH = feather.bmp
|
||||
MAN2TCL = $(DOCTMP_DIR)\man2tcl.exe
|
||||
|
||||
winhelp: docsetup $(HELPFILE)
|
||||
|
||||
docsetup:
|
||||
@if not exist $(DOCTMP_DIR)\nul mkdir $(DOCTMP_DIR)
|
||||
|
||||
$(MAN2HELP) $(MAN2HELP2) $(INDEX) $(BMP): $(TOOLSDIR)\$$(@F)
|
||||
@$(CPY) $(TOOLSDIR)\$(@F) $(@D)
|
||||
|
||||
$(HELPFILE): $(HELPRTF) $(BMP)
|
||||
cd $(DOCTMP_DIR)
|
||||
start /wait hcrtf.exe -x <<$(PROJECT).hpj
|
||||
[OPTIONS]
|
||||
COMPRESS=12 Hall Zeck
|
||||
LCID=0x409 0x0 0x0 ; English (United States)
|
||||
TITLE=Tcl/Tk Reference Manual
|
||||
BMROOT=.
|
||||
CNT=$(@B).cnt
|
||||
HLP=$(@B).hlp
|
||||
|
||||
[FILES]
|
||||
$(PROJECT).rtf
|
||||
|
||||
[WINDOWS]
|
||||
main="Tcl/Tk Reference Manual",,27648,(r15263976),(r65535)
|
||||
|
||||
[CONFIG]
|
||||
BrowseButtons()
|
||||
CreateButton(1, "Web", ExecFile("http://www.tcl.tk"))
|
||||
CreateButton(2, "SF", ExecFile("http://sf.net/projects/tcl"))
|
||||
CreateButton(3, "Wiki", ExecFile("http://wiki.tcl.tk"))
|
||||
CreateButton(4, "FAQ", ExecFile("http://www.purl.org/NET/Tcl-FAQ/"))
|
||||
<<
|
||||
cd $(MAKEDIR)
|
||||
@$(CPY) "$(DOCTMP_DIR)\$(@B).hlp" "$(OUT_DIR)"
|
||||
@$(CPY) "$(DOCTMP_DIR)\$(@B).cnt" "$(OUT_DIR)"
|
||||
|
||||
$(MAN2TCL): $(TOOLSDIR)\$$(@B).c
|
||||
$(cc32) $(TCL_CFLAGS) -Fo$(@D)\ $(TOOLSDIR)\$(@B).c
|
||||
$(link32) $(conlflags) -out:$@ -stack:16384 $(@D)\man2tcl.obj
|
||||
$(_VC_MANIFEST_EMBED_EXE)
|
||||
|
||||
$(HELPRTF): $(MAN2TCL) $(MAN2HELP) $(MAN2HELP2) $(INDEX) $(DOCDIR)\*
|
||||
$(TCLSH) $(MAN2HELP) -bitmap $(BMP_NOPATH) $(PROJECT) $(VERSION) $(DOCDIR:\=/)
|
||||
|
||||
install-docs:
|
||||
!if exist("$(CHMFILE)")
|
||||
@echo Installing compiled HTML help
|
||||
@$(CPY) "$(CHMFILE)" "$(DOC_INSTALL_DIR)\"
|
||||
!endif
|
||||
!if exist("$(HELPFILE)")
|
||||
@echo Installing Windows help
|
||||
@$(CPY) "$(HELPFILE)" "$(DOC_INSTALL_DIR)\"
|
||||
@$(CPY) "$(HELPCNT)" "$(DOC_INSTALL_DIR)\"
|
||||
!endif
|
||||
|
||||
# "emacs font-lock highlighting fix
|
||||
|
||||
#---------------------------------------------------------------------
|
||||
# Generate the tcl.nmake file which contains the options used to build
|
||||
# Tcl itself. This is used when building extensions.
|
||||
#---------------------------------------------------------------------
|
||||
tcl-nmake: $(OUT_DIR)\tcl.nmake
|
||||
$(OUT_DIR)\tcl.nmake:
|
||||
@type << >$@
|
||||
CORE_MACHINE = $(MACHINE)
|
||||
CORE_DEBUG = $(DEBUG)
|
||||
CORE_TCL_THREADS = $(TCL_THREADS)
|
||||
CORE_USE_THREAD_ALLOC = $(USE_THREAD_ALLOC)
|
||||
CORE_USE_WIDECHAR_API = $(USE_WIDECHAR_API)
|
||||
<<
|
||||
|
||||
#---------------------------------------------------------------------
|
||||
# Build tclConfig.sh for the TEA build system.
|
||||
@@ -846,6 +585,7 @@ install-docs:
|
||||
|
||||
tclConfig: $(OUT_DIR)\tclConfig.sh
|
||||
|
||||
# TBD - is this tclConfig.sh file ever used? The values are incorrect!
|
||||
$(OUT_DIR)\tclConfig.sh: $(WINDIR)\tclConfig.sh.in
|
||||
@echo Creating tclConfig.sh
|
||||
@nmakehlp -s << $** >$@
|
||||
@@ -855,7 +595,7 @@ $(OUT_DIR)\tclConfig.sh: $(WINDIR)\tclConfig.sh.in
|
||||
@TCL_MINOR_VERSION@ $(TCL_MINOR_VERSION)
|
||||
@TCL_PATCH_LEVEL@ $(TCL_PATCH_LEVEL)
|
||||
@CC@ $(CC)
|
||||
@DEFS@ $(TCL_CFLAGS)
|
||||
@DEFS@ $(pkgcflags)
|
||||
@CFLAGS_DEBUG@ -nologo -c -W3 -YX -Fp$(TMP_DIR)\ -MDd
|
||||
@CFLAGS_OPTIMIZE@ -nologo -c -W3 -YX -Fp$(TMP_DIR)\ -MD
|
||||
@LDFLAGS_DEBUG@ -nologo -machine:$(MACHINE) -debug -debugtype:cv
|
||||
@@ -863,7 +603,7 @@ $(OUT_DIR)\tclConfig.sh: $(WINDIR)\tclConfig.sh.in
|
||||
@TCL_DBGX@ $(SUFX)
|
||||
@TCL_LIB_FILE@ $(PROJECT)$(VERSION)$(SUFX).lib
|
||||
@TCL_NEEDS_EXP_FILE@
|
||||
@LIBS@ $(baselibs)
|
||||
@LIBS@ $(baselibs) $(PRJ_LIBS)
|
||||
@prefix@ $(_INSTALLDIR)
|
||||
@exec_prefix@ $(BIN_INSTALL_DIR)
|
||||
@SHLIB_CFLAGS@
|
||||
@@ -872,10 +612,11 @@ $(OUT_DIR)\tclConfig.sh: $(WINDIR)\tclConfig.sh.in
|
||||
@EXTRA_CFLAGS@ -YX
|
||||
@SHLIB_LD@ $(link32) $(dlllflags)
|
||||
@STLIB_LD@ $(lib32) -nologo
|
||||
@SHLIB_LD_LIBS@ $(baselibs)
|
||||
@SHLIB_LD_LIBS@ $(baselibs) $(PRJ_LIBS)
|
||||
@SHLIB_SUFFIX@ .dll
|
||||
@DL_LIBS@
|
||||
@LDFLAGS@
|
||||
@TCL_CC_SEARCH_FLAGS@
|
||||
@TCL_LD_SEARCH_FLAGS@
|
||||
@LIBOBJS@
|
||||
@RANLIB@
|
||||
@@ -922,28 +663,28 @@ gendate:
|
||||
#---------------------------------------------------------------------
|
||||
|
||||
$(TMP_DIR)\testMain.obj: $(WINDIR)\tclAppInit.c
|
||||
$(cc32) $(TCL_CFLAGS) -DTCL_TEST \
|
||||
$(cc32) $(appcflags) -DTCL_TEST \
|
||||
-DTCL_USE_STATIC_PACKAGES=$(TCL_USE_STATIC_PACKAGES) \
|
||||
-Fo$@ $?
|
||||
|
||||
$(TMP_DIR)\tclMain2.obj: $(GENERICDIR)\tclMain.c
|
||||
$(cc32) $(TCL_CFLAGS) -DBUILD_tcl -DTCL_ASCII_MAIN \
|
||||
$(cc32) $(pkgcflags) -DTCL_ASCII_MAIN \
|
||||
-Fo$@ $?
|
||||
|
||||
$(TMP_DIR)\tclTest.obj: $(GENERICDIR)\tclTest.c
|
||||
$(cc32) $(TCL_CFLAGS) -Fo$@ $?
|
||||
$(cc32) $(appcflags) -Fo$@ $?
|
||||
|
||||
$(TMP_DIR)\tclTestObj.obj: $(GENERICDIR)\tclTestObj.c
|
||||
$(cc32) $(TCL_CFLAGS) -Fo$@ $?
|
||||
$(cc32) $(appcflags) -Fo$@ $?
|
||||
|
||||
$(TMP_DIR)\tclWinTest.obj: $(WINDIR)\tclWinTest.c
|
||||
$(cc32) $(TCL_CFLAGS) -Fo$@ $?
|
||||
$(CCAPPCMD) $?
|
||||
|
||||
$(TMP_DIR)\tclZlib.obj: $(GENERICDIR)\tclZlib.c
|
||||
$(cc32) $(TCL_CFLAGS) -I$(COMPATDIR)\zlib -DBUILD_tcl -Fo$@ $?
|
||||
$(cc32) $(pkgcflags) -I$(COMPATDIR)\zlib -Fo$@ $?
|
||||
|
||||
$(TMP_DIR)\tclPkgConfig.obj: $(GENERICDIR)\tclPkgConfig.c
|
||||
$(cc32) -DBUILD_tcl $(TCL_CFLAGS) \
|
||||
$(cc32) $(pkgcflags) \
|
||||
-DCFG_INSTALL_LIBDIR="\"$(LIB_INSTALL_DIR:\=\\)\"" \
|
||||
-DCFG_INSTALL_BINDIR="\"$(BIN_INSTALL_DIR:\=\\)\"" \
|
||||
-DCFG_INSTALL_SCRDIR="\"$(SCRIPT_INSTALL_DIR:\=\\)\"" \
|
||||
@@ -957,7 +698,7 @@ $(TMP_DIR)\tclPkgConfig.obj: $(GENERICDIR)\tclPkgConfig.c
|
||||
-Fo$@ $?
|
||||
|
||||
$(TMP_DIR)\tclAppInit.obj: $(WINDIR)\tclAppInit.c
|
||||
$(cc32) $(TCL_CFLAGS) \
|
||||
$(cc32) $(appcflags) \
|
||||
-DTCL_USE_STATIC_PACKAGES=$(TCL_USE_STATIC_PACKAGES) \
|
||||
-Fo$@ $?
|
||||
|
||||
@@ -966,17 +707,17 @@ $(TMP_DIR)\tclAppInit.obj: $(WINDIR)\tclAppInit.c
|
||||
|
||||
$(TMP_DIR)\tclWinReg.obj: $(WINDIR)\tclWinReg.c
|
||||
!if $(STATIC_BUILD)
|
||||
$(cc32) $(TCL_CFLAGS) -DTCL_THREADS=1 -DSTATIC_BUILD -Fo$@ $?
|
||||
$(cc32) $(appcflags) -DSTATIC_BUILD -Fo$@ $?
|
||||
!else
|
||||
$(cc32) $(TCL_CFLAGS) -DTCL_THREADS=1 -DUSE_TCL_STUBS -Fo$@ $?
|
||||
$(cc32) $(appcflags) -DUSE_TCL_STUBS -Fo$@ $?
|
||||
!endif
|
||||
|
||||
|
||||
$(TMP_DIR)\tclWinDde.obj: $(WINDIR)\tclWinDde.c
|
||||
!if $(STATIC_BUILD)
|
||||
$(cc32) $(TCL_CFLAGS) -DTCL_THREADS=1 -DSTATIC_BUILD -Fo$@ $?
|
||||
$(cc32) $(appcflags) -DSTATIC_BUILD -Fo$@ $?
|
||||
!else
|
||||
$(cc32) $(TCL_CFLAGS) -DTCL_THREADS=1 -DUSE_TCL_STUBS -Fo$@ $?
|
||||
$(cc32) $(appcflags) -DUSE_TCL_STUBS -Fo$@ $?
|
||||
!endif
|
||||
|
||||
|
||||
@@ -985,13 +726,13 @@ $(TMP_DIR)\tclWinDde.obj: $(WINDIR)\tclWinDde.c
|
||||
### specific C run-time.
|
||||
|
||||
$(TMP_DIR)\tclStubLib.obj: $(GENERICDIR)\tclStubLib.c
|
||||
$(cc32) $(STUB_CFLAGS) -Zl -DSTATIC_BUILD $(TCL_INCLUDES) -Fo$@ $?
|
||||
$(cc32) $(stubscflags) -Fo$@ $?
|
||||
|
||||
$(TMP_DIR)\tclTomMathStubLib.obj: $(GENERICDIR)\tclTomMathStubLib.c
|
||||
$(cc32) $(STUB_CFLAGS) -Zl -DSTATIC_BUILD $(TCL_INCLUDES) -Fo$@ $?
|
||||
$(cc32) $(stubscflags) -Fo$@ $?
|
||||
|
||||
$(TMP_DIR)\tclOOStubLib.obj: $(GENERICDIR)\tclOOStubLib.c
|
||||
$(cc32) $(STUB_CFLAGS) -Zl -DSTATIC_BUILD $(TCL_INCLUDES) -Fo$@ $?
|
||||
$(cc32) $(stubscflags) -Fo$@ $?
|
||||
|
||||
$(TMP_DIR)\tclsh.exe.manifest: $(WINDIR)\tclsh.exe.manifest.in
|
||||
@nmakehlp -s << $** >$@
|
||||
@@ -1012,7 +753,7 @@ depend:
|
||||
@echo Build tclsh first!
|
||||
!else
|
||||
$(TCLSH) $(TOOLSDIR:\=/)/mkdepend.tcl -vc32 -out:"$(OUT_DIR)\depend.mk" \
|
||||
-passthru:"-DBUILD_tcl $(TCL_INCLUDES)" $(GENERICDIR),$$(GENERICDIR) \
|
||||
-passthru:"-DBUILD_tcl $(TCL_INCLUDES) $(PRJ_INCLUDES)" $(GENERICDIR),$$(GENERICDIR) \
|
||||
$(COMPATDIR),$$(COMPATDIR) $(TOMMATHDIR),$$(TOMMATHDIR) $(WINDIR),$$(WINDIR) @<<
|
||||
$(TCLOBJS)
|
||||
<<
|
||||
@@ -1034,47 +775,23 @@ $(TCLOBJS)
|
||||
|
||||
|
||||
#---------------------------------------------------------------------
|
||||
# Implicit rules. A limitation exists with nmake that requires that
|
||||
# Implicit rules that are not covered by the common ones defined in
|
||||
# rules.vc. A limitation exists with nmake that requires that
|
||||
# source directory can not contain spaces in the path. This an
|
||||
# absolute.
|
||||
#---------------------------------------------------------------------
|
||||
|
||||
{$(WINDIR)}.c{$(TMP_DIR)}.obj::
|
||||
$(cc32) $(TCL_CFLAGS) -DBUILD_tcl -Fo$(TMP_DIR)\ @<<
|
||||
$<
|
||||
<<
|
||||
|
||||
{$(TOMMATHDIR)}.c{$(TMP_DIR)}.obj::
|
||||
$(cc32) $(TCL_CFLAGS) -DBUILD_tcl -Fo$(TMP_DIR)\ @<<
|
||||
$<
|
||||
<<
|
||||
|
||||
{$(GENERICDIR)}.c{$(TMP_DIR)}.obj::
|
||||
$(cc32) $(TCL_CFLAGS) -DBUILD_tcl -Fo$(TMP_DIR)\ @<<
|
||||
$<
|
||||
<<
|
||||
|
||||
{$(COMPATDIR)}.c{$(TMP_DIR)}.obj::
|
||||
$(cc32) $(TCL_CFLAGS) -DBUILD_tcl -Fo$(TMP_DIR)\ @<<
|
||||
$(cc32) $(pkgcflags) -Fo$(TMP_DIR)\ @<<
|
||||
$<
|
||||
<<
|
||||
|
||||
{$(COMPATDIR)\zlib}.c{$(TMP_DIR)}.obj::
|
||||
$(cc32) $(TCL_CFLAGS) -DBUILD_tcl -Fo$(TMP_DIR)\ @<<
|
||||
$(cc32) $(pkgcflags) -Fo$(TMP_DIR)\ @<<
|
||||
$<
|
||||
<<
|
||||
|
||||
{$(WINDIR)}.rc{$(TMP_DIR)}.res:
|
||||
$(rc32) -fo $@ -r -i "$(GENERICDIR)" -i "$(TMP_DIR)" \
|
||||
-d DEBUG=$(DEBUG) -d UNCHECKED=$(UNCHECKED) \
|
||||
-d TCL_THREADS=$(TCL_THREADS) \
|
||||
-d STATIC_BUILD=$(STATIC_BUILD) \
|
||||
$<
|
||||
|
||||
$(TMP_DIR)\tclsh.res: $(TMP_DIR)\tclsh.exe.manifest
|
||||
|
||||
.SUFFIXES:
|
||||
.SUFFIXES:.c .rc
|
||||
$(TMP_DIR)\tclsh.res: $(TMP_DIR)\tclsh.exe.manifest $(WINDIR)\tclsh.rc
|
||||
|
||||
|
||||
#---------------------------------------------------------------------
|
||||
@@ -1095,21 +812,21 @@ install-binaries:
|
||||
@echo Installing $(TCLSTUBLIBNAME)
|
||||
@$(CPY) "$(TCLSTUBLIB)" "$(LIB_INSTALL_DIR)\"
|
||||
|
||||
#" emacs fix
|
||||
|
||||
install-libraries: tclConfig install-msgs install-tzdata
|
||||
@if not exist "$(SCRIPT_INSTALL_DIR)$(NULL)" \
|
||||
install-libraries: tclConfig tcl-nmake install-msgs install-tzdata
|
||||
@if not exist "$(SCRIPT_INSTALL_DIR)" \
|
||||
$(MKDIR) "$(SCRIPT_INSTALL_DIR)"
|
||||
@if not exist "$(SCRIPT_INSTALL_DIR)\..\tcl8$(NULL)" \
|
||||
@if not exist "$(SCRIPT_INSTALL_DIR)\..\tcl8" \
|
||||
$(MKDIR) "$(SCRIPT_INSTALL_DIR)\..\tcl8"
|
||||
@if not exist "$(SCRIPT_INSTALL_DIR)\..\tcl8\8.4$(NULL)" \
|
||||
@if not exist "$(SCRIPT_INSTALL_DIR)\..\tcl8\8.4" \
|
||||
$(MKDIR) "$(SCRIPT_INSTALL_DIR)\..\tcl8\8.4"
|
||||
@if not exist "$(SCRIPT_INSTALL_DIR)\..\tcl8\8.4\platform$(NULL)" \
|
||||
@if not exist "$(SCRIPT_INSTALL_DIR)\..\tcl8\8.4\platform" \
|
||||
$(MKDIR) "$(SCRIPT_INSTALL_DIR)\..\tcl8\8.4\platform"
|
||||
@if not exist "$(SCRIPT_INSTALL_DIR)\..\tcl8\8.5$(NULL)" \
|
||||
@if not exist "$(SCRIPT_INSTALL_DIR)\..\tcl8\8.5" \
|
||||
$(MKDIR) "$(SCRIPT_INSTALL_DIR)\..\tcl8\8.5"
|
||||
@if not exist "$(SCRIPT_INSTALL_DIR)\..\tcl8\8.6$(NULL)" \
|
||||
@if not exist "$(SCRIPT_INSTALL_DIR)\..\tcl8\8.6" \
|
||||
$(MKDIR) "$(SCRIPT_INSTALL_DIR)\..\tcl8\8.6"
|
||||
@if not exist "$(LIB_INSTALL_DIR)\nmake" \
|
||||
$(MKDIR) "$(LIB_INSTALL_DIR)\nmake"
|
||||
@echo Installing header files
|
||||
@$(CPY) "$(GENERICDIR)\tcl.h" "$(INCLUDE_INSTALL_DIR)\"
|
||||
@$(CPY) "$(GENERICDIR)\tclDecls.h" "$(INCLUDE_INSTALL_DIR)\"
|
||||
@@ -1133,6 +850,10 @@ install-libraries: tclConfig install-msgs install-tzdata
|
||||
@$(CPY) "$(ROOT)\library\auto.tcl" "$(SCRIPT_INSTALL_DIR)\"
|
||||
@$(CPY) "$(OUT_DIR)\tclConfig.sh" "$(LIB_INSTALL_DIR)\"
|
||||
@$(CPY) "$(WINDIR)\tclooConfig.sh" "$(LIB_INSTALL_DIR)\"
|
||||
@$(CPY) "$(WINDIR)\rules.vc" "$(LIB_INSTALL_DIR)\nmake\"
|
||||
@$(CPY) "$(WINDIR)\targets.vc" "$(LIB_INSTALL_DIR)\nmake\"
|
||||
@$(CPY) "$(WINDIR)\nmakehlp.c" "$(LIB_INSTALL_DIR)\nmake\"
|
||||
@$(CPY) "$(OUT_DIR)\tcl.nmake" "$(LIB_INSTALL_DIR)\nmake\"
|
||||
@echo Installing library http1.0 directory
|
||||
@$(CPY) "$(ROOT)\library\http1.0\*.tcl" \
|
||||
"$(SCRIPT_INSTALL_DIR)\http1.0\"
|
||||
@@ -1177,8 +898,7 @@ install-libraries: tclConfig install-msgs install-tzdata
|
||||
@echo Installing encodings
|
||||
@$(CPY) "$(ROOT)\library\encoding\*.enc" \
|
||||
"$(SCRIPT_INSTALL_DIR)\encoding\"
|
||||
|
||||
#" emacs fix
|
||||
# "emacs font-lock highlighting fix
|
||||
|
||||
install-tzdata:
|
||||
@echo Installing time zone data
|
||||
@@ -1212,28 +932,10 @@ tidy:
|
||||
@echo Removing $(TCLREGLIB) ...
|
||||
@if exist $(TCLREGLIB) del $(TCLREGLIB)
|
||||
|
||||
clean: clean-pkgs
|
||||
@echo Cleaning $(TMP_DIR)\* ...
|
||||
@if exist $(TMP_DIR)\nul $(RMDIR) $(TMP_DIR)
|
||||
@echo Cleaning $(WINDIR)\nmakehlp.obj ...
|
||||
@if exist $(WINDIR)\nmakehlp.obj del $(WINDIR)\nmakehlp.obj
|
||||
@echo Cleaning $(WINDIR)\nmakehlp.exe ...
|
||||
@if exist $(WINDIR)\nmakehlp.exe del $(WINDIR)\nmakehlp.exe
|
||||
@echo Cleaning $(WINDIR)\_junk.pch ...
|
||||
@if exist $(WINDIR)\_junk.pch del $(WINDIR)\_junk.pch
|
||||
@echo Cleaning $(WINDIR)\vercl.x ...
|
||||
@if exist $(WINDIR)\vercl.x del $(WINDIR)\vercl.x
|
||||
@echo Cleaning $(WINDIR)\vercl.i ...
|
||||
@if exist $(WINDIR)\vercl.i del $(WINDIR)\vercl.i
|
||||
@echo Cleaning $(WINDIR)\versions.vc ...
|
||||
@if exist $(WINDIR)\versions.vc del $(WINDIR)\versions.vc
|
||||
|
||||
clean: default-clean clean-pkgs
|
||||
hose: default-hose
|
||||
realclean: hose
|
||||
|
||||
hose:
|
||||
@echo Hosing $(OUT_DIR)\* ...
|
||||
@if exist $(OUT_DIR)\nul $(RMDIR) $(OUT_DIR)
|
||||
|
||||
# Local Variables:
|
||||
# mode: makefile
|
||||
# End:
|
||||
|
||||
Reference in New Issue
Block a user