Removed USES_LIBDYNINSTRT_SO defines
[dyninst.git] / nmake.config
1 # Paradyn overall build configuration (Windows/NT)
2 #
3 # $Id: nmake.config,v 1.30 2001/06/04 19:25:59 bernat Exp $
4 #
5
6 SUITE_NAME      = Paradyn
7 RELEASE_NUM     = 3.2
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 CC              = cl -nologo
47 CXX             = cl -nologo
48 LINK            = link
49 LEX             = p:\paradyn\packages\winnt\bin\flex
50 FLEX_LIB        = p:\paradyn\packages\winnt\lib\libfl.lib
51 RANLIB          =
52 RPCPKG          = p:\paradyn\packages\winnt\oncrpc
53 RPC_LIB         = oncrpc.lib
54 #X11DIR         = 
55 YACC            = bison
56 YFLAGS          = -d -y
57 LDFLAGS         = -nologo
58 PERL            = perl          # NB: perl v5 or higher required!
59
60 !ifdef SHELL    # use richer Unix shell utilities when they're available!
61 CP              = cp
62 MV              = mv
63 RM              = rm -f
64 MKDIR           = mkdir
65 BUILDSTAMP      = sh $(TO_CORE)/../scripts/buildstamp  # generate build vouchers
66 !else           # try and work as much as possible with "vanilla" WinNT!
67 CP              = copy
68 MV              = move
69 RM              = del
70 MKDIR           = md
71 BUILDSTAMP      = cmd /c $(TO_CORE)/../scripts/buildstamp.bat
72 !endif
73
74 # COLLECTOR is only used by purify & quantify
75 #COLLECTOR      =
76
77 ARCH_DEF        = -Di386_unknown_nt4_0
78
79 # Default module compiler; modules which want $(CC) should redefine
80 # this, **NOT** CC
81
82 MODCC           = $(CXX)
83 MODCFLAGS       = $(CXXFLAGS)
84
85 .SUFFIXES:      .I .y .l
86
87 VPATH         = ..\src:$(TO_CORE)\$(LIBRARY_DEST):$(TO_CORE)\..\lib\$(PLATFORM):$(BACKUP_CORE)\..\lib\$(PLATFORM)
88
89 IFLAGS          = -I. -I$(TO_CORE) -I$(RPCPKG)
90
91 #ASFLAGS         = -P $(ARCH_DEF)
92
93 #don't inline -- for the files that won't emit template code
94 INLINE_DEFINES = 
95
96 #inline the private members of the class -- templates.o can use this
97 TEMP_INLINE_DEFINES = -DDO_INLINE_P="inline"
98
99 # inline everything -- the way things should be
100 ALL_INLINE_DEFINES = -DDO_INLINE_F="inline" -DDO_INLINE_P="inline"
101
102 # if we don't want OPT_FLAG defined for a particular part of the code
103 # (e.g. rtinst for aix), we just need to define NO_OPT_FLAG before doing
104 # the include of make.config - naim
105 !ifndef NO_OPT_FLAG
106 OPT_FLAG        = -Ox
107 !endif
108
109 DEFCFLAGS       = -Z7 -W3 -GR -DNOMINMAX
110
111 CFLAGS          = $(DEFCFLAGS) $(OPT_FLAG) $(IFLAGS) \
112                         $(ARCH_DEF) -D_WIN32_WINNT=0x0400
113
114 CXXFLAGS        = $(DEFCFLAGS) $(OPT_FLAG) $(IFLAGS) \
115                         $(ARCH_DEF) -TP -DWIN32 -D_WIN32_WINNT=0x0400
116  
117 # flags for kludge files, won't have warnings generated
118 KFLAGS          = $(IFLAGS) $(ARCH_DEF)
119
120 # flags for template files, don't define external template flags
121 # -g is optional in this case -- should be defined at module level
122 TFLAGS          = $(IFLAGS) $(OPT_FLAG) $(TEMP_INLINE_DEFINES) $(ARCH_DEF)
123
124 !ifdef DO_INLINE_ALL
125 CXXFLAGS        = $(CXXFLAGS) -DDO_INLINE_F="inline" -DDO_INLINE_P="inline"
126 !endif
127
128 # Start off LIBDIR to point to the user's devel area's paradyn lib directory.
129 # As a backup, in case the user hasn't checked out & compiled some paradyn lib,
130 # we stick in /p/paradyn/lib _second_.
131 LIBDIR          = -LIBPATH:$(TO_CORE)\$(LIBRARY_DEST) \
132                         -LIBPATH:$(TO_CORE)\..\lib\$(PLATFORM) \
133                         -LIBPATH:$(BACKUP_CORE)\..\lib\$(PLATFORM) \
134                         -LIBPATH:$(RPCPKG)\lib
135
136 # Set IGEN to point to $(TO_CORE)/../bin/$(PLATFORM)/igen, if it exists,
137 # else set it to $(BACKUP_CORE)/../bin/$(PLATFORM)/igen, if it exists,
138 # else set it to just "igen" (i.e. assume it's in the user's path)
139 IGEN = $(TO_CORE)\igen\$(PLATFORM) 
140
141 !ifdef NO_IMPLICIT_TEMPLATES
142 #CFLAGS          += -fno-implicit-templates
143 #CXXFLAGS        += -fno-implicit-templates
144 #KFLAGS          += -fno-implicit-templates
145 #TFLAGS          += -fno-implicit-templates
146 !endif
147
148 !ifndef INSTANTIATE_TEMPLATES
149 !ifndef NO_IMPLICIT_TEMPLATES
150 # -fexternal-templates and -Dexternal_templates should both be used or
151 # neither should be used; add them to CFLAGS, CXXFLAGS, and KFLAGS
152 # (but not to TFLAGS).
153 #
154 #CFLAGS          = $(CFLAGS) -fexternal-templates -Dexternal_templates
155 #CXXFLAGS        = $(CXXFLAGS) -fexternal-templates -Dexternal_templates
156 #KFLAGS          = $(KFLAGS) -fexternal-templates -Dexternal_templates
157 !endif
158 !endif
159
160 # ***** EXTERNAL SOFTWARE CONFIGURATION *****
161
162 !ifdef INCLUDE_PVM_SUPPORT
163 !ifdef USES_PVM
164 !ifndef PVM_ROOT
165 BUILDERROR: PVM_ROOT must be defined in environment to build (and run) Paradyn
166 !endif
167 !ifndef PVM_ARCH
168 BUILDERROR: PVM_ROOT must be defined in environment to build (and run) Paradyn
169 !endif
170 PVM_INCDIR      = $(PVM_ROOT)/include
171 PVM_LIBDIR      = $(PVM_ROOT)/lib/$(PVM_ARCH)
172 IFLAGS          = $(IFLAGS) -I$(PVM_INCDIR)
173 #LIBDIR         += $(patsubst %,-L%,$(PVM_LIBDIR))
174 #VPATH          += $(PVM_LIBDIR)
175 !endif
176 !endif
177
178 !ifdef USES_TCLTK
179 # TCL2C is used to generate compilable sources from tcl files
180 TCL2C           = $(TO_CORE)/../scripts/tcl2c
181 TCL2C_GEN_SRCS  = tcl2c.C
182
183 # Specify the Tcl/Tk files to be used
184 TCLTK_DIR       = p:\paradyn\packages\tcl8.3.0
185 TCLTK_INCLUDES  = -I$(TCLTK_DIR)\include
186 TCLTK_LIBPATH   = -LIBPATH:$(TCLTK_DIR)\lib
187 TCLTK_LIBVER_ID = 83
188 TCL_LIB         = tcl$(TCLTK_LIBVER_ID).lib
189 TK_LIB          = tk$(TCLTK_LIBVER_ID).lib
190 TCLTK_LIBS      = $(TCL_LIB) $(TK_LIB)
191
192 IFLAGS          = $(IFLAGS) $(TCLTK_INCLUDES)
193 LIBDIR          = $(LIBDIR) $(TCLTK_LIBPATH)
194 !endif /* USES_TCLTK */
195
196
197 # Include any per-user configuration changes; this "local" config file
198 # should *not* be under CVS control, so that it never gets committed.
199
200 !if exist ($(TO_CORE)\nmake.config.local)
201 !include $(TO_CORE)\nmake.config.local
202 !else # try the common one
203 !if exist ($(TO_CORE)\make.config.local)
204 !include $(TO_CORE)\make.config.local
205 !endif
206 !endif