Updated to support building with recent Visual C++ compiler and Platform SDK
[dyninst.git] / nmake.config
1 # Paradyn overall build configuration (Windows/NT)
2 #
3 # $Id: nmake.config,v 1.43 2003/03/28 23:27:12 pcroth Exp $
4 #
5
6 SUITE_NAME      = Paradyn
7 RELEASE_NUM     = 3.3
8 #BUILD_MARK     =
9
10 # Apart from actual "full" releases, don't modify these build Id components.
11 # For personal/experimental builds, feel free to use your core/make.config.local
12 # file to (re-)define BUILD_MARK as you desire.
13
14 # ***** IMPORTANT INSTALLATION/CONFIGURATION INSTRUCTIONS *****
15 # Unless your site is set-up identically to that of the Paradyn/DyninstAPI
16 # developers, you should carefully examine the (GNU)make configuration
17 # parameters defined in this file, particularly utilities such as the C/C++
18 # compilers, perl, flex and bison, and the installed locations and names
19 # for FLEX and RPCPKG.
20
21 !ifdef USES_PVM
22 # (PVM support only potentially relevant for paradynd)
23 # uncomment/comment the following line to build with/without PVM support
24 #INCLUDE_PVM_SUPPORT=true
25 !endif
26
27 # most "main" modules are only two levels deep, but we need to be able to
28 # change this for those that are deeper in the tree
29 !ifndef TO_CORE
30 TO_CORE         = ..\..
31 !endif
32
33 # Destinations for library and executable installation (relative to core!)
34 # Warning: modification of the build/install structure is not recommended!
35 LIBRARY_DEST  = ..\lib\$(PLATFORM)
36 PROGRAM_DEST  = ..\bin\$(PLATFORM)
37
38 # Usually, we look for files, binaries, libs in $(TO_CORE)/....<something>.
39 # But if the file doesn't exist there (i.e. if the user hasn't checked them out
40 # with cvs), then we should look in a backup location.  That's what this vrble
41 # is about.  It's used several times below in this file.
42 BACKUP_CORE = p:\paradyn\core
43
44 AR              = ar
45 AS              =
46 NASM            = nasmw
47 CC              = cl -nologo
48 CXX             = cl -nologo
49 LINK            = link
50 RANLIB          =
51 RPCPKG          = p:\paradyn\packages\winnt\oncrpc
52 #RPCPKG         = f:\oncrpc
53 RPC_LIB         = oncrpc.lib
54 #X11DIR         =
55 YACC            = bison
56 YFLAGS          = -d -y
57 LDFLAGS         = -nologo
58
59 PERL            = perl          # NB: perl v5 or higher required!
60
61 !ifdef USES_FLEX
62 LEX                     = flex
63 FLEX_LIB        = libfl.a
64 LDFLAGS         = $(LDFLAGS) -LIBPATH:c:\cygwin\lib
65 !endif
66
67 !ifdef SHELL    # use richer Unix shell utilities when they're available!
68 CP              = cp
69 MV              = mv
70 RM              = rm -f
71 MKDIR           = mkdir
72 BUILDSTAMP      = sh $(TO_CORE)/../scripts/buildstamp  # generate build vouchers
73 !else           # try and work as much as possible with "vanilla" WinNT!
74 CP              = copy
75 MV              = move
76 RM              = del
77 MKDIR           = md
78 BUILDSTAMP      = cmd /c $(TO_CORE)\..\scripts\buildstamp.bat
79 !endif
80
81 # COLLECTOR is only used by purify & quantify
82 #COLLECTOR      =
83
84 ARCH_DEF        = -Di386_unknown_nt4_0
85
86 # Default module compiler; modules which want $(CC) should redefine
87 # this, **NOT** CC
88
89 MODCC           = $(CXX)
90 MODCFLAGS       = $(CXXFLAGS)
91
92 .SUFFIXES:      .I .y .l
93
94 VPATH         = ..\src:$(TO_CORE)\$(LIBRARY_DEST):$(TO_CORE)\..\lib\$(PLATFORM):$(BACKUP_CORE)\..\lib\$(PLATFORM)
95
96 IFLAGS          = -I. -I$(TO_CORE) -I$(RPCPKG)
97
98 #ASFLAGS         = -P $(ARCH_DEF)
99
100 #don't inline -- for the files that won't emit template code
101 INLINE_DEFINES =
102
103 #inline the private members of the class -- templates.o can use this
104 TEMP_INLINE_DEFINES = -DDO_INLINE_P="inline"
105
106 # inline everything -- the way things should be
107 ALL_INLINE_DEFINES = -DDO_INLINE_F="inline" -DDO_INLINE_P="inline"
108
109 # NO_OPT_FLAG = 1
110 # if we don't want OPT_FLAG defined for a particular part of the code
111 # (e.g. rtinst for aix), we just need to define NO_OPT_FLAG before doing
112 # the include of make.config - naim
113 !ifndef NO_OPT_FLAG
114 OPT_FLAG        = -Ox
115 !endif
116
117 DEFCFLAGS       = -Zi -W3 -GR -DNOMINMAX /wd4995
118
119 CFLAGS          = $(DEFCFLAGS) $(OPT_FLAG) $(IFLAGS) \
120                         $(ARCH_DEF) -D_WIN32_WINNT=0x0500 # ccw 20 june 2001 was 0x0400
121
122 CXXFLAGS        = $(DEFCFLAGS) $(OPT_FLAG) $(IFLAGS) \
123                         $(ARCH_DEF) -TP -DWIN32 -D_WIN32_WINNT=0x0500 # ccw 20 june 2001 was 0x0400
124
125 # flags for kludge files, won't have warnings generated
126 KFLAGS          = $(IFLAGS) $(ARCH_DEF)
127
128 # flags for template files, don't define external template flags
129 # -g is optional in this case -- should be defined at module level
130 TFLAGS          = $(IFLAGS) $(OPT_FLAG) $(TEMP_INLINE_DEFINES) $(ARCH_DEF)
131
132 !ifdef DO_INLINE_ALL
133 CXXFLAGS        = $(CXXFLAGS) -DDO_INLINE_F="inline" -DDO_INLINE_P="inline"
134 !endif
135
136 # Start off LIBDIR to point to the user's devel area's paradyn lib directory.
137 # As a backup, in case the user hasn't checked out & compiled some paradyn lib,
138 # we stick in /p/paradyn/lib _second_.
139 LIBDIR          = -LIBPATH:$(TO_CORE)\$(LIBRARY_DEST) \
140                         -LIBPATH:$(TO_CORE)\..\lib\$(PLATFORM) \
141                         -LIBPATH:$(BACKUP_CORE)\..\lib\$(PLATFORM) \
142                         -LIBPATH:$(RPCPKG)\lib
143
144 # Set IGEN to point to $(TO_CORE)/../bin/$(PLATFORM)/igen, if it exists,
145 # else set it to $(BACKUP_CORE)/../bin/$(PLATFORM)/igen, if it exists,
146 # else set it to just "igen" (i.e. assume it's in the user's path)
147 IGEN = $(TO_CORE)\igen\$(PLATFORM)
148
149 !ifdef NO_IMPLICIT_TEMPLATES
150 #CFLAGS          += -fno-implicit-templates
151 #CXXFLAGS        += -fno-implicit-templates
152 #KFLAGS          += -fno-implicit-templates
153 #TFLAGS          += -fno-implicit-templates
154 !endif
155
156 !ifndef INSTANTIATE_TEMPLATES
157 !ifndef NO_IMPLICIT_TEMPLATES
158 # -fexternal-templates and -Dexternal_templates should both be used or
159 # neither should be used; add them to CFLAGS, CXXFLAGS, and KFLAGS
160 # (but not to TFLAGS).
161 #
162 #CFLAGS          = $(CFLAGS) -fexternal-templates -Dexternal_templates
163 #CXXFLAGS        = $(CXXFLAGS) -fexternal-templates -Dexternal_templates
164 #KFLAGS          = $(KFLAGS) -fexternal-templates -Dexternal_templates
165 !endif
166 !endif
167
168 # ***** EXTERNAL SOFTWARE CONFIGURATION *****
169
170 !ifdef INCLUDE_PVM_SUPPORT
171 !ifdef USES_PVM
172 !ifndef PVM_ROOT
173 BUILDERROR: PVM_ROOT must be defined in environment to build (and run) Paradyn
174 !endif
175 !ifndef PVM_ARCH
176 BUILDERROR: PVM_ROOT must be defined in environment to build (and run) Paradyn
177 !endif
178 PVM_INCDIR      = $(PVM_ROOT)/include
179 PVM_LIBDIR      = $(PVM_ROOT)/lib/$(PVM_ARCH)
180 IFLAGS          = $(IFLAGS) -I$(PVM_INCDIR)
181 #LIBDIR         += $(patsubst %,-L%,$(PVM_LIBDIR))
182 #VPATH          += $(PVM_LIBDIR)
183 !endif
184 !endif
185
186 !ifdef USES_TCLTK
187 # TCL2C is used to generate compilable sources from tcl files
188 TCL2C           = $(TO_CORE)/../scripts/tcl2c
189 TCL2C_GEN_SRCS  = tcl2c.C
190
191 # Specify the Tcl/Tk files to be used
192 TCLTK_DIR       = p:\paradyn\packages\tcl8.3.4
193 TCLTK_INCLUDES  = -I$(TCLTK_DIR)\include
194 TCLTK_LIBPATH   = -LIBPATH:$(TCLTK_DIR)\lib
195 TCLTK_LIBVER_ID = 83
196 TCL_LIB         = tcl$(TCLTK_LIBVER_ID).lib
197 TK_LIB          = tk$(TCLTK_LIBVER_ID).lib
198 TCLTK_LIBS      = $(TCL_LIB) $(TK_LIB)
199
200 IFLAGS          = $(IFLAGS) $(TCLTK_INCLUDES)
201 LIBDIR          = $(LIBDIR) $(TCLTK_LIBPATH)
202 !endif /* USES_TCLTK */
203
204
205 # Include any per-user configuration changes; this "local" config file
206 # should *not* be under CVS control, so that it never gets committed.
207
208 !if exist ($(TO_CORE)\nmake.config.local)
209 !include $(TO_CORE)\nmake.config.local
210 !endif