1 karl 1.36 #//%2006////////////////////////////////////////////////////////////////////////
|
2 martin 1.31 #//
3 #// Copyright (c) 2000, 2001, 2002 BMC Software; Hewlett-Packard Development
4 #// Company, L.P.; IBM Corp.; The Open Group; Tivoli Systems.
5 #// Copyright (c) 2003 BMC Software; Hewlett-Packard Development Company, L.P.;
6 #// IBM Corp.; EMC Corporation, The Open Group.
7 #// Copyright (c) 2004 BMC Software; Hewlett-Packard Development Company, L.P.;
8 #// IBM Corp.; EMC Corporation; VERITAS Software Corporation; The Open Group.
9 #// Copyright (c) 2005 Hewlett-Packard Development Company, L.P.; IBM Corp.;
10 #// EMC Corporation; VERITAS Software Corporation; The Open Group.
|
11 karl 1.36 #// Copyright (c) 2006 Hewlett-Packard Development Company, L.P.; IBM Corp.;
12 #// EMC Corporation; Symantec Corporation; The Open Group.
|
13 martin 1.31 #//
14 #// Permission is hereby granted, free of charge, to any person obtaining a copy
15 #// of this software and associated documentation files (the "Software"), to
16 #// deal in the Software without restriction, including without limitation the
17 #// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
18 #// sell copies of the Software, and to permit persons to whom the Software is
19 #// furnished to do so, subject to the following conditions:
20 #//
21 #// THE ABOVE COPYRIGHT NOTICE AND THIS PERMISSION NOTICE SHALL BE INCLUDED IN
22 #// ALL COPIES OR SUBSTANTIAL PORTIONS OF THE SOFTWARE. THE SOFTWARE IS PROVIDED
23 #// "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT
24 #// LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
25 #// PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
26 #// HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
27 #// ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
28 #// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
29 #//
30 #//==============================================================================
|
31 karl 1.6 # Pegasus top level make file
|
32 jim.wunderlich 1.34 # see the usage rule for options
33
|
34 mike 1.1 ROOT = .
35
|
36 konrad.r 1.24 include $(ROOT)/env_var.status
|
37 mike 1.1 include $(ROOT)/mak/config.mak
38
|
39 karl 1.11 # This is a recurse make file
|
40 karl 1.6 # Defines subdirectorys to go to recursively
41
|
42 mike 1.3 # DIRS = src cgi
|
43 denise.eckstein 1.41 DIRS = src test Schemas
|
44 mike 1.1
|
45 karl 1.11 # Define the inclusion of the recurse.mak file to execute the next
46 # level of makefiles defined by the DIRS variable
|
47 karl 1.6
|
48 jim.wunderlich 1.34 defaultrule: all setupdevserver
49
|
50 mike 1.1 include $(ROOT)/mak/recurse.mak
51
|
52 jim.wunderlich 1.34 .PHONY: FORCE
|
53 jim.wunderlich 1.32
|
54 jim.wunderlich 1.34 FORCE:
|
55 jim.wunderlich 1.32
|
56 jim.wunderlich 1.34 usage: FORCE
57 $(USAGE)
58 $(USAGE)"Makefile targets:"
59 $(USAGE)
60 $(USAGE)"Recursive rules - These are the primatives that traverse the tree"
61 $(USAGE)"invoking the specified command in each subdirectory directory."
62 $(USAGE)"NOTE: all is special, it specifies no target and therefore invokes"
63 $(USAGE)"the default rule for that directory."
64 $(USAGE)"all - recursive DEFAULT rule"
65 $(USAGE)"clean - recursive clean"
66 $(USAGE)"depend - buildmu recursive depend"
67 $(USAGE)"messages - rootbundle recursive messages"
68 $(USAGE)"tests - recursive tests"
69 $(USAGE)"poststarttests - recursive poststarttests"
70 $(USAGE)
71 $(USAGE)"Combinational rules - Combine other rules to achieve results"
72 $(USAGE)"DEFAULT RULE - all, setupdevserver"
73 $(USAGE)"new - clean repositoryclean"
74 $(USAGE)"build - depend all, setupdevserver"
75 $(USAGE)"world - build unittests servertests"
76 $(USAGE)
77 jim.wunderlich 1.34 $(USAGE)"Functional rules - Other rules to achieve specified results"
|
78 jim.wunderlich 1.35 $(USAGE)"clobber -removes objects built during compile"
79 $(USAGE)" specifically the following directories are removed:"
80 $(USAGE)" $(PEGASUS_HOME)/bin"
81 $(USAGE)" $(PEGASUS_HOME)/lib"
82 $(USAGE)" $(PEGASUS_HOME)/obj"
|
83 jim.wunderlich 1.34 $(USAGE)"buildmu - builds the mu utility"
84 $(USAGE)"setupdevserver - setup the development server env"
85 $(USAGE)"cleandevserver - cleans the development server env"
|
86 karl 1.39 $(USAGE)"repository - builds the base repository. Does not remove other"
87 $(USAGE)" namespaces than the base namespaces."
|
88 jim.wunderlich 1.34 $(USAGE)"testrepository - builds items for the test suites into the repository"
89 $(USAGE)"removetestrepository- removes test items from the repository"
|
90 karl 1.39 $(USAGE)"repositoryclean - removes the complete repository"
|
91 jim.wunderlich 1.34 $(USAGE)"listplatforms - List all valid platforms"
92 $(USAGE)
93 $(USAGE)"Test rules (accessable here but implemented in TestMakefile)"
94 $(USAGE)"alltests - unittests and servertests"
95 $(USAGE)"unittests - runs the unit functional test"
96 $(USAGE)"servertests - runs basic server tests"
|
97 jim.wunderlich 1.35 $(USAGE)"perftests - runs basic server performance tests"
|
98 jim.wunderlich 1.34 $(USAGE)"standardtests - runs server extended tests"
99 $(USAGE)"testusage - TestMakefile usage"
100 $(USAGE)"testusage2 - TestMakefile usage2"
|
101 j.alex 1.37 $(USAGE)"stresstests - Runs the default stresstests"
|
102 jim.wunderlich 1.34 $(USAGE)
103 $(USAGE)"--------------------"
104 $(USAGE)"Quick start:"
105 $(USAGE)" After checkout of new tree:"
106 $(USAGE)" use \"make listplatforms\" to view a list of platforms"
107 $(USAGE)" set PEGASUS_PLATFORM=<your platofrm>"
108 $(USAGE)" set PEGASUS_ROOT=<location of your pegasus source>"
109 $(USAGE)" set PEGASUS_HOME=<build output location"
|
110 kumpf 1.42 $(USAGE)" make world"
|
111 jim.wunderlich 1.34 $(USAGE)
112 $(USAGE)" This will build everthing with a default configuration"
|
113 kumpf 1.42 $(USAGE)" and run the automated tests."
|
114 jim.wunderlich 1.34 $(USAGE)
115 $(USAGE)"--------------------"
116 $(USAGE)"Examples:"
|
117 kumpf 1.42 $(USAGE)" After \"cvs checkout\" of new tree: make world"
|
118 jim.wunderlich 1.34 $(USAGE)
119 $(USAGE)" After changes to include files: make"
120 $(USAGE)
121 $(USAGE)" After changes to the files included: make build"
122 $(USAGE)
|
123 kumpf 1.42 $(USAGE)" After \"cvs update\" or to start over: make new world"
|
124 jim.wunderlich 1.34 $(USAGE)
125
126 listplatforms: FORCE
127 $(USAGE)
128 $(USAGE)"The $(words $(VALID_PLATFORMS)) valid platforms are:"
129 $(USAGE)" $(foreach w, $(VALID_PLATFORMS), " $w ")"
130 $(USAGE)
131 $(USAGE)
132
133 #########################################################################
134 # This section defines any prerequisites that are required by the
135 # recursive rules.
136 #
137 # NOTE: You can add prerequisties for the recursive rules but you cannot
138 # add any commands to run as part of the rule. You can define them
139 # and make will quietly ignore them and they will not be run either
140 # before or after the recursive rule.
141 #
142 #
143 messages: rootbundle
|
144 karl 1.6
|
145 jim.wunderlich 1.34 depend: buildmu
|
146 kumpf 1.18
|
147 jim.wunderlich 1.34 #########################################################################
148 # This section defines combinational rules
149 #
|
150 jim.wunderlich 1.32 #-----------------------
|
151 jim.wunderlich 1.34 # build target: builds all source
|
152 jim.wunderlich 1.32 #
|
153 jim.wunderlich 1.34 build: depend all setupdevserver
|
154 jim.wunderlich 1.32
|
155 jim.wunderlich 1.34 #------------------------
156 # rebuild target is being deprecated instead use "make new build"
157 #
158 rebuild_msg: FORCE
159 @$(ECHO) "==============================================================================="
160 @$(ECHO) "Makefile: The rebuild target is being deprecated."
161 @$(ECHO) " Use \"make usage\" for a description of the usage model."
|
162 kumpf 1.42 @$(ECHO) " Consider using \"make new world\" ."
|
163 jim.wunderlich 1.34 @$(ECHO) " Invoking the old rebuild rule now."
164 @$(ECHO) "==============================================================================="
165
166 rebuild: rebuild_msg shortsleep new build s_unittests repository
|
167 jim.wunderlich 1.32
168 #-----------------------
|
169 jim.wunderlich 1.34 # new target: cleans everthing
170 #
171 # This can be combined on the command line with other rules like:
|
172 jim.wunderlich 1.32 #
|
173 jim.wunderlich 1.34 # make new build
174 # make new world
|
175 jim.wunderlich 1.32
|
176 jim.wunderlich 1.34 new: clean repositoryclean
|
177 jim.wunderlich 1.32
178 #-----------------------
|
179 jim.wunderlich 1.34 # world targets: builds everything and dependent on which target may do testing
|
180 jim.wunderlich 1.32 #
181 # Typically used after a fresh checkout from CVS
|
182 jim.wunderlich 1.34
183 world: build s_unittests servertests
184
185
186 ############################
187 #
188 # rules defined in TestMakefile that are repeated here for convenience
|
189 jim.wunderlich 1.32 #
|
190 jim.wunderlich 1.34 shortsleep: FORCE
191 @$(MAKE) -f TestMakefile shortsleep
192
193 servertests: FORCE
194 @ $(MAKE) -f TestMakefile servertests
195
|
196 jim.wunderlich 1.35 perftests: FORCE
197 @ $(MAKE) -f TestMakefile perftests
198
|
199 jim.wunderlich 1.34 s_unittests: FORCE
200 @ $(MAKE) -f TestMakefile -s unittests
201
202 unittests: FORCE
203 @ $(MAKE) -f TestMakefile unittests
204
205 standardtests: FORCE
206 @ $(MAKE) -f TestMakefile standardtests
207
208 alltests: FORCE
209 @ $(MAKE) -f TestMakefile alltests
210
211 testusage: FORCE
212 @ $(MAKE) -f TestMakefile usage
|
213 jim.wunderlich 1.32
|
214 jim.wunderlich 1.34 testusage2: FORCE
215 @ $(MAKE) -f TestMakefile usage2
|
216 mike 1.1
|
217 j.alex 1.37 stresstests:
218 @$(ECHO) "Running OpenPegasus StressTests"
219 @$(MAKE) -f TestMakefile stresstests
220 @$(ECHO) "+++++ OpenPegasus StressTests complete"
|
221 jim.wunderlich 1.35
|
222 jim.wunderlich 1.34 ##########################################################################
223 #
224 # This section defines functional rules
225 #
|
226 jim.wunderlich 1.32 #---------------------
227 # buildmu target: build mu the make utility that among other things
228 # includes depend
229 buildmu: FORCE
230 $(MKDIRHIER) $(BIN_DIR)
231 $(MAKE) --directory=$(PEGASUS_ROOT)/src/utils/mu -f Makefile
232
233 #----------------------
234 # setupdevserver and cleandevserver are used to setup and clear the
235 # server configuration files needed to run the server in a development
236 # environment.
237 #
238 setupdevserver: FORCE
239 $(MAKE) --directory=$(PEGASUS_ROOT)/src/Server -f Makefile install_run
240 @$(ECHO) "PEGASUS Development Server Runtime Environment configured "
241
242 cleandevserver: FORCE
243 $(MAKE) --directory=$(PEGASUS_ROOT)/src/Server -f Makefile install_run_clean
|
244 karl 1.6
|
245 jim.wunderlich 1.35 clobber: FORCE
246 - $(RMDIRHIER) $(PEGASUS_HOME)/bin
247 - $(RMDIRHIER) $(PEGASUS_HOME)/lib
248 - $(RMDIRHIER) $(PEGASUS_HOME)/obj
249
|
250 jim.wunderlich 1.34
251 #---------------------
|
252 karl 1.39 # The repository Target removes and rebuilds the base repository. It
253 # does not remove all possible namespaces. See
254 # Schemas/Pegasus/Makefile for details. The repository clean has the
255 # same limitation
|
256 mike 1.4
|
257 kumpf 1.25 # Note: Arguments must be quoted to preserve upper case characters in VMS.
|
258 kumpf 1.18 repository: FORCE
|
259 kumpf 1.25 @ $(MAKE) "-SC" Schemas/Pegasus repository
|
260 mike 1.9
|
261 jim.wunderlich 1.29 repositoryclean: FORCE
262 @ $(RMREPOSITORY) $(REPOSITORY_ROOT)
263
|
264 kumpf 1.18 repositoryServer: FORCE
|
265 kumpf 1.25 @ $(MAKE) "-SC" Schemas/Pegasus repositoryServer
|
266 kumpf 1.17
|
267 kumpf 1.18 testrepository: FORCE
|
268 kumpf 1.25 @ $(MAKE) "-SC" src/Providers/sample/Load repository
269 @ $(MAKE) "-SC" test/wetest repository
270 @ $(MAKE) "-SC" src/Clients/benchmarkTest/Load repository
|
271 chuck 1.26 @ $(MAKE) "-SC" src/Pegasus/CQL/CQLCLI repository
|
272 chuck 1.27 @ $(MAKE) "-SC" src/Pegasus/Query/QueryExpression/tests repository
|
273 kumpf 1.28 @ $(MAKE) "-SC" src/Providers/TestProviders/Load repository
|
274 karl 1.44 ifeq ($(PEGASUS_ENABLE_CQL),true)
|
275 a.arora 1.30 @ $(MAKE) "-SC" src/Pegasus/ControlProviders/QueryCapabilitiesProvider/tests repository
|
276 kumpf 1.43 endif
|
277 marek 1.38 ifeq ($(PEGASUS_ENABLE_JMPI_PROVIDER_MANAGER), true)
278 @ $(MAKE) "-SC" src/Pegasus/ProviderManager2/JMPI/org/pegasus/jmpi/tests repository
279 endif
|
280 w.otsuka 1.40 @ $(MAKE) --directory=$(PEGASUS_ROOT)/src/Clients/cimsub/tests/testscript \
281 -f Makefile repository
|
282 kumpf 1.17
|
283 kumpf 1.18 testrepositoryServer: FORCE
|
284 kumpf 1.25 @ $(MAKE) "-SC" src/Providers/sample/Load repositoryServer
285 @ $(MAKE) "-SC" test/wetest repositoryServer
286 @ $(MAKE) "-SC" src/Clients/benchmarkTest/Load repositoryServer
|
287 chuck 1.26 @ $(MAKE) "-SC" src/Pegasus/CQL/CQLCLI repositoryServer
|
288 chuck 1.27 @ $(MAKE) "-SC" src/Pegasus/Query/QueryExpression/tests repositoryServer
|
289 kumpf 1.28 @ $(MAKE) "-SC" src/Providers/TestProviders/Load repositoryServer
|
290 karl 1.44 ifeq ($(PEGASUS_ENABLE_CQL),true)
|
291 a.arora 1.30 @ $(MAKE) "-SC" src/Pegasus/ControlProviders/QueryCapabilitiesProvider/tests repositoryServer
|
292 kumpf 1.43 endif
|
293 marek 1.38 ifeq ($(PEGASUS_ENABLE_JMPI_PROVIDER_MANAGER), true)
294 @ $(MAKE) "-SC" src/Pegasus/ProviderManager2/JMPI/org/pegasus/jmpi/tests repositoryServer
295 endif
|
296 w.otsuka 1.40 @ $(MAKE) --directory=$(PEGASUS_ROOT)/src/Clients/cimsub/tests/testscript \
297 -f Makefile repositoryServer
|
298 kumpf 1.16
|
299 kumpf 1.18 removetestrepository: FORCE
|
300 kumpf 1.25 @ $(MAKE) "-SC" src/Providers/sample/Load removerepository
301 @ $(MAKE) "-SC" test/wetest removerepository
302 @ $(MAKE) "-SC" src/Clients/benchmarkTest/Load removerepository
|
303 kumpf 1.28 @ $(MAKE) "-SC" src/Providers/TestProviders/Load removerepository
|
304 w.otsuka 1.40 @ $(MAKE) "-SC" src/Clients/cimsub/tests/testscript removerepository
|
305 karl 1.15
|
306 konrad.r 1.24 config:
307 @ $(ROOT)/SetConfig_EnvVar
308
|
309 humberto 1.21 rootbundle:
310 $(MAKE) --directory=$(PEGASUS_ROOT)/src/utils/cnv2rootbundle -f Makefile
|